diff options
author | Igor Sysoev <igor@sysoev.ru> | 2011-09-16 12:43:16 +0000 |
---|---|---|
committer | Igor Sysoev <igor@sysoev.ru> | 2011-09-16 12:43:16 +0000 |
commit | 4134b48b68c29536d59521d8f8d156967f0e8a8b (patch) | |
tree | ee482a985136e8603a010a3cd65223b28078228b /src/os/unix/ngx_linux_aio_read.c | |
parent | c6353a5654bc14a66f5d0a6657b373fca7bce8a3 (diff) | |
download | nginx-4134b48b68c29536d59521d8f8d156967f0e8a8b.tar.gz nginx-4134b48b68c29536d59521d8f8d156967f0e8a8b.zip |
Fixing Linux AIO syscalls return value handling:
syscall(2) uses usual libc convention, it returns -1 on error and
sets errno. Obsolete _syscall(2) returns negative value of error.
Thanks to Hagai Avrahami.
Diffstat (limited to 'src/os/unix/ngx_linux_aio_read.c')
-rw-r--r-- | src/os/unix/ngx_linux_aio_read.c | 16 |
1 files changed, 7 insertions, 9 deletions
diff --git a/src/os/unix/ngx_linux_aio_read.c b/src/os/unix/ngx_linux_aio_read.c index b9d1d01cd..d31c4a064 100644 --- a/src/os/unix/ngx_linux_aio_read.c +++ b/src/os/unix/ngx_linux_aio_read.c @@ -16,7 +16,7 @@ extern aio_context_t ngx_aio_ctx; static void ngx_file_aio_event_handler(ngx_event_t *ev); -static long +static int io_submit(aio_context_t ctx, long n, struct iocb **paiocb) { return syscall(SYS_io_submit, ctx, n, paiocb); @@ -27,7 +27,7 @@ ssize_t ngx_file_aio_read(ngx_file_t *file, u_char *buf, size_t size, off_t offset, ngx_pool_t *pool) { - long n; + ngx_err_t err; struct iocb *piocb[1]; ngx_event_t *ev; ngx_event_aio_t *aio; @@ -96,9 +96,7 @@ ngx_file_aio_read(ngx_file_t *file, u_char *buf, size_t size, off_t offset, piocb[0] = &aio->aiocb; - n = io_submit(ngx_aio_ctx, 1, piocb); - - if (n == 1) { + if (io_submit(ngx_aio_ctx, 1, piocb) == 1) { ev->active = 1; ev->ready = 0; ev->complete = 0; @@ -106,16 +104,16 @@ ngx_file_aio_read(ngx_file_t *file, u_char *buf, size_t size, off_t offset, return NGX_AGAIN; } - n = -n; + err = ngx_errno; - if (n == NGX_EAGAIN) { + if (err == NGX_EAGAIN) { return ngx_read_file(file, buf, size, offset); } - ngx_log_error(NGX_LOG_CRIT, file->log, n, + ngx_log_error(NGX_LOG_CRIT, file->log, err, "io_submit(\"%V\") failed", &file->name); - if (n == NGX_ENOSYS) { + if (err == NGX_ENOSYS) { ngx_file_aio = 0; return ngx_read_file(file, buf, size, offset); } |