Geo: fixed access to already freed memory.

Previously, in "ranges" mode when all added ranges were deleted,
the ctx.high.low[i] was left pointing to a temporary array.
This commit is contained in:
Valentin Bartenev 2016-08-18 17:11:03 +03:00
parent aa85edd539
commit 06af4eb471
2 changed files with 12 additions and 2 deletions

View file

@ -469,7 +469,12 @@ ngx_http_geo_block(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
for (i = 0; i < 0x10000; i++) { for (i = 0; i < 0x10000; i++) {
a = (ngx_array_t *) ctx.high.low[i]; a = (ngx_array_t *) ctx.high.low[i];
if (a == NULL || a->nelts == 0) { if (a == NULL) {
continue;
}
if (a->nelts == 0) {
ctx.high.low[i] = NULL;
continue; continue;
} }

View file

@ -436,7 +436,12 @@ ngx_stream_geo_block(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
for (i = 0; i < 0x10000; i++) { for (i = 0; i < 0x10000; i++) {
a = (ngx_array_t *) ctx.high.low[i]; a = (ngx_array_t *) ctx.high.low[i];
if (a == NULL || a->nelts == 0) { if (a == NULL) {
continue;
}
if (a->nelts == 0) {
ctx.high.low[i] = NULL;
continue; continue;
} }