/* SPDX-License-Identifier: GPL-2.0 */ /* * Common code for Intel CPUs * * Copyright (c) 2016 Google, Inc */ #ifndef __ASM_CPU_COMMON_H #define __ASM_CPU_COMMON_H /* Standard Intel bus clock is fixed at 100MHz */ enum { INTEL_BCLK_MHZ = 100 }; struct cpu_info; /** * cpu_common_init() - Set up common CPU init * * This reports BIST failure, enables the LAPIC, updates microcode, enables * the upper 128-bytes of CROM RAM, probes the northbridge, PCH, LPC and SATA. * * @return 0 if OK, -ve on error */ int cpu_common_init(void); /** * cpu_set_flex_ratio_to_tdp_nominal() - Set up the maximum non-turbo rate * * If a change is needed, this function will do a soft reset so it takes * effect. * * Some details are available here: * http://forum.hwbot.org/showthread.php?t=76092 * * @return 0 if OK, -ve on error */ int cpu_set_flex_ratio_to_tdp_nominal(void); /** * cpu_intel_get_info() - Obtain CPU info for Intel CPUs * * Most Intel CPUs use the same MSR to obtain the clock speed, and use the same * features. This function fills in these values, given the value of the base * clock in MHz (typically this should be set to 100). * * @info: cpu_info struct to fill in * @bclk_mz: the base clock in MHz * * @return 0 always */ int cpu_intel_get_info(struct cpu_info *info, int bclk_mz); /** * cpu_configure_thermal_target() - Set the thermal target for a CPU * * This looks up the tcc-offset property and uses it to set the * MSR_TEMPERATURE_TARGET value. * * @dev: CPU device * @return 0 if OK, -ENOENT if no target is given in device tree */ int cpu_configure_thermal_target(struct udevice *dev); /** * cpu_set_perf_control() - Set the nominal CPU clock speed * * This sets the clock speed as a multiplier of BCLK * * @clk_ratio: Ratio to use */ void cpu_set_perf_control(uint clk_ratio); /** * cpu_config_tdp_levels() - Check for configurable TDP option * * @return true if the CPU has configurable TDP (Thermal-design power) */ bool cpu_config_tdp_levels(void); #endif