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:
parent
aa85edd539
commit
06af4eb471
2 changed files with 12 additions and 2 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue