diff options
author | Ingo Molnar <mingo@elte.hu> | 2009-02-26 06:47:40 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-02-26 06:49:34 -0500 |
commit | 0917c01f8e793f57a53cf886533d4c75c67f6e89 (patch) | |
tree | 0aaf2e2107ecb54f28bcd97c2b9706842f395552 /arch/x86/include/asm/apic.h | |
parent | 129d8bc828e011bda0b7110a097bf3a0167f966e (diff) |
x86: remove update_apic from x86_quirks, fix
Impact: build fix
wakeup_secondary_cpu_via_init(), the default platform method for
booting a secondary CPU, is always used on UP due to probe_32.c,
if CONFIG_X86_LOCAL_APIC is enabled but SMP is off.
So provide a UP wrapper inline as well.
Cc: Yinghai Lu <yinghai@kernel.org>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/include/asm/apic.h')
-rw-r--r-- | arch/x86/include/asm/apic.h | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/arch/x86/include/asm/apic.h b/arch/x86/include/asm/apic.h index 24e21273e30b..0fbf6f1520fa 100644 --- a/arch/x86/include/asm/apic.h +++ b/arch/x86/include/asm/apic.h | |||
@@ -331,10 +331,27 @@ struct apic { | |||
331 | u32 (*safe_wait_icr_idle)(void); | 331 | u32 (*safe_wait_icr_idle)(void); |
332 | }; | 332 | }; |
333 | 333 | ||
334 | /* | ||
335 | * Pointer to the local APIC driver in use on this system (there's | ||
336 | * always just one such driver in use - the kernel decides via an | ||
337 | * early probing process which one it picks - and then sticks to it): | ||
338 | */ | ||
334 | extern struct apic *apic; | 339 | extern struct apic *apic; |
340 | |||
341 | /* | ||
342 | * APIC functionality to boot other CPUs - only used on SMP: | ||
343 | */ | ||
344 | #ifdef CONFIG_SMP | ||
335 | extern atomic_t init_deasserted; | 345 | extern atomic_t init_deasserted; |
336 | extern int wakeup_secondary_cpu_via_nmi(int apicid, unsigned long start_eip); | 346 | extern int wakeup_secondary_cpu_via_nmi(int apicid, unsigned long start_eip); |
337 | extern int wakeup_secondary_cpu_via_init(int apicid, unsigned long start_eip); | 347 | extern int wakeup_secondary_cpu_via_init(int apicid, unsigned long start_eip); |
348 | #else | ||
349 | static inline int | ||
350 | wakeup_secondary_cpu_via_init(int apicid, unsigned long start_eip) | ||
351 | { | ||
352 | return 0; | ||
353 | } | ||
354 | #endif | ||
338 | 355 | ||
339 | static inline u32 apic_read(u32 reg) | 356 | static inline u32 apic_read(u32 reg) |
340 | { | 357 | { |