summaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorSujith Manoharan <c_manoha@qca.qualcomm.com>2014-09-05 09:50:56 +0530
committerJohn W. Linville <linville@tuxdriver.com>2014-09-09 15:27:22 -0400
commitda0162f3f0012465cc6d77c4d416fabb182713ad (patch)
tree69653c915409e0fe380517685950384f0267ef1e /drivers
parenta402764452672dfe119e68edf7a21f1739b71f76 (diff)
downloadlinux-da0162f3f0012465cc6d77c4d416fabb182713ad.tar.gz
linux-da0162f3f0012465cc6d77c4d416fabb182713ad.tar.bz2
linux-da0162f3f0012465cc6d77c4d416fabb182713ad.zip
ath9k: Fix offchannel operation
When multiple channel contexts are active, an offchannel request will not be handled immediately, but will be queued to be handled later. But, currently, the channel definition is not copied to the local offchannel state. This breaks operation like scanning when MCC is active. Fix this by storing the offchannel parameters properly. Signed-off-by: Sujith Manoharan <c_manoha@qca.qualcomm.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/wireless/ath/ath9k/channel.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/drivers/net/wireless/ath/ath9k/channel.c b/drivers/net/wireless/ath/ath9k/channel.c
index e73d305ea1e4..a31f526ba852 100644
--- a/drivers/net/wireless/ath/ath9k/channel.c
+++ b/drivers/net/wireless/ath/ath9k/channel.c
@@ -588,7 +588,11 @@ static void ath_chanctx_switch(struct ath_softc *sc, struct ath_chanctx *ctx,
if (test_bit(ATH_OP_MULTI_CHANNEL, &common->op_flags) &&
(sc->cur_chan != ctx) && (ctx == &sc->offchannel.chan)) {
sc->sched.offchannel_pending = true;
+ if (chandef)
+ ctx->chandef = *chandef;
spin_unlock_bh(&sc->chan_lock);
+ ath_dbg(common, CHAN_CTX,
+ "Set offchannel_pending to true\n");
return;
}