diff options
Diffstat (limited to 'net/ipv6/tcp_ipv6.c')
| -rw-r--r-- | net/ipv6/tcp_ipv6.c | 21 | 
1 files changed, 10 insertions, 11 deletions
| diff --git a/net/ipv6/tcp_ipv6.c b/net/ipv6/tcp_ipv6.c index f52b6f271a24..11b736a76bd7 100644 --- a/net/ipv6/tcp_ipv6.c +++ b/net/ipv6/tcp_ipv6.c @@ -665,12 +665,11 @@ static int tcp_v6_parse_md5_keys(struct sock *sk, int optname,  	if (ipv6_addr_v4mapped(&sin6->sin6_addr))  		return tcp_md5_do_add(sk, (union tcp_md5_addr *)&sin6->sin6_addr.s6_addr32[3],  				      AF_INET, prefixlen, l3index, flags, -				      cmd.tcpm_key, cmd.tcpm_keylen, -				      GFP_KERNEL); +				      cmd.tcpm_key, cmd.tcpm_keylen);  	return tcp_md5_do_add(sk, (union tcp_md5_addr *)&sin6->sin6_addr,  			      AF_INET6, prefixlen, l3index, flags, -			      cmd.tcpm_key, cmd.tcpm_keylen, GFP_KERNEL); +			      cmd.tcpm_key, cmd.tcpm_keylen);  }  static int tcp_v6_md5_hash_headers(struct tcp_md5sig_pool *hp, @@ -1365,14 +1364,14 @@ static struct sock *tcp_v6_syn_recv_sock(const struct sock *sk, struct sk_buff *  	/* Copy over the MD5 key from the original socket */  	key = tcp_v6_md5_do_lookup(sk, &newsk->sk_v6_daddr, l3index);  	if (key) { -		/* We're using one, so create a matching key -		 * on the newsk structure. If we fail to get -		 * memory, then we end up not copying the key -		 * across. Shucks. -		 */ -		tcp_md5_do_add(newsk, (union tcp_md5_addr *)&newsk->sk_v6_daddr, -			       AF_INET6, 128, l3index, key->flags, key->key, key->keylen, -			       sk_gfp_mask(sk, GFP_ATOMIC)); +		const union tcp_md5_addr *addr; + +		addr = (union tcp_md5_addr *)&newsk->sk_v6_daddr; +		if (tcp_md5_key_copy(newsk, addr, AF_INET6, 128, l3index, key)) { +			inet_csk_prepare_forced_close(newsk); +			tcp_done(newsk); +			goto out; +		}  	}  #endif | 
