conf_space.h 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. /*
  2. * PCI Backend - Common data structures for overriding the configuration space
  3. *
  4. * Author: Ryan Wilson <hap9@epoch.ncsc.mil>
  5. */
  6. #ifndef __XEN_PCIBACK_CONF_SPACE_H__
  7. #define __XEN_PCIBACK_CONF_SPACE_H__
  8. #include <linux/list.h>
  9. #include <linux/err.h>
  10. /* conf_field_init can return an errno in a ptr with ERR_PTR() */
  11. typedef void *(*conf_field_init) (struct pci_dev *dev, int offset);
  12. typedef void (*conf_field_reset) (struct pci_dev *dev, int offset, void *data);
  13. typedef void (*conf_field_free) (struct pci_dev *dev, int offset, void *data);
  14. typedef int (*conf_dword_write) (struct pci_dev *dev, int offset, u32 value,
  15. void *data);
  16. typedef int (*conf_word_write) (struct pci_dev *dev, int offset, u16 value,
  17. void *data);
  18. typedef int (*conf_byte_write) (struct pci_dev *dev, int offset, u8 value,
  19. void *data);
  20. typedef int (*conf_dword_read) (struct pci_dev *dev, int offset, u32 *value,
  21. void *data);
  22. typedef int (*conf_word_read) (struct pci_dev *dev, int offset, u16 *value,
  23. void *data);
  24. typedef int (*conf_byte_read) (struct pci_dev *dev, int offset, u8 *value,
  25. void *data);
  26. /* These are the fields within the configuration space which we
  27. * are interested in intercepting reads/writes to and changing their
  28. * values.
  29. */
  30. struct config_field {
  31. unsigned int offset;
  32. unsigned int size;
  33. unsigned int mask;
  34. conf_field_init init;
  35. conf_field_reset reset;
  36. conf_field_free release;
  37. void (*clean) (struct config_field *field);
  38. union {
  39. struct {
  40. conf_dword_write write;
  41. conf_dword_read read;
  42. } dw;
  43. struct {
  44. conf_word_write write;
  45. conf_word_read read;
  46. } w;
  47. struct {
  48. conf_byte_write write;
  49. conf_byte_read read;
  50. } b;
  51. } u;
  52. struct list_head list;
  53. };
  54. struct config_field_entry {
  55. struct list_head list;
  56. const struct config_field *field;
  57. unsigned int base_offset;
  58. void *data;
  59. };
  60. #define OFFSET(cfg_entry) ((cfg_entry)->base_offset+(cfg_entry)->field->offset)
  61. /* Add fields to a device - the add_fields macro expects to get a pointer to
  62. * the first entry in an array (of which the ending is marked by size==0)
  63. */
  64. int xen_pcibk_config_add_field_offset(struct pci_dev *dev,
  65. const struct config_field *field,
  66. unsigned int offset);
  67. static inline int xen_pcibk_config_add_field(struct pci_dev *dev,
  68. const struct config_field *field)
  69. {
  70. return xen_pcibk_config_add_field_offset(dev, field, 0);
  71. }
  72. static inline int xen_pcibk_config_add_fields(struct pci_dev *dev,
  73. const struct config_field *field)
  74. {
  75. int i, err = 0;
  76. for (i = 0; field[i].size != 0; i++) {
  77. err = xen_pcibk_config_add_field(dev, &field[i]);
  78. if (err)
  79. break;
  80. }
  81. return err;
  82. }
  83. static inline int xen_pcibk_config_add_fields_offset(struct pci_dev *dev,
  84. const struct config_field *field,
  85. unsigned int offset)
  86. {
  87. int i, err = 0;
  88. for (i = 0; field[i].size != 0; i++) {
  89. err = xen_pcibk_config_add_field_offset(dev, &field[i], offset);
  90. if (err)
  91. break;
  92. }
  93. return err;
  94. }
  95. /* Read/Write the real configuration space */
  96. int xen_pcibk_read_config_byte(struct pci_dev *dev, int offset, u8 *value,
  97. void *data);
  98. int xen_pcibk_read_config_word(struct pci_dev *dev, int offset, u16 *value,
  99. void *data);
  100. int xen_pcibk_read_config_dword(struct pci_dev *dev, int offset, u32 *value,
  101. void *data);
  102. int xen_pcibk_write_config_byte(struct pci_dev *dev, int offset, u8 value,
  103. void *data);
  104. int xen_pcibk_write_config_word(struct pci_dev *dev, int offset, u16 value,
  105. void *data);
  106. int xen_pcibk_write_config_dword(struct pci_dev *dev, int offset, u32 value,
  107. void *data);
  108. int xen_pcibk_config_capability_init(void);
  109. int xen_pcibk_config_header_add_fields(struct pci_dev *dev);
  110. int xen_pcibk_config_capability_add_fields(struct pci_dev *dev);
  111. #endif /* __XEN_PCIBACK_CONF_SPACE_H__ */