From eb55ef86f3319c0f08b72fc8dbac1377c2a1dae2 Mon Sep 17 00:00:00 2001 From: nbd Date: Mon, 11 Jan 2010 05:57:59 +0000 Subject: mac80211: fix some monitor mode queue selection bugs git-svn-id: svn://svn.openwrt.org/openwrt/trunk@19099 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- package/mac80211/patches/590-endian_fix.patch | 15 +++++++++++++++ 1 file changed, 15 insertions(+) create mode 100644 package/mac80211/patches/590-endian_fix.patch (limited to 'package/mac80211/patches/590-endian_fix.patch') 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; -- cgit v1.2.3