diff options
author | Johannes Berg <johannes.berg@intel.com> | 2013-05-28 11:24:15 -0400 |
---|---|---|
committer | Johannes Berg <johannes.berg@intel.com> | 2013-05-29 05:04:48 -0400 |
commit | f4d57941bf89997bad3294f94987caebf2771a33 (patch) | |
tree | 1c5ed489d3113645ebb123b6e862144a636dd620 /net/mac80211 | |
parent | bd5e14fb77d9d1dd15f9102759e8c8b31c667488 (diff) |
mac80211: always send multicast on CAB queue
If the driver advertised support for a CAB queue, then we
should put all multicast frames there, otherwise sending
them can be racy with clients going to sleep while we TX
a frame. To avoid this, always TX multicast frames on the
multicast queue.
It seems like even drivers not using the queue framework
might want to do this which would mean also moving the
IEEE80211_TX_CTL_SEND_AFTER_DTIM flag assignment, but it
also seems that drivers behave differently here so that
just moving it wouldn't be a good idea. It'd be better to
modify those drivers to use the queue framework.
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'net/mac80211')
-rw-r--r-- | net/mac80211/tx.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/net/mac80211/tx.c b/net/mac80211/tx.c index 9972e07a2f96..34be9336b5d1 100644 --- a/net/mac80211/tx.c +++ b/net/mac80211/tx.c | |||
@@ -398,13 +398,14 @@ ieee80211_tx_h_multicast_ps_buf(struct ieee80211_tx_data *tx) | |||
398 | if (ieee80211_has_order(hdr->frame_control)) | 398 | if (ieee80211_has_order(hdr->frame_control)) |
399 | return TX_CONTINUE; | 399 | return TX_CONTINUE; |
400 | 400 | ||
401 | if (tx->local->hw.flags & IEEE80211_HW_QUEUE_CONTROL) | ||
402 | info->hw_queue = tx->sdata->vif.cab_queue; | ||
403 | |||
401 | /* no stations in PS mode */ | 404 | /* no stations in PS mode */ |
402 | if (!atomic_read(&ps->num_sta_ps)) | 405 | if (!atomic_read(&ps->num_sta_ps)) |
403 | return TX_CONTINUE; | 406 | return TX_CONTINUE; |
404 | 407 | ||
405 | info->flags |= IEEE80211_TX_CTL_SEND_AFTER_DTIM; | 408 | info->flags |= IEEE80211_TX_CTL_SEND_AFTER_DTIM; |
406 | if (tx->local->hw.flags & IEEE80211_HW_QUEUE_CONTROL) | ||
407 | info->hw_queue = tx->sdata->vif.cab_queue; | ||
408 | 409 | ||
409 | /* device releases frame after DTIM beacon */ | 410 | /* device releases frame after DTIM beacon */ |
410 | if (!(tx->local->hw.flags & IEEE80211_HW_HOST_BROADCAST_PS_BUFFERING)) | 411 | if (!(tx->local->hw.flags & IEEE80211_HW_HOST_BROADCAST_PS_BUFFERING)) |