diff options
author | Igor Sysoev <igor@sysoev.ru> | 2003-05-19 16:39:14 +0000 |
---|---|---|
committer | Igor Sysoev <igor@sysoev.ru> | 2003-05-19 16:39:14 +0000 |
commit | a98301160de4c12f455cca8f78509f2e04626c0b (patch) | |
tree | cdf14046298d40ca8398925603fb4011360b187a /src/os/unix/ngx_recv.c | |
parent | bb4ec5c1721defd7b10f83ace51bddb71726dd1a (diff) | |
download | nginx-a98301160de4c12f455cca8f78509f2e04626c0b.tar.gz nginx-a98301160de4c12f455cca8f78509f2e04626c0b.zip |
nginx-0.0.1-2003-05-19-20:39:14 import
Diffstat (limited to 'src/os/unix/ngx_recv.c')
-rw-r--r-- | src/os/unix/ngx_recv.c | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/src/os/unix/ngx_recv.c b/src/os/unix/ngx_recv.c new file mode 100644 index 000000000..c6e8b0390 --- /dev/null +++ b/src/os/unix/ngx_recv.c @@ -0,0 +1,92 @@ + +#include <ngx_config.h> +#include <ngx_core.h> +#include <ngx_errno.h> +#include <ngx_log.h> +#include <ngx_recv.h> +#include <ngx_connection.h> + + +ssize_t ngx_unix_recv(ngx_connection_t *c, char *buf, size_t size) +{ + ssize_t n; + ngx_err_t err; + ngx_event_t *ev; + + ev = c->read; + +#if (HAVE_KQUEUE) /* DEBUG */ + if (ngx_event_flags & NGX_HAVE_KQUEUE_EVENT) { + ngx_log_debug(c->log, "ngx_recv: eof:%d, avail:%d, err:%d" _ + ev->eof _ ev->available _ ev->error); + } +#endif + +#if (HAVE_KQUEUE) + + if ((ngx_event_flags & NGX_HAVE_KQUEUE_EVENT) + && ev->eof && ev->available == 0) { + + if (ev->error == 0) { + return 0; + } + + ngx_set_socket_errno(ev->error); + err = ev->error; + n = -1; + + } else { + n = recv(c->fd, buf, size, 0); + +ngx_log_debug(c->log, "ngx_recv: read:%d:%d" _ n _ size); + + if (n == -1) { + err = ngx_socket_errno; + } + } + +#else /* not kqueue */ + + n = recv(c->fd, buf, size, 0); + + if (n == -1) { + err = ngx_socket_errno; + } + +#endif + + if (n == -1) { + ev->ready = 0; + + if (err == NGX_ECONNRESET && ev->ignore_econnreset) { + return 0; + } + + if (err == NGX_EAGAIN) { + ngx_log_error(NGX_LOG_INFO, c->log, err, "recv() returned EAGAIN"); + return NGX_AGAIN; + } + + ngx_log_error(NGX_LOG_ERR, c->log, err, "recv() failed"); + return NGX_ERROR; + } + +#if (HAVE_KQUEUE) + + if (ngx_event_flags & NGX_HAVE_KQUEUE_EVENT) { + ev->available -= n; + if (ev->available == 0) { + ev->ready = 0; + } + + return n; + } + +#endif + + if ((size_t) n < size) { + ev->ready = 0; + } + + return n; +} |