CVE-2026-31408

NONE EPSS 0.01%
Обновлено 18 апреля 2026
Linux
Параметр Значение
Поставщик Linux
Публичный эксплойт Нет

В ядре 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.