batman-adv: Convert batadv_orig_node 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:

committed by
Antonio Quartulli

parent
161a3be932
commit
7c12439115
@@ -118,7 +118,7 @@ batadv_gw_get_selected_orig(struct batadv_priv *bat_priv)
|
||||
if (!orig_node)
|
||||
goto unlock;
|
||||
|
||||
if (!atomic_inc_not_zero(&orig_node->refcount))
|
||||
if (!kref_get_unless_zero(&orig_node->refcount))
|
||||
orig_node = NULL;
|
||||
|
||||
unlock:
|
||||
@@ -441,7 +441,7 @@ static void batadv_gw_node_add(struct batadv_priv *bat_priv,
|
||||
if (gateway->bandwidth_down == 0)
|
||||
return;
|
||||
|
||||
if (!atomic_inc_not_zero(&orig_node->refcount))
|
||||
if (!kref_get_unless_zero(&orig_node->refcount))
|
||||
return;
|
||||
|
||||
gw_node = kzalloc(sizeof(*gw_node), GFP_ATOMIC);
|
||||
|
Reference in New Issue
Block a user