Commit 65d53afd authored by Jakub Kicinski's avatar Jakub Kicinski

Merge branch 'net-adopt-netdev_lockdep_set_classes'

Eric Dumazet says:

====================
net: adopt netdev_lockdep_set_classes()

Instead of waiting for syzbot to discover lockdep false positives,
make sure we use netdev_lockdep_set_classes() a bit more.
====================

Link: https://lore.kernel.org/r/20240212140700.2795436-1-edumazet@google.comSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parents 88c9d07b 0bef5120
...@@ -71,6 +71,7 @@ static int dummy_dev_init(struct net_device *dev) ...@@ -71,6 +71,7 @@ static int dummy_dev_init(struct net_device *dev)
if (!dev->lstats) if (!dev->lstats)
return -ENOMEM; return -ENOMEM;
netdev_lockdep_set_classes(dev);
return 0; return 0;
} }
......
...@@ -335,6 +335,7 @@ static int geneve_init(struct net_device *dev) ...@@ -335,6 +335,7 @@ static int geneve_init(struct net_device *dev)
gro_cells_destroy(&geneve->gro_cells); gro_cells_destroy(&geneve->gro_cells);
return err; return err;
} }
netdev_lockdep_set_classes(dev);
return 0; return 0;
} }
......
...@@ -144,6 +144,7 @@ static int loopback_dev_init(struct net_device *dev) ...@@ -144,6 +144,7 @@ static int loopback_dev_init(struct net_device *dev)
dev->lstats = netdev_alloc_pcpu_stats(struct pcpu_lstats); dev->lstats = netdev_alloc_pcpu_stats(struct pcpu_lstats);
if (!dev->lstats) if (!dev->lstats)
return -ENOMEM; return -ENOMEM;
netdev_lockdep_set_classes(dev);
return 0; return 0;
} }
......
...@@ -1499,6 +1499,7 @@ static void veth_free_queues(struct net_device *dev) ...@@ -1499,6 +1499,7 @@ static void veth_free_queues(struct net_device *dev)
static int veth_dev_init(struct net_device *dev) static int veth_dev_init(struct net_device *dev)
{ {
netdev_lockdep_set_classes(dev);
return veth_alloc_queues(dev); return veth_alloc_queues(dev);
} }
......
...@@ -2855,6 +2855,7 @@ static int vxlan_init(struct net_device *dev) ...@@ -2855,6 +2855,7 @@ static int vxlan_init(struct net_device *dev)
if (err) if (err)
goto err_gro_cells_destroy; goto err_gro_cells_destroy;
netdev_lockdep_set_classes(dev);
return 0; return 0;
err_gro_cells_destroy: err_gro_cells_destroy:
......
...@@ -504,28 +504,6 @@ static void vlan_dev_set_rx_mode(struct net_device *vlan_dev) ...@@ -504,28 +504,6 @@ static void vlan_dev_set_rx_mode(struct net_device *vlan_dev)
dev_uc_sync(vlan_dev_priv(vlan_dev)->real_dev, vlan_dev); dev_uc_sync(vlan_dev_priv(vlan_dev)->real_dev, vlan_dev);
} }
/*
* vlan network devices have devices nesting below it, and are a special
* "super class" of normal network devices; split their locks off into a
* separate class since they always nest.
*/
static struct lock_class_key vlan_netdev_xmit_lock_key;
static struct lock_class_key vlan_netdev_addr_lock_key;
static void vlan_dev_set_lockdep_one(struct net_device *dev,
struct netdev_queue *txq,
void *unused)
{
lockdep_set_class(&txq->_xmit_lock, &vlan_netdev_xmit_lock_key);
}
static void vlan_dev_set_lockdep_class(struct net_device *dev)
{
lockdep_set_class(&dev->addr_list_lock,
&vlan_netdev_addr_lock_key);
netdev_for_each_tx_queue(dev, vlan_dev_set_lockdep_one, NULL);
}
static __be16 vlan_parse_protocol(const struct sk_buff *skb) static __be16 vlan_parse_protocol(const struct sk_buff *skb)
{ {
struct vlan_ethhdr *veth = (struct vlan_ethhdr *)(skb->data); struct vlan_ethhdr *veth = (struct vlan_ethhdr *)(skb->data);
...@@ -627,7 +605,7 @@ static int vlan_dev_init(struct net_device *dev) ...@@ -627,7 +605,7 @@ static int vlan_dev_init(struct net_device *dev)
SET_NETDEV_DEVTYPE(dev, &vlan_type); SET_NETDEV_DEVTYPE(dev, &vlan_type);
vlan_dev_set_lockdep_class(dev); netdev_lockdep_set_classes(dev);
vlan->vlan_pcpu_stats = netdev_alloc_pcpu_stats(struct vlan_pcpu_stats); vlan->vlan_pcpu_stats = netdev_alloc_pcpu_stats(struct vlan_pcpu_stats);
if (!vlan->vlan_pcpu_stats) if (!vlan->vlan_pcpu_stats)
......
...@@ -108,13 +108,6 @@ netdev_tx_t br_dev_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -108,13 +108,6 @@ netdev_tx_t br_dev_xmit(struct sk_buff *skb, struct net_device *dev)
return NETDEV_TX_OK; return NETDEV_TX_OK;
} }
static struct lock_class_key bridge_netdev_addr_lock_key;
static void br_set_lockdep_class(struct net_device *dev)
{
lockdep_set_class(&dev->addr_list_lock, &bridge_netdev_addr_lock_key);
}
static int br_dev_init(struct net_device *dev) static int br_dev_init(struct net_device *dev)
{ {
struct net_bridge *br = netdev_priv(dev); struct net_bridge *br = netdev_priv(dev);
...@@ -153,7 +146,7 @@ static int br_dev_init(struct net_device *dev) ...@@ -153,7 +146,7 @@ static int br_dev_init(struct net_device *dev)
br_fdb_hash_fini(br); br_fdb_hash_fini(br);
} }
br_set_lockdep_class(dev); netdev_lockdep_set_classes(dev);
return err; return err;
} }
......
...@@ -1269,6 +1269,7 @@ int ip_tunnel_init(struct net_device *dev) ...@@ -1269,6 +1269,7 @@ int ip_tunnel_init(struct net_device *dev)
if (tunnel->collect_md) if (tunnel->collect_md)
netif_keep_dst(dev); netif_keep_dst(dev);
netdev_lockdep_set_classes(dev);
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(ip_tunnel_init); EXPORT_SYMBOL_GPL(ip_tunnel_init);
......
...@@ -1511,6 +1511,7 @@ static int ip6gre_tunnel_init_common(struct net_device *dev) ...@@ -1511,6 +1511,7 @@ static int ip6gre_tunnel_init_common(struct net_device *dev)
ip6gre_tnl_init_features(dev); ip6gre_tnl_init_features(dev);
netdev_hold(dev, &tunnel->dev_tracker, GFP_KERNEL); netdev_hold(dev, &tunnel->dev_tracker, GFP_KERNEL);
netdev_lockdep_set_classes(dev);
return 0; return 0;
cleanup_dst_cache_init: cleanup_dst_cache_init:
...@@ -1901,6 +1902,7 @@ static int ip6erspan_tap_init(struct net_device *dev) ...@@ -1901,6 +1902,7 @@ static int ip6erspan_tap_init(struct net_device *dev)
ip6erspan_tnl_link_config(tunnel, 1); ip6erspan_tnl_link_config(tunnel, 1);
netdev_hold(dev, &tunnel->dev_tracker, GFP_KERNEL); netdev_hold(dev, &tunnel->dev_tracker, GFP_KERNEL);
netdev_lockdep_set_classes(dev);
return 0; return 0;
cleanup_dst_cache_init: cleanup_dst_cache_init:
......
...@@ -1898,6 +1898,7 @@ ip6_tnl_dev_init_gen(struct net_device *dev) ...@@ -1898,6 +1898,7 @@ ip6_tnl_dev_init_gen(struct net_device *dev)
dev->max_mtu = IP6_MAX_MTU - dev->hard_header_len; dev->max_mtu = IP6_MAX_MTU - dev->hard_header_len;
netdev_hold(dev, &t->dev_tracker, GFP_KERNEL); netdev_hold(dev, &t->dev_tracker, GFP_KERNEL);
netdev_lockdep_set_classes(dev);
return 0; return 0;
destroy_dst: destroy_dst:
......
...@@ -935,6 +935,7 @@ static inline int vti6_dev_init_gen(struct net_device *dev) ...@@ -935,6 +935,7 @@ static inline int vti6_dev_init_gen(struct net_device *dev)
if (!dev->tstats) if (!dev->tstats)
return -ENOMEM; return -ENOMEM;
netdev_hold(dev, &t->dev_tracker, GFP_KERNEL); netdev_hold(dev, &t->dev_tracker, GFP_KERNEL);
netdev_lockdep_set_classes(dev);
return 0; return 0;
} }
......
...@@ -1460,6 +1460,7 @@ static int ipip6_tunnel_init(struct net_device *dev) ...@@ -1460,6 +1460,7 @@ static int ipip6_tunnel_init(struct net_device *dev)
return err; return err;
} }
netdev_hold(dev, &tunnel->dev_tracker, GFP_KERNEL); netdev_hold(dev, &tunnel->dev_tracker, GFP_KERNEL);
netdev_lockdep_set_classes(dev);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment