]> xenbits.xensource.com Git - people/liuw/libxenctrl-split/libvirt.git/log
people/liuw/libxenctrl-split/libvirt.git
9 years agoqemu: Fix numatune nodeset reporting
Martin Kletzander [Mon, 18 May 2015 21:55:10 +0000 (14:55 -0700)]
qemu: Fix numatune nodeset reporting

Since af2a1f0587d88656f2c14265a63fbc11ecbd924e,
qemuDomainGetNumaParameters() returns invalid value for a running
guest.  The problem is that it is getting the information from cgroups,
but the parent cgroup is being left alone since the mentioned commit.
Since the running guest's XML is in sync with cgroups, there is no need
to look into cgroups (unless someone changes the configuration behind
libvirt's back).  Returning the info from the definition fixes a bug and
is also a cleanup.

Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1221047
Signed-off-by: Martin Kletzander <mkletzan@redhat.com>
9 years agoxenconfig: fix spice mousemode and copypaste
Jim Fehlig [Thu, 23 Apr 2015 23:00:26 +0000 (17:00 -0600)]
xenconfig: fix spice mousemode and copypaste

From xl.cfg950 man page:

spiceagent_mouse=BOOLEAN
Whether SPICE agent is used for client mouse mode. The default is
true (1) (turn on)

spicevdagent=BOOLEAN
Enables spice vdagent. The Spice vdagent is an optional component for
enhancing user experience and performing guest-oriented management
tasks. Its features includes: client mouse mode (no need to grab
mouse by client, no mouse lag), automatic adjustment of screen
resolution, copy and paste (text and image) between client and domU.
It also requires vdagent service installed on domU o.s. to work.
The default is 0.

spice_clipboard_sharing=BOOLEAN
Enables Spice clipboard sharing (copy/paste). It requires spicevdagent
enabled. The default is false (0).

So if spiceagent_mouse is enabled (client mouse mode) or
spice_clipboard_sharing is enabled, spicevdagent must be enabled.
Along with this change, s/spicedvagent/spicevdagent, set
spiceagent_mouse correctly, and add a test for these spice
features.

Signed-off-by: Jim Fehlig <jfehlig@suse.com>
9 years agoxenconfig: fix spicepasswd handling
Jim Fehlig [Thu, 23 Apr 2015 22:00:45 +0000 (16:00 -0600)]
xenconfig: fix spicepasswd handling

The logic related to spicedisable_ticketing and spicepasswd was
inverted.  As per man xl.cfg(5), 'spicedisable_ticketing = 1'
means no passwd is required.  On the other hand, a passwd is
required if 'spicedisable_ticketing = 0'.  Fix the logic and
produce and error if 'spicedisable_ticketing = 0' but spicepasswd
is not provided.  Also fix the spice cfg test file.

Signed-off-by: Jim Fehlig <jfehlig@suse.com>
9 years agoxenconfig: format spice listenAddr when formating ports
Jim Fehlig [Thu, 23 Apr 2015 21:42:50 +0000 (15:42 -0600)]
xenconfig: format spice listenAddr when formating ports

Move formating of spice listenAddr to the section of code
where spice ports are formatted.  It is more logical to
format address and ports together.  Account for the change
in spice cfg test file by moving 'spicehost'.

Signed-off-by: Jim Fehlig <jfehlig@suse.com>
9 years agoxenconfig: use local variable for graphics def
Jim Fehlig [Thu, 23 Apr 2015 21:26:04 +0000 (15:26 -0600)]
xenconfig: use local variable for graphics def

'graphics->' is a bit easier to read and type, and makes for
shorter lines than 'def->graphics[0]->'.

Signed-off-by: Jim Fehlig <jfehlig@suse.com>
9 years agonode_device: replace duplicated code in hal and udev backends
Laine Stump [Mon, 11 May 2015 17:50:37 +0000 (13:50 -0400)]
node_device: replace duplicated code in hal and udev backends

Both the hal and udev drivers call virPCI*() functions to the the
SRIOV VF/PF info about PCI devices, and the UDEV backend calls
virPCI*() to get IOMMU group info. Since there is now a single
function call in node_device_linux_sysfs.c to do all of this, replace
all that code in the two backends with calls to
nodeDeviceSysfsGetPCIRelatedDevCaps().

Note that this results in the HAL driver (probably) unnecessarily
calling virPCIDevieAddressGetIOMMUGroupNum(), but in the case that the
host doesn't support IOMMU groups, that function turns into a NOP (it
returns -2, which causes the caller to skip the call to
virPCIDeviceAddressGetIOMMUGroupAddresses()). So in the worst case it
is a few extra cycles spent, and in the best case a mythical platform
that supported IOMMU groups but used HAL rather than UDEV would gain
proper reporting of IOMMU group info.

9 years agonode_device: update sriov/iommu info before dumpxml of a device
Laine Stump [Mon, 11 May 2015 17:40:21 +0000 (13:40 -0400)]
node_device: update sriov/iommu info before dumpxml of a device

Because reloading a PF driver with a different number of VFs doesn't
result in any sort of event sent from udev to the libvirt node_device
driver, libvirt's cache of that info can be out of date when a request
arrives for the info about a device. To fix this, we refresh that data
at the time of the dumpxml request, similar to what is already done
for netdev link info and SCSI host capabilities.

Since the same is true for iommu group information (for example, some
other device in the same iommu group could have been detached from the
host), we also create a function to update the iommu group info from
sysfs, and a common function that does both. (a later patch will call
this common function from the udev and hal backends).

This resolves:

  https://bugzilla.redhat.com/show_bug.cgi?id=981546

9 years agonode_device: new functions to get sriov/iommu info from sysfs
Laine Stump [Mon, 11 May 2015 17:35:50 +0000 (13:35 -0400)]
node_device: new functions to get sriov/iommu info from sysfs

The udev and hal drivers both already call the same functions as these
new functions added to node_device_linux_sysfs.c, but 1) we need to
call them from node_device_driver.c, and 2) it would be nice to
eliminate the duplicated code from the hal and udev backends.

9 years agonode device: prepare node_device_linux_sysfs.c to add more functions
Laine Stump [Wed, 6 May 2015 20:40:39 +0000 (16:40 -0400)]
node device: prepare node_device_linux_sysfs.c to add more functions

This file contains only a single function, detect_scsi_host_caps(),
which is declared in node_device_driver.h and called from both the hal
and udev backends. Other things common to the hal and udev drivers
can be placed in that file though. As a prelude to adding further
functions, this patch renames the existing function to something
closer in line with other internal libvirt function names
(nodeDeviceSysfsGetSCSIHostCaps()), and puts the declarations into a
separate .h file.

9 years agonodedev: change if-else if in update_caps to switch
Laine Stump [Wed, 6 May 2015 17:51:47 +0000 (13:51 -0400)]
nodedev: change if-else if in update_caps to switch

Makes it nicer as update bits are added for different cap types.

9 years agoconf: make virNodeDevCapData an official type
Laine Stump [Fri, 8 May 2015 16:55:00 +0000 (12:55 -0400)]
conf: make virNodeDevCapData an official type

