diff options
| author | Christian Marangi <[email protected]> | 2023-04-19 21:07:39 +0000 |
|---|---|---|
| committer | Lee Jones <[email protected]> | 2023-05-25 11:07:34 +0000 |
| commit | cee4bd16c3195a701be683f7da9e88c6e11acb73 (patch) | |
| tree | 4a366d139bf96c1e6d77d3a91b994112157f499d /drivers/leds/trigger/ledtrig-netdev.c | |
| parent | Linux 6.4-rc1 (diff) | |
| download | kernel-cee4bd16c3195a701be683f7da9e88c6e11acb73.tar.gz kernel-cee4bd16c3195a701be683f7da9e88c6e11acb73.zip | |
leds: trigger: netdev: Recheck NETDEV_LED_MODE_LINKUP on dev rename
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: [email protected] # v5.5+
Signed-off-by: Christian Marangi <[email protected]>
Reviewed-by: Andrew Lunn <[email protected]>
Signed-off-by: Lee Jones <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Diffstat (limited to 'drivers/leds/trigger/ledtrig-netdev.c')
| -rw-r--r-- | drivers/leds/trigger/ledtrig-netdev.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/leds/trigger/ledtrig-netdev.c b/drivers/leds/trigger/ledtrig-netdev.c index d5e774d83021..f4d670ec30bc 100644 --- a/drivers/leds/trigger/ledtrig-netdev.c +++ b/drivers/leds/trigger/ledtrig-netdev.c @@ -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); |
