diff options
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-scan.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-scan.c b/drivers/net/wireless/iwlwifi/iwl-scan.c index 3379b41fb5ee..b0abf891516f 100644 --- a/drivers/net/wireless/iwlwifi/iwl-scan.c +++ b/drivers/net/wireless/iwlwifi/iwl-scan.c | |||
@@ -834,6 +834,13 @@ static void iwl_bg_request_scan(struct work_struct *data) | |||
834 | return; | 834 | return; |
835 | 835 | ||
836 | done: | 836 | done: |
837 | /* Cannot perform scan. Make sure we clear scanning | ||
838 | * bits from status so next scan request can be performed. | ||
839 | * If we don't clear scanning status bit here all next scan | ||
840 | * will fail | ||
841 | */ | ||
842 | clear_bit(STATUS_SCAN_HW, &priv->status); | ||
843 | clear_bit(STATUS_SCANNING, &priv->status); | ||
837 | /* inform mac80211 scan aborted */ | 844 | /* inform mac80211 scan aborted */ |
838 | queue_work(priv->workqueue, &priv->scan_completed); | 845 | queue_work(priv->workqueue, &priv->scan_completed); |
839 | mutex_unlock(&priv->mutex); | 846 | mutex_unlock(&priv->mutex); |