]> git.ipfire.org Git - thirdparty/libvirt.git/log
thirdparty/libvirt.git
15 years agobuild: fix up some compiler flags
Eric Blake [Fri, 14 May 2010 22:45:52 +0000 (16:45 -0600)] 
build: fix up some compiler flags

Matthias noted that the line:
virt_aa_helper_LDFLAGS = $(WARN_CFLAGS)
looks inconsistent, so I did an audit.

Currently, the set of compiler warning flags passed to gcc as $CC are
equally permitted as the set of linker flags passed to gcc as $LD, so
there was no problem with that usage.  But if we ever get in a
situation where $CC and $LD treat particular flags differently, using
the right variable form will make it easier.

In the process, I spotted a couple of typos that were omitting useful
flags, as well as specifying a -l under the wrong variable.

* acinclude.m4 (LIBVIRT_COMPILE_WARNINGS): Define WARN_LDFLAGS as
an alias for WARN_CFLAGS.
* tools/Makefile.am (virsh_LDFLAGS): Use more canonical spelling.
* proxy/Makefile.am (libvirt_proxy_LDFLAGS): Likewise. Move
library...
(libvirt_proxy_LDADD): ...here.
* src/Makefile.am (virt_aa_helper_LDFLAGS): Use more canonical
spelling of WARN_LDFLAGS.
(libvirt_parthelper_LDFLAGS, libvirt_lxc_LDFLAGS): Likewise.  Use
correct spelling of COVERAGE_LDFLAGS.
Reported by Matthias Bolte.

15 years agobuild: avoid compile failure on linux kernels older than 2.6.19
Jim Meyering [Mon, 17 May 2010 14:17:08 +0000 (16:17 +0200)] 
build: avoid compile failure on linux kernels older than 2.6.19

* configure.ac: Check for <linux/magic.h>.
* src/util/storage_file.c: Include <linux/magic.h> only if present.
Linux kernels prior to 2.6.19 lacked it.
[__linux__] (NFS_SUPER_MAGIC): Define if not already defined.

15 years agox86ModelHasFeature: avoid NULL-dereference for unmatched CPU "feature"
Jim Meyering [Mon, 17 May 2010 12:06:13 +0000 (14:06 +0200)] 
x86ModelHasFeature: avoid NULL-dereference for unmatched CPU "feature"

* src/cpu/cpu_x86.c (x86ModelHasFeature): Do not dereference the pointer
returned by x86cpuidFind without first ensuring it is non-NULL.

15 years agoqemu: Report cmdline output if VM dies early
Cole Robinson [Mon, 17 May 2010 14:15:53 +0000 (10:15 -0400)] 
qemu: Report cmdline output if VM dies early

qemuReadLogOutput early VM death detection is racy and won't always work.
Startup then errors when connecting to the VM monitor. This won't report
the emulator cmdline output which is typically the most useful diagnostic.

Check if the VM has died at the very end of the monitor connection step,
and if so, report the cmdline output.

See also: https://bugzilla.redhat.com/show_bug.cgi?id=581381

15 years agoqemu: Fix previous commit, use comparision in if()
Cole Robinson [Mon, 17 May 2010 13:39:11 +0000 (09:39 -0400)] 
qemu: Fix previous commit, use comparision in if()

15 years agoqemu_driver: avoid NULL dereference
Jim Meyering [Mon, 17 May 2010 10:10:52 +0000 (12:10 +0200)] 
qemu_driver: avoid NULL dereference

* src/qemu/qemu_driver.c (qemudDomainStart): After setting vm to NULL,
goto cleanup, rather than dereferencing the NULL pointer.

15 years agoRemove debugging fprintf() calls
Daniel P. Berrange [Mon, 17 May 2010 09:44:49 +0000 (10:44 +0100)] 
Remove debugging fprintf() calls

* src/qemu/qemu_driver.c: Remove debugging fprintf() calls
  accidentally left in code

15 years agoqemudDomainSetVcpus: avoid NULL-deref
Jim Meyering [Fri, 14 May 2010 10:38:43 +0000 (12:38 +0200)] 
qemudDomainSetVcpus: avoid NULL-deref

* src/qemu/qemu_driver.c (qemudDomainSetVcpus): Avoid NULL-deref
upon unknown UUID.  Call qemuDomainObjBeginJob(vm) only after
ensuring that vm != NULL, not before.  This potential NULL-deref
was introduced by commit 2c555d87b0041e0d1ec4742386d2161d1b2f0600.

15 years agoRevert "build: fix cygwin build"
Eric Blake [Fri, 14 May 2010 23:46:47 +0000 (17:46 -0600)] 
Revert "build: fix cygwin build"

This reverts commit 2d550542ee729c1d9a4d92de344892650817b213.

The patch worked for incremental builds, but broke fresh
builds, because it interfered with automake's automatic
dependency generation.  Until I figure out how to make
automake do what we want, I'd rather leave cygwin broken
but fresh Linux builds working.

15 years agobuild: fix cygwin build
Eric Blake [Fri, 14 May 2010 21:14:58 +0000 (15:14 -0600)] 
build: fix cygwin build

make[3]: *** No rule to make target `-lxml2', needed by `libvirt.la'.  Stop.

Due to treating the wrong string as a dependency.

* src/Makefile.am (libvirt_la_DEPENDENCIES): Depend only on
locally-built file, not on strings that might resolve as '-lxml2'.

15 years agonwfilter: Add missing driver lock in qemu driver
Stefan Berger [Fri, 14 May 2010 18:22:39 +0000 (14:22 -0400)] 
nwfilter: Add missing driver lock in qemu driver

This adds a missing driver lock in the qemu driver to protect
the list of domains.

15 years agoFix a misuse of virAsprintf in qemudDomainMemoryPeek
Ryota Ozaki [Fri, 14 May 2010 10:08:59 +0000 (19:08 +0900)] 
Fix a misuse of virAsprintf in qemudDomainMemoryPeek

The code specifies driver->cacheDir as the format string,
but it usually doesn't contain '%s', so the subsequent
argument, "/qemu.mem.XXXXXX", is always ignored.

The patch fixes the misuse.

15 years agoMake domain save work when dynamic_ownership=0
Daniel P. Berrange [Thu, 13 May 2010 17:30:33 +0000 (13:30 -0400)] 
Make domain save work when dynamic_ownership=0

