diff options
Diffstat (limited to 'arch/x86/include')
| -rw-r--r-- | arch/x86/include/asm/acpi_s3.h | 130 | ||||
| -rw-r--r-- | arch/x86/include/asm/arch-broadwell/cpu.h | 3 | ||||
| -rw-r--r-- | arch/x86/include/asm/arch-broadwell/pch.h | 3 | ||||
| -rw-r--r-- | arch/x86/include/asm/arch-ivybridge/model_206ax.h | 5 | ||||
| -rw-r--r-- | arch/x86/include/asm/cpu_common.h | 99 | ||||
| -rw-r--r-- | arch/x86/include/asm/fsp/fsp_hob.h | 4 | ||||
| -rw-r--r-- | arch/x86/include/asm/fsp/fsp_infoheader.h | 15 | ||||
| -rw-r--r-- | arch/x86/include/asm/fsp/fsp_support.h | 141 | ||||
| -rw-r--r-- | arch/x86/include/asm/fsp1/fsp_api.h (renamed from arch/x86/include/asm/fsp/fsp_api.h) | 0 | ||||
| -rw-r--r-- | arch/x86/include/asm/fsp1/fsp_ffs.h (renamed from arch/x86/include/asm/fsp/fsp_ffs.h) | 0 | ||||
| -rw-r--r-- | arch/x86/include/asm/fsp1/fsp_support.h | 72 | ||||
| -rw-r--r-- | arch/x86/include/asm/fsp_arch.h | 22 | ||||
| -rw-r--r-- | arch/x86/include/asm/handoff.h | 8 | ||||
| -rw-r--r-- | arch/x86/include/asm/hob.h | 18 | ||||
| -rw-r--r-- | arch/x86/include/asm/msr-index.h | 131 | ||||
| -rw-r--r-- | arch/x86/include/asm/mtrr.h | 13 | ||||
| -rw-r--r-- | arch/x86/include/asm/pci.h | 45 | ||||
| -rw-r--r-- | arch/x86/include/asm/spl.h | 3 | ||||
| -rw-r--r-- | arch/x86/include/asm/u-boot-x86.h | 2 | 
19 files changed, 408 insertions, 306 deletions
| diff --git a/arch/x86/include/asm/acpi_s3.h b/arch/x86/include/asm/acpi_s3.h deleted file mode 100644 index baa848dcd15..00000000000 --- a/arch/x86/include/asm/acpi_s3.h +++ /dev/null @@ -1,130 +0,0 @@ -/* SPDX-License-Identifier: GPL-2.0+ */ -/* - * Copyright (C) 2017, Bin Meng <bmeng.cn@gmail.com> - */ - -#ifndef __ASM_ACPI_S3_H__ -#define __ASM_ACPI_S3_H__ - -#define WAKEUP_BASE	0x600 - -/* PM1_STATUS register */ -#define WAK_STS		(1 << 15) -#define PCIEXPWAK_STS	(1 << 14) -#define RTC_STS		(1 << 10) -#define SLPBTN_STS	(1 << 9) -#define PWRBTN_STS	(1 << 8) -#define GBL_STS		(1 << 5) -#define BM_STS		(1 << 4) -#define TMR_STS		(1 << 0) - -/* PM1_CNT register */ -#define SLP_EN		(1 << 13) -#define SLP_TYP_SHIFT	10 -#define SLP_TYP		(7 << SLP_TYP_SHIFT) -#define SLP_TYP_S0	0 -#define SLP_TYP_S1	1 -#define SLP_TYP_S3	5 -#define SLP_TYP_S4	6 -#define SLP_TYP_S5	7 - -/* Memory size reserved for S3 resume */ -#define S3_RESERVE_SIZE	0x1000 - -#ifndef __ASSEMBLY__ - -extern char __wakeup[]; -extern int __wakeup_size; - -enum acpi_sleep_state { -	ACPI_S0, -	ACPI_S1, -	ACPI_S2, -	ACPI_S3, -	ACPI_S4, -	ACPI_S5, -}; - -/** - * acpi_ss_string() - get ACPI-defined sleep state string - * - * @pm1_cnt:	ACPI-defined sleep state - * @return:	a pointer to the sleep state string. - */ -static inline char *acpi_ss_string(enum acpi_sleep_state state) -{ -	char *ss_string[] = { "S0", "S1", "S2", "S3", "S4", "S5"}; - -	return ss_string[state]; -} - -/** - * acpi_sleep_from_pm1() - get ACPI-defined sleep state from PM1_CNT register - * - * @pm1_cnt:	PM1_CNT register value - * @return:	ACPI-defined sleep state if given valid PM1_CNT register value, - *		-EINVAL otherwise. - */ -static inline enum acpi_sleep_state acpi_sleep_from_pm1(u32 pm1_cnt) -{ -	switch ((pm1_cnt & SLP_TYP) >> SLP_TYP_SHIFT) { -	case SLP_TYP_S0: -		return ACPI_S0; -	case SLP_TYP_S1: -		return ACPI_S1; -	case SLP_TYP_S3: -		return ACPI_S3; -	case SLP_TYP_S4: -		return ACPI_S4; -	case SLP_TYP_S5: -		return ACPI_S5; -	} - -	return -EINVAL; -} - -/** - * chipset_prev_sleep_state() - Get chipset previous sleep state - * - * This returns chipset previous sleep state from ACPI registers. - * Platform codes must supply this routine in order to support ACPI S3. - * - * @return ACPI_S0/S1/S2/S3/S4/S5. - */ -enum acpi_sleep_state chipset_prev_sleep_state(void); - -/** - * chipset_clear_sleep_state() - Clear chipset sleep state - * - * This clears chipset sleep state in ACPI registers. - * Platform codes must supply this routine in order to support ACPI S3. - */ -void chipset_clear_sleep_state(void); - -struct acpi_fadt; -/** - * acpi_resume() - Do ACPI S3 resume - * - * This calls U-Boot wake up assembly stub and jumps to OS's wake up vector. - * - * @fadt:	FADT table pointer in the ACPI table - * @return:	Never returns - */ -void acpi_resume(struct acpi_fadt *fadt); - -/** - * acpi_s3_reserve() - Reserve memory for ACPI S3 resume - * - * This copies memory where real mode interrupt handler stubs reside to the - * reserved place on the stack. - * - * This routine should be called by reserve_arch() before U-Boot is relocated - * when ACPI S3 resume is enabled. - * - * @return:	0 always - */ -int acpi_s3_reserve(void); - -#endif /* __ASSEMBLY__ */ - -#endif /* __ASM_ACPI_S3_H__ */ diff --git a/arch/x86/include/asm/arch-broadwell/cpu.h b/arch/x86/include/asm/arch-broadwell/cpu.h index ca22a799968..3bc3bd6609e 100644 --- a/arch/x86/include/asm/arch-broadwell/cpu.h +++ b/arch/x86/include/asm/arch-broadwell/cpu.h @@ -21,9 +21,6 @@  #define CPUID_BROADWELL_D0	0x306d3  #define CPUID_BROADWELL_E0	0x306d4 -/* Broadwell bus clock is fixed at 100MHz */ -#define BROADWELL_BCLK		100 -  #define BROADWELL_FAMILY_ULT	0x306d0  #define CORE_THREAD_COUNT_MSR		0x35 diff --git a/arch/x86/include/asm/arch-broadwell/pch.h b/arch/x86/include/asm/arch-broadwell/pch.h index 23153a040fa..ecdf6d16f94 100644 --- a/arch/x86/include/asm/arch-broadwell/pch.h +++ b/arch/x86/include/asm/arch-broadwell/pch.h @@ -6,9 +6,6 @@  #ifndef __ASM_ARCH_PCH_H  #define __ASM_ARCH_PCH_H -/* CPU bus clock is fixed at 100MHz */ -#define CPU_BCLK		100 -  #define PMBASE			0x40  #define ACPI_CNTL		0x44  #define  ACPI_EN		(1 << 7) diff --git a/arch/x86/include/asm/arch-ivybridge/model_206ax.h b/arch/x86/include/asm/arch-ivybridge/model_206ax.h index 850d96bdd9a..4839ebc3124 100644 --- a/arch/x86/include/asm/arch-ivybridge/model_206ax.h +++ b/arch/x86/include/asm/arch-ivybridge/model_206ax.h @@ -8,9 +8,6 @@  #ifndef _ASM_ARCH_MODEL_206AX_H  #define _ASM_ARCH_MODEL_206AX_H -/* SandyBridge/IvyBridge bus clock is fixed at 100MHz */ -#define SANDYBRIDGE_BCLK		100 -  #define  CPUID_VMX			(1 << 5)  #define  CPUID_SMX			(1 << 6)  #define MSR_FEATURE_CONFIG		0x13c @@ -61,6 +58,6 @@  /* Configure power limits for turbo mode */  void set_power_limits(u8 power_limit_1_time); -int cpu_config_tdp_levels(void); +bool cpu_ivybridge_config_tdp_levels(void);  #endif diff --git a/arch/x86/include/asm/cpu_common.h b/arch/x86/include/asm/cpu_common.h index 4c91a5daced..cdd99a90b76 100644 --- a/arch/x86/include/asm/cpu_common.h +++ b/arch/x86/include/asm/cpu_common.h @@ -1,12 +1,19 @@  /* 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 -#define IA32_PERF_CTL			0x199 +/* Standard Intel bus clock is fixed at 100MHz */ +enum { +	INTEL_BCLK_MHZ		= 100 +}; + +struct cpu_info;  /**   * cpu_common_init() - Set up common CPU init @@ -31,4 +38,94 @@ int cpu_common_init(void);   */  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); + +/** enum burst_mode_t - Burst-mode states */ +enum burst_mode_t { +	BURST_MODE_UNKNOWN, +	BURST_MODE_UNAVAILABLE, +	BURST_MODE_DISABLED, +	BURST_MODE_ENABLED +}; + +/* + * cpu_get_burst_mode_state() - Get the Burst/Turbo Mode State + * + * This reads MSR IA32_MISC_ENABLE 0x1A0 + * Bit 38 - TURBO_MODE_DISABLE Bit to get state ENABLED / DISABLED. + * Also checks cpuid 0x6 to see whether burst mode is supported. + * + * @return current burst mode status + */ +enum burst_mode_t cpu_get_burst_mode_state(void); + +/** + * cpu_set_burst_mode() - Set CPU burst mode + * + * @burst_mode: true to enable burst mode, false to disable + */ +void cpu_set_burst_mode(bool burst_mode); + +/** + * cpu_set_eist() - Enable Enhanced Intel Speed Step Technology + * + * @eist_status: true to enable EIST, false to disable + */ +void cpu_set_eist(bool eist_status); + +/** + * cpu_set_p_state_to_turbo_ratio() - Set turbo ratio + * + * TURBO_RATIO_LIMIT MSR (0x1AD) Bits 31:0 indicates the + * factory configured values for of 1-core, 2-core, 3-core + * and 4-core turbo ratio limits for all processors. + * + * 7:0 -	MAX_TURBO_1_CORE + * 15:8 -	MAX_TURBO_2_CORES + * 23:16 -	MAX_TURBO_3_CORES + * 31:24 -	MAX_TURBO_4_CORES + * + * Set PERF_CTL MSR (0x199) P_Req with that value. + */ +void cpu_set_p_state_to_turbo_ratio(void); +  #endif diff --git a/arch/x86/include/asm/fsp/fsp_hob.h b/arch/x86/include/asm/fsp/fsp_hob.h index 3bb79c4b67a..d248520e972 100644 --- a/arch/x86/include/asm/fsp/fsp_hob.h +++ b/arch/x86/include/asm/fsp/fsp_hob.h @@ -69,6 +69,10 @@ struct __packed hob_graphics_info {  	EFI_GUID(0x721acf02, 0x4d77, 0x4c2a, \  		0xb3, 0xdc, 0x27, 0x0b, 0x7b, 0xa9, 0xe4, 0xb0) +#define FSP_VARIABLE_NV_DATA_HOB_GUID \ +	EFI_GUID(0xa034147d, 0x690c, 0x4154, \ +		0x8d, 0xe6, 0xc0, 0x44, 0x64, 0x1d, 0xe9, 0x42) +  #define FSP_BOOTLOADER_TEMP_MEM_HOB_GUID \  	EFI_GUID(0xbbcff46c, 0xc8d3, 0x4113, \  		0x89, 0x85, 0xb9, 0xd4, 0xf3, 0xb3, 0xf6, 0x4e) diff --git a/arch/x86/include/asm/fsp/fsp_infoheader.h b/arch/x86/include/asm/fsp/fsp_infoheader.h index 86f78014b7b..e72c052ed1e 100644 --- a/arch/x86/include/asm/fsp/fsp_infoheader.h +++ b/arch/x86/include/asm/fsp/fsp_infoheader.h @@ -33,6 +33,19 @@ struct __packed fsp_header {  #define FSP_HEADER_REVISION_1		1  #define FSP_HEADER_REVISION_2		2 -#define FSP_ATTR_GRAPHICS_SUPPORT	(1 << 0) +enum fsp_type { +	FSP_ATTR_COMP_TYPE_FSP_T	= 1, +	FSP_ATTR_COMP_TYPE_FSP_M	= 2, +	FSP_ATTR_COMP_TYPE_FSP_S	= 3, +}; + +enum { +	FSP_ATTR_GRAPHICS_SUPPORT	= 1 << 0, +	FSP_ATTR_COMP_TYPE_SHIFT	= 28, +	FSP_ATTR_COMP_TYPE_MASK		= 0xfU << FSP_ATTR_COMP_TYPE_SHIFT, + +}; + +#define EFI_FSPH_SIGNATURE		SIGNATURE_32('F', 'S', 'P', 'H')  #endif diff --git a/arch/x86/include/asm/fsp/fsp_support.h b/arch/x86/include/asm/fsp/fsp_support.h index 7b92392a277..4ac27d26f55 100644 --- a/arch/x86/include/asm/fsp/fsp_support.h +++ b/arch/x86/include/asm/fsp/fsp_support.h @@ -7,182 +7,157 @@  #ifndef __FSP_SUPPORT_H__  #define __FSP_SUPPORT_H__ -#include "fsp_types.h" -#include "fsp_hob.h" -#include "fsp_fv.h" -#include "fsp_ffs.h" -#include "fsp_api.h" -#include "fsp_infoheader.h" -#include "fsp_bootmode.h" -#include "fsp_azalia.h" -#include <asm/arch/fsp/fsp_vpd.h> -#include <asm/arch/fsp/fsp_configs.h> +#include <asm/fsp/fsp_bootmode.h> +#include <asm/fsp/fsp_fv.h> +#include <asm/fsp/fsp_hob.h> +#include <asm/fsp/fsp_infoheader.h> +#include <asm/fsp/fsp_types.h> +#include <asm/fsp_arch.h> +#include <asm/fsp/fsp_azalia.h>  #define FSP_LOWMEM_BASE		0x100000UL  #define FSP_HIGHMEM_BASE	0x100000000ULL  #define UPD_TERMINATOR		0x55AA - -/** - * FSP Continuation assembly helper routine - * - * This routine jumps to the C version of FSP continuation function - */ -void asm_continuation(void); - -/** - * FSP initialization complete - * - * This is the function that indicates FSP initialization is complete and jumps - * back to the bootloader with HOB list pointer as the parameter. - * - * @hob_list:    HOB list pointer - */ -void fsp_init_done(void *hob_list); - -/** - * FSP Continuation function - * - * @status:      Always 0 - * @hob_list:    HOB list pointer - * - * @retval:      Never returns - */ -void fsp_continue(u32 status, void *hob_list); - -/** - * Find FSP header offset in FSP image - * - * @retval: the offset of FSP header. If signature is invalid, returns 0. - */ -struct fsp_header *find_fsp_header(void); -  /** - * FSP initialization wrapper function. + * fsp_find_header() - Find FSP header offset in FSP image   * - * @stack_top: bootloader stack top address - * @boot_mode: boot mode defined in fsp_bootmode.h - * @nvs_buf:   Non-volatile memory buffer pointer + * @return the offset of FSP header. If signature is invalid, returns 0.   */ -void fsp_init(u32 stack_top, u32 boot_mode, void *nvs_buf); +struct fsp_header *fsp_find_header(void);  /** - * FSP notification wrapper function + * fsp_notify() - FSP notification wrapper function   *   * @fsp_hdr: Pointer to FSP information header   * @phase:   FSP initialization phase defined in enum fsp_phase   * - * @retval:  compatible status code with EFI_STATUS defined in PI spec + * @return compatible status code with EFI_STATUS defined in PI spec   */  u32 fsp_notify(struct fsp_header *fsp_hdr, u32 phase);  /** - * This function retrieves the top of usable low memory. + * fsp_get_usable_lowmem_top() - retrieves the top of usable low memory   *   * @hob_list: A HOB list pointer.   * - * @retval:   Usable low memory top. + * @return Usable low memory top.   */  u32 fsp_get_usable_lowmem_top(const void *hob_list);  /** - * This function retrieves the top of usable high memory. + * fsp_get_usable_highmem_top() - retrieves the top of usable high memory   *   * @hob_list: A HOB list pointer.   * - * @retval:   Usable high memory top. + * @return Usable high memory top.   */  u64 fsp_get_usable_highmem_top(const void *hob_list);  /** - * This function retrieves a special reserved memory region. + * fsp_get_reserved_mem_from_guid() - retrieves a special reserved memory region   *   * @hob_list: A HOB list pointer.   * @len:      A pointer to the GUID HOB data buffer length.   *            If the GUID HOB is located, the length will be updated.   * @guid:     A pointer to the owner guild.   * - * @retval:   Reserved region start address. + * @return Reserved region start address.   *            0 if this region does not exist.   */  u64 fsp_get_reserved_mem_from_guid(const void *hob_list,  				   u64 *len, const efi_guid_t *guid);  /** - * This function retrieves the FSP reserved normal memory. + * fsp_get_fsp_reserved_mem() - retrieves the FSP reserved normal memory   *   * @hob_list: A HOB list pointer.   * @len:      A pointer to the FSP reserved memory length buffer.   *            If the GUID HOB is located, the length will be updated. - * @retval:   FSP reserved memory base + * @return FSP reserved memory base   *            0 if this region does not exist.   */  u32 fsp_get_fsp_reserved_mem(const void *hob_list, u32 *len);  /** - * This function retrieves the TSEG reserved normal memory. + * fsp_get_tseg_reserved_mem() - retrieves the TSEG reserved normal memory   *   * @hob_list:      A HOB list pointer.   * @len:           A pointer to the TSEG reserved memory length buffer.   *                 If the GUID HOB is located, the length will be updated.   * - * @retval NULL:   Failed to find the TSEG reserved memory. - * @retval others: TSEG reserved memory base. + * @return NULL:   Failed to find the TSEG reserved memory. + * @return others: TSEG reserved memory base.   */  u32 fsp_get_tseg_reserved_mem(const void *hob_list, u32 *len);  /** - * This function retrieves FSP Non-volatile Storage HOB buffer and size. + * fsp_get_nvs_data() - retrieves FSP Non-volatile Storage HOB buffer and size   *   * @hob_list:      A HOB list pointer.   * @len:           A pointer to the NVS data buffer length.   *                 If the HOB is located, the length will be updated.   * - * @retval NULL:   Failed to find the NVS HOB. - * @retval others: FSP NVS data buffer pointer. + * @return NULL:   Failed to find the NVS HOB. + * @return others: FSP NVS data buffer pointer.   */  void *fsp_get_nvs_data(const void *hob_list, u32 *len);  /** - * This function retrieves Bootloader temporary stack buffer and size. + * fsp_get_var_nvs_data() - get FSP variable Non-volatile Storage HOB buffer   *   * @hob_list:      A HOB list pointer. - * @len:           A pointer to the bootloader temporary stack length. + * @len:           A pointer to the NVS data buffer length.   *                 If the HOB is located, the length will be updated.   * - * @retval NULL:   Failed to find the bootloader temporary stack HOB. - * @retval others: Bootloader temporary stackbuffer pointer. + * @return NULL:   Failed to find the NVS HOB. + * @return others: FSP NVS data buffer pointer.   */ -void *fsp_get_bootloader_tmp_mem(const void *hob_list, u32 *len); +void *fsp_get_var_nvs_data(const void *hob_list, u32 *len);  /** - * This function retrieves graphics information. + * fsp_get_graphics_info() - retrieves graphics information.   *   * @hob_list:      A HOB list pointer.   * @len:           A pointer to the graphics info HOB length.   *                 If the HOB is located, the length will be updated.   * - * @retval NULL:   Failed to find the graphics info HOB. - * @retval others: A pointer to struct hob_graphics_info. + * @return NULL:   Failed to find the graphics info HOB. + * @return others: A pointer to struct hob_graphics_info.   */  void *fsp_get_graphics_info(const void *hob_list, u32 *len);  /** - * This function overrides the default configurations of FSP. + * fsp_init_phase_pci() - Tell the FSP that we have completed PCI init + * + * @return 0 if OK, -EPERM if the FSP gave an error. + */ +int fsp_init_phase_pci(void); + +/** + * fsp_scan_for_ram_size() - Scan the HOB list to find the RAM size   * - * @config:  A pointer to the FSP configuration data structure - * @rt_buf:  A pointer to the FSP runtime buffer data structure + * This sets gd->ram_size based on what it finds.   * - * @return:  None + * @return 0 if OK, -ve on error   */ -void update_fsp_configs(struct fsp_config_data *config, -			struct fspinit_rtbuf *rt_buf); +int fsp_scan_for_ram_size(void);  /** - * fsp_init_phase_pci() - Tell the FSP that we have completed PCI init + * fsp_prepare_mrc_cache() - Find the DRAM training data from the MRC cache   * - * @return 0 if OK, -EPERM if the FSP gave an error. + * @return pointer to data, or NULL if no cache or no data found in the cache   */ -int fsp_init_phase_pci(void); +void *fsp_prepare_mrc_cache(void); + +/** + * fsp_notify() - FSP notification wrapper function + * + * @fsp_hdr: Pointer to FSP information header + * @phase:   FSP initialization phase defined in enum fsp_phase + * + * @return compatible status code with EFI_STATUS defined in PI spec + */ +u32 fsp_notify(struct fsp_header *fsp_hdr, u32 phase);  #endif diff --git a/arch/x86/include/asm/fsp/fsp_api.h b/arch/x86/include/asm/fsp1/fsp_api.h index f2d70799f33..f2d70799f33 100644 --- a/arch/x86/include/asm/fsp/fsp_api.h +++ b/arch/x86/include/asm/fsp1/fsp_api.h diff --git a/arch/x86/include/asm/fsp/fsp_ffs.h b/arch/x86/include/asm/fsp1/fsp_ffs.h index b7558e5a17f..b7558e5a17f 100644 --- a/arch/x86/include/asm/fsp/fsp_ffs.h +++ b/arch/x86/include/asm/fsp1/fsp_ffs.h diff --git a/arch/x86/include/asm/fsp1/fsp_support.h b/arch/x86/include/asm/fsp1/fsp_support.h new file mode 100644 index 00000000000..a44a5504a4f --- /dev/null +++ b/arch/x86/include/asm/fsp1/fsp_support.h @@ -0,0 +1,72 @@ +/* SPDX-License-Identifier: Intel */ +/* + * Copyright (C) 2013, Intel Corporation + * Copyright (C) 2014, Bin Meng <bmeng.cn@gmail.com> + */ + +#ifndef __FSP1_SUPPORT_H__ +#define __FSP1_SUPPORT_H__ + +#include <asm/fsp/fsp_support.h> +#include "fsp_ffs.h" + +/** + * fsp_asm_continuation() - FSP Continuation assembly helper routine + * + * This routine jumps to the C version of FSP continuation function + */ +void fsp_asm_continuation(void); + +/** + * fsp_init_done() - FSP initialization complete + * + * This is the function that indicates FSP initialization is complete and jumps + * back to the bootloader with HOB list pointer as the parameter. + * + * @hob_list:    HOB list pointer + */ +void fsp_init_done(void *hob_list); + +/** + * fsp_continue() - FSP Continuation function + * + * @status:      Always 0 + * @hob_list:    HOB list pointer + * + * @return Never returns + */ +void fsp_continue(u32 status, void *hob_list); + +/** + * fsp_init() - FSP initialization wrapper function + * + * @stack_top: bootloader stack top address + * @boot_mode: boot mode defined in fsp_bootmode.h + * @nvs_buf:   Non-volatile memory buffer pointer + */ +void fsp_init(u32 stack_top, u32 boot_mode, void *nvs_buf); + +/** + * fsp_get_bootloader_tmp_mem() - retrieves temporary stack buffer and size + * + * @hob_list:      A HOB list pointer. + * @len:           A pointer to the bootloader temporary stack length. + *                 If the HOB is located, the length will be updated. + * + * @return NULL:   Failed to find the bootloader temporary stack HOB. + * @return others: Bootloader temporary stackbuffer pointer. + */ +void *fsp_get_bootloader_tmp_mem(const void *hob_list, u32 *len); + +/** + * fsp_update_configs() - overrides the default configurations of FSP + * + * @config:  A pointer to the FSP configuration data structure + * @rt_buf:  A pointer to the FSP runtime buffer data structure + * + * @return None + */ +void fsp_update_configs(struct fsp_config_data *config, +			struct fspinit_rtbuf *rt_buf); + +#endif diff --git a/arch/x86/include/asm/fsp_arch.h b/arch/x86/include/asm/fsp_arch.h new file mode 100644 index 00000000000..3b2077b3924 --- /dev/null +++ b/arch/x86/include/asm/fsp_arch.h @@ -0,0 +1,22 @@ +/* SPDX-License-Identifier: GPL-2.0+ */ +/* + * Copyright 2019 Google LLC + * Written by Simon Glass <sjg@chromium.org> + * + * Architecture-specific definitions (FSP config and VPD/UPD) + */ + +#ifndef __FSP_ARCH_H__ +#define __FSP_ARCH_H__ + +/* + * Note: use #ifndef __ASSEMBLY__ around any struct definitions or other C code + * since this file can be included from assembly. + */ + +#include <asm/fsp1/fsp_api.h> +#include <asm/fsp1/fsp_ffs.h> +#include <asm/arch/fsp/fsp_vpd.h> +#include <asm/arch/fsp/fsp_configs.h> + +#endif diff --git a/arch/x86/include/asm/handoff.h b/arch/x86/include/asm/handoff.h index 4d18d59efed..aec49b9b815 100644 --- a/arch/x86/include/asm/handoff.h +++ b/arch/x86/include/asm/handoff.h @@ -9,7 +9,15 @@  #ifndef __x86_asm_handoff_h  #define __x86_asm_handoff_h +/** + * struct arch_spl_handoff - architecture-specific handoff info + * + * @usable_ram_top: Value returned by board_get_usable_ram_top() in SPL + * @hob_list: Start of FSP hand-off blocks (HOBs) + */  struct arch_spl_handoff { +	ulong usable_ram_top; +	void *hob_list;  };  #endif diff --git a/arch/x86/include/asm/hob.h b/arch/x86/include/asm/hob.h index b4239821aaa..56e11dbb28f 100644 --- a/arch/x86/include/asm/hob.h +++ b/arch/x86/include/asm/hob.h @@ -135,7 +135,7 @@ struct hob_guid {   *   * @hdr:    A pointer to a HOB.   * - * @return: A pointer to the next HOB in the HOB list. + * @return A pointer to the next HOB in the HOB list.   */  static inline const struct hob_header *get_next_hob(const struct hob_header  						    *hdr) @@ -152,8 +152,8 @@ static inline const struct hob_header *get_next_hob(const struct hob_header   *   * @hdr:          A pointer to a HOB.   * - * @retval true:  The HOB specified by hdr is the last HOB in the HOB list. - * @retval false: The HOB specified by hdr is not the last HOB in the HOB list. + * @return true:  The HOB specified by hdr is the last HOB in the HOB list. + * @return false: The HOB specified by hdr is not the last HOB in the HOB list.   */  static inline bool end_of_hob(const struct hob_header *hdr)  { @@ -169,7 +169,7 @@ static inline bool end_of_hob(const struct hob_header *hdr)   *   * @hdr:    A pointer to a HOB.   * - * @return: A pointer to the data buffer in a HOB. + * @return A pointer to the data buffer in a HOB.   */  static inline void *get_guid_hob_data(const struct hob_header *hdr)  { @@ -185,7 +185,7 @@ static inline void *get_guid_hob_data(const struct hob_header *hdr)   *   * @hdr:    A pointer to a HOB.   * - * @return: The size of the data buffer. + * @return The size of the data buffer.   */  static inline u16 get_guid_hob_data_size(const struct hob_header *hdr)  { @@ -198,7 +198,7 @@ static inline u16 get_guid_hob_data_size(const struct hob_header *hdr)   * @type:     HOB type to search   * @hob_list: A pointer to the HOB list   * - * @retval:   A HOB object with matching type; Otherwise NULL. + * @return A HOB object with matching type; Otherwise NULL.   */  const struct hob_header *hob_get_next_hob(uint type, const void *hob_list); @@ -208,7 +208,7 @@ const struct hob_header *hob_get_next_hob(uint type, const void *hob_list);   * @guid:     GUID to search   * @hob_list: A pointer to the HOB list   * - * @retval:   A HOB object with matching GUID; Otherwise NULL. + * @return A HOB object with matching GUID; Otherwise NULL.   */  const struct hob_header *hob_get_next_guid_hob(const efi_guid_t *guid,  					       const void *hob_list); @@ -221,8 +221,8 @@ const struct hob_header *hob_get_next_guid_hob(const efi_guid_t *guid,   *                 If the GUID HOB is located, the length will be updated.   * @guid           A pointer to HOB GUID.   * - * @retval NULL:   Failed to find the GUID HOB. - * @retval others: GUID HOB data buffer pointer. + * @return NULL:   Failed to find the GUID HOB. + * @return others: GUID HOB data buffer pointer.   */  void *hob_get_guid_hob_data(const void *hob_list, u32 *len,  			    const efi_guid_t *guid); diff --git a/arch/x86/include/asm/msr-index.h b/arch/x86/include/asm/msr-index.h index 9c1dbe61d59..5bc8b6c22c7 100644 --- a/arch/x86/include/asm/msr-index.h +++ b/arch/x86/include/asm/msr-index.h @@ -43,6 +43,12 @@  #define MSR_PIC_MSG_CONTROL		0x2e  #define  PLATFORM_INFO_SET_TDP		(1 << 29) +#define MSR_MTRR_CAP_MSR		0x0fe +#define MSR_MTRR_CAP_SMRR		(1 << 11) +#define MSR_MTRR_CAP_WC			(1 << 10) +#define MSR_MTRR_CAP_FIX		(1 << 8) +#define MSR_MTRR_CAP_VCNT		0xff +  #define MSR_IA32_PERFCTR0		0x000000c1  #define MSR_IA32_PERFCTR1		0x000000c2  #define MSR_FSB_FREQ			0x000000cd @@ -67,6 +73,11 @@  #define ENABLE_ULFM_AUTOCM_MASK		(1 << 2)  #define ENABLE_INDP_AUTOCM_MASK		(1 << 3) +#define MSR_EMULATE_PM_TIMER		0x121 +#define  EMULATE_DELAY_OFFSET_VALUE	20 +#define  EMULATE_PM_TMR_EN		(1 << 16) +#define  EMULATE_DELAY_VALUE		0x13 +  #define MSR_IA32_SYSENTER_CS		0x00000174  #define MSR_IA32_SYSENTER_ESP		0x00000175  #define MSR_IA32_SYSENTER_EIP		0x00000176 @@ -78,21 +89,67 @@  #define MSR_FLEX_RATIO			0x194  #define  FLEX_RATIO_LOCK		(1 << 20)  #define  FLEX_RATIO_EN			(1 << 16) +/* This is burst mode BIT 38 in IA32_MISC_ENABLE MSR at offset 1A0h */ +#define BURST_MODE_DISABLE		(1 << 6) + +#define MSR_IA32_MISC_ENABLE		0x000001a0 + +/* MISC_ENABLE bits: architectural */ +#define MISC_ENABLE_FAST_STRING		BIT_ULL(0) +#define MISC_ENABLE_TCC			BIT_ULL(1) +#define MISC_DISABLE_TURBO		BIT_ULL(6) +#define MISC_ENABLE_EMON		BIT_ULL(7) +#define MISC_ENABLE_BTS_UNAVAIL		BIT_ULL(11) +#define MISC_ENABLE_PEBS_UNAVAIL	BIT_ULL(12) +#define MISC_ENABLE_ENHANCED_SPEEDSTEP	BIT_ULL(16) +#define MISC_ENABLE_MWAIT		BIT_ULL(18) +#define MISC_ENABLE_LIMIT_CPUID		BIT_ULL(22) +#define MISC_ENABLE_XTPR_DISABLE	BIT_ULL(23) +#define MISC_ENABLE_XD_DISABLE		BIT_ULL(34) + +/* MISC_ENABLE bits: model-specific, meaning may vary from core to core */ +#define MISC_ENABLE_X87_COMPAT		BIT_ULL(2) +#define MISC_ENABLE_TM1			BIT_ULL(3) +#define MISC_ENABLE_SPLIT_LOCK_DISABLE	BIT_ULL(4) +#define MISC_ENABLE_L3CACHE_DISABLE	BIT_ULL(6) +#define MISC_ENABLE_SUPPRESS_LOCK	BIT_ULL(8) +#define MISC_ENABLE_PREFETCH_DISABLE	BIT_ULL(9) +#define MISC_ENABLE_FERR		BIT_ULL(10) +#define MISC_ENABLE_FERR_MULTIPLEX	BIT_ULL(10) +#define MISC_ENABLE_TM2			BIT_ULL(13) +#define MISC_ENABLE_ADJ_PREF_DISABLE	BIT_ULL(19) +#define MISC_ENABLE_SPEEDSTEP_LOCK	BIT_ULL(20) +#define MISC_ENABLE_L1D_CONTEXT		BIT_ULL(24) +#define MISC_ENABLE_DCU_PREF_DISABLE	BIT_ULL(37) +#define MISC_ENABLE_TURBO_DISABLE	BIT_ULL(38) +#define MISC_ENABLE_IP_PREF_DISABLE	BIT_ULL(39) -#define MSR_IA32_MISC_ENABLES		0x000001a0  #define MSR_TEMPERATURE_TARGET		0x1a2 +#define MSR_PREFETCH_CTL		0x1a4 +#define  PREFETCH_L1_DISABLE		(1 << 0) +#define  PREFETCH_L2_DISABLE		(1 << 2)  #define MSR_OFFCORE_RSP_0		0x000001a6  #define MSR_OFFCORE_RSP_1		0x000001a7  #define MSR_MISC_PWR_MGMT		0x1aa  #define  MISC_PWR_MGMT_EIST_HW_DIS	(1 << 0) -#define MSR_NHM_TURBO_RATIO_LIMIT	0x000001ad -#define MSR_IVT_TURBO_RATIO_LIMIT	0x000001ae +#define MSR_TURBO_RATIO_LIMIT		0x000001ad  #define MSR_IA32_ENERGY_PERFORMANCE_BIAS	0x1b0  #define  ENERGY_POLICY_PERFORMANCE	0  #define  ENERGY_POLICY_NORMAL		6  #define  ENERGY_POLICY_POWERSAVE	15 +#define MSR_IA32_PACKAGE_THERM_STATUS		0x000001b1 + +#define PACKAGE_THERM_STATUS_PROCHOT		BIT(0) +#define PACKAGE_THERM_STATUS_POWER_LIMIT	BIT(10) + +#define MSR_IA32_PACKAGE_THERM_INTERRUPT	0x000001b2 + +#define PACKAGE_THERM_INT_HIGH_ENABLE		BIT(0) +#define PACKAGE_THERM_INT_LOW_ENABLE		BIT(1) +#define PACKAGE_THERM_INT_PLN_ENABLE		BIT(24) +  #define MSR_LBR_SELECT			0x000001c8  #define MSR_LBR_TOS			0x000001c9  #define MSR_IA32_PLATFORM_DCA_CAP	0x1f8 @@ -404,68 +461,6 @@  #define MSR_THERM2_CTL_TM_SELECT	(1ULL << 16) -#define MSR_IA32_MISC_ENABLE		0x000001a0 -#define H_MISC_DISABLE_TURBO		(1 << 6) - -#define MSR_IA32_TEMPERATURE_TARGET	0x000001a2 - -#define MSR_IA32_ENERGY_PERF_BIAS	0x000001b0 -#define ENERGY_PERF_BIAS_PERFORMANCE	0 -#define ENERGY_PERF_BIAS_NORMAL		6 -#define ENERGY_PERF_BIAS_POWERSAVE	15 - -#define MSR_IA32_PACKAGE_THERM_STATUS		0x000001b1 - -#define PACKAGE_THERM_STATUS_PROCHOT		(1 << 0) -#define PACKAGE_THERM_STATUS_POWER_LIMIT	(1 << 10) - -#define MSR_IA32_PACKAGE_THERM_INTERRUPT	0x000001b2 - -#define PACKAGE_THERM_INT_HIGH_ENABLE		(1 << 0) -#define PACKAGE_THERM_INT_LOW_ENABLE		(1 << 1) -#define PACKAGE_THERM_INT_PLN_ENABLE		(1 << 24) - -/* Thermal Thresholds Support */ -#define THERM_INT_THRESHOLD0_ENABLE    (1 << 15) -#define THERM_SHIFT_THRESHOLD0        8 -#define THERM_MASK_THRESHOLD0          (0x7f << THERM_SHIFT_THRESHOLD0) -#define THERM_INT_THRESHOLD1_ENABLE    (1 << 23) -#define THERM_SHIFT_THRESHOLD1        16 -#define THERM_MASK_THRESHOLD1          (0x7f << THERM_SHIFT_THRESHOLD1) -#define THERM_STATUS_THRESHOLD0        (1 << 6) -#define THERM_LOG_THRESHOLD0           (1 << 7) -#define THERM_STATUS_THRESHOLD1        (1 << 8) -#define THERM_LOG_THRESHOLD1           (1 << 9) - -/* MISC_ENABLE bits: architectural */ -#define MSR_IA32_MISC_ENABLE_FAST_STRING	(1ULL << 0) -#define MSR_IA32_MISC_ENABLE_TCC		(1ULL << 1) -#define MSR_IA32_MISC_ENABLE_EMON		(1ULL << 7) -#define MSR_IA32_MISC_ENABLE_BTS_UNAVAIL	(1ULL << 11) -#define MSR_IA32_MISC_ENABLE_PEBS_UNAVAIL	(1ULL << 12) -#define MSR_IA32_MISC_ENABLE_ENHANCED_SPEEDSTEP	(1ULL << 16) -#define MSR_IA32_MISC_ENABLE_MWAIT		(1ULL << 18) -#define MSR_IA32_MISC_ENABLE_LIMIT_CPUID	(1ULL << 22) -#define MSR_IA32_MISC_ENABLE_XTPR_DISABLE	(1ULL << 23) -#define MSR_IA32_MISC_ENABLE_XD_DISABLE		(1ULL << 34) - -/* MISC_ENABLE bits: model-specific, meaning may vary from core to core */ -#define MSR_IA32_MISC_ENABLE_X87_COMPAT		(1ULL << 2) -#define MSR_IA32_MISC_ENABLE_TM1		(1ULL << 3) -#define MSR_IA32_MISC_ENABLE_SPLIT_LOCK_DISABLE	(1ULL << 4) -#define MSR_IA32_MISC_ENABLE_L3CACHE_DISABLE	(1ULL << 6) -#define MSR_IA32_MISC_ENABLE_SUPPRESS_LOCK	(1ULL << 8) -#define MSR_IA32_MISC_ENABLE_PREFETCH_DISABLE	(1ULL << 9) -#define MSR_IA32_MISC_ENABLE_FERR		(1ULL << 10) -#define MSR_IA32_MISC_ENABLE_FERR_MULTIPLEX	(1ULL << 10) -#define MSR_IA32_MISC_ENABLE_TM2		(1ULL << 13) -#define MSR_IA32_MISC_ENABLE_ADJ_PREF_DISABLE	(1ULL << 19) -#define MSR_IA32_MISC_ENABLE_SPEEDSTEP_LOCK	(1ULL << 20) -#define MSR_IA32_MISC_ENABLE_L1D_CONTEXT	(1ULL << 24) -#define MSR_IA32_MISC_ENABLE_DCU_PREF_DISABLE	(1ULL << 37) -#define MSR_IA32_MISC_ENABLE_TURBO_DISABLE	(1ULL << 38) -#define MSR_IA32_MISC_ENABLE_IP_PREF_DISABLE	(1ULL << 39) -  #define MSR_IA32_TSC_DEADLINE		0x000006E0  /* P4/Xeon+ specific */ @@ -600,6 +595,12 @@  #define MSR_IA32_VMX_TRUE_ENTRY_CTLS     0x00000490  #define MSR_IA32_VMX_VMFUNC             0x00000491 +#define MSR_IA32_PQR_ASSOC		0xc8f +/* MSR bits 33:32 encode slot number 0-3 */ +#define MSR_IA32_PQR_ASSOC_MASK		(1 << 0 | 1 << 1) + +#define MSR_L2_QOS_MASK(reg)		(0xd10 + (reg)) +  /* VMX_BASIC bits and bitmasks */  #define VMX_BASIC_VMCS_SIZE_SHIFT	32  #define VMX_BASIC_64		0x0001000000000000LLU diff --git a/arch/x86/include/asm/mtrr.h b/arch/x86/include/asm/mtrr.h index 2d897f82ef7..672617256e9 100644 --- a/arch/x86/include/asm/mtrr.h +++ b/arch/x86/include/asm/mtrr.h @@ -25,6 +25,7 @@  #define MTRR_CAP_FIX		(1 << 8)  #define MTRR_CAP_VCNT_MASK	0xff +#define MTRR_DEF_TYPE_MASK	0xff  #define MTRR_DEF_TYPE_EN	(1 << 11)  #define MTRR_DEF_TYPE_FIX_EN	(1 << 10) @@ -116,6 +117,18 @@ int mtrr_add_request(int type, uint64_t start, uint64_t size);   */  int mtrr_commit(bool do_caches); +/** + * mtrr_set_next_var() - set up a variable MTRR + * + * This finds the first free variable MTRR and sets to the given area + * + * @type:	Requested type (MTRR_TYPE_) + * @start:	Start address + * @size:	Size + * @return 0 on success, -ENOSPC if there are no more MTRRs + */ +int mtrr_set_next_var(uint type, uint64_t base, uint64_t size); +  #endif  #if ((CONFIG_XIP_ROM_SIZE & (CONFIG_XIP_ROM_SIZE - 1)) != 0) diff --git a/arch/x86/include/asm/pci.h b/arch/x86/include/asm/pci.h index 118ac937d93..2a720735728 100644 --- a/arch/x86/include/asm/pci.h +++ b/arch/x86/include/asm/pci.h @@ -17,11 +17,48 @@  #ifndef __ASSEMBLY__ -int pci_x86_read_config(struct udevice *bus, pci_dev_t bdf, uint offset, -			ulong *valuep, enum pci_size_t size); +/** + * pci_x86_read_config() - Read a configuration value from a device + * + * This function can be called before PCI is set up in driver model. + * + * @bdf:	PCI device address: bus, device and function -see PCI_BDF() + * @offset:	Register offset to read + * @valuep:	Place to put the returned value + * @size:	Access size + * @return 0 if OK, -ve on error + */ +int pci_x86_read_config(pci_dev_t bdf, uint offset, ulong *valuep, +			enum pci_size_t size); -int pci_x86_write_config(struct udevice *bus, pci_dev_t bdf, uint offset, -			 ulong value, enum pci_size_t size); +/** + * pci_bus_write_config() - Write a configuration value to a device + * + * This function can be called before PCI is set up in driver model. + * + * @bdf:	PCI device address: bus, device and function -see PCI_BDF() + * @offset:	Register offset to write + * @value:	Value to write + * @size:	Access size + * @return 0 if OK, -ve on error + */ +int pci_x86_write_config(pci_dev_t bdf, uint offset, ulong value, +			 enum pci_size_t size); + +/** + * pci_bus_clrset_config32() - Update a configuration value for a device + * + * The register at @offset is updated to (oldvalue & ~clr) | set. This function + * can be called before PCI is set up in driver model. + * + * @bdf:	PCI device address: bus, device and function -see PCI_BDF() + * @offset:	Register offset to update + * @clr:	Bits to clear + * @set:	Bits to set + * @return 0 if OK, -ve on error + */ +int pci_x86_clrset_config(pci_dev_t bdf, uint offset, ulong clr, ulong set, +			  enum pci_size_t size);  /**   * Assign IRQ number to a PCI device diff --git a/arch/x86/include/asm/spl.h b/arch/x86/include/asm/spl.h index 27432b28979..1bef4877eb3 100644 --- a/arch/x86/include/asm/spl.h +++ b/arch/x86/include/asm/spl.h @@ -10,8 +10,7 @@  #define CONFIG_SPL_BOARD_LOAD_IMAGE  enum { -	BOOT_DEVICE_SPI		= 10, -	BOOT_DEVICE_BOARD, +	BOOT_DEVICE_SPI_MMAP	= 10,  	BOOT_DEVICE_CROS_VBOOT,  }; diff --git a/arch/x86/include/asm/u-boot-x86.h b/arch/x86/include/asm/u-boot-x86.h index c252192bf41..2466ad2ad30 100644 --- a/arch/x86/include/asm/u-boot-x86.h +++ b/arch/x86/include/asm/u-boot-x86.h @@ -74,7 +74,7 @@ u32 isa_map_rom(u32 bus_addr, int size);  /* arch/x86/lib/... */  int video_bios_init(void); -/* arch/x86/lib/fsp/... */ +/* arch/x86/lib/fsp1,2/... */  /**   * fsp_save_s3_stack() - save stack address to CMOS for next S3 boot | 
