/** @file Copyright (c) 2024, Intel Corporation. All rights reserved.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. * Neither the name of Intel Corporation nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. This file is automatically generated. Please do NOT modify !!! **/ #ifndef __FSPS_UPD_H__ #define __FSPS_UPD_H__ #include #pragma pack(1) typedef struct { /** PCIe Controller 0 Enable / Disable PCI Express controller 0 $EN_DIS **/ UINT8 EnablePcie0; /** PCIe Controller 1 Enable / Disable PCI Express controller 1 $EN_DIS **/ UINT8 EnablePcie1; /** Embedded Multi-Media Controller (eMMC) Enable / Disable Embedded Multi-Media controller $EN_DIS **/ UINT8 EnableEmmc; /** LAN Controllers Enable / Disable LAN controllers, refer to FSP Integration Guide for details. 0:Disable LAN 0 & LAN 1, 1:Enable LAN 0 & LAN 1, 2:Disable LAN 1 only **/ UINT8 EnableGbE; /** PCIe Root Port 0 DeEmphasis Desired DeEmphasis level for PCIE root port 0:6dB, 1:3.5dB **/ UINT8 PcieRootPort0DeEmphasis; /** PCIe Root Port 1 DeEmphasis Desired DeEmphasis level for PCIE root port 0:6dB, 1:3.5dB **/ UINT8 PcieRootPort1DeEmphasis; /** PCIe Root Port 2 DeEmphasis Desired DeEmphasis level for PCIE root port 0:6dB, 1:3.5dB **/ UINT8 PcieRootPort2DeEmphasis; /** PCIe Root Port 3 DeEmphasis Desired DeEmphasis level for PCIE root port 0:6dB, 1:3.5dB **/ UINT8 PcieRootPort3DeEmphasis; /** PCIe Root Port 4 DeEmphasis Desired DeEmphasis level for PCIE root port 0:6dB, 1:3.5dB **/ UINT8 PcieRootPort4DeEmphasis; /** PCIe Root Port 5 DeEmphasis Desired DeEmphasis level for PCIE root port 0:6dB, 1:3.5dB **/ UINT8 PcieRootPort5DeEmphasis; /** PCIe Root Port 6 DeEmphasis Desired DeEmphasis level for PCIE root port 0:6dB, 1:3.5dB **/ UINT8 PcieRootPort6DeEmphasis; /** PCIe Root Port 7 DeEmphasis Desired DeEmphasis level for PCIE root port 0:6dB, 1:3.5dB **/ UINT8 PcieRootPort7DeEmphasis; /** eMMC DLL Configuration Data Pointer to eMMC DLL Configuration Data **/ UINT32 EMMCDLLConfigPtr; /** PCH Protect Range Limit Left shifted address by 12 bits with address bits 11:0 are assumed to be FFFh for limit comparison. **/ UINT16 PchProtectedRangeLimit[5]; /** PCH Protect Range Base Left shifted address by 12 bits with address bits 11:0 are assumed to be 0. **/ UINT16 PchProtectedRangeBase[5]; /** PchAdrEn PchAdr 0:PLATFORM POR, 1:FORCE ENABLE(Default), 2:FORCE DISABLE 0:PLATFORM POR, 1:FORCE ENABLE, 2:FORCE DISABLE **/ UINT8 PchAdrEn; /** Enable Timed GPIO0 Enable/Disable Timed GPIO0. When disabled, it disables cross time stamp time-synchronization as extension of Hammock Harbor time synchronization $EN_DIS **/ UINT8 EnableTimedGpio0; /** Enable Timed GPIO1 Enable/Disable Timed GPIO0. When disabled, it disables cross time stamp time-synchronization as extension of Hammock Harbor time synchronization $EN_DIS **/ UINT8 EnableTimedGpio1; /** FSP smm init enable Enable / Disable FSP smm init $EN_DIS **/ UINT8 FspSmmInitEn; /** C2C3TT Default = 0, means [AUTO]. C2 to C3 Transition Timer, PPDN_INIT = C2C3TT CSR Bit[11:0] 0: Default, Bit[11:0] : C2 to C3 Transition Timer **/ UINT8 CpuPmC2c3tt; /** Processor Enable Monitor MWAIT Enable(Default) or Disable Processor Monitor MWAIT $EN_DIS **/ UINT8 CpuPmMonitorMWait; /** Processor TurboMode Function Enable(Default) or Disable Processor TurboMode Function $EN_DIS **/ UINT8 CpuPmTurboMode; /** Hardware P-States Disable: Hardware chooses a P-state based on OS Request (Legacy P-States)\n Native Mode:Hardware chooses a P-state based on OS guidance\n Out of Band Mode:Hardware autonomously chooses a P-state (no OS guidance) 0:Disable, 1:Native Mode (Default), 2:Out of Band Mode, 3:Native Mode with No Legacy Support **/ UINT8 CpuPmProcessorHWPMEnable; /** HardwarePM Interrupt Enable or Disable (Default) Hardware PM Interrupt $EN_DIS **/ UINT8 CpuPmProcessorHWPMInterrupt; /** EPP Profile Choose an HWPM Profile, 0: Performance, 128: Balanced Performance, 192: Balanced Power, 255: Power 0: Performance, 128: Balanced Performance, 192: Balanced Power, 255: Power **/ UINT8 CpuPmProcessorEPPProfile; /** Boot Performance Mode Select the performance state that the BIOS will set before OS hand off, 0: Max Performance, 1: Max Efficiency 0: Max Performance (Default), 1: Max Efficiency **/ UINT8 CpuPmBootPstate; /** Power Performance Tuning Power Performance Tuning 0: OS Controls EPB (Default), 1: BIOS Controls EPB, 2: PECI Controls EPB 0: OS Controls EPB, 1: BIOS Controls EPB, 2: PECI Controls EPB **/ UINT8 CpuPmPwrPerfTuning; /** FSPS Upd settings support : FSPS Upd settings support $EN_DIS **/ UINT8 FspsUpdSupport; /** N/A Pointer to node list which is used to initizalize security variables - CCT_VS_METADATA_NODE **/ EFI_PHYSICAL_ADDRESS SecurityCctVarStorageMetadataNodePtr; /** N/A **/ UINT8 ReservedSiliconInitUpd[16]; } FSPS_CONFIG; typedef struct { /** N/A **/ FSP_UPD_HEADER FspUpdHeader; /** N/A **/ FSPS_ARCH2_UPD FspsArchUpd; /** N/A **/ FSPS_CONFIG FspsConfig; /** N/A **/ UINT16 UpdTerminator; } FSPS_UPD; #pragma pack() #endif