aboutsummaryrefslogtreecommitdiffstats
path: root/package/madwifi/patches/111-minstrel_crash.patch
blob: 975bc4e94ac336206732b8f4c66fc86ee35f073f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
--- a/ath_rate/minstrel/minstrel.c
+++ b/ath_rate/minstrel/minstrel.c
@@ -393,6 +393,9 @@ ath_rate_get_mrr(struct ath_softc *sc, s
 		struct minstrel_node *sn = ATH_NODE_MINSTREL(an);
 		int rc1, rc2, rc3;         /* Index into the rate table, so for example, it is  0..11 */
 
+		if (sn->num_rates <= 0)
+			return;
+
 		if (sn->is_sampling) {
 			sn->is_sampling = 0;
 			if (sn->rs_sample_rate_slower)
ss="gu">@@ -8438,8 +8438,6 @@ process_tx_again: 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); } @@ -8486,8 +8484,6 @@ process_tx_again: 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); } @@ -8520,8 +8516,6 @@ process_tx_again: 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 @@ ieee80211_deliver_data(struct ieee80211_ (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)