]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
udev: do not try to rename interface if it is already up
authorYu Watanabe <watanabe.yu+github@gmail.com>
Sun, 24 Oct 2021 11:43:34 +0000 (20:43 +0900)
committerLuca Boccassi <luca.boccassi@gmail.com>
Mon, 25 Oct 2021 19:18:53 +0000 (20:18 +0100)
See dev_change_name() in kernel's net/core/dev.c.

Fixes #21105.

src/udev/udev-event.c

index 0d98b0788747245932131a32c305a99d6cb5a720..1c666d01231632fcc029299a424e3eca9c2ea028 100644 (file)
@@ -827,6 +827,7 @@ int udev_event_spawn(UdevEvent *event,
 static int rename_netif(UdevEvent *event) {
         sd_device *dev = event->dev;
         const char *oldname;
+        unsigned flags;
         int ifindex, r;
 
         if (!event->name)
@@ -854,6 +855,16 @@ static int rename_netif(UdevEvent *event) {
                 return 0;
         }
 
+        r = rtnl_get_link_info(&event->rtnl, ifindex, NULL, &flags);
+        if (r < 0)
+                return log_device_warning_errno(dev, r, "Failed to get link flags: %m");
+
+        if (FLAGS_SET(flags, IFF_UP)) {
+                log_device_info(dev, "Network interface '%s' is already up, refusing to rename to '%s'.",
+                                oldname, event->name);
+                return 0;
+        }
+
         /* Set ID_RENAMING boolean property here, and drop it in the corresponding move uevent later. */
         r = device_add_property(dev, "ID_RENAMING", "1");
         if (r < 0)