2008-06-04 16:16:18 +03:00
|
|
|
--- a/ath/if_ath.c
|
|
|
|
+++ b/ath/if_ath.c
|
2008-11-02 15:04:36 +02:00
|
|
|
@@ -8438,8 +8438,6 @@ process_tx_again:
|
2008-01-28 21:35:38 +02:00
|
|
|
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);
|
|
|
|
}
|
2008-11-02 15:04:36 +02:00
|
|
|
@@ -8486,8 +8484,6 @@ process_tx_again:
|
2008-01-28 21:35:38 +02:00
|
|
|
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);
|
|
|
|
}
|
2008-11-02 15:04:36 +02:00
|
|
|
@@ -8520,8 +8516,6 @@ process_tx_again:
|
2008-01-28 21:35:38 +02:00
|
|
|
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);
|
|
|
|
}
|
2008-06-04 16:16:18 +03:00
|
|
|
--- a/net80211/ieee80211_input.c
|
|
|
|
+++ b/net80211/ieee80211_input.c
|
2008-11-02 15:04:36 +02:00
|
|
|
@@ -1132,7 +1132,7 @@ ieee80211_deliver_data(struct ieee80211_
|
2008-01-29 19:17:04 +02:00
|
|
|
(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)
|