summaryrefslogtreecommitdiff
path: root/drivers/net/wireless/ath/ath9k
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2014-06-11 14:48:00 +0400
committerJohn W. Linville <linville@tuxdriver.com>2014-06-19 23:49:18 +0400
commit26f16c246cea41f30ab2f63214a5529678677d0d (patch)
tree6956ba03c110a9804c8a0909e7b178402158a5c5 /drivers/net/wireless/ath/ath9k
parentb01459e856cbe9ccf64dde251aec02eae60094ce (diff)
downloadlinux-26f16c246cea41f30ab2f63214a5529678677d0d.tar.xz
ath9k: Add ATH_OP_MULTI_CHANNEL
Signed-off-by: Felix Fietkau <nbd@openwrt.org> Signed-off-by: Rajkumar Manoharan <rmanohar@qti.qualcomm.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/ath/ath9k')
-rw-r--r--drivers/net/wireless/ath/ath9k/channel.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/drivers/net/wireless/ath/ath9k/channel.c b/drivers/net/wireless/ath/ath9k/channel.c
index 097207073cd4..e3127b52e1ee 100644
--- a/drivers/net/wireless/ath/ath9k/channel.c
+++ b/drivers/net/wireless/ath/ath9k/channel.c
@@ -150,8 +150,10 @@ ath_chanctx_send_vif_ps_frame(struct ath_softc *sc, struct ath_vif *avp,
void ath_chanctx_check_active(struct ath_softc *sc, struct ath_chanctx *ctx)
{
+ struct ath_common *common = ath9k_hw_common(sc->sc_ah);
struct ath_vif *avp;
bool active = false;
+ u8 n_active = 0;
if (!ctx)
return;
@@ -171,6 +173,17 @@ void ath_chanctx_check_active(struct ath_softc *sc, struct ath_chanctx *ctx)
}
}
ctx->active = active;
+
+ ath_for_each_chanctx(sc, ctx) {
+ if (!ctx->assigned || list_empty(&ctx->vifs))
+ continue;
+ n_active++;
+ }
+
+ if (n_active > 1)
+ set_bit(ATH_OP_MULTI_CHANNEL, &common->op_flags);
+ else
+ clear_bit(ATH_OP_MULTI_CHANNEL, &common->op_flags);
}
static bool