|
@@ -1705,6 +1705,34 @@ static int check_cpu_on_node(void *data)
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
+static void unmap_cpu_on_node(void *data)
|
|
|
+{
|
|
|
+#ifdef CONFIG_ACPI_NUMA
|
|
|
+ struct pglist_data *pgdat = data;
|
|
|
+ int cpu;
|
|
|
+
|
|
|
+ for_each_possible_cpu(cpu)
|
|
|
+ if (cpu_to_node(cpu) == pgdat->node_id)
|
|
|
+ numa_clear_node(cpu);
|
|
|
+#endif
|
|
|
+}
|
|
|
+
|
|
|
+static int check_and_unmap_cpu_on_node(void *data)
|
|
|
+{
|
|
|
+ int ret = check_cpu_on_node(data);
|
|
|
+
|
|
|
+ if (ret)
|
|
|
+ return ret;
|
|
|
+
|
|
|
+ /*
|
|
|
+ * the node will be offlined when we come here, so we can clear
|
|
|
+ * the cpu_to_node() now.
|
|
|
+ */
|
|
|
+
|
|
|
+ unmap_cpu_on_node(data);
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
/* offline the node if all memory sections of this node are removed */
|
|
|
void try_offline_node(int nid)
|
|
|
{
|
|
@@ -1731,7 +1759,7 @@ void try_offline_node(int nid)
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
- if (stop_machine(check_cpu_on_node, pgdat, NULL))
|
|
|
+ if (stop_machine(check_and_unmap_cpu_on_node, pgdat, NULL))
|
|
|
return;
|
|
|
|
|
|
/*
|