version 1.11.2.11, 2012/08/02 13:45:02
|
version 1.15.2.1, 2012/08/21 13:15:49
|
Line 53 SUCH DAMAGE.
|
Line 53 SUCH DAMAGE.
|
#include <sys/uio.h> |
#include <sys/uio.h> |
#include <stdint.h> |
#include <stdint.h> |
#include <pthread.h> |
#include <pthread.h> |
|
#include <assert.h> |
#ifdef EVFILT_LIO |
#ifdef EVFILT_LIO |
#include <aio.h> |
#include <aio.h> |
#endif |
#endif |
Line 85 typedef enum {
|
Line 86 typedef enum {
|
taskLIO, |
taskLIO, |
taskUSER, |
taskUSER, |
taskEVENT, |
taskEVENT, |
taskEVENTLO, | taskTASK, |
taskSUSPEND, |
taskSUSPEND, |
taskREADY, |
taskREADY, |
taskUNUSE, |
taskUNUSE, |
|
taskTHREAD, |
taskMAX |
taskMAX |
} sched_task_type_t; |
} sched_task_type_t; |
|
|
Line 118 struct sched_HooksTask {
|
Line 120 struct sched_HooksTask {
|
sched_hook_func_t user; |
sched_hook_func_t user; |
/* event(sched_task_t *task, NULL) -> int */ |
/* event(sched_task_t *task, NULL) -> int */ |
sched_hook_func_t event; |
sched_hook_func_t event; |
/* eventlo(sched_task_t *task, NULL) -> int */ | /* task(sched_task_t *task, NULL) -> int */ |
sched_hook_func_t eventlo; | sched_hook_func_t task; |
/* suspend(sched_task_t *task, NULL) -> int */ |
/* suspend(sched_task_t *task, NULL) -> int */ |
sched_hook_func_t suspend; |
sched_hook_func_t suspend; |
|
/* thread(sched_task_t *task, NULL) -> int */ |
|
sched_hook_func_t thread; |
} hook_add; |
} hook_add; |
struct { |
struct { |
|
/* exit(sched_task_t *task, void *exitValue) -> int */ |
|
sched_hook_func_t exit; |
/* cancel(sched_task_t *task, NULL) -> int */ |
/* cancel(sched_task_t *task, NULL) -> int */ |
sched_hook_func_t cancel; |
sched_hook_func_t cancel; |
/* resume(sched_task_t *task, NULL) -> int */ |
/* resume(sched_task_t *task, NULL) -> int */ |
Line 158 typedef void *(*sched_task_func_t)(sched_task_t * /* c
|
Line 164 typedef void *(*sched_task_func_t)(sched_task_t * /* c
|
|
|
/* task & queue */ |
/* task & queue */ |
struct sched_Task { |
struct sched_Task { |
volatile int task_lock; |
|
uintptr_t task_id; |
uintptr_t task_id; |
#define TASK_ID(x) ((struct sched_Task*) (x)->task_id) |
#define TASK_ID(x) ((struct sched_Task*) (x)->task_id) |
sched_task_type_t task_type; |
sched_task_type_t task_type; |
#define TASK_TYPE(x) (x)->task_type |
#define TASK_TYPE(x) (x)->task_type |
|
volatile int task_lock; |
|
|
sched_root_task_t *task_root; |
sched_root_task_t *task_root; |
#define TASK_ROOT(x) (x)->task_root |
#define TASK_ROOT(x) (x)->task_root |
sched_task_func_t task_func; |
sched_task_func_t task_func; |
#define TASK_FUNC(x) (x)->task_func |
#define TASK_FUNC(x) (x)->task_func |
|
intptr_t task_ret; |
|
#define TASK_RET(x) (x)->task_ret |
|
unsigned int task_flag; |
|
#define TASK_FLAG(x) (x)->task_flag |
|
|
void *task_arg; |
void *task_arg; |
union { |
union { |
Line 197 typedef TAILQ_HEAD(, sched_Task) sched_queue_t;
|
Line 207 typedef TAILQ_HEAD(, sched_Task) sched_queue_t;
|
/* root task */ |
/* root task */ |
struct sched_RootTask { |
struct sched_RootTask { |
int root_kq; |
int root_kq; |
|
unsigned long root_miss; |
struct timespec root_wait; |
struct timespec root_wait; |
struct timespec root_poll; |
struct timespec root_poll; |
intptr_t root_cond; |
intptr_t root_cond; |
Line 215 struct sched_RootTask {
|
Line 226 struct sched_RootTask {
|
sched_queue_t root_lio; |
sched_queue_t root_lio; |
sched_queue_t root_user; |
sched_queue_t root_user; |
sched_queue_t root_event; |
sched_queue_t root_event; |
sched_queue_t root_eventlo; | sched_queue_t root_task; |
sched_queue_t root_suspend; |
sched_queue_t root_suspend; |
sched_queue_t root_ready; |
sched_queue_t root_ready; |
sched_queue_t root_unuse; |
sched_queue_t root_unuse; |
int root_eventlo_miss; | sched_queue_t root_thread; |
|
|
hooks_task_t root_hooks; |
hooks_task_t root_hooks; |
struct iovec root_data; |
struct iovec root_data; |
Line 258 int schedEnd(sched_root_task_t ** __restrict root);
|
Line 269 int schedEnd(sched_root_task_t ** __restrict root);
|
*/ |
*/ |
int schedRegisterHooks(sched_root_task_t * __restrict root); |
int schedRegisterHooks(sched_root_task_t * __restrict root); |
/* |
/* |
|
* sched_useTask() - Get and init new task |
|
* |
|
* @root = root task |
|
* return: NULL error or !=NULL prepared task |
|
*/ |
|
inline sched_task_t *sched_useTask(sched_root_task_t * __restrict root); |
|
/* |
|
* sched_unuseTask() - Unlock and put task to unuse queue |
|
* |
|
* @task = task |
|
* return: always is NULL |
|
*/ |
|
inline sched_task_t *sched_unuseTask(sched_task_t * __restrict task); |
|
/* |
* schedPolling() - Polling timeout period if no timer task is present |
* schedPolling() - Polling timeout period if no timer task is present |
* |
* |
* @root = root task |
* @root = root task |
Line 272 inline int schedPolling(sched_root_task_t * __restrict
|
Line 297 inline int schedPolling(sched_root_task_t * __restrict
|
* |
* |
* @root = root task |
* @root = root task |
* @condValue = condition value, kill schedRun() if condValue == killState |
* @condValue = condition value, kill schedRun() if condValue == killState |
* return: -1 error ok 0 ok | * return: -1 error or 0 ok |
*/ |
*/ |
inline int schedTermCondition(sched_root_task_t * __restrict root, intptr_t condValue); |
inline int schedTermCondition(sched_root_task_t * __restrict root, intptr_t condValue); |
/* |
/* |
Line 550 sched_task_t *schedEvent(sched_root_task_t * __restric
|
Line 575 sched_task_t *schedEvent(sched_root_task_t * __restric
|
#define schedEventSelf(x) schedEvent(TASK_ROOT((x)), TASK_FUNC((x)), TASK_ARG((x)), \ |
#define schedEventSelf(x) schedEvent(TASK_ROOT((x)), TASK_FUNC((x)), TASK_ARG((x)), \ |
TASK_VAL((x)), TASK_DATA((x)), TASK_DATLEN((x))) |
TASK_VAL((x)), TASK_DATA((x)), TASK_DATLEN((x))) |
/* |
/* |
* schedEventLo() - Add EVENT_Lo task to scheduler queue | * schedTask() - Add regular task to scheduler queue |
* |
* |
* @root = root task |
* @root = root task |
* @func = task execution function |
* @func = task execution function |
* @arg = 1st func argument |
* @arg = 1st func argument |
* @val = additional func argument | * @prio = regular task priority, 0 is hi priority for regular tasks |
* @opt_data = Optional data |
* @opt_data = Optional data |
* @opt_dlen = Optional data length |
* @opt_dlen = Optional data length |
* return: NULL error or !=NULL new queued task |
* return: NULL error or !=NULL new queued task |
*/ |
*/ |
sched_task_t *schedEventLo(sched_root_task_t * __restrict root, sched_task_func_t func, void *arg, | sched_task_t *schedTask(sched_root_task_t * __restrict root, sched_task_func_t func, void *arg, |
unsigned long val, void *opt_data, size_t opt_dlen); | unsigned long prio, void *opt_data, size_t opt_dlen); |
#define schedEventLoSelf(x) schedEventLo(TASK_ROOT((x)), TASK_FUNC((x)), TASK_ARG((x)), \ | #define schedTaskSelf(x) schedTask(TASK_ROOT((x)), TASK_FUNC((x)), TASK_ARG((x)), \ |
TASK_VAL((x)), TASK_DATA((x)), TASK_DATLEN((x))) |
TASK_VAL((x)), TASK_DATA((x)), TASK_DATLEN((x))) |
/* |
/* |
* schedSuspend() - Add Suspended task to scheduler queue |
* schedSuspend() - Add Suspended task to scheduler queue |
Line 605 sched_task_t *schedCallOnce(sched_root_task_t * __rest
|
Line 630 sched_task_t *schedCallOnce(sched_root_task_t * __rest
|
unsigned long val, void *opt_data, size_t opt_dlen); |
unsigned long val, void *opt_data, size_t opt_dlen); |
#define schedCallAgain(x) schedCallOnce(TASK_ROOT((x)), TASK_FUNC((x)), TASK_ARG((x)), \ |
#define schedCallAgain(x) schedCallOnce(TASK_ROOT((x)), TASK_FUNC((x)), TASK_ARG((x)), \ |
TASK_VAL((x)), TASK_DATA((x)), TASK_DATLEN((x))) |
TASK_VAL((x)), TASK_DATA((x)), TASK_DATLEN((x))) |
|
|
|
/* |
|
* schedThread() - Add thread task to scheduler queue |
|
* |
|
* @root = root task |
|
* @func = task execution function |
|
* @arg = 1st func argument |
|
* @detach = Detach thread from scheduler, if !=0 |
|
* @opt_data = Optional data |
|
* @opt_dlen = Optional data length |
|
* return: NULL error or !=NULL new queued task |
|
*/ |
|
sched_task_t *schedThread(sched_root_task_t * __restrict root, sched_task_func_t func, void *arg, |
|
int detach, void *opt_data, size_t opt_dlen); |
|
#define schedThreadSelf(x) schedThread(TASK_ROOT((x)), TASK_FUNC((x)), TASK_ARG((x)), \ |
|
TASK_VAL((x)), TASK_DATA((x)), TASK_DATLEN((x))) |
|
/* |
|
* taskExit() - Exit routine for scheduler task |
|
* |
|
* @t = current executed task |
|
* @x = exit value for task |
|
* return: none |
|
*/ |
|
#define taskExit(t, x) do { assert((t) && TASK_ROOT(t)); \ |
|
if (TASK_ROOT(t)->root_hooks.hook_exec.exit) \ |
|
TASK_ROOT(t)->root_hooks.hook_exec.exit((t), \ |
|
(void*) (x)); \ |
|
TASK_ROOT(t)->root_ret = (void*) (x); \ |
|
if (TASK_TYPE(t) == taskTHREAD) { \ |
|
sched_unuseTask(t); \ |
|
pthread_exit((void*) (x)); \ |
|
} else \ |
|
return ((void*) (x)); \ |
|
} while (0) |
|
#define taskKill(t, s) do { assert((t) && TASK_ROOT(t)); \ |
|
if (TASK_TYPE(t) == taskTHREAD) { \ |
|
pthread_t _tid = (pthread_t) TASK_VAL((t)); \ |
|
sched_unuseTask(t); \ |
|
pthread_kill(_tid, (s)); \ |
|
} else \ |
|
schedCancel((t)); \ |
|
} while (0) |
|
|
|
|
#endif |
#endif |