aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorReinette Chatre <reinette.chatre@intel.com>2009-03-27 15:45:30 -0400
committerJohn W. Linville <linville@tuxdriver.com>2009-04-22 16:54:37 -0400
commit55a3757a5703ebc58612ffbfbcb7f193dae17df7 (patch)
treed24e72c38f311e2e5398bb6ce1bda2823e0eacea
parent71a7b26d3e6404e43574f80236c00eaa39b2525e (diff)
iwlwifi: change check triggering device restart after rfkill change
The STATUS_ALIVE value cannot be used because it is cleared when interface is brought down and will not be set if rfkill is enabled when interface is started again. The interface can thus not be brought up if rfkill was enabled before stopping the interface and disabled after starting the interface. Change the test to use priv->is_open instead, this will be set when interface is started whether rfkill is enabled or not. Thanks to Helmut Schaa for the suggested fix. Signed-off-by: Reinette Chatre <reinette.chatre@intel.com> Acked-by: Helmut Schaa <helmut.schaa@googlemail.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-core.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-core.c b/drivers/net/wireless/iwlwifi/iwl-core.c
index 7609bfced10f..82abb1f9087f 100644
--- a/drivers/net/wireless/iwlwifi/iwl-core.c
+++ b/drivers/net/wireless/iwlwifi/iwl-core.c
@@ -2054,7 +2054,7 @@ void iwl_bg_rf_kill(struct work_struct *work)
2054 "HW and/or SW RF Kill no longer active, restarting " 2054 "HW and/or SW RF Kill no longer active, restarting "
2055 "device\n"); 2055 "device\n");
2056 if (!test_bit(STATUS_EXIT_PENDING, &priv->status) && 2056 if (!test_bit(STATUS_EXIT_PENDING, &priv->status) &&
2057 test_bit(STATUS_ALIVE, &priv->status)) 2057 priv->is_open)
2058 queue_work(priv->workqueue, &priv->restart); 2058 queue_work(priv->workqueue, &priv->restart);
2059 } else { 2059 } else {
2060 /* make sure mac80211 stop sending Tx frame */ 2060 /* make sure mac80211 stop sending Tx frame */