CVE-2025-38166 Information
Description
In the Linux kernel the following vulnerability has been resolved:
bpf: fix ktls panic with sockmap
[ 2172.936997] ————[ cut here ]————
[ 2172.936999] kernel BUG at lib/iov_iter.c:629!
……
[ 2172.944996] PKRU: 55555554
[ 2172.945155] Call Trace:
[ 2172.945299]
After calling bpf_exec_tx_verdict() the size of msg_pl->sg may increase e.g. when the BPF program executes bpf_msg_push_data().
If the BPF program sets cork_bytes and sg.size is smaller than cork_bytes it will return -ENOSPC and attempt to roll back to the non-zero copy logic. However during rollback msg->msg_iter is reset but since msg_pl->sg.size has been increased subsequent executions will exceed the actual size of msg_iter. ’’' iov_iter_revert(&msg->msg_iter msg_pl->sg.size - orig_size); ’''
The changes in this commit are based on the following considerations:
-
When cork_bytes is set rolling back to non-zero copy logic is pointless and can directly go to zero-copy logic.
-
We can not calculate the correct number of bytes to revert msg_iter.
Assume the original data is bcdefgh\ (8 bytes) and after 3 pushes by the BPF program it becomes 11-byte data: bc?de?fgh?. Then we set cork_bytes to 6 which means the first 6 bytes have been processed and the remaining 5 bytes ?fgh?\ will be cached until the length meets the cork_bytes requirement.
However some data in ?fgh?\ is not within ‘sg->msg_iter’ (but in msg_pl instead) especially the data ?\ we pushed.
So it doesn’t seem as simple as just reverting through an offset of msg_iter.
- For non-TLS sockets in tcp_bpf_sendmsg when a ## Reference https://git.kernel.org/stable/c/2e36a81d388ec9c3f78b6223f7eda2088cd40adb https://git.kernel.org/stable/c/328cac3f9f8ae394748485e769a527518a9137c8 https://git.kernel.org/stable/c/54a3ecaeeeae8176da8badbd7d72af1017032c39 https://git.kernel.org/stable/c/57fbbe29e86042bbaa31c1a30d2afa16c427e3f7 https://git.kernel.org/stable/c/603943f022a7fe5cc83ca7005faf34798fb7853f
Related CNNVD
CNNVD-202507-247 (Published: 2025-07-03)
Share on: