CVE-2025-37797
Severity CVSS v4.0:
Pending analysis
Type:
CWE-416
Use After Free
Publication date:
02/05/2025
Last modified:
06/11/2025
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
net_sched: hfsc: Fix a UAF vulnerability in class handling<br />
<br />
This patch fixes a Use-After-Free vulnerability in the HFSC qdisc class<br />
handling. The issue occurs due to a time-of-check/time-of-use condition<br />
in hfsc_change_class() when working with certain child qdiscs like netem<br />
or codel.<br />
<br />
The vulnerability works as follows:<br />
1. hfsc_change_class() checks if a class has packets (q.qlen != 0)<br />
2. It then calls qdisc_peek_len(), which for certain qdiscs (e.g.,<br />
codel, netem) might drop packets and empty the queue<br />
3. The code continues assuming the queue is still non-empty, adding<br />
the class to vttree<br />
4. This breaks HFSC scheduler assumptions that only non-empty classes<br />
are in vttree<br />
5. Later, when the class is destroyed, this can lead to a Use-After-Free<br />
<br />
The fix adds a second queue length check after qdisc_peek_len() to verify<br />
the queue wasn&#39;t emptied.
Impact
Base Score 3.x
7.80
Severity 3.x
HIGH
Vulnerable products and versions
| CPE | From | Up to |
|---|---|---|
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 4.14.1 (including) | 5.4.293 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.5 (including) | 5.10.237 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.11 (including) | 5.15.181 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.16 (including) | 6.1.136 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.2 (including) | 6.6.89 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.7 (including) | 6.12.26 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.13 (including) | 6.14.5 (excluding) |
| cpe:2.3:o:linux:linux_kernel:4.14:-:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:4.14:rc2:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:4.14:rc3:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:4.14:rc4:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:4.14:rc5:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:4.14:rc6:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:4.14:rc7:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:4.14:rc8:*:*:*:*:*:* |
To consult the complete list of CPE names with products and versions, see this page
References to Advisories, Solutions, and Tools
- https://git.kernel.org/stable/c/20d584a33e480ae80d105f43e0e7b56784da41b9
- https://git.kernel.org/stable/c/28b09a067831f7317c3841812276022d6c940677
- https://git.kernel.org/stable/c/39b9095dd3b55d9b2743df038c32138efa34a9de
- https://git.kernel.org/stable/c/3aa852e3605000d5c47035c3fc3a986d14ccfa9f
- https://git.kernel.org/stable/c/3df275ef0a6ae181e8428a6589ef5d5231e58b5c
- https://git.kernel.org/stable/c/86cd4641c713455a4f1c8e54c370c598c2b1cee0
- https://git.kernel.org/stable/c/bb583c88d23b72d8d16453d24856c99bd93dadf5
- https://git.kernel.org/stable/c/fcc8ede663569c704fb00a702973bd6c00373283
- https://lists.debian.org/debian-lts-announce/2025/05/msg00030.html
- https://lists.debian.org/debian-lts-announce/2025/05/msg00045.html