Setting dynamic_ownership=0 in /etc/libvirt/qemu.conf prevents
libvirt's DAC security driver from setting uid/gid on disk
files when starting/stopping QEMU, allowing the admin to manage
this manually. As a side effect it also stopped setting of
uid/gid when saving guests to a file, which completely breaks
save when QEMU is running non-root. Thus saved state labelling
code must ignore the dynamic_ownership parameter

* src/qemu/qemu_security_dac.c: Ignore dynamic_ownership=0 when
  doing save/restore image labelling

15 years agoDon't reset user/group/security label on shared filesystems during migrate
Daniel P. Berrange [Thu, 13 May 2010 15:49:22 +0000 (11:49 -0400)] 
Don't reset user/group/security label on shared filesystems during migrate

When QEMU runs with its disk on NFS, and as a non-root user, the
disk is chownd to that non-root user. When migration completes
the last step is shutting down the QEMU on the source host. THis
normally resets user/group/security label. This is bad when the
VM was just migrated because the file is still in use on the dest
host. It is thus neccessary to skip the reset step for any files
found to be on a shared filesystem

* src/libvirt_private.syms: Export virStorageFileIsSharedFS
* src/util/storage_file.c, src/util/storage_file.h: Add a new
  method virStorageFileIsSharedFS() to determine if a file is
  on a shared filesystem (NFS, GFS, OCFS2, etc)
* src/qemu/qemu_driver.c: Tell security driver not to reset
  disk labels on migration completion
* src/qemu/qemu_security_dac.c, src/qemu/qemu_security_stacked.c,
  src/security/security_selinux.c, src/security/security_driver.h,
  src/security/security_apparmor.c: Add ability to skip disk
  restore step for files on shared filesystems.

15 years agoFix handling of disk backing stores with cgroups
Daniel P. Berrange [Wed, 28 Apr 2010 15:25:42 +0000 (16:25 +0100)] 
Fix handling of disk backing stores with cgroups

The cgroups ACL code was only allowing the primary disk image.
It is possible to chain images together, so we need to search
for backing stores and add them to the ACL too. Since the ACL
only handles block devices, we ignore the EINVAL we get from
plain files. In addition it was missing code to teardown the
cgroup when hot-unplugging a disk

* src/qemu/qemu_driver.c: Allow backing stores in cgroup ACLs
  and add missing teardown code in unplug path

15 years agoFix possible crash in handling IO Error event
Daniel P. Berrange [Tue, 11 May 2010 14:34:38 +0000 (10:34 -0400)] 
Fix possible crash in handling IO Error event

If the IO error event does not include a reason, then there
is a possible crash dispatching the event

* src/conf/domain_event.c: Missing check for a NULL reason before
  strduping allows for a crash

15 years agoAdd support for NIC hotplug using netdev_add in QEMU
Daniel P. Berrange [Thu, 15 Apr 2010 13:52:03 +0000 (14:52 +0100)] 
Add support for NIC hotplug using netdev_add in QEMU

QEMU is gaining a new monitor command netdev_add for hotplugging
NICs using the netdev backend code. We already support this on
the command this, though it is disabled. This adds support for
hotplug too, also to remain disabled until 0.13 QEMU is released

* src/qemu/qemu_driver.c: Support netdev hotplug for NICs
* src/qemu/qemu_monitor.c, src/qemu/qemu_monitor.h,
  src/qemu/qemu_monitor_json.c, src/qemu/qemu_monitor_json.h,
  src/qemu/qemu_monitor_text.c, src/qemu/qemu_monitor_text.h: Add
  support for netdev_add and netdev_remove commands

15 years agodatatypes: fix comment typo
Eric Blake [Wed, 12 May 2010 18:00:17 +0000 (12:00 -0600)] 
datatypes: fix comment typo

* src/datatypes.c: Use correct word.

15 years agoFix monitor ref counting when adding event handle
Jiri Denemark [Wed, 12 May 2010 09:50:52 +0000 (11:50 +0200)] 
Fix monitor ref counting when adding event handle

When closing a monitor using qemuMonitorClose(), we are aware of
the possibility the monitor is still being used somewhere:

    /* NB: ordinarily one might immediately set mon->watch to -1
     * and mon->fd to -1, but there may be a callback active
     * that is still relying on these fields being valid. So
     * we merely close them, but not clear their values and
     * use this explicit 'closed' flag to track this state */

but since we call virEventAddHandle() on that monitor without increasing
its ref counter, the monitor is still freed which makes possible users
of it quite unhappy. The unhappiness can lead to a hang if qemuMonitorIO
tries to lock mutex which no longer exists.

15 years agoRemove watches before calling REMOTE_PROC_CLOSE
Jiri Denemark [Mon, 10 May 2010 13:13:17 +0000 (15:13 +0200)] 
Remove watches before calling REMOTE_PROC_CLOSE

First calling REMOTE_PROC_CLOSE and then removing watches might lead to
a hang as HANGUP event can be triggered before the watches are actually
removed but after virConnectPtr is already freed. As a result of that
remoteDomainEventFired() would try to lock uninitialized mutex, which
would hang for ever.

15 years agotests: use GPLv2+, not GPLv3
Jim Meyering [Tue, 11 May 2010 18:10:18 +0000 (20:10 +0200)] 
tests: use GPLv2+, not GPLv3

* tests/cpuset: Change from GPLv3 to GPLv2+
* tests/read-bufsiz: Likewise.
* tests/read-non-seekable: Likewise.
* tests/start: Likewise.
* tests/undefine: Likewise.
* tests/vcpupin: Likewise.
* tests/virsh-all: Likewise.
* tests/virsh-schedinfo: Likewise.
* tests/virsh-synopsis: Likewise.

15 years agolibvirt_proxy: link with -lpthread if needed
Eric Blake [Tue, 11 May 2010 22:12:15 +0000 (16:12 -0600)] 
libvirt_proxy: link with -lpthread if needed

Continuation of earlier patches to fix LIB_PTHREAD, only
triggered by ./configure --with-xen-proxy (a la autobuild.sh).

* proxy/Makefile.am (libvirt_proxy_LDADD): Add LIB_PTHREAD.

15 years agonode_device: udev: Fix PCI product/vendor swappage
Cole Robinson [Tue, 11 May 2010 18:44:34 +0000 (14:44 -0400)] 
node_device: udev: Fix PCI product/vendor swappage

