mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 0500871f21
			
		
	
	
		0500871f21
		
	
	
	
	
		
			
			Construct the init thread stack in the linker script rather than doing it by means of a union so that ia64's init_task.c can be got rid of. The following symbols are then made available from INIT_TASK_DATA() linker script macro: init_thread_union init_stack INIT_TASK_DATA() also expands the region to THREAD_SIZE to accommodate the size of the init stack. init_thread_union is given its own section so that it can be placed into the stack space in the right order. I'm assuming that the ia64 ordering is correct and that the task_struct is first and the thread_info second. Signed-off-by: David Howells <dhowells@redhat.com> Tested-by: Tony Luck <tony.luck@intel.com> Tested-by: Will Deacon <will.deacon@arm.com> (arm64) Tested-by: Palmer Dabbelt <palmer@sifive.com> Acked-by: Thomas Gleixner <tglx@linutronix.de>
		
			
				
	
	
		
			93 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef _ASM_PARISC_THREAD_INFO_H
 | |
| #define _ASM_PARISC_THREAD_INFO_H
 | |
| 
 | |
| #ifdef __KERNEL__
 | |
| 
 | |
| #ifndef __ASSEMBLY__
 | |
| #include <asm/processor.h>
 | |
| #include <asm/special_insns.h>
 | |
| 
 | |
| struct thread_info {
 | |
| 	struct task_struct *task;	/* main task structure */
 | |
| 	unsigned long flags;		/* thread_info flags (see TIF_*) */
 | |
| 	mm_segment_t addr_limit;	/* user-level address space limit */
 | |
| 	__u32 cpu;			/* current CPU */
 | |
| 	int preempt_count;		/* 0=premptable, <0=BUG; will also serve as bh-counter */
 | |
| };
 | |
| 
 | |
| #define INIT_THREAD_INFO(tsk)			\
 | |
| {						\
 | |
| 	.task		= &tsk,			\
 | |
| 	.flags		= 0,			\
 | |
| 	.cpu		= 0,			\
 | |
| 	.addr_limit	= KERNEL_DS,		\
 | |
| 	.preempt_count	= INIT_PREEMPT_COUNT,	\
 | |
| }
 | |
| 
 | |
| /* how to get the thread information struct from C */
 | |
| #define current_thread_info()	((struct thread_info *)mfctl(30))
 | |
| 
 | |
| #endif /* !__ASSEMBLY */
 | |
| 
 | |
| /* thread information allocation */
 | |
| 
 | |
| #ifdef CONFIG_IRQSTACKS
 | |
| #define THREAD_SIZE_ORDER	2 /* PA-RISC requires at least 16k stack */
 | |
| #else
 | |
| #define THREAD_SIZE_ORDER	3 /* PA-RISC requires at least 32k stack */
 | |
| #endif
 | |
| 
 | |
| /* Be sure to hunt all references to this down when you change the size of
 | |
|  * the kernel stack */
 | |
| #define THREAD_SIZE             (PAGE_SIZE << THREAD_SIZE_ORDER)
 | |
| #define THREAD_SHIFT            (PAGE_SHIFT + THREAD_SIZE_ORDER)
 | |
| 
 | |
| /*
 | |
|  * thread information flags
 | |
|  */
 | |
| #define TIF_SYSCALL_TRACE	0	/* syscall trace active */
 | |
| #define TIF_SIGPENDING		1	/* signal pending */
 | |
| #define TIF_NEED_RESCHED	2	/* rescheduling necessary */
 | |
| #define TIF_POLLING_NRFLAG	3	/* true if poll_idle() is polling TIF_NEED_RESCHED */
 | |
| #define TIF_32BIT               4       /* 32 bit binary */
 | |
| #define TIF_MEMDIE		5	/* is terminating due to OOM killer */
 | |
| #define TIF_SYSCALL_AUDIT	7	/* syscall auditing active */
 | |
| #define TIF_NOTIFY_RESUME	8	/* callback before returning to user */
 | |
| #define TIF_SINGLESTEP		9	/* single stepping? */
 | |
| #define TIF_BLOCKSTEP		10	/* branch stepping? */
 | |
| #define TIF_SECCOMP		11	/* secure computing */
 | |
| #define TIF_SYSCALL_TRACEPOINT	12	/* syscall tracepoint instrumentation */
 | |
| 
 | |
| #define _TIF_SYSCALL_TRACE	(1 << TIF_SYSCALL_TRACE)
 | |
| #define _TIF_SIGPENDING		(1 << TIF_SIGPENDING)
 | |
| #define _TIF_NEED_RESCHED	(1 << TIF_NEED_RESCHED)
 | |
| #define _TIF_POLLING_NRFLAG	(1 << TIF_POLLING_NRFLAG)
 | |
| #define _TIF_32BIT		(1 << TIF_32BIT)
 | |
| #define _TIF_SYSCALL_AUDIT	(1 << TIF_SYSCALL_AUDIT)
 | |
| #define _TIF_NOTIFY_RESUME	(1 << TIF_NOTIFY_RESUME)
 | |
| #define _TIF_SINGLESTEP		(1 << TIF_SINGLESTEP)
 | |
| #define _TIF_BLOCKSTEP		(1 << TIF_BLOCKSTEP)
 | |
| #define _TIF_SECCOMP		(1 << TIF_SECCOMP)
 | |
| #define _TIF_SYSCALL_TRACEPOINT	(1 << TIF_SYSCALL_TRACEPOINT)
 | |
| 
 | |
| #define _TIF_USER_WORK_MASK     (_TIF_SIGPENDING | _TIF_NOTIFY_RESUME | \
 | |
|                                  _TIF_NEED_RESCHED)
 | |
| #define _TIF_SYSCALL_TRACE_MASK (_TIF_SYSCALL_TRACE | _TIF_SINGLESTEP |	\
 | |
| 				 _TIF_BLOCKSTEP | _TIF_SYSCALL_AUDIT | \
 | |
| 				 _TIF_SECCOMP | _TIF_SYSCALL_TRACEPOINT)
 | |
| 
 | |
| #ifdef CONFIG_64BIT
 | |
| # ifdef CONFIG_COMPAT
 | |
| #  define is_32bit_task()	(test_thread_flag(TIF_32BIT))
 | |
| # else
 | |
| #  define is_32bit_task()	(0)
 | |
| # endif
 | |
| #else
 | |
| # define is_32bit_task()	(1)
 | |
| #endif
 | |
| 
 | |
| #endif /* __KERNEL__ */
 | |
| 
 | |
| #endif /* _ASM_PARISC_THREAD_INFO_H */
 |