if (data->chardevDef) {
g_autoptr(virJSONValue) props = NULL;
- if (qemuChardevGetBackendProps(data->chardevDef, false,
+ if (qemuChardevGetBackendProps(data->chardevDef, false, data->qemuCaps,
data->chardevAlias, NULL, &props) < 0)
return -1;
char *driveCmd;
+ virQEMUCaps *qemuCaps; /* borrowed from VM, valid only for chardev-backed source */
virDomainChrSourceDef *chardevDef;
char *chardevAlias;
bool chardevAdded;
int
qemuChardevGetBackendProps(const virDomainChrSourceDef *chr,
bool commandline,
+ virQEMUCaps *qemuCaps,
const char *alias,
const char **backendType,
virJSONValue **props)
virTristateBool waitval = VIR_TRISTATE_BOOL_ABSENT;
virTristateBool server = VIR_TRISTATE_BOOL_ABSENT;
int reconnect = -1;
+ long long reconnect_ms = -1;
*backendType = "socket";
reconnect = 0;
}
+ if (reconnect != -1 &&
+ virQEMUCapsGet(qemuCaps, QEMU_CAPS_CHARDEV_RECONNECT_MILISECONDS)) {
+ reconnect_ms = reconnect * 1000;
+ reconnect = -1;
+ }
+
if (virJSONValueObjectAdd(props,
"T:server", server,
"T:wait", waitval,
"k:reconnect", reconnect,
+ "K:reconnect-ms", reconnect_ms,
NULL) < 0)
return -1;
}
virTristateBool telnet = VIR_TRISTATE_BOOL_ABSENT;
virTristateBool server = VIR_TRISTATE_BOOL_ABSENT;
int reconnect = -1;
+ long long reconnect_ms = -1;
*backendType = "socket";
else if (chr->data.tcp.reconnect.enabled == VIR_TRISTATE_BOOL_NO)
reconnect = 0;
+ if (reconnect != -1 &&
+ virQEMUCapsGet(qemuCaps, QEMU_CAPS_CHARDEV_RECONNECT_MILISECONDS)) {
+ reconnect_ms = reconnect * 1000;
+ reconnect = -1;
+ }
+
if (qemuChardevBackendAddSocketAddressInet(props, "addr",
commandline, NULL,
chr->data.tcp.host,
"T:server", server,
"T:wait", waitval,
"k:reconnect", reconnect,
+ "K:reconnect-ms", reconnect_ms,
"S:tls-creds", chrSourcePriv->tlsCredsAlias,
NULL) < 0)
return -1;
bool useJSON = virQEMUCapsGet(qemuCaps, QEMU_CAPS_CHARDEV_JSON);
const char *backendType = NULL;
- if (qemuChardevGetBackendProps(dev, !useJSON, charAlias, &backendType, &props) < 0)
+ if (qemuChardevGetBackendProps(dev, !useJSON, qemuCaps, charAlias,
+ &backendType, &props) < 0)
return -1;
if (useJSON) {
int
qemuChardevGetBackendProps(const virDomainChrSourceDef *chr,
bool commandline,
+ virQEMUCaps *qemuCaps,
const char *alias,
const char **backendType,
virJSONValue **props);
size_t i;
if (virStorageSourceGetActualType(disk->src) == VIR_STORAGE_TYPE_VHOST_USER) {
- if (!(data = qemuBuildStorageSourceChainAttachPrepareChardev(disk)))
+ if (!(data = qemuBuildStorageSourceChainAttachPrepareChardev(disk, qemuCaps)))
return -1;
} else if (!qemuDiskBusIsSD(disk->bus)) {
if (virStorageSourceIsEmpty(disk->src))
/**
* qemuBuildStorageSourceAttachPrepareChardev:
* @src: disk source to prepare
+ * @qemuCaps: qemu capabilities object borrowed for chardev backend generation
*
* Prepare qemuBlockStorageSourceAttachData *for vhost-user disk
* to be used with -chardev.
*/
static qemuBlockStorageSourceAttachData *
-qemuBuildStorageSourceAttachPrepareChardev(virDomainDiskDef *disk)
+qemuBuildStorageSourceAttachPrepareChardev(virDomainDiskDef *disk,
+ virQEMUCaps *qemuCaps)
{
g_autoptr(qemuBlockStorageSourceAttachData) data = NULL;
data = g_new0(qemuBlockStorageSourceAttachData, 1);
data->chardevDef = disk->src->vhostuser;
+ data->qemuCaps = qemuCaps;
data->chardevAlias = qemuDomainGetVhostUserChrAlias(disk->info.alias);
return g_steal_pointer(&data);
* disk's backend via -chardev.
*/
qemuBlockStorageSourceChainData *
-qemuBuildStorageSourceChainAttachPrepareChardev(virDomainDiskDef *disk)
+qemuBuildStorageSourceChainAttachPrepareChardev(virDomainDiskDef *disk,
+ virQEMUCaps *qemuCaps)
{
g_autoptr(qemuBlockStorageSourceAttachData) elem = NULL;
g_autoptr(qemuBlockStorageSourceChainData) data = NULL;
data = g_new0(qemuBlockStorageSourceChainData, 1);
- if (!(elem = qemuBuildStorageSourceAttachPrepareChardev(disk)))
+ if (!(elem = qemuBuildStorageSourceAttachPrepareChardev(disk, qemuCaps)))
return NULL;
VIR_APPEND_ELEMENT(data->srcdata, data->nsrcdata, elem);
qemuBlockStorageSourceChainData *
-qemuBuildStorageSourceChainAttachPrepareChardev(virDomainDiskDef *disk);
+qemuBuildStorageSourceChainAttachPrepareChardev(virDomainDiskDef *disk,
+ virQEMUCaps *qemuCaps);
qemuBlockStorageSourceChainData *
static int
qemuHotplugChardevAttach(qemuMonitor *mon,
const char *alias,
- virDomainChrSourceDef *def)
+ virDomainChrSourceDef *def,
+ virQEMUCaps *qemuCaps)
{
g_autoptr(virJSONValue) props = NULL;
g_autofree char *ptypath = NULL;
return -1;
}
- if (qemuChardevGetBackendProps(def, false, alias, NULL, &props) < 0)
+ if (qemuChardevGetBackendProps(def, false, qemuCaps, alias, NULL, &props) < 0)
return -1;
if (qemuMonitorAttachCharDev(mon, &props, &ptypath) < 0)
disk->src->readonly = true;
if (virStorageSourceGetActualType(disk->src) == VIR_STORAGE_TYPE_VHOST_USER) {
- if (!(data = qemuBuildStorageSourceChainAttachPrepareChardev(disk)))
+ if (!(data = qemuBuildStorageSourceChainAttachPrepareChardev(disk, priv->qemuCaps)))
return -1;
} else {
if (!(data = qemuBuildStorageSourceChainAttachPrepareBlockdev(disk->src)))
}
if (actualType == VIR_DOMAIN_NET_TYPE_VHOSTUSER) {
- if (qemuHotplugChardevAttach(priv->mon, charDevAlias, net->data.vhostuser) < 0) {
+ if (qemuHotplugChardevAttach(priv->mon, charDevAlias, net->data.vhostuser, priv->qemuCaps) < 0) {
qemuDomainObjExitMonitor(vm);
virDomainAuditNet(vm, NULL, net, "attach", false);
goto cleanup;
qemuDomainObjEnterMonitor(vm);
- if (qemuHotplugChardevAttach(priv->mon, charAlias, redirdev->source) < 0)
+ if (qemuHotplugChardevAttach(priv->mon, charAlias, redirdev->source, priv->qemuCaps) < 0)
goto exit_monitor;
chardevAdded = true;
qemuFDPassDirectTransferMonitor(charpriv->directfd, priv->mon) < 0)
goto exit_monitor;
- if (qemuHotplugChardevAttach(priv->mon, charAlias, chr->source) < 0)
+ if (qemuHotplugChardevAttach(priv->mon, charAlias, chr->source, priv->qemuCaps) < 0)
goto exit_monitor;
chardevAttached = true;
qemuDomainObjEnterMonitor(vm);
if (rng->backend == VIR_DOMAIN_RNG_BACKEND_EGD &&
- qemuHotplugChardevAttach(priv->mon, charAlias, rng->source.chardev) < 0)
+ qemuHotplugChardevAttach(priv->mon, charAlias, rng->source.chardev, priv->qemuCaps) < 0)
goto exit_monitor;
chardevAdded = true;
qemuDomainObjEnterMonitor(vm);
if (shmem->server.enabled) {
- if (qemuHotplugChardevAttach(priv->mon, charAlias, shmem->server.chr) < 0)
+ if (qemuHotplugChardevAttach(priv->mon, charAlias, shmem->server.chr, priv->qemuCaps) < 0)
goto exit_monitor;
} else {
if (qemuMonitorAddObject(priv->mon, &props, &memAlias) < 0)
qemuDomainObjEnterMonitor(vm);
- if (qemuHotplugChardevAttach(priv->mon, charAlias, chardev) < 0)
+ if (qemuHotplugChardevAttach(priv->mon, charAlias, chardev, priv->qemuCaps) < 0)
goto exit_monitor;
chardevAdded = true;
return -1;
}
- if (qemuChardevGetBackendProps(data->chr, false, "alias", NULL, &props) < 0)
+ if (qemuChardevGetBackendProps(data->chr, false, NULL, "alias", NULL, &props) < 0)
return -1;
if ((rc = qemuMonitorAttachCharDev(qemuMonitorTestGetMonitor(test), &props, &ptypath)) < 0)