aboutsummaryrefslogtreecommitdiffstats
path: root/net/batman-adv
diff options
context:
space:
mode:
Diffstat (limited to 'net/batman-adv')
-rw-r--r--net/batman-adv/main.h11
-rw-r--r--net/batman-adv/translation-table.c32
2 files changed, 23 insertions, 20 deletions
diff --git a/net/batman-adv/main.h b/net/batman-adv/main.h
index 86354e06eb48..f9c659b3f3a9 100644
--- a/net/batman-adv/main.h
+++ b/net/batman-adv/main.h
@@ -202,6 +202,17 @@ static inline int compare_eth(const void *data1, const void *data2)
202 return (memcmp(data1, data2, ETH_ALEN) == 0 ? 1 : 0); 202 return (memcmp(data1, data2, ETH_ALEN) == 0 ? 1 : 0);
203} 203}
204 204
205/**
206 * has_timed_out - compares current time (jiffies) and timestamp + timeout
207 * @timestamp: base value to compare with (in jiffies)
208 * @timeout: added to base value before comparing (in milliseconds)
209 *
210 * Returns true if current time is after timestamp + timeout
211 */
212static inline bool has_timed_out(unsigned long timestamp, unsigned int timeout)
213{
214 return time_is_before_jiffies(timestamp + msecs_to_jiffies(timeout));
215}
205 216
206#define atomic_dec_not_zero(v) atomic_add_unless((v), -1, 0) 217#define atomic_dec_not_zero(v) atomic_add_unless((v), -1, 0)
207 218
diff --git a/net/batman-adv/translation-table.c b/net/batman-adv/translation-table.c
index bc518fca0b69..a84e80409f9b 100644
--- a/net/batman-adv/translation-table.c
+++ b/net/batman-adv/translation-table.c
@@ -108,14 +108,6 @@ static struct tt_global_entry *tt_global_hash_find(struct bat_priv *bat_priv,
108 108
109} 109}
110 110
111static bool is_out_of_time(unsigned long starting_time, unsigned long timeout)
112{
113 unsigned long deadline;
114 deadline = starting_time + msecs_to_jiffies(timeout);
115
116 return time_after(jiffies, deadline);
117}
118
119static void tt_local_entry_free_ref(struct tt_local_entry *tt_local_entry) 111static void tt_local_entry_free_ref(struct tt_local_entry *tt_local_entry)
120{ 112{
121 if (atomic_dec_and_test(&tt_local_entry->common.refcount)) 113 if (atomic_dec_and_test(&tt_local_entry->common.refcount))
@@ -420,8 +412,8 @@ static void tt_local_purge(struct bat_priv *bat_priv)
420 if (tt_local_entry->common.flags & TT_CLIENT_PENDING) 412 if (tt_local_entry->common.flags & TT_CLIENT_PENDING)
421 continue; 413 continue;
422 414
423 if (!is_out_of_time(tt_local_entry->last_seen, 415 if (!has_timed_out(tt_local_entry->last_seen,
424 TT_LOCAL_TIMEOUT * 1000)) 416 TT_LOCAL_TIMEOUT * 1000))
425 continue; 417 continue;
426 418
427 tt_local_set_pending(bat_priv, tt_local_entry, 419 tt_local_set_pending(bat_priv, tt_local_entry,
@@ -758,8 +750,8 @@ static void tt_global_roam_purge(struct bat_priv *bat_priv)
758 common); 750 common);
759 if (!(tt_global_entry->common.flags & TT_CLIENT_ROAM)) 751 if (!(tt_global_entry->common.flags & TT_CLIENT_ROAM))
760 continue; 752 continue;
761 if (!is_out_of_time(tt_global_entry->roam_at, 753 if (!has_timed_out(tt_global_entry->roam_at,
762 TT_CLIENT_ROAM_TIMEOUT * 1000)) 754 TT_CLIENT_ROAM_TIMEOUT * 1000))
763 continue; 755 continue;
764 756
765 bat_dbg(DBG_TT, bat_priv, "Deleting global " 757 bat_dbg(DBG_TT, bat_priv, "Deleting global "
@@ -978,8 +970,8 @@ static void tt_req_purge(struct bat_priv *bat_priv)
978 970
979 spin_lock_bh(&bat_priv->tt_req_list_lock); 971 spin_lock_bh(&bat_priv->tt_req_list_lock);
980 list_for_each_entry_safe(node, safe, &bat_priv->tt_req_list, list) { 972 list_for_each_entry_safe(node, safe, &bat_priv->tt_req_list, list) {
981 if (is_out_of_time(node->issued_at, 973 if (has_timed_out(node->issued_at,
982 TT_REQUEST_TIMEOUT * 1000)) { 974 TT_REQUEST_TIMEOUT * 1000)) {
983 list_del(&node->list); 975 list_del(&node->list);
984 kfree(node); 976 kfree(node);
985 } 977 }
@@ -997,8 +989,8 @@ static struct tt_req_node *new_tt_req_node(struct bat_priv *bat_priv,
997 spin_lock_bh(&bat_priv->tt_req_list_lock); 989 spin_lock_bh(&bat_priv->tt_req_list_lock);
998 list_for_each_entry(tt_req_node_tmp, &bat_priv->tt_req_list, list) { 990 list_for_each_entry(tt_req_node_tmp, &bat_priv->tt_req_list, list) {
999 if (compare_eth(tt_req_node_tmp, orig_node) && 991 if (compare_eth(tt_req_node_tmp, orig_node) &&
1000 !is_out_of_time(tt_req_node_tmp->issued_at, 992 !has_timed_out(tt_req_node_tmp->issued_at,
1001 TT_REQUEST_TIMEOUT * 1000)) 993 TT_REQUEST_TIMEOUT * 1000))
1002 goto unlock; 994 goto unlock;
1003 } 995 }
1004 996
@@ -1591,8 +1583,8 @@ static void tt_roam_purge(struct bat_priv *bat_priv)
1591 1583
1592 spin_lock_bh(&bat_priv->tt_roam_list_lock); 1584 spin_lock_bh(&bat_priv->tt_roam_list_lock);
1593 list_for_each_entry_safe(node, safe, &bat_priv->tt_roam_list, list) { 1585 list_for_each_entry_safe(node, safe, &bat_priv->tt_roam_list, list) {
1594 if (!is_out_of_time(node->first_time, 1586 if (!has_timed_out(node->first_time,
1595 ROAMING_MAX_TIME * 1000)) 1587 ROAMING_MAX_TIME * 1000))
1596 continue; 1588 continue;
1597 1589
1598 list_del(&node->list); 1590 list_del(&node->list);
@@ -1619,8 +1611,8 @@ static bool tt_check_roam_count(struct bat_priv *bat_priv,
1619 if (!compare_eth(tt_roam_node->addr, client)) 1611 if (!compare_eth(tt_roam_node->addr, client))
1620 continue; 1612 continue;
1621 1613
1622 if (is_out_of_time(tt_roam_node->first_time, 1614 if (has_timed_out(tt_roam_node->first_time,
1623 ROAMING_MAX_TIME * 1000)) 1615 ROAMING_MAX_TIME * 1000))
1624 continue; 1616 continue;
1625 1617
1626 if (!atomic_dec_not_zero(&tt_roam_node->counter)) 1618 if (!atomic_dec_not_zero(&tt_roam_node->counter))