aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless
diff options
context:
space:
mode:
authorSujith Manoharan <Sujith.Manoharan@atheros.com>2011-01-26 11:29:05 -0500
committerJohn W. Linville <linville@tuxdriver.com>2011-01-28 15:44:27 -0500
commit00e0003e0969517c5a447ac3173442dfbdb0613b (patch)
treea82f405a2ac1852d50962c01cf349e3b5d03cec6 /drivers/net/wireless
parent45cbad6a1299842b5ae9a8a9c09630af063692f8 (diff)
ath9k_hw: Fix opmode initialization
Commit "ath9k_hw: Relocate Opmode initialization" moved the opmode initialization before the STA_ID1 register was programmed with defaults. This changed the original behaviour because the re-programming code doesn't take into account the existing value in the register. Both ath9k and ath9k_htc were not affected by this change because the opmode is re-initialized after every reset, when RX is started. Revert to the original behavior, except keep it outside the REGWRITE block. This would help remove extraneous opmode calls in the driver core. Signed-off-by: Sujith Manoharan <Sujith.Manoharan@atheros.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r--drivers/net/wireless/ath/ath9k/hw.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/net/wireless/ath/ath9k/hw.c b/drivers/net/wireless/ath/ath9k/hw.c
index bc92b4579b27..48d121c24eb7 100644
--- a/drivers/net/wireless/ath/ath9k/hw.c
+++ b/drivers/net/wireless/ath/ath9k/hw.c
@@ -1346,8 +1346,6 @@ int ath9k_hw_reset(struct ath_hw *ah, struct ath9k_channel *chan,
1346 ath9k_hw_spur_mitigate_freq(ah, chan); 1346 ath9k_hw_spur_mitigate_freq(ah, chan);
1347 ah->eep_ops->set_board_values(ah, chan); 1347 ah->eep_ops->set_board_values(ah, chan);
1348 1348
1349 ath9k_hw_set_operating_mode(ah, ah->opmode);
1350
1351 ENABLE_REGWRITE_BUFFER(ah); 1349 ENABLE_REGWRITE_BUFFER(ah);
1352 1350
1353 REG_WRITE(ah, AR_STA_ID0, get_unaligned_le32(common->macaddr)); 1351 REG_WRITE(ah, AR_STA_ID0, get_unaligned_le32(common->macaddr));
@@ -1365,6 +1363,8 @@ int ath9k_hw_reset(struct ath_hw *ah, struct ath9k_channel *chan,
1365 1363
1366 REGWRITE_BUFFER_FLUSH(ah); 1364 REGWRITE_BUFFER_FLUSH(ah);
1367 1365
1366 ath9k_hw_set_operating_mode(ah, ah->opmode);
1367
1368 r = ath9k_hw_rf_set_freq(ah, chan); 1368 r = ath9k_hw_rf_set_freq(ah, chan);
1369 if (r) 1369 if (r)
1370 return r; 1370 return r;