From: Lennart Poettering Date: Fri, 23 Sep 2011 15:09:49 +0000 (+0200) Subject: condition: optionally test against type of virtualization (vm vs. container) X-Git-Tag: v36~4 X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=8095200d05ad28e84a3480f94f061783150db81e;p=systemd condition: optionally test against type of virtualization (vm vs. container) --- diff --git a/man/systemd.unit.xml b/man/systemd.unit.xml index 9066e66c..bf8de322 100644 --- a/man/systemd.unit.xml +++ b/man/systemd.unit.xml @@ -707,8 +707,8 @@ is similar to ConditionPathExists= but verifies whether a certain path - exists and is a - symbolic link. ConditionPathIsMountPoint= + exists and is a symbolic + link. ConditionPathIsMountPoint= is similar to ConditionPathExists= but verifies whether a certain path @@ -746,13 +746,19 @@ whether it is a specific implementation. Takes either boolean value to check if being executed in - any virtual environment or one of + any virtualized environment, or one of + vm and + container to test against + a specific type of virtualization + solution, or one of qemu, kvm, vmware, microsoft, oracle, xen, + bochs, + chroot, openvz, lxc, systemd-nspawn, diff --git a/src/condition.c b/src/condition.c index 1438ea85..e9786567 100644 --- a/src/condition.c +++ b/src/condition.c @@ -30,6 +30,7 @@ #include "util.h" #include "condition.h" +#include "virt.h" Condition* condition_new(ConditionType type, const char *parameter, bool trigger, bool negate) { Condition *c; @@ -118,25 +119,35 @@ static bool test_kernel_command_line(const char *parameter) { } static bool test_virtualization(const char *parameter) { - int r, b; + int b; + Virtualization v; const char *id; assert(parameter); - r = detect_virtualization(&id); - if (r < 0) { - log_warning("Failed to detect virtualization, ignoring: %s", strerror(-r)); + v = detect_virtualization(&id); + if (v < 0) { + log_warning("Failed to detect virtualization, ignoring: %s", strerror(-v)); return false; } + /* First, compare with yes/no */ b = parse_boolean(parameter); - if (r > 0 && b > 0) + if (v > 0 && b > 0) + return true; + + if (v == 0 && b == 0) + return true; + + /* Then, compare categorization */ + if (v == VIRTUALIZATION_VM && streq(parameter, "vm")) return true; - if (r == 0 && b == 0) + if (v == VIRTUALIZATION_CONTAINER && streq(parameter, "container")) return true; + /* Finally compare id */ return streq(parameter, id); }