From mboxrd@z Thu Jan 1 00:00:00 1970 From: Veaceslav Falico Subject: [PATCH net-next 02/26] net: add RCU variant to search for netdev_adjacent link Date: Mon, 9 Sep 2013 22:16:20 +0200 Message-ID: <1378757804-3159-3-git-send-email-vfalico@redhat.com> References: <1378757804-3159-1-git-send-email-vfalico@redhat.com> Cc: jiri@resnulli.us, Veaceslav Falico , "David S. Miller" , Eric Dumazet , Alexander Duyck , Cong Wang To: netdev@vger.kernel.org Return-path: Received: from mx1.redhat.com ([209.132.183.28]:55001 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755526Ab3IIUQd (ORCPT ); Mon, 9 Sep 2013 16:16:33 -0400 In-Reply-To: <1378757804-3159-1-git-send-email-vfalico@redhat.com> Sender: netdev-owner@vger.kernel.org List-ID: Currently we have only the RTNL flavour, however we can traverse it while holding only RCU, so add the RCU search. Add only one function that will be used further, other functions can be added easily afterwards, if anyone would need them. CC: "David S. Miller" CC: Eric Dumazet CC: Jiri Pirko CC: Alexander Duyck CC: Cong Wang Signed-off-by: Veaceslav Falico --- net/core/dev.c | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/net/core/dev.c b/net/core/dev.c index 8832711..749ec0b 100644 --- a/net/core/dev.c +++ b/net/core/dev.c @@ -4380,6 +4380,33 @@ struct netdev_adjacent { struct rcu_head rcu; }; +static struct netdev_adjacent *__netdev_find_adj_rcu(struct net_device *dev, + struct net_device *adj_dev, + bool upper, bool neighbour) +{ + struct netdev_adjacent *adj; + struct list_head *adj_list; + + if (neighbour) + adj_list = upper ? &dev->adj_list.upper : + &dev->adj_list.lower; + else + adj_list = upper ? &dev->all_adj_list.upper : + &dev->all_adj_list.lower; + + list_for_each_entry_rcu(adj, adj_list, list) { + if (adj->dev == adj_dev) + return adj; + } + return NULL; +} + +static struct netdev_adjacent *__netdev_lower_find_rcu(struct net_device *dev, + struct net_device *ldev) +{ + return __netdev_find_adj_rcu(dev, ldev, false, true); +} + static struct netdev_adjacent *__netdev_find_adj(struct net_device *dev, struct net_device *adj_dev, bool upper, bool neighbour) -- 1.8.4