diff options
author | Felix Fietkau <nbd@openwrt.org> | 2016-01-21 10:34:08 -0500 |
---|---|---|
committer | Kalle Valo <kvalo@qca.qualcomm.com> | 2016-01-25 08:33:25 -0500 |
commit | 65dc1a5d1efb0ec54ffb715468070890d27d63fc (patch) | |
tree | 72843b2b347588a58008509545ca9c70cafc0294 | |
parent | e0045bf80f62779ba75ba04513020d60e59f5298 (diff) |
ath9k_hw: ignore eeprom magic mismatch on flash based devices
Many AR913x based devices (maybe others too) do not have a valid EEPROM
magic in their calibration data partition.
Fixes: 6fa658fd5ab2 ("ath9k: Simplify and fix eeprom endianness swapping")
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
Acked-by: Martin Blumenstingl <martin.blumenstingl@googlemail.com>
Signed-off-by: Kalle Valo <kvalo@qca.qualcomm.com>
-rw-r--r-- | drivers/net/wireless/ath/ath9k/eeprom.c | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/drivers/net/wireless/ath/ath9k/eeprom.c b/drivers/net/wireless/ath/ath9k/eeprom.c index a7afdeee698c..73fb4232f9f2 100644 --- a/drivers/net/wireless/ath/ath9k/eeprom.c +++ b/drivers/net/wireless/ath/ath9k/eeprom.c | |||
@@ -150,18 +150,18 @@ int ath9k_hw_nvram_swap_data(struct ath_hw *ah, bool *swap_needed, int size) | |||
150 | return -EIO; | 150 | return -EIO; |
151 | } | 151 | } |
152 | 152 | ||
153 | if (magic == AR5416_EEPROM_MAGIC) { | 153 | *swap_needed = false; |
154 | *swap_needed = false; | 154 | if (swab16(magic) == AR5416_EEPROM_MAGIC) { |
155 | } else if (swab16(magic) == AR5416_EEPROM_MAGIC) { | ||
156 | if (ah->ah_flags & AH_NO_EEP_SWAP) { | 155 | if (ah->ah_flags & AH_NO_EEP_SWAP) { |
157 | ath_info(common, | 156 | ath_info(common, |
158 | "Ignoring endianness difference in EEPROM magic bytes.\n"); | 157 | "Ignoring endianness difference in EEPROM magic bytes.\n"); |
159 | |||
160 | *swap_needed = false; | ||
161 | } else { | 158 | } else { |
162 | *swap_needed = true; | 159 | *swap_needed = true; |
163 | } | 160 | } |
164 | } else { | 161 | } else if (magic != AR5416_EEPROM_MAGIC) { |
162 | if (ath9k_hw_use_flash(ah)) | ||
163 | return 0; | ||
164 | |||
165 | ath_err(common, | 165 | ath_err(common, |
166 | "Invalid EEPROM Magic (0x%04x).\n", magic); | 166 | "Invalid EEPROM Magic (0x%04x).\n", magic); |
167 | return -EINVAL; | 167 | return -EINVAL; |