]> Gentwo Git Trees - linux/.git/commit
Bluetooth: MGMT: Fix OOB access in parse_adv_monitor_pattern()
authorIlia Gavrilov <Ilia.Gavrilov@infotecs.ru>
Mon, 20 Oct 2025 15:12:55 +0000 (15:12 +0000)
committerLuiz Augusto von Dentz <luiz.von.dentz@intel.com>
Fri, 31 Oct 2025 16:43:05 +0000 (12:43 -0400)
commit8d59fba49362c65332395789fd82771f1028d87e
tree1f59cde87f39523c2a439f6b4818916fc1a051e1
parent1c21cf89a66413eb04b2d22c955b7a50edc14dfa
Bluetooth: MGMT: Fix OOB access in parse_adv_monitor_pattern()

In the parse_adv_monitor_pattern() function, the value of
the 'length' variable is currently limited to HCI_MAX_EXT_AD_LENGTH(251).
The size of the 'value' array in the mgmt_adv_pattern structure is 31.
If the value of 'pattern[i].length' is set in the user space
and exceeds 31, the 'patterns[i].value' array can be accessed
out of bound when copied.

Increasing the size of the 'value' array in
the 'mgmt_adv_pattern' structure will break the userspace.
Considering this, and to avoid OOB access revert the limits for 'offset'
and 'length' back to the value of HCI_MAX_AD_LENGTH.

Found by InfoTeCS on behalf of Linux Verification Center
(linuxtesting.org) with SVACE.

Fixes: db08722fc7d4 ("Bluetooth: hci_core: Fix missing instances using HCI_MAX_AD_LENGTH")
Cc: stable@vger.kernel.org
Signed-off-by: Ilia Gavrilov <Ilia.Gavrilov@infotecs.ru>
Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
include/net/bluetooth/mgmt.h
net/bluetooth/mgmt.c