pci.h 3.6 KB

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