diff options
author | Igor Sysoev <igor@sysoev.ru> | 2003-10-29 08:30:44 +0000 |
---|---|---|
committer | Igor Sysoev <igor@sysoev.ru> | 2003-10-29 08:30:44 +0000 |
commit | b5faed2dc853ee7e6bda6004b16ceedc6c194641 (patch) | |
tree | 7812abde1b258c5e751ac6a85072c792549d55f5 /src/os/unix/ngx_readv_chain.c | |
parent | ab0c4f5038cec58e23a023d8a1e01be038504e3e (diff) | |
download | nginx-b5faed2dc853ee7e6bda6004b16ceedc6c194641.tar.gz nginx-b5faed2dc853ee7e6bda6004b16ceedc6c194641.zip |
nginx-0.0.1-2003-10-29-11:30:44 import
Diffstat (limited to 'src/os/unix/ngx_readv_chain.c')
-rw-r--r-- | src/os/unix/ngx_readv_chain.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/src/os/unix/ngx_readv_chain.c b/src/os/unix/ngx_readv_chain.c index f19569879..1ea683f0d 100644 --- a/src/os/unix/ngx_readv_chain.c +++ b/src/os/unix/ngx_readv_chain.c @@ -7,13 +7,14 @@ ssize_t ngx_readv_chain(ngx_connection_t *c, ngx_chain_t *chain) { char *prev; - ssize_t n; + ssize_t n, size; struct iovec *iov; ngx_err_t err; ngx_array_t io; prev = NULL; iov = NULL; + size = 0; ngx_init_array(io, c->pool, 10, sizeof(struct iovec), NGX_ERROR); @@ -29,6 +30,7 @@ ssize_t ngx_readv_chain(ngx_connection_t *c, ngx_chain_t *chain) iov->iov_len = chain->hunk->end - chain->hunk->last; } + size += chain->hunk->end - chain->hunk->last; prev = chain->hunk->end; chain = chain->next; } @@ -42,7 +44,6 @@ ngx_log_debug(c->log, "recv: %d:%d" _ io.nelts _ iov->iov_len); } else if (n == -1) { c->read->ready = 0; - c->read->error = 1; err = ngx_errno; if (err == NGX_EAGAIN) { @@ -50,8 +51,12 @@ ngx_log_debug(c->log, "recv: %d:%d" _ io.nelts _ iov->iov_len); return NGX_AGAIN; } + c->read->error = 1; ngx_log_error(NGX_LOG_ERR, c->log, err, "readv() failed"); return NGX_ERROR; + + } else if (n < size) { + c->read->ready = 0; } return n; |