net: tipc: fix possible refcount leak in tipc_sk_create()
[ Upstream commit 00aff3590fc0a73bddd3b743863c14e76fd35c0c ] Free sk in case tipc_sk_insert() fails. Signed-off-by: Hangyu Hua <hbh25y@gmail.com> Reviewed-by: Tung Nguyen <tung.q.nguyen@dektech.com.au> Signed-off-by: David S. Miller <davem@davemloft.net> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
bacfef0bf2
commit
efa78f2ae3
@@ -489,6 +489,7 @@ static int tipc_sk_create(struct net *net, struct socket *sock,
|
|||||||
sock_init_data(sock, sk);
|
sock_init_data(sock, sk);
|
||||||
tipc_set_sk_state(sk, TIPC_OPEN);
|
tipc_set_sk_state(sk, TIPC_OPEN);
|
||||||
if (tipc_sk_insert(tsk)) {
|
if (tipc_sk_insert(tsk)) {
|
||||||
|
sk_free(sk);
|
||||||
pr_warn("Socket create failed; port number exhausted\n");
|
pr_warn("Socket create failed; port number exhausted\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user