ip-route: Fix for memleak in error path
If call to rta_addattr_l() failed, parse_encap_seg6() would leak memory.
Fix this by making sure calls to free() are not skipped.
Fixes: bd59e5b151 ("ip-route: Fix segfault with many nexthops")
Signed-off-by: Phil Sutter <phil@nwl.cc>
Signed-off-by: Stephen Hemminger <stephen@networkplumber.org>
This commit is contained in:
parent
3b0070f6b1
commit
e5da392ff8
|
|
@ -498,6 +498,7 @@ static int parse_encap_seg6(struct rtattr *rta, size_t len, int *argcp,
|
||||||
int argc = *argcp;
|
int argc = *argcp;
|
||||||
int encap = -1;
|
int encap = -1;
|
||||||
__u32 hmac = 0;
|
__u32 hmac = 0;
|
||||||
|
int ret = 0;
|
||||||
int srhlen;
|
int srhlen;
|
||||||
|
|
||||||
while (argc > 0) {
|
while (argc > 0) {
|
||||||
|
|
@ -539,16 +540,19 @@ static int parse_encap_seg6(struct rtattr *rta, size_t len, int *argcp,
|
||||||
memcpy(tuninfo->srh, srh, srhlen);
|
memcpy(tuninfo->srh, srh, srhlen);
|
||||||
|
|
||||||
if (rta_addattr_l(rta, len, SEG6_IPTUNNEL_SRH, tuninfo,
|
if (rta_addattr_l(rta, len, SEG6_IPTUNNEL_SRH, tuninfo,
|
||||||
sizeof(*tuninfo) + srhlen))
|
sizeof(*tuninfo) + srhlen)) {
|
||||||
return -1;
|
ret = -1;
|
||||||
|
goto out;
|
||||||
free(tuninfo);
|
}
|
||||||
free(srh);
|
|
||||||
|
|
||||||
*argcp = argc + 1;
|
*argcp = argc + 1;
|
||||||
*argvp = argv - 1;
|
*argvp = argv - 1;
|
||||||
|
|
||||||
return 0;
|
out:
|
||||||
|
free(tuninfo);
|
||||||
|
free(srh);
|
||||||
|
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct lwt_x {
|
struct lwt_x {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue