soc/amd: introduce and use get_uvolts_from_vid for SVI2 and SVI3
Instead of implementing the conversion from the raw serial voltage ID value to the voltage in microvolts in every SoC, introduce the SOC_AMD_COMMON_BLOCK_SVI[2,3] Kconfig options for the SoC to select the correct version, implement get_uvolts_from_vid for both cases and only include the selected implementation in the build. Signed-off-by: Felix Held <felix-coreboot@felixheld.de> Change-Id: I344641217e6e4654fd281d434b88e346e0482f57 Reviewed-on: https://review.coreboot.org/c/coreboot/+/73995 Reviewed-by: Fred Reitberger <reitbergerfred@gmail.com> Reviewed-by: Matt DeVillier <matt.devillier@amd.corp-partner.google.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
fd5d26522c
commit
23a398e001
20 changed files with 64 additions and 55 deletions
|
@ -63,6 +63,7 @@ config SOC_AMD_CEZANNE
|
|||
select SOC_AMD_COMMON_BLOCK_SMU
|
||||
select SOC_AMD_COMMON_BLOCK_SMU_SX_ENTRY
|
||||
select SOC_AMD_COMMON_BLOCK_SPI
|
||||
select SOC_AMD_COMMON_BLOCK_SVI2
|
||||
select SOC_AMD_COMMON_BLOCK_TSC_FAM17H_19H
|
||||
select SOC_AMD_COMMON_BLOCK_UART
|
||||
select SOC_AMD_COMMON_BLOCK_UCODE
|
||||
|
|
|
@ -146,13 +146,7 @@ uint32_t get_pstate_core_power(union pstate_msr pstate_reg)
|
|||
current_divisor = pstate_reg.idd_div;
|
||||
|
||||
/* Voltage */
|
||||
if ((core_vid >= 0xF8) && (core_vid <= 0xFF)) {
|
||||
/* Voltage off for VID codes 0xF8 to 0xFF */
|
||||
voltage_in_uvolts = 0;
|
||||
} else {
|
||||
voltage_in_uvolts = SERIAL_VID_2_MAX_MICROVOLTS -
|
||||
(SERIAL_VID_2_DECODE_MICROVOLTS * core_vid);
|
||||
}
|
||||
voltage_in_uvolts = get_uvolts_from_vid(core_vid);
|
||||
|
||||
/* Power in mW */
|
||||
power_in_mw = (voltage_in_uvolts) / 10 * current_value_amps;
|
||||
|
|
|
@ -22,10 +22,6 @@ union pstate_msr {
|
|||
#define PSTATE_DEF_FREQ_DIV_MAX 0x3E
|
||||
#define PSTATE_DEF_CORE_FREQ_BASE 25
|
||||
|
||||
/* Value defined in Serial VID Interface 2.0 spec (#48022, NDA only) */
|
||||
#define SERIAL_VID_2_DECODE_MICROVOLTS 6250
|
||||
#define SERIAL_VID_2_MAX_MICROVOLTS 1550000L
|
||||
|
||||
#define MSR_CPPC_CAPABILITY_1 0xc00102b0
|
||||
#define SHIFT_CPPC_CAPABILITY_1_HIGHEST_PERF 24
|
||||
#define SHIFT_CPPC_CAPABILITY_1_NOMINAL_PERF 16
|
||||
|
|
|
@ -66,6 +66,18 @@ config SOC_AMD_COMMON_BLOCK_SMM
|
|||
Add common SMM relocation, finalization and handler functionality to
|
||||
the build.
|
||||
|
||||
config SOC_AMD_COMMON_BLOCK_SVI2
|
||||
bool
|
||||
help
|
||||
Select this option is the SoC uses the serial VID 2 standard for
|
||||
encoding the voltage it requests from the VRM.
|
||||
|
||||
config SOC_AMD_COMMON_BLOCK_SVI3
|
||||
bool
|
||||
help
|
||||
Select this option is the SoC uses the serial VID 3 standard for
|
||||
encoding the voltage it requests from the VRM.
|
||||
|
||||
config SOC_AMD_COMMON_BLOCK_TSC_FAM17H_19H
|
||||
bool
|
||||
select COLLECT_TIMESTAMPS_NO_TSC # selected use SoC-specific timestamp function
|
||||
|
|
|
@ -4,6 +4,9 @@ ramstage-$(CONFIG_SOC_AMD_COMMON_BLOCK_UCODE) += update_microcode.c
|
|||
romstage-y += cpu.c
|
||||
ramstage-y += cpu.c
|
||||
|
||||
ramstage-$(CONFIG_SOC_AMD_COMMON_BLOCK_SVI2) += svi2.c
|
||||
ramstage-$(CONFIG_SOC_AMD_COMMON_BLOCK_SVI3) += svi3.c
|
||||
|
||||
ifeq ($(CONFIG_SOC_AMD_COMMON_BLOCK_UCODE),y)
|
||||
define add-ucode-as-cbfs
|
||||
cbfs-files-y += cpu_microcode_$(2).bin
|
||||
|
|
19
src/soc/amd/common/block/cpu/svi2.c
Normal file
19
src/soc/amd/common/block/cpu/svi2.c
Normal file
|
@ -0,0 +1,19 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#include <amdblocks/cpu.h>
|
||||
#include <types.h>
|
||||
|
||||
/* Value defined in Serial VID Interface 2.0 spec (#48022, NDA only) */
|
||||
#define SERIAL_VID_2_DECODE_MICROVOLTS 6250
|
||||
#define SERIAL_VID_2_MAX_MICROVOLTS 1550000L
|
||||
|
||||
uint32_t get_uvolts_from_vid(uint16_t core_vid)
|
||||
{
|
||||
if ((core_vid >= 0xF8) && (core_vid <= 0xFF)) {
|
||||
/* Voltage off for VID codes 0xF8 to 0xFF */
|
||||
return 0;
|
||||
} else {
|
||||
return SERIAL_VID_2_MAX_MICROVOLTS -
|
||||
(SERIAL_VID_2_DECODE_MICROVOLTS * core_vid);
|
||||
}
|
||||
}
|
19
src/soc/amd/common/block/cpu/svi3.c
Normal file
19
src/soc/amd/common/block/cpu/svi3.c
Normal file
|
@ -0,0 +1,19 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#include <amdblocks/cpu.h>
|
||||
#include <types.h>
|
||||
|
||||
/* Value defined in Serial VID Interface 3.0 spec (#56413, NDA only) */
|
||||
#define SERIAL_VID_3_DECODE_MICROVOLTS 5000
|
||||
#define SERIAL_VID_3_BASE_MICROVOLTS 245000L
|
||||
|
||||
uint32_t get_uvolts_from_vid(uint16_t core_vid)
|
||||
{
|
||||
if (core_vid == 0x00) {
|
||||
/* Voltage off for VID code 0x00 */
|
||||
return 0;
|
||||
} else {
|
||||
return SERIAL_VID_3_BASE_MICROVOLTS +
|
||||
(SERIAL_VID_3_DECODE_MICROVOLTS * core_vid);
|
||||
}
|
||||
}
|
|
@ -16,6 +16,7 @@ void write_resume_eip(void);
|
|||
|
||||
union pstate_msr; /* proper definition is in soc/msr.h */
|
||||
|
||||
uint32_t get_uvolts_from_vid(uint16_t core_vid);
|
||||
uint32_t get_pstate_core_freq(union pstate_msr pstate_reg);
|
||||
uint32_t get_pstate_core_power(union pstate_msr pstate_reg);
|
||||
const acpi_cstate_t *get_cstate_config_data(size_t *size);
|
||||
|
|
|
@ -69,6 +69,7 @@ config SOC_AMD_GLINDA
|
|||
select SOC_AMD_COMMON_BLOCK_SMU # TODO: Check if this is still correct
|
||||
select SOC_AMD_COMMON_BLOCK_SMU_SX_ENTRY # TODO: Check if this is still correct
|
||||
select SOC_AMD_COMMON_BLOCK_SPI # TODO: Check if this is still correct
|
||||
select SOC_AMD_COMMON_BLOCK_SVI3
|
||||
select SOC_AMD_COMMON_BLOCK_TSC_FAM17H_19H # FIXME: This is likely incompatible
|
||||
select SOC_AMD_COMMON_BLOCK_UART # TODO: Check if this is still correct
|
||||
select SOC_AMD_COMMON_BLOCK_UCODE # TODO: Check if this is still correct
|
||||
|
|
|
@ -123,13 +123,7 @@ uint32_t get_pstate_core_power(union pstate_msr pstate_reg)
|
|||
current_divisor = pstate_reg.idd_div;
|
||||
|
||||
/* Voltage */
|
||||
if (core_vid == 0x00) {
|
||||
/* Voltage off for VID code 0x00 */
|
||||
voltage_in_uvolts = 0;
|
||||
} else {
|
||||
voltage_in_uvolts = SERIAL_VID_3_BASE_MICROVOLTS +
|
||||
(SERIAL_VID_3_DECODE_MICROVOLTS * core_vid);
|
||||
}
|
||||
voltage_in_uvolts = get_uvolts_from_vid(core_vid);
|
||||
|
||||
/* Power in mW */
|
||||
power_in_mw = (voltage_in_uvolts) / 10 * current_value_amps;
|
||||
|
|
|
@ -22,10 +22,6 @@ union pstate_msr {
|
|||
|
||||
#define PSTATE_DEF_CORE_FREQ_BASE 5
|
||||
|
||||
/* Value defined in Serial VID Interface 3.0 spec (#56413, NDA only) */
|
||||
#define SERIAL_VID_3_DECODE_MICROVOLTS 5000
|
||||
#define SERIAL_VID_3_BASE_MICROVOLTS 245000L
|
||||
|
||||
#define MSR_CPPC_CAPABILITY_1 0xc00102b0
|
||||
#define SHIFT_CPPC_CAPABILITY_1_HIGHEST_PERF 24
|
||||
#define SHIFT_CPPC_CAPABILITY_1_NOMINAL_PERF 16
|
||||
|
|
|
@ -71,6 +71,7 @@ config SOC_AMD_REMBRANDT_BASE
|
|||
select SOC_AMD_COMMON_BLOCK_SMU_SX_ENTRY
|
||||
select SOC_AMD_COMMON_BLOCK_SPI
|
||||
select SOC_AMD_COMMON_BLOCK_STB
|
||||
select SOC_AMD_COMMON_BLOCK_SVI3
|
||||
select SOC_AMD_COMMON_BLOCK_TSC_FAM17H_19H
|
||||
select SOC_AMD_COMMON_BLOCK_UART
|
||||
select SOC_AMD_COMMON_BLOCK_UCODE
|
||||
|
|
|
@ -148,13 +148,7 @@ uint32_t get_pstate_core_power(union pstate_msr pstate_reg)
|
|||
current_divisor = pstate_reg.idd_div;
|
||||
|
||||
/* Voltage */
|
||||
if (core_vid == 0x00) {
|
||||
/* Voltage off for VID code 0x00 */
|
||||
voltage_in_uvolts = 0;
|
||||
} else {
|
||||
voltage_in_uvolts = SERIAL_VID_3_BASE_MICROVOLTS +
|
||||
(SERIAL_VID_3_DECODE_MICROVOLTS * core_vid);
|
||||
}
|
||||
voltage_in_uvolts = get_uvolts_from_vid(core_vid);
|
||||
|
||||
/* Power in mW */
|
||||
power_in_mw = (voltage_in_uvolts) / 10 * current_value_amps;
|
||||
|
|
|
@ -23,10 +23,6 @@ union pstate_msr {
|
|||
#define PSTATE_DEF_FREQ_DIV_MAX 0x3E
|
||||
#define PSTATE_DEF_CORE_FREQ_BASE 25
|
||||
|
||||
/* Value defined in Serial VID Interface 3.0 spec (#56413, NDA only) */
|
||||
#define SERIAL_VID_3_DECODE_MICROVOLTS 5000
|
||||
#define SERIAL_VID_3_BASE_MICROVOLTS 245000L
|
||||
|
||||
#define MSR_CPPC_CAPABILITY_1 0xc00102b0
|
||||
#define SHIFT_CPPC_CAPABILITY_1_HIGHEST_PERF 24
|
||||
#define SHIFT_CPPC_CAPABILITY_1_NOMINAL_PERF 16
|
||||
|
|
|
@ -69,6 +69,7 @@ config SOC_AMD_PHOENIX
|
|||
select SOC_AMD_COMMON_BLOCK_SMU
|
||||
select SOC_AMD_COMMON_BLOCK_SMU_SX_ENTRY
|
||||
select SOC_AMD_COMMON_BLOCK_SPI
|
||||
select SOC_AMD_COMMON_BLOCK_SVI3
|
||||
select SOC_AMD_COMMON_BLOCK_TSC_FAM17H_19H
|
||||
select SOC_AMD_COMMON_BLOCK_UART
|
||||
select SOC_AMD_COMMON_BLOCK_UCODE
|
||||
|
|
|
@ -149,13 +149,7 @@ uint32_t get_pstate_core_power(union pstate_msr pstate_reg)
|
|||
current_divisor = pstate_reg.idd_div;
|
||||
|
||||
/* Voltage */
|
||||
if (core_vid == 0x00) {
|
||||
/* Voltage off for VID code 0x00 */
|
||||
voltage_in_uvolts = 0;
|
||||
} else {
|
||||
voltage_in_uvolts = SERIAL_VID_3_BASE_MICROVOLTS +
|
||||
(SERIAL_VID_3_DECODE_MICROVOLTS * core_vid);
|
||||
}
|
||||
voltage_in_uvolts = get_uvolts_from_vid(core_vid);
|
||||
|
||||
/* Power in mW */
|
||||
power_in_mw = (voltage_in_uvolts) / 10 * current_value_amps;
|
||||
|
|
|
@ -25,10 +25,6 @@ union pstate_msr {
|
|||
#define PSTATE_DEF_FREQ_DIV_MAX 0x3E
|
||||
#define PSTATE_DEF_CORE_FREQ_BASE 25
|
||||
|
||||
/* Value defined in Serial VID Interface 3.0 spec (#56413, NDA only) */
|
||||
#define SERIAL_VID_3_DECODE_MICROVOLTS 5000
|
||||
#define SERIAL_VID_3_BASE_MICROVOLTS 245000L
|
||||
|
||||
#define MSR_CPPC_CAPABILITY_1 0xc00102b0
|
||||
#define SHIFT_CPPC_CAPABILITY_1_HIGHEST_PERF 24
|
||||
#define SHIFT_CPPC_CAPABILITY_1_NOMINAL_PERF 16
|
||||
|
|
|
@ -59,6 +59,7 @@ config SOC_AMD_PICASSO
|
|||
select SOC_AMD_COMMON_BLOCK_SMU
|
||||
select SOC_AMD_COMMON_BLOCK_SMU_SX_ENTRY
|
||||
select SOC_AMD_COMMON_BLOCK_SPI
|
||||
select SOC_AMD_COMMON_BLOCK_SVI2
|
||||
select SOC_AMD_COMMON_BLOCK_TSC_FAM17H_19H
|
||||
select SOC_AMD_COMMON_BLOCK_UART
|
||||
select SOC_AMD_COMMON_BLOCK_UCODE
|
||||
|
|
|
@ -150,13 +150,7 @@ uint32_t get_pstate_core_power(union pstate_msr pstate_reg)
|
|||
current_divisor = pstate_reg.idd_div;
|
||||
|
||||
/* Voltage */
|
||||
if ((core_vid >= 0xF8) && (core_vid <= 0xFF)) {
|
||||
/* Voltage off for VID codes 0xF8 to 0xFF */
|
||||
voltage_in_uvolts = 0;
|
||||
} else {
|
||||
voltage_in_uvolts = SERIAL_VID_2_MAX_MICROVOLTS -
|
||||
(SERIAL_VID_2_DECODE_MICROVOLTS * core_vid);
|
||||
}
|
||||
voltage_in_uvolts = get_uvolts_from_vid(core_vid);
|
||||
|
||||
/* Power in mW */
|
||||
power_in_mw = (voltage_in_uvolts) / 10 * current_value_amps;
|
||||
|
|
|
@ -26,8 +26,4 @@ union pstate_msr {
|
|||
#define PSTATE_DEF_FREQ_DIV_MAX 0x3E
|
||||
#define PSTATE_DEF_CORE_FREQ_BASE 25
|
||||
|
||||
/* Value defined in Serial VID Interface 2.0 spec (#48022, NDA only) */
|
||||
#define SERIAL_VID_2_DECODE_MICROVOLTS 6250
|
||||
#define SERIAL_VID_2_MAX_MICROVOLTS 1550000L
|
||||
|
||||
#endif /* AMD_PICASSO_MSR_H */
|
||||
|
|
Loading…
Reference in a new issue