aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/wireless/ath9k/main.c87
1 files changed, 41 insertions, 46 deletions
diff --git a/drivers/net/wireless/ath9k/main.c b/drivers/net/wireless/ath9k/main.c
index 756604485532..5cbda9245560 100644
--- a/drivers/net/wireless/ath9k/main.c
+++ b/drivers/net/wireless/ath9k/main.c
@@ -268,61 +268,56 @@ static int ath_set_channel(struct ath_softc *sc, struct ath9k_channel *hchan)
268 if (sc->sc_flags & SC_OP_INVALID) 268 if (sc->sc_flags & SC_OP_INVALID)
269 return -EIO; 269 return -EIO;
270 270
271 if (hchan->channel != sc->sc_ah->ah_curchan->channel || 271 /*
272 hchan->channelFlags != sc->sc_ah->ah_curchan->channelFlags || 272 * This is only performed if the channel settings have
273 (sc->sc_flags & SC_OP_CHAINMASK_UPDATE) || 273 * actually changed.
274 (sc->sc_flags & SC_OP_FULL_RESET)) { 274 *
275 /* 275 * To switch channels clear any pending DMA operations;
276 * This is only performed if the channel settings have 276 * wait long enough for the RX fifo to drain, reset the
277 * actually changed. 277 * hardware at the new frequency, and then re-enable
278 * 278 * the relevant bits of the h/w.
279 * To switch channels clear any pending DMA operations; 279 */
280 * wait long enough for the RX fifo to drain, reset the 280 ath9k_hw_set_interrupts(ah, 0);
281 * hardware at the new frequency, and then re-enable 281 ath_draintxq(sc, false);
282 * the relevant bits of the h/w. 282 stopped = ath_stoprecv(sc);
283 */
284 ath9k_hw_set_interrupts(ah, 0);
285 ath_draintxq(sc, false);
286 stopped = ath_stoprecv(sc);
287 283
288 /* XXX: do not flush receive queue here. We don't want 284 /* XXX: do not flush receive queue here. We don't want
289 * to flush data frames already in queue because of 285 * to flush data frames already in queue because of
290 * changing channel. */ 286 * changing channel. */
291 287
292 if (!stopped || (sc->sc_flags & SC_OP_FULL_RESET)) 288 if (!stopped || (sc->sc_flags & SC_OP_FULL_RESET))
293 fastcc = false; 289 fastcc = false;
294 290
295 DPRINTF(sc, ATH_DBG_CONFIG, 291 DPRINTF(sc, ATH_DBG_CONFIG,
296 "(%u MHz) -> (%u MHz), chanwidth: %d\n", 292 "(%u MHz) -> (%u MHz), chanwidth: %d\n",
297 sc->sc_ah->ah_curchan->channel, 293 sc->sc_ah->ah_curchan->channel,
298 channel->center_freq, sc->tx_chan_width); 294 channel->center_freq, sc->tx_chan_width);
299 295
300 spin_lock_bh(&sc->sc_resetlock); 296 spin_lock_bh(&sc->sc_resetlock);
301 297
302 r = ath9k_hw_reset(ah, hchan, fastcc); 298 r = ath9k_hw_reset(ah, hchan, fastcc);
303 if (r) { 299 if (r) {
304 DPRINTF(sc, ATH_DBG_FATAL, 300 DPRINTF(sc, ATH_DBG_FATAL,
305 "Unable to reset channel (%u Mhz) " 301 "Unable to reset channel (%u Mhz) "
306 "reset status %u\n", 302 "reset status %u\n",
307 channel->center_freq, r); 303 channel->center_freq, r);
308 spin_unlock_bh(&sc->sc_resetlock);
309 return r;
310 }
311 spin_unlock_bh(&sc->sc_resetlock); 304 spin_unlock_bh(&sc->sc_resetlock);
305 return r;
306 }
307 spin_unlock_bh(&sc->sc_resetlock);
312 308
313 sc->sc_flags &= ~SC_OP_CHAINMASK_UPDATE; 309 sc->sc_flags &= ~SC_OP_CHAINMASK_UPDATE;
314 sc->sc_flags &= ~SC_OP_FULL_RESET; 310 sc->sc_flags &= ~SC_OP_FULL_RESET;
315
316 if (ath_startrecv(sc) != 0) {
317 DPRINTF(sc, ATH_DBG_FATAL,
318 "Unable to restart recv logic\n");
319 return -EIO;
320 }
321 311
322 ath_cache_conf_rate(sc, &hw->conf); 312 if (ath_startrecv(sc) != 0) {
323 ath_update_txpow(sc); 313 DPRINTF(sc, ATH_DBG_FATAL,
324 ath9k_hw_set_interrupts(ah, sc->sc_imask); 314 "Unable to restart recv logic\n");
315 return -EIO;
325 } 316 }
317
318 ath_cache_conf_rate(sc, &hw->conf);
319 ath_update_txpow(sc);
320 ath9k_hw_set_interrupts(ah, sc->sc_imask);
326 return 0; 321 return 0;
327} 322}
328 323