diff options
Diffstat (limited to 'net/batman-adv/routing.c')
-rw-r--r-- | net/batman-adv/routing.c | 40 |
1 files changed, 13 insertions, 27 deletions
diff --git a/net/batman-adv/routing.c b/net/batman-adv/routing.c index b54bf6ec637e..fc4c12a049da 100644 --- a/net/batman-adv/routing.c +++ b/net/batman-adv/routing.c | |||
@@ -39,9 +39,8 @@ void slide_own_bcast_window(struct batman_if *batman_if) | |||
39 | { | 39 | { |
40 | struct bat_priv *bat_priv = netdev_priv(batman_if->soft_iface); | 40 | struct bat_priv *bat_priv = netdev_priv(batman_if->soft_iface); |
41 | struct hashtable_t *hash = bat_priv->orig_hash; | 41 | struct hashtable_t *hash = bat_priv->orig_hash; |
42 | struct hlist_node *walk; | 42 | struct hlist_node *node; |
43 | struct hlist_head *head; | 43 | struct hlist_head *head; |
44 | struct element_t *bucket; | ||
45 | struct orig_node *orig_node; | 44 | struct orig_node *orig_node; |
46 | unsigned long *word; | 45 | unsigned long *word; |
47 | int i; | 46 | int i; |
@@ -53,8 +52,7 @@ void slide_own_bcast_window(struct batman_if *batman_if) | |||
53 | head = &hash->table[i]; | 52 | head = &hash->table[i]; |
54 | 53 | ||
55 | rcu_read_lock(); | 54 | rcu_read_lock(); |
56 | hlist_for_each_entry_rcu(bucket, walk, head, hlist) { | 55 | hlist_for_each_entry_rcu(orig_node, node, head, hash_entry) { |
57 | orig_node = bucket->data; | ||
58 | spin_lock_bh(&orig_node->ogm_cnt_lock); | 56 | spin_lock_bh(&orig_node->ogm_cnt_lock); |
59 | word_index = batman_if->if_num * NUM_WORDS; | 57 | word_index = batman_if->if_num * NUM_WORDS; |
60 | word = &(orig_node->bcast_own[word_index]); | 58 | word = &(orig_node->bcast_own[word_index]); |
@@ -908,14 +906,11 @@ static int recv_my_icmp_packet(struct bat_priv *bat_priv, | |||
908 | /* get routing information */ | 906 | /* get routing information */ |
909 | spin_lock_bh(&bat_priv->orig_hash_lock); | 907 | spin_lock_bh(&bat_priv->orig_hash_lock); |
910 | rcu_read_lock(); | 908 | rcu_read_lock(); |
911 | orig_node = ((struct orig_node *)hash_find(bat_priv->orig_hash, | 909 | orig_node = orig_hash_find(bat_priv, icmp_packet->orig); |
912 | compare_orig, choose_orig, | ||
913 | icmp_packet->orig)); | ||
914 | 910 | ||
915 | if (!orig_node) | 911 | if (!orig_node) |
916 | goto unlock; | 912 | goto unlock; |
917 | 913 | ||
918 | kref_get(&orig_node->refcount); | ||
919 | neigh_node = orig_node->router; | 914 | neigh_node = orig_node->router; |
920 | 915 | ||
921 | if (!neigh_node) | 916 | if (!neigh_node) |
@@ -987,14 +982,11 @@ static int recv_icmp_ttl_exceeded(struct bat_priv *bat_priv, | |||
987 | /* get routing information */ | 982 | /* get routing information */ |
988 | spin_lock_bh(&bat_priv->orig_hash_lock); | 983 | spin_lock_bh(&bat_priv->orig_hash_lock); |
989 | rcu_read_lock(); | 984 | rcu_read_lock(); |
990 | orig_node = ((struct orig_node *) | 985 | orig_node = orig_hash_find(bat_priv, icmp_packet->orig); |
991 | hash_find(bat_priv->orig_hash, compare_orig, choose_orig, | ||
992 | icmp_packet->orig)); | ||
993 | 986 | ||
994 | if (!orig_node) | 987 | if (!orig_node) |
995 | goto unlock; | 988 | goto unlock; |
996 | 989 | ||
997 | kref_get(&orig_node->refcount); | ||
998 | neigh_node = orig_node->router; | 990 | neigh_node = orig_node->router; |
999 | 991 | ||
1000 | if (!neigh_node) | 992 | if (!neigh_node) |
@@ -1098,13 +1090,11 @@ int recv_icmp_packet(struct sk_buff *skb, struct batman_if *recv_if) | |||
1098 | /* get routing information */ | 1090 | /* get routing information */ |
1099 | spin_lock_bh(&bat_priv->orig_hash_lock); | 1091 | spin_lock_bh(&bat_priv->orig_hash_lock); |
1100 | rcu_read_lock(); | 1092 | rcu_read_lock(); |
1101 | orig_node = ((struct orig_node *) | 1093 | orig_node = orig_hash_find(bat_priv, icmp_packet->dst); |
1102 | hash_find(bat_priv->orig_hash, compare_orig, choose_orig, | 1094 | |
1103 | icmp_packet->dst)); | ||
1104 | if (!orig_node) | 1095 | if (!orig_node) |
1105 | goto unlock; | 1096 | goto unlock; |
1106 | 1097 | ||
1107 | kref_get(&orig_node->refcount); | ||
1108 | neigh_node = orig_node->router; | 1098 | neigh_node = orig_node->router; |
1109 | 1099 | ||
1110 | if (!neigh_node) | 1100 | if (!neigh_node) |
@@ -1194,11 +1184,12 @@ struct neigh_node *find_router(struct bat_priv *bat_priv, | |||
1194 | if (compare_eth(router_orig->primary_addr, router_orig->orig)) { | 1184 | if (compare_eth(router_orig->primary_addr, router_orig->orig)) { |
1195 | primary_orig_node = router_orig; | 1185 | primary_orig_node = router_orig; |
1196 | } else { | 1186 | } else { |
1197 | primary_orig_node = hash_find(bat_priv->orig_hash, compare_orig, | 1187 | primary_orig_node = orig_hash_find(bat_priv, |
1198 | choose_orig, | 1188 | router_orig->primary_addr); |
1199 | router_orig->primary_addr); | ||
1200 | if (!primary_orig_node) | 1189 | if (!primary_orig_node) |
1201 | goto return_router; | 1190 | goto return_router; |
1191 | |||
1192 | kref_put(&primary_orig_node->refcount, orig_node_free_ref); | ||
1202 | } | 1193 | } |
1203 | 1194 | ||
1204 | /* with less than 2 candidates, we can't do any | 1195 | /* with less than 2 candidates, we can't do any |
@@ -1344,13 +1335,11 @@ int route_unicast_packet(struct sk_buff *skb, struct batman_if *recv_if, | |||
1344 | /* get routing information */ | 1335 | /* get routing information */ |
1345 | spin_lock_bh(&bat_priv->orig_hash_lock); | 1336 | spin_lock_bh(&bat_priv->orig_hash_lock); |
1346 | rcu_read_lock(); | 1337 | rcu_read_lock(); |
1347 | orig_node = ((struct orig_node *) | 1338 | orig_node = orig_hash_find(bat_priv, unicast_packet->dest); |
1348 | hash_find(bat_priv->orig_hash, compare_orig, choose_orig, | 1339 | |
1349 | unicast_packet->dest)); | ||
1350 | if (!orig_node) | 1340 | if (!orig_node) |
1351 | goto unlock; | 1341 | goto unlock; |
1352 | 1342 | ||
1353 | kref_get(&orig_node->refcount); | ||
1354 | rcu_read_unlock(); | 1343 | rcu_read_unlock(); |
1355 | 1344 | ||
1356 | /* find_router() increases neigh_nodes refcount if found. */ | 1345 | /* find_router() increases neigh_nodes refcount if found. */ |
@@ -1508,14 +1497,11 @@ int recv_bcast_packet(struct sk_buff *skb, struct batman_if *recv_if) | |||
1508 | 1497 | ||
1509 | spin_lock_bh(&bat_priv->orig_hash_lock); | 1498 | spin_lock_bh(&bat_priv->orig_hash_lock); |
1510 | rcu_read_lock(); | 1499 | rcu_read_lock(); |
1511 | orig_node = ((struct orig_node *) | 1500 | orig_node = orig_hash_find(bat_priv, bcast_packet->orig); |
1512 | hash_find(bat_priv->orig_hash, compare_orig, choose_orig, | ||
1513 | bcast_packet->orig)); | ||
1514 | 1501 | ||
1515 | if (!orig_node) | 1502 | if (!orig_node) |
1516 | goto rcu_unlock; | 1503 | goto rcu_unlock; |
1517 | 1504 | ||
1518 | kref_get(&orig_node->refcount); | ||
1519 | rcu_read_unlock(); | 1505 | rcu_read_unlock(); |
1520 | 1506 | ||
1521 | spin_lock_bh(&orig_node->bcast_seqno_lock); | 1507 | spin_lock_bh(&orig_node->bcast_seqno_lock); |