diff options
Diffstat (limited to 'drivers/net/wireless/ath/ath5k/base.c')
| -rw-r--r-- | drivers/net/wireless/ath/ath5k/base.c | 57 | 
1 files changed, 24 insertions, 33 deletions
| diff --git a/drivers/net/wireless/ath/ath5k/base.c b/drivers/net/wireless/ath/ath5k/base.c index 029c1bc7468f..753f50e8d84f 100644 --- a/drivers/net/wireless/ath/ath5k/base.c +++ b/drivers/net/wireless/ath/ath5k/base.c @@ -666,7 +666,6 @@ ath5k_pci_suspend(struct pci_dev *pdev, pm_message_t state)  	ath5k_led_off(sc); -	free_irq(pdev->irq, sc);  	pci_save_state(pdev);  	pci_disable_device(pdev);  	pci_set_power_state(pdev, PCI_D3hot); @@ -694,18 +693,8 @@ ath5k_pci_resume(struct pci_dev *pdev)  	 */  	pci_write_config_byte(pdev, 0x41, 0); -	err = request_irq(pdev->irq, ath5k_intr, IRQF_SHARED, "ath", sc); -	if (err) { -		ATH5K_ERR(sc, "request_irq failed\n"); -		goto err_no_irq; -	} -  	ath5k_led_enable(sc);  	return 0; - -err_no_irq: -	pci_disable_device(pdev); -	return err;  }  #endif /* CONFIG_PM */ @@ -2445,27 +2434,29 @@ ath5k_stop_hw(struct ath5k_softc *sc)  	ret = ath5k_stop_locked(sc);  	if (ret == 0 && !test_bit(ATH_STAT_INVALID, sc->status)) {  		/* -		 * Set the chip in full sleep mode.  Note that we are -		 * careful to do this only when bringing the interface -		 * completely to a stop.  When the chip is in this state -		 * it must be carefully woken up or references to -		 * registers in the PCI clock domain may freeze the bus -		 * (and system).  This varies by chip and is mostly an -		 * issue with newer parts that go to sleep more quickly. -		 */ -		if (sc->ah->ah_mac_srev >= 0x78) { -			/* -			 * XXX -			 * don't put newer MAC revisions > 7.8 to sleep because -			 * of the above mentioned problems -			 */ -			ATH5K_DBG(sc, ATH5K_DEBUG_RESET, "mac version > 7.8, " -				"not putting device to sleep\n"); -		} else { -			ATH5K_DBG(sc, ATH5K_DEBUG_RESET, -				"putting device to full sleep\n"); -			ath5k_hw_set_power(sc->ah, AR5K_PM_FULL_SLEEP, true, 0); -		} +		 * Don't set the card in full sleep mode! +		 * +		 * a) When the device is in this state it must be carefully +		 * woken up or references to registers in the PCI clock +		 * domain may freeze the bus (and system).  This varies +		 * by chip and is mostly an issue with newer parts +		 * (madwifi sources mentioned srev >= 0x78) that go to +		 * sleep more quickly. +		 * +		 * b) On older chips full sleep results a weird behaviour +		 * during wakeup. I tested various cards with srev < 0x78 +		 * and they don't wake up after module reload, a second +		 * module reload is needed to bring the card up again. +		 * +		 * Until we figure out what's going on don't enable +		 * full chip reset on any chip (this is what Legacy HAL +		 * and Sam's HAL do anyway). Instead Perform a full reset +		 * on the device (same as initial state after attach) and +		 * leave it idle (keep MAC/BB on warm reset) */ +		ret = ath5k_hw_on_hold(sc->ah); + +		ATH5K_DBG(sc, ATH5K_DEBUG_RESET, +				"putting device to sleep\n");  	}  	ath5k_txbuf_free(sc, sc->bbuf); @@ -2676,7 +2667,7 @@ ath5k_reset(struct ath5k_softc *sc, struct ieee80211_channel *chan)  		sc->curchan = chan;  		sc->curband = &sc->sbands[chan->band];  	} -	ret = ath5k_hw_reset(ah, sc->opmode, sc->curchan, true); +	ret = ath5k_hw_reset(ah, sc->opmode, sc->curchan, chan != NULL);  	if (ret) {  		ATH5K_ERR(sc, "can't reset hardware (%d)\n", ret);  		goto err; | 
