mirror of https://gitee.com/openkylin/libvirt.git
226 lines
5.1 KiB
C
226 lines
5.1 KiB
C
/*
|
|
* virt-host-validate.c: Sanity check a hypervisor host
|
|
*
|
|
* Copyright (C) 2012 Red Hat, Inc.
|
|
*
|
|
* This library 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.
|
|
*
|
|
* This library 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 this library. If not, see
|
|
* <http://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
|
|
#include <config.h>
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <gettext.h>
|
|
#include <getopt.h>
|
|
#include <locale.h>
|
|
|
|
#include "internal.h"
|
|
#include "configmake.h"
|
|
|
|
#include "virt-host-validate-common.h"
|
|
#if WITH_QEMU
|
|
# include "virt-host-validate-qemu.h"
|
|
#endif
|
|
#if WITH_LXC
|
|
# include "virt-host-validate-lxc.h"
|
|
#endif
|
|
|
|
static void
|
|
show_help(FILE *out, const char *argv0)
|
|
{
|
|
fprintf(out,
|
|
_("\n"
|
|
"syntax: %s [OPTIONS] [HVTYPE]\n"
|
|
"\n"
|
|
" Hypervisor types:\n"
|
|
"\n"
|
|
" - qemu\n"
|
|
" - lxc\n"
|
|
"\n"
|
|
" Options:\n"
|
|
" -h, --help Display command line help\n"
|
|
" -v, --version Display command version\n"
|
|
" -q, --quiet Don't display progress information\n"
|
|
"\n"),
|
|
argv0);
|
|
}
|
|
|
|
static void
|
|
show_version(FILE *out, const char *argv0)
|
|
{
|
|
fprintf(out, "version: %s %s\n", argv0, VERSION);
|
|
}
|
|
|
|
static const struct option argOptions[] = {
|
|
{ "help", 0, NULL, 'h', },
|
|
{ "version", 0, NULL, 'v', },
|
|
{ "quiet", 0, NULL, 'q', },
|
|
{ NULL, 0, NULL, '\0', }
|
|
};
|
|
|
|
int
|
|
main(int argc, char **argv)
|
|
{
|
|
const char *hvname = NULL;
|
|
int c;
|
|
int ret = EXIT_SUCCESS;
|
|
bool quiet = false;
|
|
bool usedHvname = false;
|
|
|
|
if (!setlocale(LC_ALL, "")) {
|
|
perror("setlocale");
|
|
/* failure to setup locale is not fatal */
|
|
}
|
|
if (!bindtextdomain(PACKAGE, LOCALEDIR)) {
|
|
perror("bindtextdomain");
|
|
return EXIT_FAILURE;
|
|
}
|
|
if (!textdomain(PACKAGE)) {
|
|
perror("textdomain");
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
while ((c = getopt_long(argc, argv, "hvq", argOptions, NULL)) != -1) {
|
|
switch (c) {
|
|
case 'v':
|
|
show_version(stdout, argv[0]);
|
|
return EXIT_SUCCESS;
|
|
|
|
case 'h':
|
|
show_help(stdout, argv[0]);
|
|
return EXIT_SUCCESS;
|
|
|
|
case 'q':
|
|
quiet = true;
|
|
break;
|
|
|
|
case '?':
|
|
default:
|
|
show_help(stderr, argv[0]);
|
|
return EXIT_FAILURE;
|
|
}
|
|
}
|
|
|
|
if ((argc-optind) > 2) {
|
|
fprintf(stderr, _("%s: too many command line arguments\n"), argv[0]);
|
|
show_help(stderr, argv[0]);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
if (argc > 1)
|
|
hvname = argv[optind];
|
|
|
|
virHostMsgSetQuiet(quiet);
|
|
|
|
#if WITH_QEMU
|
|
if (!hvname || STREQ(hvname, "qemu")) {
|
|
usedHvname = true;
|
|
if (virHostValidateQEMU() < 0)
|
|
ret = EXIT_FAILURE;
|
|
}
|
|
#endif
|
|
|
|
#if WITH_LXC
|
|
if (!hvname || STREQ(hvname, "lxc")) {
|
|
usedHvname = true;
|
|
if (virHostValidateLXC() < 0)
|
|
ret = EXIT_FAILURE;
|
|
}
|
|
#endif
|
|
|
|
if (hvname && !usedHvname) {
|
|
fprintf(stderr, _("%s: unsupported hypervisor name %s\n"),
|
|
argv[0], hvname);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
/*
|
|
|
|
=pod
|
|
|
|
=head1 NAME
|
|
|
|
virt-host-validate - validate host virtualization setup
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
virt-host-validate [OPTIONS...] [HV-TYPE]
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
This tool validates that the host is configured in a suitable
|
|
way to run libvirt hypervisor drivers. If invoked without any
|
|
arguments it will check support for all hypervisor drivers it
|
|
is aware of. Optionally it can be given a particular hypervisor
|
|
type ('qemu' or 'lxc') to restrict the checks to those relevant
|
|
for that virtualization technology
|
|
|
|
=head1 OPTIONS
|
|
|
|
=over 4
|
|
|
|
=item C<-v>, C<--version>
|
|
|
|
Display the command version
|
|
|
|
=item C<-h>, C<--help>
|
|
|
|
Display the command line help
|
|
|
|
=item C<-q>, C<--quiet>
|
|
|
|
Don't display details of individual checks being performed.
|
|
Only display output if a check does not pass.
|
|
|
|
=back
|
|
|
|
=head1 EXIT STATUS
|
|
|
|
Upon successful validation, an exit status of 0 will be set. Upon
|
|
failure a non-zero status will be set.
|
|
|
|
=head1 AUTHOR
|
|
|
|
Daniel P. Berrange
|
|
|
|
=head1 BUGS
|
|
|
|
Report any bugs discovered to the libvirt community via the
|
|
mailing list C<http://libvirt.org/contact.html> or bug tracker C<http://libvirt.org/bugs.html>.
|
|
Alternatively report bugs to your software distributor / vendor.
|
|
|
|
=head1 COPYRIGHT
|
|
|
|
Copyright (C) 2012 by Red Hat, Inc.
|
|
|
|
=head1 LICENSE
|
|
|
|
virt-host-validate is distributed under the terms of the GNU GPL v2+.
|
|
This is free software; see the source for copying conditions. There
|
|
is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
PURPOSE
|
|
|
|
=head1 SEE ALSO
|
|
|
|
C<virsh(1)>, C<virt-pki-validate>, C<virt-xml-validate>
|
|
|
|
=cut
|
|
|
|
*/
|