|
version 1.31.2.2, 2023/02/23 17:13:01
|
version 1.34.2.2, 2026/05/19 15:47:47
|
|
Line 12 terms:
|
Line 12 terms:
|
| All of the documentation and software included in the ELWIX and AITNET |
All of the documentation and software included in the ELWIX and AITNET |
| Releases is copyrighted by ELWIX - Sofia/Bulgaria <info@elwix.org> |
Releases is copyrighted by ELWIX - Sofia/Bulgaria <info@elwix.org> |
| |
|
| Copyright 2004 - 2023 | Copyright 2004 - 2026 |
| by Michael Pounov <misho@elwix.org>. All rights reserved. |
by Michael Pounov <misho@elwix.org>. All rights reserved. |
| |
|
| Redistribution and use in source and binary forms, with or without |
Redistribution and use in source and binary forms, with or without |
|
Line 146 struct sched_HooksTask {
|
Line 146 struct sched_HooksTask {
|
| sched_hook_func_t exception; |
sched_hook_func_t exception; |
| /* condition(sched_root_task_t *root, intptr_t *stopValue) -> int */ |
/* condition(sched_root_task_t *root, intptr_t *stopValue) -> int */ |
| sched_hook_func_t condition; |
sched_hook_func_t condition; |
| |
/* profile(sched_task_t *root, intptr_t *stageValue) -> int */ |
| |
sched_hook_func_t profile; |
| } hook_exec; |
} hook_exec; |
| struct { |
struct { |
| /* init(sched_root_task_t *root, void *data) -> int */ |
/* init(sched_root_task_t *root, void *data) -> int */ |
|
Line 225 struct sched_RootTask {
|
Line 227 struct sched_RootTask {
|
| intptr_t root_cond[1]; |
intptr_t root_cond[1]; |
| void *root_ret; |
void *root_ret; |
| #ifdef HAVE_LIBPTHREAD |
#ifdef HAVE_LIBPTHREAD |
| |
pthread_mutex_t root_sigmtx; |
| pthread_t root_sigthr; |
pthread_t root_sigthr; |
| sigset_t root_sigset; |
sigset_t root_sigset; |
| |
sigset_t root_oldset; |
| #endif |
#endif |
| |
|
| pthread_mutex_t root_mtx[taskMAX]; |
pthread_mutex_t root_mtx[taskMAX]; |
|
Line 256 struct sched_RootTask {
|
Line 260 struct sched_RootTask {
|
| }; |
}; |
| #define ROOT_QUEUE_EMPTY(x, _q) TAILQ_EMPTY(&((x)->root_##_q)) |
#define ROOT_QUEUE_EMPTY(x, _q) TAILQ_EMPTY(&((x)->root_##_q)) |
| #define ROOT_RETURN(x) (x)->root_ret |
#define ROOT_RETURN(x) (x)->root_ret |
| |
#define ROOT_PROFILING(x, _cb) (x)->root_hooks.hook_exec.profile = (_cb) |
| |
|
| |
#ifdef __cplusplus |
| |
extern "C" { |
| |
#endif |
| |
|
| int sched_GetErrno(); |
int sched_GetErrno(); |
| const char *sched_GetError(); |
const char *sched_GetError(); |
|
Line 385 sched_task_t *schedQueryby(sched_root_task_t * __restr
|
Line 393 sched_task_t *schedQueryby(sched_root_task_t * __restr
|
| * |
* |
| * @root = root task |
* @root = root task |
| * @on = Activate or =0 deactivate |
* @on = Activate or =0 deactivate |
| * return: -1 error or 0 ok | * return: -1 error, 1 already started, 2 another thread already started or 0 ok |
| */ |
*/ |
| int schedSignalDispatch(sched_root_task_t * __restrict root, int on); |
int schedSignalDispatch(sched_root_task_t * __restrict root, int on); |
| |
|
|
Line 765 void *sched_taskExit(sched_task_t *task, intptr_t retc
|
Line 773 void *sched_taskExit(sched_task_t *task, intptr_t retc
|
| */ |
*/ |
| #define taskExit(t, x) return sched_taskExit((t), (intptr_t) (x)) |
#define taskExit(t, x) return sched_taskExit((t), (intptr_t) (x)) |
| |
|
| |
#ifdef __cplusplus |
| |
} |
| |
#endif |
| |
|
| #endif |
#endif |