diff options
author | Florian Weimer <fweimer@redhat.com> | 2016-05-04 14:35:23 +0200 |
---|---|---|
committer | Florian Weimer <fweimer@redhat.com> | 2016-05-09 11:08:02 +0200 |
commit | 05d2606fa110a8afd85419d969a6d55bf88efb0f (patch) | |
tree | cca3dd7d4474232e70e9733b6986c7a9ee4b0820 /inet | |
parent | c5aae1035cac6305a111e3461af23a924914d9f5 (diff) | |
download | glibc-05d2606fa110a8afd85419d969a6d55bf88efb0f.zip glibc-05d2606fa110a8afd85419d969a6d55bf88efb0f.tar.gz glibc-05d2606fa110a8afd85419d969a6d55bf88efb0f.tar.bz2 |
getnameinfo: Avoid calling strnlen on uninitialized buffer
In the numeric AF_INET/AF_INET6 case, if inet_ntop fails
as the result of a short host buffer, we used to call strnlen
on the uninitialized host buffer.
(cherry picked from commit 1c3490d4b29fc5b3f30dd6b13082046aee94443d)
Diffstat (limited to 'inet')
-rw-r--r-- | inet/getnameinfo.c | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/inet/getnameinfo.c b/inet/getnameinfo.c index c649c49..c8de163 100644 --- a/inet/getnameinfo.c +++ b/inet/getnameinfo.c @@ -303,12 +303,12 @@ gni_host_inet_numeric (struct scratch_buffer *tmpbuf, const struct sockaddr *sa, socklen_t addrlen, char *host, socklen_t hostlen, int flags) { - const char *c; if (sa->sa_family == AF_INET6) { const struct sockaddr_in6 *sin6p = (const struct sockaddr_in6 *) sa; - c = inet_ntop (AF_INET6, - (const void *) &sin6p->sin6_addr, host, hostlen); + if (inet_ntop (AF_INET6, &sin6p->sin6_addr, host, hostlen) == NULL) + return EAI_OVERFLOW; + uint32_t scopeid = sin6p->sin6_scope_id; if (scopeid != 0) { @@ -344,7 +344,7 @@ gni_host_inet_numeric (struct scratch_buffer *tmpbuf, if (real_hostlen + scopelen + 1 > hostlen) /* Signal the buffer is too small. This is what inet_ntop does. */ - c = NULL; + return EAI_OVERFLOW; else memcpy (host + real_hostlen, scopebuf, scopelen + 1); } @@ -352,10 +352,9 @@ gni_host_inet_numeric (struct scratch_buffer *tmpbuf, else { const struct sockaddr_in *sinp = (const struct sockaddr_in *) sa; - c = inet_ntop (AF_INET, &sinp->sin_addr, host, hostlen); + if (inet_ntop (AF_INET, &sinp->sin_addr, host, hostlen) == NULL) + return EAI_OVERFLOW; } - if (c == NULL) - return EAI_OVERFLOW; return 0; } |