From: Felix Fietkau Date: Fri, 7 Oct 2022 12:58:41 +0000 (+0200) Subject: mac80211: sync rx STP fix with updated version X-Git-Url: http://git.cdn.openwrt.org/?a=commitdiff_plain;h=f6c359a65528b994e97235b5f0b0d02d6cdad918;p=openwrt%2Fstaging%2Fblocktrron.git mac80211: sync rx STP fix with updated version Add back skb length check and fix a minor issue in protocol detection Signed-off-by: Felix Fietkau --- diff --git a/package/kernel/mac80211/patches/subsys/344-wifi-cfg80211-fix-ieee80211_data_to_8023_exthdr-hand.patch b/package/kernel/mac80211/patches/subsys/344-wifi-cfg80211-fix-ieee80211_data_to_8023_exthdr-hand.patch index 220de79d9e..161c7d6c8f 100644 --- a/package/kernel/mac80211/patches/subsys/344-wifi-cfg80211-fix-ieee80211_data_to_8023_exthdr-hand.patch +++ b/package/kernel/mac80211/patches/subsys/344-wifi-cfg80211-fix-ieee80211_data_to_8023_exthdr-hand.patch @@ -15,16 +15,16 @@ Signed-off-by: Felix Fietkau --- a/net/wireless/util.c +++ b/net/wireless/util.c -@@ -557,8 +557,6 @@ int ieee80211_data_to_8023_exthdr(struct +@@ -557,7 +557,7 @@ int ieee80211_data_to_8023_exthdr(struct return -1; hdrlen = ieee80211_hdrlen(hdr->frame_control) + data_offset; - if (skb->len < hdrlen + 8) -- return -1; ++ if (skb->len < hdrlen) + return -1; /* convert IEEE 802.11 header + possible LLC headers into Ethernet - * header -@@ -572,8 +570,9 @@ int ieee80211_data_to_8023_exthdr(struct +@@ -572,8 +572,9 @@ int ieee80211_data_to_8023_exthdr(struct memcpy(tmp.h_dest, ieee80211_get_DA(hdr), ETH_ALEN); memcpy(tmp.h_source, ieee80211_get_SA(hdr), ETH_ALEN); @@ -36,7 +36,7 @@ Signed-off-by: Felix Fietkau mesh_flags &= MESH_FLAGS_AE; -@@ -593,11 +592,12 @@ int ieee80211_data_to_8023_exthdr(struct +@@ -593,11 +594,12 @@ int ieee80211_data_to_8023_exthdr(struct if (iftype == NL80211_IFTYPE_MESH_POINT) { if (mesh_flags == MESH_FLAGS_AE_A4) return -1; @@ -54,7 +54,7 @@ Signed-off-by: Felix Fietkau hdrlen += __ieee80211_get_mesh_hdrlen(mesh_flags); } break; -@@ -611,10 +611,11 @@ int ieee80211_data_to_8023_exthdr(struct +@@ -611,10 +613,11 @@ int ieee80211_data_to_8023_exthdr(struct if (iftype == NL80211_IFTYPE_MESH_POINT) { if (mesh_flags == MESH_FLAGS_AE_A5_A6) return -1; @@ -70,7 +70,7 @@ Signed-off-by: Felix Fietkau hdrlen += __ieee80211_get_mesh_hdrlen(mesh_flags); } break; -@@ -626,18 +627,18 @@ int ieee80211_data_to_8023_exthdr(struct +@@ -626,18 +629,18 @@ int ieee80211_data_to_8023_exthdr(struct break; } @@ -78,12 +78,14 @@ Signed-off-by: Felix Fietkau - tmp.h_proto = payload.proto; - - if (likely((!is_amsdu && ether_addr_equal(payload.hdr, rfc1042_header) && -+ if (likely(skb_copy_bits(skb, hdrlen, &payload, sizeof(payload)) == 0) && -+ likely((!is_amsdu && ether_addr_equal(payload.hdr, rfc1042_header) && - tmp.h_proto != htons(ETH_P_AARP) && - tmp.h_proto != htons(ETH_P_IPX)) || +- tmp.h_proto != htons(ETH_P_AARP) && +- tmp.h_proto != htons(ETH_P_IPX)) || - ether_addr_equal(payload.hdr, bridge_tunnel_header))) -+ ether_addr_equal(payload.hdr, bridge_tunnel_header))) { ++ if (likely(skb_copy_bits(skb, hdrlen, &payload, sizeof(payload)) == 0 && ++ ((!is_amsdu && ether_addr_equal(payload.hdr, rfc1042_header) && ++ payload.proto != htons(ETH_P_AARP) && ++ payload.proto != htons(ETH_P_IPX)) || ++ ether_addr_equal(payload.hdr, bridge_tunnel_header)))) { /* remove RFC1042 or Bridge-Tunnel encapsulation and * replace EtherType */ hdrlen += ETH_ALEN + 2;