|
@@ -1432,11 +1432,9 @@ static int update_cpu_topology(void *data)
|
|
|
if (cpu != update->cpu)
|
|
|
continue;
|
|
|
|
|
|
- unregister_cpu_under_node(update->cpu, update->old_nid);
|
|
|
unmap_cpu_from_node(update->cpu);
|
|
|
map_cpu_to_node(update->cpu, update->new_nid);
|
|
|
vdso_getcpu_init();
|
|
|
- register_cpu_under_node(update->cpu, update->new_nid);
|
|
|
}
|
|
|
|
|
|
return 0;
|
|
@@ -1484,6 +1482,9 @@ int arch_update_cpu_topology(void)
|
|
|
stop_machine(update_cpu_topology, &updates[0], &updated_cpus);
|
|
|
|
|
|
for (ud = &updates[0]; ud; ud = ud->next) {
|
|
|
+ unregister_cpu_under_node(ud->cpu, ud->old_nid);
|
|
|
+ register_cpu_under_node(ud->cpu, ud->new_nid);
|
|
|
+
|
|
|
dev = get_cpu_device(ud->cpu);
|
|
|
if (dev)
|
|
|
kobject_uevent(&dev->kobj, KOBJ_CHANGE);
|