diff options
author | Igor Sysoev <igor@sysoev.ru> | 2017-01-23 19:56:03 +0300 |
---|---|---|
committer | Igor Sysoev <igor@sysoev.ru> | 2017-01-23 19:56:03 +0300 |
commit | de532922d9ab42aa15b40d47c8db53ac2af38500 (patch) | |
tree | d6b7c6b21c7a6e0e3620a3e0c7198e63454d05e3 /src/nxt_event_conn_read.c | |
parent | 16cbf3c076a0aca6d47adaf3f719493674cf2363 (diff) | |
download | unit-de532922d9ab42aa15b40d47c8db53ac2af38500.tar.gz unit-de532922d9ab42aa15b40d47c8db53ac2af38500.tar.bz2 |
Introducing tasks.
Diffstat (limited to '')
-rw-r--r-- | src/nxt_event_conn_read.c | 48 |
1 files changed, 25 insertions, 23 deletions
diff --git a/src/nxt_event_conn_read.c b/src/nxt_event_conn_read.c index 59d7d59c..f6bbbbd8 100644 --- a/src/nxt_event_conn_read.c +++ b/src/nxt_event_conn_read.c @@ -8,43 +8,46 @@ void -nxt_event_conn_read(nxt_thread_t *thr, nxt_event_conn_t *c) +nxt_event_conn_read(nxt_task_t *task, nxt_event_conn_t *c) { nxt_work_queue_t *wq; nxt_work_handler_t handler; handler = c->io->read; - if (thr->engine->batch != 0) { + if (task->thread->engine->batch != 0) { - wq = &thr->engine->read_work_queue; + wq = &task->thread->engine->read_work_queue; c->socket.read_work_queue = wq; - nxt_thread_work_queue_add(thr, wq, handler, c, c->socket.data, - c->socket.log); + nxt_thread_work_queue_add(task->thread, wq, handler, task, c, + c->socket.data); return; } - handler(thr, c, c->socket.data); + handler(task, c, c->socket.data); } void -nxt_event_conn_io_read(nxt_thread_t *thr, void *obj, void *data) +nxt_event_conn_io_read(nxt_task_t *task, void *obj, void *data) { ssize_t n; nxt_buf_t *b; nxt_bool_t batch; nxt_event_conn_t *c; + nxt_event_engine_t *engine; nxt_work_handler_t handler; const nxt_event_conn_state_t *state; c = obj; - nxt_log_debug(thr->log, "event conn read fd:%d rdy:%d cl:%d", - c->socket.fd, c->socket.read_ready, c->socket.closed); + nxt_debug(task, "event conn read fd:%d rdy:%d cl:%d", + c->socket.fd, c->socket.read_ready, c->socket.closed); - batch = (thr->engine->batch != 0); + engine = task->thread->engine; + + batch = (engine->batch != 0); state = c->read_state; if (c->socket.read_ready) { @@ -83,7 +86,7 @@ nxt_event_conn_io_read(nxt_thread_t *thr, void *obj, void *data) } if (n != NXT_AGAIN) { - nxt_event_fd_block_read(thr->engine, &c->socket); + nxt_event_fd_block_read(engine, &c->socket); nxt_event_timer_disable(&c->read_timer); if (n == 0) { @@ -109,10 +112,10 @@ nxt_event_conn_io_read(nxt_thread_t *thr, void *obj, void *data) || nxt_event_fd_is_disabled(c->socket.read)) { /* Timer may be set or reset. */ - nxt_event_conn_timer(thr->engine, c, state, &c->read_timer); + nxt_event_conn_timer(engine, c, state, &c->read_timer); if (nxt_event_fd_is_disabled(c->socket.read)) { - nxt_event_fd_enable_read(thr->engine, &c->socket); + nxt_event_fd_enable_read(engine, &c->socket); } } @@ -120,7 +123,7 @@ nxt_event_conn_io_read(nxt_thread_t *thr, void *obj, void *data) ready: - nxt_event_fd_block_read(thr->engine, &c->socket); + nxt_event_fd_block_read(engine, &c->socket); if (state->autoreset_timer) { nxt_event_timer_disable(&c->read_timer); @@ -131,10 +134,10 @@ ready: done: if (batch) { - nxt_thread_work_queue_add(thr, c->read_work_queue, handler, - c, data, thr->log); + nxt_thread_work_queue_add(task->thread, c->read_work_queue, handler, + task, c, data); } else { - handler(thr, c, data); + handler(task, c, data); } } @@ -165,8 +168,7 @@ nxt_event_conn_io_recvbuf(nxt_event_conn_t *c, nxt_buf_t *b) err = (n == -1) ? nxt_socket_errno : 0; - nxt_log_debug(c->socket.log, "readv(%d, %ui): %z", - c->socket.fd, niov, n); + nxt_debug(c->socket.task, "readv(%d, %ui): %z", c->socket.fd, niov, n); if (n > 0) { if ((size_t) n < rb.size) { @@ -187,12 +189,12 @@ nxt_event_conn_io_recvbuf(nxt_event_conn_t *c, nxt_buf_t *b) switch (err) { case NXT_EAGAIN: - nxt_log_debug(c->socket.log, "readv() %E", err); + nxt_debug(c->socket.task, "readv() %E", err); c->socket.read_ready = 0; return NXT_AGAIN; case NXT_EINTR: - nxt_log_debug(c->socket.log, "readv() %E", err); + nxt_debug(c->socket.task, "readv() %E", err); continue; default: @@ -218,8 +220,8 @@ nxt_event_conn_io_recv(nxt_event_conn_t *c, void *buf, size_t size, err = (n == -1) ? nxt_socket_errno : 0; - nxt_log_debug(c->socket.log, "recv(%d, %p, %uz, 0x%ui): %z", - c->socket.fd, buf, size, flags, n); + nxt_debug(c->socket.task, "recv(%d, %p, %uz, 0x%ui): %z", + c->socket.fd, buf, size, flags, n); if (n > 0) { if ((size_t) n < size) { |