mac80211: add fix for receiving STP frames on mesh
Fix length in ethernet header
Signed-off-by: Felix Fietkau <nbd@nbd.name>
(cherry picked from commit 8f7be2a2ba)
Link: https://github.com/openwrt/openwrt/pull/15898
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
This commit is contained in:
committed by
Hauke Mehrtens
parent
bed2272605
commit
c145f0f8f6
@@ -0,0 +1,25 @@
|
|||||||
|
From: Felix Fietkau <nbd@nbd.name>
|
||||||
|
Date: Tue, 11 Jul 2023 13:30:12 +0200
|
||||||
|
Subject: [PATCH] wifi: cfg80211: fix receving mesh packets without RFC1042
|
||||||
|
header
|
||||||
|
|
||||||
|
Fix ethernet header length field after stripping the mesh header
|
||||||
|
|
||||||
|
Cc: stable@vger.kernel.org
|
||||||
|
Link: https://lore.kernel.org/all/CT5GNZSK28AI.2K6M69OXM9RW5@syracuse/
|
||||||
|
Fixes: 986e43b19ae9 ("wifi: mac80211: fix receiving A-MSDU frames on mesh interfaces")
|
||||||
|
Reported-by: Nicolas Escande <nico.escande@gmail.com>
|
||||||
|
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
||||||
|
---
|
||||||
|
|
||||||
|
--- a/net/wireless/util.c
|
||||||
|
+++ b/net/wireless/util.c
|
||||||
|
@@ -580,6 +580,8 @@ int ieee80211_strip_8023_mesh_hdr(struct
|
||||||
|
hdrlen += ETH_ALEN + 2;
|
||||||
|
else if (!pskb_may_pull(skb, hdrlen))
|
||||||
|
return -EINVAL;
|
||||||
|
+ else
|
||||||
|
+ payload.eth.h_proto = htons(skb->len - hdrlen);
|
||||||
|
|
||||||
|
mesh_addr = skb->data + sizeof(payload.eth) + ETH_ALEN;
|
||||||
|
switch (payload.flags & MESH_FLAGS_AE) {
|
||||||
@@ -176,7 +176,7 @@ Signed-off-by: Johannes Berg <johannes.berg@intel.com>
|
|||||||
* Use the wdev event list so that if there are pending
|
* Use the wdev event list so that if there are pending
|
||||||
--- a/net/wireless/util.c
|
--- a/net/wireless/util.c
|
||||||
+++ b/net/wireless/util.c
|
+++ b/net/wireless/util.c
|
||||||
@@ -1057,7 +1057,9 @@ void cfg80211_process_wdev_events(struct
|
@@ -1059,7 +1059,9 @@ void cfg80211_process_wdev_events(struct
|
||||||
__cfg80211_leave(wiphy_to_rdev(wdev->wiphy), wdev);
|
__cfg80211_leave(wiphy_to_rdev(wdev->wiphy), wdev);
|
||||||
break;
|
break;
|
||||||
case EVENT_PORT_AUTHORIZED:
|
case EVENT_PORT_AUTHORIZED:
|
||||||
|
|||||||
Reference in New Issue
Block a user