/* $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: 47940 $ @e \$Date: 2011-03-02 14:25:35 +0800 (Wed, 02 Mar 2011) $ */ /***************************************************************************** * * Copyright (c) 2011, 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) && (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[] = { { (UINTN) MemUWriteCachelines, "WriteCl(PhyAddrLo,BufferAddr,ClCnt)"}, { (UINTN) MemUReadCachelines, "ReadCl(BufferAddr,PhyAddrLo,ClCnt)"}, { (UINTN) MemUFlushPattern, "FlushCl(PhyAddrLo,ClCnt)"} }; #elif (AGESA_ENTRY_INIT_RECOVERY == TRUE) #include CONST SCRIPT_FUNCTION ROMDATA ScriptFuncList[] = { { (UINTN) MemRecUWrite1CL, "Write1Cl(PhyAddrLo,BufferAddr)"}, { (UINTN) MemRecURead1CL, "Read1Cl(BufferAddr,PhyAddrLo)"}, { (UINTN) MemRecUFlushPattern, "Flush1Cl(PhyAddrLo)"} }; #else CONST SCRIPT_FUNCTION ROMDATA ScriptFuncList[] = { { (UINTN) CommonReturnFalse, "DefRet()"}, { (UINTN) CommonReturnFalse, "DefRet()"}, { (UINTN) CommonReturnFalse, "DefRet()"} }; #endif #endif ///Ids Feat Options #if (IDSOPT_IDS_ENABLED == 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 #define OPTION_IDS_FEAT_CPB_CTRL\ OPTION_IDS_FEAT_CPB_CTRL_F12 #define OPTION_IDS_FEAT_HTC_CTRL\ OPTION_IDS_FEAT_HTC_CTRL_F15 #define OPTION_IDS_FEAT_MEMORY_MAPPING\ OPTION_IDS_FEAT_MEMORY_MAPPING_F12 \ OPTION_IDS_FEAT_MEMORY_MAPPING_F15_OR #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_FEAT_STRUCT ROMDATA IdsFeatEccSymbolSizeBlockF10; #undef OPTION_IDS_FEAT_ECCSYMBOLSIZE_F10 #define OPTION_IDS_FEAT_ECCSYMBOLSIZE_F10 &IdsFeatEccSymbolSizeBlockF10, //ECC scrub control extern CONST IDS_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_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 #ifdef OPTION_FAMILY12H #if OPTION_FAMILY12H == TRUE extern CONST IDS_FEAT_STRUCT ROMDATA IdsFeatGnbPlatformCfgBlockF12; #undef OPTION_IDS_FEAT_GNB_PLATFORMCFGF12 #define OPTION_IDS_FEAT_GNB_PLATFORMCFGF12 &IdsFeatGnbPlatformCfgBlockF12, //ECC scrub control extern CONST IDS_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_FEAT_STRUCT ROMDATA IdsFeatCpbCtrlBlockF12; #define OPTION_IDS_FEAT_CPB_CTRL_F12 &IdsFeatCpbCtrlBlockF12, #endif #endif /*---------------------------------------------------------------------------- * Family 14 feat blocks * *---------------------------------------------------------------------------- */ #define OPTION_IDS_FEAT_GNB_PLATFORMCFGF14 #ifdef OPTION_FAMILY14H #if OPTION_FAMILY14H == TRUE extern CONST IDS_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_FEAT_STRUCT ROMDATA IdsFeatHtcControlBlockF15Or; extern CONST IDS_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_FEAT_STRUCT ROMDATA IdsFeatMemoryMappingPostBeforeBlockF15Or; extern CONST IDS_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_FEAT_STRUCT ROMDATA IdsFeatHtAssistBlockPlatformCfgF15Or; #undef OPTION_IDS_FEAT_HT_ASSIST_F15_OR #define OPTION_IDS_FEAT_HT_ASSIST_F15_OR\ &IdsFeatHtAssistBlockPlatformCfgF15Or, extern CONST IDS_FEAT_STRUCT ROMDATA IdsFeatEccCtrlBlockF15Or; #undef OPTION_IDS_FEAT_ECCCTRL_F15_OR #define OPTION_IDS_FEAT_ECCCTRL_F15_OR &IdsFeatEccCtrlBlockF15Or, extern CONST IDS_FEAT_STRUCT ROMDATA IdsFeatEccSymbolSizeBlockF15Or; #undef OPTION_IDS_FEAT_ECCSYMBOLSIZE_F15_OR #define OPTION_IDS_FEAT_ECCSYMBOLSIZE_F15_OR &IdsFeatEccSymbolSizeBlockF15Or, #endif #endif CONST IDS_FEAT_STRUCT ROMDATA IdsFeatUcodeBlock = { IDS_FEAT_UCODE_UPDATE, IDS_ALL_CORES, IDS_UCODE, IDS_FAMILY_ALL, IdsSubUCode }; CONST IDS_FEAT_STRUCT ROMDATA IdsFeatPowerPolicyBlock = { IDS_FEAT_POWER_POLICY, IDS_ALL_CORES, IDS_PLATFORMCFG_OVERRIDE, IDS_FAMILY_ALL, IdsSubPowerPolicyOverride }; CONST IDS_FEAT_STRUCT ROMDATA IdsFeatTargetPstateBlock = { IDS_FEAT_TARGET_PSTATE, IDS_BSP_ONLY, IDS_INIT_LATE_AFTER, IDS_FAMILY_ALL, IdsSubTargetPstate }; CONST IDS_FEAT_STRUCT ROMDATA IdsFeatPostPstateBlock = { IDS_FEAT_POSTPSTATE, IDS_ALL_CORES, IDS_CPU_Early_Override, IDS_FAMILY_ALL, IdsSubPostPState }; //Dram controller Features CONST IDS_FEAT_STRUCT ROMDATA IdsFeatDctAllMemClkBlock = { IDS_FEAT_DCT_ALLMEMCLK, IDS_BSP_ONLY, IDS_ALL_MEMORY_CLOCK, IDS_FAMILY_ALL, IdsSubAllMemClkEn }; CONST IDS_FEAT_STRUCT ROMDATA IdsFeatDctGangModeBlock = { IDS_FEAT_DCT_GANGMODE, IDS_BSP_ONLY, IDS_GANGING_MODE, IDS_FAMILY_ALL, IdsSubGangingMode }; CONST IDS_FEAT_STRUCT ROMDATA IdsFeatDctBurstLengthBlock = { IDS_FEAT_DCT_BURSTLENGTH, IDS_BSP_ONLY, IDS_BURST_LENGTH32, AMD_FAMILY_10, IdsSubBurstLength32 }; CONST IDS_FEAT_STRUCT ROMDATA IdsFeatDctPowerDownCtrlBlock = { IDS_FEAT_DCT_POWERDOWN, IDS_BSP_ONLY, IDS_INIT_POST_BEFORE, IDS_FAMILY_ALL, IdsSubPowerDownCtrl }; CONST IDS_FEAT_STRUCT ROMDATA IdsFeatDctDllShutDownBlock = { IDS_FEAT_DCT_DLLSHUTDOWN, IDS_BSP_ONLY, IDS_DLL_SHUT_DOWN, IDS_FAMILY_ALL, IdsSubDllShutDownSR }; CONST IDS_FEAT_STRUCT ROMDATA IdsFeatDctPowerDownModeBlock = { IDS_FEAT_DCT_POWERDOWN, IDS_BSP_ONLY, IDS_POWERDOWN_MODE, IDS_FAMILY_ALL, IdsSubPowerDownMode }; CONST IDS_FEAT_STRUCT ROMDATA IdsFeatHdtOutBlock = { IDS_FEAT_HDTOUT, IDS_BSP_ONLY, IDS_INIT_EARLY_BEFORE, IDS_FAMILY_ALL, IdsSubHdtOut }; CONST IDS_FEAT_STRUCT ROMDATA IdsFeatHtSettingBlock = { IDS_FEAT_HT_SETTING, IDS_BSP_ONLY, IDS_HT_CONTROL, IDS_FAMILY_ALL, IdsSubHtLinkControl }; CONST IDS_FEAT_STRUCT* ROMDATA IdsCommonFeats[] = { &IdsFeatUcodeBlock, &IdsFeatPowerPolicyBlock, &IdsFeatTargetPstateBlock, &IdsFeatPostPstateBlock, 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_FEAT_STRUCT* ROMDATA IdsCommonFeats[] = { NULL }; #endif//IDSOPT_CONTROL_ENABLED #else CONST IDS_FEAT_STRUCT* ROMDATA IdsCommonFeats[] = { NULL }; #endif// IDSOPT_IDS_ENABLED #endif