conf_space.h 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  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. extern bool xen_pcibk_permissive;
  61. #define OFFSET(cfg_entry) ((cfg_entry)->base_offset+(cfg_entry)->field->offset)
  62. /* Add fields to a device - the add_fields macro expects to get a pointer to
  63. * the first entry in an array (of which the ending is marked by size==0)
  64. */
  65. int xen_pcibk_config_add_field_offset(struct pci_dev *dev,
  66. const struct config_field *field,
  67. unsigned int offset);
  68. static inline int xen_pcibk_config_add_field(struct pci_dev *dev,
  69. const struct config_field *field)
  70. {
  71. return xen_pcibk_config_add_field_offset(dev, field, 0);
  72. }
  73. static inline int xen_pcibk_config_add_fields(struct pci_dev *dev,
  74. const struct config_field *field)
  75. {
  76. int i, err = 0;
  77. for (i = 0; field[i].size != 0; i++) {
  78. err = xen_pcibk_config_add_field(dev, &field[i]);
  79. if (err)
  80. break;
  81. }
  82. return err;
  83. }
  84. static inline int xen_pcibk_config_add_fields_offset(struct pci_dev *dev,
  85. const struct config_field *field,
  86. unsigned int offset)
  87. {
  88. int i, err = 0;
  89. for (i = 0; field[i].size != 0; i++) {
  90. err = xen_pcibk_config_add_field_offset(dev, &field[i], offset);
  91. if (err)
  92. break;
  93. }
  94. return err;
  95. }
  96. /* Read/Write the real configuration space */
  97. int xen_pcibk_read_config_byte(struct pci_dev *dev, int offset, u8 *value,
  98. void *data);
  99. int xen_pcibk_read_config_word(struct pci_dev *dev, int offset, u16 *value,
  100. void *data);
  101. int xen_pcibk_read_config_dword(struct pci_dev *dev, int offset, u32 *value,
  102. void *data);
  103. int xen_pcibk_write_config_byte(struct pci_dev *dev, int offset, u8 value,
  104. void *data);
  105. int xen_pcibk_write_config_word(struct pci_dev *dev, int offset, u16 value,
  106. void *data);
  107. int xen_pcibk_write_config_dword(struct pci_dev *dev, int offset, u32 value,
  108. void *data);
  109. int xen_pcibk_config_capability_init(void);
  110. int xen_pcibk_config_header_add_fields(struct pci_dev *dev);
  111. int xen_pcibk_config_capability_add_fields(struct pci_dev *dev);
  112. #endif /* __XEN_PCIBACK_CONF_SPACE_H__ */