soc/intel/apollolake: Update FSP header files
Update autogenerated FSP 2.0 generic header files based on FSP release 136_30. Changes were made to avoid duplicating some of the structs for every SoC. BUG=chrome-os-partner:50765 TEST=Build coreboot Change-Id: I6f3c9270fb67210d6ea87e17ccf52d203fa64b4b Signed-off-by: Bora Guvendik <bora.guvendik@intel.com> Reviewed-on: https://chromium.devtools.intel.com/7145 Reviewed-by: Petrov, Andrey <andrey.petrov@intel.com> Tested-by: Petrov, Andrey <andrey.petrov@intel.com> Reviewed-on: https://chromium.devtools.intel.com/7584 Reviewed-on: https://review.coreboot.org/15081 Tested-by: build bot (Jenkins) Reviewed-by: Aaron Durbin <adurbin@chromium.org>
This commit is contained in:
parent
1a718642ea
commit
de4b09fa26
5 changed files with 443 additions and 217 deletions
64
src/drivers/intel/fsp2_0/include/fsp/upd.h
Normal file
64
src/drivers/intel/fsp2_0/include/fsp/upd.h
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
/*
|
||||||
|
* This file is part of the coreboot project.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2016 Intel Corp.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _FSP2_0_UPD_H_
|
||||||
|
#define _FSP2_0_UPD_H_
|
||||||
|
|
||||||
|
struct FSP_UPD_HEADER {
|
||||||
|
///
|
||||||
|
/// UPD Region Signature. This signature will be
|
||||||
|
/// "XXXXXX_T" for FSP-T
|
||||||
|
/// "XXXXXX_M" for FSP-M
|
||||||
|
/// "XXXXXX_S" for FSP-S
|
||||||
|
/// Where XXXXXX is an unique signature
|
||||||
|
///
|
||||||
|
uint64_t Signature;
|
||||||
|
///
|
||||||
|
/// Revision of the Data structure. For FSP v2.0 value is 1.
|
||||||
|
///
|
||||||
|
uint8_t Revision;
|
||||||
|
uint8_t Reserved[23];
|
||||||
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
struct FSPM_ARCH_UPD {
|
||||||
|
///
|
||||||
|
/// Revision of the structure. For FSP v2.0 value is 1.
|
||||||
|
///
|
||||||
|
uint8_t Revision;
|
||||||
|
uint8_t Reserved[3];
|
||||||
|
///
|
||||||
|
/// Pointer to the non-volatile storage (NVS) data buffer.
|
||||||
|
/// If it is NULL it indicates the NVS data is not available.
|
||||||
|
///
|
||||||
|
void *NvsBufferPtr;
|
||||||
|
///
|
||||||
|
/// Pointer to the temporary stack base address to be
|
||||||
|
/// consumed inside FspMemoryInit() API.
|
||||||
|
///
|
||||||
|
void *StackBase;
|
||||||
|
///
|
||||||
|
/// Temporary stack size to be consumed inside
|
||||||
|
/// FspMemoryInit() API.
|
||||||
|
///
|
||||||
|
uint32_t StackSize;
|
||||||
|
///
|
||||||
|
/// Size of memory to be reserved by FSP below "top
|
||||||
|
/// of low usable memory" for bootloader usage.
|
||||||
|
///
|
||||||
|
uint32_t BootLoaderTolumSize;
|
||||||
|
///
|
||||||
|
/// Current boot mode.
|
||||||
|
///
|
||||||
|
uint32_t BootMode;
|
||||||
|
uint8_t Reserved1[8];
|
||||||
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
#endif /* _FSP2_0_UPD_H_ */
|
|
@ -1,42 +1,42 @@
|
||||||
/*
|
/** @file
|
||||||
* This file is part of the coreboot project.
|
|
||||||
*
|
|
||||||
* Copyright (C) 2016 Intel Corp.
|
|
||||||
* (Written by Lance Zhao <lijian.zhao@intel.com> for Intel Corp.)
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef _FSP_API_H_
|
Copyright (c) 2016, Intel Corporation. All rights reserved.<BR>
|
||||||
#define _FSP_API_H_
|
|
||||||
|
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 !!!
|
||||||
|
|
||||||
/** FSP UPD Header
|
|
||||||
**/
|
**/
|
||||||
struct FSP_UPD_HEADER {
|
|
||||||
|
|
||||||
/** Offset 0x00 to 0x07 - UPD Region Signature
|
#ifndef __FSPUPD_H__
|
||||||
The signature will be
|
#define __FSPUPD_H__
|
||||||
"FSPT_UPD" for FSP-T
|
|
||||||
"FSPM_UPD" for FSP-M
|
|
||||||
"FSPS_UPD" for FSP-S
|
|
||||||
**/
|
|
||||||
uint64_t Signature;
|
|
||||||
|
|
||||||
/** Offset 0x08 - Revision
|
#define FSPT_UPD_SIGNATURE 0x4450555F54505346 /* 'FSPT_UPD' */
|
||||||
**/
|
|
||||||
uint8_t Revision;
|
|
||||||
|
|
||||||
/** Offset 0x09 to 0x1F - ReservedUpd
|
#define FSPM_UPD_SIGNATURE 0x4450555F4D505346 /* 'FSPM_UPD' */
|
||||||
**/
|
|
||||||
uint8_t ReservedUpd[23];
|
|
||||||
} __attribute__((packed));
|
|
||||||
|
|
||||||
#endif /* _FSP_API_H_ */
|
#define FSPS_UPD_SIGNATURE 0x4450555F53505346 /* 'FSPS_UPD' */
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
|
@ -34,111 +34,28 @@ are permitted provided that the following conditions are met:
|
||||||
#define __FSPMUPD_H__
|
#define __FSPMUPD_H__
|
||||||
|
|
||||||
#include "FspUpd.h"
|
#include "FspUpd.h"
|
||||||
|
#include <fsp/upd.h>
|
||||||
|
|
||||||
typedef union {
|
|
||||||
uint32_t PadCnf0;
|
|
||||||
struct {
|
|
||||||
uint32_t GPIOTxState:1; ///< 0 GPIO TX State
|
|
||||||
uint32_t GPIORxState:1; ///< 1 GPIO RX State, RO
|
|
||||||
uint32_t Reserved1:6; ///< 2-7 Reserved, RO
|
|
||||||
uint32_t GPIORxTxDis:2; ///< 8-9 GPIO RX Disable[9], GPIO TX Disable[8]
|
|
||||||
uint32_t PMode:3; ///< 10-12 Pad Mode, 0h = GPIO Controller controls the Pad; 1h = Native Function 1, if applicable, controls the pad; 2h = Native Function 2, if applicable, controls the pad, etc.
|
|
||||||
uint32_t Reserved2:4; ///< 13-16 Reserved, RO
|
|
||||||
uint32_t GPIRout:4; ///< 17-20 Route to IOxAPIC[20], SCI[19], SMI[18], NMI[17]
|
|
||||||
uint32_t RXTXEnCfg:2; ///< 21-22 RX/TX Enable Config (RXTXEnCfg) RO
|
|
||||||
uint32_t RXINV:1; ///< 23 RX Invert, 0 = No inversion; 1 = Inversion
|
|
||||||
uint32_t PreGfRXSel:1; ///< 24 Pre Glitch Filter Stage RX Pad State Select, RO, not support in BXT
|
|
||||||
uint32_t RxEvCfg:2; ///< 25-26 0h = Level 1h = Edge (RxInv=0 for rising edge; 1 for falling edge), 2h = Disabled ,3h = Either rising edge or falling edge
|
|
||||||
uint32_t Reserved3:1; ///< 27 RO
|
|
||||||
uint32_t RXRAW1:1; ///< 28 Override the RX to 1
|
|
||||||
uint32_t RXPadStSel:1; ///< 29 RX Pad State Select
|
|
||||||
uint32_t PadRstCfg:2; ///< 30-31 Pad Reset Config
|
|
||||||
} r;
|
|
||||||
} BL_CONF_PAD0;
|
|
||||||
|
|
||||||
typedef union {
|
|
||||||
uint32_t PadCnf1;
|
|
||||||
struct {
|
|
||||||
uint32_t IntSel:7; ///< 0-6 Interrupt Select. RO
|
|
||||||
uint32_t Reserved:1; ///< 7 Reserved.
|
|
||||||
uint32_t IOSTerm:2; ///< 8-9 I/O Standby Termination (IOSTerm) RW
|
|
||||||
uint32_t Term:4; ///< 10-13 Termination,
|
|
||||||
///< 0 000: none;0 010: 5k wpd;0 100: 20k wpd;1 000: none;1 001: 1k wpu;1 011: 2k wpu;1 010: 5k wpu;
|
|
||||||
///< 1 100: 20k wpu;1 101: 1k & 2k wpu;1 111: (optional) Native controller selected by Pad Mode controls the Termination
|
|
||||||
uint32_t IOSState:4; ///< 14-17 I/O Standby State, I/O Standby is not implemented in BXT, RW
|
|
||||||
uint32_t CFIOPadCfg:14; ///< 18-31 For BXT, this is done thru Family Register if necessary. RO
|
|
||||||
} r;
|
|
||||||
} BL_CONF_PAD1;
|
|
||||||
|
|
||||||
struct BL_GPIO_PAD_INIT {
|
|
||||||
BL_CONF_PAD0 PadConfg0;
|
|
||||||
BL_CONF_PAD1 PadConfg1;
|
|
||||||
uint8_t Community;
|
|
||||||
uint16_t MmioAddress;
|
|
||||||
bool HostSw;
|
|
||||||
bool WakeEnabled;
|
|
||||||
wchar_t *PadName;
|
|
||||||
} __attribute__((packed));
|
|
||||||
|
|
||||||
/** Fsp M Architectural UPD
|
|
||||||
**/
|
|
||||||
struct FSP_M_ARCH_UPD {
|
|
||||||
|
|
||||||
/** Offset 0x0020
|
|
||||||
**/
|
|
||||||
uint8_t Revision;
|
|
||||||
|
|
||||||
/** Offset 0x0021
|
|
||||||
**/
|
|
||||||
uint8_t Reserved[3];
|
|
||||||
|
|
||||||
/** Offset 0x0024
|
|
||||||
**/
|
|
||||||
void* NvsBufferPtr;
|
|
||||||
|
|
||||||
/** Offset 0x0028 - StackBase
|
|
||||||
To hold the stack base.
|
|
||||||
**/
|
|
||||||
void* StackBase;
|
|
||||||
|
|
||||||
/** Offset 0x002C - StackSize
|
|
||||||
To hold the stack size.
|
|
||||||
**/
|
|
||||||
uint32_t StackSize;
|
|
||||||
|
|
||||||
/** Offset 0x0030 - BootLoaderTolumSize
|
|
||||||
To pass Bootloader Tolum size.
|
|
||||||
**/
|
|
||||||
uint32_t BootLoaderTolumSize;
|
|
||||||
|
|
||||||
/** Offset 0x0034 - Bootmode
|
|
||||||
To maintain Bootmode details.
|
|
||||||
**/
|
|
||||||
uint32_t Bootmode;
|
|
||||||
|
|
||||||
/** Offset 0x0038
|
|
||||||
**/
|
|
||||||
uint8_t Reserved1[8];
|
|
||||||
} __attribute__((packed));
|
|
||||||
|
|
||||||
/** Fsp M Configuration
|
/** Fsp M Configuration
|
||||||
**/
|
**/
|
||||||
struct FSP_M_CONFIG {
|
struct FSP_M_CONFIG {
|
||||||
|
|
||||||
/** Offset 0x0040 - Debug Serial Port Base address
|
/** Offset 0x0040 - Debug Serial Port Base address
|
||||||
Debug serial port base address. This option will be used only when the 'Serial Port Debug Device' option is set to 'External Device'. 0x00000000(Default).
|
Debug serial port base address. This option will be used only when the 'Serial Port
|
||||||
|
Debug Device' option is set to 'External Device'. 0x00000000(Default).
|
||||||
**/
|
**/
|
||||||
uint32_t SerialDebugPortAddress;
|
uint32_t SerialDebugPortAddress;
|
||||||
|
|
||||||
/** Offset 0x0044 - Debug Serial Port Type
|
/** Offset 0x0044 - Debug Serial Port Type
|
||||||
16550 compatible debug serial port resource type. NONE means no serial port support. 0x02:MMIO(Default).
|
16550 compatible debug serial port resource type. NONE means no serial port support.
|
||||||
|
0x02:MMIO(Default).
|
||||||
0:NONE, 1:I/O, 2:MMIO
|
0:NONE, 1:I/O, 2:MMIO
|
||||||
**/
|
**/
|
||||||
uint8_t SerialDebugPortType;
|
uint8_t SerialDebugPortType;
|
||||||
|
|
||||||
/** Offset 0x0045 - Serial Port Debug Device
|
/** Offset 0x0045 - Serial Port Debug Device
|
||||||
Select active serial port device for debug. For SOC UART devices,'Debug Serial Port Base' options will be ignored. 0x02:SOC UART2(Default).
|
Select active serial port device for debug. For SOC UART devices,'Debug Serial Port
|
||||||
|
Base' options will be ignored. 0x02:SOC UART2(Default).
|
||||||
0:SOC UART0, 1:SOC UART1, 2:SOC UART2, 3:External Device
|
0:SOC UART0, 1:SOC UART1, 2:SOC UART2, 3:External Device
|
||||||
**/
|
**/
|
||||||
uint8_t SerialDebugPortDevice;
|
uint8_t SerialDebugPortDevice;
|
||||||
|
@ -156,44 +73,63 @@ struct FSP_M_CONFIG {
|
||||||
uint8_t MrcFastBoot;
|
uint8_t MrcFastBoot;
|
||||||
|
|
||||||
/** Offset 0x0048 - Integrated Graphics Device
|
/** Offset 0x0048 - Integrated Graphics Device
|
||||||
Enable : Enable Integrated Graphics Device (IGD) when selected as the Primary Video Adaptor. Disable: Always disable IGD. 0x00:Disable, 0x01:Enable(Default).
|
Enable : Enable Integrated Graphics Device (IGD) when selected as the Primary Video
|
||||||
|
Adaptor. Disable: Always disable IGD. 0x00:Disable, 0x01:Enable(Default).
|
||||||
$EN_DIS
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t Igd;
|
uint8_t Igd;
|
||||||
|
|
||||||
/** Offset 0x0049 - DVMT Pre-Allocated
|
/** Offset 0x0049 - DVMT Pre-Allocated
|
||||||
Select DVMT 5.0 Pre-Allocated (Fixed) Graphics Memory size used by the Internal Graphics Device. 0x02:64 MB(Default).
|
Select DVMT 5.0 Pre-Allocated (Fixed) Graphics Memory size used by the Internal
|
||||||
0x02:64 MB, 0x03:96 MB, 0x04:128 MB, 0x05:160 MB, 0x06:192 MB, 0x07:224 MB, 0x08:256 MB, 0x09:288 MB, 0x0A:320 MB, 0x0B:352 MB, 0x0C:384 MB, 0x0D:416 MB, 0x0E:448 MB, 0x0F:480 MB, 0x10:512 MB
|
Graphics Device. 0x02:64 MB(Default).
|
||||||
|
0x02:64 MB, 0x03:96 MB, 0x04:128 MB, 0x05:160 MB, 0x06:192 MB, 0x07:224 MB, 0x08:256
|
||||||
|
MB, 0x09:288 MB, 0x0A:320 MB, 0x0B:352 MB, 0x0C:384 MB, 0x0D:416 MB, 0x0E:448 MB,
|
||||||
|
0x0F:480 MB, 0x10:512 MB
|
||||||
**/
|
**/
|
||||||
uint8_t IgdDvmt50PreAlloc;
|
uint8_t IgdDvmt50PreAlloc;
|
||||||
|
|
||||||
/** Offset 0x004A - Aperture Size
|
/** Offset 0x004A - Aperture Size
|
||||||
Select the Aperture Size used by the Internal Graphics Device. 0x1:128 MB(Default), 0x2:256 MB, 0x3:512 MB.
|
Select the Aperture Size used by the Internal Graphics Device. 0x1:128 MB(Default),
|
||||||
|
0x2:256 MB, 0x3:512 MB.
|
||||||
0x1:128 MB, 0x2:256 MB, 0x3:512 MB
|
0x1:128 MB, 0x2:256 MB, 0x3:512 MB
|
||||||
**/
|
**/
|
||||||
uint8_t IgdApertureSize;
|
uint8_t IgdApertureSize;
|
||||||
|
|
||||||
/** Offset 0x004B - GTT Size
|
/** Offset 0x004B - GTT Size
|
||||||
Select the GTT Size used by the Internal Graphics Device. 0x1:2 MB, 0x2:4 MB, 0x3:8 MB(Default).
|
Select the GTT Size used by the Internal Graphics Device. 0x1:2 MB, 0x2:4 MB, 0x3:8
|
||||||
|
MB(Default).
|
||||||
0x1:2 MB, 0x2:4 MB, 0x3:8 MB
|
0x1:2 MB, 0x2:4 MB, 0x3:8 MB
|
||||||
**/
|
**/
|
||||||
uint8_t GttSize;
|
uint8_t GttSize;
|
||||||
|
|
||||||
/** Offset 0x004C - Primary Display
|
/** Offset 0x004C - Primary Display
|
||||||
Select which of IGD/PCI Graphics device should be Primary Display. 0x0:AUTO(Default), 0x2:IGD, 0x3:PCI
|
Select which of IGD/PCI Graphics device should be Primary Display. 0x0:AUTO(Default),
|
||||||
|
0x2:IGD, 0x3:PCI
|
||||||
0x0:AUTO, 0x2:IGD, 0x3:PCI
|
0x0:AUTO, 0x2:IGD, 0x3:PCI
|
||||||
**/
|
**/
|
||||||
uint8_t PrimaryVideoAdaptor;
|
uint8_t PrimaryVideoAdaptor;
|
||||||
|
|
||||||
/** Offset 0x004D - Package
|
/** Offset 0x004D - Package
|
||||||
NOTE: First option is CoPOP if LPDDR3/LPDDR4 is being used. It is SODIMM if DDR3L is being used. 0x00(Default).
|
NOTE: First option is CoPOP if LPDDR3/LPDDR4 is being used. It is SODIMM if DDR3L
|
||||||
|
is being used. 0x00(Default).
|
||||||
0x0:CoPop, 0x1:BGA, 0x2:LP3 ACRD
|
0x0:CoPop, 0x1:BGA, 0x2:LP3 ACRD
|
||||||
**/
|
**/
|
||||||
uint8_t Package;
|
uint8_t Package;
|
||||||
|
|
||||||
/** Offset 0x004E - Profile
|
/** Offset 0x004E - Profile
|
||||||
Profile list. 0x19(Default).
|
Profile list. 0x19(Default).
|
||||||
0x1:WIO2_800_7_8_8, 0x2:WIO2_1066_9_10_10, 0x3:LPDDR3_1066_8_10_10, 0x4:LPDDR3_1333_10_12_12, 0x5:LPDDR3_1600_12_15_15, 0x6:LPDDR3_1866_14_17_17, 0x7:LPDDR3_2133_16_20_20, 0x8:LPDDR4_1066_10_10_10, 0x9:LPDDR4_1600_14_15_15, 0xA:LPDDR4_2133_20_20_20, 0xB:LPDDR4_2400_24_22_22, 0xC:LPDDR4_2666_24_24_24, 0xD:LPDDR4_2933_28_27_27, 0xE:LPDDR4_3200_28_29_29, 0xF:DDR3_1066_6_6_6, 0x10:DDR3_1066_7_7_7, 0x11:DDR3_1066_8_8_8, 0x12:DDR3_1333_7_7_7, 0x13:DDR3_1333_8_8_8, 0x14:DDR3_1333_9_9_9, 0x15:DDR3_1333_10_10_10, 0x16:DDR3_1600_8_8_8, 0x17:DDR3_1600_9_9_9, 0x18:DDR3_1600_10_10_10, 0x19:DDR3_1600_11_11_11, 0x1A:DDR3_1866_10_10_10, 0x1B:DDR3_1866_11_11_11, 0x1C:DDR3_1866_12_12_12, 0x1D:DDR3_1866_13_13_13, 0x1E:DDR3_2133_11_11_11, 0x1F:DDR3_2133_12_12_12, 0x20:DDR3_2133_13_13_13, 0x21:DDR3_2133_14_14_14, 0x22:DDR4_1333_10_10_10, 0x23:DDR4_1600_10_10_10, 0x24:DDR4_1600_11_11_11, 0x25:DDR4_1600_12_12_12, 0x26:DDR4_1866_12_12_12, 0x27:DDR4_1866_13_13_13, 0x28:DDR4_1866_14_14_14, 0x29:DDR4_2133_14_14_14, 0x2A:DDR4_2133_15_15_15, 0x2B:DDR4_2133_16_16_16, 0x2C:DDR4_2400_15_15_15, 0x2D:DDR4_2400_16_16_16, 0x2E:DDR4_2400_17_17_17, 0x2F:DDR4_2400_18_18_18
|
0x1:WIO2_800_7_8_8, 0x2:WIO2_1066_9_10_10, 0x3:LPDDR3_1066_8_10_10, 0x4:LPDDR3_1333_10_12_12,
|
||||||
|
0x5:LPDDR3_1600_12_15_15, 0x6:LPDDR3_1866_14_17_17, 0x7:LPDDR3_2133_16_20_20, 0x8:LPDDR4_1066_10_10_10,
|
||||||
|
0x9:LPDDR4_1600_14_15_15, 0xA:LPDDR4_2133_20_20_20, 0xB:LPDDR4_2400_24_22_22, 0xC:LPDDR4_2666_24_24_24,
|
||||||
|
0xD:LPDDR4_2933_28_27_27, 0xE:LPDDR4_3200_28_29_29, 0xF:DDR3_1066_6_6_6, 0x10:DDR3_1066_7_7_7,
|
||||||
|
0x11:DDR3_1066_8_8_8, 0x12:DDR3_1333_7_7_7, 0x13:DDR3_1333_8_8_8, 0x14:DDR3_1333_9_9_9,
|
||||||
|
0x15:DDR3_1333_10_10_10, 0x16:DDR3_1600_8_8_8, 0x17:DDR3_1600_9_9_9, 0x18:DDR3_1600_10_10_10,
|
||||||
|
0x19:DDR3_1600_11_11_11, 0x1A:DDR3_1866_10_10_10, 0x1B:DDR3_1866_11_11_11, 0x1C:DDR3_1866_12_12_12,
|
||||||
|
0x1D:DDR3_1866_13_13_13, 0x1E:DDR3_2133_11_11_11, 0x1F:DDR3_2133_12_12_12, 0x20:DDR3_2133_13_13_13,
|
||||||
|
0x21:DDR3_2133_14_14_14, 0x22:DDR4_1333_10_10_10, 0x23:DDR4_1600_10_10_10, 0x24:DDR4_1600_11_11_11,
|
||||||
|
0x25:DDR4_1600_12_12_12, 0x26:DDR4_1866_12_12_12, 0x27:DDR4_1866_13_13_13, 0x28:DDR4_1866_14_14_14,
|
||||||
|
0x29:DDR4_2133_14_14_14, 0x2A:DDR4_2133_15_15_15, 0x2B:DDR4_2133_16_16_16, 0x2C:DDR4_2400_15_15_15,
|
||||||
|
0x2D:DDR4_2400_16_16_16, 0x2E:DDR4_2400_17_17_17, 0x2F:DDR4_2400_18_18_18
|
||||||
**/
|
**/
|
||||||
uint8_t Profile;
|
uint8_t Profile;
|
||||||
|
|
||||||
|
@ -204,7 +140,7 @@ struct FSP_M_CONFIG {
|
||||||
uint8_t MemoryDown;
|
uint8_t MemoryDown;
|
||||||
|
|
||||||
/** Offset 0x0050 - DDR3LPageSize
|
/** Offset 0x0050 - DDR3LPageSize
|
||||||
NOTE: Only for memory down or downgrade DDR3L frequency. 0x01:1KB, 0x02:2KB, 0x00(Default).
|
NOTE: Only for memory down or downgrade DDR3L frequency. 0x01:1KB(Default), 0x02:2KB.
|
||||||
0x1:1KB, 0x2:2KB
|
0x1:1KB, 0x2:2KB
|
||||||
**/
|
**/
|
||||||
uint8_t DDR3LPageSize;
|
uint8_t DDR3LPageSize;
|
||||||
|
@ -232,8 +168,8 @@ struct FSP_M_CONFIG {
|
||||||
uint16_t SliceHashMask;
|
uint16_t SliceHashMask;
|
||||||
|
|
||||||
/** Offset 0x0057 - InterleavedMode
|
/** Offset 0x0057 - InterleavedMode
|
||||||
Interleaved Mode. 0x00:Disable(Default), 0x01:Enable.
|
Interleaved Mode. 0x00:Disable(Default), 0x02:Enable.
|
||||||
$EN_DIS
|
0x0:Disable, 0x2:Enable
|
||||||
**/
|
**/
|
||||||
uint8_t InterleavedMode;
|
uint8_t InterleavedMode;
|
||||||
|
|
||||||
|
@ -244,7 +180,8 @@ struct FSP_M_CONFIG {
|
||||||
uint8_t ChannelsSlicesEnable;
|
uint8_t ChannelsSlicesEnable;
|
||||||
|
|
||||||
/** Offset 0x0059 - MinRefRate2xEnable
|
/** Offset 0x0059 - MinRefRate2xEnable
|
||||||
Provided as a means to defend against Row-Hammer attacks. 0x00:Disable(Default), 0x01:Enable.
|
Provided as a means to defend against Row-Hammer attacks. 0x00:Disable(Default),
|
||||||
|
0x01:Enable.
|
||||||
$EN_DIS
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t MinRefRate2xEnable;
|
uint8_t MinRefRate2xEnable;
|
||||||
|
@ -262,23 +199,30 @@ struct FSP_M_CONFIG {
|
||||||
uint8_t RmtMode;
|
uint8_t RmtMode;
|
||||||
|
|
||||||
/** Offset 0x005C - MemorySizeLimit
|
/** Offset 0x005C - MemorySizeLimit
|
||||||
Memory Size Limit: This value is used to restrict the total amount of memory and the calculations based on it. Value is in MB. Example encodings are: 0x400 = 1GB, 0x800 = 2GB, 0x1000 = 4GB, 0x2000 8GB. 0x0000(Default)
|
Memory Size Limit: This value is used to restrict the total amount of memory and
|
||||||
|
the calculations based on it. Value is in MB. Example encodings are: 0x400 = 1GB,
|
||||||
|
0x800 = 2GB, 0x1000 = 4GB, 0x2000 8GB. 0x0000(Default)
|
||||||
**/
|
**/
|
||||||
uint16_t MemorySizeLimit;
|
uint16_t MemorySizeLimit;
|
||||||
|
|
||||||
/** Offset 0x005E - LowMemoryMaxValue
|
/** Offset 0x005E - LowMemoryMaxValue
|
||||||
Low Memory Max Value: This value is used to restrict the amount of memory below 4GB and the calculations based on it. Value is in MB.Example encodings are: 0x400 = 1GB, 0x800 = 2GB, 0x1000 = 4GB, 0x2000 8GB. 0x0000(Default).
|
Low Memory Max Value: This value is used to restrict the amount of memory below
|
||||||
|
4GB and the calculations based on it. Value is in MB.Example encodings are: 0x400
|
||||||
|
= 1GB, 0x800 = 2GB, 0x1000 = 4GB, 0x2000 8GB. 0x0000(Default).
|
||||||
**/
|
**/
|
||||||
uint16_t LowMemoryMaxValue;
|
uint16_t LowMemoryMaxValue;
|
||||||
|
|
||||||
/** Offset 0x0060 - DisableFastBoot
|
/** Offset 0x0060 - DisableFastBoot
|
||||||
00:Disabled Used saved training data (if valid)(Default), 01:Enabled; Full re-train of memory.
|
00:Disabled Used saved training data (if valid)(Default), 01:Enabled; Full re-train
|
||||||
|
of memory.
|
||||||
$EN_DIS
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t DisableFastBoot;
|
uint8_t DisableFastBoot;
|
||||||
|
|
||||||
/** Offset 0x0061 - HighMemoryMaxValue
|
/** Offset 0x0061 - HighMemoryMaxValue
|
||||||
High Memory Max Value: This value is used to restrict the amount of memory above 4GB and the calculations based on it. Value is in MB. Example encodings are: 0x0400:1GB, 0x0800:2GB, 0x1000:4GB, 0x2000:8GB. 0x00(Default).
|
High Memory Max Value: This value is used to restrict the amount of memory above
|
||||||
|
4GB and the calculations based on it. Value is in MB. Example encodings are: 0x0400:1GB,
|
||||||
|
0x0800:2GB, 0x1000:4GB, 0x2000:8GB. 0x00(Default).
|
||||||
**/
|
**/
|
||||||
uint16_t HighMemoryMaxValue;
|
uint16_t HighMemoryMaxValue;
|
||||||
|
|
||||||
|
@ -310,7 +254,12 @@ struct FSP_M_CONFIG {
|
||||||
uint8_t Ch0_DramDensity;
|
uint8_t Ch0_DramDensity;
|
||||||
|
|
||||||
/** Offset 0x0068 - Ch0_Option
|
/** Offset 0x0068 - Ch0_Option
|
||||||
Rank Select Interleaving Enable. See Address Mapping section for full description. 0:Rank Select Interleaving disabled, 1:Rank Select Interleaving enabled. [1] Bank Address Hashing Enable. See Address Mapping section for full description. 0:Bank Address Hashing disabled, 1:Bank Address Hashing enabled. [3:2] Reserved. [5:4] This register specifies the address mapping to be used: 00:1KB (A), 01:2KB (B). 0x03(Default).
|
Rank Select Interleaving Enable. See Address Mapping section for full description.
|
||||||
|
0:Rank Select Interleaving disabled, 1:Rank Select Interleaving enabled. [1] Bank
|
||||||
|
Address Hashing Enable. See Address Mapping section for full description. 0:Bank
|
||||||
|
Address Hashing disabled, 1:Bank Address Hashing enabled. [3:2] Reserved. [5:4]
|
||||||
|
This register specifies the address mapping to be used: 00:1KB (A), 01:2KB (B).
|
||||||
|
0x03(Default).
|
||||||
**/
|
**/
|
||||||
uint8_t Ch0_Option;
|
uint8_t Ch0_Option;
|
||||||
|
|
||||||
|
@ -330,7 +279,11 @@ struct FSP_M_CONFIG {
|
||||||
uint8_t Ch0_Mode2N;
|
uint8_t Ch0_Mode2N;
|
||||||
|
|
||||||
/** Offset 0x006C - Ch0_OdtLevels
|
/** Offset 0x006C - Ch0_OdtLevels
|
||||||
Rank Select Interleaving Enable. See Address Mapping section for full description. 0:Rank Select Interleaving disabled(Default), 1:Rank Select Interleaving enabled. [1] Bank Address Hashing Enable. See Address Mapping section for full description. 0:Bank Address Hashing disabled, 1:Bank Address Hashing enabled. [3:2] Reserved. [5:4] This register specifies the address mapping to be used:00:1KB (A), 01:2KB (B).
|
Rank Select Interleaving Enable. See Address Mapping section for full description.
|
||||||
|
0:Rank Select Interleaving disabled(Default), 1:Rank Select Interleaving enabled.
|
||||||
|
[1] Bank Address Hashing Enable. See Address Mapping section for full description.
|
||||||
|
0:Bank Address Hashing disabled, 1:Bank Address Hashing enabled. [3:2] Reserved.
|
||||||
|
[5:4] This register specifies the address mapping to be used:00:1KB (A), 01:2KB (B).
|
||||||
**/
|
**/
|
||||||
uint8_t Ch0_OdtLevels;
|
uint8_t Ch0_OdtLevels;
|
||||||
|
|
||||||
|
@ -352,7 +305,12 @@ struct FSP_M_CONFIG {
|
||||||
uint8_t Ch1_DramDensity;
|
uint8_t Ch1_DramDensity;
|
||||||
|
|
||||||
/** Offset 0x0070 - Ch1_Option
|
/** Offset 0x0070 - Ch1_Option
|
||||||
Rank Select Interleaving Enable. See Address Mapping section for full description. 0 - Rank Select Interleaving disabled. 1 - Rank Select Interleaving enabled. [1] Bank Address Hashing Enable. See Address Mapping section for full description. 0 - Bank Address Hashing disabled. 1 - Bank Address Hashing enabled. [3:2] Reserved. [5:4] This register specifies the address mapping to be used: 00:1KB (A), 01:2KB (B), 0x03(Default).
|
Rank Select Interleaving Enable. See Address Mapping section for full description.
|
||||||
|
0 - Rank Select Interleaving disabled. 1 - Rank Select Interleaving enabled. [1]
|
||||||
|
Bank Address Hashing Enable. See Address Mapping section for full description.
|
||||||
|
0 - Bank Address Hashing disabled. 1 - Bank Address Hashing enabled. [3:2] Reserved.
|
||||||
|
[5:4] This register specifies the address mapping to be used: 00:1KB (A), 01:2KB
|
||||||
|
(B), 0x03(Default).
|
||||||
**/
|
**/
|
||||||
uint8_t Ch1_Option;
|
uint8_t Ch1_Option;
|
||||||
|
|
||||||
|
@ -372,7 +330,8 @@ struct FSP_M_CONFIG {
|
||||||
uint8_t Ch1_Mode2N;
|
uint8_t Ch1_Mode2N;
|
||||||
|
|
||||||
/** Offset 0x0074 - Ch1_OdtLevels
|
/** Offset 0x0074 - Ch1_OdtLevels
|
||||||
Parameter used to determine if ODT will be held high or low. 0:Use MRC default(Default), 1:ODT_AB_HIGH_HIGH. 3:ODT_AB_HIGH_LOW.
|
Parameter used to determine if ODT will be held high or low. 0:Use MRC default(Default),
|
||||||
|
1:ODT_AB_HIGH_HIGH. 3:ODT_AB_HIGH_LOW.
|
||||||
**/
|
**/
|
||||||
uint8_t Ch1_OdtLevels;
|
uint8_t Ch1_OdtLevels;
|
||||||
|
|
||||||
|
@ -394,7 +353,12 @@ struct FSP_M_CONFIG {
|
||||||
uint8_t Ch2_DramDensity;
|
uint8_t Ch2_DramDensity;
|
||||||
|
|
||||||
/** Offset 0x0078 - Ch2_Option
|
/** Offset 0x0078 - Ch2_Option
|
||||||
Rank Select Interleaving Enable. See Address Mapping section for full description.. 0 - Rank Select Interleaving disabled. 1 - Rank Select Interleaving enabled. [1] Bank Address Hashing Enable. See Address Mapping section for full description.. 0 - Bank Address Hashing disabled. 1 - Bank Address Hashing enabled. [3:2] Reserved. [5:4] This register specifies the address mapping to be used:. 00:1KB (A)(Default). 01:2KB (B).
|
Rank Select Interleaving Enable. See Address Mapping section for full description..
|
||||||
|
0 - Rank Select Interleaving disabled. 1 - Rank Select Interleaving enabled. [1]
|
||||||
|
Bank Address Hashing Enable. See Address Mapping section for full description..
|
||||||
|
0 - Bank Address Hashing disabled. 1 - Bank Address Hashing enabled. [3:2] Reserved.
|
||||||
|
[5:4] This register specifies the address mapping to be used:. 00:1KB (A)(Default).
|
||||||
|
01:2KB (B).
|
||||||
**/
|
**/
|
||||||
uint8_t Ch2_Option;
|
uint8_t Ch2_Option;
|
||||||
|
|
||||||
|
@ -414,7 +378,8 @@ struct FSP_M_CONFIG {
|
||||||
uint8_t Ch2_Mode2N;
|
uint8_t Ch2_Mode2N;
|
||||||
|
|
||||||
/** Offset 0x007C - Ch2_OdtLevels
|
/** Offset 0x007C - Ch2_OdtLevels
|
||||||
Parameter used to determine if ODT will be held high or low. 0:Use MRC default(Default), 1:ODT_AB_HIGH_HIGH, 3:ODT_AB_HIGH_LOW.
|
Parameter used to determine if ODT will be held high or low. 0:Use MRC default(Default),
|
||||||
|
1:ODT_AB_HIGH_HIGH, 3:ODT_AB_HIGH_LOW.
|
||||||
**/
|
**/
|
||||||
uint8_t Ch2_OdtLevels;
|
uint8_t Ch2_OdtLevels;
|
||||||
|
|
||||||
|
@ -424,19 +389,26 @@ struct FSP_M_CONFIG {
|
||||||
uint8_t Ch3_RankEnable;
|
uint8_t Ch3_RankEnable;
|
||||||
|
|
||||||
/** Offset 0x007E - Ch3_DeviceWidth
|
/** Offset 0x007E - Ch3_DeviceWidth
|
||||||
NOTE: Only for memory down. DRAM Device Data Width populated on Ranks 0 and 1. 0x00:x8(Default), 0x01:x16, 0x02:x32, 0x03:x64.
|
NOTE: Only for memory down. DRAM Device Data Width populated on Ranks 0 and 1. 0x00:x8(Default),
|
||||||
|
0x01:x16, 0x02:x32, 0x03:x64.
|
||||||
0b0000:x8, 0b0001:x16, 0b0010:x32, 0b0011:x64
|
0b0000:x8, 0b0001:x16, 0b0010:x32, 0b0011:x64
|
||||||
**/
|
**/
|
||||||
uint8_t Ch3_DeviceWidth;
|
uint8_t Ch3_DeviceWidth;
|
||||||
|
|
||||||
/** Offset 0x007F - Ch3_DramDensity
|
/** Offset 0x007F - Ch3_DramDensity
|
||||||
NOTE: Only for memory down. DRAM Device Density populated on Ranks 0 and 1. 0x00:4Gb(Default), 0x01:6Gb, 0x02:8Gb, 0x03:12Gb, 0x04:16Gb.
|
NOTE: Only for memory down. DRAM Device Density populated on Ranks 0 and 1. 0x00:4Gb(Default),
|
||||||
|
0x01:6Gb, 0x02:8Gb, 0x03:12Gb, 0x04:16Gb.
|
||||||
0b0000:4Gb, 0b0001:6Gb, 0b0010:8Gb, 0b0011:12Gb, 0b0100:16Gb
|
0b0000:4Gb, 0b0001:6Gb, 0b0010:8Gb, 0b0011:12Gb, 0b0100:16Gb
|
||||||
**/
|
**/
|
||||||
uint8_t Ch3_DramDensity;
|
uint8_t Ch3_DramDensity;
|
||||||
|
|
||||||
/** Offset 0x0080 - Ch3_Option
|
/** Offset 0x0080 - Ch3_Option
|
||||||
Rank Select Interleaving Enable. See Address Mapping section for full description.. 0 - Rank Select Interleaving disabled. 1 - Rank Select Interleaving enabled. [1] Bank Address Hashing Enable. See Address Mapping section for full description.. 0 - Bank Address Hashing disabled. 1 - Bank Address Hashing enabled. [3:2] Reserved. [5:4] This register specifies the address mapping to be used:. 00 - 1KB (A). 01 - 2KB (B).
|
Rank Select Interleaving Enable. See Address Mapping section for full description..
|
||||||
|
0 - Rank Select Interleaving disabled. 1 - Rank Select Interleaving enabled. [1]
|
||||||
|
Bank Address Hashing Enable. See Address Mapping section for full description..
|
||||||
|
0 - Bank Address Hashing disabled. 1 - Bank Address Hashing enabled. [3:2] Reserved.
|
||||||
|
[5:4] This register specifies the address mapping to be used:. 00 - 1KB (A). 01
|
||||||
|
- 2KB (B).
|
||||||
**/
|
**/
|
||||||
uint8_t Ch3_Option;
|
uint8_t Ch3_Option;
|
||||||
|
|
||||||
|
@ -456,7 +428,8 @@ struct FSP_M_CONFIG {
|
||||||
uint8_t Ch3_Mode2N;
|
uint8_t Ch3_Mode2N;
|
||||||
|
|
||||||
/** Offset 0x0084 - Ch3_OdtLevels
|
/** Offset 0x0084 - Ch3_OdtLevels
|
||||||
Parameter used to determine if ODT will be held high or low. 0:Use MRC default(Default), 1:ODT_AB_HIGH_HIGH, 3:ODT_AB_HIGH_LOW.
|
Parameter used to determine if ODT will be held high or low. 0:Use MRC default(Default),
|
||||||
|
1:ODT_AB_HIGH_HIGH, 3:ODT_AB_HIGH_LOW.
|
||||||
**/
|
**/
|
||||||
uint8_t Ch3_OdtLevels;
|
uint8_t Ch3_OdtLevels;
|
||||||
|
|
||||||
|
@ -495,25 +468,65 @@ struct FSP_M_CONFIG {
|
||||||
**/
|
**/
|
||||||
uint32_t MsgLevelMask;
|
uint32_t MsgLevelMask;
|
||||||
|
|
||||||
/** Offset 0x010C - FIT Table Pointer
|
/** Offset 0x010C
|
||||||
FIT table pointer. 0x00000000(Default).
|
|
||||||
**/
|
**/
|
||||||
uint32_t FitTablePtr;
|
uint32_t UnusedUpdSpace0;
|
||||||
|
|
||||||
/** Offset 0x0110 - GPIO Table Pointer
|
/** Offset 0x0110 - PreMem GPIO Table Entry Number. Currently maximum entry number is 4
|
||||||
GPIO table pointer to a BL_GPIO_PAD_INIT structure. 0x00000000(Default).
|
Number of Entries in PreMem GPIO Table. 0(Default).
|
||||||
**/
|
**/
|
||||||
struct BL_GPIO_PAD_INIT* GpioPadInitTablePtr;
|
uint8_t PreMemGpioTableEntryNum;
|
||||||
|
|
||||||
/** Offset 0x0114 - Enhance the port 8xh decoding
|
/** Offset 0x0111 - PreMem GPIO Pin Number for each table
|
||||||
|
Number of Pins in each PreMem GPIO Table. 0(Default).
|
||||||
|
**/
|
||||||
|
uint8_t PreMemGpioTablePinNum[4];
|
||||||
|
|
||||||
|
/** Offset 0x0115 - PreMem GPIO Table Pointer
|
||||||
|
Pointer to Array of pointers to PreMem GPIO Table. 0x00000000(Default).
|
||||||
|
**/
|
||||||
|
uint32_t PreMemGpioTablePtr;
|
||||||
|
|
||||||
|
/** Offset 0x0119 - Enhance the port 8xh decoding
|
||||||
Enable/Disable Enhance the port 8xh decoding. 0:Disable, 1:Enable(Default).
|
Enable/Disable Enhance the port 8xh decoding. 0:Disable, 1:Enable(Default).
|
||||||
$EN_DIS
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t EnhancePort8xhDecoding;
|
uint8_t EnhancePort8xhDecoding;
|
||||||
|
|
||||||
/** Offset 0x0115
|
/** Offset 0x011A - OEM File Loading Address
|
||||||
|
Determine the memory base address to load a specified file from CSE file system
|
||||||
|
after memory is available.
|
||||||
**/
|
**/
|
||||||
uint8_t ReservedFspmUpd[59];
|
uint32_t OemLoadingBase;
|
||||||
|
|
||||||
|
/** Offset 0x011E - OEM File Name to Load
|
||||||
|
Specify a file name to load from CSE file system after memory is available. Empty
|
||||||
|
indicates no file needs to be loaded.
|
||||||
|
**/
|
||||||
|
uint8_t OemFileName[16];
|
||||||
|
|
||||||
|
/** Offset 0x012E - SPD Data Write
|
||||||
|
Enable/Disable SPD data write on the SMBUS. 0x00:Disable(Default), 0x01:Enable.
|
||||||
|
$EN_DIS
|
||||||
|
**/
|
||||||
|
uint8_t SpdWriteEnable;
|
||||||
|
|
||||||
|
/** Offset 0x012F - MRC Training Data Saving
|
||||||
|
Enable/Disable MRC training data saving in FSP. 0x00:Disable(Default), 0x01:Enable.
|
||||||
|
$EN_DIS
|
||||||
|
**/
|
||||||
|
uint8_t MrcDataSaving;
|
||||||
|
|
||||||
|
/** Offset 0x0130 - eMMC Trace Length
|
||||||
|
Select eMMC trace length to load OEM file from when loading OEM file name is specified.
|
||||||
|
0x0:Long(Default), 0x1:Short.
|
||||||
|
0x0:Long, 0x1:Short
|
||||||
|
**/
|
||||||
|
uint8_t eMMCTraceLen;
|
||||||
|
|
||||||
|
/** Offset 0x0131
|
||||||
|
**/
|
||||||
|
uint8_t ReservedFspmUpd[31];
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
|
||||||
/** Fsp M Test Configuration
|
/** Fsp M Test Configuration
|
||||||
|
@ -542,8 +555,6 @@ struct FSP_M_RESTRICTED_CONFIG {
|
||||||
uint8_t ReservedFspmRestrictedUpd[138];
|
uint8_t ReservedFspmRestrictedUpd[138];
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
|
||||||
#define FSPM_UPD_SIGNATURE 0x4450555F4D505346 /* 'FSPM_UPD' */
|
|
||||||
|
|
||||||
/** Fsp M UPD Configuration
|
/** Fsp M UPD Configuration
|
||||||
**/
|
**/
|
||||||
struct FSPM_UPD {
|
struct FSPM_UPD {
|
||||||
|
@ -554,7 +565,7 @@ struct FSPM_UPD {
|
||||||
|
|
||||||
/** Offset 0x0020
|
/** Offset 0x0020
|
||||||
**/
|
**/
|
||||||
struct FSP_M_ARCH_UPD FspmArchUpd;
|
struct FSPM_ARCH_UPD FspmArchUpd;
|
||||||
|
|
||||||
/** Offset 0x0040
|
/** Offset 0x0040
|
||||||
**/
|
**/
|
||||||
|
|
|
@ -34,7 +34,7 @@ are permitted provided that the following conditions are met:
|
||||||
#define __FSPSUPD_H__
|
#define __FSPSUPD_H__
|
||||||
|
|
||||||
#include "FspUpd.h"
|
#include "FspUpd.h"
|
||||||
|
#include <fsp/upd.h>
|
||||||
|
|
||||||
/** Fsp S Configuration
|
/** Fsp S Configuration
|
||||||
**/
|
**/
|
||||||
|
@ -70,7 +70,8 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t VmxEnable;
|
uint8_t VmxEnable;
|
||||||
|
|
||||||
/** Offset 0x0025 - Memory region allocation for Processor Trace
|
/** Offset 0x0025 - Memory region allocation for Processor Trace
|
||||||
Memory region allocation for Processor Trace, allowed range is from 4K (0x0) to 128MB (0xF); <b>0xFF: Disable. 0xFF:Disable(Default)
|
Memory region allocation for Processor Trace, allowed range is from 4K (0x0) to
|
||||||
|
128MB (0xF); <b>0xFF: Disable. 0xFF:Disable(Default)
|
||||||
**/
|
**/
|
||||||
uint8_t ProcTraceMemSize;
|
uint8_t ProcTraceMemSize;
|
||||||
|
|
||||||
|
@ -110,7 +111,8 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t BiProcHot;
|
uint8_t BiProcHot;
|
||||||
|
|
||||||
/** Offset 0x002C - Max Pkg Cstate
|
/** Offset 0x002C - Max Pkg Cstate
|
||||||
Max Pkg Cstate. 0:PkgC0C1, 1:PkgC2, 2:PkgC3(Default), 3:PkgC6, 4:PkgC7, 5:PkgC7s, 6:PkgC8, 7:PkgC9, 8:PkgC10, 9:PkgCMax, 254:PkgCpuDefault, 255:PkgAuto.
|
Max Pkg Cstate. 0:PkgC0C1, 1:PkgC2, 2:PkgC3(Default), 3:PkgC6, 4:PkgC7, 5:PkgC7s,
|
||||||
|
6:PkgC8, 7:PkgC9, 8:PkgC10, 9:PkgCMax, 254:PkgCpuDefault, 255:PkgAuto.
|
||||||
**/
|
**/
|
||||||
uint8_t PkgCStateLimit;
|
uint8_t PkgCStateLimit;
|
||||||
|
|
||||||
|
@ -119,12 +121,15 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t UnusedUpdSpace0;
|
uint8_t UnusedUpdSpace0;
|
||||||
|
|
||||||
/** Offset 0x002E - C-State auto-demotion
|
/** Offset 0x002E - C-State auto-demotion
|
||||||
C-State Auto Demotion. 0:Disable(Default) C1 and C3 Auto-demotion, 1:Enable C3/C6/C7 Auto-demotion to C1, 2:Enable C6/C7 Auto-demotion to C3, 3:Enable C6/C7 Auto-demotion to C1 and C3.
|
C-State Auto Demotion. 0:Disable(Default) C1 and C3 Auto-demotion, 1:Enable C3/C6/C7
|
||||||
|
Auto-demotion to C1, 2:Enable C6/C7 Auto-demotion to C3, 3:Enable C6/C7 Auto-demotion
|
||||||
|
to C1 and C3.
|
||||||
**/
|
**/
|
||||||
uint8_t CStateAutoDemotion;
|
uint8_t CStateAutoDemotion;
|
||||||
|
|
||||||
/** Offset 0x002F - C-State un-demotion
|
/** Offset 0x002F - C-State un-demotion
|
||||||
C-State un-demotion. 0:Disable(Default) C1 and C3 Un-demotion, 1:Enable C1 Un-demotion, 2:Enable C3 Un-demotion, 3:Enable C1 and C3 Un-demotion.
|
C-State un-demotion. 0:Disable(Default) C1 and C3 Un-demotion, 1:Enable C1 Un-demotion,
|
||||||
|
2:Enable C3 Un-demotion, 3:Enable C1 and C3 Un-demotion.
|
||||||
**/
|
**/
|
||||||
uint8_t CStateUnDemotion;
|
uint8_t CStateUnDemotion;
|
||||||
|
|
||||||
|
@ -436,7 +441,8 @@ struct FSP_S_CONFIG {
|
||||||
|
|
||||||
/** Offset 0x0091 - HD-Audio I/O Buffer Ownership
|
/** Offset 0x0091 - HD-Audio I/O Buffer Ownership
|
||||||
Set HD-Audio I/O Buffer Ownership. 0:Disable(Default), 1:Enable.
|
Set HD-Audio I/O Buffer Ownership. 0:Disable(Default), 1:Enable.
|
||||||
0:HD-Audio link owns all the I/O buffers, 1:HD-Audio link owns 4 I/O buffers and I2S port owns 4 I/O buffers, 3:I2S port owns all the I/O buffers
|
0:HD-Audio link owns all the I/O buffers, 1:HD-Audio link owns 4 I/O buffers and
|
||||||
|
I2S port owns 4 I/O buffers, 3:I2S port owns all the I/O buffers
|
||||||
**/
|
**/
|
||||||
uint8_t HdAudioIoBufferOwnership;
|
uint8_t HdAudioIoBufferOwnership;
|
||||||
|
|
||||||
|
@ -453,13 +459,15 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t HdAudioVcType;
|
uint8_t HdAudioVcType;
|
||||||
|
|
||||||
/** Offset 0x0094 - HD-Audio Link Frequency
|
/** Offset 0x0094 - HD-Audio Link Frequency
|
||||||
HD-Audio Virtual Channel Type Selectiton. 0:6MHz(Default), 1:12MHz, 2:24MHz, 3:48MHz, 4:96MHz, 5:Invalid.
|
HD-Audio Virtual Channel Type Selectiton. 0:6MHz(Default), 1:12MHz, 2:24MHz, 3:48MHz,
|
||||||
|
4:96MHz, 5:Invalid.
|
||||||
0: 6MHz, 1: 12MHz, 2: 24MHz, 3: 48MHz, 4: 96MHz, 5: Invalid
|
0: 6MHz, 1: 12MHz, 2: 24MHz, 3: 48MHz, 4: 96MHz, 5: Invalid
|
||||||
**/
|
**/
|
||||||
uint8_t HdAudioLinkFrequency;
|
uint8_t HdAudioLinkFrequency;
|
||||||
|
|
||||||
/** Offset 0x0095 - HD-Audio iDisp-Link Frequency
|
/** Offset 0x0095 - HD-Audio iDisp-Link Frequency
|
||||||
HD-Audio iDisp-Link Frequency Selectiton. 0:6MHz(Default), 1:12MHz, 2:24MHz, 3:48MHz, 4:96MHz, 5:Invalid.
|
HD-Audio iDisp-Link Frequency Selectiton. 0:6MHz(Default), 1:12MHz, 2:24MHz, 3:48MHz,
|
||||||
|
4:96MHz, 5:Invalid.
|
||||||
0: 6MHz, 1: 12MHz, 2: 24MHz, 3: 48MHz, 4: 96MHz, 5: Invalid
|
0: 6MHz, 1: 12MHz, 2: 24MHz, 3: 48MHz, 4: 96MHz, 5: Invalid
|
||||||
**/
|
**/
|
||||||
uint8_t HdAudioIDispLinkFrequency;
|
uint8_t HdAudioIDispLinkFrequency;
|
||||||
|
@ -495,13 +503,13 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t DspEndpointI2sHp;
|
uint8_t DspEndpointI2sHp;
|
||||||
|
|
||||||
/** Offset 0x009B - HD-Audio Controller Power Gating
|
/** Offset 0x009B - HD-Audio Controller Power Gating
|
||||||
Enable/Disable HD-Audio Controller Power Gating. 0:Disable(Default), 1:Enable.
|
Enable/Disable HD-Audio Controller Power Gating. This option is deprecated.
|
||||||
$EN_DIS
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t AudioCtlPwrGate;
|
uint8_t AudioCtlPwrGate;
|
||||||
|
|
||||||
/** Offset 0x009C - HD-Audio ADSP Power Gating
|
/** Offset 0x009C - HD-Audio ADSP Power Gating
|
||||||
Enable/Disable HD-Audio ADSP Power Gating. 0:Disable(Default), 1:Enable.
|
Enable/Disable HD-Audio ADSP Power Gating. This option is deprecated.
|
||||||
$EN_DIS
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t AudioDspPwrGate;
|
uint8_t AudioDspPwrGate;
|
||||||
|
@ -538,13 +546,17 @@ struct FSP_S_CONFIG {
|
||||||
|
|
||||||
/** Offset 0x00A2 - Bitmask of DSP Feature
|
/** Offset 0x00A2 - Bitmask of DSP Feature
|
||||||
Set Bitmask of HD-Audio DSP Feature. 0x00000000(Default).
|
Set Bitmask of HD-Audio DSP Feature. 0x00000000(Default).
|
||||||
[BIT0] - WoV, [BIT1] - BT Sideband, [BIT2] - Codec VAD, [BIT5] - BT Intel HFP, [BIT6] - BT Intel A2DP, [BIT7] - DSP based speech pre-processing disabled, [BIT8] - 0: Intel WoV, 1: Windows Voice Activation
|
[BIT0] - WoV, [BIT1] - BT Sideband, [BIT2] - Codec VAD, [BIT5] - BT Intel HFP, [BIT6]
|
||||||
|
- BT Intel A2DP, [BIT7] - DSP based speech pre-processing disabled, [BIT8] - 0:
|
||||||
|
Intel WoV, 1: Windows Voice Activation
|
||||||
**/
|
**/
|
||||||
uint32_t DspFeatureMask;
|
uint32_t DspFeatureMask;
|
||||||
|
|
||||||
/** Offset 0x00A6 - Bitmask of supported DSP Post-Processing Modules
|
/** Offset 0x00A6 - Bitmask of supported DSP Post-Processing Modules
|
||||||
Set HD-Audio Bitmask of supported DSP Post-Processing Modules. 0x00000000(Default).
|
Set HD-Audio Bitmask of supported DSP Post-Processing Modules. 0x00000000(Default).
|
||||||
[BIT0] - WoV, [BIT1] - BT Sideband, [BIT2] - Codec VAD, [BIT5] - BT Intel HFP, [BIT6] - BT Intel A2DP, [BIT7] - DSP based speech pre-processing disabled, [BIT8] - 0: Intel WoV, 1: Windows Voice Activation
|
[BIT0] - WoV, [BIT1] - BT Sideband, [BIT2] - Codec VAD, [BIT5] - BT Intel HFP, [BIT6]
|
||||||
|
- BT Intel A2DP, [BIT7] - DSP based speech pre-processing disabled, [BIT8] - 0:
|
||||||
|
Intel WoV, 1: Windows Voice Activation
|
||||||
**/
|
**/
|
||||||
uint32_t DspPpModuleMask;
|
uint32_t DspPpModuleMask;
|
||||||
|
|
||||||
|
@ -624,7 +636,8 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t IshEnable;
|
uint8_t IshEnable;
|
||||||
|
|
||||||
/** Offset 0x00BB - ISH Controller
|
/** Offset 0x00BB - ISH Controller
|
||||||
Enable/Disable BIOS Interface Lock Down bit to prevent writes to the Backup Control Register. 0:Disable, 1:Enable(Default).
|
Enable/Disable BIOS Interface Lock Down bit to prevent writes to the Backup Control
|
||||||
|
Register. 0:Disable, 1:Enable(Default).
|
||||||
$EN_DIS
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t BiosInterface;
|
uint8_t BiosInterface;
|
||||||
|
@ -768,11 +781,11 @@ struct FSP_S_CONFIG {
|
||||||
**/
|
**/
|
||||||
uint8_t OsDbgEnable;
|
uint8_t OsDbgEnable;
|
||||||
|
|
||||||
/** Offset 0x00E3 - Exi Feature
|
/** Offset 0x00E3 - DCI Feature
|
||||||
Enable/Disable Exi Feature. 0:Disable(Default), 1: Enable.
|
Enable/Disable DCI Feature. 0:Disable(Default), 1: Enable.
|
||||||
$EN_DIS
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t ExiEnable;
|
uint8_t DciEn;
|
||||||
|
|
||||||
/** Offset 0x00E4 - Enable PCIE Clock Gating
|
/** Offset 0x00E4 - Enable PCIE Clock Gating
|
||||||
Enable/disable PCIE Clock Gating. 0:Enable, 1:Disable(Default).
|
Enable/disable PCIE Clock Gating. 0:Enable, 1:Disable(Default).
|
||||||
|
@ -848,7 +861,8 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t PcieRpClkReqSupported[6];
|
uint8_t PcieRpClkReqSupported[6];
|
||||||
|
|
||||||
/** Offset 0x011F - Configure CLKREQ Number
|
/** Offset 0x011F - Configure CLKREQ Number
|
||||||
Configure Root Port CLKREQ Number if CLKREQ is supported. Default=0x04, 0x05, 0x00, 0x01, 0x02, 0x03.
|
Configure Root Port CLKREQ Number if CLKREQ is supported. Default=0x04, 0x05, 0x00,
|
||||||
|
0x01, 0x02, 0x03.
|
||||||
**/
|
**/
|
||||||
uint8_t PcieRpClkReqNumber[6];
|
uint8_t PcieRpClkReqNumber[6];
|
||||||
|
|
||||||
|
@ -923,7 +937,8 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t PtmEnable[6];
|
uint8_t PtmEnable[6];
|
||||||
|
|
||||||
/** Offset 0x0179 - ASPM
|
/** Offset 0x0179 - ASPM
|
||||||
PCI Express Active State Power Management settings. 0:Disable, 1:L0s, 2:L1, 3:L0sL1, 4:Auto(Default).
|
PCI Express Active State Power Management settings. 0:Disable, 1:L0s, 2:L1, 3:L0sL1,
|
||||||
|
4:Auto(Default).
|
||||||
**/
|
**/
|
||||||
uint8_t PcieRpAspm[6];
|
uint8_t PcieRpAspm[6];
|
||||||
|
|
||||||
|
@ -949,19 +964,21 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t PmeB0S5Dis;
|
uint8_t PmeB0S5Dis;
|
||||||
|
|
||||||
/** Offset 0x0192 - PCI Clock Run
|
/** Offset 0x0192 - PCI Clock Run
|
||||||
This member describes whether or not the PCI ClockRun feature of SC should be enabled. 0:Disable(Default), 1:Enable.
|
This member describes whether or not the PCI ClockRun feature of SC should be enabled.
|
||||||
|
0:Disable(Default), 1:Enable.
|
||||||
$EN_DIS
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t PciClockRun;
|
uint8_t PciClockRun;
|
||||||
|
|
||||||
/** Offset 0x0193 - Enable/Disable Timer 8254 Clock Setting
|
/** Offset 0x0193 - Enable/Disable Timer 8254 Clock Setting
|
||||||
Enable/Disable Timer 8254 Clock. 0:Disable, 1:Enable(Default).
|
Enable/Disable Timer 8254 Clock. 0:Disable(Default), 1:Enable.
|
||||||
$EN_DIS
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t Timer8254ClkSetting;
|
uint8_t Timer8254ClkSetting;
|
||||||
|
|
||||||
/** Offset 0x0194 - Chipset SATA
|
/** Offset 0x0194 - Chipset SATA
|
||||||
Enables or Disables the Chipset SATA Controller. The Chipset SATA controller supports the 2 black internal SATA ports (up to 3Gb/s supported per port). 0:Disable, 1:Enable(Default).
|
Enables or Disables the Chipset SATA Controller. The Chipset SATA controller supports
|
||||||
|
the 2 black internal SATA ports (up to 3Gb/s supported per port). 0:Disable, 1:Enable(Default).
|
||||||
$EN_DIS
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t EnableSata;
|
uint8_t EnableSata;
|
||||||
|
@ -1012,7 +1029,8 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t SataPortsHotPlug[2];
|
uint8_t SataPortsHotPlug[2];
|
||||||
|
|
||||||
/** Offset 0x01A0 - Mechanical Presence Switch
|
/** Offset 0x01A0 - Mechanical Presence Switch
|
||||||
Controls reporting if this port has an Mechanical Presence Switch.\nNote:Requires hardware support. 0:Disable, 1:Enable(Default).
|
Controls reporting if this port has an Mechanical Presence Switch.\nNote:Requires
|
||||||
|
hardware support. 0:Disable, 1:Enable(Default).
|
||||||
**/
|
**/
|
||||||
uint8_t SataPortsInterlockSw[2];
|
uint8_t SataPortsInterlockSw[2];
|
||||||
|
|
||||||
|
@ -1027,7 +1045,8 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t SataPortsSpinUp[2];
|
uint8_t SataPortsSpinUp[2];
|
||||||
|
|
||||||
/** Offset 0x01A6 - SATA Solid State
|
/** Offset 0x01A6 - SATA Solid State
|
||||||
Identify the SATA port is connected to Solid State Drive or Hard Disk Drive. 0:Hard Disk Drive(Default), 1:Solid State Drive.
|
Identify the SATA port is connected to Solid State Drive or Hard Disk Drive. 0:Hard
|
||||||
|
Disk Drive(Default), 1:Solid State Drive.
|
||||||
**/
|
**/
|
||||||
uint8_t SataPortsSolidStateDrive[2];
|
uint8_t SataPortsSolidStateDrive[2];
|
||||||
|
|
||||||
|
@ -1163,7 +1182,8 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t RsvdSmbusAddressTable[128];
|
uint8_t RsvdSmbusAddressTable[128];
|
||||||
|
|
||||||
/** Offset 0x024F - XHCI Disable Compliance Mode
|
/** Offset 0x024F - XHCI Disable Compliance Mode
|
||||||
Options to disable XHCI Link Compliance Mode. Default is FALSE to not disable Compliance Mode. Set TRUE to disable Compliance Mode. 0:FALSE(Default), 1:True.
|
Options to disable XHCI Link Compliance Mode. Default is FALSE to not disable Compliance
|
||||||
|
Mode. Set TRUE to disable Compliance Mode. 0:FALSE(Default), 1:True.
|
||||||
$EN_DIS
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t DisableComplianceMode;
|
uint8_t DisableComplianceMode;
|
||||||
|
@ -1181,7 +1201,8 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t Usb30Mode;
|
uint8_t Usb30Mode;
|
||||||
|
|
||||||
/** Offset 0x0252 - Enable USB2 ports
|
/** Offset 0x0252 - Enable USB2 ports
|
||||||
Enable/disable per USB2 ports. One byte for each port, byte0 for port0, byte1 for port1, and so on. 0x01(Default).
|
Enable/disable per USB2 ports. One byte for each port, byte0 for port0, byte1 for
|
||||||
|
port1, and so on. 0x01(Default).
|
||||||
**/
|
**/
|
||||||
uint8_t PortUsb20Enable[8];
|
uint8_t PortUsb20Enable[8];
|
||||||
|
|
||||||
|
@ -1191,7 +1212,8 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t PortUs20bOverCurrentPin[8];
|
uint8_t PortUs20bOverCurrentPin[8];
|
||||||
|
|
||||||
/** Offset 0x0262 - Enable USB3 ports
|
/** Offset 0x0262 - Enable USB3 ports
|
||||||
Enable/disable per USB3 ports. One byte for each port, byte0 for port0, byte1 for port1, and so on. 0x01(Default).
|
Enable/disable per USB3 ports. One byte for each port, byte0 for port0, byte1 for
|
||||||
|
port1, and so on. 0x01(Default).
|
||||||
**/
|
**/
|
||||||
uint8_t PortUsb30Enable[6];
|
uint8_t PortUsb30Enable[6];
|
||||||
|
|
||||||
|
@ -1213,7 +1235,8 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t HsicSupportEnable;
|
uint8_t HsicSupportEnable;
|
||||||
|
|
||||||
/** Offset 0x0270 - Enable XHCI SSIC Support
|
/** Offset 0x0270 - Enable XHCI SSIC Support
|
||||||
Enable/disable XHCI SSIC ports. One byte for each port, byte0 for port0, byte1 for port1. 0x00(Default).
|
Enable/disable XHCI SSIC ports. One byte for each port, byte0 for port0, byte1 for
|
||||||
|
port1. 0x00(Default).
|
||||||
**/
|
**/
|
||||||
uint8_t SsicPortEnable[2];
|
uint8_t SsicPortEnable[2];
|
||||||
|
|
||||||
|
@ -1235,7 +1258,8 @@ struct FSP_S_CONFIG {
|
||||||
uint16_t ResetWaitTimer;
|
uint16_t ResetWaitTimer;
|
||||||
|
|
||||||
/** Offset 0x0277 - SMI Lock bit
|
/** Offset 0x0277 - SMI Lock bit
|
||||||
Enable/Disable SMI_LOCK bit to prevent writes to the Global SMI Enable bit. 0:Disable, 1:Enable(Default).
|
Enable/Disable SMI_LOCK bit to prevent writes to the Global SMI Enable bit. 0:Disable,
|
||||||
|
1:Enable(Default).
|
||||||
$EN_DIS
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t LockDownGlobalSmi;
|
uint8_t LockDownGlobalSmi;
|
||||||
|
@ -1269,7 +1293,8 @@ struct FSP_S_CONFIG {
|
||||||
uint16_t PcieRpLtrMaxSnoopLatency[6];
|
uint16_t PcieRpLtrMaxSnoopLatency[6];
|
||||||
|
|
||||||
/** Offset 0x028A - Snoop Latency Override
|
/** Offset 0x028A - Snoop Latency Override
|
||||||
Snoop Latency Override for PCH PCIE. \nDisabled:Disable override.\nManual:Manually enter override values.\nAuto:Maintain default BIOS flow. 0:Disable, 1:Enable, 2:Auto(Default).
|
Snoop Latency Override for PCH PCIE. \nDisabled:Disable override.\nManual:Manually
|
||||||
|
enter override values.\nAuto:Maintain default BIOS flow. 0:Disable, 1:Enable, 2:Auto(Default).
|
||||||
**/
|
**/
|
||||||
uint8_t PcieRpSnoopLatencyOverrideMode[6];
|
uint8_t PcieRpSnoopLatencyOverrideMode[6];
|
||||||
|
|
||||||
|
@ -1279,7 +1304,8 @@ struct FSP_S_CONFIG {
|
||||||
uint16_t PcieRpSnoopLatencyOverrideValue[6];
|
uint16_t PcieRpSnoopLatencyOverrideValue[6];
|
||||||
|
|
||||||
/** Offset 0x029C - Snoop Latency Multiplier
|
/** Offset 0x029C - Snoop Latency Multiplier
|
||||||
LTR Snoop Latency Multiplier of PCH PCIE. 0:1ns, 1:32ns, 2:1024ns(Default), 3:32768ns, 4:1048576ns, 5:33554432ns.
|
LTR Snoop Latency Multiplier of PCH PCIE. 0:1ns, 1:32ns, 2:1024ns(Default), 3:32768ns,
|
||||||
|
4:1048576ns, 5:33554432ns.
|
||||||
**/
|
**/
|
||||||
uint8_t PcieRpSnoopLatencyOverrideMultiplier[6];
|
uint8_t PcieRpSnoopLatencyOverrideMultiplier[6];
|
||||||
|
|
||||||
|
@ -1289,7 +1315,9 @@ struct FSP_S_CONFIG {
|
||||||
uint16_t PcieRpLtrMaxNonSnoopLatency[6];
|
uint16_t PcieRpLtrMaxNonSnoopLatency[6];
|
||||||
|
|
||||||
/** Offset 0x02AE - Non Snoop Latency Override
|
/** Offset 0x02AE - Non Snoop Latency Override
|
||||||
Non Snoop Latency Override for PCH PCIE. \nDisabled:Disable override.\nManual:Manually enter override values.\nAuto: Maintain default BIOS flow. 0:Disable, 1:Enable, 2:Auto(Default).
|
Non Snoop Latency Override for PCH PCIE. \nDisabled:Disable override.\nManual:Manually
|
||||||
|
enter override values.\nAuto: Maintain default BIOS flow. 0:Disable, 1:Enable,
|
||||||
|
2:Auto(Default).
|
||||||
**/
|
**/
|
||||||
uint8_t PcieRpNonSnoopLatencyOverrideMode[6];
|
uint8_t PcieRpNonSnoopLatencyOverrideMode[6];
|
||||||
|
|
||||||
|
@ -1299,7 +1327,8 @@ struct FSP_S_CONFIG {
|
||||||
uint16_t PcieRpNonSnoopLatencyOverrideValue[6];
|
uint16_t PcieRpNonSnoopLatencyOverrideValue[6];
|
||||||
|
|
||||||
/** Offset 0x02C0 - Non Snoop Latency Multiplier
|
/** Offset 0x02C0 - Non Snoop Latency Multiplier
|
||||||
LTR Non Snoop Latency Multiplier of PCH PCIE. 0:1ns, 1:32ns, 2:1024ns(Default), 3:32768ns, 4:1048576ns, 5:33554432ns.
|
LTR Non Snoop Latency Multiplier of PCH PCIE. 0:1ns, 1:32ns, 2:1024ns(Default),
|
||||||
|
3:32768ns, 4:1048576ns, 5:33554432ns.
|
||||||
**/
|
**/
|
||||||
uint8_t PcieRpNonSnoopLatencyOverrideMultiplier[6];
|
uint8_t PcieRpNonSnoopLatencyOverrideMultiplier[6];
|
||||||
|
|
||||||
|
@ -1314,25 +1343,154 @@ struct FSP_S_CONFIG {
|
||||||
uint8_t PcieRpSlotPowerLimitValue[6];
|
uint8_t PcieRpSlotPowerLimitValue[6];
|
||||||
|
|
||||||
/** Offset 0x02D2 - Skip Multi-Processor Initialization
|
/** Offset 0x02D2 - Skip Multi-Processor Initialization
|
||||||
When this is skipped, boot loader must initialize processors before SilicionInit API. 0: Initialize(Default), <b>1: Skip
|
When this is skipped, boot loader must initialize processors before SilicionInit
|
||||||
|
API. 0: Initialize(Default), <b>1: Skip
|
||||||
$EN_DIS
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t SkipMpInit;
|
uint8_t SkipMpInit;
|
||||||
|
|
||||||
/** Offset 0x02D3
|
/** Offset 0x02D3 - DCI Auto Detect
|
||||||
|
Enable/disable DCI AUTO mode.
|
||||||
|
$EN_DIS
|
||||||
**/
|
**/
|
||||||
uint8_t ReservedFspsUpd[45];
|
uint8_t DciAutoDetect;
|
||||||
|
|
||||||
|
/** Offset 0x02D4 - Halt and Lock TCO Timer
|
||||||
|
Halt and Lock the TCO Timer (Watchdog).
|
||||||
|
0:No, 1:Yes (default)
|
||||||
|
**/
|
||||||
|
uint8_t TcoTimerHaltLock;
|
||||||
|
|
||||||
|
/** Offset 0x02D5 - Power Button Override Peroid
|
||||||
|
specifies how long will PMC wait before initiating a global reset. 000b-4s(default),
|
||||||
|
001b-6s, 010b-8s, 011b-10s, 100b-12s, 101b-14s.)
|
||||||
|
0x0:4s, 0x1:6s, 0x2:8s, 0x3:10s, 0x4:12s, 0x5:14s
|
||||||
|
**/
|
||||||
|
uint8_t PwrBtnOverridePeriod;
|
||||||
|
|
||||||
|
/** Offset 0x02D6 - Power Button Native Mode Disable
|
||||||
|
Diable power button native mode, when 1, this will result in the PMC logic constantly
|
||||||
|
seeing the power button as de-asserted. 0 (default))
|
||||||
|
$EN_DIS
|
||||||
|
**/
|
||||||
|
uint8_t DisableNativePowerButton;
|
||||||
|
|
||||||
|
/** Offset 0x02D7 - Power Button Debounce Mode
|
||||||
|
Enable interrupt when PWRBTN# is asserted. 0:Disabled, 1:Enabled(default)
|
||||||
|
$EN_DIS
|
||||||
|
**/
|
||||||
|
uint8_t PowerButterDebounceMode;
|
||||||
|
|
||||||
|
/** Offset 0x02D8 - SDIO_TX_CMD_DLL_CNTL
|
||||||
|
SDIO_TX_CMD_DLL_CNTL. 0x505(Default).
|
||||||
|
**/
|
||||||
|
uint32_t SdioTxCmdCntl;
|
||||||
|
|
||||||
|
/** Offset 0x02DC - SDIO_TX_DATA_DLL_CNTL1
|
||||||
|
SDIO_TX_DATA_DLL_CNTL1. 0xE(Default).
|
||||||
|
**/
|
||||||
|
uint32_t SdioTxDataCntl1;
|
||||||
|
|
||||||
|
/** Offset 0x02E0 - SDIO_TX_DATA_DLL_CNTL2
|
||||||
|
SDIO_TX_DATA_DLL_CNTL2. 0x22272828(Default).
|
||||||
|
**/
|
||||||
|
uint32_t SdioTxDataCntl2;
|
||||||
|
|
||||||
|
/** Offset 0x02E4 - SDIO_RX_CMD_DATA_DLL_CNTL1
|
||||||
|
SDIO_RX_CMD_DATA_DLL_CNTL1. 0x16161616(Default).
|
||||||
|
**/
|
||||||
|
uint32_t SdioRxCmdDataCntl1;
|
||||||
|
|
||||||
|
/** Offset 0x02E8 - SDIO_RX_CMD_DATA_DLL_CNTL2
|
||||||
|
SDIO_RX_CMD_DATA_DLL_CNTL2. 0x10000(Default).
|
||||||
|
**/
|
||||||
|
uint32_t SdioRxCmdDataCntl2;
|
||||||
|
|
||||||
|
/** Offset 0x02EC - SDCARD_TX_CMD_DLL_CNTL
|
||||||
|
SDCARD_TX_CMD_DLL_CNTL. 0x505(Default).
|
||||||
|
**/
|
||||||
|
uint32_t SdcardTxCmdCntl;
|
||||||
|
|
||||||
|
/** Offset 0x02F0 - SDCARD_TX_DATA_DLL_CNTL1
|
||||||
|
SDCARD_TX_DATA_DLL_CNTL1. 0xA13(Default).
|
||||||
|
**/
|
||||||
|
uint32_t SdcardTxDataCntl1;
|
||||||
|
|
||||||
|
/** Offset 0x02F4 - SDCARD_TX_DATA_DLL_CNTL2
|
||||||
|
SDCARD_TX_DATA_DLL_CNTL2. 0x24242828(Default).
|
||||||
|
**/
|
||||||
|
uint32_t SdcardTxDataCntl2;
|
||||||
|
|
||||||
|
/** Offset 0x02F8 - SDCARD_RX_CMD_DATA_DLL_CNTL1
|
||||||
|
SDCARD_RX_CMD_DATA_DLL_CNTL1. 0x73A3637(Default).
|
||||||
|
**/
|
||||||
|
uint32_t SdcardRxCmdDataCntl1;
|
||||||
|
|
||||||
|
/** Offset 0x02FC - SDCARD_RX_STROBE_DLL_CNTL
|
||||||
|
SDCARD_RX_STROBE_DLL_CNTL. 0x0(Default).
|
||||||
|
**/
|
||||||
|
uint32_t SdcardRxStrobeCntl;
|
||||||
|
|
||||||
|
/** Offset 0x0300 - SDCARD_RX_CMD_DATA_DLL_CNTL2
|
||||||
|
SDCARD_RX_CMD_DATA_DLL_CNTL2. 0x10000(Default).
|
||||||
|
**/
|
||||||
|
uint32_t SdcardRxCmdDataCntl2;
|
||||||
|
|
||||||
|
/** Offset 0x0304 - EMMC_TX_CMD_DLL_CNTL
|
||||||
|
EMMC_TX_CMD_DLL_CNTL. 0x505(Default).
|
||||||
|
**/
|
||||||
|
uint32_t EmmcTxCmdCntl;
|
||||||
|
|
||||||
|
/** Offset 0x0308 - EMMC_TX_DATA_DLL_CNTL1
|
||||||
|
EMMC_TX_DATA_DLL_CNTL1. 0xC11(Default).
|
||||||
|
**/
|
||||||
|
uint32_t EmmcTxDataCntl1;
|
||||||
|
|
||||||
|
/** Offset 0x030C - EMMC_TX_DATA_DLL_CNTL2
|
||||||
|
EMMC_TX_DATA_DLL_CNTL2. 0x1C2A2927(Default).
|
||||||
|
**/
|
||||||
|
uint32_t EmmcTxDataCntl2;
|
||||||
|
|
||||||
|
/** Offset 0x0310 - EMMC_RX_CMD_DATA_DLL_CNTL1
|
||||||
|
EMMC_RX_CMD_DATA_DLL_CNTL1. 0x000D162F(Default).
|
||||||
|
**/
|
||||||
|
uint32_t EmmcRxCmdDataCntl1;
|
||||||
|
|
||||||
|
/** Offset 0x0314 - EMMC_RX_STROBE_DLL_CNTL
|
||||||
|
EMMC_RX_STROBE_DLL_CNTL. 0x0a0a(Default).
|
||||||
|
**/
|
||||||
|
uint32_t EmmcRxStrobeCntl;
|
||||||
|
|
||||||
|
/** Offset 0x0318 - EMMC_RX_CMD_DATA_DLL_CNTL2
|
||||||
|
EMMC_RX_CMD_DATA_DLL_CNTL2. 0x1003b(Default).
|
||||||
|
**/
|
||||||
|
uint32_t EmmcRxCmdDataCntl2;
|
||||||
|
|
||||||
|
/** Offset 0x031C - EMMC_MASTER_DLL_CNTL
|
||||||
|
EMMC_MASTER_DLL_CNTL. 0x001(Default).
|
||||||
|
**/
|
||||||
|
uint32_t EmmcMasterSwCntl;
|
||||||
|
|
||||||
|
/** Offset 0x0320 - PCIe Selectable De-emphasis
|
||||||
|
When the Link is operating at 5.0 GT/s speed, this bit selects the level of de-emphasis
|
||||||
|
for an Upstream component. 1b:-3.5 dB 0b:-6 dB. 0:Disable, 1:Enable(Default).
|
||||||
|
**/
|
||||||
|
uint8_t PcieRpSelectableDeemphasis[6];
|
||||||
|
|
||||||
|
/** Offset 0x0326
|
||||||
|
**/
|
||||||
|
uint8_t ReservedFspsUpd[10];
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
|
||||||
/** Fsp S Test Configuration
|
/** Fsp S Test Configuration
|
||||||
**/
|
**/
|
||||||
struct FSP_S_TEST_CONFIG {
|
struct FSP_S_TEST_CONFIG {
|
||||||
|
|
||||||
/** Offset 0x0300
|
/** Offset 0x0330
|
||||||
**/
|
**/
|
||||||
uint32_t Signature;
|
uint32_t Signature;
|
||||||
|
|
||||||
/** Offset 0x0304
|
/** Offset 0x0334
|
||||||
**/
|
**/
|
||||||
uint8_t ReservedFspsTestUpd[12];
|
uint8_t ReservedFspsTestUpd[12];
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
@ -1341,17 +1499,15 @@ struct FSP_S_TEST_CONFIG {
|
||||||
**/
|
**/
|
||||||
struct FSP_S_RESTRICTED_CONFIG {
|
struct FSP_S_RESTRICTED_CONFIG {
|
||||||
|
|
||||||
/** Offset 0x0310
|
/** Offset 0x0340
|
||||||
**/
|
**/
|
||||||
uint32_t Signature;
|
uint32_t Signature;
|
||||||
|
|
||||||
/** Offset 0x0314
|
/** Offset 0x0344
|
||||||
**/
|
**/
|
||||||
uint8_t ReservedFspsRestrictedUpd[12];
|
uint8_t ReservedFspsRestrictedUpd[12];
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
|
||||||
#define FSPS_UPD_SIGNATURE 0x4450555F53505346 /* 'FSPS_UPD' */
|
|
||||||
|
|
||||||
/** Fsp S UPD Configuration
|
/** Fsp S UPD Configuration
|
||||||
**/
|
**/
|
||||||
struct FSPS_UPD {
|
struct FSPS_UPD {
|
||||||
|
@ -1364,15 +1520,15 @@ struct FSPS_UPD {
|
||||||
**/
|
**/
|
||||||
struct FSP_S_CONFIG FspsConfig;
|
struct FSP_S_CONFIG FspsConfig;
|
||||||
|
|
||||||
/** Offset 0x0300
|
/** Offset 0x0330
|
||||||
**/
|
**/
|
||||||
struct FSP_S_TEST_CONFIG FspsTestConfig;
|
struct FSP_S_TEST_CONFIG FspsTestConfig;
|
||||||
|
|
||||||
/** Offset 0x0310
|
/** Offset 0x0340
|
||||||
**/
|
**/
|
||||||
struct FSP_S_RESTRICTED_CONFIG FspsRestrictedConfig;
|
struct FSP_S_RESTRICTED_CONFIG FspsRestrictedConfig;
|
||||||
|
|
||||||
/** Offset 0x0320
|
/** Offset 0x0350
|
||||||
**/
|
**/
|
||||||
uint16_t UpdTerminator;
|
uint16_t UpdTerminator;
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
|
|
@ -218,7 +218,7 @@ static void fill_console_params(struct FSPM_UPD *mupd)
|
||||||
void platform_fsp_memory_init_params_cb(struct FSPM_UPD *mupd)
|
void platform_fsp_memory_init_params_cb(struct FSPM_UPD *mupd)
|
||||||
{
|
{
|
||||||
const struct mrc_saved_data *mrc_cache;
|
const struct mrc_saved_data *mrc_cache;
|
||||||
struct FSP_M_ARCH_UPD *arch_upd = &mupd->FspmArchUpd;
|
struct FSPM_ARCH_UPD *arch_upd = &mupd->FspmArchUpd;
|
||||||
struct chipset_power_state *ps = car_get_var_ptr(&power_state);
|
struct chipset_power_state *ps = car_get_var_ptr(&power_state);
|
||||||
int prev_sleep_state = chipset_prev_sleep_state(ps);
|
int prev_sleep_state = chipset_prev_sleep_state(ps);
|
||||||
|
|
||||||
|
@ -226,12 +226,7 @@ void platform_fsp_memory_init_params_cb(struct FSPM_UPD *mupd)
|
||||||
mainboard_memory_init_params(mupd);
|
mainboard_memory_init_params(mupd);
|
||||||
|
|
||||||
/* Do NOT let FSP do any GPIO pad configuration */
|
/* Do NOT let FSP do any GPIO pad configuration */
|
||||||
mupd->FspmConfig.GpioPadInitTablePtr = NULL;
|
mupd->FspmConfig.PreMemGpioTablePtr = (uintptr_t) NULL;
|
||||||
/*
|
|
||||||
* At FIT_POINTER there is an address that points to FIT. Even though it
|
|
||||||
* is technically 64bit value we know only 32bit address is used.
|
|
||||||
*/
|
|
||||||
mupd->FspmConfig.FitTablePtr = read32((void*) FIT_POINTER);
|
|
||||||
/* Reserve enough memory under TOLUD to save CBMEM header */
|
/* Reserve enough memory under TOLUD to save CBMEM header */
|
||||||
mupd->FspmArchUpd.BootLoaderTolumSize = cbmem_overhead_size();
|
mupd->FspmArchUpd.BootLoaderTolumSize = cbmem_overhead_size();
|
||||||
/*
|
/*
|
||||||
|
@ -247,18 +242,18 @@ void platform_fsp_memory_init_params_cb(struct FSPM_UPD *mupd)
|
||||||
mupd->FspmArchUpd.StackBase = _car_region_end -
|
mupd->FspmArchUpd.StackBase = _car_region_end -
|
||||||
mupd->FspmArchUpd.StackSize;
|
mupd->FspmArchUpd.StackSize;
|
||||||
#endif
|
#endif
|
||||||
arch_upd->Bootmode = FSP_BOOT_WITH_FULL_CONFIGURATION;
|
arch_upd->BootMode = FSP_BOOT_WITH_FULL_CONFIGURATION;
|
||||||
|
|
||||||
if (IS_ENABLED(CONFIG_CACHE_MRC_SETTINGS)) {
|
if (IS_ENABLED(CONFIG_CACHE_MRC_SETTINGS)) {
|
||||||
if (!mrc_cache_get_current_with_version(&mrc_cache, 0)) {
|
if (!mrc_cache_get_current_with_version(&mrc_cache, 0)) {
|
||||||
/* MRC cache found */
|
/* MRC cache found */
|
||||||
arch_upd->NvsBufferPtr = (void *)mrc_cache->data;
|
arch_upd->NvsBufferPtr = (void *)mrc_cache->data;
|
||||||
arch_upd->Bootmode =
|
arch_upd->BootMode =
|
||||||
prev_sleep_state == SLEEP_STATE_S3 ?
|
prev_sleep_state == SLEEP_STATE_S3 ?
|
||||||
FSP_BOOT_ON_S3_RESUME:
|
FSP_BOOT_ON_S3_RESUME:
|
||||||
FSP_BOOT_ASSUMING_NO_CONFIGURATION_CHANGES;
|
FSP_BOOT_ASSUMING_NO_CONFIGURATION_CHANGES;
|
||||||
printk(BIOS_DEBUG, "MRC cache found, size %x bootmode:%d\n",
|
printk(BIOS_DEBUG, "MRC cache found, size %x bootmode:%d\n",
|
||||||
mrc_cache->size, arch_upd->Bootmode);
|
mrc_cache->size, arch_upd->BootMode);
|
||||||
} else
|
} else
|
||||||
printk(BIOS_DEBUG, "MRC cache was not found\n");
|
printk(BIOS_DEBUG, "MRC cache was not found\n");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue