diff options
author | Maxim Dounin <mdounin@mdounin.ru> | 2011-09-05 16:36:19 +0000 |
---|---|---|
committer | Maxim Dounin <mdounin@mdounin.ru> | 2011-09-05 16:36:19 +0000 |
commit | 4f65a05d1819392acdef365f387fa078baaabaab (patch) | |
tree | a0e33e0aa7456138366e8eff2143a8dfabfe5e25 /src/os/unix/ngx_linux_aio_read.c | |
parent | 3a73e50498cc7bba3d2fd2ac31236b5a1b2c287e (diff) | |
download | nginx-4f65a05d1819392acdef365f387fa078baaabaab.tar.gz nginx-4f65a05d1819392acdef365f387fa078baaabaab.zip |
Bugfix: open_file_cache lost is_directio flag.
On file retest open_file_cache lost is_directio if file wasn't changed.
This caused unaligned operations under Linux to fail with EINVAL.
It wasn't noticeable with AIO though, as errors wasn't properly logged.
Diffstat (limited to 'src/os/unix/ngx_linux_aio_read.c')
-rw-r--r-- | src/os/unix/ngx_linux_aio_read.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/src/os/unix/ngx_linux_aio_read.c b/src/os/unix/ngx_linux_aio_read.c index 72875ca01..b9d1d01cd 100644 --- a/src/os/unix/ngx_linux_aio_read.c +++ b/src/os/unix/ngx_linux_aio_read.c @@ -74,6 +74,10 @@ ngx_file_aio_read(ngx_file_t *file, u_char *buf, size_t size, off_t offset, } ngx_set_errno(-aio->res); + + ngx_log_error(NGX_LOG_CRIT, file->log, ngx_errno, + "aio read \"%s\" failed", file->name.data); + return NGX_ERROR; } |