mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-11-04 06:54:27 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			41 lines
		
	
	
		
			980 B
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			980 B
		
	
	
	
		
			Diff
		
	
	
	
	
	
--- a/ath/if_ath.c
 | 
						|
+++ b/ath/if_ath.c
 | 
						|
@@ -8431,8 +8431,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);
 | 
						|
 }
 | 
						|
@@ -8479,8 +8477,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);
 | 
						|
 }
 | 
						|
@@ -8513,8 +8509,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);
 | 
						|
 }
 | 
						|
--- a/net80211/ieee80211_input.c
 | 
						|
+++ b/net80211/ieee80211_input.c
 | 
						|
@@ -1132,7 +1132,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)
 |