aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorRuslan Ermilov <ru@nginx.com>2013-12-09 10:14:51 +0400
committerRuslan Ermilov <ru@nginx.com>2013-12-09 10:14:51 +0400
commit675e73e3bd70af7780ed8c9dde47d2d28a8a9f56 (patch)
treee16f0fd02dff4d1b9acc33cec5a2a9cb188fdb4c /src
parent19f475276de07e8c72ab4acca56c36ea4afb6572 (diff)
downloadnginx-675e73e3bd70af7780ed8c9dde47d2d28a8a9f56.tar.gz
nginx-675e73e3bd70af7780ed8c9dde47d2d28a8a9f56.zip
Core: keep the length of the local sockaddr.
Diffstat (limited to 'src')
-rw-r--r--src/core/ngx_connection.c11
-rw-r--r--src/core/ngx_connection.h1
-rw-r--r--src/event/ngx_event_accept.c1
-rw-r--r--src/event/ngx_event_acceptex.c3
4 files changed, 11 insertions, 5 deletions
diff --git a/src/core/ngx_connection.c b/src/core/ngx_connection.c
index 4544b294a..4d73eb3e0 100644
--- a/src/core/ngx_connection.c
+++ b/src/core/ngx_connection.c
@@ -1078,12 +1078,15 @@ ngx_connection_local_sockaddr(ngx_connection_t *c, ngx_str_t *s,
struct sockaddr_in6 *sin6;
#endif
+ if (c->local_socklen == 0) {
+ return NGX_ERROR;
+ }
+
switch (c->local_sockaddr->sa_family) {
#if (NGX_HAVE_INET6)
case AF_INET6:
sin6 = (struct sockaddr_in6 *) c->local_sockaddr;
- len = sizeof(struct sockaddr_in6);
for (addr = 0, i = 0; addr == 0 && i < 16; i++) {
addr |= sin6->sin6_addr.s6_addr[i];
@@ -1094,7 +1097,6 @@ ngx_connection_local_sockaddr(ngx_connection_t *c, ngx_str_t *s,
default: /* AF_INET */
sin = (struct sockaddr_in *) c->local_sockaddr;
- len = sizeof(struct sockaddr_in);
addr = sin->sin_addr.s_addr;
break;
}
@@ -1114,13 +1116,16 @@ ngx_connection_local_sockaddr(ngx_connection_t *c, ngx_str_t *s,
}
ngx_memcpy(c->local_sockaddr, &sa, len);
+
+ c->local_socklen = len;
}
if (s == NULL) {
return NGX_OK;
}
- s->len = ngx_sock_ntop(c->local_sockaddr, len, s->data, s->len, port);
+ s->len = ngx_sock_ntop(c->local_sockaddr, c->local_socklen,
+ s->data, s->len, port);
return NGX_OK;
}
diff --git a/src/core/ngx_connection.h b/src/core/ngx_connection.h
index 53149676e..c7b3b315c 100644
--- a/src/core/ngx_connection.h
+++ b/src/core/ngx_connection.h
@@ -143,6 +143,7 @@ struct ngx_connection_s {
#endif
struct sockaddr *local_sockaddr;
+ socklen_t local_socklen;
ngx_buf_t *buffer;
diff --git a/src/event/ngx_event_accept.c b/src/event/ngx_event_accept.c
index b1145446a..e33dce81e 100644
--- a/src/event/ngx_event_accept.c
+++ b/src/event/ngx_event_accept.c
@@ -212,6 +212,7 @@ ngx_event_accept(ngx_event_t *ev)
c->socklen = socklen;
c->listening = ls;
c->local_sockaddr = ls->sockaddr;
+ c->local_socklen = ls->socklen;
c->unexpected_eof = 1;
diff --git a/src/event/ngx_event_acceptex.c b/src/event/ngx_event_acceptex.c
index 1fde03105..ac511ef77 100644
--- a/src/event/ngx_event_acceptex.c
+++ b/src/event/ngx_event_acceptex.c
@@ -18,7 +18,6 @@ ngx_event_acceptex(ngx_event_t *rev)
{
ngx_listening_t *ls;
ngx_connection_t *c;
- socklen_t len;
c = rev->data;
ls = c->listening;
@@ -50,7 +49,7 @@ ngx_event_acceptex(ngx_event_t *rev)
ls->post_accept_buffer_size,
ls->socklen + 16,
ls->socklen + 16,
- &c->local_sockaddr, &len,
+ &c->local_sockaddr, &c->local_socklen,
&c->sockaddr, &c->socklen);
if (ls->post_accept_buffer_size) {