diff options
author | tuexen <tuexen@FreeBSD.org> | 2015-05-29 11:25:38 +0000 |
---|---|---|
committer | tuexen <tuexen@FreeBSD.org> | 2015-05-29 11:25:38 +0000 |
commit | 551a3dd3e4681c055c9c2088984999a8dfe55801 (patch) | |
tree | f73068bfe4757732c085cccd7e16dfcd55965eb2 /sys/netinet6/sctp6_usrreq.c | |
parent | 4f472903627e114d312c683f667422654d0d25c7 (diff) | |
download | FreeBSD-src-551a3dd3e4681c055c9c2088984999a8dfe55801.zip FreeBSD-src-551a3dd3e4681c055c9c2088984999a8dfe55801.tar.gz |
MFC r275868:
Plug a memory leak in an error code path.
Reported by: Coverity
CID: 1018936
Diffstat (limited to 'sys/netinet6/sctp6_usrreq.c')
-rw-r--r-- | sys/netinet6/sctp6_usrreq.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/sys/netinet6/sctp6_usrreq.c b/sys/netinet6/sctp6_usrreq.c index 9c12662..ed5f842 100644 --- a/sys/netinet6/sctp6_usrreq.c +++ b/sys/netinet6/sctp6_usrreq.c @@ -1129,8 +1129,11 @@ sctp6_peeraddr(struct socket *so, struct sockaddr **addr) SCTP_LTRACE_ERR_RET(inp, NULL, NULL, SCTP_FROM_SCTP6_USRREQ, ENOENT); return (ENOENT); } - if ((error = sa6_recoverscope(sin6)) != 0) + if ((error = sa6_recoverscope(sin6)) != 0) { + SCTP_FREE_SONAME(sin6); + SCTP_LTRACE_ERR_RET(inp, NULL, NULL, SCTP_FROM_SCTP6_USRREQ, error); return (error); + } *addr = (struct sockaddr *)sin6; return (0); } |