]> git.kaiwu.me - nginx.git/commitdiff
Fixed division by zero exception in ngx_hash_init().
authorValentin Bartenev <vbart@nginx.com>
Mon, 16 Jan 2012 12:42:07 +0000 (12:42 +0000)
committerValentin Bartenev <vbart@nginx.com>
Mon, 16 Jan 2012 12:42:07 +0000 (12:42 +0000)
The ngx_hash_init() function did not expect call with zero elements count,
which caused FPE error on configs with an empty "types" block in http context
and "types_hash_max_size" > 10000.

Example configuration to reproduce:

  events { }

  http {
          types_hash_max_size 10001;
          types {}
          server {}
  }

src/core/ngx_hash.c

index 0c7285202fbd1a3f7b19ecf7dd8867a3e5b27e5a..74d89b8b9480cc39327357e621f361837a51feb2 100644 (file)
@@ -277,7 +277,7 @@ ngx_hash_init(ngx_hash_init_t *hinit, ngx_hash_key_t *names, ngx_uint_t nelts)
     start = nelts / (bucket_size / (2 * sizeof(void *)));
     start = start ? start : 1;
 
-    if (hinit->max_size > 10000 && hinit->max_size / nelts < 100) {
+    if (hinit->max_size > 10000 && nelts && hinit->max_size / nelts < 100) {
         start = hinit->max_size - 1000;
     }