diff options
author | Wey-Yi Guy <wey-yi.w.guy@intel.com> | 2009-10-02 16:43:58 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-10-07 16:39:44 -0400 |
commit | 7812b16730ccebce71a3b2228ac08dd4f8b39469 (patch) | |
tree | 83f45bd70261ea6405ca0b8792b92ad998e7547f /drivers/net/wireless/iwlwifi/iwl-power.h | |
parent | ffe9793252de2e9a3cc7e29a6c7debd1d549df07 (diff) |
iwlwifi: reliable entering of critical temperature state
When uCode detects critical temperature it should send "card state
notification" interrupt to driver and then shut itself down to prevent
overheating. There is a race condition where uCode shuts down before it
can deliver the interrupt to driver.
Additional method provided here for driver to enter CT_KILL state based
on temperature reading.
How it works:
Method 1:
If driver receive "card state notification" interrupt from uCode; it
enters "CT_KILL" state immediately
Method 2:
If the last temperature report by Card reach Critical temperature,
driver will send "statistic notification" request to uCode to verify the
temperature reading, if driver can not get reply from uCode within
300ms, driver will enter CT_KILL state automatically.
Method 3:
If the last temperature report by Card did not reach Critical
temperature, but uCode already shut down due to critical temperature.
All the host commands send to uCode will not get process by uCode;
when command queue reach the limit, driver will check the last reported
temperature reading, if it is within pre-defined margin, enter "CT_KILL"
state immediately. In this case, when uCode ready to exit from "CT_KILL" state,
driver need to restart the adapter in order to reset all the queues and
resume normal operation.
One additional issue being address here, when system is in CT_KILL
state, both tx and rx already stopped, but driver still can send host
command to uCode, it will flood the command queue since card was not
responding; adding STATUS_CT_KILL flag to reject enqueue host commands
to uCode if it is in CT_KILL state, when uCode is ready to come out of
CT_KILL, driver will clear the STATUS_CT_KILL bit and allow enqueue the host
commands to uCode to recover from CT_KILL state.
Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com>
Signed-off-by: Reinette Chatre <reinette.chatre@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/iwlwifi/iwl-power.h')
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-power.h | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-power.h b/drivers/net/wireless/iwlwifi/iwl-power.h index df6f6a49712b..310c32e8f698 100644 --- a/drivers/net/wireless/iwlwifi/iwl-power.h +++ b/drivers/net/wireless/iwlwifi/iwl-power.h | |||
@@ -33,6 +33,7 @@ | |||
33 | #define IWL_ABSOLUTE_ZERO 0 | 33 | #define IWL_ABSOLUTE_ZERO 0 |
34 | #define IWL_ABSOLUTE_MAX 0xFFFFFFFF | 34 | #define IWL_ABSOLUTE_MAX 0xFFFFFFFF |
35 | #define IWL_TT_INCREASE_MARGIN 5 | 35 | #define IWL_TT_INCREASE_MARGIN 5 |
36 | #define IWL_TT_CT_KILL_MARGIN 3 | ||
36 | 37 | ||
37 | enum iwl_antenna_ok { | 38 | enum iwl_antenna_ok { |
38 | IWL_ANT_OK_NONE, | 39 | IWL_ANT_OK_NONE, |
@@ -110,6 +111,7 @@ struct iwl_tt_mgmt { | |||
110 | struct iwl_tt_restriction *restriction; | 111 | struct iwl_tt_restriction *restriction; |
111 | struct iwl_tt_trans *transaction; | 112 | struct iwl_tt_trans *transaction; |
112 | struct timer_list ct_kill_exit_tm; | 113 | struct timer_list ct_kill_exit_tm; |
114 | struct timer_list ct_kill_waiting_tm; | ||
113 | }; | 115 | }; |
114 | 116 | ||
115 | enum iwl_power_level { | 117 | enum iwl_power_level { |
@@ -129,6 +131,7 @@ struct iwl_power_mgr { | |||
129 | 131 | ||
130 | int iwl_power_update_mode(struct iwl_priv *priv, bool force); | 132 | int iwl_power_update_mode(struct iwl_priv *priv, bool force); |
131 | bool iwl_ht_enabled(struct iwl_priv *priv); | 133 | bool iwl_ht_enabled(struct iwl_priv *priv); |
134 | bool iwl_within_ct_kill_margin(struct iwl_priv *priv); | ||
132 | enum iwl_antenna_ok iwl_tx_ant_restriction(struct iwl_priv *priv); | 135 | enum iwl_antenna_ok iwl_tx_ant_restriction(struct iwl_priv *priv); |
133 | enum iwl_antenna_ok iwl_rx_ant_restriction(struct iwl_priv *priv); | 136 | enum iwl_antenna_ok iwl_rx_ant_restriction(struct iwl_priv *priv); |
134 | void iwl_tt_enter_ct_kill(struct iwl_priv *priv); | 137 | void iwl_tt_enter_ct_kill(struct iwl_priv *priv); |