ath9k: Pass context to ath9k_chanctx_wake_queues()
authorSujith Manoharan <c_manoha@qca.qualcomm.com>
Thu, 2 Oct 2014 01:03:17 +0000 (06:33 +0530)
committerJohn W. Linville <linville@tuxdriver.com>
Thu, 2 Oct 2014 18:26:32 +0000 (14:26 -0400)
Change the ath9k_chanctx_wake_queues() API so
that we can pass the channel context that needs its
queues to be stopped.

Signed-off-by: Sujith Manoharan <c_manoha@qca.qualcomm.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/ath/ath9k/ath9k.h
drivers/net/wireless/ath/ath9k/channel.c
drivers/net/wireless/ath/ath9k/main.c

index 37a5ccf..4f94d31 100644 (file)
@@ -455,7 +455,7 @@ void ath9k_p2p_bss_info_changed(struct ath_softc *sc,
 void ath9k_beacon_add_noa(struct ath_softc *sc, struct ath_vif *avp,
                          struct sk_buff *skb);
 void ath9k_p2p_ps_timer(void *priv);
-void ath9k_chanctx_wake_queues(struct ath_softc *sc);
+void ath9k_chanctx_wake_queues(struct ath_softc *sc, struct ath_chanctx *ctx);
 void ath_chanctx_check_active(struct ath_softc *sc, struct ath_chanctx *ctx);
 
 void ath_chanctx_beacon_recv_ev(struct ath_softc *sc,
@@ -525,7 +525,8 @@ static inline void ath9k_beacon_add_noa(struct ath_softc *sc, struct ath_vif *av
 static inline void ath9k_p2p_ps_timer(struct ath_softc *sc)
 {
 }
-static inline void ath9k_chanctx_wake_queues(struct ath_softc *sc)
+static inline void ath9k_chanctx_wake_queues(struct ath_softc *sc,
+                                            struct ath_chanctx *ctx)
 {
 }
 static inline void ath_chanctx_check_active(struct ath_softc *sc,
index d088f06..96da03e 100644 (file)
@@ -1177,18 +1177,18 @@ bool ath9k_is_chanctx_enabled(void)
 /* Queue management */
 /********************/
 
-void ath9k_chanctx_wake_queues(struct ath_softc *sc)
+void ath9k_chanctx_wake_queues(struct ath_softc *sc, struct ath_chanctx *ctx)
 {
        struct ath_hw *ah = sc->sc_ah;
        int i;
 
-       if (sc->cur_chan == &sc->offchannel.chan) {
+       if (ctx == &sc->offchannel.chan) {
                ieee80211_wake_queue(sc->hw,
                                     sc->hw->offchannel_tx_hw_queue);
        } else {
                for (i = 0; i < IEEE80211_NUM_ACS; i++)
                        ieee80211_wake_queue(sc->hw,
-                                            sc->cur_chan->hw_queue_base + i);
+                                            ctx->hw_queue_base + i);
        }
 
        if (ah->opmode == NL80211_IFTYPE_AP)
index b4c2642..19bbc91 100644 (file)
@@ -268,7 +268,7 @@ static bool ath_complete_reset(struct ath_softc *sc, bool start)
        if (!ath9k_is_chanctx_enabled())
                ieee80211_wake_queues(sc->hw);
        else
-               ath9k_chanctx_wake_queues(sc);
+               ath9k_chanctx_wake_queues(sc, sc->cur_chan);
 
        ath9k_p2p_ps_timer(sc);