mac80211: debounce queue stop/wake
When the queue status changes we need to do a fair bit of work, so ignore no-op changes early. Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
ded81f6ba9
commit
ada1512526
|
@ -276,6 +276,9 @@ static void __ieee80211_wake_queue(struct ieee80211_hw *hw, int queue,
|
|||
if (WARN_ON(queue >= hw->queues))
|
||||
return;
|
||||
|
||||
if (!test_bit(reason, &local->queue_stop_reasons[queue]))
|
||||
return;
|
||||
|
||||
__clear_bit(reason, &local->queue_stop_reasons[queue]);
|
||||
|
||||
if (local->queue_stop_reasons[queue] != 0)
|
||||
|
@ -323,6 +326,9 @@ static void __ieee80211_stop_queue(struct ieee80211_hw *hw, int queue,
|
|||
if (WARN_ON(queue >= hw->queues))
|
||||
return;
|
||||
|
||||
if (test_bit(reason, &local->queue_stop_reasons[queue]))
|
||||
return;
|
||||
|
||||
__set_bit(reason, &local->queue_stop_reasons[queue]);
|
||||
|
||||
rcu_read_lock();
|
||||
|
|
Loading…
Reference in New Issue