summaryrefslogtreecommitdiffstats
path: root/package/madwifi/patches-r3776/306-queue.patch
diff options
context:
space:
mode:
authornbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73>2008-07-17 02:30:08 +0000
committernbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73>2008-07-17 02:30:08 +0000
commit613e530afeab2eb78d7b4100420fd305662beab1 (patch)
tree547d05d8319b3931a4fa1e5b1a5cbd543af52361 /package/madwifi/patches-r3776/306-queue.patch
parent0e9ca337996b5b4ef392bc92cde7f4bc9699b3ea (diff)
huge madwifi update (work in progress, disabled by default, compiles but breaks at run time)
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@11851 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/madwifi/patches-r3776/306-queue.patch')
-rw-r--r--package/madwifi/patches-r3776/306-queue.patch46
1 files changed, 46 insertions, 0 deletions
diff --git a/package/madwifi/patches-r3776/306-queue.patch b/package/madwifi/patches-r3776/306-queue.patch
new file mode 100644
index 000000000..4b9665f99
--- /dev/null
+++ b/package/madwifi/patches-r3776/306-queue.patch
@@ -0,0 +1,46 @@
+Index: madwifi-trunk-r3776/ath/if_ath.c
+===================================================================
+--- madwifi-trunk-r3776.orig/ath/if_ath.c 2008-07-17 02:00:09.000000000 +0200
++++ madwifi-trunk-r3776/ath/if_ath.c 2008-07-17 02:09:38.000000000 +0200
+@@ -8447,8 +8447,6 @@
+ ath_hal_intrset(sc->sc_ah, sc->sc_imask);
+ local_irq_restore(flags);
+
+- netif_wake_queue(dev);
+-
+ if (sc->sc_softled)
+ ath_led_event(sc, ATH_LED_TX);
+ }
+@@ -8504,8 +8502,6 @@
+ ath_hal_intrset(sc->sc_ah, sc->sc_imask);
+ local_irq_restore(flags);
+
+- netif_wake_queue(dev);
+-
+ if (sc->sc_softled)
+ ath_led_event(sc, ATH_LED_TX);
+ }
+@@ -8536,7 +8532,9 @@
+ STAILQ_FIRST(&sc->sc_cabq->axq_q) ? "not setup" : "empty");
+ }
+ }
+- netif_wake_queue(dev);
++
++ if (ath_get_buffers_available(sc) > ATH_TXBUF_MGT_RESERVED)
++ netif_wake_queue(dev);
+
+ if (sc->sc_softled)
+ ath_led_event(sc, ATH_LED_TX);
+Index: madwifi-trunk-r3776/net80211/ieee80211_input.c
+===================================================================
+--- madwifi-trunk-r3776.orig/net80211/ieee80211_input.c 2008-07-17 02:04:20.000000000 +0200
++++ madwifi-trunk-r3776/net80211/ieee80211_input.c 2008-07-17 02:05:45.000000000 +0200
+@@ -1116,7 +1116,7 @@
+ (vap->iv_flags & IEEE80211_F_NOBRIDGE) == 0) {
+ struct sk_buff *skb1 = NULL;
+
+- if (ETHER_IS_MULTICAST(eh->ether_dhost)) {
++ if (ETHER_IS_MULTICAST(eh->ether_dhost) && !netif_queue_stopped(dev)) {
+ /* Create a SKB for the BSS to send out. */
+ skb1 = skb_copy(skb, GFP_ATOMIC);
+ if (skb1)