mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-06 13:14:27 +00:00
d3abc5d1ee
Add cpu_intel_get_info() to find out the CPU info on modern Intel CPUs. Signed-off-by: Simon Glass <sjg@chromium.org> Reviewed-by: Bin Meng <bmeng.cn@gmail.com> [bmeng: add parameter and return value descriptions] Signed-off-by: Bin Meng <bmeng.cn@gmail.com>
50 lines
1.2 KiB
C
50 lines
1.2 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (c) 2016 Google, Inc
|
|
*/
|
|
|
|
#ifndef __ASM_CPU_COMMON_H
|
|
#define __ASM_CPU_COMMON_H
|
|
|
|
#define IA32_PERF_CTL 0x199
|
|
|
|
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);
|
|
|
|
#endif
|