For some reason a union (_virNodeDevCapData) that had only been
declared inside the toplevel struct virNodeDevCapsDef was being used
as an argument to functions all over the place. Since it was only a
union, the "type" attribute wasn't necessarily sent with it. While
this works, it just seems wrong.

This patch creates a toplevel typedef for virNodeDevCapData and
virNodeDevCapDataPtr, making it a struct that has the type attribute
as a member, along with an anonymous union of everything that used to
be in union _virNodeDevCapData. This way we only have to change the
following:

  s/union _virNodeDevCapData */virNodeDevCapDataPtr /

and

  s/caps->type/caps->data.type/

This will make me feel less guilty when adding functions that need a
pointer to one of these.

9 years agovirsh: Improve handling of send-process-signal --pid.
Andrea Bolognani [Fri, 15 May 2015 16:14:41 +0000 (18:14 +0200)]
virsh: Improve handling of send-process-signal --pid.

Use vshCommandOptLongLong() instead of retrieving the value as a
string and converting it to a number manually.

9 years agovirsh: Fix dommemstat --period option type.
Andrea Bolognani [Fri, 15 May 2015 16:14:40 +0000 (18:14 +0200)]
virsh: Fix dommemstat --period option type.

The option didn't have VSH_OT_INT type even thought it's expected
to be numeric, as shown by the fact that vshCommandOptInt() is later
used to retrieve its value.

9 years agovirsh: Improve error message on integer value parsing failure.
Andrea Bolognani [Fri, 15 May 2015 16:14:39 +0000 (18:14 +0200)]
virsh: Improve error message on integer value parsing failure.

Replace more than 30 ad-hoc error messages with a single, generic one
that contains the name of the option being processed and some hints
to help the user understand what could have gone wrong.

Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1207043

9 years agolibvirt: tests: test protected key mgmt ops support
Tony Krowiak [Mon, 27 Apr 2015 21:57:30 +0000 (17:57 -0400)]
libvirt: tests: test protected key mgmt ops support

Test the support for enabling/disabling CPACF protected key management
operations for a guest.

Signed-off-by: Tony Krowiak <akrowiak@linux.vnet.ibm.com>
Signed-off-by: Viktor Mihajlovski <mihajlov@linux.vnet.ibm.com>
Reviewed-by: Boris Fiuczynski <fiuczy@linux.vnet.ibm.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
9 years agolibvirt: qemu: enable/disable protected key management ops
Tony Krowiak [Mon, 27 Apr 2015 21:57:29 +0000 (17:57 -0400)]
libvirt: qemu: enable/disable protected key management ops

Introduces two new -machine option parameters to the QEMU command to
enable/disable the CPACF protected key management operations for a guest:

    aes-key-wrap='on|off'
    dea-key-wrap='on|off'

The QEMU code maps the corresponding domain configuration elements to the
QEMU -machine option parameters to create the QEMU command:

    <cipher name='aes' state='on'>   --> aes-key-wrap=on
    <cipher name='aes' state='off'>  --> aes-key-wrap=off
    <cipher name='dea' state='on'>   --> dea-key-wrap=on
    <cipher name='dea' state='off'>  --> dea-key-wrap=off

Signed-off-by: Tony Krowiak <akrowiak@linux.vnet.ibm.com>
Signed-off-by: Daniel Hansel <daniel.hansel@linux.vnet.ibm.com>
Signed-off-by: Boris Fiuczynski <fiuczy@linux.vnet.ibm.com>
Reviewed-by: Boris Fiuczynski <fiuczy@linux.vnet.ibm.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
9 years agolibvirt: Introduce protected key mgmt ops
Tony Krowiak [Mon, 27 Apr 2015 21:57:27 +0000 (17:57 -0400)]
libvirt: Introduce protected key mgmt ops

Two new domain configuration XML elements are added to enable/disable
the protected key management operations for a guest:

    <domain>
      ...
      <keywrap>
        <cipher name='aes|dea' state='on|off'/>
      </keywrap>
      ...
    </domain>

Signed-off-by: Tony Krowiak <akrowiak@linux.vnet.ibm.com>
Signed-off-by: Viktor Mihajlovski <mihajlov@linux.vnet.ibm.com>
Signed-off-by: Daniel Hansel <daniel.hansel@linux.vnet.ibm.com>
Reviewed-by: Boris Fiuczynski <fiuczy@linux.vnet.ibm.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
9 years agolibxl: provide impl for nodeGetSecurityModel
Jim Fehlig [Fri, 15 May 2015 18:26:30 +0000 (12:26 -0600)]
libxl: provide impl for nodeGetSecurityModel

Currently, the libxl driver does not support any security drivers.
When the qemu driver has no security driver configued,
nodeGetSecurityModel succeeds but returns an empty virSecurityModel
object.  Do the same in the libxl driver instead of reporting

this function is not supported by the connection driver:
virNodeGetSecurityModel

9 years agoqemu: log error when domain has an unsupported IDE controller
Laine Stump [Thu, 30 Apr 2015 20:59:04 +0000 (16:59 -0400)]
qemu: log error when domain has an unsupported IDE controller

We have previously effectively ignored all <controller type='ide'>
elements in a domain definition.

