With interfaces being kept track of as iflink private data, there is no
need for the global list anymore. batadv_hardif_get_by_netdev() can now
use netdev_master_upper_dev_get()+netdev_lower_dev_get_private() to find
the hardif corresponding to a netdev.

Signed-off-by: Matthias Schiffer <[email protected]>
---
 net/batman-adv/hard-interface.c | 26 ++++++++++----------------
 net/batman-adv/hard-interface.h |  2 +-
 net/batman-adv/main.c           |  5 -----
 net/batman-adv/main.h           |  1 -
 net/batman-adv/types.h          |  3 ---
 5 files changed, 11 insertions(+), 26 deletions(-)

diff --git a/net/batman-adv/hard-interface.c b/net/batman-adv/hard-interface.c
index 89e0e11250ca..5b46104dcf61 100644
--- a/net/batman-adv/hard-interface.c
+++ b/net/batman-adv/hard-interface.c
@@ -63,21 +63,19 @@ void batadv_hardif_release(struct kref *ref)
  * Return: batadv_hard_iface of net_dev (with increased refcnt), NULL on errors
  */
 struct batadv_hard_iface *
-batadv_hardif_get_by_netdev(const struct net_device *net_dev)
+batadv_hardif_get_by_netdev(struct net_device *net_dev)
 {
        struct batadv_hard_iface *hard_iface;
+       struct net_device *mesh_iface;
 
-       rcu_read_lock();
-       list_for_each_entry_rcu(hard_iface, &batadv_hardif_list, list) {
-               if (hard_iface->net_dev == net_dev &&
-                   kref_get_unless_zero(&hard_iface->refcount))
-                       goto out;
-       }
+       mesh_iface = netdev_master_upper_dev_get(net_dev);
+       if (!mesh_iface || !batadv_meshif_is_valid(mesh_iface))
+               return NULL;
 
-       hard_iface = NULL;
+       hard_iface = netdev_lower_dev_get_private(mesh_iface, net_dev);
+       if (!kref_get_unless_zero(&hard_iface->refcount))
+               return NULL;
 
-out:
-       rcu_read_unlock();
        return hard_iface;
 }
 
@@ -721,7 +719,6 @@ int batadv_hardif_enable_interface(struct net_device 
*net_dev,
        hard_iface->mesh_iface = NULL;
        hard_iface->if_status = BATADV_IF_INACTIVE;
 
-       INIT_LIST_HEAD(&hard_iface->list);
        INIT_HLIST_HEAD(&hard_iface->neigh_list);
 
        mutex_init(&hard_iface->bat_iv.ogm_buff_mutex);
@@ -738,8 +735,6 @@ int batadv_hardif_enable_interface(struct net_device 
*net_dev,
        batadv_v_hardif_init(hard_iface);
 
        kref_get(&hard_iface->refcount);
-       list_add_tail_rcu(&hard_iface->list, &batadv_hardif_list);
-       batadv_hardif_generation++;
 
        hardif_mtu = READ_ONCE(hard_iface->net_dev->mtu);
        required_mtu = READ_ONCE(mesh_iface->mtu) + max_header_len;
@@ -753,6 +748,7 @@ int batadv_hardif_enable_interface(struct net_device 
*net_dev,
        hard_iface->mesh_iface = mesh_iface;
        bat_priv = netdev_priv(hard_iface->mesh_iface);
 
+       batadv_hardif_generation++;
        ret = netdev_master_upper_dev_link(hard_iface->net_dev,
                                           mesh_iface, hard_iface, NULL, NULL);
        if (ret)
@@ -850,9 +846,6 @@ void batadv_hardif_disable_interface(struct 
batadv_hard_iface *hard_iface)
        if (hard_iface->if_status != BATADV_IF_INACTIVE)
                goto out;
 
-       list_del_rcu(&hard_iface->list);
-       batadv_hardif_generation++;
-
        batadv_info(hard_iface->mesh_iface, "Removing interface: %s\n",
                    hard_iface->net_dev->name);
        dev_remove_pack(&hard_iface->batman_adv_ptype);
@@ -876,6 +869,7 @@ void batadv_hardif_disable_interface(struct 
batadv_hard_iface *hard_iface)
        batadv_purge_outstanding_packets(bat_priv, hard_iface);
        netdev_put(hard_iface->mesh_iface, &hard_iface->meshif_dev_tracker);
 
+       batadv_hardif_generation++;
        netdev_upper_dev_unlink(hard_iface->net_dev, hard_iface->mesh_iface);
        batadv_hardif_recalc_extra_skbroom(hard_iface->mesh_iface);
 
diff --git a/net/batman-adv/hard-interface.h b/net/batman-adv/hard-interface.h
index ace7a0f6f3b6..6b210ebe45b3 100644
--- a/net/batman-adv/hard-interface.h
+++ b/net/batman-adv/hard-interface.h
@@ -66,7 +66,7 @@ struct net_device *batadv_get_real_netdev(struct net_device 
*net_device);
 bool batadv_is_cfg80211_hardif(struct batadv_hard_iface *hard_iface);
 bool batadv_is_wifi_hardif(struct batadv_hard_iface *hard_iface);
 struct batadv_hard_iface*
-batadv_hardif_get_by_netdev(const struct net_device *net_dev);
+batadv_hardif_get_by_netdev(struct net_device *net_dev);
 int batadv_hardif_enable_interface(struct net_device *net_dev,
                                   struct net_device *mesh_iface);
 void batadv_hardif_disable_interface(struct batadv_hard_iface *hard_iface);
diff --git a/net/batman-adv/main.c b/net/batman-adv/main.c
index f1a7233de1da..8e8ea93cf61d 100644
--- a/net/batman-adv/main.c
+++ b/net/batman-adv/main.c
@@ -61,10 +61,6 @@
 #include "tp_meter.h"
 #include "translation-table.h"
 
-/* List manipulations on hardif_list have to be rtnl_lock()'ed,
- * list traversals just rcu-locked
- */
-struct list_head batadv_hardif_list;
 unsigned int batadv_hardif_generation;
 static int (*batadv_rx_handler[256])(struct sk_buff *skb,
                                     struct batadv_hard_iface *recv_if);
@@ -97,7 +93,6 @@ static int __init batadv_init(void)
        if (ret < 0)
                return ret;
 
-       INIT_LIST_HEAD(&batadv_hardif_list);
        batadv_algo_init();
 
        batadv_recv_handler_init();
diff --git a/net/batman-adv/main.h b/net/batman-adv/main.h
index 692109be2210..debc55922fe1 100644
--- a/net/batman-adv/main.h
+++ b/net/batman-adv/main.h
@@ -232,7 +232,6 @@ static inline int batadv_print_vid(unsigned short vid)
                return -1;
 }
 
-extern struct list_head batadv_hardif_list;
 extern unsigned int batadv_hardif_generation;
 
 extern struct workqueue_struct *batadv_event_workqueue;
diff --git a/net/batman-adv/types.h b/net/batman-adv/types.h
index 0ca0fc072fc9..fc84c2a80020 100644
--- a/net/batman-adv/types.h
+++ b/net/batman-adv/types.h
@@ -166,9 +166,6 @@ enum batadv_hard_iface_wifi_flags {
  * struct batadv_hard_iface - network device known to batman-adv
  */
 struct batadv_hard_iface {
-       /** @list: list node for batadv_hardif_list */
-       struct list_head list;
-
        /** @if_status: status of the interface for batman-adv */
        char if_status;
 
-- 
2.49.0

Reply via email to