summaryrefslogtreecommitdiffhomepage
path: root/src/core
diff options
context:
space:
mode:
authorIgor Sysoev <igor@sysoev.ru>2011-09-30 13:57:44 +0000
committerIgor Sysoev <igor@sysoev.ru>2011-09-30 13:57:44 +0000
commit66ef8eba590ab96429356650297e173f41396eff (patch)
tree6d21815f4ed1dac2103f9170ecd72f1bb12b26a8 /src/core
parent86553d2e0a955c97846e621fb62a4d3550982ab1 (diff)
downloadnginx-66ef8eba590ab96429356650297e173f41396eff.tar.gz
nginx-66ef8eba590ab96429356650297e173f41396eff.tar.bz2
Merging r4077, r4101, r4102:
open_file_cache related fixes: *) 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. *) Bugfix: open_file_cache did not update file info on retest. If file inode was not changed, cached file information was not updated on retest. As a result stale information might be cached forever if file attributes was changed and/or file was extended.
Diffstat (limited to 'src/core')
-rw-r--r--src/core/ngx_open_file_cache.c8
1 files changed, 3 insertions, 5 deletions
diff --git a/src/core/ngx_open_file_cache.c b/src/core/ngx_open_file_cache.c
index a70385c35..0d605b527 100644
--- a/src/core/ngx_open_file_cache.c
+++ b/src/core/ngx_open_file_cache.c
@@ -284,13 +284,13 @@ ngx_open_cached_file(ngx_open_file_cache_t *cache, ngx_str_t *name,
if (of->uniq == file->uniq) {
- file->count++;
-
if (file->event) {
file->use_event = 1;
}
- goto renew;
+ of->is_directio = file->is_directio;
+
+ goto update;
}
/* file was changed */
@@ -394,8 +394,6 @@ update:
}
}
-renew:
-
file->created = now;
found: