/* SPDX-License-Identifier: GPL-2.0-only */ /* This file is part of the coreboot project. */ #ifndef _SOC_JASPERLAKE_CPU_H_ #define _SOC_JASPERLAKE_CPU_H_ #include /* Latency times in units of 32768ns */ #define C_STATE_LATENCY_CONTROL_0_LIMIT 0x9d #define C_STATE_LATENCY_CONTROL_1_LIMIT 0x9d #define C_STATE_LATENCY_CONTROL_2_LIMIT 0x9d #define C_STATE_LATENCY_CONTROL_3_LIMIT 0x9d #define C_STATE_LATENCY_CONTROL_4_LIMIT 0x9d #define C_STATE_LATENCY_CONTROL_5_LIMIT 0x9d /* Power in units of mW */ #define C1_POWER 0x3e8 #define C6_POWER 0x15e #define C7_POWER 0xc8 #define C8_POWER 0xc8 #define C9_POWER 0xc8 #define C10_POWER 0xc8 /* Common Timer Copy (CTC) frequency - 38.4MHz. */ #define CTC_FREQ 38400000 #define C_STATE_LATENCY_MICRO_SECONDS(limit, base) \ (((1 << ((base)*5)) * (limit)) / 1000) #define C_STATE_LATENCY_FROM_LAT_REG(reg) \ C_STATE_LATENCY_MICRO_SECONDS(C_STATE_LATENCY_CONTROL_ ##reg## _LIMIT, \ (IRTL_1024_NS >> 10)) /* Configure power limits for turbo mode */ void set_power_limits(u8 power_limit_1_time); #endif