pci.h 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. /* Functions internal to the PCI core code */
  2. extern int pci_uevent(struct device *dev, struct kobj_uevent_env *env);
  3. extern int pci_create_sysfs_dev_files(struct pci_dev *pdev);
  4. extern void pci_remove_sysfs_dev_files(struct pci_dev *pdev);
  5. extern void pci_cleanup_rom(struct pci_dev *dev);
  6. /* Firmware callbacks */
  7. extern pci_power_t (*platform_pci_choose_state)(struct pci_dev *dev,
  8. pm_message_t state);
  9. extern int (*platform_pci_set_power_state)(struct pci_dev *dev,
  10. pci_power_t state);
  11. extern int pci_user_read_config_byte(struct pci_dev *dev, int where, u8 *val);
  12. extern int pci_user_read_config_word(struct pci_dev *dev, int where, u16 *val);
  13. extern int pci_user_read_config_dword(struct pci_dev *dev, int where, u32 *val);
  14. extern int pci_user_write_config_byte(struct pci_dev *dev, int where, u8 val);
  15. extern int pci_user_write_config_word(struct pci_dev *dev, int where, u16 val);
  16. extern int pci_user_write_config_dword(struct pci_dev *dev, int where, u32 val);
  17. struct pci_vpd_ops {
  18. int (*read)(struct pci_dev *dev, int pos, int size, char *buf);
  19. int (*write)(struct pci_dev *dev, int pos, int size, const char *buf);
  20. int (*get_size)(struct pci_dev *dev);
  21. void (*release)(struct pci_dev *dev);
  22. };
  23. struct pci_vpd {
  24. struct pci_vpd_ops *ops;
  25. struct bin_attribute *attr; /* descriptor for sysfs VPD entry */
  26. };
  27. extern int pci_vpd_pci22_init(struct pci_dev *dev);
  28. static inline void pci_vpd_release(struct pci_dev *dev)
  29. {
  30. if (dev->vpd)
  31. dev->vpd->ops->release(dev);
  32. }
  33. /* PCI /proc functions */
  34. #ifdef CONFIG_PROC_FS
  35. extern int pci_proc_attach_device(struct pci_dev *dev);
  36. extern int pci_proc_detach_device(struct pci_dev *dev);
  37. extern int pci_proc_detach_bus(struct pci_bus *bus);
  38. #else
  39. static inline int pci_proc_attach_device(struct pci_dev *dev) { return 0; }
  40. static inline int pci_proc_detach_device(struct pci_dev *dev) { return 0; }
  41. static inline int pci_proc_detach_bus(struct pci_bus *bus) { return 0; }
  42. #endif
  43. /* Functions for PCI Hotplug drivers to use */
  44. extern unsigned int pci_do_scan_bus(struct pci_bus *bus);
  45. extern void pci_remove_legacy_files(struct pci_bus *bus);
  46. /* Lock for read/write access to pci device and bus lists */
  47. extern struct rw_semaphore pci_bus_sem;
  48. extern unsigned int pci_pm_d3_delay;
  49. #ifdef CONFIG_PCI_MSI
  50. void pci_no_msi(void);
  51. extern void pci_msi_init_pci_dev(struct pci_dev *dev);
  52. #else
  53. static inline void pci_no_msi(void) { }
  54. static inline void pci_msi_init_pci_dev(struct pci_dev *dev) { }
  55. #endif
  56. #ifdef CONFIG_PCIEAER
  57. void pci_no_aer(void);
  58. #else
  59. static inline void pci_no_aer(void) { }
  60. #endif
  61. static inline int pci_no_d1d2(struct pci_dev *dev)
  62. {
  63. unsigned int parent_dstates = 0;
  64. if (dev->bus->self)
  65. parent_dstates = dev->bus->self->no_d1d2;
  66. return (dev->no_d1d2 || parent_dstates);
  67. }
  68. extern int pcie_mch_quirk;
  69. extern struct device_attribute pci_dev_attrs[];
  70. extern struct device_attribute dev_attr_cpuaffinity;
  71. /**
  72. * pci_match_one_device - Tell if a PCI device structure has a matching
  73. * PCI device id structure
  74. * @id: single PCI device id structure to match
  75. * @dev: the PCI device structure to match against
  76. *
  77. * Returns the matching pci_device_id structure or %NULL if there is no match.
  78. */
  79. static inline const struct pci_device_id *
  80. pci_match_one_device(const struct pci_device_id *id, const struct pci_dev *dev)
  81. {
  82. if ((id->vendor == PCI_ANY_ID || id->vendor == dev->vendor) &&
  83. (id->device == PCI_ANY_ID || id->device == dev->device) &&
  84. (id->subvendor == PCI_ANY_ID || id->subvendor == dev->subsystem_vendor) &&
  85. (id->subdevice == PCI_ANY_ID || id->subdevice == dev->subsystem_device) &&
  86. !((id->class ^ dev->class) & id->class_mask))
  87. return id;
  88. return NULL;
  89. }
  90. struct pci_dev *pci_find_upstream_pcie_bridge(struct pci_dev *pdev);