diff options
Diffstat (limited to 'arch/x86/kernel/process_32.c')
| -rw-r--r-- | arch/x86/kernel/process_32.c | 12 | 
1 files changed, 10 insertions, 2 deletions
| diff --git a/arch/x86/kernel/process_32.c b/arch/x86/kernel/process_32.c index 884f98f69354..6f1236c29c4b 100644 --- a/arch/x86/kernel/process_32.c +++ b/arch/x86/kernel/process_32.c @@ -153,7 +153,7 @@ int copy_thread(unsigned long clone_flags, unsigned long sp,  		childregs->orig_ax = -1;  		childregs->cs = __KERNEL_CS | get_kernel_rpl();  		childregs->flags = X86_EFLAGS_IF | X86_EFLAGS_FIXED; -		p->fpu_counter = 0; +		p->thread.fpu_counter = 0;  		p->thread.io_bitmap_ptr = NULL;  		memset(p->thread.ptrace_bps, 0, sizeof(p->thread.ptrace_bps));  		return 0; @@ -166,7 +166,7 @@ int copy_thread(unsigned long clone_flags, unsigned long sp,  	p->thread.ip = (unsigned long) ret_from_fork;  	task_user_gs(p) = get_user_gs(current_pt_regs()); -	p->fpu_counter = 0; +	p->thread.fpu_counter = 0;  	p->thread.io_bitmap_ptr = NULL;  	tsk = current;  	err = -ENOMEM; @@ -292,6 +292,14 @@ __switch_to(struct task_struct *prev_p, struct task_struct *next_p)  		set_iopl_mask(next->iopl);  	/* +	 * If it were not for PREEMPT_ACTIVE we could guarantee that the +	 * preempt_count of all tasks was equal here and this would not be +	 * needed. +	 */ +	task_thread_info(prev_p)->saved_preempt_count = this_cpu_read(__preempt_count); +	this_cpu_write(__preempt_count, task_thread_info(next_p)->saved_preempt_count); + +	/*  	 * Now maybe handle debug registers and/or IO bitmaps  	 */  	if (unlikely(task_thread_info(prev_p)->flags & _TIF_WORK_CTXSW_PREV || | 
