blob: 1704479772787b28950c9768a9e73c35c88dcd9a [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * File pci-acpi.h
3 *
4 * Copyright (C) 2004 Intel
5 * Copyright (C) Tom Long Nguyen (tom.l.nguyen@intel.com)
6 */
7
8#ifndef _PCI_ACPI_H_
9#define _PCI_ACPI_H_
10
Andrew Patterson8b620912008-11-10 15:30:40 -070011#include <linux/acpi.h>
12
Linus Torvalds1da177e2005-04-16 15:20:36 -070013#ifdef CONFIG_ACPI
Rafael J. Wysockib67ea762010-02-17 23:44:09 +010014extern acpi_status pci_acpi_add_bus_pm_notifier(struct acpi_device *dev,
15 struct pci_bus *pci_bus);
16extern acpi_status pci_acpi_remove_bus_pm_notifier(struct acpi_device *dev);
17extern acpi_status pci_acpi_add_pm_notifier(struct acpi_device *dev,
18 struct pci_dev *pci_dev);
19extern acpi_status pci_acpi_remove_pm_notifier(struct acpi_device *dev);
Jiang Liuf4b57a32012-06-22 14:55:16 +080020extern phys_addr_t acpi_pci_root_get_mcfg_addr(acpi_handle handle);
Rafael J. Wysockib67ea762010-02-17 23:44:09 +010021
Jiri Slaby056c58e2008-08-18 20:22:54 +020022static inline acpi_handle acpi_find_root_bridge_handle(struct pci_dev *pdev)
23{
Kenji Kaneshiged18690a2009-02-17 14:12:36 +090024 struct pci_bus *pbus = pdev->bus;
Yinghai Lu059e4ba2012-09-24 14:51:23 -060025
Kenji Kaneshiged18690a2009-02-17 14:12:36 +090026 /* Find a PCI root bus */
Kenji Kaneshigea222b8f2009-05-26 16:05:33 +090027 while (!pci_is_root_bus(pbus))
Kenji Kaneshiged18690a2009-02-17 14:12:36 +090028 pbus = pbus->parent;
Yinghai Lu059e4ba2012-09-24 14:51:23 -060029
30 return DEVICE_ACPI_HANDLE(pbus->bridge);
Jiri Slaby056c58e2008-08-18 20:22:54 +020031}
Kenji Kaneshigee8c331e2008-12-17 12:09:12 +090032
33static inline acpi_handle acpi_pci_get_bridge_handle(struct pci_bus *pbus)
34{
Yinghai Lu059e4ba2012-09-24 14:51:23 -060035 struct device *dev;
36
37 if (pci_is_root_bus(pbus))
38 dev = pbus->bridge;
39 else
40 dev = &pbus->self->dev;
41
42 return DEVICE_ACPI_HANDLE(dev);
Kenji Kaneshigee8c331e2008-12-17 12:09:12 +090043}
Jiang Liu5090d4a2013-04-12 05:44:21 +000044
45void acpi_pci_add_bus(struct pci_bus *bus);
46void acpi_pci_remove_bus(struct pci_bus *bus);
Jiang Liu5c0b04e2013-04-12 05:44:24 +000047
48#ifdef CONFIG_ACPI_PCI_SLOT
49void acpi_pci_slot_init(void);
50void acpi_pci_slot_enumerate(struct pci_bus *bus, acpi_handle handle);
51void acpi_pci_slot_remove(struct pci_bus *bus);
52#else
53static inline void acpi_pci_slot_init(void) { }
54static inline void acpi_pci_slot_enumerate(struct pci_bus *bus,
55 acpi_handle handle) { }
56static inline void acpi_pci_slot_remove(struct pci_bus *bus) { }
57#endif
58
Jiang Liu3b63aaa2013-04-12 05:44:26 +000059#ifdef CONFIG_HOTPLUG_PCI_ACPI
60void acpiphp_init(void);
61void acpiphp_enumerate_slots(struct pci_bus *bus, acpi_handle handle);
62void acpiphp_remove_slots(struct pci_bus *bus);
Yinghai Lu3f327e32013-05-07 11:06:03 -060063void acpiphp_check_host_bridge(acpi_handle handle);
Jiang Liu3b63aaa2013-04-12 05:44:26 +000064#else
65static inline void acpiphp_init(void) { }
66static inline void acpiphp_enumerate_slots(struct pci_bus *bus,
67 acpi_handle handle) { }
68static inline void acpiphp_remove_slots(struct pci_bus *bus) { }
Yinghai Lu3f327e32013-05-07 11:06:03 -060069static inline void acpiphp_check_host_bridge(acpi_handle handle) { }
Jiang Liu3b63aaa2013-04-12 05:44:26 +000070#endif
71
Jiang Liu5090d4a2013-04-12 05:44:21 +000072#else /* CONFIG_ACPI */
73static inline void acpi_pci_add_bus(struct pci_bus *bus) { }
74static inline void acpi_pci_remove_bus(struct pci_bus *bus) { }
75#endif /* CONFIG_ACPI */
Linus Torvalds1da177e2005-04-16 15:20:36 -070076
Rafael J. Wysocki415e12b2011-01-07 00:55:09 +010077#ifdef CONFIG_ACPI_APEI
78extern bool aer_acpi_firmware_first(void);
79#else
80static inline bool aer_acpi_firmware_first(void) { return false; }
81#endif
82
Linus Torvalds1da177e2005-04-16 15:20:36 -070083#endif /* _PCI_ACPI_H_ */