CVE-2025-21786

Source
https://nvd.nist.gov/vuln/detail/CVE-2025-21786
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2025-21786.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2025-21786
Downstream
Related
Published
2025-02-27T02:18:26Z
Modified
2025-10-17T21:31:31.141936Z
Severity
  • 7.8 (High) CVSS_V3 - CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H CVSS Calculator
Summary
workqueue: Put the pwq after detaching the rescuer from the pool
Details

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

workqueue: Put the pwq after detaching the rescuer from the pool

The commit 68f83057b913("workqueue: Reap workers via kthreadstop() and remove detachcompletion") adds code to reap the normal workers but mistakenly does not handle the rescuer and also removes the code waiting for the rescuer in putunboundpool(), which caused a use-after-free bug reported by Cheung Wall.

To avoid the use-after-free bug, the pool’s reference must be held until the detachment is complete. Therefore, move the code that puts the pwq after detaching the rescuer from the pool.

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
68f83057b913467a999e1bf9e0da6a119668f769
Fixed
e7c16028a424dd35be1064a68fa318be4359310f
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
68f83057b913467a999e1bf9e0da6a119668f769
Fixed
835b69c868f53f959d4986bbecd561ba6f38e492
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
68f83057b913467a999e1bf9e0da6a119668f769
Fixed
e76946110137703c16423baf6ee177b751a34b7e

Affected versions

v6.*

v6.10
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.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.12.10
v6.12.11
v6.12.12
v6.12.13
v6.12.14
v6.12.15
v6.12.2
v6.12.3
v6.12.4
v6.12.5
v6.12.6
v6.12.7
v6.12.8
v6.12.9
v6.13
v6.13-rc1
v6.13-rc2
v6.13-rc3
v6.13-rc4
v6.13-rc5
v6.13-rc6
v6.13-rc7
v6.13.1
v6.13.2
v6.13.3

Database specific

vanir_signatures

[
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@e76946110137703c16423baf6ee177b751a34b7e",
        "id": "CVE-2025-21786-09084dc3",
        "digest": {
            "line_hashes": [
                "314086374304315960264947960451143637853",
                "271006954375188191313169001384716593954",
                "298644611077016624485711838853411360988",
                "26801368842522646480082018550341492494",
                "118078771785722951129716126887090484919",
                "37579092056659682294378288522272079129",
                "43780320731975192163177956272451778748"
            ],
            "threshold": 0.9
        },
        "signature_version": "v1",
        "deprecated": false,
        "target": {
            "file": "kernel/workqueue.c"
        },
        "signature_type": "Line"
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@835b69c868f53f959d4986bbecd561ba6f38e492",
        "id": "CVE-2025-21786-15b4ab66",
        "digest": {
            "function_hash": "297813396933722049141738421622730477261",
            "length": 1456.0
        },
        "signature_version": "v1",
        "deprecated": false,
        "target": {
            "function": "rescuer_thread",
            "file": "kernel/workqueue.c"
        },
        "signature_type": "Function"
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@835b69c868f53f959d4986bbecd561ba6f38e492",
        "id": "CVE-2025-21786-21065aba",
        "digest": {
            "line_hashes": [
                "314086374304315960264947960451143637853",
                "271006954375188191313169001384716593954",
                "298644611077016624485711838853411360988",
                "26801368842522646480082018550341492494",
                "118078771785722951129716126887090484919",
                "37579092056659682294378288522272079129",
                "43780320731975192163177956272451778748"
            ],
            "threshold": 0.9
        },
        "signature_version": "v1",
        "deprecated": false,
        "target": {
            "file": "kernel/workqueue.c"
        },
        "signature_type": "Line"
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@e76946110137703c16423baf6ee177b751a34b7e",
        "id": "CVE-2025-21786-71fe0af5",
        "digest": {
            "function_hash": "297813396933722049141738421622730477261",
            "length": 1456.0
        },
        "signature_version": "v1",
        "deprecated": false,
        "target": {
            "function": "rescuer_thread",
            "file": "kernel/workqueue.c"
        },
        "signature_type": "Function"
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@e7c16028a424dd35be1064a68fa318be4359310f",
        "id": "CVE-2025-21786-9e158985",
        "digest": {
            "line_hashes": [
                "314086374304315960264947960451143637853",
                "271006954375188191313169001384716593954",
                "298644611077016624485711838853411360988",
                "26801368842522646480082018550341492494",
                "118078771785722951129716126887090484919",
                "37579092056659682294378288522272079129",
                "43780320731975192163177956272451778748"
            ],
            "threshold": 0.9
        },
        "signature_version": "v1",
        "deprecated": false,
        "target": {
            "file": "kernel/workqueue.c"
        },
        "signature_type": "Line"
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@e7c16028a424dd35be1064a68fa318be4359310f",
        "id": "CVE-2025-21786-d81f3d99",
        "digest": {
            "function_hash": "297813396933722049141738421622730477261",
            "length": 1456.0
        },
        "signature_version": "v1",
        "deprecated": false,
        "target": {
            "function": "rescuer_thread",
            "file": "kernel/workqueue.c"
        },
        "signature_type": "Function"
    }
]

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
6.11.0
Fixed
6.12.16
Type
ECOSYSTEM
Events
Introduced
6.13.0
Fixed
6.13.4