iwlwifi: mvm: add D0i3 ref/unref for scan
authorArik Nemtsov <arik@wizery.com>
Thu, 17 Oct 2013 14:51:35 +0000 (17:51 +0300)
committerEmmanuel Grumbach <emmanuel.grumbach@intel.com>
Mon, 3 Feb 2014 20:23:40 +0000 (22:23 +0200)
Take a reference when starting to scan and release it on completion.
Note that if the scan is cancelled/aborted, a completion will still be
sent up.

Signed-off-by: Arik Nemtsov <arikx.nemtsov@intel.com>
Signed-off-by: Eliad Peller <eliadx.peller@intel.com>
Reviewed-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com>
drivers/net/wireless/iwlwifi/mvm/mac80211.c
drivers/net/wireless/iwlwifi/mvm/mvm.h
drivers/net/wireless/iwlwifi/mvm/scan.c

index e12168556381ed9e14bbf19316738aad5cd66141..64d9efd127d70a454a5dd25fd8ca197b54f948bc 100644 (file)
@@ -1442,11 +1442,17 @@ static int iwl_mvm_mac_hw_scan(struct ieee80211_hw *hw,
 
        mutex_lock(&mvm->mutex);
 
-       if (mvm->scan_status == IWL_MVM_SCAN_NONE)
-               ret = iwl_mvm_scan_request(mvm, vif, req);
-       else
+       if (mvm->scan_status != IWL_MVM_SCAN_NONE) {
                ret = -EBUSY;
+               goto out;
+       }
 
+       iwl_mvm_ref(mvm, IWL_MVM_REF_SCAN);
+
+       ret = iwl_mvm_scan_request(mvm, vif, req);
+       if (ret)
+               iwl_mvm_unref(mvm, IWL_MVM_REF_SCAN);
+out:
        mutex_unlock(&mvm->mutex);
 
        return ret;
index 9ffafe80dad5caabef06cd7fb8ba7bd9fd62f8ca..3a3e9f18a2ed8610f617d9cba73b4fd3ae59950d 100644 (file)
@@ -241,6 +241,7 @@ enum iwl_mvm_smps_type_request {
 
 enum iwl_mvm_ref_type {
        IWL_MVM_REF_UCODE_DOWN,
+       IWL_MVM_REF_SCAN,
 
        IWL_MVM_REF_COUNT,
 };
index 6c5c17397f7ee205fdca007663a313b4bb552ad1..8477902a91838dcb72c201d3da797de66be1c735 100644 (file)
@@ -407,6 +407,8 @@ int iwl_mvm_rx_scan_complete(struct iwl_mvm *mvm, struct iwl_rx_cmd_buffer *rxb,
        mvm->scan_status = IWL_MVM_SCAN_NONE;
        ieee80211_scan_completed(mvm->hw, notif->status != SCAN_COMP_STATUS_OK);
 
+       iwl_mvm_unref(mvm, IWL_MVM_REF_SCAN);
+
        return 0;
 }
 
@@ -475,6 +477,7 @@ void iwl_mvm_cancel_scan(struct iwl_mvm *mvm)
 
        if (iwl_mvm_is_radio_killed(mvm)) {
                ieee80211_scan_completed(mvm->hw, true);
+               iwl_mvm_unref(mvm, IWL_MVM_REF_SCAN);
                mvm->scan_status = IWL_MVM_SCAN_NONE;
                return;
        }