Commit bdd214a7 authored by Jon Maloy's avatar Jon Maloy Committed by Kleber Sacilotto de Souza

tipc: fix memory leak in tipc_accept_from_sock()

BugLink: http://bugs.launchpad.net/bugs/1745047

[ Upstream commit a7d5f107 ]

When the function tipc_accept_from_sock() fails to create an instance of
struct tipc_subscriber it omits to free the already created instance of
struct tipc_conn instance before it returns.

We fix that with this commit.
Reported-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarJon Maloy <jon.maloy@ericsson.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarKhalid Elmously <khalid.elmously@canonical.com>
Signed-off-by: default avatarStefan Bader <stefan.bader@canonical.com>
parent 09cf6085
...@@ -311,6 +311,7 @@ static int tipc_accept_from_sock(struct tipc_conn *con) ...@@ -311,6 +311,7 @@ static int tipc_accept_from_sock(struct tipc_conn *con)
newcon->usr_data = s->tipc_conn_new(newcon->conid); newcon->usr_data = s->tipc_conn_new(newcon->conid);
if (!newcon->usr_data) { if (!newcon->usr_data) {
sock_release(newsock); sock_release(newsock);
conn_put(newcon);
return -ENOMEM; return -ENOMEM;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment