tipc: purge deferred updates from dead nodes
If a peer node becomes unavailable, in addition to removing the nametable entries from this node we also need to purge all deferred updates associated with this node. Signed-off-by: Erik Hugne <erik.hugne@gmail.com> Signed-off-by: Jon Maloy <jon.maloy@ericsson.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
541726abe7
commit
ddb1d33969
|
@ -224,12 +224,31 @@ static void tipc_publ_purge(struct net *net, struct publication *publ, u32 addr)
|
|||
kfree_rcu(p, rcu);
|
||||
}
|
||||
|
||||
/**
|
||||
* tipc_dist_queue_purge - remove deferred updates from a node that went down
|
||||
*/
|
||||
static void tipc_dist_queue_purge(struct net *net, u32 addr)
|
||||
{
|
||||
struct tipc_net *tn = net_generic(net, tipc_net_id);
|
||||
struct distr_queue_item *e, *tmp;
|
||||
|
||||
spin_lock_bh(&tn->nametbl_lock);
|
||||
list_for_each_entry_safe(e, tmp, &tn->dist_queue, next) {
|
||||
if (e->node != addr)
|
||||
continue;
|
||||
list_del(&e->next);
|
||||
kfree(e);
|
||||
}
|
||||
spin_unlock_bh(&tn->nametbl_lock);
|
||||
}
|
||||
|
||||
void tipc_publ_notify(struct net *net, struct list_head *nsub_list, u32 addr)
|
||||
{
|
||||
struct publication *publ, *tmp;
|
||||
|
||||
list_for_each_entry_safe(publ, tmp, nsub_list, nodesub_list)
|
||||
tipc_publ_purge(net, publ, addr);
|
||||
tipc_dist_queue_purge(net, addr);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Reference in New Issue