inet_diag: Fix error path to cancel the meseage in inet_req_diag_fill()
nlmsg_cancel() needs to be called in the error path of
inet_req_diag_fill to cancel the message.
Fixes: d545caca82
("net: inet: diag: expose the socket mark to privileged processes.")
Reported-by: Hulk Robot <hulkci@huawei.com>
Signed-off-by: Wang Hai <wanghai38@huawei.com>
Link: https://lore.kernel.org/r/20201116082018.16496-1-wanghai38@huawei.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
138559b9f9
commit
e33de7c531
|
@ -479,8 +479,10 @@ static int inet_req_diag_fill(struct sock *sk, struct sk_buff *skb,
|
||||||
r->idiag_inode = 0;
|
r->idiag_inode = 0;
|
||||||
|
|
||||||
if (net_admin && nla_put_u32(skb, INET_DIAG_MARK,
|
if (net_admin && nla_put_u32(skb, INET_DIAG_MARK,
|
||||||
inet_rsk(reqsk)->ir_mark))
|
inet_rsk(reqsk)->ir_mark)) {
|
||||||
|
nlmsg_cancel(skb, nlh);
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
}
|
||||||
|
|
||||||
nlmsg_end(skb, nlh);
|
nlmsg_end(skb, nlh);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
Loading…
Reference in New Issue