CVE-2022-49204 Information
Description
In the Linux kernel the following vulnerability has been resolved:
bpf sockmap: Fix more uncharged while msg has more_data
In tcp_bpf_send_verdict() if msg has more data after tcp_bpf_sendmsg_redir():
tcp_bpf_send_verdict() tosend = msg->sg.size //msg->sg.size = 22220 case __SK_REDIRECT: sk_msg_return() //uncharged msg->sg.size(22220) sk->sk_forward_alloc tcp_bpf_sendmsg_redir() //after tcp_bpf_sendmsg_redir msg->sg.size=11000 goto more_data; tosend = msg->sg.size //msg->sg.size = 11000 case __SK_REDIRECT: sk_msg_return() //uncharged msg->sg.size(11000) to sk->sk_forward_alloc
The msg->sg.size(11000) has been uncharged twice to fix we can charge the remaining msg->sg.size before goto more data.
This issue can cause the following info:
WARNING: CPU: 0 PID: 9860 at net/core/stream.c:208 sk_stream_kill_queues+0xd4/0x1a0
Call Trace:
WARNING: CPU: 0 PID: 2136 at net/ipv4/af_inet.c:155 inet_sock_destruct+0x13c/0x260
Call Trace:
Reference
https://git.kernel.org/stable/c/168ff181f5b6e7fce684c98a30d35da1dbf8f82a https://git.kernel.org/stable/c/244ce90c8d0bd10ebf957da02c6f3fcd5d920bdf https://git.kernel.org/stable/c/7b812a369e6416ab06d83cdd39d8e3f752781dd0 https://git.kernel.org/stable/c/84472b436e760ba439e1969a9e3c5ae7c86de39d https://git.kernel.org/stable/c/87d532d41ef937e16f61b3d2094f3a2ac49be365 https://git.kernel.org/stable/c/abb4caa477a5450817d2aa1198edce66450aecf8
Share on: