diff options
| author | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2021-08-09 09:03:47 +0200 | 
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2021-08-09 09:03:47 +0200 | 
| commit | bd935a7b21340e2e37f51a7f2d3188145e2fcf1f (patch) | |
| tree | ac8af4e6ea552d32839c415b2f36d416ee327ea4 /net/tipc/socket.c | |
| parent | 96ba6c6e8922e89ca4908c650072d8f8d7b39cbc (diff) | |
| parent | 36a21d51725af2ce0700c6ebcb6b9594aac658a6 (diff) | |
Merge 5.14-rc5 into driver-core-next
We need the driver core fixes in here as well.
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'net/tipc/socket.c')
| -rw-r--r-- | net/tipc/socket.c | 30 | 
1 files changed, 17 insertions, 13 deletions
| diff --git a/net/tipc/socket.c b/net/tipc/socket.c index 34a97ea36cc8..75b99b7eda22 100644 --- a/net/tipc/socket.c +++ b/net/tipc/socket.c @@ -158,6 +158,7 @@ static void tipc_sk_remove(struct tipc_sock *tsk);  static int __tipc_sendstream(struct socket *sock, struct msghdr *m, size_t dsz);  static int __tipc_sendmsg(struct socket *sock, struct msghdr *m, size_t dsz);  static void tipc_sk_push_backlog(struct tipc_sock *tsk, bool nagle_ack); +static int tipc_wait_for_connect(struct socket *sock, long *timeo_p);  static const struct proto_ops packet_ops;  static const struct proto_ops stream_ops; @@ -1515,8 +1516,13 @@ static int __tipc_sendmsg(struct socket *sock, struct msghdr *m, size_t dlen)  		rc = 0;  	} -	if (unlikely(syn && !rc)) +	if (unlikely(syn && !rc)) {  		tipc_set_sk_state(sk, TIPC_CONNECTING); +		if (timeout) { +			timeout = msecs_to_jiffies(timeout); +			tipc_wait_for_connect(sock, &timeout); +		} +	}  	return rc ? rc : dlen;  } @@ -1564,7 +1570,7 @@ static int __tipc_sendstream(struct socket *sock, struct msghdr *m, size_t dlen)  		return -EMSGSIZE;  	/* Handle implicit connection setup */ -	if (unlikely(dest)) { +	if (unlikely(dest && sk->sk_state == TIPC_OPEN)) {  		rc = __tipc_sendmsg(sock, m, dlen);  		if (dlen && dlen == rc) {  			tsk->peer_caps = tipc_node_get_capabilities(net, dnode); @@ -2646,7 +2652,7 @@ static int tipc_listen(struct socket *sock, int len)  static int tipc_wait_for_accept(struct socket *sock, long timeo)  {  	struct sock *sk = sock->sk; -	DEFINE_WAIT(wait); +	DEFINE_WAIT_FUNC(wait, woken_wake_function);  	int err;  	/* True wake-one mechanism for incoming connections: only @@ -2655,12 +2661,12 @@ static int tipc_wait_for_accept(struct socket *sock, long timeo)  	 * anymore, the common case will execute the loop only once.  	*/  	for (;;) { -		prepare_to_wait_exclusive(sk_sleep(sk), &wait, -					  TASK_INTERRUPTIBLE);  		if (timeo && skb_queue_empty(&sk->sk_receive_queue)) { +			add_wait_queue(sk_sleep(sk), &wait);  			release_sock(sk); -			timeo = schedule_timeout(timeo); +			timeo = wait_woken(&wait, TASK_INTERRUPTIBLE, timeo);  			lock_sock(sk); +			remove_wait_queue(sk_sleep(sk), &wait);  		}  		err = 0;  		if (!skb_queue_empty(&sk->sk_receive_queue)) @@ -2672,7 +2678,6 @@ static int tipc_wait_for_accept(struct socket *sock, long timeo)  		if (signal_pending(current))  			break;  	} -	finish_wait(sk_sleep(sk), &wait);  	return err;  } @@ -2689,9 +2694,10 @@ static int tipc_accept(struct socket *sock, struct socket *new_sock, int flags,  		       bool kern)  {  	struct sock *new_sk, *sk = sock->sk; -	struct sk_buff *buf;  	struct tipc_sock *new_tsock; +	struct msghdr m = {NULL,};  	struct tipc_msg *msg; +	struct sk_buff *buf;  	long timeo;  	int res; @@ -2737,19 +2743,17 @@ static int tipc_accept(struct socket *sock, struct socket *new_sock, int flags,  	}  	/* -	 * Respond to 'SYN-' by discarding it & returning 'ACK'-. -	 * Respond to 'SYN+' by queuing it on new socket. +	 * Respond to 'SYN-' by discarding it & returning 'ACK'. +	 * Respond to 'SYN+' by queuing it on new socket & returning 'ACK'.  	 */  	if (!msg_data_sz(msg)) { -		struct msghdr m = {NULL,}; -  		tsk_advance_rx_queue(sk); -		__tipc_sendstream(new_sock, &m, 0);  	} else {  		__skb_dequeue(&sk->sk_receive_queue);  		__skb_queue_head(&new_sk->sk_receive_queue, buf);  		skb_set_owner_r(buf, new_sk);  	} +	__tipc_sendstream(new_sock, &m, 0);  	release_sock(new_sk);  exit:  	release_sock(sk); | 
