mac80211: add specific-queue flushing support
If the HW supports IEEE80211_HW_QUEUE_CONTROL, allow flushing only specific queues rather than all of them. Signed-off-by: Liad Kaufman <liad.kaufman@intel.com> Signed-off-by: Arik Nemtsov <arik@wizery.com> Signed-off-by: Johannes Berg <johannes.berg@intel.com>
This commit is contained in:
parent
8a4d32f30d
commit
4f9610d528
|
@ -1881,6 +1881,9 @@ void ieee80211_add_pending_skbs(struct ieee80211_local *local,
|
||||||
struct sk_buff_head *skbs);
|
struct sk_buff_head *skbs);
|
||||||
void ieee80211_flush_queues(struct ieee80211_local *local,
|
void ieee80211_flush_queues(struct ieee80211_local *local,
|
||||||
struct ieee80211_sub_if_data *sdata);
|
struct ieee80211_sub_if_data *sdata);
|
||||||
|
void __ieee80211_flush_queues(struct ieee80211_local *local,
|
||||||
|
struct ieee80211_sub_if_data *sdata,
|
||||||
|
unsigned int queues);
|
||||||
|
|
||||||
void ieee80211_send_auth(struct ieee80211_sub_if_data *sdata,
|
void ieee80211_send_auth(struct ieee80211_sub_if_data *sdata,
|
||||||
u16 transaction, u16 auth_alg, u16 status,
|
u16 transaction, u16 auth_alg, u16 status,
|
||||||
|
|
|
@ -576,15 +576,19 @@ ieee80211_get_vif_queues(struct ieee80211_local *local,
|
||||||
return queues;
|
return queues;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ieee80211_flush_queues(struct ieee80211_local *local,
|
void __ieee80211_flush_queues(struct ieee80211_local *local,
|
||||||
struct ieee80211_sub_if_data *sdata)
|
struct ieee80211_sub_if_data *sdata,
|
||||||
|
unsigned int queues)
|
||||||
{
|
{
|
||||||
unsigned int queues;
|
|
||||||
|
|
||||||
if (!local->ops->flush)
|
if (!local->ops->flush)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
queues = ieee80211_get_vif_queues(local, sdata);
|
/*
|
||||||
|
* If no queue was set, or if the HW doesn't support
|
||||||
|
* IEEE80211_HW_QUEUE_CONTROL - flush all queues
|
||||||
|
*/
|
||||||
|
if (!queues || !(local->hw.flags & IEEE80211_HW_QUEUE_CONTROL))
|
||||||
|
queues = ieee80211_get_vif_queues(local, sdata);
|
||||||
|
|
||||||
ieee80211_stop_queues_by_reason(&local->hw, queues,
|
ieee80211_stop_queues_by_reason(&local->hw, queues,
|
||||||
IEEE80211_QUEUE_STOP_REASON_FLUSH,
|
IEEE80211_QUEUE_STOP_REASON_FLUSH,
|
||||||
|
@ -597,6 +601,12 @@ void ieee80211_flush_queues(struct ieee80211_local *local,
|
||||||
false);
|
false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ieee80211_flush_queues(struct ieee80211_local *local,
|
||||||
|
struct ieee80211_sub_if_data *sdata)
|
||||||
|
{
|
||||||
|
__ieee80211_flush_queues(local, sdata, 0);
|
||||||
|
}
|
||||||
|
|
||||||
void ieee80211_stop_vif_queues(struct ieee80211_local *local,
|
void ieee80211_stop_vif_queues(struct ieee80211_local *local,
|
||||||
struct ieee80211_sub_if_data *sdata,
|
struct ieee80211_sub_if_data *sdata,
|
||||||
enum queue_stop_reason reason)
|
enum queue_stop_reason reason)
|
||||||
|
|
Loading…
Reference in New Issue