soc/intel/skylake: Add config for cpu base clock frequency

Add config for cpu base clock frequency(Mhz) and replace current
refrence from soc/cpu.h with config option.

Change-Id: Idf8e85f7ae6d965fa987a4f5c4905503ee354d69
Signed-off-by: Aamir Bohra <aamir.bohra@intel.com>
Reviewed-on: https://review.coreboot.org/20016
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Aaron Durbin <adurbin@chromium.org>
This commit is contained in:
Aamir Bohra 2017-06-02 11:56:14 +05:30 committed by Aaron Durbin
parent 5391e554e1
commit 1041d399cb
6 changed files with 9 additions and 9 deletions

View File

@ -323,4 +323,8 @@ config SOC_INTEL_COMMON_BLOCK_GSPI_MAX
int int
default 2 default 2
config CPU_BCLK_MHZ
int
default 100
endif endif

View File

@ -410,7 +410,7 @@ static void generate_p_state_entries(int core, int cores_per_package)
/* Max Non-Turbo Ratio */ /* Max Non-Turbo Ratio */
ratio_max = (msr.lo >> 8) & 0xff; ratio_max = (msr.lo >> 8) & 0xff;
} }
clock_max = ratio_max * CPU_BCLK; clock_max = ratio_max * CONFIG_CPU_BCLK_MHZ;
/* Calculate CPU TDP in mW */ /* Calculate CPU TDP in mW */
msr = rdmsr(MSR_PKG_POWER_SKU_UNIT); msr = rdmsr(MSR_PKG_POWER_SKU_UNIT);
@ -474,7 +474,7 @@ static void generate_p_state_entries(int core, int cores_per_package)
/* Calculate power at this ratio */ /* Calculate power at this ratio */
power = calculate_power(power_max, ratio_max, ratio); power = calculate_power(power_max, ratio_max, ratio);
clock = ratio * CPU_BCLK; clock = ratio * CONFIG_CPU_BCLK_MHZ;
acpigen_write_PSS_package( acpigen_write_PSS_package(
clock, /* MHz */ clock, /* MHz */

View File

@ -113,5 +113,5 @@ void set_max_freq(void)
wrmsr(MSR_IA32_PERF_CTL, perf_ctl); wrmsr(MSR_IA32_PERF_CTL, perf_ctl);
printk(BIOS_DEBUG, "CPU: frequency set to %d MHz\n", printk(BIOS_DEBUG, "CPU: frequency set to %d MHz\n",
((perf_ctl.lo >> 8) & 0xff) * CPU_BCLK); ((perf_ctl.lo >> 8) & 0xff) * CONFIG_CPU_BCLK_MHZ);
} }

View File

@ -320,7 +320,7 @@ static void set_max_ratio(void)
wrmsr(IA32_PERF_CTL, perf_ctl); wrmsr(IA32_PERF_CTL, perf_ctl);
printk(BIOS_DEBUG, "cpu: frequency set to %d\n", printk(BIOS_DEBUG, "cpu: frequency set to %d\n",
((perf_ctl.lo >> 8) & 0xff) * CPU_BCLK); ((perf_ctl.lo >> 8) & 0xff) * CONFIG_CPU_BCLK_MHZ);
} }
static void set_energy_perf_bias(u8 policy) static void set_energy_perf_bias(u8 policy)

View File

@ -34,9 +34,6 @@
#define CPUID_KABYLAKE_HA0 0x506e8 #define CPUID_KABYLAKE_HA0 0x506e8
#define CPUID_KABYLAKE_HB0 0x906e9 #define CPUID_KABYLAKE_HB0 0x906e9
/* CPU bus clock is fixed at 100MHz */
#define CPU_BCLK 100
/* Latency times in units of 1024ns. */ /* Latency times in units of 1024ns. */
#define C_STATE_LATENCY_CONTROL_0_LIMIT 0x4e #define C_STATE_LATENCY_CONTROL_0_LIMIT 0x4e
#define C_STATE_LATENCY_CONTROL_1_LIMIT 0x76 #define C_STATE_LATENCY_CONTROL_1_LIMIT 0x76

View File

@ -17,7 +17,6 @@
#include <stdint.h> #include <stdint.h>
#include <cpu/x86/msr.h> #include <cpu/x86/msr.h>
#include <cpu/x86/tsc.h> #include <cpu/x86/tsc.h>
#include <soc/cpu.h>
#include <soc/msr.h> #include <soc/msr.h>
unsigned long tsc_freq_mhz(void) unsigned long tsc_freq_mhz(void)
@ -25,5 +24,5 @@ unsigned long tsc_freq_mhz(void)
msr_t platform_info; msr_t platform_info;
platform_info = rdmsr(MSR_PLATFORM_INFO); platform_info = rdmsr(MSR_PLATFORM_INFO);
return CPU_BCLK * ((platform_info.lo >> 8) & 0xff); return CONFIG_CPU_BCLK_MHZ * ((platform_info.lo >> 8) & 0xff);
} }