aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/tools/perf/arch/s390/git:/ssh:/git@git.zx2c4.com
diff options
context:
space:
mode:
authorMuhammad Bilal <meatuni001@gmail.com>2026-05-27 04:59:18 +0000
committerLuiz Augusto von Dentz <luiz.von.dentz@intel.com>2026-05-28 08:52:21 -0400
commit4b5f8e608749b7e8fa386c6e4301cf9272595859 (patch)
tree964d6e9ea14ac8437efa2d3924b63b1f8aeff92b /tools/perf/arch/s390/git:/ssh:/git@git.zx2c4.com
parentBluetooth: ISO: fix UAF in iso_recv_frame (diff)
Bluetooth: ISO: serialize iso_sock_clear_timer with socket lock
iso_sock_close() calls iso_sock_clear_timer() before acquiring lock_sock(sk). iso_sock_clear_timer() reads iso_pi(sk)->conn twice without the socket lock held: if (!iso_pi(sk)->conn) return; cancel_delayed_work(&iso_pi(sk)->conn->timeout_work); Concurrently, iso_conn_del() executes under lock_sock(sk) and calls iso_chan_del(), which sets iso_pi(sk)->conn to NULL and may result in the final reference to the connection being dropped: CPU0 CPU1 ---- ---- iso_sock_clear_timer() if (conn != NULL) ... lock_sock(sk) iso_chan_del() iso_pi(sk)->conn = NULL cancel_delayed_work(conn) /* NULL deref or UAF */ iso_pi(sk)->conn is not stable across the unlock window, causing a NULL pointer dereference or use-after-free. Serialize iso_sock_clear_timer() with the socket lock by moving it inside lock_sock()/release_sock(), matching the pattern used in iso_conn_del() and all other call sites. Fixes: ccf74f2390d60a2f9a75ef496d2564abb478f46a ("Bluetooth: Add BTPROTO_ISO socket type") Cc: stable@vger.kernel.org Signed-off-by: Muhammad Bilal <meatuni001@gmail.com> Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
Diffstat (limited to 'tools/perf/arch/s390/git:/ssh:/git@git.zx2c4.com')
0 files changed, 0 insertions, 0 deletions