ath5k: Always set IFS intervals on reset
authorNick Kossifidis <mickflemm@gmail.com>
Tue, 23 Nov 2010 19:24:54 +0000 (21:24 +0200)
committerJohn W. Linville <linville@tuxdriver.com>
Tue, 30 Nov 2010 18:53:22 +0000 (13:53 -0500)
 * Make sure we always set IFS timings even if no
 coverage class is set. If we don't we'll miss the
 needed changes for different bwmodes.

Signed-off-by: Nick Kossifidis <mickflemm@gmail.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/ath/ath5k/ath5k.h
drivers/net/wireless/ath/ath5k/pcu.c
drivers/net/wireless/ath/ath5k/qcu.c

index ddbbf4c02fe126c66b5643742d0b21957b84ce5a..e2588308e6774f03717f93056190bd9001aced0f 100644 (file)
@@ -1224,6 +1224,7 @@ int ath5k_eeprom_read_mac(struct ath5k_hw *ah, u8 *mac);
 /* Helpers */
 int ath5k_hw_get_frame_duration(struct ath5k_hw *ah,
                int len, struct ieee80211_rate *rate);
+unsigned int ath5k_hw_get_default_slottime(struct ath5k_hw *ah);
 unsigned int ath5k_hw_get_default_sifs(struct ath5k_hw *ah);
 extern int ath5k_hw_set_opmode(struct ath5k_hw *ah, enum nl80211_iftype opmode);
 void ath5k_hw_set_coverage_class(struct ath5k_hw *ah, u8 coverage_class);
index 6af9504cc7f83e213003ee894fde097212c2bcbd..e5f2b96a4c63621cfd1ab41156f6f93d1a352a25 100644 (file)
@@ -129,7 +129,7 @@ int ath5k_hw_get_frame_duration(struct ath5k_hw *ah,
  *
  * @ah: The &struct ath5k_hw
  */
-static unsigned int ath5k_hw_get_default_slottime(struct ath5k_hw *ah)
+unsigned int ath5k_hw_get_default_slottime(struct ath5k_hw *ah)
 {
        struct ieee80211_channel *channel = ah->ah_current_channel;
        unsigned int slot_time;
index 69bff047a49a73dba066e7a712ce36e4aaed93f3..1849eee8235c6aab94c945a4d7b3077aeb70ae5a 100644 (file)
@@ -652,5 +652,13 @@ int ath5k_hw_init_queues(struct ath5k_hw *ah)
                AR5K_REG_ENABLE_BITS(ah, AR5K_DCU_GBL_IFS_MISC,
                                AR5K_DCU_GBL_IFS_MISC_TURBO_MODE);
 
+       /* If we didn't set IFS timings through
+        * ath5k_hw_set_coverage_class make sure
+        * we set them here */
+       if (!ah->ah_coverage_class) {
+               unsigned int slot_time = ath5k_hw_get_default_slottime(ah);
+               ath5k_hw_set_ifs_intervals(ah, slot_time);
+       }
+
        return 0;
 }