2005-04-17 05:20:36 +07:00
|
|
|
/*
|
|
|
|
* File pci-acpi.h
|
|
|
|
*
|
|
|
|
* Copyright (C) 2004 Intel
|
|
|
|
* Copyright (C) Tom Long Nguyen (tom.l.nguyen@intel.com)
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _PCI_ACPI_H_
|
|
|
|
#define _PCI_ACPI_H_
|
|
|
|
|
2008-11-11 05:30:40 +07:00
|
|
|
#include <linux/acpi.h>
|
|
|
|
|
2005-04-17 05:20:36 +07:00
|
|
|
#ifdef CONFIG_ACPI
|
2010-02-18 05:44:09 +07:00
|
|
|
extern acpi_status pci_acpi_add_bus_pm_notifier(struct acpi_device *dev,
|
|
|
|
struct pci_bus *pci_bus);
|
|
|
|
extern acpi_status pci_acpi_remove_bus_pm_notifier(struct acpi_device *dev);
|
|
|
|
extern acpi_status pci_acpi_add_pm_notifier(struct acpi_device *dev,
|
|
|
|
struct pci_dev *pci_dev);
|
|
|
|
extern acpi_status pci_acpi_remove_pm_notifier(struct acpi_device *dev);
|
|
|
|
|
2008-08-19 01:22:54 +07:00
|
|
|
static inline acpi_handle acpi_find_root_bridge_handle(struct pci_dev *pdev)
|
|
|
|
{
|
2009-02-17 12:12:36 +07:00
|
|
|
struct pci_bus *pbus = pdev->bus;
|
|
|
|
/* Find a PCI root bus */
|
2009-05-26 14:05:33 +07:00
|
|
|
while (!pci_is_root_bus(pbus))
|
2009-02-17 12:12:36 +07:00
|
|
|
pbus = pbus->parent;
|
|
|
|
return acpi_get_pci_rootbridge_handle(pci_domain_nr(pbus),
|
|
|
|
pbus->number);
|
2008-08-19 01:22:54 +07:00
|
|
|
}
|
2008-12-17 10:09:12 +07:00
|
|
|
|
|
|
|
static inline acpi_handle acpi_pci_get_bridge_handle(struct pci_bus *pbus)
|
|
|
|
{
|
2009-05-26 14:05:06 +07:00
|
|
|
if (!pci_is_root_bus(pbus))
|
2009-02-17 12:11:56 +07:00
|
|
|
return DEVICE_ACPI_HANDLE(&(pbus->self->dev));
|
|
|
|
return acpi_get_pci_rootbridge_handle(pci_domain_nr(pbus),
|
|
|
|
pbus->number);
|
2008-12-17 10:09:12 +07:00
|
|
|
}
|
2005-04-17 05:20:36 +07:00
|
|
|
#endif
|
|
|
|
|
2011-01-07 06:55:09 +07:00
|
|
|
#ifdef CONFIG_ACPI_APEI
|
|
|
|
extern bool aer_acpi_firmware_first(void);
|
|
|
|
#else
|
|
|
|
static inline bool aer_acpi_firmware_first(void) { return false; }
|
|
|
|
#endif
|
|
|
|
|
2005-04-17 05:20:36 +07:00
|
|
|
#endif /* _PCI_ACPI_H_ */
|