]> git.pld-linux.org Git - packages/systemd.git/blob - net-rename-revert.patch
up to 246.4
[packages/systemd.git] / net-rename-revert.patch
1 This is updated patch that fixes interface renaming broken by
2 systemd commit 97595710b77aa162ca5e20da57d0a1ed7355eaad.
3
4 udev: network device renaming - immediately give up if the target name isn't available
5
6 We want to to keep supporting systems with 75-persistent-net-generator.rules
7 generated names. Re-apply this old hack to make the renaming less likely to fail.
8
9 --- systemd-stable-246.1/src/udev/udev-event.c.orig     2020-08-07 17:09:53.000000000 +0200
10 +++ systemd-stable-246.1/src/udev/udev-event.c  2020-08-15 11:04:10.263428290 +0200
11 @@ -820,6 +820,8 @@
12          sd_device *dev = event->dev;
13          const char *oldname;
14          int ifindex, r;
15 +        char name[IFNAMSIZ];
16 +        int loop;
17  
18          if (!event->name)
19                  return 0; /* No new name is requested. */
20 @@ -861,6 +863,32 @@
21                  return log_device_debug_errno(event->dev_db_clone, r, "Failed to update database under /run/udev/data/: %m");
22  
23          r = rtnl_set_link_name(&event->rtnl, ifindex, event->name);
24 +        /* keep trying if the destination interface name already exists */
25 +        if (r != -EEXIST)
26 +                goto out;
27 +
28 +        /* free our own name, another process may wait for us */
29 +        snprintf(name, IFNAMSIZ, "rename%u", ifindex);
30 +        r = rtnl_set_link_name(&event->rtnl, ifindex, name);
31 +        if (r < 0)
32 +                goto out;
33 +
34 +        /* log temporary name */
35 +        log_device_debug(dev, "Network interface %i is renamed from '%s' to '%s'", ifindex, oldname, event->name);
36 +
37 +        /* wait a maximum of 90 seconds for our target to become available */
38 +        strscpy(name, IFNAMSIZ, event->name);
39 +        loop = 90 * 20;
40 +        while (loop--) {
41 +                const struct timespec duration = { 0, 1000 * 1000 * 1000 / 20 };
42 +
43 +                nanosleep(&duration, NULL);
44 +
45 +                r = rtnl_set_link_name(&event->rtnl, ifindex, name);
46 +                if (r != -EEXIST)
47 +                        goto out;
48 +        }
49 +out:
50          if (r < 0)
51                  return log_device_error_errno(dev, r, "Failed to rename network interface %i from '%s' to '%s': %m",
52                                                ifindex, oldname, event->name);
This page took 0.091253 seconds and 3 git commands to generate.