Commit 2f122062 authored by Dave Jones's avatar Dave Jones Committed by Patrick McHardy

[AX25]: Fix digipeat leak.

Signed-off-by: default avatarDave Jones <davej@redhat.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 6cb553d2
...@@ -1176,13 +1176,16 @@ static int ax25_connect(struct socket *sock, struct sockaddr *uaddr, ...@@ -1176,13 +1176,16 @@ static int ax25_connect(struct socket *sock, struct sockaddr *uaddr,
/* check if we can remove this feature. It is broken. */ /* check if we can remove this feature. It is broken. */
printk(KERN_WARNING "ax25_connect(): %s uses autobind, please contact jreuter@yaina.de\n", printk(KERN_WARNING "ax25_connect(): %s uses autobind, please contact jreuter@yaina.de\n",
current->comm); current->comm);
if ((err = ax25_rt_autobind(ax25, &fsa->fsa_ax25.sax25_call)) < 0) if ((err = ax25_rt_autobind(ax25, &fsa->fsa_ax25.sax25_call)) < 0) {
kfree(digi);
goto out; goto out;
}
ax25_fillin_cb(ax25, ax25->ax25_dev); ax25_fillin_cb(ax25, ax25->ax25_dev);
ax25_cb_add(ax25); ax25_cb_add(ax25);
} else { } else {
if (ax25->ax25_dev == NULL) { if (ax25->ax25_dev == NULL) {
kfree(digi);
err = -EHOSTUNREACH; err = -EHOSTUNREACH;
goto out; goto out;
} }
...@@ -1191,7 +1194,6 @@ static int ax25_connect(struct socket *sock, struct sockaddr *uaddr, ...@@ -1191,7 +1194,6 @@ static int ax25_connect(struct socket *sock, struct sockaddr *uaddr,
if (sk->sk_type == SOCK_SEQPACKET && if (sk->sk_type == SOCK_SEQPACKET &&
(ax25t=ax25_find_cb(&ax25->source_addr, &fsa->fsa_ax25.sax25_call, digi, (ax25t=ax25_find_cb(&ax25->source_addr, &fsa->fsa_ax25.sax25_call, digi,
ax25->ax25_dev->dev))) { ax25->ax25_dev->dev))) {
if (digi != NULL)
kfree(digi); kfree(digi);
err = -EADDRINUSE; /* Already such a connection */ err = -EADDRINUSE; /* Already such a connection */
ax25_cb_put(ax25t); ax25_cb_put(ax25t);
......
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