diff options
author | Min Li <lm0963hack@gmail.com> | 2023-04-17 10:27:54 +0800 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2023-05-30 12:44:03 +0100 |
commit | 2112c4c47d36bc5aba3ddeb9afedce6ae6a67e7d (patch) | |
tree | db93475bb34684aee3c847a3970520470546caeb /net/bluetooth | |
parent | fa57021262e998e2229d6383b1081638df2fe238 (diff) | |
download | linux-stable-2112c4c47d36bc5aba3ddeb9afedce6ae6a67e7d.tar.gz linux-stable-2112c4c47d36bc5aba3ddeb9afedce6ae6a67e7d.tar.bz2 linux-stable-2112c4c47d36bc5aba3ddeb9afedce6ae6a67e7d.zip |
Bluetooth: L2CAP: fix "bad unlock balance" in l2cap_disconnect_rsp
[ 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>
Diffstat (limited to 'net/bluetooth')
-rw-r--r-- | net/bluetooth/l2cap_core.c | 1 |
1 files changed, 0 insertions, 1 deletions
diff --git a/net/bluetooth/l2cap_core.c b/net/bluetooth/l2cap_core.c index 3c559a177761..5f53e75d8302 100644 --- a/net/bluetooth/l2cap_core.c +++ b/net/bluetooth/l2cap_core.c @@ -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; } |