diff options
| author | Luke Shumaker <lukeshu@sbcglobal.net> | 2016-09-11 01:05:13 -0400 | 
|---|---|---|
| committer | Luke Shumaker <lukeshu@sbcglobal.net> | 2016-09-11 01:05:13 -0400 | 
| commit | 4ee12cf36c4af8d3ae4313735677c57f6f640596 (patch) | |
| tree | 02c10c478c44ea0bf1847926c2043b4548592ed0 /src/grp-initprogs/systemd-detect-virt | |
| parent | 7e9315c610d0bf290cbac06418e9f545a66f1435 (diff) | |
./tools/notsd-move
Diffstat (limited to 'src/grp-initprogs/systemd-detect-virt')
5 files changed, 501 insertions, 0 deletions
| diff --git a/src/grp-initprogs/systemd-detect-virt/Makefile b/src/grp-initprogs/systemd-detect-virt/Makefile new file mode 100644 index 0000000000..7b9b9f667b --- /dev/null +++ b/src/grp-initprogs/systemd-detect-virt/Makefile @@ -0,0 +1,36 @@ +#  -*- Mode: makefile; indent-tabs-mode: t -*- +# +#  This file is part of systemd. +# +#  Copyright 2010-2012 Lennart Poettering +#  Copyright 2010-2012 Kay Sievers +#  Copyright 2013 Zbigniew Jędrzejewski-Szmek +#  Copyright 2013 David Strauss +#  Copyright 2016 Luke Shumaker +# +#  systemd is free software; you can redistribute it and/or modify it +#  under the terms of the GNU Lesser General Public License as published by +#  the Free Software Foundation; either version 2.1 of the License, or +#  (at your option) any later version. +# +#  systemd is distributed in the hope that it will be useful, but +#  WITHOUT ANY WARRANTY; without even the implied warranty of +#  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +#  Lesser General Public License for more details. +# +#  You should have received a copy of the GNU Lesser General Public License +#  along with systemd; If not, see <http://www.gnu.org/licenses/>. +include $(dir $(lastword $(MAKEFILE_LIST)))/../../../config.mk +include $(topsrcdir)/build-aux/Makefile.head.mk + +bin_PROGRAMS += systemd-detect-virt +systemd_detect_virt_SOURCES = \ +	src/detect-virt/detect-virt.c + +systemd_detect_virt_LDADD = \ +	libshared.la + +INSTALL_EXEC_HOOKS += \ +	systemd-detect-virt-install-hook + +include $(topsrcdir)/build-aux/Makefile.tail.mk diff --git a/src/grp-initprogs/systemd-detect-virt/detect-virt.c b/src/grp-initprogs/systemd-detect-virt/detect-virt.c new file mode 100644 index 0000000000..06cdab5297 --- /dev/null +++ b/src/grp-initprogs/systemd-detect-virt/detect-virt.c @@ -0,0 +1,169 @@ +/*** +  This file is part of systemd. + +  Copyright 2010 Lennart Poettering + +  systemd is free software; you can redistribute it and/or modify it +  under the terms of the GNU Lesser General Public License as published by +  the Free Software Foundation; either version 2.1 of the License, or +  (at your option) any later version. + +  systemd is distributed in the hope that it will be useful, but +  WITHOUT ANY WARRANTY; without even the implied warranty of +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +  Lesser General Public License for more details. + +  You should have received a copy of the GNU Lesser General Public License +  along with systemd; If not, see <http://www.gnu.org/licenses/>. +***/ + +#include <errno.h> +#include <getopt.h> +#include <stdbool.h> +#include <stdlib.h> + +#include "basic/util.h" +#include "basic/virt.h" + +static bool arg_quiet = false; +static enum { +        ANY_VIRTUALIZATION, +        ONLY_VM, +        ONLY_CONTAINER, +        ONLY_CHROOT, +} arg_mode = ANY_VIRTUALIZATION; + +static void help(void) { +        printf("%s [OPTIONS...]\n\n" +               "Detect execution in a virtualized environment.\n\n" +               "  -h --help             Show this help\n" +               "     --version          Show package version\n" +               "  -c --container        Only detect whether we are run in a container\n" +               "  -v --vm               Only detect whether we are run in a VM\n" +               "  -r --chroot           Detect whether we are run in a chroot() environment\n" +               "  -q --quiet            Don't output anything, just set return value\n" +               , program_invocation_short_name); +} + +static int parse_argv(int argc, char *argv[]) { + +        enum { +                ARG_VERSION = 0x100 +        }; + +        static const struct option options[] = { +                { "help",      no_argument,       NULL, 'h'           }, +                { "version",   no_argument,       NULL, ARG_VERSION   }, +                { "container", no_argument,       NULL, 'c'           }, +                { "vm",        no_argument,       NULL, 'v'           }, +                { "chroot",    no_argument,       NULL, 'r'           }, +                { "quiet",     no_argument,       NULL, 'q'           }, +                {} +        }; + +        int c; + +        assert(argc >= 0); +        assert(argv); + +        while ((c = getopt_long(argc, argv, "hqcvr", options, NULL)) >= 0) + +                switch (c) { + +                case 'h': +                        help(); +                        return 0; + +                case ARG_VERSION: +                        return version(); + +                case 'q': +                        arg_quiet = true; +                        break; + +                case 'c': +                        arg_mode = ONLY_CONTAINER; +                        break; + +                case 'v': +                        arg_mode = ONLY_VM; +                        break; + +                case 'r': +                        arg_mode = ONLY_CHROOT; +                        break; + +                case '?': +                        return -EINVAL; + +                default: +                        assert_not_reached("Unhandled option"); +                } + +        if (optind < argc) { +                log_error("%s takes no arguments.", program_invocation_short_name); +                return -EINVAL; +        } + +        return 1; +} + +int main(int argc, char *argv[]) { +        int r; + +        /* This is mostly intended to be used for scripts which want +         * to detect whether we are being run in a virtualized +         * environment or not */ + +        log_parse_environment(); +        log_open(); + +        r = parse_argv(argc, argv); +        if (r <= 0) +                return r < 0 ? EXIT_FAILURE : EXIT_SUCCESS; + +        switch (arg_mode) { + +        case ONLY_VM: +                r = detect_vm(); +                if (r < 0) { +                        log_error_errno(r, "Failed to check for VM: %m"); +                        return EXIT_FAILURE; +                } + +                break; + +        case ONLY_CONTAINER: +                r = detect_container(); +                if (r < 0) { +                        log_error_errno(r, "Failed to check for container: %m"); +                        return EXIT_FAILURE; +                } + +                break; + +        case ONLY_CHROOT: +                r = running_in_chroot(); +                if (r < 0) { +                        log_error_errno(r, "Failed to check for chroot() environment: %m"); +                        return EXIT_FAILURE; +                } + +                return r ? EXIT_SUCCESS : EXIT_FAILURE; + +        case ANY_VIRTUALIZATION: +        default: +                r = detect_virtualization(); +                if (r < 0) { +                        log_error_errno(r, "Failed to check for virtualization: %m"); +                        return EXIT_FAILURE; +                } + +                break; +        } + +        if (!arg_quiet) +                puts(virtualization_to_string(r)); + +        return r != VIRTUALIZATION_NONE ? EXIT_SUCCESS : EXIT_FAILURE; +} diff --git a/src/grp-initprogs/systemd-detect-virt/systemd-detect-virt.completion.bash b/src/grp-initprogs/systemd-detect-virt/systemd-detect-virt.completion.bash new file mode 100644 index 0000000000..df06c29841 --- /dev/null +++ b/src/grp-initprogs/systemd-detect-virt/systemd-detect-virt.completion.bash @@ -0,0 +1,40 @@ +# systemd-detect-virt(1) completion             -*- shell-script -*- +# +# This file is part of systemd. +# +# Copyright 2014 Thomas H.P. Andersen +# +# systemd is free software; you can redistribute it and/or modify it +# under the terms of the GNU Lesser General Public License as published by +# the Free Software Foundation; either version 2.1 of the License, or +# (at your option) any later version. +# +# systemd is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public License +# along with systemd; If not, see <http://www.gnu.org/licenses/>. + +__contains_word() { +        local w word=$1; shift +        for w in "$@"; do +                [[ $w = "$word" ]] && return +        done +} + +_systemd_detect_virt() { +        local cur=${COMP_WORDS[COMP_CWORD]} prev=${COMP_WORDS[COMP_CWORD-1]} +        local i verb comps + +        local -A OPTS=( +               [STANDALONE]='-h --help --version -c --container -v --vm -q --quiet' +        ) + +        _init_completion || return + +        COMPREPLY=( $(compgen -W '${OPTS[*]}' -- "$cur") ) +} + +complete -F _systemd_detect_virt systemd-detect-virt diff --git a/src/grp-initprogs/systemd-detect-virt/systemd-detect-virt.completion.zsh b/src/grp-initprogs/systemd-detect-virt/systemd-detect-virt.completion.zsh new file mode 100644 index 0000000000..a0c7df727c --- /dev/null +++ b/src/grp-initprogs/systemd-detect-virt/systemd-detect-virt.completion.zsh @@ -0,0 +1,11 @@ +#compdef systemd-detect-virt + +local curcontext="$curcontext" state lstate line +_arguments \ +    {-h,--help}'[Show this help]' \ +    '--version[Show package version]' \ +    {-c,--container}'[Only detect whether we are run in a container]' \ +    {-v,--vm}'[Only detect whether we are run in a VM]' \ +    {-q,--quiet}"[Don't output anything, just set return value]" + +#vim: set ft=zsh sw=4 ts=4 et diff --git a/src/grp-initprogs/systemd-detect-virt/systemd-detect-virt.xml b/src/grp-initprogs/systemd-detect-virt/systemd-detect-virt.xml new file mode 100644 index 0000000000..2b7f4e69ab --- /dev/null +++ b/src/grp-initprogs/systemd-detect-virt/systemd-detect-virt.xml @@ -0,0 +1,245 @@ +<?xml version='1.0'?> <!--*-nxml-*--> +<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" +  "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"> + +<!-- +  This file is part of systemd. + +  Copyright 2010 Lennart Poettering + +  systemd is free software; you can redistribute it and/or modify it +  under the terms of the GNU Lesser General Public License as published by +  the Free Software Foundation; either version 2.1 of the License, or +  (at your option) any later version. + +  systemd is distributed in the hope that it will be useful, but +  WITHOUT ANY WARRANTY; without even the implied warranty of +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +  Lesser General Public License for more details. + +  You should have received a copy of the GNU Lesser General Public License +  along with systemd; If not, see <http://www.gnu.org/licenses/>. +--> + +<refentry id="systemd-detect-virt" +          xmlns:xi="http://www.w3.org/2001/XInclude"> + +  <refentryinfo> +    <title>systemd-detect-virt</title> +    <productname>systemd</productname> + +    <authorgroup> +      <author> +        <contrib>Developer</contrib> +        <firstname>Lennart</firstname> +        <surname>Poettering</surname> +        <email>lennart@poettering.net</email> +      </author> +    </authorgroup> +  </refentryinfo> + +  <refmeta> +    <refentrytitle>systemd-detect-virt</refentrytitle> +    <manvolnum>1</manvolnum> +  </refmeta> + +  <refnamediv> +    <refname>systemd-detect-virt</refname> +    <refpurpose>Detect execution in a virtualized environment</refpurpose> +  </refnamediv> + +  <refsynopsisdiv> +    <cmdsynopsis> +      <command>systemd-detect-virt <arg choice="opt" rep="repeat">OPTIONS</arg></command> +    </cmdsynopsis> +  </refsynopsisdiv> + +  <refsect1> +    <title>Description</title> + +    <para><command>systemd-detect-virt</command> detects execution in +    a virtualized environment. It identifies the virtualization +    technology and can distinguish full machine virtualization from +    container virtualization. <filename>systemd-detect-virt</filename> +    exits with a return value of 0 (success) if a virtualization +    technology is detected, and non-zero (error) otherwise. By default, +    any type of virtualization is detected, and the options +    <option>--container</option> and <option>--vm</option> can be used +    to limit what types of virtualization are detected.</para> + +    <para>When executed without <option>--quiet</option> will print a +    short identifier for the detected virtualization technology. The +    following technologies are currently identified:</para> + +    <table> +      <title>Known virtualization technologies (both +      VM, i.e. full hardware virtualization, +      and container, i.e. shared kernel virtualization)</title> +      <tgroup cols='3' align='left' colsep='1' rowsep='1'> +        <colspec colname="type" /> +        <colspec colname="id" /> +        <colspec colname="product" /> +        <thead> +          <row> +            <entry>Type</entry> +            <entry>ID</entry> +            <entry>Product</entry> +          </row> +        </thead> +        <tbody> +          <row> +            <entry valign="top" morerows="9">VM</entry> +            <entry><varname>qemu</varname></entry> +            <entry>QEMU software virtualization</entry> +          </row> + +          <row> +            <entry><varname>kvm</varname></entry> +            <entry>Linux KVM kernel virtual machine</entry> +          </row> + +          <row> +            <entry><varname>zvm</varname></entry> +            <entry>s390 z/VM</entry> +          </row> + +          <row> +            <entry><varname>vmware</varname></entry> +            <entry>VMware Workstation or Server, and related products</entry> +          </row> + +          <row> +            <entry><varname>microsoft</varname></entry> +            <entry>Hyper-V, also known as Viridian or Windows Server Virtualization</entry> +          </row> + +          <row> +            <entry><varname>oracle</varname></entry> +            <entry>Oracle VM VirtualBox (historically marketed by innotek and Sun Microsystems)</entry> +          </row> + +          <row> +            <entry><varname>xen</varname></entry> +            <entry>Xen hypervisor (only domU, not dom0)</entry> +          </row> + +          <row> +            <entry><varname>bochs</varname></entry> +            <entry>Bochs Emulator</entry> +          </row> + +          <row> +            <entry><varname>uml</varname></entry> +            <entry>User-mode Linux</entry> +          </row> + +          <row> +            <entry><varname>parallels</varname></entry> +            <entry>Parallels Desktop, Parallels Server</entry> +          </row> + +          <row> +            <entry valign="top" morerows="5">Container</entry> +            <entry><varname>openvz</varname></entry> +            <entry>OpenVZ/Virtuozzo</entry> +          </row> + +          <row> +            <entry><varname>lxc</varname></entry> +            <entry>Linux container implementation by LXC</entry> +          </row> + +          <row> +            <entry><varname>lxc-libvirt</varname></entry> +            <entry>Linux container implementation by libvirt</entry> +          </row> + +          <row> +            <entry><varname>systemd-nspawn</varname></entry> +            <entry>systemd's minimal container implementation, see <citerefentry><refentrytitle>systemd-nspawn</refentrytitle><manvolnum>1</manvolnum></citerefentry></entry> +          </row> + +          <row> +            <entry><varname>docker</varname></entry> +            <entry>Docker container manager</entry> +          </row> + +          <row> +            <entry><varname>rkt</varname></entry> +            <entry>rkt app container runtime</entry> +          </row> +        </tbody> +      </tgroup> +    </table> + +    <para>If multiple virtualization solutions are used, only the +    "innermost" is detected and identified. That means if both +    machine and container virtualization are used in +    conjunction, only the latter will be identified (unless +    <option>--vm</option> is passed).</para> +  </refsect1> + +  <refsect1> +    <title>Options</title> + +    <para>The following options are understood:</para> + +    <variablelist> +      <varlistentry> +        <term><option>-c</option></term> +        <term><option>--container</option></term> + +        <listitem><para>Only detects container virtualization (i.e. +        shared kernel virtualization).</para></listitem> +      </varlistentry> + +      <varlistentry> +        <term><option>-v</option></term> +        <term><option>--vm</option></term> + +        <listitem><para>Only detects hardware virtualization).</para></listitem> +      </varlistentry> + +      <varlistentry> +        <term><option>-r</option></term> +        <term><option>--chroot</option></term> + +        <listitem><para>Detect whether invoked in a +        <citerefentry><refentrytitle>chroot</refentrytitle><manvolnum>2</manvolnum></citerefentry> +        environment. In this mode, no output is written, but the return +        value indicates whether the process was invoked in a +        <function>chroot()</function> +        environment or not.</para></listitem> +      </varlistentry> + +      <varlistentry> +        <term><option>-q</option></term> +        <term><option>--quiet</option></term> + +        <listitem><para>Suppress output of the virtualization +        technology identifier.</para></listitem> +      </varlistentry> + +      <xi:include href="standard-options.xml" xpointer="help" /> +      <xi:include href="standard-options.xml" xpointer="version" /> +    </variablelist> + +  </refsect1> + +  <refsect1> +    <title>Exit status</title> + +    <para>If a virtualization technology is detected, 0 is returned, a +    non-zero code otherwise.</para> +  </refsect1> + +  <refsect1> +    <title>See Also</title> +    <para> +      <citerefentry><refentrytitle>systemd</refentrytitle><manvolnum>1</manvolnum></citerefentry>, +      <citerefentry><refentrytitle>systemd-nspawn</refentrytitle><manvolnum>1</manvolnum></citerefentry>, +      <citerefentry><refentrytitle>chroot</refentrytitle><manvolnum>2</manvolnum></citerefentry> +    </para> +  </refsect1> + +</refentry> | 
