]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
tipc: Prevent broadcast link stalling in dual LAN environments
authorAllan Stephens <allan.stephens@windriver.com>
Tue, 25 Oct 2011 16:19:05 +0000 (12:19 -0400)
committerPaul Gortmaker <paul.gortmaker@windriver.com>
Mon, 6 Feb 2012 21:59:16 +0000 (16:59 -0500)
Ensure that sequence number information about incoming broadcast link
messages is initialized only by the activation of the first link to a
given cluster node.  Previously, a race condition allowed reset and/or
activation messages for a second link to re-initialize this sequence
number information with obsolete values. This could trigger TIPC to
request the retransmission of previously acknowledged broadcast link
messages from that node, resulting in broadcast link processing becoming
stalled if the node had already released one or more of those messages
and was unable to perform the required retransmission.

Thanks to Laser <gotolaser@gmail.com> for identifying this problem
and assisting in the development of this fix.

Signed-off-by: Allan Stephens <allan.stephens@windriver.com>
Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>
net/tipc/link.c

index bee316ce387cce3f8c7209f181ed1694b8ba8a1d..4ea6cad1174626781a0ef744c01ab91cef7c4bed 100644 (file)
@@ -2128,14 +2128,15 @@ static void link_recv_proto_msg(struct tipc_link *l_ptr, struct sk_buff *buf)
                }
                l_ptr->owner->bclink.supported = (max_pkt_info != 0);
 
+               /* Synchronize broadcast link info, if not done previously */
+
+               if (!tipc_node_is_up(l_ptr->owner))
+                       l_ptr->owner->bclink.last_in = msg_last_bcast(msg);
+
                link_state_event(l_ptr, msg_type(msg));
 
                l_ptr->peer_session = msg_session(msg);
                l_ptr->peer_bearer_id = msg_bearer_id(msg);
-
-               /* Synchronize broadcast sequence numbers */
-               if (!tipc_node_redundant_links(l_ptr->owner))
-                       l_ptr->owner->bclink.last_in = mod(msg_last_bcast(msg));
                break;
        case STATE_MSG: