Skip to content

Commit 92597f9

Browse files
rafaeljwbjorn-helgaas
authored andcommitted
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 14858dc ("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 <[email protected]> Signed-off-by: Rafael J. Wysocki <[email protected]> Signed-off-by: Bjorn Helgaas <[email protected]> Cc: [email protected] # v5.15+
1 parent 3123109 commit 92597f9

File tree

1 file changed

+10
-0
lines changed

1 file changed

+10
-0
lines changed

drivers/pci/pci.c

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2920,6 +2920,16 @@ static const struct dmi_system_id bridge_d3_blacklist[] = {
29202920
DMI_MATCH(DMI_BOARD_VENDOR, "Gigabyte Technology Co., Ltd."),
29212921
DMI_MATCH(DMI_BOARD_NAME, "X299 DESIGNARE EX-CF"),
29222922
},
2923+
/*
2924+
* Downstream device is not accessible after putting a root port
2925+
* into D3cold and back into D0 on Elo i2.
2926+
*/
2927+
.ident = "Elo i2",
2928+
.matches = {
2929+
DMI_MATCH(DMI_SYS_VENDOR, "Elo Touch Solutions"),
2930+
DMI_MATCH(DMI_PRODUCT_NAME, "Elo i2"),
2931+
DMI_MATCH(DMI_PRODUCT_VERSION, "RevB"),
2932+
},
29232933
},
29242934
#endif
29252935
{ }

0 commit comments

Comments
 (0)