[nginx] Threads: task pointer stored in ngx_file_t.
Maxim Dounin
mdounin at mdounin.ru
Fri Mar 18 03:49:24 UTC 2016
details: http://hg.nginx.org/nginx/rev/9fd738b85fad
branches:
changeset: 6441:9fd738b85fad
user: Maxim Dounin <mdounin at mdounin.ru>
date: Fri Mar 18 06:43:52 2016 +0300
description:
Threads: task pointer stored in ngx_file_t.
This simplifies the interface of the ngx_thread_read() function.
Additionally, most of the thread operations now explicitly set
file->thread_task, file->thread_handler and file->thread_ctx,
to facilitate use of thread operations in other places.
(Potential problems remain with sendfile in threads though - it uses
file->thread_handler as set in ngx_output_chain(), and it should not
be overwritten to an incompatible one.)
In collaboration with Valentin Bartenev.
diffstat:
src/core/ngx_file.h | 1 +
src/core/ngx_output_chain.c | 11 ++++++++---
src/http/ngx_http_file_cache.c | 7 ++++---
src/os/unix/ngx_files.c | 8 ++++----
src/os/unix/ngx_files.h | 4 ++--
5 files changed, 19 insertions(+), 12 deletions(-)
diffs (99 lines):
diff --git a/src/core/ngx_file.h b/src/core/ngx_file.h
--- a/src/core/ngx_file.h
+++ b/src/core/ngx_file.h
@@ -27,6 +27,7 @@ struct ngx_file_s {
ngx_int_t (*thread_handler)(ngx_thread_task_t *task,
ngx_file_t *file);
void *thread_ctx;
+ ngx_thread_task_t *thread_task;
#endif
#if (NGX_HAVE_FILE_AIO)
diff --git a/src/core/ngx_output_chain.c b/src/core/ngx_output_chain.c
--- a/src/core/ngx_output_chain.c
+++ b/src/core/ngx_output_chain.c
@@ -577,10 +577,15 @@ ngx_output_chain_copy_buf(ngx_output_cha
} else
#endif
#if (NGX_THREADS)
- if (src->file->thread_handler) {
- n = ngx_thread_read(&ctx->thread_task, src->file, dst->pos,
- (size_t) size, src->file_pos, ctx->pool);
+ if (ctx->thread_handler) {
+ src->file->thread_task = ctx->thread_task;
+ src->file->thread_handler = ctx->thread_handler;
+ src->file->thread_ctx = ctx->filter_ctx;
+
+ n = ngx_thread_read(src->file, dst->pos, (size_t) size,
+ src->file_pos, ctx->pool);
if (n == NGX_AGAIN) {
+ ctx->thread_task = src->file->thread_task;
return NGX_AGAIN;
}
diff --git a/src/http/ngx_http_file_cache.c b/src/http/ngx_http_file_cache.c
--- a/src/http/ngx_http_file_cache.c
+++ b/src/http/ngx_http_file_cache.c
@@ -691,12 +691,13 @@ ngx_http_file_cache_aio_read(ngx_http_re
#if (NGX_THREADS)
if (clcf->aio == NGX_HTTP_AIO_THREADS) {
+ c->file.thread_task = c->thread_task;
c->file.thread_handler = ngx_http_cache_thread_handler;
c->file.thread_ctx = r;
- n = ngx_thread_read(&c->thread_task, &c->file, c->buf->pos,
- c->body_start, 0, r->pool);
-
+ n = ngx_thread_read(&c->file, c->buf->pos, c->body_start, 0, r->pool);
+
+ c->thread_task = c->file.thread_task;
c->reading = (n == NGX_AGAIN);
return n;
diff --git a/src/os/unix/ngx_files.c b/src/os/unix/ngx_files.c
--- a/src/os/unix/ngx_files.c
+++ b/src/os/unix/ngx_files.c
@@ -88,8 +88,8 @@ typedef struct {
ssize_t
-ngx_thread_read(ngx_thread_task_t **taskp, ngx_file_t *file, u_char *buf,
- size_t size, off_t offset, ngx_pool_t *pool)
+ngx_thread_read(ngx_file_t *file, u_char *buf, size_t size, off_t offset,
+ ngx_pool_t *pool)
{
ngx_thread_task_t *task;
ngx_thread_read_ctx_t *ctx;
@@ -98,7 +98,7 @@ ngx_thread_read(ngx_thread_task_t **task
"thread read: %d, %p, %uz, %O",
file->fd, buf, size, offset);
- task = *taskp;
+ task = file->thread_task;
if (task == NULL) {
task = ngx_thread_task_alloc(pool, sizeof(ngx_thread_read_ctx_t));
@@ -108,7 +108,7 @@ ngx_thread_read(ngx_thread_task_t **task
task->handler = ngx_thread_read_handler;
- *taskp = task;
+ file->thread_task = task;
}
ctx = task->ctx;
diff --git a/src/os/unix/ngx_files.h b/src/os/unix/ngx_files.h
--- a/src/os/unix/ngx_files.h
+++ b/src/os/unix/ngx_files.h
@@ -385,8 +385,8 @@ extern ngx_uint_t ngx_file_aio;
#endif
#if (NGX_THREADS)
-ssize_t ngx_thread_read(ngx_thread_task_t **taskp, ngx_file_t *file,
- u_char *buf, size_t size, off_t offset, ngx_pool_t *pool);
+ssize_t ngx_thread_read(ngx_file_t *file, u_char *buf, size_t size,
+ off_t offset, ngx_pool_t *pool);
#endif
More information about the nginx-devel
mailing list