Commit 92018c7c authored by Jon Maloy's avatar Jon Maloy Committed by David S. Miller

tipc: fix correct setting of message type in second discoverer

The duplicate address discovery protocol is not safe against two
discoverers running in parallel. The one executing first after the
trial period is over will set the node address and change its own
message type to DSC_REQ_MSG. The one executing last may find that the
node address is already set, and never change message type, with the
result that its links may never be established.

In this commmit we ensure that the message type always is set correctly
after the trial period is over.

Fixes: 25b0b9c4 ("tipc: handle collisions of 32-bit node address hash values")
Signed-off-by: default avatarJon Maloy <jon.maloy@ericsson.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent e415577f
...@@ -287,7 +287,6 @@ static void tipc_disc_timeout(struct timer_list *t) ...@@ -287,7 +287,6 @@ static void tipc_disc_timeout(struct timer_list *t)
{ {
struct tipc_discoverer *d = from_timer(d, t, timer); struct tipc_discoverer *d = from_timer(d, t, timer);
struct tipc_net *tn = tipc_net(d->net); struct tipc_net *tn = tipc_net(d->net);
u32 self = tipc_own_addr(d->net);
struct tipc_media_addr maddr; struct tipc_media_addr maddr;
struct sk_buff *skb = NULL; struct sk_buff *skb = NULL;
struct net *net = d->net; struct net *net = d->net;
...@@ -301,12 +300,14 @@ static void tipc_disc_timeout(struct timer_list *t) ...@@ -301,12 +300,14 @@ static void tipc_disc_timeout(struct timer_list *t)
goto exit; goto exit;
} }
/* Did we just leave the address trial period ? */ /* Trial period over ? */
if (!self && !time_before(jiffies, tn->addr_trial_end)) { if (!time_before(jiffies, tn->addr_trial_end)) {
self = tn->trial_addr; /* Did we just leave it ? */
tipc_net_finalize(net, self); if (!tipc_own_addr(net))
msg_set_prevnode(buf_msg(d->skb), self); tipc_net_finalize(net, tn->trial_addr);
msg_set_type(buf_msg(d->skb), DSC_REQ_MSG); msg_set_type(buf_msg(d->skb), DSC_REQ_MSG);
msg_set_prevnode(buf_msg(d->skb), tipc_own_addr(net));
} }
/* Adjust timeout interval according to discovery phase */ /* Adjust timeout interval according to discovery phase */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment