CVE-2021-46935
Severity CVSS v4.0:
Pending analysis
Type:
Unavailable / Other
Publication date:
27/02/2024
Last modified:
10/04/2024
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
binder: fix async_free_space accounting for empty parcels<br />
<br />
In 4.13, commit 74310e06be4d ("android: binder: Move buffer out of area shared with user space")<br />
fixed a kernel structure visibility issue. As part of that patch,<br />
sizeof(void *) was used as the buffer size for 0-length data payloads so<br />
the driver could detect abusive clients sending 0-length asynchronous<br />
transactions to a server by enforcing limits on async_free_size.<br />
<br />
Unfortunately, on the "free" side, the accounting of async_free_space<br />
did not add the sizeof(void *) back. The result was that up to 8-bytes of<br />
async_free_space were leaked on every async transaction of 8-bytes or<br />
less. These small transactions are uncommon, so this accounting issue<br />
has gone undetected for several years.<br />
<br />
The fix is to use "buffer_size" (the allocated buffer size) instead of<br />
"size" (the logical buffer size) when updating the async_free_space<br />
during the free operation. These are the same except for this<br />
corner case of asynchronous transactions with payloads
Impact
Base Score 3.x
5.50
Severity 3.x
MEDIUM
Vulnerable products and versions
CPE | From | Up to |
---|---|---|
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 4.14.0 (including) | 4.14.261 (excluding) |
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 4.15.0 (including) | 4.19.224 (excluding) |
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 4.20.0 (including) | 5.4.170 (excluding) |
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.5.0 (including) | 5.10.90 (excluding) |
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 5.11.0 (including) | 5.15.13 (excluding) |
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/103b16a8c51f96d5fe063022869ea906c256e5da
- https://git.kernel.org/stable/c/17691bada6b2f1d5f1c0f6d28cd9d0727023b0ff
- https://git.kernel.org/stable/c/1cb8444f3114f0bb2f6e3bcadcf09aa4a28425d4
- https://git.kernel.org/stable/c/2d2df539d05205fd83c404d5f2dff48d36f9b495
- https://git.kernel.org/stable/c/7c7064402609aeb6fb11be1b4ec10673ff17b593
- https://git.kernel.org/stable/c/cfd0d84ba28c18b531648c9d4a35ecca89ad9901