| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* Functions internal to the PCI core code */ | 
|  | 2 |  | 
| Hidetoshi Seto | 38cc130 | 2006-12-18 10:30:00 +0900 | [diff] [blame] | 3 | extern int __must_check __pci_reenable_device(struct pci_dev *); | 
| Kay Sievers | 312c004 | 2005-11-16 09:00:00 +0100 | [diff] [blame] | 4 | extern int pci_uevent(struct device *dev, char **envp, int num_envp, | 
|  | 5 | char *buffer, int buffer_size); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 6 | extern int pci_create_sysfs_dev_files(struct pci_dev *pdev); | 
|  | 7 | extern void pci_remove_sysfs_dev_files(struct pci_dev *pdev); | 
|  | 8 | extern void pci_cleanup_rom(struct pci_dev *dev); | 
|  | 9 | extern int pci_bus_alloc_resource(struct pci_bus *bus, struct resource *res, | 
| Greg Kroah-Hartman | e31dd6e | 2006-06-12 17:06:02 -0700 | [diff] [blame] | 10 | resource_size_t size, resource_size_t align, | 
|  | 11 | resource_size_t min, unsigned int type_mask, | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 12 | void (*alignf)(void *, struct resource *, | 
| Greg Kroah-Hartman | e31dd6e | 2006-06-12 17:06:02 -0700 | [diff] [blame] | 13 | resource_size_t, resource_size_t), | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 14 | void *alignf_data); | 
| David Shaohua Li | 0f64474 | 2005-03-19 00:15:48 -0500 | [diff] [blame] | 15 | /* Firmware callbacks */ | 
|  | 16 | extern int (*platform_pci_choose_state)(struct pci_dev *dev, pm_message_t state); | 
| David Shaohua Li | b913100 | 2005-03-19 00:16:18 -0500 | [diff] [blame] | 17 | extern int (*platform_pci_set_power_state)(struct pci_dev *dev, pci_power_t state); | 
| David Shaohua Li | 0f64474 | 2005-03-19 00:15:48 -0500 | [diff] [blame] | 18 |  | 
| Brian King | e04b0ea | 2005-09-27 01:21:55 -0700 | [diff] [blame] | 19 | extern int pci_user_read_config_byte(struct pci_dev *dev, int where, u8 *val); | 
|  | 20 | extern int pci_user_read_config_word(struct pci_dev *dev, int where, u16 *val); | 
|  | 21 | extern int pci_user_read_config_dword(struct pci_dev *dev, int where, u32 *val); | 
|  | 22 | extern int pci_user_write_config_byte(struct pci_dev *dev, int where, u8 val); | 
|  | 23 | extern int pci_user_write_config_word(struct pci_dev *dev, int where, u16 val); | 
|  | 24 | extern int pci_user_write_config_dword(struct pci_dev *dev, int where, u32 val); | 
|  | 25 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 26 | /* PCI /proc functions */ | 
|  | 27 | #ifdef CONFIG_PROC_FS | 
|  | 28 | extern int pci_proc_attach_device(struct pci_dev *dev); | 
|  | 29 | extern int pci_proc_detach_device(struct pci_dev *dev); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 30 | extern int pci_proc_detach_bus(struct pci_bus *bus); | 
|  | 31 | #else | 
|  | 32 | static inline int pci_proc_attach_device(struct pci_dev *dev) { return 0; } | 
|  | 33 | static inline int pci_proc_detach_device(struct pci_dev *dev) { return 0; } | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 34 | static inline int pci_proc_detach_bus(struct pci_bus *bus) { return 0; } | 
|  | 35 | #endif | 
|  | 36 |  | 
|  | 37 | /* Functions for PCI Hotplug drivers to use */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 38 | extern unsigned int pci_do_scan_bus(struct pci_bus *bus); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 39 | extern int pci_bus_find_capability (struct pci_bus *bus, unsigned int devfn, int cap); | 
|  | 40 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 41 | extern void pci_remove_legacy_files(struct pci_bus *bus); | 
|  | 42 |  | 
|  | 43 | /* Lock for read/write access to pci device and bus lists */ | 
| Zhang Yanmin | d71374d | 2006-06-02 12:35:43 +0800 | [diff] [blame] | 44 | extern struct rw_semaphore pci_bus_sem; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 45 |  | 
| Kristen Carlson Accardi | ffadcc2 | 2006-07-12 08:59:00 -0700 | [diff] [blame] | 46 | extern unsigned int pci_pm_d3_delay; | 
| Michael Ellerman | 88187df | 2007-01-25 19:34:07 +1100 | [diff] [blame] | 47 |  | 
| Andrew Morton | 4b47b0e | 2005-08-16 15:16:05 -0700 | [diff] [blame] | 48 | #ifdef CONFIG_PCI_MSI | 
| Matthew Wilcox | 309e57d | 2006-03-05 22:33:34 -0700 | [diff] [blame] | 49 | void pci_no_msi(void); | 
| Andrew Morton | 4b47b0e | 2005-08-16 15:16:05 -0700 | [diff] [blame] | 50 | #else | 
| Matthew Wilcox | 309e57d | 2006-03-05 22:33:34 -0700 | [diff] [blame] | 51 | static inline void pci_no_msi(void) { } | 
| Andrew Morton | 4b47b0e | 2005-08-16 15:16:05 -0700 | [diff] [blame] | 52 | #endif | 
| Michael Ellerman | 8fed4b6 | 2007-01-25 19:34:08 +1100 | [diff] [blame] | 53 |  | 
| Shaohua Li | 41017f0 | 2006-02-08 17:11:38 +0800 | [diff] [blame] | 54 | #if defined(CONFIG_PCI_MSI) && defined(CONFIG_PM) | 
| Shaohua Li | 41017f0 | 2006-02-08 17:11:38 +0800 | [diff] [blame] | 55 | void pci_restore_msi_state(struct pci_dev *dev); | 
| Shaohua Li | 41017f0 | 2006-02-08 17:11:38 +0800 | [diff] [blame] | 56 | #else | 
| Shaohua Li | 41017f0 | 2006-02-08 17:11:38 +0800 | [diff] [blame] | 57 | static inline void pci_restore_msi_state(struct pci_dev *dev) {} | 
| Shaohua Li | 41017f0 | 2006-02-08 17:11:38 +0800 | [diff] [blame] | 58 | #endif | 
| Michael Ellerman | 8fed4b6 | 2007-01-25 19:34:08 +1100 | [diff] [blame] | 59 |  | 
| Kristen Carlson Accardi | ffadcc2 | 2006-07-12 08:59:00 -0700 | [diff] [blame] | 60 | static inline int pci_no_d1d2(struct pci_dev *dev) | 
|  | 61 | { | 
|  | 62 | unsigned int parent_dstates = 0; | 
| Andrew Morton | 4b47b0e | 2005-08-16 15:16:05 -0700 | [diff] [blame] | 63 |  | 
| Kristen Carlson Accardi | ffadcc2 | 2006-07-12 08:59:00 -0700 | [diff] [blame] | 64 | if (dev->bus->self) | 
|  | 65 | parent_dstates = dev->bus->self->no_d1d2; | 
|  | 66 | return (dev->no_d1d2 || parent_dstates); | 
|  | 67 |  | 
|  | 68 | } | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 69 | extern int pcie_mch_quirk; | 
|  | 70 | extern struct device_attribute pci_dev_attrs[]; | 
|  | 71 | extern struct class_device_attribute class_device_attr_cpuaffinity; | 
|  | 72 |  | 
|  | 73 | /** | 
|  | 74 | * pci_match_one_device - Tell if a PCI device structure has a matching | 
|  | 75 | *                        PCI device id structure | 
|  | 76 | * @id: single PCI device id structure to match | 
|  | 77 | * @dev: the PCI device structure to match against | 
|  | 78 | * | 
|  | 79 | * Returns the matching pci_device_id structure or %NULL if there is no match. | 
|  | 80 | */ | 
|  | 81 | static inline const struct pci_device_id * | 
|  | 82 | pci_match_one_device(const struct pci_device_id *id, const struct pci_dev *dev) | 
|  | 83 | { | 
|  | 84 | if ((id->vendor == PCI_ANY_ID || id->vendor == dev->vendor) && | 
|  | 85 | (id->device == PCI_ANY_ID || id->device == dev->device) && | 
|  | 86 | (id->subvendor == PCI_ANY_ID || id->subvendor == dev->subsystem_vendor) && | 
|  | 87 | (id->subdevice == PCI_ANY_ID || id->subdevice == dev->subsystem_device) && | 
|  | 88 | !((id->class ^ dev->class) & id->class_mask)) | 
|  | 89 | return id; | 
|  | 90 | return NULL; | 
|  | 91 | } | 
|  | 92 |  |