]> git.ipfire.org Git - thirdparty/kernel/stable.git/commit
Bluetooth: SCO: Fix use-after-free in sco_recv_frame() due to missing sock_hold
authorHyunwoo Kim <imv4bel@gmail.com>
Thu, 12 Mar 2026 20:26:16 +0000 (05:26 +0900)
committerLuiz Augusto von Dentz <luiz.von.dentz@intel.com>
Thu, 19 Mar 2026 18:42:35 +0000 (14:42 -0400)
commit598dbba9919c5e36c54fe1709b557d64120cb94b
tree2e739ce1b226211858532ab5f7ebccbc8aaf8b4d
parentc65bd945d1c08c3db756821b6bf9f1c4a77b29c6
Bluetooth: SCO: Fix use-after-free in sco_recv_frame() due to missing sock_hold

sco_recv_frame() reads conn->sk under sco_conn_lock() but immediately
releases the lock without holding a reference to the socket. A concurrent
close() can free the socket between the lock release and the subsequent
sk->sk_state access, resulting in a use-after-free.

Other functions in the same file (sco_sock_timeout(), sco_conn_del())
correctly use sco_sock_hold() to safely hold a reference under the lock.

Fix by using sco_sock_hold() to take a reference before releasing the
lock, and adding sock_put() on all exit paths.

Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2")
Signed-off-by: Hyunwoo Kim <imv4bel@gmail.com>
Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
net/bluetooth/sco.c