| /* $NoKeywords:$ */ |
| /** |
| * @file |
| * |
| * Install of all appropriate CPU family specific support. |
| * |
| * This file generates the defaults tables for all family specific |
| * combinations. |
| * |
| * @xrefitem bom "File Content Label" "Release Content" |
| * @e project: AGESA |
| * @e sub-project: Core |
| * @e \$Revision: 37640 $ @e \$Date: 2010-09-08 23:01:59 +0800 (Wed, 08 Sep 2010) $ |
| */ |
| /* |
| ***************************************************************************** |
| * |
| * 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. |
| * |
| * *************************************************************************** |
| * |
| */ |
| |
| /* Default all CPU Specific Service members to off. They |
| will be enabled as needed by cross referencing families |
| with entry points in the family / model install files. */ |
| #define GET_PSTATE_POWER FALSE |
| #define GET_PSTATE_FREQ FALSE |
| #define DISABLE_PSTATE FALSE |
| #define TRANSITION_PSTATE FALSE |
| #define PROC_IDD_MAX FALSE |
| #define GET_TSC_RATE FALSE |
| #define PSTATE_TRANSITION_LATENCY FALSE |
| #define GET_PSTATE_REGISTER_INFO FALSE |
| #define GET_PSTATE_MAX_STATE FALSE |
| #define SET_PSTATE_LEVELING_REG FALSE |
| #define GET_NB_FREQ FALSE |
| #define IS_NBCOF_INIT_NEEDED FALSE |
| #define AP_INITIAL_LAUNCH FALSE |
| #define GET_AP_MAILBOX_FROM_HW FALSE |
| #define SET_AP_CORE_NUMBER FALSE |
| #define GET_AP_CORE_NUMBER FALSE |
| #define TRANSFER_AP_CORE_NUMBER FALSE |
| #define ID_POSITION_INITIAL_APICID FALSE |
| #define SAVE_FEATURES FALSE |
| #define WRITE_FEATURES FALSE |
| #define SET_DOWN_CORE_REG FALSE |
| #define SET_WARM_RESET_FLAG FALSE |
| #define GET_WARM_RESET_FLAG FALSE |
| #define USES_REGISTER_TABLES FALSE |
| #define BASE_FAMILY_PCI FALSE |
| #define MODEL_SPECIFIC_PCI FALSE |
| #define BASE_FAMILY_MSR FALSE |
| #define MODEL_SPECIFIC_MSR FALSE |
| #define BRAND_STRING1 FALSE |
| #define BRAND_STRING2 FALSE |
| #define BASE_FAMILY_HT_PCI FALSE |
| #define MODEL_SPECIFIC_HT_PCI FALSE |
| #define BASE_FAMILY_WORKAROUNDS FALSE |
| #define GET_PATCHES FALSE |
| #define GET_PATCHES_EQUIVALENCE_TABLE FALSE |
| #define GET_CACHE_INFO FALSE |
| #define GET_SYSTEM_PM_TABLE FALSE |
| #define GET_WHEA_INIT FALSE |
| #define GET_CFOH_REG FALSE |
| #define GET_PLATFORM_TYPE_SPECIFIC_INFO FALSE |
| #define IS_NB_PSTATE_ENABLED FALSE |
| |
| /* |
| * Pull in family specific services based on entry point |
| */ |
| #if AGESA_ENTRY_INIT_RESET == TRUE |
| #undef ID_POSITION_INITIAL_APICID |
| #define ID_POSITION_INITIAL_APICID TRUE |
| #undef GET_AP_MAILBOX_FROM_HW |
| #define GET_AP_MAILBOX_FROM_HW TRUE |
| #undef SET_WARM_RESET_FLAG |
| #define SET_WARM_RESET_FLAG TRUE |
| #undef GET_WARM_RESET_FLAG |
| #define GET_WARM_RESET_FLAG TRUE |
| #undef GET_CACHE_INFO |
| #define GET_CACHE_INFO TRUE |
| #undef GET_AP_CORE_NUMBER |
| #define GET_AP_CORE_NUMBER TRUE |
| #undef TRANSFER_AP_CORE_NUMBER |
| #define TRANSFER_AP_CORE_NUMBER TRUE |
| #endif |
| |
| #if AGESA_ENTRY_INIT_EARLY == TRUE |
| #undef TRANSITION_PSTATE |
| #define TRANSITION_PSTATE TRUE |
| #undef DISABLE_PSTATE |
| #define DISABLE_PSTATE TRUE |
| #undef PROC_IDD_MAX |
| #define PROC_IDD_MAX TRUE |
| #undef GET_TSC_RATE |
| #define GET_TSC_RATE TRUE |
| #undef GET_NB_FREQ |
| #define GET_NB_FREQ TRUE |
| #undef IS_NBCOF_INIT_NEEDED |
| #define IS_NBCOF_INIT_NEEDED TRUE |
| #undef AP_INITIAL_LAUNCH |
| #define AP_INITIAL_LAUNCH TRUE |
| #undef GET_AP_MAILBOX_FROM_HW |
| #define GET_AP_MAILBOX_FROM_HW TRUE |
| #undef SET_AP_CORE_NUMBER |
| #define SET_AP_CORE_NUMBER TRUE |
| #undef GET_AP_CORE_NUMBER |
| #define GET_AP_CORE_NUMBER TRUE |
| #undef TRANSFER_AP_CORE_NUMBER |
| #define TRANSFER_AP_CORE_NUMBER TRUE |
| #undef ID_POSITION_INITIAL_APICID |
| #define ID_POSITION_INITIAL_APICID TRUE |
| #undef SET_DOWN_CORE_REG |
| #define SET_DOWN_CORE_REG TRUE |
| #undef SET_WARM_RESET_FLAG |
| #define SET_WARM_RESET_FLAG TRUE |
| #undef GET_WARM_RESET_FLAG |
| #define GET_WARM_RESET_FLAG TRUE |
| #undef USES_REGISTER_TABLES |
| #define USES_REGISTER_TABLES TRUE |
| #undef BASE_FAMILY_PCI |
| #define BASE_FAMILY_PCI TRUE |
| #undef MODEL_SPECIFIC_PCI |
| #define MODEL_SPECIFIC_PCI TRUE |
| #undef BASE_FAMILY_MSR |
| #define BASE_FAMILY_MSR TRUE |
| #undef MODEL_SPECIFIC_MSR |
| #define MODEL_SPECIFIC_MSR TRUE |
| #undef BRAND_STRING1 |
| #define BRAND_STRING1 TRUE |
| #undef BRAND_STRING2 |
| #define BRAND_STRING2 TRUE |
| #undef BASE_FAMILY_HT_PCI |
| #define BASE_FAMILY_HT_PCI TRUE |
| #undef MODEL_SPECIFIC_HT_PCI |
| #define MODEL_SPECIFIC_HT_PCI TRUE |
| #undef BASE_FAMILY_WORKAROUNDS |
| #define BASE_FAMILY_WORKAROUNDS TRUE |
| #undef GET_PATCHES |
| #define GET_PATCHES TRUE |
| #undef GET_PATCHES_EQUIVALENCE_TABLE |
| #define GET_PATCHES_EQUIVALENCE_TABLE TRUE |
| #undef GET_SYSTEM_PM_TABLE |
| #define GET_SYSTEM_PM_TABLE TRUE |
| #undef GET_CACHE_INFO |
| #define GET_CACHE_INFO TRUE |
| #undef GET_PLATFORM_TYPE_SPECIFIC_INFO |
| #define GET_PLATFORM_TYPE_SPECIFIC_INFO TRUE |
| #undef IS_NB_PSTATE_ENABLED |
| #define IS_NB_PSTATE_ENABLED TRUE |
| #endif |
| |
| #if AGESA_ENTRY_INIT_POST == TRUE |
| #undef ID_POSITION_INITIAL_APICID |
| #define ID_POSITION_INITIAL_APICID TRUE |
| #undef GET_PSTATE_POWER |
| #define GET_PSTATE_POWER TRUE |
| #undef GET_PSTATE_FREQ |
| #define GET_PSTATE_FREQ TRUE |
| #undef TRANSITION_PSTATE |
| #define TRANSITION_PSTATE TRUE |
| #undef PROC_IDD_MAX |
| #define PROC_IDD_MAX TRUE |
| #undef GET_AP_CORE_NUMBER |
| #define GET_AP_CORE_NUMBER TRUE |
| #undef GET_PSTATE_REGISTER_INFO |
| #define GET_PSTATE_REGISTER_INFO TRUE |
| #undef GET_PSTATE_MAX_STATE |
| #define GET_PSTATE_MAX_STATE TRUE |
| #undef SET_PSTATE_LEVELING_REG |
| #define SET_PSTATE_LEVELING_REG TRUE |
| #undef SET_WARM_RESET_FLAG |
| #define SET_WARM_RESET_FLAG TRUE |
| #undef GET_WARM_RESET_FLAG |
| #define GET_WARM_RESET_FLAG TRUE |
| #undef SAVE_FEATURES |
| #define SAVE_FEATURES TRUE |
| #undef WRITE_FEATURES |
| #define WRITE_FEATURES TRUE |
| #undef GET_CFOH_REG |
| #define GET_CFOH_REG TRUE |
| #undef IS_NB_PSTATE_ENABLED |
| #define IS_NB_PSTATE_ENABLED TRUE |
| #endif |
| |
| #if AGESA_ENTRY_INIT_ENV == TRUE |
| #endif |
| |
| #if AGESA_ENTRY_INIT_MID == TRUE |
| #endif |
| |
| #if AGESA_ENTRY_INIT_LATE == TRUE |
| #undef GET_AP_CORE_NUMBER |
| #define GET_AP_CORE_NUMBER TRUE |
| #undef GET_PSTATE_FREQ |
| #define GET_PSTATE_FREQ TRUE |
| #undef TRANSITION_PSTATE |
| #define TRANSITION_PSTATE TRUE |
| #undef PSTATE_TRANSITION_LATENCY |
| #define PSTATE_TRANSITION_LATENCY TRUE |
| #undef GET_WHEA_INIT |
| #define GET_WHEA_INIT TRUE |
| #undef GET_PLATFORM_TYPE_SPECIFIC_INFO |
| #define GET_PLATFORM_TYPE_SPECIFIC_INFO TRUE |
| #undef GET_TSC_RATE |
| #define GET_TSC_RATE TRUE |
| #undef BRAND_STRING1 |
| #define BRAND_STRING1 TRUE |
| #undef BRAND_STRING2 |
| #define BRAND_STRING2 TRUE |
| #endif |
| |
| #if AGESA_ENTRY_INIT_S3SAVE == TRUE |
| #endif |
| |
| #if AGESA_ENTRY_INIT_RESUME == TRUE |
| #undef GET_CFOH_REG |
| #define GET_CFOH_REG TRUE |
| #endif |
| |
| #if AGESA_ENTRY_INIT_LATE_RESTORE == TRUE |
| #endif |
| |
| #if AGESA_ENTRY_INIT_GENERAL_SERVICES == TRUE |
| #undef ID_POSITION_INITIAL_APICID |
| #define ID_POSITION_INITIAL_APICID TRUE |
| #endif |
| |
| /* |
| * Initialize PCI MMIO mask to 0 |
| */ |
| #define FAMILY_MMIO_BASE_MASK (0ull) |
| |
| |
| /* |
| * Initialize all families to disabled |
| */ |
| #define OPT_F14_TABLE |
| |
| #define OPT_F14_ID_TABLE |
| |
| |
| /* |
| * Install family specific support |
| */ |
| |
| #if (OPTION_FAMILY14H == TRUE) |
| #include "OptionFamily14hInstall.h" |
| #endif |
| |
| /* |
| * Process PCI MMIO mask |
| */ |
| |
| // If size is 0, but base is not, break the build. |
| #if (CFG_PCI_MMIO_BASE != 0) && (CFG_PCI_MMIO_SIZE == 0) |
| #error BLDCFG: Invalid PCI MMIO size -- acceptable values are 1, 2, 4, 8, 16, 32, 64, 128, and 256 |
| #endif |
| |
| // If base is 0, but size is not, break the build. |
| #if (CFG_PCI_MMIO_BASE == 0) && (CFG_PCI_MMIO_SIZE != 0) |
| #error BLDCFG: Invalid PCI MMIO base -- must be 8MB or greater |
| #endif |
| |
| #if (CFG_PCI_MMIO_BASE != 0) && (CFG_PCI_MMIO_SIZE != 0) |
| // Both are non-zero, begin further processing. |
| |
| // Heap runs from 4MB to 8MB. Disallow any addresses below 8MB. |
| #if (CFG_PCI_MMIO_BASE < 0x800000) |
| #error BLDCFG: Invalid PCI MMIO base -- must be 8MB or greater |
| #endif |
| |
| // Break the build if the address is too high for the enabled families. |
| #if ((CFG_PCI_MMIO_BASE & FAMILY_MMIO_BASE_MASK) != 0) |
| #error BLDCFG: Invalid PCI MMIO base address for the installed CPU families |
| #endif |
| |
| // If the size parameter is not valid, break the build. |
| #if (CFG_PCI_MMIO_SIZE != 1) && (CFG_PCI_MMIO_SIZE != 2) && (CFG_PCI_MMIO_SIZE != 4) && (CFG_PCI_MMIO_SIZE != 8) && (CFG_PCI_MMIO_SIZE != 16) |
| #if (CFG_PCI_MMIO_SIZE != 32) && (CFG_PCI_MMIO_SIZE != 64) && (CFG_PCI_MMIO_SIZE != 128) && (CFG_PCI_MMIO_SIZE != 256) |
| #error BLDCFG: Invalid PCI MMIO size -- acceptable values are 1, 2, 4, 8, 16, 32, 64, 128, and 256 |
| #endif |
| #endif |
| |
| #define PCI_MMIO_ALIGNMENT ((0x100000 * CFG_PCI_MMIO_SIZE) - 1) |
| // If the base is not aligned according to size, break the build. |
| #if ((CFG_PCI_MMIO_BASE & PCI_MMIO_ALIGNMENT) != 0) |
| #error BLDCFG: Invalid PCI MMIO base -- must be properly aligned according to MMIO size |
| #endif |
| #undef PCI_MMIO_ALIGNMENT |
| #endif |
| |
| /* |
| * Process sockets / modules |
| */ |
| #ifndef ADVCFG_PLATFORM_SOCKETS |
| #error BLDOPT Set Family supported sockets. |
| #endif |
| #ifndef ADVCFG_PLATFORM_MODULES |
| #error BLDOPT Set Family supported modules. |
| #endif |
| |
| CONST OPTIONS_CONFIG_TOPOLOGY ROMDATA TopologyConfiguration = |
| { |
| ADVCFG_PLATFORM_SOCKETS, |
| ADVCFG_PLATFORM_MODULES |
| }; |
| |
| /* |
| * Instantiate global data needed for processor identification |
| */ |
| CONST CPU_SPECIFIC_SERVICES_XLAT ROMDATA CpuSupportedFamiliesArray[] = |
| { |
| OPT_F14_TABLE |
| }; |
| |
| CONST CPU_FAMILY_SUPPORT_TABLE ROMDATA CpuSupportedFamiliesTable = |
| { |
| (sizeof (CpuSupportedFamiliesArray) / sizeof (CPU_SPECIFIC_SERVICES_XLAT)), |
| &CpuSupportedFamiliesArray[0] |
| }; |
| |
| |
| CONST CPU_LOGICAL_ID_FAMILY_XLAT ROMDATA CpuSupportedFamilyIdArray[] = |
| { |
| OPT_F14_ID_TABLE |
| }; |
| |
| CONST CPU_FAMILY_ID_XLAT_TABLE ROMDATA CpuSupportedFamilyIdTable = |
| { |
| (sizeof (CpuSupportedFamilyIdArray) / sizeof (CPU_LOGICAL_ID_FAMILY_XLAT)), |
| CpuSupportedFamilyIdArray |
| }; |