From 2331d13ae5c6c8de49aeae1cb23a7c23f3a71b62 Mon Sep 17 00:00:00 2001 From: deraadt <> Date: Fri, 27 Sep 1996 18:37:11 +0000 Subject: use INADDRSZ, more careful length checking --- src/lib/libc/net/gethostnamadr.c | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) (limited to 'src/lib') diff --git a/src/lib/libc/net/gethostnamadr.c b/src/lib/libc/net/gethostnamadr.c index 29fbedc594..3830e52cc6 100644 --- a/src/lib/libc/net/gethostnamadr.c +++ b/src/lib/libc/net/gethostnamadr.c @@ -52,7 +52,7 @@ */ #if defined(LIBC_SCCS) && !defined(lint) -static char rcsid[] = "$OpenBSD: gethostnamadr.c,v 1.9 1996/09/26 09:13:21 deraadt Exp $"; +static char rcsid[] = "$OpenBSD: gethostnamadr.c,v 1.10 1996/09/27 18:37:11 deraadt Exp $"; #endif /* LIBC_SCCS and not lint */ #include @@ -212,6 +212,8 @@ getanswer(answer, anslen, iquery) continue; *ap++ = bp; n = strlen(bp) + 1; + if (n > MAXHOSTNAMELEN) + bp[MAXHOSTNAMELEN-1] = '\0'; bp += n; buflen -= n; continue; @@ -237,6 +239,7 @@ getanswer(answer, anslen, iquery) cp += n; continue; } + if (haveanswer) { if (n != host.h_length) { cp += n; @@ -251,12 +254,12 @@ getanswer(answer, anslen, iquery) getclass = class; host.h_addrtype = (class == C_IN) ? AF_INET : AF_UNSPEC; if (host.h_addrtype == AF_INET) - host.h_length = sizeof(struct in_addr); + host.h_length = INADDRSZ; if (!iquery) { host.h_name = bp; - if (strlen(bp) >= MAXHOSTNAMELEN) - host.h_name[MAXHOSTNAMELEN-1] = '\0'; bp += strlen(bp) + 1; + if (strlen(host.h_name) >= MAXHOSTNAMELEN) + host.h_name[MAXHOSTNAMELEN-1] = '\0'; } } @@ -270,8 +273,6 @@ getanswer(answer, anslen, iquery) break; } bcopy(cp, *hap++ = bp, n); - if (n >= MAXHOSTNAMELEN) - bp[MAXHOSTNAMELEN-1] = '\0'; bp +=n; cp += n; haveanswer++; @@ -577,7 +578,7 @@ _yphostent(line) host.h_name = NULL; host.h_addr_list = h_addr_ptrs; - host.h_length = sizeof(u_int32_t); + host.h_length = INADDRSZ; host.h_addrtype = AF_INET; hap = h_addr_ptrs; buf = host_addrs; -- cgit v1.2.3-55-g6feb