From: Gustavo A. R. Silva Date: Sat, 5 Jan 2019 16:52:23 +0000 (-0600) Subject: tipc: fix memory leak in tipc_nl_compat_publ_dump X-Git-Tag: v5.15~7163^2~28 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=f87d8ad9233f115db92c6c087d58403b0009ed36;p=platform%2Fkernel%2Flinux-starfive.git tipc: fix memory leak in tipc_nl_compat_publ_dump There is a memory leak in case genlmsg_put fails. Fix this by freeing *args* before return. Addresses-Coverity-ID: 1476406 ("Resource leak") Fixes: 46273cf7e009 ("tipc: fix a missing check of genlmsg_put") Signed-off-by: Gustavo A. R. Silva Acked-by: Ying Xue Signed-off-by: David S. Miller --- diff --git a/net/tipc/netlink_compat.c b/net/tipc/netlink_compat.c index 40f5cae..77e4b24 100644 --- a/net/tipc/netlink_compat.c +++ b/net/tipc/netlink_compat.c @@ -904,8 +904,10 @@ static int tipc_nl_compat_publ_dump(struct tipc_nl_compat_msg *msg, u32 sock) hdr = genlmsg_put(args, 0, 0, &tipc_genl_family, NLM_F_MULTI, TIPC_NL_PUBL_GET); - if (!hdr) + if (!hdr) { + kfree_skb(args); return -EMSGSIZE; + } nest = nla_nest_start(args, TIPC_NLA_SOCK); if (!nest) {