linux/arch/i386/mach-generic
Fernando Luis Vazquez Cao a36166c6ef Use the APIC to determine the hardware processor id - i386
hard_smp_processor_id used to be just a macro that hard-coded
hard_smp_processor_id to 0 in the non SMP case.  When booting non SMP kernels
on hardware where the boot ioapic id is not 0 this turns out to be a problem.
This is happens frequently in the case of kdump and once in a great while in
the case of real hardware.

Use the APIC to determine the hardware processor id in both UP and SMP kernels
to fix this issue.

Notice that hard_smp_processor_id is only used by SMP code or by code that
works with apics so we do not need to handle the case when apics are not
present and hard_smp_processor_id should never be called there.

Signed-off-by: Fernando Luis Vazquez Cao <fernando@oss.ntt.co.jp>
Cc: "Luck, Tony" <tony.luck@intel.com>
Acked-by: Andi Kleen <ak@suse.de>
Cc: "Eric W. Biederman" <ebiederm@xmission.com>
Cc: Vivek Goyal <vgoyal@in.ibm.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2007-05-09 12:30:48 -07:00
..
bigsmp.c [PATCH] i386: Add __init to probe_bigsmp 2007-05-02 19:27:05 +02:00
default.c [PATCH] i386: make apic probe function non-init 2007-01-11 01:52:44 +01:00
es7000.c [PATCH] i386: modpost apic related warning fixes 2007-05-02 19:27:08 +02:00
Makefile
probe.c Use the APIC to determine the hardware processor id - i386 2007-05-09 12:30:48 -07:00
summit.c [PATCH] i386: make apic probe function non-init 2007-01-11 01:52:44 +01:00