]> git.baikalelectronics.ru Git - kernel.git/commitdiff
Bluetooth: L2CAP: fix "bad unlock balance" in l2cap_disconnect_rsp
authorMin Li <lm0963hack@gmail.com>
Mon, 17 Apr 2023 02:27:54 +0000 (10:27 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 30 May 2023 11:44:03 +0000 (12:44 +0100)
[ Upstream commit 25e97f7b1866e6b8503be349eeea44bb52d661ce ]

conn->chan_lock isn't acquired before l2cap_get_chan_by_scid,
if l2cap_get_chan_by_scid returns NULL, then 'bad unlock balance'
is triggered.

Reported-by: syzbot+9519d6b5b79cf7787cf3@syzkaller.appspotmail.com
Link: https://lore.kernel.org/all/000000000000894f5f05f95e9f4d@google.com/
Signed-off-by: Min Li <lm0963hack@gmail.com>
Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
net/bluetooth/l2cap_core.c

index 3c559a177761b279e1b4d61bb98c75fba1cce474..5f53e75d83024ccfcbb1e8f81b5845c619d40de5 100644 (file)
@@ -4410,7 +4410,6 @@ static inline int l2cap_disconnect_rsp(struct l2cap_conn *conn,
 
        chan = l2cap_get_chan_by_scid(conn, scid);
        if (!chan) {
-               mutex_unlock(&conn->chan_lock);
                return 0;
        }