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 encap = -1;
|
||||
__u32 hmac = 0;
|
||||
int ret = 0;
|
||||
int srhlen;
|
||||
|
||||
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);
|
||||
|
||||
if (rta_addattr_l(rta, len, SEG6_IPTUNNEL_SRH, tuninfo,
|
||||
sizeof(*tuninfo) + srhlen))
|
||||
return -1;
|
||||
|
||||
free(tuninfo);
|
||||
free(srh);
|
||||
sizeof(*tuninfo) + srhlen)) {
|
||||
ret = -1;
|
||||
goto out;
|
||||
}
|
||||
|
||||
*argcp = argc + 1;
|
||||
*argvp = argv - 1;
|
||||
|
||||
return 0;
|
||||
out:
|
||||
free(tuninfo);
|
||||
free(srh);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
struct lwt_x {
|
||||
|
|
|
|||
Loading…
Reference in New Issue