CVE-2024-58093

Source
https://nvd.nist.gov/vuln/detail/CVE-2024-58093
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2024-58093.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2024-58093
Downstream
Related
Published
2025-04-16T14:11:42.682Z
Modified
2025-11-28T02:34:38.321047Z
Summary
PCI/ASPM: Fix link state exit during switch upstream function removal
Details

In the Linux kernel, the following vulnerability has been resolved:

PCI/ASPM: Fix link state exit during switch upstream function removal

Before 456d8aa37d0f ("PCI/ASPM: Disable ASPM on MFD function removal to avoid use-after-free"), we would free the ASPM link only after the last function on the bus pertaining to the given link was removed.

That was too late. If function 0 is removed before sibling function, link->downstream would point to free'd memory after.

After above change, we freed the ASPM parent link state upon any function removal on the bus pertaining to a given link.

That is too early. If the link is to a PCIe switch with MFD on the upstream port, then removing functions other than 0 first would free a link which still remains parent_link to the remaining downstream ports.

The resulting GPFs are especially frequent during hot-unplug, because pciehp removes devices on the link bus in reverse order.

On that switch, function 0 is the virtual P2P bridge to the internal bus. Free exactly when function 0 is removed -- before the parent link is obsolete, but after all subordinate links are gone.

[kwilczynski: commit log]

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2024/58xxx/CVE-2024-58093.json"
}
References

Affected packages

Git / git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git

Affected ranges

Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
456d8aa37d0f56fc9e985e812496e861dcd6f2f2
Fixed
cbf937dcadfd571a434f8074d057b32cd14fbea5
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
0 Unknown introduced commit / All previous commits are affected
Last affected
666e7f9d60cee23077ea3e6331f6f8a19f7ea03f
Last affected
7badf4d6f49a358a01ab072bbff88d3ee886c33b
Last affected
9856c0de49052174ab474113f4ba40c02aaee086
Last affected
7aecdd47910c51707696e8b0e045b9f88bd4230f
Last affected
d51d2eeae4ce54d542909c4d9d07bf371a78592c
Last affected
4203722d51afe3d239e03f15cc73efdf023a7103