On the i440fx-based machinetypes there is an IDE controller that is
included in the chipset and can't be removed (which is the ide
controller with index='0'>), so it makes sense to ignore that one
controller. However, if an i440fx domain definition has a 2nd
controller, nothing catches this error (unless you also have a disk
attached to it, in which case qemu will complain that you're trying to
use the ide controller named "ide1", which doesn't exist), and if any
other type of domain has even a single controller defined, it will be
incorrectly ignored.

Ignoring a bogus controller definition isn't such a big problem, as
long as an error is logged when any disk is attached to that
non-existent controller. But in the case of q35-based machinetypes,
the hardcoded id ("alias" in libvirt terms) of its builtin SATA
controller is "ide", which happens to be the same id as the builtin
IDE controller on i440fx machinetypes. So libvirt creates a
commandline believing that it is connecting the disk to the builtin
(but actually nonexistent) IDE controller, qemu thinks that libvirt
wanted that disk connected to the builtin SATA controller, and
everybody is happy.

Until you try to connect a 2nd disk to the IDE controller. Then qemu
will complain that you're trying to set unit=1 on a controller that
requires unit=0 (SATA controllers are organized differently than IDE
controllers).

After this patch, if a domain has an IDE controller defined for a
machinetype that has no IDE controllers, libvirt will log an error
about the controller itself as it is building the qemu commandline
(rather than a (possible) error from qemu about disks attached to that
controller). This is done by adding IDE to the list of controller
types that are handled in the loop that creates controller command
strings in qemuBuildCommandline() (previously it would *always* skip
IDE controllers). Then qemuBuildControllerDevStr() is modified to log
an appropriate error in the case of IDE controllers.

In the future, if we add support for extra IDE controllers (piix3-ide
and/or piix4-ide) we can just add it into the IDE case in
qemuBuildControllerDevStr(). For now, nobody seems anxious to add
extra support for an aging and very slow controller, when there are so
many better options available.

Resolves:

https://bugzilla.redhat.com/show_bug.cgi?id=1176071 (Fedora)

9 years agoqemu: clean up qemuBuildCommandline loop that builds controller args
Laine Stump [Thu, 14 May 2015 15:10:22 +0000 (11:10 -0400)]
qemu: clean up qemuBuildCommandline loop that builds controller args

Reorganize the loop that builds controller args to remove unnecessary
duplicated code and superfluous else clauses. No functional change.

9 years agoqemu: remove test for allowing ide controller in s390, rename usb tests
Laine Stump [Tue, 5 May 2015 17:09:42 +0000 (13:09 -0400)]
qemu: remove test for allowing ide controller in s390, rename usb tests

Back in 2013, commit 877bc089 added in some tests that made sure no
error was generated on a domain definition that had an automatically
added usb controller if that domain didn't have a PCI bus to attach
the usb controller to. This was done because, at that time, libvirt
was automatically adding a usb controller to *any* domain definition
that didn't have one.  Along with permitting the controller, two
s390-specific tests were added to ensure this behavior was maintained
- one with <controller type='usb' model='none'/> and another (called
"s390-piix-controllers") that had both usb and ide controllers, but
nothing attached to them.

Then in February of this year, commit 09ab9dcc eliminated the annoying
auto-adding of a usb device for s390 and s390x machines, stating:

 "Since s390 does not support usb the default creation of a usb
  controller for a domain should not occur."

Although, as verified here, the s390 doesn't support usb, and usb
controllers aren't currently added to s390 domain definitions
automatically, there are likely still some domain definitions in the
wild that have a usb controller (which was added *by libvirt*, not by
the user), so we will keep the tests verifying that behavior for
now. But this patch changes the names of the tests to reflect that
they don't actually contain a valid s390 config; this way future
developers won't propagate the incorrect idea that an s390 virtual
machine can have a USB (or IDE) bus.

In the case of the IDE controller, though, libvirt has never
automatically added an IDE controller unless a user added an IDE disk
(which itself would have caused an error), and we specifically *do*
want to begin generating an error when someone tries to add an IDE
controller to a domain that can't support one. For that reason, while
renaming the sz390-piix-controllers patch, this patch removes the
<controller type='ide'...> from it (otherwise the upcoming patch would
break make check)

9 years agoqemu: use controller alias when constructing device/controller args
Laine Stump [Thu, 30 Apr 2015 17:19:10 +0000 (13:19 -0400)]
qemu: use controller alias when constructing device/controller args

This makes sure that that the commandlines generated for devices and
controller devices are all using the alias that has been set in the
controller's object as the id of the controller, rather than
hardcoding a printf (or worse, encoding exceptions to the standard
${controller}${index} into the logic)

Since this "fixes" the controller name used for the sata controller,
the commandline arg for the sata controller in the sata test case had
to be adjusted to be "sata0" instead of "ahci0". All other tests
remain unchanged, verifying that the patch causes no other functional
change.

Because the function that finds a controller alias based on a device
def requires a pointer to the full domainDef in order to get the list
of controllers, the arglist of a few functions had to have this added.

9 years agoqemu: fix exceptions in qemuAssignDeviceControllerAlias
Laine Stump [Tue, 12 May 2015 00:51:52 +0000 (20:51 -0400)]
qemu: fix exceptions in qemuAssignDeviceControllerAlias

There are a few extra exceptions that weren't being accounted for when
creating the alias for a controller. This resulted in 1) incorrect
status XML, and 2) exceptions/printfs of what *should* have been
directly available in the controller alias when constructing device
commandline arguments:

1) The primary (and only) IDE controller on a 440FX machinetype is
hardcoded to be "ide" in qemu.

2) The primary SATA controller on a 440FX machinetype is also
hardcoded to be "ide" in qemu.

3) On machinetypes that don't support multiple PCI buses, the PCI bus
is hardcoded in qemu to have the name "pci".

4) The first usb master controller is "usb", all others are the normal
"usb%d". (note that usb controllers that are not a "master" will have
the same index, and thus alias, as the master).

We needed to pass in the full domainDef and qemuCaps in order to
properly make the decisions about these exceptions.

9 years agoconf: utility to return alias of a controller based on type/index
Laine Stump [Wed, 29 Apr 2015 19:37:20 +0000 (15:37 -0400)]
conf: utility to return alias of a controller based on type/index

Because there are multiple potential reasons for an error, this
function logs any errors before returning NULL (since the caller won't
have the information needed to determine which was the reason for
failure).

9 years agoqemu: Don't give up on first error in qemuMigrationCancelDriverMirror
Jiri Denemark [Mon, 11 May 2015 18:15:43 +0000 (20:15 +0200)]
qemu: Don't give up on first error in qemuMigrationCancelDriverMirror

When cancelling drive mirror, always try to do that for all disks even
if it fails for some of them. Report the first error we saw.

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
9 years agoqemu: Keep track of what disks are being migrated
Jiri Denemark [Mon, 11 May 2015 18:10:06 +0000 (20:10 +0200)]
qemu: Keep track of what disks are being migrated

Instead of redoing the same filtering over and over everytime we need to
walk through all disks which are being migrated.

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
9 years agoMove QEMU-only fields from virDomainDiskDef into privateData
Jiri Denemark [Wed, 13 May 2015 09:20:36 +0000 (11:20 +0200)]
Move QEMU-only fields from virDomainDiskDef into privateData

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
9 years agoRename virDomainHasBlockjob as qemuDomainHasBlockjob
Jiri Denemark [Wed, 13 May 2015 07:47:21 +0000 (09:47 +0200)]
Rename virDomainHasBlockjob as qemuDomainHasBlockjob

And move it to qemu_domain.[ch] because this API is QEMU-only.

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
9 years agoAdd privateData to virDomainDiskDef
Jiri Denemark [Wed, 13 May 2015 07:00:02 +0000 (09:00 +0200)]
Add privateData to virDomainDiskDef

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
9 years agoreject out of range memory in SetMemory APIs
Ján Tomko [Tue, 5 May 2015 15:58:49 +0000 (17:58 +0200)]
reject out of range memory in SetMemory APIs

The APIs take the memory value in KiB and we store it in KiB
internally, but we cannot parse the whole ULONG_MAX range
on 64-bit systems, because virDomainParseScaledValue
needs to fit the value in bytes in an unsigned long long.

https://bugzilla.redhat.com/show_bug.cgi?id=1176739

9 years agoSome alignment fixes in lxc_controller and jsontest
Martin Kletzander [Tue, 12 May 2015 12:40:34 +0000 (14:40 +0200)]
Some alignment fixes in lxc_controller and jsontest

Again, a clean-up for which we don't have proper syntax-check.

Signed-off-by: Martin Kletzander <mkletzan@redhat.com>
9 years agogendispatch: Don't generate long lines
Martin Kletzander [Thu, 7 May 2015 08:02:32 +0000 (10:02 +0200)]
gendispatch: Don't generate long lines

We don't allow it in normal code, why would it need to be in the
generated one.  IT also splits the line in perl code so it's readable.

