Commit 697f2531 authored by Antonio Quartulli's avatar Antonio Quartulli Committed by Sven Eckelmann

batman-adv: generalise tt_local_reset_flags()

The tt_local_reset_flags() is actually used for one use case only. It is not
generalised enough to be used indifferent situations. This patch make it general
enough in order to let other code use it whenever a flag set is requested over
the whole hash table (passed as parameter). The function is now called
tt_set_flags()
Signed-off-by: default avatarAntonio Quartulli <ordex@autistici.org>
Signed-off-by: default avatarSven Eckelmann <sven@narfation.org>
parent 48100bac
...@@ -1695,19 +1695,19 @@ void tt_free(struct bat_priv *bat_priv) ...@@ -1695,19 +1695,19 @@ void tt_free(struct bat_priv *bat_priv)
kfree(bat_priv->tt_buff); kfree(bat_priv->tt_buff);
} }
/* This function will reset the specified flags from all the entries in /* This function will enable or disable the specified flags for all the entries
* the given hash table and will increment num_local_tt for each involved * in the given hash table and returns the number of modified entries */
* entry */ static uint16_t tt_set_flags(struct hashtable_t *hash, uint16_t flags,
static void tt_local_reset_flags(struct bat_priv *bat_priv, uint16_t flags) bool enable)
{ {
uint32_t i; uint32_t i;
struct hashtable_t *hash = bat_priv->tt_local_hash; uint16_t changed_num = 0;
struct hlist_head *head; struct hlist_head *head;
struct hlist_node *node; struct hlist_node *node;
struct tt_common_entry *tt_common_entry; struct tt_common_entry *tt_common_entry;
if (!hash) if (!hash)
return; goto out;
for (i = 0; i < hash->size; i++) { for (i = 0; i < hash->size; i++) {
head = &hash->table[i]; head = &hash->table[i];
...@@ -1715,14 +1715,21 @@ static void tt_local_reset_flags(struct bat_priv *bat_priv, uint16_t flags) ...@@ -1715,14 +1715,21 @@ static void tt_local_reset_flags(struct bat_priv *bat_priv, uint16_t flags)
rcu_read_lock(); rcu_read_lock();
hlist_for_each_entry_rcu(tt_common_entry, node, hlist_for_each_entry_rcu(tt_common_entry, node,
head, hash_entry) { head, hash_entry) {
if (enable) {
if ((tt_common_entry->flags & flags) == flags)
continue;
tt_common_entry->flags |= flags;
} else {
if (!(tt_common_entry->flags & flags)) if (!(tt_common_entry->flags & flags))
continue; continue;
tt_common_entry->flags &= ~flags; tt_common_entry->flags &= ~flags;
atomic_inc(&bat_priv->num_local_tt); }
changed_num++;
} }
rcu_read_unlock(); rcu_read_unlock();
} }
out:
return changed_num;
} }
/* Purge out all the tt local entries marked with TT_CLIENT_PENDING */ /* Purge out all the tt local entries marked with TT_CLIENT_PENDING */
...@@ -1766,7 +1773,11 @@ static void tt_local_purge_pending_clients(struct bat_priv *bat_priv) ...@@ -1766,7 +1773,11 @@ static void tt_local_purge_pending_clients(struct bat_priv *bat_priv)
void tt_commit_changes(struct bat_priv *bat_priv) void tt_commit_changes(struct bat_priv *bat_priv)
{ {
tt_local_reset_flags(bat_priv, TT_CLIENT_NEW); uint16_t changed_num = tt_set_flags(bat_priv->tt_local_hash,
TT_CLIENT_NEW, false);
/* all the reset entries have now to be effectively counted as local
* entries */
atomic_add(changed_num, &bat_priv->num_local_tt);
tt_local_purge_pending_clients(bat_priv); tt_local_purge_pending_clients(bat_priv);
/* Increment the TTVN only once per OGM interval */ /* Increment the TTVN only once per OGM interval */
......
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