batman-adv: Convert batadv_bla_claim to kref
batman-adv uses a self-written reference implementation which is just based on atomic_t. This is less obvious when reading the code than kref and therefore increases the change that the reference counting will be missed. Signed-off-by: Sven Eckelmann <sven@narfation.org> Signed-off-by: Marek Lindner <mareklindner@neomailbox.ch> Signed-off-by: Antonio Quartulli <a@unstable.cc>
This commit is contained in:
parent
06e56ded86
commit
71b7e3d316
@ -174,8 +174,12 @@ batadv_backbone_gw_free_ref(struct batadv_bla_backbone_gw *backbone_gw)
|
|||||||
* grace period
|
* grace period
|
||||||
* @ref: kref pointer of the claim
|
* @ref: kref pointer of the claim
|
||||||
*/
|
*/
|
||||||
static void batadv_claim_release(struct batadv_bla_claim *claim)
|
static void batadv_claim_release(struct kref *ref)
|
||||||
{
|
{
|
||||||
|
struct batadv_bla_claim *claim;
|
||||||
|
|
||||||
|
claim = container_of(ref, struct batadv_bla_claim, refcount);
|
||||||
|
|
||||||
batadv_backbone_gw_free_ref(claim->backbone_gw);
|
batadv_backbone_gw_free_ref(claim->backbone_gw);
|
||||||
kfree_rcu(claim, rcu);
|
kfree_rcu(claim, rcu);
|
||||||
}
|
}
|
||||||
@ -187,8 +191,7 @@ static void batadv_claim_release(struct batadv_bla_claim *claim)
|
|||||||
*/
|
*/
|
||||||
static void batadv_claim_free_ref(struct batadv_bla_claim *claim)
|
static void batadv_claim_free_ref(struct batadv_bla_claim *claim)
|
||||||
{
|
{
|
||||||
if (atomic_dec_and_test(&claim->refcount))
|
kref_put(&claim->refcount, batadv_claim_release);
|
||||||
batadv_claim_release(claim);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -219,7 +222,7 @@ static struct batadv_bla_claim
|
|||||||
if (!batadv_compare_claim(&claim->hash_entry, data))
|
if (!batadv_compare_claim(&claim->hash_entry, data))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (!atomic_inc_not_zero(&claim->refcount))
|
if (!kref_get_unless_zero(&claim->refcount))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
claim_tmp = claim;
|
claim_tmp = claim;
|
||||||
@ -651,7 +654,8 @@ static void batadv_bla_add_claim(struct batadv_priv *bat_priv,
|
|||||||
claim->lasttime = jiffies;
|
claim->lasttime = jiffies;
|
||||||
claim->backbone_gw = backbone_gw;
|
claim->backbone_gw = backbone_gw;
|
||||||
|
|
||||||
atomic_set(&claim->refcount, 2);
|
kref_init(&claim->refcount);
|
||||||
|
kref_get(&claim->refcount);
|
||||||
batadv_dbg(BATADV_DBG_BLA, bat_priv,
|
batadv_dbg(BATADV_DBG_BLA, bat_priv,
|
||||||
"bla_add_claim(): adding new entry %pM, vid %d to hash ...\n",
|
"bla_add_claim(): adding new entry %pM, vid %d to hash ...\n",
|
||||||
mac, BATADV_PRINT_VID(vid));
|
mac, BATADV_PRINT_VID(vid));
|
||||||
|
@ -951,7 +951,7 @@ struct batadv_bla_claim {
|
|||||||
unsigned long lasttime;
|
unsigned long lasttime;
|
||||||
struct hlist_node hash_entry;
|
struct hlist_node hash_entry;
|
||||||
struct rcu_head rcu;
|
struct rcu_head rcu;
|
||||||
atomic_t refcount;
|
struct kref refcount;
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user