diff options
Diffstat (limited to 'net/irda/af_irda.c')
| -rw-r--r-- | net/irda/af_irda.c | 8 | 
1 files changed, 2 insertions, 6 deletions
| diff --git a/net/irda/af_irda.c b/net/irda/af_irda.c index 8d2f7c9b491d..391c3cbd2eed 100644 --- a/net/irda/af_irda.c +++ b/net/irda/af_irda.c @@ -832,7 +832,7 @@ static int irda_accept(struct socket *sock, struct socket *newsock, int flags)  	struct sock *sk = sock->sk;  	struct irda_sock *new, *self = irda_sk(sk);  	struct sock *newsk; -	struct sk_buff *skb; +	struct sk_buff *skb = NULL;  	int err;  	err = irda_create(sock_net(sk), newsock, sk->sk_protocol, 0); @@ -845,9 +845,6 @@ static int irda_accept(struct socket *sock, struct socket *newsock, int flags)  	if (sock->state != SS_UNCONNECTED)  		goto out; -	if ((sk = sock->sk) == NULL) -		goto out; -  	err = -EOPNOTSUPP;  	if ((sk->sk_type != SOCK_STREAM) && (sk->sk_type != SOCK_SEQPACKET) &&  	    (sk->sk_type != SOCK_DGRAM)) @@ -900,7 +897,6 @@ static int irda_accept(struct socket *sock, struct socket *newsock, int flags)  	err = -EPERM; /* value does not seem to make sense. -arnd */  	if (!new->tsap) {  		pr_debug("%s(), dup failed!\n", __func__); -		kfree_skb(skb);  		goto out;  	} @@ -919,7 +915,6 @@ static int irda_accept(struct socket *sock, struct socket *newsock, int flags)  	/* Clean up the original one to keep it in listen state */  	irttp_listen(self->tsap); -	kfree_skb(skb);  	sk->sk_ack_backlog--;  	newsock->state = SS_CONNECTED; @@ -927,6 +922,7 @@ static int irda_accept(struct socket *sock, struct socket *newsock, int flags)  	irda_connect_response(new);  	err = 0;  out: +	kfree_skb(skb);  	release_sock(sk);  	return err;  } |