Skip to content

Commit df5192d

Browse files
committed
PCI/ASPM: Enable only L0s and L1 for devicetree platforms
f3ac2ff ("PCI/ASPM: Enable all ClockPM and ASPM states for devicetree platforms") enabled Clock Power Management and L1 PM Substates, but those features depend on CLKREQ# and possibly other device-specific configuration. We don't know whether CLKREQ# is supported, so we shouldn't blindly enable Clock PM and L1 PM Substates. Enable only ASPM L0s and L1, and only when both ends of the link advertise support for them. Fixes: f3ac2ff ("PCI/ASPM: Enable all ClockPM and ASPM states for devicetree platforms") Reported-by: Christian Zigotzky <chzigotzky@xenosoft.de> Link: https://lore.kernel.org/r/db5c95a1-cf3e-46f9-8045-a1b04908051a@xenosoft.de/ Reported-by: FUKAUMI Naoki <naoki@radxa.com> Closes: https://lore.kernel.org/r/22594781424C5C98+22cb5d61-19b1-4353-9818-3bb2b311da0b@radxa.com/ Reported-by: Herve Codina <herve.codina@bootlin.com> Link: https://lore.kernel.org/r/20251015101304.3ec03e6b@bootlin.com/ Reported-by: Diederik de Haas <diederik@cknow-tech.com> Closes: https://lore.kernel.org/r/DDJXHRIRGTW9.GYC2ULZ5WQAL@cknow-tech.com/ Signed-off-by: Bjorn Helgaas <bhelgaas@google.com> Tested-by: FUKAUMI Naoki <naoki@radxa.com> Tested-by: Diederik de Haas <diederik@cknow-tech.com> Acked-by: Dragan Simic <dsimic@manjaro.org> Link: https://patch.msgid.link/20251023180645.1304701-1-helgaas@kernel.org
1 parent f294a5f commit df5192d

File tree

1 file changed

+9
-25
lines changed

1 file changed

+9
-25
lines changed

drivers/pci/pcie/aspm.c

Lines changed: 9 additions & 25 deletions
Original file line numberDiff line numberDiff line change
@@ -243,8 +243,7 @@ struct pcie_link_state {
243243
/* Clock PM state */
244244
u32 clkpm_capable:1; /* Clock PM capable? */
245245
u32 clkpm_enabled:1; /* Current Clock PM state */
246-
u32 clkpm_default:1; /* Default Clock PM state by BIOS or
247-
override */
246+
u32 clkpm_default:1; /* Default Clock PM state by BIOS */
248247
u32 clkpm_disable:1; /* Clock PM disabled */
249248
};
250249

@@ -376,18 +375,6 @@ static void pcie_set_clkpm(struct pcie_link_state *link, int enable)
376375
pcie_set_clkpm_nocheck(link, enable);
377376
}
378377

379-
static void pcie_clkpm_override_default_link_state(struct pcie_link_state *link,
380-
int enabled)
381-
{
382-
struct pci_dev *pdev = link->downstream;
383-
384-
/* For devicetree platforms, enable ClockPM by default */
385-
if (of_have_populated_dt() && !enabled) {
386-
link->clkpm_default = 1;
387-
pci_info(pdev, "ASPM: DT platform, enabling ClockPM\n");
388-
}
389-
}
390-
391378
static void pcie_clkpm_cap_init(struct pcie_link_state *link, int blacklist)
392379
{
393380
int capable = 1, enabled = 1;
@@ -410,7 +397,6 @@ static void pcie_clkpm_cap_init(struct pcie_link_state *link, int blacklist)
410397
}
411398
link->clkpm_enabled = enabled;
412399
link->clkpm_default = enabled;
413-
pcie_clkpm_override_default_link_state(link, enabled);
414400
link->clkpm_capable = capable;
415401
link->clkpm_disable = blacklist ? 1 : 0;
416402
}
@@ -811,19 +797,17 @@ static void pcie_aspm_override_default_link_state(struct pcie_link_state *link)
811797
struct pci_dev *pdev = link->downstream;
812798
u32 override;
813799

814-
/* For devicetree platforms, enable all ASPM states by default */
800+
/* For devicetree platforms, enable L0s and L1 by default */
815801
if (of_have_populated_dt()) {
816-
link->aspm_default = PCIE_LINK_STATE_ASPM_ALL;
802+
if (link->aspm_support & PCIE_LINK_STATE_L0S)
803+
link->aspm_default |= PCIE_LINK_STATE_L0S;
804+
if (link->aspm_support & PCIE_LINK_STATE_L1)
805+
link->aspm_default |= PCIE_LINK_STATE_L1;
817806
override = link->aspm_default & ~link->aspm_enabled;
818807
if (override)
819-
pci_info(pdev, "ASPM: DT platform, enabling%s%s%s%s%s%s%s\n",
820-
FLAG(override, L0S_UP, " L0s-up"),
821-
FLAG(override, L0S_DW, " L0s-dw"),
822-
FLAG(override, L1, " L1"),
823-
FLAG(override, L1_1, " ASPM-L1.1"),
824-
FLAG(override, L1_2, " ASPM-L1.2"),
825-
FLAG(override, L1_1_PCIPM, " PCI-PM-L1.1"),
826-
FLAG(override, L1_2_PCIPM, " PCI-PM-L1.2"));
808+
pci_info(pdev, "ASPM: default states%s%s\n",
809+
FLAG(override, L0S, " L0s"),
810+
FLAG(override, L1, " L1"));
827811
}
828812
}
829813

0 commit comments

Comments
 (0)