[7/7] batman-adv: Increase orig_node refcount before releasing rcu read lock
Commit Message
When unicast_send_skb() is increasing the orig_node's refcount another
thread might have been freeing this orig_node already. We need to
increase the refcount in the rcu read lock protected area to avoid that.
Signed-off-by: Linus Lüssing <linus.luessing@ascom.ch>
---
gateway_client.c | 3 +++
unicast.c | 1 -
2 files changed, 3 insertions(+), 1 deletions(-)
Comments
On Friday 04 February 2011 16:21:36 Linus Lüssing wrote:
> When unicast_send_skb() is increasing the orig_node's refcount another
> thread might have been freeing this orig_node already. We need to
> increase the refcount in the rcu read lock protected area to avoid that.
Applied in revision 1943.
Thanks,
Marek
@@ -55,6 +55,9 @@ void *gw_get_selected(struct bat_priv *bat_priv)
}
orig_node = curr_gateway_tmp->orig_node;
+ if (orig_node)
+ kref_get(&orig_node->refcount);
+
rcu_read_unlock();
return orig_node;
@@ -298,7 +298,6 @@ int unicast_send_skb(struct sk_buff *skb, struct bat_priv *bat_priv)
if (!orig_node)
goto trans_search;
- kref_get(&orig_node->refcount);
goto find_router;
} else {
rcu_read_lock();