aboutsummaryrefslogtreecommitdiff
path: root/src/core/ngx_output_chain.c
diff options
context:
space:
mode:
authorMaxim Dounin <mdounin@mdounin.ru>2016-03-18 06:43:52 +0300
committerMaxim Dounin <mdounin@mdounin.ru>2016-03-18 06:43:52 +0300
commitac78b26324a348ebdd108de0c022729b671549fb (patch)
tree606691334fa0d164469073bacb4c132c86a2f4d3 /src/core/ngx_output_chain.c
parent931ce7f02a9c55987ef9a7128882097b89a36540 (diff)
downloadnginx-ac78b26324a348ebdd108de0c022729b671549fb.tar.gz
nginx-ac78b26324a348ebdd108de0c022729b671549fb.zip
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 (limited to 'src/core/ngx_output_chain.c')
-rw-r--r--src/core/ngx_output_chain.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/src/core/ngx_output_chain.c b/src/core/ngx_output_chain.c
index b8361dcd6..f7845787b 100644
--- 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_chain_ctx_t *ctx)
} 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;
}