|
@@ -306,7 +306,6 @@ static void amd_get_topology(struct cpuinfo_x86 *c)
|
|
|
u32 eax, ebx, ecx, edx;
|
|
|
|
|
|
cpuid(0x8000001e, &eax, &ebx, &ecx, &edx);
|
|
|
- nodes_per_socket = ((ecx >> 8) & 7) + 1;
|
|
|
node_id = ecx & 7;
|
|
|
|
|
|
/* get compute unit information */
|
|
@@ -317,7 +316,6 @@ static void amd_get_topology(struct cpuinfo_x86 *c)
|
|
|
u64 value;
|
|
|
|
|
|
rdmsrl(MSR_FAM10H_NODE_ID, value);
|
|
|
- nodes_per_socket = ((value >> 3) & 7) + 1;
|
|
|
node_id = value & 7;
|
|
|
} else
|
|
|
return;
|
|
@@ -519,6 +517,18 @@ static void bsp_init_amd(struct cpuinfo_x86 *c)
|
|
|
|
|
|
if (cpu_has(c, X86_FEATURE_MWAITX))
|
|
|
use_mwaitx_delay();
|
|
|
+
|
|
|
+ if (boot_cpu_has(X86_FEATURE_TOPOEXT)) {
|
|
|
+ u32 ecx;
|
|
|
+
|
|
|
+ ecx = cpuid_ecx(0x8000001e);
|
|
|
+ nodes_per_socket = ((ecx >> 8) & 7) + 1;
|
|
|
+ } else if (boot_cpu_has(X86_FEATURE_NODEID_MSR)) {
|
|
|
+ u64 value;
|
|
|
+
|
|
|
+ rdmsrl(MSR_FAM10H_NODE_ID, value);
|
|
|
+ nodes_per_socket = ((value >> 3) & 7) + 1;
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
static void early_init_amd(struct cpuinfo_x86 *c)
|