]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
Bluetooth: LE L2CAP: Disconnect if sum of payload sizes exceed SDU
authorChristian Eggers <ceggers@arri.de>
Wed, 25 Feb 2026 17:07:27 +0000 (18:07 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 25 Mar 2026 10:08:52 +0000 (11:08 +0100)
[ Upstream commit b6a2bf43aa37670432843bc73ae2a6288ba4d6f8 ]

Core 6.0, Vol 3, Part A, 3.4.3:
"... If the sum of the payload sizes for the K-frames exceeds the
specified SDU length, the receiver shall disconnect the channel."

This fixes L2CAP/LE/CFC/BV-27-C (running together with 'l2test -r -P
0x0027 -V le_public').

Fixes: aac23bf63659 ("Bluetooth: Implement LE L2CAP reassembly")
Signed-off-by: Christian Eggers <ceggers@arri.de>
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 de8e18fe50557c1f1648e219b7d01d5d6c8d8023..560a17d36f7fa4239d81ecae3cedc3ada532e9f1 100644 (file)
@@ -6686,6 +6686,7 @@ static int l2cap_ecred_data_rcv(struct l2cap_chan *chan, struct sk_buff *skb)
 
        if (chan->sdu->len + skb->len > chan->sdu_len) {
                BT_ERR("Too much LE L2CAP data received");
+               l2cap_send_disconn_req(chan, ECONNRESET);
                err = -EINVAL;
                goto failed;
        }