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:
Родитель
ded81f6ba9
Коммит
ada1512526
|
@ -276,6 +276,9 @@ static void __ieee80211_wake_queue(struct ieee80211_hw *hw, int queue,
|
||||||
if (WARN_ON(queue >= hw->queues))
|
if (WARN_ON(queue >= hw->queues))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (!test_bit(reason, &local->queue_stop_reasons[queue]))
|
||||||
|
return;
|
||||||
|
|
||||||
__clear_bit(reason, &local->queue_stop_reasons[queue]);
|
__clear_bit(reason, &local->queue_stop_reasons[queue]);
|
||||||
|
|
||||||
if (local->queue_stop_reasons[queue] != 0)
|
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))
|
if (WARN_ON(queue >= hw->queues))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (test_bit(reason, &local->queue_stop_reasons[queue]))
|
||||||
|
return;
|
||||||
|
|
||||||
__set_bit(reason, &local->queue_stop_reasons[queue]);
|
__set_bit(reason, &local->queue_stop_reasons[queue]);
|
||||||
|
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
|
|
Загрузка…
Ссылка в новой задаче