aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/iwlwifi/iwl-rx.c
diff options
context:
space:
mode:
authorWey-Yi Guy <wey-yi.w.guy@intel.com>2010-03-16 13:46:31 -0400
committerReinette Chatre <reinette.chatre@intel.com>2010-03-25 14:16:37 -0400
commit872c8ddcbec06995c1c7caa3e41c921290a8b6df (patch)
tree15aebc3465235e7d35c41f9f2470221b957fab71 /drivers/net/wireless/iwlwifi/iwl-rx.c
parente184f67d39f681b1e8c9a43ff7001c3405c2bd7c (diff)
iwlwifi: iwl_good_ack_health() only apply to AGN device
iwl_good_ack_health() check for expected and actual ack count which only apply to aggregation mode. Move the function to iwlagn module. Reported-by: Chantry Xavier <chantry.xavier@gmail.com> Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com> Signed-off-by: Reinette Chatre <reinette.chatre@intel.com>
Diffstat (limited to 'drivers/net/wireless/iwlwifi/iwl-rx.c')
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-rx.c55
1 files changed, 0 insertions, 55 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-rx.c b/drivers/net/wireless/iwlwifi/iwl-rx.c
index b6a64d83718a..de453f25f1c9 100644
--- a/drivers/net/wireless/iwlwifi/iwl-rx.c
+++ b/drivers/net/wireless/iwlwifi/iwl-rx.c
@@ -616,61 +616,6 @@ static void iwl_accumulative_statistics(struct iwl_priv *priv,
616 616
617#define REG_RECALIB_PERIOD (60) 617#define REG_RECALIB_PERIOD (60)
618 618
619/* the threshold ratio of actual_ack_cnt to expected_ack_cnt in percent */
620#define ACK_CNT_RATIO (50)
621#define BA_TIMEOUT_CNT (5)
622#define BA_TIMEOUT_MAX (16)
623
624/**
625 * iwl_good_ack_health - checks for ACK count ratios, BA timeout retries.
626 *
627 * When the ACK count ratio is 0 and aggregated BA timeout retries exceeding
628 * the BA_TIMEOUT_MAX, reload firmware and bring system back to normal
629 * operation state.
630 */
631bool iwl_good_ack_health(struct iwl_priv *priv,
632 struct iwl_rx_packet *pkt)
633{
634 bool rc = true;
635 int actual_ack_cnt_delta, expected_ack_cnt_delta;
636 int ba_timeout_delta;
637
638 actual_ack_cnt_delta =
639 le32_to_cpu(pkt->u.stats.tx.actual_ack_cnt) -
640 le32_to_cpu(priv->statistics.tx.actual_ack_cnt);
641 expected_ack_cnt_delta =
642 le32_to_cpu(pkt->u.stats.tx.expected_ack_cnt) -
643 le32_to_cpu(priv->statistics.tx.expected_ack_cnt);
644 ba_timeout_delta =
645 le32_to_cpu(pkt->u.stats.tx.agg.ba_timeout) -
646 le32_to_cpu(priv->statistics.tx.agg.ba_timeout);
647 if ((priv->_agn.agg_tids_count > 0) &&
648 (expected_ack_cnt_delta > 0) &&
649 (((actual_ack_cnt_delta * 100) / expected_ack_cnt_delta)
650 < ACK_CNT_RATIO) &&
651 (ba_timeout_delta > BA_TIMEOUT_CNT)) {
652 IWL_DEBUG_RADIO(priv, "actual_ack_cnt delta = %d,"
653 " expected_ack_cnt = %d\n",
654 actual_ack_cnt_delta, expected_ack_cnt_delta);
655
656#ifdef CONFIG_IWLWIFI_DEBUG
657 IWL_DEBUG_RADIO(priv, "rx_detected_cnt delta = %d\n",
658 priv->delta_statistics.tx.rx_detected_cnt);
659 IWL_DEBUG_RADIO(priv,
660 "ack_or_ba_timeout_collision delta = %d\n",
661 priv->delta_statistics.tx.
662 ack_or_ba_timeout_collision);
663#endif
664 IWL_DEBUG_RADIO(priv, "agg ba_timeout delta = %d\n",
665 ba_timeout_delta);
666 if (!actual_ack_cnt_delta &&
667 (ba_timeout_delta >= BA_TIMEOUT_MAX))
668 rc = false;
669 }
670 return rc;
671}
672EXPORT_SYMBOL(iwl_good_ack_health);
673
674/** 619/**
675 * iwl_good_plcp_health - checks for plcp error. 620 * iwl_good_plcp_health - checks for plcp error.
676 * 621 *