В ядре Linux устранена следующая уязвимость:
Bluetooth: SCO: исправлено использование после освобождения в sco_recv_frame() из-за отсутствия sock_hold.
sco_recv_frame() читает conn->sk под sco_conn_lock(), но сразу
снимает блокировку без сохранения ссылки на сокет. Параллельный
close() может освободить сокет между снятием блокировки и последующим
sk->sk_state, что приводит к использованию после освобождения. Другие функции в том же файле (sco_sock_timeout(), sco_conn_del())
правильно используйте sco_sock_hold() для безопасного хранения ссылки под блокировкой.
Исправьте это, используя sco_sock_hold() для получения ссылки перед освобождением.
lock и добавление sock_put() на все пути выхода.
Показать оригинальное описание (EN)
In the Linux kernel, the following vulnerability has been resolved: 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.