Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/crypto/dist/ipsec-tools/src/racoon fix memory leaks: https:/...
details: https://anonhg.NetBSD.org/src/rev/e8704b61b4c1
branches: trunk
changeset: 993168:e8704b61b4c1
user: christos <christos%NetBSD.org@localhost>
date: Tue Aug 28 09:10:28 2018 +0000
description:
fix memory leaks: https://github.com/NetBSD/src/issues/6
diffstat:
crypto/dist/ipsec-tools/src/racoon/privsep.c | 21 ++++++++++++---------
1 files changed, 12 insertions(+), 9 deletions(-)
diffs (102 lines):
diff -r b0a355b1628b -r e8704b61b4c1 crypto/dist/ipsec-tools/src/racoon/privsep.c
--- a/crypto/dist/ipsec-tools/src/racoon/privsep.c Tue Aug 28 08:50:46 2018 +0000
+++ b/crypto/dist/ipsec-tools/src/racoon/privsep.c Tue Aug 28 09:10:28 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: privsep.c,v 1.24 2018/05/19 19:23:15 maxv Exp $ */
+/* $NetBSD: privsep.c,v 1.25 2018/08/28 09:10:28 christos Exp $ */
/* Id: privsep.c,v 1.15 2005/08/08 11:23:44 vanhu Exp */
@@ -917,7 +917,7 @@
memcpy(msg + 1, path, msg->bufs.buflen[0]);
if (privsep_send(privsep_sock[1], msg, len) != 0)
- return NULL;
+ goto out;
if (privsep_recv(privsep_sock[1], &msg, &len) != 0)
return NULL;
@@ -1034,13 +1034,14 @@
* And send it!
*/
if (privsep_send(privsep_sock[1], msg, msg->hdr.ac_len) != 0)
- return -1;
+ goto out;
if (privsep_recv(privsep_sock[1], &msg, &len) != 0)
return -1;
if (msg->hdr.ac_errno != 0) {
errno = msg->hdr.ac_errno;
+out:
racoon_free(msg);
return -1;
}
@@ -1081,7 +1082,7 @@
memcpy(data, &keylen, sizeof(keylen));
if (privsep_send(privsep_sock[1], msg, len) != 0)
- return NULL;
+ goto out;
if (privsep_recv(privsep_sock[1], &msg, &len) != 0)
return NULL;
@@ -1354,12 +1355,13 @@
/* frees msg */
if (privsep_send(privsep_sock[1], msg, len) != 0)
- return -1;
+ goto out;
if (privsep_recv(privsep_sock[1], &msg, &len) != 0)
return -1;
if (msg->hdr.ac_errno != 0) {
+out:
racoon_free(msg);
return -1;
}
@@ -1416,7 +1418,7 @@
/* frees msg */
if (privsep_send(privsep_sock[1], msg, len) != 0)
- return -1;
+ goto out;
if (privsep_recv(privsep_sock[1], &msg, &len) != 0)
return -1;
@@ -1664,7 +1666,7 @@
/* frees msg */
if (privsep_send(privsep_sock[1], msg, len) != 0)
- return -1;
+ goto out;
if (privsep_recv(privsep_sock[1], &msg, &len) != 0)
return -1;
@@ -1734,7 +1736,7 @@
/* frees msg */
if (privsep_send(privsep_sock[1], msg, len) != 0)
- return -1;
+ goto out;
if (privsep_recv(privsep_sock[1], &msg, &len) != 0)
return -1;
@@ -1786,7 +1788,7 @@
/* frees msg */
if (privsep_send(privsep_sock[1], msg, len) != 0)
- return;
+ goto out;
if (privsep_recv(privsep_sock[1], &msg, &len) != 0)
return;
@@ -1794,6 +1796,7 @@
if (msg->hdr.ac_errno != 0)
errno = msg->hdr.ac_errno;
+out:
racoon_free(msg);
return;
}
Home |
Main Index |
Thread Index |
Old Index