Commit ee93053d authored by Martin Townsend's avatar Martin Townsend Committed by Marcel Holtmann

Bluetooth: Fix missing channel unlock in l2cap_le_credits

In the error case where credits is greater than max_credits there
is a missing l2cap_chan_unlock before returning.
Signed-off-by: default avatarMartin Townsend <mtownsend1973@gmail.com>
Tested-by: default avatarJukka Rissanen <jukka.rissanen@linux.intel.com>
Signed-off-by: default avatarMarcel Holtmann <marcel@holtmann.org>
parent 11e3ff70
...@@ -5492,6 +5492,7 @@ static inline int l2cap_le_credits(struct l2cap_conn *conn, ...@@ -5492,6 +5492,7 @@ static inline int l2cap_le_credits(struct l2cap_conn *conn,
if (credits > max_credits) { if (credits > max_credits) {
BT_ERR("LE credits overflow"); BT_ERR("LE credits overflow");
l2cap_send_disconn_req(chan, ECONNRESET); l2cap_send_disconn_req(chan, ECONNRESET);
l2cap_chan_unlock(chan);
/* Return 0 so that we don't trigger an unnecessary /* Return 0 so that we don't trigger an unnecessary
* command reject packet. * command reject packet.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment