• Ruihan Li's avatar
    Bluetooth: Fix UAF in hci_conn_hash_flush again · a2ac591c
    Ruihan Li authored
    Commit 06149746 ("Bluetooth: hci_conn: Add support for linking
    multiple hcon") reintroduced a previously fixed bug [1] ("KASAN:
    slab-use-after-free Read in hci_conn_hash_flush"). This bug was
    originally fixed by commit 5dc7d23e ("Bluetooth: hci_conn: Fix
    possible UAF").
    
    The hci_conn_unlink function was added to avoid invalidating the link
    traversal caused by successive hci_conn_del operations releasing extra
    connections. However, currently hci_conn_unlink itself also releases
    extra connections, resulted in the reintroduced bug.
    
    This patch follows a more robust solution for cleaning up all
    connections, by repeatedly removing the first connection until there are
    none left. This approach does not rely on the inner workings of
    hci_conn_del and ensures proper cleanup of all connections.
    
    Meanwhile, we need to make sure that hci_conn_del never fails. Indeed it
    doesn't, as it now always returns zero. To make this a bit clearer, this
    patch also changes its return type to void.
    
    Reported-by: syzbot+8bb72f86fc823817bc5d@syzkaller.appspotmail.com
    Closes: https://lore.kernel.org/linux-bluetooth/000000000000aa920505f60d25ad@google.com/
    Fixes: 06149746 ("Bluetooth: hci_conn: Add support for linking multiple hcon")
    Signed-off-by: default avatarRuihan Li <lrh2000@pku.edu.cn>
    Co-developed-by: default avatarLuiz Augusto von Dentz <luiz.von.dentz@intel.com>
    Signed-off-by: default avatarLuiz Augusto von Dentz <luiz.von.dentz@intel.com>
    a2ac591c
hci_core.h 59 KB