While running in L2CAP ERTM mode, sometimes ERTM packet queue gets corrupted because though method l2cap_ertm_send() is not thread-safe, it is called simultaneously from multiple threads. Signed-off-by: Manoj <manojkr.sharma@xxxxxxxxxxxxxx> --- net/bluetooth/l2cap_core.c | 3 ++- 1 files changed, 2 insertions(+), 1 deletions(-) diff --git a/net/bluetooth/l2cap_core.c b/net/bluetooth/l2cap_core.c index 19807c9..a9319e2 100644 --- a/net/bluetooth/l2cap_core.c +++ b/net/bluetooth/l2cap_core.c @@ -1713,6 +1713,7 @@ static int l2cap_ertm_send(struct l2cap_chan *chan) if (chan->state != BT_CONNECTED) return -ENOTCONN; + mutex_lock(&chan->conn->chan_lock); while ((skb = chan->tx_send_head) && (!l2cap_tx_window_full(chan))) { if (chan->remote_max_tx && @@ -1765,7 +1766,7 @@ static int l2cap_ertm_send(struct l2cap_chan *chan) else chan->tx_send_head = skb_queue_next(&chan->tx_q, skb); } - + mutex_unlock(&chan->conn->chan_lock); return nsent; } -- 1.6.6.1 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html