diff options
author | Tomas Winkler <tomas.winkler@intel.com> | 2008-10-24 02:48:51 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2008-10-31 19:02:24 -0400 |
commit | 0ef2ca67b19e2286eed8eeb7ef7a35ce57d6d629 (patch) | |
tree | c19702e83267fe503a790b164290fd2fec1eb6b9 | |
parent | ed7fafec5e566a30fb21586c98cbef76c306d209 (diff) |
iwlwifi: parametrize eeprom versions
This patch uses new parameters eeprom_ver and eeprom_calib_ver
to support additional HW.
Signed-off-by: Tomas Winkler <tomas.winkler@intel.com>
Signed-off-by: Reinette Chatre <reinette.chatre@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-4965.c | 26 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-5000.c | 29 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-core.h | 2 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-eeprom.c | 18 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-eeprom.h | 5 |
5 files changed, 41 insertions, 39 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-4965.c b/drivers/net/wireless/iwlwifi/iwl-4965.c index 741b425b5883..f53cd2b096df 100644 --- a/drivers/net/wireless/iwlwifi/iwl-4965.c +++ b/drivers/net/wireless/iwlwifi/iwl-4965.c | |||
@@ -318,27 +318,9 @@ static int is_fat_channel(__le32 rxon_flags) | |||
318 | /* | 318 | /* |
319 | * EEPROM handlers | 319 | * EEPROM handlers |
320 | */ | 320 | */ |
321 | 321 | static u16 iwl4965_eeprom_calib_version(struct iwl_priv *priv) | |
322 | static int iwl4965_eeprom_check_version(struct iwl_priv *priv) | ||
323 | { | 322 | { |
324 | u16 eeprom_ver; | 323 | return iwl_eeprom_query16(priv, EEPROM_4965_CALIB_VERSION_OFFSET); |
325 | u16 calib_ver; | ||
326 | |||
327 | eeprom_ver = iwl_eeprom_query16(priv, EEPROM_VERSION); | ||
328 | |||
329 | calib_ver = iwl_eeprom_query16(priv, EEPROM_4965_CALIB_VERSION_OFFSET); | ||
330 | |||
331 | if (eeprom_ver < EEPROM_4965_EEPROM_VERSION || | ||
332 | calib_ver < EEPROM_4965_TX_POWER_VERSION) | ||
333 | goto err; | ||
334 | |||
335 | return 0; | ||
336 | err: | ||
337 | IWL_ERROR("Unsuported EEPROM VER=0x%x < 0x%x CALIB=0x%x < 0x%x\n", | ||
338 | eeprom_ver, EEPROM_4965_EEPROM_VERSION, | ||
339 | calib_ver, EEPROM_4965_TX_POWER_VERSION); | ||
340 | return -EINVAL; | ||
341 | |||
342 | } | 324 | } |
343 | 325 | ||
344 | /* | 326 | /* |
@@ -2355,7 +2337,7 @@ static struct iwl_lib_ops iwl4965_lib = { | |||
2355 | .verify_signature = iwlcore_eeprom_verify_signature, | 2337 | .verify_signature = iwlcore_eeprom_verify_signature, |
2356 | .acquire_semaphore = iwlcore_eeprom_acquire_semaphore, | 2338 | .acquire_semaphore = iwlcore_eeprom_acquire_semaphore, |
2357 | .release_semaphore = iwlcore_eeprom_release_semaphore, | 2339 | .release_semaphore = iwlcore_eeprom_release_semaphore, |
2358 | .check_version = iwl4965_eeprom_check_version, | 2340 | .calib_version = iwl4965_eeprom_calib_version, |
2359 | .query_addr = iwlcore_eeprom_query_addr, | 2341 | .query_addr = iwlcore_eeprom_query_addr, |
2360 | }, | 2342 | }, |
2361 | .send_tx_power = iwl4965_send_tx_power, | 2343 | .send_tx_power = iwl4965_send_tx_power, |
@@ -2374,6 +2356,8 @@ struct iwl_cfg iwl4965_agn_cfg = { | |||
2374 | .fw_name = "iwlwifi-4965" IWL4965_UCODE_API ".ucode", | 2356 | .fw_name = "iwlwifi-4965" IWL4965_UCODE_API ".ucode", |
2375 | .sku = IWL_SKU_A|IWL_SKU_G|IWL_SKU_N, | 2357 | .sku = IWL_SKU_A|IWL_SKU_G|IWL_SKU_N, |
2376 | .eeprom_size = IWL4965_EEPROM_IMG_SIZE, | 2358 | .eeprom_size = IWL4965_EEPROM_IMG_SIZE, |
2359 | .eeprom_ver = EEPROM_4965_EEPROM_VERSION, | ||
2360 | .eeprom_calib_ver = EEPROM_4965_TX_POWER_VERSION, | ||
2377 | .ops = &iwl4965_ops, | 2361 | .ops = &iwl4965_ops, |
2378 | .mod_params = &iwl4965_mod_params, | 2362 | .mod_params = &iwl4965_mod_params, |
2379 | }; | 2363 | }; |
diff --git a/drivers/net/wireless/iwlwifi/iwl-5000.c b/drivers/net/wireless/iwlwifi/iwl-5000.c index a8c8c858e209..f3316d488240 100644 --- a/drivers/net/wireless/iwlwifi/iwl-5000.c +++ b/drivers/net/wireless/iwlwifi/iwl-5000.c | |||
@@ -293,30 +293,17 @@ static u32 eeprom_indirect_address(const struct iwl_priv *priv, u32 address) | |||
293 | return (address & ADDRESS_MSK) + (offset << 1); | 293 | return (address & ADDRESS_MSK) + (offset << 1); |
294 | } | 294 | } |
295 | 295 | ||
296 | static int iwl5000_eeprom_check_version(struct iwl_priv *priv) | 296 | static u16 iwl5000_eeprom_calib_version(struct iwl_priv *priv) |
297 | { | 297 | { |
298 | u16 eeprom_ver; | ||
299 | struct iwl_eeprom_calib_hdr { | 298 | struct iwl_eeprom_calib_hdr { |
300 | u8 version; | 299 | u8 version; |
301 | u8 pa_type; | 300 | u8 pa_type; |
302 | u16 voltage; | 301 | u16 voltage; |
303 | } *hdr; | 302 | } *hdr; |
304 | 303 | ||
305 | eeprom_ver = iwl_eeprom_query16(priv, EEPROM_VERSION); | ||
306 | |||
307 | hdr = (struct iwl_eeprom_calib_hdr *)iwl_eeprom_query_addr(priv, | 304 | hdr = (struct iwl_eeprom_calib_hdr *)iwl_eeprom_query_addr(priv, |
308 | EEPROM_5000_CALIB_ALL); | 305 | EEPROM_5000_CALIB_ALL); |
309 | 306 | return hdr->version; | |
310 | if (eeprom_ver < EEPROM_5000_EEPROM_VERSION || | ||
311 | hdr->version < EEPROM_5000_TX_POWER_VERSION) | ||
312 | goto err; | ||
313 | |||
314 | return 0; | ||
315 | err: | ||
316 | IWL_ERROR("Unsuported EEPROM VER=0x%x < 0x%x CALIB=0x%x < 0x%x\n", | ||
317 | eeprom_ver, EEPROM_5000_EEPROM_VERSION, | ||
318 | hdr->version, EEPROM_5000_TX_POWER_VERSION); | ||
319 | return -EINVAL; | ||
320 | 307 | ||
321 | } | 308 | } |
322 | 309 | ||
@@ -1510,7 +1497,7 @@ static struct iwl_lib_ops iwl5000_lib = { | |||
1510 | .verify_signature = iwlcore_eeprom_verify_signature, | 1497 | .verify_signature = iwlcore_eeprom_verify_signature, |
1511 | .acquire_semaphore = iwlcore_eeprom_acquire_semaphore, | 1498 | .acquire_semaphore = iwlcore_eeprom_acquire_semaphore, |
1512 | .release_semaphore = iwlcore_eeprom_release_semaphore, | 1499 | .release_semaphore = iwlcore_eeprom_release_semaphore, |
1513 | .check_version = iwl5000_eeprom_check_version, | 1500 | .calib_version = iwl5000_eeprom_calib_version, |
1514 | .query_addr = iwl5000_eeprom_query_addr, | 1501 | .query_addr = iwl5000_eeprom_query_addr, |
1515 | }, | 1502 | }, |
1516 | }; | 1503 | }; |
@@ -1537,6 +1524,8 @@ struct iwl_cfg iwl5300_agn_cfg = { | |||
1537 | .sku = IWL_SKU_A|IWL_SKU_G|IWL_SKU_N, | 1524 | .sku = IWL_SKU_A|IWL_SKU_G|IWL_SKU_N, |
1538 | .ops = &iwl5000_ops, | 1525 | .ops = &iwl5000_ops, |
1539 | .eeprom_size = IWL_5000_EEPROM_IMG_SIZE, | 1526 | .eeprom_size = IWL_5000_EEPROM_IMG_SIZE, |
1527 | .eeprom_ver = EEPROM_5000_EEPROM_VERSION, | ||
1528 | .eeprom_calib_ver = EEPROM_5000_TX_POWER_VERSION, | ||
1540 | .mod_params = &iwl50_mod_params, | 1529 | .mod_params = &iwl50_mod_params, |
1541 | }; | 1530 | }; |
1542 | 1531 | ||
@@ -1546,6 +1535,8 @@ struct iwl_cfg iwl5100_bg_cfg = { | |||
1546 | .sku = IWL_SKU_G, | 1535 | .sku = IWL_SKU_G, |
1547 | .ops = &iwl5000_ops, | 1536 | .ops = &iwl5000_ops, |
1548 | .eeprom_size = IWL_5000_EEPROM_IMG_SIZE, | 1537 | .eeprom_size = IWL_5000_EEPROM_IMG_SIZE, |
1538 | .eeprom_ver = EEPROM_5000_EEPROM_VERSION, | ||
1539 | .eeprom_calib_ver = EEPROM_5000_TX_POWER_VERSION, | ||
1549 | .mod_params = &iwl50_mod_params, | 1540 | .mod_params = &iwl50_mod_params, |
1550 | }; | 1541 | }; |
1551 | 1542 | ||
@@ -1555,6 +1546,8 @@ struct iwl_cfg iwl5100_abg_cfg = { | |||
1555 | .sku = IWL_SKU_A|IWL_SKU_G, | 1546 | .sku = IWL_SKU_A|IWL_SKU_G, |
1556 | .ops = &iwl5000_ops, | 1547 | .ops = &iwl5000_ops, |
1557 | .eeprom_size = IWL_5000_EEPROM_IMG_SIZE, | 1548 | .eeprom_size = IWL_5000_EEPROM_IMG_SIZE, |
1549 | .eeprom_ver = EEPROM_5000_EEPROM_VERSION, | ||
1550 | .eeprom_calib_ver = EEPROM_5000_TX_POWER_VERSION, | ||
1558 | .mod_params = &iwl50_mod_params, | 1551 | .mod_params = &iwl50_mod_params, |
1559 | }; | 1552 | }; |
1560 | 1553 | ||
@@ -1564,6 +1557,8 @@ struct iwl_cfg iwl5100_agn_cfg = { | |||
1564 | .sku = IWL_SKU_A|IWL_SKU_G|IWL_SKU_N, | 1557 | .sku = IWL_SKU_A|IWL_SKU_G|IWL_SKU_N, |
1565 | .ops = &iwl5000_ops, | 1558 | .ops = &iwl5000_ops, |
1566 | .eeprom_size = IWL_5000_EEPROM_IMG_SIZE, | 1559 | .eeprom_size = IWL_5000_EEPROM_IMG_SIZE, |
1560 | .eeprom_ver = EEPROM_5000_EEPROM_VERSION, | ||
1561 | .eeprom_calib_ver = EEPROM_5000_TX_POWER_VERSION, | ||
1567 | .mod_params = &iwl50_mod_params, | 1562 | .mod_params = &iwl50_mod_params, |
1568 | }; | 1563 | }; |
1569 | 1564 | ||
@@ -1573,6 +1568,8 @@ struct iwl_cfg iwl5350_agn_cfg = { | |||
1573 | .sku = IWL_SKU_A|IWL_SKU_G|IWL_SKU_N, | 1568 | .sku = IWL_SKU_A|IWL_SKU_G|IWL_SKU_N, |
1574 | .ops = &iwl5000_ops, | 1569 | .ops = &iwl5000_ops, |
1575 | .eeprom_size = IWL_5000_EEPROM_IMG_SIZE, | 1570 | .eeprom_size = IWL_5000_EEPROM_IMG_SIZE, |
1571 | .eeprom_ver = EEPROM_5050_EEPROM_VERSION, | ||
1572 | .eeprom_calib_ver = EEPROM_5050_TX_POWER_VERSION, | ||
1576 | .mod_params = &iwl50_mod_params, | 1573 | .mod_params = &iwl50_mod_params, |
1577 | }; | 1574 | }; |
1578 | 1575 | ||
diff --git a/drivers/net/wireless/iwlwifi/iwl-core.h b/drivers/net/wireless/iwlwifi/iwl-core.h index a2d8afe92beb..fb95c6a9825b 100644 --- a/drivers/net/wireless/iwlwifi/iwl-core.h +++ b/drivers/net/wireless/iwlwifi/iwl-core.h | |||
@@ -173,6 +173,8 @@ struct iwl_cfg { | |||
173 | const char *fw_name; | 173 | const char *fw_name; |
174 | unsigned int sku; | 174 | unsigned int sku; |
175 | int eeprom_size; | 175 | int eeprom_size; |
176 | u16 eeprom_ver; | ||
177 | u16 eeprom_calib_ver; | ||
176 | const struct iwl_ops *ops; | 178 | const struct iwl_ops *ops; |
177 | const struct iwl_mod_params *mod_params; | 179 | const struct iwl_mod_params *mod_params; |
178 | }; | 180 | }; |
diff --git a/drivers/net/wireless/iwlwifi/iwl-eeprom.c b/drivers/net/wireless/iwlwifi/iwl-eeprom.c index 37155755efc5..5160b4b0c0de 100644 --- a/drivers/net/wireless/iwlwifi/iwl-eeprom.c +++ b/drivers/net/wireless/iwlwifi/iwl-eeprom.c | |||
@@ -279,7 +279,23 @@ EXPORT_SYMBOL(iwl_eeprom_free); | |||
279 | 279 | ||
280 | int iwl_eeprom_check_version(struct iwl_priv *priv) | 280 | int iwl_eeprom_check_version(struct iwl_priv *priv) |
281 | { | 281 | { |
282 | return priv->cfg->ops->lib->eeprom_ops.check_version(priv); | 282 | u16 eeprom_ver; |
283 | u16 calib_ver; | ||
284 | |||
285 | eeprom_ver = iwl_eeprom_query16(priv, EEPROM_VERSION); | ||
286 | calib_ver = priv->cfg->ops->lib->eeprom_ops.calib_version(priv); | ||
287 | |||
288 | if (eeprom_ver < priv->cfg->eeprom_ver || | ||
289 | calib_ver < priv->cfg->eeprom_calib_ver) | ||
290 | goto err; | ||
291 | |||
292 | return 0; | ||
293 | err: | ||
294 | IWL_ERROR("Unsuported EEPROM VER=0x%x < 0x%x CALIB=0x%x < 0x%x\n", | ||
295 | eeprom_ver, priv->cfg->eeprom_ver, | ||
296 | calib_ver, priv->cfg->eeprom_calib_ver); | ||
297 | return -EINVAL; | ||
298 | |||
283 | } | 299 | } |
284 | EXPORT_SYMBOL(iwl_eeprom_check_version); | 300 | EXPORT_SYMBOL(iwl_eeprom_check_version); |
285 | 301 | ||
diff --git a/drivers/net/wireless/iwlwifi/iwl-eeprom.h b/drivers/net/wireless/iwlwifi/iwl-eeprom.h index d3a2a5b4ac56..997f23c8db2e 100644 --- a/drivers/net/wireless/iwlwifi/iwl-eeprom.h +++ b/drivers/net/wireless/iwlwifi/iwl-eeprom.h | |||
@@ -174,6 +174,9 @@ struct iwl_eeprom_channel { | |||
174 | #define EEPROM_5000_REG_BAND_52_FAT_CHANNELS ((0x92)\ | 174 | #define EEPROM_5000_REG_BAND_52_FAT_CHANNELS ((0x92)\ |
175 | | INDIRECT_ADDRESS | INDIRECT_REGULATORY) /* 22 bytes */ | 175 | | INDIRECT_ADDRESS | INDIRECT_REGULATORY) /* 22 bytes */ |
176 | 176 | ||
177 | /* 5050 Specific */ | ||
178 | #define EEPROM_5050_TX_POWER_VERSION (4) | ||
179 | #define EEPROM_5050_EEPROM_VERSION (0x21E) | ||
177 | 180 | ||
178 | /* 2.4 GHz */ | 181 | /* 2.4 GHz */ |
179 | extern const u8 iwl_eeprom_band_1[14]; | 182 | extern const u8 iwl_eeprom_band_1[14]; |
@@ -371,7 +374,7 @@ struct iwl_eeprom_ops { | |||
371 | int (*verify_signature) (struct iwl_priv *priv); | 374 | int (*verify_signature) (struct iwl_priv *priv); |
372 | int (*acquire_semaphore) (struct iwl_priv *priv); | 375 | int (*acquire_semaphore) (struct iwl_priv *priv); |
373 | void (*release_semaphore) (struct iwl_priv *priv); | 376 | void (*release_semaphore) (struct iwl_priv *priv); |
374 | int (*check_version) (struct iwl_priv *priv); | 377 | u16 (*calib_version) (struct iwl_priv *priv); |
375 | const u8* (*query_addr) (const struct iwl_priv *priv, size_t offset); | 378 | const u8* (*query_addr) (const struct iwl_priv *priv, size_t offset); |
376 | }; | 379 | }; |
377 | 380 | ||