leds: trigger: netdev: Recheck NETDEV_LED_MODE_LINKUP on dev rename
authorChristian Marangi <ansuelsmth@gmail.com>
Wed, 19 Apr 2023 21:07:39 +0000 (23:07 +0200)
committerLee Jones <lee@kernel.org>
Thu, 25 May 2023 11:07:34 +0000 (12:07 +0100)
Dev can be renamed also while up for supported device. We currently
wrongly clear the NETDEV_LED_MODE_LINKUP flag on NETDEV_CHANGENAME
event.

Fix this by rechecking if the carrier is ok on NETDEV_CHANGENAME and
correctly set the NETDEV_LED_MODE_LINKUP bit.

Fixes: 5f820ed52371 ("leds: trigger: netdev: fix handling on interface rename")
Cc: stable@vger.kernel.org # v5.5+
Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Signed-off-by: Lee Jones <lee@kernel.org>
Link: https://lore.kernel.org/r/20230419210743.3594-2-ansuelsmth@gmail.com
drivers/leds/trigger/ledtrig-netdev.c

index d5e774d..f4d670e 100644 (file)
@@ -318,6 +318,9 @@ static int netdev_trig_notify(struct notifier_block *nb,
        clear_bit(NETDEV_LED_MODE_LINKUP, &trigger_data->mode);
        switch (evt) {
        case NETDEV_CHANGENAME:
+               if (netif_carrier_ok(dev))
+                       set_bit(NETDEV_LED_MODE_LINKUP, &trigger_data->mode);
+               fallthrough;
        case NETDEV_REGISTER:
                if (trigger_data->net_dev)
                        dev_put(trigger_data->net_dev);