CVE-2026-45994
published 2026-05-27CVE-2026-45994: In the Linux kernel, the following vulnerability has been resolved: ibmasm: fix OOB reads in command_file_write due to missing size checks The…
medium5.5
In the Linux kernel, the following vulnerability has been resolved:
ibmasm: fix OOB reads in command_file_write due to missing size checks
The command_file_write() handler allocates a kernel buffer of exactly
count bytes and copies user data into it, but does not validate the
buffer against the dot command protocol before passing it to
get_dot_command_size() and get_dot_command_timeout().
Since both the allocation size (count) and the header fields (command_size,
data_size) are independently user-controlled, an attacker can cause
get_dot_command_size() to return a value exceeding the allocation,
triggering OOB reads in get_dot_command_timeout() and an out-of-bounds
memcpy_toio() that leaks kernel heap memory to the service processor.
Fix with two guards: reject writes smaller than sizeof(struct
dot_command_header) before allocation, then after copying user data
reject commands where the buffer is smaller than the total size declared
by the header (sizeof(header) + command_size + data_size). This ensures
all subsequent header and payload field accesses stay within the buffer.
Affected
10 ranges
| Vendor | Product | Version range | Fixed in |
|---|---|---|---|
| linux | linux | — | — |
| linux | linux | >= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < 44ee19422aa82a6847594866de7e5a31e4ef98b3 | 44ee19422aa82a6847594866de7e5a31e4ef98b3 |
| linux | linux | >= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < 7b8a574da5d7ea99b943f7a3458a17a1d95e8838 | 7b8a574da5d7ea99b943f7a3458a17a1d95e8838 |
| linux | linux | >= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < d50e2019c9d7c433f56d9dff65703eb904aa1fb1 | d50e2019c9d7c433f56d9dff65703eb904aa1fb1 |
| linux | linux | >= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < a672682d39dd34e2b5ba4feb436723bed65125ff | a672682d39dd34e2b5ba4feb436723bed65125ff |
| linux | linux | >= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < aefc1a97da17d8309974690c8a03e439a91ebb1c | aefc1a97da17d8309974690c8a03e439a91ebb1c |
| linux | linux | >= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < ee5737891464030a189837467df3b81a273718ad | ee5737891464030a189837467df3b81a273718ad |
| linux | linux | >= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < d0fb4d1dc43f8d5179917a2daaa82680993d4cdf | d0fb4d1dc43f8d5179917a2daaa82680993d4cdf |
| linux | linux | >= 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 < 0eb09f737428e482a32a2e31e5e223f2b35a71d3 | 0eb09f737428e482a32a2e31e5e223f2b35a71d3 |
| linux | linux_kernel | — | — |