aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeremy Fitzhardinge <jeremy@goop.org>2006-12-06 20:14:03 -0500
committerAndi Kleen <andi@basil.nowhere.org>2006-12-06 20:14:03 -0500
commitb2938f880890ebfcccad356275e0000193153623 (patch)
treef2dcde93e6bd449369e4d305f081e9c12af99948
parent49d26b6eaa8e970c8cf6e299e6ccba2474191bf5 (diff)
[PATCH] i386: Implement smp_processor_id() with the PDA
Use the cpu_number in the PDA to implement raw_smp_processor_id. This is a little simpler than using thread_info, though the cpu field in thread_info cannot be removed since it is used for things other than getting the current CPU in common code. Signed-off-by: Jeremy Fitzhardinge <jeremy@xensource.com> Signed-off-by: Andi Kleen <ak@suse.de> Cc: Chuck Ebbert <76306.1226@compuserve.com> Cc: Zachary Amsden <zach@vmware.com> Cc: Jan Beulich <jbeulich@novell.com> Cc: Andi Kleen <ak@suse.de> Signed-off-by: Andrew Morton <akpm@osdl.org>
-rw-r--r--arch/i386/kernel/asm-offsets.c4
-rw-r--r--arch/i386/kernel/cpu/common.c2
-rw-r--r--arch/i386/kernel/entry.S3
-rw-r--r--include/asm-i386/pda.h2
-rw-r--r--include/asm-i386/smp.h3
5 files changed, 10 insertions, 4 deletions
diff --git a/arch/i386/kernel/asm-offsets.c b/arch/i386/kernel/asm-offsets.c
index 9620872d3534..85f1b038e9c3 100644
--- a/arch/i386/kernel/asm-offsets.c
+++ b/arch/i386/kernel/asm-offsets.c
@@ -51,7 +51,6 @@ void foo(void)
51 OFFSET(TI_exec_domain, thread_info, exec_domain); 51 OFFSET(TI_exec_domain, thread_info, exec_domain);
52 OFFSET(TI_flags, thread_info, flags); 52 OFFSET(TI_flags, thread_info, flags);
53 OFFSET(TI_status, thread_info, status); 53 OFFSET(TI_status, thread_info, status);
54 OFFSET(TI_cpu, thread_info, cpu);
55 OFFSET(TI_preempt_count, thread_info, preempt_count); 54 OFFSET(TI_preempt_count, thread_info, preempt_count);
56 OFFSET(TI_addr_limit, thread_info, addr_limit); 55 OFFSET(TI_addr_limit, thread_info, addr_limit);
57 OFFSET(TI_restart_block, thread_info, restart_block); 56 OFFSET(TI_restart_block, thread_info, restart_block);
@@ -97,4 +96,7 @@ void foo(void)
97 DEFINE(VDSO_PRELINK, VDSO_PRELINK); 96 DEFINE(VDSO_PRELINK, VDSO_PRELINK);
98 97
99 OFFSET(crypto_tfm_ctx_offset, crypto_tfm, __crt_ctx); 98 OFFSET(crypto_tfm_ctx_offset, crypto_tfm, __crt_ctx);
99
100 BLANK();
101 OFFSET(PDA_cpu, i386_pda, cpu_number);
100} 102}
diff --git a/arch/i386/kernel/cpu/common.c b/arch/i386/kernel/cpu/common.c
index 4e63d8ce602b..e476202b887f 100644
--- a/arch/i386/kernel/cpu/common.c
+++ b/arch/i386/kernel/cpu/common.c
@@ -650,6 +650,7 @@ __cpuinit int alloc_gdt(int cpu)
650/* Initial PDA used by boot CPU */ 650/* Initial PDA used by boot CPU */
651struct i386_pda boot_pda = { 651struct i386_pda boot_pda = {
652 ._pda = &boot_pda, 652 ._pda = &boot_pda,
653 .cpu_number = 0,
653}; 654};
654 655
655static inline void set_kernel_gs(void) 656static inline void set_kernel_gs(void)
@@ -694,6 +695,7 @@ __cpuinit int init_gdt(int cpu, struct task_struct *idle)
694 695
695 memset(pda, 0, sizeof(*pda)); 696 memset(pda, 0, sizeof(*pda));
696 pda->_pda = pda; 697 pda->_pda = pda;
698 pda->cpu_number = cpu;
697 699
698 return 1; 700 return 1;
699} 701}
diff --git a/arch/i386/kernel/entry.S b/arch/i386/kernel/entry.S
index b99d4a160078..d7423efaeea4 100644
--- a/arch/i386/kernel/entry.S
+++ b/arch/i386/kernel/entry.S
@@ -524,8 +524,7 @@ syscall_badsys:
524 524
525#define FIXUP_ESPFIX_STACK \ 525#define FIXUP_ESPFIX_STACK \
526 /* since we are on a wrong stack, we cant make it a C code :( */ \ 526 /* since we are on a wrong stack, we cant make it a C code :( */ \
527 GET_THREAD_INFO(%ebp); \ 527 movl %gs:PDA_cpu, %ebx; \
528 movl TI_cpu(%ebp), %ebx; \
529 PER_CPU(cpu_gdt_descr, %ebx); \ 528 PER_CPU(cpu_gdt_descr, %ebx); \
530 movl GDS_address(%ebx), %ebx; \ 529 movl GDS_address(%ebx), %ebx; \
531 GET_DESC_BASE(GDT_ENTRY_ESPFIX_SS, %ebx, %eax, %ax, %al, %ah); \ 530 GET_DESC_BASE(GDT_ENTRY_ESPFIX_SS, %ebx, %eax, %ax, %al, %ah); \
diff --git a/include/asm-i386/pda.h b/include/asm-i386/pda.h
index 4c39ccb1305c..f90fde22566d 100644
--- a/include/asm-i386/pda.h
+++ b/include/asm-i386/pda.h
@@ -11,6 +11,8 @@
11struct i386_pda 11struct i386_pda
12{ 12{
13 struct i386_pda *_pda; /* pointer to self */ 13 struct i386_pda *_pda; /* pointer to self */
14
15 int cpu_number;
14}; 16};
15 17
16extern struct i386_pda *_cpu_pda[]; 18extern struct i386_pda *_cpu_pda[];
diff --git a/include/asm-i386/smp.h b/include/asm-i386/smp.h
index bd59c1508e71..64fe624c02ca 100644
--- a/include/asm-i386/smp.h
+++ b/include/asm-i386/smp.h
@@ -8,6 +8,7 @@
8#include <linux/kernel.h> 8#include <linux/kernel.h>
9#include <linux/threads.h> 9#include <linux/threads.h>
10#include <linux/cpumask.h> 10#include <linux/cpumask.h>
11#include <asm/pda.h>
11#endif 12#endif
12 13
13#ifdef CONFIG_X86_LOCAL_APIC 14#ifdef CONFIG_X86_LOCAL_APIC
@@ -56,7 +57,7 @@ extern void cpu_uninit(void);
56 * from the initial startup. We map APIC_BASE very early in page_setup(), 57 * from the initial startup. We map APIC_BASE very early in page_setup(),
57 * so this is correct in the x86 case. 58 * so this is correct in the x86 case.
58 */ 59 */
59#define raw_smp_processor_id() (current_thread_info()->cpu) 60#define raw_smp_processor_id() (read_pda(cpu_number))
60 61
61extern cpumask_t cpu_callout_map; 62extern cpumask_t cpu_callout_map;
62extern cpumask_t cpu_callin_map; 63extern cpumask_t cpu_callin_map;