version 1.11.2.2, 2012/08/01 12:49:26
|
version 1.12, 2012/08/02 13:56:19
|
Line 49 SUCH DAMAGE.
|
Line 49 SUCH DAMAGE.
|
|
|
#include <sys/types.h> |
#include <sys/types.h> |
#include <sys/queue.h> |
#include <sys/queue.h> |
|
#include <sys/event.h> |
#include <sys/uio.h> |
#include <sys/uio.h> |
#include <stdint.h> |
#include <stdint.h> |
#include <pthread.h> |
#include <pthread.h> |
|
#ifdef EVFILT_LIO |
|
#include <aio.h> |
|
#endif |
|
|
|
|
/* criteria type */ |
/* criteria type */ |
Line 78 typedef enum {
|
Line 82 typedef enum {
|
taskPROC, |
taskPROC, |
taskSIGNAL, |
taskSIGNAL, |
taskAIO, |
taskAIO, |
|
taskLIO, |
taskUSER, |
taskUSER, |
taskEVENT, |
taskEVENT, |
taskEVENTLO, |
taskEVENTLO, |
Line 107 struct sched_HooksTask {
|
Line 112 struct sched_HooksTask {
|
sched_hook_func_t signal; |
sched_hook_func_t signal; |
/* aio(sched_task_t *task, NULL) -> int */ |
/* aio(sched_task_t *task, NULL) -> int */ |
sched_hook_func_t aio; |
sched_hook_func_t aio; |
|
/* lio(sched_task_t *task, NULL) -> int */ |
|
sched_hook_func_t lio; |
/* user(sched_task_t *task, NULL) -> int */ |
/* user(sched_task_t *task, NULL) -> int */ |
sched_hook_func_t user; |
sched_hook_func_t user; |
/* event(sched_task_t *task, NULL) -> int */ |
/* event(sched_task_t *task, NULL) -> int */ |
Line 205 struct sched_RootTask {
|
Line 212 struct sched_RootTask {
|
sched_queue_t root_proc; |
sched_queue_t root_proc; |
sched_queue_t root_signal; |
sched_queue_t root_signal; |
sched_queue_t root_aio; |
sched_queue_t root_aio; |
|
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_eventlo; |
Line 402 sched_task_t *schedSignal(sched_root_task_t * __restri
|
Line 410 sched_task_t *schedSignal(sched_root_task_t * __restri
|
#define schedSignalSelf(x) schedSignal(TASK_ROOT((x)), TASK_FUNC((x)), TASK_ARG((x)), \ |
#define schedSignalSelf(x) schedSignal(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))) |
|
|
|
#ifdef EVFILT_LIO |
/* |
/* |
* schedAIO() - Add AIO task to scheduler queue |
* schedAIO() - Add AIO task to scheduler queue |
* |
* |
Line 414 sched_task_t *schedSignal(sched_root_task_t * __restri
|
Line 423 sched_task_t *schedSignal(sched_root_task_t * __restri
|
* return: NULL error or !=NULL new queued task |
* return: NULL error or !=NULL new queued task |
*/ |
*/ |
sched_task_t *schedAIO(sched_root_task_t * __restrict root, sched_task_func_t func, void *arg, |
sched_task_t *schedAIO(sched_root_task_t * __restrict root, sched_task_func_t func, void *arg, |
unsigned long acb, void *opt_data, size_t opt_dlen); | struct aiocb * __restrict acb, void *opt_data, size_t opt_dlen); |
#define schedAIOSelf(x) schedAIO(TASK_ROOT((x)), TASK_FUNC((x)), TASK_ARG((x)), \ | /* |
TASK_VAL((x)), TASK_DATA((x)), TASK_DATLEN((x))) | * schedAIORead() - Add AIO read task to scheduler queue |
| * |
| * @root = root task |
| * @func = task execution function |
| * @arg = 1st func argument |
| * @fd = file descriptor |
| * @buffer = Buffer |
| * @buflen = Buffer length |
| * @offset = Offset from start of file, if =-1 from current position |
| * return: NULL error or !=NULL new queued task |
| */ |
| inline sched_task_t *schedAIORead(sched_root_task_t * __restrict root, sched_task_func_t func, |
| void *arg, int fd, void *buffer, size_t buflen, off_t offset); |
| /* |
| * schedAIOWrite() - Add AIO write task to scheduler queue |
| * |
| * @root = root task |
| * @func = task execution function |
| * @arg = 1st func argument |
| * @fd = file descriptor |
| * @buffer = Buffer |
| * @buflen = Buffer length |
| * @offset = Offset from start of file, if =-1 from current position |
| * return: NULL error or !=NULL new queued task |
| */ |
| inline sched_task_t *schedAIOWrite(sched_root_task_t * __restrict root, sched_task_func_t func, |
| void *arg, int fd, void *buffer, size_t buflen, off_t offset); |
| |
| /* |
| * schedLIO() - Add AIO bulk tasks to scheduler queue |
| * |
| * @root = root task |
| * @func = task execution function |
| * @arg = 1st func argument |
| * @acbs = AIO cb structure addresses |
| * @opt_data = Optional data |
| * @opt_dlen = Optional data length |
| * return: NULL error or !=NULL new queued task |
| */ |
| sched_task_t *schedLIO(sched_root_task_t * __restrict root, sched_task_func_t func, void *arg, |
| struct aiocb ** __restrict acbs, void *opt_data, size_t opt_dlen); |
| /* |
| * schedLIORead() - Add list of AIO read tasks to scheduler queue |
| * |
| * @root = root task |
| * @func = task execution function |
| * @arg = 1st func argument |
| * @fd = file descriptor |
| * @bufs = Buffer's list |
| * @nbufs = Number of Buffers |
| * @offset = Offset from start of file, if =-1 from current position |
| * return: NULL error or !=NULL new queued task |
| */ |
| inline sched_task_t *schedLIORead(sched_root_task_t * __restrict root, sched_task_func_t func, |
| void *arg, int fd, struct iovec *bufs, size_t nbufs, off_t offset); |
| /* |
| * schedLIOWrite() - Add list of AIO write tasks to scheduler queue |
| * |
| * @root = root task |
| * @func = task execution function |
| * @arg = 1st func argument |
| * @fd = file descriptor |
| * @bufs = Buffer's list |
| * @nbufs = Number of Buffers |
| * @offset = Offset from start of file, if =-1 from current position |
| * return: NULL error or !=NULL new queued task |
| */ |
| inline sched_task_t *schedLIOWrite(sched_root_task_t * __restrict root, sched_task_func_t func, |
| void *arg, int fd, struct iovec *bufs, size_t nbufs, off_t offset); |
| #endif /* EVFILT_LIO */ |
|
|
/* |
/* |
* schedUser() - Add trigger USER task to scheduler queue |
* schedUser() - Add trigger USER task to scheduler queue |