diff options
Diffstat (limited to 'arch')
-rw-r--r-- | arch/i386/kernel/asm-offsets.c | 4 | ||||
-rw-r--r-- | arch/i386/kernel/cpu/common.c | 2 | ||||
-rw-r--r-- | arch/i386/kernel/entry.S | 3 |
3 files changed, 6 insertions, 3 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 */ |
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 | }; | 654 | }; |
654 | 655 | ||
655 | static inline void set_kernel_gs(void) | 656 | static 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); \ |