CVE-2025-40120

Source
https://nvd.nist.gov/vuln/detail/CVE-2025-40120
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2025-40120.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2025-40120
Downstream
Published
2025-11-12T10:23:18.726Z
Modified
2025-11-27T02:32:53.375696Z
Summary
net: usb: asix: hold PM usage ref to avoid PM/MDIO + RTNL deadlock
Details

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

net: usb: asix: hold PM usage ref to avoid PM/MDIO + RTNL deadlock

Prevent USB runtime PM (autosuspend) for AX88772* in bind.

usbnet enables runtime PM (autosuspend) by default, so disabling it via the usb_driver flag is ineffective. On AX88772B, autosuspend shows no measurable power saving with current driver (no link partner, admin up/down). The ~0.453 W -> ~0.248 W drop on v6.1 comes from phylib powering the PHY off on admin-down, not from USB autosuspend.

The real hazard is that with runtime PM enabled, ndoopen() (under RTNL) may synchronously trigger autoresume (usbautopmgetinterface()) into asix_resume() while the USB PM lock is held. Resume paths then invoke phylink/phylib and MDIO, which also expect RTNL, leading to possible deadlocks or PM lock vs MDIO wake issues.

To avoid this, keep the device runtime-PM active by taking a usage reference in ax88772bind() and dropping it in unbind(). A non-zero PM usage count blocks runtime suspend regardless of userspace policy (.../power/control - pmruntime_allow/forbid), making this approach robust against sysfs overrides.

Holding a runtime-PM usage ref does not affect system-wide suspend; system sleep/resume callbacks continue to run as before.

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/blob/cc431b3424123d84bcd7afd4de150b33f117a8ef/cves/2025/40xxx/CVE-2025-40120.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
4a2c7217cd5a87e85ceb761e307b030fe6db4805
Fixed
71a0ba7fdaf8d035426912a4ed7bf1738a81010c
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
4a2c7217cd5a87e85ceb761e307b030fe6db4805
Fixed
3e96cd27ff1a004d84908c1b6cc68ac60913874e
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
4a2c7217cd5a87e85ceb761e307b030fe6db4805
Fixed
724a9db84188f80ef60b1f21cc7b4e9c84e0cb64
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
4a2c7217cd5a87e85ceb761e307b030fe6db4805
Fixed
1534517300e12f2930b6ff477b8820ff658afd11
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
4a2c7217cd5a87e85ceb761e307b030fe6db4805
Fixed
9d8bcaf6fae1bd82bc27ec09a2694497e6f6c4b4
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
4a2c7217cd5a87e85ceb761e307b030fe6db4805
Fixed
3d3c4cd5c62f24bb3cb4511b7a95df707635e00a

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
5.14.0
Fixed
5.15.195
Type
ECOSYSTEM
Events
Introduced
5.16.0
Fixed
6.1.156
Type
ECOSYSTEM
Events
Introduced
6.2.0
Fixed
6.6.112
Type
ECOSYSTEM
Events
Introduced
6.7.0
Fixed
6.12.53
Type
ECOSYSTEM
Events
Introduced
6.13.0
Fixed
6.17.3