mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 9fc658763b
			
		
	
	
		9fc658763b
		
	
	
	
	
		
			
			Patchset annotates arch/* uses of ->thread_info. Ones that really are about access of thread_info of given process are simply switched to task_thread_info(task); ones that deal with access to objects on stack are switched to new helper - task_stack_page(). A _lot_ of the latter are actually open-coded instances of "find where pt_regs are"; those are consolidated into task_pt_regs(task) (many architectures actually have such helper already). Note that these annotations are not mandatory - any code not converted to these helpers still works. However, they clean up a lot of places and have actually caught a number of bugs, so converting out of tree ports would be a good idea... As an example of breakage caught by that stuff, see i386 pt_regs mess - we used to have it open-coded in a bunch of places and when back in April Stas had fixed a bug in copy_thread(), the rest had been left out of sync. That required two followup patches (the latest - just before 2.6.15) _and_ still had left /proc/*/stat eip field broken. Try ps -eo eip on i386 and watch the junk... This patch: new helper - task_stack_page(task). Returns pointer to the memory object containing task stack; usually thread_info of task sits in the beginning of that object. Signed-off-by: Al Viro <viro@zeniv.linux.org.uk> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
		
			
				
	
	
		
			63 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			2.0 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 */
 | |
| #if PAGE_SHIFT == 13 /* 8k machines */
 | |
| #define alloc_thread_info(tsk)   ((struct thread_info *)__get_free_pages(GFP_KERNEL,0))
 | |
| #define free_thread_info(ti)  free_pages((unsigned long)(ti),0)
 | |
| #else /* otherwise assume 4k pages */
 | |
| #define alloc_thread_info(tsk)   ((struct thread_info *)__get_free_pages(GFP_KERNEL,1))
 | |
| #define free_thread_info(ti)  free_pages((unsigned long)(ti),1)
 | |
| #endif /* PAGE_SHIFT == 13 */
 | |
| 
 | |
| #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)	((void *)(tsk)->thread_info)
 | |
| #define current_thread_info()	task_thread_info(current)
 | |
| 
 | |
| #define __HAVE_THREAD_FUNCTIONS
 | |
| 
 | |
| #define setup_thread_stack(p, org) ({			\
 | |
| 	*(struct task_struct **)(p)->thread_info = (p);	\
 | |
| 	task_thread_info(p)->task = (p);		\
 | |
| })
 | |
| 
 | |
| #define end_of_stack(p) ((unsigned long *)(p)->thread_info + 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 */
 |