Commit dafe6c43 authored by eytan lifshitz's avatar eytan lifshitz Committed by Johannes Berg

iwlwifi: mvm: add thermal throttling debugging

Add prints visible to the user when entering and exiting
thrermal throttling, because so users can tell that the
NIC is getting too hot (and throughput will decrease.)
Signed-off-by: default avatareytan lifshitz <eytan.lifshitz@intel.com>
Reviewed-by: default avatarEmmanuel Grumbach <emmanuel.grumbach@intel.com>
Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
parent e715c3a9
...@@ -352,12 +352,14 @@ struct iwl_tt_params { ...@@ -352,12 +352,14 @@ struct iwl_tt_params {
* @dynamic_smps: Is thermal throttling enabled dynamic_smps? * @dynamic_smps: Is thermal throttling enabled dynamic_smps?
* @tx_backoff: The current thremal throttling tx backoff in uSec. * @tx_backoff: The current thremal throttling tx backoff in uSec.
* @params: Parameters to configure the thermal throttling algorithm. * @params: Parameters to configure the thermal throttling algorithm.
* @throttle: Is thermal throttling is active?
*/ */
struct iwl_mvm_tt_mgmt { struct iwl_mvm_tt_mgmt {
struct delayed_work ct_kill_exit; struct delayed_work ct_kill_exit;
bool dynamic_smps; bool dynamic_smps;
u32 tx_backoff; u32 tx_backoff;
const struct iwl_tt_params *params; const struct iwl_tt_params *params;
bool throttle;
}; };
struct iwl_mvm { struct iwl_mvm {
......
...@@ -427,6 +427,7 @@ void iwl_mvm_tt_handler(struct iwl_mvm *mvm) ...@@ -427,6 +427,7 @@ void iwl_mvm_tt_handler(struct iwl_mvm *mvm)
const struct iwl_tt_params *params = mvm->thermal_throttle.params; const struct iwl_tt_params *params = mvm->thermal_throttle.params;
struct iwl_mvm_tt_mgmt *tt = &mvm->thermal_throttle; struct iwl_mvm_tt_mgmt *tt = &mvm->thermal_throttle;
s32 temperature = mvm->temperature; s32 temperature = mvm->temperature;
bool throttle_enable = false;
int i; int i;
u32 tx_backoff; u32 tx_backoff;
...@@ -445,6 +446,7 @@ void iwl_mvm_tt_handler(struct iwl_mvm *mvm) ...@@ -445,6 +446,7 @@ void iwl_mvm_tt_handler(struct iwl_mvm *mvm)
ieee80211_iterate_active_interfaces_atomic( ieee80211_iterate_active_interfaces_atomic(
mvm->hw, IEEE80211_IFACE_ITER_NORMAL, mvm->hw, IEEE80211_IFACE_ITER_NORMAL,
iwl_mvm_tt_smps_iterator, mvm); iwl_mvm_tt_smps_iterator, mvm);
throttle_enable = true;
} else if (tt->dynamic_smps && } else if (tt->dynamic_smps &&
temperature <= params->dynamic_smps_exit) { temperature <= params->dynamic_smps_exit) {
IWL_DEBUG_TEMP(mvm, "Disable dynamic SMPS\n"); IWL_DEBUG_TEMP(mvm, "Disable dynamic SMPS\n");
...@@ -456,10 +458,12 @@ void iwl_mvm_tt_handler(struct iwl_mvm *mvm) ...@@ -456,10 +458,12 @@ void iwl_mvm_tt_handler(struct iwl_mvm *mvm)
} }
if (params->support_tx_protection) { if (params->support_tx_protection) {
if (temperature >= params->tx_protection_entry) if (temperature >= params->tx_protection_entry) {
iwl_mvm_tt_tx_protection(mvm, true); iwl_mvm_tt_tx_protection(mvm, true);
else if (temperature <= params->tx_protection_exit) throttle_enable = true;
} else if (temperature <= params->tx_protection_exit) {
iwl_mvm_tt_tx_protection(mvm, false); iwl_mvm_tt_tx_protection(mvm, false);
}
} }
if (params->support_tx_backoff) { if (params->support_tx_backoff) {
...@@ -469,9 +473,22 @@ void iwl_mvm_tt_handler(struct iwl_mvm *mvm) ...@@ -469,9 +473,22 @@ void iwl_mvm_tt_handler(struct iwl_mvm *mvm)
break; break;
tx_backoff = params->tx_backoff[i].backoff; tx_backoff = params->tx_backoff[i].backoff;
} }
if (tx_backoff != 0)
throttle_enable = true;
if (tt->tx_backoff != tx_backoff) if (tt->tx_backoff != tx_backoff)
iwl_mvm_tt_tx_backoff(mvm, tx_backoff); iwl_mvm_tt_tx_backoff(mvm, tx_backoff);
} }
if (!tt->throttle && throttle_enable) {
IWL_WARN(mvm,
"Due to high temperature thermal throttling initiated\n");
tt->throttle = true;
} else if (tt->throttle && !tt->dynamic_smps && tt->tx_backoff == 0 &&
temperature <= params->tx_protection_exit) {
IWL_WARN(mvm,
"Temperature is back to normal thermal throttling stopped\n");
tt->throttle = false;
}
} }
static const struct iwl_tt_params iwl7000_tt_params = { static const struct iwl_tt_params iwl7000_tt_params = {
...@@ -502,6 +519,7 @@ void iwl_mvm_tt_initialize(struct iwl_mvm *mvm) ...@@ -502,6 +519,7 @@ void iwl_mvm_tt_initialize(struct iwl_mvm *mvm)
IWL_DEBUG_TEMP(mvm, "Initialize Thermal Throttling\n"); IWL_DEBUG_TEMP(mvm, "Initialize Thermal Throttling\n");
tt->params = &iwl7000_tt_params; tt->params = &iwl7000_tt_params;
tt->throttle = false;
INIT_DELAYED_WORK(&tt->ct_kill_exit, check_exit_ctkill); INIT_DELAYED_WORK(&tt->ct_kill_exit, check_exit_ctkill);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment