]> git.baikalelectronics.ru Git - kernel.git/commit
PCI/PM: Avoid putting Elo i2 PCIe Ports in D3cold
authorRafael J. Wysocki <rafael.j.wysocki@intel.com>
Thu, 31 Mar 2022 17:38:51 +0000 (19:38 +0200)
committerBjorn Helgaas <bhelgaas@google.com>
Mon, 11 Apr 2022 16:18:11 +0000 (11:18 -0500)
commitf3a1035cca6a43710a4de45c7b199612a63bac3f
treef4e99f7826a6c5be17408ad53af1f0d9e386947e
parentdbb008736a8c113ef1e12b4e4b4351fac2a15ede
PCI/PM: Avoid putting Elo i2 PCIe Ports in D3cold

If a Root Port on Elo i2 is put into D3cold and then back into D0, the
downstream device becomes permanently inaccessible, so add a bridge D3 DMI
quirk for that system.

This was exposed by 5b02fa97e935 ("PCI: Use pci_update_current_state() in
pci_enable_device_flags()"), but before that commit the Root Port in
question had never been put into D3cold for real due to a mismatch between
its power state retrieved from the PCI_PM_CTRL register (which was
accessible even though the platform firmware indicated that the port was in
D3cold) and the state of an ACPI power resource involved in its power
management.

BugLink: https://bugzilla.kernel.org/show_bug.cgi?id=215715
Link: https://lore.kernel.org/r/11980172.O9o76ZdvQC@kreacher
Reported-by: Stefan Gottwald <gottwald@igel.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Cc: stable@vger.kernel.org # v5.15+
drivers/pci/pci.c