Product and vendor values were swapped in the XML, which made virt-manager
PCI device listing kinda useless.

15 years agobuild: update gnulib
Eric Blake [Tue, 11 May 2010 15:32:19 +0000 (09:32 -0600)] 
build: update gnulib

* .gnulib: Update to latest.
* bootstrap.conf (gnulib_modules): Import netdb.
* src/esx/esx_util.c (AI_ADDRCONFIG): Rely on gnulib.
* src/remote/remote_driver.c (AI_ADDRCONFIG): Likewise.
* tools/virsh.c (WEXITSTATUS, O_SYNC): Likewise.

15 years agobuild: allow older gettext
Eric Blake [Mon, 10 May 2010 22:56:34 +0000 (16:56 -0600)] 
build: allow older gettext

* bootstrap.conf (gnulib_modules): Use gettext-h, not gettext,
since the latter drags in a depedency on gettext 0.18.
Suggested by Bruno Haible.

15 years agotests: correct PATH in new test, for when running manually
Jim Meyering [Tue, 11 May 2010 15:43:16 +0000 (17:43 +0200)] 
tests: correct PATH in new test, for when running manually

* tests/virsh-schedinfo: This test sets PATH internally, just in
case you're running it manually.  Normally, the PATH setting from
tests/Makefile.am's TESTS_ENVIRONMENT is sufficient.  Prepend the
correct directory, and take advantage of the PATH setting in one
more case.

15 years agoAdd env variable for debugging gnutls usage
Daniel P. Berrange [Fri, 7 May 2010 12:42:11 +0000 (13:42 +0100)] 
Add env variable for debugging gnutls usage

Allow debugging of GNUTLS interactions by setting

  LIBVIRT_GNUTLS_DEBUG=10 LIBVIRT_DEBUG=1 virsh

* src/remote/remote_driver.c: Use LIBVIRT_GNUTLS_DEBUG to
  enable gnutls debugging

15 years agotests: adjust copyrights on scripts: s/FSF/Red Hat/
Jim Meyering [Tue, 11 May 2010 14:43:07 +0000 (16:43 +0200)] 
tests: adjust copyrights on scripts: s/FSF/Red Hat/

* tests/cpuset: Change copyright holder from FSF to Red Hat, Inc.
* tests/read-bufsiz: Likewise.
* tests/read-non-seekable: Likewise.
* tests/start: Likewise.
* tests/undefine: Likewise.
* tests/vcpupin: Likewise.
* tests/virsh-all: Likewise.
* tests/virsh-synopsis: Likewise.

15 years agovirsh: schedinfo --set invalid=value would simply ignore the option
Jim Meyering [Tue, 11 May 2010 13:38:21 +0000 (15:38 +0200)] 
virsh: schedinfo --set invalid=value would simply ignore the option

For example, virsh -c test:///default schedinfo 1 --set P=k would
mistakenly exit successfully, giving no indication that it had failed
to set the scheduling parameter "P".
* tools/virsh.c (cmdSchedinfo): Diagnose an invalid --set j=k option,
rather than silently ignoring it.
* tests/virsh-schedinfo: New test for the above.
* tests/Makefile.am (test_scripts): Add it.
Reported by Jintao Yang in http://bugzilla.redhat.com/586632

15 years agovirsh: fix a typo in a diagnostic
Jim Meyering [Tue, 11 May 2010 14:02:28 +0000 (16:02 +0200)] 
virsh: fix a typo in a diagnostic

* tools/virsh.c (cmdSchedInfoUpdate): Fix typo in a diagnostic:
s/an long long/a long long/.  One in a comment, too.

15 years agodelMacvtap: typo fix
Eric Blake [Mon, 10 May 2010 23:12:22 +0000 (17:12 -0600)] 
delMacvtap: typo fix

* src/util/macvtap.c (delMacvtap): Fix documentation.

15 years agomaint: allow VPATH use of remote_protocol-structs
Eric Blake [Mon, 10 May 2010 21:17:31 +0000 (15:17 -0600)] 
maint: allow VPATH use of remote_protocol-structs

* src/Makefile.am (remote_protocol-structs): Ensure file lives in srcdir.

15 years agodocs/Makefile.am: remove unnecessary subshells
Eric Blake [Thu, 29 Apr 2010 01:32:20 +0000 (19:32 -0600)] 
docs/Makefile.am: remove unnecessary subshells

* docs/Makefile.am (ChangeLog.html.in, %.html.tmp, %.html)
(html/index.html, $(devhelphtml)): Avoid spurious subshells.

15 years agomaint: avoid spurious output if program not present
Eric Blake [Mon, 10 May 2010 20:17:10 +0000 (14:17 -0600)] 
maint: avoid spurious output if program not present

Some shells warn about missing programs before redirection;
the idiomatic way to silence them is to run the program check
inside a subshell, with the redirections outside the subshell.
But a subshell is only needed in places where it is reasonable
to expect the use of such a noisy shell in the first place.

* src/Makefile.am (remote_protocol-structs): Use subshell, for
FreeBSD 8.0 /bin/sh.
* cfg.mk (sc_preprocessor_indentation): Avoid subshell, since the
only users running cfg.mk can be assumed to have decent tools.

15 years agostorage_encryption: silence clang warning
Eric Blake [Fri, 7 May 2010 20:34:15 +0000 (14:34 -0600)] 
storage_encryption: silence clang warning

For printf("%*s",foo,bar), clang complains if foo is not int:

warning: field width should have type 'int', but argument has
type 'unsigned int' [-Wformat]

* src/conf/storage_encryption_conf.c
(virStorageEncryptionSecretFormat, virStorageEncryptionFormat):
Use correct type.
* src/conf/storage_encryption_conf.h (virStorageEncryptionFormat):
Likewise.

15 years agohelp avoid accidental remote_protocol.x changes
Jim Meyering [Fri, 7 May 2010 14:01:26 +0000 (16:01 +0200)] 
help avoid accidental remote_protocol.x changes

Now, if you update remote_protocol.x without also updating
remote_protocol-structs to match, then "make check" will fail.
* src/Makefile.am (remote_protocol-structs): Extract list of
structs and member names from remote_protocol.o.
(check-local): Depend on it.
* src/remote_protocol-structs: New file.

