From 5ce2341a03263daa1a09bb86e302591bb6516719 Mon Sep 17 00:00:00 2001 From: Felix Fietkau Date: Mon, 11 Jul 2016 15:10:58 +0200 Subject: [PATCH] mac80211: fix a powersave issue in the intermediate queueing code Signed-off-by: Felix Fietkau --- ...ck-for-buffered-powersave-frames-wit.patch | 21 +++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 package/kernel/mac80211/patches/329-mac80211-fix-check-for-buffered-powersave-frames-wit.patch diff --git a/package/kernel/mac80211/patches/329-mac80211-fix-check-for-buffered-powersave-frames-wit.patch b/package/kernel/mac80211/patches/329-mac80211-fix-check-for-buffered-powersave-frames-wit.patch new file mode 100644 index 00000000000..38e541c7150 --- /dev/null +++ b/package/kernel/mac80211/patches/329-mac80211-fix-check-for-buffered-powersave-frames-wit.patch @@ -0,0 +1,21 @@ +From: Felix Fietkau +Date: Mon, 11 Jul 2016 15:07:06 +0200 +Subject: [PATCH] mac80211: fix check for buffered powersave frames with txq + +The logic was inverted here, set the bit if frames are pending. + +Fixes: ba8c3d6f16a1 ("mac80211: add an intermediate software queue implementation") +Signed-off-by: Felix Fietkau +--- + +--- a/net/mac80211/rx.c ++++ b/net/mac80211/rx.c +@@ -1268,7 +1268,7 @@ static void sta_ps_start(struct sta_info + for (tid = 0; tid < ARRAY_SIZE(sta->sta.txq); tid++) { + struct txq_info *txqi = to_txq_info(sta->sta.txq[tid]); + +- if (!txqi->tin.backlog_packets) ++ if (txqi->tin.backlog_packets) + set_bit(tid, &sta->txq_buffered_tids); + else + clear_bit(tid, &sta->txq_buffered_tids); -- 2.30.2