mac80211: refcount aggregation queue stop
mac80211 currently maintains the ampdu_lock to avoid starting a queue due to one aggregation session while another aggregation session needs the queue stopped. We can do better, however, and instead refcount the queue stops for this particular purpose, thus removing the need for the lock. This will help making ampdu_action able to sleep. Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
committed by
John W. Linville
parent
5d22c89b9b
commit
a6a67db2bc
@@ -723,13 +723,7 @@ struct ieee80211_local {
|
||||
struct sk_buff_head pending[IEEE80211_MAX_QUEUES];
|
||||
struct tasklet_struct tx_pending_tasklet;
|
||||
|
||||
/*
|
||||
* This lock is used to prevent concurrent A-MPDU
|
||||
* session start/stop processing, this thus also
|
||||
* synchronises the ->ampdu_action() callback to
|
||||
* drivers and limits it to one at a time.
|
||||
*/
|
||||
spinlock_t ampdu_lock;
|
||||
atomic_t agg_queue_stop[IEEE80211_MAX_QUEUES];
|
||||
|
||||
/* number of interfaces with corresponding IFF_ flags */
|
||||
atomic_t iff_allmultis, iff_promiscs;
|
||||
|
Reference in New Issue
Block a user