diff options
Diffstat (limited to 'resources/libreboot/patch/kgpe-d16/0032-cpu-amd-Move-model_10xxx-to-family_10h-family_15h.patch')
-rw-r--r-- | resources/libreboot/patch/kgpe-d16/0032-cpu-amd-Move-model_10xxx-to-family_10h-family_15h.patch | 7896 |
1 files changed, 0 insertions, 7896 deletions
diff --git a/resources/libreboot/patch/kgpe-d16/0032-cpu-amd-Move-model_10xxx-to-family_10h-family_15h.patch b/resources/libreboot/patch/kgpe-d16/0032-cpu-amd-Move-model_10xxx-to-family_10h-family_15h.patch deleted file mode 100644 index c70b089f..00000000 --- a/resources/libreboot/patch/kgpe-d16/0032-cpu-amd-Move-model_10xxx-to-family_10h-family_15h.patch +++ /dev/null @@ -1,7896 +0,0 @@ -From a9c46688fdefebdf70848b4aba0021d747baee16 Mon Sep 17 00:00:00 2001 -From: Timothy Pearson <tpearson@raptorengineeringinc.com> -Date: Fri, 16 Oct 2015 14:24:06 -0500 -Subject: [PATCH 032/143] cpu/amd: Move model_10xxx to family_10h-family_15h - -Change-Id: I34501d3fc68b71db7781dad11d5b883868932a60 -Signed-off-by: Timothy Pearson <tpearson@raptorengineeringinc.com> ---- - src/cpu/amd/Kconfig | 2 +- - src/cpu/amd/family_10h-family_15h/Kconfig | 88 ++ - src/cpu/amd/family_10h-family_15h/Makefile.inc | 14 + - src/cpu/amd/family_10h-family_15h/defaults.h | 479 +++++++++ - src/cpu/amd/family_10h-family_15h/fidvid.c | 1048 ++++++++++++++++++++ - src/cpu/amd/family_10h-family_15h/init_cpus.c | 968 ++++++++++++++++++ - .../amd/family_10h-family_15h/model_10xxx_init.c | 165 +++ - .../amd/family_10h-family_15h/monotonic_timer.c | 98 ++ - src/cpu/amd/family_10h-family_15h/powernow_acpi.c | 311 ++++++ - src/cpu/amd/family_10h-family_15h/processor_name.c | 323 ++++++ - src/cpu/amd/family_10h-family_15h/ram_calc.c | 54 + - src/cpu/amd/family_10h-family_15h/ram_calc.h | 25 + - .../amd/family_10h-family_15h/update_microcode.c | 71 ++ - src/cpu/amd/model_10xxx/Kconfig | 88 -- - src/cpu/amd/model_10xxx/Makefile.inc | 14 - - src/cpu/amd/model_10xxx/defaults.h | 479 --------- - src/cpu/amd/model_10xxx/fidvid.c | 1048 -------------------- - src/cpu/amd/model_10xxx/init_cpus.c | 968 ------------------ - src/cpu/amd/model_10xxx/model_10xxx_init.c | 165 --- - src/cpu/amd/model_10xxx/monotonic_timer.c | 98 -- - src/cpu/amd/model_10xxx/powernow_acpi.c | 311 ------ - src/cpu/amd/model_10xxx/processor_name.c | 323 ------ - src/cpu/amd/model_10xxx/ram_calc.c | 54 - - src/cpu/amd/model_10xxx/ram_calc.h | 25 - - src/cpu/amd/model_10xxx/update_microcode.c | 71 -- - src/cpu/amd/socket_AM2r2/Makefile.inc | 2 +- - src/cpu/amd/socket_AM3/Makefile.inc | 2 +- - src/cpu/amd/socket_ASB2/Makefile.inc | 2 +- - src/cpu/amd/socket_C32/Makefile.inc | 2 +- - src/cpu/amd/socket_F_1207/Makefile.inc | 2 +- - src/cpu/amd/socket_G34/Makefile.inc | 2 +- - src/mainboard/advansus/a785e-i/romstage.c | 2 +- - src/mainboard/amd/bimini_fam10/romstage.c | 2 +- - src/mainboard/amd/mahogany_fam10/romstage.c | 2 +- - .../amd/serengeti_cheetah_fam10/romstage.c | 2 +- - src/mainboard/amd/tilapia_fam10/romstage.c | 2 +- - src/mainboard/asus/kfsn4-dre/romstage.c | 2 +- - src/mainboard/asus/kgpe-d16/romstage.c | 2 +- - src/mainboard/asus/m4a78-em/romstage.c | 2 +- - src/mainboard/asus/m4a785-m/romstage.c | 2 +- - src/mainboard/asus/m5a88-v/romstage.c | 2 +- - src/mainboard/avalue/eax-785e/romstage.c | 2 +- - src/mainboard/gigabyte/ma785gm/romstage.c | 2 +- - src/mainboard/gigabyte/ma785gmt/romstage.c | 2 +- - src/mainboard/gigabyte/ma78gm/romstage.c | 2 +- - src/mainboard/hp/dl165_g6_fam10/romstage.c | 2 +- - src/mainboard/iei/kino-780am2-fam10/romstage.c | 2 +- - src/mainboard/jetway/pa78vm5/romstage.c | 2 +- - src/mainboard/msi/ms9652_fam10/romstage.c | 2 +- - src/mainboard/supermicro/h8dmr_fam10/romstage.c | 2 +- - src/mainboard/supermicro/h8qme_fam10/romstage.c | 2 +- - src/mainboard/supermicro/h8scm_fam10/romstage.c | 2 +- - src/mainboard/tyan/s2912_fam10/romstage.c | 2 +- - src/northbridge/amd/amdfam10/northbridge.c | 2 +- - 54 files changed, 3674 insertions(+), 3674 deletions(-) - create mode 100644 src/cpu/amd/family_10h-family_15h/Kconfig - create mode 100644 src/cpu/amd/family_10h-family_15h/Makefile.inc - create mode 100644 src/cpu/amd/family_10h-family_15h/defaults.h - create mode 100644 src/cpu/amd/family_10h-family_15h/fidvid.c - create mode 100644 src/cpu/amd/family_10h-family_15h/init_cpus.c - create mode 100644 src/cpu/amd/family_10h-family_15h/model_10xxx_init.c - create mode 100644 src/cpu/amd/family_10h-family_15h/monotonic_timer.c - create mode 100644 src/cpu/amd/family_10h-family_15h/powernow_acpi.c - create mode 100644 src/cpu/amd/family_10h-family_15h/processor_name.c - create mode 100644 src/cpu/amd/family_10h-family_15h/ram_calc.c - create mode 100644 src/cpu/amd/family_10h-family_15h/ram_calc.h - create mode 100644 src/cpu/amd/family_10h-family_15h/update_microcode.c - delete mode 100644 src/cpu/amd/model_10xxx/Kconfig - delete mode 100644 src/cpu/amd/model_10xxx/Makefile.inc - delete mode 100644 src/cpu/amd/model_10xxx/defaults.h - delete mode 100644 src/cpu/amd/model_10xxx/fidvid.c - delete mode 100644 src/cpu/amd/model_10xxx/init_cpus.c - delete mode 100644 src/cpu/amd/model_10xxx/model_10xxx_init.c - delete mode 100644 src/cpu/amd/model_10xxx/monotonic_timer.c - delete mode 100644 src/cpu/amd/model_10xxx/powernow_acpi.c - delete mode 100644 src/cpu/amd/model_10xxx/processor_name.c - delete mode 100644 src/cpu/amd/model_10xxx/ram_calc.c - delete mode 100644 src/cpu/amd/model_10xxx/ram_calc.h - delete mode 100644 src/cpu/amd/model_10xxx/update_microcode.c - -diff --git a/src/cpu/amd/Kconfig b/src/cpu/amd/Kconfig -index 3a02043..8abc984 100644 ---- a/src/cpu/amd/Kconfig -+++ b/src/cpu/amd/Kconfig -@@ -12,7 +12,7 @@ source src/cpu/amd/socket_F_1207/Kconfig - source src/cpu/amd/socket_S1G1/Kconfig - - source src/cpu/amd/model_fxx/Kconfig --source src/cpu/amd/model_10xxx/Kconfig -+source src/cpu/amd/family_10h-family_15h/Kconfig - source src/cpu/amd/geode_gx2/Kconfig - source src/cpu/amd/geode_lx/Kconfig - -diff --git a/src/cpu/amd/family_10h-family_15h/Kconfig b/src/cpu/amd/family_10h-family_15h/Kconfig -new file mode 100644 -index 0000000..7c47e27 ---- /dev/null -+++ b/src/cpu/amd/family_10h-family_15h/Kconfig -@@ -0,0 +1,88 @@ -+config CPU_AMD_MODEL_10XXX -+ bool -+ select ARCH_BOOTBLOCK_X86_32 -+ select ARCH_VERSTAGE_X86_32 -+ select ARCH_ROMSTAGE_X86_32 -+ select ARCH_RAMSTAGE_X86_32 -+ select SSE -+ select SSE2 -+ select MMCONF_SUPPORT_DEFAULT -+ select TSC_SYNC_LFENCE -+ select UDELAY_LAPIC -+ select HAVE_MONOTONIC_TIMER -+ select SUPPORT_CPU_UCODE_IN_CBFS -+ select CPU_MICROCODE_MULTIPLE_FILES -+ -+if CPU_AMD_MODEL_10XXX -+ -+config NUM_IPI_STARTS -+ int -+ default 1 -+ -+config CPU_ADDR_BITS -+ int -+ default 48 -+ -+config DCACHE_RAM_BASE -+ hex -+ default 0xc4000 -+ -+config DCACHE_RAM_SIZE -+ hex -+ default 0x0c000 -+ -+config DCACHE_BSP_STACK_SIZE -+ hex -+ default 0x2000 -+ -+config DCACHE_BSP_STACK_SLUSH -+ hex -+ default 0x1000 -+ -+config DCACHE_AP_STACK_SIZE -+ hex -+ default 0x400 -+ -+config UDELAY_IO -+ bool -+ default n -+ -+config SET_FIDVID -+ bool -+ default y -+ -+config MAX_PHYSICAL_CPUS -+ int -+ default 1 -+ -+config LIFT_BSP_APIC_ID -+ bool -+ default n -+ -+if SET_FIDVID -+config SET_FIDVID_DEBUG -+ bool -+ default y -+ -+config SET_FIDVID_STORE_AP_APICID_AT_FIRST -+ bool -+ default y -+ -+config SET_FIDVID_CORE0_ONLY -+ bool -+ default n -+ -+# 0: all cores -+# 1: core 0 only -+# 2: all but core 0 -+config SET_FIDVID_CORE_RANGE -+ int -+ default 0 -+ -+endif # SET_FIDVID -+ -+config UDELAY_LAPIC_FIXED_FSB -+ int -+ default 200 -+ -+endif # CPU_AMD_MODEL_10XXX -diff --git a/src/cpu/amd/family_10h-family_15h/Makefile.inc b/src/cpu/amd/family_10h-family_15h/Makefile.inc -new file mode 100644 -index 0000000..5a81ab8 ---- /dev/null -+++ b/src/cpu/amd/family_10h-family_15h/Makefile.inc -@@ -0,0 +1,14 @@ -+romstage-y += ../../x86/mtrr/earlymtrr.c -+ramstage-y += model_10xxx_init.c -+ramstage-y += processor_name.c -+ -+romstage-y += update_microcode.c -+romstage-y += ram_calc.c -+ramstage-y += ram_calc.c -+ramstage-y += monotonic_timer.c -+ramstage-$(CONFIG_HAVE_ACPI_TABLES) += powernow_acpi.c -+ -+# Microcode for Family 10h, 11h, 12h, and 14h -+cbfs-files-$(CONFIG_CPU_MICROCODE_MULTIPLE_FILES) += microcode_amd.bin -+microcode_amd.bin-file := 3rdparty/blobs/cpu/amd/family_10h-family_14h/microcode_amd.bin -+microcode_amd.bin-type := microcode -diff --git a/src/cpu/amd/family_10h-family_15h/defaults.h b/src/cpu/amd/family_10h-family_15h/defaults.h -new file mode 100644 -index 0000000..6fd1a7e ---- /dev/null -+++ b/src/cpu/amd/family_10h-family_15h/defaults.h -@@ -0,0 +1,479 @@ -+/* -+ * This file is part of the coreboot project. -+ * -+ * Copyright (C) 2008 Advanced Micro Devices, Inc. -+ * -+ * 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; version 2 of the License. -+ * -+ * 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. -+ * -+ * You should have received a copy of the GNU General Public License -+ * along with this program; if not, write to the Free Software -+ * Foundation, Inc. -+ */ -+ -+#include <northbridge/amd/amdmct/amddefs.h> -+#include <cpu/amd/mtrr.h> -+ -+/* -+ * Default MSR and errata settings. -+ */ -+static const struct { -+ u32 msr; -+ u32 revision; -+ u32 platform; -+ u32 data_lo; -+ u32 data_hi; -+ u32 mask_lo; -+ u32 mask_hi; -+} fam10_msr_default[] = { -+ { TOP_MEM2, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000000, 0x00000000, -+ 0xFFFFFFFF, 0xFFFFFFFF }, -+ -+ { SYSCFG, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 3 << 21, 0x00000000, -+ 3 << 21, 0x00000000 }, /* [MtrrTom2En]=1,[TOM2EnWB] = 1*/ -+ -+ { HWCR, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 1 << 4, 0x00000000, -+ 1 << 4, 0x00000000 }, /* [INVD_WBINVD]=1 */ -+ -+ { MC4_CTL_MASK, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0xF << 19, 0x00000000, -+ 0xF << 19, 0x00000000 }, /* [RtryHt[0..3]]=1 */ -+ -+ { DC_CFG, AMD_FAM10_ALL, AMD_PTYPE_SVR, -+ 0x00000000, 0x00000004, -+ 0x00000000, 0x0000000C }, /* [REQ_CTR] = 1 for Server */ -+ -+ { DC_CFG, AMD_DR_Bx, AMD_PTYPE_SVR, -+ 0x00000000, 0x00000000, -+ 0x00000000, 0x00000C00 }, /* Erratum 326 */ -+ -+ { NB_CFG, AMD_FAM10_ALL, AMD_PTYPE_DC | AMD_PTYPE_MC, -+ 0x00000000, 1 << 22, -+ 0x00000000, 1 << 22 }, /* [ApicInitIDLo]=1 */ -+ -+ { BU_CFG2, AMD_DR_Bx, AMD_PTYPE_ALL, -+ 1 << 29, 0x00000000, -+ 1 << 29, 0x00000000 }, /* For Bx Smash1GPages=1 */ -+ -+ { DC_CFG, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 1 << 24, 0x00000000, -+ 1 << 24, 0x00000000 }, /* Erratum #261 [DIS_PIGGY_BACK_SCRUB]=1 */ -+ -+ { LS_CFG, AMD_DR_GT_B0, AMD_PTYPE_ALL, -+ 0 << 1, 0x00000000, -+ 1 << 1, 0x00000000 }, /* IDX_MATCH_ALL=0 */ -+ -+ { BU_CFG, AMD_DR_LT_B3, AMD_PTYPE_ALL, -+ 1 << 21, 0x00000000, -+ 1 << 21, 0x00000000 }, /* Erratum #254 DR B1 BU_CFG[21]=1 */ -+ -+ { BU_CFG, AMD_DR_LT_B3, AMD_PTYPE_ALL, -+ 1 << 23, 0x00000000, -+ 1 << 23, 0x00000000 }, /* Erratum #309 BU_CFG[23]=1 */ -+ -+ /* CPUID_EXT_FEATURES */ -+ { CPUIDFEATURES, AMD_FAM10_ALL, AMD_PTYPE_DC | AMD_PTYPE_MC, -+ 1 << 28, 0x00000000, -+ 1 << 28, 0x00000000 }, /* [HyperThreadFeatEn]=1 */ -+ -+ { CPUIDFEATURES, AMD_FAM10_ALL, AMD_PTYPE_DC, -+ 0x00000000, 1 << (33-32), -+ 0x00000000, 1 << (33-32) }, /* [ExtendedFeatEn]=1 */ -+ -+ { BU_CFG2, AMD_DRBH_Cx, AMD_PTYPE_ALL, -+ 0x00000000, 1 << (35-32), -+ 0x00000000, 1 << (35-32) }, /* Erratum 343 (set to 0 after CAR, in post_cache_as_ram()/model_10xxx_init() ) */ -+ -+ { OSVW_ID_Length, AMD_DR_Bx | AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, -+ 0x00000004, 0x00000000, -+ 0x00000004, 0x00000000}, /* B0 or Above, OSVW_ID_Length is 0004h */ -+ -+ { OSVW_Status, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_MC, -+ 0x0000000C, 0x00000000, -+ 0x0000000C, 0x00000000}, /* Cx and Dx multiple-link processor */ -+ -+ { BU_CFG2, AMD_DR_Dx, AMD_PTYPE_ALL, -+ 0x00000000, 1 << (50-32), -+ 0x00000000, 1 << (50-32)}, /* D0 or Above, RdMmExtCfgQwEn*/ -+ -+ { CPU_ID_EXT_FEATURES_MSR, AMD_DR_Dx, AMD_PTYPE_ALL, -+ 0x00000000, 1 << (51 - 32), -+ 0x00000000, 1 << (51 - 32)}, /* G34_PKG | C32_PKG | S1G4_PKG | ASB2_PKG */ -+}; -+ -+ -+/* -+ * Default PCI and errata settings. -+ */ -+static const struct { -+ u8 function; -+ u16 offset; -+ u32 revision; -+ u32 platform; -+ u32 data; -+ u32 mask; -+} fam10_pci_default[] = { -+ -+ /* Function 0 - HT Config */ -+ -+ { 0, 0x68, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x004E4800, 0x006E6800 }, /* [19:17] for 8bit APIC config, -+ [14:13] BufPriRel = 2h [11] RspPassPW set, -+ [22:21] DsNpReqLmt = 10b */ -+ -+ /* Errata 281 Workaround */ -+ { 0, 0x68, (AMD_DR_B0 | AMD_DR_B1), -+ AMD_PTYPE_SVR, 0x00200000, 0x00600000 }, /* [22:21] DsNpReqLmt0 = 01b */ -+ -+ { 0, 0x84, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00002000, 0x00002000 }, /* [13] LdtStopTriEn = 1 */ -+ -+ { 0, 0xA4, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00002000, 0x00002000 }, /* [13] LdtStopTriEn = 1 */ -+ -+ { 0, 0xC4, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00002000, 0x00002000 }, /* [13] LdtStopTriEn = 1 */ -+ -+ { 0, 0xE4, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00002000, 0x00002000 }, /* [13] LdtStopTriEn = 1 */ -+ -+ /* Link Global Retry Control Register */ -+ { 0, 0x150, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00073900, 0x00073F00 }, -+ -+ /* Errata 351 -+ * System software should program the Link Extended Control Registers[LS2En] -+ * (F0x[18C:170][8]) to 0b for all links. System software should also -+ * program Link Global Extended Control Register[ForceFullT0] -+ * (F0x16C[15:13]) to 000b */ -+ -+ { 0, 0x170, AMD_FAM10_ALL, AMD_PTYPE_ALL, /* Fix FAM10_ALL when fixed in rev guide */ -+ 0x00000000, 0x00000100 }, -+ { 0, 0x174, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000000, 0x00000100 }, -+ { 0, 0x178, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000000, 0x00000100 }, -+ { 0, 0x17C, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000000, 0x00000100 }, -+ { 0, 0x180, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000000, 0x00000100 }, -+ { 0, 0x184, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000000, 0x00000100 }, -+ { 0, 0x188, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000000, 0x00000100 }, -+ { 0, 0x18C, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000000, 0x00000100 }, -+ { 0, 0x170, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000000, 0x00000100 }, -+ -+ /* Link Global Extended Control Register */ -+ { 0, 0x16C, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000014, 0x0000003F }, /* [15:13] ForceFullT0 = 0b, -+ * Set T0Time 14h per BKDG */ -+ -+ -+ /* Function 1 - Map Init */ -+ -+ /* Before reading F1x114_x2 or F1x114_x3 software must -+ * initialize the registers or NB Array MCA errors may -+ * occur. BIOS should initialize index 0h of F1x114_x2 and -+ * F1x114_x3 to prevent reads from F1x114 from generating NB -+ * Array MCA errors. BKDG Doc #3116 Rev 1.07 -+ */ -+ -+ { 1, 0x110, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x20000000, 0xFFFFFFFF }, /* Select extended MMIO Base */ -+ -+ { 1, 0x114, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000000, 0xFFFFFFFF }, /* Clear map */ -+ -+ { 1, 0x110, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x30000000, 0xFFFFFFFF }, /* Select extended MMIO Base */ -+ -+ { 1, 0x114, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000000, 0xFFFFFFFF }, /* Clear map */ -+ -+ /* Function 2 - DRAM Controller */ -+ -+ /* Function 3 - Misc. Control */ -+ { 3, 0x40, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000100, 0x00000100 }, /* [8] MstrAbrtEn */ -+ -+ { 3, 0x44, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x4A30005C, 0x4A30005C }, /* [30] SyncOnDramAdrParErrEn = 1, -+ [27] NbMcaToMstCpuEn = 1, -+ [25] DisPciCfgCpuErrRsp = 1, -+ [21] SyncOnAnyErrEn = 1, -+ [20] SyncOnWDTEn = 1, -+ [6] CpuErrDis = 1, -+ [4] SyncPktPropDis = 1, -+ [3] SyncPktGenDis = 1, -+ [2] SyncOnUcEccEn = 1 */ -+ -+ /* XBAR buffer settings */ -+ { 3, 0x6C, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00018052, 0x700780F7 }, -+ -+ /* Errata 281 Workaround */ -+ { 3, 0x6C, ( AMD_DR_B0 | AMD_DR_B1), -+ AMD_PTYPE_SVR, 0x00010094, 0x700780F7 }, -+ -+ { 3, 0x6C, AMD_FAM10_ALL, AMD_PTYPE_UMA, -+ 0x60018051, 0x700780F7 }, -+ -+ { 3, 0x70, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00041153, 0x777777F7 }, -+ -+ { 3, 0x70, AMD_FAM10_ALL, AMD_PTYPE_UMA, -+ 0x61221151, 0x777777F7 }, -+ -+ { 3, 0x74, AMD_FAM10_ALL, AMD_PTYPE_UMA, -+ 0x00080101, 0x000F7777 }, -+ -+ { 3, 0x7C, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00090914, 0x707FFF1F }, -+ -+ /* Errata 281 Workaround */ -+ { 3, 0x7C, ( AMD_DR_B0 | AMD_DR_B1), -+ AMD_PTYPE_SVR, 0x00144514, 0x707FFF1F }, -+ -+ { 3, 0x7C, AMD_FAM10_ALL, AMD_PTYPE_UMA, -+ 0x00070814, 0x007FFF1F }, -+ -+ { 3, 0x140, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00800756, 0x00F3FFFF }, -+ -+ { 3, 0x140, AMD_FAM10_ALL, AMD_PTYPE_UMA, -+ 0x00C37756, 0x00F3FFFF }, -+ -+ { 3, 0x144, AMD_FAM10_ALL, AMD_PTYPE_UMA, -+ 0x00000036, 0x000000FF }, -+ -+ /* Errata 281 Workaround */ -+ { 3, 0x144, ( AMD_DR_B0 | AMD_DR_B1), -+ AMD_PTYPE_SVR, 0x00000001, 0x0000000F }, -+ /* [3:0] RspTok = 0001b */ -+ -+ { 3, 0x148, AMD_FAM10_ALL, AMD_PTYPE_UMA, -+ 0x8000052A, 0xD5FFFFFF }, -+ -+ /* ACPI Power State Control Reg1 */ -+ { 3, 0x80, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0xE6002200, 0xFFFFFFFF }, -+ -+ /* ACPI Power State Control Reg2 */ -+ { 3, 0x84, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0xA0E641E6, 0xFFFFFFFF }, -+ -+ { 3, 0xA0, AMD_FAM10_ALL, AMD_PTYPE_MOB | AMD_PTYPE_DSK, -+ 0x00000080, 0x00000080 }, /* [7] PSIVidEnable */ -+ -+ { 3, 0xA0, AMD_DR_Bx, AMD_PTYPE_ALL, -+ 0x00002800, 0x000003800 }, /* [13:11] PllLockTime = 5 */ -+ -+ { 3, 0xA0, (AMD_FAM10_ALL & ~(AMD_DR_Bx)), AMD_PTYPE_ALL, -+ 0x00000800, 0x000003800 }, /* [13:11] PllLockTime = 1 */ -+ -+ /* Reported Temp Control Register */ -+ { 3, 0xA4, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000080, 0x00000080 }, /* [7] TempSlewDnEn = 1 */ -+ -+ /* Clock Power/Timing Control 0 Register */ -+ { 3, 0xD4, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0xC0000F00, 0xF0000F00 }, /* [31] NbClkDivApplyAll = 1, -+ [30:28] NbClkDiv = 100b,[11:8] ClkRampHystSel = 1111b */ -+ -+ /* Clock Power/Timing Control 1 Register */ -+ { 3, 0xD8, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x03000016, 0x0F000077 }, /* [6:4] VSRampTime = 1, -+ [2:0] VSSlamTime = 6, [27:24] ReConDel = 3 */ -+ -+ -+ /* Clock Power/Timing Control 2 Register */ -+ { 3, 0xDC, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00005000, 0x00007000 }, /* [14:12] NbsynPtrAdj = 5 */ -+ -+ -+ /* Extended NB MCA Config Register */ -+ { 3, 0x180, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x007003E2, 0x007003E2 }, /* [22:20] = SyncFloodOn_Err = 7, -+ [9] SyncOnUncNbAryEn = 1 , -+ [8] SyncOnProtEn = 1, -+ [7] SyncFloodOnTgtAbtErr = 1, -+ [6] SyncFloodOnDatErr = 1, -+ [5] DisPciCfgCpuMstAbtRsp = 1, -+ [1] SyncFloodOnUsPwDataErr = 1 */ -+ -+ /* errata 346 - Fam10 C2, C3 -+ * System software should set F3x188[22] to 1b. */ -+ { 3, 0x188, AMD_DR_Cx, AMD_PTYPE_ALL, -+ 0x00400000, 0x00400000 }, -+ -+ /* L3 Control Register */ -+ { 3, 0x1B8, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00001000, 0x00001000 }, /* [12] = L3PrivReplEn */ -+ -+ /* IBS Control Register */ -+ { 3, 0x1CC, AMD_FAM10_ALL, AMD_PTYPE_ALL, -+ 0x00000100, 0x00000100 }, /* [8] = LvtOffsetVal */ -+}; -+ -+ -+/* -+ * Default HyperTransport Phy and errata settings. -+ */ -+static const struct { -+ u16 htreg; /* HT Phy Register index */ -+ u32 revision; -+ u32 platform; -+ u32 linktype; -+ u32 data; -+ u32 mask; -+} fam10_htphy_default[] = { -+ -+ /* Errata 344 - Fam10 C2/C3, D0/D1 -+ * System software should set bit 6 of F4x1[9C, 94, 8C, 84]_x[78:70, 68:60]. */ -+ { 0x60, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x61, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x62, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x63, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x64, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x65, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x66, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x67, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x68, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ -+ { 0x70, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x71, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x72, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x73, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x74, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x75, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x76, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x77, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x78, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ -+ /* Errata 354 - Fam10 C2, C3 -+ * System software should set bit 6 of F4x1[9C,94,8C,84]_x[58:50, 48:40] for all links. */ -+ { 0x40, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x41, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x42, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x43, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x44, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x45, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x46, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x47, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x48, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ -+ { 0x50, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x51, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x52, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x53, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x54, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x55, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x56, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x57, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ { 0x58, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00000040, 0x00000040 }, -+ -+ /* Errata 327 - Fam10 C2/C3, D0/D1 -+ * BIOS should set the Link Phy Impedance Register[RttCtl] -+ * (F4x1[9C, 94, 8C, 84]_x[D0, C0][31:29]) to 010b and -+ * Link Phy Impedance Register[RttIndex] -+ * (F4x1[9C, 94, 8C, 84]_x[D0, C0][20:16]) to 00100b */ -+ { 0xC0, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x40040000, 0xe01F0000 }, -+ { 0xD0, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x40040000, 0xe01F0000 }, -+ -+ { 0x520A,AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00004000, 0x00006000 }, /* HT_PHY_DLL_REG */ -+ -+ { 0x530A, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00004000, 0x00006000 }, /* HT_PHY_DLL_REG */ -+ -+ { 0x520A, AMD_DR_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00004400, 0x00006400 }, /* HT_PHY_DLL_REG */ -+ -+ { 0x530A, AMD_DR_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x00004400, 0x00006400 }, /* HT_PHY_DLL_REG */ -+ -+ { 0xCF, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT3, -+ 0x00000000, 0x000000FF }, /* Provide clear setting for logical -+ completeness */ -+ -+ { 0xDF, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT3, -+ 0x00000000, 0x000000FF }, /* Provide clear setting for logical -+ completeness */ -+ -+ { 0xCF, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT1, -+ 0x0000006D, 0x000000FF }, /* HT_PHY_HT1_FIFO_PTR_OPT_VALUE */ -+ -+ { 0xDF, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT1, -+ 0x0000006D, 0x000000FF }, /* HT_PHY_HT1_FIFO_PTR_OPT_VALUE */ -+ -+ /* Link Phy Receiver Loop Filter Registers */ -+ { 0xD1, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT3, -+ 0x08040000, 0x3FFFC000 }, /* [29:22] LfcMax = 20h, -+ [21:14] LfcMin = 10h */ -+ -+ { 0xC1, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT3, -+ 0x08040000, 0x3FFFC000 }, /* [29:22] LfcMax = 20h, -+ [21:14] LfcMin = 10h */ -+ -+ { 0xD1, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT1, -+ 0x04020000, 0x3FFFC000 }, /* [29:22] LfcMax = 10h, -+ [21:14] LfcMin = 08h */ -+ -+ { 0xC1, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT1, -+ 0x04020000, 0x3FFFC000 }, /* [29:22] LfcMax = 10h, -+ [21:14] LfcMin = 08h */ -+ -+ { 0xC0, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -+ 0x40040000, 0xe01F0000 }, /* [31:29] RttCtl = 02h, -+ [20:16] RttIndex = 04h */ -+}; -diff --git a/src/cpu/amd/family_10h-family_15h/fidvid.c b/src/cpu/amd/family_10h-family_15h/fidvid.c -new file mode 100644 -index 0000000..5b1c581 ---- /dev/null -+++ b/src/cpu/amd/family_10h-family_15h/fidvid.c -@@ -0,0 +1,1048 @@ -+/* -+ * This file is part of the coreboot project. -+ * -+ * Copyright (C) 2007 Advanced Micro Devices, Inc. -+ * -+ * 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; version 2 of the License. -+ * -+ * 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. -+ * -+ * You should have received a copy of the GNU General Public License -+ * along with this program; if not, write to the Free Software -+ * Foundation, Inc. -+ */ -+/* -+ * This file initializes the CPU cores for voltage and frequency settings -+ * in the different power states. -+ */ -+/* -+ -+checklist (functions are in this file if no source file named) -+Fam10 Bios and Kernel Development Guide #31116, rev 3.48, April 22, 2010 -+ -+2.4.2.6 Requirements for p-states -+ -+1.- F3x[84:80] According to table 100 : prep_fid_change -+ -+2.- COF/VID : -+ 2.4.2.9.1 Steps 1,3-6 and warning for 2,7 if they apply -+ fixPsNbVidBeforeWR(...) -+ 2.4.2.9.1 Step 8 enable_fid_change -+ We do this for all nodes, I don't understand BKDG 100% on -+ whether this is or isn't meant by "on the local -+ processor". Must be OK. -+ 2.4.2.9.1 Steps 9-10 (repeat 1-7 and reset) romstage.c/init_cpus ? -+ 2.4.2.9.1 Steps 11-12 init_fidvid_stage2 -+ 2.4.2.9.2 DualPlane PVI : Not supported, don't know how to detect, -+ needs specific circuitry. -+ -+3.- 2.4.2.7 dualPlaneOnly(dev) -+ -+4.- 2.4.2.8 applyBoostFIDOffset(dev) -+ -+5.- enableNbPState1(dev) -+ -+6.- 2.4.1.7 -+ a) UpdateSinglePlaneNbVid() -+ b) setVSRamp(), called from prep_fid_change -+ c) prep_fid_change -+ d) improperly, for lack of voltage regulator details?, -+ F3xA0[PsiVidEn] in defaults.h -+ F3xA0[PsiVid] in init_cpus.c AMD_SetupPSIVID_d (before prep_fid_change) -+ -+7.- TODO (Core Performance Boost is only available in revision E cpus, and we -+ don't seem to support those yet, at least they don't have any -+ constant in amddefs.h ) -+ -+8.- FIXME ? Transition to min Pstate according to 2.4.2.15.3 is required -+ by 2.4.2.6 after warm reset. But 2.4.2.15 states that it is not required -+ if the warm reset is issued by coreboot to update NbFid. So it is required -+ or not ? How can I tell who issued warm reset ? -+ Coreboot transitions to P0 instead, which is not recommended, and does -+ not follow 2.4.2.15.2 to do so. -+ -+9.- TODO Requires information on current delivery capability -+ (depends on mainboard and maybe power supply ?). One might use a config -+ option with the maximum number of Amperes that the board can deliver to CPU. -+ -+10.- [Multiprocessor] TODO 2.4.2.12 -+ [Uniprocessor] FIXME ? We call setPStateMaxVal() in init_fidvid_stage2, -+ but not sure this is what is meant by "Determine the valid set of -+ P-states based on enabled P-states indicated -+ in MSRC001_00[68:64][PstateEn]" in 2.4.2.6-10 -+ -+11.- finalPstateChange() from init_fidvid_Stage2 (BKDG says just "may", anyway) -+ -+12.- generate ACPI for p-states. -+ generated in powernow_acpi.c amd_generate_powernow() -+ -+"must also be completed" -+ -+a.- PllLockTime set in ruleset in defaults.h -+ BKDG says set it "If MSRC001_00[68:64][CpuFid] is different between -+ any two enabled P-states", but since it does not say "only if" -+ I guess it is safe to do it always. -+ -+b.- prep_fid_change(...) -+ -+ */ -+ -+#if CONFIG_SET_FIDVID -+ -+#include <northbridge/amd/amdht/AsPsDefs.h> -+ -+static inline void print_debug_fv(const char *str, u32 val) -+{ -+#if CONFIG_SET_FIDVID_DEBUG -+ printk(BIOS_DEBUG, "%s%x\n", str, val); -+#endif -+} -+ -+static inline void print_debug_fv_8(const char *str, u8 val) -+{ -+#if CONFIG_SET_FIDVID_DEBUG -+ printk(BIOS_DEBUG, "%s%02x\n", str, val); -+#endif -+} -+ -+static inline void print_debug_fv_64(const char *str, u32 val, u32 val2) -+{ -+#if CONFIG_SET_FIDVID_DEBUG -+ printk(BIOS_DEBUG, "%s%x%x\n", str, val, val2); -+#endif -+} -+ -+struct fidvid_st { -+ u32 common_fid; -+}; -+ -+static void enable_fid_change(u8 fid) -+{ -+ u32 dword; -+ u32 nodes; -+ device_t dev; -+ int i; -+ -+ nodes = get_nodes(); -+ -+ for (i = 0; i < nodes; i++) { -+ dev = NODE_PCI(i, 3); -+ dword = pci_read_config32(dev, 0xd4); -+ dword &= ~0x1F; -+ dword |= (u32) fid & 0x1F; -+ dword |= 1 << 5; // enable -+ pci_write_config32(dev, 0xd4, dword); -+ printk(BIOS_DEBUG, "FID Change Node:%02x, F3xD4: %08x \n", i, -+ dword); -+ } -+} -+ -+static void applyBoostFIDOffset( device_t dev ) { -+ // BKDG 2.4.2.8 -+ // revision E only, but E is apparently not supported yet, therefore untested -+ if ((cpuid_edx(0x80000007) & CPB_MASK) -+ && ((cpuid_ecx(0x80000008) & NC_MASK) ==5) ) { -+ u32 core = get_node_core_id_x().coreid; -+ u32 asymetricBoostThisCore = ((pci_read_config32(dev, 0x10C) >> (core*2))) & 3; -+ msr_t msr = rdmsr(PS_REG_BASE); -+ u32 cpuFid = msr.lo & PS_CPU_FID_MASK; -+ cpuFid = cpuFid + asymetricBoostThisCore; -+ msr.lo &= ~PS_CPU_FID_MASK; -+ msr.lo |= cpuFid ; -+ wrmsr(PS_REG_BASE , msr); -+ -+ } -+} -+ -+static void enableNbPState1( device_t dev ) { -+ u32 cpuRev = mctGetLogicalCPUID(0xFF); -+ if (cpuRev & AMD_FAM10_C3) { -+ u32 nbPState = (pci_read_config32(dev, 0x1F0) & NB_PSTATE_MASK); -+ if ( nbPState){ -+ u32 nbVid1 = (pci_read_config32(dev, 0x1F4) & NB_VID1_MASK) >> NB_VID1_SHIFT; -+ u32 i; -+ for (i = nbPState; i < NM_PS_REG; i++) { -+ msr_t msr = rdmsr(PS_REG_BASE + i); -+ if (msr.hi & PS_EN_MASK ) { -+ msr.hi |= NB_DID_M_ON; -+ msr.lo &= NB_VID_MASK_OFF; -+ msr.lo |= ( nbVid1 << NB_VID_POS); -+ wrmsr(PS_REG_BASE + i, msr); -+ } -+ } -+ } -+ } -+} -+ -+static u8 setPStateMaxVal( device_t dev ) { -+ u8 i,maxpstate=0; -+ for (i = 0; i < NM_PS_REG; i++) { -+ msr_t msr = rdmsr(PS_REG_BASE + i); -+ if (msr.hi & PS_IDD_VALUE_MASK) { -+ msr.hi |= PS_EN_MASK ; -+ wrmsr(PS_REG_BASE + i, msr); -+ } -+ if (msr.hi & PS_EN_MASK) { -+ maxpstate = i; -+ } -+ } -+ //FIXME: CPTC2 and HTC_REG should get max per node, not per core ? -+ u32 reg = pci_read_config32(dev, CPTC2); -+ reg &= PS_MAX_VAL_MASK; -+ reg |= (maxpstate << PS_MAX_VAL_POS); -+ pci_write_config32(dev, CPTC2,reg); -+ return maxpstate; -+} -+ -+static void dualPlaneOnly( device_t dev ) { -+ // BKDG 2.4.2.7 -+ -+ u32 cpuRev = mctGetLogicalCPUID(0xFF); -+ if ((mctGetProcessorPackageType() == AMD_PKGTYPE_AM3_2r2) -+ && (cpuRev & AMD_DR_Cx)) { // should be rev C or rev E but there's no constant for E -+ if ( (pci_read_config32(dev, 0x1FC) & DUAL_PLANE_ONLY_MASK) -+ && (pci_read_config32(dev, 0xA0) & PVI_MODE) ){ -+ if (cpuid_edx(0x80000007) & CPB_MASK) { -+ // revision E only, but E is apparently not supported yet, therefore untested -+ msr_t minPstate = rdmsr(0xC0010065); -+ wrmsr(0xC0010065, rdmsr(0xC0010068) ); -+ wrmsr(0xC0010068,minPstate); -+ } else { -+ msr_t msr; -+ msr.lo=0; msr.hi=0; -+ wrmsr(0xC0010064, rdmsr(0xC0010068) ); -+ wrmsr(0xC0010068, msr ); -+ } -+ -+ //FIXME: CPTC2 and HTC_REG should get max per node, not per core ? -+ u8 maxpstate = setPStateMaxVal(dev); -+ -+ u32 reg = pci_read_config32(dev, HTC_REG); -+ reg &= HTC_PS_LMT_MASK; -+ reg |= (maxpstate << PS_LIMIT_POS); -+ pci_write_config32(dev, HTC_REG,reg); -+ -+ } -+ } -+} -+ -+static int vidTo100uV(u8 vid) -+{// returns voltage corresponding to vid in tenths of mV, i.e. hundreds of uV -+ // BKDG #31116 rev 3.48 2.4.1.6 -+ int voltage; -+ if (vid >= 0x7c) { -+ voltage = 0; -+ } else { -+ voltage = (15500 - (125*vid)); -+ } -+ return voltage; -+} -+ -+static void setVSRamp(device_t dev) { -+ /* BKDG r31116 2010-04-22 2.4.1.7 step b F3xD8[VSRampTime] -+ * If this field accepts 8 values between 10 and 500 us why -+ * does page 324 say "BIOS should set this field to 001b." -+ * (20 us) ? -+ * Shouldn't it depend on the voltage regulators, mainboard -+ * or something ? -+ */ -+ u32 dword; -+ dword = pci_read_config32(dev, 0xd8); -+ dword &= VSRAMP_MASK; -+ dword |= VSRAMP_VALUE; -+ pci_write_config32(dev, 0xd8, dword); -+} -+ -+static void recalculateVsSlamTimeSettingOnCorePre(device_t dev) -+{ -+ u8 pviModeFlag; -+ u8 highVoltageVid, lowVoltageVid, bValue; -+ u16 minimumSlamTime; -+ u16 vSlamTimes[7] = { 1000, 2000, 3000, 4000, 6000, 10000, 20000 }; /* Reg settings scaled by 100 */ -+ u32 dtemp; -+ msr_t msr; -+ -+ /* This function calculates the VsSlamTime using the range of possible -+ * voltages instead of a hardcoded 200us. -+ * Note: his function is called only from prep_fid_change, -+ * and that from init_cpus.c finalize_node_setup() -+ * (after set AMD MSRs and init ht ) -+ */ -+ -+ /* BKDG r31116 2010-04-22 2.4.1.7 step b F3xD8[VSSlamTime] */ -+ /* Calculate Slam Time -+ * Vslam = (mobileCPU?0.2:0.4)us/mV * (Vp0 - (lowest out of Vpmin or Valt)) mV -+ * In our case, we will scale the values by 100 to avoid -+ * decimals. -+ */ -+ -+ /* Determine if this is a PVI or SVI system */ -+ dtemp = pci_read_config32(dev, 0xA0); -+ -+ if (dtemp & PVI_MODE) -+ pviModeFlag = 1; -+ else -+ pviModeFlag = 0; -+ -+ /* Get P0's voltage */ -+ /* MSRC001_00[68:64] are not programmed yet when called from -+ prep_fid_change, one might use F4x1[F0:E0] instead, but -+ theoretically MSRC001_00[68:64] are equal to them after -+ reset. */ -+ msr = rdmsr(0xC0010064); -+ highVoltageVid = (u8) ((msr.lo >> PS_CPU_VID_SHFT) & 0x7F); -+ if (!(msr.hi & 0x80000000)) { -+ printk(BIOS_ERR,"P-state info in MSRC001_0064 is invalid !!!\n"); -+ highVoltageVid = (u8) ((pci_read_config32(dev, 0x1E0) -+ >> PS_CPU_VID_SHFT) & 0x7F); -+ } -+ -+ /* If SVI, we only care about CPU VID. -+ * If PVI, determine the higher voltage b/t NB and CPU -+ */ -+ if (pviModeFlag) { -+ bValue = (u8) ((msr.lo >> PS_NB_VID_SHFT) & 0x7F); -+ if (highVoltageVid > bValue) -+ highVoltageVid = bValue; -+ } -+ -+ /* Get PSmax's index */ -+ msr = rdmsr(0xC0010061); -+ bValue = (u8) ((msr.lo >> PS_MAX_VAL_SHFT) & BIT_MASK_3); -+ -+ /* Get PSmax's VID */ -+ msr = rdmsr(0xC0010064 + bValue); -+ lowVoltageVid = (u8) ((msr.lo >> PS_CPU_VID_SHFT) & 0x7F); -+ if (!(msr.hi & 0x80000000)) { -+ printk(BIOS_ERR,"P-state info in MSR%8x is invalid !!!\n",0xC0010064 + bValue); -+ lowVoltageVid = (u8) ((pci_read_config32(dev, 0x1E0+(bValue*4)) -+ >> PS_CPU_VID_SHFT) & 0x7F); -+ } -+ -+ /* If SVI, we only care about CPU VID. -+ * If PVI, determine the higher voltage b/t NB and CPU -+ * BKDG 2.4.1.7 (a) -+ */ -+ if (pviModeFlag) { -+ bValue = (u8) ((msr.lo >> PS_NB_VID_SHFT) & 0x7F); -+ if (lowVoltageVid > bValue) -+ lowVoltageVid = bValue; -+ } -+ -+ /* Get AltVID */ -+ dtemp = pci_read_config32(dev, 0xDC); -+ bValue = (u8) (dtemp & BIT_MASK_7); -+ -+ /* Use the VID with the lowest voltage (higher VID) */ -+ if (lowVoltageVid < bValue) -+ lowVoltageVid = bValue; -+ -+ u8 mobileFlag = get_platform_type() & AMD_PTYPE_MOB; -+ minimumSlamTime = (mobileFlag?2:4) * (vidTo100uV(highVoltageVid) - vidTo100uV(lowVoltageVid)); /* * 0.01 us */ -+ -+ -+ /* Now round up to nearest register setting. -+ * Note that if we don't find a value, we -+ * will fall through to a value of 7 -+ */ -+ for (bValue = 0; bValue < 7; bValue++) { -+ if (minimumSlamTime <= vSlamTimes[bValue]) -+ break; -+ } -+ -+ /* Apply the value */ -+ dtemp = pci_read_config32(dev, 0xD8); -+ dtemp &= VSSLAM_MASK; -+ dtemp |= bValue; -+ pci_write_config32(dev, 0xd8, dtemp); -+} -+ -+static u32 nb_clk_did(int node, u32 cpuRev,u8 procPkg) { -+ u8 link0isGen3 = 0; -+ u8 offset; -+ if (AMD_CpuFindCapability(node, 0, &offset)) { -+ link0isGen3 = (AMD_checkLinkType(node, 0, offset) & HTPHY_LINKTYPE_HT3 ); -+ } -+ /* FIXME: NB_CLKDID should be 101b for AMD_DA_C2 in package -+ S1g3 in link Gen3 mode, but I don't know how to tell -+ package S1g3 from S1g4 */ -+ if ((cpuRev & AMD_DA_C2) && (procPkg & AMD_PKGTYPE_S1gX) -+ && link0isGen3) { -+ return 5 ; /* divide clk by 128*/ -+ } else { -+ return 4 ; /* divide clk by 16 */ -+ } -+} -+ -+ -+static u32 power_up_down(int node, u8 procPkg) { -+ u32 dword=0; -+ /* from CPU rev guide #41322 rev 3.74 June 2010 Table 26 */ -+ u8 singleLinkFlag = ((procPkg == AMD_PKGTYPE_AM3_2r2) -+ || (procPkg == AMD_PKGTYPE_S1gX) -+ || (procPkg == AMD_PKGTYPE_ASB2)); -+ -+ if (singleLinkFlag) { -+ /* -+ * PowerStepUp=01000b - 50nS -+ * PowerStepDown=01000b - 50ns -+ */ -+ dword |= PW_STP_UP50 | PW_STP_DN50; -+ } else { -+ u32 dispRefModeEn = (pci_read_config32(NODE_PCI(node,0),0x68) >> 24) & 1; -+ u32 isocEn = 0; -+ int j; -+ for(j=0 ; (j<4) && (!isocEn) ; j++ ) { -+ u8 offset; -+ if (AMD_CpuFindCapability(node, j, &offset)) { -+ isocEn = (pci_read_config32(NODE_PCI(node,0),offset+4) >>12) & 1; -+ } -+ } -+ -+ if (dispRefModeEn || isocEn) { -+ dword |= PW_STP_UP50 | PW_STP_DN50 ; -+ } else { -+ /* get number of cores for PowerStepUp & PowerStepDown in server -+ 1 core - 400nS - 0000b -+ 2 cores - 200nS - 0010b -+ 3 cores - 133nS -> 100nS - 0011b -+ 4 cores - 100nS - 0011b -+ */ -+ switch (get_core_num_in_bsp(node)) { -+ case 0: -+ dword |= PW_STP_UP400 | PW_STP_DN400; -+ break; -+ case 1: -+ case 2: -+ dword |= PW_STP_UP200 | PW_STP_DN200; -+ break; -+ case 3: -+ dword |= PW_STP_UP100 | PW_STP_DN100; -+ break; -+ default: -+ dword |= PW_STP_UP100 | PW_STP_DN100; -+ break; -+ } -+ } -+ } -+ return dword; -+} -+ -+static void config_clk_power_ctrl_reg0(int node, u32 cpuRev, u8 procPkg) { -+ device_t dev = NODE_PCI(node, 3); -+ -+ /* Program fields in Clock Power/Control register0 (F3xD4) */ -+ -+ /* set F3xD4 Clock Power/Timing Control 0 Register -+ * NbClkDidApplyAll=1b -+ * NbClkDid=100b or 101b -+ * PowerStepUp= "platform dependent" -+ * PowerStepDown= "platform dependent" -+ * LinkPllLink=01b -+ * ClkRampHystCtl=HW default -+ * ClkRampHystSel=1111b -+ */ -+ u32 dword= pci_read_config32(dev, 0xd4); -+ dword &= CPTC0_MASK; -+ dword |= NB_CLKDID_ALL | LNK_PLL_LOCK | CLK_RAMP_HYST_SEL_VAL; -+ dword |= (nb_clk_did(node,cpuRev,procPkg) << NB_CLKDID_SHIFT); -+ -+ dword |= power_up_down(node, procPkg); -+ -+ pci_write_config32(dev, 0xd4, dword); -+ -+} -+ -+static void config_power_ctrl_misc_reg(device_t dev,u32 cpuRev, u8 procPkg) { -+ /* check PVI/SVI */ -+ u32 dword = pci_read_config32(dev, 0xa0); -+ -+ /* BKDG r31116 2010-04-22 2.4.1.7 step b F3xA0[VSSlamVidMod] */ -+ /* PllLockTime and PsiVidEn set in ruleset in defaults.h */ -+ if (dword & PVI_MODE) { /* PVI */ -+ /* set slamVidMode to 0 for PVI */ -+ dword &= VID_SLAM_OFF ; -+ } else { /* SVI */ -+ /* set slamVidMode to 1 for SVI */ -+ dword |= VID_SLAM_ON; -+ } -+ /* set the rest of A0 since we're at it... */ -+ -+ if (cpuRev & (AMD_DA_Cx | AMD_RB_C3 )) { -+ dword |= NB_PSTATE_FORCE_ON; -+ } // else should we clear it ? -+ -+ -+ if ((procPkg == AMD_PKGTYPE_G34) || (procPkg == AMD_PKGTYPE_C32) ) { -+ dword |= BP_INS_TRI_EN_ON ; -+ } -+ -+ /* TODO: look into C1E state and F3xA0[IdleExitEn]*/ -+ #if CONFIG_SVI_HIGH_FREQ -+ if (cpuRev & AMD_FAM10_C3) { -+ dword |= SVI_HIGH_FREQ_ON; -+ } -+ #endif -+ pci_write_config32(dev, 0xa0, dword); -+} -+ -+static void config_nb_syn_ptr_adj(device_t dev, u32 cpuRev) { -+ /* Note the following settings are additional from the ported -+ * function setFidVidRegs() -+ */ -+ /* adjust FIFO between nb and core clocks to max allowed -+ values (min latency) */ -+ u32 nbPstate = pci_read_config32(dev,0x1f0) & NB_PSTATE_MASK; -+ u8 nbSynPtrAdj; -+ if ((cpuRev & (AMD_DR_Bx|AMD_DA_Cx) ) -+ || ( (cpuRev & AMD_RB_C3) && (nbPstate!=0))) { -+ nbSynPtrAdj = 5; -+ } else { -+ nbSynPtrAdj = 6; -+ } -+ -+ u32 dword = pci_read_config32(dev, 0xDc); -+ dword &= ~ NB_SYN_PTR_ADJ_MASK; -+ dword |= nbSynPtrAdj << NB_SYN_PTR_ADJ_POS; -+ /* NbsynPtrAdj set to 5 or 6 per BKDG (needs reset) */ -+ pci_write_config32(dev, 0xdc, dword); -+} -+ -+static void config_acpi_pwr_state_ctrl_regs(device_t dev, u32 cpuRev, u8 procPkg) { -+ /* step 1, chapter 2.4.2.6 of AMD Fam 10 BKDG #31116 Rev 3.48 22.4.2010 */ -+ u32 dword; -+ u32 c1= 1; -+ if (cpuRev & (AMD_DR_Bx)) { -+ // will coreboot ever enable cache scrubbing ? -+ // if it does, will it be enough to check the current state -+ // or should we configure for what we'll set up later ? -+ dword = pci_read_config32(dev, 0x58); -+ u32 scrubbingCache = dword & -+ ( (0x1F << 16) // DCacheScrub -+ | (0x1F << 8) ); // L2Scrub -+ if (scrubbingCache) { -+ c1 = 0x80; -+ } else { -+ c1 = 0xA0; -+ } -+ } else { // rev C or later -+ // same doubt as cache scrubbing: ok to check current state ? -+ dword = pci_read_config32(dev, 0xDC); -+ u32 cacheFlushOnHalt = dword & (7 << 16); -+ if (!cacheFlushOnHalt) { -+ c1 = 0x80; -+ } -+ } -+ dword = (c1 << 24) | (0xE641E6); -+ pci_write_config32(dev, 0x84, dword); -+ -+ -+ /* FIXME: BKDG Table 100 says if the link is at a Gen1 -+frequency and the chipset does not support a 10us minimum LDTSTOP -+assertion time, then { If ASB2 && SVI then smaf001 = F6h else -+smaf001=87h. } else ... I hardly know what it means or how to check -+it from here, so I bluntly assume it is false and code here the else, -+which is easier */ -+ -+ u32 smaf001 = 0xE6; -+ if (cpuRev & AMD_DR_Bx ) { -+ smaf001 = 0xA6; -+ } else { -+ #if CONFIG_SVI_HIGH_FREQ -+ if (cpuRev & (AMD_RB_C3 | AMD_DA_C3)) { -+ smaf001 = 0xF6; -+ } -+ #endif -+ } -+ u32 fidvidChange = 0; -+ if (((cpuRev & AMD_DA_Cx) && (procPkg & AMD_PKGTYPE_S1gX)) -+ || (cpuRev & AMD_RB_C3) ) { -+ fidvidChange=0x0B; -+ } -+ dword = (0xE6 << 24) | (fidvidChange << 16) -+ | (smaf001 << 8) | 0x81; -+ pci_write_config32(dev, 0x80, dword); -+} -+ -+static void prep_fid_change(void) -+{ -+ u32 dword; -+ u32 nodes; -+ device_t dev; -+ int i; -+ -+ /* This needs to be run before any Pstate changes are requested */ -+ -+ nodes = get_nodes(); -+ -+ for (i = 0; i < nodes; i++) { -+ printk(BIOS_DEBUG, "Prep FID/VID Node:%02x\n", i); -+ dev = NODE_PCI(i, 3); -+ u32 cpuRev = mctGetLogicalCPUID(0xFF) ; -+ u8 procPkg = mctGetProcessorPackageType(); -+ -+ setVSRamp(dev); -+ /* BKDG r31116 2010-04-22 2.4.1.7 step b F3xD8[VSSlamTime] */ -+ /* Figure out the value for VsSlamTime and program it */ -+ recalculateVsSlamTimeSettingOnCorePre(dev); -+ -+ config_clk_power_ctrl_reg0(i,cpuRev,procPkg); -+ -+ config_power_ctrl_misc_reg(dev,cpuRev,procPkg); -+ config_nb_syn_ptr_adj(dev,cpuRev); -+ -+ config_acpi_pwr_state_ctrl_regs(dev,cpuRev,procPkg); -+ -+ dword = pci_read_config32(dev, 0x80); -+ printk(BIOS_DEBUG, " F3x80: %08x\n", dword); -+ dword = pci_read_config32(dev, 0x84); -+ printk(BIOS_DEBUG, " F3x84: %08x\n", dword); -+ dword = pci_read_config32(dev, 0xD4); -+ printk(BIOS_DEBUG, " F3xD4: %08x\n", dword); -+ dword = pci_read_config32(dev, 0xD8); -+ printk(BIOS_DEBUG, " F3xD8: %08x\n", dword); -+ dword = pci_read_config32(dev, 0xDC); -+ printk(BIOS_DEBUG, " F3xDC: %08x\n", dword); -+ } -+} -+ -+static void waitCurrentPstate(u32 target_pstate){ -+ msr_t initial_msr = rdmsr(TSC_MSR); -+ msr_t pstate_msr = rdmsr(CUR_PSTATE_MSR); -+ msr_t tsc_msr; -+ u8 timedout ; -+ -+ /* paranoia ? I fear when we run fixPsNbVidBeforeWR we can enter a -+ * P1 that is a copy of P0, therefore has the same NB DID but the -+ * TSC will count twice per tick, so we have to wait for twice the -+ * count to achieve the desired timeout. But I'm likely to -+ * misunderstand this... -+ */ -+ u32 corrected_timeout = ( (pstate_msr.lo==1) -+ && (!(rdmsr(0xC0010065).lo & NB_DID_M_ON)) ) ? -+ WAIT_PSTATE_TIMEOUT*2 : WAIT_PSTATE_TIMEOUT ; -+ msr_t timeout; -+ -+ timeout.lo = initial_msr.lo + corrected_timeout ; -+ timeout.hi = initial_msr.hi; -+ if ( (((u32)0xffffffff) - initial_msr.lo) < corrected_timeout ) { -+ timeout.hi++; -+ } -+ -+ // assuming TSC ticks at 1.25 ns per tick (800 MHz) -+ do { -+ pstate_msr = rdmsr(CUR_PSTATE_MSR); -+ tsc_msr = rdmsr(TSC_MSR); -+ timedout = (tsc_msr.hi > timeout.hi) -+ || ((tsc_msr.hi == timeout.hi) && (tsc_msr.lo > timeout.lo )); -+ } while ( (pstate_msr.lo != target_pstate) && (! timedout) ) ; -+ -+ if (pstate_msr.lo != target_pstate) { -+ msr_t limit_msr = rdmsr(0xc0010061); -+ printk(BIOS_ERR, "*** Time out waiting for P-state %01x. Current P-state %01x P-state current limit MSRC001_0061=%02x\n", target_pstate, pstate_msr.lo, limit_msr.lo); -+ -+ do { // should we just go on instead ? -+ pstate_msr = rdmsr(CUR_PSTATE_MSR); -+ } while ( pstate_msr.lo != target_pstate ) ; -+ } -+} -+ -+static void set_pstate(u32 nonBoostedPState) { -+ msr_t msr; -+ -+ // Transition P0 for calling core. -+ msr = rdmsr(0xC0010062); -+ -+ msr.lo = nonBoostedPState; -+ wrmsr(0xC0010062, msr); -+ -+ /* Wait for P0 to set. */ -+ waitCurrentPstate(nonBoostedPState); -+} -+ -+ -+ -+ -+static void UpdateSinglePlaneNbVid(void) -+{ -+ u32 nbVid, cpuVid; -+ u8 i; -+ msr_t msr; -+ -+ /* copy higher voltage (lower VID) of NBVID & CPUVID to both */ -+ for (i = 0; i < 5; i++) { -+ msr = rdmsr(PS_REG_BASE + i); -+ nbVid = (msr.lo & PS_CPU_VID_M_ON) >> PS_CPU_VID_SHFT; -+ cpuVid = (msr.lo & PS_NB_VID_M_ON) >> PS_NB_VID_SHFT; -+ -+ if (nbVid != cpuVid) { -+ if (nbVid > cpuVid) -+ nbVid = cpuVid; -+ -+ msr.lo = msr.lo & PS_BOTH_VID_OFF; -+ msr.lo = msr.lo | (u32) ((nbVid) << PS_NB_VID_SHFT); -+ msr.lo = msr.lo | (u32) ((nbVid) << PS_CPU_VID_SHFT); -+ wrmsr(PS_REG_BASE + i, msr); -+ } -+ } -+} -+ -+static void fixPsNbVidBeforeWR(u32 newNbVid, u32 coreid, u32 dev, u8 pviMode) -+ { -+ msr_t msr; -+ u8 startup_pstate; -+ -+ /* This function sets NbVid before the warm reset. -+ * Get StartupPstate from MSRC001_0071. -+ * Read Pstate register pointed by [StartupPstate]. -+ * and copy its content to P0 and P1 registers. -+ * Copy newNbVid to P0[NbVid]. -+ * transition to P1 on all cores, -+ * then transition to P0 on core 0. -+ * Wait for MSRC001_0063[CurPstate] = 000b on core 0. -+ * see BKDG rev 3.48 2.4.2.9.1 BIOS NB COF and VID Configuration -+ * for SVI and Single-Plane PVI Systems -+ */ -+ -+ msr = rdmsr(0xc0010071); -+ startup_pstate = (msr.hi >> (32 - 32)) & 0x07; -+ -+ /* Copy startup pstate to P1 and P0 MSRs. Set the maxvid for -+ * this node in P0. Then transition to P1 for corex and P0 -+ * for core0. These setting will be cleared by the warm reset -+ */ -+ msr = rdmsr(0xC0010064 + startup_pstate); -+ wrmsr(0xC0010065, msr); -+ wrmsr(0xC0010064, msr); -+ -+ /* missing step 2 from BDKG , F3xDC[PstateMaxVal] = -+ * max(1,F3xDC[PstateMaxVal] ) because it would take -+ * synchronization between cores and we don't think -+ * PstatMaxVal is going to be 0 on cold reset anyway ? -+ */ -+ if ( ! (pci_read_config32(dev, 0xDC) & (~ PS_MAX_VAL_MASK)) ) { -+ printk(BIOS_ERR,"F3xDC[PstateMaxVal] is zero. Northbridge voltage setting will fail. fixPsNbVidBeforeWR in fidvid.c needs fixing. See AMD # 31116 rev 3.48 BKDG 2.4.2.9.1 \n"); -+ }; -+ -+ msr.lo &= ~0xFE000000; // clear nbvid -+ msr.lo |= (newNbVid << 25); -+ wrmsr(0xC0010064, msr); -+ -+ if (pviMode) { /* single plane*/ -+ UpdateSinglePlaneNbVid(); -+ } -+ -+ // Transition to P1 for all APs and P0 for core0. -+ set_pstate(1); -+ -+ if (coreid == 0) { -+ set_pstate(0); -+ } -+ -+ /* missing step 7 (restore PstateMax to 0 if needed) because -+ * we skipped step 2 -+ */ -+ -+} -+ -+static u32 needs_NB_COF_VID_update(void) -+{ -+ u8 nb_cof_vid_update; -+ u8 nodes; -+ u8 i; -+ -+ /* If any node has nb_cof_vid_update set all nodes need an update. */ -+ nodes = get_nodes(); -+ nb_cof_vid_update = 0; -+ for (i = 0; i < nodes; i++) { -+ u32 cpuRev = mctGetLogicalCPUID(i) ; -+ u32 nbCofVidUpdateDefined = (cpuRev & (AMD_FAM10_LT_D)); -+ if (nbCofVidUpdateDefined -+ && (pci_read_config32(NODE_PCI(i, 3), 0x1FC) -+ & NB_COF_VID_UPDATE_MASK)) { -+ nb_cof_vid_update = 1; -+ break; -+ } -+ } -+ return nb_cof_vid_update; -+} -+ -+static u32 init_fidvid_core(u32 nodeid, u32 coreid) -+{ -+ device_t dev; -+ u32 vid_max; -+ u32 fid_max = 0; -+ u8 nb_cof_vid_update = needs_NB_COF_VID_update(); -+ u8 pvimode; -+ u32 reg1fc; -+ -+ /* Steps 1-6 of BIOS NB COF and VID Configuration -+ * for SVI and Single-Plane PVI Systems. BKDG 2.4.2.9 #31116 rev 3.48 -+ */ -+ -+ dev = NODE_PCI(nodeid, 3); -+ pvimode = pci_read_config32(dev, PW_CTL_MISC) & PVI_MODE; -+ reg1fc = pci_read_config32(dev, 0x1FC); -+ -+ if (nb_cof_vid_update) { -+ vid_max = (reg1fc & SINGLE_PLANE_NB_VID_MASK ) >> SINGLE_PLANE_NB_VID_SHIFT ; -+ fid_max = (reg1fc & SINGLE_PLANE_NB_FID_MASK ) >> SINGLE_PLANE_NB_FID_SHIFT ; -+ -+ if (!pvimode) { /* SVI, dual power plane */ -+ vid_max = vid_max - ((reg1fc & DUAL_PLANE_NB_VID_OFF_MASK ) >> DUAL_PLANE_NB_VID_SHIFT ); -+ fid_max = fid_max + ((reg1fc & DUAL_PLANE_NB_FID_OFF_MASK ) >> DUAL_PLANE_NB_FID_SHIFT ); -+ } -+ /* write newNbVid to P-state Reg's NbVid always if NbVidUpdatedAll=1 */ -+ fixPsNbVidBeforeWR(vid_max, coreid,dev,pvimode); -+ -+ /* fid setup is handled by the BSP at the end. */ -+ -+ } else { /* ! nb_cof_vid_update */ -+ /* Use max values */ -+ if (pvimode) -+ UpdateSinglePlaneNbVid(); -+ } -+ -+ return ((nb_cof_vid_update << 16) | (fid_max << 8)); -+ -+} -+ -+static void init_fidvid_ap(u32 apicid, u32 nodeid, u32 coreid) -+{ -+ u32 send; -+ -+ printk(BIOS_DEBUG, "FIDVID on AP: %02x\n", apicid); -+ -+ send = init_fidvid_core(nodeid,coreid); -+ send |= (apicid << 24); // ap apicid -+ -+ // Send signal to BSP about this AP max fid -+ // This also indicates this AP is ready for warm reset (if required). -+ lapic_write(LAPIC_MSG_REG, send | F10_APSTATE_RESET); -+} -+ -+static u32 calc_common_fid(u32 fid_packed, u32 fid_packed_new) -+{ -+ u32 fidmax; -+ u32 fidmax_new; -+ -+ fidmax = (fid_packed >> 8) & 0xFF; -+ -+ fidmax_new = (fid_packed_new >> 8) & 0xFF; -+ -+ if (fidmax > fidmax_new) { -+ fidmax = fidmax_new; -+ } -+ -+ fid_packed &= 0xFF << 16; -+ fid_packed |= (fidmax << 8); -+ fid_packed |= fid_packed_new & (0xFF << 16); // set nb_cof_vid_update -+ -+ return fid_packed; -+} -+ -+static void init_fidvid_bsp_stage1(u32 ap_apicid, void *gp) -+{ -+ u32 readback = 0; -+ u32 timeout = 1; -+ -+ struct fidvid_st *fvp = gp; -+ int loop; -+ -+ print_debug_fv("Wait for AP stage 1: ap_apicid = ", ap_apicid); -+ -+ loop = 100000; -+ while (--loop > 0) { -+ if (lapic_remote_read(ap_apicid, LAPIC_MSG_REG, &readback) != 0) -+ continue; -+ if ((readback & 0x3f) == 1) { -+ timeout = 0; -+ break; /* target ap is in stage 1 */ -+ } -+ } -+ -+ if (timeout) { -+ printk(BIOS_DEBUG, "%s: timed out reading from ap %02x\n", -+ __func__, ap_apicid); -+ return; -+ } -+ -+ print_debug_fv("\treadback = ", readback); -+ -+ fvp->common_fid = calc_common_fid(fvp->common_fid, readback); -+ -+ print_debug_fv("\tcommon_fid(packed) = ", fvp->common_fid); -+ -+} -+ -+static void fixPsNbVidAfterWR(u32 newNbVid, u8 NbVidUpdatedAll,u8 pviMode) -+{ -+ msr_t msr; -+ u8 i; -+ u8 StartupPstate; -+ -+ /* BKDG 2.4.2.9.1 11-12 -+ * This function copies newNbVid to NbVid bits in P-state -+ * Registers[4:0] if its NbDid bit=0, and IddValue!=0 in case of -+ * NbVidUpdatedAll =0 or copies newNbVid to NbVid bits in -+ * P-state Registers[4:0] if its IddValue!=0 in case of -+ * NbVidUpdatedAll=1. Then transition to StartPstate. -+ */ -+ -+ /* write newNbVid to P-state Reg's NbVid if its NbDid=0 */ -+ for (i = 0; i < 5; i++) { -+ msr = rdmsr(0xC0010064 + i); -+ /* NbDid (bit 22 of P-state Reg) == 0 or NbVidUpdatedAll = 1 */ -+ if ( (msr.hi & PS_IDD_VALUE_MASK) -+ && (msr.hi & PS_EN_MASK) -+ &&(((msr.lo & PS_NB_DID_MASK) == 0) || NbVidUpdatedAll)) { -+ msr.lo &= PS_NB_VID_M_OFF; -+ msr.lo |= (newNbVid & 0x7F) << PS_NB_VID_SHFT; -+ wrmsr(0xC0010064 + i, msr); -+ } -+ } -+ -+ /* Not documented. Would overwrite Nb_Vids just copied -+ * should we just update cpu_vid or nothing at all ? -+ */ -+ if (pviMode) { //single plane -+ UpdateSinglePlaneNbVid(); -+ } -+ /* For each core in the system, transition all cores to StartupPstate */ -+ msr = rdmsr(0xC0010071); -+ StartupPstate = msr.hi & 0x07; -+ -+ /* Set and wait for StartupPstate to set. */ -+ set_pstate(StartupPstate); -+ -+} -+ -+static void finalPstateChange(void) -+{ -+ /* Enable P0 on all cores for best performance. -+ * Linux can slow them down later if need be. -+ * It is safe since they will be in C1 halt -+ * most of the time anyway. -+ */ -+ set_pstate(0); -+} -+ -+static void init_fidvid_stage2(u32 apicid, u32 nodeid) -+{ -+ msr_t msr; -+ device_t dev; -+ u32 reg1fc; -+ u32 dtemp; -+ u32 nbvid; -+ u8 nb_cof_vid_update = needs_NB_COF_VID_update(); -+ u8 NbVidUpdateAll; -+ u8 pvimode; -+ -+ /* After warm reset finish the fid/vid setup for all cores. */ -+ -+ /* If any node has nb_cof_vid_update set all nodes need an update. */ -+ -+ dev = NODE_PCI(nodeid, 3); -+ pvimode = (pci_read_config32(dev, 0xA0) >> 8) & 1; -+ reg1fc = pci_read_config32(dev, 0x1FC); -+ nbvid = (reg1fc >> 7) & 0x7F; -+ NbVidUpdateAll = (reg1fc >> 1) & 1; -+ -+ if (nb_cof_vid_update) { -+ if (!pvimode) { /* SVI */ -+ nbvid = nbvid - ((reg1fc >> 17) & 0x1F); -+ } -+ /* write newNbVid to P-state Reg's NbVid if its NbDid=0 */ -+ fixPsNbVidAfterWR(nbvid, NbVidUpdateAll,pvimode); -+ } else { /* !nb_cof_vid_update */ -+ if (pvimode) -+ UpdateSinglePlaneNbVid(); -+ } -+ dtemp = pci_read_config32(dev, 0xA0); -+ dtemp &= PLLLOCK_OFF; -+ dtemp |= PLLLOCK_DFT_L; -+ pci_write_config32(dev, 0xA0, dtemp); -+ -+ dualPlaneOnly(dev); -+ applyBoostFIDOffset(dev); -+ enableNbPState1(dev); -+ -+ finalPstateChange(); -+ -+ /* Set TSC to tick at the P0 ndfid rate */ -+ msr = rdmsr(HWCR); -+ msr.lo |= 1 << 24; -+ wrmsr(HWCR, msr); -+} -+ -+ -+#if CONFIG_SET_FIDVID_STORE_AP_APICID_AT_FIRST -+struct ap_apicid_st { -+ u32 num; -+ // it could use 256 bytes for 64 node quad core system -+ u8 apicid[NODE_NUMS * 4]; -+}; -+ -+static void store_ap_apicid(unsigned ap_apicid, void *gp) -+{ -+ struct ap_apicid_st *p = gp; -+ -+ p->apicid[p->num++] = ap_apicid; -+ -+} -+#endif -+ -+ -+static int init_fidvid_bsp(u32 bsp_apicid, u32 nodes) -+{ -+#if CONFIG_SET_FIDVID_STORE_AP_APICID_AT_FIRST -+ struct ap_apicid_st ap_apicidx; -+ u32 i; -+#endif -+ struct fidvid_st fv; -+ -+ printk(BIOS_DEBUG, "FIDVID on BSP, APIC_id: %02x\n", bsp_apicid); -+ -+ /* Steps 1-6 of BIOS NB COF and VID Configuration -+ * for SVI and Single-Plane PVI Systems. -+ */ -+ -+ fv.common_fid = init_fidvid_core(0,0); -+ -+ print_debug_fv("BSP fid = ", fv.common_fid); -+ -+#if CONFIG_SET_FIDVID_STORE_AP_APICID_AT_FIRST && !CONFIG_SET_FIDVID_CORE0_ONLY -+ /* For all APs (We know the APIC ID of all APs even when the APIC ID -+ is lifted) remote read from AP LAPIC_MSG_REG about max fid. -+ Then calculate the common max fid that can be used for all -+ APs and BSP */ -+ ap_apicidx.num = 0; -+ -+ for_each_ap(bsp_apicid, CONFIG_SET_FIDVID_CORE_RANGE, store_ap_apicid, &ap_apicidx); -+ -+ for (i = 0; i < ap_apicidx.num; i++) { -+ init_fidvid_bsp_stage1(ap_apicidx.apicid[i], &fv); -+ } -+#else -+ for_each_ap(bsp_apicid, CONFIG_SET_FIDVID_CORE0_ONLY, init_fidvid_bsp_stage1, &fv); -+#endif -+ -+ print_debug_fv("common_fid = ", fv.common_fid); -+ -+ if (fv.common_fid & (1 << 16)) { /* check nb_cof_vid_update */ -+ -+ // Enable the common fid and other settings. -+ enable_fid_change((fv.common_fid >> 8) & 0x1F); -+ -+ // nbfid change need warm reset, so reset at first -+ return 1; -+ } -+ -+ return 0; // No FID/VID changes. Don't reset -+} -+#endif -diff --git a/src/cpu/amd/family_10h-family_15h/init_cpus.c b/src/cpu/amd/family_10h-family_15h/init_cpus.c -new file mode 100644 -index 0000000..8de6d25 ---- /dev/null -+++ b/src/cpu/amd/family_10h-family_15h/init_cpus.c -@@ -0,0 +1,968 @@ -+/* -+ * This file is part of the coreboot project. -+ * -+ * Copyright (C) 2007-2008 Advanced Micro Devices, Inc. -+ * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -+ * -+ * 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; version 2 of the License. -+ * -+ * 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. -+ * -+ * You should have received a copy of the GNU General Public License -+ * along with this program; if not, write to the Free Software -+ * Foundation, Inc. -+ */ -+ -+#include "cpu/amd/car/post_cache_as_ram.c" -+#include "defaults.h" -+#include <stdlib.h> -+#include <cpu/x86/lapic.h> -+#include <cpu/x86/mtrr.h> -+#include <northbridge/amd/amdfam10/amdfam10.h> -+#include <northbridge/amd/amdht/AsPsDefs.h> -+#include <northbridge/amd/amdht/porting.h> -+ -+#include <northbridge/amd/amdfam10/raminit_amdmct.c> -+#include <reset.h> -+ -+static void prep_fid_change(void); -+static void init_fidvid_stage2(u32 apicid, u32 nodeid); -+void cpuSetAMDMSR(void); -+ -+#if CONFIG_PCI_IO_CFG_EXT -+static void set_EnableCf8ExtCfg(void) -+{ -+ // set the NB_CFG[46]=1; -+ msr_t msr; -+ msr = rdmsr(NB_CFG_MSR); -+ // EnableCf8ExtCfg: We need that to access CONFIG_PCI_IO_CFG_EXT 4K range -+ msr.hi |= (1 << (46 - 32)); -+ wrmsr(NB_CFG_MSR, msr); -+} -+#else -+static void set_EnableCf8ExtCfg(void) { } -+#endif -+ -+ -+typedef void (*process_ap_t) (u32 apicid, void *gp); -+ -+//core_range = 0 : all cores -+//core range = 1 : core 0 only -+//core range = 2 : cores other than core0 -+ -+static void for_each_ap(u32 bsp_apicid, u32 core_range, process_ap_t process_ap, -+ void *gp) -+{ -+ // here assume the OS don't change our apicid -+ u32 ap_apicid; -+ -+ u32 nodes; -+ u32 siblings; -+ u32 disable_siblings; -+ u32 cores_found; -+ u32 nb_cfg_54; -+ int i, j; -+ u32 ApicIdCoreIdSize; -+ uint8_t rev_gte_d = 0; -+ uint8_t dual_node = 0; -+ uint32_t f3xe8; -+ -+ /* get_nodes define in ht_wrapper.c */ -+ nodes = get_nodes(); -+ -+ if (!CONFIG_LOGICAL_CPUS || -+ read_option(multi_core, 0) != 0) { // 0 means multi core -+ disable_siblings = 1; -+ } else { -+ disable_siblings = 0; -+ } -+ -+ /* Assume that all node are same stepping, otherwise we can use use -+ nb_cfg_54 from bsp for all nodes */ -+ nb_cfg_54 = read_nb_cfg_54(); -+ f3xe8 = pci_read_config32(NODE_PCI(0, 3), 0xe8); -+ -+ if (cpuid_eax(0x80000001) >= 0x8) -+ /* Revision D or later */ -+ rev_gte_d = 1; -+ -+ if (rev_gte_d) -+ /* Check for dual node capability */ -+ if (f3xe8 & 0x20000000) -+ dual_node = 1; -+ -+ ApicIdCoreIdSize = (cpuid_ecx(0x80000008) >> 12 & 0xf); -+ if (ApicIdCoreIdSize) { -+ siblings = ((1 << ApicIdCoreIdSize) - 1); -+ } else { -+ siblings = 3; //quad core -+ } -+ -+ for (i = 0; i < nodes; i++) { -+ cores_found = get_core_num_in_bsp(i); -+ if (siblings > cores_found) -+ siblings = cores_found; -+ -+ u32 jstart, jend; -+ -+ if (core_range == 2) { -+ jstart = 1; -+ } else { -+ jstart = 0; -+ } -+ -+ if (disable_siblings || (core_range == 1)) { -+ jend = 0; -+ } else { -+ jend = cores_found; -+ } -+ -+ for (j = jstart; j <= jend; j++) { -+ if (dual_node) { -+ ap_apicid = 0; -+ if (nb_cfg_54) { -+ ap_apicid |= ((i >> 1) & 0x3) << 4; /* Node ID */ -+ ap_apicid |= ((i & 0x1) * (siblings + 1)) + j; /* Core ID */ -+ } else { -+ ap_apicid |= i & 0x3; /* Node ID */ -+ ap_apicid |= (((i & 0x1) * (siblings + 1)) + j) << 4; /* Core ID */ -+ } -+ } else { -+ ap_apicid = -+ i * (nb_cfg_54 ? (siblings + 1) : 1) + -+ j * (nb_cfg_54 ? 1 : 64); -+ } -+ -+ -+#if CONFIG_ENABLE_APIC_EXT_ID && (CONFIG_APIC_ID_OFFSET > 0) -+#if !CONFIG_LIFT_BSP_APIC_ID -+ if ((i != 0) || (j != 0)) /* except bsp */ -+#endif -+ ap_apicid += CONFIG_APIC_ID_OFFSET; -+#endif -+ -+ if (ap_apicid == bsp_apicid) -+ continue; -+ -+ process_ap(ap_apicid, gp); -+ -+ } -+ } -+} -+ -+static inline int lapic_remote_read(int apicid, int reg, u32 *pvalue) -+{ -+ int timeout; -+ u32 status; -+ int result; -+ lapic_wait_icr_idle(); -+ lapic_write(LAPIC_ICR2, SET_LAPIC_DEST_FIELD(apicid)); -+ lapic_write(LAPIC_ICR, LAPIC_DM_REMRD | (reg >> 4)); -+ -+/* Extra busy check compared to lapic.h */ -+ timeout = 0; -+ do { -+ status = lapic_read(LAPIC_ICR) & LAPIC_ICR_BUSY; -+ } while (status == LAPIC_ICR_BUSY && timeout++ < 1000); -+ -+ timeout = 0; -+ do { -+ status = lapic_read(LAPIC_ICR) & LAPIC_ICR_RR_MASK; -+ } while (status == LAPIC_ICR_RR_INPROG && timeout++ < 1000); -+ -+ result = -1; -+ -+ if (status == LAPIC_ICR_RR_VALID) { -+ *pvalue = lapic_read(LAPIC_RRR); -+ result = 0; -+ } -+ return result; -+} -+ -+#if CONFIG_SET_FIDVID -+static void init_fidvid_ap(u32 apicid, u32 nodeid, u32 coreid); -+#endif -+ -+static inline __attribute__ ((always_inline)) -+void print_apicid_nodeid_coreid(u32 apicid, struct node_core_id id, -+ const char *str) -+{ -+ printk(BIOS_DEBUG, -+ "%s --- { APICID = %02x NODEID = %02x COREID = %02x} ---\n", str, -+ apicid, id.nodeid, id.coreid); -+} -+ -+static u32 wait_cpu_state(u32 apicid, u32 state) -+{ -+ u32 readback = 0; -+ u32 timeout = 1; -+ int loop = 4000000; -+ while (--loop > 0) { -+ if (lapic_remote_read(apicid, LAPIC_MSG_REG, &readback) != 0) -+ continue; -+ if ((readback & 0x3f) == state || (readback & 0x3f) == F10_APSTATE_RESET) { -+ timeout = 0; -+ break; //target cpu is in stage started -+ } -+ } -+ if (timeout) { -+ if (readback) { -+ timeout = readback; -+ } -+ } -+ -+ return timeout; -+} -+ -+static void wait_ap_started(u32 ap_apicid, void *gp) -+{ -+ u32 timeout; -+ timeout = wait_cpu_state(ap_apicid, F10_APSTATE_STARTED); -+ printk(BIOS_DEBUG, "* AP %02x", ap_apicid); -+ if (timeout) { -+ printk(BIOS_DEBUG, " timed out:%08x\n", timeout); -+ } else { -+ printk(BIOS_DEBUG, "started\n"); -+ } -+} -+ -+void wait_all_other_cores_started(u32 bsp_apicid) -+{ -+ // all aps other than core0 -+ printk(BIOS_DEBUG, "started ap apicid: "); -+ for_each_ap(bsp_apicid, 2, wait_ap_started, (void *)0); -+ printk(BIOS_DEBUG, "\n"); -+} -+ -+void allow_all_aps_stop(u32 bsp_apicid) -+{ -+ /* Called by the BSP to indicate AP can stop */ -+ -+ /* FIXME Do APs use this? */ -+ -+ // allow aps to stop use 6 bits for state -+ lapic_write(LAPIC_MSG_REG, (bsp_apicid << 24) | F10_APSTATE_STOPPED); -+} -+ -+static void enable_apic_ext_id(u32 node) -+{ -+ u32 val; -+ -+ val = pci_read_config32(NODE_HT(node), 0x68); -+ val |= (HTTC_APIC_EXT_SPUR | HTTC_APIC_EXT_ID | HTTC_APIC_EXT_BRD_CST); -+ pci_write_config32(NODE_HT(node), 0x68, val); -+} -+ -+static void STOP_CAR_AND_CPU(void) -+{ -+ msr_t msr; -+ -+ /* Disable L2 IC to L3 connection (Only for CAR) */ -+ msr = rdmsr(BU_CFG2); -+ msr.lo &= ~(1 << ClLinesToNbDis); -+ wrmsr(BU_CFG2, msr); -+ -+ disable_cache_as_ram(); // inline -+ /* stop all cores except node0/core0 the bsp .... */ -+ stop_this_cpu(); -+} -+ -+static u32 init_cpus(u32 cpu_init_detectedx, struct sys_info *sysinfo) -+{ -+ u32 bsp_apicid = 0; -+ u32 apicid; -+ struct node_core_id id; -+ -+ /* Please refer to the calculations and explaination in cache_as_ram.inc before modifying these values */ -+ uint32_t max_ap_stack_region_size = CONFIG_MAX_CPUS * CONFIG_DCACHE_AP_STACK_SIZE; -+ uint32_t max_bsp_stack_region_size = CONFIG_DCACHE_BSP_STACK_SIZE + CONFIG_DCACHE_BSP_STACK_SLUSH; -+ uint32_t bsp_stack_region_upper_boundary = CONFIG_DCACHE_RAM_BASE + CONFIG_DCACHE_RAM_SIZE; -+ uint32_t bsp_stack_region_lower_boundary = bsp_stack_region_upper_boundary - max_bsp_stack_region_size; -+ void * lower_stack_region_boundary = (void*)(bsp_stack_region_lower_boundary - max_ap_stack_region_size); -+ if (((void*)(sysinfo + 1)) > lower_stack_region_boundary) -+ printk(BIOS_WARNING, -+ "sysinfo extends into stack region (sysinfo range: [%p,%p] lower stack region boundary: %p)\n", -+ sysinfo, sysinfo + 1, lower_stack_region_boundary); -+ -+ /* -+ * already set early mtrr in cache_as_ram.inc -+ */ -+ -+ /* that is from initial apicid, we need nodeid and coreid -+ later */ -+ id = get_node_core_id_x(); -+ -+ /* NB_CFG MSR is shared between cores, so we need make sure -+ core0 is done at first --- use wait_all_core0_started */ -+ if (id.coreid == 0) { -+ set_apicid_cpuid_lo(); /* only set it on core0 */ -+ set_EnableCf8ExtCfg(); /* only set it on core0 */ -+#if CONFIG_ENABLE_APIC_EXT_ID -+ enable_apic_ext_id(id.nodeid); -+#endif -+ } -+ -+ enable_lapic(); -+ -+#if CONFIG_ENABLE_APIC_EXT_ID && (CONFIG_APIC_ID_OFFSET > 0) -+ u32 initial_apicid = get_initial_apicid(); -+ -+#if !CONFIG_LIFT_BSP_APIC_ID -+ if (initial_apicid != 0) // other than bsp -+#endif -+ { -+ /* use initial apic id to lift it */ -+ u32 dword = lapic_read(LAPIC_ID); -+ dword &= ~(0xff << 24); -+ dword |= -+ (((initial_apicid + CONFIG_APIC_ID_OFFSET) & 0xff) << 24); -+ -+ lapic_write(LAPIC_ID, dword); -+ } -+#if CONFIG_LIFT_BSP_APIC_ID -+ bsp_apicid += CONFIG_APIC_ID_OFFSET; -+#endif -+ -+#endif -+ -+ /* get the apicid, it may be lifted already */ -+ apicid = lapicid(); -+ -+ // show our apicid, nodeid, and coreid -+ if (id.coreid == 0) { -+ if (id.nodeid != 0) //all core0 except bsp -+ print_apicid_nodeid_coreid(apicid, id, " core0: "); -+ } else { //all other cores -+ print_apicid_nodeid_coreid(apicid, id, " corex: "); -+ } -+ -+ if (cpu_init_detectedx) { -+ print_apicid_nodeid_coreid(apicid, id, -+ "\n\n\nINIT detected from "); -+ printk(BIOS_DEBUG, "\nIssuing SOFT_RESET...\n"); -+ soft_reset(); -+ } -+ -+ if (id.coreid == 0) { -+ if (!(warm_reset_detect(id.nodeid))) //FIXME: INIT is checked above but check for more resets? -+ distinguish_cpu_resets(id.nodeid); // Also indicates we are started -+ } -+ // Mark the core as started. -+ lapic_write(LAPIC_MSG_REG, (apicid << 24) | F10_APSTATE_STARTED); -+ -+ if (apicid != bsp_apicid) { -+ /* Setup each AP's cores MSRs. -+ * This happens after HTinit. -+ * The BSP runs this code in it's own path. -+ */ -+ update_microcode(cpuid_eax(1)); -+ -+ cpuSetAMDMSR(); -+ -+#if CONFIG_SET_FIDVID -+#if CONFIG_LOGICAL_CPUS && CONFIG_SET_FIDVID_CORE0_ONLY -+ // Run on all AP for proper FID/VID setup. -+ if (id.coreid == 0) // only need set fid for core0 -+#endif -+ { -+ // check warm(bios) reset to call stage2 otherwise do stage1 -+ if (warm_reset_detect(id.nodeid)) { -+ printk(BIOS_DEBUG, -+ "init_fidvid_stage2 apicid: %02x\n", -+ apicid); -+ init_fidvid_stage2(apicid, id.nodeid); -+ } else { -+ printk(BIOS_DEBUG, -+ "init_fidvid_ap(stage1) apicid: %02x\n", -+ apicid); -+ init_fidvid_ap(apicid, id.nodeid, id.coreid); -+ } -+ } -+#endif -+ -+ /* AP is ready, configure MTRRs and go to sleep */ -+ set_var_mtrr(0, 0x00000000, CONFIG_RAMTOP, MTRR_TYPE_WRBACK); -+ -+ STOP_CAR_AND_CPU(); -+ -+ printk(BIOS_DEBUG, -+ "\nAP %02x should be halted but you are reading this....\n", -+ apicid); -+ } -+ -+ return bsp_apicid; -+} -+ -+static u32 is_core0_started(u32 nodeid) -+{ -+ u32 htic; -+ device_t device; -+ device = NODE_PCI(nodeid, 0); -+ htic = pci_read_config32(device, HT_INIT_CONTROL); -+ htic &= HTIC_ColdR_Detect; -+ return htic; -+} -+ -+void wait_all_core0_started(void) -+{ -+ /* When core0 is started, it will distingush_cpu_resets -+ * So wait for that to finish */ -+ u32 i; -+ u32 nodes = get_nodes(); -+ -+ printk(BIOS_DEBUG, "core0 started: "); -+ for (i = 1; i < nodes; i++) { // skip bsp, because it is running on bsp -+ while (!is_core0_started(i)) { -+ } -+ printk(BIOS_DEBUG, " %02x", i); -+ } -+ printk(BIOS_DEBUG, "\n"); -+} -+ -+#if CONFIG_MAX_PHYSICAL_CPUS > 1 -+/** -+ * void start_node(u32 node) -+ * -+ * start the core0 in node, so it can generate HT packet to feature code. -+ * -+ * This function starts the AP nodes core0s. wait_all_core0_started() in -+ * romstage.c waits for all the AP to be finished before continuing -+ * system init. -+ */ -+static void start_node(u8 node) -+{ -+ u32 val; -+ -+ /* Enable routing table */ -+ printk(BIOS_DEBUG, "Start node %02x", node); -+ -+#if CONFIG_NORTHBRIDGE_AMD_AMDFAM10 -+ /* For FAM10 support, we need to set Dram base/limit for the new node */ -+ pci_write_config32(NODE_MP(node), 0x44, 0); -+ pci_write_config32(NODE_MP(node), 0x40, 3); -+#endif -+ -+ /* Allow APs to make requests (ROM fetch) */ -+ val = pci_read_config32(NODE_HT(node), 0x6c); -+ val &= ~(1 << 1); -+ pci_write_config32(NODE_HT(node), 0x6c, val); -+ -+ printk(BIOS_DEBUG, " done.\n"); -+} -+ -+/** -+ * static void setup_remote_node(u32 node) -+ * -+ * Copy the BSP Address Map to each AP. -+ */ -+static void setup_remote_node(u8 node) -+{ -+ /* There registers can be used with F1x114_x Address Map at the -+ same time, So must set them even 32 node */ -+ static const u16 pci_reg[] = { -+ /* DRAM Base/Limits Registers */ -+ 0x44, 0x4c, 0x54, 0x5c, 0x64, 0x6c, 0x74, 0x7c, -+ 0x40, 0x48, 0x50, 0x58, 0x60, 0x68, 0x70, 0x78, -+ 0x144, 0x14c, 0x154, 0x15c, 0x164, 0x16c, 0x174, 0x17c, -+ 0x140, 0x148, 0x150, 0x158, 0x160, 0x168, 0x170, 0x178, -+ /* MMIO Base/Limits Registers */ -+ 0x84, 0x8c, 0x94, 0x9c, 0xa4, 0xac, 0xb4, 0xbc, -+ 0x80, 0x88, 0x90, 0x98, 0xa0, 0xa8, 0xb0, 0xb8, -+ /* IO Base/Limits Registers */ -+ 0xc4, 0xcc, 0xd4, 0xdc, -+ 0xc0, 0xc8, 0xd0, 0xd8, -+ /* Configuration Map Registers */ -+ 0xe0, 0xe4, 0xe8, 0xec, -+ }; -+ u16 i; -+ -+ printk(BIOS_DEBUG, "setup_remote_node: %02x", node); -+ -+ /* copy the default resource map from node 0 */ -+ for (i = 0; i < ARRAY_SIZE(pci_reg); i++) { -+ u32 value; -+ u16 reg; -+ reg = pci_reg[i]; -+ value = pci_read_config32(NODE_MP(0), reg); -+ pci_write_config32(NODE_MP(node), reg, value); -+ -+ } -+ printk(BIOS_DEBUG, " done\n"); -+} -+#endif /* CONFIG_MAX_PHYSICAL_CPUS > 1 */ -+ -+static void AMD_Errata281(u8 node, u32 revision, u32 platform) -+{ -+ /* Workaround for Transaction Scheduling Conflict in -+ * Northbridge Cross Bar. Implement XCS Token adjustment -+ * for ganged links. Also, perform fix up for the mixed -+ * revision case. -+ */ -+ -+ u32 reg, val; -+ u8 i; -+ u8 mixed = 0; -+ u8 nodes = get_nodes(); -+ -+ if (platform & AMD_PTYPE_SVR) { -+ /* For each node we need to check for a "broken" node */ -+ if (!(revision & (AMD_DR_B0 | AMD_DR_B1))) { -+ for (i = 0; i < nodes; i++) { -+ if (mctGetLogicalCPUID(i) & -+ (AMD_DR_B0 | AMD_DR_B1)) { -+ mixed = 1; -+ break; -+ } -+ } -+ } -+ -+ if ((revision & (AMD_DR_B0 | AMD_DR_B1)) || mixed) { -+ -+ /* F0X68[22:21] DsNpReqLmt0 = 01b */ -+ val = pci_read_config32(NODE_PCI(node, 0), 0x68); -+ val &= ~0x00600000; -+ val |= 0x00200000; -+ pci_write_config32(NODE_PCI(node, 0), 0x68, val); -+ -+ /* F3X6C */ -+ val = pci_read_config32(NODE_PCI(node, 3), 0x6C); -+ val &= ~0x700780F7; -+ val |= 0x00010094; -+ pci_write_config32(NODE_PCI(node, 3), 0x6C, val); -+ -+ /* F3X7C */ -+ val = pci_read_config32(NODE_PCI(node, 3), 0x7C); -+ val &= ~0x707FFF1F; -+ val |= 0x00144514; -+ pci_write_config32(NODE_PCI(node, 3), 0x7C, val); -+ -+ /* F3X144[3:0] RspTok = 0001b */ -+ val = pci_read_config32(NODE_PCI(node, 3), 0x144); -+ val &= ~0x0000000F; -+ val |= 0x00000001; -+ pci_write_config32(NODE_PCI(node, 3), 0x144, val); -+ -+ for (i = 0; i < 3; i++) { -+ reg = 0x148 + (i * 4); -+ val = pci_read_config32(NODE_PCI(node, 3), reg); -+ val &= ~0x000000FF; -+ val |= 0x000000DB; -+ pci_write_config32(NODE_PCI(node, 3), reg, val); -+ } -+ } -+ } -+} -+ -+static void AMD_Errata298(void) -+{ -+ /* Workaround for L2 Eviction May Occur during operation to -+ * set Accessed or dirty bit. -+ */ -+ -+ msr_t msr; -+ u8 i; -+ u8 affectedRev = 0; -+ u8 nodes = get_nodes(); -+ -+ /* For each core we need to check for a "broken" node */ -+ for (i = 0; i < nodes; i++) { -+ if (mctGetLogicalCPUID(i) & (AMD_DR_B0 | AMD_DR_B1 | AMD_DR_B2)) { -+ affectedRev = 1; -+ break; -+ } -+ } -+ -+ if (affectedRev) { -+ msr = rdmsr(HWCR); -+ msr.lo |= 0x08; /* Set TlbCacheDis bit[3] */ -+ wrmsr(HWCR, msr); -+ -+ msr = rdmsr(BU_CFG); -+ msr.lo |= 0x02; /* Set TlbForceMemTypeUc bit[1] */ -+ wrmsr(BU_CFG, msr); -+ -+ msr = rdmsr(OSVW_ID_Length); -+ msr.lo |= 0x01; /* OS Visible Workaround - MSR */ -+ wrmsr(OSVW_ID_Length, msr); -+ -+ msr = rdmsr(OSVW_Status); -+ msr.lo |= 0x01; /* OS Visible Workaround - MSR */ -+ wrmsr(OSVW_Status, msr); -+ } -+ -+ if (!affectedRev && (mctGetLogicalCPUID(0xFF) & AMD_DR_B3)) { -+ msr = rdmsr(OSVW_ID_Length); -+ msr.lo |= 0x01; /* OS Visible Workaround - MSR */ -+ wrmsr(OSVW_ID_Length, msr); -+ -+ } -+} -+ -+static u32 get_platform_type(void) -+{ -+ u32 ret = 0; -+ -+ switch (SYSTEM_TYPE) { -+ case 1: -+ ret |= AMD_PTYPE_DSK; -+ break; -+ case 2: -+ ret |= AMD_PTYPE_MOB; -+ break; -+ case 0: -+ ret |= AMD_PTYPE_SVR; -+ break; -+ default: -+ break; -+ } -+ -+ /* FIXME: add UMA support. */ -+ -+ /* All Fam10 are multi core */ -+ ret |= AMD_PTYPE_MC; -+ -+ return ret; -+} -+ -+static void AMD_SetupPSIVID_d(u32 platform_type, u8 node) -+{ -+ u32 dword; -+ int i; -+ msr_t msr; -+ -+ if (platform_type & (AMD_PTYPE_MOB | AMD_PTYPE_DSK)) { -+ -+ /* The following code sets the PSIVID to the lowest support P state -+ * assuming that the VID for the lowest power state is below -+ * the VDD voltage regulator threshold. (This also assumes that there -+ * is a Pstate lower than P0) -+ */ -+ -+ for (i = 4; i >= 0; i--) { -+ msr = rdmsr(PS_REG_BASE + i); -+ /* Pstate valid? */ -+ if (msr.hi & PS_EN_MASK) { -+ dword = pci_read_config32(NODE_PCI(i, 3), 0xA0); -+ dword &= ~0x7F; -+ dword |= (msr.lo >> 9) & 0x7F; -+ pci_write_config32(NODE_PCI(i, 3), 0xA0, dword); -+ break; -+ } -+ } -+ } -+} -+ -+/** -+ * AMD_CpuFindCapability - Traverse PCI capability list to find host HT links. -+ * HT Phy operations are not valid on links that aren't present, so this -+ * prevents invalid accesses. -+ * -+ * Returns the offset of the link register. -+ */ -+static BOOL AMD_CpuFindCapability(u8 node, u8 cap_count, u8 * offset) -+{ -+ u32 reg; -+ u32 val; -+ -+ /* get start of CPU HT Host Capabilities */ -+ val = pci_read_config32(NODE_PCI(node, 0), 0x34); -+ val &= 0xFF; //reg offset of first link -+ -+ cap_count++; -+ -+ /* Traverse through the capabilities. */ -+ do { -+ reg = pci_read_config32(NODE_PCI(node, 0), val); -+ /* Is the capability block a HyperTransport capability block? */ -+ if ((reg & 0xFF) == 0x08) { -+ /* Is the HT capability block an HT Host Capability? */ -+ if ((reg & 0xE0000000) == (1 << 29)) -+ cap_count--; -+ } -+ -+ if (cap_count) -+ val = (reg >> 8) & 0xFF; //update reg offset -+ } while (cap_count && val); -+ -+ *offset = (u8) val; -+ -+ /* If requested capability found val != 0 */ -+ if (!cap_count) -+ return TRUE; -+ else -+ return FALSE; -+} -+ -+/** -+ * AMD_checkLinkType - Compare desired link characteristics using a logical -+ * link type mask. -+ * -+ * Returns the link characteristic mask. -+ */ -+static u32 AMD_checkLinkType(u8 node, u8 link, u8 regoff) -+{ -+ u32 val; -+ u32 linktype = 0; -+ -+ /* Check connect, init and coherency */ -+ val = pci_read_config32(NODE_PCI(node, 0), regoff + 0x18); -+ val &= 0x1F; -+ -+ if (val == 3) -+ linktype |= HTPHY_LINKTYPE_COHERENT; -+ -+ if (val == 7) -+ linktype |= HTPHY_LINKTYPE_NONCOHERENT; -+ -+ if (linktype) { -+ /* Check gen3 */ -+ val = pci_read_config32(NODE_PCI(node, 0), regoff + 0x08); -+ -+ if (((val >> 8) & 0x0F) > 6) -+ linktype |= HTPHY_LINKTYPE_HT3; -+ else -+ linktype |= HTPHY_LINKTYPE_HT1; -+ -+ /* Check ganged */ -+ val = pci_read_config32(NODE_PCI(node, 0), (link << 2) + 0x170); -+ -+ if (val & 1) -+ linktype |= HTPHY_LINKTYPE_GANGED; -+ else -+ linktype |= HTPHY_LINKTYPE_UNGANGED; -+ } -+ return linktype; -+} -+ -+/** -+ * AMD_SetHtPhyRegister - Use the HT link's HT Phy portal registers to update -+ * a phy setting for that link. -+ */ -+static void AMD_SetHtPhyRegister(u8 node, u8 link, u8 entry) -+{ -+ u32 phyReg; -+ u32 phyBase; -+ u32 val; -+ -+ /* Determine this link's portal */ -+ if (link > 3) -+ link -= 4; -+ -+ phyBase = ((u32) link << 3) | 0x180; -+ -+ /* Get the portal control register's initial value -+ * and update it to access the desired phy register -+ */ -+ phyReg = pci_read_config32(NODE_PCI(node, 4), phyBase); -+ -+ if (fam10_htphy_default[entry].htreg > 0x1FF) { -+ phyReg &= ~HTPHY_DIRECT_OFFSET_MASK; -+ phyReg |= HTPHY_DIRECT_MAP; -+ } else { -+ phyReg &= ~HTPHY_OFFSET_MASK; -+ } -+ -+ /* Now get the current phy register data -+ * LinkPhyDone = 0, LinkPhyWrite = 0 is a read -+ */ -+ phyReg |= fam10_htphy_default[entry].htreg; -+ pci_write_config32(NODE_PCI(node, 4), phyBase, phyReg); -+ -+ do { -+ val = pci_read_config32(NODE_PCI(node, 4), phyBase); -+ } while (!(val & HTPHY_IS_COMPLETE_MASK)); -+ -+ /* Now we have the phy register data, apply the change */ -+ val = pci_read_config32(NODE_PCI(node, 4), phyBase + 4); -+ val &= ~fam10_htphy_default[entry].mask; -+ val |= fam10_htphy_default[entry].data; -+ pci_write_config32(NODE_PCI(node, 4), phyBase + 4, val); -+ -+ /* write it through the portal to the phy -+ * LinkPhyDone = 0, LinkPhyWrite = 1 is a write -+ */ -+ phyReg |= HTPHY_WRITE_CMD; -+ pci_write_config32(NODE_PCI(node, 4), phyBase, phyReg); -+ -+ do { -+ val = pci_read_config32(NODE_PCI(node, 4), phyBase); -+ } while (!(val & HTPHY_IS_COMPLETE_MASK)); -+} -+ -+void cpuSetAMDMSR(void) -+{ -+ /* This routine loads the CPU with default settings in fam10_msr_default -+ * table . It must be run after Cache-As-RAM has been enabled, and -+ * Hypertransport initialization has taken place. Also note -+ * that it is run on the current processor only, and only for the current -+ * processor core. -+ */ -+ msr_t msr; -+ u8 i; -+ u32 revision, platform; -+ -+ printk(BIOS_DEBUG, "cpuSetAMDMSR "); -+ -+ revision = mctGetLogicalCPUID(0xFF); -+ platform = get_platform_type(); -+ -+ for (i = 0; i < ARRAY_SIZE(fam10_msr_default); i++) { -+ if ((fam10_msr_default[i].revision & revision) && -+ (fam10_msr_default[i].platform & platform)) { -+ msr = rdmsr(fam10_msr_default[i].msr); -+ msr.hi &= ~fam10_msr_default[i].mask_hi; -+ msr.hi |= fam10_msr_default[i].data_hi; -+ msr.lo &= ~fam10_msr_default[i].mask_lo; -+ msr.lo |= fam10_msr_default[i].data_lo; -+ wrmsr(fam10_msr_default[i].msr, msr); -+ } -+ } -+ AMD_Errata298(); -+ -+ printk(BIOS_DEBUG, " done\n"); -+} -+ -+static void cpuSetAMDPCI(u8 node) -+{ -+ /* This routine loads the CPU with default settings in fam10_pci_default -+ * table . It must be run after Cache-As-RAM has been enabled, and -+ * Hypertransport initialization has taken place. Also note -+ * that it is run for the first core on each node -+ */ -+ u8 i, j; -+ u32 revision, platform; -+ u32 val; -+ u8 offset; -+ -+ printk(BIOS_DEBUG, "cpuSetAMDPCI %02d", node); -+ -+ revision = mctGetLogicalCPUID(node); -+ platform = get_platform_type(); -+ -+ AMD_SetupPSIVID_d(platform, node); /* Set PSIVID offset which is not table driven */ -+ -+ for (i = 0; i < ARRAY_SIZE(fam10_pci_default); i++) { -+ if ((fam10_pci_default[i].revision & revision) && -+ (fam10_pci_default[i].platform & platform)) { -+ val = pci_read_config32(NODE_PCI(node, -+ fam10_pci_default[i]. -+ function), -+ fam10_pci_default[i].offset); -+ val &= ~fam10_pci_default[i].mask; -+ val |= fam10_pci_default[i].data; -+ pci_write_config32(NODE_PCI(node, -+ fam10_pci_default[i]. -+ function), -+ fam10_pci_default[i].offset, val); -+ } -+ } -+ -+ for (i = 0; i < ARRAY_SIZE(fam10_htphy_default); i++) { -+ if ((fam10_htphy_default[i].revision & revision) && -+ (fam10_htphy_default[i].platform & platform)) { -+ /* HT Phy settings either apply to both sublinks or have -+ * separate registers for sublink zero and one, so there -+ * will be two table entries. So, here we only loop -+ * through the sublink zeros in function zero. -+ */ -+ for (j = 0; j < 4; j++) { -+ if (AMD_CpuFindCapability(node, j, &offset)) { -+ if (AMD_checkLinkType(node, j, offset) -+ & fam10_htphy_default[i].linktype) { -+ AMD_SetHtPhyRegister(node, j, -+ i); -+ } -+ } else { -+ /* No more capabilities, -+ * link not present -+ */ -+ break; -+ } -+ } -+ } -+ } -+ -+ /* FIXME: add UMA support and programXbarToSriReg(); */ -+ -+ AMD_Errata281(node, revision, platform); -+ -+ /* FIXME: if the dct phy doesn't init correct it needs to reset. -+ if (revision & (AMD_DR_B2 | AMD_DR_B3)) -+ dctPhyDiag(); */ -+ -+ printk(BIOS_DEBUG, " done\n"); -+} -+ -+#ifdef UNUSED_CODE -+static void cpuInitializeMCA(void) -+{ -+ /* Clears Machine Check Architecture (MCA) registers, which power on -+ * containing unknown data, on currently running processor. -+ * This routine should only be executed on initial power on (cold boot), -+ * not across a warm reset because valid data is present at that time. -+ */ -+ -+ msr_t msr; -+ u32 reg; -+ u8 i; -+ -+ if (cpuid_edx(1) & 0x4080) { /* MCE and MCA (edx[7] and edx[14]) */ -+ msr = rdmsr(MCG_CAP); -+ if (msr.lo & MCG_CTL_P) { /* MCG_CTL_P bit is set? */ -+ msr.lo &= 0xFF; -+ msr.lo--; -+ msr.lo <<= 2; /* multiply the count by 4 */ -+ reg = MC0_STA + msr.lo; -+ msr.lo = msr.hi = 0; -+ for (i = 0; i < 4; i++) { -+ wrmsr(reg, msr); -+ reg -= 4; /* Touch status regs for each bank */ -+ } -+ } -+ } -+} -+#endif -+ -+/** -+ * finalize_node_setup() -+ * -+ * Do any additional post HT init -+ * -+ */ -+static void finalize_node_setup(struct sys_info *sysinfo) -+{ -+ u8 i; -+ u8 nodes = get_nodes(); -+ u32 reg; -+ -+ /* read Node0 F0_0x64 bit [8:10] to find out SbLink # */ -+ reg = pci_read_config32(NODE_HT(0), 0x64); -+ sysinfo->sblk = (reg >> 8) & 7; -+ sysinfo->sbbusn = 0; -+ sysinfo->nodes = nodes; -+ sysinfo->sbdn = get_sbdn(sysinfo->sbbusn); -+ -+ for (i = 0; i < nodes; i++) { -+ cpuSetAMDPCI(i); -+ } -+ -+#if CONFIG_SET_FIDVID -+ // Prep each node for FID/VID setup. -+ prep_fid_change(); -+#endif -+ -+#if CONFIG_MAX_PHYSICAL_CPUS > 1 -+ /* Skip the BSP, start at node 1 */ -+ for (i = 1; i < nodes; i++) { -+ setup_remote_node(i); -+ start_node(i); -+ } -+#endif -+} -+ -+#include "fidvid.c" -diff --git a/src/cpu/amd/family_10h-family_15h/model_10xxx_init.c b/src/cpu/amd/family_10h-family_15h/model_10xxx_init.c -new file mode 100644 -index 0000000..b942c1a ---- /dev/null -+++ b/src/cpu/amd/family_10h-family_15h/model_10xxx_init.c -@@ -0,0 +1,165 @@ -+/* -+ * This file is part of the coreboot project. -+ * -+ * Copyright (C) 2007 Advanced Micro Devices, Inc. -+ * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -+ * -+ * 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; version 2 of the License. -+ * -+ * 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. -+ * -+ * You should have received a copy of the GNU General Public License -+ * along with this program; if not, write to the Free Software -+ * Foundation, Inc. -+ */ -+ -+#include <console/console.h> -+#include <cpu/x86/msr.h> -+#include <cpu/amd/mtrr.h> -+#include <device/device.h> -+#include <device/pci.h> -+#include <string.h> -+#include <cpu/x86/msr.h> -+#include <cpu/x86/smm.h> -+#include <cpu/x86/pae.h> -+#include <pc80/mc146818rtc.h> -+#include <cpu/x86/lapic.h> -+#include "northbridge/amd/amdfam10/amdfam10.h" -+#include <cpu/amd/model_10xxx_rev.h> -+#include <cpu/cpu.h> -+#include <cpu/x86/cache.h> -+#include <cpu/x86/mtrr.h> -+#include <cpu/amd/multicore.h> -+#include <cpu/amd/model_10xxx_msr.h> -+ -+#define MCI_STATUS 0x401 -+ -+static void model_10xxx_init(device_t dev) -+{ -+ u8 i; -+ msr_t msr; -+ struct node_core_id id; -+#if CONFIG_LOGICAL_CPUS -+ u32 siblings; -+#endif -+ -+ id = get_node_core_id(read_nb_cfg_54()); /* nb_cfg_54 can not be set */ -+ printk(BIOS_DEBUG, "nodeid = %02d, coreid = %02d\n", id.nodeid, id.coreid); -+ -+ /* Turn on caching if we haven't already */ -+ x86_enable_cache(); -+ amd_setup_mtrrs(); -+ x86_mtrr_check(); -+ -+ disable_cache(); -+ -+ /* zero the machine check error status registers */ -+ msr.lo = 0; -+ msr.hi = 0; -+ for (i = 0; i < 5; i++) { -+ wrmsr(MCI_STATUS + (i * 4), msr); -+ } -+ -+ enable_cache(); -+ -+ /* Enable the local cpu apics */ -+ setup_lapic(); -+ -+ /* Set the processor name string */ -+ init_processor_name(); -+ -+#if CONFIG_LOGICAL_CPUS -+ siblings = cpuid_ecx(0x80000008) & 0xff; -+ -+ if (siblings > 0) { -+ msr = rdmsr_amd(CPU_ID_FEATURES_MSR); -+ msr.lo |= 1 << 28; -+ wrmsr_amd(CPU_ID_FEATURES_MSR, msr); -+ -+ msr = rdmsr_amd(CPU_ID_EXT_FEATURES_MSR); -+ msr.hi |= 1 << (33 - 32); -+ wrmsr_amd(CPU_ID_EXT_FEATURES_MSR, msr); -+ } -+ printk(BIOS_DEBUG, "siblings = %02d, ", siblings); -+#endif -+ -+ /* DisableCf8ExtCfg */ -+ msr = rdmsr(NB_CFG_MSR); -+ msr.hi &= ~(1 << (46 - 32)); -+ wrmsr(NB_CFG_MSR, msr); -+ -+ msr = rdmsr(BU_CFG2_MSR); -+ /* Clear ClLinesToNbDis */ -+ msr.lo &= ~(1 << 15); -+ /* Clear bit 35 as per Erratum 343 */ -+ msr.hi &= ~(1 << (35-32)); -+ wrmsr(BU_CFG2_MSR, msr); -+ -+ if (IS_ENABLED(CONFIG_HAVE_SMI_HANDLER)) { -+ printk(BIOS_DEBUG, "Initializing SMM ASeg memory\n"); -+ -+ /* Set SMM base address for this CPU */ -+ msr = rdmsr(SMM_BASE_MSR); -+ msr.lo = SMM_BASE - (lapicid() * 0x400); -+ wrmsr(SMM_BASE_MSR, msr); -+ -+ /* Enable the SMM memory window */ -+ msr = rdmsr(SMM_MASK_MSR); -+ msr.lo |= (1 << 0); /* Enable ASEG SMRAM Range */ -+ wrmsr(SMM_MASK_MSR, msr); -+ } else { -+ printk(BIOS_DEBUG, "Disabling SMM ASeg memory\n"); -+ -+ /* Set SMM base address for this CPU */ -+ msr = rdmsr(SMM_BASE_MSR); -+ msr.lo = SMM_BASE - (lapicid() * 0x400); -+ wrmsr(SMM_BASE_MSR, msr); -+ -+ /* Disable the SMM memory window */ -+ msr.hi = 0x0; -+ msr.lo = 0x0; -+ wrmsr(SMM_MASK_MSR, msr); -+ } -+ -+ /* Set SMMLOCK to avoid exploits messing with SMM */ -+ msr = rdmsr(HWCR_MSR); -+ msr.lo |= (1 << 0); -+ wrmsr(HWCR_MSR, msr); -+ -+} -+ -+static struct device_operations cpu_dev_ops = { -+ .init = model_10xxx_init, -+}; -+ -+static struct cpu_device_id cpu_table[] = { -+//AMD_GH_SUPPORT -+ { X86_VENDOR_AMD, 0x100f00 }, /* SH-F0 L1 */ -+ { X86_VENDOR_AMD, 0x100f10 }, /* M2 */ -+ { X86_VENDOR_AMD, 0x100f20 }, /* S1g1 */ -+ { X86_VENDOR_AMD, 0x100f21 }, -+ { X86_VENDOR_AMD, 0x100f2A }, -+ { X86_VENDOR_AMD, 0x100f22 }, -+ { X86_VENDOR_AMD, 0x100f23 }, -+ { X86_VENDOR_AMD, 0x100f40 }, /* RB-C0 */ -+ { X86_VENDOR_AMD, 0x100F42 }, /* RB-C2 */ -+ { X86_VENDOR_AMD, 0x100F43 }, /* RB-C3 */ -+ { X86_VENDOR_AMD, 0x100F52 }, /* BL-C2 */ -+ { X86_VENDOR_AMD, 0x100F62 }, /* DA-C2 */ -+ { X86_VENDOR_AMD, 0x100F63 }, /* DA-C3 */ -+ { X86_VENDOR_AMD, 0x100F80 }, /* HY-D0 */ -+ { X86_VENDOR_AMD, 0x100F81 }, /* HY-D1 */ -+ { X86_VENDOR_AMD, 0x100F91 }, /* HY-D1 */ -+ { X86_VENDOR_AMD, 0x100FA0 }, /* PH-E0 */ -+ { 0, 0 }, -+}; -+ -+static const struct cpu_driver model_10xxx __cpu_driver = { -+ .ops = &cpu_dev_ops, -+ .id_table = cpu_table, -+}; -diff --git a/src/cpu/amd/family_10h-family_15h/monotonic_timer.c b/src/cpu/amd/family_10h-family_15h/monotonic_timer.c -new file mode 100644 -index 0000000..8c02fd1 ---- /dev/null -+++ b/src/cpu/amd/family_10h-family_15h/monotonic_timer.c -@@ -0,0 +1,98 @@ -+/* -+ * This file is part of the coreboot project. -+ * -+ * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -+ * Copyright (C) 2013 Google, Inc. -+ * -+ * 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; version 2 of the License. -+ * -+ * 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. -+ * -+ * You should have received a copy of the GNU General Public License -+ * along with this program; if not, write to the Free Software -+ * Foundation, Inc. -+ */ -+#include <stdint.h> -+#include <arch/cpu.h> -+#include <cpu/x86/msr.h> -+#include <timer.h> -+#include <device/pci.h> -+#include <device/pci_ids.h> -+ -+#include <northbridge/amd/amdht/AsPsDefs.h> -+#include <cpu/amd/model_10xxx_msr.h> -+ -+static struct monotonic_counter { -+ int initialized; -+ uint32_t core_frequency; -+ struct mono_time time; -+ uint64_t last_value; -+} mono_counter; -+ -+static inline uint64_t read_counter_msr(void) -+{ -+ msr_t counter_msr; -+ -+ counter_msr = rdmsr(TSC_MSR); -+ -+ return ((uint64_t)counter_msr.hi << 32) | (uint64_t)counter_msr.lo; -+} -+ -+static void init_timer(void) -+{ -+ uint8_t model; -+ uint32_t cpuid_fms; -+ uint8_t cpufid; -+ uint8_t cpudid; -+ uint8_t boost_capable = 0; -+ -+ /* Get CPU model */ -+ cpuid_fms = cpuid_eax(0x80000001); -+ model = ((cpuid_fms & 0xf0000) >> 16) | ((cpuid_fms & 0xf0) >> 4); -+ -+ /* Get boost capability */ -+ if ((model == 0x8) || (model == 0x9)) { /* revision D */ -+ boost_capable = (pci_read_config32(dev_find_slot(0, PCI_DEVFN(0x18, 4)), 0x15c) & 0x4) >> 2; -+ } -+ -+ /* Set up TSC (BKDG v3.62 section 2.9.4)*/ -+ msr_t msr = rdmsr(HWCR_MSR); -+ msr.lo |= 0x1000000; -+ wrmsr(HWCR_MSR, msr); -+ -+ /* Get core Pstate 0 frequency in MHz */ -+ msr = rdmsr(0xC0010064 + boost_capable); -+ cpufid = (msr.lo & 0x3f); -+ cpudid = (msr.lo & 0x1c0) >> 6; -+ mono_counter.core_frequency = (100 * (cpufid + 0x10)) / (0x01 << cpudid); -+ -+ mono_counter.last_value = read_counter_msr(); -+ mono_counter.initialized = 1; -+} -+ -+void timer_monotonic_get(struct mono_time *mt) -+{ -+ uint64_t current_tick; -+ uint32_t usecs_elapsed = 0; -+ -+ if (!mono_counter.initialized) -+ init_timer(); -+ -+ current_tick = read_counter_msr(); -+ if (mono_counter.core_frequency != 0) -+ usecs_elapsed = (current_tick - mono_counter.last_value) / mono_counter.core_frequency; -+ -+ /* Update current time and tick values only if a full tick occurred. */ -+ if (usecs_elapsed) { -+ mono_time_add_usecs(&mono_counter.time, usecs_elapsed); -+ mono_counter.last_value = current_tick; -+ } -+ -+ /* Save result. */ -+ *mt = mono_counter.time; -+} -diff --git a/src/cpu/amd/family_10h-family_15h/powernow_acpi.c b/src/cpu/amd/family_10h-family_15h/powernow_acpi.c -new file mode 100644 -index 0000000..98ef08a ---- /dev/null -+++ b/src/cpu/amd/family_10h-family_15h/powernow_acpi.c -@@ -0,0 +1,311 @@ -+/* -+ * This file is part of the coreboot project. -+ * -+ * Copyright (C) 2007-2008 Advanced Micro Devices, Inc. -+ * Copyright (C) 2009 Rudolf Marek <r.marek@assembler.cz> -+ * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -+ * -+ * 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; version 2 of the License. -+ * -+ * 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. -+ * -+ * You should have received a copy of the GNU General Public License -+ * along with this program; if not, write to the Free Software -+ * Foundation, Inc. -+ */ -+ -+#include <console/console.h> -+#include <stdint.h> -+#include <cpu/x86/msr.h> -+#include <arch/acpigen.h> -+#include <cpu/amd/powernow.h> -+#include <device/pci.h> -+#include <device/pci_ids.h> -+#include <cpu/x86/msr.h> -+#include <cpu/amd/mtrr.h> -+#include <cpu/amd/amdfam10_sysconf.h> -+#include <arch/cpu.h> -+#include <northbridge/amd/amdht/AsPsDefs.h> -+#include <northbridge/amd/amdmct/mct/mct.h> -+#include <northbridge/amd/amdmct/amddefs.h> -+ -+static void write_pstates_for_core(u8 pstate_num, u16 *pstate_feq, u32 *pstate_power, -+ u32 *pstate_latency, u32 *pstate_control, -+ u32 *pstate_status, int coreID, -+ u32 pcontrol_blk, u8 plen, u8 onlyBSP, -+ uint8_t single_link) -+{ -+ int i; -+ struct cpuid_result cpuid1; -+ -+ if ((onlyBSP) && (coreID != 0)) { -+ plen = 0; -+ pcontrol_blk = 0; -+ } -+ -+ acpigen_write_processor(coreID, pcontrol_blk, plen); -+ acpigen_write_empty_PCT(); -+ acpigen_write_name("_PSS"); -+ -+ /* add later to total sum */ -+ acpigen_write_package(pstate_num); -+ -+ for (i = 0;i < pstate_num; i++) -+ acpigen_write_PSS_package(pstate_feq[i], -+ pstate_power[i], -+ pstate_latency[i], -+ pstate_latency[i], -+ pstate_control[i], -+ pstate_status[i]); -+ -+ /* update the package size */ -+ acpigen_pop_len(); -+ -+ /* Write PPC object */ -+ acpigen_write_PPC(pstate_num); -+ -+ /* Write PSD indicating coordination type */ -+ if ((single_link) && (mctGetLogicalCPUID(0) & AMD_DR_GT_Bx)) { -+ /* Revision C or greater single-link processor */ -+ cpuid1 = cpuid(0x80000008); -+ acpigen_write_PSD_package(0, (cpuid1.ecx & 0xff) + 1, SW_ALL); -+ } -+ else { -+ /* Find the local APIC ID for the specified core ID */ -+ struct device* cpu; -+ int cpu_index = 0; -+ for (cpu = all_devices; cpu; cpu = cpu->next) { -+ if ((cpu->path.type != DEVICE_PATH_APIC) || -+ (cpu->bus->dev->path.type != DEVICE_PATH_CPU_CLUSTER)) -+ continue; -+ if (!cpu->enabled) -+ continue; -+ if (cpu_index == coreID) -+ break; -+ cpu_index++; -+ } -+ -+ if (cpu) -+ acpigen_write_PSD_package(cpu->path.apic.apic_id, 1, SW_ANY); -+ } -+ -+ /* patch the whole Processor token length */ -+ acpigen_pop_len(); -+} -+ -+/* -+* For details of this algorithm, please refer to the BDKG 3.62 page 69 -+* -+* WARNING: The core count algorithm below assumes that all processors -+* are identical, with the same number of active cores. While the BKDG -+* states the BIOS must enforce this coreboot does not currently do so. -+* As a result it is possible that this code may break if an illegal -+* processor combination is installed. If it does break please fix the -+* code in the proper locations! -+*/ -+void amd_generate_powernow(u32 pcontrol_blk, u8 plen, u8 onlyBSP) -+{ -+ u8 processor_brand[49]; -+ u32 *v; -+ struct cpuid_result cpuid1; -+ -+ u16 Pstate_feq[10]; -+ u32 Pstate_power[10]; -+ u32 Pstate_latency[10]; -+ u32 Pstate_control[10]; -+ u32 Pstate_status[10]; -+ u8 Pstate_num; -+ u8 cmp_cap; -+ u8 index; -+ msr_t msr; -+ -+ /* Get the Processor Brand String using cpuid(0x8000000x) command x=2,3,4 */ -+ cpuid1 = cpuid(0x80000002); -+ v = (u32 *) processor_brand; -+ v[0] = cpuid1.eax; -+ v[1] = cpuid1.ebx; -+ v[2] = cpuid1.ecx; -+ v[3] = cpuid1.edx; -+ cpuid1 = cpuid(0x80000003); -+ v[4] = cpuid1.eax; -+ v[5] = cpuid1.ebx; -+ v[6] = cpuid1.ecx; -+ v[7] = cpuid1.edx; -+ cpuid1 = cpuid(0x80000004); -+ v[8] = cpuid1.eax; -+ v[9] = cpuid1.ebx; -+ v[10] = cpuid1.ecx; -+ v[11] = cpuid1.edx; -+ processor_brand[48] = 0; -+ printk(BIOS_INFO, "processor_brand=%s\n", processor_brand); -+ -+ uint32_t dtemp; -+ uint8_t node_index; -+ uint8_t node_count; -+ uint8_t cores_per_node; -+ uint8_t total_core_count; -+ -+ /* -+ * Based on the CPU socket type,cmp_cap and pwr_lmt , get the power limit. -+ * socket_type : 0x10 SocketF; 0x11 AM2/ASB1 ; 0x12 S1G1 -+ * cmp_cap : 0x0 SingleCore ; 0x1 DualCore ; 0x2 TripleCore ; 0x3 QuadCore ; 0x4 QuintupleCore ; 0x5 HexCore -+ */ -+ printk(BIOS_INFO, "Pstates algorithm ...\n"); -+ /* Get number of cores */ -+ dtemp = pci_read_config32(dev_find_slot(0, PCI_DEVFN(0x18, 3)), 0xE8); -+ cmp_cap = (dtemp & 0x3000) >> 12; -+ if (mctGetLogicalCPUID(0) & AMD_FAM10_REV_D) /* revision D */ -+ cmp_cap |= (dtemp & 0x8000) >> 13; -+ /* Get number of nodes */ -+ dtemp = pci_read_config32(dev_find_slot(0, PCI_DEVFN(0x18, 0)), 0x60); -+ node_count = ((dtemp & 0x70) >> 4) + 1; -+ cores_per_node = cmp_cap + 1; -+ -+ /* Compute total number of cores installed in system */ -+ total_core_count = cores_per_node * node_count; -+ -+ Pstate_num = 0; -+ -+ /* See if the CPUID(0x80000007) returned EDX[7]==1b */ -+ cpuid1 = cpuid(0x80000007); -+ if ((cpuid1.edx & 0x80) != 0x80) { -+ printk(BIOS_INFO, "No valid set of P-states\n"); -+ return; -+ } -+ -+ uint8_t pviModeFlag; -+ uint8_t Pstate_max; -+ uint8_t cpufid; -+ uint8_t cpudid; -+ uint8_t cpuvid; -+ uint8_t cpuidd; -+ uint8_t cpuidv; -+ uint8_t power_step_up; -+ uint8_t power_step_down; -+ uint8_t pll_lock_time; -+ uint32_t expanded_cpuidv; -+ uint32_t core_frequency; -+ uint32_t core_power; -+ uint32_t core_latency; -+ uint32_t core_voltage; /* multiplied by 10000 */ -+ uint8_t single_link; -+ -+ /* Determine if this is a PVI or SVI system */ -+ dtemp = pci_read_config32(dev_find_slot(0, PCI_DEVFN(0x18, 3)), 0xA0); -+ -+ if (dtemp & PVI_MODE) -+ pviModeFlag = 1; -+ else -+ pviModeFlag = 0; -+ -+ /* Get PSmax's index */ -+ msr = rdmsr(0xC0010061); -+ Pstate_max = (uint8_t) ((msr.lo >> PS_MAX_VAL_SHFT) & BIT_MASK_3); -+ -+ /* Determine if all enabled Pstates have the same fidvid */ -+ uint8_t i; -+ uint8_t cpufid_prev = (rdmsr(0xC0010064).lo & 0x3f); -+ uint8_t all_enabled_cores_have_same_cpufid = 1; -+ for (i = 1; i < Pstate_max; i++) { -+ cpufid = rdmsr(0xC0010064 + i).lo & 0x3f; -+ if (cpufid != cpufid_prev) { -+ all_enabled_cores_have_same_cpufid = 0; -+ break; -+ } -+ } -+ -+ /* Populate tables with all Pstate information */ -+ for (Pstate_num = 0; Pstate_num < Pstate_max; Pstate_num++) { -+ /* Get power state information */ -+ msr = rdmsr(0xC0010064 + Pstate_num); -+ cpufid = (msr.lo & 0x3f); -+ cpudid = (msr.lo & 0x1c0) >> 6; -+ cpuvid = (msr.lo & 0xfe00) >> 9; -+ cpuidd = (msr.hi & 0xff); -+ cpuidv = (msr.hi & 0x300) >> 8; -+ core_frequency = (100 * (cpufid + 0x10)) / (0x01 << cpudid); -+ if (pviModeFlag) { -+ if (cpuvid >= 0x20) { -+ core_voltage = 7625 - (((cpuvid - 0x20) * 10000) / 80); -+ } -+ else { -+ core_voltage = 15500 - ((cpuvid * 10000) / 40); -+ } -+ } -+ else { -+ cpuvid = cpuvid & 0x7f; -+ if (cpuvid >= 0x7c) -+ core_voltage = 0; -+ else -+ core_voltage = 15500 - ((cpuvid * 10000) / 80); -+ } -+ switch (cpuidv) { -+ case 0x0: -+ expanded_cpuidv = 1; -+ break; -+ case 0x1: -+ expanded_cpuidv = 10; -+ break; -+ case 0x2: -+ expanded_cpuidv = 100; -+ break; -+ case 0x3: -+ expanded_cpuidv = 1000; -+ break; -+ default: -+ printk(BIOS_ERR, "%s:%s:%d: Invalid cpuidv, " -+ "not generating pstate tables.\n", -+ __FILE__, __func__, __LINE__); -+ return; -+ } -+ core_power = (core_voltage * cpuidd) / (expanded_cpuidv * 10); -+ -+ /* Calculate transition latency */ -+ dtemp = pci_read_config32(dev_find_slot(0, PCI_DEVFN(0x18, 3)), 0xD4); -+ power_step_up = (dtemp & 0xf000000) >> 24; -+ power_step_down = (dtemp & 0xf00000) >> 20; -+ dtemp = pci_read_config32(dev_find_slot(0, PCI_DEVFN(0x18, 3)), 0xA0); -+ pll_lock_time = (dtemp & 0x3800) >> 11; -+ if (all_enabled_cores_have_same_cpufid) -+ core_latency = ((12 * power_step_down) + power_step_up) / 1000; -+ else -+ core_latency = (12 * (power_step_down + power_step_up) / 1000) -+ + pll_lock_time; -+ -+ Pstate_feq[Pstate_num] = core_frequency; -+ Pstate_power[Pstate_num] = core_power; -+ Pstate_latency[Pstate_num] = core_latency; -+ Pstate_control[Pstate_num] = Pstate_num; -+ Pstate_status[Pstate_num] = Pstate_num; -+ } -+ -+ /* Print Pstate frequency, power, and latency */ -+ for (index = 0; index < Pstate_num; index++) { -+ printk(BIOS_INFO, "Pstate_freq[%d] = %dMHz\t", index, -+ Pstate_feq[index]); -+ printk(BIOS_INFO, "Pstate_power[%d] = %dmw\n", index, -+ Pstate_power[index]); -+ printk(BIOS_INFO, "Pstate_latency[%d] = %dus\n", index, -+ Pstate_latency[index]); -+ } -+ -+ char pscope[] = "\\_PR"; -+ -+ acpigen_write_scope(pscope); -+ for (index = 0; index < total_core_count; index++) { -+ /* Determine if this is a single-link processor */ -+ node_index = 0x18 + (index / cores_per_node); -+ dtemp = pci_read_config32(dev_find_slot(0, PCI_DEVFN(node_index, 0)), 0x80); -+ single_link = !!(((dtemp & 0xff00) >> 8) == 0); -+ -+ write_pstates_for_core(Pstate_num, Pstate_feq, Pstate_power, -+ Pstate_latency, Pstate_control, Pstate_status, -+ index, pcontrol_blk, plen, onlyBSP, single_link); -+ } -+ acpigen_pop_len(); -+} -diff --git a/src/cpu/amd/family_10h-family_15h/processor_name.c b/src/cpu/amd/family_10h-family_15h/processor_name.c -new file mode 100644 -index 0000000..12c45c9 ---- /dev/null -+++ b/src/cpu/amd/family_10h-family_15h/processor_name.c -@@ -0,0 +1,323 @@ -+/* -+ * This file is part of the coreboot project. -+ * -+ * Copyright (C) 2007 Advanced Micro Devices, Inc. -+ * Copyright (C) 2008 Peter Stuge -+ * Copyright (C) 2010 Marc Jones <marcj303@gmail.com> -+ * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -+ * -+ * 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; version 2 of the License. -+ * -+ * 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. -+ * -+ * You should have received a copy of the GNU General Public License -+ * along with this program; if not, write to the Free Software -+ * Foundation, Inc. -+ */ -+ -+/* -+ * This code sets the Processor Name String for AMD64 CPUs. -+ * -+ * Revision Guide for AMD Family 10h Processors -+ * Publication # 41322 Revision: 3.17 Issue Date: February 2008 -+ */ -+ -+#include <console/console.h> -+#include <string.h> -+#include <cpu/x86/msr.h> -+#include <cpu/amd/mtrr.h> -+#include <cpu/cpu.h> -+#include <cpu/amd/model_10xxx_rev.h> -+ -+/* The maximum length of CPU names is 48 bytes, including the final NULL byte. -+ * If you change these names your BIOS will _NOT_ pass the AMD validation and -+ * your mainboard will not be posted on the AMD Recommended Motherboard Website -+ */ -+ -+struct str_s { -+ u8 Pg; -+ u8 NC; -+ u8 String; -+ char const *value; -+}; -+ -+ -+static const struct str_s String1_socket_F[] = { -+ {0x00, 0x01, 0x00, "Dual-Core AMD Opteron(tm) Processor 83"}, -+ {0x00, 0x01, 0x01, "Dual-Core AMD Opteron(tm) Processor 23"}, -+ {0x00, 0x03, 0x00, "Quad-Core AMD Opteron(tm) Processor 83"}, -+ {0x00, 0x03, 0x01, "Quad-Core AMD Opteron(tm) Processor 23"}, -+ {0x00, 0x05, 0x00, "Six-Core AMD Opteron(tm) Processor 84"}, -+ {0x00, 0x05, 0x01, "Six-Core AMD Opteron(tm) Processor 24"}, -+ {0x00, 0x03, 0x02, "Embedded AMD Opteron(tm) Processor 83"}, -+ {0x00, 0x03, 0x03, "Embedded AMD Opteron(tm) Processor 23"}, -+ {0x00, 0x03, 0x04, "Embedded AMD Opteron(tm) Processor 13"}, -+ {0x00, 0x03, 0x05, "AMD Phenom(tm) FX-"}, -+ {0x01, 0x01, 0x01, "Embedded AMD Opteron(tm) Processor"}, -+ {0, 0, 0, NULL} -+}; -+ -+static const struct str_s String2_socket_F[] = { -+ {0x00, 0xFF, 0x02, " EE"}, -+ {0x00, 0xFF, 0x0A, " SE"}, -+ {0x00, 0xFF, 0x0B, " HE"}, -+ {0x00, 0xFF, 0x0C, " EE"}, -+ {0x00, 0xFF, 0x0D, " Quad-Core Processor"}, -+ {0x00, 0xFF, 0x0F, ""}, -+ {0x01, 0x01, 0x01, "GF HE"}, -+ {0, 0, 0, NULL} -+}; -+ -+ -+static const struct str_s String1_socket_AM2[] = { -+ {0x00, 0x00, 0x00, "AMD Athlon(tm) Processor LE-"}, -+ {0x00, 0x00, 0x01, "AMD Sempron(tm) Processor LE-"}, -+ {0x00, 0x00, 0x02, "AMD Sempron(tm) 1"}, -+ {0x00, 0x00, 0x03, "AMD Athlon(tm) II 1"}, -+ {0x00, 0x01, 0x00, "Dual-Core AMD Opteron(tm) Processor 13"}, -+ {0x00, 0x01, 0x01, "AMD Athlon(tm)"}, -+ {0x00, 0x01, 0x03, "AMD Athlon(tm) II X2 2"}, -+ {0x00, 0x01, 0x04, "AMD Athlon(tm) II X2 B"}, -+ {0x00, 0x01, 0x05, "AMD Athlon(tm) II X2"}, -+ {0x00, 0x01, 0x07, "AMD Phenom(tm) II X2 5"}, -+ {0x00, 0x01, 0x0A, "AMD Phenom(tm) II X2"}, -+ {0x00, 0x01, 0x0B, "AMD Phenom(tm) II X2 B"}, -+ {0x00, 0x02, 0x00, "AMD Phenom(tm)"}, -+ {0x00, 0x02, 0x03, "AMD Phenom(tm) II X3 B"}, -+ {0x00, 0x02, 0x04, "AMD Phenom(tm) II X3"}, -+ {0x00, 0x02, 0x07, "AMD Athlon(tm) II X3 4"}, -+ {0x00, 0x02, 0x08, "AMD Phenom(tm) II X3 7"}, -+ {0x00, 0x02, 0x0A, "AMD Athlon(tm) II X3"}, -+ {0x00, 0x03, 0x00, "Quad-Core AMD Opteron(tm) Processor 13"}, -+ {0x00, 0x03, 0x01, "AMD Phenom(tm) FX-"}, -+ {0x00, 0x03, 0x02, "AMD Phenom(tm)"}, -+ {0x00, 0x03, 0x03, "AMD Phenom(tm) II X4 9"}, -+ {0x00, 0x03, 0x04, "AMD Phenom(tm) II X4 8"}, -+ {0x00, 0x03, 0x07, "AMD Phenom(tm) II X4 B"}, -+ {0x00, 0x03, 0x08, "AMD Phenom(tm) II X4"}, -+ {0x00, 0x03, 0x0A, "AMD Athlon(tm) II X4 6"}, -+ {0x00, 0x03, 0x0F, "AMD Athlon(tm) II X4"}, -+ {0, 0, 0, NULL} -+}; -+ -+static const struct str_s String2_socket_AM2[] = { -+ {0x00, 0x00, 0x00, "00"}, -+ {0x00, 0x00, 0x01, "10"}, -+ {0x00, 0x00, 0x02, "20"}, -+ {0x00, 0x00, 0x03, "30"}, -+ {0x00, 0x00, 0x04, "40"}, -+ {0x00, 0x00, 0x05, "50"}, -+ {0x00, 0x00, 0x06, "60"}, -+ {0x00, 0x00, 0x07, "70"}, -+ {0x00, 0x00, 0x08, "80"}, -+ {0x00, 0x00, 0x09, "90"}, -+ {0x00, 0x00, 0x09, " Processor"}, -+ {0x00, 0x00, 0x09, "u Processor"}, -+ {0x00, 0x01, 0x00, "00 Dual-Core Processor"}, -+ {0x00, 0x01, 0x01, "00e Dual-Core Processor"}, -+ {0x00, 0x01, 0x02, "00B Dual-Core Processor"}, -+ {0x00, 0x01, 0x03, "50 Dual-Core Processor"}, -+ {0x00, 0x01, 0x04, "50e Dual-Core Processor"}, -+ {0x00, 0x01, 0x05, "50B Dual-Core Processor"}, -+ {0x00, 0x01, 0x06, " Processor"}, -+ {0x00, 0x01, 0x07, "e Processor"}, -+ {0x00, 0x01, 0x09, "0 Processor"}, -+ {0x00, 0x01, 0x0A, "0e Processor"}, -+ {0x00, 0x01, 0x0B, "u Processor"}, -+ {0x00, 0x02, 0x00, "00 Triple-Core Processor"}, -+ {0x00, 0x02, 0x01, "00e Triple-Core Processor"}, -+ {0x00, 0x02, 0x02, "00B Triple-Core Processor"}, -+ {0x00, 0x02, 0x03, "50 Triple-Core Processor"}, -+ {0x00, 0x02, 0x04, "50e Triple-Core Processor"}, -+ {0x00, 0x02, 0x05, "50B Triple-Core Processor"}, -+ {0x00, 0x02, 0x06, " Processor"}, -+ {0x00, 0x02, 0x07, "e Processor"}, -+ {0x00, 0x02, 0x09, "0e Processor"}, -+ {0x00, 0x02, 0x0A, "0 Processor"}, -+ {0x00, 0x03, 0x00, "00 Quad-Core Processor"}, -+ {0x00, 0x03, 0x01, "00e Quad-Core Processor"}, -+ {0x00, 0x03, 0x02, "00B Quad-Core Processor"}, -+ {0x00, 0x03, 0x03, "50 Quad-Core Processor"}, -+ {0x00, 0x03, 0x04, "50e Quad-Core Processor"}, -+ {0x00, 0x03, 0x05, "50B Quad-Core Processor"}, -+ {0x00, 0x03, 0x06, " Processor"}, -+ {0x00, 0x03, 0x07, "e Processor"}, -+ {0x00, 0x03, 0x09, "0e Processor"}, -+ {0x00, 0x03, 0x0A, " SE"}, -+ {0x00, 0x03, 0x0B, " HE"}, -+ {0x00, 0x03, 0x0C, " EE"}, -+ {0x00, 0x03, 0x0D, " Quad-Core Processor"}, -+ {0x00, 0x03, 0x0E, "0 Processor"}, -+ {0x00, 0xFF, 0x0F, ""}, -+ {0, 0, 0, NULL} -+}; -+ -+static const struct str_s String1_socket_G34[] = { -+ {0x00, 0x07, 0x00, "AMD Opteron(tm) Processor 61"}, -+ {0x00, 0x0B, 0x00, "AMD Opteron(tm) Processor 61"}, -+ {0x01, 0x07, 0x01, "Embedded AMD Opteron(tm) Processor "}, -+ {0, 0, 0, NULL} -+}; -+ -+static const struct str_s String2_socket_G34[] = { -+ {0x00, 0x07, 0x00, " HE"}, -+ {0x00, 0x07, 0x01, " SE"}, -+ {0x00, 0x0B, 0x00, " HE"}, -+ {0x00, 0x0B, 0x01, " SE"}, -+ {0x00, 0x0B, 0x0F, ""}, -+ {0x01, 0x07, 0x01, " QS"}, -+ {0x01, 0x07, 0x02, " KS"}, -+ {0, 0, 0, NULL} -+}; -+ -+static const struct str_s String1_socket_C32[] = { -+ {0x00, 0x03, 0x00, "AMD Opteron(tm) Processor 41"}, -+ {0x00, 0x05, 0x00, "AMD Opteron(tm) Processor 41"}, -+ {0x01, 0x03, 0x01, "Embedded AMD Opteron(tm) Processor "}, -+ {0x01, 0x05, 0x01, "Embedded AMD Opteron(tm) Processor "}, -+ {0, 0, 0, NULL} -+}; -+ -+static const struct str_s String2_socket_C32[] = { -+ {0x00, 0x03, 0x00, " HE"}, -+ {0x00, 0x03, 0x01, " EE"}, -+ {0x00, 0x05, 0x00, " HE"}, -+ {0x00, 0x05, 0x01, " EE"}, -+ {0x01, 0x03, 0x01, "QS HE"}, -+ {0x01, 0x03, 0x02, "LE HE"}, -+ {0x01, 0x05, 0x01, "KX HE"}, -+ {0x01, 0x05, 0x02, "GL EE"}, -+ {0, 0, 0, NULL} -+}; -+ -+const char *unknown = "AMD Processor model unknown"; -+const char *unknown2 = " type unknown"; -+const char *sample = "AMD Engineering Sample"; -+const char *thermal = "AMD Thermal Test Kit"; -+ -+ -+static int strcpymax(char *dst, const char *src, int buflen) -+{ -+ int i; -+ for (i = 0; i < buflen && src[i]; i++) -+ dst[i] = src[i]; -+ if (i >= buflen) -+ i--; -+ dst[i] = 0; -+ return i; -+} -+ -+ -+int init_processor_name(void) -+{ -+ /* variable names taken from fam10 revision guide for clarity */ -+ u32 BrandId; /* CPUID Fn8000_0001_EBX */ -+ u8 String1; /* BrandID[14:11] */ -+ u8 String2; /* BrandID[3:0] */ -+ u8 Model; /* BrandID[10:4] */ -+ u8 Pg; /* BrandID[15] */ -+ u8 PkgTyp; /* BrandID[31:28] */ -+ u8 NC; /* CPUID Fn8000_0008_ECX */ -+ const char *processor_name_string = unknown; -+ char program_string[48]; -+ u32 *p_program_string = (u32 *)program_string; -+ msr_t msr; -+ int i, j = 0, str2_checkNC = 1; -+ const struct str_s *str, *str2; -+ -+ -+ /* Find out which CPU brand it is */ -+ BrandId = cpuid_ebx(0x80000001); -+ String1 = (u8)((BrandId >> 11) & 0x0F); -+ String2 = (u8)((BrandId >> 0) & 0x0F); -+ Model = (u8)((BrandId >> 4) & 0x7F); -+ Pg = (u8)((BrandId >> 15) & 0x01); -+ PkgTyp = (u8)((BrandId >> 28) & 0x0F); -+ NC = (u8)(cpuid_ecx(0x80000008) & 0xFF); -+ -+ /* null the string */ -+ memset(program_string, 0, sizeof(program_string)); -+ -+ if (!Model) { -+ processor_name_string = Pg ? thermal : sample; -+ goto done; -+ } -+ -+ switch (PkgTyp) { -+ case 0: /* F1207 */ -+ str = String1_socket_F; -+ str2 = String2_socket_F; -+ str2_checkNC = 0; -+ break; -+ case 1: /* AM2 */ -+ str = String1_socket_AM2; -+ str2 = String2_socket_AM2; -+ break; -+ case 3: /* G34 */ -+ str = String1_socket_G34; -+ str2 = String2_socket_G34; -+ str2_checkNC = 0; -+ break; -+ case 5: /* C32 */ -+ str = String1_socket_C32; -+ str2 = String2_socket_C32; -+ break; -+ default: -+ goto done; -+ } -+ -+ /* String1 */ -+ for (i = 0; str[i].value; i++) { -+ if ((str[i].Pg == Pg) && -+ (str[i].NC == NC) && -+ (str[i].String == String1)) { -+ processor_name_string = str[i].value; -+ break; -+ } -+ } -+ -+ if (!str[i].value) -+ goto done; -+ -+ j = strcpymax(program_string, processor_name_string, -+ sizeof(program_string)); -+ -+ /* Translate Model from 01-99 to ASCII and put it on the end. -+ * Numbers less than 10 should include a leading zero, e.g., 09.*/ -+ if (Model < 100 && j < sizeof(program_string) - 2) { -+ program_string[j++] = (Model / 10) + '0'; -+ program_string[j++] = (Model % 10) + '0'; -+ } -+ -+ processor_name_string = unknown2; -+ -+ /* String 2 */ -+ for(i = 0; str2[i].value; i++) { -+ if ((str2[i].Pg == Pg) && -+ ((str2[i].NC == NC) || !str2_checkNC) && -+ (str2[i].String == String2)) { -+ processor_name_string = str2[i].value; -+ break; -+ } -+ } -+ -+ -+done: -+ strcpymax(&program_string[j], processor_name_string, -+ sizeof(program_string) - j); -+ -+ printk(BIOS_DEBUG, "CPU model: %s\n", program_string); -+ -+ for (i = 0; i < 6; i++) { -+ msr.lo = p_program_string[(2 * i) + 0]; -+ msr.hi = p_program_string[(2 * i) + 1]; -+ wrmsr_amd(0xC0010030 + i, msr); -+ } -+ -+ return 0; -+} -diff --git a/src/cpu/amd/family_10h-family_15h/ram_calc.c b/src/cpu/amd/family_10h-family_15h/ram_calc.c -new file mode 100644 -index 0000000..46ccdbd ---- /dev/null -+++ b/src/cpu/amd/family_10h-family_15h/ram_calc.c -@@ -0,0 +1,54 @@ -+/* -+ * This file is part of the coreboot project. -+ * -+ * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -+ * Copyright (C) 2007 Advanced Micro Devices, Inc. -+ * -+ * 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; version 2 of the License. -+ * -+ * 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. -+ * -+ * You should have received a copy of the GNU General Public License -+ * along with this program; if not, write to the Free Software -+ * Foundation, Inc. -+ */ -+ -+#include <cpu/cpu.h> -+#include <cpu/x86/msr.h> -+#include <cpu/amd/mtrr.h> -+ -+#include <cbmem.h> -+ -+#include "ram_calc.h" -+ -+#if !IS_ENABLED(CONFIG_LATE_CBMEM_INIT) -+uint64_t get_uma_memory_size(uint64_t topmem) -+{ -+ uint64_t uma_size = 0; -+ if (IS_ENABLED(CONFIG_GFXUMA)) { -+ /* refer to UMA Size Consideration in 780 BDG. */ -+ if (topmem >= 0x40000000) /* 1GB and above system memory */ -+ uma_size = 0x10000000; /* 256M recommended UMA */ -+ -+ else if (topmem >= 0x20000000) /* 512M - 1023M system memory */ -+ uma_size = 0x8000000; /* 128M recommended UMA */ -+ -+ else if (topmem >= 0x10000000) /* 256M - 511M system memory */ -+ uma_size = 0x4000000; /* 64M recommended UMA */ -+ } -+ -+ return uma_size; -+} -+ -+void *cbmem_top(void) -+{ -+ uint32_t topmem = rdmsr(TOP_MEM).lo; -+ -+ return (void *) topmem - get_uma_memory_size(topmem); -+} -+#endif -diff --git a/src/cpu/amd/family_10h-family_15h/ram_calc.h b/src/cpu/amd/family_10h-family_15h/ram_calc.h -new file mode 100644 -index 0000000..61da328 ---- /dev/null -+++ b/src/cpu/amd/family_10h-family_15h/ram_calc.h -@@ -0,0 +1,25 @@ -+/* -+ * This file is part of the coreboot project. -+ * -+ * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -+ * -+ * 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; version 2 of the License. -+ * -+ * 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. -+ * -+ * You should have received a copy of the GNU General Public License -+ * along with this program; if not, write to the Free Software -+ * Foundation, Inc. -+ */ -+ -+#ifndef _AMD_MODEL_10XXX_RAM_CALC_H_ -+#define _AMD_MODEL_10XXX_RAM_CALC_H_ -+ -+uint64_t get_uma_memory_size(uint64_t topmem); -+ -+#endif -diff --git a/src/cpu/amd/family_10h-family_15h/update_microcode.c b/src/cpu/amd/family_10h-family_15h/update_microcode.c -new file mode 100644 -index 0000000..51aca35 ---- /dev/null -+++ b/src/cpu/amd/family_10h-family_15h/update_microcode.c -@@ -0,0 +1,71 @@ -+/* -+ * This file is part of the coreboot project. -+ * -+ * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -+ * Copyright (C) 2007 Advanced Micro Devices, Inc. -+ * -+ * 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; version 2 of the License. -+ * -+ * 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. -+ * -+ * You should have received a copy of the GNU General Public License -+ * along with this program; if not, write to the Free Software -+ * Foundation, Inc. -+ */ -+ -+#include <stdint.h> -+#include <cpu/amd/microcode.h> -+ -+struct id_mapping { -+ uint32_t orig_id; -+ uint16_t new_id; -+}; -+ -+static u16 get_equivalent_processor_rev_id(u32 orig_id) { -+ static const struct id_mapping id_mapping_table[] = { -+ { 0x100f00, 0x1000 }, -+ { 0x100f01, 0x1000 }, -+ { 0x100f02, 0x1000 }, -+ { 0x100f20, 0x1020 }, -+ { 0x100f21, 0x1020 }, /* DR-B1 */ -+ { 0x100f2A, 0x1020 }, /* DR-BA */ -+ { 0x100f22, 0x1022 }, /* DR-B2 */ -+ { 0x100f23, 0x1022 }, /* DR-B3 */ -+ { 0x100f42, 0x1041 }, /* RB-C2 */ -+ { 0x100f43, 0x1043 }, /* RB-C3 */ -+ { 0x100f52, 0x1041 }, /* BL-C2 */ -+ { 0x100f62, 0x1062 }, /* DA-C2 */ -+ { 0x100f63, 0x1043 }, /* DA-C3 */ -+ { 0x100f81, 0x1081 }, /* HY-D1 */ -+ { 0x100fa0, 0x10A0 }, /* PH-E0 */ -+ -+ /* Array terminator */ -+ { 0xffffff, 0x0000 }, -+ }; -+ -+ u32 new_id; -+ int i; -+ -+ new_id = 0; -+ -+ for (i = 0; id_mapping_table[i].orig_id != 0xffffff; i++) { -+ if (id_mapping_table[i].orig_id == orig_id) { -+ new_id = id_mapping_table[i].new_id; -+ break; -+ } -+ } -+ -+ return new_id; -+ -+} -+ -+void update_microcode(u32 cpu_deviceid) -+{ -+ u32 equivalent_processor_rev_id = get_equivalent_processor_rev_id(cpu_deviceid); -+ amd_update_microcode_from_cbfs(equivalent_processor_rev_id); -+} -diff --git a/src/cpu/amd/model_10xxx/Kconfig b/src/cpu/amd/model_10xxx/Kconfig -deleted file mode 100644 -index 7c47e27..0000000 ---- a/src/cpu/amd/model_10xxx/Kconfig -+++ /dev/null -@@ -1,88 +0,0 @@ --config CPU_AMD_MODEL_10XXX -- bool -- select ARCH_BOOTBLOCK_X86_32 -- select ARCH_VERSTAGE_X86_32 -- select ARCH_ROMSTAGE_X86_32 -- select ARCH_RAMSTAGE_X86_32 -- select SSE -- select SSE2 -- select MMCONF_SUPPORT_DEFAULT -- select TSC_SYNC_LFENCE -- select UDELAY_LAPIC -- select HAVE_MONOTONIC_TIMER -- select SUPPORT_CPU_UCODE_IN_CBFS -- select CPU_MICROCODE_MULTIPLE_FILES -- --if CPU_AMD_MODEL_10XXX -- --config NUM_IPI_STARTS -- int -- default 1 -- --config CPU_ADDR_BITS -- int -- default 48 -- --config DCACHE_RAM_BASE -- hex -- default 0xc4000 -- --config DCACHE_RAM_SIZE -- hex -- default 0x0c000 -- --config DCACHE_BSP_STACK_SIZE -- hex -- default 0x2000 -- --config DCACHE_BSP_STACK_SLUSH -- hex -- default 0x1000 -- --config DCACHE_AP_STACK_SIZE -- hex -- default 0x400 -- --config UDELAY_IO -- bool -- default n -- --config SET_FIDVID -- bool -- default y -- --config MAX_PHYSICAL_CPUS -- int -- default 1 -- --config LIFT_BSP_APIC_ID -- bool -- default n -- --if SET_FIDVID --config SET_FIDVID_DEBUG -- bool -- default y -- --config SET_FIDVID_STORE_AP_APICID_AT_FIRST -- bool -- default y -- --config SET_FIDVID_CORE0_ONLY -- bool -- default n -- --# 0: all cores --# 1: core 0 only --# 2: all but core 0 --config SET_FIDVID_CORE_RANGE -- int -- default 0 -- --endif # SET_FIDVID -- --config UDELAY_LAPIC_FIXED_FSB -- int -- default 200 -- --endif # CPU_AMD_MODEL_10XXX -diff --git a/src/cpu/amd/model_10xxx/Makefile.inc b/src/cpu/amd/model_10xxx/Makefile.inc -deleted file mode 100644 -index 5a81ab8..0000000 ---- a/src/cpu/amd/model_10xxx/Makefile.inc -+++ /dev/null -@@ -1,14 +0,0 @@ --romstage-y += ../../x86/mtrr/earlymtrr.c --ramstage-y += model_10xxx_init.c --ramstage-y += processor_name.c -- --romstage-y += update_microcode.c --romstage-y += ram_calc.c --ramstage-y += ram_calc.c --ramstage-y += monotonic_timer.c --ramstage-$(CONFIG_HAVE_ACPI_TABLES) += powernow_acpi.c -- --# Microcode for Family 10h, 11h, 12h, and 14h --cbfs-files-$(CONFIG_CPU_MICROCODE_MULTIPLE_FILES) += microcode_amd.bin --microcode_amd.bin-file := 3rdparty/blobs/cpu/amd/family_10h-family_14h/microcode_amd.bin --microcode_amd.bin-type := microcode -diff --git a/src/cpu/amd/model_10xxx/defaults.h b/src/cpu/amd/model_10xxx/defaults.h -deleted file mode 100644 -index 6fd1a7e..0000000 ---- a/src/cpu/amd/model_10xxx/defaults.h -+++ /dev/null -@@ -1,479 +0,0 @@ --/* -- * This file is part of the coreboot project. -- * -- * Copyright (C) 2008 Advanced Micro Devices, Inc. -- * -- * 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; version 2 of the License. -- * -- * 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. -- * -- * You should have received a copy of the GNU General Public License -- * along with this program; if not, write to the Free Software -- * Foundation, Inc. -- */ -- --#include <northbridge/amd/amdmct/amddefs.h> --#include <cpu/amd/mtrr.h> -- --/* -- * Default MSR and errata settings. -- */ --static const struct { -- u32 msr; -- u32 revision; -- u32 platform; -- u32 data_lo; -- u32 data_hi; -- u32 mask_lo; -- u32 mask_hi; --} fam10_msr_default[] = { -- { TOP_MEM2, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000000, 0x00000000, -- 0xFFFFFFFF, 0xFFFFFFFF }, -- -- { SYSCFG, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 3 << 21, 0x00000000, -- 3 << 21, 0x00000000 }, /* [MtrrTom2En]=1,[TOM2EnWB] = 1*/ -- -- { HWCR, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 1 << 4, 0x00000000, -- 1 << 4, 0x00000000 }, /* [INVD_WBINVD]=1 */ -- -- { MC4_CTL_MASK, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0xF << 19, 0x00000000, -- 0xF << 19, 0x00000000 }, /* [RtryHt[0..3]]=1 */ -- -- { DC_CFG, AMD_FAM10_ALL, AMD_PTYPE_SVR, -- 0x00000000, 0x00000004, -- 0x00000000, 0x0000000C }, /* [REQ_CTR] = 1 for Server */ -- -- { DC_CFG, AMD_DR_Bx, AMD_PTYPE_SVR, -- 0x00000000, 0x00000000, -- 0x00000000, 0x00000C00 }, /* Erratum 326 */ -- -- { NB_CFG, AMD_FAM10_ALL, AMD_PTYPE_DC | AMD_PTYPE_MC, -- 0x00000000, 1 << 22, -- 0x00000000, 1 << 22 }, /* [ApicInitIDLo]=1 */ -- -- { BU_CFG2, AMD_DR_Bx, AMD_PTYPE_ALL, -- 1 << 29, 0x00000000, -- 1 << 29, 0x00000000 }, /* For Bx Smash1GPages=1 */ -- -- { DC_CFG, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 1 << 24, 0x00000000, -- 1 << 24, 0x00000000 }, /* Erratum #261 [DIS_PIGGY_BACK_SCRUB]=1 */ -- -- { LS_CFG, AMD_DR_GT_B0, AMD_PTYPE_ALL, -- 0 << 1, 0x00000000, -- 1 << 1, 0x00000000 }, /* IDX_MATCH_ALL=0 */ -- -- { BU_CFG, AMD_DR_LT_B3, AMD_PTYPE_ALL, -- 1 << 21, 0x00000000, -- 1 << 21, 0x00000000 }, /* Erratum #254 DR B1 BU_CFG[21]=1 */ -- -- { BU_CFG, AMD_DR_LT_B3, AMD_PTYPE_ALL, -- 1 << 23, 0x00000000, -- 1 << 23, 0x00000000 }, /* Erratum #309 BU_CFG[23]=1 */ -- -- /* CPUID_EXT_FEATURES */ -- { CPUIDFEATURES, AMD_FAM10_ALL, AMD_PTYPE_DC | AMD_PTYPE_MC, -- 1 << 28, 0x00000000, -- 1 << 28, 0x00000000 }, /* [HyperThreadFeatEn]=1 */ -- -- { CPUIDFEATURES, AMD_FAM10_ALL, AMD_PTYPE_DC, -- 0x00000000, 1 << (33-32), -- 0x00000000, 1 << (33-32) }, /* [ExtendedFeatEn]=1 */ -- -- { BU_CFG2, AMD_DRBH_Cx, AMD_PTYPE_ALL, -- 0x00000000, 1 << (35-32), -- 0x00000000, 1 << (35-32) }, /* Erratum 343 (set to 0 after CAR, in post_cache_as_ram()/model_10xxx_init() ) */ -- -- { OSVW_ID_Length, AMD_DR_Bx | AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, -- 0x00000004, 0x00000000, -- 0x00000004, 0x00000000}, /* B0 or Above, OSVW_ID_Length is 0004h */ -- -- { OSVW_Status, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_MC, -- 0x0000000C, 0x00000000, -- 0x0000000C, 0x00000000}, /* Cx and Dx multiple-link processor */ -- -- { BU_CFG2, AMD_DR_Dx, AMD_PTYPE_ALL, -- 0x00000000, 1 << (50-32), -- 0x00000000, 1 << (50-32)}, /* D0 or Above, RdMmExtCfgQwEn*/ -- -- { CPU_ID_EXT_FEATURES_MSR, AMD_DR_Dx, AMD_PTYPE_ALL, -- 0x00000000, 1 << (51 - 32), -- 0x00000000, 1 << (51 - 32)}, /* G34_PKG | C32_PKG | S1G4_PKG | ASB2_PKG */ --}; -- -- --/* -- * Default PCI and errata settings. -- */ --static const struct { -- u8 function; -- u16 offset; -- u32 revision; -- u32 platform; -- u32 data; -- u32 mask; --} fam10_pci_default[] = { -- -- /* Function 0 - HT Config */ -- -- { 0, 0x68, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x004E4800, 0x006E6800 }, /* [19:17] for 8bit APIC config, -- [14:13] BufPriRel = 2h [11] RspPassPW set, -- [22:21] DsNpReqLmt = 10b */ -- -- /* Errata 281 Workaround */ -- { 0, 0x68, (AMD_DR_B0 | AMD_DR_B1), -- AMD_PTYPE_SVR, 0x00200000, 0x00600000 }, /* [22:21] DsNpReqLmt0 = 01b */ -- -- { 0, 0x84, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00002000, 0x00002000 }, /* [13] LdtStopTriEn = 1 */ -- -- { 0, 0xA4, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00002000, 0x00002000 }, /* [13] LdtStopTriEn = 1 */ -- -- { 0, 0xC4, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00002000, 0x00002000 }, /* [13] LdtStopTriEn = 1 */ -- -- { 0, 0xE4, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00002000, 0x00002000 }, /* [13] LdtStopTriEn = 1 */ -- -- /* Link Global Retry Control Register */ -- { 0, 0x150, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00073900, 0x00073F00 }, -- -- /* Errata 351 -- * System software should program the Link Extended Control Registers[LS2En] -- * (F0x[18C:170][8]) to 0b for all links. System software should also -- * program Link Global Extended Control Register[ForceFullT0] -- * (F0x16C[15:13]) to 000b */ -- -- { 0, 0x170, AMD_FAM10_ALL, AMD_PTYPE_ALL, /* Fix FAM10_ALL when fixed in rev guide */ -- 0x00000000, 0x00000100 }, -- { 0, 0x174, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000000, 0x00000100 }, -- { 0, 0x178, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000000, 0x00000100 }, -- { 0, 0x17C, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000000, 0x00000100 }, -- { 0, 0x180, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000000, 0x00000100 }, -- { 0, 0x184, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000000, 0x00000100 }, -- { 0, 0x188, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000000, 0x00000100 }, -- { 0, 0x18C, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000000, 0x00000100 }, -- { 0, 0x170, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000000, 0x00000100 }, -- -- /* Link Global Extended Control Register */ -- { 0, 0x16C, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000014, 0x0000003F }, /* [15:13] ForceFullT0 = 0b, -- * Set T0Time 14h per BKDG */ -- -- -- /* Function 1 - Map Init */ -- -- /* Before reading F1x114_x2 or F1x114_x3 software must -- * initialize the registers or NB Array MCA errors may -- * occur. BIOS should initialize index 0h of F1x114_x2 and -- * F1x114_x3 to prevent reads from F1x114 from generating NB -- * Array MCA errors. BKDG Doc #3116 Rev 1.07 -- */ -- -- { 1, 0x110, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x20000000, 0xFFFFFFFF }, /* Select extended MMIO Base */ -- -- { 1, 0x114, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000000, 0xFFFFFFFF }, /* Clear map */ -- -- { 1, 0x110, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x30000000, 0xFFFFFFFF }, /* Select extended MMIO Base */ -- -- { 1, 0x114, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000000, 0xFFFFFFFF }, /* Clear map */ -- -- /* Function 2 - DRAM Controller */ -- -- /* Function 3 - Misc. Control */ -- { 3, 0x40, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000100, 0x00000100 }, /* [8] MstrAbrtEn */ -- -- { 3, 0x44, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x4A30005C, 0x4A30005C }, /* [30] SyncOnDramAdrParErrEn = 1, -- [27] NbMcaToMstCpuEn = 1, -- [25] DisPciCfgCpuErrRsp = 1, -- [21] SyncOnAnyErrEn = 1, -- [20] SyncOnWDTEn = 1, -- [6] CpuErrDis = 1, -- [4] SyncPktPropDis = 1, -- [3] SyncPktGenDis = 1, -- [2] SyncOnUcEccEn = 1 */ -- -- /* XBAR buffer settings */ -- { 3, 0x6C, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00018052, 0x700780F7 }, -- -- /* Errata 281 Workaround */ -- { 3, 0x6C, ( AMD_DR_B0 | AMD_DR_B1), -- AMD_PTYPE_SVR, 0x00010094, 0x700780F7 }, -- -- { 3, 0x6C, AMD_FAM10_ALL, AMD_PTYPE_UMA, -- 0x60018051, 0x700780F7 }, -- -- { 3, 0x70, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00041153, 0x777777F7 }, -- -- { 3, 0x70, AMD_FAM10_ALL, AMD_PTYPE_UMA, -- 0x61221151, 0x777777F7 }, -- -- { 3, 0x74, AMD_FAM10_ALL, AMD_PTYPE_UMA, -- 0x00080101, 0x000F7777 }, -- -- { 3, 0x7C, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00090914, 0x707FFF1F }, -- -- /* Errata 281 Workaround */ -- { 3, 0x7C, ( AMD_DR_B0 | AMD_DR_B1), -- AMD_PTYPE_SVR, 0x00144514, 0x707FFF1F }, -- -- { 3, 0x7C, AMD_FAM10_ALL, AMD_PTYPE_UMA, -- 0x00070814, 0x007FFF1F }, -- -- { 3, 0x140, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00800756, 0x00F3FFFF }, -- -- { 3, 0x140, AMD_FAM10_ALL, AMD_PTYPE_UMA, -- 0x00C37756, 0x00F3FFFF }, -- -- { 3, 0x144, AMD_FAM10_ALL, AMD_PTYPE_UMA, -- 0x00000036, 0x000000FF }, -- -- /* Errata 281 Workaround */ -- { 3, 0x144, ( AMD_DR_B0 | AMD_DR_B1), -- AMD_PTYPE_SVR, 0x00000001, 0x0000000F }, -- /* [3:0] RspTok = 0001b */ -- -- { 3, 0x148, AMD_FAM10_ALL, AMD_PTYPE_UMA, -- 0x8000052A, 0xD5FFFFFF }, -- -- /* ACPI Power State Control Reg1 */ -- { 3, 0x80, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0xE6002200, 0xFFFFFFFF }, -- -- /* ACPI Power State Control Reg2 */ -- { 3, 0x84, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0xA0E641E6, 0xFFFFFFFF }, -- -- { 3, 0xA0, AMD_FAM10_ALL, AMD_PTYPE_MOB | AMD_PTYPE_DSK, -- 0x00000080, 0x00000080 }, /* [7] PSIVidEnable */ -- -- { 3, 0xA0, AMD_DR_Bx, AMD_PTYPE_ALL, -- 0x00002800, 0x000003800 }, /* [13:11] PllLockTime = 5 */ -- -- { 3, 0xA0, (AMD_FAM10_ALL & ~(AMD_DR_Bx)), AMD_PTYPE_ALL, -- 0x00000800, 0x000003800 }, /* [13:11] PllLockTime = 1 */ -- -- /* Reported Temp Control Register */ -- { 3, 0xA4, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000080, 0x00000080 }, /* [7] TempSlewDnEn = 1 */ -- -- /* Clock Power/Timing Control 0 Register */ -- { 3, 0xD4, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0xC0000F00, 0xF0000F00 }, /* [31] NbClkDivApplyAll = 1, -- [30:28] NbClkDiv = 100b,[11:8] ClkRampHystSel = 1111b */ -- -- /* Clock Power/Timing Control 1 Register */ -- { 3, 0xD8, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x03000016, 0x0F000077 }, /* [6:4] VSRampTime = 1, -- [2:0] VSSlamTime = 6, [27:24] ReConDel = 3 */ -- -- -- /* Clock Power/Timing Control 2 Register */ -- { 3, 0xDC, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00005000, 0x00007000 }, /* [14:12] NbsynPtrAdj = 5 */ -- -- -- /* Extended NB MCA Config Register */ -- { 3, 0x180, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x007003E2, 0x007003E2 }, /* [22:20] = SyncFloodOn_Err = 7, -- [9] SyncOnUncNbAryEn = 1 , -- [8] SyncOnProtEn = 1, -- [7] SyncFloodOnTgtAbtErr = 1, -- [6] SyncFloodOnDatErr = 1, -- [5] DisPciCfgCpuMstAbtRsp = 1, -- [1] SyncFloodOnUsPwDataErr = 1 */ -- -- /* errata 346 - Fam10 C2, C3 -- * System software should set F3x188[22] to 1b. */ -- { 3, 0x188, AMD_DR_Cx, AMD_PTYPE_ALL, -- 0x00400000, 0x00400000 }, -- -- /* L3 Control Register */ -- { 3, 0x1B8, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00001000, 0x00001000 }, /* [12] = L3PrivReplEn */ -- -- /* IBS Control Register */ -- { 3, 0x1CC, AMD_FAM10_ALL, AMD_PTYPE_ALL, -- 0x00000100, 0x00000100 }, /* [8] = LvtOffsetVal */ --}; -- -- --/* -- * Default HyperTransport Phy and errata settings. -- */ --static const struct { -- u16 htreg; /* HT Phy Register index */ -- u32 revision; -- u32 platform; -- u32 linktype; -- u32 data; -- u32 mask; --} fam10_htphy_default[] = { -- -- /* Errata 344 - Fam10 C2/C3, D0/D1 -- * System software should set bit 6 of F4x1[9C, 94, 8C, 84]_x[78:70, 68:60]. */ -- { 0x60, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x61, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x62, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x63, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x64, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x65, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x66, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x67, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x68, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- -- { 0x70, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x71, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x72, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x73, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x74, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x75, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x76, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x77, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x78, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- -- /* Errata 354 - Fam10 C2, C3 -- * System software should set bit 6 of F4x1[9C,94,8C,84]_x[58:50, 48:40] for all links. */ -- { 0x40, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x41, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x42, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x43, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x44, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x45, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x46, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x47, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x48, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- -- { 0x50, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x51, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x52, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x53, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x54, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x55, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x56, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x57, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- { 0x58, AMD_DR_Cx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00000040, 0x00000040 }, -- -- /* Errata 327 - Fam10 C2/C3, D0/D1 -- * BIOS should set the Link Phy Impedance Register[RttCtl] -- * (F4x1[9C, 94, 8C, 84]_x[D0, C0][31:29]) to 010b and -- * Link Phy Impedance Register[RttIndex] -- * (F4x1[9C, 94, 8C, 84]_x[D0, C0][20:16]) to 00100b */ -- { 0xC0, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x40040000, 0xe01F0000 }, -- { 0xD0, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x40040000, 0xe01F0000 }, -- -- { 0x520A,AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00004000, 0x00006000 }, /* HT_PHY_DLL_REG */ -- -- { 0x530A, AMD_DR_Cx | AMD_DR_Dx, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00004000, 0x00006000 }, /* HT_PHY_DLL_REG */ -- -- { 0x520A, AMD_DR_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00004400, 0x00006400 }, /* HT_PHY_DLL_REG */ -- -- { 0x530A, AMD_DR_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x00004400, 0x00006400 }, /* HT_PHY_DLL_REG */ -- -- { 0xCF, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT3, -- 0x00000000, 0x000000FF }, /* Provide clear setting for logical -- completeness */ -- -- { 0xDF, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT3, -- 0x00000000, 0x000000FF }, /* Provide clear setting for logical -- completeness */ -- -- { 0xCF, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT1, -- 0x0000006D, 0x000000FF }, /* HT_PHY_HT1_FIFO_PTR_OPT_VALUE */ -- -- { 0xDF, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT1, -- 0x0000006D, 0x000000FF }, /* HT_PHY_HT1_FIFO_PTR_OPT_VALUE */ -- -- /* Link Phy Receiver Loop Filter Registers */ -- { 0xD1, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT3, -- 0x08040000, 0x3FFFC000 }, /* [29:22] LfcMax = 20h, -- [21:14] LfcMin = 10h */ -- -- { 0xC1, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT3, -- 0x08040000, 0x3FFFC000 }, /* [29:22] LfcMax = 20h, -- [21:14] LfcMin = 10h */ -- -- { 0xD1, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT1, -- 0x04020000, 0x3FFFC000 }, /* [29:22] LfcMax = 10h, -- [21:14] LfcMin = 08h */ -- -- { 0xC1, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_HT1, -- 0x04020000, 0x3FFFC000 }, /* [29:22] LfcMax = 10h, -- [21:14] LfcMin = 08h */ -- -- { 0xC0, AMD_FAM10_ALL, AMD_PTYPE_ALL, HTPHY_LINKTYPE_ALL, -- 0x40040000, 0xe01F0000 }, /* [31:29] RttCtl = 02h, -- [20:16] RttIndex = 04h */ --}; -diff --git a/src/cpu/amd/model_10xxx/fidvid.c b/src/cpu/amd/model_10xxx/fidvid.c -deleted file mode 100644 -index 5b1c581..0000000 ---- a/src/cpu/amd/model_10xxx/fidvid.c -+++ /dev/null -@@ -1,1048 +0,0 @@ --/* -- * This file is part of the coreboot project. -- * -- * Copyright (C) 2007 Advanced Micro Devices, Inc. -- * -- * 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; version 2 of the License. -- * -- * 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. -- * -- * You should have received a copy of the GNU General Public License -- * along with this program; if not, write to the Free Software -- * Foundation, Inc. -- */ --/* -- * This file initializes the CPU cores for voltage and frequency settings -- * in the different power states. -- */ --/* -- --checklist (functions are in this file if no source file named) --Fam10 Bios and Kernel Development Guide #31116, rev 3.48, April 22, 2010 -- --2.4.2.6 Requirements for p-states -- --1.- F3x[84:80] According to table 100 : prep_fid_change -- --2.- COF/VID : -- 2.4.2.9.1 Steps 1,3-6 and warning for 2,7 if they apply -- fixPsNbVidBeforeWR(...) -- 2.4.2.9.1 Step 8 enable_fid_change -- We do this for all nodes, I don't understand BKDG 100% on -- whether this is or isn't meant by "on the local -- processor". Must be OK. -- 2.4.2.9.1 Steps 9-10 (repeat 1-7 and reset) romstage.c/init_cpus ? -- 2.4.2.9.1 Steps 11-12 init_fidvid_stage2 -- 2.4.2.9.2 DualPlane PVI : Not supported, don't know how to detect, -- needs specific circuitry. -- --3.- 2.4.2.7 dualPlaneOnly(dev) -- --4.- 2.4.2.8 applyBoostFIDOffset(dev) -- --5.- enableNbPState1(dev) -- --6.- 2.4.1.7 -- a) UpdateSinglePlaneNbVid() -- b) setVSRamp(), called from prep_fid_change -- c) prep_fid_change -- d) improperly, for lack of voltage regulator details?, -- F3xA0[PsiVidEn] in defaults.h -- F3xA0[PsiVid] in init_cpus.c AMD_SetupPSIVID_d (before prep_fid_change) -- --7.- TODO (Core Performance Boost is only available in revision E cpus, and we -- don't seem to support those yet, at least they don't have any -- constant in amddefs.h ) -- --8.- FIXME ? Transition to min Pstate according to 2.4.2.15.3 is required -- by 2.4.2.6 after warm reset. But 2.4.2.15 states that it is not required -- if the warm reset is issued by coreboot to update NbFid. So it is required -- or not ? How can I tell who issued warm reset ? -- Coreboot transitions to P0 instead, which is not recommended, and does -- not follow 2.4.2.15.2 to do so. -- --9.- TODO Requires information on current delivery capability -- (depends on mainboard and maybe power supply ?). One might use a config -- option with the maximum number of Amperes that the board can deliver to CPU. -- --10.- [Multiprocessor] TODO 2.4.2.12 -- [Uniprocessor] FIXME ? We call setPStateMaxVal() in init_fidvid_stage2, -- but not sure this is what is meant by "Determine the valid set of -- P-states based on enabled P-states indicated -- in MSRC001_00[68:64][PstateEn]" in 2.4.2.6-10 -- --11.- finalPstateChange() from init_fidvid_Stage2 (BKDG says just "may", anyway) -- --12.- generate ACPI for p-states. -- generated in powernow_acpi.c amd_generate_powernow() -- --"must also be completed" -- --a.- PllLockTime set in ruleset in defaults.h -- BKDG says set it "If MSRC001_00[68:64][CpuFid] is different between -- any two enabled P-states", but since it does not say "only if" -- I guess it is safe to do it always. -- --b.- prep_fid_change(...) -- -- */ -- --#if CONFIG_SET_FIDVID -- --#include <northbridge/amd/amdht/AsPsDefs.h> -- --static inline void print_debug_fv(const char *str, u32 val) --{ --#if CONFIG_SET_FIDVID_DEBUG -- printk(BIOS_DEBUG, "%s%x\n", str, val); --#endif --} -- --static inline void print_debug_fv_8(const char *str, u8 val) --{ --#if CONFIG_SET_FIDVID_DEBUG -- printk(BIOS_DEBUG, "%s%02x\n", str, val); --#endif --} -- --static inline void print_debug_fv_64(const char *str, u32 val, u32 val2) --{ --#if CONFIG_SET_FIDVID_DEBUG -- printk(BIOS_DEBUG, "%s%x%x\n", str, val, val2); --#endif --} -- --struct fidvid_st { -- u32 common_fid; --}; -- --static void enable_fid_change(u8 fid) --{ -- u32 dword; -- u32 nodes; -- device_t dev; -- int i; -- -- nodes = get_nodes(); -- -- for (i = 0; i < nodes; i++) { -- dev = NODE_PCI(i, 3); -- dword = pci_read_config32(dev, 0xd4); -- dword &= ~0x1F; -- dword |= (u32) fid & 0x1F; -- dword |= 1 << 5; // enable -- pci_write_config32(dev, 0xd4, dword); -- printk(BIOS_DEBUG, "FID Change Node:%02x, F3xD4: %08x \n", i, -- dword); -- } --} -- --static void applyBoostFIDOffset( device_t dev ) { -- // BKDG 2.4.2.8 -- // revision E only, but E is apparently not supported yet, therefore untested -- if ((cpuid_edx(0x80000007) & CPB_MASK) -- && ((cpuid_ecx(0x80000008) & NC_MASK) ==5) ) { -- u32 core = get_node_core_id_x().coreid; -- u32 asymetricBoostThisCore = ((pci_read_config32(dev, 0x10C) >> (core*2))) & 3; -- msr_t msr = rdmsr(PS_REG_BASE); -- u32 cpuFid = msr.lo & PS_CPU_FID_MASK; -- cpuFid = cpuFid + asymetricBoostThisCore; -- msr.lo &= ~PS_CPU_FID_MASK; -- msr.lo |= cpuFid ; -- wrmsr(PS_REG_BASE , msr); -- -- } --} -- --static void enableNbPState1( device_t dev ) { -- u32 cpuRev = mctGetLogicalCPUID(0xFF); -- if (cpuRev & AMD_FAM10_C3) { -- u32 nbPState = (pci_read_config32(dev, 0x1F0) & NB_PSTATE_MASK); -- if ( nbPState){ -- u32 nbVid1 = (pci_read_config32(dev, 0x1F4) & NB_VID1_MASK) >> NB_VID1_SHIFT; -- u32 i; -- for (i = nbPState; i < NM_PS_REG; i++) { -- msr_t msr = rdmsr(PS_REG_BASE + i); -- if (msr.hi & PS_EN_MASK ) { -- msr.hi |= NB_DID_M_ON; -- msr.lo &= NB_VID_MASK_OFF; -- msr.lo |= ( nbVid1 << NB_VID_POS); -- wrmsr(PS_REG_BASE + i, msr); -- } -- } -- } -- } --} -- --static u8 setPStateMaxVal( device_t dev ) { -- u8 i,maxpstate=0; -- for (i = 0; i < NM_PS_REG; i++) { -- msr_t msr = rdmsr(PS_REG_BASE + i); -- if (msr.hi & PS_IDD_VALUE_MASK) { -- msr.hi |= PS_EN_MASK ; -- wrmsr(PS_REG_BASE + i, msr); -- } -- if (msr.hi & PS_EN_MASK) { -- maxpstate = i; -- } -- } -- //FIXME: CPTC2 and HTC_REG should get max per node, not per core ? -- u32 reg = pci_read_config32(dev, CPTC2); -- reg &= PS_MAX_VAL_MASK; -- reg |= (maxpstate << PS_MAX_VAL_POS); -- pci_write_config32(dev, CPTC2,reg); -- return maxpstate; --} -- --static void dualPlaneOnly( device_t dev ) { -- // BKDG 2.4.2.7 -- -- u32 cpuRev = mctGetLogicalCPUID(0xFF); -- if ((mctGetProcessorPackageType() == AMD_PKGTYPE_AM3_2r2) -- && (cpuRev & AMD_DR_Cx)) { // should be rev C or rev E but there's no constant for E -- if ( (pci_read_config32(dev, 0x1FC) & DUAL_PLANE_ONLY_MASK) -- && (pci_read_config32(dev, 0xA0) & PVI_MODE) ){ -- if (cpuid_edx(0x80000007) & CPB_MASK) { -- // revision E only, but E is apparently not supported yet, therefore untested -- msr_t minPstate = rdmsr(0xC0010065); -- wrmsr(0xC0010065, rdmsr(0xC0010068) ); -- wrmsr(0xC0010068,minPstate); -- } else { -- msr_t msr; -- msr.lo=0; msr.hi=0; -- wrmsr(0xC0010064, rdmsr(0xC0010068) ); -- wrmsr(0xC0010068, msr ); -- } -- -- //FIXME: CPTC2 and HTC_REG should get max per node, not per core ? -- u8 maxpstate = setPStateMaxVal(dev); -- -- u32 reg = pci_read_config32(dev, HTC_REG); -- reg &= HTC_PS_LMT_MASK; -- reg |= (maxpstate << PS_LIMIT_POS); -- pci_write_config32(dev, HTC_REG,reg); -- -- } -- } --} -- --static int vidTo100uV(u8 vid) --{// returns voltage corresponding to vid in tenths of mV, i.e. hundreds of uV -- // BKDG #31116 rev 3.48 2.4.1.6 -- int voltage; -- if (vid >= 0x7c) { -- voltage = 0; -- } else { -- voltage = (15500 - (125*vid)); -- } -- return voltage; --} -- --static void setVSRamp(device_t dev) { -- /* BKDG r31116 2010-04-22 2.4.1.7 step b F3xD8[VSRampTime] -- * If this field accepts 8 values between 10 and 500 us why -- * does page 324 say "BIOS should set this field to 001b." -- * (20 us) ? -- * Shouldn't it depend on the voltage regulators, mainboard -- * or something ? -- */ -- u32 dword; -- dword = pci_read_config32(dev, 0xd8); -- dword &= VSRAMP_MASK; -- dword |= VSRAMP_VALUE; -- pci_write_config32(dev, 0xd8, dword); --} -- --static void recalculateVsSlamTimeSettingOnCorePre(device_t dev) --{ -- u8 pviModeFlag; -- u8 highVoltageVid, lowVoltageVid, bValue; -- u16 minimumSlamTime; -- u16 vSlamTimes[7] = { 1000, 2000, 3000, 4000, 6000, 10000, 20000 }; /* Reg settings scaled by 100 */ -- u32 dtemp; -- msr_t msr; -- -- /* This function calculates the VsSlamTime using the range of possible -- * voltages instead of a hardcoded 200us. -- * Note: his function is called only from prep_fid_change, -- * and that from init_cpus.c finalize_node_setup() -- * (after set AMD MSRs and init ht ) -- */ -- -- /* BKDG r31116 2010-04-22 2.4.1.7 step b F3xD8[VSSlamTime] */ -- /* Calculate Slam Time -- * Vslam = (mobileCPU?0.2:0.4)us/mV * (Vp0 - (lowest out of Vpmin or Valt)) mV -- * In our case, we will scale the values by 100 to avoid -- * decimals. -- */ -- -- /* Determine if this is a PVI or SVI system */ -- dtemp = pci_read_config32(dev, 0xA0); -- -- if (dtemp & PVI_MODE) -- pviModeFlag = 1; -- else -- pviModeFlag = 0; -- -- /* Get P0's voltage */ -- /* MSRC001_00[68:64] are not programmed yet when called from -- prep_fid_change, one might use F4x1[F0:E0] instead, but -- theoretically MSRC001_00[68:64] are equal to them after -- reset. */ -- msr = rdmsr(0xC0010064); -- highVoltageVid = (u8) ((msr.lo >> PS_CPU_VID_SHFT) & 0x7F); -- if (!(msr.hi & 0x80000000)) { -- printk(BIOS_ERR,"P-state info in MSRC001_0064 is invalid !!!\n"); -- highVoltageVid = (u8) ((pci_read_config32(dev, 0x1E0) -- >> PS_CPU_VID_SHFT) & 0x7F); -- } -- -- /* If SVI, we only care about CPU VID. -- * If PVI, determine the higher voltage b/t NB and CPU -- */ -- if (pviModeFlag) { -- bValue = (u8) ((msr.lo >> PS_NB_VID_SHFT) & 0x7F); -- if (highVoltageVid > bValue) -- highVoltageVid = bValue; -- } -- -- /* Get PSmax's index */ -- msr = rdmsr(0xC0010061); -- bValue = (u8) ((msr.lo >> PS_MAX_VAL_SHFT) & BIT_MASK_3); -- -- /* Get PSmax's VID */ -- msr = rdmsr(0xC0010064 + bValue); -- lowVoltageVid = (u8) ((msr.lo >> PS_CPU_VID_SHFT) & 0x7F); -- if (!(msr.hi & 0x80000000)) { -- printk(BIOS_ERR,"P-state info in MSR%8x is invalid !!!\n",0xC0010064 + bValue); -- lowVoltageVid = (u8) ((pci_read_config32(dev, 0x1E0+(bValue*4)) -- >> PS_CPU_VID_SHFT) & 0x7F); -- } -- -- /* If SVI, we only care about CPU VID. -- * If PVI, determine the higher voltage b/t NB and CPU -- * BKDG 2.4.1.7 (a) -- */ -- if (pviModeFlag) { -- bValue = (u8) ((msr.lo >> PS_NB_VID_SHFT) & 0x7F); -- if (lowVoltageVid > bValue) -- lowVoltageVid = bValue; -- } -- -- /* Get AltVID */ -- dtemp = pci_read_config32(dev, 0xDC); -- bValue = (u8) (dtemp & BIT_MASK_7); -- -- /* Use the VID with the lowest voltage (higher VID) */ -- if (lowVoltageVid < bValue) -- lowVoltageVid = bValue; -- -- u8 mobileFlag = get_platform_type() & AMD_PTYPE_MOB; -- minimumSlamTime = (mobileFlag?2:4) * (vidTo100uV(highVoltageVid) - vidTo100uV(lowVoltageVid)); /* * 0.01 us */ -- -- -- /* Now round up to nearest register setting. -- * Note that if we don't find a value, we -- * will fall through to a value of 7 -- */ -- for (bValue = 0; bValue < 7; bValue++) { -- if (minimumSlamTime <= vSlamTimes[bValue]) -- break; -- } -- -- /* Apply the value */ -- dtemp = pci_read_config32(dev, 0xD8); -- dtemp &= VSSLAM_MASK; -- dtemp |= bValue; -- pci_write_config32(dev, 0xd8, dtemp); --} -- --static u32 nb_clk_did(int node, u32 cpuRev,u8 procPkg) { -- u8 link0isGen3 = 0; -- u8 offset; -- if (AMD_CpuFindCapability(node, 0, &offset)) { -- link0isGen3 = (AMD_checkLinkType(node, 0, offset) & HTPHY_LINKTYPE_HT3 ); -- } -- /* FIXME: NB_CLKDID should be 101b for AMD_DA_C2 in package -- S1g3 in link Gen3 mode, but I don't know how to tell -- package S1g3 from S1g4 */ -- if ((cpuRev & AMD_DA_C2) && (procPkg & AMD_PKGTYPE_S1gX) -- && link0isGen3) { -- return 5 ; /* divide clk by 128*/ -- } else { -- return 4 ; /* divide clk by 16 */ -- } --} -- -- --static u32 power_up_down(int node, u8 procPkg) { -- u32 dword=0; -- /* from CPU rev guide #41322 rev 3.74 June 2010 Table 26 */ -- u8 singleLinkFlag = ((procPkg == AMD_PKGTYPE_AM3_2r2) -- || (procPkg == AMD_PKGTYPE_S1gX) -- || (procPkg == AMD_PKGTYPE_ASB2)); -- -- if (singleLinkFlag) { -- /* -- * PowerStepUp=01000b - 50nS -- * PowerStepDown=01000b - 50ns -- */ -- dword |= PW_STP_UP50 | PW_STP_DN50; -- } else { -- u32 dispRefModeEn = (pci_read_config32(NODE_PCI(node,0),0x68) >> 24) & 1; -- u32 isocEn = 0; -- int j; -- for(j=0 ; (j<4) && (!isocEn) ; j++ ) { -- u8 offset; -- if (AMD_CpuFindCapability(node, j, &offset)) { -- isocEn = (pci_read_config32(NODE_PCI(node,0),offset+4) >>12) & 1; -- } -- } -- -- if (dispRefModeEn || isocEn) { -- dword |= PW_STP_UP50 | PW_STP_DN50 ; -- } else { -- /* get number of cores for PowerStepUp & PowerStepDown in server -- 1 core - 400nS - 0000b -- 2 cores - 200nS - 0010b -- 3 cores - 133nS -> 100nS - 0011b -- 4 cores - 100nS - 0011b -- */ -- switch (get_core_num_in_bsp(node)) { -- case 0: -- dword |= PW_STP_UP400 | PW_STP_DN400; -- break; -- case 1: -- case 2: -- dword |= PW_STP_UP200 | PW_STP_DN200; -- break; -- case 3: -- dword |= PW_STP_UP100 | PW_STP_DN100; -- break; -- default: -- dword |= PW_STP_UP100 | PW_STP_DN100; -- break; -- } -- } -- } -- return dword; --} -- --static void config_clk_power_ctrl_reg0(int node, u32 cpuRev, u8 procPkg) { -- device_t dev = NODE_PCI(node, 3); -- -- /* Program fields in Clock Power/Control register0 (F3xD4) */ -- -- /* set F3xD4 Clock Power/Timing Control 0 Register -- * NbClkDidApplyAll=1b -- * NbClkDid=100b or 101b -- * PowerStepUp= "platform dependent" -- * PowerStepDown= "platform dependent" -- * LinkPllLink=01b -- * ClkRampHystCtl=HW default -- * ClkRampHystSel=1111b -- */ -- u32 dword= pci_read_config32(dev, 0xd4); -- dword &= CPTC0_MASK; -- dword |= NB_CLKDID_ALL | LNK_PLL_LOCK | CLK_RAMP_HYST_SEL_VAL; -- dword |= (nb_clk_did(node,cpuRev,procPkg) << NB_CLKDID_SHIFT); -- -- dword |= power_up_down(node, procPkg); -- -- pci_write_config32(dev, 0xd4, dword); -- --} -- --static void config_power_ctrl_misc_reg(device_t dev,u32 cpuRev, u8 procPkg) { -- /* check PVI/SVI */ -- u32 dword = pci_read_config32(dev, 0xa0); -- -- /* BKDG r31116 2010-04-22 2.4.1.7 step b F3xA0[VSSlamVidMod] */ -- /* PllLockTime and PsiVidEn set in ruleset in defaults.h */ -- if (dword & PVI_MODE) { /* PVI */ -- /* set slamVidMode to 0 for PVI */ -- dword &= VID_SLAM_OFF ; -- } else { /* SVI */ -- /* set slamVidMode to 1 for SVI */ -- dword |= VID_SLAM_ON; -- } -- /* set the rest of A0 since we're at it... */ -- -- if (cpuRev & (AMD_DA_Cx | AMD_RB_C3 )) { -- dword |= NB_PSTATE_FORCE_ON; -- } // else should we clear it ? -- -- -- if ((procPkg == AMD_PKGTYPE_G34) || (procPkg == AMD_PKGTYPE_C32) ) { -- dword |= BP_INS_TRI_EN_ON ; -- } -- -- /* TODO: look into C1E state and F3xA0[IdleExitEn]*/ -- #if CONFIG_SVI_HIGH_FREQ -- if (cpuRev & AMD_FAM10_C3) { -- dword |= SVI_HIGH_FREQ_ON; -- } -- #endif -- pci_write_config32(dev, 0xa0, dword); --} -- --static void config_nb_syn_ptr_adj(device_t dev, u32 cpuRev) { -- /* Note the following settings are additional from the ported -- * function setFidVidRegs() -- */ -- /* adjust FIFO between nb and core clocks to max allowed -- values (min latency) */ -- u32 nbPstate = pci_read_config32(dev,0x1f0) & NB_PSTATE_MASK; -- u8 nbSynPtrAdj; -- if ((cpuRev & (AMD_DR_Bx|AMD_DA_Cx) ) -- || ( (cpuRev & AMD_RB_C3) && (nbPstate!=0))) { -- nbSynPtrAdj = 5; -- } else { -- nbSynPtrAdj = 6; -- } -- -- u32 dword = pci_read_config32(dev, 0xDc); -- dword &= ~ NB_SYN_PTR_ADJ_MASK; -- dword |= nbSynPtrAdj << NB_SYN_PTR_ADJ_POS; -- /* NbsynPtrAdj set to 5 or 6 per BKDG (needs reset) */ -- pci_write_config32(dev, 0xdc, dword); --} -- --static void config_acpi_pwr_state_ctrl_regs(device_t dev, u32 cpuRev, u8 procPkg) { -- /* step 1, chapter 2.4.2.6 of AMD Fam 10 BKDG #31116 Rev 3.48 22.4.2010 */ -- u32 dword; -- u32 c1= 1; -- if (cpuRev & (AMD_DR_Bx)) { -- // will coreboot ever enable cache scrubbing ? -- // if it does, will it be enough to check the current state -- // or should we configure for what we'll set up later ? -- dword = pci_read_config32(dev, 0x58); -- u32 scrubbingCache = dword & -- ( (0x1F << 16) // DCacheScrub -- | (0x1F << 8) ); // L2Scrub -- if (scrubbingCache) { -- c1 = 0x80; -- } else { -- c1 = 0xA0; -- } -- } else { // rev C or later -- // same doubt as cache scrubbing: ok to check current state ? -- dword = pci_read_config32(dev, 0xDC); -- u32 cacheFlushOnHalt = dword & (7 << 16); -- if (!cacheFlushOnHalt) { -- c1 = 0x80; -- } -- } -- dword = (c1 << 24) | (0xE641E6); -- pci_write_config32(dev, 0x84, dword); -- -- -- /* FIXME: BKDG Table 100 says if the link is at a Gen1 --frequency and the chipset does not support a 10us minimum LDTSTOP --assertion time, then { If ASB2 && SVI then smaf001 = F6h else --smaf001=87h. } else ... I hardly know what it means or how to check --it from here, so I bluntly assume it is false and code here the else, --which is easier */ -- -- u32 smaf001 = 0xE6; -- if (cpuRev & AMD_DR_Bx ) { -- smaf001 = 0xA6; -- } else { -- #if CONFIG_SVI_HIGH_FREQ -- if (cpuRev & (AMD_RB_C3 | AMD_DA_C3)) { -- smaf001 = 0xF6; -- } -- #endif -- } -- u32 fidvidChange = 0; -- if (((cpuRev & AMD_DA_Cx) && (procPkg & AMD_PKGTYPE_S1gX)) -- || (cpuRev & AMD_RB_C3) ) { -- fidvidChange=0x0B; -- } -- dword = (0xE6 << 24) | (fidvidChange << 16) -- | (smaf001 << 8) | 0x81; -- pci_write_config32(dev, 0x80, dword); --} -- --static void prep_fid_change(void) --{ -- u32 dword; -- u32 nodes; -- device_t dev; -- int i; -- -- /* This needs to be run before any Pstate changes are requested */ -- -- nodes = get_nodes(); -- -- for (i = 0; i < nodes; i++) { -- printk(BIOS_DEBUG, "Prep FID/VID Node:%02x\n", i); -- dev = NODE_PCI(i, 3); -- u32 cpuRev = mctGetLogicalCPUID(0xFF) ; -- u8 procPkg = mctGetProcessorPackageType(); -- -- setVSRamp(dev); -- /* BKDG r31116 2010-04-22 2.4.1.7 step b F3xD8[VSSlamTime] */ -- /* Figure out the value for VsSlamTime and program it */ -- recalculateVsSlamTimeSettingOnCorePre(dev); -- -- config_clk_power_ctrl_reg0(i,cpuRev,procPkg); -- -- config_power_ctrl_misc_reg(dev,cpuRev,procPkg); -- config_nb_syn_ptr_adj(dev,cpuRev); -- -- config_acpi_pwr_state_ctrl_regs(dev,cpuRev,procPkg); -- -- dword = pci_read_config32(dev, 0x80); -- printk(BIOS_DEBUG, " F3x80: %08x\n", dword); -- dword = pci_read_config32(dev, 0x84); -- printk(BIOS_DEBUG, " F3x84: %08x\n", dword); -- dword = pci_read_config32(dev, 0xD4); -- printk(BIOS_DEBUG, " F3xD4: %08x\n", dword); -- dword = pci_read_config32(dev, 0xD8); -- printk(BIOS_DEBUG, " F3xD8: %08x\n", dword); -- dword = pci_read_config32(dev, 0xDC); -- printk(BIOS_DEBUG, " F3xDC: %08x\n", dword); -- } --} -- --static void waitCurrentPstate(u32 target_pstate){ -- msr_t initial_msr = rdmsr(TSC_MSR); -- msr_t pstate_msr = rdmsr(CUR_PSTATE_MSR); -- msr_t tsc_msr; -- u8 timedout ; -- -- /* paranoia ? I fear when we run fixPsNbVidBeforeWR we can enter a -- * P1 that is a copy of P0, therefore has the same NB DID but the -- * TSC will count twice per tick, so we have to wait for twice the -- * count to achieve the desired timeout. But I'm likely to -- * misunderstand this... -- */ -- u32 corrected_timeout = ( (pstate_msr.lo==1) -- && (!(rdmsr(0xC0010065).lo & NB_DID_M_ON)) ) ? -- WAIT_PSTATE_TIMEOUT*2 : WAIT_PSTATE_TIMEOUT ; -- msr_t timeout; -- -- timeout.lo = initial_msr.lo + corrected_timeout ; -- timeout.hi = initial_msr.hi; -- if ( (((u32)0xffffffff) - initial_msr.lo) < corrected_timeout ) { -- timeout.hi++; -- } -- -- // assuming TSC ticks at 1.25 ns per tick (800 MHz) -- do { -- pstate_msr = rdmsr(CUR_PSTATE_MSR); -- tsc_msr = rdmsr(TSC_MSR); -- timedout = (tsc_msr.hi > timeout.hi) -- || ((tsc_msr.hi == timeout.hi) && (tsc_msr.lo > timeout.lo )); -- } while ( (pstate_msr.lo != target_pstate) && (! timedout) ) ; -- -- if (pstate_msr.lo != target_pstate) { -- msr_t limit_msr = rdmsr(0xc0010061); -- printk(BIOS_ERR, "*** Time out waiting for P-state %01x. Current P-state %01x P-state current limit MSRC001_0061=%02x\n", target_pstate, pstate_msr.lo, limit_msr.lo); -- -- do { // should we just go on instead ? -- pstate_msr = rdmsr(CUR_PSTATE_MSR); -- } while ( pstate_msr.lo != target_pstate ) ; -- } --} -- --static void set_pstate(u32 nonBoostedPState) { -- msr_t msr; -- -- // Transition P0 for calling core. -- msr = rdmsr(0xC0010062); -- -- msr.lo = nonBoostedPState; -- wrmsr(0xC0010062, msr); -- -- /* Wait for P0 to set. */ -- waitCurrentPstate(nonBoostedPState); --} -- -- -- -- --static void UpdateSinglePlaneNbVid(void) --{ -- u32 nbVid, cpuVid; -- u8 i; -- msr_t msr; -- -- /* copy higher voltage (lower VID) of NBVID & CPUVID to both */ -- for (i = 0; i < 5; i++) { -- msr = rdmsr(PS_REG_BASE + i); -- nbVid = (msr.lo & PS_CPU_VID_M_ON) >> PS_CPU_VID_SHFT; -- cpuVid = (msr.lo & PS_NB_VID_M_ON) >> PS_NB_VID_SHFT; -- -- if (nbVid != cpuVid) { -- if (nbVid > cpuVid) -- nbVid = cpuVid; -- -- msr.lo = msr.lo & PS_BOTH_VID_OFF; -- msr.lo = msr.lo | (u32) ((nbVid) << PS_NB_VID_SHFT); -- msr.lo = msr.lo | (u32) ((nbVid) << PS_CPU_VID_SHFT); -- wrmsr(PS_REG_BASE + i, msr); -- } -- } --} -- --static void fixPsNbVidBeforeWR(u32 newNbVid, u32 coreid, u32 dev, u8 pviMode) -- { -- msr_t msr; -- u8 startup_pstate; -- -- /* This function sets NbVid before the warm reset. -- * Get StartupPstate from MSRC001_0071. -- * Read Pstate register pointed by [StartupPstate]. -- * and copy its content to P0 and P1 registers. -- * Copy newNbVid to P0[NbVid]. -- * transition to P1 on all cores, -- * then transition to P0 on core 0. -- * Wait for MSRC001_0063[CurPstate] = 000b on core 0. -- * see BKDG rev 3.48 2.4.2.9.1 BIOS NB COF and VID Configuration -- * for SVI and Single-Plane PVI Systems -- */ -- -- msr = rdmsr(0xc0010071); -- startup_pstate = (msr.hi >> (32 - 32)) & 0x07; -- -- /* Copy startup pstate to P1 and P0 MSRs. Set the maxvid for -- * this node in P0. Then transition to P1 for corex and P0 -- * for core0. These setting will be cleared by the warm reset -- */ -- msr = rdmsr(0xC0010064 + startup_pstate); -- wrmsr(0xC0010065, msr); -- wrmsr(0xC0010064, msr); -- -- /* missing step 2 from BDKG , F3xDC[PstateMaxVal] = -- * max(1,F3xDC[PstateMaxVal] ) because it would take -- * synchronization between cores and we don't think -- * PstatMaxVal is going to be 0 on cold reset anyway ? -- */ -- if ( ! (pci_read_config32(dev, 0xDC) & (~ PS_MAX_VAL_MASK)) ) { -- printk(BIOS_ERR,"F3xDC[PstateMaxVal] is zero. Northbridge voltage setting will fail. fixPsNbVidBeforeWR in fidvid.c needs fixing. See AMD # 31116 rev 3.48 BKDG 2.4.2.9.1 \n"); -- }; -- -- msr.lo &= ~0xFE000000; // clear nbvid -- msr.lo |= (newNbVid << 25); -- wrmsr(0xC0010064, msr); -- -- if (pviMode) { /* single plane*/ -- UpdateSinglePlaneNbVid(); -- } -- -- // Transition to P1 for all APs and P0 for core0. -- set_pstate(1); -- -- if (coreid == 0) { -- set_pstate(0); -- } -- -- /* missing step 7 (restore PstateMax to 0 if needed) because -- * we skipped step 2 -- */ -- --} -- --static u32 needs_NB_COF_VID_update(void) --{ -- u8 nb_cof_vid_update; -- u8 nodes; -- u8 i; -- -- /* If any node has nb_cof_vid_update set all nodes need an update. */ -- nodes = get_nodes(); -- nb_cof_vid_update = 0; -- for (i = 0; i < nodes; i++) { -- u32 cpuRev = mctGetLogicalCPUID(i) ; -- u32 nbCofVidUpdateDefined = (cpuRev & (AMD_FAM10_LT_D)); -- if (nbCofVidUpdateDefined -- && (pci_read_config32(NODE_PCI(i, 3), 0x1FC) -- & NB_COF_VID_UPDATE_MASK)) { -- nb_cof_vid_update = 1; -- break; -- } -- } -- return nb_cof_vid_update; --} -- --static u32 init_fidvid_core(u32 nodeid, u32 coreid) --{ -- device_t dev; -- u32 vid_max; -- u32 fid_max = 0; -- u8 nb_cof_vid_update = needs_NB_COF_VID_update(); -- u8 pvimode; -- u32 reg1fc; -- -- /* Steps 1-6 of BIOS NB COF and VID Configuration -- * for SVI and Single-Plane PVI Systems. BKDG 2.4.2.9 #31116 rev 3.48 -- */ -- -- dev = NODE_PCI(nodeid, 3); -- pvimode = pci_read_config32(dev, PW_CTL_MISC) & PVI_MODE; -- reg1fc = pci_read_config32(dev, 0x1FC); -- -- if (nb_cof_vid_update) { -- vid_max = (reg1fc & SINGLE_PLANE_NB_VID_MASK ) >> SINGLE_PLANE_NB_VID_SHIFT ; -- fid_max = (reg1fc & SINGLE_PLANE_NB_FID_MASK ) >> SINGLE_PLANE_NB_FID_SHIFT ; -- -- if (!pvimode) { /* SVI, dual power plane */ -- vid_max = vid_max - ((reg1fc & DUAL_PLANE_NB_VID_OFF_MASK ) >> DUAL_PLANE_NB_VID_SHIFT ); -- fid_max = fid_max + ((reg1fc & DUAL_PLANE_NB_FID_OFF_MASK ) >> DUAL_PLANE_NB_FID_SHIFT ); -- } -- /* write newNbVid to P-state Reg's NbVid always if NbVidUpdatedAll=1 */ -- fixPsNbVidBeforeWR(vid_max, coreid,dev,pvimode); -- -- /* fid setup is handled by the BSP at the end. */ -- -- } else { /* ! nb_cof_vid_update */ -- /* Use max values */ -- if (pvimode) -- UpdateSinglePlaneNbVid(); -- } -- -- return ((nb_cof_vid_update << 16) | (fid_max << 8)); -- --} -- --static void init_fidvid_ap(u32 apicid, u32 nodeid, u32 coreid) --{ -- u32 send; -- -- printk(BIOS_DEBUG, "FIDVID on AP: %02x\n", apicid); -- -- send = init_fidvid_core(nodeid,coreid); -- send |= (apicid << 24); // ap apicid -- -- // Send signal to BSP about this AP max fid -- // This also indicates this AP is ready for warm reset (if required). -- lapic_write(LAPIC_MSG_REG, send | F10_APSTATE_RESET); --} -- --static u32 calc_common_fid(u32 fid_packed, u32 fid_packed_new) --{ -- u32 fidmax; -- u32 fidmax_new; -- -- fidmax = (fid_packed >> 8) & 0xFF; -- -- fidmax_new = (fid_packed_new >> 8) & 0xFF; -- -- if (fidmax > fidmax_new) { -- fidmax = fidmax_new; -- } -- -- fid_packed &= 0xFF << 16; -- fid_packed |= (fidmax << 8); -- fid_packed |= fid_packed_new & (0xFF << 16); // set nb_cof_vid_update -- -- return fid_packed; --} -- --static void init_fidvid_bsp_stage1(u32 ap_apicid, void *gp) --{ -- u32 readback = 0; -- u32 timeout = 1; -- -- struct fidvid_st *fvp = gp; -- int loop; -- -- print_debug_fv("Wait for AP stage 1: ap_apicid = ", ap_apicid); -- -- loop = 100000; -- while (--loop > 0) { -- if (lapic_remote_read(ap_apicid, LAPIC_MSG_REG, &readback) != 0) -- continue; -- if ((readback & 0x3f) == 1) { -- timeout = 0; -- break; /* target ap is in stage 1 */ -- } -- } -- -- if (timeout) { -- printk(BIOS_DEBUG, "%s: timed out reading from ap %02x\n", -- __func__, ap_apicid); -- return; -- } -- -- print_debug_fv("\treadback = ", readback); -- -- fvp->common_fid = calc_common_fid(fvp->common_fid, readback); -- -- print_debug_fv("\tcommon_fid(packed) = ", fvp->common_fid); -- --} -- --static void fixPsNbVidAfterWR(u32 newNbVid, u8 NbVidUpdatedAll,u8 pviMode) --{ -- msr_t msr; -- u8 i; -- u8 StartupPstate; -- -- /* BKDG 2.4.2.9.1 11-12 -- * This function copies newNbVid to NbVid bits in P-state -- * Registers[4:0] if its NbDid bit=0, and IddValue!=0 in case of -- * NbVidUpdatedAll =0 or copies newNbVid to NbVid bits in -- * P-state Registers[4:0] if its IddValue!=0 in case of -- * NbVidUpdatedAll=1. Then transition to StartPstate. -- */ -- -- /* write newNbVid to P-state Reg's NbVid if its NbDid=0 */ -- for (i = 0; i < 5; i++) { -- msr = rdmsr(0xC0010064 + i); -- /* NbDid (bit 22 of P-state Reg) == 0 or NbVidUpdatedAll = 1 */ -- if ( (msr.hi & PS_IDD_VALUE_MASK) -- && (msr.hi & PS_EN_MASK) -- &&(((msr.lo & PS_NB_DID_MASK) == 0) || NbVidUpdatedAll)) { -- msr.lo &= PS_NB_VID_M_OFF; -- msr.lo |= (newNbVid & 0x7F) << PS_NB_VID_SHFT; -- wrmsr(0xC0010064 + i, msr); -- } -- } -- -- /* Not documented. Would overwrite Nb_Vids just copied -- * should we just update cpu_vid or nothing at all ? -- */ -- if (pviMode) { //single plane -- UpdateSinglePlaneNbVid(); -- } -- /* For each core in the system, transition all cores to StartupPstate */ -- msr = rdmsr(0xC0010071); -- StartupPstate = msr.hi & 0x07; -- -- /* Set and wait for StartupPstate to set. */ -- set_pstate(StartupPstate); -- --} -- --static void finalPstateChange(void) --{ -- /* Enable P0 on all cores for best performance. -- * Linux can slow them down later if need be. -- * It is safe since they will be in C1 halt -- * most of the time anyway. -- */ -- set_pstate(0); --} -- --static void init_fidvid_stage2(u32 apicid, u32 nodeid) --{ -- msr_t msr; -- device_t dev; -- u32 reg1fc; -- u32 dtemp; -- u32 nbvid; -- u8 nb_cof_vid_update = needs_NB_COF_VID_update(); -- u8 NbVidUpdateAll; -- u8 pvimode; -- -- /* After warm reset finish the fid/vid setup for all cores. */ -- -- /* If any node has nb_cof_vid_update set all nodes need an update. */ -- -- dev = NODE_PCI(nodeid, 3); -- pvimode = (pci_read_config32(dev, 0xA0) >> 8) & 1; -- reg1fc = pci_read_config32(dev, 0x1FC); -- nbvid = (reg1fc >> 7) & 0x7F; -- NbVidUpdateAll = (reg1fc >> 1) & 1; -- -- if (nb_cof_vid_update) { -- if (!pvimode) { /* SVI */ -- nbvid = nbvid - ((reg1fc >> 17) & 0x1F); -- } -- /* write newNbVid to P-state Reg's NbVid if its NbDid=0 */ -- fixPsNbVidAfterWR(nbvid, NbVidUpdateAll,pvimode); -- } else { /* !nb_cof_vid_update */ -- if (pvimode) -- UpdateSinglePlaneNbVid(); -- } -- dtemp = pci_read_config32(dev, 0xA0); -- dtemp &= PLLLOCK_OFF; -- dtemp |= PLLLOCK_DFT_L; -- pci_write_config32(dev, 0xA0, dtemp); -- -- dualPlaneOnly(dev); -- applyBoostFIDOffset(dev); -- enableNbPState1(dev); -- -- finalPstateChange(); -- -- /* Set TSC to tick at the P0 ndfid rate */ -- msr = rdmsr(HWCR); -- msr.lo |= 1 << 24; -- wrmsr(HWCR, msr); --} -- -- --#if CONFIG_SET_FIDVID_STORE_AP_APICID_AT_FIRST --struct ap_apicid_st { -- u32 num; -- // it could use 256 bytes for 64 node quad core system -- u8 apicid[NODE_NUMS * 4]; --}; -- --static void store_ap_apicid(unsigned ap_apicid, void *gp) --{ -- struct ap_apicid_st *p = gp; -- -- p->apicid[p->num++] = ap_apicid; -- --} --#endif -- -- --static int init_fidvid_bsp(u32 bsp_apicid, u32 nodes) --{ --#if CONFIG_SET_FIDVID_STORE_AP_APICID_AT_FIRST -- struct ap_apicid_st ap_apicidx; -- u32 i; --#endif -- struct fidvid_st fv; -- -- printk(BIOS_DEBUG, "FIDVID on BSP, APIC_id: %02x\n", bsp_apicid); -- -- /* Steps 1-6 of BIOS NB COF and VID Configuration -- * for SVI and Single-Plane PVI Systems. -- */ -- -- fv.common_fid = init_fidvid_core(0,0); -- -- print_debug_fv("BSP fid = ", fv.common_fid); -- --#if CONFIG_SET_FIDVID_STORE_AP_APICID_AT_FIRST && !CONFIG_SET_FIDVID_CORE0_ONLY -- /* For all APs (We know the APIC ID of all APs even when the APIC ID -- is lifted) remote read from AP LAPIC_MSG_REG about max fid. -- Then calculate the common max fid that can be used for all -- APs and BSP */ -- ap_apicidx.num = 0; -- -- for_each_ap(bsp_apicid, CONFIG_SET_FIDVID_CORE_RANGE, store_ap_apicid, &ap_apicidx); -- -- for (i = 0; i < ap_apicidx.num; i++) { -- init_fidvid_bsp_stage1(ap_apicidx.apicid[i], &fv); -- } --#else -- for_each_ap(bsp_apicid, CONFIG_SET_FIDVID_CORE0_ONLY, init_fidvid_bsp_stage1, &fv); --#endif -- -- print_debug_fv("common_fid = ", fv.common_fid); -- -- if (fv.common_fid & (1 << 16)) { /* check nb_cof_vid_update */ -- -- // Enable the common fid and other settings. -- enable_fid_change((fv.common_fid >> 8) & 0x1F); -- -- // nbfid change need warm reset, so reset at first -- return 1; -- } -- -- return 0; // No FID/VID changes. Don't reset --} --#endif -diff --git a/src/cpu/amd/model_10xxx/init_cpus.c b/src/cpu/amd/model_10xxx/init_cpus.c -deleted file mode 100644 -index 8de6d25..0000000 ---- a/src/cpu/amd/model_10xxx/init_cpus.c -+++ /dev/null -@@ -1,968 +0,0 @@ --/* -- * This file is part of the coreboot project. -- * -- * Copyright (C) 2007-2008 Advanced Micro Devices, Inc. -- * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -- * -- * 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; version 2 of the License. -- * -- * 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. -- * -- * You should have received a copy of the GNU General Public License -- * along with this program; if not, write to the Free Software -- * Foundation, Inc. -- */ -- --#include "cpu/amd/car/post_cache_as_ram.c" --#include "defaults.h" --#include <stdlib.h> --#include <cpu/x86/lapic.h> --#include <cpu/x86/mtrr.h> --#include <northbridge/amd/amdfam10/amdfam10.h> --#include <northbridge/amd/amdht/AsPsDefs.h> --#include <northbridge/amd/amdht/porting.h> -- --#include <northbridge/amd/amdfam10/raminit_amdmct.c> --#include <reset.h> -- --static void prep_fid_change(void); --static void init_fidvid_stage2(u32 apicid, u32 nodeid); --void cpuSetAMDMSR(void); -- --#if CONFIG_PCI_IO_CFG_EXT --static void set_EnableCf8ExtCfg(void) --{ -- // set the NB_CFG[46]=1; -- msr_t msr; -- msr = rdmsr(NB_CFG_MSR); -- // EnableCf8ExtCfg: We need that to access CONFIG_PCI_IO_CFG_EXT 4K range -- msr.hi |= (1 << (46 - 32)); -- wrmsr(NB_CFG_MSR, msr); --} --#else --static void set_EnableCf8ExtCfg(void) { } --#endif -- -- --typedef void (*process_ap_t) (u32 apicid, void *gp); -- --//core_range = 0 : all cores --//core range = 1 : core 0 only --//core range = 2 : cores other than core0 -- --static void for_each_ap(u32 bsp_apicid, u32 core_range, process_ap_t process_ap, -- void *gp) --{ -- // here assume the OS don't change our apicid -- u32 ap_apicid; -- -- u32 nodes; -- u32 siblings; -- u32 disable_siblings; -- u32 cores_found; -- u32 nb_cfg_54; -- int i, j; -- u32 ApicIdCoreIdSize; -- uint8_t rev_gte_d = 0; -- uint8_t dual_node = 0; -- uint32_t f3xe8; -- -- /* get_nodes define in ht_wrapper.c */ -- nodes = get_nodes(); -- -- if (!CONFIG_LOGICAL_CPUS || -- read_option(multi_core, 0) != 0) { // 0 means multi core -- disable_siblings = 1; -- } else { -- disable_siblings = 0; -- } -- -- /* Assume that all node are same stepping, otherwise we can use use -- nb_cfg_54 from bsp for all nodes */ -- nb_cfg_54 = read_nb_cfg_54(); -- f3xe8 = pci_read_config32(NODE_PCI(0, 3), 0xe8); -- -- if (cpuid_eax(0x80000001) >= 0x8) -- /* Revision D or later */ -- rev_gte_d = 1; -- -- if (rev_gte_d) -- /* Check for dual node capability */ -- if (f3xe8 & 0x20000000) -- dual_node = 1; -- -- ApicIdCoreIdSize = (cpuid_ecx(0x80000008) >> 12 & 0xf); -- if (ApicIdCoreIdSize) { -- siblings = ((1 << ApicIdCoreIdSize) - 1); -- } else { -- siblings = 3; //quad core -- } -- -- for (i = 0; i < nodes; i++) { -- cores_found = get_core_num_in_bsp(i); -- if (siblings > cores_found) -- siblings = cores_found; -- -- u32 jstart, jend; -- -- if (core_range == 2) { -- jstart = 1; -- } else { -- jstart = 0; -- } -- -- if (disable_siblings || (core_range == 1)) { -- jend = 0; -- } else { -- jend = cores_found; -- } -- -- for (j = jstart; j <= jend; j++) { -- if (dual_node) { -- ap_apicid = 0; -- if (nb_cfg_54) { -- ap_apicid |= ((i >> 1) & 0x3) << 4; /* Node ID */ -- ap_apicid |= ((i & 0x1) * (siblings + 1)) + j; /* Core ID */ -- } else { -- ap_apicid |= i & 0x3; /* Node ID */ -- ap_apicid |= (((i & 0x1) * (siblings + 1)) + j) << 4; /* Core ID */ -- } -- } else { -- ap_apicid = -- i * (nb_cfg_54 ? (siblings + 1) : 1) + -- j * (nb_cfg_54 ? 1 : 64); -- } -- -- --#if CONFIG_ENABLE_APIC_EXT_ID && (CONFIG_APIC_ID_OFFSET > 0) --#if !CONFIG_LIFT_BSP_APIC_ID -- if ((i != 0) || (j != 0)) /* except bsp */ --#endif -- ap_apicid += CONFIG_APIC_ID_OFFSET; --#endif -- -- if (ap_apicid == bsp_apicid) -- continue; -- -- process_ap(ap_apicid, gp); -- -- } -- } --} -- --static inline int lapic_remote_read(int apicid, int reg, u32 *pvalue) --{ -- int timeout; -- u32 status; -- int result; -- lapic_wait_icr_idle(); -- lapic_write(LAPIC_ICR2, SET_LAPIC_DEST_FIELD(apicid)); -- lapic_write(LAPIC_ICR, LAPIC_DM_REMRD | (reg >> 4)); -- --/* Extra busy check compared to lapic.h */ -- timeout = 0; -- do { -- status = lapic_read(LAPIC_ICR) & LAPIC_ICR_BUSY; -- } while (status == LAPIC_ICR_BUSY && timeout++ < 1000); -- -- timeout = 0; -- do { -- status = lapic_read(LAPIC_ICR) & LAPIC_ICR_RR_MASK; -- } while (status == LAPIC_ICR_RR_INPROG && timeout++ < 1000); -- -- result = -1; -- -- if (status == LAPIC_ICR_RR_VALID) { -- *pvalue = lapic_read(LAPIC_RRR); -- result = 0; -- } -- return result; --} -- --#if CONFIG_SET_FIDVID --static void init_fidvid_ap(u32 apicid, u32 nodeid, u32 coreid); --#endif -- --static inline __attribute__ ((always_inline)) --void print_apicid_nodeid_coreid(u32 apicid, struct node_core_id id, -- const char *str) --{ -- printk(BIOS_DEBUG, -- "%s --- { APICID = %02x NODEID = %02x COREID = %02x} ---\n", str, -- apicid, id.nodeid, id.coreid); --} -- --static u32 wait_cpu_state(u32 apicid, u32 state) --{ -- u32 readback = 0; -- u32 timeout = 1; -- int loop = 4000000; -- while (--loop > 0) { -- if (lapic_remote_read(apicid, LAPIC_MSG_REG, &readback) != 0) -- continue; -- if ((readback & 0x3f) == state || (readback & 0x3f) == F10_APSTATE_RESET) { -- timeout = 0; -- break; //target cpu is in stage started -- } -- } -- if (timeout) { -- if (readback) { -- timeout = readback; -- } -- } -- -- return timeout; --} -- --static void wait_ap_started(u32 ap_apicid, void *gp) --{ -- u32 timeout; -- timeout = wait_cpu_state(ap_apicid, F10_APSTATE_STARTED); -- printk(BIOS_DEBUG, "* AP %02x", ap_apicid); -- if (timeout) { -- printk(BIOS_DEBUG, " timed out:%08x\n", timeout); -- } else { -- printk(BIOS_DEBUG, "started\n"); -- } --} -- --void wait_all_other_cores_started(u32 bsp_apicid) --{ -- // all aps other than core0 -- printk(BIOS_DEBUG, "started ap apicid: "); -- for_each_ap(bsp_apicid, 2, wait_ap_started, (void *)0); -- printk(BIOS_DEBUG, "\n"); --} -- --void allow_all_aps_stop(u32 bsp_apicid) --{ -- /* Called by the BSP to indicate AP can stop */ -- -- /* FIXME Do APs use this? */ -- -- // allow aps to stop use 6 bits for state -- lapic_write(LAPIC_MSG_REG, (bsp_apicid << 24) | F10_APSTATE_STOPPED); --} -- --static void enable_apic_ext_id(u32 node) --{ -- u32 val; -- -- val = pci_read_config32(NODE_HT(node), 0x68); -- val |= (HTTC_APIC_EXT_SPUR | HTTC_APIC_EXT_ID | HTTC_APIC_EXT_BRD_CST); -- pci_write_config32(NODE_HT(node), 0x68, val); --} -- --static void STOP_CAR_AND_CPU(void) --{ -- msr_t msr; -- -- /* Disable L2 IC to L3 connection (Only for CAR) */ -- msr = rdmsr(BU_CFG2); -- msr.lo &= ~(1 << ClLinesToNbDis); -- wrmsr(BU_CFG2, msr); -- -- disable_cache_as_ram(); // inline -- /* stop all cores except node0/core0 the bsp .... */ -- stop_this_cpu(); --} -- --static u32 init_cpus(u32 cpu_init_detectedx, struct sys_info *sysinfo) --{ -- u32 bsp_apicid = 0; -- u32 apicid; -- struct node_core_id id; -- -- /* Please refer to the calculations and explaination in cache_as_ram.inc before modifying these values */ -- uint32_t max_ap_stack_region_size = CONFIG_MAX_CPUS * CONFIG_DCACHE_AP_STACK_SIZE; -- uint32_t max_bsp_stack_region_size = CONFIG_DCACHE_BSP_STACK_SIZE + CONFIG_DCACHE_BSP_STACK_SLUSH; -- uint32_t bsp_stack_region_upper_boundary = CONFIG_DCACHE_RAM_BASE + CONFIG_DCACHE_RAM_SIZE; -- uint32_t bsp_stack_region_lower_boundary = bsp_stack_region_upper_boundary - max_bsp_stack_region_size; -- void * lower_stack_region_boundary = (void*)(bsp_stack_region_lower_boundary - max_ap_stack_region_size); -- if (((void*)(sysinfo + 1)) > lower_stack_region_boundary) -- printk(BIOS_WARNING, -- "sysinfo extends into stack region (sysinfo range: [%p,%p] lower stack region boundary: %p)\n", -- sysinfo, sysinfo + 1, lower_stack_region_boundary); -- -- /* -- * already set early mtrr in cache_as_ram.inc -- */ -- -- /* that is from initial apicid, we need nodeid and coreid -- later */ -- id = get_node_core_id_x(); -- -- /* NB_CFG MSR is shared between cores, so we need make sure -- core0 is done at first --- use wait_all_core0_started */ -- if (id.coreid == 0) { -- set_apicid_cpuid_lo(); /* only set it on core0 */ -- set_EnableCf8ExtCfg(); /* only set it on core0 */ --#if CONFIG_ENABLE_APIC_EXT_ID -- enable_apic_ext_id(id.nodeid); --#endif -- } -- -- enable_lapic(); -- --#if CONFIG_ENABLE_APIC_EXT_ID && (CONFIG_APIC_ID_OFFSET > 0) -- u32 initial_apicid = get_initial_apicid(); -- --#if !CONFIG_LIFT_BSP_APIC_ID -- if (initial_apicid != 0) // other than bsp --#endif -- { -- /* use initial apic id to lift it */ -- u32 dword = lapic_read(LAPIC_ID); -- dword &= ~(0xff << 24); -- dword |= -- (((initial_apicid + CONFIG_APIC_ID_OFFSET) & 0xff) << 24); -- -- lapic_write(LAPIC_ID, dword); -- } --#if CONFIG_LIFT_BSP_APIC_ID -- bsp_apicid += CONFIG_APIC_ID_OFFSET; --#endif -- --#endif -- -- /* get the apicid, it may be lifted already */ -- apicid = lapicid(); -- -- // show our apicid, nodeid, and coreid -- if (id.coreid == 0) { -- if (id.nodeid != 0) //all core0 except bsp -- print_apicid_nodeid_coreid(apicid, id, " core0: "); -- } else { //all other cores -- print_apicid_nodeid_coreid(apicid, id, " corex: "); -- } -- -- if (cpu_init_detectedx) { -- print_apicid_nodeid_coreid(apicid, id, -- "\n\n\nINIT detected from "); -- printk(BIOS_DEBUG, "\nIssuing SOFT_RESET...\n"); -- soft_reset(); -- } -- -- if (id.coreid == 0) { -- if (!(warm_reset_detect(id.nodeid))) //FIXME: INIT is checked above but check for more resets? -- distinguish_cpu_resets(id.nodeid); // Also indicates we are started -- } -- // Mark the core as started. -- lapic_write(LAPIC_MSG_REG, (apicid << 24) | F10_APSTATE_STARTED); -- -- if (apicid != bsp_apicid) { -- /* Setup each AP's cores MSRs. -- * This happens after HTinit. -- * The BSP runs this code in it's own path. -- */ -- update_microcode(cpuid_eax(1)); -- -- cpuSetAMDMSR(); -- --#if CONFIG_SET_FIDVID --#if CONFIG_LOGICAL_CPUS && CONFIG_SET_FIDVID_CORE0_ONLY -- // Run on all AP for proper FID/VID setup. -- if (id.coreid == 0) // only need set fid for core0 --#endif -- { -- // check warm(bios) reset to call stage2 otherwise do stage1 -- if (warm_reset_detect(id.nodeid)) { -- printk(BIOS_DEBUG, -- "init_fidvid_stage2 apicid: %02x\n", -- apicid); -- init_fidvid_stage2(apicid, id.nodeid); -- } else { -- printk(BIOS_DEBUG, -- "init_fidvid_ap(stage1) apicid: %02x\n", -- apicid); -- init_fidvid_ap(apicid, id.nodeid, id.coreid); -- } -- } --#endif -- -- /* AP is ready, configure MTRRs and go to sleep */ -- set_var_mtrr(0, 0x00000000, CONFIG_RAMTOP, MTRR_TYPE_WRBACK); -- -- STOP_CAR_AND_CPU(); -- -- printk(BIOS_DEBUG, -- "\nAP %02x should be halted but you are reading this....\n", -- apicid); -- } -- -- return bsp_apicid; --} -- --static u32 is_core0_started(u32 nodeid) --{ -- u32 htic; -- device_t device; -- device = NODE_PCI(nodeid, 0); -- htic = pci_read_config32(device, HT_INIT_CONTROL); -- htic &= HTIC_ColdR_Detect; -- return htic; --} -- --void wait_all_core0_started(void) --{ -- /* When core0 is started, it will distingush_cpu_resets -- * So wait for that to finish */ -- u32 i; -- u32 nodes = get_nodes(); -- -- printk(BIOS_DEBUG, "core0 started: "); -- for (i = 1; i < nodes; i++) { // skip bsp, because it is running on bsp -- while (!is_core0_started(i)) { -- } -- printk(BIOS_DEBUG, " %02x", i); -- } -- printk(BIOS_DEBUG, "\n"); --} -- --#if CONFIG_MAX_PHYSICAL_CPUS > 1 --/** -- * void start_node(u32 node) -- * -- * start the core0 in node, so it can generate HT packet to feature code. -- * -- * This function starts the AP nodes core0s. wait_all_core0_started() in -- * romstage.c waits for all the AP to be finished before continuing -- * system init. -- */ --static void start_node(u8 node) --{ -- u32 val; -- -- /* Enable routing table */ -- printk(BIOS_DEBUG, "Start node %02x", node); -- --#if CONFIG_NORTHBRIDGE_AMD_AMDFAM10 -- /* For FAM10 support, we need to set Dram base/limit for the new node */ -- pci_write_config32(NODE_MP(node), 0x44, 0); -- pci_write_config32(NODE_MP(node), 0x40, 3); --#endif -- -- /* Allow APs to make requests (ROM fetch) */ -- val = pci_read_config32(NODE_HT(node), 0x6c); -- val &= ~(1 << 1); -- pci_write_config32(NODE_HT(node), 0x6c, val); -- -- printk(BIOS_DEBUG, " done.\n"); --} -- --/** -- * static void setup_remote_node(u32 node) -- * -- * Copy the BSP Address Map to each AP. -- */ --static void setup_remote_node(u8 node) --{ -- /* There registers can be used with F1x114_x Address Map at the -- same time, So must set them even 32 node */ -- static const u16 pci_reg[] = { -- /* DRAM Base/Limits Registers */ -- 0x44, 0x4c, 0x54, 0x5c, 0x64, 0x6c, 0x74, 0x7c, -- 0x40, 0x48, 0x50, 0x58, 0x60, 0x68, 0x70, 0x78, -- 0x144, 0x14c, 0x154, 0x15c, 0x164, 0x16c, 0x174, 0x17c, -- 0x140, 0x148, 0x150, 0x158, 0x160, 0x168, 0x170, 0x178, -- /* MMIO Base/Limits Registers */ -- 0x84, 0x8c, 0x94, 0x9c, 0xa4, 0xac, 0xb4, 0xbc, -- 0x80, 0x88, 0x90, 0x98, 0xa0, 0xa8, 0xb0, 0xb8, -- /* IO Base/Limits Registers */ -- 0xc4, 0xcc, 0xd4, 0xdc, -- 0xc0, 0xc8, 0xd0, 0xd8, -- /* Configuration Map Registers */ -- 0xe0, 0xe4, 0xe8, 0xec, -- }; -- u16 i; -- -- printk(BIOS_DEBUG, "setup_remote_node: %02x", node); -- -- /* copy the default resource map from node 0 */ -- for (i = 0; i < ARRAY_SIZE(pci_reg); i++) { -- u32 value; -- u16 reg; -- reg = pci_reg[i]; -- value = pci_read_config32(NODE_MP(0), reg); -- pci_write_config32(NODE_MP(node), reg, value); -- -- } -- printk(BIOS_DEBUG, " done\n"); --} --#endif /* CONFIG_MAX_PHYSICAL_CPUS > 1 */ -- --static void AMD_Errata281(u8 node, u32 revision, u32 platform) --{ -- /* Workaround for Transaction Scheduling Conflict in -- * Northbridge Cross Bar. Implement XCS Token adjustment -- * for ganged links. Also, perform fix up for the mixed -- * revision case. -- */ -- -- u32 reg, val; -- u8 i; -- u8 mixed = 0; -- u8 nodes = get_nodes(); -- -- if (platform & AMD_PTYPE_SVR) { -- /* For each node we need to check for a "broken" node */ -- if (!(revision & (AMD_DR_B0 | AMD_DR_B1))) { -- for (i = 0; i < nodes; i++) { -- if (mctGetLogicalCPUID(i) & -- (AMD_DR_B0 | AMD_DR_B1)) { -- mixed = 1; -- break; -- } -- } -- } -- -- if ((revision & (AMD_DR_B0 | AMD_DR_B1)) || mixed) { -- -- /* F0X68[22:21] DsNpReqLmt0 = 01b */ -- val = pci_read_config32(NODE_PCI(node, 0), 0x68); -- val &= ~0x00600000; -- val |= 0x00200000; -- pci_write_config32(NODE_PCI(node, 0), 0x68, val); -- -- /* F3X6C */ -- val = pci_read_config32(NODE_PCI(node, 3), 0x6C); -- val &= ~0x700780F7; -- val |= 0x00010094; -- pci_write_config32(NODE_PCI(node, 3), 0x6C, val); -- -- /* F3X7C */ -- val = pci_read_config32(NODE_PCI(node, 3), 0x7C); -- val &= ~0x707FFF1F; -- val |= 0x00144514; -- pci_write_config32(NODE_PCI(node, 3), 0x7C, val); -- -- /* F3X144[3:0] RspTok = 0001b */ -- val = pci_read_config32(NODE_PCI(node, 3), 0x144); -- val &= ~0x0000000F; -- val |= 0x00000001; -- pci_write_config32(NODE_PCI(node, 3), 0x144, val); -- -- for (i = 0; i < 3; i++) { -- reg = 0x148 + (i * 4); -- val = pci_read_config32(NODE_PCI(node, 3), reg); -- val &= ~0x000000FF; -- val |= 0x000000DB; -- pci_write_config32(NODE_PCI(node, 3), reg, val); -- } -- } -- } --} -- --static void AMD_Errata298(void) --{ -- /* Workaround for L2 Eviction May Occur during operation to -- * set Accessed or dirty bit. -- */ -- -- msr_t msr; -- u8 i; -- u8 affectedRev = 0; -- u8 nodes = get_nodes(); -- -- /* For each core we need to check for a "broken" node */ -- for (i = 0; i < nodes; i++) { -- if (mctGetLogicalCPUID(i) & (AMD_DR_B0 | AMD_DR_B1 | AMD_DR_B2)) { -- affectedRev = 1; -- break; -- } -- } -- -- if (affectedRev) { -- msr = rdmsr(HWCR); -- msr.lo |= 0x08; /* Set TlbCacheDis bit[3] */ -- wrmsr(HWCR, msr); -- -- msr = rdmsr(BU_CFG); -- msr.lo |= 0x02; /* Set TlbForceMemTypeUc bit[1] */ -- wrmsr(BU_CFG, msr); -- -- msr = rdmsr(OSVW_ID_Length); -- msr.lo |= 0x01; /* OS Visible Workaround - MSR */ -- wrmsr(OSVW_ID_Length, msr); -- -- msr = rdmsr(OSVW_Status); -- msr.lo |= 0x01; /* OS Visible Workaround - MSR */ -- wrmsr(OSVW_Status, msr); -- } -- -- if (!affectedRev && (mctGetLogicalCPUID(0xFF) & AMD_DR_B3)) { -- msr = rdmsr(OSVW_ID_Length); -- msr.lo |= 0x01; /* OS Visible Workaround - MSR */ -- wrmsr(OSVW_ID_Length, msr); -- -- } --} -- --static u32 get_platform_type(void) --{ -- u32 ret = 0; -- -- switch (SYSTEM_TYPE) { -- case 1: -- ret |= AMD_PTYPE_DSK; -- break; -- case 2: -- ret |= AMD_PTYPE_MOB; -- break; -- case 0: -- ret |= AMD_PTYPE_SVR; -- break; -- default: -- break; -- } -- -- /* FIXME: add UMA support. */ -- -- /* All Fam10 are multi core */ -- ret |= AMD_PTYPE_MC; -- -- return ret; --} -- --static void AMD_SetupPSIVID_d(u32 platform_type, u8 node) --{ -- u32 dword; -- int i; -- msr_t msr; -- -- if (platform_type & (AMD_PTYPE_MOB | AMD_PTYPE_DSK)) { -- -- /* The following code sets the PSIVID to the lowest support P state -- * assuming that the VID for the lowest power state is below -- * the VDD voltage regulator threshold. (This also assumes that there -- * is a Pstate lower than P0) -- */ -- -- for (i = 4; i >= 0; i--) { -- msr = rdmsr(PS_REG_BASE + i); -- /* Pstate valid? */ -- if (msr.hi & PS_EN_MASK) { -- dword = pci_read_config32(NODE_PCI(i, 3), 0xA0); -- dword &= ~0x7F; -- dword |= (msr.lo >> 9) & 0x7F; -- pci_write_config32(NODE_PCI(i, 3), 0xA0, dword); -- break; -- } -- } -- } --} -- --/** -- * AMD_CpuFindCapability - Traverse PCI capability list to find host HT links. -- * HT Phy operations are not valid on links that aren't present, so this -- * prevents invalid accesses. -- * -- * Returns the offset of the link register. -- */ --static BOOL AMD_CpuFindCapability(u8 node, u8 cap_count, u8 * offset) --{ -- u32 reg; -- u32 val; -- -- /* get start of CPU HT Host Capabilities */ -- val = pci_read_config32(NODE_PCI(node, 0), 0x34); -- val &= 0xFF; //reg offset of first link -- -- cap_count++; -- -- /* Traverse through the capabilities. */ -- do { -- reg = pci_read_config32(NODE_PCI(node, 0), val); -- /* Is the capability block a HyperTransport capability block? */ -- if ((reg & 0xFF) == 0x08) { -- /* Is the HT capability block an HT Host Capability? */ -- if ((reg & 0xE0000000) == (1 << 29)) -- cap_count--; -- } -- -- if (cap_count) -- val = (reg >> 8) & 0xFF; //update reg offset -- } while (cap_count && val); -- -- *offset = (u8) val; -- -- /* If requested capability found val != 0 */ -- if (!cap_count) -- return TRUE; -- else -- return FALSE; --} -- --/** -- * AMD_checkLinkType - Compare desired link characteristics using a logical -- * link type mask. -- * -- * Returns the link characteristic mask. -- */ --static u32 AMD_checkLinkType(u8 node, u8 link, u8 regoff) --{ -- u32 val; -- u32 linktype = 0; -- -- /* Check connect, init and coherency */ -- val = pci_read_config32(NODE_PCI(node, 0), regoff + 0x18); -- val &= 0x1F; -- -- if (val == 3) -- linktype |= HTPHY_LINKTYPE_COHERENT; -- -- if (val == 7) -- linktype |= HTPHY_LINKTYPE_NONCOHERENT; -- -- if (linktype) { -- /* Check gen3 */ -- val = pci_read_config32(NODE_PCI(node, 0), regoff + 0x08); -- -- if (((val >> 8) & 0x0F) > 6) -- linktype |= HTPHY_LINKTYPE_HT3; -- else -- linktype |= HTPHY_LINKTYPE_HT1; -- -- /* Check ganged */ -- val = pci_read_config32(NODE_PCI(node, 0), (link << 2) + 0x170); -- -- if (val & 1) -- linktype |= HTPHY_LINKTYPE_GANGED; -- else -- linktype |= HTPHY_LINKTYPE_UNGANGED; -- } -- return linktype; --} -- --/** -- * AMD_SetHtPhyRegister - Use the HT link's HT Phy portal registers to update -- * a phy setting for that link. -- */ --static void AMD_SetHtPhyRegister(u8 node, u8 link, u8 entry) --{ -- u32 phyReg; -- u32 phyBase; -- u32 val; -- -- /* Determine this link's portal */ -- if (link > 3) -- link -= 4; -- -- phyBase = ((u32) link << 3) | 0x180; -- -- /* Get the portal control register's initial value -- * and update it to access the desired phy register -- */ -- phyReg = pci_read_config32(NODE_PCI(node, 4), phyBase); -- -- if (fam10_htphy_default[entry].htreg > 0x1FF) { -- phyReg &= ~HTPHY_DIRECT_OFFSET_MASK; -- phyReg |= HTPHY_DIRECT_MAP; -- } else { -- phyReg &= ~HTPHY_OFFSET_MASK; -- } -- -- /* Now get the current phy register data -- * LinkPhyDone = 0, LinkPhyWrite = 0 is a read -- */ -- phyReg |= fam10_htphy_default[entry].htreg; -- pci_write_config32(NODE_PCI(node, 4), phyBase, phyReg); -- -- do { -- val = pci_read_config32(NODE_PCI(node, 4), phyBase); -- } while (!(val & HTPHY_IS_COMPLETE_MASK)); -- -- /* Now we have the phy register data, apply the change */ -- val = pci_read_config32(NODE_PCI(node, 4), phyBase + 4); -- val &= ~fam10_htphy_default[entry].mask; -- val |= fam10_htphy_default[entry].data; -- pci_write_config32(NODE_PCI(node, 4), phyBase + 4, val); -- -- /* write it through the portal to the phy -- * LinkPhyDone = 0, LinkPhyWrite = 1 is a write -- */ -- phyReg |= HTPHY_WRITE_CMD; -- pci_write_config32(NODE_PCI(node, 4), phyBase, phyReg); -- -- do { -- val = pci_read_config32(NODE_PCI(node, 4), phyBase); -- } while (!(val & HTPHY_IS_COMPLETE_MASK)); --} -- --void cpuSetAMDMSR(void) --{ -- /* This routine loads the CPU with default settings in fam10_msr_default -- * table . It must be run after Cache-As-RAM has been enabled, and -- * Hypertransport initialization has taken place. Also note -- * that it is run on the current processor only, and only for the current -- * processor core. -- */ -- msr_t msr; -- u8 i; -- u32 revision, platform; -- -- printk(BIOS_DEBUG, "cpuSetAMDMSR "); -- -- revision = mctGetLogicalCPUID(0xFF); -- platform = get_platform_type(); -- -- for (i = 0; i < ARRAY_SIZE(fam10_msr_default); i++) { -- if ((fam10_msr_default[i].revision & revision) && -- (fam10_msr_default[i].platform & platform)) { -- msr = rdmsr(fam10_msr_default[i].msr); -- msr.hi &= ~fam10_msr_default[i].mask_hi; -- msr.hi |= fam10_msr_default[i].data_hi; -- msr.lo &= ~fam10_msr_default[i].mask_lo; -- msr.lo |= fam10_msr_default[i].data_lo; -- wrmsr(fam10_msr_default[i].msr, msr); -- } -- } -- AMD_Errata298(); -- -- printk(BIOS_DEBUG, " done\n"); --} -- --static void cpuSetAMDPCI(u8 node) --{ -- /* This routine loads the CPU with default settings in fam10_pci_default -- * table . It must be run after Cache-As-RAM has been enabled, and -- * Hypertransport initialization has taken place. Also note -- * that it is run for the first core on each node -- */ -- u8 i, j; -- u32 revision, platform; -- u32 val; -- u8 offset; -- -- printk(BIOS_DEBUG, "cpuSetAMDPCI %02d", node); -- -- revision = mctGetLogicalCPUID(node); -- platform = get_platform_type(); -- -- AMD_SetupPSIVID_d(platform, node); /* Set PSIVID offset which is not table driven */ -- -- for (i = 0; i < ARRAY_SIZE(fam10_pci_default); i++) { -- if ((fam10_pci_default[i].revision & revision) && -- (fam10_pci_default[i].platform & platform)) { -- val = pci_read_config32(NODE_PCI(node, -- fam10_pci_default[i]. -- function), -- fam10_pci_default[i].offset); -- val &= ~fam10_pci_default[i].mask; -- val |= fam10_pci_default[i].data; -- pci_write_config32(NODE_PCI(node, -- fam10_pci_default[i]. -- function), -- fam10_pci_default[i].offset, val); -- } -- } -- -- for (i = 0; i < ARRAY_SIZE(fam10_htphy_default); i++) { -- if ((fam10_htphy_default[i].revision & revision) && -- (fam10_htphy_default[i].platform & platform)) { -- /* HT Phy settings either apply to both sublinks or have -- * separate registers for sublink zero and one, so there -- * will be two table entries. So, here we only loop -- * through the sublink zeros in function zero. -- */ -- for (j = 0; j < 4; j++) { -- if (AMD_CpuFindCapability(node, j, &offset)) { -- if (AMD_checkLinkType(node, j, offset) -- & fam10_htphy_default[i].linktype) { -- AMD_SetHtPhyRegister(node, j, -- i); -- } -- } else { -- /* No more capabilities, -- * link not present -- */ -- break; -- } -- } -- } -- } -- -- /* FIXME: add UMA support and programXbarToSriReg(); */ -- -- AMD_Errata281(node, revision, platform); -- -- /* FIXME: if the dct phy doesn't init correct it needs to reset. -- if (revision & (AMD_DR_B2 | AMD_DR_B3)) -- dctPhyDiag(); */ -- -- printk(BIOS_DEBUG, " done\n"); --} -- --#ifdef UNUSED_CODE --static void cpuInitializeMCA(void) --{ -- /* Clears Machine Check Architecture (MCA) registers, which power on -- * containing unknown data, on currently running processor. -- * This routine should only be executed on initial power on (cold boot), -- * not across a warm reset because valid data is present at that time. -- */ -- -- msr_t msr; -- u32 reg; -- u8 i; -- -- if (cpuid_edx(1) & 0x4080) { /* MCE and MCA (edx[7] and edx[14]) */ -- msr = rdmsr(MCG_CAP); -- if (msr.lo & MCG_CTL_P) { /* MCG_CTL_P bit is set? */ -- msr.lo &= 0xFF; -- msr.lo--; -- msr.lo <<= 2; /* multiply the count by 4 */ -- reg = MC0_STA + msr.lo; -- msr.lo = msr.hi = 0; -- for (i = 0; i < 4; i++) { -- wrmsr(reg, msr); -- reg -= 4; /* Touch status regs for each bank */ -- } -- } -- } --} --#endif -- --/** -- * finalize_node_setup() -- * -- * Do any additional post HT init -- * -- */ --static void finalize_node_setup(struct sys_info *sysinfo) --{ -- u8 i; -- u8 nodes = get_nodes(); -- u32 reg; -- -- /* read Node0 F0_0x64 bit [8:10] to find out SbLink # */ -- reg = pci_read_config32(NODE_HT(0), 0x64); -- sysinfo->sblk = (reg >> 8) & 7; -- sysinfo->sbbusn = 0; -- sysinfo->nodes = nodes; -- sysinfo->sbdn = get_sbdn(sysinfo->sbbusn); -- -- for (i = 0; i < nodes; i++) { -- cpuSetAMDPCI(i); -- } -- --#if CONFIG_SET_FIDVID -- // Prep each node for FID/VID setup. -- prep_fid_change(); --#endif -- --#if CONFIG_MAX_PHYSICAL_CPUS > 1 -- /* Skip the BSP, start at node 1 */ -- for (i = 1; i < nodes; i++) { -- setup_remote_node(i); -- start_node(i); -- } --#endif --} -- --#include "fidvid.c" -diff --git a/src/cpu/amd/model_10xxx/model_10xxx_init.c b/src/cpu/amd/model_10xxx/model_10xxx_init.c -deleted file mode 100644 -index b942c1a..0000000 ---- a/src/cpu/amd/model_10xxx/model_10xxx_init.c -+++ /dev/null -@@ -1,165 +0,0 @@ --/* -- * This file is part of the coreboot project. -- * -- * Copyright (C) 2007 Advanced Micro Devices, Inc. -- * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -- * -- * 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; version 2 of the License. -- * -- * 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. -- * -- * You should have received a copy of the GNU General Public License -- * along with this program; if not, write to the Free Software -- * Foundation, Inc. -- */ -- --#include <console/console.h> --#include <cpu/x86/msr.h> --#include <cpu/amd/mtrr.h> --#include <device/device.h> --#include <device/pci.h> --#include <string.h> --#include <cpu/x86/msr.h> --#include <cpu/x86/smm.h> --#include <cpu/x86/pae.h> --#include <pc80/mc146818rtc.h> --#include <cpu/x86/lapic.h> --#include "northbridge/amd/amdfam10/amdfam10.h" --#include <cpu/amd/model_10xxx_rev.h> --#include <cpu/cpu.h> --#include <cpu/x86/cache.h> --#include <cpu/x86/mtrr.h> --#include <cpu/amd/multicore.h> --#include <cpu/amd/model_10xxx_msr.h> -- --#define MCI_STATUS 0x401 -- --static void model_10xxx_init(device_t dev) --{ -- u8 i; -- msr_t msr; -- struct node_core_id id; --#if CONFIG_LOGICAL_CPUS -- u32 siblings; --#endif -- -- id = get_node_core_id(read_nb_cfg_54()); /* nb_cfg_54 can not be set */ -- printk(BIOS_DEBUG, "nodeid = %02d, coreid = %02d\n", id.nodeid, id.coreid); -- -- /* Turn on caching if we haven't already */ -- x86_enable_cache(); -- amd_setup_mtrrs(); -- x86_mtrr_check(); -- -- disable_cache(); -- -- /* zero the machine check error status registers */ -- msr.lo = 0; -- msr.hi = 0; -- for (i = 0; i < 5; i++) { -- wrmsr(MCI_STATUS + (i * 4), msr); -- } -- -- enable_cache(); -- -- /* Enable the local cpu apics */ -- setup_lapic(); -- -- /* Set the processor name string */ -- init_processor_name(); -- --#if CONFIG_LOGICAL_CPUS -- siblings = cpuid_ecx(0x80000008) & 0xff; -- -- if (siblings > 0) { -- msr = rdmsr_amd(CPU_ID_FEATURES_MSR); -- msr.lo |= 1 << 28; -- wrmsr_amd(CPU_ID_FEATURES_MSR, msr); -- -- msr = rdmsr_amd(CPU_ID_EXT_FEATURES_MSR); -- msr.hi |= 1 << (33 - 32); -- wrmsr_amd(CPU_ID_EXT_FEATURES_MSR, msr); -- } -- printk(BIOS_DEBUG, "siblings = %02d, ", siblings); --#endif -- -- /* DisableCf8ExtCfg */ -- msr = rdmsr(NB_CFG_MSR); -- msr.hi &= ~(1 << (46 - 32)); -- wrmsr(NB_CFG_MSR, msr); -- -- msr = rdmsr(BU_CFG2_MSR); -- /* Clear ClLinesToNbDis */ -- msr.lo &= ~(1 << 15); -- /* Clear bit 35 as per Erratum 343 */ -- msr.hi &= ~(1 << (35-32)); -- wrmsr(BU_CFG2_MSR, msr); -- -- if (IS_ENABLED(CONFIG_HAVE_SMI_HANDLER)) { -- printk(BIOS_DEBUG, "Initializing SMM ASeg memory\n"); -- -- /* Set SMM base address for this CPU */ -- msr = rdmsr(SMM_BASE_MSR); -- msr.lo = SMM_BASE - (lapicid() * 0x400); -- wrmsr(SMM_BASE_MSR, msr); -- -- /* Enable the SMM memory window */ -- msr = rdmsr(SMM_MASK_MSR); -- msr.lo |= (1 << 0); /* Enable ASEG SMRAM Range */ -- wrmsr(SMM_MASK_MSR, msr); -- } else { -- printk(BIOS_DEBUG, "Disabling SMM ASeg memory\n"); -- -- /* Set SMM base address for this CPU */ -- msr = rdmsr(SMM_BASE_MSR); -- msr.lo = SMM_BASE - (lapicid() * 0x400); -- wrmsr(SMM_BASE_MSR, msr); -- -- /* Disable the SMM memory window */ -- msr.hi = 0x0; -- msr.lo = 0x0; -- wrmsr(SMM_MASK_MSR, msr); -- } -- -- /* Set SMMLOCK to avoid exploits messing with SMM */ -- msr = rdmsr(HWCR_MSR); -- msr.lo |= (1 << 0); -- wrmsr(HWCR_MSR, msr); -- --} -- --static struct device_operations cpu_dev_ops = { -- .init = model_10xxx_init, --}; -- --static struct cpu_device_id cpu_table[] = { --//AMD_GH_SUPPORT -- { X86_VENDOR_AMD, 0x100f00 }, /* SH-F0 L1 */ -- { X86_VENDOR_AMD, 0x100f10 }, /* M2 */ -- { X86_VENDOR_AMD, 0x100f20 }, /* S1g1 */ -- { X86_VENDOR_AMD, 0x100f21 }, -- { X86_VENDOR_AMD, 0x100f2A }, -- { X86_VENDOR_AMD, 0x100f22 }, -- { X86_VENDOR_AMD, 0x100f23 }, -- { X86_VENDOR_AMD, 0x100f40 }, /* RB-C0 */ -- { X86_VENDOR_AMD, 0x100F42 }, /* RB-C2 */ -- { X86_VENDOR_AMD, 0x100F43 }, /* RB-C3 */ -- { X86_VENDOR_AMD, 0x100F52 }, /* BL-C2 */ -- { X86_VENDOR_AMD, 0x100F62 }, /* DA-C2 */ -- { X86_VENDOR_AMD, 0x100F63 }, /* DA-C3 */ -- { X86_VENDOR_AMD, 0x100F80 }, /* HY-D0 */ -- { X86_VENDOR_AMD, 0x100F81 }, /* HY-D1 */ -- { X86_VENDOR_AMD, 0x100F91 }, /* HY-D1 */ -- { X86_VENDOR_AMD, 0x100FA0 }, /* PH-E0 */ -- { 0, 0 }, --}; -- --static const struct cpu_driver model_10xxx __cpu_driver = { -- .ops = &cpu_dev_ops, -- .id_table = cpu_table, --}; -diff --git a/src/cpu/amd/model_10xxx/monotonic_timer.c b/src/cpu/amd/model_10xxx/monotonic_timer.c -deleted file mode 100644 -index 8c02fd1..0000000 ---- a/src/cpu/amd/model_10xxx/monotonic_timer.c -+++ /dev/null -@@ -1,98 +0,0 @@ --/* -- * This file is part of the coreboot project. -- * -- * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -- * Copyright (C) 2013 Google, Inc. -- * -- * 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; version 2 of the License. -- * -- * 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. -- * -- * You should have received a copy of the GNU General Public License -- * along with this program; if not, write to the Free Software -- * Foundation, Inc. -- */ --#include <stdint.h> --#include <arch/cpu.h> --#include <cpu/x86/msr.h> --#include <timer.h> --#include <device/pci.h> --#include <device/pci_ids.h> -- --#include <northbridge/amd/amdht/AsPsDefs.h> --#include <cpu/amd/model_10xxx_msr.h> -- --static struct monotonic_counter { -- int initialized; -- uint32_t core_frequency; -- struct mono_time time; -- uint64_t last_value; --} mono_counter; -- --static inline uint64_t read_counter_msr(void) --{ -- msr_t counter_msr; -- -- counter_msr = rdmsr(TSC_MSR); -- -- return ((uint64_t)counter_msr.hi << 32) | (uint64_t)counter_msr.lo; --} -- --static void init_timer(void) --{ -- uint8_t model; -- uint32_t cpuid_fms; -- uint8_t cpufid; -- uint8_t cpudid; -- uint8_t boost_capable = 0; -- -- /* Get CPU model */ -- cpuid_fms = cpuid_eax(0x80000001); -- model = ((cpuid_fms & 0xf0000) >> 16) | ((cpuid_fms & 0xf0) >> 4); -- -- /* Get boost capability */ -- if ((model == 0x8) || (model == 0x9)) { /* revision D */ -- boost_capable = (pci_read_config32(dev_find_slot(0, PCI_DEVFN(0x18, 4)), 0x15c) & 0x4) >> 2; -- } -- -- /* Set up TSC (BKDG v3.62 section 2.9.4)*/ -- msr_t msr = rdmsr(HWCR_MSR); -- msr.lo |= 0x1000000; -- wrmsr(HWCR_MSR, msr); -- -- /* Get core Pstate 0 frequency in MHz */ -- msr = rdmsr(0xC0010064 + boost_capable); -- cpufid = (msr.lo & 0x3f); -- cpudid = (msr.lo & 0x1c0) >> 6; -- mono_counter.core_frequency = (100 * (cpufid + 0x10)) / (0x01 << cpudid); -- -- mono_counter.last_value = read_counter_msr(); -- mono_counter.initialized = 1; --} -- --void timer_monotonic_get(struct mono_time *mt) --{ -- uint64_t current_tick; -- uint32_t usecs_elapsed = 0; -- -- if (!mono_counter.initialized) -- init_timer(); -- -- current_tick = read_counter_msr(); -- if (mono_counter.core_frequency != 0) -- usecs_elapsed = (current_tick - mono_counter.last_value) / mono_counter.core_frequency; -- -- /* Update current time and tick values only if a full tick occurred. */ -- if (usecs_elapsed) { -- mono_time_add_usecs(&mono_counter.time, usecs_elapsed); -- mono_counter.last_value = current_tick; -- } -- -- /* Save result. */ -- *mt = mono_counter.time; --} -diff --git a/src/cpu/amd/model_10xxx/powernow_acpi.c b/src/cpu/amd/model_10xxx/powernow_acpi.c -deleted file mode 100644 -index 98ef08a..0000000 ---- a/src/cpu/amd/model_10xxx/powernow_acpi.c -+++ /dev/null -@@ -1,311 +0,0 @@ --/* -- * This file is part of the coreboot project. -- * -- * Copyright (C) 2007-2008 Advanced Micro Devices, Inc. -- * Copyright (C) 2009 Rudolf Marek <r.marek@assembler.cz> -- * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -- * -- * 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; version 2 of the License. -- * -- * 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. -- * -- * You should have received a copy of the GNU General Public License -- * along with this program; if not, write to the Free Software -- * Foundation, Inc. -- */ -- --#include <console/console.h> --#include <stdint.h> --#include <cpu/x86/msr.h> --#include <arch/acpigen.h> --#include <cpu/amd/powernow.h> --#include <device/pci.h> --#include <device/pci_ids.h> --#include <cpu/x86/msr.h> --#include <cpu/amd/mtrr.h> --#include <cpu/amd/amdfam10_sysconf.h> --#include <arch/cpu.h> --#include <northbridge/amd/amdht/AsPsDefs.h> --#include <northbridge/amd/amdmct/mct/mct.h> --#include <northbridge/amd/amdmct/amddefs.h> -- --static void write_pstates_for_core(u8 pstate_num, u16 *pstate_feq, u32 *pstate_power, -- u32 *pstate_latency, u32 *pstate_control, -- u32 *pstate_status, int coreID, -- u32 pcontrol_blk, u8 plen, u8 onlyBSP, -- uint8_t single_link) --{ -- int i; -- struct cpuid_result cpuid1; -- -- if ((onlyBSP) && (coreID != 0)) { -- plen = 0; -- pcontrol_blk = 0; -- } -- -- acpigen_write_processor(coreID, pcontrol_blk, plen); -- acpigen_write_empty_PCT(); -- acpigen_write_name("_PSS"); -- -- /* add later to total sum */ -- acpigen_write_package(pstate_num); -- -- for (i = 0;i < pstate_num; i++) -- acpigen_write_PSS_package(pstate_feq[i], -- pstate_power[i], -- pstate_latency[i], -- pstate_latency[i], -- pstate_control[i], -- pstate_status[i]); -- -- /* update the package size */ -- acpigen_pop_len(); -- -- /* Write PPC object */ -- acpigen_write_PPC(pstate_num); -- -- /* Write PSD indicating coordination type */ -- if ((single_link) && (mctGetLogicalCPUID(0) & AMD_DR_GT_Bx)) { -- /* Revision C or greater single-link processor */ -- cpuid1 = cpuid(0x80000008); -- acpigen_write_PSD_package(0, (cpuid1.ecx & 0xff) + 1, SW_ALL); -- } -- else { -- /* Find the local APIC ID for the specified core ID */ -- struct device* cpu; -- int cpu_index = 0; -- for (cpu = all_devices; cpu; cpu = cpu->next) { -- if ((cpu->path.type != DEVICE_PATH_APIC) || -- (cpu->bus->dev->path.type != DEVICE_PATH_CPU_CLUSTER)) -- continue; -- if (!cpu->enabled) -- continue; -- if (cpu_index == coreID) -- break; -- cpu_index++; -- } -- -- if (cpu) -- acpigen_write_PSD_package(cpu->path.apic.apic_id, 1, SW_ANY); -- } -- -- /* patch the whole Processor token length */ -- acpigen_pop_len(); --} -- --/* --* For details of this algorithm, please refer to the BDKG 3.62 page 69 --* --* WARNING: The core count algorithm below assumes that all processors --* are identical, with the same number of active cores. While the BKDG --* states the BIOS must enforce this coreboot does not currently do so. --* As a result it is possible that this code may break if an illegal --* processor combination is installed. If it does break please fix the --* code in the proper locations! --*/ --void amd_generate_powernow(u32 pcontrol_blk, u8 plen, u8 onlyBSP) --{ -- u8 processor_brand[49]; -- u32 *v; -- struct cpuid_result cpuid1; -- -- u16 Pstate_feq[10]; -- u32 Pstate_power[10]; -- u32 Pstate_latency[10]; -- u32 Pstate_control[10]; -- u32 Pstate_status[10]; -- u8 Pstate_num; -- u8 cmp_cap; -- u8 index; -- msr_t msr; -- -- /* Get the Processor Brand String using cpuid(0x8000000x) command x=2,3,4 */ -- cpuid1 = cpuid(0x80000002); -- v = (u32 *) processor_brand; -- v[0] = cpuid1.eax; -- v[1] = cpuid1.ebx; -- v[2] = cpuid1.ecx; -- v[3] = cpuid1.edx; -- cpuid1 = cpuid(0x80000003); -- v[4] = cpuid1.eax; -- v[5] = cpuid1.ebx; -- v[6] = cpuid1.ecx; -- v[7] = cpuid1.edx; -- cpuid1 = cpuid(0x80000004); -- v[8] = cpuid1.eax; -- v[9] = cpuid1.ebx; -- v[10] = cpuid1.ecx; -- v[11] = cpuid1.edx; -- processor_brand[48] = 0; -- printk(BIOS_INFO, "processor_brand=%s\n", processor_brand); -- -- uint32_t dtemp; -- uint8_t node_index; -- uint8_t node_count; -- uint8_t cores_per_node; -- uint8_t total_core_count; -- -- /* -- * Based on the CPU socket type,cmp_cap and pwr_lmt , get the power limit. -- * socket_type : 0x10 SocketF; 0x11 AM2/ASB1 ; 0x12 S1G1 -- * cmp_cap : 0x0 SingleCore ; 0x1 DualCore ; 0x2 TripleCore ; 0x3 QuadCore ; 0x4 QuintupleCore ; 0x5 HexCore -- */ -- printk(BIOS_INFO, "Pstates algorithm ...\n"); -- /* Get number of cores */ -- dtemp = pci_read_config32(dev_find_slot(0, PCI_DEVFN(0x18, 3)), 0xE8); -- cmp_cap = (dtemp & 0x3000) >> 12; -- if (mctGetLogicalCPUID(0) & AMD_FAM10_REV_D) /* revision D */ -- cmp_cap |= (dtemp & 0x8000) >> 13; -- /* Get number of nodes */ -- dtemp = pci_read_config32(dev_find_slot(0, PCI_DEVFN(0x18, 0)), 0x60); -- node_count = ((dtemp & 0x70) >> 4) + 1; -- cores_per_node = cmp_cap + 1; -- -- /* Compute total number of cores installed in system */ -- total_core_count = cores_per_node * node_count; -- -- Pstate_num = 0; -- -- /* See if the CPUID(0x80000007) returned EDX[7]==1b */ -- cpuid1 = cpuid(0x80000007); -- if ((cpuid1.edx & 0x80) != 0x80) { -- printk(BIOS_INFO, "No valid set of P-states\n"); -- return; -- } -- -- uint8_t pviModeFlag; -- uint8_t Pstate_max; -- uint8_t cpufid; -- uint8_t cpudid; -- uint8_t cpuvid; -- uint8_t cpuidd; -- uint8_t cpuidv; -- uint8_t power_step_up; -- uint8_t power_step_down; -- uint8_t pll_lock_time; -- uint32_t expanded_cpuidv; -- uint32_t core_frequency; -- uint32_t core_power; -- uint32_t core_latency; -- uint32_t core_voltage; /* multiplied by 10000 */ -- uint8_t single_link; -- -- /* Determine if this is a PVI or SVI system */ -- dtemp = pci_read_config32(dev_find_slot(0, PCI_DEVFN(0x18, 3)), 0xA0); -- -- if (dtemp & PVI_MODE) -- pviModeFlag = 1; -- else -- pviModeFlag = 0; -- -- /* Get PSmax's index */ -- msr = rdmsr(0xC0010061); -- Pstate_max = (uint8_t) ((msr.lo >> PS_MAX_VAL_SHFT) & BIT_MASK_3); -- -- /* Determine if all enabled Pstates have the same fidvid */ -- uint8_t i; -- uint8_t cpufid_prev = (rdmsr(0xC0010064).lo & 0x3f); -- uint8_t all_enabled_cores_have_same_cpufid = 1; -- for (i = 1; i < Pstate_max; i++) { -- cpufid = rdmsr(0xC0010064 + i).lo & 0x3f; -- if (cpufid != cpufid_prev) { -- all_enabled_cores_have_same_cpufid = 0; -- break; -- } -- } -- -- /* Populate tables with all Pstate information */ -- for (Pstate_num = 0; Pstate_num < Pstate_max; Pstate_num++) { -- /* Get power state information */ -- msr = rdmsr(0xC0010064 + Pstate_num); -- cpufid = (msr.lo & 0x3f); -- cpudid = (msr.lo & 0x1c0) >> 6; -- cpuvid = (msr.lo & 0xfe00) >> 9; -- cpuidd = (msr.hi & 0xff); -- cpuidv = (msr.hi & 0x300) >> 8; -- core_frequency = (100 * (cpufid + 0x10)) / (0x01 << cpudid); -- if (pviModeFlag) { -- if (cpuvid >= 0x20) { -- core_voltage = 7625 - (((cpuvid - 0x20) * 10000) / 80); -- } -- else { -- core_voltage = 15500 - ((cpuvid * 10000) / 40); -- } -- } -- else { -- cpuvid = cpuvid & 0x7f; -- if (cpuvid >= 0x7c) -- core_voltage = 0; -- else -- core_voltage = 15500 - ((cpuvid * 10000) / 80); -- } -- switch (cpuidv) { -- case 0x0: -- expanded_cpuidv = 1; -- break; -- case 0x1: -- expanded_cpuidv = 10; -- break; -- case 0x2: -- expanded_cpuidv = 100; -- break; -- case 0x3: -- expanded_cpuidv = 1000; -- break; -- default: -- printk(BIOS_ERR, "%s:%s:%d: Invalid cpuidv, " -- "not generating pstate tables.\n", -- __FILE__, __func__, __LINE__); -- return; -- } -- core_power = (core_voltage * cpuidd) / (expanded_cpuidv * 10); -- -- /* Calculate transition latency */ -- dtemp = pci_read_config32(dev_find_slot(0, PCI_DEVFN(0x18, 3)), 0xD4); -- power_step_up = (dtemp & 0xf000000) >> 24; -- power_step_down = (dtemp & 0xf00000) >> 20; -- dtemp = pci_read_config32(dev_find_slot(0, PCI_DEVFN(0x18, 3)), 0xA0); -- pll_lock_time = (dtemp & 0x3800) >> 11; -- if (all_enabled_cores_have_same_cpufid) -- core_latency = ((12 * power_step_down) + power_step_up) / 1000; -- else -- core_latency = (12 * (power_step_down + power_step_up) / 1000) -- + pll_lock_time; -- -- Pstate_feq[Pstate_num] = core_frequency; -- Pstate_power[Pstate_num] = core_power; -- Pstate_latency[Pstate_num] = core_latency; -- Pstate_control[Pstate_num] = Pstate_num; -- Pstate_status[Pstate_num] = Pstate_num; -- } -- -- /* Print Pstate frequency, power, and latency */ -- for (index = 0; index < Pstate_num; index++) { -- printk(BIOS_INFO, "Pstate_freq[%d] = %dMHz\t", index, -- Pstate_feq[index]); -- printk(BIOS_INFO, "Pstate_power[%d] = %dmw\n", index, -- Pstate_power[index]); -- printk(BIOS_INFO, "Pstate_latency[%d] = %dus\n", index, -- Pstate_latency[index]); -- } -- -- char pscope[] = "\\_PR"; -- -- acpigen_write_scope(pscope); -- for (index = 0; index < total_core_count; index++) { -- /* Determine if this is a single-link processor */ -- node_index = 0x18 + (index / cores_per_node); -- dtemp = pci_read_config32(dev_find_slot(0, PCI_DEVFN(node_index, 0)), 0x80); -- single_link = !!(((dtemp & 0xff00) >> 8) == 0); -- -- write_pstates_for_core(Pstate_num, Pstate_feq, Pstate_power, -- Pstate_latency, Pstate_control, Pstate_status, -- index, pcontrol_blk, plen, onlyBSP, single_link); -- } -- acpigen_pop_len(); --} -diff --git a/src/cpu/amd/model_10xxx/processor_name.c b/src/cpu/amd/model_10xxx/processor_name.c -deleted file mode 100644 -index 12c45c9..0000000 ---- a/src/cpu/amd/model_10xxx/processor_name.c -+++ /dev/null -@@ -1,323 +0,0 @@ --/* -- * This file is part of the coreboot project. -- * -- * Copyright (C) 2007 Advanced Micro Devices, Inc. -- * Copyright (C) 2008 Peter Stuge -- * Copyright (C) 2010 Marc Jones <marcj303@gmail.com> -- * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -- * -- * 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; version 2 of the License. -- * -- * 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. -- * -- * You should have received a copy of the GNU General Public License -- * along with this program; if not, write to the Free Software -- * Foundation, Inc. -- */ -- --/* -- * This code sets the Processor Name String for AMD64 CPUs. -- * -- * Revision Guide for AMD Family 10h Processors -- * Publication # 41322 Revision: 3.17 Issue Date: February 2008 -- */ -- --#include <console/console.h> --#include <string.h> --#include <cpu/x86/msr.h> --#include <cpu/amd/mtrr.h> --#include <cpu/cpu.h> --#include <cpu/amd/model_10xxx_rev.h> -- --/* The maximum length of CPU names is 48 bytes, including the final NULL byte. -- * If you change these names your BIOS will _NOT_ pass the AMD validation and -- * your mainboard will not be posted on the AMD Recommended Motherboard Website -- */ -- --struct str_s { -- u8 Pg; -- u8 NC; -- u8 String; -- char const *value; --}; -- -- --static const struct str_s String1_socket_F[] = { -- {0x00, 0x01, 0x00, "Dual-Core AMD Opteron(tm) Processor 83"}, -- {0x00, 0x01, 0x01, "Dual-Core AMD Opteron(tm) Processor 23"}, -- {0x00, 0x03, 0x00, "Quad-Core AMD Opteron(tm) Processor 83"}, -- {0x00, 0x03, 0x01, "Quad-Core AMD Opteron(tm) Processor 23"}, -- {0x00, 0x05, 0x00, "Six-Core AMD Opteron(tm) Processor 84"}, -- {0x00, 0x05, 0x01, "Six-Core AMD Opteron(tm) Processor 24"}, -- {0x00, 0x03, 0x02, "Embedded AMD Opteron(tm) Processor 83"}, -- {0x00, 0x03, 0x03, "Embedded AMD Opteron(tm) Processor 23"}, -- {0x00, 0x03, 0x04, "Embedded AMD Opteron(tm) Processor 13"}, -- {0x00, 0x03, 0x05, "AMD Phenom(tm) FX-"}, -- {0x01, 0x01, 0x01, "Embedded AMD Opteron(tm) Processor"}, -- {0, 0, 0, NULL} --}; -- --static const struct str_s String2_socket_F[] = { -- {0x00, 0xFF, 0x02, " EE"}, -- {0x00, 0xFF, 0x0A, " SE"}, -- {0x00, 0xFF, 0x0B, " HE"}, -- {0x00, 0xFF, 0x0C, " EE"}, -- {0x00, 0xFF, 0x0D, " Quad-Core Processor"}, -- {0x00, 0xFF, 0x0F, ""}, -- {0x01, 0x01, 0x01, "GF HE"}, -- {0, 0, 0, NULL} --}; -- -- --static const struct str_s String1_socket_AM2[] = { -- {0x00, 0x00, 0x00, "AMD Athlon(tm) Processor LE-"}, -- {0x00, 0x00, 0x01, "AMD Sempron(tm) Processor LE-"}, -- {0x00, 0x00, 0x02, "AMD Sempron(tm) 1"}, -- {0x00, 0x00, 0x03, "AMD Athlon(tm) II 1"}, -- {0x00, 0x01, 0x00, "Dual-Core AMD Opteron(tm) Processor 13"}, -- {0x00, 0x01, 0x01, "AMD Athlon(tm)"}, -- {0x00, 0x01, 0x03, "AMD Athlon(tm) II X2 2"}, -- {0x00, 0x01, 0x04, "AMD Athlon(tm) II X2 B"}, -- {0x00, 0x01, 0x05, "AMD Athlon(tm) II X2"}, -- {0x00, 0x01, 0x07, "AMD Phenom(tm) II X2 5"}, -- {0x00, 0x01, 0x0A, "AMD Phenom(tm) II X2"}, -- {0x00, 0x01, 0x0B, "AMD Phenom(tm) II X2 B"}, -- {0x00, 0x02, 0x00, "AMD Phenom(tm)"}, -- {0x00, 0x02, 0x03, "AMD Phenom(tm) II X3 B"}, -- {0x00, 0x02, 0x04, "AMD Phenom(tm) II X3"}, -- {0x00, 0x02, 0x07, "AMD Athlon(tm) II X3 4"}, -- {0x00, 0x02, 0x08, "AMD Phenom(tm) II X3 7"}, -- {0x00, 0x02, 0x0A, "AMD Athlon(tm) II X3"}, -- {0x00, 0x03, 0x00, "Quad-Core AMD Opteron(tm) Processor 13"}, -- {0x00, 0x03, 0x01, "AMD Phenom(tm) FX-"}, -- {0x00, 0x03, 0x02, "AMD Phenom(tm)"}, -- {0x00, 0x03, 0x03, "AMD Phenom(tm) II X4 9"}, -- {0x00, 0x03, 0x04, "AMD Phenom(tm) II X4 8"}, -- {0x00, 0x03, 0x07, "AMD Phenom(tm) II X4 B"}, -- {0x00, 0x03, 0x08, "AMD Phenom(tm) II X4"}, -- {0x00, 0x03, 0x0A, "AMD Athlon(tm) II X4 6"}, -- {0x00, 0x03, 0x0F, "AMD Athlon(tm) II X4"}, -- {0, 0, 0, NULL} --}; -- --static const struct str_s String2_socket_AM2[] = { -- {0x00, 0x00, 0x00, "00"}, -- {0x00, 0x00, 0x01, "10"}, -- {0x00, 0x00, 0x02, "20"}, -- {0x00, 0x00, 0x03, "30"}, -- {0x00, 0x00, 0x04, "40"}, -- {0x00, 0x00, 0x05, "50"}, -- {0x00, 0x00, 0x06, "60"}, -- {0x00, 0x00, 0x07, "70"}, -- {0x00, 0x00, 0x08, "80"}, -- {0x00, 0x00, 0x09, "90"}, -- {0x00, 0x00, 0x09, " Processor"}, -- {0x00, 0x00, 0x09, "u Processor"}, -- {0x00, 0x01, 0x00, "00 Dual-Core Processor"}, -- {0x00, 0x01, 0x01, "00e Dual-Core Processor"}, -- {0x00, 0x01, 0x02, "00B Dual-Core Processor"}, -- {0x00, 0x01, 0x03, "50 Dual-Core Processor"}, -- {0x00, 0x01, 0x04, "50e Dual-Core Processor"}, -- {0x00, 0x01, 0x05, "50B Dual-Core Processor"}, -- {0x00, 0x01, 0x06, " Processor"}, -- {0x00, 0x01, 0x07, "e Processor"}, -- {0x00, 0x01, 0x09, "0 Processor"}, -- {0x00, 0x01, 0x0A, "0e Processor"}, -- {0x00, 0x01, 0x0B, "u Processor"}, -- {0x00, 0x02, 0x00, "00 Triple-Core Processor"}, -- {0x00, 0x02, 0x01, "00e Triple-Core Processor"}, -- {0x00, 0x02, 0x02, "00B Triple-Core Processor"}, -- {0x00, 0x02, 0x03, "50 Triple-Core Processor"}, -- {0x00, 0x02, 0x04, "50e Triple-Core Processor"}, -- {0x00, 0x02, 0x05, "50B Triple-Core Processor"}, -- {0x00, 0x02, 0x06, " Processor"}, -- {0x00, 0x02, 0x07, "e Processor"}, -- {0x00, 0x02, 0x09, "0e Processor"}, -- {0x00, 0x02, 0x0A, "0 Processor"}, -- {0x00, 0x03, 0x00, "00 Quad-Core Processor"}, -- {0x00, 0x03, 0x01, "00e Quad-Core Processor"}, -- {0x00, 0x03, 0x02, "00B Quad-Core Processor"}, -- {0x00, 0x03, 0x03, "50 Quad-Core Processor"}, -- {0x00, 0x03, 0x04, "50e Quad-Core Processor"}, -- {0x00, 0x03, 0x05, "50B Quad-Core Processor"}, -- {0x00, 0x03, 0x06, " Processor"}, -- {0x00, 0x03, 0x07, "e Processor"}, -- {0x00, 0x03, 0x09, "0e Processor"}, -- {0x00, 0x03, 0x0A, " SE"}, -- {0x00, 0x03, 0x0B, " HE"}, -- {0x00, 0x03, 0x0C, " EE"}, -- {0x00, 0x03, 0x0D, " Quad-Core Processor"}, -- {0x00, 0x03, 0x0E, "0 Processor"}, -- {0x00, 0xFF, 0x0F, ""}, -- {0, 0, 0, NULL} --}; -- --static const struct str_s String1_socket_G34[] = { -- {0x00, 0x07, 0x00, "AMD Opteron(tm) Processor 61"}, -- {0x00, 0x0B, 0x00, "AMD Opteron(tm) Processor 61"}, -- {0x01, 0x07, 0x01, "Embedded AMD Opteron(tm) Processor "}, -- {0, 0, 0, NULL} --}; -- --static const struct str_s String2_socket_G34[] = { -- {0x00, 0x07, 0x00, " HE"}, -- {0x00, 0x07, 0x01, " SE"}, -- {0x00, 0x0B, 0x00, " HE"}, -- {0x00, 0x0B, 0x01, " SE"}, -- {0x00, 0x0B, 0x0F, ""}, -- {0x01, 0x07, 0x01, " QS"}, -- {0x01, 0x07, 0x02, " KS"}, -- {0, 0, 0, NULL} --}; -- --static const struct str_s String1_socket_C32[] = { -- {0x00, 0x03, 0x00, "AMD Opteron(tm) Processor 41"}, -- {0x00, 0x05, 0x00, "AMD Opteron(tm) Processor 41"}, -- {0x01, 0x03, 0x01, "Embedded AMD Opteron(tm) Processor "}, -- {0x01, 0x05, 0x01, "Embedded AMD Opteron(tm) Processor "}, -- {0, 0, 0, NULL} --}; -- --static const struct str_s String2_socket_C32[] = { -- {0x00, 0x03, 0x00, " HE"}, -- {0x00, 0x03, 0x01, " EE"}, -- {0x00, 0x05, 0x00, " HE"}, -- {0x00, 0x05, 0x01, " EE"}, -- {0x01, 0x03, 0x01, "QS HE"}, -- {0x01, 0x03, 0x02, "LE HE"}, -- {0x01, 0x05, 0x01, "KX HE"}, -- {0x01, 0x05, 0x02, "GL EE"}, -- {0, 0, 0, NULL} --}; -- --const char *unknown = "AMD Processor model unknown"; --const char *unknown2 = " type unknown"; --const char *sample = "AMD Engineering Sample"; --const char *thermal = "AMD Thermal Test Kit"; -- -- --static int strcpymax(char *dst, const char *src, int buflen) --{ -- int i; -- for (i = 0; i < buflen && src[i]; i++) -- dst[i] = src[i]; -- if (i >= buflen) -- i--; -- dst[i] = 0; -- return i; --} -- -- --int init_processor_name(void) --{ -- /* variable names taken from fam10 revision guide for clarity */ -- u32 BrandId; /* CPUID Fn8000_0001_EBX */ -- u8 String1; /* BrandID[14:11] */ -- u8 String2; /* BrandID[3:0] */ -- u8 Model; /* BrandID[10:4] */ -- u8 Pg; /* BrandID[15] */ -- u8 PkgTyp; /* BrandID[31:28] */ -- u8 NC; /* CPUID Fn8000_0008_ECX */ -- const char *processor_name_string = unknown; -- char program_string[48]; -- u32 *p_program_string = (u32 *)program_string; -- msr_t msr; -- int i, j = 0, str2_checkNC = 1; -- const struct str_s *str, *str2; -- -- -- /* Find out which CPU brand it is */ -- BrandId = cpuid_ebx(0x80000001); -- String1 = (u8)((BrandId >> 11) & 0x0F); -- String2 = (u8)((BrandId >> 0) & 0x0F); -- Model = (u8)((BrandId >> 4) & 0x7F); -- Pg = (u8)((BrandId >> 15) & 0x01); -- PkgTyp = (u8)((BrandId >> 28) & 0x0F); -- NC = (u8)(cpuid_ecx(0x80000008) & 0xFF); -- -- /* null the string */ -- memset(program_string, 0, sizeof(program_string)); -- -- if (!Model) { -- processor_name_string = Pg ? thermal : sample; -- goto done; -- } -- -- switch (PkgTyp) { -- case 0: /* F1207 */ -- str = String1_socket_F; -- str2 = String2_socket_F; -- str2_checkNC = 0; -- break; -- case 1: /* AM2 */ -- str = String1_socket_AM2; -- str2 = String2_socket_AM2; -- break; -- case 3: /* G34 */ -- str = String1_socket_G34; -- str2 = String2_socket_G34; -- str2_checkNC = 0; -- break; -- case 5: /* C32 */ -- str = String1_socket_C32; -- str2 = String2_socket_C32; -- break; -- default: -- goto done; -- } -- -- /* String1 */ -- for (i = 0; str[i].value; i++) { -- if ((str[i].Pg == Pg) && -- (str[i].NC == NC) && -- (str[i].String == String1)) { -- processor_name_string = str[i].value; -- break; -- } -- } -- -- if (!str[i].value) -- goto done; -- -- j = strcpymax(program_string, processor_name_string, -- sizeof(program_string)); -- -- /* Translate Model from 01-99 to ASCII and put it on the end. -- * Numbers less than 10 should include a leading zero, e.g., 09.*/ -- if (Model < 100 && j < sizeof(program_string) - 2) { -- program_string[j++] = (Model / 10) + '0'; -- program_string[j++] = (Model % 10) + '0'; -- } -- -- processor_name_string = unknown2; -- -- /* String 2 */ -- for(i = 0; str2[i].value; i++) { -- if ((str2[i].Pg == Pg) && -- ((str2[i].NC == NC) || !str2_checkNC) && -- (str2[i].String == String2)) { -- processor_name_string = str2[i].value; -- break; -- } -- } -- -- --done: -- strcpymax(&program_string[j], processor_name_string, -- sizeof(program_string) - j); -- -- printk(BIOS_DEBUG, "CPU model: %s\n", program_string); -- -- for (i = 0; i < 6; i++) { -- msr.lo = p_program_string[(2 * i) + 0]; -- msr.hi = p_program_string[(2 * i) + 1]; -- wrmsr_amd(0xC0010030 + i, msr); -- } -- -- return 0; --} -diff --git a/src/cpu/amd/model_10xxx/ram_calc.c b/src/cpu/amd/model_10xxx/ram_calc.c -deleted file mode 100644 -index 46ccdbd..0000000 ---- a/src/cpu/amd/model_10xxx/ram_calc.c -+++ /dev/null -@@ -1,54 +0,0 @@ --/* -- * This file is part of the coreboot project. -- * -- * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -- * Copyright (C) 2007 Advanced Micro Devices, Inc. -- * -- * 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; version 2 of the License. -- * -- * 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. -- * -- * You should have received a copy of the GNU General Public License -- * along with this program; if not, write to the Free Software -- * Foundation, Inc. -- */ -- --#include <cpu/cpu.h> --#include <cpu/x86/msr.h> --#include <cpu/amd/mtrr.h> -- --#include <cbmem.h> -- --#include "ram_calc.h" -- --#if !IS_ENABLED(CONFIG_LATE_CBMEM_INIT) --uint64_t get_uma_memory_size(uint64_t topmem) --{ -- uint64_t uma_size = 0; -- if (IS_ENABLED(CONFIG_GFXUMA)) { -- /* refer to UMA Size Consideration in 780 BDG. */ -- if (topmem >= 0x40000000) /* 1GB and above system memory */ -- uma_size = 0x10000000; /* 256M recommended UMA */ -- -- else if (topmem >= 0x20000000) /* 512M - 1023M system memory */ -- uma_size = 0x8000000; /* 128M recommended UMA */ -- -- else if (topmem >= 0x10000000) /* 256M - 511M system memory */ -- uma_size = 0x4000000; /* 64M recommended UMA */ -- } -- -- return uma_size; --} -- --void *cbmem_top(void) --{ -- uint32_t topmem = rdmsr(TOP_MEM).lo; -- -- return (void *) topmem - get_uma_memory_size(topmem); --} --#endif -diff --git a/src/cpu/amd/model_10xxx/ram_calc.h b/src/cpu/amd/model_10xxx/ram_calc.h -deleted file mode 100644 -index 61da328..0000000 ---- a/src/cpu/amd/model_10xxx/ram_calc.h -+++ /dev/null -@@ -1,25 +0,0 @@ --/* -- * This file is part of the coreboot project. -- * -- * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -- * -- * 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; version 2 of the License. -- * -- * 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. -- * -- * You should have received a copy of the GNU General Public License -- * along with this program; if not, write to the Free Software -- * Foundation, Inc. -- */ -- --#ifndef _AMD_MODEL_10XXX_RAM_CALC_H_ --#define _AMD_MODEL_10XXX_RAM_CALC_H_ -- --uint64_t get_uma_memory_size(uint64_t topmem); -- --#endif -diff --git a/src/cpu/amd/model_10xxx/update_microcode.c b/src/cpu/amd/model_10xxx/update_microcode.c -deleted file mode 100644 -index 51aca35..0000000 ---- a/src/cpu/amd/model_10xxx/update_microcode.c -+++ /dev/null -@@ -1,71 +0,0 @@ --/* -- * This file is part of the coreboot project. -- * -- * Copyright (C) 2015 Timothy Pearson <tpearson@raptorengineeringinc.com>, Raptor Engineering -- * Copyright (C) 2007 Advanced Micro Devices, Inc. -- * -- * 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; version 2 of the License. -- * -- * 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. -- * -- * You should have received a copy of the GNU General Public License -- * along with this program; if not, write to the Free Software -- * Foundation, Inc. -- */ -- --#include <stdint.h> --#include <cpu/amd/microcode.h> -- --struct id_mapping { -- uint32_t orig_id; -- uint16_t new_id; --}; -- --static u16 get_equivalent_processor_rev_id(u32 orig_id) { -- static const struct id_mapping id_mapping_table[] = { -- { 0x100f00, 0x1000 }, -- { 0x100f01, 0x1000 }, -- { 0x100f02, 0x1000 }, -- { 0x100f20, 0x1020 }, -- { 0x100f21, 0x1020 }, /* DR-B1 */ -- { 0x100f2A, 0x1020 }, /* DR-BA */ -- { 0x100f22, 0x1022 }, /* DR-B2 */ -- { 0x100f23, 0x1022 }, /* DR-B3 */ -- { 0x100f42, 0x1041 }, /* RB-C2 */ -- { 0x100f43, 0x1043 }, /* RB-C3 */ -- { 0x100f52, 0x1041 }, /* BL-C2 */ -- { 0x100f62, 0x1062 }, /* DA-C2 */ -- { 0x100f63, 0x1043 }, /* DA-C3 */ -- { 0x100f81, 0x1081 }, /* HY-D1 */ -- { 0x100fa0, 0x10A0 }, /* PH-E0 */ -- -- /* Array terminator */ -- { 0xffffff, 0x0000 }, -- }; -- -- u32 new_id; -- int i; -- -- new_id = 0; -- -- for (i = 0; id_mapping_table[i].orig_id != 0xffffff; i++) { -- if (id_mapping_table[i].orig_id == orig_id) { -- new_id = id_mapping_table[i].new_id; -- break; -- } -- } -- -- return new_id; -- --} -- --void update_microcode(u32 cpu_deviceid) --{ -- u32 equivalent_processor_rev_id = get_equivalent_processor_rev_id(cpu_deviceid); -- amd_update_microcode_from_cbfs(equivalent_processor_rev_id); --} -diff --git a/src/cpu/amd/socket_AM2r2/Makefile.inc b/src/cpu/amd/socket_AM2r2/Makefile.inc -index 3675af4..6917441 100644 ---- a/src/cpu/amd/socket_AM2r2/Makefile.inc -+++ b/src/cpu/amd/socket_AM2r2/Makefile.inc -@@ -1,4 +1,4 @@ --subdirs-y += ../model_10xxx -+subdirs-y += ../family_10h-family_15h - subdirs-y += ../quadcore - subdirs-y += ../mtrr - subdirs-y += ../microcode -diff --git a/src/cpu/amd/socket_AM3/Makefile.inc b/src/cpu/amd/socket_AM3/Makefile.inc -index 3675af4..6917441 100644 ---- a/src/cpu/amd/socket_AM3/Makefile.inc -+++ b/src/cpu/amd/socket_AM3/Makefile.inc -@@ -1,4 +1,4 @@ --subdirs-y += ../model_10xxx -+subdirs-y += ../family_10h-family_15h - subdirs-y += ../quadcore - subdirs-y += ../mtrr - subdirs-y += ../microcode -diff --git a/src/cpu/amd/socket_ASB2/Makefile.inc b/src/cpu/amd/socket_ASB2/Makefile.inc -index 3675af4..6917441 100644 ---- a/src/cpu/amd/socket_ASB2/Makefile.inc -+++ b/src/cpu/amd/socket_ASB2/Makefile.inc -@@ -1,4 +1,4 @@ --subdirs-y += ../model_10xxx -+subdirs-y += ../family_10h-family_15h - subdirs-y += ../quadcore - subdirs-y += ../mtrr - subdirs-y += ../microcode -diff --git a/src/cpu/amd/socket_C32/Makefile.inc b/src/cpu/amd/socket_C32/Makefile.inc -index 3675af4..6917441 100644 ---- a/src/cpu/amd/socket_C32/Makefile.inc -+++ b/src/cpu/amd/socket_C32/Makefile.inc -@@ -1,4 +1,4 @@ --subdirs-y += ../model_10xxx -+subdirs-y += ../family_10h-family_15h - subdirs-y += ../quadcore - subdirs-y += ../mtrr - subdirs-y += ../microcode -diff --git a/src/cpu/amd/socket_F_1207/Makefile.inc b/src/cpu/amd/socket_F_1207/Makefile.inc -index b74862e..ece8d9a 100644 ---- a/src/cpu/amd/socket_F_1207/Makefile.inc -+++ b/src/cpu/amd/socket_F_1207/Makefile.inc -@@ -1,4 +1,4 @@ --subdirs-y += ../model_10xxx -+subdirs-y += ../family_10h-family_15h - subdirs-y += ../quadcore - subdirs-y += ../mtrr - subdirs-y += ../microcode -diff --git a/src/cpu/amd/socket_G34/Makefile.inc b/src/cpu/amd/socket_G34/Makefile.inc -index a8e1333..de33cd3 100644 ---- a/src/cpu/amd/socket_G34/Makefile.inc -+++ b/src/cpu/amd/socket_G34/Makefile.inc -@@ -1,5 +1,5 @@ - ramstage-y += socket_G34.c --subdirs-y += ../model_10xxx -+subdirs-y += ../family_10h-family_15h - subdirs-y += ../quadcore - subdirs-y += ../mtrr - subdirs-y += ../microcode -diff --git a/src/mainboard/advansus/a785e-i/romstage.c b/src/mainboard/advansus/a785e-i/romstage.c -index dfda22e..4c2b38a 100644 ---- a/src/mainboard/advansus/a785e-i/romstage.c -+++ b/src/mainboard/advansus/a785e-i/romstage.c -@@ -68,7 +68,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "resourcemap.c" - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - #include "spd.h" - #include <reset.h> -diff --git a/src/mainboard/amd/bimini_fam10/romstage.c b/src/mainboard/amd/bimini_fam10/romstage.c -index 9e2e904..e2bd351 100644 ---- a/src/mainboard/amd/bimini_fam10/romstage.c -+++ b/src/mainboard/amd/bimini_fam10/romstage.c -@@ -65,7 +65,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - - void cache_as_ram_main(unsigned long bist, unsigned long cpu_init_detectedx) -diff --git a/src/mainboard/amd/mahogany_fam10/romstage.c b/src/mainboard/amd/mahogany_fam10/romstage.c -index c01ccf0..74bc9d5 100644 ---- a/src/mainboard/amd/mahogany_fam10/romstage.c -+++ b/src/mainboard/amd/mahogany_fam10/romstage.c -@@ -68,7 +68,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - - void cache_as_ram_main(unsigned long bist, unsigned long cpu_init_detectedx) -diff --git a/src/mainboard/amd/serengeti_cheetah_fam10/romstage.c b/src/mainboard/amd/serengeti_cheetah_fam10/romstage.c -index 3d7c168..20d46e6 100644 ---- a/src/mainboard/amd/serengeti_cheetah_fam10/romstage.c -+++ b/src/mainboard/amd/serengeti_cheetah_fam10/romstage.c -@@ -87,7 +87,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - - static const u8 spd_addr[] = { -diff --git a/src/mainboard/amd/tilapia_fam10/romstage.c b/src/mainboard/amd/tilapia_fam10/romstage.c -index 924345d..89100b1 100644 ---- a/src/mainboard/amd/tilapia_fam10/romstage.c -+++ b/src/mainboard/amd/tilapia_fam10/romstage.c -@@ -67,7 +67,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - #include <spd.h> - -diff --git a/src/mainboard/asus/kfsn4-dre/romstage.c b/src/mainboard/asus/kfsn4-dre/romstage.c -index b35473c..5d1f5a6 100644 ---- a/src/mainboard/asus/kfsn4-dre/romstage.c -+++ b/src/mainboard/asus/kfsn4-dre/romstage.c -@@ -74,7 +74,7 @@ static inline int spd_read_byte(unsigned device, unsigned address) - #include "southbridge/nvidia/ck804/early_setup_car.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - - #define GPIO3_DEV PNP_DEV(0x2e, W83627THG_GPIO3) -diff --git a/src/mainboard/asus/kgpe-d16/romstage.c b/src/mainboard/asus/kgpe-d16/romstage.c -index 18e7c16..a3f3310 100644 ---- a/src/mainboard/asus/kgpe-d16/romstage.c -+++ b/src/mainboard/asus/kgpe-d16/romstage.c -@@ -66,7 +66,7 @@ static inline int spd_read_byte(unsigned device, unsigned address) - - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - - /* -diff --git a/src/mainboard/asus/m4a78-em/romstage.c b/src/mainboard/asus/m4a78-em/romstage.c -index bcff9e4..82f30d9 100644 ---- a/src/mainboard/asus/m4a78-em/romstage.c -+++ b/src/mainboard/asus/m4a78-em/romstage.c -@@ -68,7 +68,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - #include <spd.h> - -diff --git a/src/mainboard/asus/m4a785-m/romstage.c b/src/mainboard/asus/m4a785-m/romstage.c -index e49c9b9..780bf81 100644 ---- a/src/mainboard/asus/m4a785-m/romstage.c -+++ b/src/mainboard/asus/m4a785-m/romstage.c -@@ -68,7 +68,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - #include <spd.h> - -diff --git a/src/mainboard/asus/m5a88-v/romstage.c b/src/mainboard/asus/m5a88-v/romstage.c -index 35e9e94..38761a6 100644 ---- a/src/mainboard/asus/m5a88-v/romstage.c -+++ b/src/mainboard/asus/m5a88-v/romstage.c -@@ -66,7 +66,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "resourcemap.c" - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - #include "spd.h" - #include <reset.h> -diff --git a/src/mainboard/avalue/eax-785e/romstage.c b/src/mainboard/avalue/eax-785e/romstage.c -index bace1d0..764a5c6 100644 ---- a/src/mainboard/avalue/eax-785e/romstage.c -+++ b/src/mainboard/avalue/eax-785e/romstage.c -@@ -69,7 +69,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "resourcemap.c" - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - #include "spd.h" - #include <reset.h> -diff --git a/src/mainboard/gigabyte/ma785gm/romstage.c b/src/mainboard/gigabyte/ma785gm/romstage.c -index 8ac24f9..db4e449 100644 ---- a/src/mainboard/gigabyte/ma785gm/romstage.c -+++ b/src/mainboard/gigabyte/ma785gm/romstage.c -@@ -64,7 +64,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - #include <spd.h> - -diff --git a/src/mainboard/gigabyte/ma785gmt/romstage.c b/src/mainboard/gigabyte/ma785gmt/romstage.c -index cd9b790..4ce7c58 100644 ---- a/src/mainboard/gigabyte/ma785gmt/romstage.c -+++ b/src/mainboard/gigabyte/ma785gmt/romstage.c -@@ -64,7 +64,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - #include <spd.h> - -diff --git a/src/mainboard/gigabyte/ma78gm/romstage.c b/src/mainboard/gigabyte/ma78gm/romstage.c -index 6cb4227..d2a0b95 100644 ---- a/src/mainboard/gigabyte/ma78gm/romstage.c -+++ b/src/mainboard/gigabyte/ma78gm/romstage.c -@@ -68,7 +68,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - #include <spd.h> - -diff --git a/src/mainboard/hp/dl165_g6_fam10/romstage.c b/src/mainboard/hp/dl165_g6_fam10/romstage.c -index 62fd6cb..97e60d5 100644 ---- a/src/mainboard/hp/dl165_g6_fam10/romstage.c -+++ b/src/mainboard/hp/dl165_g6_fam10/romstage.c -@@ -78,7 +78,7 @@ static inline int spd_read_byte(unsigned device, unsigned address) - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - - static const u8 spd_addr[] = { -diff --git a/src/mainboard/iei/kino-780am2-fam10/romstage.c b/src/mainboard/iei/kino-780am2-fam10/romstage.c -index 6df828b..edbae3a 100644 ---- a/src/mainboard/iei/kino-780am2-fam10/romstage.c -+++ b/src/mainboard/iei/kino-780am2-fam10/romstage.c -@@ -67,7 +67,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - #include <spd.h> - -diff --git a/src/mainboard/jetway/pa78vm5/romstage.c b/src/mainboard/jetway/pa78vm5/romstage.c -index ac66ada..16bb089 100644 ---- a/src/mainboard/jetway/pa78vm5/romstage.c -+++ b/src/mainboard/jetway/pa78vm5/romstage.c -@@ -72,7 +72,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - #include <spd.h> - -diff --git a/src/mainboard/msi/ms9652_fam10/romstage.c b/src/mainboard/msi/ms9652_fam10/romstage.c -index b8fca64..4ea3306 100644 ---- a/src/mainboard/msi/ms9652_fam10/romstage.c -+++ b/src/mainboard/msi/ms9652_fam10/romstage.c -@@ -74,7 +74,7 @@ static inline int spd_read_byte(unsigned device, unsigned address) - #include "southbridge/nvidia/mcp55/early_setup_car.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - - static void sio_setup(void) -diff --git a/src/mainboard/supermicro/h8dmr_fam10/romstage.c b/src/mainboard/supermicro/h8dmr_fam10/romstage.c -index d94d917..c224dbc 100644 ---- a/src/mainboard/supermicro/h8dmr_fam10/romstage.c -+++ b/src/mainboard/supermicro/h8dmr_fam10/romstage.c -@@ -66,7 +66,7 @@ static inline int spd_read_byte(unsigned device, unsigned address) - #include "southbridge/nvidia/mcp55/early_setup_car.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - - static void sio_setup(void) -diff --git a/src/mainboard/supermicro/h8qme_fam10/romstage.c b/src/mainboard/supermicro/h8qme_fam10/romstage.c -index c79c2b1..0f9445b 100644 ---- a/src/mainboard/supermicro/h8qme_fam10/romstage.c -+++ b/src/mainboard/supermicro/h8qme_fam10/romstage.c -@@ -73,7 +73,7 @@ static inline int spd_read_byte(unsigned device, unsigned address) - #include "southbridge/nvidia/mcp55/early_setup_car.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - - static void sio_setup(void) -diff --git a/src/mainboard/supermicro/h8scm_fam10/romstage.c b/src/mainboard/supermicro/h8scm_fam10/romstage.c -index b3174ae..4ea14fe 100644 ---- a/src/mainboard/supermicro/h8scm_fam10/romstage.c -+++ b/src/mainboard/supermicro/h8scm_fam10/romstage.c -@@ -65,7 +65,7 @@ static int spd_read_byte(u32 device, u32 address) - #include "resourcemap.c" - #include "cpu/amd/quadcore/quadcore.c" - #include <cpu/amd/microcode.h> --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - #include <spd.h> - -diff --git a/src/mainboard/tyan/s2912_fam10/romstage.c b/src/mainboard/tyan/s2912_fam10/romstage.c -index 1049014..0030619 100644 ---- a/src/mainboard/tyan/s2912_fam10/romstage.c -+++ b/src/mainboard/tyan/s2912_fam10/romstage.c -@@ -74,7 +74,7 @@ static inline int spd_read_byte(unsigned device, unsigned address) - #include "southbridge/nvidia/mcp55/early_setup_car.c" - #include <cpu/amd/microcode.h> - --#include "cpu/amd/model_10xxx/init_cpus.c" -+#include "cpu/amd/family_10h-family_15h/init_cpus.c" - #include "northbridge/amd/amdfam10/early_ht.c" - - static void sio_setup(void) -diff --git a/src/northbridge/amd/amdfam10/northbridge.c b/src/northbridge/amd/amdfam10/northbridge.c -index ff324cd..fb3b2f7 100644 ---- a/src/northbridge/amd/amdfam10/northbridge.c -+++ b/src/northbridge/amd/amdfam10/northbridge.c -@@ -34,7 +34,7 @@ - #include <cpu/x86/lapic.h> - #include <cpu/amd/mtrr.h> - #include <cpu/amd/amdfam10_sysconf.h> --#include <cpu/amd/model_10xxx/ram_calc.h> -+#include <cpu/amd/family_10h-family_15h/ram_calc.h> - - #if CONFIG_LOGICAL_CPUS - #include <cpu/amd/multicore.h> --- -1.7.9.5 - |