Commit 7fda1666 authored by Luis R. Rodriguez's avatar Luis R. Rodriguez Committed by John W. Linville

ath9k: add helper to un-init the hw properly

This is used in several places, ensure we do it right in all
callers by using a helper.
Signed-off-by: default avatarLuis R. Rodriguez <lrodriguez@atheros.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 211f5859
...@@ -1325,6 +1325,17 @@ void ath_cleanup(struct ath_softc *sc) ...@@ -1325,6 +1325,17 @@ void ath_cleanup(struct ath_softc *sc)
ieee80211_free_hw(sc->hw); ieee80211_free_hw(sc->hw);
} }
static void ath9k_uninit_hw(struct ath_softc *sc)
{
struct ath_hw *ah = sc->sc_ah;
BUG_ON(!ah);
ath9k_exit_debug(ah);
ath9k_hw_detach(ah);
sc->sc_ah = NULL;
}
void ath_detach(struct ath_softc *sc) void ath_detach(struct ath_softc *sc)
{ {
struct ieee80211_hw *hw = sc->hw; struct ieee80211_hw *hw = sc->hw;
...@@ -1365,9 +1376,7 @@ void ath_detach(struct ath_softc *sc) ...@@ -1365,9 +1376,7 @@ void ath_detach(struct ath_softc *sc)
ah->btcoex_hw.scheme == ATH_BTCOEX_CFG_3WIRE) ah->btcoex_hw.scheme == ATH_BTCOEX_CFG_3WIRE)
ath_gen_timer_free(ah, sc->btcoex.no_stomp_timer); ath_gen_timer_free(ah, sc->btcoex.no_stomp_timer);
ath9k_exit_debug(ah); ath9k_uninit_hw(sc);
ath9k_hw_detach(ah);
sc->sc_ah = NULL;
} }
static int ath9k_reg_notifier(struct wiphy *wiphy, static int ath9k_reg_notifier(struct wiphy *wiphy,
...@@ -1850,10 +1859,8 @@ static int ath_init_softc(u16 devid, struct ath_softc *sc, u16 subsysid, ...@@ -1850,10 +1859,8 @@ static int ath_init_softc(u16 devid, struct ath_softc *sc, u16 subsysid,
if (ATH_TXQ_SETUP(sc, i)) if (ATH_TXQ_SETUP(sc, i))
ath_tx_cleanupq(sc, &sc->tx.txq[i]); ath_tx_cleanupq(sc, &sc->tx.txq[i]);
ath9k_exit_debug(ah);
bad_free_hw: bad_free_hw:
ath9k_hw_detach(ah); ath9k_uninit_hw(sc);
sc->sc_ah = NULL;
return r; return r;
} }
...@@ -1966,9 +1973,7 @@ int ath_init_device(u16 devid, struct ath_softc *sc, u16 subsysid, ...@@ -1966,9 +1973,7 @@ int ath_init_device(u16 devid, struct ath_softc *sc, u16 subsysid,
if (ATH_TXQ_SETUP(sc, i)) if (ATH_TXQ_SETUP(sc, i))
ath_tx_cleanupq(sc, &sc->tx.txq[i]); ath_tx_cleanupq(sc, &sc->tx.txq[i]);
ath9k_exit_debug(ah); ath9k_uninit_hw(sc);
ath9k_hw_detach(ah);
sc->sc_ah = NULL;
return error; return error;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment