mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-26 14:35:18 +00:00
Standard internal API syntax for building QEMU command line arguments
All the helper functions for building command line arguments now return a 'char *', instead of acepting a 'char **' or virBufferPtr argument * qemu/qemu_conf.c: Standardize syntax for building args * qemu/qemu_conf.h: Export all functions for building args * qemu/qemu_driver.c: Update for changed syntax for building NIC/hostnet args
This commit is contained in:
parent
c37ff6a1ec
commit
c129d4fe45
@ -2057,10 +2057,10 @@ error:
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
|
||||||
|
char *
|
||||||
qemuBuildDriveDevStr(virConnectPtr conn,
|
qemuBuildDriveDevStr(virConnectPtr conn,
|
||||||
virDomainDiskDefPtr disk,
|
virDomainDiskDefPtr disk)
|
||||||
char **str)
|
|
||||||
{
|
{
|
||||||
virBuffer opt = VIR_BUFFER_INITIALIZER;
|
virBuffer opt = VIR_BUFFER_INITIALIZER;
|
||||||
const char *bus = virDomainDiskQEMUBusTypeToString(disk->bus);
|
const char *bus = virDomainDiskQEMUBusTypeToString(disk->bus);
|
||||||
@ -2101,17 +2101,20 @@ qemuBuildDriveDevStr(virConnectPtr conn,
|
|||||||
virBufferVSprintf(&opt, ",drive=drive-%s", disk->info.alias);
|
virBufferVSprintf(&opt, ",drive=drive-%s", disk->info.alias);
|
||||||
virBufferVSprintf(&opt, ",id=%s", disk->info.alias);
|
virBufferVSprintf(&opt, ",id=%s", disk->info.alias);
|
||||||
|
|
||||||
*str = virBufferContentAndReset(&opt);
|
if (virBufferError(&opt)) {
|
||||||
return 0;
|
virReportOOMError(NULL);
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
|
return virBufferContentAndReset(&opt);
|
||||||
|
|
||||||
error:
|
error:
|
||||||
virBufferFreeAndReset(&opt);
|
virBufferFreeAndReset(&opt);
|
||||||
*str = NULL;
|
return NULL;
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static char *
|
char *
|
||||||
qemuBuildControllerDevStr(virDomainControllerDefPtr def)
|
qemuBuildControllerDevStr(virDomainControllerDefPtr def)
|
||||||
{
|
{
|
||||||
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
||||||
@ -2131,8 +2134,10 @@ qemuBuildControllerDevStr(virDomainControllerDefPtr def)
|
|||||||
if (qemuBuildDeviceAddressStr(&buf, &def->info) < 0)
|
if (qemuBuildDeviceAddressStr(&buf, &def->info) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
if (virBufferError(&buf))
|
if (virBufferError(&buf)) {
|
||||||
|
virReportOOMError(NULL);
|
||||||
goto error;
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
return virBufferContentAndReset(&buf);
|
return virBufferContentAndReset(&buf);
|
||||||
|
|
||||||
@ -2142,14 +2147,14 @@ error:
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int
|
char *
|
||||||
qemuBuildNicStr(virConnectPtr conn,
|
qemuBuildNicStr(virConnectPtr conn,
|
||||||
virDomainNetDefPtr net,
|
virDomainNetDefPtr net,
|
||||||
const char *prefix,
|
const char *prefix,
|
||||||
int vlan,
|
int vlan)
|
||||||
char **str)
|
|
||||||
{
|
{
|
||||||
if (virAsprintf(str,
|
char *str;
|
||||||
|
if (virAsprintf(&str,
|
||||||
"%smacaddr=%02x:%02x:%02x:%02x:%02x:%02x,vlan=%d%s%s%s%s",
|
"%smacaddr=%02x:%02x:%02x:%02x:%02x:%02x,vlan=%d%s%s%s%s",
|
||||||
prefix ? prefix : "",
|
prefix ? prefix : "",
|
||||||
net->mac[0], net->mac[1],
|
net->mac[0], net->mac[1],
|
||||||
@ -2161,13 +2166,14 @@ qemuBuildNicStr(virConnectPtr conn,
|
|||||||
(net->info.alias ? ",name=" : ""),
|
(net->info.alias ? ",name=" : ""),
|
||||||
(net->info.alias ? net->info.alias : "")) < 0) {
|
(net->info.alias ? net->info.alias : "")) < 0) {
|
||||||
virReportOOMError(conn);
|
virReportOOMError(conn);
|
||||||
return -1;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
static char *
|
|
||||||
|
char *
|
||||||
qemuBuildNicDevStr(virDomainNetDefPtr net)
|
qemuBuildNicDevStr(virDomainNetDefPtr net)
|
||||||
{
|
{
|
||||||
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
||||||
@ -2202,23 +2208,25 @@ error:
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
|
||||||
|
char *
|
||||||
qemuBuildHostNetStr(virConnectPtr conn,
|
qemuBuildHostNetStr(virConnectPtr conn,
|
||||||
virDomainNetDefPtr net,
|
virDomainNetDefPtr net,
|
||||||
char type_sep,
|
char type_sep,
|
||||||
int vlan,
|
int vlan,
|
||||||
const char *tapfd,
|
const char *tapfd)
|
||||||
char **str)
|
|
||||||
{
|
{
|
||||||
|
char *str = NULL;
|
||||||
|
|
||||||
switch (net->type) {
|
switch (net->type) {
|
||||||
case VIR_DOMAIN_NET_TYPE_NETWORK:
|
case VIR_DOMAIN_NET_TYPE_NETWORK:
|
||||||
case VIR_DOMAIN_NET_TYPE_BRIDGE:
|
case VIR_DOMAIN_NET_TYPE_BRIDGE:
|
||||||
if (virAsprintf(str, "tap%cfd=%s,vlan=%d%s%s",
|
if (virAsprintf(&str, "tap%cfd=%s,vlan=%d%s%s",
|
||||||
type_sep, tapfd, vlan,
|
type_sep, tapfd, vlan,
|
||||||
(net->hostnet_name ? ",name=" : ""),
|
(net->hostnet_name ? ",name=" : ""),
|
||||||
(net->hostnet_name ? net->hostnet_name : "")) < 0) {
|
(net->hostnet_name ? net->hostnet_name : "")) < 0) {
|
||||||
virReportOOMError(conn);
|
virReportOOMError(conn);
|
||||||
return -1;
|
return NULL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -2245,10 +2253,10 @@ qemuBuildHostNetStr(virConnectPtr conn,
|
|||||||
if (virBufferError(&buf)) {
|
if (virBufferError(&buf)) {
|
||||||
virBufferFreeAndReset(&buf);
|
virBufferFreeAndReset(&buf);
|
||||||
virReportOOMError(conn);
|
virReportOOMError(conn);
|
||||||
return -1;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
*str = virBufferContentAndReset(&buf);
|
str = virBufferContentAndReset(&buf);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -2270,7 +2278,7 @@ qemuBuildHostNetStr(virConnectPtr conn,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virAsprintf(str, "socket%c%s=%s:%d,vlan=%d%s%s",
|
if (virAsprintf(&str, "socket%c%s=%s:%d,vlan=%d%s%s",
|
||||||
type_sep, mode,
|
type_sep, mode,
|
||||||
net->data.socket.address,
|
net->data.socket.address,
|
||||||
net->data.socket.port,
|
net->data.socket.port,
|
||||||
@ -2278,40 +2286,41 @@ qemuBuildHostNetStr(virConnectPtr conn,
|
|||||||
(net->hostnet_name ? ",name=" : ""),
|
(net->hostnet_name ? ",name=" : ""),
|
||||||
(net->hostnet_name ? net->hostnet_name : "")) < 0) {
|
(net->hostnet_name ? net->hostnet_name : "")) < 0) {
|
||||||
virReportOOMError(conn);
|
virReportOOMError(conn);
|
||||||
return -1;
|
return NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_NET_TYPE_USER:
|
case VIR_DOMAIN_NET_TYPE_USER:
|
||||||
default:
|
default:
|
||||||
if (virAsprintf(str, "user%cvlan=%d%s%s",
|
if (virAsprintf(&str, "user%cvlan=%d%s%s",
|
||||||
type_sep, vlan,
|
type_sep, vlan,
|
||||||
(net->hostnet_name ? ",name=" : ""),
|
(net->hostnet_name ? ",name=" : ""),
|
||||||
(net->hostnet_name ? net->hostnet_name : "")) < 0) {
|
(net->hostnet_name ? net->hostnet_name : "")) < 0) {
|
||||||
virReportOOMError(conn);
|
virReportOOMError(conn);
|
||||||
return -1;
|
return NULL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int
|
char *
|
||||||
qemuBuildNetDevStr(virConnectPtr conn,
|
qemuBuildNetDevStr(virConnectPtr conn,
|
||||||
virDomainNetDefPtr net,
|
virDomainNetDefPtr net,
|
||||||
const char *tapfd,
|
const char *tapfd)
|
||||||
char **str)
|
|
||||||
{
|
{
|
||||||
|
char *str = NULL;
|
||||||
|
|
||||||
switch (net->type) {
|
switch (net->type) {
|
||||||
case VIR_DOMAIN_NET_TYPE_NETWORK:
|
case VIR_DOMAIN_NET_TYPE_NETWORK:
|
||||||
case VIR_DOMAIN_NET_TYPE_BRIDGE:
|
case VIR_DOMAIN_NET_TYPE_BRIDGE:
|
||||||
if (virAsprintf(str, "tap,fd=%s,id=%s",
|
if (virAsprintf(&str, "tap,fd=%s,id=%s",
|
||||||
tapfd, net->hostnet_name) < 0) {
|
tapfd, net->hostnet_name) < 0) {
|
||||||
virReportOOMError(conn);
|
virReportOOMError(conn);
|
||||||
return -1;
|
return NULL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -2331,10 +2340,10 @@ qemuBuildNetDevStr(virConnectPtr conn,
|
|||||||
if (virBufferError(&buf)) {
|
if (virBufferError(&buf)) {
|
||||||
virBufferFreeAndReset(&buf);
|
virBufferFreeAndReset(&buf);
|
||||||
virReportOOMError(conn);
|
virReportOOMError(conn);
|
||||||
return -1;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
*str = virBufferContentAndReset(&buf);
|
str = virBufferContentAndReset(&buf);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -2356,32 +2365,33 @@ qemuBuildNetDevStr(virConnectPtr conn,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virAsprintf(str, "socket,%s=%s:%d,id=%s",
|
if (virAsprintf(&str, "socket,%s=%s:%d,id=%s",
|
||||||
mode,
|
mode,
|
||||||
net->data.socket.address,
|
net->data.socket.address,
|
||||||
net->data.socket.port,
|
net->data.socket.port,
|
||||||
net->hostnet_name) < 0) {
|
net->hostnet_name) < 0) {
|
||||||
virReportOOMError(conn);
|
virReportOOMError(conn);
|
||||||
return -1;
|
return NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_NET_TYPE_USER:
|
case VIR_DOMAIN_NET_TYPE_USER:
|
||||||
default:
|
default:
|
||||||
if (virAsprintf(str, "user,id=%s",
|
if (virAsprintf(&str, "user,id=%s",
|
||||||
net->hostnet_name) < 0) {
|
net->hostnet_name) < 0) {
|
||||||
virReportOOMError(conn);
|
virReportOOMError(conn);
|
||||||
return -1;
|
return NULL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static char *qemuBuildWatchdogDevStr(virDomainWatchdogDefPtr dev)
|
char *
|
||||||
|
qemuBuildWatchdogDevStr(virDomainWatchdogDefPtr dev)
|
||||||
{
|
{
|
||||||
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
||||||
|
|
||||||
@ -2410,7 +2420,8 @@ error:
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static char *qemuBuildUSBInputDevStr(virDomainInputDefPtr dev)
|
char *
|
||||||
|
qemuBuildUSBInputDevStr(virDomainInputDefPtr dev)
|
||||||
{
|
{
|
||||||
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
||||||
|
|
||||||
@ -2432,7 +2443,7 @@ error:
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static char *
|
char *
|
||||||
qemuBuildSoundDevStr(virDomainSoundDefPtr sound)
|
qemuBuildSoundDevStr(virDomainSoundDefPtr sound)
|
||||||
{
|
{
|
||||||
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
||||||
@ -2468,7 +2479,7 @@ error:
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static char *
|
char *
|
||||||
qemuBuildPCIHostdevDevStr(virDomainHostdevDefPtr dev)
|
qemuBuildPCIHostdevDevStr(virDomainHostdevDefPtr dev)
|
||||||
{
|
{
|
||||||
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
||||||
@ -2494,43 +2505,46 @@ error:
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* This function outputs a -chardev command line option which describes only the
|
/* This function outputs a -chardev command line option which describes only the
|
||||||
* host side of the character device */
|
* host side of the character device */
|
||||||
static void qemudBuildCommandLineChrDevChardevStr(virDomainChrDefPtr dev,
|
char *
|
||||||
virBufferPtr buf)
|
qemuBuildChrChardevStr(virDomainChrDefPtr dev)
|
||||||
{
|
{
|
||||||
|
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
||||||
bool telnet;
|
bool telnet;
|
||||||
|
|
||||||
switch(dev->type) {
|
switch(dev->type) {
|
||||||
case VIR_DOMAIN_CHR_TYPE_NULL:
|
case VIR_DOMAIN_CHR_TYPE_NULL:
|
||||||
virBufferVSprintf(buf, "null,id=%s", dev->info.alias);
|
virBufferVSprintf(&buf, "null,id=%s", dev->info.alias);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_VC:
|
case VIR_DOMAIN_CHR_TYPE_VC:
|
||||||
virBufferVSprintf(buf, "vc,id=%s", dev->info.alias);
|
virBufferVSprintf(&buf, "vc,id=%s", dev->info.alias);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_PTY:
|
case VIR_DOMAIN_CHR_TYPE_PTY:
|
||||||
virBufferVSprintf(buf, "pty,id=%s", dev->info.alias);
|
virBufferVSprintf(&buf, "pty,id=%s", dev->info.alias);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_DEV:
|
case VIR_DOMAIN_CHR_TYPE_DEV:
|
||||||
virBufferVSprintf(buf, "tty,id=%s,path=%s", dev->info.alias, dev->data.file.path);
|
virBufferVSprintf(&buf, "tty,id=%s,path=%s", dev->info.alias, dev->data.file.path);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_FILE:
|
case VIR_DOMAIN_CHR_TYPE_FILE:
|
||||||
virBufferVSprintf(buf, "file,id=%s,path=%s", dev->info.alias, dev->data.file.path);
|
virBufferVSprintf(&buf, "file,id=%s,path=%s", dev->info.alias, dev->data.file.path);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_PIPE:
|
case VIR_DOMAIN_CHR_TYPE_PIPE:
|
||||||
virBufferVSprintf(buf, "pipe,id=%s,path=%s", dev->info.alias, dev->data.file.path);
|
virBufferVSprintf(&buf, "pipe,id=%s,path=%s", dev->info.alias, dev->data.file.path);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_STDIO:
|
case VIR_DOMAIN_CHR_TYPE_STDIO:
|
||||||
virBufferVSprintf(buf, "stdio,id=%s", dev->info.alias);
|
virBufferVSprintf(&buf, "stdio,id=%s", dev->info.alias);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_UDP:
|
case VIR_DOMAIN_CHR_TYPE_UDP:
|
||||||
virBufferVSprintf(buf,
|
virBufferVSprintf(&buf,
|
||||||
"udp,id=%s,host=%s,port=%s,localaddr=%s,localport=%s",
|
"udp,id=%s,host=%s,port=%s,localaddr=%s,localport=%s",
|
||||||
dev->info.alias,
|
dev->info.alias,
|
||||||
dev->data.udp.connectHost,
|
dev->data.udp.connectHost,
|
||||||
@ -2541,7 +2555,7 @@ static void qemudBuildCommandLineChrDevChardevStr(virDomainChrDefPtr dev,
|
|||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_TCP:
|
case VIR_DOMAIN_CHR_TYPE_TCP:
|
||||||
telnet = dev->data.tcp.protocol == VIR_DOMAIN_CHR_TCP_PROTOCOL_TELNET;
|
telnet = dev->data.tcp.protocol == VIR_DOMAIN_CHR_TCP_PROTOCOL_TELNET;
|
||||||
virBufferVSprintf(buf,
|
virBufferVSprintf(&buf,
|
||||||
"socket,id=%s,host=%s,port=%s%s%s",
|
"socket,id=%s,host=%s,port=%s%s%s",
|
||||||
dev->info.alias,
|
dev->info.alias,
|
||||||
dev->data.tcp.host,
|
dev->data.tcp.host,
|
||||||
@ -2551,49 +2565,66 @@ static void qemudBuildCommandLineChrDevChardevStr(virDomainChrDefPtr dev,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_UNIX:
|
case VIR_DOMAIN_CHR_TYPE_UNIX:
|
||||||
virBufferVSprintf(buf,
|
virBufferVSprintf(&buf,
|
||||||
"socket,id=%s,path=%s%s",
|
"socket,id=%s,path=%s%s",
|
||||||
dev->info.alias,
|
dev->info.alias,
|
||||||
dev->data.nix.path,
|
dev->data.nix.path,
|
||||||
dev->data.nix.listen ? ",server,nowait" : "");
|
dev->data.nix.listen ? ",server,nowait" : "");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (virBufferError(&buf)) {
|
||||||
|
virReportOOMError(NULL);
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
|
return virBufferContentAndReset(&buf);
|
||||||
|
|
||||||
|
error:
|
||||||
|
virBufferFreeAndReset(&buf);
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void qemudBuildCommandLineChrDevStr(virDomainChrDefPtr dev,
|
|
||||||
virBufferPtr buf)
|
char *
|
||||||
|
qemuBuildChrArgStr(virDomainChrDefPtr dev, const char *prefix)
|
||||||
{
|
{
|
||||||
|
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
||||||
|
|
||||||
|
if (prefix)
|
||||||
|
virBufferAdd(&buf, prefix, strlen(prefix));
|
||||||
|
|
||||||
switch (dev->type) {
|
switch (dev->type) {
|
||||||
case VIR_DOMAIN_CHR_TYPE_NULL:
|
case VIR_DOMAIN_CHR_TYPE_NULL:
|
||||||
virBufferAddLit(buf, "null");
|
virBufferAddLit(&buf, "null");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_VC:
|
case VIR_DOMAIN_CHR_TYPE_VC:
|
||||||
virBufferAddLit(buf, "vc");
|
virBufferAddLit(&buf, "vc");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_PTY:
|
case VIR_DOMAIN_CHR_TYPE_PTY:
|
||||||
virBufferAddLit(buf, "pty");
|
virBufferAddLit(&buf, "pty");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_DEV:
|
case VIR_DOMAIN_CHR_TYPE_DEV:
|
||||||
virBufferStrcat(buf, dev->data.file.path, NULL);
|
virBufferStrcat(&buf, dev->data.file.path, NULL);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_FILE:
|
case VIR_DOMAIN_CHR_TYPE_FILE:
|
||||||
virBufferVSprintf(buf, "file:%s", dev->data.file.path);
|
virBufferVSprintf(&buf, "file:%s", dev->data.file.path);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_PIPE:
|
case VIR_DOMAIN_CHR_TYPE_PIPE:
|
||||||
virBufferVSprintf(buf, "pipe:%s", dev->data.file.path);
|
virBufferVSprintf(&buf, "pipe:%s", dev->data.file.path);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_STDIO:
|
case VIR_DOMAIN_CHR_TYPE_STDIO:
|
||||||
virBufferAddLit(buf, "stdio");
|
virBufferAddLit(&buf, "stdio");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_UDP:
|
case VIR_DOMAIN_CHR_TYPE_UDP:
|
||||||
virBufferVSprintf(buf, "udp:%s:%s@%s:%s",
|
virBufferVSprintf(&buf, "udp:%s:%s@%s:%s",
|
||||||
dev->data.udp.connectHost,
|
dev->data.udp.connectHost,
|
||||||
dev->data.udp.connectService,
|
dev->data.udp.connectService,
|
||||||
dev->data.udp.bindHost,
|
dev->data.udp.bindHost,
|
||||||
@ -2602,12 +2633,12 @@ static void qemudBuildCommandLineChrDevStr(virDomainChrDefPtr dev,
|
|||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_TCP:
|
case VIR_DOMAIN_CHR_TYPE_TCP:
|
||||||
if (dev->data.tcp.protocol == VIR_DOMAIN_CHR_TCP_PROTOCOL_TELNET) {
|
if (dev->data.tcp.protocol == VIR_DOMAIN_CHR_TCP_PROTOCOL_TELNET) {
|
||||||
virBufferVSprintf(buf, "telnet:%s:%s%s",
|
virBufferVSprintf(&buf, "telnet:%s:%s%s",
|
||||||
dev->data.tcp.host,
|
dev->data.tcp.host,
|
||||||
dev->data.tcp.service,
|
dev->data.tcp.service,
|
||||||
dev->data.tcp.listen ? ",server,nowait" : "");
|
dev->data.tcp.listen ? ",server,nowait" : "");
|
||||||
} else {
|
} else {
|
||||||
virBufferVSprintf(buf, "tcp:%s:%s%s",
|
virBufferVSprintf(&buf, "tcp:%s:%s%s",
|
||||||
dev->data.tcp.host,
|
dev->data.tcp.host,
|
||||||
dev->data.tcp.service,
|
dev->data.tcp.service,
|
||||||
dev->data.tcp.listen ? ",server,nowait" : "");
|
dev->data.tcp.listen ? ",server,nowait" : "");
|
||||||
@ -2615,16 +2646,27 @@ static void qemudBuildCommandLineChrDevStr(virDomainChrDefPtr dev,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case VIR_DOMAIN_CHR_TYPE_UNIX:
|
case VIR_DOMAIN_CHR_TYPE_UNIX:
|
||||||
virBufferVSprintf(buf, "unix:%s%s",
|
virBufferVSprintf(&buf, "unix:%s%s",
|
||||||
dev->data.nix.path,
|
dev->data.nix.path,
|
||||||
dev->data.nix.listen ? ",server,nowait" : "");
|
dev->data.nix.listen ? ",server,nowait" : "");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (virBufferError(&buf)) {
|
||||||
|
virReportOOMError(NULL);
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
|
return virBufferContentAndReset(&buf);
|
||||||
|
|
||||||
|
error:
|
||||||
|
virBufferFreeAndReset(&buf);
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
qemudBuildCommandLineCPU(virConnectPtr conn,
|
qemuBuildCpuArgStr(virConnectPtr conn,
|
||||||
const struct qemud_driver *driver,
|
const struct qemud_driver *driver,
|
||||||
const virDomainDefPtr def,
|
const virDomainDefPtr def,
|
||||||
const char *emulator,
|
const char *emulator,
|
||||||
@ -2715,7 +2757,7 @@ no_memory:
|
|||||||
}
|
}
|
||||||
|
|
||||||
static char *
|
static char *
|
||||||
qemudBuildCommandLineSmp(virConnectPtr conn,
|
qemuBuildSmpArgStr(virConnectPtr conn,
|
||||||
const virDomainDefPtr def,
|
const virDomainDefPtr def,
|
||||||
int qemuCmdFlags)
|
int qemuCmdFlags)
|
||||||
{
|
{
|
||||||
@ -2947,7 +2989,7 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
|||||||
ADD_ARG_LIT(def->os.machine);
|
ADD_ARG_LIT(def->os.machine);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemudBuildCommandLineCPU(conn, driver, def, emulator, &ut, &cpu) < 0)
|
if (qemuBuildCpuArgStr(conn, driver, def, emulator, &ut, &cpu) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
if (cpu) {
|
if (cpu) {
|
||||||
@ -2987,7 +3029,7 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
ADD_ARG_LIT("-smp");
|
ADD_ARG_LIT("-smp");
|
||||||
if (!(smp = qemudBuildCommandLineSmp(conn, def, qemuCmdFlags)))
|
if (!(smp = qemuBuildSmpArgStr(conn, def, qemuCmdFlags)))
|
||||||
goto error;
|
goto error;
|
||||||
ADD_ARG(smp);
|
ADD_ARG(smp);
|
||||||
|
|
||||||
@ -3031,25 +3073,14 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
|||||||
ADD_ARG_LIT("-nodefaults");
|
ADD_ARG_LIT("-nodefaults");
|
||||||
|
|
||||||
if (monitor_chr) {
|
if (monitor_chr) {
|
||||||
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
char *chrdev;
|
||||||
|
|
||||||
/* Use -chardev if it's available */
|
/* Use -chardev if it's available */
|
||||||
if (qemuCmdFlags & QEMUD_CMD_FLAG_CHARDEV) {
|
if (qemuCmdFlags & QEMUD_CMD_FLAG_CHARDEV) {
|
||||||
qemudBuildCommandLineChrDevChardevStr(monitor_chr, &buf);
|
|
||||||
if (virBufferError(&buf)) {
|
|
||||||
virBufferFreeAndReset(&buf);
|
|
||||||
goto no_memory;
|
|
||||||
}
|
|
||||||
|
|
||||||
ADD_ARG_LIT("-chardev");
|
ADD_ARG_LIT("-chardev");
|
||||||
ADD_ARG(virBufferContentAndReset(&buf));
|
if (!(chrdev = qemuBuildChrChardevStr(monitor_chr)))
|
||||||
|
goto error;
|
||||||
virBufferVSprintf(&buf, "chardev=%s", monitor_chr->info.alias);
|
ADD_ARG(chrdev);
|
||||||
|
|
||||||
if (virBufferError(&buf)) {
|
|
||||||
virBufferFreeAndReset(&buf);
|
|
||||||
goto no_memory;
|
|
||||||
}
|
|
||||||
|
|
||||||
ADD_ARG_LIT("-mon");
|
ADD_ARG_LIT("-mon");
|
||||||
if (monitor_json)
|
if (monitor_json)
|
||||||
@ -3057,18 +3088,14 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
|||||||
else
|
else
|
||||||
ADD_ARG_LIT("chardev=monitor,mode=readline");
|
ADD_ARG_LIT("chardev=monitor,mode=readline");
|
||||||
} else {
|
} else {
|
||||||
|
const char *prefix = NULL;
|
||||||
if (monitor_json)
|
if (monitor_json)
|
||||||
virBufferAddLit(&buf, "control,");
|
prefix = "control,";
|
||||||
|
|
||||||
qemudBuildCommandLineChrDevStr(monitor_chr, &buf);
|
|
||||||
|
|
||||||
if (virBufferError(&buf)) {
|
|
||||||
virBufferFreeAndReset(&buf);
|
|
||||||
goto no_memory;
|
|
||||||
}
|
|
||||||
|
|
||||||
ADD_ARG_LIT("-monitor");
|
ADD_ARG_LIT("-monitor");
|
||||||
ADD_ARG(virBufferContentAndReset(&buf));
|
if (!(chrdev = qemuBuildChrArgStr(monitor_chr, prefix)))
|
||||||
|
goto error;
|
||||||
|
ADD_ARG(chrdev);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3250,7 +3277,7 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
|||||||
} else {
|
} else {
|
||||||
ADD_ARG_LIT("-device");
|
ADD_ARG_LIT("-device");
|
||||||
|
|
||||||
if (qemuBuildDriveDevStr(conn, disk, &optstr) < 0)
|
if (!(optstr = qemuBuildDriveDevStr(conn, disk)))
|
||||||
goto error;
|
goto error;
|
||||||
ADD_ARG(optstr);
|
ADD_ARG(optstr);
|
||||||
}
|
}
|
||||||
@ -3357,7 +3384,7 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
|||||||
|
|
||||||
if (qemuCmdFlags & QEMUD_CMD_FLAG_DEVICE) {
|
if (qemuCmdFlags & QEMUD_CMD_FLAG_DEVICE) {
|
||||||
ADD_ARG_LIT("-netdev");
|
ADD_ARG_LIT("-netdev");
|
||||||
if (qemuBuildNetDevStr(conn, net, tapfd_name, &host) < 0)
|
if (!(host = qemuBuildNetDevStr(conn, net, tapfd_name)))
|
||||||
goto error;
|
goto error;
|
||||||
ADD_ARG(host);
|
ADD_ARG(host);
|
||||||
|
|
||||||
@ -3367,13 +3394,13 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
|||||||
ADD_ARG(nic);
|
ADD_ARG(nic);
|
||||||
} else {
|
} else {
|
||||||
ADD_ARG_LIT("-net");
|
ADD_ARG_LIT("-net");
|
||||||
if (qemuBuildNicStr(conn, net, "nic,", net->vlan, &nic) < 0)
|
if (!(nic = qemuBuildNicStr(conn, net, "nic,", net->vlan)))
|
||||||
goto error;
|
goto error;
|
||||||
ADD_ARG(nic);
|
ADD_ARG(nic);
|
||||||
|
|
||||||
ADD_ARG_LIT("-net");
|
ADD_ARG_LIT("-net");
|
||||||
if (qemuBuildHostNetStr(conn, net, ',',
|
if (!(host = qemuBuildHostNetStr(conn, net, ',',
|
||||||
net->vlan, tapfd_name, &host) < 0)
|
net->vlan, tapfd_name)))
|
||||||
goto error;
|
goto error;
|
||||||
ADD_ARG(host);
|
ADD_ARG(host);
|
||||||
}
|
}
|
||||||
@ -3388,40 +3415,26 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
for (i = 0 ; i < def->nserials ; i++) {
|
for (i = 0 ; i < def->nserials ; i++) {
|
||||||
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
|
||||||
virDomainChrDefPtr serial = def->serials[i];
|
virDomainChrDefPtr serial = def->serials[i];
|
||||||
|
char *devstr;
|
||||||
|
|
||||||
/* Use -chardev with -device if they are available */
|
/* Use -chardev with -device if they are available */
|
||||||
if ((qemuCmdFlags & QEMUD_CMD_FLAG_CHARDEV) &&
|
if ((qemuCmdFlags & QEMUD_CMD_FLAG_CHARDEV) &&
|
||||||
(qemuCmdFlags & QEMUD_CMD_FLAG_DEVICE)) {
|
(qemuCmdFlags & QEMUD_CMD_FLAG_DEVICE)) {
|
||||||
qemudBuildCommandLineChrDevChardevStr(serial, &buf);
|
|
||||||
if (virBufferError(&buf)) {
|
|
||||||
virBufferFreeAndReset(&buf);
|
|
||||||
goto no_memory;
|
|
||||||
}
|
|
||||||
|
|
||||||
ADD_ARG_LIT("-chardev");
|
ADD_ARG_LIT("-chardev");
|
||||||
ADD_ARG(virBufferContentAndReset(&buf));
|
if (!(devstr = qemuBuildChrChardevStr(serial)))
|
||||||
|
goto error;
|
||||||
virBufferVSprintf(&buf, "isa-serial,chardev=%s", serial->info.alias);
|
ADD_ARG(devstr);
|
||||||
if (virBufferError(&buf)) {
|
|
||||||
virBufferFreeAndReset(&buf);
|
|
||||||
goto no_memory;
|
|
||||||
}
|
|
||||||
|
|
||||||
ADD_ARG_LIT("-device");
|
ADD_ARG_LIT("-device");
|
||||||
ADD_ARG(virBufferContentAndReset(&buf));
|
if (virAsprintf(&devstr, "isa-serial,chardev=%s", serial->info.alias) < 0)
|
||||||
}
|
|
||||||
|
|
||||||
else {
|
|
||||||
qemudBuildCommandLineChrDevStr(serial, &buf);
|
|
||||||
if (virBufferError(&buf)) {
|
|
||||||
virBufferFreeAndReset(&buf);
|
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
}
|
ADD_ARG(devstr);
|
||||||
|
} else {
|
||||||
ADD_ARG_LIT("-serial");
|
ADD_ARG_LIT("-serial");
|
||||||
ADD_ARG(virBufferContentAndReset(&buf));
|
if (!(devstr = qemuBuildChrArgStr(serial, NULL)))
|
||||||
|
goto error;
|
||||||
|
ADD_ARG(devstr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3434,47 +3447,33 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
for (i = 0 ; i < def->nparallels ; i++) {
|
for (i = 0 ; i < def->nparallels ; i++) {
|
||||||
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
|
||||||
virDomainChrDefPtr parallel = def->parallels[i];
|
virDomainChrDefPtr parallel = def->parallels[i];
|
||||||
|
char *devstr;
|
||||||
|
|
||||||
/* Use -chardev with -device if they are available */
|
/* Use -chardev with -device if they are available */
|
||||||
if ((qemuCmdFlags & QEMUD_CMD_FLAG_CHARDEV) &&
|
if ((qemuCmdFlags & QEMUD_CMD_FLAG_CHARDEV) &&
|
||||||
(qemuCmdFlags & QEMUD_CMD_FLAG_DEVICE)) {
|
(qemuCmdFlags & QEMUD_CMD_FLAG_DEVICE)) {
|
||||||
qemudBuildCommandLineChrDevChardevStr(parallel, &buf);
|
|
||||||
if (virBufferError(&buf)) {
|
|
||||||
virBufferFreeAndReset(&buf);
|
|
||||||
goto no_memory;
|
|
||||||
}
|
|
||||||
|
|
||||||
ADD_ARG_LIT("-chardev");
|
ADD_ARG_LIT("-chardev");
|
||||||
ADD_ARG(virBufferContentAndReset(&buf));
|
if (!(devstr = qemuBuildChrChardevStr(parallel)))
|
||||||
|
goto error;
|
||||||
virBufferVSprintf(&buf, "isa-parallel,chardev=%s", parallel->info.alias);
|
ADD_ARG(devstr);
|
||||||
if (virBufferError(&buf)) {
|
|
||||||
virBufferFreeAndReset(&buf);
|
|
||||||
goto no_memory;
|
|
||||||
}
|
|
||||||
|
|
||||||
ADD_ARG_LIT("-device");
|
ADD_ARG_LIT("-device");
|
||||||
ADD_ARG(virBufferContentAndReset(&buf));
|
if (virAsprintf(&devstr, "isa-parallel,chardev=%s", parallel->info.alias) < 0)
|
||||||
}
|
|
||||||
|
|
||||||
else {
|
|
||||||
qemudBuildCommandLineChrDevStr(parallel, &buf);
|
|
||||||
if (virBufferError(&buf)) {
|
|
||||||
virBufferFreeAndReset(&buf);
|
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
}
|
ADD_ARG(devstr);
|
||||||
|
} else {
|
||||||
ADD_ARG_LIT("-parallel");
|
ADD_ARG_LIT("-parallel");
|
||||||
ADD_ARG(virBufferContentAndReset(&buf));
|
if (!(devstr = qemuBuildChrArgStr(parallel, NULL)))
|
||||||
|
goto error;
|
||||||
|
ADD_ARG(devstr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0 ; i < def->nchannels ; i++) {
|
for (i = 0 ; i < def->nchannels ; i++) {
|
||||||
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
|
||||||
virDomainChrDefPtr channel = def->channels[i];
|
virDomainChrDefPtr channel = def->channels[i];
|
||||||
|
char *devstr;
|
||||||
|
|
||||||
switch(channel->targetType) {
|
switch(channel->targetType) {
|
||||||
case VIR_DOMAIN_CHR_TARGET_TYPE_GUESTFWD:
|
case VIR_DOMAIN_CHR_TARGET_TYPE_GUESTFWD:
|
||||||
@ -3485,30 +3484,22 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
qemudBuildCommandLineChrDevChardevStr(channel, &buf);
|
|
||||||
if (virBufferError(&buf)) {
|
|
||||||
virBufferFreeAndReset(&buf);
|
|
||||||
goto no_memory;
|
|
||||||
}
|
|
||||||
|
|
||||||
ADD_ARG_LIT("-chardev");
|
ADD_ARG_LIT("-chardev");
|
||||||
ADD_ARG(virBufferContentAndReset(&buf));
|
if (!(devstr = qemuBuildChrChardevStr(channel)))
|
||||||
|
goto error;
|
||||||
|
ADD_ARG(devstr);
|
||||||
|
|
||||||
const char *addr = virSocketFormatAddr(channel->target.addr);
|
char *addr = virSocketFormatAddr(channel->target.addr);
|
||||||
int port = virSocketGetPort(channel->target.addr);
|
int port = virSocketGetPort(channel->target.addr);
|
||||||
|
|
||||||
ADD_ARG_LIT("-netdev");
|
ADD_ARG_LIT("-netdev");
|
||||||
virBufferVSprintf(&buf, "user,guestfwd=tcp:%s:%i,chardev=%s,id=user-%s",
|
if (virAsprintf(&devstr, "user,guestfwd=tcp:%s:%i,chardev=%s,id=user-%s",
|
||||||
addr, port, channel->info.alias, channel->info.alias);
|
addr, port, channel->info.alias, channel->info.alias) < 0) {
|
||||||
|
|
||||||
VIR_FREE(addr);
|
VIR_FREE(addr);
|
||||||
|
|
||||||
if (virBufferError(&buf)) {
|
|
||||||
virBufferFreeAndReset(&buf);
|
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
}
|
}
|
||||||
|
VIR_FREE(addr);
|
||||||
ADD_ARG(virBufferContentAndReset(&buf));
|
ADD_ARG(devstr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -188,24 +188,52 @@ int qemudBuildCommandLine (virConnectPtr conn,
|
|||||||
int *ntapfds,
|
int *ntapfds,
|
||||||
const char *migrateFrom);
|
const char *migrateFrom);
|
||||||
|
|
||||||
int qemuBuildHostNetStr (virConnectPtr conn,
|
/* Legacy, pre device support */
|
||||||
|
char * qemuBuildHostNetStr(virConnectPtr conn,
|
||||||
virDomainNetDefPtr net,
|
virDomainNetDefPtr net,
|
||||||
char type_sep,
|
char type_sep,
|
||||||
int vlan,
|
int vlan,
|
||||||
const char *tapfd,
|
const char *tapfd);
|
||||||
char **str);
|
|
||||||
|
|
||||||
int qemuBuildNicStr (virConnectPtr conn,
|
/* Current, best practice */
|
||||||
|
char * qemuBuildNetDevStr(virConnectPtr conn,
|
||||||
|
virDomainNetDefPtr net,
|
||||||
|
const char *tapfd);
|
||||||
|
|
||||||
|
|
||||||
|
/* Legacy, pre device support */
|
||||||
|
char * qemuBuildNicStr(virConnectPtr conn,
|
||||||
virDomainNetDefPtr net,
|
virDomainNetDefPtr net,
|
||||||
const char *prefix,
|
const char *prefix,
|
||||||
int vlan,
|
int vlan);
|
||||||
char **str);
|
|
||||||
|
|
||||||
|
/* Current, best practice */
|
||||||
|
char * qemuBuildNicDevStr(virDomainNetDefPtr net);
|
||||||
|
|
||||||
char * qemuBuildDriveStr (virDomainDiskDefPtr disk,
|
/* Both legacy & current support */
|
||||||
|
char *qemuBuildDriveStr(virDomainDiskDefPtr disk,
|
||||||
int bootable,
|
int bootable,
|
||||||
int qemuCmdFlags);
|
int qemuCmdFlags);
|
||||||
|
|
||||||
|
/* Current, best practice */
|
||||||
|
char * qemuBuildDriveDevStr(virConnectPtr conn,
|
||||||
|
virDomainDiskDefPtr disk);
|
||||||
|
/* Current, best practice */
|
||||||
|
char * qemuBuildControllerDevStr(virDomainControllerDefPtr def);
|
||||||
|
|
||||||
|
char * qemuBuildWatchdogDevStr(virDomainWatchdogDefPtr dev);
|
||||||
|
|
||||||
|
char * qemuBuildUSBInputDevStr(virDomainInputDefPtr dev);
|
||||||
|
|
||||||
|
char * qemuBuildSoundDevStr(virDomainSoundDefPtr sound);
|
||||||
|
|
||||||
|
char * qemuBuildPCIHostdevDevStr(virDomainHostdevDefPtr dev);
|
||||||
|
|
||||||
|
char * qemuBuildChrChardevStr(virDomainChrDefPtr dev);
|
||||||
|
char * qemuBuildChrArgStr(virDomainChrDefPtr dev, const char *prefix);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int qemudNetworkIfaceConnect (virConnectPtr conn,
|
int qemudNetworkIfaceConnect (virConnectPtr conn,
|
||||||
struct qemud_driver *driver,
|
struct qemud_driver *driver,
|
||||||
virDomainNetDefPtr net,
|
virDomainNetDefPtr net,
|
||||||
|
@ -5522,8 +5522,8 @@ static int qemudDomainAttachNetDevice(virConnectPtr conn,
|
|||||||
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
qemuDomainObjExitMonitorWithDriver(driver, vm);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qemuBuildHostNetStr(conn, net, ' ',
|
if (!(netstr = qemuBuildHostNetStr(conn, net, ' ',
|
||||||
net->vlan, tapfd_name, &netstr) < 0)
|
net->vlan, tapfd_name)))
|
||||||
goto try_tapfd_close;
|
goto try_tapfd_close;
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
@ -5537,7 +5537,7 @@ static int qemudDomainAttachNetDevice(virConnectPtr conn,
|
|||||||
close(tapfd);
|
close(tapfd);
|
||||||
tapfd = -1;
|
tapfd = -1;
|
||||||
|
|
||||||
if (qemuBuildNicStr(conn, net, NULL, net->vlan, &nicstr) < 0)
|
if (!(nicstr = qemuBuildNicStr(conn, net, NULL, net->vlan)))
|
||||||
goto try_remove;
|
goto try_remove;
|
||||||
|
|
||||||
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
qemuDomainObjEnterMonitorWithDriver(driver, vm);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user