diff options
Diffstat (limited to 'arch/x86/include/asm/processor.h')
| -rw-r--r-- | arch/x86/include/asm/processor.h | 25 | 
1 files changed, 14 insertions, 11 deletions
| diff --git a/arch/x86/include/asm/processor.h b/arch/x86/include/asm/processor.h index 63def9537a2d..984a7bf17f6a 100644 --- a/arch/x86/include/asm/processor.h +++ b/arch/x86/include/asm/processor.h @@ -389,9 +389,9 @@ struct thread_struct {  	unsigned short		fsindex;  	unsigned short		gsindex;  #endif -#ifdef CONFIG_X86_32 -	unsigned long		ip; -#endif + +	u32			status;		/* thread synchronous flags */ +  #ifdef CONFIG_X86_64  	unsigned long		fsbase;  	unsigned long		gsbase; @@ -438,6 +438,15 @@ struct thread_struct {  };  /* + * Thread-synchronous status. + * + * This is different from the flags in that nobody else + * ever touches our thread-synchronous status, so we don't + * have to worry about atomic accesses. + */ +#define TS_COMPAT		0x0002	/* 32bit syscall active (64BIT)*/ + +/*   * Set IOPL bits in EFLAGS from given mask   */  static inline void native_set_iopl_mask(unsigned mask) @@ -724,8 +733,6 @@ static inline void spin_lock_prefetch(const void *x)  	.addr_limit		= KERNEL_DS,				  \  } -extern unsigned long thread_saved_pc(struct task_struct *tsk); -  /*   * TOP_OF_KERNEL_STACK_PADDING reserves 8 bytes on top of the ring0 stack.   * This is necessary to guarantee that the entire "struct pt_regs" @@ -776,17 +783,13 @@ extern unsigned long thread_saved_pc(struct task_struct *tsk);  	.addr_limit		= KERNEL_DS,			\  } -/* - * Return saved PC of a blocked thread. - * What is this good for? it will be always the scheduler or ret_from_fork. - */ -#define thread_saved_pc(t)	READ_ONCE_NOCHECK(*(unsigned long *)((t)->thread.sp - 8)) -  #define task_pt_regs(tsk)	((struct pt_regs *)(tsk)->thread.sp0 - 1)  extern unsigned long KSTK_ESP(struct task_struct *task);  #endif /* CONFIG_X86_64 */ +extern unsigned long thread_saved_pc(struct task_struct *tsk); +  extern void start_thread(struct pt_regs *regs, unsigned long new_ip,  					       unsigned long new_sp); |