aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorRuslan Ermilov <ru@nginx.com>2015-03-17 00:26:22 +0300
committerRuslan Ermilov <ru@nginx.com>2015-03-17 00:26:22 +0300
commita43f1bcf6e9c926cf6949d1a936f99243d672510 (patch)
tree102c66521fee375510ada3d70c3837b52a26030b /src
parent3ad3f4ae0a7ad64ded4ad4bebf156526deaf95a2 (diff)
downloadnginx-a43f1bcf6e9c926cf6949d1a936f99243d672510.tar.gz
nginx-a43f1bcf6e9c926cf6949d1a936f99243d672510.zip
Overflow detection in ngx_inet_addr().
Diffstat (limited to 'src')
-rw-r--r--src/core/ngx_inet.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/src/core/ngx_inet.c b/src/core/ngx_inet.c
index 26c5bc4b0..2c84daf6e 100644
--- a/src/core/ngx_inet.c
+++ b/src/core/ngx_inet.c
@@ -27,6 +27,10 @@ ngx_inet_addr(u_char *text, size_t len)
for (p = text; p < text + len; p++) {
+ if (octet > 255) {
+ return INADDR_NONE;
+ }
+
c = *p;
if (c >= '0' && c <= '9') {
@@ -34,7 +38,7 @@ ngx_inet_addr(u_char *text, size_t len)
continue;
}
- if (c == '.' && octet < 256) {
+ if (c == '.') {
addr = (addr << 8) + octet;
octet = 0;
n++;
@@ -44,7 +48,7 @@ ngx_inet_addr(u_char *text, size_t len)
return INADDR_NONE;
}
- if (n == 3 && octet < 256) {
+ if (n == 3) {
addr = (addr << 8) + octet;
return htonl(addr);
}