2005-04-17 02:20:36 +04:00
# 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 */
2005-11-14 03:06:59 +03:00
unsigned long flags ;
2005-04-17 02:20:36 +04:00
struct exec_domain * exec_domain ; /* execution domain */
2005-06-23 11:09:07 +04:00
int preempt_count ; /* 0 => preemptable, <0 => BUG */
2005-04-17 02:20:36 +04:00
__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 */
2005-11-14 03:06:58 +03:00
# define init_thread_info (init_task.thread.info)
2005-04-17 02:20:36 +04:00
# define init_stack (init_thread_union.stack)
2005-11-14 03:06:58 +03:00
# define task_thread_info(tsk) (&(tsk)->thread.info)
2007-05-09 13:35:17 +04:00
# define task_stack_page(tsk) ((tsk)->stack)
2005-11-14 03:06:58 +03:00
# define current_thread_info() task_thread_info(current)
2005-04-17 02:20:36 +04:00
# define __HAVE_THREAD_FUNCTIONS
2005-11-14 03:06:58 +03:00
# define setup_thread_stack(p, org) ({ \
2007-05-09 13:35:17 +04:00
* ( struct task_struct * * ) ( p ) - > stack = ( p ) ; \
2005-11-14 03:06:58 +03:00
task_thread_info ( p ) - > task = ( p ) ; \
} )
2007-05-09 13:35:17 +04:00
# define end_of_stack(p) ((unsigned long *)(p)->stack + 1)
2005-11-14 03:06:58 +03:00
2005-11-14 03:06:59 +03:00
/* entry.S relies on these definitions!
* bits 0 - 7 are tested at every exception exit
* bits 8 - 15 are also tested at syscall exit
2005-04-17 02:20:36 +04:00
*/
2005-11-14 03:06:59 +03:00
# 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
2005-04-17 02:20:36 +04:00
# endif /* _ASM_M68K_THREAD_INFO_H */