// IBM_PROLOG_BEGIN_TAG // This is an automatically generated prolog. // // $Source: src/include/kernel/task.H $ // // IBM CONFIDENTIAL // // COPYRIGHT International Business Machines Corp. 2010 - 2011 // // p1 // // Object Code Only (OCO) source materials // Licensed Internal Code Source Materials // IBM HostBoot Licensed Internal Code // // The source code for this program is not published or other- // wise divested of its trade secrets, irrespective of what has // been deposited with the U.S. Copyright Office. // // Origin: 30 // // IBM_PROLOG_END /** @file task.H * @brief Defines kernel information about tasks. */ #ifndef __KERNEL_TASK_H #define __KERNEL_TASK_H #include /** @struct context_t * @brief Defines the save-restore context for the task. * * See PowerISA for information on registers listed. */ struct context_t { void* stack_ptr; void* nip; uint64_t gprs[32]; uint64_t lr; uint64_t cr; uint64_t ctr; uint64_t xer; }; /** @struct context_fp_t * @brief Defines the save-restore context for the floating point registers * associated with a task. * * See PowerISA for information on registers listed. */ struct context_fp_t { uint64_t fprs[32]; uint64_t fpscr; }; enum task_states { /** Task is currently running. */ TASK_STATE_RUNNING = 'R', /** Task is on scheduler queue ready to run. */ TASK_STATE_READY = 'r', /** Task has ended or crashed. */ TASK_STATE_ENDED = 'E', /** Task is blocked on a futex. */ TASK_STATE_BLOCK_FUTEX = 'f', /** Task is blocked on a message queue. */ TASK_STATE_BLOCK_MSG = 'M', /** Task is defered due to a kernel->userspace request. */ TASK_STATE_BLOCK_USRSPACE = 'u', /** Task is blocked sleeping. */ TASK_STATE_BLOCK_SLEEP = 's', /** Task is blocked on join. */ TASK_STATE_BLOCK_JOIN = 'j', }; // Forward declaration. struct task_tracking_t; /** @struct task_t * @brief The kernel-level task structure. */ struct task_t { /** Pointer to the CPU this task is assigned to. */ cpu_t* cpu; /** Context information. This MUST stay here due to * save-restore asm code. */ context_t context; /** Pointer to optional floating point context. */ context_fp_t* fp_context; /** Task ID */ tid_t tid; /** Determines if user-space would like this task pinned to a CPU. * This value is considered a count of the number of times the pinned * as been requested, so pinning can be used recursively. */ uint64_t affinity_pinned; /** State of task */ task_states state; /** Extra info about the state. * This is used when the task is blocked to give a pointer to the * object the task is blocked on. */ void* state_info; /** Pointer to tracking tree for joining, parent info, etc. */ task_tracking_t* tracker; /** Detached state of the task. */ bool detached; // Pointers for queue containers. task_t* prev; task_t* next; }; // Macros for manipulating task's saved contexts. #define TASK_GETARGN(t, n) (t->context.gprs[n+4]) #define TASK_GETARG0(t) (TASK_GETARGN(t,0)) #define TASK_GETARG1(t) (TASK_GETARGN(t,1)) #define TASK_GETARG2(t) (TASK_GETARGN(t,2)) #define TASK_GETARG3(t) (TASK_GETARGN(t,3)) #define TASK_GETARG4(t) (TASK_GETARGN(t,4)) #define TASK_GETARG5(t) (TASK_GETARGN(t,5)) #define TASK_GETARG6(t) (TASK_GETARGN(t,6)) #define TASK_GETARG7(t) (TASK_GETARGN(t,7)) #define TASK_SETRTN(t, n) (t->context.gprs[3] = (n)) #endif