mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-31 16:38:31 +00:00 
			
		
		
		
	 b69c49b784
			
		
	
	
		b69c49b784
		
	
	
	
	
		
			
			We duplicate alloc/free_thread_info defines on many platforms (the majority uses __get_free_pages/free_pages). This patch defines common defines and removes these duplicated defines. __HAVE_ARCH_THREAD_INFO_ALLOCATOR is introduced for platforms that do something different. Signed-off-by: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp> Acked-by: Russell King <rmk+kernel@arm.linux.org.uk> Cc: Pekka Enberg <penberg@cs.helsinki.fi> Cc: <linux-arch@vger.kernel.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
			
				
	
	
		
			57 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef _ASM_M68K_THREAD_INFO_H
 | |
| #define _ASM_M68K_THREAD_INFO_H
 | |
| 
 | |
| #include <asm/types.h>
 | |
| #include <asm/page.h>
 | |
| 
 | |
| struct thread_info {
 | |
| 	struct task_struct	*task;		/* main task structure */
 | |
| 	unsigned long		flags;
 | |
| 	struct exec_domain	*exec_domain;	/* execution domain */
 | |
| 	int			preempt_count;	/* 0 => preemptable, <0 => BUG */
 | |
| 	__u32 cpu; /* should always be 0 on m68k */
 | |
| 	struct restart_block    restart_block;
 | |
| };
 | |
| 
 | |
| #define PREEMPT_ACTIVE		0x4000000
 | |
| 
 | |
| #define INIT_THREAD_INFO(tsk)			\
 | |
| {						\
 | |
| 	.task		= &tsk,			\
 | |
| 	.exec_domain	= &default_exec_domain,	\
 | |
| 	.restart_block = {			\
 | |
| 		.fn = do_no_restart_syscall,	\
 | |
| 	},					\
 | |
| }
 | |
| 
 | |
| /* THREAD_SIZE should be 8k, so handle differently for 4k and 8k machines */
 | |
| #define THREAD_SIZE_ORDER (13 - PAGE_SHIFT)
 | |
| 
 | |
| #define init_thread_info	(init_task.thread.info)
 | |
| #define init_stack		(init_thread_union.stack)
 | |
| 
 | |
| #define task_thread_info(tsk)	(&(tsk)->thread.info)
 | |
| #define task_stack_page(tsk)	((tsk)->stack)
 | |
| #define current_thread_info()	task_thread_info(current)
 | |
| 
 | |
| #define __HAVE_THREAD_FUNCTIONS
 | |
| 
 | |
| #define setup_thread_stack(p, org) ({			\
 | |
| 	*(struct task_struct **)(p)->stack = (p);	\
 | |
| 	task_thread_info(p)->task = (p);		\
 | |
| })
 | |
| 
 | |
| #define end_of_stack(p) ((unsigned long *)(p)->stack + 1)
 | |
| 
 | |
| /* entry.S relies on these definitions!
 | |
|  * bits 0-7 are tested at every exception exit
 | |
|  * bits 8-15 are also tested at syscall exit
 | |
|  */
 | |
| #define TIF_SIGPENDING		6	/* signal pending */
 | |
| #define TIF_NEED_RESCHED	7	/* rescheduling necessary */
 | |
| #define TIF_DELAYED_TRACE	14	/* single step a syscall */
 | |
| #define TIF_SYSCALL_TRACE	15	/* syscall trace active */
 | |
| #define TIF_MEMDIE		16
 | |
| 
 | |
| #endif	/* _ASM_M68K_THREAD_INFO_H */
 |