summaryrefslogtreecommitdiffhomepage
path: root/src/event
diff options
context:
space:
mode:
authorIgor Sysoev <igor@sysoev.ru>2007-09-22 19:02:39 +0000
committerIgor Sysoev <igor@sysoev.ru>2007-09-22 19:02:39 +0000
commit72963cd4e7e7efa954162066fbe1506208698106 (patch)
tree0d52a9cdf73b78a9773da2f65cb38a1e76d7cb1a /src/event
parent5963fbae8ee06329e347d5fe113c649ed1aa179e (diff)
downloadnginx-72963cd4e7e7efa954162066fbe1506208698106.tar.gz
nginx-72963cd4e7e7efa954162066fbe1506208698106.tar.bz2
r1381 merge:
ignore meaningless bits in CIDR and warn about them
Diffstat (limited to 'src/event')
-rw-r--r--src/event/ngx_event.c19
1 files changed, 14 insertions, 5 deletions
diff --git a/src/event/ngx_event.c b/src/event/ngx_event.c
index 91efde009..9be0b1ab3 100644
--- a/src/event/ngx_event.c
+++ b/src/event/ngx_event.c
@@ -1038,8 +1038,9 @@ ngx_event_debug_connection(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
#if (NGX_DEBUG)
ngx_event_conf_t *ecf = conf;
- ngx_event_debug_t *dc;
+ ngx_int_t rc;
ngx_str_t *value;
+ ngx_event_debug_t *dc;
struct hostent *h;
ngx_inet_cidr_t in_cidr;
@@ -1056,13 +1057,21 @@ ngx_event_debug_connection(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
if (dc->addr != INADDR_NONE) {
dc->mask = 0xffffffff;
- return NGX_OK;
+ return NGX_CONF_OK;
+ }
+
+ rc = ngx_ptocidr(&value[1], &in_cidr);
+
+ if (rc == NGX_DONE) {
+ ngx_conf_log_error(NGX_LOG_WARN, cf, 0,
+ "low address bits of %V are meaningless", &value[1]);
+ rc = NGX_OK;
}
- if (ngx_ptocidr(&value[1], &in_cidr) == NGX_OK) {
+ if (rc == NGX_OK) {
dc->mask = in_cidr.mask;
dc->addr = in_cidr.addr;
- return NGX_OK;
+ return NGX_CONF_OK;
}
h = gethostbyname((char *) value[1].data);
@@ -1084,7 +1093,7 @@ ngx_event_debug_connection(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
#endif
- return NGX_OK;
+ return NGX_CONF_OK;
}