diff options
| -rw-r--r-- | net/l2tp/l2tp_ip.c | 22 | ||||
| -rw-r--r-- | net/l2tp/l2tp_ip6.c | 23 | 
2 files changed, 16 insertions, 29 deletions
| diff --git a/net/l2tp/l2tp_ip.c b/net/l2tp/l2tp_ip.c index 2a77732c6496..fd7363f8405a 100644 --- a/net/l2tp/l2tp_ip.c +++ b/net/l2tp/l2tp_ip.c @@ -122,6 +122,7 @@ static int l2tp_ip_recv(struct sk_buff *skb)  	unsigned char *ptr, *optr;  	struct l2tp_session *session;  	struct l2tp_tunnel *tunnel = NULL; +	struct iphdr *iph;  	int length;  	if (!pskb_may_pull(skb, 4)) @@ -180,23 +181,16 @@ pass_up:  		goto discard;  	tunnel_id = ntohl(*(__be32 *) &skb->data[4]); -	tunnel = l2tp_tunnel_find(net, tunnel_id); -	if (tunnel) { -		sk = tunnel->sock; -		sock_hold(sk); -	} else { -		struct iphdr *iph = (struct iphdr *) skb_network_header(skb); +	iph = (struct iphdr *)skb_network_header(skb); -		read_lock_bh(&l2tp_ip_lock); -		sk = __l2tp_ip_bind_lookup(net, iph->daddr, 0, tunnel_id); -		if (!sk) { -			read_unlock_bh(&l2tp_ip_lock); -			goto discard; -		} - -		sock_hold(sk); +	read_lock_bh(&l2tp_ip_lock); +	sk = __l2tp_ip_bind_lookup(net, iph->daddr, 0, tunnel_id); +	if (!sk) {  		read_unlock_bh(&l2tp_ip_lock); +		goto discard;  	} +	sock_hold(sk); +	read_unlock_bh(&l2tp_ip_lock);  	if (!xfrm4_policy_check(sk, XFRM_POLICY_IN, skb))  		goto discard_put; diff --git a/net/l2tp/l2tp_ip6.c b/net/l2tp/l2tp_ip6.c index 4d4561dd4023..5bb5337e74fc 100644 --- a/net/l2tp/l2tp_ip6.c +++ b/net/l2tp/l2tp_ip6.c @@ -134,6 +134,7 @@ static int l2tp_ip6_recv(struct sk_buff *skb)  	unsigned char *ptr, *optr;  	struct l2tp_session *session;  	struct l2tp_tunnel *tunnel = NULL; +	struct ipv6hdr *iph;  	int length;  	if (!pskb_may_pull(skb, 4)) @@ -193,24 +194,16 @@ pass_up:  		goto discard;  	tunnel_id = ntohl(*(__be32 *) &skb->data[4]); -	tunnel = l2tp_tunnel_find(net, tunnel_id); -	if (tunnel) { -		sk = tunnel->sock; -		sock_hold(sk); -	} else { -		struct ipv6hdr *iph = ipv6_hdr(skb); - -		read_lock_bh(&l2tp_ip6_lock); -		sk = __l2tp_ip6_bind_lookup(net, &iph->daddr, -					    0, tunnel_id); -		if (!sk) { -			read_unlock_bh(&l2tp_ip6_lock); -			goto discard; -		} +	iph = ipv6_hdr(skb); -		sock_hold(sk); +	read_lock_bh(&l2tp_ip6_lock); +	sk = __l2tp_ip6_bind_lookup(net, &iph->daddr, 0, tunnel_id); +	if (!sk) {  		read_unlock_bh(&l2tp_ip6_lock); +		goto discard;  	} +	sock_hold(sk); +	read_unlock_bh(&l2tp_ip6_lock);  	if (!xfrm6_policy_check(sk, XFRM_POLICY_IN, skb))  		goto discard_put; | 
