aboutsummaryrefslogtreecommitdiffstats
path: root/net/tipc/node.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/tipc/node.c')
-rw-r--r--net/tipc/node.c37
1 files changed, 18 insertions, 19 deletions
diff --git a/net/tipc/node.c b/net/tipc/node.c
index c47cc69eb575..58e189bf5c96 100644
--- a/net/tipc/node.c
+++ b/net/tipc/node.c
@@ -62,9 +62,9 @@ u32 tipc_own_tag = 0;
62 62
63struct tipc_node *tipc_node_create(u32 addr) 63struct tipc_node *tipc_node_create(u32 addr)
64{ 64{
65 struct cluster *c_ptr;
66 struct tipc_node *n_ptr; 65 struct tipc_node *n_ptr;
67 struct tipc_node **curr_node; 66 struct tipc_node **curr_node;
67 u32 n_num;
68 68
69 spin_lock_bh(&node_create_lock); 69 spin_lock_bh(&node_create_lock);
70 70
@@ -84,21 +84,14 @@ struct tipc_node *tipc_node_create(u32 addr)
84 return NULL; 84 return NULL;
85 } 85 }
86 86
87 c_ptr = tipc_cltr_find(addr);
88 if (!c_ptr) {
89 c_ptr = tipc_cltr_create(addr);
90 }
91 if (!c_ptr) {
92 spin_unlock_bh(&node_create_lock);
93 kfree(n_ptr);
94 return NULL;
95 }
96
97 n_ptr->addr = addr; 87 n_ptr->addr = addr;
98 spin_lock_init(&n_ptr->lock); 88 spin_lock_init(&n_ptr->lock);
99 INIT_LIST_HEAD(&n_ptr->nsub); 89 INIT_LIST_HEAD(&n_ptr->nsub);
100 n_ptr->owner = c_ptr; 90
101 tipc_cltr_attach_node(c_ptr, n_ptr); 91 n_num = tipc_node(addr);
92 tipc_net.nodes[n_num] = n_ptr;
93 if (n_num > tipc_net.highest_node)
94 tipc_net.highest_node = n_num;
102 95
103 /* Insert node into ordered list */ 96 /* Insert node into ordered list */
104 for (curr_node = &tipc_nodes; *curr_node; 97 for (curr_node = &tipc_nodes; *curr_node;
@@ -115,11 +108,19 @@ struct tipc_node *tipc_node_create(u32 addr)
115 108
116void tipc_node_delete(struct tipc_node *n_ptr) 109void tipc_node_delete(struct tipc_node *n_ptr)
117{ 110{
111 u32 n_num;
112
118 if (!n_ptr) 113 if (!n_ptr)
119 return; 114 return;
120 115
121 dbg("node %x deleted\n", n_ptr->addr); 116 dbg("node %x deleted\n", n_ptr->addr);
117 n_num = tipc_node(n_ptr->addr);
118 tipc_net.nodes[n_num] = NULL;
122 kfree(n_ptr); 119 kfree(n_ptr);
120
121 while (!tipc_net.nodes[tipc_net.highest_node])
122 if (--tipc_net.highest_node == 0)
123 break;
123} 124}
124 125
125 126
@@ -324,7 +325,7 @@ static void node_established_contact(struct tipc_node *n_ptr)
324 n_ptr->bclink.acked = tipc_bclink_get_last_sent(); 325 n_ptr->bclink.acked = tipc_bclink_get_last_sent();
325 326
326 if (n_ptr->bclink.supported) { 327 if (n_ptr->bclink.supported) {
327 tipc_nmap_add(&tipc_cltr_bcast_nodes, n_ptr->addr); 328 tipc_nmap_add(&tipc_bcast_nmap, n_ptr->addr);
328 if (n_ptr->addr < tipc_own_addr) 329 if (n_ptr->addr < tipc_own_addr)
329 tipc_own_tag++; 330 tipc_own_tag++;
330 } 331 }
@@ -361,13 +362,11 @@ static void node_lost_contact(struct tipc_node *n_ptr)
361 buf_discard(n_ptr->bclink.defragm); 362 buf_discard(n_ptr->bclink.defragm);
362 n_ptr->bclink.defragm = NULL; 363 n_ptr->bclink.defragm = NULL;
363 } 364 }
364 if (in_own_cluster(n_ptr->addr) && n_ptr->bclink.supported) {
365 tipc_bclink_acknowledge(n_ptr, mod(n_ptr->bclink.acked + 10000));
366 }
367 365
368 /* Update routing tables */
369 if (n_ptr->bclink.supported) { 366 if (n_ptr->bclink.supported) {
370 tipc_nmap_remove(&tipc_cltr_bcast_nodes, n_ptr->addr); 367 tipc_bclink_acknowledge(n_ptr,
368 mod(n_ptr->bclink.acked + 10000));
369 tipc_nmap_remove(&tipc_bcast_nmap, n_ptr->addr);
371 if (n_ptr->addr < tipc_own_addr) 370 if (n_ptr->addr < tipc_own_addr)
372 tipc_own_tag--; 371 tipc_own_tag--;
373 } 372 }