/** @file CPU Overclocking Config Block. Copyright (c) 2019 Intel Corporation. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent **/ #ifndef _CPU_OVERCLOCKING_PREMEM_CONFIG_H_ #define _CPU_OVERCLOCKING_PREMEM_CONFIG_H_ #define CPU_OVERCLOCKING_CONFIG_REVISION 4 extern EFI_GUID gCpuOverclockingPreMemConfigGuid; #pragma pack (push,1) /** CPU Overclocking Configuration Structure. Revision 1: - Initial version. Revision 2 - Deprecate RingMinOcRatio Revision 3 - Change RingDownBin default to 'Enabled' Revision 4 - Add TvbRatioClipping, TvbVoltageOptimization **/ typedef struct { CONFIG_BLOCK_HEADER Header; ///< Config Block Header /** Overclocking support. This controls whether OC mailbox transactions are sent. If disabled, all policies in this config block besides OcSupport and OcLock will be ignored. 0: Disable; 1: Enable. @note If PcdOverclockEnable is disabled, this should also be disabled. **/ UINT32 OcSupport : 1; UINT32 OcLock : 1; ///< If enabled, sets OC lock bit in MSR 0x194[20], locking the OC mailbox and other OC configuration settings.; 0: Disable; 1: Enable (Lock). /** Core voltage mode, specifies which voltage mode the processor will be operating. 0: Adaptive Mode allows the processor to interpolate a voltage curve when beyond fused P0 range; 1: Override, sets one voltage for for the entire frequency range, Pn-P0. **/ UINT32 CoreVoltageMode : 1; UINT32 CorePllVoltageOffset : 6; ///< Core PLL voltage offset. 0: No offset. Range 0-63 in 17.5mv units. UINT32 Avx2RatioOffset : 5; ///< AVX2 Ratio Offset. 0: No offset. Range is 0-31. Used to lower the AVX ratio to maximize possible ratio for SSE workload. UINT32 Avx3RatioOffset : 5; ///< AVX3 Ratio Offset. 0: No offset. Range is 0-31. Used to lower the AVX3 ratio to maximize possible ratio for SSE workload. UINT32 BclkAdaptiveVoltage : 1; ///< Bclk Adaptive Voltage enable/disable. 0: Disabled, 1: Enabled. When enabled, the CPU V/F curves are aware of BCLK frequency when calculated. /** Ring Downbin enable/disable. When enabled, the CPU will force the ring ratio to be lower than the core ratio. Disabling will allow the ring and core ratios to run at the same frequency. Uses OC Mailbox command 0x19. 0: Disables Ring Downbin feature. 1: Enables Ring downbin feature. **/ UINT32 RingDownBin : 1; /** Ring voltage mode, specifies which voltage mode the processor will be operating. 0: Adaptive Mode allows the processor to interpolate a voltage curve when beyond fused P0 range; 1: Override, sets one voltage for for the entire frequency range, Pn-P0. **/ UINT32 RingVoltageMode : 1; UINT32 RsvdBits : 10; ///< Reserved for future use /** Maximum core turbo ratio override allows to increase CPU core frequency beyond the fused max turbo ratio limit (P0). 0. no override/HW defaults.. Range 0-255. Max range varies by CPU sku. **/ UINT8 CoreMaxOcRatio; /** The core voltage override which is applied to the entire range of cpu core frequencies. Used when CoreVoltageMode = Override. 0. no override. Range 0-2000 mV. **/ UINT16 CoreVoltageOverride; /** Adaptive Turbo voltage target used to define the interpolation voltage point when the cpu is operating in turbo mode range. Used when CoreVoltageMode = Adaptive. 0. no override. Range 0-2000mV. **/ UINT16 CoreVoltageAdaptive; /** The core voltage offset applied on top of all other voltage modes. This offset is applied over the entire frequency range. This is a 2's complement number in mV units. Default: 0 Range: -1000 to 1000. **/ INT16 CoreVoltageOffset; /** Maximum ring ratio override allows to increase CPU ring frequency beyond the fused max ring ratio limit. 0. no override/HW defaults.. Range 0-255. Max range varies by CPU sku. **/ UINT8 RingMaxOcRatio; /** The ring voltage override which is applied to the entire range of cpu ring frequencies. Used when RingVoltageMode = Override. 0. no override. Range 0-2000 mV. **/ UINT16 RingVoltageOverride; /** Adaptive Turbo voltage target used to define the interpolation voltage point when the ring is operating in turbo mode range. Used when RingVoltageMode = Adaptive. 0. no override. Range 0-2000mV. **/ UINT16 RingVoltageAdaptive; /** The ring voltage offset applied on top of all other voltage modes. This offset is applied over the entire frequency range. This is a 2's complement number in mV units. Default: 0 Range: -1000 to 1000. **/ INT16 RingVoltageOffset; UINT8 RingMinOcRatio; ///< Deprecated since rev 2. Minimum ring ratio override. 0: Hardware defaults. Range: 0-83. UINT32 GtPllVoltageOffset : 6; ///< GT PLL voltage offset. 0: No offset. Range 0-63 in 17.5mv units. UINT32 RingPllVoltageOffset : 6; ///< Ring PLL voltage offset. 0: No offset. Range 0-63 in 17.5mv units. UINT32 SaPllVoltageOffset : 6; ///< System Agent PLL voltage offset. 0: No offset. Range 0-63 in 17.5mv units. UINT32 McPllVoltageOffset : 6; ///< Memory Controller PLL voltage offset. 0: No offset. Range 0-63 in 17.5mv units. /** This service controls Core frequency reduction caused by high package temperatures for processors that implement the Intel Thermal Velocity Boost (TVB) feature. It is required to be disabled for supporting overclocking at frequencies higher than the default max turbo frequency. 0: Disables TVB ratio clipping. 1: Enables TVB ratio clipping. **/ UINT32 TvbRatioClipping : 1; /** This service controls thermal based voltage optimizations for processors that implement the Intel Thermal Velocity Boost (TVB) feature. 0: Disables TVB voltage optimization. 1: Enables TVB voltage optimization. **/ UINT32 TvbVoltageOptimization : 1; UINT32 RsvdBits1 : 6; /** TjMax Offset. Specified value here is clipped by pCode (125 - TjMax Offset) to support TjMax in the range of 62 to 115 deg Celsius. Default: 0 Hardware Defaults Range 0 to 63. **/ UINT8 TjMaxOffset; } CPU_OVERCLOCKING_PREMEM_CONFIG; #pragma pack (pop) #endif // _CPU_OVERCLOCKING_CONFIG_H_