/** @file PCH FIVR policy @copyright INTEL CONFIDENTIAL Copyright 2017 - 2021 Intel Corporation. The source code contained or described herein and all documents related to the source code ("Material") are owned by Intel Corporation or its suppliers or licensors. Title to the Material remains with Intel Corporation or its suppliers and licensors. The Material may contain trade secrets and proprietary and confidential information of Intel Corporation and its suppliers and licensors, and is protected by worldwide copyright and trade secret laws and treaty provisions. No part of the Material may be used, copied, reproduced, modified, published, uploaded, posted, transmitted, distributed, or disclosed in any way without Intel's prior express written permission. No license under any patent, copyright, trade secret or other intellectual property right is granted to or conferred upon you by disclosure or delivery of the Materials, either expressly, by implication, inducement, estoppel or otherwise. Any license under such intellectual property rights must be express and approved by Intel in writing. Unless otherwise agreed by Intel in writing, you may not remove or alter this notice or any other notice embedded in Materials by Intel or Intel's suppliers or licensors in any way. This file contains an 'Intel Peripheral Driver' and is uniquely identified as "Intel Reference Module" and is licensed for Intel CPUs and chipsets under the terms of your license agreement with Intel or your vendor. This file may be modified by the user, subject to additional terms of the license agreement. @par Specification Reference: **/ #ifndef _FIVR_CONFIG_H_ #define _FIVR_CONFIG_H_ /** Revision 1: - Initial version. Revision 2: - Added BypassFivrConfig **/ #define PCH_FIVR_CONFIG_REVISION 2 extern EFI_GUID gFivrConfigGuid; #pragma pack (push,1) /** Rail support in S0ix and Sx Settings other than FivrRailDisabled can be OR'ed **/ typedef enum { FivrRailDisabled = 0, FivrRailInS0i1S0i2 = BIT0, FivrRailInS0i3 = BIT1, FivrRailInS3 = BIT2, FivrRailInS4 = BIT3, FivrRailInS5 = BIT4, FivrRailInS0ix = FivrRailInS0i1S0i2 | FivrRailInS0i3, FivrRailInSx = FivrRailInS3 | FivrRailInS4 | FivrRailInS5, FivrRailAlwaysOn = FivrRailInS0ix | FivrRailInSx } FIVR_RAIL_SX_STATE; typedef enum { FivrRetentionActive = BIT0, FivrNormActive = BIT1, FivrMinActive = BIT2, FivrMinRetention = BIT3 } FIVR_RAIL_SUPPORTED_VOLTAGE; /** Structure for V1p05/Vnn VR rail configuration **/ typedef struct { /** Mask to enable the usage of external VR rail in specific S0ix or Sx states Use values from FIVR_RAIL_SX_STATE The default is FivrRailDisabled. **/ UINT32 EnabledStates : 6; /** VR rail voltage value that will be used in S0i2/S0i3 states. This value is given in 2.5mV increments (0=0mV, 1=2.5mV, 2=5mV...) The default for Vnn is set to 420 - 1050 mV. **/ UINT32 Voltage : 11; /** @deprecated THIS POLICY IS DEPRECATED, PLEASE USE IccMaximum INSTEAD VR rail Icc Max Value Granularity of this setting is 1mA and maximal possible value is 500mA The default is 0mA . **/ UINT32 IccMax : 8; /** UINT32 Alignement **/ UINT32 RsvdBits1 : 7; /** This register holds the control hold off values to be used when changing the rail control for external bypass value in us **/ UINT32 CtrlRampTmr : 8; /** Mask to set the supported configuration in VR rail. Use values from FIVR_RAIL_SUPPORTED_VOLTAGE **/ UINT32 SupportedVoltageStates : 4; /** VR rail Icc Maximum Value Granularity of this setting is 1mA and maximal possible value is 500mA The default is 0mA . **/ UINT32 IccMaximum : 16; /** UINT32 Alignment **/ UINT32 RsvdBits2 : 4; } FIVR_EXT_RAIL_CONFIG; /** Structure for VCCIN_AUX voltage rail configuration **/ typedef struct { /** Transition time in microseconds from Low Current Mode Voltage to High Current Mode Voltage. Voltage transition time required by motherboard voltage regulator when PCH changes the VCCIN_AUX regulator set point from the low current mode voltage and high current mode voltage. This field has 1us resolution. When value is 0 PCH will not transition VCCIN_AUX to low current mode voltage. The default is 0xC . **/ UINT8 LowToHighCurModeVolTranTime; /** Transition time in microseconds from Retention Mode Voltage to High Current Mode Voltage. Voltage transition time required by motherboard voltage regulator when PCH changes the VCCIN_AUX regulator set point from the retention mode voltage to high current mode voltage. This field has 1us resolution. When value is 0 PCH will not transition VCCIN_AUX to retention voltage. The default is 0x36 . **/ UINT8 RetToHighCurModeVolTranTime; /** Transition time in microseconds from Retention Mode Voltage to Low Current Mode Voltage. Voltage transition time required by motherboard voltage regulator when PCH changes the VCCIN_AUX regulator set point from the retention mode voltage to low current mode voltage. This field has 1us resolution. When value is 0 PCH will not transition VCCIN_AUX to retention voltage. The default is 0x2B . **/ UINT8 RetToLowCurModeVolTranTime; UINT8 RsvdByte1; /** Transition time in microseconds from Off (0V) to High Current Mode Voltage. Voltage transition time required by motherboard voltage regulator when PCH changes the VCCIN_AUX regulator set point from 0V to the high current mode voltage. This field has 1us resolution. 0 = Transition to 0V is disabled Setting this field to 0 sets VCCIN_AUX as a fixed rail that stays on in all S0 & Sx power states after initial start up on G3 exit The default is 0x96 . **/ UINT32 OffToHighCurModeVolTranTime : 11; UINT32 RsvdBits1 : 21; } FIVR_VCCIN_AUX_CONFIG; /** The PCH_FIVR_CONFIG block describes FIVR settings. **/ typedef struct { CONFIG_BLOCK_HEADER Header; ///< Config Block Header /** External V1P05 VR rail configuration. **/ FIVR_EXT_RAIL_CONFIG ExtV1p05Rail; /** External Vnn VR rail configuration. **/ FIVR_EXT_RAIL_CONFIG ExtVnnRail; /** Additional External Vnn VR rail configuration that will get applied in Sx entry SMI callback. Required only if External Vnn VR needs different settings for Sx than those specified in ExtVnnRail. **/ FIVR_EXT_RAIL_CONFIG ExtVnnRailSx; /** VCCIN_AUX voltage rail configuration. **/ FIVR_VCCIN_AUX_CONFIG VccinAux; /** Enable/Disable FIVR Dynamic Power Management Default is 1 . **/ UINT32 FivrDynPm : 1; /** Enable/Disable Bypass of FIVR configuration Default is 0 . **/ UINT32 BypassFivrConfig : 1; UINT32 RsvdBits2 : 30; } PCH_FIVR_CONFIG; #pragma pack (pop) #endif // _FIVR_CONFIG_H_