iwlwifi: mvm: don't warn in queue sync on RF-kill
authorJohannes Berg <johannes.berg@intel.com>
Tue, 25 Apr 2017 08:21:18 +0000 (10:21 +0200)
committerLuca Coelho <luciano.coelho@intel.com>
Thu, 22 Jun 2017 21:13:01 +0000 (00:13 +0300)
If we happen to be in or get into the queue sync when RF-kill
is asserted, we return from there and warn since there are
still queue sync notifications outstanding. These can't ever
come though, because we're in RF-kill, so don't WARN then.

While at it, also move the warning to the appropriate place,
if the request is not synchronous then we shouldn't warn, but
currently always will.

To make it fast, also trigger the waitq when on rfkill assert.

Fixes: 0636b938214c ("iwlwifi: mvm: implement driver RX queues sync command")
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: Luca Coelho <luciano.coelho@intel.com>
drivers/net/wireless/intel/iwlwifi/mvm/mac80211.c
drivers/net/wireless/intel/iwlwifi/mvm/ops.c

index 75ec567ab9e2de21336ca2ad7b2b420108326bf0..2449be6f95a50c077971b5b63790088b89e3cf22 100644 (file)
@@ -4277,11 +4277,13 @@ void iwl_mvm_sync_rx_queues_internal(struct iwl_mvm *mvm,
                goto out;
        }
 
-       if (notif->sync)
+       if (notif->sync) {
                ret = wait_event_timeout(mvm->rx_sync_waitq,
-                                        atomic_read(&mvm->queue_sync_counter) == 0,
+                                        atomic_read(&mvm->queue_sync_counter) == 0 ||
+                                        iwl_mvm_is_radio_killed(mvm),
                                         HZ);
-       WARN_ON_ONCE(!ret);
+               WARN_ON_ONCE(!ret && !iwl_mvm_is_radio_killed(mvm));
+       }
 
 out:
        atomic_set(&mvm->queue_sync_counter, 0);
index c9686e31b32e530771b66e4dfa58488d609a12cd..30fc756b5b01f7ddc0f0101894026762b3e55fcf 100644 (file)
@@ -1094,6 +1094,16 @@ static void iwl_mvm_wake_sw_queue(struct iwl_op_mode *op_mode, int hw_queue)
        iwl_mvm_start_mac_queues(mvm, mq);
 }
 
+static void iwl_mvm_set_rfkill_state(struct iwl_mvm *mvm)
+{
+       bool state = iwl_mvm_is_radio_killed(mvm);
+
+       if (state)
+               wake_up(&mvm->rx_sync_waitq);
+
+       wiphy_rfkill_set_hw_state(mvm->hw->wiphy, state);
+}
+
 void iwl_mvm_set_hw_ctkill_state(struct iwl_mvm *mvm, bool state)
 {
        if (state)
@@ -1101,7 +1111,7 @@ void iwl_mvm_set_hw_ctkill_state(struct iwl_mvm *mvm, bool state)
        else
                clear_bit(IWL_MVM_STATUS_HW_CTKILL, &mvm->status);
 
-       wiphy_rfkill_set_hw_state(mvm->hw->wiphy, iwl_mvm_is_radio_killed(mvm));
+       iwl_mvm_set_rfkill_state(mvm);
 }
 
 static bool iwl_mvm_set_hw_rfkill_state(struct iwl_op_mode *op_mode, bool state)
@@ -1114,7 +1124,7 @@ static bool iwl_mvm_set_hw_rfkill_state(struct iwl_op_mode *op_mode, bool state)
        else
                clear_bit(IWL_MVM_STATUS_HW_RFKILL, &mvm->status);
 
-       wiphy_rfkill_set_hw_state(mvm->hw->wiphy, iwl_mvm_is_radio_killed(mvm));
+       iwl_mvm_set_rfkill_state(mvm);
 
        /* iwl_run_init_mvm_ucode is waiting for results, abort it */
        if (calibrating)