diff mbox series

[wireless] wifi: cfg80211: fix out-of-bounds access during multi-link element defragmentation

Message ID 20250424-fix_mle_defragmentation_oob_access-v1-1-84412a1743fa@quicinc.com
State New
Headers show
Series [wireless] wifi: cfg80211: fix out-of-bounds access during multi-link element defragmentation | expand

Commit Message

Veerendranath Jakkam April 24, 2025, 12:31 p.m. UTC
Currently during the multi-link element defragmentation process, the
multi-link element length added to the total IEs length when calculating
the length of remaining IEs after the multi-link element in
cfg80211_defrag_mle(). This could lead to out-of-bounds access if the
multi-link element or its corresponding fragment elements are the last
elements in the IEs buffer.

To address this issue, correctly calculate the remaining IEs length by
deducting the multi-link element end offset from total IEs end offset.

Fixes: 2481b5da9c6b ("wifi: cfg80211: handle BSS data contained in ML probe responses")
Signed-off-by: Veerendranath Jakkam <quic_vjakkam@quicinc.com>
---
 net/wireless/scan.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)


---
base-commit: 175e69e33c66904dfe910c5f43edfe5c95b32f0c
change-id: 20250424-fix_mle_defragmentation_oob_access-65951d4d3a1d
diff mbox series

Patch

diff --git a/net/wireless/scan.c b/net/wireless/scan.c
index 9865f305275d..ddd3a97f6609 100644
--- a/net/wireless/scan.c
+++ b/net/wireless/scan.c
@@ -2681,7 +2681,7 @@  cfg80211_defrag_mle(const struct element *mle, const u8 *ie, size_t ielen,
 	/* Required length for first defragmentation */
 	buf_len = mle->datalen - 1;
 	for_each_element(elem, mle->data + mle->datalen,
-			 ielen - sizeof(*mle) + mle->datalen) {
+			 ie + ielen - mle->data - mle->datalen) {
 		if (elem->id != WLAN_EID_FRAGMENT)
 			break;