Skip to content

Commit

Permalink
powerpc/vphn: Update CPU topology when VPHN enabled
Browse files Browse the repository at this point in the history
powerpc/vphn: On Power systems with shared configurations of CPUs
and memory, there are some issues with the association of additional
CPUs and memory to nodes when hot-adding resources.  This patch
corrects the currently broken capability to set the topology for
shared CPUs in LPARs.  At boot time for shared CPU lpars, the
topology for each CPU was being set to node zero.  Now when
numa_update_cpu_topology() is called appropriately, the Virtual
Processor Home Node (VPHN) capabilities information provided by the
pHyp allows the appropriate node in the shared configuration to be
selected for the CPU.

Signed-off-by: Michael Bringmann <[email protected]>
Signed-off-by: Michael Ellerman <[email protected]>
  • Loading branch information
mwbringmann authored and mpe committed Oct 16, 2017
1 parent 733e4a4 commit 17f444c
Showing 1 changed file with 21 additions and 1 deletion.
22 changes: 21 additions & 1 deletion arch/powerpc/mm/numa.c
Original file line number Diff line number Diff line change
Expand Up @@ -1153,6 +1153,8 @@ static cpumask_t cpu_associativity_changes_mask;
static int vphn_enabled;
static int prrn_enabled;
static void reset_topology_timer(void);
static int topology_inited;
static int topology_update_needed;

/*
* Store the current values of the associativity change counters in the
Expand Down Expand Up @@ -1246,6 +1248,10 @@ static long vphn_get_associativity(unsigned long cpu,
"hcall_vphn() experienced a hardware fault "
"preventing VPHN. Disabling polling...\n");
stop_topology_update();
break;
case H_SUCCESS:
dbg("VPHN hcall succeeded. Reset polling...\n");
break;
}

return rc;
Expand Down Expand Up @@ -1323,8 +1329,11 @@ int numa_update_cpu_topology(bool cpus_locked)
struct device *dev;
int weight, new_nid, i = 0;

if (!prrn_enabled && !vphn_enabled)
if (!prrn_enabled && !vphn_enabled) {
if (!topology_inited)
topology_update_needed = 1;
return 0;
}

weight = cpumask_weight(&cpu_associativity_changes_mask);
if (!weight)
Expand Down Expand Up @@ -1363,6 +1372,8 @@ int numa_update_cpu_topology(bool cpus_locked)
cpumask_andnot(&cpu_associativity_changes_mask,
&cpu_associativity_changes_mask,
cpu_sibling_mask(cpu));
dbg("Assoc chg gives same node %d for cpu%d\n",
new_nid, cpu);
cpu = cpu_last_thread_sibling(cpu);
continue;
}
Expand Down Expand Up @@ -1433,6 +1444,7 @@ int numa_update_cpu_topology(bool cpus_locked)

out:
kfree(updates);
topology_update_needed = 0;
return changed;
}

Expand Down Expand Up @@ -1613,9 +1625,17 @@ static int topology_update_init(void)
if (topology_updates_enabled)
start_topology_update();

if (vphn_enabled)
topology_schedule_update();

if (!proc_create("powerpc/topology_updates", 0644, NULL, &topology_ops))
return -ENOMEM;

topology_inited = 1;
if (topology_update_needed)
bitmap_fill(cpumask_bits(&cpu_associativity_changes_mask),
nr_cpumask_bits);

return 0;
}
device_initcall(topology_update_init);
Expand Down

0 comments on commit 17f444c

Please sign in to comment.