]> 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)
commitdb6ed3463b975d17a1fe6c9982fcd5ac1cd032e2
treef4e99f7826a6c5be17408ad53af1f0d9e386947e
parent6d94017b7b59bab528be97be158d0d602982e3a6
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 67f8e78c0297 ("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