/* * low level task data that entry.S needs immediate access to * - this struct should fit entirely inside of one cache line * - this struct shares the supervisor stack pages * - if the contents of this structure are changed, the assembly constants * must also be changed
*/ struct thread_info { struct task_struct *task; /* main task structure */ unsignedlong flags; /* low level flags */ unsignedlong tp_value; /* thread pointer */
__u32 cpu; /* current CPU */ int preempt_count; /* 0 => preemptible, <0 => BUG */ struct pt_regs *regs; unsignedlong syscall; /* syscall number */ unsignedlong syscall_work; /* SYSCALL_WORK_ flags */
};
/* * macros/functions for gaining access to the thread information structure
*/ #define INIT_THREAD_INFO(tsk) \
{ \
.task = &tsk, \
.flags = _TIF_FIXADE, \
.cpu = 0, \
.preempt_count = INIT_PREEMPT_COUNT, \
}
/* How to get the thread information struct from C. */ registerstruct thread_info *__current_thread_info __asm__("$tp");
/* thread information allocation */ #define THREAD_SIZE SZ_16K #define THREAD_MASK (THREAD_SIZE - 1UL) #define THREAD_SIZE_ORDER ilog2(THREAD_SIZE / PAGE_SIZE) /* * thread information flags * - these are process state flags that various assembly files may need to * access * - pending work-to-be-done flags are in LSW * - other flags in MSW
*/ #define TIF_NEED_RESCHED 0/* rescheduling necessary */ #define TIF_NEED_RESCHED_LAZY 1/* lazy rescheduling necessary */ #define TIF_SIGPENDING 2/* signal pending */ #define TIF_NOTIFY_RESUME 3/* callback before returning to user */ #define TIF_NOTIFY_SIGNAL 4/* signal notifications exist */ #define TIF_RESTORE_SIGMASK 5/* restore signal mask in do_signal() */ #define TIF_NOHZ 6/* in adaptive nohz mode */ #define TIF_UPROBE 7/* breakpointed or singlestepping */ #define TIF_USEDFPU 8/* FPU was used by this task this quantum (SMP) */ #define TIF_USEDSIMD 9/* SIMD has been used this quantum */ #define TIF_MEMDIE 10/* is terminating due to OOM killer */ #define TIF_FIXADE 11/* Fix address errors in software */ #define TIF_LOGADE 12/* Log address errors to syslog */ #define TIF_32BIT_REGS 13/* 32-bit general purpose registers */ #define TIF_32BIT_ADDR 14/* 32-bit address space */ #define TIF_LOAD_WATCH 15/* If set, load watch registers */ #define TIF_SINGLESTEP 16/* Single Step */ #define TIF_LSX_CTX_LIVE 17/* LSX context must be preserved */ #define TIF_LASX_CTX_LIVE 18/* LASX context must be preserved */ #define TIF_USEDLBT 19/* LBT was used by this task this quantum (SMP) */ #define TIF_LBT_CTX_LIVE 20/* LBT context must be preserved */ #define TIF_PATCH_PENDING 21/* pending live patching update */
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.