/* $NoKeywords:$ */ /** * @file * * IDS Option Install File * * This file generates the defaults tables for family 10h model 5 processors. * * @xrefitem bom "File Content Label" "Release Content" * @e project: AGESA * @e sub-project: Core * @e \$Revision: 55277 $ @e \$Date: 2011-06-19 23:03:21 -0600 (Sun, 19 Jun 2011) $ */ /***************************************************************************** * * Copyright (C) 2012 Advanced Micro Devices, Inc. * 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 Advanced Micro Devices, Inc. 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 ADVANCED MICRO DEVICES, INC. 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. * * ***************************************************************************/ #ifndef _OPTION_IDS_INSTALL_H_ #define _OPTION_IDS_INSTALL_H_ #include "Ids.h" #include "IdsHt.h" #include "IdsLib.h" #ifdef __IDS_EXTENDED__ #include OPTION_IDS_EXT_INSTALL_FILE #endif #define IDS_LATE_RUN_AP_TASK #define M_HTIDS_PORT_OVERRIDE_HOOK (PF_HtIdsGetPortOverride)CommonVoid #if (IDSOPT_IDS_ENABLED == TRUE) #if (IDSOPT_CONTROL_ENABLED == TRUE) // Check for all families which include HT Features. #if ((OPTION_FAMILY10H == TRUE) || (OPTION_FAMILY15H_OR == TRUE) || (OPTION_FAMILY15H_KM == TRUE)) && (AGESA_ENTRY_INIT_POST == TRUE) #undef M_HTIDS_PORT_OVERRIDE_HOOK #define M_HTIDS_PORT_OVERRIDE_HOOK HtIdsGetPortOverride #endif #endif #endif // OPTION_IDS_LEVEL CONST PF_HtIdsGetPortOverride ROMDATA pf_HtIdsGetPortOverride = M_HTIDS_PORT_OVERRIDE_HOOK; #if (IDSOPT_IDS_ENABLED == TRUE) #if (AGESA_ENTRY_INIT_LATE == TRUE) #undef IDS_LATE_RUN_AP_TASK #define IDS_LATE_RUN_AP_TASK #endif #endif // OPTION_IDS_LEVEL #if (IDSOPT_TRACING_ENABLED == TRUE) #if (AGESA_ENTRY_INIT_POST == TRUE) #include CONST SCRIPT_FUNCTION ROMDATA ScriptFuncList[] = { { (UINT32) (UINT64) MemUWriteCachelines, "WriteCl(PhyAddrLo,BufferAddr,ClCnt)"}, { (UINT32) (UINT64) MemUReadCachelines, "ReadCl(BufferAddr,PhyAddrLo,ClCnt)"}, { (UINT32) (UINT64) MemUFlushPattern, "FlushCl(PhyAddrLo,ClCnt)"} }; #elif (AGESA_ENTRY_INIT_RECOVERY == TRUE) #include CONST SCRIPT_FUNCTION ROMDATA ScriptFuncList[] = { { (UINT32) (UINT64) MemRecUWrite1CL, "Write1Cl(PhyAddrLo,BufferAddr)"}, { (UINT32) (UINT64) MemRecURead1CL, "Read1Cl(BufferAddr,PhyAddrLo)"}, { (UINT32) (UINT64) MemRecUFlushPattern, "Flush1Cl(PhyAddrLo)"} }; #else CONST SCRIPT_FUNCTION ROMDATA ScriptFuncList[] = { { (UINT32) (UINT64) CommonReturnFalse, "DefRet()"}, { (UINT32) (UINT64) CommonReturnFalse, "DefRet()"}, { (UINT32) (UINT64) CommonReturnFalse, "DefRet()"} }; #endif #else CONST SCRIPT_FUNCTION ROMDATA ScriptFuncList[] = { { (UINT32) (UINT64) CommonReturnFalse, "DefRet()"}, { (UINT32) (UINT64) CommonReturnFalse, "DefRet()"}, { (UINT32) (UINT64) CommonReturnFalse, "DefRet()"} }; #endif #define NV_TO_CMOS(Len, NV_ID) {Len, NV_ID}, #define OPTION_IDS_NV_TO_CMOS_END NV_TO_CMOS (IDS_NV_TO_CMOS_LEN_END, IDS_NV_TO_CMOS_ID_END) #if (IDSOPT_IDS_ENABLED == TRUE) #if ((IDSOPT_CONTROL_ENABLED == TRUE) && \ ((AGESA_ENTRY_INIT_EARLY == TRUE) || (AGESA_ENTRY_INIT_POST == TRUE) || (AGESA_ENTRY_INIT_ENV == TRUE) || \ (AGESA_ENTRY_INIT_MID == TRUE) || (AGESA_ENTRY_INIT_LATE == TRUE) || (AGESA_ENTRY_INIT_S3SAVE == TRUE) || \ (AGESA_ENTRY_INIT_RESUME == TRUE) || (AGESA_ENTRY_INIT_LATE_RESTORE == TRUE))) #if (IDSOPT_CONTROL_NV_TO_CMOS == TRUE) #define OPTION_IDS_NV_TO_CMOS_COMMON #ifdef OPTION_FAMILY10H #if OPTION_FAMILY10H == TRUE #define OPTION_IDS_NV_TO_CMOS_F10 #endif #endif #ifdef OPTION_FAMILY12H #if OPTION_FAMILY12H == TRUE #define OPTION_IDS_NV_TO_CMOS_F12 #endif #endif #ifdef OPTION_FAMILY14H #if OPTION_FAMILY14H == TRUE #define OPTION_IDS_NV_TO_CMOS_F14 #endif #endif #ifdef OPTION_FAMILY15H_OR #if OPTION_FAMILY15H_OR == TRUE #define OPTION_IDS_NV_TO_CMOS_F15_OR #endif #endif #ifdef OPTION_FAMILY15H_TN #if OPTION_FAMILY15H_TN == TRUE #define OPTION_IDS_NV_TO_CMOS_F15_TN\ {IDS_NV_TO_CMOS_LEN_BYTE, AGESA_IDS_NV_UCODE}, #endif #endif #ifndef OPTION_IDS_NV_TO_CMOS_F10 #define OPTION_IDS_NV_TO_CMOS_F10 #endif #ifndef OPTION_IDS_NV_TO_CMOS_F12 #define OPTION_IDS_NV_TO_CMOS_F12 #endif #ifndef OPTION_IDS_NV_TO_CMOS_F14 #define OPTION_IDS_NV_TO_CMOS_F14 #endif #ifndef OPTION_IDS_NV_TO_CMOS_F15_OR #define OPTION_IDS_NV_TO_CMOS_F15_OR #endif #ifndef OPTION_IDS_NV_TO_CMOS_F15_TN #define OPTION_IDS_NV_TO_CMOS_F15_TN #endif #ifndef OPTION_IDS_NV_TO_CMOS_EXTEND #define OPTION_IDS_NV_TO_CMOS_EXTEND #endif IDS_NV_TO_CMOS gIdsNVToCmos[] = { OPTION_IDS_NV_TO_CMOS_COMMON OPTION_IDS_NV_TO_CMOS_F10 OPTION_IDS_NV_TO_CMOS_F12 OPTION_IDS_NV_TO_CMOS_F14 OPTION_IDS_NV_TO_CMOS_F15_OR OPTION_IDS_NV_TO_CMOS_F15_TN OPTION_IDS_NV_TO_CMOS_EXTEND OPTION_IDS_NV_TO_CMOS_END }; #else IDS_NV_TO_CMOS gIdsNVToCmos[] = { OPTION_IDS_NV_TO_CMOS_END }; #endif #else IDS_NV_TO_CMOS gIdsNVToCmos[] = { OPTION_IDS_NV_TO_CMOS_END }; #endif #else IDS_NV_TO_CMOS gIdsNVToCmos[] = { OPTION_IDS_NV_TO_CMOS_END }; #endif ///Ids Feat Options #if ((IDSOPT_IDS_ENABLED == TRUE) && \ ((AGESA_ENTRY_INIT_EARLY == TRUE) || (AGESA_ENTRY_INIT_POST == TRUE) || (AGESA_ENTRY_INIT_ENV == TRUE) || \ (AGESA_ENTRY_INIT_MID == TRUE) || (AGESA_ENTRY_INIT_LATE == TRUE) || (AGESA_ENTRY_INIT_S3SAVE == TRUE) || \ (AGESA_ENTRY_INIT_RESUME == TRUE) || (AGESA_ENTRY_INIT_LATE_RESTORE == TRUE))) #if (IDSOPT_CONTROL_ENABLED == TRUE) #ifndef OPTION_IDS_EXTEND_FEATS #define OPTION_IDS_EXTEND_FEATS #endif #define OPTION_IDS_FEAT_ECCCTRL\ OPTION_IDS_FEAT_ECCCTRL_F10 \ OPTION_IDS_FEAT_ECCCTRL_F12 \ OPTION_IDS_FEAT_ECCCTRL_F15_OR #define OPTION_IDS_FEAT_GNB_PLATFORMCFG\ OPTION_IDS_FEAT_GNB_PLATFORMCFGF12 \ OPTION_IDS_FEAT_GNB_PLATFORMCFGF14 \ OPTION_IDS_FEAT_GNB_PLATFORMCFGF15TN #define OPTION_IDS_FEAT_CPB_CTRL\ OPTION_IDS_FEAT_CPB_CTRL_F12 #define OPTION_IDS_FEAT_HTC_CTRL\ OPTION_IDS_FEAT_HTC_CTRL_F15_OR \ OPTION_IDS_FEAT_HTC_CTRL_F15_TN #define OPTION_IDS_FEAT_MEMORY_MAPPING\ OPTION_IDS_FEAT_MEMORY_MAPPING_F12 \ OPTION_IDS_FEAT_MEMORY_MAPPING_F15_OR \ OPTION_IDS_FEAT_MEMORY_MAPPING_F15_TN #define OPTION_IDS_FEAT_HT_ASSIST\ OPTION_IDS_FEAT_HT_ASSIST_F10HY \ OPTION_IDS_FEAT_HT_ASSIST_F15_OR #define OPTION_IDS_FEAT_ECCSYMBOLSIZE\ OPTION_IDS_FEAT_ECCSYMBOLSIZE_F10 \ OPTION_IDS_FEAT_ECCSYMBOLSIZE_F15_OR /*---------------------------------------------------------------------------- * Family 10 feat blocks * *---------------------------------------------------------------------------- */ #define OPTION_IDS_FEAT_ECCSYMBOLSIZE_F10 #define OPTION_IDS_FEAT_ECCCTRL_F10 #ifdef OPTION_FAMILY10H #if OPTION_FAMILY10H == TRUE //Ecc symbol size extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatEccSymbolSizeBlockF10; #undef OPTION_IDS_FEAT_ECCSYMBOLSIZE_F10 #define OPTION_IDS_FEAT_ECCSYMBOLSIZE_F10 &IdsFeatEccSymbolSizeBlockF10, //ECC scrub control extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatEccCtrlBlockF10; #undef OPTION_IDS_FEAT_ECCCTRL_F10 #define OPTION_IDS_FEAT_ECCCTRL_F10 &IdsFeatEccCtrlBlockF10, #endif #endif //Misc Features #define OPTION_IDS_FEAT_HT_ASSIST_F10HY #ifdef OPTION_FAMILY10H_HY #if OPTION_FAMILY10H_HY == TRUE #undef OPTION_IDS_FEAT_HT_ASSIST_F10HY extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatHtAssistBlockPlatformCfgF10Hy; #define OPTION_IDS_FEAT_HT_ASSIST_F10HY \ &IdsFeatHtAssistBlockPlatformCfgF10Hy, #endif #endif /*---------------------------------------------------------------------------- * Family 12 feat blocks * *---------------------------------------------------------------------------- */ #define OPTION_IDS_FEAT_GNB_PLATFORMCFGF12 #define OPTION_IDS_FEAT_ECCCTRL_F12 #define OPTION_IDS_FEAT_CPB_CTRL_F12 #define OPTION_IDS_FEAT_MEMORY_MAPPING_F12 #ifdef OPTION_FAMILY12H #if OPTION_FAMILY12H == TRUE extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatGnbPlatformCfgBlockF12; #undef OPTION_IDS_FEAT_GNB_PLATFORMCFGF12 #define OPTION_IDS_FEAT_GNB_PLATFORMCFGF12 &IdsFeatGnbPlatformCfgBlockF12, //ECC scrub control extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatEccCtrlBlockF12; #undef OPTION_IDS_FEAT_ECCCTRL_F12 #define OPTION_IDS_FEAT_ECCCTRL_F12 &IdsFeatEccCtrlBlockF12, #undef OPTION_IDS_FEAT_CPB_CTRL_F12 extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatCpbCtrlBlockF12; #define OPTION_IDS_FEAT_CPB_CTRL_F12 &IdsFeatCpbCtrlBlockF12, extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatMemoryChIntlvPostBeforeBlockF12; extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatMemoryMappingChIntlvBlockF12; #undef OPTION_IDS_FEAT_MEMORY_MAPPING_F12 #define OPTION_IDS_FEAT_MEMORY_MAPPING_F12 \ &IdsFeatMemoryChIntlvPostBeforeBlockF12, \ &IdsFeatMemoryMappingChIntlvBlockF12, #endif #endif /*---------------------------------------------------------------------------- * Family 14 feat blocks * *---------------------------------------------------------------------------- */ #define OPTION_IDS_FEAT_GNB_PLATFORMCFGF14 #ifdef OPTION_FAMILY14H #if OPTION_FAMILY14H == TRUE extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatGnbPlatformCfgBlockF14; #undef OPTION_IDS_FEAT_GNB_PLATFORMCFGF14 #define OPTION_IDS_FEAT_GNB_PLATFORMCFGF14 &IdsFeatGnbPlatformCfgBlockF14, #endif #endif /*---------------------------------------------------------------------------- * Family 15 OR feat blocks * *---------------------------------------------------------------------------- */ #define OPTION_IDS_FEAT_HTC_CTRL_F15_OR #define OPTION_IDS_FEAT_MEMORY_MAPPING_F15_OR #define OPTION_IDS_FEAT_HT_ASSIST_F15_OR #define OPTION_IDS_FEAT_ECCCTRL_F15_OR #define OPTION_IDS_FEAT_ECCSYMBOLSIZE_F15_OR #ifdef OPTION_FAMILY15H_OR #if OPTION_FAMILY15H_OR == TRUE extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatHtcControlBlockF15Or; extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatHtcControlLateBlockF15Or; #undef OPTION_IDS_FEAT_HTC_CTRL_F15_OR #define OPTION_IDS_FEAT_HTC_CTRL_F15_OR\ &IdsFeatHtcControlBlockF15Or,\ &IdsFeatHtcControlLateBlockF15Or, extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatMemoryMappingPostBeforeBlockF15Or; extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatMemoryMappingChIntlvBlockF15Or; #undef OPTION_IDS_FEAT_MEMORY_MAPPING_F15_OR #define OPTION_IDS_FEAT_MEMORY_MAPPING_F15_OR\ &IdsFeatMemoryMappingPostBeforeBlockF15Or,\ &IdsFeatMemoryMappingChIntlvBlockF15Or, extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatHtAssistBlockPlatformCfgF15Or; #undef OPTION_IDS_FEAT_HT_ASSIST_F15_OR #define OPTION_IDS_FEAT_HT_ASSIST_F15_OR\ &IdsFeatHtAssistBlockPlatformCfgF15Or, extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatEccCtrlBlockF15Or; #undef OPTION_IDS_FEAT_ECCCTRL_F15_OR #define OPTION_IDS_FEAT_ECCCTRL_F15_OR &IdsFeatEccCtrlBlockF15Or, extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatEccSymbolSizeBlockF15Or; #undef OPTION_IDS_FEAT_ECCSYMBOLSIZE_F15_OR #define OPTION_IDS_FEAT_ECCSYMBOLSIZE_F15_OR &IdsFeatEccSymbolSizeBlockF15Or, #endif #endif /*---------------------------------------------------------------------------- * Family 15 TN feat blocks * *---------------------------------------------------------------------------- */ #define OPTION_IDS_FEAT_HTC_CTRL_F15_TN #define OPTION_IDS_FEAT_MEMORY_MAPPING_F15_TN #define OPTION_IDS_FEAT_GNB_PLATFORMCFGF15TN #ifdef OPTION_FAMILY15H_TN #if OPTION_FAMILY15H_TN == TRUE extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatHtcControlBlockF15Tn; #undef OPTION_IDS_FEAT_HTC_CTRL_F15_TN #define OPTION_IDS_FEAT_HTC_CTRL_F15_TN\ &IdsFeatHtcControlBlockF15Tn, extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatMemoryMappingPostBeforeBlockF15Tn; extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatMemoryMappingChIntlvBlockF15Tn; #undef OPTION_IDS_FEAT_MEMORY_MAPPING_F15_TN #define OPTION_IDS_FEAT_MEMORY_MAPPING_F15_TN\ &IdsFeatMemoryMappingPostBeforeBlockF15Tn,\ &IdsFeatMemoryMappingChIntlvBlockF15Tn, extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatGnbPlatformCfgBlockF15Tn; #undef OPTION_IDS_FEAT_GNB_PLATFORMCFGF15TN #define OPTION_IDS_FEAT_GNB_PLATFORMCFGF15TN &IdsFeatGnbPlatformCfgBlockF15Tn, #endif #endif #define OPTION_IDS_FEAT_NV_TO_CMOS #if IDSOPT_CONTROL_NV_TO_CMOS == TRUE #undef OPTION_IDS_FEAT_NV_TO_CMOS extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatNvToCmosSaveBlock; extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatNvToCmosRestoreBlock; #define OPTION_IDS_FEAT_NV_TO_CMOS\ &IdsFeatNvToCmosSaveBlock, \ &IdsFeatNvToCmosRestoreBlock, #endif CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatUcodeBlock = { IDS_FEAT_UCODE_UPDATE, IDS_ALL_CORES, IDS_UCODE, IDS_FAMILY_ALL, IdsSubUCode }; CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatPowerPolicyBlock = { IDS_FEAT_POWER_POLICY, IDS_ALL_CORES, IDS_PLATFORMCFG_OVERRIDE, IDS_FAMILY_ALL, IdsSubPowerPolicyOverride }; CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatTargetPstateBlock = { IDS_FEAT_TARGET_PSTATE, IDS_BSP_ONLY, IDS_INIT_LATE_AFTER, IDS_FAMILY_ALL, IdsSubTargetPstate }; CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatPostPstateBlock = { IDS_FEAT_POSTPSTATE, IDS_ALL_CORES, IDS_CPU_Early_Override, IDS_FAMILY_ALL, IdsSubPostPState }; //Dram controller Features CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatDctAllMemClkBlock = { IDS_FEAT_DCT_ALLMEMCLK, IDS_BSP_ONLY, IDS_ALL_MEMORY_CLOCK, IDS_FAMILY_ALL, IdsSubAllMemClkEn }; CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatDctGangModeBlock = { IDS_FEAT_DCT_GANGMODE, IDS_BSP_ONLY, IDS_GANGING_MODE, IDS_FAMILY_ALL, IdsSubGangingMode }; CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatDctBurstLengthBlock = { IDS_FEAT_DCT_BURSTLENGTH, IDS_BSP_ONLY, IDS_BURST_LENGTH32, AMD_FAMILY_10, IdsSubBurstLength32 }; CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatDctPowerDownCtrlBlock = { IDS_FEAT_DCT_POWERDOWN, IDS_BSP_ONLY, IDS_INIT_POST_BEFORE, IDS_FAMILY_ALL, IdsSubPowerDownCtrl }; CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatDctDllShutDownBlock = { IDS_FEAT_DCT_DLLSHUTDOWN, IDS_BSP_ONLY, IDS_DLL_SHUT_DOWN, IDS_FAMILY_ALL, IdsSubDllShutDownSR }; CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatDctPowerDownModeBlock = { IDS_FEAT_DCT_POWERDOWN, IDS_BSP_ONLY, IDS_POWERDOWN_MODE, IDS_FAMILY_ALL, IdsSubPowerDownMode }; CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatHdtOutBlock = { IDS_FEAT_HDTOUT, IDS_BSP_ONLY, IDS_INIT_EARLY_BEFORE, IDS_FAMILY_ALL, IdsSubHdtOut }; CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatHtSettingBlock = { IDS_FEAT_HT_SETTING, IDS_BSP_ONLY, IDS_HT_CONTROL, IDS_FAMILY_ALL, IdsSubHtLinkControl }; CONST IDS_FAMILY_FEAT_STRUCT* ROMDATA IdsContorlFeats[] = { &IdsFeatUcodeBlock, &IdsFeatPowerPolicyBlock, &IdsFeatTargetPstateBlock, &IdsFeatPostPstateBlock, OPTION_IDS_FEAT_NV_TO_CMOS OPTION_IDS_FEAT_ECCSYMBOLSIZE OPTION_IDS_FEAT_ECCCTRL &IdsFeatDctAllMemClkBlock, &IdsFeatDctGangModeBlock, &IdsFeatDctBurstLengthBlock, &IdsFeatDctPowerDownCtrlBlock, &IdsFeatDctPowerDownModeBlock, &IdsFeatDctPowerDownModeBlock, OPTION_IDS_FEAT_HT_ASSIST &IdsFeatHdtOutBlock, &IdsFeatHtSettingBlock, OPTION_IDS_FEAT_GNB_PLATFORMCFG OPTION_IDS_FEAT_CPB_CTRL OPTION_IDS_FEAT_HTC_CTRL OPTION_IDS_FEAT_MEMORY_MAPPING OPTION_IDS_EXTEND_FEATS NULL }; #else CONST IDS_FAMILY_FEAT_STRUCT* ROMDATA IdsContorlFeats[] = { NULL }; #endif//IDSOPT_CONTROL_ENABLED #define OPTION_IDS_FAM_REGACC\ OPTION_IDS_FAM_REGACC_F15TN #define OPTION_IDS_FAM_REGACC_F15TN #ifdef OPTION_FAMILY15H_TN #if OPTION_FAMILY15H_TN == TRUE extern CONST IDS_FAMILY_FEAT_STRUCT ROMDATA IdsFeatRegGmmxF15Tn; #undef OPTION_IDS_FAM_REGACC_F15TN #define OPTION_IDS_FAM_REGACC_F15TN \ &IdsFeatRegGmmxF15Tn, #endif #endif CONST IDS_FAMILY_FEAT_STRUCT* ROMDATA IdsRegAccessTbl[] = { OPTION_IDS_FAM_REGACC NULL }; #else CONST IDS_FAMILY_FEAT_STRUCT* ROMDATA IdsContorlFeats[] = { NULL }; CONST IDS_FAMILY_FEAT_STRUCT* ROMDATA IdsRegAccessTbl[] = { NULL }; #endif// IDSOPT_IDS_ENABLED #endif