diff options
author | Felix Fietkau <nbd@nbd.name> | 2016-08-28 13:10:37 +0200 |
---|---|---|
committer | Johannes Berg <johannes.berg@intel.com> | 2016-09-12 11:54:42 +0200 |
commit | 83843c80dcf11a78995d167255b03072a1e49c2c (patch) | |
tree | f9dfd841ddb98caeaf08fded9b89845d833c31c0 /net | |
parent | Merge tag 'mac80211-for-davem-2016-08-30' of git://git.kernel.org/pub/scm/lin... (diff) | |
download | linux-83843c80dcf11a78995d167255b03072a1e49c2c.tar.xz linux-83843c80dcf11a78995d167255b03072a1e49c2c.zip |
mac80211: fix tim recalculation after PS response
Handle the case where the mac80211 intermediate queues are empty and the
driver has buffered frames
Fixes: ba8c3d6f16a1 ("mac80211: add an intermediate software queue implementation")
Signed-off-by: Felix Fietkau <nbd@nbd.name>
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'net')
-rw-r--r-- | net/mac80211/sta_info.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/net/mac80211/sta_info.c b/net/mac80211/sta_info.c index 76b737dcc36f..aa58df80ede0 100644 --- a/net/mac80211/sta_info.c +++ b/net/mac80211/sta_info.c @@ -1616,7 +1616,6 @@ ieee80211_sta_ps_deliver_response(struct sta_info *sta, sta_info_recalc_tim(sta); } else { - unsigned long tids = sta->txq_buffered_tids & driver_release_tids; int tid; /* @@ -1648,7 +1647,8 @@ ieee80211_sta_ps_deliver_response(struct sta_info *sta, for (tid = 0; tid < ARRAY_SIZE(sta->sta.txq); tid++) { struct txq_info *txqi = to_txq_info(sta->sta.txq[tid]); - if (!(tids & BIT(tid)) || txqi->tin.backlog_packets) + if (!(driver_release_tids & BIT(tid)) || + txqi->tin.backlog_packets) continue; sta_info_recalc_tim(sta); |