diff options
Diffstat (limited to 'arch/x86/include/asm/thread_info.h')
| -rw-r--r-- | arch/x86/include/asm/thread_info.h | 64 | 
1 files changed, 5 insertions, 59 deletions
| diff --git a/arch/x86/include/asm/thread_info.h b/arch/x86/include/asm/thread_info.h index 8b7c8d8e0852..ad6f5eb07a95 100644 --- a/arch/x86/include/asm/thread_info.h +++ b/arch/x86/include/asm/thread_info.h @@ -53,20 +53,14 @@ struct task_struct;  #include <linux/atomic.h>  struct thread_info { -	struct task_struct	*task;		/* main task structure */ -	__u32			flags;		/* low level flags */ -	__u32			status;		/* thread synchronous flags */ -	__u32			cpu;		/* current CPU */ +	unsigned long		flags;		/* low level flags */  };  #define INIT_THREAD_INFO(tsk)			\  {						\ -	.task		= &tsk,			\  	.flags		= 0,			\ -	.cpu		= 0,			\  } -#define init_thread_info	(init_thread_union.thread_info)  #define init_stack		(init_thread_union.stack)  #else /* !__ASSEMBLY__ */ @@ -95,7 +89,6 @@ struct thread_info {  #define TIF_UPROBE		12	/* breakpointed or singlestepping */  #define TIF_NOTSC		16	/* TSC is not accessible in userland */  #define TIF_IA32		17	/* IA32 compatibility process */ -#define TIF_FORK		18	/* ret_from_fork */  #define TIF_NOHZ		19	/* in adaptive nohz mode */  #define TIF_MEMDIE		20	/* is terminating due to OOM killer */  #define TIF_POLLING_NRFLAG	21	/* idle is polling for TIF_NEED_RESCHED */ @@ -119,7 +112,6 @@ struct thread_info {  #define _TIF_UPROBE		(1 << TIF_UPROBE)  #define _TIF_NOTSC		(1 << TIF_NOTSC)  #define _TIF_IA32		(1 << TIF_IA32) -#define _TIF_FORK		(1 << TIF_FORK)  #define _TIF_NOHZ		(1 << TIF_NOHZ)  #define _TIF_POLLING_NRFLAG	(1 << TIF_POLLING_NRFLAG)  #define _TIF_IO_BITMAP		(1 << TIF_IO_BITMAP) @@ -160,11 +152,6 @@ struct thread_info {   */  #ifndef __ASSEMBLY__ -static inline struct thread_info *current_thread_info(void) -{ -	return (struct thread_info *)(current_top_of_stack() - THREAD_SIZE); -} -  static inline unsigned long current_stack_pointer(void)  {  	unsigned long sp; @@ -226,60 +213,19 @@ static inline int arch_within_stack_frames(const void * const stack,  # define cpu_current_top_of_stack (cpu_tss + TSS_sp0)  #endif -/* - * ASM operand which evaluates to a 'thread_info' address of - * the current task, if it is known that "reg" is exactly "off" - * bytes below the top of the stack currently. - * - * ( The kernel stack's size is known at build time, it is usually - *   2 or 4 pages, and the bottom  of the kernel stack contains - *   the thread_info structure. So to access the thread_info very - *   quickly from assembly code we can calculate down from the - *   top of the kernel stack to the bottom, using constant, - *   build-time calculations only. ) - * - * For example, to fetch the current thread_info->flags value into %eax - * on x86-64 defconfig kernels, in syscall entry code where RSP is - * currently at exactly SIZEOF_PTREGS bytes away from the top of the - * stack: - * - *      mov ASM_THREAD_INFO(TI_flags, %rsp, SIZEOF_PTREGS), %eax - * - * will translate to: - * - *      8b 84 24 b8 c0 ff ff      mov    -0x3f48(%rsp), %eax - * - * which is below the current RSP by almost 16K. - */ -#define ASM_THREAD_INFO(field, reg, off) ((field)+(off)-THREAD_SIZE)(reg) -  #endif -/* - * 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)*/  #ifdef CONFIG_COMPAT  #define TS_I386_REGS_POKED	0x0004	/* regs poked by 32-bit ptracer */  #endif -  #ifndef __ASSEMBLY__ -static inline bool in_ia32_syscall(void) -{  #ifdef CONFIG_X86_32 -	return true; -#endif -#ifdef CONFIG_IA32_EMULATION -	if (current_thread_info()->status & TS_COMPAT) -		return true; +#define in_ia32_syscall() true +#else +#define in_ia32_syscall() (IS_ENABLED(CONFIG_IA32_EMULATION) && \ +			   current->thread.status & TS_COMPAT)  #endif -	return false; -}  /*   * Force syscall return via IRET by making it look as if there was |