1

- Have AMD Zen common init code run on all families from Zen1 onwards

in order to save some future enablement effort
 -----BEGIN PGP SIGNATURE-----
 
 iQIzBAABCgAdFiEEzv7L6UO9uDPlPSfHEsHwGGHeVUoFAmXuxn4ACgkQEsHwGGHe
 VUolmQ//djDJa11FTQ5Zfnu8RjH4LFe6ZanLMIP93urT8rRuOfhlOZLHqxFGvJHy
 1K1yT34NmHdXBsVWX7MxDmyhRJMOhgkkgGhYaBqZWrcV1RO26PKg8FS5B/a3BsVI
 Y7ryOOqWNg0Hf/++Qm0zSq21VEH3Ehq4gYitK0irX/gBbHQMdui63pbLqOHwdszG
 bhgMSI42EjZxpbR1ow5Bx7dia0ChBODbV4WeVB0eZo47mSJU4eu8yDPuy5+5ywwA
 fOOVWZ2e12HrisfJYxL01vivU/pK0WYB2gJlAKv0tp+Q2ReIvo/vh4w2MHC1c+YT
 X8e95rz1jzzlTkEKt4iWE/NZ1XS30z77jGbKVLxl8lsWswTtup48xLw0idLHc39L
 M0ayY3yXbWRVxSltucH2DVKMzG8IP5XNeG53qfiMqIHsoYbmnVgxWk/0HrtgcrSL
 jvcU4f2hwehO/ZvwlRyRlQACOlDSHGehNHmAVK3BqxYxM2+a9ArTA2KmnbC6+U9u
 LAKaXlf+lMo6lszHDqKb+GUePqZ4EX01X4EuSTRX/G6qD4RMZIu1+4sBwfr79miE
 uKJvRIT9DH74+OLPeSt/osdbGAK26BzJM9ZnqkdcggOMM/tHPNkQ5YTK/lStP3gl
 JAh8ih/Or9p3LQHNKIU1zoT0MOKv6Mbr8n+MPYAhaS/oNpST6Bs=
 =h7IU
 -----END PGP SIGNATURE-----

Merge tag 'x86_cpu_for_v6.9_rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip

Pull x86 cpu update from Borislav Petkov:

 - Have AMD Zen common init code run on all families from Zen1 onwards
   in order to save some future enablement effort

* tag 'x86_cpu_for_v6.9_rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
  x86/CPU/AMD: Do the common init on future Zens too
This commit is contained in:
Linus Torvalds 2024-03-11 17:25:45 -07:00
commit 742582acec

View File

@ -828,7 +828,6 @@ static void init_amd_zen_common(void)
static void init_amd_zen1(struct cpuinfo_x86 *c) static void init_amd_zen1(struct cpuinfo_x86 *c)
{ {
init_amd_zen_common();
fix_erratum_1386(c); fix_erratum_1386(c);
/* Fix up CPUID bits, but only if not virtualised. */ /* Fix up CPUID bits, but only if not virtualised. */
@ -882,7 +881,6 @@ static void zen2_zenbleed_check(struct cpuinfo_x86 *c)
static void init_amd_zen2(struct cpuinfo_x86 *c) static void init_amd_zen2(struct cpuinfo_x86 *c)
{ {
init_amd_zen_common();
init_spectral_chicken(c); init_spectral_chicken(c);
fix_erratum_1386(c); fix_erratum_1386(c);
zen2_zenbleed_check(c); zen2_zenbleed_check(c);
@ -890,8 +888,6 @@ static void init_amd_zen2(struct cpuinfo_x86 *c)
static void init_amd_zen3(struct cpuinfo_x86 *c) static void init_amd_zen3(struct cpuinfo_x86 *c)
{ {
init_amd_zen_common();
if (!cpu_has(c, X86_FEATURE_HYPERVISOR)) { if (!cpu_has(c, X86_FEATURE_HYPERVISOR)) {
/* /*
* Zen3 (Fam19 model < 0x10) parts are not susceptible to * Zen3 (Fam19 model < 0x10) parts are not susceptible to
@ -905,15 +901,12 @@ static void init_amd_zen3(struct cpuinfo_x86 *c)
static void init_amd_zen4(struct cpuinfo_x86 *c) static void init_amd_zen4(struct cpuinfo_x86 *c)
{ {
init_amd_zen_common();
if (!cpu_has(c, X86_FEATURE_HYPERVISOR)) if (!cpu_has(c, X86_FEATURE_HYPERVISOR))
msr_set_bit(MSR_ZEN4_BP_CFG, MSR_ZEN4_BP_CFG_SHARED_BTB_FIX_BIT); msr_set_bit(MSR_ZEN4_BP_CFG, MSR_ZEN4_BP_CFG_SHARED_BTB_FIX_BIT);
} }
static void init_amd_zen5(struct cpuinfo_x86 *c) static void init_amd_zen5(struct cpuinfo_x86 *c)
{ {
init_amd_zen_common();
} }
static void init_amd(struct cpuinfo_x86 *c) static void init_amd(struct cpuinfo_x86 *c)
@ -950,6 +943,13 @@ static void init_amd(struct cpuinfo_x86 *c)
case 0x16: init_amd_jg(c); break; case 0x16: init_amd_jg(c); break;
} }
/*
* Save up on some future enablement work and do common Zen
* settings.
*/
if (c->x86 >= 0x17)
init_amd_zen_common();
if (boot_cpu_has(X86_FEATURE_ZEN1)) if (boot_cpu_has(X86_FEATURE_ZEN1))
init_amd_zen1(c); init_amd_zen1(c);
else if (boot_cpu_has(X86_FEATURE_ZEN2)) else if (boot_cpu_has(X86_FEATURE_ZEN2))