summaryrefslogtreecommitdiff
path: root/usr.sbin/bgpd
diff options
context:
space:
mode:
authorHenning Brauer <henning@cvs.openbsd.org>2003-12-30 20:59:44 +0000
committerHenning Brauer <henning@cvs.openbsd.org>2003-12-30 20:59:44 +0000
commit503a8c85bf9b1b8f59ca6cf77745900bead089c9 (patch)
treeef09024a0e2d2b515d9976e34bd6e0c509325c74 /usr.sbin/bgpd
parent734763169e94ae457cd653755000ed4aa04b5a42 (diff)
missing free()s in error cases that (now) lead to program termination
From: Patrick Latifi <pat@eyeo.org>
Diffstat (limited to 'usr.sbin/bgpd')
-rw-r--r--usr.sbin/bgpd/bgpd.c10
-rw-r--r--usr.sbin/bgpd/imsg.c5
2 files changed, 11 insertions, 4 deletions
diff --git a/usr.sbin/bgpd/bgpd.c b/usr.sbin/bgpd/bgpd.c
index 95e3c0ba3f0..a046d330d3a 100644
--- a/usr.sbin/bgpd/bgpd.c
+++ b/usr.sbin/bgpd/bgpd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: bgpd.c,v 1.45 2003/12/27 14:58:22 henning Exp $ */
+/* $OpenBSD: bgpd.c,v 1.46 2003/12/30 20:59:43 henning Exp $ */
/*
* Copyright (c) 2003 Henning Brauer <henning@openbsd.org>
@@ -358,10 +358,14 @@ dispatch_imsg(struct imsgbuf *ibuf, int idx, struct mrt_config *conf)
wbuf = buf_open(len);
if (wbuf == NULL)
return (-1);
- if (buf_add(wbuf, imsg.data, len) == -1)
+ if (buf_add(wbuf, imsg.data, len) == -1) {
+ free(wbuf);
return (-1);
- if ((n = buf_close(&m->msgbuf, wbuf)) < 0)
+ }
+ if ((n = buf_close(&m->msgbuf, wbuf)) < 0) {
+ free(wbuf);
return (-1);
+ }
break;
}
break;
diff --git a/usr.sbin/bgpd/imsg.c b/usr.sbin/bgpd/imsg.c
index fb92c6d6003..2214fb7e2d1 100644
--- a/usr.sbin/bgpd/imsg.c
+++ b/usr.sbin/bgpd/imsg.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: imsg.c,v 1.12 2003/12/28 14:34:30 henning Exp $ */
+/* $OpenBSD: imsg.c,v 1.13 2003/12/30 20:59:43 henning Exp $ */
/*
* Copyright (c) 2003 Henning Brauer <henning@openbsd.org>
@@ -101,16 +101,19 @@ imsg_compose(struct imsgbuf *ibuf, int type, u_int32_t peerid, void *data,
}
if (buf_add(wbuf, &hdr, sizeof(hdr)) == -1) {
logit(LOG_CRIT, "imsg_compose: buf_add error");
+ free(wbuf);
return (-1);
}
if (datalen)
if (buf_add(wbuf, data, datalen) == -1) {
logit(LOG_CRIT, "imsg_compose: buf_add error");
+ free(wbuf);
return (-1);
}
if ((n = buf_close(&ibuf->w, wbuf)) < 0) {
logit(LOG_CRIT, "imsg_compose: buf_add error");
+ free(wbuf);
return (-1);
}
return (n);