aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/iwlwifi
diff options
context:
space:
mode:
authorJohn W. Linville <linville@tuxdriver.com>2010-04-12 15:20:53 -0400
committerJohn W. Linville <linville@tuxdriver.com>2010-04-12 15:20:53 -0400
commitb1f90866fb3a329b1c4ebfff93ae9c110943e50a (patch)
tree9c765f6d21c8cad4906a2d1eb1b26f4f9842a3d6 /drivers/net/wireless/iwlwifi
parent68dd5b7a45d1935fcd32b786e8d3d3f7bb4bbfe7 (diff)
parent470058e0ad82fcfaaffd57307d8bf8c094e8e9d7 (diff)
Merge branch 'wireless-next-2.6' of git://git.kernel.org/pub/scm/linux/kernel/git/iwlwifi/iwlwifi-2.6
Diffstat (limited to 'drivers/net/wireless/iwlwifi')
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-1000.c2
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-3945-rs.c2
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-3945.c10
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-4965.c4
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-5000.c7
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-6000.c7
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-agn-lib.c32
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-agn-rs.c2
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-agn-tx.c39
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-agn.c59
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-agn.h27
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-commands.h108
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-core.h1
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-dev.h5
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-sta.c35
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-sta.h2
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-tx.c61
-rw-r--r--drivers/net/wireless/iwlwifi/iwl3945-base.c15
18 files changed, 274 insertions, 144 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-1000.c b/drivers/net/wireless/iwlwifi/iwl-1000.c
index b941b3e95697..9a0191a5ea35 100644
--- a/drivers/net/wireless/iwlwifi/iwl-1000.c
+++ b/drivers/net/wireless/iwlwifi/iwl-1000.c
@@ -253,6 +253,7 @@ struct iwl_cfg iwl1000_bgn_cfg = {
253 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_EXT_LONG_THRESHOLD_DEF, 253 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_EXT_LONG_THRESHOLD_DEF,
254 .chain_noise_scale = 1000, 254 .chain_noise_scale = 1000,
255 .monitor_recover_period = IWL_MONITORING_PERIOD, 255 .monitor_recover_period = IWL_MONITORING_PERIOD,
256 .max_event_log_size = 128,
256}; 257};
257 258
258struct iwl_cfg iwl1000_bg_cfg = { 259struct iwl_cfg iwl1000_bg_cfg = {
@@ -282,6 +283,7 @@ struct iwl_cfg iwl1000_bg_cfg = {
282 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_EXT_LONG_THRESHOLD_DEF, 283 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_EXT_LONG_THRESHOLD_DEF,
283 .chain_noise_scale = 1000, 284 .chain_noise_scale = 1000,
284 .monitor_recover_period = IWL_MONITORING_PERIOD, 285 .monitor_recover_period = IWL_MONITORING_PERIOD,
286 .max_event_log_size = 128,
285}; 287};
286 288
287MODULE_FIRMWARE(IWL1000_MODULE_FIRMWARE(IWL1000_UCODE_API_MAX)); 289MODULE_FIRMWARE(IWL1000_MODULE_FIRMWARE(IWL1000_UCODE_API_MAX));
diff --git a/drivers/net/wireless/iwlwifi/iwl-3945-rs.c b/drivers/net/wireless/iwlwifi/iwl-3945-rs.c
index 9e411dc0e5e1..80e9bbc7884a 100644
--- a/drivers/net/wireless/iwlwifi/iwl-3945-rs.c
+++ b/drivers/net/wireless/iwlwifi/iwl-3945-rs.c
@@ -647,7 +647,7 @@ static void rs_get_rate(void *priv_r, struct ieee80211_sta *sta,
647 unsigned long flags; 647 unsigned long flags;
648 u16 rate_mask = sta ? sta->supp_rates[sband->band] : 0; 648 u16 rate_mask = sta ? sta->supp_rates[sband->band] : 0;
649 s8 max_rate_idx = -1; 649 s8 max_rate_idx = -1;
650 struct iwl_priv *priv = (struct iwl_priv *)priv_r; 650 struct iwl_priv *priv __maybe_unused = (struct iwl_priv *)priv_r;
651 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); 651 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
652 652
653 IWL_DEBUG_RATE(priv, "enter\n"); 653 IWL_DEBUG_RATE(priv, "enter\n");
diff --git a/drivers/net/wireless/iwlwifi/iwl-3945.c b/drivers/net/wireless/iwlwifi/iwl-3945.c
index f88f75dfd96e..15de649888d8 100644
--- a/drivers/net/wireless/iwlwifi/iwl-3945.c
+++ b/drivers/net/wireless/iwlwifi/iwl-3945.c
@@ -191,12 +191,12 @@ static int iwl3945_hwrate_to_plcp_idx(u8 plcp)
191} 191}
192 192
193#ifdef CONFIG_IWLWIFI_DEBUG 193#ifdef CONFIG_IWLWIFI_DEBUG
194#define TX_STATUS_ENTRY(x) case TX_STATUS_FAIL_ ## x: return #x 194#define TX_STATUS_ENTRY(x) case TX_3945_STATUS_FAIL_ ## x: return #x
195 195
196static const char *iwl3945_get_tx_fail_reason(u32 status) 196static const char *iwl3945_get_tx_fail_reason(u32 status)
197{ 197{
198 switch (status & TX_STATUS_MSK) { 198 switch (status & TX_STATUS_MSK) {
199 case TX_STATUS_SUCCESS: 199 case TX_3945_STATUS_SUCCESS:
200 return "SUCCESS"; 200 return "SUCCESS";
201 TX_STATUS_ENTRY(SHORT_LIMIT); 201 TX_STATUS_ENTRY(SHORT_LIMIT);
202 TX_STATUS_ENTRY(LONG_LIMIT); 202 TX_STATUS_ENTRY(LONG_LIMIT);
@@ -597,8 +597,8 @@ static void iwl3945_rx_reply_rx(struct iwl_priv *priv,
597 struct iwl3945_rx_frame_stats *rx_stats = IWL_RX_STATS(pkt); 597 struct iwl3945_rx_frame_stats *rx_stats = IWL_RX_STATS(pkt);
598 struct iwl3945_rx_frame_hdr *rx_hdr = IWL_RX_HDR(pkt); 598 struct iwl3945_rx_frame_hdr *rx_hdr = IWL_RX_HDR(pkt);
599 struct iwl3945_rx_frame_end *rx_end = IWL_RX_END(pkt); 599 struct iwl3945_rx_frame_end *rx_end = IWL_RX_END(pkt);
600 u16 rx_stats_sig_avg = le16_to_cpu(rx_stats->sig_avg); 600 u16 rx_stats_sig_avg __maybe_unused = le16_to_cpu(rx_stats->sig_avg);
601 u16 rx_stats_noise_diff = le16_to_cpu(rx_stats->noise_diff); 601 u16 rx_stats_noise_diff __maybe_unused = le16_to_cpu(rx_stats->noise_diff);
602 u8 network_packet; 602 u8 network_packet;
603 603
604 rx_status.flag = 0; 604 rx_status.flag = 0;
@@ -2770,6 +2770,7 @@ static struct iwl_cfg iwl3945_bg_cfg = {
2770 .broken_powersave = true, 2770 .broken_powersave = true,
2771 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF, 2771 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF,
2772 .monitor_recover_period = IWL_MONITORING_PERIOD, 2772 .monitor_recover_period = IWL_MONITORING_PERIOD,
2773 .max_event_log_size = 512,
2773}; 2774};
2774 2775
2775static struct iwl_cfg iwl3945_abg_cfg = { 2776static struct iwl_cfg iwl3945_abg_cfg = {
@@ -2789,6 +2790,7 @@ static struct iwl_cfg iwl3945_abg_cfg = {
2789 .broken_powersave = true, 2790 .broken_powersave = true,
2790 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF, 2791 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF,
2791 .monitor_recover_period = IWL_MONITORING_PERIOD, 2792 .monitor_recover_period = IWL_MONITORING_PERIOD,
2793 .max_event_log_size = 512,
2792}; 2794};
2793 2795
2794DEFINE_PCI_DEVICE_TABLE(iwl3945_hw_card_ids) = { 2796DEFINE_PCI_DEVICE_TABLE(iwl3945_hw_card_ids) = {
diff --git a/drivers/net/wireless/iwlwifi/iwl-4965.c b/drivers/net/wireless/iwlwifi/iwl-4965.c
index 8c889fdddf0e..2e3cda75f3ad 100644
--- a/drivers/net/wireless/iwlwifi/iwl-4965.c
+++ b/drivers/net/wireless/iwlwifi/iwl-4965.c
@@ -2054,8 +2054,7 @@ static void iwl4965_rx_reply_tx(struct iwl_priv *priv,
2054 if (qc && likely(sta_id != IWL_INVALID_STATION)) 2054 if (qc && likely(sta_id != IWL_INVALID_STATION))
2055 iwlagn_txq_check_empty(priv, sta_id, tid, txq_id); 2055 iwlagn_txq_check_empty(priv, sta_id, tid, txq_id);
2056 2056
2057 if (iwl_check_bits(status, TX_ABORT_REQUIRED_MSK)) 2057 iwl_check_abort_status(priv, tx_resp->frame_count, status);
2058 IWL_ERR(priv, "TODO: Implement Tx ABORT REQUIRED!!!\n");
2059} 2058}
2060 2059
2061static int iwl4965_calc_rssi(struct iwl_priv *priv, 2060static int iwl4965_calc_rssi(struct iwl_priv *priv,
@@ -2255,6 +2254,7 @@ struct iwl_cfg iwl4965_agn_cfg = {
2255 .monitor_recover_period = IWL_MONITORING_PERIOD, 2254 .monitor_recover_period = IWL_MONITORING_PERIOD,
2256 .temperature_kelvin = true, 2255 .temperature_kelvin = true,
2257 .off_channel_workaround = true, 2256 .off_channel_workaround = true,
2257 .max_event_log_size = 512,
2258}; 2258};
2259 2259
2260/* Module firmware */ 2260/* Module firmware */
diff --git a/drivers/net/wireless/iwlwifi/iwl-5000.c b/drivers/net/wireless/iwlwifi/iwl-5000.c
index ecc302e4c205..e967cfcac224 100644
--- a/drivers/net/wireless/iwlwifi/iwl-5000.c
+++ b/drivers/net/wireless/iwlwifi/iwl-5000.c
@@ -423,6 +423,7 @@ struct iwl_cfg iwl5300_agn_cfg = {
423 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_LONG_THRESHOLD_DEF, 423 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_LONG_THRESHOLD_DEF,
424 .chain_noise_scale = 1000, 424 .chain_noise_scale = 1000,
425 .monitor_recover_period = IWL_MONITORING_PERIOD, 425 .monitor_recover_period = IWL_MONITORING_PERIOD,
426 .max_event_log_size = 512,
426}; 427};
427 428
428struct iwl_cfg iwl5100_bgn_cfg = { 429struct iwl_cfg iwl5100_bgn_cfg = {
@@ -450,6 +451,7 @@ struct iwl_cfg iwl5100_bgn_cfg = {
450 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_LONG_THRESHOLD_DEF, 451 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_LONG_THRESHOLD_DEF,
451 .chain_noise_scale = 1000, 452 .chain_noise_scale = 1000,
452 .monitor_recover_period = IWL_MONITORING_PERIOD, 453 .monitor_recover_period = IWL_MONITORING_PERIOD,
454 .max_event_log_size = 512,
453}; 455};
454 456
455struct iwl_cfg iwl5100_abg_cfg = { 457struct iwl_cfg iwl5100_abg_cfg = {
@@ -475,6 +477,7 @@ struct iwl_cfg iwl5100_abg_cfg = {
475 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_LONG_THRESHOLD_DEF, 477 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_LONG_THRESHOLD_DEF,
476 .chain_noise_scale = 1000, 478 .chain_noise_scale = 1000,
477 .monitor_recover_period = IWL_MONITORING_PERIOD, 479 .monitor_recover_period = IWL_MONITORING_PERIOD,
480 .max_event_log_size = 512,
478}; 481};
479 482
480struct iwl_cfg iwl5100_agn_cfg = { 483struct iwl_cfg iwl5100_agn_cfg = {
@@ -502,6 +505,7 @@ struct iwl_cfg iwl5100_agn_cfg = {
502 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_LONG_THRESHOLD_DEF, 505 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_LONG_THRESHOLD_DEF,
503 .chain_noise_scale = 1000, 506 .chain_noise_scale = 1000,
504 .monitor_recover_period = IWL_MONITORING_PERIOD, 507 .monitor_recover_period = IWL_MONITORING_PERIOD,
508 .max_event_log_size = 512,
505}; 509};
506 510
507struct iwl_cfg iwl5350_agn_cfg = { 511struct iwl_cfg iwl5350_agn_cfg = {
@@ -529,6 +533,7 @@ struct iwl_cfg iwl5350_agn_cfg = {
529 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_LONG_THRESHOLD_DEF, 533 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_LONG_THRESHOLD_DEF,
530 .chain_noise_scale = 1000, 534 .chain_noise_scale = 1000,
531 .monitor_recover_period = IWL_MONITORING_PERIOD, 535 .monitor_recover_period = IWL_MONITORING_PERIOD,
536 .max_event_log_size = 512,
532}; 537};
533 538
534struct iwl_cfg iwl5150_agn_cfg = { 539struct iwl_cfg iwl5150_agn_cfg = {
@@ -556,6 +561,7 @@ struct iwl_cfg iwl5150_agn_cfg = {
556 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_LONG_THRESHOLD_DEF, 561 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_LONG_THRESHOLD_DEF,
557 .chain_noise_scale = 1000, 562 .chain_noise_scale = 1000,
558 .monitor_recover_period = IWL_MONITORING_PERIOD, 563 .monitor_recover_period = IWL_MONITORING_PERIOD,
564 .max_event_log_size = 512,
559}; 565};
560 566
561struct iwl_cfg iwl5150_abg_cfg = { 567struct iwl_cfg iwl5150_abg_cfg = {
@@ -581,6 +587,7 @@ struct iwl_cfg iwl5150_abg_cfg = {
581 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_LONG_THRESHOLD_DEF, 587 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_LONG_THRESHOLD_DEF,
582 .chain_noise_scale = 1000, 588 .chain_noise_scale = 1000,
583 .monitor_recover_period = IWL_MONITORING_PERIOD, 589 .monitor_recover_period = IWL_MONITORING_PERIOD,
590 .max_event_log_size = 512,
584}; 591};
585 592
586MODULE_FIRMWARE(IWL5000_MODULE_FIRMWARE(IWL5000_UCODE_API_MAX)); 593MODULE_FIRMWARE(IWL5000_MODULE_FIRMWARE(IWL5000_UCODE_API_MAX));
diff --git a/drivers/net/wireless/iwlwifi/iwl-6000.c b/drivers/net/wireless/iwlwifi/iwl-6000.c
index 7473518e7e0a..dd03384432f4 100644
--- a/drivers/net/wireless/iwlwifi/iwl-6000.c
+++ b/drivers/net/wireless/iwlwifi/iwl-6000.c
@@ -394,6 +394,7 @@ struct iwl_cfg iwl6000i_g2_2agn_cfg = {
394 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF, 394 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF,
395 .chain_noise_scale = 1000, 395 .chain_noise_scale = 1000,
396 .monitor_recover_period = IWL_MONITORING_PERIOD, 396 .monitor_recover_period = IWL_MONITORING_PERIOD,
397 .max_event_log_size = 1024,
397}; 398};
398 399
399struct iwl_cfg iwl6000i_2agn_cfg = { 400struct iwl_cfg iwl6000i_2agn_cfg = {
@@ -427,6 +428,7 @@ struct iwl_cfg iwl6000i_2agn_cfg = {
427 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF, 428 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF,
428 .chain_noise_scale = 1000, 429 .chain_noise_scale = 1000,
429 .monitor_recover_period = IWL_MONITORING_PERIOD, 430 .monitor_recover_period = IWL_MONITORING_PERIOD,
431 .max_event_log_size = 1024,
430}; 432};
431 433
432struct iwl_cfg iwl6000i_2abg_cfg = { 434struct iwl_cfg iwl6000i_2abg_cfg = {
@@ -459,6 +461,7 @@ struct iwl_cfg iwl6000i_2abg_cfg = {
459 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF, 461 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF,
460 .chain_noise_scale = 1000, 462 .chain_noise_scale = 1000,
461 .monitor_recover_period = IWL_MONITORING_PERIOD, 463 .monitor_recover_period = IWL_MONITORING_PERIOD,
464 .max_event_log_size = 1024,
462}; 465};
463 466
464struct iwl_cfg iwl6000i_2bg_cfg = { 467struct iwl_cfg iwl6000i_2bg_cfg = {
@@ -491,6 +494,7 @@ struct iwl_cfg iwl6000i_2bg_cfg = {
491 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF, 494 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF,
492 .chain_noise_scale = 1000, 495 .chain_noise_scale = 1000,
493 .monitor_recover_period = IWL_MONITORING_PERIOD, 496 .monitor_recover_period = IWL_MONITORING_PERIOD,
497 .max_event_log_size = 1024,
494}; 498};
495 499
496struct iwl_cfg iwl6050_2agn_cfg = { 500struct iwl_cfg iwl6050_2agn_cfg = {
@@ -524,6 +528,7 @@ struct iwl_cfg iwl6050_2agn_cfg = {
524 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF, 528 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF,
525 .chain_noise_scale = 1500, 529 .chain_noise_scale = 1500,
526 .monitor_recover_period = IWL_MONITORING_PERIOD, 530 .monitor_recover_period = IWL_MONITORING_PERIOD,
531 .max_event_log_size = 1024,
527}; 532};
528 533
529struct iwl_cfg iwl6050_2abg_cfg = { 534struct iwl_cfg iwl6050_2abg_cfg = {
@@ -556,6 +561,7 @@ struct iwl_cfg iwl6050_2abg_cfg = {
556 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF, 561 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF,
557 .chain_noise_scale = 1500, 562 .chain_noise_scale = 1500,
558 .monitor_recover_period = IWL_MONITORING_PERIOD, 563 .monitor_recover_period = IWL_MONITORING_PERIOD,
564 .max_event_log_size = 1024,
559}; 565};
560 566
561struct iwl_cfg iwl6000_3agn_cfg = { 567struct iwl_cfg iwl6000_3agn_cfg = {
@@ -589,6 +595,7 @@ struct iwl_cfg iwl6000_3agn_cfg = {
589 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF, 595 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF,
590 .chain_noise_scale = 1000, 596 .chain_noise_scale = 1000,
591 .monitor_recover_period = IWL_MONITORING_PERIOD, 597 .monitor_recover_period = IWL_MONITORING_PERIOD,
598 .max_event_log_size = 1024,
592}; 599};
593 600
594MODULE_FIRMWARE(IWL6000_MODULE_FIRMWARE(IWL6000_UCODE_API_MAX)); 601MODULE_FIRMWARE(IWL6000_MODULE_FIRMWARE(IWL6000_UCODE_API_MAX));
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn-lib.c b/drivers/net/wireless/iwlwifi/iwl-agn-lib.c
index 49e20f1acb7c..c465c8590833 100644
--- a/drivers/net/wireless/iwlwifi/iwl-agn-lib.c
+++ b/drivers/net/wireless/iwlwifi/iwl-agn-lib.c
@@ -161,6 +161,14 @@ static int iwlagn_tx_status_reply_tx(struct iwl_priv *priv,
161 return 0; 161 return 0;
162} 162}
163 163
164void iwl_check_abort_status(struct iwl_priv *priv,
165 u8 frame_count, u32 status)
166{
167 if (frame_count == 1 && status == TX_STATUS_FAIL_RFKILL_FLUSH) {
168 IWL_ERR(priv, "TODO: Implement Tx flush command!!!\n");
169 }
170}
171
164static void iwlagn_rx_reply_tx(struct iwl_priv *priv, 172static void iwlagn_rx_reply_tx(struct iwl_priv *priv,
165 struct iwl_rx_mem_buffer *rxb) 173 struct iwl_rx_mem_buffer *rxb)
166{ 174{
@@ -246,8 +254,7 @@ static void iwlagn_rx_reply_tx(struct iwl_priv *priv,
246 254
247 iwlagn_txq_check_empty(priv, sta_id, tid, txq_id); 255 iwlagn_txq_check_empty(priv, sta_id, tid, txq_id);
248 256
249 if (iwl_check_bits(status, TX_ABORT_REQUIRED_MSK)) 257 iwl_check_abort_status(priv, tx_resp->frame_count, status);
250 IWL_ERR(priv, "TODO: Implement Tx ABORT REQUIRED!!!\n");
251} 258}
252 259
253void iwlagn_rx_handler_setup(struct iwl_priv *priv) 260void iwlagn_rx_handler_setup(struct iwl_priv *priv)
@@ -505,10 +512,13 @@ int iwlagn_hw_nic_init(struct iwl_priv *priv)
505 512
506 spin_unlock_irqrestore(&priv->lock, flags); 513 spin_unlock_irqrestore(&priv->lock, flags);
507 514
508 /* Allocate and init all Tx and Command queues */ 515 /* Allocate or reset and init all Tx and Command queues */
509 ret = iwlagn_txq_ctx_reset(priv); 516 if (!priv->txq) {
510 if (ret) 517 ret = iwlagn_txq_ctx_alloc(priv);
511 return ret; 518 if (ret)
519 return ret;
520 } else
521 iwlagn_txq_ctx_reset(priv);
512 522
513 set_bit(STATUS_INIT, &priv->status); 523 set_bit(STATUS_INIT, &priv->status);
514 524
@@ -1001,11 +1011,11 @@ void iwlagn_rx_reply_rx(struct iwl_priv *priv,
1001 phy_res->cfg_phy_cnt + len); 1011 phy_res->cfg_phy_cnt + len);
1002 ampdu_status = le32_to_cpu(rx_pkt_status); 1012 ampdu_status = le32_to_cpu(rx_pkt_status);
1003 } else { 1013 } else {
1004 if (!priv->last_phy_res[0]) { 1014 if (!priv->_agn.last_phy_res_valid) {
1005 IWL_ERR(priv, "MPDU frame without cached PHY data\n"); 1015 IWL_ERR(priv, "MPDU frame without cached PHY data\n");
1006 return; 1016 return;
1007 } 1017 }
1008 phy_res = (struct iwl_rx_phy_res *)&priv->last_phy_res[1]; 1018 phy_res = &priv->_agn.last_phy_res;
1009 amsdu = (struct iwl4965_rx_mpdu_res_start *)pkt->u.raw; 1019 amsdu = (struct iwl4965_rx_mpdu_res_start *)pkt->u.raw;
1010 header = (struct ieee80211_hdr *)(pkt->u.raw + sizeof(*amsdu)); 1020 header = (struct ieee80211_hdr *)(pkt->u.raw + sizeof(*amsdu));
1011 len = le16_to_cpu(amsdu->byte_count); 1021 len = le16_to_cpu(amsdu->byte_count);
@@ -1094,10 +1104,10 @@ void iwlagn_rx_reply_rx(struct iwl_priv *priv,
1094/* Cache phy data (Rx signal strength, etc) for HT frame (REPLY_RX_PHY_CMD). 1104/* Cache phy data (Rx signal strength, etc) for HT frame (REPLY_RX_PHY_CMD).
1095 * This will be used later in iwl_rx_reply_rx() for REPLY_RX_MPDU_CMD. */ 1105 * This will be used later in iwl_rx_reply_rx() for REPLY_RX_MPDU_CMD. */
1096void iwlagn_rx_reply_rx_phy(struct iwl_priv *priv, 1106void iwlagn_rx_reply_rx_phy(struct iwl_priv *priv,
1097 struct iwl_rx_mem_buffer *rxb) 1107 struct iwl_rx_mem_buffer *rxb)
1098{ 1108{
1099 struct iwl_rx_packet *pkt = rxb_addr(rxb); 1109 struct iwl_rx_packet *pkt = rxb_addr(rxb);
1100 priv->last_phy_res[0] = 1; 1110 priv->_agn.last_phy_res_valid = true;
1101 memcpy(&priv->last_phy_res[1], &(pkt->u.raw[0]), 1111 memcpy(&priv->_agn.last_phy_res, pkt->u.raw,
1102 sizeof(struct iwl_rx_phy_res)); 1112 sizeof(struct iwl_rx_phy_res));
1103} 1113}
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn-rs.c b/drivers/net/wireless/iwlwifi/iwl-agn-rs.c
index 0c3c76803c5e..3c1cd417bbc5 100644
--- a/drivers/net/wireless/iwlwifi/iwl-agn-rs.c
+++ b/drivers/net/wireless/iwlwifi/iwl-agn-rs.c
@@ -2409,7 +2409,7 @@ static void rs_get_rate(void *priv_r, struct ieee80211_sta *sta, void *priv_sta,
2409 2409
2410 struct sk_buff *skb = txrc->skb; 2410 struct sk_buff *skb = txrc->skb;
2411 struct ieee80211_supported_band *sband = txrc->sband; 2411 struct ieee80211_supported_band *sband = txrc->sband;
2412 struct iwl_priv *priv = (struct iwl_priv *)priv_r; 2412 struct iwl_priv *priv __maybe_unused = (struct iwl_priv *)priv_r;
2413 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); 2413 struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
2414 struct iwl_lq_sta *lq_sta = priv_sta; 2414 struct iwl_lq_sta *lq_sta = priv_sta;
2415 int rate_idx; 2415 int rate_idx;
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn-tx.c b/drivers/net/wireless/iwlwifi/iwl-agn-tx.c
index a76e14351b5a..3077eac58880 100644
--- a/drivers/net/wireless/iwlwifi/iwl-agn-tx.c
+++ b/drivers/net/wireless/iwlwifi/iwl-agn-tx.c
@@ -809,8 +809,7 @@ void iwlagn_hw_txq_ctx_free(struct iwl_priv *priv)
809 809
810 /* Tx queues */ 810 /* Tx queues */
811 if (priv->txq) { 811 if (priv->txq) {
812 for (txq_id = 0; txq_id < priv->hw_params.max_txq_num; 812 for (txq_id = 0; txq_id < priv->hw_params.max_txq_num; txq_id++)
813 txq_id++)
814 if (txq_id == IWL_CMD_QUEUE_NUM) 813 if (txq_id == IWL_CMD_QUEUE_NUM)
815 iwl_cmd_queue_free(priv); 814 iwl_cmd_queue_free(priv);
816 else 815 else
@@ -825,15 +824,15 @@ void iwlagn_hw_txq_ctx_free(struct iwl_priv *priv)
825} 824}
826 825
827/** 826/**
828 * iwlagn_txq_ctx_reset - Reset TX queue context 827 * iwlagn_txq_ctx_alloc - allocate TX queue context
829 * Destroys all DMA structures and initialize them again 828 * Allocate all Tx DMA structures and initialize them
830 * 829 *
831 * @param priv 830 * @param priv
832 * @return error code 831 * @return error code
833 */ 832 */
834int iwlagn_txq_ctx_reset(struct iwl_priv *priv) 833int iwlagn_txq_ctx_alloc(struct iwl_priv *priv)
835{ 834{
836 int ret = 0; 835 int ret;
837 int txq_id, slots_num; 836 int txq_id, slots_num;
838 unsigned long flags; 837 unsigned long flags;
839 838
@@ -891,8 +890,31 @@ int iwlagn_txq_ctx_reset(struct iwl_priv *priv)
891 return ret; 890 return ret;
892} 891}
893 892
893void iwlagn_txq_ctx_reset(struct iwl_priv *priv)
894{
895 int txq_id, slots_num;
896 unsigned long flags;
897
898 spin_lock_irqsave(&priv->lock, flags);
899
900 /* Turn off all Tx DMA fifos */
901 priv->cfg->ops->lib->txq_set_sched(priv, 0);
902
903 /* Tell NIC where to find the "keep warm" buffer */
904 iwl_write_direct32(priv, FH_KW_MEM_ADDR_REG, priv->kw.dma >> 4);
905
906 spin_unlock_irqrestore(&priv->lock, flags);
907
908 /* Alloc and init all Tx queues, including the command queue (#4) */
909 for (txq_id = 0; txq_id < priv->hw_params.max_txq_num; txq_id++) {
910 slots_num = txq_id == IWL_CMD_QUEUE_NUM ?
911 TFD_CMD_SLOTS : TFD_TX_CMD_SLOTS;
912 iwl_tx_queue_reset(priv, &priv->txq[txq_id], slots_num, txq_id);
913 }
914}
915
894/** 916/**
895 * iwlagn_txq_ctx_stop - Stop all Tx DMA channels, free Tx queue memory 917 * iwlagn_txq_ctx_stop - Stop all Tx DMA channels
896 */ 918 */
897void iwlagn_txq_ctx_stop(struct iwl_priv *priv) 919void iwlagn_txq_ctx_stop(struct iwl_priv *priv)
898{ 920{
@@ -912,9 +934,6 @@ void iwlagn_txq_ctx_stop(struct iwl_priv *priv)
912 1000); 934 1000);
913 } 935 }
914 spin_unlock_irqrestore(&priv->lock, flags); 936 spin_unlock_irqrestore(&priv->lock, flags);
915
916 /* Deallocate memory for all Tx queues */
917 iwlagn_hw_txq_ctx_free(priv);
918} 937}
919 938
920/* 939/*
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn.c b/drivers/net/wireless/iwlwifi/iwl-agn.c
index 4f0cb803f732..8a002c6f3a61 100644
--- a/drivers/net/wireless/iwlwifi/iwl-agn.c
+++ b/drivers/net/wireless/iwlwifi/iwl-agn.c
@@ -158,6 +158,11 @@ int iwl_commit_rxon(struct iwl_priv *priv)
158 } 158 }
159 iwl_clear_ucode_stations(priv, false); 159 iwl_clear_ucode_stations(priv, false);
160 iwl_restore_stations(priv); 160 iwl_restore_stations(priv);
161 ret = iwl_restore_default_wep_keys(priv);
162 if (ret) {
163 IWL_ERR(priv, "Failed to restore WEP keys (%d)\n", ret);
164 return ret;
165 }
161 } 166 }
162 167
163 IWL_DEBUG_INFO(priv, "Sending RXON\n" 168 IWL_DEBUG_INFO(priv, "Sending RXON\n"
@@ -185,6 +190,11 @@ int iwl_commit_rxon(struct iwl_priv *priv)
185 memcpy(active_rxon, &priv->staging_rxon, sizeof(*active_rxon)); 190 memcpy(active_rxon, &priv->staging_rxon, sizeof(*active_rxon));
186 iwl_clear_ucode_stations(priv, false); 191 iwl_clear_ucode_stations(priv, false);
187 iwl_restore_stations(priv); 192 iwl_restore_stations(priv);
193 ret = iwl_restore_default_wep_keys(priv);
194 if (ret) {
195 IWL_ERR(priv, "Failed to restore WEP keys (%d)\n", ret);
196 return ret;
197 }
188 } 198 }
189 199
190 priv->start_calib = 0; 200 priv->start_calib = 0;
@@ -1833,6 +1843,7 @@ void iwl_dump_nic_error_log(struct iwl_priv *priv)
1833 u32 data2, line; 1843 u32 data2, line;
1834 u32 desc, time, count, base, data1; 1844 u32 desc, time, count, base, data1;
1835 u32 blink1, blink2, ilink1, ilink2; 1845 u32 blink1, blink2, ilink1, ilink2;
1846 u32 pc, hcmd;
1836 1847
1837 if (priv->ucode_type == UCODE_INIT) 1848 if (priv->ucode_type == UCODE_INIT)
1838 base = le32_to_cpu(priv->card_alive_init.error_event_table_ptr); 1849 base = le32_to_cpu(priv->card_alive_init.error_event_table_ptr);
@@ -1855,6 +1866,7 @@ void iwl_dump_nic_error_log(struct iwl_priv *priv)
1855 } 1866 }
1856 1867
1857 desc = iwl_read_targ_mem(priv, base + 1 * sizeof(u32)); 1868 desc = iwl_read_targ_mem(priv, base + 1 * sizeof(u32));
1869 pc = iwl_read_targ_mem(priv, base + 2 * sizeof(u32));
1858 blink1 = iwl_read_targ_mem(priv, base + 3 * sizeof(u32)); 1870 blink1 = iwl_read_targ_mem(priv, base + 3 * sizeof(u32));
1859 blink2 = iwl_read_targ_mem(priv, base + 4 * sizeof(u32)); 1871 blink2 = iwl_read_targ_mem(priv, base + 4 * sizeof(u32));
1860 ilink1 = iwl_read_targ_mem(priv, base + 5 * sizeof(u32)); 1872 ilink1 = iwl_read_targ_mem(priv, base + 5 * sizeof(u32));
@@ -1863,6 +1875,7 @@ void iwl_dump_nic_error_log(struct iwl_priv *priv)
1863 data2 = iwl_read_targ_mem(priv, base + 8 * sizeof(u32)); 1875 data2 = iwl_read_targ_mem(priv, base + 8 * sizeof(u32));
1864 line = iwl_read_targ_mem(priv, base + 9 * sizeof(u32)); 1876 line = iwl_read_targ_mem(priv, base + 9 * sizeof(u32));
1865 time = iwl_read_targ_mem(priv, base + 11 * sizeof(u32)); 1877 time = iwl_read_targ_mem(priv, base + 11 * sizeof(u32));
1878 hcmd = iwl_read_targ_mem(priv, base + 22 * sizeof(u32));
1866 1879
1867 trace_iwlwifi_dev_ucode_error(priv, desc, time, data1, data2, line, 1880 trace_iwlwifi_dev_ucode_error(priv, desc, time, data1, data2, line,
1868 blink1, blink2, ilink1, ilink2); 1881 blink1, blink2, ilink1, ilink2);
@@ -1871,10 +1884,9 @@ void iwl_dump_nic_error_log(struct iwl_priv *priv)
1871 "data1 data2 line\n"); 1884 "data1 data2 line\n");
1872 IWL_ERR(priv, "%-28s (#%02d) %010u 0x%08X 0x%08X %u\n", 1885 IWL_ERR(priv, "%-28s (#%02d) %010u 0x%08X 0x%08X %u\n",
1873 desc_lookup(desc), desc, time, data1, data2, line); 1886 desc_lookup(desc), desc, time, data1, data2, line);
1874 IWL_ERR(priv, "blink1 blink2 ilink1 ilink2\n"); 1887 IWL_ERR(priv, "pc blink1 blink2 ilink1 ilink2 hcmd\n");
1875 IWL_ERR(priv, "0x%05X 0x%05X 0x%05X 0x%05X\n", blink1, blink2, 1888 IWL_ERR(priv, "0x%05X 0x%05X 0x%05X 0x%05X 0x%05X 0x%05X\n",
1876 ilink1, ilink2); 1889 pc, blink1, blink2, ilink1, ilink2, hcmd);
1877
1878} 1890}
1879 1891
1880#define EVENT_START_OFFSET (4 * sizeof(u32)) 1892#define EVENT_START_OFFSET (4 * sizeof(u32))
@@ -1990,9 +2002,6 @@ static int iwl_print_last_event_logs(struct iwl_priv *priv, u32 capacity,
1990 return pos; 2002 return pos;
1991} 2003}
1992 2004
1993/* For sanity check only. Actual size is determined by uCode, typ. 512 */
1994#define MAX_EVENT_LOG_SIZE (512)
1995
1996#define DEFAULT_DUMP_EVENT_LOG_ENTRIES (20) 2005#define DEFAULT_DUMP_EVENT_LOG_ENTRIES (20)
1997 2006
1998int iwl_dump_nic_event_log(struct iwl_priv *priv, bool full_log, 2007int iwl_dump_nic_event_log(struct iwl_priv *priv, bool full_log,
@@ -2025,16 +2034,16 @@ int iwl_dump_nic_event_log(struct iwl_priv *priv, bool full_log,
2025 num_wraps = iwl_read_targ_mem(priv, base + (2 * sizeof(u32))); 2034 num_wraps = iwl_read_targ_mem(priv, base + (2 * sizeof(u32)));
2026 next_entry = iwl_read_targ_mem(priv, base + (3 * sizeof(u32))); 2035 next_entry = iwl_read_targ_mem(priv, base + (3 * sizeof(u32)));
2027 2036
2028 if (capacity > MAX_EVENT_LOG_SIZE) { 2037 if (capacity > priv->cfg->max_event_log_size) {
2029 IWL_ERR(priv, "Log capacity %d is bogus, limit to %d entries\n", 2038 IWL_ERR(priv, "Log capacity %d is bogus, limit to %d entries\n",
2030 capacity, MAX_EVENT_LOG_SIZE); 2039 capacity, priv->cfg->max_event_log_size);
2031 capacity = MAX_EVENT_LOG_SIZE; 2040 capacity = priv->cfg->max_event_log_size;
2032 } 2041 }
2033 2042
2034 if (next_entry > MAX_EVENT_LOG_SIZE) { 2043 if (next_entry > priv->cfg->max_event_log_size) {
2035 IWL_ERR(priv, "Log write index %d is bogus, limit to %d\n", 2044 IWL_ERR(priv, "Log write index %d is bogus, limit to %d\n",
2036 next_entry, MAX_EVENT_LOG_SIZE); 2045 next_entry, priv->cfg->max_event_log_size);
2037 next_entry = MAX_EVENT_LOG_SIZE; 2046 next_entry = priv->cfg->max_event_log_size;
2038 } 2047 }
2039 2048
2040 size = num_wraps ? capacity : next_entry; 2049 size = num_wraps ? capacity : next_entry;
@@ -2894,12 +2903,13 @@ static int iwl_mac_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd,
2894 mutex_lock(&priv->mutex); 2903 mutex_lock(&priv->mutex);
2895 iwl_scan_cancel_timeout(priv, 100); 2904 iwl_scan_cancel_timeout(priv, 100);
2896 2905
2897 /* If we are getting WEP group key and we didn't receive any key mapping 2906 /*
2907 * If we are getting WEP group key and we didn't receive any key mapping
2898 * so far, we are in legacy wep mode (group key only), otherwise we are 2908 * so far, we are in legacy wep mode (group key only), otherwise we are
2899 * in 1X mode. 2909 * in 1X mode.
2900 * In legacy wep mode, we use another host command to the uCode */ 2910 * In legacy wep mode, we use another host command to the uCode.
2901 if (key->alg == ALG_WEP && sta_id == priv->hw_params.bcast_sta_id && 2911 */
2902 priv->iw_mode != NL80211_IFTYPE_AP) { 2912 if (key->alg == ALG_WEP && !sta && vif->type != NL80211_IFTYPE_AP) {
2903 if (cmd == SET_KEY) 2913 if (cmd == SET_KEY)
2904 is_default_wep_key = !priv->key_mapping_key; 2914 is_default_wep_key = !priv->key_mapping_key;
2905 else 2915 else
@@ -3033,19 +3043,6 @@ static void iwl_mac_sta_notify(struct ieee80211_hw *hw,
3033 } 3043 }
3034} 3044}
3035 3045
3036/**
3037 * iwl_restore_wepkeys - Restore WEP keys to device
3038 */
3039static void iwl_restore_wepkeys(struct iwl_priv *priv)
3040{
3041 mutex_lock(&priv->mutex);
3042 if (priv->iw_mode == NL80211_IFTYPE_STATION &&
3043 priv->default_wep_key &&
3044 iwl_send_static_wepkey_cmd(priv, 0))
3045 IWL_ERR(priv, "Could not send WEP static key\n");
3046 mutex_unlock(&priv->mutex);
3047}
3048
3049static int iwlagn_mac_sta_add(struct ieee80211_hw *hw, 3046static int iwlagn_mac_sta_add(struct ieee80211_hw *hw,
3050 struct ieee80211_vif *vif, 3047 struct ieee80211_vif *vif,
3051 struct ieee80211_sta *sta) 3048 struct ieee80211_sta *sta)
@@ -3072,8 +3069,6 @@ static int iwlagn_mac_sta_add(struct ieee80211_hw *hw,
3072 return ret; 3069 return ret;
3073 } 3070 }
3074 3071
3075 iwl_restore_wepkeys(priv);
3076
3077 /* Initialize rate scaling */ 3072 /* Initialize rate scaling */
3078 IWL_DEBUG_INFO(priv, "Initializing rate scaling for station %pM\n", 3073 IWL_DEBUG_INFO(priv, "Initializing rate scaling for station %pM\n",
3079 sta->addr); 3074 sta->addr);
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn.h b/drivers/net/wireless/iwlwifi/iwl-agn.h
index 5ad14055eda3..5d3142287e14 100644
--- a/drivers/net/wireless/iwlwifi/iwl-agn.h
+++ b/drivers/net/wireless/iwlwifi/iwl-agn.h
@@ -105,6 +105,8 @@ void iwlagn_init_alive_start(struct iwl_priv *priv);
105int iwlagn_alive_notify(struct iwl_priv *priv); 105int iwlagn_alive_notify(struct iwl_priv *priv);
106 106
107/* lib */ 107/* lib */
108void iwl_check_abort_status(struct iwl_priv *priv,
109 u8 frame_count, u32 status);
108void iwlagn_rx_handler_setup(struct iwl_priv *priv); 110void iwlagn_rx_handler_setup(struct iwl_priv *priv);
109void iwlagn_setup_deferred_work(struct iwl_priv *priv); 111void iwlagn_setup_deferred_work(struct iwl_priv *priv);
110int iwlagn_hw_valid_rtc_data_addr(u32 addr); 112int iwlagn_hw_valid_rtc_data_addr(u32 addr);
@@ -143,7 +145,30 @@ void iwlagn_rx_reply_compressed_ba(struct iwl_priv *priv,
143 struct iwl_rx_mem_buffer *rxb); 145 struct iwl_rx_mem_buffer *rxb);
144int iwlagn_tx_queue_reclaim(struct iwl_priv *priv, int txq_id, int index); 146int iwlagn_tx_queue_reclaim(struct iwl_priv *priv, int txq_id, int index);
145void iwlagn_hw_txq_ctx_free(struct iwl_priv *priv); 147void iwlagn_hw_txq_ctx_free(struct iwl_priv *priv);
146int iwlagn_txq_ctx_reset(struct iwl_priv *priv); 148int iwlagn_txq_ctx_alloc(struct iwl_priv *priv);
149void iwlagn_txq_ctx_reset(struct iwl_priv *priv);
147void iwlagn_txq_ctx_stop(struct iwl_priv *priv); 150void iwlagn_txq_ctx_stop(struct iwl_priv *priv);
148 151
152static inline u32 iwl_tx_status_to_mac80211(u32 status)
153{
154 status &= TX_STATUS_MSK;
155
156 switch (status) {
157 case TX_STATUS_SUCCESS:
158 case TX_STATUS_DIRECT_DONE:
159 return IEEE80211_TX_STAT_ACK;
160 case TX_STATUS_FAIL_DEST_PS:
161 return IEEE80211_TX_STAT_TX_FILTERED;
162 default:
163 return 0;
164 }
165}
166
167static inline bool iwl_is_tx_success(u32 status)
168{
169 status &= TX_STATUS_MSK;
170 return (status == TX_STATUS_SUCCESS) ||
171 (status == TX_STATUS_DIRECT_DONE);
172}
173
149#endif /* __iwl_agn_h__ */ 174#endif /* __iwl_agn_h__ */
diff --git a/drivers/net/wireless/iwlwifi/iwl-commands.h b/drivers/net/wireless/iwlwifi/iwl-commands.h
index 6383d9f8c9b3..d830086ca195 100644
--- a/drivers/net/wireless/iwlwifi/iwl-commands.h
+++ b/drivers/net/wireless/iwlwifi/iwl-commands.h
@@ -106,7 +106,7 @@ enum {
106 REPLY_TX = 0x1c, 106 REPLY_TX = 0x1c,
107 REPLY_RATE_SCALE = 0x47, /* 3945 only */ 107 REPLY_RATE_SCALE = 0x47, /* 3945 only */
108 REPLY_LEDS_CMD = 0x48, 108 REPLY_LEDS_CMD = 0x48,
109 REPLY_TX_LINK_QUALITY_CMD = 0x4e, /* 4965 only */ 109 REPLY_TX_LINK_QUALITY_CMD = 0x4e, /* for 4965 and up */
110 110
111 /* WiMAX coexistence */ 111 /* WiMAX coexistence */
112 COEX_PRIORITY_TABLE_CMD = 0x5a, /* for 5000 series and up */ 112 COEX_PRIORITY_TABLE_CMD = 0x5a, /* for 5000 series and up */
@@ -512,8 +512,9 @@ struct iwl_init_alive_resp {
512 * 512 *
513 * Entries without timestamps contain only event_id and data. 513 * Entries without timestamps contain only event_id and data.
514 * 514 *
515 *
515 * 2) error_event_table_ptr indicates base of the error log. This contains 516 * 2) error_event_table_ptr indicates base of the error log. This contains
516 * information about any uCode error that occurs. For 4965, the format 517 * information about any uCode error that occurs. For agn, the format
517 * of the error log is: 518 * of the error log is:
518 * 519 *
519 * __le32 valid; (nonzero) valid, (0) log is empty 520 * __le32 valid; (nonzero) valid, (0) log is empty
@@ -529,6 +530,30 @@ struct iwl_init_alive_resp {
529 * __le32 bcon_time; beacon timer 530 * __le32 bcon_time; beacon timer
530 * __le32 tsf_low; network timestamp function timer 531 * __le32 tsf_low; network timestamp function timer
531 * __le32 tsf_hi; network timestamp function timer 532 * __le32 tsf_hi; network timestamp function timer
533 * __le32 gp1; GP1 timer register
534 * __le32 gp2; GP2 timer register
535 * __le32 gp3; GP3 timer register
536 * __le32 ucode_ver; uCode version
537 * __le32 hw_ver; HW Silicon version
538 * __le32 brd_ver; HW board version
539 * __le32 log_pc; log program counter
540 * __le32 frame_ptr; frame pointer
541 * __le32 stack_ptr; stack pointer
542 * __le32 hcmd; last host command
543 * __le32 isr0; isr status register LMPM_NIC_ISR0: rxtx_flag
544 * __le32 isr1; isr status register LMPM_NIC_ISR1: host_flag
545 * __le32 isr2; isr status register LMPM_NIC_ISR2: enc_flag
546 * __le32 isr3; isr status register LMPM_NIC_ISR3: time_flag
547 * __le32 isr4; isr status register LMPM_NIC_ISR4: wico interrupt
548 * __le32 isr_pref; isr status register LMPM_NIC_PREF_STAT
549 * __le32 wait_event; wait event() caller address
550 * __le32 l2p_control; L2pControlField
551 * __le32 l2p_duration; L2pDurationField
552 * __le32 l2p_mhvalid; L2pMhValidBits
553 * __le32 l2p_addr_match; L2pAddrMatchStat
554 * __le32 lmpm_pmg_sel; indicate which clocks are turned on (LMPM_PMG_SEL)
555 * __le32 u_timestamp; indicate when the date and time of the compilation
556 * __le32 reserved;
532 * 557 *
533 * The Linux driver can print both logs to the system log when a uCode error 558 * The Linux driver can print both logs to the system log when a uCode error
534 * occurs. 559 * occurs.
@@ -1637,7 +1662,7 @@ struct iwl_tx_cmd {
1637 struct ieee80211_hdr hdr[0]; 1662 struct ieee80211_hdr hdr[0];
1638} __attribute__ ((packed)); 1663} __attribute__ ((packed));
1639 1664
1640/* TX command response is sent after *all* transmission attempts. 1665/* TX command response is sent after *3945* transmission attempts.
1641 * 1666 *
1642 * NOTES: 1667 * NOTES:
1643 * 1668 *
@@ -1665,24 +1690,65 @@ struct iwl_tx_cmd {
1665 * control line. Receiving is still allowed in this case. 1690 * control line. Receiving is still allowed in this case.
1666 */ 1691 */
1667enum { 1692enum {
1693 TX_3945_STATUS_SUCCESS = 0x01,
1694 TX_3945_STATUS_DIRECT_DONE = 0x02,
1695 TX_3945_STATUS_FAIL_SHORT_LIMIT = 0x82,
1696 TX_3945_STATUS_FAIL_LONG_LIMIT = 0x83,
1697 TX_3945_STATUS_FAIL_FIFO_UNDERRUN = 0x84,
1698 TX_3945_STATUS_FAIL_MGMNT_ABORT = 0x85,
1699 TX_3945_STATUS_FAIL_NEXT_FRAG = 0x86,
1700 TX_3945_STATUS_FAIL_LIFE_EXPIRE = 0x87,
1701 TX_3945_STATUS_FAIL_DEST_PS = 0x88,
1702 TX_3945_STATUS_FAIL_ABORTED = 0x89,
1703 TX_3945_STATUS_FAIL_BT_RETRY = 0x8a,
1704 TX_3945_STATUS_FAIL_STA_INVALID = 0x8b,
1705 TX_3945_STATUS_FAIL_FRAG_DROPPED = 0x8c,
1706 TX_3945_STATUS_FAIL_TID_DISABLE = 0x8d,
1707 TX_3945_STATUS_FAIL_FRAME_FLUSHED = 0x8e,
1708 TX_3945_STATUS_FAIL_INSUFFICIENT_CF_POLL = 0x8f,
1709 TX_3945_STATUS_FAIL_TX_LOCKED = 0x90,
1710 TX_3945_STATUS_FAIL_NO_BEACON_ON_RADAR = 0x91,
1711};
1712
1713/*
1714 * TX command response is sent after *agn* transmission attempts.
1715 *
1716 * both postpone and abort status are expected behavior from uCode. there is
1717 * no special operation required from driver; except for RFKILL_FLUSH,
1718 * which required tx flush host command to flush all the tx frames in queues
1719 */
1720enum {
1668 TX_STATUS_SUCCESS = 0x01, 1721 TX_STATUS_SUCCESS = 0x01,
1669 TX_STATUS_DIRECT_DONE = 0x02, 1722 TX_STATUS_DIRECT_DONE = 0x02,
1723 /* postpone TX */
1724 TX_STATUS_POSTPONE_DELAY = 0x40,
1725 TX_STATUS_POSTPONE_FEW_BYTES = 0x41,
1726 TX_STATUS_POSTPONE_BT_PRIO = 0x42,
1727 TX_STATUS_POSTPONE_QUIET_PERIOD = 0x43,
1728 TX_STATUS_POSTPONE_CALC_TTAK = 0x44,
1729 /* abort TX */
1730 TX_STATUS_FAIL_INTERNAL_CROSSED_RETRY = 0x81,
1670 TX_STATUS_FAIL_SHORT_LIMIT = 0x82, 1731 TX_STATUS_FAIL_SHORT_LIMIT = 0x82,
1671 TX_STATUS_FAIL_LONG_LIMIT = 0x83, 1732 TX_STATUS_FAIL_LONG_LIMIT = 0x83,
1672 TX_STATUS_FAIL_FIFO_UNDERRUN = 0x84, 1733 TX_STATUS_FAIL_FIFO_UNDERRUN = 0x84,
1673 TX_STATUS_FAIL_MGMNT_ABORT = 0x85, 1734 TX_STATUS_FAIL_DRAIN_FLOW = 0x85,
1674 TX_STATUS_FAIL_NEXT_FRAG = 0x86, 1735 TX_STATUS_FAIL_RFKILL_FLUSH = 0x86,
1675 TX_STATUS_FAIL_LIFE_EXPIRE = 0x87, 1736 TX_STATUS_FAIL_LIFE_EXPIRE = 0x87,
1676 TX_STATUS_FAIL_DEST_PS = 0x88, 1737 TX_STATUS_FAIL_DEST_PS = 0x88,
1677 TX_STATUS_FAIL_ABORTED = 0x89, 1738 TX_STATUS_FAIL_HOST_ABORTED = 0x89,
1678 TX_STATUS_FAIL_BT_RETRY = 0x8a, 1739 TX_STATUS_FAIL_BT_RETRY = 0x8a,
1679 TX_STATUS_FAIL_STA_INVALID = 0x8b, 1740 TX_STATUS_FAIL_STA_INVALID = 0x8b,
1680 TX_STATUS_FAIL_FRAG_DROPPED = 0x8c, 1741 TX_STATUS_FAIL_FRAG_DROPPED = 0x8c,
1681 TX_STATUS_FAIL_TID_DISABLE = 0x8d, 1742 TX_STATUS_FAIL_TID_DISABLE = 0x8d,
1682 TX_STATUS_FAIL_FRAME_FLUSHED = 0x8e, 1743 TX_STATUS_FAIL_FIFO_FLUSHED = 0x8e,
1683 TX_STATUS_FAIL_INSUFFICIENT_CF_POLL = 0x8f, 1744 TX_STATUS_FAIL_INSUFFICIENT_CF_POLL = 0x8f,
1684 TX_STATUS_FAIL_TX_LOCKED = 0x90, 1745 /* uCode drop due to FW drop request */
1685 TX_STATUS_FAIL_NO_BEACON_ON_RADAR = 0x91, 1746 TX_STATUS_FAIL_FW_DROP = 0x90,
1747 /*
1748 * uCode drop due to station color mismatch
1749 * between tx command and station table
1750 */
1751 TX_STATUS_FAIL_STA_COLOR_MISMATCH_DROP = 0x91,
1686}; 1752};
1687 1753
1688#define TX_PACKET_MODE_REGULAR 0x0000 1754#define TX_PACKET_MODE_REGULAR 0x0000
@@ -1704,30 +1770,6 @@ enum {
1704 TX_ABORT_REQUIRED_MSK = 0x80000000, /* bits 31:31 */ 1770 TX_ABORT_REQUIRED_MSK = 0x80000000, /* bits 31:31 */
1705}; 1771};
1706 1772
1707static inline u32 iwl_tx_status_to_mac80211(u32 status)
1708{
1709 status &= TX_STATUS_MSK;
1710
1711 switch (status) {
1712 case TX_STATUS_SUCCESS:
1713 case TX_STATUS_DIRECT_DONE:
1714 return IEEE80211_TX_STAT_ACK;
1715 case TX_STATUS_FAIL_DEST_PS:
1716 return IEEE80211_TX_STAT_TX_FILTERED;
1717 default:
1718 return 0;
1719 }
1720}
1721
1722static inline bool iwl_is_tx_success(u32 status)
1723{
1724 status &= TX_STATUS_MSK;
1725 return (status == TX_STATUS_SUCCESS) ||
1726 (status == TX_STATUS_DIRECT_DONE);
1727}
1728
1729
1730
1731/* ******************************* 1773/* *******************************
1732 * TX aggregation status 1774 * TX aggregation status
1733 ******************************* */ 1775 ******************************* */
diff --git a/drivers/net/wireless/iwlwifi/iwl-core.h b/drivers/net/wireless/iwlwifi/iwl-core.h
index 10f95724536f..d89755f5031a 100644
--- a/drivers/net/wireless/iwlwifi/iwl-core.h
+++ b/drivers/net/wireless/iwlwifi/iwl-core.h
@@ -307,6 +307,7 @@ struct iwl_cfg {
307 u32 monitor_recover_period; 307 u32 monitor_recover_period;
308 bool temperature_kelvin; 308 bool temperature_kelvin;
309 bool off_channel_workaround; 309 bool off_channel_workaround;
310 u32 max_event_log_size;
310}; 311};
311 312
312/*************************** 313/***************************
diff --git a/drivers/net/wireless/iwlwifi/iwl-dev.h b/drivers/net/wireless/iwlwifi/iwl-dev.h
index 4319bda487d9..9466e909f553 100644
--- a/drivers/net/wireless/iwlwifi/iwl-dev.h
+++ b/drivers/net/wireless/iwlwifi/iwl-dev.h
@@ -1120,7 +1120,6 @@ struct iwl_priv {
1120 __le16 sensitivity_tbl[HD_TABLE_SIZE]; 1120 __le16 sensitivity_tbl[HD_TABLE_SIZE];
1121 1121
1122 struct iwl_ht_config current_ht_config; 1122 struct iwl_ht_config current_ht_config;
1123 u8 last_phy_res[100];
1124 1123
1125 /* Rate scaling data */ 1124 /* Rate scaling data */
1126 u8 retry_rate; 1125 u8 retry_rate;
@@ -1167,7 +1166,6 @@ struct iwl_priv {
1167 int num_stations; 1166 int num_stations;
1168 struct iwl_station_entry stations[IWL_STATION_COUNT]; 1167 struct iwl_station_entry stations[IWL_STATION_COUNT];
1169 struct iwl_wep_key wep_keys[WEP_KEYS_MAX]; /* protected by mutex */ 1168 struct iwl_wep_key wep_keys[WEP_KEYS_MAX]; /* protected by mutex */
1170 u8 default_wep_key;
1171 u8 key_mapping_key; 1169 u8 key_mapping_key;
1172 unsigned long ucode_key_table; 1170 unsigned long ucode_key_table;
1173 1171
@@ -1238,6 +1236,9 @@ struct iwl_priv {
1238 * no AGGREGATION 1236 * no AGGREGATION
1239 */ 1237 */
1240 u8 agg_tids_count; 1238 u8 agg_tids_count;
1239
1240 struct iwl_rx_phy_res last_phy_res;
1241 bool last_phy_res_valid;
1241 } _agn; 1242 } _agn;
1242#endif 1243#endif
1243 }; 1244 };
diff --git a/drivers/net/wireless/iwlwifi/iwl-sta.c b/drivers/net/wireless/iwlwifi/iwl-sta.c
index e34ac0355c75..d86ecd2f9ec2 100644
--- a/drivers/net/wireless/iwlwifi/iwl-sta.c
+++ b/drivers/net/wireless/iwlwifi/iwl-sta.c
@@ -194,7 +194,7 @@ int iwl_send_add_sta(struct iwl_priv *priv,
194 .flags = flags, 194 .flags = flags,
195 .data = data, 195 .data = data,
196 }; 196 };
197 u8 sta_id = sta->sta.sta_id; 197 u8 sta_id __maybe_unused = sta->sta.sta_id;
198 198
199 IWL_DEBUG_INFO(priv, "Adding sta %u (%pM) %ssynchronously\n", 199 IWL_DEBUG_INFO(priv, "Adding sta %u (%pM) %ssynchronously\n",
200 sta_id, sta->sta.addr, flags & CMD_ASYNC ? "a" : ""); 200 sta_id, sta->sta.addr, flags & CMD_ASYNC ? "a" : "");
@@ -425,6 +425,7 @@ static void iwl_sta_init_lq(struct iwl_priv *priv, const u8 *addr, bool is_ap)
425 .reserved1 = 0, 425 .reserved1 = 0,
426 }; 426 };
427 u32 rate_flags; 427 u32 rate_flags;
428 int ret = 0;
428 429
429 /* Set up the rate scaling to start at selected rate, fall back 430 /* Set up the rate scaling to start at selected rate, fall back
430 * all the way down to 1M in IEEE order, and then spin on 1M */ 431 * all the way down to 1M in IEEE order, and then spin on 1M */
@@ -458,8 +459,10 @@ static void iwl_sta_init_lq(struct iwl_priv *priv, const u8 *addr, bool is_ap)
458 /* Update the rate scaling for control frame Tx to AP */ 459 /* Update the rate scaling for control frame Tx to AP */
459 link_cmd.sta_id = is_ap ? IWL_AP_ID : priv->hw_params.bcast_sta_id; 460 link_cmd.sta_id = is_ap ? IWL_AP_ID : priv->hw_params.bcast_sta_id;
460 461
461 iwl_send_cmd_pdu(priv, REPLY_TX_LINK_QUALITY_CMD, 462 ret = iwl_send_cmd_pdu(priv, REPLY_TX_LINK_QUALITY_CMD,
462 sizeof(link_cmd), &link_cmd); 463 sizeof(link_cmd), &link_cmd);
464 if (ret)
465 IWL_ERR(priv, "REPLY_TX_LINK_QUALITY_CMD failed (%d)\n", ret);
463} 466}
464 467
465/* 468/*
@@ -759,7 +762,7 @@ int iwl_get_free_ucode_key_index(struct iwl_priv *priv)
759} 762}
760EXPORT_SYMBOL(iwl_get_free_ucode_key_index); 763EXPORT_SYMBOL(iwl_get_free_ucode_key_index);
761 764
762int iwl_send_static_wepkey_cmd(struct iwl_priv *priv, u8 send_if_empty) 765static int iwl_send_static_wepkey_cmd(struct iwl_priv *priv, u8 send_if_empty)
763{ 766{
764 int i, not_empty = 0; 767 int i, not_empty = 0;
765 u8 buff[sizeof(struct iwl_wep_cmd) + 768 u8 buff[sizeof(struct iwl_wep_cmd) +
@@ -803,7 +806,14 @@ int iwl_send_static_wepkey_cmd(struct iwl_priv *priv, u8 send_if_empty)
803 else 806 else
804 return 0; 807 return 0;
805} 808}
806EXPORT_SYMBOL(iwl_send_static_wepkey_cmd); 809
810int iwl_restore_default_wep_keys(struct iwl_priv *priv)
811{
812 WARN_ON(!mutex_is_locked(&priv->mutex));
813
814 return iwl_send_static_wepkey_cmd(priv, 0);
815}
816EXPORT_SYMBOL(iwl_restore_default_wep_keys);
807 817
808int iwl_remove_default_wep_key(struct iwl_priv *priv, 818int iwl_remove_default_wep_key(struct iwl_priv *priv,
809 struct ieee80211_key_conf *keyconf) 819 struct ieee80211_key_conf *keyconf)
@@ -815,11 +825,6 @@ int iwl_remove_default_wep_key(struct iwl_priv *priv,
815 IWL_DEBUG_WEP(priv, "Removing default WEP key: idx=%d\n", 825 IWL_DEBUG_WEP(priv, "Removing default WEP key: idx=%d\n",
816 keyconf->keyidx); 826 keyconf->keyidx);
817 827
818 if (!test_and_clear_bit(keyconf->keyidx, &priv->ucode_key_table))
819 IWL_ERR(priv, "index %d not used in uCode key table.\n",
820 keyconf->keyidx);
821
822 priv->default_wep_key--;
823 memset(&priv->wep_keys[keyconf->keyidx], 0, sizeof(priv->wep_keys[0])); 828 memset(&priv->wep_keys[keyconf->keyidx], 0, sizeof(priv->wep_keys[0]));
824 if (iwl_is_rfkill(priv)) { 829 if (iwl_is_rfkill(priv)) {
825 IWL_DEBUG_WEP(priv, "Not sending REPLY_WEPKEY command due to RFKILL.\n"); 830 IWL_DEBUG_WEP(priv, "Not sending REPLY_WEPKEY command due to RFKILL.\n");
@@ -851,12 +856,6 @@ int iwl_set_default_wep_key(struct iwl_priv *priv,
851 keyconf->hw_key_idx = HW_KEY_DEFAULT; 856 keyconf->hw_key_idx = HW_KEY_DEFAULT;
852 priv->stations[IWL_AP_ID].keyinfo.alg = ALG_WEP; 857 priv->stations[IWL_AP_ID].keyinfo.alg = ALG_WEP;
853 858
854 priv->default_wep_key++;
855
856 if (test_and_set_bit(keyconf->keyidx, &priv->ucode_key_table))
857 IWL_ERR(priv, "index %d already used in uCode key table.\n",
858 keyconf->keyidx);
859
860 priv->wep_keys[keyconf->keyidx].key_size = keyconf->keylen; 859 priv->wep_keys[keyconf->keyidx].key_size = keyconf->keylen;
861 memcpy(&priv->wep_keys[keyconf->keyidx].key, &keyconf->key, 860 memcpy(&priv->wep_keys[keyconf->keyidx].key, &keyconf->key,
862 keyconf->keylen); 861 keyconf->keylen);
@@ -1191,13 +1190,9 @@ int iwl_send_lq_cmd(struct iwl_priv *priv,
1191 .data = lq, 1190 .data = lq,
1192 }; 1191 };
1193 1192
1194 if ((lq->sta_id == 0xFF) && 1193 if (WARN_ON(lq->sta_id == IWL_INVALID_STATION))
1195 (priv->iw_mode == NL80211_IFTYPE_ADHOC))
1196 return -EINVAL; 1194 return -EINVAL;
1197 1195
1198 if (lq->sta_id == 0xFF)
1199 lq->sta_id = IWL_AP_ID;
1200
1201 iwl_dump_lq_cmd(priv, lq); 1196 iwl_dump_lq_cmd(priv, lq);
1202 BUG_ON(init && (cmd.flags & CMD_ASYNC)); 1197 BUG_ON(init && (cmd.flags & CMD_ASYNC));
1203 1198
diff --git a/drivers/net/wireless/iwlwifi/iwl-sta.h b/drivers/net/wireless/iwlwifi/iwl-sta.h
index 87a34997a758..42cd2f4a01cd 100644
--- a/drivers/net/wireless/iwlwifi/iwl-sta.h
+++ b/drivers/net/wireless/iwlwifi/iwl-sta.h
@@ -44,11 +44,11 @@
44 */ 44 */
45u8 iwl_find_station(struct iwl_priv *priv, const u8 *bssid); 45u8 iwl_find_station(struct iwl_priv *priv, const u8 *bssid);
46 46
47int iwl_send_static_wepkey_cmd(struct iwl_priv *priv, u8 send_if_empty);
48int iwl_remove_default_wep_key(struct iwl_priv *priv, 47int iwl_remove_default_wep_key(struct iwl_priv *priv,
49 struct ieee80211_key_conf *key); 48 struct ieee80211_key_conf *key);
50int iwl_set_default_wep_key(struct iwl_priv *priv, 49int iwl_set_default_wep_key(struct iwl_priv *priv,
51 struct ieee80211_key_conf *key); 50 struct ieee80211_key_conf *key);
51int iwl_restore_default_wep_keys(struct iwl_priv *priv);
52int iwl_set_dynamic_key(struct iwl_priv *priv, 52int iwl_set_dynamic_key(struct iwl_priv *priv,
53 struct ieee80211_key_conf *key, u8 sta_id); 53 struct ieee80211_key_conf *key, u8 sta_id);
54int iwl_remove_dynamic_key(struct iwl_priv *priv, 54int iwl_remove_dynamic_key(struct iwl_priv *priv,
diff --git a/drivers/net/wireless/iwlwifi/iwl-tx.c b/drivers/net/wireless/iwlwifi/iwl-tx.c
index a631afef5e33..c3c6505a8c69 100644
--- a/drivers/net/wireless/iwlwifi/iwl-tx.c
+++ b/drivers/net/wireless/iwlwifi/iwl-tx.c
@@ -394,6 +394,26 @@ out_free_arrays:
394} 394}
395EXPORT_SYMBOL(iwl_tx_queue_init); 395EXPORT_SYMBOL(iwl_tx_queue_init);
396 396
397void iwl_tx_queue_reset(struct iwl_priv *priv, struct iwl_tx_queue *txq,
398 int slots_num, u32 txq_id)
399{
400 int actual_slots = slots_num;
401
402 if (txq_id == IWL_CMD_QUEUE_NUM)
403 actual_slots++;
404
405 memset(txq->meta, 0, sizeof(struct iwl_cmd_meta) * actual_slots);
406
407 txq->need_update = 0;
408
409 /* Initialize queue's high/low-water marks, and head/tail indexes */
410 iwl_queue_init(priv, &txq->q, TFD_QUEUE_SIZE_MAX, slots_num, txq_id);
411
412 /* Tell device where to find queue */
413 priv->cfg->ops->lib->txq_init(priv, txq);
414}
415EXPORT_SYMBOL(iwl_tx_queue_reset);
416
397/*************** HOST COMMAND QUEUE FUNCTIONS *****/ 417/*************** HOST COMMAND QUEUE FUNCTIONS *****/
398 418
399/** 419/**
@@ -629,29 +649,36 @@ void iwl_tx_cmd_complete(struct iwl_priv *priv, struct iwl_rx_mem_buffer *rxb)
629EXPORT_SYMBOL(iwl_tx_cmd_complete); 649EXPORT_SYMBOL(iwl_tx_cmd_complete);
630 650
631#ifdef CONFIG_IWLWIFI_DEBUG 651#ifdef CONFIG_IWLWIFI_DEBUG
632#define TX_STATUS_ENTRY(x) case TX_STATUS_FAIL_ ## x: return #x 652#define TX_STATUS_FAIL(x) case TX_STATUS_FAIL_ ## x: return #x
653#define TX_STATUS_POSTPONE(x) case TX_STATUS_POSTPONE_ ## x: return #x
633 654
634const char *iwl_get_tx_fail_reason(u32 status) 655const char *iwl_get_tx_fail_reason(u32 status)
635{ 656{
636 switch (status & TX_STATUS_MSK) { 657 switch (status & TX_STATUS_MSK) {
637 case TX_STATUS_SUCCESS: 658 case TX_STATUS_SUCCESS:
638 return "SUCCESS"; 659 return "SUCCESS";
639 TX_STATUS_ENTRY(SHORT_LIMIT); 660 TX_STATUS_POSTPONE(DELAY);
640 TX_STATUS_ENTRY(LONG_LIMIT); 661 TX_STATUS_POSTPONE(FEW_BYTES);
641 TX_STATUS_ENTRY(FIFO_UNDERRUN); 662 TX_STATUS_POSTPONE(BT_PRIO);
642 TX_STATUS_ENTRY(MGMNT_ABORT); 663 TX_STATUS_POSTPONE(QUIET_PERIOD);
643 TX_STATUS_ENTRY(NEXT_FRAG); 664 TX_STATUS_POSTPONE(CALC_TTAK);
644 TX_STATUS_ENTRY(LIFE_EXPIRE); 665 TX_STATUS_FAIL(INTERNAL_CROSSED_RETRY);
645 TX_STATUS_ENTRY(DEST_PS); 666 TX_STATUS_FAIL(SHORT_LIMIT);
646 TX_STATUS_ENTRY(ABORTED); 667 TX_STATUS_FAIL(LONG_LIMIT);
647 TX_STATUS_ENTRY(BT_RETRY); 668 TX_STATUS_FAIL(FIFO_UNDERRUN);
648 TX_STATUS_ENTRY(STA_INVALID); 669 TX_STATUS_FAIL(DRAIN_FLOW);
649 TX_STATUS_ENTRY(FRAG_DROPPED); 670 TX_STATUS_FAIL(RFKILL_FLUSH);
650 TX_STATUS_ENTRY(TID_DISABLE); 671 TX_STATUS_FAIL(LIFE_EXPIRE);
651 TX_STATUS_ENTRY(FRAME_FLUSHED); 672 TX_STATUS_FAIL(DEST_PS);
652 TX_STATUS_ENTRY(INSUFFICIENT_CF_POLL); 673 TX_STATUS_FAIL(HOST_ABORTED);
653 TX_STATUS_ENTRY(TX_LOCKED); 674 TX_STATUS_FAIL(BT_RETRY);
654 TX_STATUS_ENTRY(NO_BEACON_ON_RADAR); 675 TX_STATUS_FAIL(STA_INVALID);
676 TX_STATUS_FAIL(FRAG_DROPPED);
677 TX_STATUS_FAIL(TID_DISABLE);
678 TX_STATUS_FAIL(FIFO_FLUSHED);
679 TX_STATUS_FAIL(INSUFFICIENT_CF_POLL);
680 TX_STATUS_FAIL(FW_DROP);
681 TX_STATUS_FAIL(STA_COLOR_MISMATCH_DROP);
655 } 682 }
656 683
657 return "UNKNOWN"; 684 return "UNKNOWN";
diff --git a/drivers/net/wireless/iwlwifi/iwl3945-base.c b/drivers/net/wireless/iwlwifi/iwl3945-base.c
index c9188b9c5651..24e969440b31 100644
--- a/drivers/net/wireless/iwlwifi/iwl3945-base.c
+++ b/drivers/net/wireless/iwlwifi/iwl3945-base.c
@@ -1603,9 +1603,6 @@ static int iwl3945_print_last_event_logs(struct iwl_priv *priv, u32 capacity,
1603 return pos; 1603 return pos;
1604} 1604}
1605 1605
1606/* For sanity check only. Actual size is determined by uCode, typ. 512 */
1607#define IWL3945_MAX_EVENT_LOG_SIZE (512)
1608
1609#define DEFAULT_IWL3945_DUMP_EVENT_LOG_ENTRIES (20) 1606#define DEFAULT_IWL3945_DUMP_EVENT_LOG_ENTRIES (20)
1610 1607
1611int iwl3945_dump_nic_event_log(struct iwl_priv *priv, bool full_log, 1608int iwl3945_dump_nic_event_log(struct iwl_priv *priv, bool full_log,
@@ -1632,16 +1629,16 @@ int iwl3945_dump_nic_event_log(struct iwl_priv *priv, bool full_log,
1632 num_wraps = iwl_read_targ_mem(priv, base + (2 * sizeof(u32))); 1629 num_wraps = iwl_read_targ_mem(priv, base + (2 * sizeof(u32)));
1633 next_entry = iwl_read_targ_mem(priv, base + (3 * sizeof(u32))); 1630 next_entry = iwl_read_targ_mem(priv, base + (3 * sizeof(u32)));
1634 1631
1635 if (capacity > IWL3945_MAX_EVENT_LOG_SIZE) { 1632 if (capacity > priv->cfg->max_event_log_size) {
1636 IWL_ERR(priv, "Log capacity %d is bogus, limit to %d entries\n", 1633 IWL_ERR(priv, "Log capacity %d is bogus, limit to %d entries\n",
1637 capacity, IWL3945_MAX_EVENT_LOG_SIZE); 1634 capacity, priv->cfg->max_event_log_size);
1638 capacity = IWL3945_MAX_EVENT_LOG_SIZE; 1635 capacity = priv->cfg->max_event_log_size;
1639 } 1636 }
1640 1637
1641 if (next_entry > IWL3945_MAX_EVENT_LOG_SIZE) { 1638 if (next_entry > priv->cfg->max_event_log_size) {
1642 IWL_ERR(priv, "Log write index %d is bogus, limit to %d\n", 1639 IWL_ERR(priv, "Log write index %d is bogus, limit to %d\n",
1643 next_entry, IWL3945_MAX_EVENT_LOG_SIZE); 1640 next_entry, priv->cfg->max_event_log_size);
1644 next_entry = IWL3945_MAX_EVENT_LOG_SIZE; 1641 next_entry = priv->cfg->max_event_log_size;
1645 } 1642 }
1646 1643
1647 size = num_wraps ? capacity : next_entry; 1644 size = num_wraps ? capacity : next_entry;