From: Lennart Poettering Date: Sat, 10 Apr 2010 02:46:52 +0000 (+0200) Subject: unit: make cgroup controller/path specification more flexible X-Git-Tag: v1~580 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=013b87c09199926434583e8bb54ac6cb4b835eb5;hp=8e471ccd1583371cab19a6263b8952b37d069b07 unit: make cgroup controller/path specification more flexible --- diff --git a/unit.c b/unit.c index 6406015b4..a8058500d 100644 --- a/unit.c +++ b/unit.c @@ -1316,55 +1316,72 @@ int unit_add_cgroup(Unit *u, CGroupBonding *b) { return 0; } +static char *default_cgroup_path(Unit *u) { + char *p; + + assert(u); + + if (asprintf(&p, "%s/%s", u->meta.manager->cgroup_hierarchy, unit_id(u)) < 0) + return NULL; + + return p; +} + int unit_add_cgroup_from_text(Unit *u, const char *name) { size_t n; - const char *p; - char *controller; - CGroupBonding *b; + char *controller = NULL, *path = NULL; + CGroupBonding *b = NULL; int r; assert(u); assert(name); /* Detect controller name */ - n = strcspn(name, ":/"); + n = strcspn(name, ":"); - /* Only controller name, no path? No path? */ - if (name[n] == 0) - return -EINVAL; + if (name[n] == 0 || + (name[n] == ':' && name[n+1] == 0)) { - if (n > 0) { - if (name[n] != ':') - return -EINVAL; + /* Only controller name, no path? */ - p = name+n+1; - } else - p = name; + if (!(path = default_cgroup_path(u))) + return -ENOMEM; - /* Insist in absolute paths */ - if (p[0] != '/') - return -EINVAL; + } else { + const char *p; - if (!(controller = strndup(name, n))) - return -ENOMEM; + /* Controller name, and path. */ + p = name+n+1; - if (cgroup_bonding_find_list(u->meta.cgroup_bondings, controller)) { - free(controller); - return -EEXIST; + if (!path_is_absolute(p)) + return -EINVAL; + + if (!(path = strdup(p))) + return -ENOMEM; } - if (!(b = new0(CGroupBonding, 1))) { - free(controller); - return -ENOMEM; + if (n > 0) + controller = strndup(name, n); + else + controller = strdup(u->meta.manager->cgroup_controller); + + if (!controller) { + r = -ENOMEM; + goto fail; } - b->controller = controller; + if (cgroup_bonding_find_list(u->meta.cgroup_bondings, controller)) { + r = -EEXIST; + goto fail; + } - if (!(b->path = strdup(p))) { + if (!(b = new0(CGroupBonding, 1))) { r = -ENOMEM; goto fail; } + b->controller = controller; + b->path = path; b->only_us = false; b->clean_up = false; @@ -1374,8 +1391,8 @@ int unit_add_cgroup_from_text(Unit *u, const char *name) { return 0; fail: - free(b->path); - free(b->controller); + free(path); + free(controller); free(b); return r; @@ -1398,7 +1415,7 @@ int unit_add_default_cgroup(Unit *u) { if (!(b->controller = strdup(u->meta.manager->cgroup_controller))) goto fail; - if (asprintf(&b->path, "%s/%s", u->meta.manager->cgroup_hierarchy, unit_id(u)) < 0) + if (!(b->path = default_cgroup_path(u))) goto fail; b->clean_up = true;