CVE-2024-53152

Source
https://nvd.nist.gov/vuln/detail/CVE-2024-53152
Import Source
https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2024-53152.json
JSON Data
https://api.osv.dev/v1/vulns/CVE-2024-53152
Downstream
Related
Published
2024-12-24T11:28:51Z
Modified
2025-10-22T06:07:26.506854Z
Summary
PCI: tegra194: Move controller cleanups to pex_ep_event_pex_rst_deassert()
Details

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

PCI: tegra194: Move controller cleanups to pexepeventpexrst_deassert()

Currently, the endpoint cleanup function dwpcieepcleanup() and EPF deinit notify function pciepcdeinitnotify() are called during the execution of pexepeventpexrst_assert() i.e., when the host has asserted PERST#. But quickly after this step, refclk will also be disabled by the host.

All of the tegra194 endpoint SoCs supported as of now depend on the refclk from the host for keeping the controller operational. Due to this limitation, any access to the hardware registers in the absence of refclk will result in a whole endpoint crash. Unfortunately, most of the controller cleanups require accessing the hardware registers (like eDMA cleanup performed in dwpcieep_cleanup(), etc...). So these cleanup functions can cause the crash in the endpoint SoC once host asserts PERST#.

One way to address this issue is by generating the refclk in the endpoint itself and not depending on the host. But that is not always possible as some of the endpoint designs do require the endpoint to consume refclk from the host.

Thus, fix this crash by moving the controller cleanups to the start of the pexepeventpexrst_deassert() function. This function is called whenever the host has deasserted PERST# and it is guaranteed that the refclk would be active at this point. So at the start of this function (after enabling resources) the controller cleanup can be performed. Once finished, rest of the code execution for PERST# deassert can continue as usual.

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
570d7715eed8a29ac5bd96c7694f060a991e5a31
Fixed
70212c2300971506e986d95000d2745529cac9d7
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
570d7715eed8a29ac5bd96c7694f060a991e5a31
Fixed
72034050ccf4202cd6558b0afd2474f756ea3b9b
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
570d7715eed8a29ac5bd96c7694f060a991e5a31
Fixed
40e2125381dc11379112485e3eefdd25c6df5375

Affected versions

v6.*

v6.10
v6.10-rc1
v6.10-rc2
v6.10-rc3
v6.10-rc4
v6.10-rc5
v6.10-rc6
v6.10-rc7
v6.11
v6.11-rc1
v6.11-rc2
v6.11-rc3
v6.11-rc4
v6.11-rc5
v6.11-rc6
v6.11-rc7
v6.11.1
v6.11.10
v6.11.2
v6.11.3
v6.11.4
v6.11.5
v6.11.6
v6.11.7
v6.11.8
v6.11.9
v6.12
v6.12-rc1
v6.12-rc2
v6.12-rc3
v6.12-rc4
v6.12-rc5
v6.12-rc6
v6.12-rc7
v6.12.1
v6.9
v6.9-rc2
v6.9-rc3
v6.9-rc4
v6.9-rc5
v6.9-rc6
v6.9-rc7

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
6.10.0
Fixed
6.11.11
Type
ECOSYSTEM
Events
Introduced
6.12.0
Fixed
6.12.2