diff options
| author | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2020-01-10 11:52:32 +0100 | 
|---|---|---|
| committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2020-01-23 00:37:01 +0100 | 
| commit | 1aefbd7aeb7695c1a9e6ece9a1612ee88e1ea3f8 (patch) | |
| tree | e481a980f673dac6091ed4de33886886fee88cfd /drivers/idle | |
| parent | 095928ae484b9f765fb4967c6cf76a2f86fc9787 (diff) | |
intel_idle: Move 3 functions closer to their callers
Move intel_idle_verify_cstate(), auto_demotion_disable() and
c1e_promotion_disable() closer to their callers.
While at it, annotate intel_idle_verify_cstate() with __init,
as it is only used during the initialization of the driver.
No intentional functional impact.
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Diffstat (limited to 'drivers/idle')
| -rw-r--r-- | drivers/idle/intel_idle.c | 67 | 
1 files changed, 34 insertions, 33 deletions
| diff --git a/drivers/idle/intel_idle.c b/drivers/idle/intel_idle.c index b796eaea8715..27c50fba26d5 100644 --- a/drivers/idle/intel_idle.c +++ b/drivers/idle/intel_idle.c @@ -951,39 +951,6 @@ static void intel_idle_s2idle(struct cpuidle_device *dev,  	mwait_idle_with_hints(eax, ecx);  } -static bool intel_idle_verify_cstate(unsigned int mwait_hint) -{ -	unsigned int mwait_cstate = MWAIT_HINT2CSTATE(mwait_hint) + 1; -	unsigned int num_substates = (mwait_substates >> mwait_cstate * 4) & -					MWAIT_SUBSTATE_MASK; - -	/* Ignore the C-state if there are NO sub-states in CPUID for it. */ -	if (num_substates == 0) -		return false; - -	if (mwait_cstate > 2 && !boot_cpu_has(X86_FEATURE_NONSTOP_TSC)) -		mark_tsc_unstable("TSC halts in idle states deeper than C2"); - -	return true; -} - -static void auto_demotion_disable(void) -{ -	unsigned long long msr_bits; - -	rdmsrl(MSR_PKG_CST_CONFIG_CONTROL, msr_bits); -	msr_bits &= ~(icpu->auto_demotion_disable_flags); -	wrmsrl(MSR_PKG_CST_CONFIG_CONTROL, msr_bits); -} -static void c1e_promotion_disable(void) -{ -	unsigned long long msr_bits; - -	rdmsrl(MSR_IA32_POWER_CTL, msr_bits); -	msr_bits &= ~0x2; -	wrmsrl(MSR_IA32_POWER_CTL, msr_bits); -} -  static const struct idle_cpu idle_cpu_nehalem = {  	.state_table = nehalem_cstates,  	.auto_demotion_disable_flags = NHM_C1_AUTO_DEMOTE | NHM_C3_AUTO_DEMOTE, @@ -1434,6 +1401,22 @@ static void __init sklh_idle_state_table_update(void)  	skl_cstates[6].flags |= CPUIDLE_FLAG_UNUSABLE;	/* C9-SKL */  } +static bool __init intel_idle_verify_cstate(unsigned int mwait_hint) +{ +	unsigned int mwait_cstate = MWAIT_HINT2CSTATE(mwait_hint) + 1; +	unsigned int num_substates = (mwait_substates >> mwait_cstate * 4) & +					MWAIT_SUBSTATE_MASK; + +	/* Ignore the C-state if there are NO sub-states in CPUID for it. */ +	if (num_substates == 0) +		return false; + +	if (mwait_cstate > 2 && !boot_cpu_has(X86_FEATURE_NONSTOP_TSC)) +		mark_tsc_unstable("TSC halts in idle states deeper than C2"); + +	return true; +} +  static void __init intel_idle_init_cstates_icpu(struct cpuidle_driver *drv)  {  	int cstate; @@ -1503,6 +1486,24 @@ static void __init intel_idle_cpuidle_driver_init(struct cpuidle_driver *drv)  		intel_idle_init_cstates_acpi(drv);  } +static void auto_demotion_disable(void) +{ +	unsigned long long msr_bits; + +	rdmsrl(MSR_PKG_CST_CONFIG_CONTROL, msr_bits); +	msr_bits &= ~(icpu->auto_demotion_disable_flags); +	wrmsrl(MSR_PKG_CST_CONFIG_CONTROL, msr_bits); +} + +static void c1e_promotion_disable(void) +{ +	unsigned long long msr_bits; + +	rdmsrl(MSR_IA32_POWER_CTL, msr_bits); +	msr_bits &= ~0x2; +	wrmsrl(MSR_IA32_POWER_CTL, msr_bits); +} +  /*   * intel_idle_cpu_init()   * allocate, initialize, register cpuidle_devices | 
