mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-02-22 11:22:23 +00:00
ch_monitor: Get nicindexes in prep for cgroup mgmt
Signed-off-by: Vineeth Pillai <viremana@linux.microsoft.com> Signed-off-by: Praveen K Paladugu <prapal@linux.microsoft.com> Signed-off-by: Michal Privoznik <mprivozn@redhat.com> Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
df6d4ff4d2
commit
dfb5574df6
@ -44,6 +44,8 @@ struct _virCHDriver
|
|||||||
{
|
{
|
||||||
virMutex lock;
|
virMutex lock;
|
||||||
|
|
||||||
|
bool privileged;
|
||||||
|
|
||||||
/* Require lock to get a reference on the object,
|
/* Require lock to get a reference on the object,
|
||||||
* lockless access thereafter */
|
* lockless access thereafter */
|
||||||
virCaps *caps;
|
virCaps *caps;
|
||||||
|
@ -21,10 +21,12 @@
|
|||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
|
||||||
#include "ch_domain.h"
|
#include "ch_domain.h"
|
||||||
|
#include "domain_driver.h"
|
||||||
#include "viralloc.h"
|
#include "viralloc.h"
|
||||||
#include "virchrdev.h"
|
#include "virchrdev.h"
|
||||||
#include "virlog.h"
|
#include "virlog.h"
|
||||||
#include "virtime.h"
|
#include "virtime.h"
|
||||||
|
#include "virsystemd.h"
|
||||||
|
|
||||||
#define VIR_FROM_THIS VIR_FROM_CH
|
#define VIR_FROM_THIS VIR_FROM_CH
|
||||||
|
|
||||||
@ -134,7 +136,7 @@ virCHDomainObjEndJob(virDomainObj *obj)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void *
|
static void *
|
||||||
virCHDomainObjPrivateAlloc(void *opaque G_GNUC_UNUSED)
|
virCHDomainObjPrivateAlloc(void *opaque)
|
||||||
{
|
{
|
||||||
virCHDomainObjPrivate *priv;
|
virCHDomainObjPrivate *priv;
|
||||||
|
|
||||||
@ -150,6 +152,7 @@ virCHDomainObjPrivateAlloc(void *opaque G_GNUC_UNUSED)
|
|||||||
g_free(priv);
|
g_free(priv);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
priv->driver = opaque;
|
||||||
|
|
||||||
return priv;
|
return priv;
|
||||||
}
|
}
|
||||||
@ -161,6 +164,7 @@ virCHDomainObjPrivateFree(void *data)
|
|||||||
|
|
||||||
virChrdevFree(priv->chrdevs);
|
virChrdevFree(priv->chrdevs);
|
||||||
virCHDomainObjFreeJob(priv);
|
virCHDomainObjFreeJob(priv);
|
||||||
|
g_free(priv->machineName);
|
||||||
g_free(priv);
|
g_free(priv);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -356,3 +360,25 @@ virCHDomainHasVcpuPids(virDomainObj *vm)
|
|||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *
|
||||||
|
virCHDomainGetMachineName(virDomainObj *vm)
|
||||||
|
{
|
||||||
|
virCHDomainObjPrivate *priv = CH_DOMAIN_PRIVATE(vm);
|
||||||
|
virCHDriver *driver = priv->driver;
|
||||||
|
char *ret = NULL;
|
||||||
|
|
||||||
|
if (vm->pid > 0) {
|
||||||
|
ret = virSystemdGetMachineNameByPID(vm->pid);
|
||||||
|
if (!ret)
|
||||||
|
virResetLastError();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!ret)
|
||||||
|
ret = virDomainDriverGenerateMachineName("ch",
|
||||||
|
NULL,
|
||||||
|
vm->def->id, vm->def->name,
|
||||||
|
driver->privileged);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
@ -54,7 +54,9 @@ struct _virCHDomainObjPrivate {
|
|||||||
struct virCHDomainJobObj job;
|
struct virCHDomainJobObj job;
|
||||||
|
|
||||||
virChrdevs *chrdevs;
|
virChrdevs *chrdevs;
|
||||||
|
virCHDriver *driver;
|
||||||
virCHMonitor *monitor;
|
virCHMonitor *monitor;
|
||||||
|
char *machineName;
|
||||||
virBitmap *autoCpuset;
|
virBitmap *autoCpuset;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -91,3 +93,6 @@ virCHDomainGetVcpuPid(virDomainObj *vm,
|
|||||||
unsigned int vcpuid);
|
unsigned int vcpuid);
|
||||||
bool
|
bool
|
||||||
virCHDomainHasVcpuPids(virDomainObj *vm);
|
virCHDomainHasVcpuPids(virDomainObj *vm);
|
||||||
|
|
||||||
|
char *
|
||||||
|
virCHDomainGetMachineName(virDomainObj *vm);
|
||||||
|
@ -933,6 +933,7 @@ static int chStateInitialize(bool privileged,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ch_driver->privileged = privileged;
|
||||||
ret = VIR_DRV_STATE_INIT_COMPLETE;
|
ret = VIR_DRV_STATE_INIT_COMPLETE;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
|
@ -226,7 +226,10 @@ virCHMonitorBuildDisksJson(virJSONValue *content, virDomainDef *vmdef)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
virCHMonitorBuildNetJson(virJSONValue *nets, virDomainNetDef *netdef)
|
virCHMonitorBuildNetJson(virJSONValue *nets,
|
||||||
|
virDomainNetDef *netdef,
|
||||||
|
size_t *nnicindexes,
|
||||||
|
int **nicindexes)
|
||||||
{
|
{
|
||||||
virDomainNetType netType = virDomainNetGetActualType(netdef);
|
virDomainNetType netType = virDomainNetGetActualType(netdef);
|
||||||
char macaddr[VIR_MAC_STRING_BUFLEN];
|
char macaddr[VIR_MAC_STRING_BUFLEN];
|
||||||
@ -236,59 +239,72 @@ virCHMonitorBuildNetJson(virJSONValue *nets, virDomainNetDef *netdef)
|
|||||||
net = virJSONValueNewObject();
|
net = virJSONValueNewObject();
|
||||||
|
|
||||||
switch (netType) {
|
switch (netType) {
|
||||||
case VIR_DOMAIN_NET_TYPE_ETHERNET:
|
case VIR_DOMAIN_NET_TYPE_ETHERNET:
|
||||||
if (netdef->guestIP.nips == 1) {
|
if (netdef->guestIP.nips == 1) {
|
||||||
const virNetDevIPAddr *ip = netdef->guestIP.ips[0];
|
const virNetDevIPAddr *ip = netdef->guestIP.ips[0];
|
||||||
g_autofree char *addr = NULL;
|
g_autofree char *addr = NULL;
|
||||||
virSocketAddr netmask;
|
virSocketAddr netmask;
|
||||||
g_autofree char *netmaskStr = NULL;
|
g_autofree char *netmaskStr = NULL;
|
||||||
if (!(addr = virSocketAddrFormat(&ip->address)))
|
|
||||||
return -1;
|
|
||||||
if (virJSONValueObjectAppendString(net, "ip", addr) < 0)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
if (virSocketAddrPrefixToNetmask(ip->prefix, &netmask, AF_INET) < 0) {
|
if (!(addr = virSocketAddrFormat(&ip->address)))
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
return -1;
|
||||||
_("Failed to translate net prefix %d to netmask"),
|
if (virJSONValueObjectAppendString(net, "ip", addr) < 0)
|
||||||
ip->prefix);
|
return -1;
|
||||||
return -1;
|
|
||||||
|
if (virSocketAddrPrefixToNetmask(ip->prefix, &netmask, AF_INET) < 0) {
|
||||||
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
|
_("Failed to translate net prefix %d to netmask"),
|
||||||
|
ip->prefix);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if (!(netmaskStr = virSocketAddrFormat(&netmask)))
|
||||||
|
return -1;
|
||||||
|
if (virJSONValueObjectAppendString(net, "mask", netmaskStr) < 0)
|
||||||
|
return -1;
|
||||||
|
} else if (netdef->guestIP.nips > 1) {
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
|
_("ethernet type supports a single guest ip"));
|
||||||
}
|
}
|
||||||
if (!(netmaskStr = virSocketAddrFormat(&netmask)))
|
|
||||||
return -1;
|
/* network and bridge use a tap device, and direct uses a
|
||||||
if (virJSONValueObjectAppendString(net, "mask", netmaskStr) < 0)
|
* macvtap device
|
||||||
return -1;
|
*/
|
||||||
} else if (netdef->guestIP.nips > 1) {
|
if (nicindexes && nnicindexes && netdef->ifname) {
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
int nicindex = 0;
|
||||||
_("ethernet type supports a single guest ip"));
|
|
||||||
}
|
if (virNetDevGetIndex(netdef->ifname, &nicindex) < 0)
|
||||||
break;
|
return -1;
|
||||||
case VIR_DOMAIN_NET_TYPE_VHOSTUSER:
|
|
||||||
if ((virDomainChrType)netdef->data.vhostuser->type != VIR_DOMAIN_CHR_TYPE_UNIX) {
|
VIR_APPEND_ELEMENT(*nicindexes, *nnicindexes, nicindex);
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
}
|
||||||
|
break;
|
||||||
|
case VIR_DOMAIN_NET_TYPE_VHOSTUSER:
|
||||||
|
if ((virDomainChrType)netdef->data.vhostuser->type != VIR_DOMAIN_CHR_TYPE_UNIX) {
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
_("vhost_user type support UNIX socket in this CH"));
|
_("vhost_user type support UNIX socket in this CH"));
|
||||||
|
return -1;
|
||||||
|
} else {
|
||||||
|
if (virJSONValueObjectAppendString(net, "vhost_socket", netdef->data.vhostuser->data.nix.path) < 0)
|
||||||
|
return -1;
|
||||||
|
if (virJSONValueObjectAppendBoolean(net, "vhost_user", true) < 0)
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case VIR_DOMAIN_NET_TYPE_BRIDGE:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_NETWORK:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_DIRECT:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_USER:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_SERVER:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_CLIENT:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_MCAST:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_INTERNAL:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_HOSTDEV:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_UDP:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_VDPA:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_LAST:
|
||||||
|
default:
|
||||||
|
virReportEnumRangeError(virDomainNetType, netType);
|
||||||
return -1;
|
return -1;
|
||||||
} else {
|
|
||||||
if (virJSONValueObjectAppendString(net, "vhost_socket", netdef->data.vhostuser->data.nix.path) < 0)
|
|
||||||
return -1;
|
|
||||||
if (virJSONValueObjectAppendBoolean(net, "vhost_user", true) < 0)
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case VIR_DOMAIN_NET_TYPE_BRIDGE:
|
|
||||||
case VIR_DOMAIN_NET_TYPE_NETWORK:
|
|
||||||
case VIR_DOMAIN_NET_TYPE_DIRECT:
|
|
||||||
case VIR_DOMAIN_NET_TYPE_USER:
|
|
||||||
case VIR_DOMAIN_NET_TYPE_SERVER:
|
|
||||||
case VIR_DOMAIN_NET_TYPE_CLIENT:
|
|
||||||
case VIR_DOMAIN_NET_TYPE_MCAST:
|
|
||||||
case VIR_DOMAIN_NET_TYPE_INTERNAL:
|
|
||||||
case VIR_DOMAIN_NET_TYPE_HOSTDEV:
|
|
||||||
case VIR_DOMAIN_NET_TYPE_UDP:
|
|
||||||
case VIR_DOMAIN_NET_TYPE_VDPA:
|
|
||||||
case VIR_DOMAIN_NET_TYPE_LAST:
|
|
||||||
default:
|
|
||||||
virReportEnumRangeError(virDomainNetType, netType);
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (netdef->ifname != NULL) {
|
if (netdef->ifname != NULL) {
|
||||||
@ -329,7 +345,10 @@ virCHMonitorBuildNetJson(virJSONValue *nets, virDomainNetDef *netdef)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
virCHMonitorBuildNetsJson(virJSONValue *content, virDomainDef *vmdef)
|
virCHMonitorBuildNetsJson(virJSONValue *content,
|
||||||
|
virDomainDef *vmdef,
|
||||||
|
size_t *nnicindexes,
|
||||||
|
int **nicindexes)
|
||||||
{
|
{
|
||||||
g_autoptr(virJSONValue) nets = NULL;
|
g_autoptr(virJSONValue) nets = NULL;
|
||||||
size_t i;
|
size_t i;
|
||||||
@ -338,7 +357,8 @@ virCHMonitorBuildNetsJson(virJSONValue *content, virDomainDef *vmdef)
|
|||||||
nets = virJSONValueNewArray();
|
nets = virJSONValueNewArray();
|
||||||
|
|
||||||
for (i = 0; i < vmdef->nnets; i++) {
|
for (i = 0; i < vmdef->nnets; i++) {
|
||||||
if (virCHMonitorBuildNetJson(nets, vmdef->nets[i]) < 0)
|
if (virCHMonitorBuildNetJson(nets, vmdef->nets[i],
|
||||||
|
nnicindexes, nicindexes) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if (virJSONValueObjectAppend(content, "net", &nets) < 0)
|
if (virJSONValueObjectAppend(content, "net", &nets) < 0)
|
||||||
@ -349,7 +369,62 @@ virCHMonitorBuildNetsJson(virJSONValue *content, virDomainDef *vmdef)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
virCHMonitorBuildVMJson(virDomainDef *vmdef, char **jsonstr)
|
virCHMonitorBuildDeviceJson(virJSONValue *devices,
|
||||||
|
virDomainHostdevDef *hostdevdef)
|
||||||
|
{
|
||||||
|
g_autoptr(virJSONValue) device = NULL;
|
||||||
|
|
||||||
|
|
||||||
|
if (hostdevdef->mode == VIR_DOMAIN_HOSTDEV_MODE_SUBSYS &&
|
||||||
|
hostdevdef->source.subsys.type == VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI) {
|
||||||
|
g_autofree char *name = NULL;
|
||||||
|
g_autofree char *path = NULL;
|
||||||
|
virDomainHostdevSubsysPCI *pcisrc = &hostdevdef->source.subsys.u.pci;
|
||||||
|
|
||||||
|
device = virJSONValueNewObject();
|
||||||
|
name = virPCIDeviceAddressAsString(&pcisrc->addr);
|
||||||
|
path = g_strdup_printf("/sys/bus/pci/devices/%s/", name);
|
||||||
|
if (!virFileExists(path)) {
|
||||||
|
virReportError(VIR_ERR_DEVICE_MISSING,
|
||||||
|
_("host pci device %s not found"), path);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if (virJSONValueObjectAppendString(device, "path", path) < 0)
|
||||||
|
return -1;
|
||||||
|
if (virJSONValueArrayAppend(devices, &device) < 0)
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
virCHMonitorBuildDevicesJson(virJSONValue *content,
|
||||||
|
virDomainDef *vmdef)
|
||||||
|
{
|
||||||
|
size_t i;
|
||||||
|
|
||||||
|
g_autoptr(virJSONValue) devices = NULL;
|
||||||
|
|
||||||
|
if (vmdef->nhostdevs == 0)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
devices = virJSONValueNewArray();
|
||||||
|
for (i = 0; i < vmdef->nhostdevs; i++) {
|
||||||
|
if (virCHMonitorBuildDeviceJson(devices, vmdef->hostdevs[i]) < 0)
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if (virJSONValueObjectAppend(content, "devices", &devices) < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
virCHMonitorBuildVMJson(virDomainDef *vmdef,
|
||||||
|
char **jsonstr,
|
||||||
|
size_t *nnicindexes,
|
||||||
|
int **nicindexes)
|
||||||
{
|
{
|
||||||
g_autoptr(virJSONValue) content = virJSONValueNewObject();
|
g_autoptr(virJSONValue) content = virJSONValueNewObject();
|
||||||
|
|
||||||
@ -374,7 +449,11 @@ virCHMonitorBuildVMJson(virDomainDef *vmdef, char **jsonstr)
|
|||||||
if (virCHMonitorBuildDisksJson(content, vmdef) < 0)
|
if (virCHMonitorBuildDisksJson(content, vmdef) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (virCHMonitorBuildNetsJson(content, vmdef) < 0)
|
|
||||||
|
if (virCHMonitorBuildNetsJson(content, vmdef, nnicindexes, nicindexes) < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
if (virCHMonitorBuildDevicesJson(content, vmdef) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (!(*jsonstr = virJSONValueToString(content, false)))
|
if (!(*jsonstr = virJSONValueToString(content, false)))
|
||||||
@ -671,7 +750,9 @@ virCHMonitorShutdownVMM(virCHMonitor *mon)
|
|||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
virCHMonitorCreateVM(virCHMonitor *mon)
|
virCHMonitorCreateVM(virCHMonitor *mon,
|
||||||
|
size_t *nnicindexes,
|
||||||
|
int **nicindexes)
|
||||||
{
|
{
|
||||||
g_autofree char *url = NULL;
|
g_autofree char *url = NULL;
|
||||||
int responseCode = 0;
|
int responseCode = 0;
|
||||||
@ -683,7 +764,8 @@ virCHMonitorCreateVM(virCHMonitor *mon)
|
|||||||
headers = curl_slist_append(headers, "Accept: application/json");
|
headers = curl_slist_append(headers, "Accept: application/json");
|
||||||
headers = curl_slist_append(headers, "Content-Type: application/json");
|
headers = curl_slist_append(headers, "Content-Type: application/json");
|
||||||
|
|
||||||
if (virCHMonitorBuildVMJson(mon->vm->def, &payload) != 0)
|
if (virCHMonitorBuildVMJson(mon->vm->def, &payload,
|
||||||
|
nnicindexes, nicindexes) != 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
virObjectLock(mon);
|
virObjectLock(mon);
|
||||||
|
@ -55,10 +55,23 @@ virCHMonitor *virCHMonitorNew(virDomainObj *vm, const char *socketdir);
|
|||||||
void virCHMonitorClose(virCHMonitor *mon);
|
void virCHMonitorClose(virCHMonitor *mon);
|
||||||
G_DEFINE_AUTOPTR_CLEANUP_FUNC(virCHMonitor, virCHMonitorClose);
|
G_DEFINE_AUTOPTR_CLEANUP_FUNC(virCHMonitor, virCHMonitorClose);
|
||||||
|
|
||||||
int virCHMonitorCreateVM(virCHMonitor *mon);
|
|
||||||
|
int virCHMonitorCreateVM(virCHMonitor *mon,
|
||||||
|
size_t *nnicindexes,
|
||||||
|
int **nicindexes);
|
||||||
int virCHMonitorBootVM(virCHMonitor *mon);
|
int virCHMonitorBootVM(virCHMonitor *mon);
|
||||||
int virCHMonitorShutdownVM(virCHMonitor *mon);
|
int virCHMonitorShutdownVM(virCHMonitor *mon);
|
||||||
int virCHMonitorRebootVM(virCHMonitor *mon);
|
int virCHMonitorRebootVM(virCHMonitor *mon);
|
||||||
int virCHMonitorSuspendVM(virCHMonitor *mon);
|
int virCHMonitorSuspendVM(virCHMonitor *mon);
|
||||||
int virCHMonitorResumeVM(virCHMonitor *mon);
|
int virCHMonitorResumeVM(virCHMonitor *mon);
|
||||||
int virCHMonitorGetInfo(virCHMonitor *mon, virJSONValue **info);
|
int virCHMonitorGetInfo(virCHMonitor *mon, virJSONValue **info);
|
||||||
|
|
||||||
|
typedef struct _virCHMonitorCPUInfo virCHMonitorCPUInfo;
|
||||||
|
struct _virCHMonitorCPUInfo {
|
||||||
|
pid_t tid;
|
||||||
|
bool online;
|
||||||
|
};
|
||||||
|
void virCHMonitorCPUInfoFree(virCHMonitorCPUInfo *cpus);
|
||||||
|
int virCHMonitorGetCPUInfo(virCHMonitor *mon,
|
||||||
|
virCHMonitorCPUInfo **vcpus,
|
||||||
|
size_t maxvcpus);
|
||||||
|
@ -147,6 +147,8 @@ int virCHProcessStart(virCHDriver *driver,
|
|||||||
{
|
{
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
virCHDomainObjPrivate *priv = vm->privateData;
|
virCHDomainObjPrivate *priv = vm->privateData;
|
||||||
|
g_autofree int *nicindexes = NULL;
|
||||||
|
size_t nnicindexes = 0;
|
||||||
|
|
||||||
if (!priv->monitor) {
|
if (!priv->monitor) {
|
||||||
/* And we can get the first monitor connection now too */
|
/* And we can get the first monitor connection now too */
|
||||||
@ -156,7 +158,8 @@ int virCHProcessStart(virCHDriver *driver,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virCHMonitorCreateVM(priv->monitor) < 0) {
|
if (virCHMonitorCreateVM(priv->monitor,
|
||||||
|
&nnicindexes, &nicindexes) < 0) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
||||||
_("failed to create guest VM"));
|
_("failed to create guest VM"));
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -169,6 +172,7 @@ int virCHProcessStart(virCHDriver *driver,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
priv->machineName = virCHDomainGetMachineName(vm);
|
||||||
vm->pid = priv->monitor->pid;
|
vm->pid = priv->monitor->pid;
|
||||||
vm->def->id = vm->pid;
|
vm->def->id = vm->pid;
|
||||||
|
|
||||||
@ -201,6 +205,7 @@ int virCHProcessStop(virCHDriver *driver G_GNUC_UNUSED,
|
|||||||
|
|
||||||
vm->pid = -1;
|
vm->pid = -1;
|
||||||
vm->def->id = -1;
|
vm->def->id = -1;
|
||||||
|
g_clear_pointer(&priv->machineName, g_free);
|
||||||
|
|
||||||
virDomainObjSetState(vm, VIR_DOMAIN_SHUTOFF, reason);
|
virDomainObjSetState(vm, VIR_DOMAIN_SHUTOFF, reason);
|
||||||
|
|
||||||
|
@ -29,6 +29,7 @@ if conf.has('WITH_CH')
|
|||||||
],
|
],
|
||||||
include_directories: [
|
include_directories: [
|
||||||
conf_inc_dir,
|
conf_inc_dir,
|
||||||
|
hypervisor_inc_dir,
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user