chiark / gitweb /
core: add support to run transient units in arbitrary slices
authorLennart Poettering <lennart@poettering.net>
Mon, 1 Jul 2013 01:02:42 +0000 (03:02 +0200)
committerLennart Poettering <lennart@poettering.net>
Mon, 1 Jul 2013 01:02:42 +0000 (03:02 +0200)
src/core/dbus-unit.c
src/run/run.c

index 6273e4627432e4d8cdba832583de3c4736b2c04b..ad6d5a603885694ab13c0f9829438c60167e0fd0 100644 (file)
@@ -790,6 +790,25 @@ static int bus_unit_set_transient_property(
                         return r;
 
                 return 1;
+
+        } else if (streq(name, "Slice") && unit_get_cgroup_context(u)) {
+                const char *s;
+                Unit *slice;
+
+                if (dbus_message_iter_get_arg_type(i) != DBUS_TYPE_STRING)
+                        return -EINVAL;
+
+                dbus_message_iter_get_basic(i, &s);
+
+                r = manager_load_unit(u->manager, s, NULL, error, &slice);
+                if (r < 0)
+                        return r;
+
+                if (slice->type != UNIT_SLICE)
+                        return -EINVAL;
+
+                unit_ref_set(&u->slice, slice);
+                return 1;
         }
 
         return 0;
index 98c3af058f620e75f28ecb71b5c9d7d321f943ce..e5a62d9e35a278f437100374b0400078599f2f32 100644 (file)
@@ -33,6 +33,7 @@ static bool arg_scope = false;
 static bool arg_user = false;
 static const char *arg_unit = NULL;
 static const char *arg_description = NULL;
+static const char *arg_slice = NULL;
 
 static int help(void) {
 
@@ -43,7 +44,8 @@ static int help(void) {
                "     --user             Run as user unit\n"
                "     --scope            Run this as scope rather than service\n"
                "     --unit=UNIT        Run under the specified unit name\n"
-               "     --description=TEXT Description for unit\n",
+               "     --description=TEXT Description for unit\n"
+               "     --slice=SLICE      Run in the specified slice\n",
                program_invocation_short_name);
 
         return 0;
@@ -56,7 +58,8 @@ static int parse_argv(int argc, char *argv[]) {
                 ARG_USER,
                 ARG_SCOPE,
                 ARG_UNIT,
-                ARG_DESCRIPTION
+                ARG_DESCRIPTION,
+                ARG_SLICE
         };
 
         static const struct option options[] = {
@@ -66,6 +69,7 @@ static int parse_argv(int argc, char *argv[]) {
                 { "scope",       no_argument,       NULL, ARG_SCOPE       },
                 { "unit",        required_argument, NULL, ARG_UNIT        },
                 { "description", required_argument, NULL, ARG_DESCRIPTION },
+                { "slice",       required_argument, NULL, ARG_SLICE       },
                 { NULL,          0,                 NULL, 0               },
         };
 
@@ -103,6 +107,10 @@ static int parse_argv(int argc, char *argv[]) {
                         arg_description = optarg;
                         break;
 
+                case ARG_SLICE:
+                        arg_slice = optarg;
+                        break;
+
                 case '?':
                         return -EINVAL;
 
@@ -147,6 +155,18 @@ static int message_start_transient_unit_new(sd_bus *bus, const char *name, sd_bu
         if (r < 0)
                 return r;
 
+        if (!isempty(arg_slice)) {
+                _cleanup_free_ char *slice;
+
+                slice = unit_name_mangle_with_suffix(arg_slice, ".slice");
+                if (!slice)
+                        return -ENOMEM;
+
+                r = sd_bus_message_append(m, "(sv)", "Slice", "s", slice);
+                if (r < 0)
+                        return r;
+        }
+
         *ret = m;
         m = NULL;