Re: [PATCH 7/8] Implement smp_processor_id() with the PDA.
From: Jeremy Fitzhardinge
Date: Thu Aug 31 2006 - 12:01:47 EST
Ian Campbell wrote:
This doesn't compile for me if CONFIG_SMP=n
Ah, good point.
LD .tmp_vmlinux1
arch/i386/kernel/built-in.o: In function `cpu_init':
(.init.text+0x1eda): undefined reference to `early_smp_processor_id'
arch/i386/kernel/built-in.o: In function `cpu_init':
(.init.text+0x1f11): undefined reference to `early_smp_processor_id'
smp_processor_id() is defined for !SMP in include/linux/smp.h, I don't
know if it would be appropriate to add early_smp_processor_id() there
since it seems i386 specific. asm/smp.h isn't included by linux/smp.h
when !SMP but you could add an explicit include to common.c I suppose.
I'll have a look.
I think my preferred solution would be to get rid of all the early*
stuff, and try to arrange to have the PDA set up before C code gets
run. For the boot CPU, it really could be done statically (I'm not
quite sure why the boot CPU's GDT is allocated, given that it already
has a static one; I think this might have been a Xen-related change?).
The secondary CPUs could have their GDT+PDA completely allocated and
initialized in advance, making secondary CPU PDA setup just a matter of
doing lgdt and setting %gs in head.S, even before hitting C code.
J
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/