Signed-off-by: Martin Kletzander <mkletzan@redhat.com>
9 years agovirnetserver: Remove unnecessary double space
Martin Kletzander [Thu, 7 May 2015 08:01:50 +0000 (10:01 +0200)]
virnetserver: Remove unnecessary double space

Since we don't have syntax-check for this, it has to be checked
manually.  Let's hope this is the only place it happened.

Signed-off-by: Martin Kletzander <mkletzan@redhat.com>
9 years agorpc: Don't mix max_clients and max_workers in PostExecRestart
Martin Kletzander [Thu, 7 May 2015 08:01:32 +0000 (10:01 +0200)]
rpc: Don't mix max_clients and max_workers in PostExecRestart

This only affected the servers that re-exec themselves, which is only
virtlockd and it didn't do any mess, so this is mostly a clenaup.

Signed-off-by: Martin Kletzander <mkletzan@redhat.com>
9 years agoqemu: Clear autofil fill flag when pinning iothread
John Ferlan [Wed, 6 May 2015 14:19:30 +0000 (10:19 -0400)]
qemu: Clear autofil fill flag when pinning iothread

https://bugzilla.redhat.com/show_bug.cgi?id=1218577

Treat pinning an IOThread via API as if someone added an IOThread to
ensure the iothreadid doesn't cause the guest to disappear

9 years agoconf: Expose iothreadids when delete non sequential iothreadids
John Ferlan [Wed, 6 May 2015 14:13:54 +0000 (10:13 -0400)]
conf: Expose iothreadids when delete non sequential iothreadids

Since 'autofill'd iothreadid entries are not written during XML format
processing, it is possible that if an iothreadid in the middle of an
autofilled list would then change it's id on a subsequent restart.

Thus during the iothreadid deletion, if we determine the delete is not
the "last" thread, then clear the autofill bit for all iothreadid's
following the one being deleted (either the first or one in the middle).
This way, iothreadid's will be printed/saved.

9 years agovirsh: Report an error when cpulist parsing fails
Luyao Huang [Mon, 11 May 2015 08:25:19 +0000 (16:25 +0800)]
virsh: Report an error when cpulist parsing fails

When parsing a cpulist, the virBitmapParse is used. On an invalid
bitmap an error is reported, but the error gets cleared
immediately by subsequent public APIs call, e.g. virDomainFree().
Moreover, we don't check whether bitmap fits into maximal CPU ID
on the host. Therefore the following examples failed without any
error:

 # virsh vcpupin test3 1 aaa

 # virsh vcpupin test3 1 1000

Signed-off-by: Luyao Huang <lhuang@redhat.com>
9 years agoparallels: remove connection wide wait timeout
Nikolay Shirokovskiy [Wed, 13 May 2015 14:23:00 +0000 (17:23 +0300)]
parallels: remove connection wide wait timeout

We have a lot of passing arguments code just to pass connection
object cause it holds jobTimeout. Taking into account that
right now this value is defined at compile time let's just
get rid of it and make arguments list more clear in many
places.

In case we later need some runtime configurable timeout
value we can provide this value through arguments
function already operate such as a parallels domain
object etc as this timeouts are operation( and thus
object) specific in practice.

Signed-off-by: Nikolay Shirokovskiy <nshirokovskiy@parallels.com>
9 years agoqemuMigrationPrepareAny: Drop useless variable @now
zhang bo [Wed, 13 May 2015 05:56:00 +0000 (13:56 +0800)]
qemuMigrationPrepareAny: Drop useless variable @now

As of eeb008dbfcf31 the variable is not used anymore. Drop it.

Signed-off-by: Wang Yufei <james.wangyufei@huawei.com>
Signed-off-by: Zhang Bo <oscar.zhangbo@huawei.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
9 years agomaint: Ignore Vim swap files
Andrea Bolognani [Tue, 5 May 2015 11:34:06 +0000 (13:34 +0200)]
maint: Ignore Vim swap files

This removes some noise when you're working on the repository
and also have a bunch of source files open in Vim in another
terminal.

9 years agoFix build --without-network
Martin Kletzander [Mon, 27 Apr 2015 11:25:51 +0000 (13:25 +0200)]
Fix build --without-network

In order not to bring in any link dependencies, bridge driver doesn't
use the usual stubs as other conditionally-built code does.  However,
having the function as a macro imposes a problem with possibly unused
variables if just defined as "0".  This was worked around by using
(dom=dom, iface=iface, 0) which should act like a 0 if used in a
condition.  However, gcc still bugs about that, so I came up with
another way how to fix that.

Using static inline functions in the header won't collide with anything,
it fixes the bug and does one thing that the macro didn't do.  It checks
whenther passed variables are pointers of compatible type.  It has only
one downside, and that is that we need to either a) define it with
ATTRIBUTE_UNUSED, which needs an exception in cfg.mk or b) do something
like ignore_value(variable); in the function body.  I went with the
first variant.

Signed-off-by: Martin Kletzander <mkletzan@redhat.com>
9 years agoAssign virtio-serial addresses after coldplugging a device
Ján Tomko [Thu, 7 May 2015 11:15:06 +0000 (13:15 +0200)]
Assign virtio-serial addresses after coldplugging a device

Otherwise we might allow coldplugging a device
that uses an address that is already occupied, creating
an unstartable domain.

https://bugzilla.redhat.com/show_bug.cgi?id=1220195

9 years agoqemu: vnc: error out for invalid port number
Pavel Hrdina [Tue, 12 May 2015 16:18:14 +0000 (18:18 +0200)]
qemu: vnc: error out for invalid port number

In the XML we have the vnc port number, but QEMU takes on command line
a vnc screen number, it's port-5900.  We should fail with error message
that only ports in range [5900,65535] are valid.

Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1164966

Signed-off-by: Pavel Hrdina <phrdina@redhat.com>
9 years agovirSysinfoParseProcessor: Drop useless check for NULL
Michal Privoznik [Tue, 12 May 2015 15:49:59 +0000 (17:49 +0200)]
virSysinfoParseProcessor: Drop useless check for NULL

VIR_STRDUP plays nicely with NULLs. Theres no need to guard its
call with check for non-NULL.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
9 years agolibxl: support VNC passwd
Jim Fehlig [Tue, 28 Apr 2015 00:20:30 +0000 (18:20 -0600)]
libxl: support VNC passwd

While implementing support for SPICE, I noticed VNC passwd was
never copied to libxl_device_vfb's vnc.passwd field.

Signed-off-by: Jim Fehlig <jfehlig@suse.com>
9 years agoconf: Remove source host name check for iSCSI
John Ferlan [Mon, 11 May 2015 17:51:04 +0000 (13:51 -0400)]
conf: Remove source host name check for iSCSI

https://bugzilla.redhat.com/show_bug.cgi?id=1171984
https://bugzilla.redhat.com/show_bug.cgi?id=1188463

Remove the check for the source host name for iSCSI source XML processing
declaring duplicate sources when the source device path and if present the
initiator of a proposed storage pool matches an existing storage pool.

