diff options
| author | Bjorn Helgaas <[email protected]> | 2025-11-10 22:22:27 +0000 |
|---|---|---|
| committer | Bjorn Helgaas <[email protected]> | 2025-11-13 00:51:39 +0000 |
| commit | 30579eebba6ae52dc7441479aec9dd8d782256d3 (patch) | |
| tree | b66a011ef3373d19b28db0b894cb5b3265060fe3 /lib/mpi/mpi-scan.c | |
| parent | PCI/ASPM: Add pcie_aspm_remove_cap() to override advertised link states (diff) | |
| download | kernel-30579eebba6ae52dc7441479aec9dd8d782256d3.tar.gz kernel-30579eebba6ae52dc7441479aec9dd8d782256d3.zip | |
PCI/ASPM: Convert quirks to override advertised link states
Existing quirks to disable ASPM L0s and L1 use pci_disable_link_state(),
which disables ASPM states and prevents their use in the future. But since
they are FINAL quirks, they happen after ASPM has already been enabled.
Here's a typical call path:
pci_host_probe
pci_scan_root_bus_bridge
pci_scan_child_bus
pci_scan_slot
pci_scan_single_device
pci_device_add
pci_fixup_device(pci_fixup_header) # HEADER quirks
pcie_aspm_init_link_state
pcie_config_aspm_path
pcie_config_aspm_link
pcie_config_aspm_dev # ASPM may be enabled
pci_bus_add_devices
pci_bus_add_devices
pci_fixup_device(pci_fixup_final) # FINAL quirks
quirk_disable_aspm_l0s
pci_disable_link_state(dev, PCIE_LINK_STATE_L0S)
Sometimes enabling ASPM can make the link non-functional, so if we know
ASPM is broken on a device, we shouldn't enable it at all, even
temporarily.
Convert the existing quirks to use pcie_aspm_remove_cap() instead, which
overrides the ASPM Support advertised in PCIe Link Capabilities, and make
them HEADER quirks so they run before pcie_aspm_init_link_state() has a
chance to enable ASPM.
Signed-off-by: Bjorn Helgaas <[email protected]>
Tested-by: Shawn Lin <[email protected]>
Reviewed-by: Lukas Wunner <[email protected]>
Link: https://patch.msgid.link/[email protected]
Diffstat (limited to 'lib/mpi/mpi-scan.c')
0 files changed, 0 insertions, 0 deletions
