diff options
author | Jeremy Fitzhardinge <jeremy@goop.org> | 2006-12-06 20:14:03 -0500 |
---|---|---|
committer | Andi Kleen <andi@basil.nowhere.org> | 2006-12-06 20:14:03 -0500 |
commit | ec7fcaabbfb3c5bd5189f857b6ac7bb9745ef291 (patch) | |
tree | 9730e2849a9943e26f8d32f394296fd685b85e39 /arch/i386/kernel | |
parent | b2938f880890ebfcccad356275e0000193153623 (diff) |
[PATCH] i386: Implement "current" with the PDA
Use the pcurrent field in the PDA to implement the "current" macro. This ends
up compiling down to a single instruction to get the current task.
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>
Diffstat (limited to 'arch/i386/kernel')
-rw-r--r-- | arch/i386/kernel/asm-offsets.c | 2 | ||||
-rw-r--r-- | arch/i386/kernel/cpu/common.c | 2 | ||||
-rw-r--r-- | arch/i386/kernel/process.c | 1 |
3 files changed, 5 insertions, 0 deletions
diff --git a/arch/i386/kernel/asm-offsets.c b/arch/i386/kernel/asm-offsets.c index 85f1b038e9c3..0666eb0ed7bc 100644 --- a/arch/i386/kernel/asm-offsets.c +++ b/arch/i386/kernel/asm-offsets.c | |||
@@ -15,6 +15,7 @@ | |||
15 | #include <asm/processor.h> | 15 | #include <asm/processor.h> |
16 | #include <asm/thread_info.h> | 16 | #include <asm/thread_info.h> |
17 | #include <asm/elf.h> | 17 | #include <asm/elf.h> |
18 | #include <asm/pda.h> | ||
18 | 19 | ||
19 | #define DEFINE(sym, val) \ | 20 | #define DEFINE(sym, val) \ |
20 | asm volatile("\n->" #sym " %0 " #val : : "i" (val)) | 21 | asm volatile("\n->" #sym " %0 " #val : : "i" (val)) |
@@ -99,4 +100,5 @@ void foo(void) | |||
99 | 100 | ||
100 | BLANK(); | 101 | BLANK(); |
101 | OFFSET(PDA_cpu, i386_pda, cpu_number); | 102 | OFFSET(PDA_cpu, i386_pda, cpu_number); |
103 | OFFSET(PDA_pcurrent, i386_pda, pcurrent); | ||
102 | } | 104 | } |
diff --git a/arch/i386/kernel/cpu/common.c b/arch/i386/kernel/cpu/common.c index e476202b887f..6958ae5e2fa5 100644 --- a/arch/i386/kernel/cpu/common.c +++ b/arch/i386/kernel/cpu/common.c | |||
@@ -651,6 +651,7 @@ __cpuinit int alloc_gdt(int cpu) | |||
651 | struct i386_pda boot_pda = { | 651 | struct i386_pda boot_pda = { |
652 | ._pda = &boot_pda, | 652 | ._pda = &boot_pda, |
653 | .cpu_number = 0, | 653 | .cpu_number = 0, |
654 | .pcurrent = &init_task, | ||
654 | }; | 655 | }; |
655 | 656 | ||
656 | static inline void set_kernel_gs(void) | 657 | static inline void set_kernel_gs(void) |
@@ -696,6 +697,7 @@ __cpuinit int init_gdt(int cpu, struct task_struct *idle) | |||
696 | memset(pda, 0, sizeof(*pda)); | 697 | memset(pda, 0, sizeof(*pda)); |
697 | pda->_pda = pda; | 698 | pda->_pda = pda; |
698 | pda->cpu_number = cpu; | 699 | pda->cpu_number = cpu; |
700 | pda->pcurrent = idle; | ||
699 | 701 | ||
700 | return 1; | 702 | return 1; |
701 | } | 703 | } |
diff --git a/arch/i386/kernel/process.c b/arch/i386/kernel/process.c index dc4272545179..8749b10d3805 100644 --- a/arch/i386/kernel/process.c +++ b/arch/i386/kernel/process.c | |||
@@ -684,6 +684,7 @@ struct task_struct fastcall * __switch_to(struct task_struct *prev_p, struct tas | |||
684 | if (unlikely(prev->fs | next->fs)) | 684 | if (unlikely(prev->fs | next->fs)) |
685 | loadsegment(fs, next->fs); | 685 | loadsegment(fs, next->fs); |
686 | 686 | ||
687 | write_pda(pcurrent, next_p); | ||
687 | 688 | ||
688 | /* | 689 | /* |
689 | * Restore IOPL if needed. | 690 | * Restore IOPL if needed. |