diff options
-rw-r--r-- | drivers/net/wireless/ath9k/hw.c | 8 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/mac.c | 3 |
2 files changed, 9 insertions, 2 deletions
diff --git a/drivers/net/wireless/ath9k/hw.c b/drivers/net/wireless/ath9k/hw.c index 58f94c3f5e9..34474edefc9 100644 --- a/drivers/net/wireless/ath9k/hw.c +++ b/drivers/net/wireless/ath9k/hw.c | |||
@@ -1212,6 +1212,14 @@ struct ath_hal *ath9k_hw_attach(u16 devid, struct ath_softc *sc, | |||
1212 | static void ath9k_hw_override_ini(struct ath_hal *ah, | 1212 | static void ath9k_hw_override_ini(struct ath_hal *ah, |
1213 | struct ath9k_channel *chan) | 1213 | struct ath9k_channel *chan) |
1214 | { | 1214 | { |
1215 | /* | ||
1216 | * Set the RX_ABORT and RX_DIS and clear if off only after | ||
1217 | * RXE is set for MAC. This prevents frames with corrupted | ||
1218 | * descriptor status. | ||
1219 | */ | ||
1220 | REG_SET_BIT(ah, AR_DIAG_SW, (AR_DIAG_RX_DIS | AR_DIAG_RX_ABORT)); | ||
1221 | |||
1222 | |||
1215 | if (!AR_SREV_5416_V20_OR_LATER(ah) || | 1223 | if (!AR_SREV_5416_V20_OR_LATER(ah) || |
1216 | AR_SREV_9280_10_OR_LATER(ah)) | 1224 | AR_SREV_9280_10_OR_LATER(ah)) |
1217 | return; | 1225 | return; |
diff --git a/drivers/net/wireless/ath9k/mac.c b/drivers/net/wireless/ath9k/mac.c index 5254ea49f8a..af32d091dc3 100644 --- a/drivers/net/wireless/ath9k/mac.c +++ b/drivers/net/wireless/ath9k/mac.c | |||
@@ -916,12 +916,11 @@ void ath9k_hw_rxena(struct ath_hal *ah) | |||
916 | 916 | ||
917 | void ath9k_hw_startpcureceive(struct ath_hal *ah) | 917 | void ath9k_hw_startpcureceive(struct ath_hal *ah) |
918 | { | 918 | { |
919 | REG_CLR_BIT(ah, AR_DIAG_SW, (AR_DIAG_RX_DIS | AR_DIAG_RX_ABORT)); | ||
920 | |||
921 | ath9k_enable_mib_counters(ah); | 919 | ath9k_enable_mib_counters(ah); |
922 | 920 | ||
923 | ath9k_ani_reset(ah); | 921 | ath9k_ani_reset(ah); |
924 | 922 | ||
923 | REG_CLR_BIT(ah, AR_DIAG_SW, (AR_DIAG_RX_DIS | AR_DIAG_RX_ABORT)); | ||
925 | } | 924 | } |
926 | 925 | ||
927 | void ath9k_hw_stoppcurecv(struct ath_hal *ah) | 926 | void ath9k_hw_stoppcurecv(struct ath_hal *ah) |