[SRU Kinetic 2/2] Bluetooth: L2CAP: Fix l2cap_global_chan_by_psm
Cengiz Can
cengiz.can at canonical.com
Fri Dec 2 18:10:18 UTC 2022
From: Luiz Augusto von Dentz <luiz.von.dentz at intel.com>
l2cap_global_chan_by_psm shall not return fixed channels as they are not
meant to be connected by (S)PSM.
Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz at intel.com>
Reviewed-by: Tedd Ho-Jeong An <tedd.an at intel.com>
CVE-2022-42896
(cherry picked from commit f937b758a188d6fd328a81367087eddbb2fce50f)
Signed-off-by: Cengiz Can <cengiz.can at canonical.com>
---
net/bluetooth/l2cap_core.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/net/bluetooth/l2cap_core.c b/net/bluetooth/l2cap_core.c
index 375ab8fa3bcf..e765cae4be6f 100644
--- a/net/bluetooth/l2cap_core.c
+++ b/net/bluetooth/l2cap_core.c
@@ -1989,7 +1989,7 @@ static struct l2cap_chan *l2cap_global_chan_by_psm(int state, __le16 psm,
if (link_type == LE_LINK && c->src_type == BDADDR_BREDR)
continue;
- if (c->psm == psm) {
+ if (c->chan_type != L2CAP_CHAN_FIXED && c->psm == psm) {
int src_match, dst_match;
int src_any, dst_any;
--
2.37.2
More information about the kernel-team
mailing list