diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2020-04-24 19:17:30 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2020-04-24 19:17:30 -0700 | 
| commit | ab51cac00ef2859f20a73d33a53f3a8987b65e11 (patch) | |
| tree | 0965ed2cb75c77c252333cdb667537c44274353a /net/mptcp/protocol.c | |
| parent | 5ef58e29078261ef5195c7fee74768546b863182 (diff) | |
| parent | 167ff131cb3dffccab8bb4d65a8d72e7c5ffc398 (diff) | |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net
Pull networking fixes from David Miller:
 1) Fix memory leak in netfilter flowtable, from Roi Dayan.
 2) Ref-count leaks in netrom and tipc, from Xiyu Yang.
 3) Fix warning when mptcp socket is never accepted before close, from
    Florian Westphal.
 4) Missed locking in ovs_ct_exit(), from Tonghao Zhang.
 5) Fix large delays during PTP synchornization in cxgb4, from Rahul
    Lakkireddy.
 6) team_mode_get() can hang, from Taehee Yoo.
 7) Need to use kvzalloc() when allocating fw tracer in mlx5 driver,
    from Niklas Schnelle.
 8) Fix handling of bpf XADD on BTF memory, from Jann Horn.
 9) Fix BPF_STX/BPF_B encoding in x86 bpf jit, from Luke Nelson.
10) Missing queue memory release in iwlwifi pcie code, from Johannes
    Berg.
11) Fix NULL deref in macvlan device event, from Taehee Yoo.
12) Initialize lan87xx phy correctly, from Yuiko Oshino.
13) Fix looping between VRF and XFRM lookups, from David Ahern.
14) etf packet scheduler assumes all sockets are full sockets, which is
    not necessarily true. From Eric Dumazet.
15) Fix mptcp data_fin handling in RX path, from Paolo Abeni.
16) fib_select_default() needs to handle nexthop objects, from David
    Ahern.
17) Use GFP_ATOMIC under spinlock in mac80211_hwsim, from Wei Yongjun.
18) vxlan and geneve use wrong nlattr array, from Sabrina Dubroca.
19) Correct rx/tx stats in bcmgenet driver, from Doug Berger.
20) BPF_LDX zero-extension is encoded improperly in x86_32 bpf jit, fix
    from Luke Nelson.
* git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net: (100 commits)
  selftests/bpf: Fix a couple of broken test_btf cases
  tools/runqslower: Ensure own vmlinux.h is picked up first
  bpf: Make bpf_link_fops static
  bpftool: Respect the -d option in struct_ops cmd
  selftests/bpf: Add test for freplace program with expected_attach_type
  bpf: Propagate expected_attach_type when verifying freplace programs
  bpf: Fix leak in LINK_UPDATE and enforce empty old_prog_fd
  bpf, x86_32: Fix logic error in BPF_LDX zero-extension
  bpf, x86_32: Fix clobbering of dst for BPF_JSET
  bpf, x86_32: Fix incorrect encoding in BPF_LDX zero-extension
  bpf: Fix reStructuredText markup
  net: systemport: suppress warnings on failed Rx SKB allocations
  net: bcmgenet: suppress warnings on failed Rx SKB allocations
  macsec: avoid to set wrong mtu
  mac80211: sta_info: Add lockdep condition for RCU list usage
  mac80211: populate debugfs only after cfg80211 init
  net: bcmgenet: correct per TX/RX ring statistics
  net: meth: remove spurious copyright text
  net: phy: bcm84881: clear settings on link down
  chcr: Fix CPU hard lockup
  ...
Diffstat (limited to 'net/mptcp/protocol.c')
| -rw-r--r-- | net/mptcp/protocol.c | 19 | 
1 files changed, 14 insertions, 5 deletions
| diff --git a/net/mptcp/protocol.c b/net/mptcp/protocol.c index 9936e33ac351..b22a63ba2348 100644 --- a/net/mptcp/protocol.c +++ b/net/mptcp/protocol.c @@ -1332,7 +1332,9 @@ static struct ipv6_pinfo *mptcp_inet6_sk(const struct sock *sk)  }  #endif -struct sock *mptcp_sk_clone(const struct sock *sk, struct request_sock *req) +struct sock *mptcp_sk_clone(const struct sock *sk, +			    const struct tcp_options_received *opt_rx, +			    struct request_sock *req)  {  	struct mptcp_subflow_request_sock *subflow_req = mptcp_subflow_rsk(req);  	struct sock *nsk = sk_clone_lock(sk, GFP_ATOMIC); @@ -1355,26 +1357,30 @@ struct sock *mptcp_sk_clone(const struct sock *sk, struct request_sock *req)  	msk->subflow = NULL;  	if (unlikely(mptcp_token_new_accept(subflow_req->token, nsk))) { +		nsk->sk_state = TCP_CLOSE;  		bh_unlock_sock(nsk);  		/* we can't call into mptcp_close() here - possible BH context -		 * free the sock directly +		 * free the sock directly. +		 * sk_clone_lock() sets nsk refcnt to two, hence call sk_free() +		 * too.  		 */ -		nsk->sk_prot->destroy(nsk); +		sk_common_release(nsk);  		sk_free(nsk);  		return NULL;  	}  	msk->write_seq = subflow_req->idsn + 1;  	atomic64_set(&msk->snd_una, msk->write_seq); -	if (subflow_req->remote_key_valid) { +	if (opt_rx->mptcp.mp_capable) {  		msk->can_ack = true; -		msk->remote_key = subflow_req->remote_key; +		msk->remote_key = opt_rx->mptcp.sndr_key;  		mptcp_crypto_key_sha(msk->remote_key, NULL, &ack_seq);  		ack_seq++;  		msk->ack_seq = ack_seq;  	} +	sock_reset_flag(nsk, SOCK_RCU_FREE);  	/* will be fully established after successful MPC subflow creation */  	inet_sk_state_store(nsk, TCP_SYN_RECV);  	bh_unlock_sock(nsk); @@ -1431,6 +1437,7 @@ static struct sock *mptcp_accept(struct sock *sk, int flags, int *err,  		newsk = new_mptcp_sock;  		mptcp_copy_inaddrs(newsk, ssk);  		list_add(&subflow->node, &msk->conn_list); +		inet_sk_state_store(newsk, TCP_ESTABLISHED);  		bh_unlock_sock(new_mptcp_sock); @@ -1775,6 +1782,8 @@ static int mptcp_listen(struct socket *sock, int backlog)  		goto unlock;  	} +	sock_set_flag(sock->sk, SOCK_RCU_FREE); +  	err = ssock->ops->listen(ssock, backlog);  	inet_sk_state_store(sock->sk, inet_sk_state_load(ssock->sk));  	if (!err) | 
