提交 3e1b1600 编写于 作者: A Andrew Patterson 提交者: Jesse Barnes

ACPI/PCI: PCIe ASPM _OSC support capabilities called when root bridge added

The _OSC capabilities OSC_ACTIVE_STATE_PWR_SUPPORT and
OSC_CLOCK_PWR_CAPABILITY_SUPPORT are set when the root bridge is added
with pci_acpi_osc_support(), so we no longer need to do it in the ASPM
driver.  Also add the function pcie_aspm_enabled, which returns true if
pcie_aspm=off is not on the kernel command-line.
Signed-off-by: NAndrew Patterson <andrew.patterson@hp.com>
Signed-off-by: NJesse Barnes <jbarnes@virtuousgeek.org>
上级 0ef5f8f6
...@@ -347,6 +347,9 @@ static int __devinit acpi_pci_root_add(struct acpi_device *device) ...@@ -347,6 +347,9 @@ static int __devinit acpi_pci_root_add(struct acpi_device *device)
/* Indicate support for various _OSC capabilities. */ /* Indicate support for various _OSC capabilities. */
if (pci_ext_cfg_avail(root->bus->self)) if (pci_ext_cfg_avail(root->bus->self))
flags |= OSC_EXT_PCI_CONFIG_SUPPORT; flags |= OSC_EXT_PCI_CONFIG_SUPPORT;
if (pcie_aspm_enabled())
flags |= OSC_ACTIVE_STATE_PWR_SUPPORT |
OSC_CLOCK_PWR_CAPABILITY_SUPPORT;
if (flags != base_flags) if (flags != base_flags)
pci_acpi_osc_support(device->handle, flags); pci_acpi_osc_support(device->handle, flags);
......
...@@ -857,24 +857,15 @@ void pcie_no_aspm(void) ...@@ -857,24 +857,15 @@ void pcie_no_aspm(void)
aspm_disabled = 1; aspm_disabled = 1;
} }
#ifdef CONFIG_ACPI /**
#include <acpi/acpi_bus.h> * pcie_aspm_enabled - is PCIe ASPM enabled?
#include <linux/pci-acpi.h> *
static void pcie_aspm_platform_init(void) * Returns true if ASPM has not been disabled by the command-line option
{ * pcie_aspm=off.
pcie_osc_support_set(OSC_ACTIVE_STATE_PWR_SUPPORT| **/
OSC_CLOCK_PWR_CAPABILITY_SUPPORT); int pcie_aspm_enabled(void)
}
#else
static inline void pcie_aspm_platform_init(void) { }
#endif
static int __init pcie_aspm_init(void)
{ {
if (aspm_disabled) return !aspm_disabled;
return 0;
pcie_aspm_platform_init();
return 0;
} }
EXPORT_SYMBOL(pcie_aspm_enabled);
fs_initcall(pcie_aspm_init);
...@@ -791,6 +791,15 @@ extern void msi_remove_pci_irq_vectors(struct pci_dev *dev); ...@@ -791,6 +791,15 @@ extern void msi_remove_pci_irq_vectors(struct pci_dev *dev);
extern void pci_restore_msi_state(struct pci_dev *dev); extern void pci_restore_msi_state(struct pci_dev *dev);
#endif #endif
#ifndef CONFIG_PCIEASPM
static inline int pcie_aspm_enabled(void)
{
return 0;
}
#else
extern int pcie_aspm_enabled(void);
#endif
#ifdef CONFIG_HT_IRQ #ifdef CONFIG_HT_IRQ
/* The functions a driver should call */ /* The functions a driver should call */
int ht_create_irq(struct pci_dev *dev, int idx); int ht_create_irq(struct pci_dev *dev, int idx);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册