diff options
author | mabbas <mabbas@linux.intel.com> | 2007-10-25 05:15:43 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2007-10-25 22:15:43 -0400 |
commit | 052c4b9f0a83a83f3fee735b57c5b1e4edc1da8c (patch) | |
tree | c5a05691c440649b700b5026e616a9ed4775534b /drivers/net/wireless/iwlwifi/iwl4965-base.c | |
parent | 702004b7455e0c4dcf875dd2f638d611892ea84f (diff) |
[PATCH] iwl4965: fix driver hang related to hardware scan
This patch fix the following:
1. make sure we are not scanning before we call REPLY_RXON
2. set RXON_FILTER_ASSOC_MSK only after we receive association response
3. call scan abort on scan watchdog instead of restart
Signed-off-by: Mohamed Abbas <mabbas@linux.intel.com>
Signed-off-by: Zhu Yi <yi.zhu@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/iwlwifi/iwl4965-base.c')
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl4965-base.c | 24 |
1 files changed, 20 insertions, 4 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl4965-base.c b/drivers/net/wireless/iwlwifi/iwl4965-base.c index 5e1279263b22..27b8569b659e 100644 --- a/drivers/net/wireless/iwlwifi/iwl4965-base.c +++ b/drivers/net/wireless/iwlwifi/iwl4965-base.c | |||
@@ -6845,8 +6845,9 @@ static void iwl_bg_scan_check(struct work_struct *data) | |||
6845 | IWL_DEBUG(IWL_DL_INFO | IWL_DL_SCAN, | 6845 | IWL_DEBUG(IWL_DL_INFO | IWL_DL_SCAN, |
6846 | "Scan completion watchdog resetting adapter (%dms)\n", | 6846 | "Scan completion watchdog resetting adapter (%dms)\n", |
6847 | jiffies_to_msecs(IWL_SCAN_CHECK_WATCHDOG)); | 6847 | jiffies_to_msecs(IWL_SCAN_CHECK_WATCHDOG)); |
6848 | |||
6848 | if (!test_bit(STATUS_EXIT_PENDING, &priv->status)) | 6849 | if (!test_bit(STATUS_EXIT_PENDING, &priv->status)) |
6849 | queue_work(priv->workqueue, &priv->restart); | 6850 | iwl_send_scan_abort(priv); |
6850 | } | 6851 | } |
6851 | mutex_unlock(&priv->mutex); | 6852 | mutex_unlock(&priv->mutex); |
6852 | } | 6853 | } |
@@ -6942,7 +6943,7 @@ static void iwl_bg_request_scan(struct work_struct *data) | |||
6942 | spin_unlock_irqrestore(&priv->lock, flags); | 6943 | spin_unlock_irqrestore(&priv->lock, flags); |
6943 | 6944 | ||
6944 | scan->suspend_time = 0; | 6945 | scan->suspend_time = 0; |
6945 | scan->max_out_time = cpu_to_le32(600 * 1024); | 6946 | scan->max_out_time = cpu_to_le32(200 * 1024); |
6946 | if (!interval) | 6947 | if (!interval) |
6947 | interval = suspend_time; | 6948 | interval = suspend_time; |
6948 | 6949 | ||
@@ -7118,6 +7119,8 @@ static void iwl_bg_post_associate(struct work_struct *data) | |||
7118 | 7119 | ||
7119 | mutex_lock(&priv->mutex); | 7120 | mutex_lock(&priv->mutex); |
7120 | 7121 | ||
7122 | iwl_scan_cancel_timeout(priv, 200); | ||
7123 | |||
7121 | conf = ieee80211_get_hw_conf(priv->hw); | 7124 | conf = ieee80211_get_hw_conf(priv->hw); |
7122 | 7125 | ||
7123 | priv->staging_rxon.filter_flags &= ~RXON_FILTER_ASSOC_MSK; | 7126 | priv->staging_rxon.filter_flags &= ~RXON_FILTER_ASSOC_MSK; |
@@ -7573,8 +7576,6 @@ static int iwl_mac_config_interface(struct ieee80211_hw *hw, int if_id, | |||
7573 | if (priv->iw_mode == IEEE80211_IF_TYPE_AP) | 7576 | if (priv->iw_mode == IEEE80211_IF_TYPE_AP) |
7574 | iwl_config_ap(priv); | 7577 | iwl_config_ap(priv); |
7575 | else { | 7578 | else { |
7576 | priv->staging_rxon.filter_flags |= | ||
7577 | RXON_FILTER_ASSOC_MSK; | ||
7578 | rc = iwl_commit_rxon(priv); | 7579 | rc = iwl_commit_rxon(priv); |
7579 | if ((priv->iw_mode == IEEE80211_IF_TYPE_STA) && rc) | 7580 | if ((priv->iw_mode == IEEE80211_IF_TYPE_STA) && rc) |
7580 | iwl_rxon_add_station( | 7581 | iwl_rxon_add_station( |
@@ -7582,6 +7583,7 @@ static int iwl_mac_config_interface(struct ieee80211_hw *hw, int if_id, | |||
7582 | } | 7583 | } |
7583 | 7584 | ||
7584 | } else { | 7585 | } else { |
7586 | iwl_scan_cancel_timeout(priv, 100); | ||
7585 | priv->staging_rxon.filter_flags &= ~RXON_FILTER_ASSOC_MSK; | 7587 | priv->staging_rxon.filter_flags &= ~RXON_FILTER_ASSOC_MSK; |
7586 | iwl_commit_rxon(priv); | 7588 | iwl_commit_rxon(priv); |
7587 | } | 7589 | } |
@@ -7642,6 +7644,7 @@ static int iwl_mac_hw_scan(struct ieee80211_hw *hw, u8 *ssid, size_t len) | |||
7642 | 7644 | ||
7643 | IWL_DEBUG_MAC80211("enter\n"); | 7645 | IWL_DEBUG_MAC80211("enter\n"); |
7644 | 7646 | ||
7647 | mutex_lock(&priv->mutex); | ||
7645 | spin_lock_irqsave(&priv->lock, flags); | 7648 | spin_lock_irqsave(&priv->lock, flags); |
7646 | 7649 | ||
7647 | if (!iwl_is_ready_rf(priv)) { | 7650 | if (!iwl_is_ready_rf(priv)) { |
@@ -7680,6 +7683,7 @@ static int iwl_mac_hw_scan(struct ieee80211_hw *hw, u8 *ssid, size_t len) | |||
7680 | 7683 | ||
7681 | out_unlock: | 7684 | out_unlock: |
7682 | spin_unlock_irqrestore(&priv->lock, flags); | 7685 | spin_unlock_irqrestore(&priv->lock, flags); |
7686 | mutex_unlock(&priv->mutex); | ||
7683 | 7687 | ||
7684 | return rc; | 7688 | return rc; |
7685 | } | 7689 | } |
@@ -7713,6 +7717,8 @@ static int iwl_mac_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd, | |||
7713 | 7717 | ||
7714 | mutex_lock(&priv->mutex); | 7718 | mutex_lock(&priv->mutex); |
7715 | 7719 | ||
7720 | iwl_scan_cancel_timeout(priv, 100); | ||
7721 | |||
7716 | switch (cmd) { | 7722 | switch (cmd) { |
7717 | case SET_KEY: | 7723 | case SET_KEY: |
7718 | rc = iwl_update_sta_key_info(priv, key, sta_id); | 7724 | rc = iwl_update_sta_key_info(priv, key, sta_id); |
@@ -7903,8 +7909,18 @@ static void iwl_mac_reset_tsf(struct ieee80211_hw *hw) | |||
7903 | 7909 | ||
7904 | spin_unlock_irqrestore(&priv->lock, flags); | 7910 | spin_unlock_irqrestore(&priv->lock, flags); |
7905 | 7911 | ||
7912 | /* we are restarting association process | ||
7913 | * clear RXON_FILTER_ASSOC_MSK bit | ||
7914 | */ | ||
7915 | if (priv->iw_mode != IEEE80211_IF_TYPE_AP) { | ||
7916 | iwl_scan_cancel_timeout(priv, 100); | ||
7917 | priv->staging_rxon.filter_flags &= ~RXON_FILTER_ASSOC_MSK; | ||
7918 | iwl_commit_rxon(priv); | ||
7919 | } | ||
7920 | |||
7906 | /* Per mac80211.h: This is only used in IBSS mode... */ | 7921 | /* Per mac80211.h: This is only used in IBSS mode... */ |
7907 | if (priv->iw_mode != IEEE80211_IF_TYPE_IBSS) { | 7922 | if (priv->iw_mode != IEEE80211_IF_TYPE_IBSS) { |
7923 | |||
7908 | IWL_DEBUG_MAC80211("leave - not in IBSS\n"); | 7924 | IWL_DEBUG_MAC80211("leave - not in IBSS\n"); |
7909 | mutex_unlock(&priv->mutex); | 7925 | mutex_unlock(&priv->mutex); |
7910 | return; | 7926 | return; |