summaryrefslogtreecommitdiffhomepage
path: root/src/nxt_work_queue.h
diff options
context:
space:
mode:
authorIgor Sysoev <igor@sysoev.ru>2017-01-27 11:35:11 +0300
committerIgor Sysoev <igor@sysoev.ru>2017-01-27 11:35:11 +0300
commitba0391577b06446307fa073f856f57748557e0dd (patch)
treeb2b871a041edee242662c95197bed292531c3a9a /src/nxt_work_queue.h
parent6886b83c1f3bfdc514d58ad6e9ab40873cafcb54 (diff)
downloadunit-ba0391577b06446307fa073f856f57748557e0dd.tar.gz
unit-ba0391577b06446307fa073f856f57748557e0dd.tar.bz2
Work queues refactoring.
Diffstat (limited to 'src/nxt_work_queue.h')
-rw-r--r--src/nxt_work_queue.h54
1 files changed, 14 insertions, 40 deletions
diff --git a/src/nxt_work_queue.h b/src/nxt_work_queue.h
index b37fe1a3..4d2422cc 100644
--- a/src/nxt_work_queue.h
+++ b/src/nxt_work_queue.h
@@ -65,7 +65,7 @@ typedef struct nxt_work_queue_s nxt_work_queue_t;
struct nxt_work_queue_s {
nxt_work_t *head;
nxt_work_t *tail;
- nxt_work_queue_t *next;
+ nxt_work_queue_cache_t *cache;
#if (NXT_DEBUG)
const char *name;
#endif
@@ -73,15 +73,6 @@ struct nxt_work_queue_s {
typedef struct {
- nxt_work_queue_t *head;
- nxt_work_queue_t *tail;
- nxt_work_queue_t main;
- nxt_work_queue_t last;
- nxt_work_queue_cache_t cache;
-} nxt_thread_work_queue_t;
-
-
-typedef struct {
nxt_thread_spinlock_t lock;
nxt_work_t *head;
nxt_work_t *tail;
@@ -89,34 +80,26 @@ typedef struct {
} nxt_locked_work_queue_t;
-NXT_EXPORT void nxt_thread_work_queue_create(nxt_thread_t *thr,
+NXT_EXPORT void nxt_work_queue_cache_create(nxt_work_queue_cache_t *cache,
size_t chunk_size);
-NXT_EXPORT void nxt_thread_work_queue_destroy(nxt_thread_t *thr);
-NXT_EXPORT void nxt_thread_work_queue_add(nxt_thread_t *thr,
- nxt_work_queue_t *wq, nxt_work_handler_t handler, nxt_task_t *task,
- void *obj, void *data);
-NXT_EXPORT void nxt_thread_work_queue_push(nxt_thread_t *thr,
- nxt_work_queue_t *wq, nxt_work_handler_t handler, nxt_task_t *task,
- void *obj, void *data);
-NXT_EXPORT void nxt_work_queue_attach(nxt_thread_t *thr, nxt_work_queue_t *wq);
-NXT_EXPORT nxt_work_handler_t nxt_thread_work_queue_pop(nxt_thread_t *thr,
+NXT_EXPORT void nxt_work_queue_cache_destroy(nxt_work_queue_cache_t *cache);
+
+NXT_EXPORT void nxt_work_queue_add(nxt_work_queue_t *wq,
+ nxt_work_handler_t handler, nxt_task_t *task, void *obj, void *data);
+NXT_EXPORT nxt_work_handler_t nxt_work_queue_pop(nxt_work_queue_t *wq,
nxt_task_t **task, void **obj, void **data);
-NXT_EXPORT void nxt_thread_work_queue_drop(nxt_thread_t *thr, void *data);
-#define \
-nxt_thread_current_work_queue_add(thr, handler, task, obj, data) \
+#define nxt_work_set(_work, _handler, _task, _obj, _data) \
do { \
- nxt_thread_t *_thr = thr; \
+ nxt_work_t *work = _work; \
\
- nxt_thread_work_queue_add(_thr, _thr->work_queue.head, \
- handler, task, obj, data); \
+ work->handler = _handler; \
+ work->task = _task; \
+ work->obj = _obj; \
+ work->data = _data; \
} while (0)
-
-NXT_EXPORT void nxt_work_queue_destroy(nxt_work_queue_t *wq);
-
-
#if (NXT_DEBUG)
#define \
@@ -131,17 +114,8 @@ nxt_work_queue_name(_wq, _name)
#endif
-NXT_EXPORT void nxt_thread_last_work_queue_add(nxt_thread_t *thr,
- nxt_work_handler_t handler, void *obj, void *data);
-NXT_EXPORT nxt_work_handler_t nxt_thread_last_work_queue_pop(nxt_thread_t *thr,
- nxt_task_t **task, void **obj, void **data);
-
-
-NXT_EXPORT void nxt_locked_work_queue_create(nxt_locked_work_queue_t *lwq,
- size_t chunk_size);
-NXT_EXPORT void nxt_locked_work_queue_destroy(nxt_locked_work_queue_t *lwq);
NXT_EXPORT void nxt_locked_work_queue_add(nxt_locked_work_queue_t *lwq,
- nxt_work_handler_t handler, nxt_task_t *task, void *obj, void *data);
+ nxt_work_t *work);
NXT_EXPORT nxt_work_handler_t nxt_locked_work_queue_pop(
nxt_locked_work_queue_t *lwq, nxt_task_t **task, void **obj, void **data);
NXT_EXPORT void nxt_locked_work_queue_move(nxt_thread_t *thr,