Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 7c9e92b6 authored by Yinghai Lu's avatar Yinghai Lu Committed by Ingo Molnar
Browse files

x86: not set node to cpu_to_node if the node is not online

resolve boot problem reported by Mel Gorman:

   http://lkml.org/lkml/2008/2/13/404



init_cpu_to_node will use cpu->apic (from MADT or mptable) and
apic->node(from SRAT or AMD config space with k8_bus_64.c) to have
cpu->node mapping, and later identify_cpu will overwrite them
again...(with nearby_node...)

this patch checks if the node is online, otherwise it will not
update cpu_node map. so keep cpu_node map to online node before
identify_cpu..., to prevent possible error.

Signed-off-by: default avatarYinghai Lu <yinghai.lu@sun.com>
Signed-off-by: default avatarIngo Molnar <mingo@elte.hu>
Acked-by: default avatarThomas Gleixner <tglx@linutronix.de>
parent 18a86221
Loading
Loading
Loading
Loading
+6 −2
Original line number Original line Diff line number Diff line
@@ -622,13 +622,17 @@ void __init init_cpu_to_node(void)
	int i;
	int i;


	for (i = 0; i < NR_CPUS; i++) {
	for (i = 0; i < NR_CPUS; i++) {
		int node;
		u16 apicid = x86_cpu_to_apicid_init[i];
		u16 apicid = x86_cpu_to_apicid_init[i];


		if (apicid == BAD_APICID)
		if (apicid == BAD_APICID)
			continue;
			continue;
		if (apicid_to_node[apicid] == NUMA_NO_NODE)
		node = apicid_to_node[apicid];
		if (node == NUMA_NO_NODE)
			continue;
			continue;
		numa_set_node(i, apicid_to_node[apicid]);
		if (!node_online(node))
			continue;
		numa_set_node(i, node);
	}
	}
}
}