diff options
author | nbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2010-01-11 05:57:59 +0000 |
---|---|---|
committer | nbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2010-01-11 05:57:59 +0000 |
commit | eb55ef86f3319c0f08b72fc8dbac1377c2a1dae2 (patch) | |
tree | 3abc1195ccbd2a5b54a6c2ee5e7a57dad31c3148 /package/mac80211/patches/590-endian_fix.patch | |
parent | 809c03fe4c0f90c640b26e6a2792553b592c68f2 (diff) |
mac80211: fix some monitor mode queue selection bugs
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@19099 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/mac80211/patches/590-endian_fix.patch')
-rw-r--r-- | package/mac80211/patches/590-endian_fix.patch | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/package/mac80211/patches/590-endian_fix.patch b/package/mac80211/patches/590-endian_fix.patch new file mode 100644 index 000000000..9381a6f43 --- /dev/null +++ b/package/mac80211/patches/590-endian_fix.patch @@ -0,0 +1,15 @@ +--- a/net/mac80211/iface.c ++++ b/net/mac80211/iface.c +@@ -690,10 +690,10 @@ static u16 ieee80211_monitor_select_queu + return 0; + + if (skb->len < 4 || +- skb->len < rtap->it_len + 2 /* frame control */) ++ skb->len < le16_to_cpu(rtap->it_len) + 2 /* frame control */) + return 0; /* doesn't matter, frame will be dropped */ + +- hdr = (void *)((u8 *)skb->data + rtap->it_len); ++ hdr = (void *)((u8 *)skb->data + le16_to_cpu(rtap->it_len)); + + if (!ieee80211_is_data(hdr->frame_control)) { + skb->priority = 7; |