/* SPDX-License-Identifier: GPL-2.0 */ #ifndef _ASM_M68K_THREAD_INFO_H #define _ASM_M68K_THREAD_INFO_H #include <asm/types.h> #include <asm/page.h> #include <asm/segment.h> /* * On machines with 4k pages we default to an 8k thread size, though we * allow a 4k with config option. Any other machine page size then * the thread size must match the page size (which is 8k and larger here). */ #if PAGE_SHIFT < 13 #ifdef CONFIG_4KSTACKS #define THREAD_SIZE 4096 #else #define THREAD_SIZE 8192 #endif #else #define THREAD_SIZE PAGE_SIZE #endif #define THREAD_SIZE_ORDER ((THREAD_SIZE / PAGE_SIZE) - 1) #ifndef __ASSEMBLY__ struct thread_info { struct task_struct *task; /* main task structure */ unsigned long flags; mm_segment_t addr_limit; /* thread address space */ int preempt_count; /* 0 => preemptable, <0 => BUG */ __u32 cpu; /* should always be 0 on m68k */ unsigned long tp_value; /* thread pointer */ }; #endif /* __ASSEMBLY__ */ #define INIT_THREAD_INFO(tsk) \ { \ .task = &tsk, \ .addr_limit = KERNEL_DS, \ .preempt_count = INIT_PREEMPT_COUNT, \ } #define init_stack (init_thread_union.stack) #ifndef __ASSEMBLY__ /* how to get the thread information struct from C */
static inline struct thread_info *current_thread_info(void) { struct thread_info *ti; __asm__( "move.l %%sp, %0 \n\t" "and.l %1, %0" : "=&d"(ti) : "di" (~(THREAD_SIZE-1)) ); return ti; }Contributors
Person | Tokens | Prop | Commits | CommitProp |
Greg Ungerer | 20 | 100.00% | 1 | 100.00% |
Total | 20 | 100.00% | 1 | 100.00% |
Person | Tokens | Prop | Commits | CommitProp |
Greg Ungerer | 152 | 90.48% | 2 | 28.57% |
Al Viro | 10 | 5.95% | 2 | 28.57% |
Sam Ravnborg | 4 | 2.38% | 1 | 14.29% |
Greg Kroah-Hartman | 1 | 0.60% | 1 | 14.29% |
Richard Weinberger | 1 | 0.60% | 1 | 14.29% |
Total | 168 | 100.00% | 7 | 100.00% |