diff options
Diffstat (limited to 'net/tipc')
| -rw-r--r-- | net/tipc/node.c | 12 | ||||
| -rw-r--r-- | net/tipc/socket.c | 2 | 
2 files changed, 10 insertions, 4 deletions
| diff --git a/net/tipc/node.c b/net/tipc/node.c index 49ddc484c4fe..5e000fde8067 100644 --- a/net/tipc/node.c +++ b/net/tipc/node.c @@ -1179,8 +1179,9 @@ void tipc_node_check_dest(struct net *net, u32 addr,  	bool addr_match = false;  	bool sign_match = false;  	bool link_up = false; +	bool link_is_reset = false;  	bool accept_addr = false; -	bool reset = true; +	bool reset = false;  	char *if_name;  	unsigned long intv;  	u16 session; @@ -1200,14 +1201,14 @@ void tipc_node_check_dest(struct net *net, u32 addr,  	/* Prepare to validate requesting node's signature and media address */  	l = le->link;  	link_up = l && tipc_link_is_up(l); +	link_is_reset = l && tipc_link_is_reset(l);  	addr_match = l && !memcmp(&le->maddr, maddr, sizeof(*maddr));  	sign_match = (signature == n->signature);  	/* These three flags give us eight permutations: */  	if (sign_match && addr_match && link_up) { -		/* All is fine. Do nothing. */ -		reset = false; +		/* All is fine. Ignore requests. */  		/* Peer node is not a container/local namespace */  		if (!n->peer_hash_mix)  			n->peer_hash_mix = hash_mixes; @@ -1232,6 +1233,7 @@ void tipc_node_check_dest(struct net *net, u32 addr,  		 */  		accept_addr = true;  		*respond = true; +		reset = true;  	} else if (!sign_match && addr_match && link_up) {  		/* Peer node rebooted. Two possibilities:  		 *  - Delayed re-discovery; this link endpoint has already @@ -1263,6 +1265,7 @@ void tipc_node_check_dest(struct net *net, u32 addr,  		n->signature = signature;  		accept_addr = true;  		*respond = true; +		reset = true;  	}  	if (!accept_addr) @@ -1291,6 +1294,7 @@ void tipc_node_check_dest(struct net *net, u32 addr,  		tipc_link_fsm_evt(l, LINK_RESET_EVT);  		if (n->state == NODE_FAILINGOVER)  			tipc_link_fsm_evt(l, LINK_FAILOVER_BEGIN_EVT); +		link_is_reset = tipc_link_is_reset(l);  		le->link = l;  		n->link_cnt++;  		tipc_node_calculate_timer(n, l); @@ -1303,7 +1307,7 @@ void tipc_node_check_dest(struct net *net, u32 addr,  	memcpy(&le->maddr, maddr, sizeof(*maddr));  exit:  	tipc_node_write_unlock(n); -	if (reset && l && !tipc_link_is_reset(l)) +	if (reset && !link_is_reset)  		tipc_node_link_down(n, b->identity, false);  	tipc_node_put(n);  } diff --git a/net/tipc/socket.c b/net/tipc/socket.c index b35c8701876a..a38733f2197a 100644 --- a/net/tipc/socket.c +++ b/net/tipc/socket.c @@ -2614,6 +2614,7 @@ static int tipc_connect(struct socket *sock, struct sockaddr *dest,  		/* Send a 'SYN-' to destination */  		m.msg_name = dest;  		m.msg_namelen = destlen; +		iov_iter_kvec(&m.msg_iter, ITER_SOURCE, NULL, 0, 0);  		/* If connect is in non-blocking case, set MSG_DONTWAIT to  		 * indicate send_msg() is never blocked. @@ -2776,6 +2777,7 @@ static int tipc_accept(struct socket *sock, struct socket *new_sock, int flags,  		__skb_queue_head(&new_sk->sk_receive_queue, buf);  		skb_set_owner_r(buf, new_sk);  	} +	iov_iter_kvec(&m.msg_iter, ITER_SOURCE, NULL, 0, 0);  	__tipc_sendstream(new_sock, &m, 0);  	release_sock(new_sk);  exit: | 