The backend iSCSI storage driver uses 'iscsiadm --mode session' to query
available iscsid target sessions. The output displayed is the IP address
and the IQN (target path) of known targets. The displayed IP address
is a resolved address based on the session --login. Additionally, iscsid
keeps track of the various ways to define the host name (IPv4 Address,
IPv6 Address, /etc/hosts, etc.) for that IQN (see output of an 'iscsiadm
--mode node'). If an incoming IQN matches and the host name provided by
libvirt is resolved to the existing IQN, then iscsid will "reuse" the
session. Although libvirt could do the same name resolution, if there
is a difference, iscsid could still declare two seemingly different sources
to be the same and not create a new session which means libvirt now has
two storage pools looking at the same source. Thus to avoid any strange
host name resolution issues, just rely on iscsid for that and do not
allow multiple pools on the same host to use the same device path (IQN).

9 years agoconf: Adjust duplicate source host port check
John Ferlan [Mon, 11 May 2015 14:19:39 +0000 (10:19 -0400)]
conf: Adjust duplicate source host port check

Only perform the port number check if the incoming definition actually
provides it. Since the port number is optional we could erroneously pass
a duplicate source host check since some storage pool backends which fill
in the default port number (e.g., iSCSI and sheepdog) for the started pool.

9 years agoqemu: fix double free when RNG cold-plug fails
Luyao Huang [Tue, 12 May 2015 13:55:05 +0000 (21:55 +0800)]
qemu: fix double free when RNG cold-plug fails

https://bugzilla.redhat.com/show_bug.cgi?id=1220809

When cold-plugging an RNG device but something fails in
qemuDomainAssignAddresses, we will double free the RNG device.
Once a device is plugged into the domain, we should set the
device pointer to NULL to fix this issue.

...
5  0x00007fb7d180ac8a in virFree at util/viralloc.c:582
6  0x00007fb7d1895cdd in virDomainRNGDefFree at conf/domain_conf.c:19786
7  0x00007fb7d1895d99 in virDomainDeviceDefFree at conf/domain_conf.c:2022
8  0x00007fb7b92b8baf in qemuDomainAttachDeviceFlags at qemu/qemu_driver.c:8785
9  0x00007fb7d190c5d7 in virDomainAttachDeviceFlags at libvirt-domain.c:8488
10 0x00007fb7d23af9d2 in remoteDispatchDomainAttachDeviceFlags at remote_dispatch.h:2842
...

Signed-off-by: Luyao Huang <lhuang@redhat.com>
9 years agodaemon: Suppress logging of VIR_ERR_NO_DOMAIN_METADATA
Peter Krempa [Tue, 12 May 2015 11:55:30 +0000 (13:55 +0200)]
daemon: Suppress logging of VIR_ERR_NO_DOMAIN_METADATA

Similarly to other error codes that notify the user that the object does
not exist lower the priority of VIR_ERR_NO_DOMAIN_METADATA to
VIR_LOG_DEBUG when writing the log entry.

9 years agoconf_capabilities: fix wrong indentation
Pavel Hrdina [Tue, 12 May 2015 10:12:58 +0000 (12:12 +0200)]
conf_capabilities: fix wrong indentation

Signed-off-by: Pavel Hrdina <phrdina@redhat.com>
9 years agoXML: escape strings where we should do it
Pavel Hrdina [Tue, 5 May 2015 14:52:46 +0000 (16:52 +0200)]
XML: escape strings where we should do it

There is a lot of places, were it's pretty easy for user to enter some
characters that we need to escape to create a valid XML description.

Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1197580

Signed-off-by: Pavel Hrdina <phrdina@redhat.com>
9 years agoDocument that virNodeGetInfo can return mhz == 0.
Richard W.M. Jones [Mon, 11 May 2015 20:24:36 +0000 (21:24 +0100)]
Document that virNodeGetInfo can return mhz == 0.

On the s/390x architecture, libvirt may already return 0 in the
node_info->mhz field (see src/nodeinfo.c:linuxNodeInfoCPUPopulate).

We may also want to return this on aarch64 in future, because
calculating the proper value requires SMBIOS, which is not available
on non-server-class systems (specifically on systems which don't
adhere to the SBSA standard).

Therefore this change documents the existing behaviour and provides a
valid path for aarch64.

Signed-off-by: Richard W.M. Jones <rjones@redhat.com>
Bug-URL: https://bugzilla.redhat.com/1206353

9 years agolibvirt-guests: Initialize SYNC_TIME
Michal Privoznik [Mon, 11 May 2015 16:18:39 +0000 (18:18 +0200)]
libvirt-guests: Initialize SYNC_TIME

https://bugzilla.redhat.com/show_bug.cgi?id=1191227

Since 0fa15b19 we have this variable SYNC_TIME which allows users to
synchronize time on domain resume. However, despite what documentation
says, it's by default on because it's never initialized. Fix this by
setting it to zero at the beginning of the libvirt-guests script.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
9 years agoqemu: eliminate duplicated code in qemuBuildDriveDevStr()
Laine Stump [Thu, 30 Apr 2015 16:51:51 +0000 (12:51 -0400)]
qemu: eliminate duplicated code in qemuBuildDriveDevStr()

The code to add device type to the commandline was identical for lsi
and other models of SCSI controllers, but was duplicated (with the
exception of a minor ordering difference of the if-else clauses) for
the two cases. This patch replaces those two with a single instance of
the code just before the if().

9 years agoqemu: use qemuDomainMachineIsI440FX() in appropriate place
Laine Stump [Wed, 29 Apr 2015 16:23:02 +0000 (12:23 -0400)]
qemu: use qemuDomainMachineIsI440FX() in appropriate place

This patch makes qemuValideDevicePCISlotsChipsets() more consistent in
appearance by replacing several clauses of an if with the equivalent
call to qemuDomainMachineIsI440FX. The if was checking exactly the
same items, just in a slightly different order.

9 years agomaint: extend PIE support check
Roman Bogorodskiy [Sat, 9 May 2015 16:06:36 +0000 (19:06 +0300)]
maint: extend PIE support check

GCC installed from FreeBSD ports doesn't support building PIE executables
and fails with:

/usr/local/bin/ld: /usr/lib/crt1.o: relocation R_X86_64_32 against
`_DYNAMIC' can not be used when making a shared object; recompile with
-fPIC
/usr/lib/crt1.o: error adding symbols: Bad value
collect2: error: ld returned 1 exit status

However, the configure check for '-fPIC -DPIC' doesn't catch that. In
order to catch this case, add '-pie' to CFLAGS in m4/virt-compile-pie.m4
so it could detect lack of PIE support on configure time and don't fail
the build.

9 years agobhyve: fix bhyvexml2argvtest build with gcc
Roman Bogorodskiy [Sat, 9 May 2015 15:10:50 +0000 (18:10 +0300)]
bhyve: fix bhyvexml2argvtest build with gcc

gcc5 reports an error like this:

bhyvexml2argvtest.c: In function 'testCompareXMLToArgvFiles':
bhyvexml2argvtest.c:24:18: error: variable 'vm' set but not used
[-Werror=unused-but-set-variable]
     virDomainObj vm;
                  ^
cc1: all warnings being treated as errors

Fix by dropping this variable.

9 years agoconf: Report error for unknown shmem ioeventfd value
Luyao Huang [Mon, 11 May 2015 12:59:37 +0000 (20:59 +0800)]
conf: Report error for unknown shmem ioeventfd value

https://bugzilla.redhat.com/show_bug.cgi?id=1220265

Passing the return value to an enum directly is not safe.  Fix this by
comparing the true integer result of virTristateSwitchTypeFromString().

Signed-off-by: Luyao Huang <lhuang@redhat.com>
9 years agoIgnore bridge template names with multiple printf conversions
Ján Tomko [Tue, 28 Apr 2015 15:07:20 +0000 (17:07 +0200)]
Ignore bridge template names with multiple printf conversions

For some reason, we allow a bridge name with %d in it, which we replace
with an unsigned integer to form a bridge name that does not yet exist
on the host.

Do not blindly pass it to virAsprintf if it's not the only conversion,
to prevent crashing on input like:

<network>
  <name>test</name>
  <forward mode='none'/>
  <bridge name='virbr%d%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s'/>
</network>

Ignore any template strings that do not have exactly one %d conversion,
like we do in various drivers before calling virNetDevTapCreateInBridgePort.

9 years agoqemu: Fix balloon size handling with memory hot(un)plug
Peter Krempa [Thu, 30 Apr 2015 16:03:41 +0000 (18:03 +0200)]
qemu: Fix balloon size handling with memory hot(un)plug

Since libvirt doesn't call to update the new balloon size in qemu add
code that will handle tweaking of the size of the current balloon
statistic until qemu reports the new size using the event.

9 years agoconf: Fix up balloon size after removing a memory device from def
Peter Krempa [Thu, 30 Apr 2015 15:43:53 +0000 (17:43 +0200)]
conf: Fix up balloon size after removing a memory device from def

To avoid having the ballooned memory size larger than the actual
physical memory size, truncate the ballooned size if it overflows.

9 years agoconf: Always truncate balloon size to maximum memory size
Peter Krempa [Thu, 30 Apr 2015 15:33:41 +0000 (17:33 +0200)]
conf: Always truncate balloon size to maximum memory size

Specifying a balloon size more than the memory size of a guest isn't
something that should be rejected when parsing the XML. Truncate the
size to the maximum memory size.

9 years agoqemu: Convert qemuConnectGetAllDomainStats to use new helpers
Peter Krempa [Wed, 29 Apr 2015 14:41:20 +0000 (16:41 +0200)]
qemu: Convert qemuConnectGetAllDomainStats to use new helpers

Use the new domain list collection helpers to avoid going through
virDomainPtrs.

This additionally implements filter capability when called through the
api that accepts domain list filters.

9 years agoconf: Add helper to convert list of virDomains to a list of virDomainObjs
Peter Krempa [Wed, 29 Apr 2015 14:15:53 +0000 (16:15 +0200)]
conf: Add helper to convert list of virDomains to a list of virDomainObjs

Add virDomainObjListConvert that will take a list of virDomains, apply
filters and return a list of virDomainObjs.

9 years agoconf: Refactor domain list collection critical section
Peter Krempa [Wed, 29 Apr 2015 12:11:09 +0000 (14:11 +0200)]
conf: Refactor domain list collection critical section

Until now the virDomainListAllDomains API would lock the domain list and
then every single domain object to access and filter it. This would
potentially allow a unresponsive VM to block the whole daemon if a
*listAllDomains call would get stuck.

To avoid this problem this patch collects a list of referenced domain
objects first from the list and then unlocks it right away. The
expensive operation requiring locking of the domain object is executed
after the list lock is dropped. While a single blocked domain will still
lock up a listAllDomains call, the domain list won't be held locked and
thus other APIs won't be blocked.

Additionally this patch also fixes the lookup code, where we'd ignore
the vm->removing flag and thus potentially return domain objects that
would be deleted very soon so calling any API wouldn't make sense.

As other clients also could benefit from operating on a list of domain
objects rather than the public domain descriptors a new intermediate
API - virDomainObjListCollect - is introduced by this patch.

Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1181074

9 years agoconf: Rename virDomainObjListFilter type to virDomainObjListACLFilter
Peter Krempa [Wed, 29 Apr 2015 13:25:34 +0000 (15:25 +0200)]
conf: Rename virDomainObjListFilter type to virDomainObjListACLFilter

The passed function is meant to filter domains according to ACL match.

9 years agoconf: Extract code to filter domain list into a separate function
Peter Krempa [Wed, 29 Apr 2015 11:18:37 +0000 (13:18 +0200)]
conf: Extract code to filter domain list into a separate function

Separate the code to simplify future refactors.

9 years agoutil: Make the virDomainListFree helper more universal
Peter Krempa [Wed, 29 Apr 2015 09:54:58 +0000 (11:54 +0200)]
util: Make the virDomainListFree helper more universal

Extend it to a universal helper used for clearing lists of any objects.
Note that the argument type is specifically void * to allow implicit
typecasting.

Additionally add a helper that works on non-NULL terminated arrays once
we know the length.

10 years agocaps: Fix regression defaulting to host arch
Cole Robinson [Wed, 6 May 2015 22:32:05 +0000 (18:32 -0400)]
caps: Fix regression defaulting to host arch

My commit 747761a79 (v1.2.15 only) dropped this bit of logic when filling
in a default arch in the XML:

-    /* First try to find one matching host arch */
-    for (i = 0; i < caps->nguests; i++) {
-        if (caps->guests[i]->ostype == ostype) {
-            for (j = 0; j < caps->guests[i]->arch.ndomains; j++) {
-                if (caps->guests[i]->arch.domains[j]->type == domain &&
-                    caps->guests[i]->arch.id == caps->host.arch)
-                    return caps->guests[i]->arch.id;
-            }
-        }
-    }

That attempt to match host.arch is important, otherwise we end up
defaulting to i686 on x86_64 host for KVM, which is not intended.
Duplicate it in the centralized CapsLookup function.

Additionally add some testcases that would have caught this.

https://bugzilla.redhat.com/show_bug.cgi?id=1219191

10 years agotests: Remove redundant aarch64 tests
Cole Robinson [Wed, 6 May 2015 23:04:52 +0000 (19:04 -0400)]
tests: Remove redundant aarch64 tests

My commit 7b9de914 added some aarch64 CPU test cases. I wanted to test
two different code paths but inadvertently added two of the same test
cases.

The second code path (using <cpu><model>host</model</cpu>) isn't easily
exercised via the qemu tests anyways, I'll need to look elsewhere.

Regardless, remove the redundant tests for now

10 years agoprocessSerialChangedEvent: Close agent monitor early
Michal Privoznik [Thu, 7 May 2015 09:19:38 +0000 (11:19 +0200)]
processSerialChangedEvent: Close agent monitor early

https://bugzilla.redhat.com/show_bug.cgi?id=890648

So, imagine you've issued an API that involves guest agent. For
instance, you want to query guest's IP addresses. So the API acquires
QUERY_JOB, locks the guest agent and issues the agent command.
However, for some reason, guest agent replies to initial ping
correctly, but then crashes tragically while executing real command
(in this case guest-network-get-interfaces). Since initial ping went
well, libvirt thinks guest agent is accessible and awaits reply to the
real command. But it will never come. What will is a monitor event.
Our handler (processSerialChangedEvent) will try to acquire
MODIFY_JOB, which will fail obviously because the other thread that's
executing the API already holds a job. So the event handler exits
early, and the QUERY_JOB is never released nor ended.

The way how to solve this is to put flag somewhere in the monitor
internals. The flag is called @running and agent commands are issued
iff the flag is set. The flag itself is set when we connect to the
agent socket. And unset whenever we see DISCONNECT event from the
agent. Moreover, we must wake up all the threads waiting for the
agent. This is done by signalizing the condition they're waiting on.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
10 years agoqemuDomainShutdownFlags: check for domain activeness prior to guest presence
Michal Privoznik [Wed, 6 May 2015 13:40:15 +0000 (15:40 +0200)]
qemuDomainShutdownFlags: check for domain activeness prior to guest presence

Running shutdown with mode agent on a shutoff domain gives cryptic
error message:

    virsh # shutdown --mode agent gentoo
    error: Failed to shutdown domain gentoo
    error: Guest agent is not responding: QEMU guest agent is not connected

After this patch, the error is more clear:

    virsh # shutdown --mode agent gentoo
    error: Failed to shutdown domain gentoo
    error: Requested operation is not valid: domain is not running

Reported-by: Martin Kletzander <mkletzan@redhat.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
10 years agolxc: don't up the veth interfaces unless explicitly asked to
Lubomir Rintel [Fri, 24 Apr 2015 13:52:56 +0000 (15:52 +0200)]
lxc: don't up the veth interfaces unless explicitly asked to

Upping an interface for no reason and not configuring it is a cardinal sin.

With the default addrgenmode if eui64 it sticks a link-local address to the
interface. That is not good, as NetworkManager would see an address configured,
assume the interface is already configured and won't touch it iself and the
interface might stay unconfigured until the end of the days.

Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1124721

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
10 years agoqemu: multiqueue for ccw devices
Boris Fiuczynski [Wed, 6 May 2015 14:07:40 +0000 (16:07 +0200)]
qemu: multiqueue for ccw devices

Allow ccw devices to be used with multiqueues. ccw provides a one to
one relation of fds to queues and does not support the vectors option.

Signed-off-by: Boris Fiuczynski <fiuczy@linux.vnet.ibm.com>
Reviewed-by: Matthew Rosato <mjrosato@linux.vnet.ibm.com>
Reviewed-by: Daniel Hansel <daniel.hansel@linux.vnet.ibm.com>
Reviewed-by: Cornelia Huck <cornelia.huck@de.ibm.com>
10 years agoqemu: Resolve Coverity FORWARD_NULL
John Ferlan [Tue, 5 May 2015 11:13:19 +0000 (07:13 -0400)]
qemu: Resolve Coverity FORWARD_NULL

Coverity points out that qemuMonitorGetAllBlockStatsInfo could return a
-1 and thus not fill in 'stats' (leaving it NULL). Then the call to
qemuMonitorBlockStatsUpdateCapacity will dereference it.

10 years agoqemu: Resolve Coverity FORWARD_NULL
John Ferlan [Tue, 5 May 2015 10:59:56 +0000 (06:59 -0400)]
qemu: Resolve Coverity FORWARD_NULL

Coverity complains over the [n]values pairing in virQEMUCapsFreeStringList
and rather than make a bunch if "if values" checks prior to calling, by
just adding the values check inside the free function we avoid the chance
that somehow nvalues is > 0, while values == NULL

10 years agoqemu: Resolve Coverity FORWARD_NULL
John Ferlan [Tue, 5 May 2015 10:53:24 +0000 (06:53 -0400)]
qemu: Resolve Coverity FORWARD_NULL

Coverity points out it was possible to have a zero return from
qemuBuildRNGBackendProps thus not filling in 'props' and then
causing a NULL dereference on the next call.

10 years agoxen: Resolve Coverity FORWARD_NULL
John Ferlan [Mon, 4 May 2015 16:00:40 +0000 (12:00 -0400)]
xen: Resolve Coverity FORWARD_NULL

Coverity found that xenXMConfigCacheAddFile has an error path in which
no error message and a -1 was not returned which could have resulted in
a NULL dereference in a VIR_DEBUG statement and of course an erroneous
0 value returned!

10 years agoqemu: Resolve Coverity FORWARD_NULL
John Ferlan [Fri, 1 May 2015 12:55:12 +0000 (08:55 -0400)]
qemu: Resolve Coverity FORWARD_NULL

Coverity notes that ->ifname is used after the VIR_FREE done in the
code path after the call to virNetDevMacVLanDeleteWithVPortProfile
by a call to virNetDevOpenvswitchRemovePort.

Since the ->ifname will be VIR_FREE()'d eventually in virDomainNetDefFree
just remove the extraneous VIR_FREE here.

When originally added, the Openvswitch code wasn't present and checks
were made for non NULL prior to use.

10 years agoqemu: Resolve Coverity IDENTICAL_BRANCHES
John Ferlan [Fri, 1 May 2015 11:55:29 +0000 (07:55 -0400)]
qemu: Resolve Coverity IDENTICAL_BRANCHES

Coverity complains that in the error paths both the < 0 condition and
the success path after the qemuDomainObjExitMonitor failure will end
up going to cleanup.  So just use ignore_value in this error path to
resolve the complaint.

10 years agovbox: Resolve Coverity RESOURCE_LEAK
John Ferlan [Fri, 1 May 2015 11:28:25 +0000 (07:28 -0400)]
vbox: Resolve Coverity RESOURCE_LEAK

If the virStringSearch() returns a 0 (zero), then each of the uses
of the call will just jump to cleanup forgetting to free the returned
empty list. Expand the scope a bit of each use and free at cleanup.

10 years agolibxl: Resolve Coverity RESOURCE_LEAK
John Ferlan [Fri, 1 May 2015 11:25:39 +0000 (07:25 -0400)]
libxl: Resolve Coverity RESOURCE_LEAK

The returned socks from virNetSocketNewListenTCP needs to be VIR_FREE'd
as well as seach of the Close/Unref on all the socks[i] that is
already done

10 years agolibxl: support soundhw for hvm domains
Jim Fehlig [Mon, 4 May 2015 19:50:10 +0000 (13:50 -0600)]
libxl: support soundhw for hvm domains

The xend driver and the parsing/formating code in src/xenconfig
have long supported soundhw.  Add support in the libxl driver too.

10 years agolibxl: add logrotate config file
Jim Fehlig [Thu, 30 Apr 2015 21:16:49 +0000 (15:16 -0600)]
libxl: add logrotate config file

Add logrotate config for log files in /var/log/libvirt/libxl.

10 years agodocs: fix a small xml error in docs
Luyao Huang [Mon, 30 Mar 2015 08:49:30 +0000 (16:49 +0800)]
docs: fix a small xml error in docs

Signed-off-by: Luyao Huang <lhuang@redhat.com>
10 years agoconf: Add the cpu duplicate use check for vm numa settings
Luyao Huang [Tue, 5 May 2015 10:13:38 +0000 (18:13 +0800)]
conf: Add the cpu duplicate use check for vm numa settings

https://bugzilla.redhat.com/show_bug.cgi?id=1176020

We had a check for the vcpu count total number in <numa>
before, however this check is not good enough. There are
some examples:

1. one of cpu id is out of maxvcpus, can set success(cpu count = 5 < 10):

<vcpu placement='static'>10</vcpu>
<cell id='0' cpus='0-3,100' memory='512000' unit='KiB'/>

2. use the same cpu in 2 cell, can set success(cpu count = 8 < 10):
<vcpu placement='static'>10</vcpu>
<cell id='0' cpus='0-3' memory='512000' unit='KiB'/>
<cell id='1' cpus='0-3' memory='512000' unit='KiB'/>

3. use the same cpu in 2 cell, cannot set success(cpu count = 11 > 10):
<vcpu placement='static'>10</vcpu>
<cell id='0' cpus='0-6' memory='512000' unit='KiB'/>
<cell id='1' cpus='0-3' memory='512000' unit='KiB'/>

Add a check for numa cpus, check if duplicate use one cpu in more
than one cell.

Signed-off-by: Luyao Huang <lhuang@redhat.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
10 years agoqemu: Implement GIC
Michal Privoznik [Mon, 27 Apr 2015 12:54:19 +0000 (14:54 +0200)]
qemu: Implement GIC

The only version that's supported in QEMU is version 2, currently.
Fortunately, it is enabled by aarch64 automatically, so there's
nothing for us that needs to be put onto command line.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
10 years agoIntroduce GIC feature
Michal Privoznik [Mon, 27 Apr 2015 12:03:19 +0000 (14:03 +0200)]
Introduce GIC feature

Some platforms, like aarch64, don't have APIC but GIC. So there's
no reason to have <apic/> feature turned on. However, we are
still missing <gic/> feature. This commit introduces the feature
to XML parser and formatter, adds documentation and updates RNG
schema.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
10 years agoqemu: Properly rename persistent def after migration
Jiri Denemark [Mon, 4 May 2015 20:21:23 +0000 (22:21 +0200)]
qemu: Properly rename persistent def after migration

When migrating a domain while changing its name and using
VIR_MIGRATE_PERSIST_DEST flag, libvirt would fail to properly change the
name in the persistent definition. The inconsistency results in weird
behavior when dumping domain XML, destroying the domain, restarting
libvirtd and likely in several other situations.

Since the new name is already stored in vm->def->name, we just need to
make sure the persistent definition uses this new name too.

https://bugzilla.redhat.com/show_bug.cgi?id=1076354

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
10 years agopolkit: Allow password-less access for 'libvirt' group
Cole Robinson [Tue, 28 Apr 2015 21:38:00 +0000 (17:38 -0400)]
polkit: Allow password-less access for 'libvirt' group

Many users, who admin their own machines, want to be able to access
system libvirtd via tools like virt-manager without having to enter
a root password. Just google 'virt-manager without password' and
you'll find many hits. I've read at least 5 blog posts over the years
describing slightly different ways of achieving this goal.

Let's finally add official support for this.

Install a polkit-1 rules file granting password-less auth for any user
in the new 'libvirt' group. Create the group on RPM install

https://bugzilla.redhat.com/show_bug.cgi?id=957300

10 years agostorage: fs: Don't try to chown directory unless user requested
Cole Robinson [Mon, 27 Apr 2015 20:48:05 +0000 (16:48 -0400)]
storage: fs: Don't try to chown directory unless user requested

Currently we try to chown any directory passed to virDirCreate,
even if the user didn't request any explicit owner/group via the
pool/vol XML.

This causes issues with qemu:///session: try to build a pool of
a root owned directory like /tmp, and it fails trying to chown the
directory to the session user. Instead it should just leave things
as they are, unless the user requests changing permissions via
the pool XML.

Similarly this is annoying if creating a storage pool via system
libvirtd of an existing directory in user $HOME, it's now owned
by root.

The virDirCreate function is pretty convoluted, since it needs to
fork off in certain specific cases. Try to document that, to make
it clear where exactly we are changing behavior.

10 years agostorage: fs: Don't attempt directory creation if it already exists
Cole Robinson [Mon, 27 Apr 2015 20:48:05 +0000 (16:48 -0400)]
storage: fs: Don't attempt directory creation if it already exists

The current code attempts to handle this, but it only catches mkdir
failing with EEXIST. However if say trying to build /tmp for an
unprivileged qemu:///session, mkdir will fail with EPERM.

Rather than catch any errors, just don't attempt mkdir if the directory
already exists.

10 years agostorage: fs: Fill in permissions on pool refresh
Cole Robinson [Mon, 27 Apr 2015 20:48:05 +0000 (16:48 -0400)]
storage: fs: Fill in permissions on pool refresh

This means pool XML actually reports accurate user/group/mode/label.

This uses UpdateVolTargetInfoFD in a bit of a hackish way, but it works

10 years agostorage: fs: Don't overwrite virDirCreate error
Cole Robinson [Mon, 27 Apr 2015 20:48:05 +0000 (16:48 -0400)]
storage: fs: Don't overwrite virDirCreate error

virDirCreate will give us fine grained details about what actually failed.

10 years agovirsh: Don't check migrate parameters
Jiri Denemark [Thu, 30 Apr 2015 12:47:46 +0000 (14:47 +0200)]
virsh: Don't check migrate parameters

Just pass anything a user specified to the appropriate API. It's the API
or libvirtd that should be responsible for checking its parameters.

https://bugzilla.redhat.com/show_bug.cgi?id=1066375
https://bugzilla.redhat.com/show_bug.cgi?id=1073233

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
10 years agoqemu: Forbid unsupported parameters for tunnelled migration
Jiri Denemark [Thu, 30 Apr 2015 13:56:07 +0000 (15:56 +0200)]
qemu: Forbid unsupported parameters for tunnelled migration

Neither migrate URI nor lister address make any sense for tunnelled
migration.

https://bugzilla.redhat.com/show_bug.cgi?id=1066375
https://bugzilla.redhat.com/show_bug.cgi?id=1073233

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
10 years agotests: Fix grammar in comments.
Andrea Bolognani [Tue, 28 Apr 2015 15:43:12 +0000 (17:43 +0200)]
tests: Fix grammar in comments.

Replace all occurrences of "stream write to differences to"
with "stream to write differences to".

10 years agotests: add machine vmport qemu test
Marc-André Lureau [Thu, 2 Apr 2015 16:44:44 +0000 (18:44 +0200)]
tests: add machine vmport qemu test

Check that the vmport feature is correctly used in qemu commande line.

10 years agoqemu: add machine vmport argument
Marc-André Lureau [Thu, 2 Apr 2015 16:44:08 +0000 (18:44 +0200)]
qemu: add machine vmport argument

Fill qemu command line vmport argument as required.

10 years agoqemu: add virQEMUCapsSupportsVmport
Marc-André Lureau [Tue, 21 Apr 2015 11:28:40 +0000 (13:28 +0200)]
qemu: add virQEMUCapsSupportsVmport

The vmport machine argument works with pc machine kind, not with xen for
example.