1c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru/* thread_info.h: i386 low-level thread information 2c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * 3c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * Copyright (C) 2002 David Howells (dhowells@redhat.com) 4c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * - Incorporating suggestions made by Linus Torvalds and Dave Miller 5c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru */ 6c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 7c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#ifndef _ASM_THREAD_INFO_H 8c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _ASM_THREAD_INFO_H 9c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 10c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#ifdef __KERNEL__ 11c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 12c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#include <linux/compiler.h> 13c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#include <asm/page.h> 14c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 15c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#ifndef __ASSEMBLY__ 16c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#include <asm/processor.h> 17c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#endif 18c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 19c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru/* 20c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * low level task data that entry.S needs immediate access to 21c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * - this struct should fit entirely inside of one cache line 22c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * - this struct shares the supervisor stack pages 23c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * - if the contents of this structure are changed, the assembly constants must also be changed 24c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru */ 25c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#ifndef __ASSEMBLY__ 26c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 27c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Querustruct thread_info { 28c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru struct task_struct *task; /* main task structure */ 29c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru struct exec_domain *exec_domain; /* execution domain */ 30c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru unsigned long flags; /* low level flags */ 31c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru unsigned long status; /* thread-synchronous flags */ 32c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru __u32 cpu; /* current CPU */ 33c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru int preempt_count; /* 0 => preemptable, <0 => BUG */ 34c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 35c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 36c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru mm_segment_t addr_limit; /* thread address space: 37c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 0-0xBFFFFFFF for user-thead 38c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 0-0xFFFFFFFF for kernel-thread 39c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru */ 40c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru void *sysenter_return; 41c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru struct restart_block restart_block; 42c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 43c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru unsigned long previous_esp; /* ESP of the previous stack in case 44c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru of nested (IRQ) stacks 45c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru */ 46c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru __u8 supervisor_stack[0]; 47c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru}; 48c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 49c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#else /* !__ASSEMBLY__ */ 50c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 51c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#include <asm/asm-offsets.h> 52c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 53c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#endif 54c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 55c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define PREEMPT_ACTIVE 0x10000000 56c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#ifdef CONFIG_4KSTACKS 57c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define THREAD_SIZE (4096) 58c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#else 59c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define THREAD_SIZE (8192) 60c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#endif 61c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 62c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define STACK_WARN (THREAD_SIZE/8) 63c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru/* 64c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * macros/functions for gaining access to the thread information structure 65c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * 66c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * preempt_count needs to be 1 initially, until the scheduler is functional. 67c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru */ 68c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#ifndef __ASSEMBLY__ 69c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 70c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define INIT_THREAD_INFO(tsk) \ 71c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru{ \ 72c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru .task = &tsk, \ 73c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru .exec_domain = &default_exec_domain, \ 74c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru .flags = 0, \ 75c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru .cpu = 0, \ 76c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru .preempt_count = 1, \ 77c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru .addr_limit = KERNEL_DS, \ 78c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru .restart_block = { \ 79c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru .fn = do_no_restart_syscall, \ 80c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru }, \ 81c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru} 82c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 83c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define init_thread_info (init_thread_union.thread_info) 84c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define init_stack (init_thread_union.stack) 85c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 86c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 87c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru/* how to get the current stack pointer from C */ 88c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queruregister unsigned long current_stack_pointer asm("esp") __attribute_used__; 89c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 90c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru/* how to get the thread information struct from C */ 91c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Querustatic inline struct thread_info *current_thread_info(void) 92c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru{ 93c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru return (struct thread_info *)(current_stack_pointer & ~(THREAD_SIZE - 1)); 94c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru} 95c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 96c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru/* thread information allocation */ 97c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#ifdef CONFIG_DEBUG_STACK_USAGE 98c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define alloc_thread_info(tsk) ((struct thread_info *) \ 99c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru __get_free_pages(GFP_KERNEL| __GFP_ZERO, get_order(THREAD_SIZE))) 100c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#else 101c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define alloc_thread_info(tsk) ((struct thread_info *) \ 102c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru __get_free_pages(GFP_KERNEL, get_order(THREAD_SIZE))) 103c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#endif 104c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 105c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define free_thread_info(info) free_pages((unsigned long)(info), get_order(THREAD_SIZE)) 106c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 107c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#else /* !__ASSEMBLY__ */ 108c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 109c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru/* how to get the thread information struct from ASM */ 110c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define GET_THREAD_INFO(reg) \ 111c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru movl $-THREAD_SIZE, reg; \ 112c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru andl %esp, reg 113c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 114c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru/* use this one if reg already contains %esp */ 115c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define GET_THREAD_INFO_WITH_ESP(reg) \ 116c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru andl $-THREAD_SIZE, reg 117c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 118c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#endif 119c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 120c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru/* 121c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * thread information flags 122c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * - these are process state flags that various assembly files may need to access 123c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * - pending work-to-be-done flags are in LSW 124c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * - other flags in MSW 125c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru */ 126c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TIF_SYSCALL_TRACE 0 /* syscall trace active */ 127c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TIF_SIGPENDING 1 /* signal pending */ 128c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TIF_NEED_RESCHED 2 /* rescheduling necessary */ 129c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TIF_SINGLESTEP 3 /* restore singlestep on return to user mode */ 130c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TIF_IRET 4 /* return with iret */ 131c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TIF_SYSCALL_EMU 5 /* syscall emulation active */ 132c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TIF_SYSCALL_AUDIT 6 /* syscall auditing active */ 133c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TIF_SECCOMP 7 /* secure computing */ 134c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TIF_RESTORE_SIGMASK 8 /* restore signal mask in do_signal() */ 135c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TIF_MEMDIE 16 136c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TIF_DEBUG 17 /* uses debug registers */ 137c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TIF_IO_BITMAP 18 /* uses I/O bitmap */ 138c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TIF_FREEZE 19 /* is freezing for suspend */ 139c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TIF_NOTSC 20 /* TSC is not accessible in userland */ 140c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 141c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_SYSCALL_TRACE (1<<TIF_SYSCALL_TRACE) 142c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_SIGPENDING (1<<TIF_SIGPENDING) 143c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_NEED_RESCHED (1<<TIF_NEED_RESCHED) 144c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_SINGLESTEP (1<<TIF_SINGLESTEP) 145c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_IRET (1<<TIF_IRET) 146c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_SYSCALL_EMU (1<<TIF_SYSCALL_EMU) 147c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_SYSCALL_AUDIT (1<<TIF_SYSCALL_AUDIT) 148c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_SECCOMP (1<<TIF_SECCOMP) 149c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_RESTORE_SIGMASK (1<<TIF_RESTORE_SIGMASK) 150c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_DEBUG (1<<TIF_DEBUG) 151c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_IO_BITMAP (1<<TIF_IO_BITMAP) 152c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_FREEZE (1<<TIF_FREEZE) 153c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_NOTSC (1<<TIF_NOTSC) 154c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 155c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru/* work to do on interrupt/exception return */ 156c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_WORK_MASK \ 157c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru (0x0000FFFF & ~(_TIF_SYSCALL_TRACE | _TIF_SYSCALL_AUDIT | \ 158c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru _TIF_SECCOMP | _TIF_SYSCALL_EMU)) 159c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru/* work to do on any return to u-space */ 160c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_ALLWORK_MASK (0x0000FFFF & ~_TIF_SECCOMP) 161c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 162c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru/* flags to check in __switch_to() */ 163c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_WORK_CTXSW_NEXT (_TIF_IO_BITMAP | _TIF_NOTSC | _TIF_DEBUG) 164c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define _TIF_WORK_CTXSW_PREV (_TIF_IO_BITMAP | _TIF_NOTSC) 165c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 166c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru/* 167c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * Thread-synchronous status. 168c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * 169c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * This is different from the flags in that nobody else 170c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * ever touches our thread-synchronous status, so we don't 171c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru * have to worry about atomic accesses. 172c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru */ 173c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TS_USEDFPU 0x0001 /* FPU was used by this task this quantum (SMP) */ 174c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define TS_POLLING 0x0002 /* True if in idle loop and not sleeping */ 175c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 176c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#define tsk_is_polling(t) (task_thread_info(t)->status & TS_POLLING) 177c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 178c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#endif /* __KERNEL__ */ 179c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru 180c559cd81139f97cecad1ad91a0b2e25a5936d53Jean-Baptiste Queru#endif /* _ASM_THREAD_INFO_H */ 181