15 years agomingw32-libvirt.spec: bring up to date
Eric Blake [Tue, 4 May 2010 17:12:01 +0000 (11:12 -0600)] 
mingw32-libvirt.spec: bring up to date

Right now, mingw32-portablexdr is not available in Fedora, but is
present in fedora-mingw.git.  With that package, plus
redhat-rpm-config and this patch, it is once again possible to build
mingw32-libvirt from a Fedora 12 host.

* mingw32-libvirt.spec.in (__debug_install_post): Override.
(%files): Mention recent additions.

15 years agoManually revert "Fix pthread related link error for virt-aa-helper"
Matthias Bolte [Fri, 7 May 2010 17:59:24 +0000 (19:59 +0200)] 
Manually revert "Fix pthread related link error for virt-aa-helper"

This reverts commit b5b8a6db69ba16a8225962bf7659b6ff6756bc18.

That commit was not necessary. The problem is fixed by commit
0e9b3a269be9ce821615aba4aece87c4451d43ac, but I didn't rebuild
it properly after pulling in the commit and didn't notice it.

15 years agoFix a typo in docs
Ersek Laszlo [Fri, 7 May 2010 17:52:35 +0000 (19:52 +0200)] 
Fix a typo in docs

15 years agobuild: use LIBADD, not LDFLAGS, for adding libraries
Eric Blake [Fri, 7 May 2010 16:39:52 +0000 (10:39 -0600)] 
build: use LIBADD, not LDFLAGS, for adding libraries

Per automake, LDFLAGS is used early in the line, and LIBADD
(libraries) or LDADD (programs) is used late.  On platforms like
cygwin, without lazy linking, this order matters.  Therefore, libtool
commands, -L, and similar should be in LDFLAGS, but -l should be in
L*ADD.

* src/Makefile.am (*_LDFLAGS): Move libraries...
(*_LIBADD): ...to their LIBADD counterpart.

15 years agomaint: whitespace cleanups
Eric Blake [Fri, 7 May 2010 17:11:02 +0000 (11:11 -0600)] 
maint: whitespace cleanups

* src/Makefile.am: Fix some space-tab issues.

15 years agoFix pthread related link error for virt-aa-helper
Matthias Bolte [Fri, 7 May 2010 15:52:37 +0000 (17:52 +0200)] 
Fix pthread related link error for virt-aa-helper

Link virt-aa-helper explicitly with pthread. This is at least
required on Ubuntu 10.04.

15 years agoqemu: Fix warning about a non-literal format string
Matthias Bolte [Fri, 7 May 2010 15:47:16 +0000 (17:47 +0200)] 
qemu: Fix warning about a non-literal format string

15 years agoavoid link error in tests using libvirt_util; due to pthread_sigmask
Jim Meyering [Fri, 7 May 2010 14:23:44 +0000 (16:23 +0200)] 
avoid link error in tests using libvirt_util; due to pthread_sigmask

* src/Makefile.am (libvirt_util_la_LDFLAGS): Add $(LIB_PTHREAD),
required, now that we're using gnulib's pthread module.

15 years agoRemove unused nwfilter field from struct remote_error
Matthew Booth [Fri, 7 May 2010 14:38:05 +0000 (16:38 +0200)] 
Remove unused nwfilter field from struct remote_error

Change 965466c1 added a new field to struct remote_error, which broke
the RPC protocol. Fortunately the new field is unused, so this change
simply removes it again.

* src/remote/remote_protocol.(c|h|x): Remove remote_nwfilter from struct
  remote_error

15 years agoImplement SCSI disk unplugging
Wolfgang Mauerer [Wed, 5 May 2010 14:52:15 +0000 (16:52 +0200)] 
Implement SCSI disk unplugging

With the introduction of the generic qemu device model, unplugging
SCSI disks works like a charm, so support it in libvirt.

* src/qemu/qemu_driver.c: Add qemudDomainDetachSCSIDiskDevice() to do the
  unplugging, extend qemudDomainDetachDeviceAdd().

Signed-off-by: Wolfgang Mauerer <wolfgang.mauerer@siemens.com>
Signed-off-by: Eric Blake <eblake@redhat.com>
15 years agoqemu: use better types
Eric Blake [Thu, 6 May 2010 21:32:56 +0000 (15:32 -0600)] 
qemu: use better types

* src/qemu/qemu_driver.c (qemudFindDisk): Mark parameter const.
(qemudShrinkDisks): Mark parameter unsigned.

15 years agoRefactor disk unplugging
Wolfgang Mauerer [Wed, 5 May 2010 14:52:14 +0000 (16:52 +0200)] 
Refactor disk unplugging

We can reuse some of the code for other purposes.

Signed-off-by: Wolfgang Mauerer <wolfgang.mauerer@siemens.com>
15 years agobuild: simplify checks for sched.h
Eric Blake [Tue, 4 May 2010 23:18:28 +0000 (17:18 -0600)] 
build: simplify checks for sched.h

* configure.ac: Remove redundant checks.

15 years agobuild: update gnulib
Eric Blake [Mon, 3 May 2010 21:00:43 +0000 (15:00 -0600)] 
build: update gnulib

81 patches to gnulib, picks up several new syntax checks.

* .gnulib: Update to latest.
* .x-sc_prohibit_always_true_header_tests: New file.
* bootstrap.conf (gnulib_modules): Add sched.
* src/util/processinfo.c (includes): <sched.h> is now guaranteed.
* src/network/bridge_driver.c (includes): Drop useless
<strings.h>.
* src/openvz/openvz_conf.c (includes): Likewise.
* src/openvz/openvz_driver.c (includes): Likewise.
* src/phyp/phyp_driver.c (includes): Likewise.
* src/qemu/qemu_driver.c (includes): Likewise.
* src/uml/uml_driver.c (includes): Likewise.

15 years agobuild: drop more redundant configure checks
Eric Blake [Thu, 29 Apr 2010 03:26:57 +0000 (21:26 -0600)] 
build: drop more redundant configure checks

* configure.ac (AC_CHECK_FUNCS_ONCE, AC_SYS_LARGEFILE): Rely on
gnulib for strtok_r and large file support.
(AC_OBJEXT): Drop call now done by AC_PROG_CC.
(m4_foreach_w): Drop macro guaranteed by gnulib.
(AC_C_CONST): Drop call declared obsolete by autoconf.

