diff --git a/man/systemd.unit.xml b/man/systemd.unit.xml index 9066e66cc2..bf8de322dd 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 1438ea85a0..e978656772 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 (r == 0 && b == 0) + if (v == 0 && b == 0) return true; + /* Then, compare categorization */ + if (v == VIRTUALIZATION_VM && streq(parameter, "vm")) + return true; + + if (v == VIRTUALIZATION_CONTAINER && streq(parameter, "container")) + return true; + + /* Finally compare id */ return streq(parameter, id); }