diff options
author | Todd C. Miller <millert@cvs.openbsd.org> | 1998-08-16 21:20:08 +0000 |
---|---|---|
committer | Todd C. Miller <millert@cvs.openbsd.org> | 1998-08-16 21:20:08 +0000 |
commit | 1c6ff3b71d87ee1764e62ffbbc57b3ec543ef219 (patch) | |
tree | c0c41d6e44c56c35fbda00c007957567235808f1 | |
parent | 976c506be0a96c2303d0f33a3a62aabcf564690c (diff) |
fix realloc memory leaks
-rw-r--r-- | usr.sbin/named/named-xfer/named-xfer.c | 12 | ||||
-rw-r--r-- | usr.sbin/named/named/ns_main.c | 14 |
2 files changed, 15 insertions, 11 deletions
diff --git a/usr.sbin/named/named-xfer/named-xfer.c b/usr.sbin/named/named-xfer/named-xfer.c index c8be29db6a9..ba4b5cdf887 100644 --- a/usr.sbin/named/named-xfer/named-xfer.c +++ b/usr.sbin/named/named-xfer/named-xfer.c @@ -1,4 +1,4 @@ -/* $OpenBSD: named-xfer.c,v 1.6 1998/05/22 07:09:23 millert Exp $ */ +/* $OpenBSD: named-xfer.c,v 1.7 1998/08/16 21:20:03 millert Exp $ */ /* * The original version of xfer by Kevin Dunlap. @@ -97,7 +97,7 @@ char copyright[] = static char sccsid[] = "@(#)named-xfer.c 4.18 (Berkeley) 3/7/91"; static char rcsid[] = "$From: named-xfer.c,v 8.24 1998/04/07 04:59:45 vixie Exp $"; #else -static char rcsid[] = "$OpenBSD: named-xfer.c,v 1.6 1998/05/22 07:09:23 millert Exp $"; +static char rcsid[] = "$OpenBSD: named-xfer.c,v 1.7 1998/08/16 21:20:03 millert Exp $"; #endif #endif /* not lint */ @@ -665,7 +665,7 @@ getzone(zp, serial_no, port) continue; } if (len > bufsize) { - if ((buf = (u_char *)realloc(buf, len)) == NULL) { + if ((tmp = (u_char *)realloc(buf, len)) == NULL) { syslog(LOG_INFO, "malloc(%u) failed for SOA from server [%s], zone %s\n", len, @@ -674,6 +674,7 @@ getzone(zp, serial_no, port) (void) my_close(s); continue; } + buf = tmp; bufsize = len; } if (netread(s, (char *)buf, len, XFER_TIMER) < 0) { @@ -906,8 +907,8 @@ getzone(zp, serial_no, port) if ((len = _getshort(buf)) == 0) break; if (len > bufsize) { - buf = (u_char *)realloc(buf, len); - if (buf == NULL) { + tmp = (u_char *)realloc(buf, len); + if (tmp == NULL) { syslog(LOG_INFO, "malloc(%u) failed for packet from server [%s], zone %s\n", len, @@ -916,6 +917,7 @@ getzone(zp, serial_no, port) error++; break; } + buf = tmp; bufsize = len; } hp = (HEADER *)buf; diff --git a/usr.sbin/named/named/ns_main.c b/usr.sbin/named/named/ns_main.c index b3a56022b79..6a243a18463 100644 --- a/usr.sbin/named/named/ns_main.c +++ b/usr.sbin/named/named/ns_main.c @@ -1,11 +1,11 @@ -/* $OpenBSD: ns_main.c,v 1.15 1998/08/14 15:07:36 millert Exp $ */ +/* $OpenBSD: ns_main.c,v 1.16 1998/08/16 21:20:07 millert Exp $ */ #if !defined(lint) && !defined(SABER) #if 0 static char sccsid[] = "@(#)ns_main.c 4.55 (Berkeley) 7/1/91"; static char rcsid[] = "$From: ns_main.c,v 8.26 1998/05/11 04:19:45 vixie Exp $"; #else -static char rcsid[] = "$OpenBSD: ns_main.c,v 1.15 1998/08/14 15:07:36 millert Exp $"; +static char rcsid[] = "$OpenBSD: ns_main.c,v 1.16 1998/08/16 21:20:07 millert Exp $"; #endif #endif /* not lint */ @@ -1037,14 +1037,16 @@ main(argc, argv, envp) if (sp->s_size > sp->s_bufsize && sp->s_bufsize != 0 ) { - sp->s_buf = (u_char *) - realloc((char *)sp->s_buf, - (unsigned)sp->s_size); - if (sp->s_buf == NULL) { + u_char *s_buf = (u_char *) + realloc((void *)sp->s_buf, + (size_t)sp->s_size); + if (s_buf == NULL) { + free(sp->s_buf); sp->s_buf = buf; sp->s_bufsize = 0; sp->s_size = sizeof(buf); } else { + sp->s_buf = s_buf; sp->s_bufsize = sp->s_size; } } |