CVE-2022-49902

Source
https://cve.org/CVERecord?id=CVE-2022-49902
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2022-49902.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2022-49902
Downstream
Related
Published
2025-05-01T14:10:47.608Z
Modified
2026-03-20T12:24:46.242788Z
Severity
  • 5.5 (Medium) CVSS_V3 - CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H CVSS Calculator
Summary
block: Fix possible memory leak for rq_wb on add_disk failure
Details

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

block: Fix possible memory leak for rqwb on adddisk failure

kmemleak reported memory leaks in deviceadddisk():

kmemleak: 3 new suspected memory leaks

unreferenced object 0xffff88800f420800 (size 512): comm "modprobe", pid 4275, jiffies 4295639067 (age 223.512s) hex dump (first 32 bytes): 04 00 00 00 08 00 00 00 01 00 00 00 00 00 00 00 ................ 00 e1 f5 05 00 00 00 00 00 00 00 00 00 00 00 00 ................ backtrace: [<00000000d3662699>] kmalloctrace+0x26/0x60 [<00000000edc7aadc>] wbtinit+0x50/0x6f0 [<0000000069601d16>] wbtenabledefault+0x157/0x1c0 [<0000000028fc393f>] blkregisterqueue+0x2a4/0x420 [<000000007345a042>] deviceadddisk+0x6fd/0xe40 [<0000000060e6aab0>] nbddevadd+0x828/0xbf0 [nbd] ...

It is because the memory allocated in wbtenabledefault() is not released in deviceadddisk() error path. Normally, these memory are freed in:

delgendisk() rqqosexit() rqos->ops->exit(rqos); wbtexit()

So rqqosexit() is called to free the rqwb memory for wbtinit(). However in the error path of deviceadddisk(), only blkunregisterqueue() is called and make rq_wb memory leaked.

Add rqqosexit() to the error path to fix it.

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2022/49xxx/CVE-2022-49902.json",
    "cna_assigner": "Linux"
}
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
83cbce9574462c6b4eed6797bdaf18fae6859ab3
Fixed
4e68c5da60cd79950bd56287ae80b39d6261f995
Fixed
528677d3b4af985445bd4ac667485ded1ed11220
Fixed
fa81cbafbf5764ad5053512152345fab37a1fe18

Database specific

source
"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2022-49902.json"