From: Benjamin Poirier Date: Thu, 18 Feb 2016 00:20:33 +0000 (-0800) Subject: ipv6: Annotate change of locking mechanism for np->opt X-Git-Tag: MMI-PSA29.97-13-9~8298^2~228 X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=e550785c30f639b3cc6ca70c489a6463ff298453;p=GitHub%2FMotorolaMobilityLLC%2Fkernel-slsi.git ipv6: Annotate change of locking mechanism for np->opt follows up commit 45f6fad84cc3 ("ipv6: add complete rcu protection around np->opt") which added mixed rcu/refcount protection to np->opt. Given the current implementation of rcu_pointer_handoff(), this has no effect at runtime. Signed-off-by: Benjamin Poirier Acked-by: Eric Dumazet Signed-off-by: David S. Miller --- diff --git a/include/net/ipv6.h b/include/net/ipv6.h index 6570f379aba2..f3c9857c645d 100644 --- a/include/net/ipv6.h +++ b/include/net/ipv6.h @@ -259,8 +259,12 @@ static inline struct ipv6_txoptions *txopt_get(const struct ipv6_pinfo *np) rcu_read_lock(); opt = rcu_dereference(np->opt); - if (opt && !atomic_inc_not_zero(&opt->refcnt)) - opt = NULL; + if (opt) { + if (!atomic_inc_not_zero(&opt->refcnt)) + opt = NULL; + else + opt = rcu_pointer_handoff(opt); + } rcu_read_unlock(); return opt; }