unit: don't add automatic dependencies on device units if they aren't supported
authorLennart Poettering <lennart@poettering.net>
Fri, 24 Apr 2015 15:28:06 +0000 (17:28 +0200)
committerLennart Poettering <lennart@poettering.net>
Fri, 24 Apr 2015 15:28:31 +0000 (17:28 +0200)
http://lists.freedesktop.org/archives/systemd-devel/2015-April/031187.html

src/core/unit.c

index 2b356e2..730492e 100644 (file)
@@ -2846,14 +2846,18 @@ int unit_add_node_link(Unit *u, const char *what, bool wants) {
 
         assert(u);
 
-        if (!what)
-                return 0;
-
         /* Adds in links to the device node that this unit is based on */
+        if (isempty(what))
+                return 0;
 
         if (!is_device_path(what))
                 return 0;
 
+        /* When device units aren't supported (such as in a
+         * container), don't create dependencies on them. */
+        if (unit_vtable[UNIT_DEVICE]->supported && !unit_vtable[UNIT_DEVICE]->supported(u->manager))
+                return 0;
+
         e = unit_name_from_path(what, ".device");
         if (!e)
                 return -ENOMEM;