1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */ 2cddafa35SGreg Ungerer #ifndef _ASM_M68K_THREAD_INFO_H 3cddafa35SGreg Ungerer #define _ASM_M68K_THREAD_INFO_H 4cddafa35SGreg Ungerer 5cddafa35SGreg Ungerer #include <asm/types.h> 6cddafa35SGreg Ungerer #include <asm/page.h> 7cddafa35SGreg Ungerer 8cddafa35SGreg Ungerer /* 9cddafa35SGreg Ungerer * On machines with 4k pages we default to an 8k thread size, though we 10cddafa35SGreg Ungerer * allow a 4k with config option. Any other machine page size then 11cddafa35SGreg Ungerer * the thread size must match the page size (which is 8k and larger here). 12cddafa35SGreg Ungerer */ 13cddafa35SGreg Ungerer #if PAGE_SHIFT < 13 14cddafa35SGreg Ungerer #ifdef CONFIG_4KSTACKS 15cddafa35SGreg Ungerer #define THREAD_SIZE 4096 1649148020SSam Ravnborg #else 17cddafa35SGreg Ungerer #define THREAD_SIZE 8192 1849148020SSam Ravnborg #endif 19cddafa35SGreg Ungerer #else 20cddafa35SGreg Ungerer #define THREAD_SIZE PAGE_SIZE 21cddafa35SGreg Ungerer #endif 22cddafa35SGreg Ungerer #define THREAD_SIZE_ORDER ((THREAD_SIZE / PAGE_SIZE) - 1) 23cddafa35SGreg Ungerer 24cddafa35SGreg Ungerer #ifndef __ASSEMBLY__ 25cddafa35SGreg Ungerer 26cddafa35SGreg Ungerer struct thread_info { 27cddafa35SGreg Ungerer struct task_struct *task; /* main task structure */ 28cddafa35SGreg Ungerer unsigned long flags; 29cddafa35SGreg Ungerer int preempt_count; /* 0 => preemptable, <0 => BUG */ 30cddafa35SGreg Ungerer __u32 cpu; /* should always be 0 on m68k */ 31cddafa35SGreg Ungerer unsigned long tp_value; /* thread pointer */ 32cddafa35SGreg Ungerer }; 33cddafa35SGreg Ungerer #endif /* __ASSEMBLY__ */ 34cddafa35SGreg Ungerer 35cddafa35SGreg Ungerer #define INIT_THREAD_INFO(tsk) \ 36cddafa35SGreg Ungerer { \ 37cddafa35SGreg Ungerer .task = &tsk, \ 38cddafa35SGreg Ungerer .preempt_count = INIT_PREEMPT_COUNT, \ 39cddafa35SGreg Ungerer } 40cddafa35SGreg Ungerer 41cddafa35SGreg Ungerer #ifndef __ASSEMBLY__ 42cddafa35SGreg Ungerer /* how to get the thread information struct from C */ current_thread_info(void)43cddafa35SGreg Ungererstatic inline struct thread_info *current_thread_info(void) 44cddafa35SGreg Ungerer { 45cddafa35SGreg Ungerer struct thread_info *ti; 46cddafa35SGreg Ungerer __asm__( 47cddafa35SGreg Ungerer "move.l %%sp, %0 \n\t" 48cddafa35SGreg Ungerer "and.l %1, %0" 49cddafa35SGreg Ungerer : "=&d"(ti) 50cddafa35SGreg Ungerer : "di" (~(THREAD_SIZE-1)) 51cddafa35SGreg Ungerer ); 52cddafa35SGreg Ungerer return ti; 53cddafa35SGreg Ungerer } 54cddafa35SGreg Ungerer #endif 55cddafa35SGreg Ungerer 56cddafa35SGreg Ungerer /* entry.S relies on these definitions! 57cddafa35SGreg Ungerer * bits 0-7 are tested at every exception exit 58cddafa35SGreg Ungerer * bits 8-15 are also tested at syscall exit 59cddafa35SGreg Ungerer */ 60e660653cSJens Axboe #define TIF_NOTIFY_SIGNAL 4 61a54f1655SAl Viro #define TIF_NOTIFY_RESUME 5 /* callback before returning to user */ 62cddafa35SGreg Ungerer #define TIF_SIGPENDING 6 /* signal pending */ 63cddafa35SGreg Ungerer #define TIF_NEED_RESCHED 7 /* rescheduling necessary */ 64*6baaade1SMichael Schmitz #define TIF_SECCOMP 13 /* seccomp syscall filtering active */ 65cddafa35SGreg Ungerer #define TIF_DELAYED_TRACE 14 /* single step a syscall */ 66cddafa35SGreg Ungerer #define TIF_SYSCALL_TRACE 15 /* syscall trace active */ 67cddafa35SGreg Ungerer #define TIF_MEMDIE 16 /* is terminating due to OOM killer */ 68e68847feSAl Viro #define TIF_RESTORE_SIGMASK 18 /* restore signal mask in do_signal */ 69cddafa35SGreg Ungerer 7062148d98SGeert Uytterhoeven #define _TIF_NOTIFY_RESUME (1 << TIF_NOTIFY_RESUME) 7162148d98SGeert Uytterhoeven #define _TIF_SIGPENDING (1 << TIF_SIGPENDING) 7262148d98SGeert Uytterhoeven #define _TIF_NEED_RESCHED (1 << TIF_NEED_RESCHED) 73*6baaade1SMichael Schmitz #define _TIF_SECCOMP (1 << TIF_SECCOMP) 7462148d98SGeert Uytterhoeven #define _TIF_DELAYED_TRACE (1 << TIF_DELAYED_TRACE) 7562148d98SGeert Uytterhoeven #define _TIF_SYSCALL_TRACE (1 << TIF_SYSCALL_TRACE) 7662148d98SGeert Uytterhoeven #define _TIF_MEMDIE (1 << TIF_MEMDIE) 7762148d98SGeert Uytterhoeven #define _TIF_RESTORE_SIGMASK (1 << TIF_RESTORE_SIGMASK) 7862148d98SGeert Uytterhoeven 79cddafa35SGreg Ungerer #endif /* _ASM_M68K_THREAD_INFO_H */ 80