Signed-off-by: Eric Blake <eblake@redhat.com>
15 years agobuild: use gnulib's sys/wait.h
Eric Blake [Thu, 29 Apr 2010 03:31:16 +0000 (21:31 -0600)] 
build: use gnulib's sys/wait.h

* configure.ac: Drop sys/wait.h check.
* src/libvirt.c (includes): Use header unconditionally.
* src/remote/remote_driver.c (includes): Likewise.
* src/storage/storage_backend.c (includes): Likewise.
* src/util/ebtables.c (includes): Likewise.
* src/util/hooks.c (includes): Likewise.
* src/util/iptables.c (includes): Likewise.
* src/util/util.c (includes): Likewise.

15 years agobuild: use gnulib's uname
Eric Blake [Thu, 29 Apr 2010 03:06:46 +0000 (21:06 -0600)] 
build: use gnulib's uname

* bootstrap.conf (gnulib_modules): Add uname.
* configure.ac: Drop uname and sys/utsname.h checks.
* src/nodeinfo.c (nodeGetInfo): Use uname unconditionally.

15 years agobuild: rely on gnulib's pthread module
Eric Blake [Thu, 29 Apr 2010 02:39:11 +0000 (20:39 -0600)] 
build: rely on gnulib's pthread module

Gnulib can guarantee that pthread.h exists, but for now, it is a dummy
header with no support for most pthread_* functions.  Modify our
use of pthread to use function checks, rather than header checks,
to determine how much pthread support is present.

* bootstrap.conf (gnulib_modules): Add pthread.
* configure.ac: Drop all pthread.h checks.  Optimize function
checks.  Add check for pthread functions.
* src/Makefile.am (libvirt_lxc_LDADD): Ensure proper link.
* src/remote/remote_driver.c (remoteIOEventLoop): Depend on
pthread_sigmask, now that gnulib guarantees pthread.h.
* src/util/util.c (virFork): Likewise.
* src/util/threads.c (threads-pthread.c): Depend on
pthread_mutexattr_init, as a witness of full pthread support.
* src/util/threads.h (threads-pthread.h): Likewise.

15 years agobuild: silence a clang false positive
Eric Blake [Wed, 5 May 2010 17:14:54 +0000 (11:14 -0600)] 
build: silence a clang false positive

* src/qemu/qemu_monitor.c (qemuMonitorIOWriteWithFD): Work around
recent clang shortcoming in analysis.

15 years agorpmbuild: add ebtables & ip(6)tables dependency for rpm
Stefan Berger [Wed, 5 May 2010 16:20:28 +0000 (12:20 -0400)] 
rpmbuild: add ebtables & ip(6)tables dependency for rpm

Add ebtables,iptables & iptables-ipv6 dependency to rpm.

Changes from V1 to V2:
  -passing --without-libpcap to configure script, if libpcap is not to be used

15 years agoutil: fix va_start usage bug
Eric Blake [Tue, 4 May 2010 22:07:18 +0000 (16:07 -0600)] 
util: fix va_start usage bug

Detected by clang.  POSIX requires that the second argument to
va_start be the name of the last variable; and in some implementations,
passing *path instead of path would dereference bogus memory instead
of pulling arguments off the stack.

* src/util/util.c (virBuildPathInternal): Use correct argument to
va_start.

15 years agoqemu: live migration with non-shared storage for kvm
Kenneth Nagin [Tue, 4 May 2010 21:36:42 +0000 (15:36 -0600)] 
qemu: live migration with non-shared storage for kvm

Support for live migration between hosts that do not share storage was
added to qemu-kvm release 0.12.1.
It supports two flags:
-b migration without shared storage with full disk copy
-i migration without shared storage with incremental copy (same base image
shared between source and destination).

I tested the live migration without shared storage (both flags) for native
and p2p with and without tunnelling.  I also verified that the fix doesn't
affect normal migration with shared storage.

15 years agoconfigure.ac: Avoid uname, which breaks cross-compilation
Matthias Bolte [Mon, 3 May 2010 23:41:55 +0000 (01:41 +0200)] 
configure.ac: Avoid uname, which breaks cross-compilation

When cross-compiling on Linux, configure will misdetect the target as
Linux because it uses uname instead of relying on the $host variable.
This results in including libvirt_linux.syms into libvirt.syms and
therefore trying to export undefined symbols.

Replace uname checks with $host checks to fix this.

15 years agoDon't wipe generated iface target in active domains
Jiri Denemark [Tue, 4 May 2010 13:16:29 +0000 (15:16 +0200)] 
Don't wipe generated iface target in active domains

Wipe generated interface target only when reading configuration of
inactive domains.

15 years agoVarious fixes for the spec file
Daniel Veillard [Tue, 4 May 2010 14:13:55 +0000 (16:13 +0200)] 
Various fixes for the spec file

This includes various things:
 - fix the Requires: libvirt-client to use %{name} to allow easy
   renaming
 - when building ESX support one need libcurl-devel
 - remove Makefile[.in] from xml/nwfilter in the docs, as this breaks
   parallel install ation of i686 and x86_64 packages
 - don't include nwfilter config files if not building with the daemon
all relatively trivial which is why I packed them together
* libvirt.spec.in: fix various small bugs

15 years agodocs: hacking: explain why using curly braces well is important
Jim Meyering [Thu, 15 Apr 2010 17:31:04 +0000 (19:31 +0200)] 
docs: hacking: explain why using curly braces well is important

* docs/hacking.html.in: Use the "curly braces" section from coreutils'
HACKING, adapting for libvirt's different formatting style.
* HACKING: Sync from the above, still mostly manually.

15 years agolxc: Check domain is active/inactive as required by operation
Jiri Denemark [Mon, 3 May 2010 12:04:44 +0000 (14:04 +0200)] 
lxc: Check domain is active/inactive as required by operation

Report VIR_ERR_OPERATION_INVALID when operation which requires running
domain is called on inactive domain and vice versa.

15 years agolxc: Make SetMemory work for active domains only
Jiri Denemark [Mon, 3 May 2010 12:02:56 +0000 (14:02 +0200)] 
lxc: Make SetMemory work for active domains only

15 years agolxc: Use virDomainFindByUUID for domain lookup
Jiri Denemark [Mon, 3 May 2010 11:59:03 +0000 (13:59 +0200)] 
lxc: Use virDomainFindByUUID for domain lookup

