2010-12-16 16:10:54 +00:00
|
|
|
/*
|
|
|
|
* qemu_hotplug.h: QEMU device hotplug management
|
|
|
|
*
|
qemu: reorganize qemuDomainChangeNet and qemuDomainChangeNetBridge
This patch resolves:
https://bugzilla.redhat.com/show_bug.cgi?id=805071
to the extent that it can be resolved with current qemu functionality.
It attempts to detect as many situations as possible when the simple
operation of disconnecting an existing tap device from one bridge and
attaching it to another will satisfy the change requested in
virDomainUpdateDeviceFlags() for a network device. Before this patch,
that situation could only be detected if the pre-change interface
*and* the post-change interface definition were both "type='bridge'".
After this patch, it can also be detected if the before or after
interfaces are any combination of type='bridge' and type='network'
(the networks can be <forward mode='nat|route|bridge'>, as long as
they use a Linux host bridge and not macvtap connections).
This extra effort is especially useful since the recent discovery that
a netdev_del+netdev_add combo (to reconnect the network device with
completely different hostside configuration) doesn't work properly
with current qemu (1.2) unless it is accompanied by the matching
device_del+device_add - see this mailing list message for details:
http://lists.nongnu.org/archive/html/qemu-devel/2012-10/msg02355.html
(A slight modification of the patch referenced there has been prepared
to apply on top of this patch, but won't be pushed until qemu can be
made to work with it.)
* qemuDomainChangeNet needs access to the virDomainDeviceDef that
holds the new netdef (so that it can clear out the virDomainDeviceDef
if it ends up using the NetDef to replace the original), so the
virDomainNetDefPtr arg is replaced with a virDomainDeviceDefPtr.
* qemuDomainChangeNet previously checked for *some* changes to the
interface config, but this check was by no means complete. It was also
a bit disorganized.
This refactoring of the code is (I believe) complete in its check of
all NetDef attributes that might be changed, and either returns a
failure (for changes that are simply impossible), or sets one of three
flags:
needLinkStateChange - if the device link state needs to go up/down
needBridgeChange - if everything else is the same, but it needs
to be connected to a difference linux host
bridge
needReconnect - if the entire host side of the device needs
to be torn down and reconstructed (currently
non-working, as mentioned above)
Note that this function will refuse to make any change that requires
the *guest* side of the device to be detached (e.g. changing the PCI
address or mac address). Those would be disruptive enough to the guest
that it's reasonable to require an explicit detach/attach sequence
from the management application.
* As mentioned above, qemuDomainChangeNet also does its best to
understand when a simple change in attached bridge for the existing
tap device will work vs. the need to completely tear down/reconstruct
the host side of the device (including tap device).
This patch *does not* implement the "reconnect" code anyway - there is
a placeholder that turns that into an error. Rather, the purpose of
this patch is to replicate existing behavior with code that is ready
to have that functionality plugged in in a later patch.
* The expanded uses for qemuDomainChangeNetBridge meant that it needed
to be enhanced as well - it no longer replaces the original brname
string in olddev with the new brname; instead, it relies on the
caller to replace the *entire* olddev with newdev (since we've gone
to great lengths to assure they are functionally identical other
than the name of the bridge, this is now not only safe, but more
correct). Additionally, qemuDomainNetChangeBridge can now set the
bridge for type='network' interfaces as well as plain type='bridge'
interfaces. (Note that I had to make this change simultaneous to the
reorganization of qemuDomainChangeNet because the two are too
closely intertwined to separate).
2012-10-10 15:38:00 -04:00
|
|
|
* Copyright (C) 2006-2007, 2009-2012 Red Hat, Inc.
|
2010-12-16 16:10:54 +00:00
|
|
|
* Copyright (C) 2006 Daniel P. Berrange
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
2012-09-20 16:30:55 -06:00
|
|
|
* License along with this library. If not, see
|
2012-07-21 18:06:23 +08:00
|
|
|
* <http://www.gnu.org/licenses/>.
|
2010-12-16 16:10:54 +00:00
|
|
|
*/
|
|
|
|
|
2019-06-18 11:12:37 -05:00
|
|
|
#pragma once
|
2010-12-16 16:10:54 +00:00
|
|
|
|
2019-06-18 11:12:37 -05:00
|
|
|
#include "qemu_conf.h"
|
|
|
|
#include "qemu_domain.h"
|
|
|
|
#include "domain_conf.h"
|
2010-12-16 16:10:54 +00:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int qemuDomainChangeEjectableMedia(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainDiskDef *disk,
|
|
|
|
virStorageSource *newsrc,
|
2018-09-25 14:21:27 +02:00
|
|
|
bool force);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void qemuDomainDelTLSObjects(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
2017-03-09 09:20:27 -05:00
|
|
|
qemuDomainAsyncJob asyncJob,
|
2017-02-16 10:33:35 -05:00
|
|
|
const char *secAlias,
|
|
|
|
const char *tlsAlias);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int qemuDomainAddTLSObjects(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
2017-03-09 09:20:27 -05:00
|
|
|
qemuDomainAsyncJob asyncJob,
|
2021-03-11 08:16:13 +01:00
|
|
|
virJSONValue **secProps,
|
|
|
|
virJSONValue **tlsProps);
|
2017-02-16 10:33:35 -05:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int qemuDomainGetTLSObjects(virQEMUCaps *qemuCaps,
|
|
|
|
qemuDomainSecretInfo *secinfo,
|
2017-02-17 10:06:14 -05:00
|
|
|
const char *tlsCertdir,
|
|
|
|
bool tlsListen,
|
|
|
|
bool tlsVerify,
|
2018-05-22 07:38:22 +02:00
|
|
|
const char *alias,
|
2021-03-11 08:16:13 +01:00
|
|
|
virJSONValue **tlsProps,
|
|
|
|
virJSONValue **secProps);
|
|
|
|
|
|
|
|
int qemuDomainAttachControllerDevice(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainControllerDef *controller);
|
|
|
|
int qemuDomainAttachDeviceDiskLive(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainDeviceDef *dev);
|
|
|
|
int qemuDomainAttachNetDevice(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainNetDef *net);
|
|
|
|
int qemuDomainAttachRedirdevDevice(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainRedirdevDef *hostdev);
|
|
|
|
int qemuDomainAttachHostDevice(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainHostdevDef *hostdev);
|
|
|
|
int qemuDomainAttachShmemDevice(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainShmemDef *shmem);
|
|
|
|
int qemuDomainAttachWatchdog(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainWatchdogDef *watchdog);
|
|
|
|
int qemuDomainFindGraphicsIndex(virDomainDef *def,
|
|
|
|
virDomainGraphicsDef *dev);
|
|
|
|
int qemuDomainAttachMemory(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainMemoryDef *mem);
|
|
|
|
int qemuDomainChangeGraphics(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainGraphicsDef *dev);
|
|
|
|
int qemuDomainChangeGraphicsPasswords(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
Use the new set_password monitor command to set password.
We try to use that command first when setting a VNC/SPICE password. If
that doesn't work we fallback to the legacy VNC only password
Allow an expiry time to be set, if that doesn't work, throw an error
if they try to use SPICE.
Change since v1:
- moved qemuInitGraphicsPasswords to qemu_hotplug, renamed
to qemuDomainChangeGraphicsPasswords.
- updated what looks like a typo (that appears to work anyway) in
initial patch from Daniel:
- ret = qemuInitGraphicsPasswords(driver, vm,
- VIR_DOMAIN_GRAPHICS_TYPE_SPICE,
- &vm->def->graphics[0]->data.vnc.auth,
- driver->vncPassword);
+ ret = qemuInitGraphicsPasswords(driver, vm,
+ VIR_DOMAIN_GRAPHICS_TYPE_SPICE,
+ &vm->def->graphics[0]->data.spice.auth,
+ driver->spicePassword);
Based on patch by Daniel P. Berrange <berrange@redhat.com>.
2011-01-10 12:12:33 +01:00
|
|
|
int type,
|
2021-03-11 08:16:13 +01:00
|
|
|
virDomainGraphicsAuthDef *auth,
|
2014-08-12 12:54:42 +10:00
|
|
|
const char *defaultPasswd,
|
|
|
|
int asyncJob);
|
2021-03-11 08:16:13 +01:00
|
|
|
int qemuDomainChangeNet(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainDeviceDef *dev);
|
|
|
|
int qemuDomainChangeNetLinkState(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainNetDef *dev,
|
2011-09-06 16:23:47 +08:00
|
|
|
int linkstate);
|
2018-01-05 10:47:47 +08:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int qemuDomainAttachInputDevice(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainInputDef *input);
|
|
|
|
|
|
|
|
int qemuDomainAttachVsockDevice(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainVsockDef *vsock);
|
|
|
|
|
|
|
|
int qemuDomainAttachLease(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainLeaseDef *lease);
|
|
|
|
int qemuDomainAttachChrDevice(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainChrDef *chr);
|
|
|
|
int qemuDomainAttachRNGDevice(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainRNGDef *rng);
|
|
|
|
|
|
|
|
int qemuDomainDetachDeviceLive(virDomainObj *vm,
|
|
|
|
virDomainDeviceDef *match,
|
|
|
|
virQEMUDriver *driver,
|
2019-03-19 13:55:13 -04:00
|
|
|
bool async);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void qemuDomainRemoveVcpuAlias(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
2016-08-16 15:02:11 +02:00
|
|
|
const char *alias);
|
|
|
|
|
2013-03-12 15:59:25 +01:00
|
|
|
int
|
2021-03-11 08:16:13 +01:00
|
|
|
qemuDomainChrInsert(virDomainDef *vmdef,
|
|
|
|
virDomainChrDef *chr);
|
|
|
|
virDomainChrDef *
|
|
|
|
qemuDomainChrRemove(virDomainDef *vmdef,
|
|
|
|
virDomainChrDef *chr);
|
2013-03-12 15:59:25 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int qemuDomainRemoveDevice(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainDeviceDef *dev);
|
2013-07-11 17:11:02 +02:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
bool qemuDomainSignalDeviceRemoval(virDomainObj *vm,
|
2016-04-04 17:17:43 +02:00
|
|
|
const char *devAlias,
|
|
|
|
qemuDomainUnpluggingDeviceStatus status);
|
2013-07-11 17:11:02 +02:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int qemuDomainSetVcpusInternal(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainDef *def,
|
|
|
|
virDomainDef *persistentDef,
|
2016-11-24 16:56:56 +01:00
|
|
|
unsigned int nvcpus,
|
|
|
|
bool hotpluggable);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int qemuDomainSetVcpuInternal(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
|
|
|
virDomainDef *def,
|
|
|
|
virDomainDef *persistentDef,
|
|
|
|
virBitmap *vcpus,
|
2016-06-21 17:17:41 +02:00
|
|
|
bool state);
|
2019-08-08 18:55:00 +04:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
unsigned long long qemuDomainGetUnplugTimeout(virDomainObj *vm) G_GNUC_NO_INLINE;
|
2020-02-25 10:55:11 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int qemuHotplugAttachDBusVMState(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
2020-02-25 10:55:11 +01:00
|
|
|
qemuDomainAsyncJob asyncJob);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int qemuHotplugRemoveDBusVMState(virQEMUDriver *driver,
|
|
|
|
virDomainObj *vm,
|
2020-02-25 10:55:11 +01:00
|
|
|
qemuDomainAsyncJob asyncJob);
|