Description
In the Linux kernel, the following vulnerability has been resolved: fs/ntfs3: Fix slab-out-of-bounds read in DeleteIndexEntryRoot In the 'DeleteIndexEntryRoot' case of the 'do_action' function, the entry size ('esize') is retrieved from the log record without adequate bounds checking. Specifically, the code calculates the end of the entry ('e2') using: e2 = Add2Ptr(e1, esize); It then calculates the size for memmove using 'PtrOffset(e2, ...)', which subtracts the end pointer from the buffer limit. If 'esize' is maliciously large, 'e2' exceeds the used buffer size. This results in a negative offset which, when cast to size_t for memmove, interprets as a massive unsigned integer, leading to a heap buffer overflow. This commit adds a check to ensure that the entry size ('esize') strictly fits within the remaining used space of the index header before performing memory operations.
Product status
b46acd6a6a627d876898e1c84d3f84902264b445 (git) before 36c03f7f177b34d51f1cf1d2304b1074607bf4b0
b46acd6a6a627d876898e1c84d3f84902264b445 (git) before b271c9cb85927210b1b799e55ee7f702d12b4336
b46acd6a6a627d876898e1c84d3f84902264b445 (git) before a584b9d1059b29e97e17c919274e9adfb846f2a0
b46acd6a6a627d876898e1c84d3f84902264b445 (git) before c065541b71b79874c83d418a9acd18ad5826339b
b46acd6a6a627d876898e1c84d3f84902264b445 (git) before 78942172d5bff4d4afed8674abc09cc560ce44a0
b46acd6a6a627d876898e1c84d3f84902264b445 (git) before f3b437a4c3e022a1449658ae9f3dd34859894513
b46acd6a6a627d876898e1c84d3f84902264b445 (git) before b2bc7c44ed1779fc9eaab9a186db0f0d01439622
5.15
Any version before 5.15
5.15.202 (semver)
6.1.165 (semver)
6.6.128 (semver)
6.12.75 (semver)
6.18.14 (semver)
6.19.4 (semver)
7.0 (original_commit_for_fix)
References
git.kernel.org/...c/36c03f7f177b34d51f1cf1d2304b1074607bf4b0
git.kernel.org/...c/b271c9cb85927210b1b799e55ee7f702d12b4336
git.kernel.org/...c/a584b9d1059b29e97e17c919274e9adfb846f2a0
git.kernel.org/...c/c065541b71b79874c83d418a9acd18ad5826339b
git.kernel.org/...c/78942172d5bff4d4afed8674abc09cc560ce44a0
git.kernel.org/...c/f3b437a4c3e022a1449658ae9f3dd34859894513
git.kernel.org/...c/b2bc7c44ed1779fc9eaab9a186db0f0d01439622