Consistently use virDomainFindByUUID instead of virDomainFindByID and
virDomainFindByName and report VIR_ERR_NO_DOMAIN when domain cannot be
found.

15 years agomingw: Fix two undefined symbols
Matthias Bolte [Mon, 3 May 2010 23:05:44 +0000 (01:05 +0200)] 
mingw: Fix two undefined symbols

Add an empty body for virCondWaitUntil and move virPipeReadUntilEOF
out of the '#ifndef WIN32' block, because it compiles fine with MinGW
in combination with gnulib.

15 years agobuild: avoid compiler warning
Eric Blake [Thu, 29 Apr 2010 03:36:03 +0000 (21:36 -0600)] 
build: avoid compiler warning

Necessary on cygwin, where uid_t and gid_t are 4-byte long rather
than int, causing gcc -Wformat warnings.

* src/util/util.c (virFileOperationNoFork, virDirCreateNoFork)
(virFileOperation, virDirCreate, virGetUserEnt): Cast uid_t and
gid_t before passing to printf.
* .gitignore: Ignore Windows executables.

15 years agonwfilter: skip some interfaces on filter update
Stefan Berger [Mon, 3 May 2010 22:14:58 +0000 (18:14 -0400)] 
nwfilter: skip some interfaces on filter update

When a filter is updated, only those interfaces must have their old
rules cleared that either reference the filter directly or indirectly
through another filter. Remember between the different steps of the
instantiation of the filters which interfaces must be skipped. I am
using a hash map to remember the names of the interfaces and store a
bogus pointer to ~0 into it that need not be freed.

15 years agopass info where request stems from to have rules applied
Stefan Berger [Mon, 3 May 2010 22:11:48 +0000 (18:11 -0400)] 
pass info where request stems from to have rules applied

For the decision on whether to instantiate the rules, the check for a
pending IP address learn request is not sufficient since then only the
thread could instantiate the rules. So, a boolean needs to be passed
when the thread instantiates the filter rules late and the IP address
learn request is still pending in order to override the check for the
pending learn request. If the rules are to be updated while the thread
is active, this will not be done immediately but the thread will do that
later on.

15 years agobuild: prefer WIN32 over __MINGW32__ checks
Eric Blake [Mon, 3 May 2010 20:44:12 +0000 (14:44 -0600)] 
build: prefer WIN32 over __MINGW32__ checks

WIN32 is always defined when __MINGW32__ is defined, but the
converse is not true.  WIN32 is more generic, if someone were
to ever attempt porting to a microsoft compiler.  This does
not affect Cygwin, which intentionally does not define WIN32.

* src/qemu/qemu_driver.c (qemuDomainGetBlockInfo): Use more
generic flag macro.
* src/storage/storage_backend.c
(virStorageBackendUpdateVolTargetInfoFD)
(virStorageBackendRunProgRegex): Likewise.
* tools/console.h (vshRunConsole): Likewise.

15 years agocgroup: Fix possible memory leak in virCgroupMakeGroup
Ryota Ozaki [Mon, 3 May 2010 19:04:51 +0000 (04:04 +0900)] 
cgroup: Fix possible memory leak in virCgroupMakeGroup

* src/util/cgroup.c: free temporal path string before breaking loop

15 years agodnsmasqReload: avoid mingw link failure
Eric Blake [Mon, 3 May 2010 18:23:50 +0000 (12:23 -0600)] 
dnsmasqReload: avoid mingw link failure

* src/util/dnsmasq.c (dnsmasqReload): Mingw lacks kill, but is not
running a dnsmasq daemon either.

15 years agomingw: Fix symbol export
Matthias Bolte [Mon, 3 May 2010 10:21:58 +0000 (12:21 +0200)] 
mingw: Fix symbol export

In commit 98fb83ce25f46e0236706fa6e0943032d921935f I changed the
version script handling. But it seems that I didn't test this properly
and broke it. The .def file is passed to the compiler directly, but it
should get passed to the linker instead.

Set VERSION_SCRIPT_FLAGS to -Wl, to pass the .def file correctly to
the linker.

This fixes the undefined symbol errors while linking virsh.

15 years agodnsmasq.c: Fix OOM error reporting
Matthias Bolte [Mon, 3 May 2010 10:26:42 +0000 (12:26 +0200)] 
dnsmasq.c: Fix OOM error reporting

Also do some indentation clean up.

15 years agoFix memory leaks in cmdInterfaceEdit and cmdNWFilterEdit.
Laine Stump [Sat, 1 May 2010 04:16:52 +0000 (00:16 -0400)] 
Fix memory leaks in cmdInterfaceEdit and cmdNWFilterEdit.

This applies a fix to thos functions similar to that made to cmdEdit
in 270895063d1cf86ab42fa220a8d090c24d58dbc0, thus fnixing a memory
leak - if tmp is unlinked and NULLed early in the function, the memory
used by tmp is never freed. Since we will always unlink tmp prior to
freeing its memory at the end of the function, just remove the earlier
code and let cleanup: do the cleanup.

15 years agolxc: Fix failure on starting a domain with multiple interfaces
Ryota Ozaki [Mon, 3 May 2010 09:13:26 +0000 (11:13 +0200)] 
lxc: Fix failure on starting a domain with multiple interfaces

[Error message]
error: Failed to start domain lxc_test1
error: internal error Failed to create veth device pair: 512

The reason of the failure is that lxc driver unexpectedly re-uses
an auto-assigned veth name and tries to create the created veth
again. The failure will happen when a domain has multiple network
interfaces and the names of those are not specified in XML.

The patch fixes the problem by resetting buffers of veth names
in every iteration of creating veth.

* src/lxc/lxc_driver.c: prevent re-using auto-assigned veth name
  Reported by Kumar L Srikanth-B22348.

15 years agoautobuild.sh: provide default prefix
Eric Blake [Fri, 30 Apr 2010 16:57:10 +0000 (10:57 -0600)] 
autobuild.sh: provide default prefix

Without this patch and with a clean environment, ./autobuild.sh
tried to use ./configure --prefix=/, and fails.

* autobuild.sh (AUTOBUILD_INSTALL_ROOT): Provide sensible
default.  Suggested by Daniel P. Berrange.

15 years agoRelease of libvirt-0.8.1 v0.8.1
Daniel Veillard [Fri, 30 Apr 2010 16:55:08 +0000 (18:55 +0200)] 
Release of libvirt-0.8.1

