CVE-2022-48988

Source
https://cve.org/CVERecord?id=CVE-2022-48988
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2022-48988.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2022-48988
Downstream
Related
Published
2024-10-21T20:06:04.601Z
Modified
2026-03-12T03:24:23.515724Z
Summary
memcg: fix possible use-after-free in memcg_write_event_control()
Details

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

memcg: fix possible use-after-free in memcgwriteevent_control()

memcgwriteeventcontrol() accesses the dentry->dname of the specified control fd to route the write call. As a cgroup interface file can't be renamed, it's safe to access d_name as long as the specified file is a regular cgroup file. Also, as these cgroup interface files can't be removed before the directory, it's safe to access the parent too.

Prior to 347c4a874710 ("memcg: remove cgroup_event->cft"), there was a call to __file_cft() which verified that the specified file is a regular cgroupfs file before further accesses. The cftype pointer returned from __filecft() was no longer necessary and the commit inadvertently dropped the file type check with it allowing any file to slip through. With the invarients broken, the dname and parent accesses can now race against renames and removals of arbitrary files and cause use-after-free's.

Fix the bug by resurrecting the file type check in _filecft(). Now that cgroupfs is implemented through kernfs, checking the file operations needs to go through a layer of indirection. Instead, let's check the superblock and dentry type.

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2022/48xxx/CVE-2022-48988.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
347c4a8747104a945ecced358944e42879176ca5
Fixed
b77600e26fd48727a95ffd50ba1e937efb548125
Fixed
e1ae97624ecf400ea56c238bff23e5cd139df0b8
Fixed
35963b31821920908e397146502066f6b032c917
Fixed
f1f7f36cf682fa59db15e2089039a2eeb58ff2ad
Fixed
aad8bbd17a1d586005feb9226c2e9cfce1432e13
Fixed
0ed074317b835caa6c03bcfa8f133365324673dc
Fixed
4a7ba45b1a435e7097ca0f79a847d0949d0eb088

Database specific

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