net: dsa: suppress device links to LAG DSA masters
authorVladimir Oltean <vladimir.oltean@nxp.com>
Sun, 11 Sep 2022 01:07:02 +0000 (04:07 +0300)
committerPaolo Abeni <pabeni@redhat.com>
Tue, 20 Sep 2022 08:32:36 +0000 (10:32 +0200)
These don't work (print a harmless error about the operation failing)
and make little sense to have anyway, because when a LAG DSA master goes
away, we will introduce logic to move our CPU port back to the first
physical DSA master. So suppress these device links in preparation for
adding support for LAG DSA masters.

Signed-off-by: Vladimir Oltean <vladimir.oltean@nxp.com>
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
net/dsa/master.c

index 99d773b..2176c14 100644 (file)
@@ -364,12 +364,14 @@ int dsa_master_setup(struct net_device *dev, struct dsa_port *cpu_dp)
        mtu = ETH_DATA_LEN + dsa_tag_protocol_overhead(tag_ops);
 
        /* The DSA master must use SET_NETDEV_DEV for this to work. */
-       consumer_link = device_link_add(ds->dev, dev->dev.parent,
-                                       DL_FLAG_AUTOREMOVE_CONSUMER);
-       if (!consumer_link)
-               netdev_err(dev,
-                          "Failed to create a device link to DSA switch %s\n",
-                          dev_name(ds->dev));
+       if (!netif_is_lag_master(dev)) {
+               consumer_link = device_link_add(ds->dev, dev->dev.parent,
+                                               DL_FLAG_AUTOREMOVE_CONSUMER);
+               if (!consumer_link)
+                       netdev_err(dev,
+                                  "Failed to create a device link to DSA switch %s\n",
+                                  dev_name(ds->dev));
+       }
 
        /* The switch driver may not implement ->port_change_mtu(), case in
         * which dsa_slave_change_mtu() will not update the master MTU either,