diff options
author | Maxim Dounin <mdounin@mdounin.ru> | 2012-02-27 22:15:39 +0000 |
---|---|---|
committer | Maxim Dounin <mdounin@mdounin.ru> | 2012-02-27 22:15:39 +0000 |
commit | 7ca6c1ff782afbb83b9f17d6552566c823247e29 (patch) | |
tree | 9f357793d471ec5655beb15e02e2b72f2f5e7c5e /src/core/ngx_open_file_cache.c | |
parent | 53d9677de451bae3d3da5c1ecbe6fa7b34fa5313 (diff) | |
download | nginx-7ca6c1ff782afbb83b9f17d6552566c823247e29.tar.gz nginx-7ca6c1ff782afbb83b9f17d6552566c823247e29.zip |
Fix of rbtree lookup on hash collisions.
Previous code incorrectly assumed that nodes with identical keys are linked
together. This might not be true after tree rebalance.
Patch by Lanshun Zhou.
Diffstat (limited to 'src/core/ngx_open_file_cache.c')
-rw-r--r-- | src/core/ngx_open_file_cache.c | 17 |
1 files changed, 6 insertions, 11 deletions
diff --git a/src/core/ngx_open_file_cache.c b/src/core/ngx_open_file_cache.c index 73a2db0c8..c44ac96b8 100644 --- a/src/core/ngx_open_file_cache.c +++ b/src/core/ngx_open_file_cache.c @@ -1142,20 +1142,15 @@ ngx_open_file_lookup(ngx_open_file_cache_t *cache, ngx_str_t *name, /* hash == node->key */ - do { - file = (ngx_cached_open_file_t *) node; - - rc = ngx_strcmp(name->data, file->name); + file = (ngx_cached_open_file_t *) node; - if (rc == 0) { - return file; - } + rc = ngx_strcmp(name->data, file->name); - node = (rc < 0) ? node->left : node->right; - - } while (node != sentinel && hash == node->key); + if (rc == 0) { + return file; + } - break; + node = (rc < 0) ? node->left : node->right; } return NULL; |