summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authoritojun <>2001-06-30 00:50:21 +0000
committeritojun <>2001-06-30 00:50:21 +0000
commitd7bfd098a5d6ef18b075d0ec5ad9c46ffd81932d (patch)
tree3ceb26b9bc5f7899db2aeee0f2ee4f968239e07a /src
parentffd66982d4c93fc099b5e4a666cd36fb7f4c3bd9 (diff)
downloadopenbsd-d7bfd098a5d6ef18b075d0ec5ad9c46ffd81932d.tar.gz
openbsd-d7bfd098a5d6ef18b075d0ec5ad9c46ffd81932d.tar.bz2
openbsd-d7bfd098a5d6ef18b075d0ec5ad9c46ffd81932d.zip
missing freeaddrinfo(). PR 1907
Diffstat (limited to 'src')
-rw-r--r--src/lib/libc/net/res_init.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/lib/libc/net/res_init.c b/src/lib/libc/net/res_init.c
index 5134323f4e..d21eed4a87 100644
--- a/src/lib/libc/net/res_init.c
+++ b/src/lib/libc/net/res_init.c
@@ -1,4 +1,4 @@
1/* $OpenBSD: res_init.c,v 1.22 2001/06/27 00:58:55 lebel Exp $ */ 1/* $OpenBSD: res_init.c,v 1.23 2001/06/30 00:50:21 itojun Exp $ */
2 2
3/* 3/*
4 * ++Copyright++ 1985, 1989, 1993 4 * ++Copyright++ 1985, 1989, 1993
@@ -64,7 +64,7 @@
64static char sccsid[] = "@(#)res_init.c 8.1 (Berkeley) 6/7/93"; 64static char sccsid[] = "@(#)res_init.c 8.1 (Berkeley) 6/7/93";
65static char rcsid[] = "$From: res_init.c,v 8.7 1996/09/28 06:51:07 vixie Exp $"; 65static char rcsid[] = "$From: res_init.c,v 8.7 1996/09/28 06:51:07 vixie Exp $";
66#else 66#else
67static char rcsid[] = "$OpenBSD: res_init.c,v 1.22 2001/06/27 00:58:55 lebel Exp $"; 67static char rcsid[] = "$OpenBSD: res_init.c,v 1.23 2001/06/30 00:50:21 itojun Exp $";
68#endif 68#endif
69#endif /* LIBC_SCCS and not lint */ 69#endif /* LIBC_SCCS and not lint */
70 70
@@ -372,6 +372,7 @@ res_init()
372 hints.ai_flags = AI_NUMERICHOST; 372 hints.ai_flags = AI_NUMERICHOST;
373 hints.ai_socktype = SOCK_DGRAM; 373 hints.ai_socktype = SOCK_DGRAM;
374 snprintf(pbuf, sizeof(pbuf), "%d", NAMESERVER_PORT); 374 snprintf(pbuf, sizeof(pbuf), "%d", NAMESERVER_PORT);
375 res = NULL;
375 if (getaddrinfo(cp, pbuf, &hints, &res) == 0 && 376 if (getaddrinfo(cp, pbuf, &hints, &res) == 0 &&
376 res->ai_next == NULL) { 377 res->ai_next == NULL) {
377 if (res->ai_addrlen <= sizeof(_res_ext.nsaddr_list[nserv])) { 378 if (res->ai_addrlen <= sizeof(_res_ext.nsaddr_list[nserv])) {
@@ -390,6 +391,8 @@ res_init()
390 } 391 }
391 nserv++; 392 nserv++;
392 } 393 }
394 if (res)
395 freeaddrinfo(res);
393#else /* INET6 */ 396#else /* INET6 */
394 if ((*cp != '\0') && (*cp != '\n') && inet_aton(cp, &a)) { 397 if ((*cp != '\0') && (*cp != '\n') && inet_aton(cp, &a)) {
395 _res.nsaddr_list[nserv].sin_addr = a; 398 _res.nsaddr_list[nserv].sin_addr = a;