rcu_read_lock() is enough here, as inet6_ifa_finish_destroy()
uses kfree_rcu()

Signed-off-by: Eric Dumazet <eduma...@google.com>
---
 net/ipv6/addrconf.c | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)

diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c
index 
d70d98122053652b4f4420786de8788c6c9385ff..a6cf37b7e34c461e204153078be92c3e297b3ec2
 100644
--- a/net/ipv6/addrconf.c
+++ b/net/ipv6/addrconf.c
@@ -1844,7 +1844,7 @@ int ipv6_chk_addr_and_flags(struct net *net, const struct 
in6_addr *addr,
        struct inet6_ifaddr *ifp;
        u32 ifp_flags;
 
-       rcu_read_lock_bh();
+       rcu_read_lock();
        hlist_for_each_entry_rcu(ifp, &inet6_addr_lst[hash], addr_lst) {
                if (!net_eq(dev_net(ifp->idev->dev), net))
                        continue;
@@ -1858,12 +1858,12 @@ int ipv6_chk_addr_and_flags(struct net *net, const 
struct in6_addr *addr,
                    !(ifp_flags&banned_flags) &&
                    (!dev || ifp->idev->dev == dev ||
                     !(ifp->scope&(IFA_LINK|IFA_HOST) || strict))) {
-                       rcu_read_unlock_bh();
+                       rcu_read_unlock();
                        return 1;
                }
        }
 
-       rcu_read_unlock_bh();
+       rcu_read_unlock();
        return 0;
 }
 EXPORT_SYMBOL(ipv6_chk_addr_and_flags);
-- 
2.15.0.rc0.271.g36b669edcc-goog

Reply via email to