* configure.ac docs/news.html.in libvirt.spec.in: updates for release
* po/*.po*: updated localizations and regenerated

15 years agodomain: Fix PCI address decimal parsing regression
Cole Robinson [Fri, 30 Apr 2010 16:14:35 +0000 (18:14 +0200)] 
domain: Fix PCI address decimal parsing regression

<hostdev> address parsing previously attempted to detect the number
base: currently it is hardcoded to base 16, which can break PCI
assignment via virt-manager. Revert to the previous behavior.

* src/conf/domain_conf.c: virDomainDevicePCIAddressParseXML, switch to
  virStrToLong_ui(bus, NULL, 0, ...) to autodetect base

15 years agoAdd support for another explicit IO error event
Daniel P. Berrange [Thu, 18 Mar 2010 19:37:44 +0000 (19:37 +0000)] 
Add support for another explicit IO error event

This introduces a new event type

   VIR_DOMAIN_EVENT_ID_IO_ERROR_REASON

This event is the same as the previous VIR_DOMAIN_ID_IO_ERROR
event, but also includes a string describing the cause of
the event.

Thus there is a new callback definition for this event type

typedef void (*virConnectDomainEventIOErrorReasonCallback)(virConnectPtr conn,
                                                           virDomainPtr dom,
                                                           const char *srcPath,
                                                           const char *devAlias,
                                                           int action,
                                                           const char *reason,
                                                           void *opaque);

This is currently wired up to the QEMU block IO error events

* daemon/remote.c: Dispatch IO error events to client
* examples/domain-events/events-c/event-test.c: Watch for
  IO error events
* include/libvirt/libvirt.h.in: Define new IO error event ID
  and callback signature
* src/conf/domain_event.c, src/conf/domain_event.h,
  src/libvirt_private.syms: Extend API to handle IO error events
* src/qemu/qemu_driver.c: Connect to the QEMU monitor event
  for block IO errors and emit a libvirt IO error event
* src/remote/remote_driver.c: Receive and dispatch IO error
  events to application
* src/remote/remote_protocol.x: Wire protocol definition for
  IO error events
* src/qemu/qemu_monitor.c, src/qemu/qemu_monitor.h,
  src/qemu/qemu_monitor_json.c: Watch for BLOCK_IO_ERROR event
  from QEMU monitor

15 years agoReport all errors in SELinuxRestoreSecurityFileLabel
Jiri Denemark [Fri, 30 Apr 2010 11:35:15 +0000 (13:35 +0200)] 
Report all errors in SELinuxRestoreSecurityFileLabel

15 years agoPrevent updates while IP address learn thread is running
Stefan Berger [Fri, 30 Apr 2010 12:12:26 +0000 (08:12 -0400)] 
Prevent updates while IP address learn thread is running

Prevent updating and tearing down of filter while the IP
address learning thread is running and has its own filtering
rules applied.

15 years agoSyncronize the teardown of rules with the thread
Stefan Berger [Fri, 30 Apr 2010 12:10:12 +0000 (08:10 -0400)] 
Syncronize the teardown of rules with the thread

Introduce a function to notify the IP address learning
thread to terminate and thus release the lock on the interface.
Notify the thread before grabbing the lock on the interface
and tearing down the rules. This prevents a 'virsh destroy' to
tear down the rules that the IP address learning thread has
applied.

15 years agoClean all tables before applying 'basic' rules
Stefan Berger [Fri, 30 Apr 2010 12:06:18 +0000 (08:06 -0400)] 
Clean all tables before applying 'basic' rules

The functions invoked by the IP address learning thread
that apply some basic filtering rules did not clean up
any previous filtering rules that may still be there
(due to a libvirt restart for example). With the
patch below all the rules are cleaned up first.

Also, I am introducing a function to drop all traffic
in case the IP address learning thread could not apply
the rules.

15 years agoMAke virFileHasSuffix case insensitive
Daniel Veillard [Fri, 30 Apr 2010 12:03:41 +0000 (14:03 +0200)] 
MAke virFileHasSuffix case insensitive

* src/util/util.c: as it's used for checking things like .iso suffixes

15 years agonwfilter: Also pick IP address from a DHCP ACK message
Stefan Berger [Fri, 30 Apr 2010 11:51:47 +0000 (07:51 -0400)] 
nwfilter: Also pick IP address from a DHCP ACK message

The local DHCP server on virtbr0 sends DHCP ACK messages when a VM is
started and requests an IP address while the initial DHCP lease on the
VM's MAC address hasn't expired. So, also pick the IP address of the VM
if that type of message is seen.
Thanks to Gerhard Stenzel for providing a test case for this.

Changes from V1 to V2:
- cleanup: replacing DHCP option numbers through constants

15 years agoFix virt-pki-validate's determination of CN
Dustin Kirkland [Thu, 29 Apr 2010 21:20:50 +0000 (16:20 -0500)] 
Fix virt-pki-validate's determination of CN

Ubuntu's gntls package generates an Issuer line that looks like this:
        Issuer: C=US,ST=NY,L=Rochester,O=example.com,CN=example.com CA,EMAIL=hostmaster@example.com

While Red Hat's looks like this
Issuer: CN=Red Hat Emerging Technologies

Note the leading whitespace, and the additional fields in the former.

This patch updates the regular expression to:
 * trim leading characters before "Issuer:"
 * trim anything between Issuer: and CN=
 * trim anything after the next ,

I've tested this against the certool output of both RH and Ubuntu
generated certs.

Signed-off-by: Dustin Kirkland <kirkland@canonical.com>
Signed-off-by: Eric Blake <eblake@redhat.com>
15 years agoqemudDomainSaveFlag: remove dead store
Jim Meyering [Thu, 29 Apr 2010 15:56:01 +0000 (17:56 +0200)] 
qemudDomainSaveFlag: remove dead store

* src/qemu/qemu_driver.c (qemudDomainSaveFlag): Remove dead store to "rc".

15 years agoFix detection of disk in IO events
Daniel P. Berrange [Wed, 28 Apr 2010 14:14:47 +0000 (15:14 +0100)] 
Fix detection of disk in IO events

When using -device syntax, the IO event will have a different
prefix, 'drive-' that needs to be skipped over before matching
against the libvirt disk alias

* src/qemu/qemu_driver.c: Skip QEMU_DRIVE_HOST_PREFIX in IO event

15 years agoImplement python binding for virDomainGetBlockInfo
Daniel P. Berrange [Wed, 28 Apr 2010 12:42:13 +0000 (13:42 +0100)] 
Implement python binding for virDomainGetBlockInfo

This binds the virDomainGetBlockInfo API to python's blockInfo
method on the domain object

>>> c = libvirt.openReadOnly('qemu:///session')
>>> d = c.lookupByName('demo')
>>> f = d.blockInfo("/dev/loop0", 0)
>>> print f
[1048576000L, 104857600L, 104857600L]

* python/libvirt-override-api.xml: Define override signature
* python/generator.py: Skip C impl generator for virDomainGetBlockInfo
* python/libvirt-override.c: Manual impl of virDomainGetBlockInfo

15 years agoAdd new domblkinfo command to virsh
Daniel P. Berrange [Tue, 27 Apr 2010 19:31:58 +0000 (20:31 +0100)] 
Add new domblkinfo command to virsh

  virsh # domblkinfo demoguest /dev/hda2
  Capacity:       1048576000
  Allocation:     104857600
  Physical:       104857600

* tools/virsh.c: Implement domblkinfo command mapping to the
  new virDomainGetBlockInfo API

15 years agoImplement virDomainGetBlockInfo in QEMU driver
Daniel P. Berrange [Tue, 27 Apr 2010 19:31:09 +0000 (20:31 +0100)] 
Implement virDomainGetBlockInfo in QEMU driver

* src/qemu/qemu_driver.c: Implementation of virDomainGetBlockInfo
* src/util/storage_file.h: Add DEV_BSIZE
* src/storage/storage_backend.c: Remove DEV_BSIZE

15 years agoRemote protocol impl for virDomainGetBlockInfo
Daniel P. Berrange [Tue, 27 Apr 2010 19:29:15 +0000 (20:29 +0100)] 
Remote protocol impl for virDomainGetBlockInfo

* daemon/remote.c: Server side dispatcher
* daemon/remote_dispatch_args.h, daemon/remote_dispatch_prototypes.h,
  daemon/remote_dispatch_ret.h, daemon/remote_dispatch_table.h: Update
  with new API
* src/remote/remote_driver.c: Client side dispatcher
* src/remote/remote_protocol.c, src/remote/remote_protocol.h: Update
* src/remote/remote_protocol.x: Define new wire protocol

15 years agoInternal driver API infrastructure for virDomainGetBlockInfo
Daniel P. Berrange [Tue, 27 Apr 2010 19:27:34 +0000 (20:27 +0100)] 
Internal driver API infrastructure for virDomainGetBlockInfo

This defines the internal driver API and stubs out each driver

* src/driver.h: Define virDrvDomainGetBlockInfo signature
* src/libvirt.c, src/libvirt_public.syms: Glue public API to drivers
* src/esx/esx_driver.c, src/lxc/lxc_driver.c, src/opennebula/one_driver.c,
  src/openvz/openvz_driver.c, src/phyp/phyp_driver.c,
  src/test/test_driver.c, src/uml/uml_driver.c, src/vbox/vbox_tmpl.c,
  src/xen/xen_driver.c, src/xenapi/xenapi_driver.c: Stub out driver

15 years agoAdd virDomainGetBlockInfo API to query disk sizing
Daniel P. Berrange [Tue, 27 Apr 2010 19:24:30 +0000 (20:24 +0100)] 
Add virDomainGetBlockInfo API to query disk sizing

Some applications need to be able to query a guest's disk info,
even for paths not managed by the storage pool APIs. This adds
a very simple API to get this information, modelled on the
virStorageVolGetInfo API, but with an extra field 'physical'.
Normally 'physical' and 'allocation' will be identical, but
in the case of a qcow2-like file stored inside a block device
'physical' will give the block device size, while 'allocation'
will give the qcow2 image size

* include/libvirt/libvirt.h.in: Define virDomainGetBlockInfo

15 years agoFix a virsh edit memory leak
Chris Lalancette [Wed, 28 Apr 2010 19:50:06 +0000 (15:50 -0400)] 
Fix a virsh edit memory leak

When running virsh edit, we are unlinking and setting
the tmp variable to NULL before going to the end of the
function, meaning that we never free tmp.  Since the
exit to the function will always unlink and free tmp,
just remove this bit of code and let it get done at the
end.

Signed-off-by: Chris Lalancette <clalance@redhat.com>
15 years agoFix a qemuDomainPCIAddressSetFree memory leak
Chris Lalancette [Wed, 28 Apr 2010 19:49:41 +0000 (15:49 -0400)] 
Fix a qemuDomainPCIAddressSetFree memory leak

qemuDomainPCIAddressSetFree was freeing up the hash
table for the pci addresses, but not freeing up the addr
structure.  Looking over the callers of this function, it
seems like they expect it to also free up the structure,
so do that here.

Signed-off-by: Chris Lalancette <clalance@redhat.com>
15 years agoFix a memory leak in the node_device_udev code
Chris Lalancette [Wed, 28 Apr 2010 19:49:10 +0000 (15:49 -0400)] 
Fix a memory leak in the node_device_udev code

We were over-writing a pointer without freeing it in
case of a disk device, leading to a memory leak.

Signed-off-by: Chris Lalancette <clalance@redhat.com>
15 years agoFix build on Ubuntu.
Chris Lalancette [Mon, 26 Apr 2010 13:41:07 +0000 (09:41 -0400)] 
Fix build on Ubuntu.

When building on Ubuntu with make -j3 (or more), it would always
fail when trying to build virt-aa-helper.  I'm not an expert in
automake by any means, but I think the entry for virt-aa-helper
is mis-using LDADD; it shouldn't be putting direct paths to
libvirt_conf.la and libvirt_util.la, but instead referencing those
names.  With this patch in place, I'm able to successfully build
on Ubuntu 9.04 with make -j3.

Signed-off-by: Chris Lalancette <clalance@redhat.com>
15 years agoReport better error if qemuSnapshotIsAllowed failed.
Chris Lalancette [Fri, 23 Apr 2010 15:59:23 +0000 (11:59 -0400)] 
Report better error if qemuSnapshotIsAllowed failed.

Signed-off-by: Chris Lalancette <clalance@redhat.com>