diff --git a/src/vendorcode/intel/fsp/fsp2_0/meteorlake/FirmwareVersionInfoHob.h b/src/vendorcode/intel/fsp/fsp2_0/meteorlake/FirmwareVersionInfoHob.h new file mode 100644 index 0000000000..14efd90f3e --- /dev/null +++ b/src/vendorcode/intel/fsp/fsp2_0/meteorlake/FirmwareVersionInfoHob.h @@ -0,0 +1,68 @@ +/** @file + Header file for Firmware Version Information + + @copyright + Copyright (c) 2015 - 2018, Intel Corporation. All rights reserved.
+ + This program and the accompanying materials are licensed and made available under + the terms and conditions of the BSD License which accompanies this distribution. + The full text of the license may be found at + http://opensource.org/licenses/bsd-license.php + + THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, + WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. + +**/ + +#ifndef _FIRMWARE_VERSION_INFO_HOB_H_ +#define _FIRMWARE_VERSION_INFO_HOB_H_ + +#include +#include +#include + +#pragma pack(1) +/// +/// Firmware Version Structure +/// +typedef struct { + UINT8 MajorVersion; + UINT8 MinorVersion; + UINT8 Revision; + UINT16 BuildNumber; +} FIRMWARE_VERSION; + +/// +/// Firmware Version Information Structure +/// +typedef struct { + UINT8 ComponentNameIndex; ///< Offset 0 Index of Component Name + UINT8 VersionStringIndex; ///< Offset 1 Index of Version String + FIRMWARE_VERSION Version; ///< Offset 2-6 Firmware version +} FIRMWARE_VERSION_INFO; + +#ifndef __SMBIOS_STANDARD_H__ +/// +/// The Smbios structure header. +/// +typedef struct { + UINT8 Type; + UINT8 Length; + UINT16 Handle; +} SMBIOS_STRUCTURE; +#endif + +/// +/// Firmware Version Information HOB Structure +/// +typedef struct { + EFI_HOB_GUID_TYPE Header; ///< Offset 0-23 The header of FVI HOB + SMBIOS_STRUCTURE SmbiosData; ///< Offset 24-27 The SMBIOS header of FVI HOB + UINT8 Count; ///< Offset 28 Number of FVI elements included. +/// +/// FIRMWARE_VERSION_INFO structures followed by the null terminated string buffer +/// +} FIRMWARE_VERSION_INFO_HOB; +#pragma pack() + +#endif // _FIRMWARE_VERSION_INFO_HOB_H_ \ No newline at end of file diff --git a/src/vendorcode/intel/fsp/fsp2_0/meteorlake/FspUpd.h b/src/vendorcode/intel/fsp/fsp2_0/meteorlake/FspUpd.h new file mode 100644 index 0000000000..f980a7e479 --- /dev/null +++ b/src/vendorcode/intel/fsp/fsp2_0/meteorlake/FspUpd.h @@ -0,0 +1,48 @@ +/** @file + +Copyright (c) 2022, 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 __FSPUPD_H__ +#define __FSPUPD_H__ + +#include + +#pragma pack(1) + +#define FSPT_UPD_SIGNATURE 0x545F4450554C4441 /* 'MTLUPD_T' */ + +#define FSPM_UPD_SIGNATURE 0x4D5F4450554C4441 /* 'MTLUPD_M' */ + +#define FSPS_UPD_SIGNATURE 0x535F4450554C4441 /* 'MTLUPD_S' */ + +#pragma pack() + +#endif diff --git a/src/vendorcode/intel/fsp/fsp2_0/meteorlake/FspmUpd.h b/src/vendorcode/intel/fsp/fsp2_0/meteorlake/FspmUpd.h new file mode 100644 index 0000000000..5f0de35a24 --- /dev/null +++ b/src/vendorcode/intel/fsp/fsp2_0/meteorlake/FspmUpd.h @@ -0,0 +1,3074 @@ +/** @file + +Copyright (c) 2022, 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 __FSPMUPD_H__ +#define __FSPMUPD_H__ + +#include + +#pragma pack(1) + + +#include + +/// +/// The ChipsetInit Info structure provides the information of ME ChipsetInit CRC and BIOS ChipsetInit CRC. +/// +typedef struct { + UINT8 Revision; ///< Chipset Init Info Revision + UINT8 Rsvd[3]; ///< Reserved + UINT16 MeChipInitCrc; ///< 16 bit CRC value of MeChipInit Table + UINT16 BiosChipInitCrc; ///< 16 bit CRC value of PchChipInit Table +} CHIPSET_INIT_INFO; + + +/** Fsp M Configuration +**/ +typedef struct { + +/** Offset 0x0040 - Platform Reserved Memory Size + The minimum platform memory size required to pass control into DXE +**/ + UINT64 PlatformMemorySize; + +/** Offset 0x0048 - SPD Data Length + Length of SPD Data + 0x100:256 Bytes, 0x200:512 Bytes, 0x400:1024 Bytes +**/ + UINT16 MemorySpdDataLen; + +/** Offset 0x004A - Reserved +**/ + UINT8 Reserved0; + +/** Offset 0x004B - Enable/Disable CrashLog Device 10 + Enable(Default): Enable CPU CrashLog Device 10, Disable: Disable CPU CrashLog + $EN_DIS +**/ + UINT8 CpuCrashLogDevice; + +/** Offset 0x004C - Memory SPD Pointer Controller 0 Channel 0 Dimm 0 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr000; + +/** Offset 0x0050 - Memory SPD Pointer Controller 0 Channel 0 Dimm 1 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr001; + +/** Offset 0x0054 - Memory SPD Pointer Controller 0 Channel 1 Dimm 0 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr010; + +/** Offset 0x0058 - Memory SPD Pointer Controller 0 Channel 1 Dimm 1 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr011; + +/** Offset 0x005C - Memory SPD Pointer Controller 0 Channel 2 Dimm 0 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr020; + +/** Offset 0x0060 - Memory SPD Pointer Controller 0 Channel 2 Dimm 1 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr021; + +/** Offset 0x0064 - Memory SPD Pointer Controller 0 Channel 3 Dimm 0 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr030; + +/** Offset 0x0068 - Memory SPD Pointer Controller 0 Channel 3 Dimm 1 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr031; + +/** Offset 0x006C - Memory SPD Pointer Controller 1 Channel 0 Dimm 0 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr100; + +/** Offset 0x0070 - Memory SPD Pointer Controller 1 Channel 0 Dimm 1 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr101; + +/** Offset 0x0074 - Memory SPD Pointer Controller 1 Channel 1 Dimm 0 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr110; + +/** Offset 0x0078 - Memory SPD Pointer Controller 1 Channel 1 Dimm 1 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr111; + +/** Offset 0x007C - Memory SPD Pointer Controller 1 Channel 2 Dimm 0 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr120; + +/** Offset 0x0080 - Memory SPD Pointer Controller 1 Channel 2 Dimm 1 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr121; + +/** Offset 0x0084 - Memory SPD Pointer Controller 1 Channel 3 Dimm 0 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr130; + +/** Offset 0x0088 - Memory SPD Pointer Controller 1 Channel 3 Dimm 1 + Pointer to SPD data, will be used only when SpdAddressTable SPD Address are marked as 00 +**/ + UINT32 MemorySpdPtr131; + +/** Offset 0x008C - RcompResistor settings + Indicates RcompResistor settings: Board-dependent +**/ + UINT16 RcompResistor; + +/** Offset 0x008E - RcompTarget settings + RcompTarget settings: board-dependent +**/ + UINT16 RcompTarget[5]; + +/** Offset 0x0098 - Dqs Map CPU to DRAM MC 0 CH 0 + Set Dqs mapping relationship between CPU and DRAM, Channel 0: board-dependent +**/ + UINT8 DqsMapCpu2DramMc0Ch0[2]; + +/** Offset 0x009A - Dqs Map CPU to DRAM MC 0 CH 1 + Set Dqs mapping relationship between CPU and DRAM, Channel 1: board-dependent +**/ + UINT8 DqsMapCpu2DramMc0Ch1[2]; + +/** Offset 0x009C - Dqs Map CPU to DRAM MC 0 CH 2 + Set Dqs mapping relationship between CPU and DRAM, Channel 2: board-dependent +**/ + UINT8 DqsMapCpu2DramMc0Ch2[2]; + +/** Offset 0x009E - Dqs Map CPU to DRAM MC 0 CH 3 + Set Dqs mapping relationship between CPU and DRAM, Channel 3: board-dependent +**/ + UINT8 DqsMapCpu2DramMc0Ch3[2]; + +/** Offset 0x00A0 - Dqs Map CPU to DRAM MC 1 CH 0 + Set Dqs mapping relationship between CPU and DRAM, Channel 0: board-dependent +**/ + UINT8 DqsMapCpu2DramMc1Ch0[2]; + +/** Offset 0x00A2 - Dqs Map CPU to DRAM MC 1 CH 1 + Set Dqs mapping relationship between CPU and DRAM, Channel 1: board-dependent +**/ + UINT8 DqsMapCpu2DramMc1Ch1[2]; + +/** Offset 0x00A4 - Dqs Map CPU to DRAM MC 1 CH 2 + Set Dqs mapping relationship between CPU and DRAM, Channel 2: board-dependent +**/ + UINT8 DqsMapCpu2DramMc1Ch2[2]; + +/** Offset 0x00A6 - Dqs Map CPU to DRAM MC 1 CH 3 + Set Dqs mapping relationship between CPU and DRAM, Channel 3: board-dependent +**/ + UINT8 DqsMapCpu2DramMc1Ch3[2]; + +/** Offset 0x00A8 - Dq Map CPU to DRAM MC 0 CH 0 + Set Dq mapping relationship between CPU and DRAM, Channel 0: board-dependent +**/ + UINT8 DqMapCpu2DramMc0Ch0[16]; + +/** Offset 0x00B8 - Dq Map CPU to DRAM MC 0 CH 1 + Set Dq mapping relationship between CPU and DRAM, Channel 1: board-dependent +**/ + UINT8 DqMapCpu2DramMc0Ch1[16]; + +/** Offset 0x00C8 - Dq Map CPU to DRAM MC 0 CH 2 + Set Dq mapping relationship between CPU and DRAM, Channel 2: board-dependent +**/ + UINT8 DqMapCpu2DramMc0Ch2[16]; + +/** Offset 0x00D8 - Dq Map CPU to DRAM MC 0 CH 3 + Set Dq mapping relationship between CPU and DRAM, Channel 3: board-dependent +**/ + UINT8 DqMapCpu2DramMc0Ch3[16]; + +/** Offset 0x00E8 - Dq Map CPU to DRAM MC 1 CH 0 + Set Dq mapping relationship between CPU and DRAM, Channel 0: board-dependent +**/ + UINT8 DqMapCpu2DramMc1Ch0[16]; + +/** Offset 0x00F8 - Dq Map CPU to DRAM MC 1 CH 1 + Set Dq mapping relationship between CPU and DRAM, Channel 1: board-dependent +**/ + UINT8 DqMapCpu2DramMc1Ch1[16]; + +/** Offset 0x0108 - Dq Map CPU to DRAM MC 1 CH 2 + Set Dq mapping relationship between CPU and DRAM, Channel 2: board-dependent +**/ + UINT8 DqMapCpu2DramMc1Ch2[16]; + +/** Offset 0x0118 - Dq Map CPU to DRAM MC 1 CH 3 + Set Dq mapping relationship between CPU and DRAM, Channel 3: board-dependent +**/ + UINT8 DqMapCpu2DramMc1Ch3[16]; + +/** Offset 0x0128 - Dqs Pins Interleaved Setting + Indicates DqPinsInterleaved setting: board-dependent + $EN_DIS +**/ + UINT8 DqPinsInterleaved; + +/** Offset 0x0129 - Reserved +**/ + UINT8 Reserved1; + +/** Offset 0x012A - Reserved +**/ + UINT8 Reserved2; + +/** Offset 0x012B - Reserved +**/ + UINT8 Reserved3; + +/** Offset 0x012C - Reserved +**/ + UINT8 Reserved4; + +/** Offset 0x012D - Reserved +**/ + UINT8 Reserved5[3]; + +/** Offset 0x0130 - Tseg Size + Size of SMRAM memory reserved. 0x400000 for Release build and 0x1000000 for Debug build + 0x0400000:4MB, 0x01000000:16MB +**/ + UINT32 TsegSize; + +/** Offset 0x0134 - Reserved +**/ + UINT16 Reserved6; + +/** Offset 0x0136 - Reserved +**/ + UINT8 Reserved7; + +/** Offset 0x0137 - Enable SMBus + Enable/disable SMBus controller. + $EN_DIS +**/ + UINT8 SmbusEnable; + +/** Offset 0x0138 - Spd Address Tabl + Specify SPD Address table for CH0D0/CH0D1/CH1D0&CH1D1. MemorySpdPtr will be used + if SPD Address is 00 +**/ + UINT8 SpdAddressTable[16]; + +/** Offset 0x0148 - Platform Debug Consent + Enabled(All Probes+TraceHub) supports all probes with TraceHub enabled and blocks + s0ix\n + \n + Enabled(Low Power) does not support DCI OOB 4-wire and Tracehub is powergated by + default, s0ix is viable\n + \n + Manual:user needs to configure Advanced Debug Settings manually, aimed at advanced users + 0:Disabled, 2:Enabled (All Probes+TraceHub), 6:Enable (Low Power), 7:Manual +**/ + UINT8 PlatformDebugConsent; + +/** Offset 0x0149 - Reserved +**/ + UINT8 Reserved8; + +/** Offset 0x014A - Reserved +**/ + UINT8 Reserved9; + +/** Offset 0x014B - Reserved +**/ + UINT8 Reserved10; + +/** Offset 0x014C - Reserved +**/ + UINT8 Reserved11; + +/** Offset 0x014D - Reserved +**/ + UINT8 Reserved12; + +/** Offset 0x014E - Reserved +**/ + UINT8 Reserved13; + +/** Offset 0x014F - Reserved +**/ + UINT8 Reserved14; + +/** Offset 0x0150 - Reserved +**/ + UINT8 Reserved15; + +/** Offset 0x0151 - Reserved +**/ + UINT8 Reserved16; + +/** Offset 0x0152 - Reserved +**/ + UINT8 Reserved17; + +/** Offset 0x0153 - Reserved +**/ + UINT8 Reserved18; + +/** Offset 0x0154 - Reserved +**/ + UINT8 Reserved19; + +/** Offset 0x0155 - Reserved +**/ + UINT8 Reserved20; + +/** Offset 0x0156 - Reserved +**/ + UINT8 Reserved21; + +/** Offset 0x0157 - Reserved +**/ + UINT8 Reserved22; + +/** Offset 0x0158 - Reserved +**/ + UINT8 Reserved23[2]; + +/** Offset 0x015A - Reserved +**/ + UINT8 Reserved24[4]; + +/** Offset 0x015E - State of X2APIC_OPT_OUT bit in the DMAR table + 0=Disable/Clear, 1=Enable/Set + $EN_DIS +**/ + UINT8 X2ApicOptOut; + +/** Offset 0x015F - Reserved +**/ + UINT8 Reserved25; + +/** Offset 0x0160 - Base addresses for VT-d function MMIO access + Base addresses for VT-d MMIO access per VT-d engine +**/ + UINT32 VtdBaseAddress[9]; + +/** Offset 0x0184 - Disable VT-d + 0=Enable/FALSE(VT-d enabled), 1=Disable/TRUE (VT-d disabled) + $EN_DIS +**/ + UINT8 VtdDisable; + +/** Offset 0x0185 - Reserved +**/ + UINT8 Reserved26; + +/** Offset 0x0186 - Reserved +**/ + UINT8 Reserved27; + +/** Offset 0x0187 - Internal Graphics Pre-allocated Memory + Size of memory preallocated for internal graphics. + 0x00:0MB, 0x01:32MB, 0x02:64MB, 0x03:96MB, 0x04:128MB, 0xF0:4MB, 0xF1:8MB, 0xF2:12MB, + 0xF3:16MB, 0xF4:20MB, 0xF5:24MB, 0xF6:28MB, 0xF7:32MB, 0xF8:36MB, 0xF9:40MB, 0xFA:44MB, + 0xFB:48MB, 0xFC:52MB, 0xFD:56MB, 0xFE:60MB +**/ + UINT8 IgdDvmt50PreAlloc; + +/** Offset 0x0188 - Internal Graphics + Enable/disable internal graphics. + $EN_DIS +**/ + UINT8 InternalGfx; + +/** Offset 0x0189 - Board Type + MrcBoardType, Options are 0=Mobile/Mobile Halo, 1=Desktop/DT Halo, 5=ULT/ULX/Mobile + Halo, 7=UP Server + 0:Mobile/Mobile Halo, 1:Desktop/DT Halo, 5:ULT/ULX/Mobile Halo, 7:UP Server +**/ + UINT8 UserBd; + +/** Offset 0x018A - Reserved +**/ + UINT8 Reserved28; + +/** Offset 0x018B - Reserved +**/ + UINT8 Reserved29; + +/** Offset 0x018C - DDR Frequency Limit + Maximum Memory Frequency Selections in Mhz. Options are 1067, 1333, 1600, 1867, + 2133, 2400, 2667, 2933 and 0 for Auto. + 1067:1067, 1333:1333, 1600:1600, 1867:1867, 2133:2133, 2400:2400, 2667:2667, 2933:2933, 0:Auto +**/ + UINT16 DdrFreqLimit; + +/** Offset 0x018E - SAGV + System Agent dynamic frequency support. + 0:Disabled, 1:Enabled +**/ + UINT8 SaGv; + +/** Offset 0x018F - Reserved +**/ + UINT8 Reserved30; + +/** Offset 0x0190 - Reserved +**/ + UINT8 Reserved31; + +/** Offset 0x0191 - Reserved +**/ + UINT8 Reserved32; + +/** Offset 0x0192 - Controller 0 Channel 0 DIMM Control + Enable / Disable DIMMs on Controller 0 Channel 0 + $EN_DIS +**/ + UINT8 DisableMc0Ch0; + +/** Offset 0x0193 - Controller 0 Channel 1 DIMM Control + Enable / Disable DIMMs on Controller 0 Channel 1 + $EN_DIS +**/ + UINT8 DisableMc0Ch1; + +/** Offset 0x0194 - Controller 0 Channel 2 DIMM Control + Enable / Disable DIMMs on Controller 0 Channel 2 + $EN_DIS +**/ + UINT8 DisableMc0Ch2; + +/** Offset 0x0195 - Controller 0 Channel 3 DIMM Control + Enable / Disable DIMMs on Controller 0 Channel 3 + $EN_DIS +**/ + UINT8 DisableMc0Ch3; + +/** Offset 0x0196 - Controller 1 Channel 0 DIMM Control + Enable / Disable DIMMs on Controller 1 Channel 0 + $EN_DIS +**/ + UINT8 DisableMc1Ch0; + +/** Offset 0x0197 - Controller 1 Channel 1 DIMM Control + Enable / Disable DIMMs on Controller 1 Channel 1 + $EN_DIS +**/ + UINT8 DisableMc1Ch1; + +/** Offset 0x0198 - Controller 1 Channel 2 DIMM Control + Enable / Disable DIMMs on Controller 1 Channel 2 + $EN_DIS +**/ + UINT8 DisableMc1Ch2; + +/** Offset 0x0199 - Controller 1 Channel 3 DIMM Control + Enable / Disable DIMMs on Controller 1 Channel 3 + $EN_DIS +**/ + UINT8 DisableMc1Ch3; + +/** Offset 0x019A - Reserved +**/ + UINT8 Reserved33; + +/** Offset 0x019B - Reserved +**/ + UINT8 Reserved34; + +/** Offset 0x019C - Reserved +**/ + UINT8 Reserved35; + +/** Offset 0x019D - Reserved +**/ + UINT8 Reserved36; + +/** Offset 0x019E - Memory Reference Clock + 100MHz, 133MHz. + 0:133MHz, 1:100MHz +**/ + UINT8 RefClk; + +/** Offset 0x019F - Reserved +**/ + UINT8 Reserved37; + +/** Offset 0x01A0 - Reserved +**/ + UINT16 Reserved38; + +/** Offset 0x01A2 - Reserved +**/ + UINT16 Reserved39; + +/** Offset 0x01A4 - Reserved +**/ + UINT16 Reserved40; + +/** Offset 0x01A6 - Reserved +**/ + UINT16 Reserved41; + +/** Offset 0x01A8 - Reserved +**/ + UINT8 Reserved42; + +/** Offset 0x01A9 - Reserved +**/ + UINT8 Reserved43; + +/** Offset 0x01AA - Reserved +**/ + UINT16 Reserved44; + +/** Offset 0x01AC - Reserved +**/ + UINT16 Reserved45; + +/** Offset 0x01AE - Reserved +**/ + UINT8 Reserved46; + +/** Offset 0x01AF - Reserved +**/ + UINT8 Reserved47; + +/** Offset 0x01B0 - Reserved +**/ + UINT16 Reserved48; + +/** Offset 0x01B2 - Reserved +**/ + UINT16 Reserved49; + +/** Offset 0x01B4 - Reserved +**/ + UINT8 Reserved50; + +/** Offset 0x01B5 - Reserved +**/ + UINT8 Reserved51; + +/** Offset 0x01B6 - Reserved +**/ + UINT8 Reserved52; + +/** Offset 0x01B7 - Reserved +**/ + UINT8 Reserved53; + +/** Offset 0x01B8 - Reserved +**/ + UINT16 Reserved54; + +/** Offset 0x01BA - Reserved +**/ + UINT16 Reserved55; + +/** Offset 0x01BC - Reserved +**/ + UINT16 Reserved56; + +/** Offset 0x01BE - Reserved +**/ + UINT8 Reserved57; + +/** Offset 0x01BF - Reserved +**/ + UINT8 Reserved58; + +/** Offset 0x01C0 - Reserved +**/ + UINT8 Reserved59; + +/** Offset 0x01C1 - Reserved +**/ + UINT8 Reserved60; + +/** Offset 0x01C2 - Reserved +**/ + UINT8 Reserved61; + +/** Offset 0x01C3 - Reserved +**/ + UINT8 Reserved62; + +/** Offset 0x01C4 - Enable Intel HD Audio (Azalia) + 0: Disable, 1: Enable (Default) Azalia controller + $EN_DIS +**/ + UINT8 PchHdaEnable; + +/** Offset 0x01C5 - Enable PCH ISH Controller + 0: Disable, 1: Enable (Default) ISH Controller + $EN_DIS +**/ + UINT8 PchIshEnable; + +/** Offset 0x01C6 - Reserved +**/ + UINT8 Reserved63[4]; + +/** Offset 0x01CA - Reserved +**/ + UINT16 Reserved64[4]; + +/** Offset 0x01D2 - Reserved +**/ + UINT8 Reserved65; + +/** Offset 0x01D3 - Reserved +**/ + UINT8 Reserved66; + +/** Offset 0x01D4 - Reserved +**/ + UINT8 Reserved67; + +/** Offset 0x01D5 - Reserved +**/ + UINT8 Reserved68; + +/** Offset 0x01D6 - Reserved +**/ + UINT16 Reserved69; + +/** Offset 0x01D8 - Reserved +**/ + UINT8 Reserved70; + +/** Offset 0x01D9 - Reserved +**/ + UINT8 Reserved71[3]; + +/** Offset 0x01DC - Reserved +**/ + UINT32 Reserved72; + +/** Offset 0x01E0 - Reserved +**/ + UINT32 Reserved73; + +/** Offset 0x01E4 - Reserved +**/ + UINT8 Reserved74; + +/** Offset 0x01E5 - Reserved +**/ + UINT8 Reserved75; + +/** Offset 0x01E6 - Reserved +**/ + UINT8 Reserved76; + +/** Offset 0x01E7 - Reserved +**/ + UINT8 Reserved77; + +/** Offset 0x01E8 - Reserved +**/ + UINT16 Reserved78; + +/** Offset 0x01EA - Reserved +**/ + UINT16 Reserved79; + +/** Offset 0x01EC - Reserved +**/ + UINT16 Reserved80; + +/** Offset 0x01EE - Reserved +**/ + UINT16 Reserved81; + +/** Offset 0x01F0 - Reserved +**/ + UINT8 Reserved82; + +/** Offset 0x01F1 - Reserved +**/ + UINT8 Reserved83; + +/** Offset 0x01F2 - Reserved +**/ + UINT8 Reserved84; + +/** Offset 0x01F3 - Enable/Disable SA IPU + Enable(Default): Enable SA IPU, Disable: Disable SA IPU + $EN_DIS +**/ + UINT8 SaIpuEnable; + +/** Offset 0x01F4 - IMGU CLKOUT Configuration + The configuration of IMGU CLKOUT, 0: Disable;1: Enable. + $EN_DIS +**/ + UINT8 ImguClkOutEn[6]; + +/** Offset 0x01FA - Program GPIOs for LFP on DDI port-A device + 0=Disabled,1(Default)=eDP, 2=MIPI DSI + 0:Disabled, 1:eDP, 2:MIPI DSI +**/ + UINT8 DdiPortAConfig; + +/** Offset 0x01FB - Program GPIOs for LFP on DDI port-B device + 0(Default)=Disabled,1=eDP, 2=MIPI DSI + 0:Disabled, 1:eDP, 2:MIPI DSI +**/ + UINT8 DdiPortBConfig; + +/** Offset 0x01FC - Enable or disable HPD of DDI port A + 0(Default)=Disable, 1=Enable + $EN_DIS +**/ + UINT8 DdiPortAHpd; + +/** Offset 0x01FD - Enable or disable HPD of DDI port B + 0=Disable, 1(Default)=Enable + $EN_DIS +**/ + UINT8 DdiPortBHpd; + +/** Offset 0x01FE - Enable or disable HPD of DDI port C + 0(Default)=Disable, 1=Enable + $EN_DIS +**/ + UINT8 DdiPortCHpd; + +/** Offset 0x01FF - Enable or disable HPD of DDI port 1 + 0=Disable, 1(Default)=Enable + $EN_DIS +**/ + UINT8 DdiPort1Hpd; + +/** Offset 0x0200 - Enable or disable HPD of DDI port 2 + 0(Default)=Disable, 1=Enable + $EN_DIS +**/ + UINT8 DdiPort2Hpd; + +/** Offset 0x0201 - Enable or disable HPD of DDI port 3 + 0(Default)=Disable, 1=Enable + $EN_DIS +**/ + UINT8 DdiPort3Hpd; + +/** Offset 0x0202 - Enable or disable HPD of DDI port 4 + 0(Default)=Disable, 1=Enable + $EN_DIS +**/ + UINT8 DdiPort4Hpd; + +/** Offset 0x0203 - Enable or disable DDC of DDI port A + 0(Default)=Disable, 1=Enable + $EN_DIS +**/ + UINT8 DdiPortADdc; + +/** Offset 0x0204 - Enable or disable DDC of DDI port B + 0=Disable, 1(Default)=Enable + $EN_DIS +**/ + UINT8 DdiPortBDdc; + +/** Offset 0x0205 - Enable or disable DDC of DDI port C + 0(Default)=Disable, 1=Enable + $EN_DIS +**/ + UINT8 DdiPortCDdc; + +/** Offset 0x0206 - Enable DDC setting of DDI Port 1 + 0(Default)=Disable, 1=Enable + $EN_DIS +**/ + UINT8 DdiPort1Ddc; + +/** Offset 0x0207 - Enable DDC setting of DDI Port 2 + 0(Default)=Disable, 1=Enable + $EN_DIS +**/ + UINT8 DdiPort2Ddc; + +/** Offset 0x0208 - Enable DDC setting of DDI Port 3 + 0(Default)=Disable, 1=Enable + $EN_DIS +**/ + UINT8 DdiPort3Ddc; + +/** Offset 0x0209 - Enable DDC setting of DDI Port 4 + 0(Default)=Disable, 1=Enable + $EN_DIS +**/ + UINT8 DdiPort4Ddc; + +/** Offset 0x020A - Reserved +**/ + UINT8 Reserved85[6]; + +/** Offset 0x0210 - Reserved +**/ + UINT64 Reserved86; + +/** Offset 0x0218 - Reserved +**/ + UINT16 Reserved87; + +/** Offset 0x021A - Reserved +**/ + UINT8 Reserved88; + +/** Offset 0x021B - Reserved +**/ + UINT8 Reserved89; + +/** Offset 0x021C - Reserved +**/ + UINT8 Reserved90; + +/** Offset 0x021D - Reserved +**/ + UINT8 Reserved91[113]; + +/** Offset 0x028E - Reserved +**/ + UINT8 Reserved92; + +/** Offset 0x028F - Reserved +**/ + UINT8 Reserved93; + +/** Offset 0x0290 - Reserved +**/ + UINT8 Reserved94; + +/** Offset 0x0291 - Reserved +**/ + UINT8 Reserved95; + +/** Offset 0x0292 - DMI Gen3 Root port preset values per lane + Used for programming DMI Gen3 preset values per lane. Range: 0-9, 4 is default for each lane +**/ + UINT8 DmiGen3RootPortPreset[8]; + +/** Offset 0x029A - Reserved +**/ + UINT8 Reserved96[8]; + +/** Offset 0x02A2 - Reserved +**/ + UINT8 Reserved97[8]; + +/** Offset 0x02AA - Reserved +**/ + UINT8 Reserved98; + +/** Offset 0x02AB - Reserved +**/ + UINT8 Reserved99; + +/** Offset 0x02AC - Reserved +**/ + UINT8 Reserved100; + +/** Offset 0x02AD - Reserved +**/ + UINT8 Reserved101; + +/** Offset 0x02AE - Reserved +**/ + UINT8 Reserved102; + +/** Offset 0x02AF - Reserved +**/ + UINT8 Reserved103; + +/** Offset 0x02B0 - Reserved +**/ + UINT8 Reserved104[8]; + +/** Offset 0x02B8 - Reserved +**/ + UINT8 Reserved105[8]; + +/** Offset 0x02C0 - Reserved +**/ + UINT8 Reserved106[8]; + +/** Offset 0x02C8 - Reserved +**/ + UINT8 Reserved107[8]; + +/** Offset 0x02D0 - Reserved +**/ + UINT8 Reserved108; + +/** Offset 0x02D1 - Reserved +**/ + UINT8 Reserved109[8]; + +/** Offset 0x02D9 - Reserved +**/ + UINT8 Reserved110[8]; + +/** Offset 0x02E1 - Reserved +**/ + UINT8 Reserved111; + +/** Offset 0x02E2 - Reserved +**/ + UINT8 Reserved112[8]; + +/** Offset 0x02EA - Reserved +**/ + UINT8 Reserved113[8]; + +/** Offset 0x02F2 - Reserved +**/ + UINT8 Reserved114[8]; + +/** Offset 0x02FA - Reserved +**/ + UINT8 Reserved115[8]; + +/** Offset 0x0302 - Reserved +**/ + UINT8 Reserved116; + +/** Offset 0x0303 - Reserved +**/ + UINT8 Reserved117; + +/** Offset 0x0304 - Reserved +**/ + UINT8 Reserved118; + +/** Offset 0x0305 - Reserved +**/ + UINT8 Reserved119[8]; + +/** Offset 0x030D - Reserved +**/ + UINT8 Reserved120; + +/** Offset 0x030E - Reserved +**/ + UINT8 Reserved121; + +/** Offset 0x030F - Reserved +**/ + UINT8 Reserved122[8]; + +/** Offset 0x0317 - Reserved +**/ + UINT8 Reserved123[8]; + +/** Offset 0x031F - Reserved +**/ + UINT8 Reserved124; + +/** Offset 0x0320 - Reserved +**/ + UINT8 Reserved125[8]; + +/** Offset 0x0328 - Reserved +**/ + UINT8 Reserved126; + +/** Offset 0x0329 - Reserved +**/ + UINT8 Reserved127[3]; + +/** Offset 0x032C - Reserved +**/ + UINT32 Reserved128; + +/** Offset 0x0330 - Reserved +**/ + UINT32 Reserved129; + +/** Offset 0x0334 - Reserved +**/ + UINT32 Reserved130; + +/** Offset 0x0338 - Reserved +**/ + UINT32 Reserved131; + +/** Offset 0x033C - Reserved +**/ + UINT16 Reserved132; + +/** Offset 0x033E - Reserved +**/ + UINT16 Reserved133; + +/** Offset 0x0340 - Reserved +**/ + UINT32 Reserved134; + +/** Offset 0x0344 - Reserved +**/ + UINT32 Reserved135; + +/** Offset 0x0348 - Reserved +**/ + UINT32 Reserved136; + +/** Offset 0x034C - Reserved +**/ + UINT32 Reserved137; + +/** Offset 0x0350 - Reserved +**/ + UINT8 Reserved138; + +/** Offset 0x0351 - Reserved +**/ + UINT8 Reserved139; + +/** Offset 0x0352 - C6DRAM power gating feature + This policy indicates whether or not BIOS should allocate PRMRR memory for C6DRAM + power gating feature.- 0: Don't allocate any PRMRR memory for C6DRAM power gating + feature.- 1: Allocate PRMRR memory for C6DRAM power gating feature. + $EN_DIS +**/ + UINT8 EnableC6Dram; + +/** Offset 0x0353 - Reserved +**/ + UINT8 Reserved140; + +/** Offset 0x0354 - Reserved +**/ + UINT8 Reserved141; + +/** Offset 0x0355 - Reserved +**/ + UINT8 Reserved142; + +/** Offset 0x0356 - Reserved +**/ + UINT8 Reserved143; + +/** Offset 0x0357 - Reserved +**/ + UINT8 Reserved144; + +/** Offset 0x0358 - Hyper Threading Enable/Disable + Enable or Disable Hyper Threading; 0: Disable; 1: Enable + $EN_DIS +**/ + UINT8 HyperThreading; + +/** Offset 0x0359 - Reserved +**/ + UINT8 Reserved145; + +/** Offset 0x035A - CPU ratio value + CPU ratio value. Valid Range 0 to 63 +**/ + UINT8 CpuRatio; + +/** Offset 0x035B - Reserved +**/ + UINT8 Reserved146; + +/** Offset 0x035C - Reserved +**/ + UINT8 Reserved147; + +/** Offset 0x035D - Processor Early Power On Configuration FCLK setting + 0: 800 MHz (ULT/ULX). 1: 1 GHz (DT/Halo). Not supported on ULT/ULX.- + 2: 400 MHz. - 3: Reserved + 0:800 MHz, 1: 1 GHz, 2: 400 MHz, 3: Reserved +**/ + UINT8 FClkFrequency; + +/** Offset 0x035E - Enable or Disable VMX + Enable or Disable VMX; 0: Disable; 1: Enable. + $EN_DIS +**/ + UINT8 VmxEnable; + +/** Offset 0x035F - Reserved +**/ + UINT8 Reserved148; + +/** Offset 0x0360 - Reserved +**/ + UINT8 Reserved149; + +/** Offset 0x0361 - Reserved +**/ + UINT8 Reserved150; + +/** Offset 0x0362 - Reserved +**/ + UINT16 Reserved151; + +/** Offset 0x0364 - Reserved +**/ + UINT16 Reserved152; + +/** Offset 0x0366 - Reserved +**/ + UINT16 Reserved153; + +/** Offset 0x0368 - Reserved +**/ + UINT8 Reserved154; + +/** Offset 0x0369 - Reserved +**/ + UINT8 Reserved155; + +/** Offset 0x036A - Reserved +**/ + UINT8 Reserved156; + +/** Offset 0x036B - Reserved +**/ + UINT8 Reserved157; + +/** Offset 0x036C - Reserved +**/ + UINT16 Reserved158; + +/** Offset 0x036E - Reserved +**/ + UINT16 Reserved159; + +/** Offset 0x0370 - Reserved +**/ + UINT16 Reserved160; + +/** Offset 0x0372 - Enable or Disable TME + Enable or Disable TME; 0: Disable; 1: Enable. + $EN_DIS +**/ + UINT8 TmeEnable; + +/** Offset 0x0373 - Enable CPU CrashLog + Enable or Disable CPU CrashLog; 0: Disable; 1: Enable. + $EN_DIS +**/ + UINT8 CpuCrashLogEnable; + +/** Offset 0x0374 - Reserved +**/ + UINT8 Reserved161; + +/** Offset 0x0375 - Reserved +**/ + UINT8 Reserved162; + +/** Offset 0x0376 - Reserved +**/ + UINT8 Reserved163; + +/** Offset 0x0377 - Reserved +**/ + UINT8 Reserved164[1]; + +/** Offset 0x0378 - Reserved +**/ + UINT16 Reserved165[4]; + +/** Offset 0x0380 - Reserved +**/ + UINT8 Reserved166[4]; + +/** Offset 0x0384 - Reserved +**/ + UINT8 Reserved167; + +/** Offset 0x0385 - Reserved +**/ + UINT8 Reserved168; + +/** Offset 0x0386 - Reserved +**/ + UINT16 Reserved169[15]; + +/** Offset 0x03A4 - Reserved +**/ + UINT8 Reserved170[15]; + +/** Offset 0x03B3 - Reserved +**/ + UINT8 Reserved171[15]; + +/** Offset 0x03C2 - Reserved +**/ + UINT8 Reserved172; + +/** Offset 0x03C3 - Reserved +**/ + UINT8 Reserved173; + +/** Offset 0x03C4 - Reserved +**/ + UINT16 Reserved174[8]; + +/** Offset 0x03D4 - Reserved +**/ + UINT8 Reserved175[8]; + +/** Offset 0x03DC - Reserved +**/ + UINT8 Reserved176; + +/** Offset 0x03DD - Reserved +**/ + UINT8 Reserved177[8]; + +/** Offset 0x03E5 - Reserved +**/ + UINT8 Reserved178; + +/** Offset 0x03E6 - Reserved +**/ + UINT16 Reserved179; + +/** Offset 0x03E8 - Reserved +**/ + UINT8 Reserved180[4]; + +/** Offset 0x03EC - Reserved +**/ + UINT8 Reserved181; + +/** Offset 0x03ED - Reserved +**/ + UINT8 Reserved182; + +/** Offset 0x03EE - Reserved +**/ + UINT8 Reserved183; + +/** Offset 0x03EF - Reserved +**/ + UINT8 Reserved184; + +/** Offset 0x03F0 - Reserved +**/ + UINT8 Reserved185; + +/** Offset 0x03F1 - Reserved +**/ + UINT8 Reserved186; + +/** Offset 0x03F2 - Reserved +**/ + UINT16 Reserved187[15]; + +/** Offset 0x0410 - Reserved +**/ + UINT8 Reserved188[15]; + +/** Offset 0x041F - Reserved +**/ + UINT8 Reserved189[15]; + +/** Offset 0x042E - Reserved +**/ + UINT8 Reserved190; + +/** Offset 0x042F - Reserved +**/ + UINT8 Reserved191; + +/** Offset 0x0430 - Reserved +**/ + UINT8 Reserved192; + +/** Offset 0x0431 - Reserved +**/ + UINT8 Reserved193; + +/** Offset 0x0432 - Reserved +**/ + UINT8 Reserved194; + +/** Offset 0x0433 - Reserved +**/ + UINT8 Reserved195; + +/** Offset 0x0434 - GPIO Override + Gpio Override Level - FSP will not configure any GPIOs and rely on GPIO setings + before moved to FSP. Available configurations 0: Disable; 1: Level 1 - Skips GPIO + configuration in PEI/FSPM/FSPT phase;2: Level 2 - Reserved for future use +**/ + UINT8 GpioOverride; + +/** Offset 0x0435 - Reserved +**/ + UINT8 Reserved196[3]; + +/** Offset 0x0438 - Reserved +**/ + UINT32 Reserved197; + +/** Offset 0x043C - Reserved +**/ + UINT32 Reserved198; + +/** Offset 0x0440 - Reserved +**/ + UINT8 Reserved199; + +/** Offset 0x0441 - Reserved +**/ + UINT8 Reserved200[7]; + +/** Offset 0x0448 - Reserved +**/ + UINT64 Reserved201; + +/** Offset 0x0450 - Reserved +**/ + UINT8 Reserved202; + +/** Offset 0x0451 - Reserved +**/ + UINT8 Reserved203; + +/** Offset 0x0452 - Reserved +**/ + UINT16 Reserved204; + +/** Offset 0x0454 - Reserved +**/ + UINT8 Reserved205; + +/** Offset 0x0455 - Reserved +**/ + UINT8 Reserved206; + +/** Offset 0x0456 - Reserved +**/ + UINT16 Reserved207; + +/** Offset 0x0458 - Reserved +**/ + UINT16 Reserved208[15]; + +/** Offset 0x0476 - Reserved +**/ + UINT8 Reserved209[15]; + +/** Offset 0x0485 - Reserved +**/ + UINT8 Reserved210[15]; + +/** Offset 0x0494 - Reserved +**/ + UINT8 Reserved211; + +/** Offset 0x0495 - Reserved +**/ + UINT8 Reserved212; + +/** Offset 0x0496 - Reserved +**/ + UINT8 Reserved213; + +/** Offset 0x0497 - Reserved +**/ + UINT8 Reserved214; + +/** Offset 0x0498 - Reserved +**/ + UINT8 Reserved215; + +/** Offset 0x0499 - Reserved +**/ + UINT8 Reserved216[28]; + +/** Offset 0x04B5 - Reserved +**/ + UINT8 Reserved217; + +/** Offset 0x04B6 - Reserved +**/ + UINT8 Reserved218; + +/** Offset 0x04B7 - Reserved +**/ + UINT8 Reserved219; + +/** Offset 0x04B8 - Reserved +**/ + UINT16 Reserved220; + +/** Offset 0x04BA - Reserved +**/ + UINT16 Reserved221[5]; + +/** Offset 0x04C4 - Reserved +**/ + UINT16 Reserved222[5]; + +/** Offset 0x04CE - Reserved +**/ + UINT16 Reserved223[5]; + +/** Offset 0x04D8 - Reserved +**/ + UINT16 Reserved224[5]; + +/** Offset 0x04E2 - Reserved +**/ + UINT16 Reserved225[5]; + +/** Offset 0x04EC - Reserved +**/ + UINT16 Reserved226[5]; + +/** Offset 0x04F6 - Reserved +**/ + UINT8 Reserved227[5]; + +/** Offset 0x04FB - Reserved +**/ + UINT8 Reserved228[5]; + +/** Offset 0x0500 - Reserved +**/ + UINT16 Reserved229[5]; + +/** Offset 0x050A - Reserved +**/ + UINT16 Reserved230[5]; + +/** Offset 0x0514 - Reserved +**/ + UINT8 Reserved231[5]; + +/** Offset 0x0519 - Thermal Design Current enable/disable + PCODE MMIO Mailbox: Thermal Design Current enable/disable; 0: Disable; 1: + Enable.For all VR Indexes +**/ + UINT8 TdcEnable[5]; + +/** Offset 0x051E - Reserved +**/ + UINT8 Reserved232[2]; + +/** Offset 0x0520 - Thermal Design Current time window + PCODE MMIO Mailbox: Thermal Design Current time window. Defined in milli seconds. + Range 1ms to 448s +**/ + UINT32 TdcTimeWindow[5]; + +/** Offset 0x0534 - Reserved +**/ + UINT8 Reserved233[5]; + +/** Offset 0x0539 - Reserved +**/ + UINT8 Reserved234; + +/** Offset 0x053A - Reserved +**/ + UINT16 Reserved235; + +/** Offset 0x053C - Reserved +**/ + UINT8 Reserved236; + +/** Offset 0x053D - Reserved +**/ + UINT8 Reserved237; + +/** Offset 0x053E - Reserved +**/ + UINT8 Reserved238; + +/** Offset 0x053F - Reserved +**/ + UINT8 Reserved239; + +/** Offset 0x0540 - Reserved +**/ + UINT8 Reserved240; + +/** Offset 0x0541 - Reserved +**/ + UINT8 Reserved241[1]; + +/** Offset 0x0542 - Reserved +**/ + UINT16 Reserved242[5]; + +/** Offset 0x054C - Reserved +**/ + UINT8 Reserved243[5]; + +/** Offset 0x0551 - Reserved +**/ + UINT8 Reserved244[1]; + +/** Offset 0x0552 - Reserved +**/ + UINT16 Reserved245[5]; + +/** Offset 0x055C - Reserved +**/ + UINT16 Reserved246[5]; + +/** Offset 0x0566 - Reserved +**/ + UINT8 Reserved247[5]; + +/** Offset 0x056B - Reserved +**/ + UINT8 Reserved248[1]; + +/** Offset 0x056C - Reserved +**/ + UINT16 Reserved249[5]; + +/** Offset 0x0576 - Reserved +**/ + UINT16 Reserved250[5]; + +/** Offset 0x0580 - Reserved +**/ + UINT8 Reserved251[5]; + +/** Offset 0x0585 - Reserved +**/ + UINT8 Reserved252[5]; + +/** Offset 0x058A - Reserved +**/ + UINT8 Reserved253[2]; + +/** Offset 0x058C - Reserved +**/ + UINT32 Reserved254[5]; + +/** Offset 0x05A0 - Reserved +**/ + UINT16 Reserved255; + +/** Offset 0x05A2 - Reserved +**/ + UINT8 Reserved256[5]; + +/** Offset 0x05A7 - Reserved +**/ + UINT8 Reserved257[5]; + +/** Offset 0x05AC - Reserved +**/ + UINT16 Reserved258[5]; + +/** Offset 0x05B6 - Reserved +**/ + UINT16 Reserved259[5]; + +/** Offset 0x05C0 - Reserved +**/ + UINT8 Reserved260[5]; + +/** Offset 0x05C5 - Reserved +**/ + UINT8 Reserved261[5]; + +/** Offset 0x05CA - Reserved +**/ + UINT8 Reserved262[5]; + +/** Offset 0x05CF - BiosGuard + Enable/Disable. 0: Disable, Enable/Disable BIOS Guard feature, 1: enable + $EN_DIS +**/ + UINT8 BiosGuard; + +/** Offset 0x05D0 +**/ + UINT8 BiosGuardToolsInterface; + +/** Offset 0x05D1 - Reserved +**/ + UINT8 Reserved263; + +/** Offset 0x05D2 - Reserved +**/ + UINT8 Reserved264[2]; + +/** Offset 0x05D4 - PrmrrSize + Enable/Disable. 0: Disable, define default value of PrmrrSize , 1: enable +**/ + UINT32 PrmrrSize; + +/** Offset 0x05D8 - SinitMemorySize + Enable/Disable. 0: Disable, define default value of SinitMemorySize , 1: enable +**/ + UINT32 SinitMemorySize; + +/** Offset 0x05DC - Reserved +**/ + UINT8 Reserved265[4]; + +/** Offset 0x05E0 - Reserved +**/ + UINT64 Reserved266; + +/** Offset 0x05E8 - TxtHeapMemorySize + Enable/Disable. 0: Disable, define default value of TxtHeapMemorySize , 1: enable +**/ + UINT32 TxtHeapMemorySize; + +/** Offset 0x05EC - TxtDprMemorySize + Enable/Disable. 0: Disable, define default value of TxtDprMemorySize , 1: enable +**/ + UINT32 TxtDprMemorySize; + +/** Offset 0x05F0 - Reserved +**/ + UINT32 Reserved267; + +/** Offset 0x05F4 - Reserved +**/ + UINT32 Reserved268; + +/** Offset 0x05F8 - Reserved +**/ + UINT32 Reserved269; + +/** Offset 0x05FC - Reserved +**/ + UINT32 Reserved270; + +/** Offset 0x0600 - Reserved +**/ + UINT64 Reserved271; + +/** Offset 0x0608 - Reserved +**/ + UINT64 Reserved272; + +/** Offset 0x0610 - Reserved +**/ + UINT8 Reserved273; + +/** Offset 0x0611 - Reserved +**/ + UINT8 Reserved274[32]; + +/** Offset 0x0631 - Reserved +**/ + UINT8 Reserved275[28]; + +/** Offset 0x064D - Reserved +**/ + UINT8 Reserved276[28]; + +/** Offset 0x0669 - Reserved +**/ + UINT8 Reserved277[28]; + +/** Offset 0x0685 - Reserved +**/ + UINT8 Reserved278[28]; + +/** Offset 0x06A1 - Reserved +**/ + UINT8 Reserved279[28]; + +/** Offset 0x06BD - Reserved +**/ + UINT8 Reserved280[28]; + +/** Offset 0x06D9 - Reserved +**/ + UINT8 Reserved281[28]; + +/** Offset 0x06F5 - Reserved +**/ + UINT8 Reserved282[28]; + +/** Offset 0x0711 - Reserved +**/ + UINT8 Reserved283[28]; + +/** Offset 0x072D - Reserved +**/ + UINT8 Reserved284[28]; + +/** Offset 0x0749 - Reserved +**/ + UINT8 Reserved285[28]; + +/** Offset 0x0765 - Reserved +**/ + UINT8 Reserved286[28]; + +/** Offset 0x0781 - Reserved +**/ + UINT8 Reserved287[28]; + +/** Offset 0x079D - Reserved +**/ + UINT8 Reserved288[28]; + +/** Offset 0x07B9 - Reserved +**/ + UINT8 Reserved289[8]; + +/** Offset 0x07C1 - Reserved +**/ + UINT8 Reserved290[8]; + +/** Offset 0x07C9 - Reserved +**/ + UINT8 Reserved291[8]; + +/** Offset 0x07D1 - Reserved +**/ + UINT8 Reserved292[8]; + +/** Offset 0x07D9 - Reserved +**/ + UINT8 Reserved293[8]; + +/** Offset 0x07E1 - Reserved +**/ + UINT8 Reserved294[8]; + +/** Offset 0x07E9 - Reserved +**/ + UINT8 Reserved295[8]; + +/** Offset 0x07F1 - Reserved +**/ + UINT8 Reserved296[8]; + +/** Offset 0x07F9 - Reserved +**/ + UINT8 Reserved297[8]; + +/** Offset 0x0801 - Reserved +**/ + UINT8 Reserved298[8]; + +/** Offset 0x0809 - Reserved +**/ + UINT8 Reserved299[8]; + +/** Offset 0x0811 - Reserved +**/ + UINT8 Reserved300[8]; + +/** Offset 0x0819 - Reserved +**/ + UINT8 Reserved301[8]; + +/** Offset 0x0821 - Reserved +**/ + UINT8 Reserved302[8]; + +/** Offset 0x0829 - Reserved +**/ + UINT8 Reserved303[8]; + +/** Offset 0x0831 - Reserved +**/ + UINT8 Reserved304[8]; + +/** Offset 0x0839 - Reserved +**/ + UINT8 Reserved305[8]; + +/** Offset 0x0841 - Reserved +**/ + UINT8 Reserved306[8]; + +/** Offset 0x0849 - Reserved +**/ + UINT8 Reserved307; + +/** Offset 0x084A - Reserved +**/ + UINT8 Reserved308; + +/** Offset 0x084B - Reserved +**/ + UINT8 Reserved309; + +/** Offset 0x084C - Number of RsvdSmbusAddressTable. + The number of elements in the RsvdSmbusAddressTable. +**/ + UINT8 PchNumRsvdSmbusAddresses; + +/** Offset 0x084D - Reserved +**/ + UINT8 Reserved310; + +/** Offset 0x084E - Reserved +**/ + UINT16 Reserved311; + +/** Offset 0x0850 - Reserved +**/ + UINT8 Reserved312; + +/** Offset 0x0851 - Usage type for ClkSrc + 0-23: PCH rootport, 0x70:LAN, 0x80: unspecified but in use (free running), 0xFF: not used +**/ + UINT8 PcieClkSrcUsage[18]; + +/** Offset 0x0863 - Reserved +**/ + UINT8 Reserved313[14]; + +/** Offset 0x0871 - ClkReq-to-ClkSrc mapping + Number of ClkReq signal assigned to ClkSrc +**/ + UINT8 PcieClkSrcClkReq[18]; + +/** Offset 0x0883 - Reserved +**/ + UINT8 Reserved314[14]; + +/** Offset 0x0891 - Reserved +**/ + UINT8 Reserved315[3]; + +/** Offset 0x0894 - Reserved +**/ + UINT32 Reserved316[8]; + +/** Offset 0x08B4 - Reserved +**/ + UINT32 Reserved317; + +/** Offset 0x08B8 - Enable PCIE RP Mask + Enable/disable PCIE Root Ports. 0: disable, 1: enable. One bit for each port, bit0 + for port1, bit1 for port2, and so on. +**/ + UINT32 PcieRpEnableMask; + +/** Offset 0x08BC - Reserved +**/ + UINT8 Reserved318; + +/** Offset 0x08BD - Reserved +**/ + UINT8 Reserved319; + +/** Offset 0x08BE - Enable HD Audio Link + Enable/disable HD Audio Link. Muxed with SSP0/SSP1/SNDW1. + $EN_DIS +**/ + UINT8 PchHdaAudioLinkHdaEnable; + +/** Offset 0x08BF - Reserved +**/ + UINT8 Reserved320[2]; + +/** Offset 0x08C1 - Reserved +**/ + UINT8 Reserved321; + +/** Offset 0x08C2 - Enable HD Audio DMIC_N Link + Enable/disable HD Audio DMIC1 link. Muxed with SNDW3. +**/ + UINT8 PchHdaAudioLinkDmicEnable[2]; + +/** Offset 0x08C4 - DMIC ClkA Pin Muxing (N - DMIC number) + Determines DMIC ClkA Pin muxing. See GPIO_*_MUXING_DMIC_CLKA_* +**/ + UINT32 PchHdaAudioLinkDmicClkAPinMux[2]; + +/** Offset 0x08CC - DMIC ClkB Pin Muxing + Determines DMIC ClkA Pin muxing. See GPIO_*_MUXING_DMIC_CLKB_* +**/ + UINT32 PchHdaAudioLinkDmicClkBPinMux[2]; + +/** Offset 0x08D4 - Enable HD Audio DSP + Enable/disable HD Audio DSP feature. + $EN_DIS +**/ + UINT8 PchHdaDspEnable; + +/** Offset 0x08D5 - Reserved +**/ + UINT8 Reserved322[3]; + +/** Offset 0x08D8 - DMIC Data Pin Muxing + Determines DMIC Data Pin muxing. See GPIO_*_MUXING_DMIC_DATA_* +**/ + UINT32 PchHdaAudioLinkDmicDataPinMux[2]; + +/** Offset 0x08E0 - Enable HD Audio SSP0 Link + Enable/disable HD Audio SSP_N/I2S link. Muxed with HDA. N-number 0-5 +**/ + UINT8 PchHdaAudioLinkSspEnable[6]; + +/** Offset 0x08E6 - Enable HD Audio SoundWire#N Link + Enable/disable HD Audio SNDW#N link. Muxed with HDA. +**/ + UINT8 PchHdaAudioLinkSndwEnable[4]; + +/** Offset 0x08EA - iDisp-Link Frequency + iDisp-Link Freq (PCH_HDAUDIO_LINK_FREQUENCY enum): 4: 96MHz, 3: 48MHz. + 4: 96MHz, 3: 48MHz +**/ + UINT8 PchHdaIDispLinkFrequency; + +/** Offset 0x08EB - iDisp-Link T-mode + iDisp-Link T-Mode (PCH_HDAUDIO_IDISP_TMODE enum): 0: 2T, 2: 4T, 3: 8T, 4: 16T + 0: 2T, 2: 4T, 3: 8T, 4: 16T +**/ + UINT8 PchHdaIDispLinkTmode; + +/** Offset 0x08EC - iDisplay Audio Codec disconnection + 0: Not disconnected, enumerable, 1: Disconnected SDI, not enumerable. + $EN_DIS +**/ + UINT8 PchHdaIDispCodecDisconnect; + +/** Offset 0x08ED - Reserved +**/ + UINT8 Reserved323[3]; + +/** Offset 0x08F0 - Reserved +**/ + UINT32 Reserved324; + +/** Offset 0x08F4 - CNVi DDR RFI Mitigation + Enable/Disable DDR RFI Mitigation. Default is ENABLE. 0: DISABLE, 1: ENABLE + $EN_DIS +**/ + UINT8 CnviDdrRfim; + +/** Offset 0x08F5 - Reserved +**/ + UINT8 Reserved325; + +/** Offset 0x08F6 - Reserved +**/ + UINT8 Reserved326; + +/** Offset 0x08F7 - Reserved +**/ + UINT8 Reserved327; + +/** Offset 0x08F8 - Reserved +**/ + UINT32 Reserved328; + +/** Offset 0x08FC - Reserved +**/ + UINT32 Reserved329; + +/** Offset 0x0900 - Debug Interfaces + Debug Interfaces. BIT0-RAM, BIT1-UART, BIT3-USB3, BIT4-Serial IO, BIT5-TraceHub, + BIT2 - Not used. +**/ + UINT8 PcdDebugInterfaceFlags; + +/** Offset 0x0901 - Serial Io Uart Debug Controller Number + Select SerialIo Uart Controller for debug. + 0:SerialIoUart0, 1:SerialIoUart1, 2:SerialIoUart2 +**/ + UINT8 SerialIoUartDebugControllerNumber; + +/** Offset 0x0902 - Reserved +**/ + UINT8 Reserved330; + +/** Offset 0x0903 - Reserved +**/ + UINT8 Reserved331; + +/** Offset 0x0904 - Reserved +**/ + UINT32 Reserved332; + +/** Offset 0x0908 - Reserved +**/ + UINT8 Reserved333; + +/** Offset 0x0909 - Reserved +**/ + UINT8 Reserved334; + +/** Offset 0x090A - Reserved +**/ + UINT8 Reserved335; + +/** Offset 0x090B - Reserved +**/ + UINT8 Reserved336; + +/** Offset 0x090C - Reserved +**/ + UINT32 Reserved337; + +/** Offset 0x0910 - ISA Serial Base selection + Select ISA Serial Base address. Default is 0x3F8. + 0:0x3F8, 1:0x2F8 +**/ + UINT8 PcdIsaSerialUartBase; + +/** Offset 0x0911 - Reserved +**/ + UINT8 Reserved338; + +/** Offset 0x0912 - Reserved +**/ + UINT8 Reserved339; + +/** Offset 0x0913 - Reserved +**/ + UINT8 Reserved340; + +/** Offset 0x0914 - Reserved +**/ + UINT8 Reserved341; + +/** Offset 0x0915 - TCSS Thunderbolt PCIE Root Port 0 Enable + Set TCSS Thunderbolt PCIE Root Port 0. 0:Disabled 1:Enabled + $EN_DIS +**/ + UINT8 TcssItbtPcie0En; + +/** Offset 0x0916 - TCSS Thunderbolt PCIE Root Port 1 Enable + Set TCSS Thunderbolt PCIE Root Port 1. 0:Disabled 1:Enabled + $EN_DIS +**/ + UINT8 TcssItbtPcie1En; + +/** Offset 0x0917 - TCSS Thunderbolt PCIE Root Port 2 Enable + Set TCSS Thunderbolt PCIE Root Port 2. 0:Disabled 1:Enabled + $EN_DIS +**/ + UINT8 TcssItbtPcie2En; + +/** Offset 0x0918 - TCSS Thunderbolt PCIE Root Port 3 Enable + Set TCSS Thunderbolt PCIE Root Port 3. 0:Disabled 1:Enabled + $EN_DIS +**/ + UINT8 TcssItbtPcie3En; + +/** Offset 0x0919 - TCSS USB HOST (xHCI) Enable + Set TCSS XHCI. 0:Disabled 1:Enabled - Must be enabled if xDCI is enabled below + $EN_DIS +**/ + UINT8 TcssXhciEn; + +/** Offset 0x091A - TCSS USB DEVICE (xDCI) Enable + Set TCSS XDCI. 0:Disabled 1:Enabled - xHCI must be enabled if xDCI is enabled + $EN_DIS +**/ + UINT8 TcssXdciEn; + +/** Offset 0x091B - TCSS DMA0 Enable + Set TCSS DMA0. 0:Disabled 1:Enabled + $EN_DIS +**/ + UINT8 TcssDma0En; + +/** Offset 0x091C - TCSS DMA1 Enable + Set TCSS DMA1. 0:Disabled 1:Enabled + $EN_DIS +**/ + UINT8 TcssDma1En; + +/** Offset 0x091D - Reserved +**/ + UINT8 Reserved342; + +/** Offset 0x091E - Reserved +**/ + UINT8 Reserved343; + +/** Offset 0x091F - Early Command Training + Enables/Disable Early Command Training + $EN_DIS +**/ + UINT8 ECT; + +/** Offset 0x0920 - Reserved +**/ + UINT8 Reserved344; + +/** Offset 0x0921 - Reserved +**/ + UINT8 Reserved345; + +/** Offset 0x0922 - Reserved +**/ + UINT8 Reserved346; + +/** Offset 0x0923 - Reserved +**/ + UINT8 Reserved347; + +/** Offset 0x0924 - Reserved +**/ + UINT8 Reserved348; + +/** Offset 0x0925 - Reserved +**/ + UINT8 Reserved349; + +/** Offset 0x0926 - Reserved +**/ + UINT8 Reserved350; + +/** Offset 0x0927 - Reserved +**/ + UINT8 Reserved351; + +/** Offset 0x0928 - Reserved +**/ + UINT8 Reserved352; + +/** Offset 0x0929 - Reserved +**/ + UINT8 Reserved353; + +/** Offset 0x092A - Reserved +**/ + UINT8 Reserved354; + +/** Offset 0x092B - Reserved +**/ + UINT8 Reserved355; + +/** Offset 0x092C - Reserved +**/ + UINT8 Reserved356; + +/** Offset 0x092D - Reserved +**/ + UINT8 Reserved357; + +/** Offset 0x092E - Reserved +**/ + UINT8 Reserved358; + +/** Offset 0x092F - Reserved +**/ + UINT8 Reserved359; + +/** Offset 0x0930 - Reserved +**/ + UINT8 Reserved360; + +/** Offset 0x0931 - Reserved +**/ + UINT8 Reserved361; + +/** Offset 0x0932 - Reserved +**/ + UINT8 Reserved362; + +/** Offset 0x0933 - Reserved +**/ + UINT8 Reserved363; + +/** Offset 0x0934 - Reserved +**/ + UINT8 Reserved364; + +/** Offset 0x0935 - Reserved +**/ + UINT8 Reserved365; + +/** Offset 0x0936 - Late Command Training + Enables/Disable Late Command Training + $EN_DIS +**/ + UINT8 LCT; + +/** Offset 0x0937 - Reserved +**/ + UINT8 Reserved366; + +/** Offset 0x0938 - Rank Margin Tool + Enable/disable Rank Margin Tool + $EN_DIS +**/ + UINT8 RMT; + +/** Offset 0x0939 - Reserved +**/ + UINT8 Reserved367; + +/** Offset 0x093A - Reserved +**/ + UINT8 Reserved368; + +/** Offset 0x093B - Reserved +**/ + UINT8 Reserved369; + +/** Offset 0x093C - Reserved +**/ + UINT8 Reserved370; + +/** Offset 0x093D - Reserved +**/ + UINT8 Reserved371; + +/** Offset 0x093E - Reserved +**/ + UINT8 Reserved372; + +/** Offset 0x093F - Reserved +**/ + UINT8 Reserved373; + +/** Offset 0x0940 - Reserved +**/ + UINT8 Reserved374; + +/** Offset 0x0941 - Reserved +**/ + UINT8 Reserved375; + +/** Offset 0x0942 - Reserved +**/ + UINT8 Reserved376; + +/** Offset 0x0943 - Reserved +**/ + UINT8 Reserved377; + +/** Offset 0x0944 - Reserved +**/ + UINT8 Reserved378; + +/** Offset 0x0945 - Reserved +**/ + UINT8 Reserved379; + +/** Offset 0x0946 - Reserved +**/ + UINT8 Reserved380; + +/** Offset 0x0947 - Reserved +**/ + UINT8 Reserved381; + +/** Offset 0x0948 - Reserved +**/ + UINT8 Reserved382; + +/** Offset 0x0949 - Reserved +**/ + UINT8 Reserved383; + +/** Offset 0x094A - Reserved +**/ + UINT8 Reserved384; + +/** Offset 0x094B - Reserved +**/ + UINT8 Reserved385; + +/** Offset 0x094C - Reserved +**/ + UINT8 Reserved386; + +/** Offset 0x094D - Reserved +**/ + UINT8 Reserved387; + +/** Offset 0x094E - Reserved +**/ + UINT8 Reserved388; + +/** Offset 0x094F - Reserved +**/ + UINT8 Reserved389; + +/** Offset 0x0950 - Reserved +**/ + UINT8 Reserved390; + +/** Offset 0x0951 - Reserved +**/ + UINT8 Reserved391; + +/** Offset 0x0952 - Reserved +**/ + UINT8 Reserved392; + +/** Offset 0x0953 - Reserved +**/ + UINT8 Reserved393; + +/** Offset 0x0954 - Reserved +**/ + UINT8 Reserved394; + +/** Offset 0x0955 - Reserved +**/ + UINT8 Reserved395; + +/** Offset 0x0956 - Reserved +**/ + UINT8 Reserved396; + +/** Offset 0x0957 - Reserved +**/ + UINT8 Reserved397; + +/** Offset 0x0958 - Reserved +**/ + UINT8 Reserved398; + +/** Offset 0x0959 - Reserved +**/ + UINT8 Reserved399; + +/** Offset 0x095A - Reserved +**/ + UINT8 Reserved400; + +/** Offset 0x095B - Reserved +**/ + UINT8 Reserved401; + +/** Offset 0x095C - Reserved +**/ + UINT8 Reserved402; + +/** Offset 0x095D - Reserved +**/ + UINT8 Reserved403; + +/** Offset 0x095E - Reserved +**/ + UINT8 Reserved404; + +/** Offset 0x095F - Reserved +**/ + UINT8 Reserved405; + +/** Offset 0x0960 - Reserved +**/ + UINT8 Reserved406; + +/** Offset 0x0961 - IbeccParity + In-Band ECC Parity Control + $EN_DIS +**/ + UINT8 IbeccParity; + +/** Offset 0x0962 - IbeccOperationMode + In-Band ECC Operation Mode + 0:Protect base on address range, 1: Non-protected, 2: All protected +**/ + UINT8 IbeccOperationMode; + +/** Offset 0x0963 - IbeccProtectedRegionEnable + In-Band ECC Protected Region Enable + $EN_DIS +**/ + UINT8 IbeccProtectedRegionEnable[8]; + +/** Offset 0x096B - Reserved +**/ + UINT8 Reserved407[1]; + +/** Offset 0x096C - IbeccProtectedRegionBases + IBECC Protected Region Bases per IBECC instance +**/ + UINT16 IbeccProtectedRegionBase[8]; + +/** Offset 0x097C - IbeccProtectedRegionMasks + IBECC Protected Region Masks +**/ + UINT16 IbeccProtectedRegionMask[8]; + +/** Offset 0x098C - IbeccProtectedRegionOverallBases + IBECC Protected Region Bases based on enabled IBECC instance +**/ + UINT16 IbeccProtectedRegionOverallBase[8]; + +/** Offset 0x099C - Reserved +**/ + UINT8 Reserved408; + +/** Offset 0x099D - Reserved +**/ + UINT8 Reserved409; + +/** Offset 0x099E - Reserved +**/ + UINT8 Reserved410; + +/** Offset 0x099F - Reserved +**/ + UINT8 Reserved411; + +/** Offset 0x09A0 - Reserved +**/ + UINT8 Reserved412; + +/** Offset 0x09A1 - Reserved +**/ + UINT8 Reserved413; + +/** Offset 0x09A2 - Reserved +**/ + UINT8 Reserved414; + +/** Offset 0x09A3 - Reserved +**/ + UINT8 Reserved415; + +/** Offset 0x09A4 - Reserved +**/ + UINT8 Reserved416; + +/** Offset 0x09A5 - Reserved +**/ + UINT8 Reserved417; + +/** Offset 0x09A6 - Reserved +**/ + UINT8 Reserved418; + +/** Offset 0x09A7 - Reserved +**/ + UINT8 Reserved419; + +/** Offset 0x09A8 - Reserved +**/ + UINT8 Reserved420; + +/** Offset 0x09A9 - Reserved +**/ + UINT8 Reserved421; + +/** Offset 0x09AA - Reserved +**/ + UINT8 Reserved422; + +/** Offset 0x09AB - Reserved +**/ + UINT8 Reserved423; + +/** Offset 0x09AC - Reserved +**/ + UINT8 Reserved424; + +/** Offset 0x09AD - Reserved +**/ + UINT8 Reserved425; + +/** Offset 0x09AE - Ch Hash Mask + Set the BIT(s) to be included in the XOR function. NOTE BIT mask corresponds to + BITS [19:6] Default is 0x30CC +**/ + UINT16 ChHashMask; + +/** Offset 0x09B0 - Reserved +**/ + UINT32 Reserved426; + +/** Offset 0x09B4 - Reserved +**/ + UINT16 Reserved427; + +/** Offset 0x09B6 - Reserved +**/ + UINT16 Reserved428; + +/** Offset 0x09B8 - Reserved +**/ + UINT8 Reserved429; + +/** Offset 0x09B9 - Reserved +**/ + UINT8 Reserved430; + +/** Offset 0x09BA - Reserved +**/ + UINT8 Reserved431; + +/** Offset 0x09BB - Reserved +**/ + UINT8 Reserved432; + +/** Offset 0x09BC - Reserved +**/ + UINT8 Reserved433; + +/** Offset 0x09BD - Reserved +**/ + UINT8 Reserved434; + +/** Offset 0x09BE - Reserved +**/ + UINT8 Reserved435; + +/** Offset 0x09BF - Reserved +**/ + UINT8 Reserved436; + +/** Offset 0x09C0 - Reserved +**/ + UINT8 Reserved437; + +/** Offset 0x09C1 - Reserved +**/ + UINT8 Reserved438; + +/** Offset 0x09C2 - Reserved +**/ + UINT8 Reserved439; + +/** Offset 0x09C3 - Reserved +**/ + UINT8 Reserved440; + +/** Offset 0x09C4 - Reserved +**/ + UINT8 Reserved441; + +/** Offset 0x09C5 - Reserved +**/ + UINT8 Reserved442; + +/** Offset 0x09C6 - Reserved +**/ + UINT8 Reserved443; + +/** Offset 0x09C7 - Reserved +**/ + UINT8 Reserved444; + +/** Offset 0x09C8 - Reserved +**/ + UINT8 Reserved445; + +/** Offset 0x09C9 - Reserved +**/ + UINT8 Reserved446; + +/** Offset 0x09CA - Reserved +**/ + UINT8 Reserved447; + +/** Offset 0x09CB - Reserved +**/ + UINT8 Reserved448; + +/** Offset 0x09CC - Reserved +**/ + UINT8 Reserved449; + +/** Offset 0x09CD - Reserved +**/ + UINT8 Reserved450; + +/** Offset 0x09CE - Reserved +**/ + UINT8 Reserved451; + +/** Offset 0x09CF - Reserved +**/ + UINT8 Reserved452; + +/** Offset 0x09D0 - Reserved +**/ + UINT8 Reserved453; + +/** Offset 0x09D1 - Reserved +**/ + UINT8 Reserved454; + +/** Offset 0x09D2 - Reserved +**/ + UINT8 Reserved455; + +/** Offset 0x09D3 - Reserved +**/ + UINT8 Reserved456; + +/** Offset 0x09D4 - Reserved +**/ + UINT8 Reserved457; + +/** Offset 0x09D5 - Reserved +**/ + UINT8 Reserved458; + +/** Offset 0x09D6 - Reserved +**/ + UINT8 Reserved459; + +/** Offset 0x09D7 - Reserved +**/ + UINT8 Reserved460; + +/** Offset 0x09D8 - Reserved +**/ + UINT8 Reserved461; + +/** Offset 0x09D9 - Reserved +**/ + UINT8 Reserved462; + +/** Offset 0x09DA - Reserved +**/ + UINT8 Reserved463; + +/** Offset 0x09DB - Reserved +**/ + UINT8 Reserved464; + +/** Offset 0x09DC - Reserved +**/ + UINT8 Reserved465; + +/** Offset 0x09DD - Reserved +**/ + UINT8 Reserved466; + +/** Offset 0x09DE - Reserved +**/ + UINT8 Reserved467; + +/** Offset 0x09DF - Reserved +**/ + UINT8 Reserved468; + +/** Offset 0x09E0 - Reserved +**/ + UINT8 Reserved469; + +/** Offset 0x09E1 - Reserved +**/ + UINT8 Reserved470; + +/** Offset 0x09E2 - Reserved +**/ + UINT8 Reserved471; + +/** Offset 0x09E3 - Reserved +**/ + UINT8 Reserved472; + +/** Offset 0x09E4 - Reserved +**/ + UINT8 Reserved473; + +/** Offset 0x09E5 - Reserved +**/ + UINT8 Reserved474; + +/** Offset 0x09E6 - Reserved +**/ + UINT8 Reserved475; + +/** Offset 0x09E7 - Reserved +**/ + UINT8 Reserved476; + +/** Offset 0x09E8 - Reserved +**/ + UINT8 Reserved477; + +/** Offset 0x09E9 - Reserved +**/ + UINT8 Reserved478; + +/** Offset 0x09EA - Reserved +**/ + UINT8 Reserved479; + +/** Offset 0x09EB - Reserved +**/ + UINT8 Reserved480; + +/** Offset 0x09EC - Reserved +**/ + UINT8 Reserved481; + +/** Offset 0x09ED - Reserved +**/ + UINT8 Reserved482; + +/** Offset 0x09EE - Reserved +**/ + UINT8 Reserved483; + +/** Offset 0x09EF - Reserved +**/ + UINT8 Reserved484; + +/** Offset 0x09F0 - Reserved +**/ + UINT8 Reserved485; + +/** Offset 0x09F1 - PcdSerialDebugLevel + Serial Debug Message Level. 0:Disable, 1:Error Only, 2:Error & Warnings, 3:Load, + Error, Warnings & Info, 4:Load, Error, Warnings, Info & Event, 5:Load, Error, Warnings, + Info & Verbose. + 0:Disable, 1:Error Only, 2:Error and Warnings, 3:Load Error Warnings and Info, 4:Load + Error Warnings and Info & Event, 5:Load Error Warnings Info and Verbose +**/ + UINT8 PcdSerialDebugLevel; + +/** Offset 0x09F2 - Reserved +**/ + UINT8 Reserved486; + +/** Offset 0x09F3 - Reserved +**/ + UINT8 Reserved487; + +/** Offset 0x09F4 - Reserved +**/ + UINT16 Reserved488; + +/** Offset 0x09F6 - Reserved +**/ + UINT16 Reserved489; + +/** Offset 0x09F8 - Reserved +**/ + UINT8 Reserved490; + +/** Offset 0x09F9 - Reserved +**/ + UINT8 Reserved491; + +/** Offset 0x09FA - TCSS USB Port Enable + Bitmap for per port enabling +**/ + UINT8 UsbTcPortEnPreMem; + +/** Offset 0x09FB - Reserved +**/ + UINT8 Reserved492; + +/** Offset 0x09FC - Reserved +**/ + UINT16 Reserved493; + +/** Offset 0x09FE - Reserved +**/ + UINT8 Reserved494; + +/** Offset 0x09FF - Reserved +**/ + UINT8 Reserved495; + +/** Offset 0x0A00 - Reserved +**/ + UINT32 Reserved496[4]; + +/** Offset 0x0A10 - Reserved +**/ + UINT16 Reserved497; + +/** Offset 0x0A12 - Reserved +**/ + UINT8 Reserved498; + +/** Offset 0x0A13 - Reserved +**/ + UINT8 Reserved499; + +/** Offset 0x0A14 - Reserved +**/ + UINT8 Reserved500; + +/** Offset 0x0A15 - Reserved +**/ + UINT8 Reserved501; + +/** Offset 0x0A16 - Reserved +**/ + UINT8 Reserved502; + +/** Offset 0x0A17 - Reserved +**/ + UINT8 Reserved503; + +/** Offset 0x0A18 - Reserved +**/ + UINT16 Reserved504; + +/** Offset 0x0A1A - Reserved +**/ + UINT16 Reserved505; + +/** Offset 0x0A1C - Reserved +**/ + UINT16 Reserved506; + +/** Offset 0x0A1E - Reserved +**/ + UINT8 Reserved507; + +/** Offset 0x0A1F - Reserved +**/ + UINT8 Reserved508; + +/** Offset 0x0A20 - Reserved +**/ + UINT8 Reserved509; + +/** Offset 0x0A21 - Reserved +**/ + UINT8 Reserved510; + +/** Offset 0x0A22 - Reserved +**/ + UINT8 Reserved511; + +/** Offset 0x0A23 - Reserved +**/ + UINT8 Reserved512[4]; + +/** Offset 0x0A27 - Skip external display device scanning + Enable: Do not scan for external display device, Disable (Default): Scan external + display devices + $EN_DIS +**/ + UINT8 SkipExtGfxScan; + +/** Offset 0x0A28 - Reserved +**/ + UINT8 Reserved513; + +/** Offset 0x0A29 - Lock PCU Thermal Management registers + Lock PCU Thermal Management registers. Enable(Default)=1, Disable=0 + $EN_DIS +**/ + UINT8 LockPTMregs; + +/** Offset 0x0A2A - Reserved +**/ + UINT8 Reserved514; + +/** Offset 0x0A2B - Reserved +**/ + UINT8 Reserved515; + +/** Offset 0x0A2C - Reserved +**/ + UINT32 Reserved516; + +/** Offset 0x0A30 - Reserved +**/ + UINT8 Reserved517; + +/** Offset 0x0A31 - Reserved +**/ + UINT8 Reserved518; + +/** Offset 0x0A32 - Reserved +**/ + UINT16 Reserved519; + +/** Offset 0x0A34 - Reserved +**/ + UINT16 Reserved520; + +/** Offset 0x0A36 - Reserved +**/ + UINT8 Reserved521[89]; + +/** Offset 0x0A8F - Reserved +**/ + UINT8 Reserved522; + +/** Offset 0x0A90 - Reserved +**/ + UINT16 Reserved523; + +/** Offset 0x0A92 - Reserved +**/ + UINT16 Reserved524; + +/** Offset 0x0A94 - Reserved +**/ + UINT8 Reserved525[12]; + +/** Offset 0x0AA0 - Smbus dynamic power gating + Disable or Enable Smbus dynamic power gating. + $EN_DIS +**/ + UINT8 SmbusDynamicPowerGating; + +/** Offset 0x0AA1 - Disable and Lock Watch Dog Register + Set 1 to clear WDT status, then disable and lock WDT registers. + $EN_DIS +**/ + UINT8 WdtDisableAndLock; + +/** Offset 0x0AA2 - Reserved +**/ + UINT8 Reserved526; + +/** Offset 0x0AA3 - Reserved +**/ + UINT8 Reserved527; + +/** Offset 0x0AA4 - Reserved +**/ + UINT8 Reserved528; + +/** Offset 0x0AA5 - Reserved +**/ + UINT8 Reserved529; + +/** Offset 0x0AA6 - Reserved +**/ + UINT8 Reserved530; + +/** Offset 0x0AA7 - Reserved +**/ + UINT8 Reserved531; + +/** Offset 0x0AA8 - Reserved +**/ + UINT8 Reserved532; + +/** Offset 0x0AA9 - Reserved +**/ + UINT8 Reserved533; + +/** Offset 0x0AAA - Skip CPU replacement check + Test, 0: disable, 1: enable, Setting this option to skip CPU replacement check + $EN_DIS +**/ + UINT8 SkipCpuReplacementCheck; + +/** Offset 0x0AAB - Reserved +**/ + UINT8 Reserved534; + +/** Offset 0x0AAC - Reserved +**/ + UINT8 Reserved535; + +/** Offset 0x0AAD - Serial Io Uart Debug Mode + Select SerialIo Uart Controller mode + 0:SerialIoUartDisabled, 1:SerialIoUartPci, 2:SerialIoUartHidden, 3:SerialIoUartCom, + 4:SerialIoUartSkipInit +**/ + UINT8 SerialIoUartDebugMode; + +/** Offset 0x0AAE - Reserved +**/ + UINT8 Reserved536[2]; + +/** Offset 0x0AB0 - Reserved +**/ + UINT32 Reserved537; + +/** Offset 0x0AB4 - Reserved +**/ + UINT32 Reserved538; + +/** Offset 0x0AB8 - Reserved +**/ + UINT32 Reserved539; + +/** Offset 0x0ABC - Reserved +**/ + UINT32 Reserved540; + +/** Offset 0x0AC0 - Reserved +**/ + UINT32 Reserved541; + +/** Offset 0x0AC4 - Reserved +**/ + UINT8 Reserved542[8]; + +/** Offset 0x0ACC - Reserved +**/ + UINT8 Reserved543[7]; + +/** Offset 0x0AD3 - Reserved +**/ + UINT8 Reserved544[5]; +} FSP_M_CONFIG; + +/** Fsp M UPD Configuration +**/ +typedef struct { + +/** Offset 0x0000 +**/ + FSP_UPD_HEADER FspUpdHeader; + +/** Offset 0x0020 +**/ + FSPM_ARCH_UPD FspmArchUpd; + +/** Offset 0x0040 +**/ + FSP_M_CONFIG FspmConfig; + +/** Offset 0x0AD8 +**/ + UINT8 UnusedUpdSpace35[6]; + +/** Offset 0x0ADE +**/ + UINT16 UpdTerminator; +} FSPM_UPD; + +#pragma pack() + +#endif diff --git a/src/vendorcode/intel/fsp/fsp2_0/meteorlake/FspsUpd.h b/src/vendorcode/intel/fsp/fsp2_0/meteorlake/FspsUpd.h new file mode 100644 index 0000000000..2fa44f3193 --- /dev/null +++ b/src/vendorcode/intel/fsp/fsp2_0/meteorlake/FspsUpd.h @@ -0,0 +1,3306 @@ +/** @file + +Copyright (c) 2022, 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 __FSPSUPD_H__ +#define __FSPSUPD_H__ + +#include + +#pragma pack(1) + + +/// +/// Azalia Header structure +/// +typedef struct { + UINT16 VendorId; ///< Codec Vendor ID + UINT16 DeviceId; ///< Codec Device ID + UINT8 RevisionId; ///< Revision ID of the codec. 0xFF matches any revision. + UINT8 SdiNum; ///< SDI number, 0xFF matches any SDI. + UINT16 DataDwords; ///< Number of data DWORDs pointed by the codec data buffer. + UINT32 Reserved; ///< Reserved for future use. Must be set to 0. +} AZALIA_HEADER; + +/// +/// Audio Azalia Verb Table structure +/// +typedef struct { + AZALIA_HEADER Header; ///< AZALIA PCH header + UINT32 *Data; ///< Pointer to the data buffer. Its length is specified in the header +} AUDIO_AZALIA_VERB_TABLE; + +/// +/// Refer to the definition of PCH_INT_PIN +/// +typedef enum { + SiPchNoInt, ///< No Interrupt Pin + SiPchIntA, + SiPchIntB, + SiPchIntC, + SiPchIntD +} SI_PCH_INT_PIN; +/// +/// The PCH_DEVICE_INTERRUPT_CONFIG block describes interrupt pin, IRQ and interrupt mode for PCH device. +/// +typedef struct { + UINT8 Device; ///< Device number + UINT8 Function; ///< Device function + UINT8 IntX; ///< Interrupt pin: INTA-INTD (see SI_PCH_INT_PIN) + UINT8 Irq; ///< IRQ to be set for device. +} SI_PCH_DEVICE_INTERRUPT_CONFIG; + +#define SI_PCH_MAX_DEVICE_INTERRUPT_CONFIG 64 ///< Number of all PCH devices + + +/** Fsp S Configuration +**/ +typedef struct { + +/** Offset 0x0040 - Reserved +**/ + UINT32 Reserved0; + +/** Offset 0x0044 - Reserved +**/ + UINT32 Reserved1; + +/** Offset 0x0048 - Reserved +**/ + UINT32 Reserved2; + +/** Offset 0x004C - Reserved +**/ + UINT32 Reserved3; + +/** Offset 0x0050 - Graphics Configuration Ptr + Points to VBT +**/ + UINT32 GraphicsConfigPtr; + +/** Offset 0x0054 - Enable Device 4 + Enable/disable Device 4 + $EN_DIS +**/ + UINT8 Device4Enable; + +/** Offset 0x0055 - Reserved +**/ + UINT8 Reserved4; + +/** Offset 0x0056 - Reserved +**/ + UINT8 Reserved5[2]; + +/** Offset 0x0058 - MicrocodeRegionBase + Memory Base of Microcode Updates +**/ + UINT32 MicrocodeRegionBase; + +/** Offset 0x005C - MicrocodeRegionSize + Size of Microcode Updates +**/ + UINT32 MicrocodeRegionSize; + +/** Offset 0x0060 - Reserved +**/ + UINT8 Reserved6; + +/** Offset 0x0061 - Enable SATA SALP Support + Enable/disable SATA Aggressive Link Power Management. + $EN_DIS +**/ + UINT8 SataSalpSupport; + +/** Offset 0x0062 - Enable SATA ports + Enable/disable SATA ports. One byte for each port, byte0 for port0, byte1 for port1, + and so on. +**/ + UINT8 SataPortsEnable[8]; + +/** Offset 0x006A - Enable SATA DEVSLP Feature + Enable/disable SATA DEVSLP per port. 0 is disable, 1 is enable. One byte for each + port, byte0 for port0, byte1 for port1, and so on. +**/ + UINT8 SataPortsDevSlp[8]; + +/** Offset 0x0072 - Reserved +**/ + UINT8 Reserved7[2]; + +/** Offset 0x0074 - Reserved +**/ + UINT32 Reserved8[8]; + +/** Offset 0x0094 - Enable USB2 ports + Enable/disable per USB2 ports. One byte for each port, byte0 for port0, byte1 for + port1, and so on. +**/ + UINT8 PortUsb20Enable[16]; + +/** Offset 0x00A4 - Enable USB3 ports + Enable/disable per USB3 ports. One byte for each port, byte0 for port0, byte1 for + port1, and so on. +**/ + UINT8 PortUsb30Enable[10]; + +/** Offset 0x00AE - Enable xDCI controller + Enable/disable to xDCI controller. + $EN_DIS +**/ + UINT8 XdciEnable; + +/** Offset 0x00AF - Reserved +**/ + UINT8 Reserved9; + +/** Offset 0x00B0 - Reserved +**/ + UINT32 Reserved10; + +/** Offset 0x00B4 - Reserved +**/ + UINT8 Reserved11; + +/** Offset 0x00B5 - Reserved +**/ + UINT8 Reserved12[8]; + +/** Offset 0x00BD - Reserved +**/ + UINT8 Reserved13; + +/** Offset 0x00BE - Reserved +**/ + UINT8 Reserved14; + +/** Offset 0x00BF - Reserved +**/ + UINT8 Reserved15; + +/** Offset 0x00C0 - Reserved +**/ + UINT8 Reserved16; + +/** Offset 0x00C1 - Reserved +**/ + UINT8 Reserved17; + +/** Offset 0x00C2 - Reserved +**/ + UINT8 Reserved18[2]; + +/** Offset 0x00C4 - Reserved +**/ + UINT32 Reserved19; + +/** Offset 0x00C8 - Reserved +**/ + UINT8 Reserved20; + +/** Offset 0x00C9 - Enable SATA + Enable/disable SATA controller. + $EN_DIS +**/ + UINT8 SataEnable; + +/** Offset 0x00CA - SATA Mode + Select SATA controller working mode. + 0:AHCI, 1:RAID +**/ + UINT8 SataMode; + +/** Offset 0x00CB - SPIn Device Mode + Selects SPI operation mode. N represents controller index: SPI0, SPI1, ... Available + modes: 0:SerialIoSpiDisabled, 1:SerialIoSpiPci, 2:SerialIoSpiHidden +**/ + UINT8 SerialIoSpiMode[7]; + +/** Offset 0x00D2 - Reserved +**/ + UINT8 Reserved21[14]; + +/** Offset 0x00E0 - Reserved +**/ + UINT8 Reserved22[14]; + +/** Offset 0x00EE - Reserved +**/ + UINT8 Reserved23[7]; + +/** Offset 0x00F5 - SPIn Default Chip Select Mode HW/SW + Sets Default CS Mode Hardware or Software. N represents controller index: SPI0, + SPI1, ... Available options: 0:HW, 1:SW +**/ + UINT8 SerialIoSpiCsMode[7]; + +/** Offset 0x00FC - SPIn Default Chip Select State Low/High + Sets Default CS State Low or High. N represents controller index: SPI0, SPI1, ... + Available options: 0:Low, 1:High +**/ + UINT8 SerialIoSpiCsState[7]; + +/** Offset 0x0103 - Reserved +**/ + UINT8 Reserved24[1]; + +/** Offset 0x0104 - Reserved +**/ + UINT32 Reserved25[14]; + +/** Offset 0x013C - Reserved +**/ + UINT32 Reserved26[7]; + +/** Offset 0x0158 - Reserved +**/ + UINT32 Reserved27[7]; + +/** Offset 0x0174 - Reserved +**/ + UINT32 Reserved28[7]; + +/** Offset 0x0190 - UARTn Device Mode + Selects Uart operation mode. N represents controller index: Uart0, Uart1, ... Available + modes: 0:SerialIoUartDisabled, 1:SerialIoUartPci, 2:SerialIoUartHidden, 3:SerialIoUartCom, + 4:SerialIoUartSkipInit +**/ + UINT8 SerialIoUartMode[7]; + +/** Offset 0x0197 - Reserved +**/ + UINT8 Reserved29[1]; + +/** Offset 0x0198 - Reserved +**/ + UINT32 Reserved30[7]; + +/** Offset 0x01B4 - Reserved +**/ + UINT8 Reserved31[7]; + +/** Offset 0x01BB - Reserved +**/ + UINT8 Reserved32[7]; + +/** Offset 0x01C2 - Reserved +**/ + UINT8 Reserved33[7]; + +/** Offset 0x01C9 - Reserved +**/ + UINT8 Reserved34[7]; + +/** Offset 0x01D0 - Reserved +**/ + UINT8 Reserved35[7]; + +/** Offset 0x01D7 - Reserved +**/ + UINT8 Reserved36[7]; + +/** Offset 0x01DE - Reserved +**/ + UINT8 Reserved37[2]; + +/** Offset 0x01E0 - SerialIoUartRtsPinMuxPolicy + Select SerialIo Uart Rts pin muxing. Refer to GPIO_*_MUXING_SERIALIO_UARTx_RTS* + for possible values. +**/ + UINT32 SerialIoUartRtsPinMuxPolicy[7]; + +/** Offset 0x01FC - SerialIoUartCtsPinMuxPolicy + Select SerialIo Uart Cts pin muxing. Refer to GPIO_*_MUXING_SERIALIO_UARTx_CTS* + for possible values. +**/ + UINT32 SerialIoUartCtsPinMuxPolicy[7]; + +/** Offset 0x0218 - SerialIoUartRxPinMuxPolicy + Select SerialIo Uart Rx pin muxing. Refer to GPIO_*_MUXING_SERIALIO_UARTx_RX* for + possible values. +**/ + UINT32 SerialIoUartRxPinMuxPolicy[7]; + +/** Offset 0x0234 - SerialIoUartTxPinMuxPolicy + Select SerialIo Uart Tx pin muxing. Refer to GPIO_*_MUXING_SERIALIO_UARTx_TX* for + possible values. +**/ + UINT32 SerialIoUartTxPinMuxPolicy[7]; + +/** Offset 0x0250 - Reserved +**/ + UINT8 Reserved38[7]; + +/** Offset 0x0257 - I2Cn Device Mode + Selects I2c operation mode. N represents controller index: I2c0, I2c1, ... Available + modes: 0:SerialIoI2cDisabled, 1:SerialIoI2cPci, 2:SerialIoI2cHidden +**/ + UINT8 SerialIoI2cMode[8]; + +/** Offset 0x025F - Reserved +**/ + UINT8 Reserved39[1]; + +/** Offset 0x0260 - Serial IO I2C SDA Pin Muxing + Select SerialIo I2c Sda pin muxing. Refer to GPIO_*_MUXING_SERIALIO_I2Cx_SDA* for + possible values. +**/ + UINT32 PchSerialIoI2cSdaPinMux[8]; + +/** Offset 0x0280 - Serial IO I2C SCL Pin Muxing + Select SerialIo I2c Scl pin muxing. Refer to GPIO_*_MUXING_SERIALIO_I2Cx_SCL* for + possible values. +**/ + UINT32 PchSerialIoI2cSclPinMux[8]; + +/** Offset 0x02A0 - Reserved +**/ + UINT8 Reserved40[8]; + +/** Offset 0x02A8 - Reserved +**/ + UINT8 Reserved41[2]; + +/** Offset 0x02AA - Reserved +**/ + UINT8 Reserved42[2]; + +/** Offset 0x02AC - Reserved +**/ + UINT32 Reserved43[2]; + +/** Offset 0x02B4 - Reserved +**/ + UINT8 Reserved44[2]; + +/** Offset 0x02B6 - Reserved +**/ + UINT8 Reserved45[2]; + +/** Offset 0x02B8 - Reserved +**/ + UINT32 Reserved46[2]; + +/** Offset 0x02C0 - Reserved +**/ + UINT8 Reserved47[2]; + +/** Offset 0x02C2 - Reserved +**/ + UINT8 Reserved48[2]; + +/** Offset 0x02C4 - Reserved +**/ + UINT32 Reserved49[2]; + +/** Offset 0x02CC - Reserved +**/ + UINT8 Reserved50[2]; + +/** Offset 0x02CE - Reserved +**/ + UINT8 Reserved51[2]; + +/** Offset 0x02D0 - Reserved +**/ + UINT32 Reserved52[12]; + +/** Offset 0x0300 - Reserved +**/ + UINT32 Reserved53[3]; + +/** Offset 0x030C - Reserved +**/ + UINT32 Reserved54[3]; + +/** Offset 0x0318 - Reserved +**/ + UINT32 Reserved55[3]; + +/** Offset 0x0324 - Reserved +**/ + UINT32 Reserved56[3]; + +/** Offset 0x0330 - Reserved +**/ + UINT32 Reserved57[3]; + +/** Offset 0x033C - Reserved +**/ + UINT32 Reserved58[3]; + +/** Offset 0x0348 - Reserved +**/ + UINT32 Reserved59; + +/** Offset 0x034C - Reserved +**/ + UINT32 Reserved60; + +/** Offset 0x0350 - Reserved +**/ + UINT32 Reserved61[2]; + +/** Offset 0x0358 - Reserved +**/ + UINT32 Reserved62[2]; + +/** Offset 0x0360 - Reserved +**/ + UINT32 Reserved63[2]; + +/** Offset 0x0368 - Reserved +**/ + UINT32 Reserved64[4]; + +/** Offset 0x0378 - Reserved +**/ + UINT8 Reserved65[12]; + +/** Offset 0x0384 - Reserved +**/ + UINT8 Reserved66[3]; + +/** Offset 0x0387 - Reserved +**/ + UINT8 Reserved67[3]; + +/** Offset 0x038A - Reserved +**/ + UINT8 Reserved68[3]; + +/** Offset 0x038D - Reserved +**/ + UINT8 Reserved69[3]; + +/** Offset 0x0390 - Reserved +**/ + UINT8 Reserved70[3]; + +/** Offset 0x0393 - Reserved +**/ + UINT8 Reserved71; + +/** Offset 0x0394 - Reserved +**/ + UINT8 Reserved72[3]; + +/** Offset 0x0397 - Reserved +**/ + UINT8 Reserved73; + +/** Offset 0x0398 - Reserved +**/ + UINT8 Reserved74[2]; + +/** Offset 0x039A - Reserved +**/ + UINT8 Reserved75[2]; + +/** Offset 0x039C - Reserved +**/ + UINT8 Reserved76[2]; + +/** Offset 0x039E - Reserved +**/ + UINT8 Reserved77[4]; + +/** Offset 0x03A2 - Reserved +**/ + UINT8 Reserved78[4]; + +/** Offset 0x03A6 - USB Per Port HS Preemphasis Bias + USB Per Port HS Preemphasis Bias. 000b-0mV, 001b-11.25mV, 010b-16.9mV, 011b-28.15mV, + 100b-28.15mV, 101b-39.35mV, 110b-45mV, 111b-56.3mV. One byte for each port. +**/ + UINT8 Usb2PhyPetxiset[16]; + +/** Offset 0x03B6 - USB Per Port HS Transmitter Bias + USB Per Port HS Transmitter Bias. 000b-0mV, 001b-11.25mV, 010b-16.9mV, 011b-28.15mV, + 100b-28.15mV, 101b-39.35mV, 110b-45mV, 111b-56.3mV, One byte for each port. +**/ + UINT8 Usb2PhyTxiset[16]; + +/** Offset 0x03C6 - USB Per Port HS Transmitter Emphasis + USB Per Port HS Transmitter Emphasis. 00b - Emphasis OFF, 01b - De-emphasis ON, + 10b - Pre-emphasis ON, 11b - Pre-emphasis & De-emphasis ON. One byte for each port. +**/ + UINT8 Usb2PhyPredeemp[16]; + +/** Offset 0x03D6 - USB Per Port Half Bit Pre-emphasis + USB Per Port Half Bit Pre-emphasis. 1b - half-bit pre-emphasis, 0b - full-bit pre-emphasis. + One byte for each port. +**/ + UINT8 Usb2PhyPehalfbit[16]; + +/** Offset 0x03E6 - Enable the write to USB 3.0 TX Output -3.5dB De-Emphasis Adjustment + Enable the write to USB 3.0 TX Output -3.5dB De-Emphasis Adjustment. Each value + in arrary can be between 0-1. One byte for each port. +**/ + UINT8 Usb3HsioTxDeEmphEnable[10]; + +/** Offset 0x03F0 - USB 3.0 TX Output -3.5dB De-Emphasis Adjustment Setting + USB 3.0 TX Output -3.5dB De-Emphasis Adjustment Setting, HSIO_TX_DWORD5[21:16], + Default = 29h (approximately -3.5dB De-Emphasis). One byte for each port. +**/ + UINT8 Usb3HsioTxDeEmph[10]; + +/** Offset 0x03FA - Enable the write to USB 3.0 TX Output Downscale Amplitude Adjustment + Enable the write to USB 3.0 TX Output Downscale Amplitude Adjustment, Each value + in arrary can be between 0-1. One byte for each port. +**/ + UINT8 Usb3HsioTxDownscaleAmpEnable[10]; + +/** Offset 0x0404 - USB 3.0 TX Output Downscale Amplitude Adjustment + USB 3.0 TX Output Downscale Amplitude Adjustment, HSIO_TX_DWORD8[21:16], Default + = 00h. One byte for each port. +**/ + UINT8 Usb3HsioTxDownscaleAmp[10]; + +/** Offset 0x040E - Reserved +**/ + UINT8 Reserved79[10]; + +/** Offset 0x0418 - Reserved +**/ + UINT8 Reserved80[10]; + +/** Offset 0x0422 - Reserved +**/ + UINT8 Reserved81[10]; + +/** Offset 0x042C - Reserved +**/ + UINT8 Reserved82[10]; + +/** Offset 0x0436 - Reserved +**/ + UINT8 Reserved83[10]; + +/** Offset 0x0440 - Reserved +**/ + UINT8 Reserved84[10]; + +/** Offset 0x044A - Reserved +**/ + UINT8 Reserved85[10]; + +/** Offset 0x0454 - Reserved +**/ + UINT8 Reserved86[10]; + +/** Offset 0x045E - Enable LAN + Enable/disable LAN controller. + $EN_DIS +**/ + UINT8 PchLanEnable; + +/** Offset 0x045F - Reserved +**/ + UINT8 Reserved87; + +/** Offset 0x0460 - Reserved +**/ + UINT8 Reserved88; + +/** Offset 0x0461 - Reserved +**/ + UINT8 Reserved89[3]; + +/** Offset 0x0464 - Reserved +**/ + UINT32 Reserved90; + +/** Offset 0x0468 - Reserved +**/ + UINT32 Reserved91; + +/** Offset 0x046C - Reserved +**/ + UINT32 Reserved92; + +/** Offset 0x0470 - Reserved +**/ + UINT32 Reserved93; + +/** Offset 0x0474 - PCIe PTM enable/disable + Enable/disable Precision Time Measurement for PCIE Root Ports. +**/ + UINT8 PciePtm[28]; + +/** Offset 0x0490 - Reserved +**/ + UINT8 Reserved94[28]; + +/** Offset 0x04AC - Reserved +**/ + UINT8 Reserved95[28]; + +/** Offset 0x04C8 - Reserved +**/ + UINT8 Reserved96; + +/** Offset 0x04C9 - Reserved +**/ + UINT8 Reserved97[3]; + +/** Offset 0x04CC - Reserved +**/ + UINT32 Reserved98; + +/** Offset 0x04D0 - Reserved +**/ + UINT8 Reserved99; + +/** Offset 0x04D1 - Reserved +**/ + UINT8 Reserved100; + +/** Offset 0x04D2 - Reserved +**/ + UINT8 Reserved101; + +/** Offset 0x04D3 - Reserved +**/ + UINT8 Reserved102; + +/** Offset 0x04D4 - Reserved +**/ + UINT16 Reserved103; + +/** Offset 0x04D6 - Reserved +**/ + UINT8 Reserved104; + +/** Offset 0x04D7 - Reserved +**/ + UINT8 Reserved105; + +/** Offset 0x04D8 - Reserved +**/ + UINT8 Reserved106; + +/** Offset 0x04D9 - Reserved +**/ + UINT8 Reserved107; + +/** Offset 0x04DA - Reserved +**/ + UINT16 Reserved108; + +/** Offset 0x04DC - Reserved +**/ + UINT8 Reserved109; + +/** Offset 0x04DD - Reserved +**/ + UINT8 Reserved110; + +/** Offset 0x04DE - Reserved +**/ + UINT16 Reserved111; + +/** Offset 0x04E0 - Reserved +**/ + UINT8 Reserved112; + +/** Offset 0x04E1 - Transition time in microseconds from Low Current Mode Voltage to High Current Mode Voltage + This field has 1us resolution. When value is 0 PCH will not transition VCCIN_AUX + to low current mode voltage. +**/ + UINT8 PchFivrVccinAuxLowToHighCurModeVolTranTime; + +/** Offset 0x04E2 - Transition time in microseconds from 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 mode voltage. +**/ + UINT8 PchFivrVccinAuxRetToHighCurModeVolTranTime; + +/** Offset 0x04E3 - Reserved +**/ + UINT8 Reserved113; + +/** Offset 0x04E4 - Transition time in microseconds from Off (0V) to High Current Mode Voltage + This field has 1us resolution. When value is 0 Transition to 0V is disabled. +**/ + UINT16 PchFivrVccinAuxOffToHighCurModeVolTranTime; + +/** Offset 0x04E6 - Reserved +**/ + UINT8 Reserved114; + +/** Offset 0x04E7 - Reserved +**/ + UINT8 Reserved115; + +/** Offset 0x04E8 - Reserved +**/ + UINT32 Reserved116; + +/** Offset 0x04EC - Reserved +**/ + UINT32 Reserved117; + +/** Offset 0x04F0 - Reserved +**/ + UINT8 Reserved118; + +/** Offset 0x04F1 - Reserved +**/ + UINT8 Reserved119; + +/** Offset 0x04F2 - Reserved +**/ + UINT16 Reserved120; + +/** Offset 0x04F4 - Reserved +**/ + UINT16 Reserved121; + +/** Offset 0x04F6 - Reserved +**/ + UINT16 Reserved122; + +/** Offset 0x04F8 - Reserved +**/ + UINT8 Reserved123; + +/** Offset 0x04F9 - Reserved +**/ + UINT8 Reserved124; + +/** Offset 0x04FA - Reserved +**/ + UINT8 Reserved125[12]; + +/** Offset 0x0506 - CNVi Configuration + This option allows for automatic detection of Connectivity Solution. [Auto Detection] + assumes that CNVi will be enabled when available, [Disable] allows for disabling CNVi. + 0:Disable, 1:Auto +**/ + UINT8 CnviMode; + +/** Offset 0x0507 - Reserved +**/ + UINT8 Reserved126; + +/** Offset 0x0508 - CNVi BT Core + Enable/Disable CNVi BT Core, Default is ENABLE. 0: DISABLE, 1: ENABLE + $EN_DIS +**/ + UINT8 CnviBtCore; + +/** Offset 0x0509 - CNVi BT Audio Offload + Enable/Disable BT Audio Offload, Default is DISABLE. 0: DISABLE, 1: ENABLE + $EN_DIS +**/ + UINT8 CnviBtAudioOffload; + +/** Offset 0x050A - Reserved +**/ + UINT8 Reserved127[2]; + +/** Offset 0x050C - CNVi RF_RESET pin muxing + Select CNVi RF_RESET# pin depending on board routing. LP/P/M: GPP_A8 = 0x2942E408(default) + or GPP_F4 = 0x194CE404. H/S: 0. Refer to GPIO_*_MUXING_CNVI_RF_RESET_* in GpioPins*.h. +**/ + UINT32 CnviRfResetPinMux; + +/** Offset 0x0510 - CNVi CLKREQ pin muxing + Select CNVi CLKREQ pin depending on board routing. LP/P/M: GPP_A9 = 0x3942E609(default) + or GPP_F5 = 0x394CE605. H/S: 0. Refer to GPIO_*_MUXING_CNVI_CRF_XTAL_CLKREQ_* in + GpioPins*.h. +**/ + UINT32 CnviClkreqPinMux; + +/** Offset 0x0514 - Reserved +**/ + UINT8 Reserved128; + +/** Offset 0x0515 - Reserved +**/ + UINT8 Reserved129; + +/** Offset 0x0516 - Reserved +**/ + UINT8 Reserved130; + +/** Offset 0x0517 - Reserved +**/ + UINT8 Reserved131; + +/** Offset 0x0518 - Reserved +**/ + UINT8 Reserved132; + +/** Offset 0x0519 - Reserved +**/ + UINT8 Reserved133; + +/** Offset 0x051A - Reserved +**/ + UINT8 Reserved134[8]; + +/** Offset 0x0522 - Reserved +**/ + UINT8 Reserved135; + +/** Offset 0x0523 - Reserved +**/ + UINT8 Reserved136; + +/** Offset 0x0524 - Reserved +**/ + UINT8 Reserved137; + +/** Offset 0x0525 - Reserved +**/ + UINT8 Reserved138; + +/** Offset 0x0526 - Reserved +**/ + UINT8 Reserved139; + +/** Offset 0x0527 - Reserved +**/ + UINT8 Reserved140; + +/** Offset 0x0528 - Reserved +**/ + UINT8 Reserved141; + +/** Offset 0x0529 - Reserved +**/ + UINT8 Reserved142; + +/** Offset 0x052A - Reserved +**/ + UINT16 Reserved143; + +/** Offset 0x052C - Reserved +**/ + UINT16 Reserved144; + +/** Offset 0x052E - Reserved +**/ + UINT8 Reserved145; + +/** Offset 0x052F - Reserved +**/ + UINT8 Reserved146[28]; + +/** Offset 0x054B - Reserved +**/ + UINT8 Reserved147[28]; + +/** Offset 0x0567 - Reserved +**/ + UINT8 Reserved148[28]; + +/** Offset 0x0583 - Reserved +**/ + UINT8 Reserved149[1]; + +/** Offset 0x0584 - Reserved +**/ + UINT16 Reserved150[24]; + +/** Offset 0x05B4 - Reserved +**/ + UINT8 Reserved151; + +/** Offset 0x05B5 - Reserved +**/ + UINT8 Reserved152; + +/** Offset 0x05B6 - Reserved +**/ + UINT8 Reserved153; + +/** Offset 0x05B7 - Reserved +**/ + UINT8 Reserved154; + +/** Offset 0x05B8 - Enable/Disable PeiGraphicsPeimInit + Enable(Default): FSP will initialize the framebuffer and provide it via EFI_PEI_GRAPHICS_INFO_HOB. + Disable: FSP will NOT initialize the framebuffer. + $EN_DIS +**/ + UINT8 PeiGraphicsPeimInit; + +/** Offset 0x05B9 - Enable D3 Hot in TCSS + This policy will enable/disable D3 hot support in IOM + $EN_DIS +**/ + UINT8 D3HotEnable; + +/** Offset 0x05BA - Enable or disable GNA device + 0=Disable, 1(Default)=Enable + $EN_DIS +**/ + UINT8 GnaEnable; + +/** Offset 0x05BB - Reserved +**/ + UINT8 Reserved155[1]; + +/** Offset 0x05BC - TypeC port GPIO setting + GPIO Ping number for Type C Aux Oritation setting, use the GpioPad that is defined + in GpioPinsXXXH.h and GpioPinsXXXLp.h as argument.(XXX is platform name, Ex: Adl + = AlderLake) +**/ + UINT32 IomTypeCPortPadCfg[8]; + +/** Offset 0x05DC - CPU USB3 Port Over Current Pin + Describe the specific over current pin number of USBC Port N. +**/ + UINT8 CpuUsb3OverCurrentPin[8]; + +/** Offset 0x05E4 - Enable D3 Cold in TCSS + This policy will enable/disable D3 cold support in IOM + $EN_DIS +**/ + UINT8 D3ColdEnable; + +/** Offset 0x05E5 - Reserved +**/ + UINT8 Reserved156; + +/** Offset 0x05E6 - Reserved +**/ + UINT8 Reserved157; + +/** Offset 0x05E7 - Reserved +**/ + UINT8 Reserved158; + +/** Offset 0x05E8 - Reserved +**/ + UINT8 Reserved159; + +/** Offset 0x05E9 - Reserved +**/ + UINT8 Reserved160[3]; + +/** Offset 0x05EC - Reserved +**/ + UINT32 Reserved161; + +/** Offset 0x05F0 - Platform LID Status for LFP Displays. + LFP Display Lid Status (LID_STATUS enum): 0 (Default): LidClosed, 1: LidOpen. + 0: LidClosed, 1: LidOpen +**/ + UINT8 LidStatus; + +/** Offset 0x05F1 - Reserved +**/ + UINT8 Reserved162[8]; + +/** Offset 0x05F9 - Enable VMD controller + Enable/disable to VMD controller.0: Disable(Default); 1: Enable + $EN_DIS +**/ + UINT8 VmdEnable; + +/** Offset 0x05FA - Reserved +**/ + UINT8 Reserved163; + +/** Offset 0x05FB - Reserved +**/ + UINT8 Reserved164[31]; + +/** Offset 0x061A - Reserved +**/ + UINT8 Reserved165[31]; + +/** Offset 0x0639 - Reserved +**/ + UINT8 Reserved166[31]; + +/** Offset 0x0658 - Reserved +**/ + UINT8 Reserved167[31]; + +/** Offset 0x0677 - Reserved +**/ + UINT8 Reserved168; + +/** Offset 0x0678 - Reserved +**/ + UINT32 Reserved169; + +/** Offset 0x067C - Reserved +**/ + UINT32 Reserved170; + +/** Offset 0x0680 - Reserved +**/ + UINT32 Reserved171; + +/** Offset 0x0684 - Reserved +**/ + UINT32 Reserved172; + +/** Offset 0x0688 - Reserved +**/ + UINT8 Reserved173; + +/** Offset 0x0689 - Reserved +**/ + UINT8 Reserved174; + +/** Offset 0x068A - TCSS Aux Orientation Override Enable + Bits 0, 2, ... 10 control override enables, bits 1, 3, ... 11 control overrides +**/ + UINT16 TcssAuxOri; + +/** Offset 0x068C - TCSS HSL Orientation Override Enable + Bits 0, 2, ... 10 control override enables, bits 1, 3, ... 11 control overrides +**/ + UINT16 TcssHslOri; + +/** Offset 0x068E - Reserved +**/ + UINT8 Reserved175; + +/** Offset 0x068F - ITBT Root Port Enable + ITBT Root Port Enable, 0:Disable, 1:Enable + 0:Disable, 1:Enable +**/ + UINT8 ITbtPcieRootPortEn[4]; + +/** Offset 0x0693 - TCSS USB Port Enable + Bits 0, 1, ... max Type C port control enables +**/ + UINT8 UsbTcPortEn; + +/** Offset 0x0694 - Reserved +**/ + UINT16 Reserved176; + +/** Offset 0x0696 - ITbtConnectTopology Timeout value + ITbtConnectTopologyTimeout value. Specified increment values in miliseconds. Range + is 0-10000. 100 = 100 ms. +**/ + UINT16 ITbtConnectTopologyTimeoutInMs; + +/** Offset 0x0698 - Reserved +**/ + UINT8 Reserved177; + +/** Offset 0x0699 - Reserved +**/ + UINT8 Reserved178[1]; + +/** Offset 0x069A - Reserved +**/ + UINT16 Reserved179[2]; + +/** Offset 0x069E - Reserved +**/ + UINT8 Reserved180; + +/** Offset 0x069F - Enable/Disable PTM + This policy will enable/disable Precision Time Measurement for TCSS PCIe Root Ports + $EN_DIS +**/ + UINT8 PtmEnabled[4]; + +/** Offset 0x06A3 - Reserved +**/ + UINT8 Reserved181[4]; + +/** Offset 0x06A7 - Reserved +**/ + UINT8 Reserved182[4]; + +/** Offset 0x06AB - Reserved +**/ + UINT8 Reserved183[4]; + +/** Offset 0x06AF - Reserved +**/ + UINT8 Reserved184[1]; + +/** Offset 0x06B0 - Reserved +**/ + UINT16 Reserved185[4]; + +/** Offset 0x06B8 - Reserved +**/ + UINT8 Reserved186[4]; + +/** Offset 0x06BC - Reserved +**/ + UINT8 Reserved187[4]; + +/** Offset 0x06C0 - Reserved +**/ + UINT16 Reserved188[4]; + +/** Offset 0x06C8 - Reserved +**/ + UINT8 Reserved189[4]; + +/** Offset 0x06CC - Reserved +**/ + UINT8 Reserved190[4]; + +/** Offset 0x06D0 - Reserved +**/ + UINT8 Reserved191; + +/** Offset 0x06D1 - Reserved +**/ + UINT8 Reserved192[3]; + +/** Offset 0x06D4 - Reserved +**/ + UINT32 Reserved193; + +/** Offset 0x06D8 - CpuMpPpi + Optional pointer to the boot loader's implementation of EFI_PEI_MP_SERVICES_PPI. + If not NULL, FSP will use the boot loader's implementation of multiprocessing. + See section 5.1.4 of the FSP Integration Guide for more details. +**/ + UINT32 CpuMpPpi; + +/** Offset 0x06DC - Reserved +**/ + UINT8 Reserved194; + +/** Offset 0x06DD - Reserved +**/ + UINT8 Reserved195[2]; + +/** Offset 0x06DF - Reserved +**/ + UINT8 Reserved196[1]; + +/** Offset 0x06E0 - Reserved +**/ + UINT16 Reserved197[5]; + +/** Offset 0x06EA - Reserved +**/ + UINT8 Reserved198; + +/** Offset 0x06EB - Reserved +**/ + UINT8 Reserved199; + +/** Offset 0x06EC - Reserved +**/ + UINT16 Reserved200; + +/** Offset 0x06EE - Reserved +**/ + UINT8 Reserved201; + +/** Offset 0x06EF - Reserved +**/ + UINT8 Reserved202; + +/** Offset 0x06F0 - Reserved +**/ + UINT8 Reserved203; + +/** Offset 0x06F1 - Reserved +**/ + UINT8 Reserved204; + +/** Offset 0x06F2 - Reserved +**/ + UINT16 Reserved205; + +/** Offset 0x06F4 - Reserved +**/ + UINT8 Reserved206; + +/** Offset 0x06F5 - Reserved +**/ + UINT8 Reserved207; + +/** Offset 0x06F6 - Reserved +**/ + UINT8 Reserved208[5]; + +/** Offset 0x06FB - Reserved +**/ + UINT8 Reserved209[5]; + +/** Offset 0x0700 - Reserved +**/ + UINT8 Reserved210[5]; + +/** Offset 0x0705 - Reserved +**/ + UINT8 Reserved211[28]; + +/** Offset 0x0721 - Enable Power Optimizer + Enable DMI Power Optimizer on PCH side. + $EN_DIS +**/ + UINT8 PchPwrOptEnable; + +/** Offset 0x0722 - Reserved +**/ + UINT8 Reserved212[5]; + +/** Offset 0x0727 - Reserved +**/ + UINT8 Reserved213[5]; + +/** Offset 0x072C - Reserved +**/ + UINT16 Reserved214[5]; + +/** Offset 0x0736 - Reserved +**/ + UINT16 Reserved215[5]; + +/** Offset 0x0740 - Reserved +**/ + UINT8 Reserved216; + +/** Offset 0x0741 - Reserved +**/ + UINT8 Reserved217; + +/** Offset 0x0742 - Enable PCH ISH SPI Cs0 pins assigned + Set if ISH SPI Cs0 pins are to be enabled by BIOS. 0: Disable; 1: Enable. +**/ + UINT8 PchIshSpiCs0Enable[1]; + +/** Offset 0x0743 - Reserved +**/ + UINT8 Reserved218; + +/** Offset 0x0744 - Reserved +**/ + UINT8 Reserved219; + +/** Offset 0x0745 - Enable PCH ISH SPI pins assigned + Set if ISH SPI native pins are to be enabled by BIOS. 0: Disable; 1: Enable. +**/ + UINT8 PchIshSpiEnable[1]; + +/** Offset 0x0746 - Enable PCH ISH UART pins assigned + Set if ISH UART native pins are to be enabled by BIOS. 0: Disable; 1: Enable. +**/ + UINT8 PchIshUartEnable[2]; + +/** Offset 0x0748 - Enable PCH ISH I2C pins assigned + Set if ISH I2C native pins are to be enabled by BIOS. 0: Disable; 1: Enable. +**/ + UINT8 PchIshI2cEnable[3]; + +/** Offset 0x074B - Reserved +**/ + UINT8 Reserved220; + +/** Offset 0x074C - Enable PCH ISH GP pins assigned + Set if ISH GP native pins are to be enabled by BIOS. 0: Disable; 1: Enable. +**/ + UINT8 PchIshGpEnable[12]; + +/** Offset 0x0758 - Reserved +**/ + UINT8 Reserved221; + +/** Offset 0x0759 - Reserved +**/ + UINT8 Reserved222; + +/** Offset 0x075A - Reserved +**/ + UINT8 Reserved223; + +/** Offset 0x075B - Enable LOCKDOWN BIOS LOCK + Enable the BIOS Lock feature and set EISS bit (D31:F5:RegDCh[5]) for the BIOS region + protection. + $EN_DIS +**/ + UINT8 PchLockDownBiosLock; + +/** Offset 0x075C - Reserved +**/ + UINT8 Reserved224; + +/** Offset 0x075D - Reserved +**/ + UINT8 Reserved225; + +/** Offset 0x075E - RTC Cmos Memory Lock + Enable RTC lower and upper 128 byte Lock bits to lock Bytes 38h-3Fh in the upper + and and lower 128-byte bank of RTC RAM. + $EN_DIS +**/ + UINT8 RtcMemoryLock; + +/** Offset 0x075F - Enable PCIE RP HotPlug + Indicate whether the root port is hot plug available. +**/ + UINT8 PcieRpHotPlug[28]; + +/** Offset 0x077B - Reserved +**/ + UINT8 Reserved226[28]; + +/** Offset 0x0797 - Reserved +**/ + UINT8 Reserved227[28]; + +/** Offset 0x07B3 - Enable PCIE RP Clk Req Detect + Probe CLKREQ# signal before enabling CLKREQ# based power management. +**/ + UINT8 PcieRpClkReqDetect[28]; + +/** Offset 0x07CF - PCIE RP Advanced Error Report + Indicate whether the Advanced Error Reporting is enabled. +**/ + UINT8 PcieRpAdvancedErrorReporting[28]; + +/** Offset 0x07EB - Reserved +**/ + UINT8 Reserved228[28]; + +/** Offset 0x0807 - Reserved +**/ + UINT8 Reserved229[28]; + +/** Offset 0x0823 - Reserved +**/ + UINT8 Reserved230[28]; + +/** Offset 0x083F - Reserved +**/ + UINT8 Reserved231[28]; + +/** Offset 0x085B - Reserved +**/ + UINT8 Reserved232[28]; + +/** Offset 0x0877 - Reserved +**/ + UINT8 Reserved233[28]; + +/** Offset 0x0893 - Reserved +**/ + UINT8 Reserved234[28]; + +/** Offset 0x08AF - PCIE RP Max Payload + Max Payload Size supported, Default 64B, see enum PCH_PCIE_MAX_PAYLOAD. +**/ + UINT8 PcieRpMaxPayload[28]; + +/** Offset 0x08CB - Reserved +**/ + UINT8 Reserved235[2]; + +/** Offset 0x08CD - Reserved +**/ + UINT8 Reserved236[8]; + +/** Offset 0x08D5 - Reserved +**/ + UINT8 Reserved237[2]; + +/** Offset 0x08D7 - Reserved +**/ + UINT8 Reserved238[2]; + +/** Offset 0x08D9 - Reserved +**/ + UINT8 Reserved239[3]; + +/** Offset 0x08DC - Reserved +**/ + UINT32 Reserved240[2]; + +/** Offset 0x08E4 - Reserved +**/ + UINT32 Reserved241[2]; + +/** Offset 0x08EC - Reserved +**/ + UINT32 Reserved242[2]; + +/** Offset 0x08F4 - Reserved +**/ + UINT32 Reserved243[2]; + +/** Offset 0x08FC - Reserved +**/ + UINT32 Reserved244[2]; + +/** Offset 0x0904 - Reserved +**/ + UINT32 Reserved245[2]; + +/** Offset 0x090C - Reserved +**/ + UINT32 Reserved246[2]; + +/** Offset 0x0914 - Reserved +**/ + UINT32 Reserved247[2]; + +/** Offset 0x091C - Reserved +**/ + UINT32 Reserved248[2]; + +/** Offset 0x0924 - Reserved +**/ + UINT32 Reserved249[2]; + +/** Offset 0x092C - Reserved +**/ + UINT32 Reserved250[2]; + +/** Offset 0x0934 - Reserved +**/ + UINT32 Reserved251[2]; + +/** Offset 0x093C - Reserved +**/ + UINT32 Reserved252[2]; + +/** Offset 0x0944 - Reserved +**/ + UINT8 Reserved253[28]; + +/** Offset 0x0960 - Reserved +**/ + UINT8 Reserved254[28]; + +/** Offset 0x097C - Reserved +**/ + UINT8 Reserved255[28]; + +/** Offset 0x0998 - PCIE RP Aspm + The ASPM configuration of the root port (see: PCH_PCIE_ASPM_CONTROL). Default is + PchPcieAspmAutoConfig. +**/ + UINT8 PcieRpAspm[28]; + +/** Offset 0x09B4 - PCIE RP L1 Substates + The L1 Substates configuration of the root port (see: PCH_PCIE_L1SUBSTATES_CONTROL). + Default is PchPcieL1SubstatesL1_1_2. +**/ + UINT8 PcieRpL1Substates[28]; + +/** Offset 0x09D0 - PCIE RP Ltr Enable + Latency Tolerance Reporting Mechanism. +**/ + UINT8 PcieRpLtrEnable[28]; + +/** Offset 0x09EC - Reserved +**/ + UINT8 Reserved256[28]; + +/** Offset 0x0A08 - Reserved +**/ + UINT8 Reserved257[12]; + +/** Offset 0x0A14 - Reserved +**/ + UINT8 Reserved258[12]; + +/** Offset 0x0A20 - Reserved +**/ + UINT8 Reserved259[12]; + +/** Offset 0x0A2C - Reserved +**/ + UINT8 Reserved260[12]; + +/** Offset 0x0A38 - Reserved +**/ + UINT8 Reserved261[12]; + +/** Offset 0x0A44 - Reserved +**/ + UINT8 Reserved262[12]; + +/** Offset 0x0A50 - Reserved +**/ + UINT8 Reserved263[12]; + +/** Offset 0x0A5C - Reserved +**/ + UINT8 Reserved264[12]; + +/** Offset 0x0A68 - Reserved +**/ + UINT8 Reserved265[12]; + +/** Offset 0x0A74 - Reserved +**/ + UINT8 Reserved266[12]; + +/** Offset 0x0A80 - Reserved +**/ + UINT8 Reserved267[12]; + +/** Offset 0x0A8C - Reserved +**/ + UINT8 Reserved268[12]; + +/** Offset 0x0A98 - Reserved +**/ + UINT8 Reserved269[12]; + +/** Offset 0x0AA4 - Reserved +**/ + UINT8 Reserved270[12]; + +/** Offset 0x0AB0 - Reserved +**/ + UINT8 Reserved271[12]; + +/** Offset 0x0ABC - Reserved +**/ + UINT8 Reserved272[12]; + +/** Offset 0x0AC8 - Reserved +**/ + UINT8 Reserved273[12]; + +/** Offset 0x0AD4 - Reserved +**/ + UINT8 Reserved274[12]; + +/** Offset 0x0AE0 - Reserved +**/ + UINT8 Reserved275[12]; + +/** Offset 0x0AEC - Reserved +**/ + UINT8 Reserved276[12]; + +/** Offset 0x0AF8 - Reserved +**/ + UINT8 Reserved277[12]; + +/** Offset 0x0B04 - Reserved +**/ + UINT8 Reserved278[12]; + +/** Offset 0x0B10 - Reserved +**/ + UINT8 Reserved279[12]; + +/** Offset 0x0B1C - Reserved +**/ + UINT8 Reserved280[12]; + +/** Offset 0x0B28 - Reserved +**/ + UINT8 Reserved281[12]; + +/** Offset 0x0B34 - Reserved +**/ + UINT8 Reserved282[12]; + +/** Offset 0x0B40 - Reserved +**/ + UINT8 Reserved283[12]; + +/** Offset 0x0B4C - Reserved +**/ + UINT8 Reserved284[12]; + +/** Offset 0x0B58 - Reserved +**/ + UINT8 Reserved285[12]; + +/** Offset 0x0B64 - Reserved +**/ + UINT8 Reserved286[12]; + +/** Offset 0x0B70 - Reserved +**/ + UINT8 Reserved287[12]; + +/** Offset 0x0B7C - Reserved +**/ + UINT8 Reserved288[12]; + +/** Offset 0x0B88 - Reserved +**/ + UINT8 Reserved289[12]; + +/** Offset 0x0B94 - Reserved +**/ + UINT8 Reserved290[12]; + +/** Offset 0x0BA0 - Reserved +**/ + UINT8 Reserved291[12]; + +/** Offset 0x0BAC - Reserved +**/ + UINT8 Reserved292[12]; + +/** Offset 0x0BB8 - Reserved +**/ + UINT8 Reserved293[12]; + +/** Offset 0x0BC4 - Reserved +**/ + UINT8 Reserved294[12]; + +/** Offset 0x0BD0 - Reserved +**/ + UINT8 Reserved295[12]; + +/** Offset 0x0BDC - Reserved +**/ + UINT8 Reserved296[12]; + +/** Offset 0x0BE8 - Reserved +**/ + UINT8 Reserved297[12]; + +/** Offset 0x0BF4 - Reserved +**/ + UINT8 Reserved298[12]; + +/** Offset 0x0C00 - Reserved +**/ + UINT8 Reserved299[12]; + +/** Offset 0x0C0C - Reserved +**/ + UINT8 Reserved300[12]; + +/** Offset 0x0C18 - Reserved +**/ + UINT8 Reserved301[12]; + +/** Offset 0x0C24 - Reserved +**/ + UINT8 Reserved302[12]; + +/** Offset 0x0C30 - Reserved +**/ + UINT8 Reserved303[12]; + +/** Offset 0x0C3C - Reserved +**/ + UINT8 Reserved304[12]; + +/** Offset 0x0C48 - Reserved +**/ + UINT8 Reserved305[12]; + +/** Offset 0x0C54 - Reserved +**/ + UINT8 Reserved306[12]; + +/** Offset 0x0C60 - Reserved +**/ + UINT8 Reserved307[12]; + +/** Offset 0x0C6C - Reserved +**/ + UINT8 Reserved308[12]; + +/** Offset 0x0C78 - Reserved +**/ + UINT8 Reserved309[12]; + +/** Offset 0x0C84 - Reserved +**/ + UINT8 Reserved310[12]; + +/** Offset 0x0C90 - Reserved +**/ + UINT8 Reserved311[12]; + +/** Offset 0x0C9C - Reserved +**/ + UINT8 Reserved312[12]; + +/** Offset 0x0CA8 - Reserved +**/ + UINT8 Reserved313[12]; + +/** Offset 0x0CB4 - Reserved +**/ + UINT8 Reserved314[12]; + +/** Offset 0x0CC0 - Reserved +**/ + UINT8 Reserved315[12]; + +/** Offset 0x0CCC - Reserved +**/ + UINT8 Reserved316[12]; + +/** Offset 0x0CD8 - Reserved +**/ + UINT8 Reserved317[12]; + +/** Offset 0x0CE4 - Reserved +**/ + UINT8 Reserved318[12]; + +/** Offset 0x0CF0 - Reserved +**/ + UINT8 Reserved319[12]; + +/** Offset 0x0CFC - Reserved +**/ + UINT8 Reserved320[12]; + +/** Offset 0x0D08 - Reserved +**/ + UINT8 Reserved321[12]; + +/** Offset 0x0D14 - Reserved +**/ + UINT8 Reserved322[12]; + +/** Offset 0x0D20 - Reserved +**/ + UINT8 Reserved323[12]; + +/** Offset 0x0D2C - Reserved +**/ + UINT8 Reserved324[12]; + +/** Offset 0x0D38 - Reserved +**/ + UINT8 Reserved325[12]; + +/** Offset 0x0D44 - Reserved +**/ + UINT8 Reserved326[12]; + +/** Offset 0x0D50 - Reserved +**/ + UINT8 Reserved327[12]; + +/** Offset 0x0D5C - Reserved +**/ + UINT8 Reserved328[12]; + +/** Offset 0x0D68 - Reserved +**/ + UINT8 Reserved329[12]; + +/** Offset 0x0D74 - Reserved +**/ + UINT8 Reserved330[12]; + +/** Offset 0x0D80 - Reserved +**/ + UINT8 Reserved331[12]; + +/** Offset 0x0D8C - Reserved +**/ + UINT8 Reserved332[12]; + +/** Offset 0x0D98 - Reserved +**/ + UINT8 Reserved333[12]; + +/** Offset 0x0DA4 - Reserved +**/ + UINT8 Reserved334[12]; + +/** Offset 0x0DB0 - Reserved +**/ + UINT8 Reserved335[12]; + +/** Offset 0x0DBC - Reserved +**/ + UINT8 Reserved336[12]; + +/** Offset 0x0DC8 - Reserved +**/ + UINT8 Reserved337[12]; + +/** Offset 0x0DD4 - Reserved +**/ + UINT8 Reserved338[12]; + +/** Offset 0x0DE0 - Reserved +**/ + UINT8 Reserved339[12]; + +/** Offset 0x0DEC - Reserved +**/ + UINT8 Reserved340[12]; + +/** Offset 0x0DF8 - Reserved +**/ + UINT8 Reserved341[12]; + +/** Offset 0x0E04 - Reserved +**/ + UINT8 Reserved342[12]; + +/** Offset 0x0E10 - Reserved +**/ + UINT8 Reserved343[12]; + +/** Offset 0x0E1C - Reserved +**/ + UINT8 Reserved344[12]; + +/** Offset 0x0E28 - Reserved +**/ + UINT8 Reserved345[12]; + +/** Offset 0x0E34 - Reserved +**/ + UINT8 Reserved346[12]; + +/** Offset 0x0E40 - Reserved +**/ + UINT8 Reserved347[12]; + +/** Offset 0x0E4C - Reserved +**/ + UINT8 Reserved348[12]; + +/** Offset 0x0E58 - Reserved +**/ + UINT8 Reserved349[12]; + +/** Offset 0x0E64 - Reserved +**/ + UINT8 Reserved350[12]; + +/** Offset 0x0E70 - Reserved +**/ + UINT8 Reserved351[12]; + +/** Offset 0x0E7C - Reserved +**/ + UINT8 Reserved352[12]; + +/** Offset 0x0E88 - Reserved +**/ + UINT8 Reserved353[12]; + +/** Offset 0x0E94 - Reserved +**/ + UINT8 Reserved354[12]; + +/** Offset 0x0EA0 - Reserved +**/ + UINT8 Reserved355[12]; + +/** Offset 0x0EAC - Reserved +**/ + UINT8 Reserved356[12]; + +/** Offset 0x0EB8 - Reserved +**/ + UINT8 Reserved357[12]; + +/** Offset 0x0EC4 - Reserved +**/ + UINT8 Reserved358[12]; + +/** Offset 0x0ED0 - Reserved +**/ + UINT8 Reserved359[12]; + +/** Offset 0x0EDC - Reserved +**/ + UINT8 Reserved360[12]; + +/** Offset 0x0EE8 - Reserved +**/ + UINT8 Reserved361[12]; + +/** Offset 0x0EF4 - Reserved +**/ + UINT8 Reserved362[12]; + +/** Offset 0x0F00 - Reserved +**/ + UINT8 Reserved363[12]; + +/** Offset 0x0F0C - Reserved +**/ + UINT8 Reserved364[12]; + +/** Offset 0x0F18 - Reserved +**/ + UINT8 Reserved365[12]; + +/** Offset 0x0F24 - Reserved +**/ + UINT8 Reserved366[12]; + +/** Offset 0x0F30 - Reserved +**/ + UINT8 Reserved367[12]; + +/** Offset 0x0F3C - Reserved +**/ + UINT8 Reserved368[12]; + +/** Offset 0x0F48 - Reserved +**/ + UINT8 Reserved369[12]; + +/** Offset 0x0F54 - Reserved +**/ + UINT8 Reserved370[12]; + +/** Offset 0x0F60 - Reserved +**/ + UINT8 Reserved371[12]; + +/** Offset 0x0F6C - Reserved +**/ + UINT8 Reserved372[12]; + +/** Offset 0x0F78 - Reserved +**/ + UINT8 Reserved373[12]; + +/** Offset 0x0F84 - Reserved +**/ + UINT8 Reserved374[12]; + +/** Offset 0x0F90 - Reserved +**/ + UINT8 Reserved375[12]; + +/** Offset 0x0F9C - Reserved +**/ + UINT8 Reserved376[12]; + +/** Offset 0x0FA8 - Reserved +**/ + UINT8 Reserved377[12]; + +/** Offset 0x0FB4 - Reserved +**/ + UINT8 Reserved378[12]; + +/** Offset 0x0FC0 - Reserved +**/ + UINT8 Reserved379[12]; + +/** Offset 0x0FCC - Reserved +**/ + UINT8 Reserved380[12]; + +/** Offset 0x0FD8 - Reserved +**/ + UINT8 Reserved381[12]; + +/** Offset 0x0FE4 - Reserved +**/ + UINT8 Reserved382[12]; + +/** Offset 0x0FF0 - Reserved +**/ + UINT8 Reserved383[12]; + +/** Offset 0x0FFC - Reserved +**/ + UINT8 Reserved384[12]; + +/** Offset 0x1008 - Reserved +**/ + UINT8 Reserved385[12]; + +/** Offset 0x1014 - Reserved +**/ + UINT8 Reserved386[12]; + +/** Offset 0x1020 - Reserved +**/ + UINT8 Reserved387; + +/** Offset 0x1021 - Reserved +**/ + UINT8 Reserved388; + +/** Offset 0x1022 - Reserved +**/ + UINT8 Reserved389[12]; + +/** Offset 0x102E - Reserved +**/ + UINT8 Reserved390[12]; + +/** Offset 0x103A - Reserved +**/ + UINT8 Reserved391[12]; + +/** Offset 0x1046 - Reserved +**/ + UINT8 Reserved392; + +/** Offset 0x1047 - Reserved +**/ + UINT8 Reserved393; + +/** Offset 0x1048 - Reserved +**/ + UINT8 Reserved394; + +/** Offset 0x1049 - Reserved +**/ + UINT8 Reserved395; + +/** Offset 0x104A - Reserved +**/ + UINT8 Reserved396; + +/** Offset 0x104B - Reserved +**/ + UINT8 Reserved397; + +/** Offset 0x104C - Reserved +**/ + UINT8 Reserved398; + +/** Offset 0x104D - Reserved +**/ + UINT8 Reserved399; + +/** Offset 0x104E - Reserved +**/ + UINT8 Reserved400; + +/** Offset 0x104F - Reserved +**/ + UINT8 Reserved401; + +/** Offset 0x1050 - Reserved +**/ + UINT8 Reserved402; + +/** Offset 0x1051 - Reserved +**/ + UINT8 Reserved403; + +/** Offset 0x1052 - Reserved +**/ + UINT8 Reserved404; + +/** Offset 0x1053 - Reserved +**/ + UINT8 Reserved405; + +/** Offset 0x1054 - Reserved +**/ + UINT8 Reserved406; + +/** Offset 0x1055 - Reserved +**/ + UINT8 Reserved407; + +/** Offset 0x1056 - Reserved +**/ + UINT8 Reserved408; + +/** Offset 0x1057 - Reserved +**/ + UINT8 Reserved409; + +/** Offset 0x1058 - Reserved +**/ + UINT8 Reserved410; + +/** Offset 0x1059 - Reserved +**/ + UINT8 Reserved411; + +/** Offset 0x105A - Reserved +**/ + UINT8 Reserved412; + +/** Offset 0x105B - Reserved +**/ + UINT8 Reserved413; + +/** Offset 0x105C - PCH Sata Pwr Opt Enable + SATA Power Optimizer on PCH side. + $EN_DIS +**/ + UINT8 SataPwrOptEnable; + +/** Offset 0x105D - Reserved +**/ + UINT8 Reserved414; + +/** Offset 0x105E - Reserved +**/ + UINT8 Reserved415; + +/** Offset 0x105F - Reserved +**/ + UINT8 Reserved416[8]; + +/** Offset 0x1067 - Reserved +**/ + UINT8 Reserved417[8]; + +/** Offset 0x106F - Reserved +**/ + UINT8 Reserved418[8]; + +/** Offset 0x1077 - Reserved +**/ + UINT8 Reserved419[8]; + +/** Offset 0x107F - Reserved +**/ + UINT8 Reserved420[8]; + +/** Offset 0x1087 - Reserved +**/ + UINT8 Reserved421[8]; + +/** Offset 0x108F - Enable SATA Port DmVal + DITO multiplier. Default is 15. +**/ + UINT8 SataPortsDmVal[8]; + +/** Offset 0x1097 - Reserved +**/ + UINT8 Reserved422[1]; + +/** Offset 0x1098 - Enable SATA Port DmVal + DEVSLP Idle Timeout (DITO), Default is 625. +**/ + UINT16 SataPortsDitoVal[8]; + +/** Offset 0x10A8 - Reserved +**/ + UINT8 Reserved423[8]; + +/** Offset 0x10B0 - Reserved +**/ + UINT8 Reserved424; + +/** Offset 0x10B1 - Reserved +**/ + UINT8 Reserved425[3]; + +/** Offset 0x10B4 - Reserved +**/ + UINT8 Reserved426[3]; + +/** Offset 0x10B7 - Reserved +**/ + UINT8 Reserved427[3]; + +/** Offset 0x10BA - UFS enable/disable + PCIe Storage Device Reset Delay in milliseconds. Default value is 100ms + $EN_DIS +**/ + UINT8 UfsEnable[2]; + +/** Offset 0x10BC - Reserved +**/ + UINT8 Reserved428[2]; + +/** Offset 0x10BE - Reserved +**/ + UINT8 Reserved429; + +/** Offset 0x10BF - Reserved +**/ + UINT8 Reserved430; + +/** Offset 0x10C0 - Reserved +**/ + UINT16 Reserved431; + +/** Offset 0x10C2 - Reserved +**/ + UINT16 Reserved432; + +/** Offset 0x10C4 - Reserved +**/ + UINT16 Reserved433; + +/** Offset 0x10C6 - Reserved +**/ + UINT8 Reserved434; + +/** Offset 0x10C7 - Reserved +**/ + UINT8 Reserved435; + +/** Offset 0x10C8 - Reserved +**/ + UINT8 Reserved436; + +/** Offset 0x10C9 - Reserved +**/ + UINT8 Reserved437; + +/** Offset 0x10CA - Reserved +**/ + UINT8 Reserved438; + +/** Offset 0x10CB - Reserved +**/ + UINT8 Reserved439; + +/** Offset 0x10CC - Reserved +**/ + UINT16 Reserved440; + +/** Offset 0x10CE - Reserved +**/ + UINT16 Reserved441; + +/** Offset 0x10D0 - Reserved +**/ + UINT16 Reserved442; + +/** Offset 0x10D2 - Reserved +**/ + UINT8 Reserved443; + +/** Offset 0x10D3 - Reserved +**/ + UINT8 Reserved444; + +/** Offset 0x10D4 - Reserved +**/ + UINT8 Reserved445; + +/** Offset 0x10D5 - Reserved +**/ + UINT8 Reserved446; + +/** Offset 0x10D6 - Reserved +**/ + UINT8 Reserved447; + +/** Offset 0x10D7 - Reserved +**/ + UINT8 Reserved448; + +/** Offset 0x10D8 - Reserved +**/ + UINT8 Reserved449; + +/** Offset 0x10D9 - Reserved +**/ + UINT8 Reserved450; + +/** Offset 0x10DA - Reserved +**/ + UINT8 Reserved451; + +/** Offset 0x10DB - Reserved +**/ + UINT8 Reserved452; + +/** Offset 0x10DC - Reserved +**/ + UINT8 Reserved453; + +/** Offset 0x10DD - Reserved +**/ + UINT8 Reserved454; + +/** Offset 0x10DE - Reserved +**/ + UINT8 Reserved455; + +/** Offset 0x10DF - Reserved +**/ + UINT8 Reserved456; + +/** Offset 0x10E0 - Reserved +**/ + UINT8 Reserved457; + +/** Offset 0x10E1 - Reserved +**/ + UINT8 Reserved458; + +/** Offset 0x10E2 - Reserved +**/ + UINT8 Reserved459; + +/** Offset 0x10E3 - Reserved +**/ + UINT8 Reserved460; + +/** Offset 0x10E4 - Reserved +**/ + UINT8 Reserved461; + +/** Offset 0x10E5 - Reserved +**/ + UINT8 Reserved462; + +/** Offset 0x10E6 - Reserved +**/ + UINT8 Reserved463; + +/** Offset 0x10E7 - Reserved +**/ + UINT8 Reserved464; + +/** Offset 0x10E8 - Reserved +**/ + UINT16 Reserved465; + +/** Offset 0x10EA - USB2 Port Over Current Pin + Describe the specific over current pin number of USB 2.0 Port N. +**/ + UINT8 Usb2OverCurrentPin[16]; + +/** Offset 0x10FA - USB3 Port Over Current Pin + Describe the specific over current pin number of USB 3.0 Port N. +**/ + UINT8 Usb3OverCurrentPin[10]; + +/** Offset 0x1104 - Reserved +**/ + UINT8 Reserved466; + +/** Offset 0x1105 - Reserved +**/ + UINT8 Reserved467[3]; + +/** Offset 0x1108 - Reserved +**/ + UINT32 Reserved468; + +/** Offset 0x110C - Reserved +**/ + UINT32 Reserved469; + +/** Offset 0x1110 - Reserved +**/ + UINT32 Reserved470; + +/** Offset 0x1114 - Enable 8254 Static Clock Gating + Set 8254CGE=1 is required for SLP_S0 support. However, set 8254CGE=1 in POST time + might fail to boot legacy OS using 8254 timer. Make sure it is disabled to support + legacy OS using 8254 timer. Also enable this while S0ix is enabled. + $EN_DIS +**/ + UINT8 Enable8254ClockGating; + +/** Offset 0x1115 - Enable 8254 Static Clock Gating On S3 + This is only applicable when Enable8254ClockGating is disabled. FSP will do the + 8254 CGE programming on S3 resume when Enable8254ClockGatingOnS3 is enabled. This + avoids the SMI requirement for the programming. + $EN_DIS +**/ + UINT8 Enable8254ClockGatingOnS3; + +/** Offset 0x1116 - Reserved +**/ + UINT8 Reserved471; + +/** Offset 0x1117 - Hybrid Storage Detection and Configuration Mode + Enables support for Hybrid storage devices. 0: Disabled; 1: Dynamic Configuration. + Default is 0: Disabled + 0: Disabled, 1: Dynamic Configuration +**/ + UINT8 HybridStorageMode; + +/** Offset 0x1118 - Reserved +**/ + UINT64 Reserved472[4]; + +/** Offset 0x1138 - Reserved +**/ + UINT32 Reserved473; + +/** Offset 0x113C - Reserved +**/ + UINT8 Reserved474[4]; + +/** Offset 0x1140 - Reserved +**/ + UINT64 Reserved475; + +/** Offset 0x1148 - Reserved +**/ + UINT64 Reserved476; + +/** Offset 0x1150 - Reserved +**/ + UINT8 Reserved477; + +/** Offset 0x1151 - Reserved +**/ + UINT8 Reserved478; + +/** Offset 0x1152 - Reserved +**/ + UINT8 Reserved479; + +/** Offset 0x1153 - Reserved +**/ + UINT8 Reserved480; + +/** Offset 0x1154 - Reserved +**/ + UINT16 Reserved481; + +/** Offset 0x1156 - Reserved +**/ + UINT16 Reserved482; + +/** Offset 0x1158 - Reserved +**/ + UINT32 Reserved483; + +/** Offset 0x115C - Reserved +**/ + UINT16 Reserved484; + +/** Offset 0x115E - Reserved +**/ + UINT8 Reserved485[16]; + +/** Offset 0x116E - Reserved +**/ + UINT8 Reserved486; + +/** Offset 0x116F - Enable PS_ON. + PS_ON is a new C10 state from the CPU on desktop SKUs that enables a lower power + target that will be required by the California Energy Commission (CEC). When FALSE, + PS_ON is to be disabled. + $EN_DIS +**/ + UINT8 PsOnEnable; + +/** Offset 0x1170 - Reserved +**/ + UINT8 Reserved487; + +/** Offset 0x1171 - Reserved +**/ + UINT8 Reserved488; + +/** Offset 0x1172 - Reserved +**/ + UINT8 Reserved489; + +/** Offset 0x1173 - Reserved +**/ + UINT8 Reserved490; + +/** Offset 0x1174 - Reserved +**/ + UINT8 Reserved491; + +/** Offset 0x1175 - Reserved +**/ + UINT8 Reserved492; + +/** Offset 0x1176 - Reserved +**/ + UINT8 Reserved493; + +/** Offset 0x1177 - Reserved +**/ + UINT8 Reserved494; + +/** Offset 0x1178 - Reserved +**/ + UINT8 Reserved495; + +/** Offset 0x1179 - Reserved +**/ + UINT8 Reserved496; + +/** Offset 0x117A - Reserved +**/ + UINT8 Reserved497; + +/** Offset 0x117B - Reserved +**/ + UINT8 Reserved498; + +/** Offset 0x117C - Reserved +**/ + UINT32 Reserved499; + +/** Offset 0x1180 - Reserved +**/ + UINT8 Reserved500; + +/** Offset 0x1181 - Reserved +**/ + UINT8 Reserved501; + +/** Offset 0x1182 - Reserved +**/ + UINT8 Reserved502[12]; + +/** Offset 0x118E - Reserved +**/ + UINT8 Reserved503[12]; + +/** Offset 0x119A - Reserved +**/ + UINT8 Reserved504[12]; + +/** Offset 0x11A6 - Reserved +**/ + UINT8 Reserved505[10]; + +/** Offset 0x11B0 - Reserved +**/ + UINT8 Reserved506[10]; + +/** Offset 0x11BA - Reserved +**/ + UINT8 Reserved507[10]; + +/** Offset 0x11C4 - Reserved +**/ + UINT8 Reserved508[10]; + +/** Offset 0x11CE - Reserved +**/ + UINT8 Reserved509[10]; + +/** Offset 0x11D8 - Reserved +**/ + UINT8 Reserved510[10]; + +/** Offset 0x11E2 - Reserved +**/ + UINT8 Reserved511[10]; + +/** Offset 0x11EC - Reserved +**/ + UINT8 Reserved512[10]; + +/** Offset 0x11F6 - Skip PAM regsiter lock + Enable: PAM register will not be locked by RC, platform code should lock it, Disable(Default): + PAM registers will be locked by RC + $EN_DIS +**/ + UINT8 SkipPamLock; + +/** Offset 0x11F7 - Reserved +**/ + UINT8 Reserved513; + +/** Offset 0x11F8 - Reserved +**/ + UINT8 Reserved514; + +/** Offset 0x11F9 - GT Frequency Limit + 0xFF: Auto(Default), 2: 100 Mhz, 3: 150 Mhz, 4: 200 Mhz, 5: 250 Mhz, 6: 300 Mhz, + 7: 350 Mhz, 8: 400 Mhz, 9: 450 Mhz, 0xA: 500 Mhz, 0xB: 550 Mhz, 0xC: 600 Mhz, 0xD: + 650 Mhz, 0xE: 700 Mhz, 0xF: 750 Mhz, 0x10: 800 Mhz, 0x11: 850 Mhz, 0x12:900 Mhz, + 0x13: 950 Mhz, 0x14: 1000 Mhz, 0x15: 1050 Mhz, 0x16: 1100 Mhz, 0x17: 1150 Mhz, + 0x18: 1200 Mhz + 0xFF: Auto(Default), 2: 100 Mhz, 3: 150 Mhz, 4: 200 Mhz, 5: 250 Mhz, 6: 300 Mhz, + 7: 350 Mhz, 8: 400 Mhz, 9: 450 Mhz, 0xA: 500 Mhz, 0xB: 550 Mhz, 0xC: 600 Mhz, 0xD: + 650 Mhz, 0xE: 700 Mhz, 0xF: 750 Mhz, 0x10: 800 Mhz, 0x11: 850 Mhz, 0x12:900 Mhz, + 0x13: 950 Mhz, 0x14: 1000 Mhz, 0x15: 1050 Mhz, 0x16: 1100 Mhz, 0x17: 1150 Mhz, + 0x18: 1200 Mhz +**/ + UINT8 GtFreqMax; + +/** Offset 0x11FA - Reserved +**/ + UINT8 Reserved515; + +/** Offset 0x11FB - Reserved +**/ + UINT8 Reserved516; + +/** Offset 0x11FC - Reserved +**/ + UINT8 Reserved517; + +/** Offset 0x11FD - Reserved +**/ + UINT8 Reserved518; + +/** Offset 0x11FE - Reserved +**/ + UINT8 Reserved519[2]; + +/** Offset 0x1200 - Reserved +**/ + UINT32 Reserved520; + +/** Offset 0x1204 - Reserved +**/ + UINT32 Reserved521; + +/** Offset 0x1208 - Reserved +**/ + UINT8 Reserved522; + +/** Offset 0x1209 - Reserved +**/ + UINT8 Reserved523; + +/** Offset 0x120A - Reserved +**/ + UINT8 Reserved524[2]; + +/** Offset 0x120C - Reserved +**/ + UINT32 Reserved525; + +/** Offset 0x1210 - Reserved +**/ + UINT32 Reserved526; + +/** Offset 0x1214 - Reserved +**/ + UINT8 Reserved527[32]; + +/** Offset 0x1234 - Reserved +**/ + UINT8 Reserved528; + +/** Offset 0x1235 - Reserved +**/ + UINT8 Reserved529[4]; + +/** Offset 0x1239 - Enable or Disable HWP + Enable or Disable HWP(Hardware P states) Support. 0: Disable; 1: Enable; + 2-3:Reserved + $EN_DIS +**/ + UINT8 Hwp; + +/** Offset 0x123A - Reserved +**/ + UINT8 Reserved530; + +/** Offset 0x123B - Reserved +**/ + UINT8 Reserved531; + +/** Offset 0x123C - Reserved +**/ + UINT8 Reserved532; + +/** Offset 0x123D - Reserved +**/ + UINT8 Reserved533; + +/** Offset 0x123E - Reserved +**/ + UINT8 Reserved534; + +/** Offset 0x123F - Reserved +**/ + UINT8 Reserved535; + +/** Offset 0x1240 - Reserved +**/ + UINT8 Reserved536; + +/** Offset 0x1241 - TCC Activation Offset + TCC Activation Offset. Offset from factory set TCC activation temperature at which + the Thermal Control Circuit must be activated. TCC will be activated at TCC Activation + Temperature, in volts.For SKL Y SKU, the recommended default for this policy is + 10, For all other SKUs the recommended default are 0 +**/ + UINT8 TccActivationOffset; + +/** Offset 0x1242 - Reserved +**/ + UINT8 Reserved537; + +/** Offset 0x1243 - Reserved +**/ + UINT8 Reserved538; + +/** Offset 0x1244 - Reserved +**/ + UINT8 Reserved539; + +/** Offset 0x1245 - Reserved +**/ + UINT8 Reserved540; + +/** Offset 0x1246 - Reserved +**/ + UINT8 Reserved541; + +/** Offset 0x1247 - Reserved +**/ + UINT8 Reserved542; + +/** Offset 0x1248 - Reserved +**/ + UINT8 Reserved543; + +/** Offset 0x1249 - Reserved +**/ + UINT8 Reserved544; + +/** Offset 0x124A - Reserved +**/ + UINT8 Reserved545; + +/** Offset 0x124B - Reserved +**/ + UINT8 Reserved546; + +/** Offset 0x124C - Reserved +**/ + UINT8 Reserved547; + +/** Offset 0x124D - Reserved +**/ + UINT8 Reserved548; + +/** Offset 0x124E - Reserved +**/ + UINT8 Reserved549; + +/** Offset 0x124F - Reserved +**/ + UINT8 Reserved550; + +/** Offset 0x1250 - Reserved +**/ + UINT8 Reserved551; + +/** Offset 0x1251 - Reserved +**/ + UINT8 Reserved552; + +/** Offset 0x1252 - Reserved +**/ + UINT8 Reserved553; + +/** Offset 0x1253 - Reserved +**/ + UINT8 Reserved554; + +/** Offset 0x1254 - Reserved +**/ + UINT8 Reserved555; + +/** Offset 0x1255 - Reserved +**/ + UINT8 Reserved556; + +/** Offset 0x1256 - Reserved +**/ + UINT8 Reserved557; + +/** Offset 0x1257 - Reserved +**/ + UINT8 Reserved558; + +/** Offset 0x1258 - Reserved +**/ + UINT8 Reserved559; + +/** Offset 0x1259 - Reserved +**/ + UINT8 Reserved560; + +/** Offset 0x125A - Reserved +**/ + UINT8 Reserved561; + +/** Offset 0x125B - Reserved +**/ + UINT8 Reserved562; + +/** Offset 0x125C - Enable or Disable Energy Efficient Turbo + Enable or Disable Energy Efficient Turbo, will be applied in Turbo mode. 0: Disable; 1: Enable + $EN_DIS +**/ + UINT8 EnergyEfficientTurbo; + +/** Offset 0x125D - Reserved +**/ + UINT8 Reserved563; + +/** Offset 0x125E - Reserved +**/ + UINT8 Reserved564; + +/** Offset 0x125F - Reserved +**/ + UINT8 Reserved565; + +/** Offset 0x1260 - Reserved +**/ + UINT8 Reserved566; + +/** Offset 0x1261 - Reserved +**/ + UINT8 Reserved567; + +/** Offset 0x1262 - Reserved +**/ + UINT8 Reserved568; + +/** Offset 0x1263 - Reserved +**/ + UINT8 Reserved569; + +/** Offset 0x1264 - Enable or Disable CPU power states (C-states) + Enable or Disable CPU power states (C-states). 0: Disable; 1: Enable + $EN_DIS +**/ + UINT8 Cx; + +/** Offset 0x1265 - Reserved +**/ + UINT8 Reserved570; + +/** Offset 0x1266 - Reserved +**/ + UINT8 Reserved571; + +/** Offset 0x1267 - Reserved +**/ + UINT8 Reserved572; + +/** Offset 0x1268 - Reserved +**/ + UINT8 Reserved573; + +/** Offset 0x1269 - Reserved +**/ + UINT8 Reserved574; + +/** Offset 0x126A - Reserved +**/ + UINT8 Reserved575; + +/** Offset 0x126B - Reserved +**/ + UINT8 Reserved576; + +/** Offset 0x126C - Reserved +**/ + UINT8 Reserved577; + +/** Offset 0x126D - Reserved +**/ + UINT8 Reserved578; + +/** Offset 0x126E - Reserved +**/ + UINT8 Reserved579; + +/** Offset 0x126F - Reserved +**/ + UINT8 Reserved580; + +/** Offset 0x1270 - Reserved +**/ + UINT8 Reserved581; + +/** Offset 0x1271 - Reserved +**/ + UINT8 Reserved582; + +/** Offset 0x1272 - Reserved +**/ + UINT8 Reserved583; + +/** Offset 0x1273 - Reserved +**/ + UINT8 Reserved584; + +/** Offset 0x1274 - Reserved +**/ + UINT8 Reserved585; + +/** Offset 0x1275 - Reserved +**/ + UINT8 Reserved586; + +/** Offset 0x1276 - Reserved +**/ + UINT8 Reserved587; + +/** Offset 0x1277 - Reserved +**/ + UINT8 Reserved588[40]; + +/** Offset 0x129F - Reserved +**/ + UINT8 Reserved589[16]; + +/** Offset 0x12AF - Reserved +**/ + UINT8 Reserved590; + +/** Offset 0x12B0 - Reserved +**/ + UINT32 Reserved591; + +/** Offset 0x12B4 - Reserved +**/ + UINT32 Reserved592; + +/** Offset 0x12B8 - Reserved +**/ + UINT32 Reserved593; + +/** Offset 0x12BC - Reserved +**/ + UINT32 Reserved594; + +/** Offset 0x12C0 - Reserved +**/ + UINT16 Reserved595; + +/** Offset 0x12C2 - Reserved +**/ + UINT8 Reserved596[2]; + +/** Offset 0x12C4 - Reserved +**/ + UINT32 Reserved597; + +/** Offset 0x12C8 - Reserved +**/ + UINT32 Reserved598; + +/** Offset 0x12CC - Reserved +**/ + UINT32 Reserved599; + +/** Offset 0x12D0 - Reserved +**/ + UINT32 Reserved600; + +/** Offset 0x12D4 - Reserved +**/ + UINT32 Reserved601; + +/** Offset 0x12D8 - Reserved +**/ + UINT32 Reserved602; + +/** Offset 0x12DC - Reserved +**/ + UINT32 Reserved603; + +/** Offset 0x12E0 - Reserved +**/ + UINT32 Reserved604; + +/** Offset 0x12E4 - Reserved +**/ + UINT32 Reserved605; + +/** Offset 0x12E8 - Reserved +**/ + UINT8 Reserved606; + +/** Offset 0x12E9 - Reserved +**/ + UINT8 Reserved607; + +/** Offset 0x12EA - Reserved +**/ + UINT8 Reserved608; + +/** Offset 0x12EB - Reserved +**/ + UINT8 Reserved609[4]; + +/** Offset 0x12EF - Reserved +**/ + UINT8 Reserved610; + +/** Offset 0x12F0 - Reserved +**/ + UINT8 Reserved611; + +/** Offset 0x12F1 - Reserved +**/ + UINT8 Reserved612; + +/** Offset 0x12F2 - Reserved +**/ + UINT8 Reserved613; + +/** Offset 0x12F3 - Reserved +**/ + UINT8 Reserved614; + +/** Offset 0x12F4 - Reserved +**/ + UINT8 Reserved615; + +/** Offset 0x12F5 - Reserved +**/ + UINT8 Reserved616; + +/** Offset 0x12F6 - Reserved +**/ + UINT8 Reserved617; + +/** Offset 0x12F7 - Reserved +**/ + UINT8 Reserved618; + +/** Offset 0x12F8 - Reserved +**/ + UINT8 Reserved619; + +/** Offset 0x12F9 - Reserved +**/ + UINT8 Reserved620; + +/** Offset 0x12FA - Reserved +**/ + UINT8 Reserved621[16]; + +/** Offset 0x130A - Reserved +**/ + UINT8 Reserved622[16]; + +/** Offset 0x131A - End of Post message + Test, Send End of Post message. Disable(0x0): Disable EOP message, Send in PEI(0x1): + EOP send in PEI, Send in DXE(0x2)(Default): EOP send in DXE + 0:Disable, 1:Send in PEI, 2:Send in DXE, 3:Reserved +**/ + UINT8 EndOfPostMessage; + +/** Offset 0x131B - Reserved +**/ + UINT8 Reserved623; + +/** Offset 0x131C - Reserved +**/ + UINT8 Reserved624; + +/** Offset 0x131D - Reserved +**/ + UINT8 Reserved625; + +/** Offset 0x131E - Reserved +**/ + UINT8 Reserved626; + +/** Offset 0x131F - Reserved +**/ + UINT8 Reserved627; + +/** Offset 0x1320 - Reserved +**/ + UINT8 Reserved628[16]; + +/** Offset 0x1330 - Enable LOCKDOWN SMI + Enable SMI_LOCK bit to prevent writes to the Global SMI Enable bit. + $EN_DIS +**/ + UINT8 PchLockDownGlobalSmi; + +/** Offset 0x1331 - Enable LOCKDOWN BIOS Interface + Enable BIOS Interface Lock Down bit to prevent writes to the Backup Control Register. + $EN_DIS +**/ + UINT8 PchLockDownBiosInterface; + +/** Offset 0x1332 - Unlock all GPIO pads + Force all GPIO pads to be unlocked for debug purpose. + $EN_DIS +**/ + UINT8 PchUnlockGpioPads; + +/** Offset 0x1333 - Reserved +**/ + UINT8 Reserved629; + +/** Offset 0x1334 - PCIE RP Ltr Max Snoop Latency + Latency Tolerance Reporting, Max Snoop Latency. +**/ + UINT16 PcieRpLtrMaxSnoopLatency[24]; + +/** Offset 0x1364 - PCIE RP Ltr Max No Snoop Latency + Latency Tolerance Reporting, Max Non-Snoop Latency. +**/ + UINT16 PcieRpLtrMaxNoSnoopLatency[24]; + +/** Offset 0x1394 - Reserved +**/ + UINT8 Reserved630[28]; + +/** Offset 0x13B0 - Reserved +**/ + UINT8 Reserved631[28]; + +/** Offset 0x13CC - Reserved +**/ + UINT16 Reserved632[24]; + +/** Offset 0x13FC - Reserved +**/ + UINT8 Reserved633[28]; + +/** Offset 0x1418 - Reserved +**/ + UINT8 Reserved634[28]; + +/** Offset 0x1434 - Reserved +**/ + UINT16 Reserved635[24]; + +/** Offset 0x1464 - Reserved +**/ + UINT8 Reserved636[28]; + +/** Offset 0x1480 - Reserved +**/ + UINT16 Reserved637[24]; + +/** Offset 0x14B0 - Reserved +**/ + UINT8 Reserved638; + +/** Offset 0x14B1 - Reserved +**/ + UINT8 Reserved639; + +/** Offset 0x14B2 - PCH Energy Reporting + Disable/Enable PCH to CPU energy report feature. + $EN_DIS +**/ + UINT8 PchPmDisableEnergyReport; + +/** Offset 0x14B3 - Reserved +**/ + UINT8 Reserved640; + +/** Offset 0x14B4 - Reserved +**/ + UINT8 Reserved641; + +/** Offset 0x14B5 - Low Power Mode Enable/Disable config mask + Configure if respective S0i2/3 sub-states are to be supported. Each bit corresponds + to one sub-state (LPMx - BITx): LPM0-s0i2.0, LPM1-s0i2.1, LPM2-s0i2.2, LPM3-s0i3.0, + LPM4-s0i3.1, LPM5-s0i3.2, LPM6-s0i3.3, LPM7-s0i3.4. +**/ + UINT8 PmcLpmS0ixSubStateEnableMask; + +/** Offset 0x14B6 - Reserved +**/ + UINT8 Reserved642; + +/** Offset 0x14B7 - Reserved +**/ + UINT8 Reserved643; + +/** Offset 0x14B8 - Reserved +**/ + UINT8 Reserved644[8]; + +/** Offset 0x14C0 - Reserved +**/ + UINT8 Reserved645[8]; + +/** Offset 0x14C8 - Reserved +**/ + UINT8 Reserved646[8]; + +/** Offset 0x14D0 - Reserved +**/ + UINT8 Reserved647[8]; + +/** Offset 0x14D8 - Reserved +**/ + UINT32 Reserved648; + +/** Offset 0x14DC - Reserved +**/ + UINT8 Reserved649[4]; + +/** Offset 0x14E0 - Reserved +**/ + UINT8 Reserved650[4]; + +/** Offset 0x14E4 - Reserved +**/ + UINT8 Reserved651[4]; + +/** Offset 0x14E8 - Reserved +**/ + UINT8 Reserved652[5]; + +/** Offset 0x14ED - Reserved +**/ + UINT8 Reserved653[3]; +} FSP_S_CONFIG; + +/** Fsp S UPD Configuration +**/ +typedef struct { + +/** Offset 0x0000 +**/ + FSP_UPD_HEADER FspUpdHeader; + +/** Offset 0x0020 +**/ + FSPS_ARCH_UPD FspsArchUpd; + +/** Offset 0x0040 +**/ + FSP_S_CONFIG FspsConfig; + +/** Offset 0x14F0 +**/ + UINT8 UnusedUpdSpace40[6]; + +/** Offset 0x14F6 +**/ + UINT16 UpdTerminator; +} FSPS_UPD; + +#pragma pack() + +#endif diff --git a/src/vendorcode/intel/fsp/fsp2_0/meteorlake/MemInfoHob.h b/src/vendorcode/intel/fsp/fsp2_0/meteorlake/MemInfoHob.h new file mode 100644 index 0000000000..a2d6d1e129 --- /dev/null +++ b/src/vendorcode/intel/fsp/fsp2_0/meteorlake/MemInfoHob.h @@ -0,0 +1,309 @@ +/** @file + This file contains definitions required for creation of + Memory S3 Save data, Memory Info data and Memory Platform + data hobs. + + @copyright + Copyright (c) 1999 - 2022, Intel Corporation. All rights reserved.
+ This program and the accompanying materials are licensed and made available under + the terms and conditions of the BSD License that accompanies this distribution. + The full text of the license may be found at + http://opensource.org/licenses/bsd-license.php. + THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, + + WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. + +@par Specification Reference: +**/ +#ifndef _MEM_INFO_HOB_H_ +#define _MEM_INFO_HOB_H_ + + +#pragma pack (push, 1) + +extern EFI_GUID gSiMemoryS3DataGuid; +extern EFI_GUID gSiMemoryS3Data2Guid; +extern EFI_GUID gSiMemoryInfoDataGuid; +extern EFI_GUID gSiMemoryPlatformDataGuid; + +#define MAX_NODE 2 +#define MAX_CH 4 +#define MAX_DIMM 2 +#define HOB_MAX_SAGV_POINTS 4 + +/// +/// Host reset states from MRC. +/// +#define WARM_BOOT 2 + +#define R_MC_CHNL_RANK_PRESENT 0x7C +#define B_RANK0_PRS BIT0 +#define B_RANK1_PRS BIT1 +#define B_RANK2_PRS BIT4 +#define B_RANK3_PRS BIT5 + +// @todo remove and use the MdePkg\Include\Pi\PiHob.h +#if !defined(_PEI_HOB_H_) && !defined(__PI_HOB_H__) +#ifndef __HOB__H__ +typedef struct _EFI_HOB_GENERIC_HEADER { + UINT16 HobType; + UINT16 HobLength; + UINT32 Reserved; +} EFI_HOB_GENERIC_HEADER; + +typedef struct _EFI_HOB_GUID_TYPE { + EFI_HOB_GENERIC_HEADER Header; + EFI_GUID Name; + /// + /// Guid specific data goes here + /// +} EFI_HOB_GUID_TYPE; +#endif +#endif + +/// +/// Defines taken from MRC so avoid having to include MrcInterface.h +/// + +// +// Matches MAX_SPD_SAVE define in MRC +// +#ifndef MAX_SPD_SAVE +#define MAX_SPD_SAVE 29 +#endif + +// +// MRC version description. +// +typedef struct { + UINT8 Major; ///< Major version number + UINT8 Minor; ///< Minor version number + UINT8 Rev; ///< Revision number + UINT8 Build; ///< Build number +} SiMrcVersion; + +// +// Matches MrcChannelSts enum in MRC +// +#ifndef CHANNEL_NOT_PRESENT +#define CHANNEL_NOT_PRESENT 0 // There is no channel present on the controller. +#endif +#ifndef CHANNEL_DISABLED +#define CHANNEL_DISABLED 1 // There is a channel present but it is disabled. +#endif +#ifndef CHANNEL_PRESENT +#define CHANNEL_PRESENT 2 // There is a channel present and it is enabled. +#endif + +// +// Matches MrcDimmSts enum in MRC +// +#ifndef DIMM_ENABLED +#define DIMM_ENABLED 0 // DIMM/rank Pair is enabled, presence will be detected. +#endif +#ifndef DIMM_DISABLED +#define DIMM_DISABLED 1 // DIMM/rank Pair is disabled, regardless of presence. +#endif +#ifndef DIMM_PRESENT +#define DIMM_PRESENT 2 // There is a DIMM present in the slot/rank pair and it will be used. +#endif +#ifndef DIMM_NOT_PRESENT +#define DIMM_NOT_PRESENT 3 // There is no DIMM present in the slot/rank pair. +#endif + +// +// Matches MrcBootMode enum in MRC +// +#ifndef __MRC_BOOT_MODE__ +#define __MRC_BOOT_MODE__ //The below values are originated from MrcCommonTypes.h + #ifndef INT32_MAX + #define INT32_MAX (0x7FFFFFFF) + #endif //INT32_MAX +typedef enum { + bmCold, ///< Cold boot + bmWarm, ///< Warm boot + bmS3, ///< S3 resume + bmFast, ///< Fast boot + MrcBootModeMax, ///< MRC_BOOT_MODE enumeration maximum value. + MrcBootModeDelim = INT32_MAX ///< This value ensures the enum size is consistent on both sides of the PPI. +} MRC_BOOT_MODE; +#endif //__MRC_BOOT_MODE__ + +// +// Matches MrcDdrType enum in MRC +// +#ifndef MRC_DDR_TYPE_DDR5 +#define MRC_DDR_TYPE_DDR5 1 +#endif +#ifndef MRC_DDR_TYPE_LPDDR5 +#define MRC_DDR_TYPE_LPDDR5 2 +#endif +#ifndef MRC_DDR_TYPE_LPDDR4 +#define MRC_DDR_TYPE_LPDDR4 3 +#endif +#ifndef MRC_DDR_TYPE_UNKNOWN +#define MRC_DDR_TYPE_UNKNOWN 4 +#endif + +#define MAX_PROFILE_NUM 7 // number of memory profiles supported +#define MAX_XMP_PROFILE_NUM 5 // number of XMP profiles supported + +#define MAX_TRACE_REGION 5 +#define MAX_TRACE_CACHE_TYPE 2 + +// +// DIMM timings +// +typedef struct { + UINT32 tCK; ///< Memory cycle time, in femtoseconds. + UINT16 NMode; ///< Number of tCK cycles for the channel DIMM's command rate mode. + UINT16 tCL; ///< Number of tCK cycles for the channel DIMM's CAS latency. + UINT16 tCWL; ///< Number of tCK cycles for the channel DIMM's minimum CAS write latency time. + UINT16 tFAW; ///< Number of tCK cycles for the channel DIMM's minimum four activate window delay time. + UINT16 tRAS; ///< Number of tCK cycles for the channel DIMM's minimum active to precharge delay time. + UINT16 tRCDtRP; ///< Number of tCK cycles for the channel DIMM's minimum RAS# to CAS# delay time and Row Precharge delay time. + UINT16 tREFI; ///< Number of tCK cycles for the channel DIMM's minimum Average Periodic Refresh Interval. + UINT16 tRFC; ///< Number of tCK cycles for the channel DIMM's minimum refresh recovery delay time. + UINT16 tRFCpb; ///< Number of tCK cycles for the channel DIMM's minimum per bank refresh recovery delay time. + UINT16 tRFC2; ///< Number of tCK cycles for the channel DIMM's minimum refresh recovery delay time. + UINT16 tRFC4; ///< Number of tCK cycles for the channel DIMM's minimum refresh recovery delay time. + UINT16 tRPab; ///< Number of tCK cycles for the channel DIMM's minimum row precharge delay time for all banks. + UINT16 tRRD; ///< Number of tCK cycles for the channel DIMM's minimum row active to row active delay time. + UINT16 tRRD_L; ///< Number of tCK cycles for the channel DIMM's minimum row active to row active delay time for same bank groups. + UINT16 tRRD_S; ///< Number of tCK cycles for the channel DIMM's minimum row active to row active delay time for different bank groups. + UINT16 tRTP; ///< Number of tCK cycles for the channel DIMM's minimum internal read to precharge command delay time. + UINT16 tWR; ///< Number of tCK cycles for the channel DIMM's minimum write recovery time. + UINT16 tWTR; ///< Number of tCK cycles for the channel DIMM's minimum internal write to read command delay time. + UINT16 tWTR_L; ///< Number of tCK cycles for the channel DIMM's minimum internal write to read command delay time for same bank groups. + UINT16 tWTR_S; ///< Number of tCK cycles for the channel DIMM's minimum internal write to read command delay time for different bank groups. + UINT16 tCCD_L; ///< Number of tCK cycles for the channel DIMM's minimum CAS-to-CAS delay for same bank group. +} MRC_CH_TIMING; + +typedef struct { + UINT16 tRDPRE; ///< Read CAS to Precharge cmd delay +} MRC_IP_TIMING; + +/// +/// Memory SMBIOS & OC Memory Data Hob +/// +typedef struct { + UINT8 Status; ///< See MrcDimmStatus for the definition of this field. + UINT8 DimmId; + UINT32 DimmCapacity; ///< DIMM size in MBytes. + UINT16 MfgId; + UINT8 ModulePartNum[20]; ///< Module part number for DDR3 is 18 bytes however for DRR4 20 bytes as per JEDEC Spec, so reserving 20 bytes + UINT8 RankInDimm; ///< The number of ranks in this DIMM. + UINT8 SpdDramDeviceType; ///< Save SPD DramDeviceType information needed for SMBIOS structure creation. + UINT8 SpdModuleType; ///< Save SPD ModuleType information needed for SMBIOS structure creation. + UINT8 SpdModuleMemoryBusWidth; ///< Save SPD ModuleMemoryBusWidth information needed for SMBIOS structure creation. + UINT8 SpdSave[MAX_SPD_SAVE]; ///< Save SPD Manufacturing information needed for SMBIOS structure creation. + UINT16 Speed; ///< The maximum capable speed of the device, in MHz + UINT8 MdSocket; ///< MdSocket: 0 = Memory Down, 1 = Socketed. Needed for SMBIOS structure creation. +} DIMM_INFO; + +typedef struct { + UINT8 Status; ///< Indicates whether this channel should be used. + UINT8 ChannelId; + UINT8 DimmCount; ///< Number of valid DIMMs that exist in the channel. + MRC_CH_TIMING Timing[MAX_PROFILE_NUM]; ///< The channel timing values. + DIMM_INFO DimmInfo[MAX_DIMM]; ///< Save the DIMM output characteristics. +} CHANNEL_INFO; + +typedef struct { + UINT8 Status; ///< Indicates whether this controller should be used. + UINT16 DeviceId; ///< The PCI device id of this memory controller. + UINT8 RevisionId; ///< The PCI revision id of this memory controller. + UINT8 ChannelCount; ///< Number of valid channels that exist on the controller. + CHANNEL_INFO ChannelInfo[MAX_CH]; ///< The following are channel level definitions. +} CONTROLLER_INFO; + +typedef struct { + UINT64 BaseAddress; ///< Trace Base Address + UINT64 TotalSize; ///< Total Trace Region of Same Cache type + UINT8 CacheType; ///< Trace Cache Type + UINT8 ErrorCode; ///< Trace Region Allocation Fail Error code + UINT8 Rsvd[2]; +} PSMI_MEM_INFO; + +/// This data structure contains per-SaGv timing values that are considered output by the MRC. +typedef struct { + UINT32 DataRate; ///< The memory rate for the current SaGv Point in units of MT/s + MRC_CH_TIMING JedecTiming; ///< Timings used for this entry's corresponding SaGv Point - derived from JEDEC SPD spec + MRC_IP_TIMING IpTiming; ///< Timings used for this entry's corresponding SaGv Point - IP specific +} HOB_SAGV_TIMING_OUT; + +/// This data structure contains SAGV config values that are considered output by the MRC. +typedef struct { + UINT32 NumSaGvPointsEnabled; ///< Count of the total number of SAGV Points enabled. + UINT32 SaGvPointMask; ///< Bit mask where each bit indicates an enabled SAGV point. + HOB_SAGV_TIMING_OUT SaGvTiming[HOB_MAX_SAGV_POINTS]; +} HOB_SAGV_INFO; + +typedef struct { + UINT8 Revision; + UINT16 DataWidth; ///< Data width, in bits, of this memory device + /** As defined in SMBIOS 3.0 spec + Section 7.18.2 and Table 75 + **/ + UINT8 MemoryType; ///< DDR type: DDR3, DDR4, or LPDDR3 + UINT16 MaximumMemoryClockSpeed;///< The maximum capable speed of the device, in megahertz (MHz) + UINT16 ConfiguredMemoryClockSpeed; ///< The configured clock speed to the memory device, in megahertz (MHz) + /** As defined in SMBIOS 3.0 spec + Section 7.17.3 and Table 72 + **/ + UINT8 ErrorCorrectionType; + + SiMrcVersion Version; + BOOLEAN EccSupport; + UINT8 MemoryProfile; + UINT32 TotalPhysicalMemorySize; + UINT32 DefaultXmptCK[MAX_XMP_PROFILE_NUM];///< Stores the tCK value read from SPD XMP profiles if they exist. + UINT8 XmpProfileEnable; ///< If XMP capable DIMMs are detected, this will indicate which XMP Profiles are common among all DIMMs. + UINT8 XmpConfigWarning; ///< If XMP capable DIMMs config support only 1DPC, but 2DPC is installed + BOOLEAN DynamicMemoryBoostTrainingFailed; ///< TRUE if Dynamic Memory Boost failed to train and was force disabled on the last full training boot. FALSE otherwise. + UINT8 Ratio; ///< DDR Frequency Ratio, Max Value 255 + UINT8 RefClk; + UINT32 VddVoltage[MAX_PROFILE_NUM]; + UINT32 VddqVoltage[MAX_PROFILE_NUM]; + UINT32 VppVoltage[MAX_PROFILE_NUM]; + CONTROLLER_INFO Controller[MAX_NODE]; + UINT16 Ratio_UINT16; ///< DDR Frequency Ratio, used for programs that require ratios higher then 255 + UINT32 NumPopulatedChannels; ///< Total number of memory channels populated + HOB_SAGV_INFO SagvConfigInfo; ///< This data structure contains SAGV config values that are considered output by the MRC. + BOOLEAN IsIbeccEnabled; + UINT16 TotalMemWidth; ///< Total Memory Width in bits from all populated channels +} MEMORY_INFO_DATA_HOB; + +/** + Memory Platform Data Hob + + Revision 1: + - Initial version. + Revision 2: + - Added TsegBase, PrmrrSize, PrmrrBase, Gttbase, MmioSize, PciEBaseAddress fields +**/ +typedef struct { + UINT8 Revision; + UINT8 Reserved[3]; + UINT32 BootMode; + UINT32 TsegSize; + UINT32 TsegBase; + UINT32 PrmrrSize; + UINT64 PrmrrBase; + UINT32 GttBase; + UINT32 MmioSize; + UINT32 PciEBaseAddress; + PSMI_MEM_INFO PsmiInfo[MAX_TRACE_CACHE_TYPE]; + PSMI_MEM_INFO PsmiRegionInfo[MAX_TRACE_REGION]; + BOOLEAN MrcBasicMemoryTestPass; +} MEMORY_PLATFORM_DATA; + +typedef struct { + EFI_HOB_GUID_TYPE EfiHobGuidType; + MEMORY_PLATFORM_DATA Data; + UINT8 *Buffer; +} MEMORY_PLATFORM_DATA_HOB; + +#pragma pack (pop) + +#endif // _MEM_INFO_HOB_H_