mac80211: fix bugs in queue handling functions
authorJohannes Berg <johannes@sipsolutions.net>
Thu, 15 May 2008 10:55:25 +0000 (12:55 +0200)
committerJohn W. Linville <linville@tuxdriver.com>
Thu, 22 May 2008 01:48:08 +0000 (21:48 -0400)
Commit 55c308c1315bc7267dbb88011c208fd743cdce31
("mac80211: QoS related cleanups") introduced another bug,
the queue handling functions that operate on all queues now
only operated on the first queues, not the A-MPDU queues as
expected. This patch fixes this.

Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
net/mac80211/util.c

index 24a465c4df099aa81dee13ce5f24f53035e2e6f4..9cd07e1031afcdc686ea3f8d5939cf69b288ef88 100644 (file)
@@ -355,7 +355,7 @@ void ieee80211_start_queues(struct ieee80211_hw *hw)
        struct ieee80211_local *local = hw_to_local(hw);
        int i;
 
-       for (i = 0; i < local->hw.queues; i++)
+       for (i = 0; i < hw->queues + hw->ampdu_queues; i++)
                clear_bit(IEEE80211_LINK_STATE_XOFF, &local->state[i]);
        if (!ieee80211_qdisc_installed(local->mdev))
                netif_start_queue(local->mdev);
@@ -366,7 +366,7 @@ void ieee80211_stop_queues(struct ieee80211_hw *hw)
 {
        int i;
 
-       for (i = 0; i < hw->queues; i++)
+       for (i = 0; i < hw->queues + hw->ampdu_queues; i++)
                ieee80211_stop_queue(hw, i);
 }
 EXPORT_SYMBOL(ieee80211_stop_queues);
@@ -375,7 +375,7 @@ void ieee80211_wake_queues(struct ieee80211_hw *hw)
 {
        int i;
 
-       for (i = 0; i < hw->queues; i++)
+       for (i = 0; i < hw->queues + hw->ampdu_queues; i++)
                ieee80211_wake_queue(hw, i);
 }
 EXPORT_SYMBOL(ieee80211_wake_queues);