The io_uring subsystem in the Linux kernel allowed the MAX_RW_COUNT limit to be bypassed in the PROVIDE_BUFFERS operation, which led to negative values being usedin mem_rw when reading /proc/<PID>/mem. This could be used to create a heap overflow leading to arbitrary code execution in the kernel. It was addressed via commit d1f82808877b ("io_uring: truncate lengths larger than MAX_RW_COUNT on provide buffers") (v5.13-rc1) and backported to the stable kernels in v5.12.4, v5.11.21, and v5.10.37. It was introduced in ddf0322db79c ("io_uring: add IORING_OP_PROVIDE_BUFFERS") (v5.7-rc1).
References
Configurations
Configuration 1 (hide)
|
Configuration 2 (hide)
|
History
21 Nov 2024, 06:21
Type | Values Removed | Values Added |
---|---|---|
References | () https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=d1f82808877bb10d3deee7cf3374a4eb3fb582db - Patch, Vendor Advisory | |
References | () https://security.netapp.com/advisory/ntap-20210716-0004/ - Third Party Advisory | |
References | () https://ubuntu.com/security/notices/USN-4949-1 - Third Party Advisory | |
References | () https://ubuntu.com/security/notices/USN-4950-1 - Third Party Advisory | |
References | () https://www.openwall.com/lists/oss-security/2021/05/11/13 - Mailing List, Patch, Third Party Advisory | |
References | () https://www.zerodayinitiative.com/advisories/ZDI-21-589/ - Third Party Advisory, VDB Entry | |
CVSS |
v2 : v3 : |
v2 : 7.2
v3 : 7.8 |
Information
Published : 2021-06-04 02:15
Updated : 2024-11-21 06:21
NVD link : CVE-2021-3491
Mitre link : CVE-2021-3491
CVE.ORG link : CVE-2021-3491
JSON object : View
Products Affected
linux
- linux_kernel
canonical
- ubuntu_linux