2005-12-07 18:10:51 +00:00
|
|
|
/*
|
|
|
|
* xen_internal.c: direct access to Xen hypervisor level
|
|
|
|
*
|
|
|
|
* Copyright (C) 2005 Red Hat, Inc.
|
|
|
|
*
|
|
|
|
* See COPYING.LIB for the License of this software
|
|
|
|
*
|
|
|
|
* Daniel Veillard <veillard@redhat.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
2006-03-23 15:42:10 +00:00
|
|
|
/* required for uint8_t, uint32_t, etc ... */
|
2005-12-07 18:10:51 +00:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <sys/mman.h>
|
|
|
|
#include <sys/ioctl.h>
|
|
|
|
|
2006-03-23 15:42:10 +00:00
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
/* required for dom0_getdomaininfo_t */
|
2005-12-07 18:10:51 +00:00
|
|
|
#include <xen/dom0_ops.h>
|
2005-12-08 13:26:52 +00:00
|
|
|
#include <xen/version.h>
|
2005-12-07 18:10:51 +00:00
|
|
|
#include <xen/xen.h>
|
|
|
|
|
|
|
|
#ifndef __LINUX_PUBLIC_PRIVCMD_H__
|
2006-03-15 12:13:25 +00:00
|
|
|
typedef struct hypercall_struct {
|
2005-12-07 18:10:51 +00:00
|
|
|
unsigned long op;
|
|
|
|
unsigned long arg[5];
|
|
|
|
} hypercall_t;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#include "internal.h"
|
2006-03-20 17:49:28 +00:00
|
|
|
#include "driver.h"
|
2005-12-07 18:10:51 +00:00
|
|
|
#include "xen_internal.h"
|
|
|
|
|
|
|
|
#define XEN_HYPERVISOR_SOCKET "/proc/xen/privcmd"
|
|
|
|
|
2006-03-20 23:42:12 +00:00
|
|
|
static virDriver xenHypervisorDriver = {
|
|
|
|
"Xen",
|
|
|
|
NULL, /* init */
|
|
|
|
xenHypervisorOpen, /* open */
|
|
|
|
xenHypervisorClose, /* close */
|
|
|
|
NULL, /* type */
|
|
|
|
xenHypervisorGetVersion, /* version */
|
2006-03-29 12:46:03 +00:00
|
|
|
NULL, /* nodeGetInfo */
|
2006-03-20 23:42:12 +00:00
|
|
|
NULL, /* listDomains */
|
|
|
|
NULL, /* numOfDomains */
|
|
|
|
NULL, /* domainCreateLinux */
|
|
|
|
NULL, /* domainLookupByID */
|
|
|
|
NULL, /* domainLookupByUUID */
|
|
|
|
NULL, /* domainLookupByName */
|
|
|
|
xenHypervisorPauseDomain, /* domainSuspend */
|
|
|
|
xenHypervisorResumeDomain, /* domainResume */
|
|
|
|
NULL, /* domainShutdown */
|
2006-04-03 13:46:43 +00:00
|
|
|
NULL, /* domainReboot */
|
2006-03-20 23:42:12 +00:00
|
|
|
xenHypervisorDestroyDomain, /* domainDestroy */
|
|
|
|
NULL, /* domainFree */
|
|
|
|
NULL, /* domainGetName */
|
|
|
|
NULL, /* domainGetID */
|
|
|
|
NULL, /* domainGetUUID */
|
|
|
|
NULL, /* domainGetOSType */
|
|
|
|
NULL, /* domainGetMaxMemory */
|
|
|
|
xenHypervisorSetMaxMemory, /* domainSetMaxMemory */
|
2006-04-13 17:18:49 +00:00
|
|
|
NULL, /* domainSetMemory */
|
2006-03-20 23:42:12 +00:00
|
|
|
xenHypervisorGetDomainInfo, /* domainGetInfo */
|
|
|
|
NULL, /* domainSave */
|
|
|
|
NULL /* domainRestore */
|
|
|
|
};
|
|
|
|
|
2006-03-27 15:24:36 +00:00
|
|
|
/**
|
|
|
|
* xenHypervisorRegister:
|
|
|
|
*
|
|
|
|
* Registers the xenHypervisor driver
|
|
|
|
*/
|
|
|
|
void xenHypervisorRegister(void)
|
|
|
|
{
|
|
|
|
virRegisterDriver(&xenHypervisorDriver);
|
|
|
|
}
|
|
|
|
|
2006-02-27 21:34:28 +00:00
|
|
|
/**
|
|
|
|
* virXenError:
|
|
|
|
* @conn: the connection if available
|
|
|
|
* @error: the error number
|
|
|
|
* @info: extra information string
|
|
|
|
*
|
|
|
|
* Handle an error at the xend daemon interface
|
|
|
|
*/
|
|
|
|
static void
|
2006-03-15 12:13:25 +00:00
|
|
|
virXenError(virErrorNumber error, const char *info, int value)
|
|
|
|
{
|
2006-02-27 21:34:28 +00:00
|
|
|
const char *errmsg;
|
2006-03-15 12:13:25 +00:00
|
|
|
|
2006-02-27 21:34:28 +00:00
|
|
|
if (error == VIR_ERR_OK)
|
|
|
|
return;
|
|
|
|
|
|
|
|
errmsg = __virErrorMsg(error, info);
|
|
|
|
__virRaiseError(NULL, NULL, VIR_FROM_XEN, error, VIR_ERR_ERROR,
|
2006-03-15 12:13:25 +00:00
|
|
|
errmsg, info, NULL, value, 0, errmsg, info, value);
|
2006-02-27 21:34:28 +00:00
|
|
|
}
|
|
|
|
|
2005-12-07 18:10:51 +00:00
|
|
|
/**
|
|
|
|
* xenHypervisorOpen:
|
2006-03-20 17:49:28 +00:00
|
|
|
* @conn: pointer to the connection block
|
|
|
|
* @name: URL for the target, NULL for local
|
|
|
|
* @flags: combination of virDrvOpenFlag(s)
|
2005-12-07 18:10:51 +00:00
|
|
|
*
|
|
|
|
* Connects to the Xen hypervisor.
|
|
|
|
*
|
2006-03-20 17:49:28 +00:00
|
|
|
* Returns 0 or -1 in case of error.
|
2005-12-07 18:10:51 +00:00
|
|
|
*/
|
2006-03-15 12:13:25 +00:00
|
|
|
int
|
2006-03-20 17:49:28 +00:00
|
|
|
xenHypervisorOpen(virConnectPtr conn, const char *name, int flags)
|
2006-03-15 12:13:25 +00:00
|
|
|
{
|
2005-12-07 18:10:51 +00:00
|
|
|
int ret;
|
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
if ((name != NULL) && (strcmp(name, "xen")))
|
|
|
|
return(-1);
|
|
|
|
|
|
|
|
conn->handle = -1;
|
|
|
|
|
2005-12-07 18:10:51 +00:00
|
|
|
ret = open(XEN_HYPERVISOR_SOCKET, O_RDWR);
|
2006-02-27 21:34:28 +00:00
|
|
|
if (ret < 0) {
|
2006-03-20 17:49:28 +00:00
|
|
|
if (!(flags & VIR_DRV_OPEN_QUIET))
|
2006-03-15 12:13:25 +00:00
|
|
|
virXenError(VIR_ERR_NO_XEN, XEN_HYPERVISOR_SOCKET, 0);
|
|
|
|
return (-1);
|
2006-02-27 21:34:28 +00:00
|
|
|
}
|
2006-03-20 17:49:28 +00:00
|
|
|
conn->handle = ret;
|
2005-12-07 18:10:51 +00:00
|
|
|
|
2006-03-15 12:13:25 +00:00
|
|
|
return (ret);
|
2005-12-07 18:10:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* xenHypervisorClose:
|
2006-03-20 17:49:28 +00:00
|
|
|
* @conn: pointer to the connection block
|
2005-12-07 18:10:51 +00:00
|
|
|
*
|
|
|
|
* Close the connection to the Xen hypervisor.
|
|
|
|
*
|
|
|
|
* Returns 0 in case of success or -1 in case of error.
|
|
|
|
*/
|
2006-03-15 12:13:25 +00:00
|
|
|
int
|
2006-03-20 17:49:28 +00:00
|
|
|
xenHypervisorClose(virConnectPtr conn)
|
2006-03-15 12:13:25 +00:00
|
|
|
{
|
2005-12-07 18:10:51 +00:00
|
|
|
int ret;
|
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
if ((conn == NULL) || (conn->handle < 0))
|
2006-03-15 12:13:25 +00:00
|
|
|
return (-1);
|
2005-12-07 18:10:51 +00:00
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
ret = close(conn->handle);
|
2005-12-07 18:10:51 +00:00
|
|
|
if (ret < 0)
|
2006-03-15 12:13:25 +00:00
|
|
|
return (-1);
|
|
|
|
return (0);
|
2005-12-07 18:10:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* xenHypervisorDoOp:
|
|
|
|
* @handle: the handle to the Xen hypervisor
|
|
|
|
* @op: pointer to the hyperviros operation structure
|
|
|
|
*
|
|
|
|
* Do an hypervisor operation, this leads to an hypervisor call through ioctl.
|
|
|
|
*
|
|
|
|
* Returns 0 in case of success and -1 in case of error.
|
|
|
|
*/
|
|
|
|
static int
|
2006-03-15 12:13:25 +00:00
|
|
|
xenHypervisorDoOp(int handle, dom0_op_t * op)
|
|
|
|
{
|
2005-12-07 18:10:51 +00:00
|
|
|
int ret;
|
2005-12-08 10:12:18 +00:00
|
|
|
unsigned int cmd;
|
2005-12-07 18:10:51 +00:00
|
|
|
hypercall_t hc;
|
|
|
|
|
|
|
|
op->interface_version = DOM0_INTERFACE_VERSION;
|
|
|
|
hc.op = __HYPERVISOR_dom0_op;
|
2006-03-15 12:13:25 +00:00
|
|
|
hc.arg[0] = (unsigned long) op;
|
2005-12-07 18:10:51 +00:00
|
|
|
|
2006-02-27 21:34:28 +00:00
|
|
|
if (mlock(op, sizeof(dom0_op_t)) < 0) {
|
|
|
|
virXenError(VIR_ERR_XEN_CALL, " locking", sizeof(dom0_op_t));
|
2006-03-15 12:13:25 +00:00
|
|
|
return (-1);
|
2006-02-27 21:34:28 +00:00
|
|
|
}
|
2005-12-07 18:10:51 +00:00
|
|
|
|
2005-12-08 10:12:18 +00:00
|
|
|
cmd = _IOC(_IOC_NONE, 'P', 0, sizeof(hc));
|
|
|
|
ret = ioctl(handle, cmd, (unsigned long) &hc);
|
2006-02-27 21:34:28 +00:00
|
|
|
if (ret < 0) {
|
|
|
|
virXenError(VIR_ERR_XEN_CALL, " ioctl ", cmd);
|
|
|
|
}
|
2005-12-07 18:10:51 +00:00
|
|
|
|
2006-02-27 21:34:28 +00:00
|
|
|
if (munlock(op, sizeof(dom0_op_t)) < 0) {
|
|
|
|
virXenError(VIR_ERR_XEN_CALL, " releasing", sizeof(dom0_op_t));
|
2005-12-07 18:10:51 +00:00
|
|
|
ret = -1;
|
2006-02-27 21:34:28 +00:00
|
|
|
}
|
2005-12-07 18:10:51 +00:00
|
|
|
|
|
|
|
if (ret < 0)
|
2006-03-15 12:13:25 +00:00
|
|
|
return (-1);
|
|
|
|
|
|
|
|
return (0);
|
2005-12-07 18:10:51 +00:00
|
|
|
}
|
|
|
|
|
2005-12-08 13:26:52 +00:00
|
|
|
/**
|
|
|
|
* xenHypervisorGetVersion:
|
2006-03-20 17:49:28 +00:00
|
|
|
* @conn: pointer to the connection block
|
|
|
|
* @hvVer: where to store the version
|
2005-12-08 13:26:52 +00:00
|
|
|
*
|
|
|
|
* Call the hypervisor to extracts his own internal API version
|
|
|
|
*
|
2006-03-20 17:49:28 +00:00
|
|
|
* Returns 0 in case of success, -1 in case of error
|
2005-12-08 13:26:52 +00:00
|
|
|
*/
|
2006-03-20 17:49:28 +00:00
|
|
|
int
|
|
|
|
xenHypervisorGetVersion(virConnectPtr conn, unsigned long *hvVer)
|
2006-03-15 12:13:25 +00:00
|
|
|
{
|
2005-12-08 13:26:52 +00:00
|
|
|
int ret;
|
|
|
|
unsigned int cmd;
|
|
|
|
hypercall_t hc;
|
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
if ((conn == NULL) || (conn->handle < 0) || (hvVer == NULL))
|
|
|
|
return (-1);
|
|
|
|
*hvVer = 0;
|
|
|
|
|
2005-12-08 13:26:52 +00:00
|
|
|
hc.op = __HYPERVISOR_xen_version;
|
2006-03-15 12:13:25 +00:00
|
|
|
hc.arg[0] = (unsigned long) XENVER_version;
|
2005-12-08 13:26:52 +00:00
|
|
|
hc.arg[1] = 0;
|
|
|
|
|
|
|
|
cmd = _IOC(_IOC_NONE, 'P', 0, sizeof(hc));
|
2006-03-20 17:49:28 +00:00
|
|
|
ret = ioctl(conn->handle, cmd, (unsigned long) &hc);
|
2005-12-08 13:26:52 +00:00
|
|
|
|
2006-02-27 21:34:28 +00:00
|
|
|
if (ret < 0) {
|
|
|
|
virXenError(VIR_ERR_XEN_CALL, " getting version ", XENVER_version);
|
2006-03-20 17:49:28 +00:00
|
|
|
return (-1);
|
2006-02-27 21:34:28 +00:00
|
|
|
}
|
2006-03-20 17:49:28 +00:00
|
|
|
*hvVer = (ret >> 16) * 1000000 + (ret & 0xFFFF) * 1000;
|
|
|
|
return(0);
|
2005-12-08 13:26:52 +00:00
|
|
|
}
|
|
|
|
|
2005-12-07 18:10:51 +00:00
|
|
|
/**
|
|
|
|
* xenHypervisorGetDomainInfo:
|
2006-03-20 17:49:28 +00:00
|
|
|
* @domain: pointer to the domain block
|
2005-12-07 18:10:51 +00:00
|
|
|
* @info: the place where informations should be stored
|
|
|
|
*
|
|
|
|
* Do an hypervisor call to get the related set of domain informations.
|
|
|
|
*
|
|
|
|
* Returns 0 in case of success, -1 in case of error.
|
|
|
|
*/
|
|
|
|
int
|
2006-03-20 17:49:28 +00:00
|
|
|
xenHypervisorGetDomainInfo(virDomainPtr domain, virDomainInfoPtr info)
|
2006-03-15 12:13:25 +00:00
|
|
|
{
|
2005-12-07 18:10:51 +00:00
|
|
|
dom0_op_t op;
|
2006-03-20 17:49:28 +00:00
|
|
|
dom0_getdomaininfo_t dominfo;
|
2005-12-07 18:10:51 +00:00
|
|
|
int ret;
|
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
if ((domain == NULL) || (domain->conn == NULL) ||
|
|
|
|
(domain->conn->handle < 0) || (info == NULL))
|
2006-03-15 12:13:25 +00:00
|
|
|
return (-1);
|
2005-12-07 18:10:51 +00:00
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
memset(info, 0, sizeof(virDomainInfo));
|
|
|
|
memset(&dominfo, 0, sizeof(dom0_getdomaininfo_t));
|
2005-12-07 18:10:51 +00:00
|
|
|
|
2006-02-27 21:34:28 +00:00
|
|
|
if (mlock(info, sizeof(dom0_getdomaininfo_t)) < 0) {
|
2006-03-15 12:13:25 +00:00
|
|
|
virXenError(VIR_ERR_XEN_CALL, " locking",
|
|
|
|
sizeof(dom0_getdomaininfo_t));
|
|
|
|
return (-1);
|
2006-02-27 21:34:28 +00:00
|
|
|
}
|
2005-12-07 18:10:51 +00:00
|
|
|
|
|
|
|
op.cmd = DOM0_GETDOMAININFOLIST;
|
2006-03-20 17:49:28 +00:00
|
|
|
op.u.getdomaininfolist.first_domain = (domid_t) domain->handle;
|
2005-12-07 18:10:51 +00:00
|
|
|
op.u.getdomaininfolist.max_domains = 1;
|
2006-03-20 17:49:28 +00:00
|
|
|
op.u.getdomaininfolist.buffer = &dominfo;
|
2005-12-08 10:12:18 +00:00
|
|
|
op.u.getdomaininfolist.num_domains = 1;
|
2006-03-20 17:49:28 +00:00
|
|
|
dominfo.domain = domain->handle;
|
2005-12-07 18:10:51 +00:00
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
ret = xenHypervisorDoOp(domain->conn->handle, &op);
|
2005-12-07 18:10:51 +00:00
|
|
|
|
2006-02-27 21:34:28 +00:00
|
|
|
if (munlock(info, sizeof(dom0_getdomaininfo_t)) < 0) {
|
2006-03-15 12:13:25 +00:00
|
|
|
virXenError(VIR_ERR_XEN_CALL, " release",
|
|
|
|
sizeof(dom0_getdomaininfo_t));
|
2005-12-07 18:10:51 +00:00
|
|
|
ret = -1;
|
2006-02-27 21:34:28 +00:00
|
|
|
}
|
2005-12-07 18:10:51 +00:00
|
|
|
|
2005-12-08 10:12:18 +00:00
|
|
|
if (ret < 0)
|
2006-03-15 12:13:25 +00:00
|
|
|
return (-1);
|
2006-03-20 17:49:28 +00:00
|
|
|
|
|
|
|
switch (dominfo.flags & 0xFF) {
|
|
|
|
case DOMFLAGS_DYING:
|
|
|
|
info->state = VIR_DOMAIN_SHUTDOWN;
|
|
|
|
break;
|
|
|
|
case DOMFLAGS_SHUTDOWN:
|
|
|
|
info->state = VIR_DOMAIN_SHUTOFF;
|
|
|
|
break;
|
|
|
|
case DOMFLAGS_PAUSED:
|
|
|
|
info->state = VIR_DOMAIN_PAUSED;
|
|
|
|
break;
|
|
|
|
case DOMFLAGS_BLOCKED:
|
|
|
|
info->state = VIR_DOMAIN_BLOCKED;
|
|
|
|
break;
|
|
|
|
case DOMFLAGS_RUNNING:
|
|
|
|
info->state = VIR_DOMAIN_RUNNING;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
info->state = VIR_DOMAIN_NONE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* the API brings back the cpu time in nanoseconds,
|
|
|
|
* convert to microseconds, same thing convert to
|
|
|
|
* kilobytes from page counts
|
|
|
|
*/
|
|
|
|
info->cpuTime = dominfo.cpu_time;
|
|
|
|
info->memory = dominfo.tot_pages * 4;
|
|
|
|
info->maxMem = dominfo.max_pages * 4;
|
|
|
|
info->nrVirtCpu = dominfo.nr_online_vcpus;
|
2006-03-15 12:13:25 +00:00
|
|
|
return (0);
|
2005-12-07 18:10:51 +00:00
|
|
|
}
|
|
|
|
|
2005-12-08 17:16:24 +00:00
|
|
|
/**
|
|
|
|
* xenHypervisorPauseDomain:
|
2006-03-20 17:49:28 +00:00
|
|
|
* @domain: pointer to the domain block
|
2005-12-08 17:16:24 +00:00
|
|
|
*
|
|
|
|
* Do an hypervisor call to pause the given domain
|
|
|
|
*
|
|
|
|
* Returns 0 in case of success, -1 in case of error.
|
|
|
|
*/
|
|
|
|
int
|
2006-03-20 17:49:28 +00:00
|
|
|
xenHypervisorPauseDomain(virDomainPtr domain)
|
2006-03-15 12:13:25 +00:00
|
|
|
{
|
2005-12-08 17:16:24 +00:00
|
|
|
dom0_op_t op;
|
|
|
|
int ret;
|
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
if ((domain == NULL) || (domain->conn == NULL) ||
|
|
|
|
(domain->conn->handle < 0))
|
|
|
|
return (-1);
|
|
|
|
|
2005-12-08 17:16:24 +00:00
|
|
|
op.cmd = DOM0_PAUSEDOMAIN;
|
2006-03-20 17:49:28 +00:00
|
|
|
op.u.pausedomain.domain = (domid_t) domain->handle;
|
2005-12-08 17:16:24 +00:00
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
ret = xenHypervisorDoOp(domain->conn->handle, &op);
|
2005-12-08 17:16:24 +00:00
|
|
|
|
|
|
|
if (ret < 0)
|
2006-03-15 12:13:25 +00:00
|
|
|
return (-1);
|
|
|
|
return (0);
|
2005-12-08 17:16:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* xenHypervisorResumeDomain:
|
2006-03-20 17:49:28 +00:00
|
|
|
* @domain: pointer to the domain block
|
2005-12-08 17:16:24 +00:00
|
|
|
*
|
|
|
|
* Do an hypervisor call to resume the given domain
|
|
|
|
*
|
|
|
|
* Returns 0 in case of success, -1 in case of error.
|
|
|
|
*/
|
|
|
|
int
|
2006-03-20 17:49:28 +00:00
|
|
|
xenHypervisorResumeDomain(virDomainPtr domain)
|
2006-03-15 12:13:25 +00:00
|
|
|
{
|
2005-12-08 17:16:24 +00:00
|
|
|
dom0_op_t op;
|
|
|
|
int ret;
|
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
if ((domain == NULL) || (domain->conn == NULL) ||
|
|
|
|
(domain->conn->handle < 0))
|
|
|
|
return (-1);
|
|
|
|
|
2005-12-08 17:16:24 +00:00
|
|
|
op.cmd = DOM0_UNPAUSEDOMAIN;
|
2006-03-20 17:49:28 +00:00
|
|
|
op.u.unpausedomain.domain = (domid_t) domain->handle;
|
2005-12-08 17:16:24 +00:00
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
ret = xenHypervisorDoOp(domain->conn->handle, &op);
|
2005-12-08 17:16:24 +00:00
|
|
|
|
|
|
|
if (ret < 0)
|
2006-03-15 12:13:25 +00:00
|
|
|
return (-1);
|
|
|
|
return (0);
|
2005-12-08 17:16:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* xenHypervisorDestroyDomain:
|
2006-03-20 17:49:28 +00:00
|
|
|
* @domain: pointer to the domain block
|
2005-12-08 17:16:24 +00:00
|
|
|
*
|
|
|
|
* Do an hypervisor call to destroy the given domain
|
|
|
|
*
|
|
|
|
* Returns 0 in case of success, -1 in case of error.
|
|
|
|
*/
|
|
|
|
int
|
2006-03-20 17:49:28 +00:00
|
|
|
xenHypervisorDestroyDomain(virDomainPtr domain)
|
2006-03-15 12:13:25 +00:00
|
|
|
{
|
2005-12-08 17:16:24 +00:00
|
|
|
dom0_op_t op;
|
|
|
|
int ret;
|
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
if ((domain == NULL) || (domain->conn == NULL) ||
|
|
|
|
(domain->conn->handle < 0))
|
|
|
|
return (-1);
|
|
|
|
|
2005-12-08 17:16:24 +00:00
|
|
|
op.cmd = DOM0_DESTROYDOMAIN;
|
2006-03-20 17:49:28 +00:00
|
|
|
op.u.destroydomain.domain = (domid_t) domain->handle;
|
2005-12-08 17:16:24 +00:00
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
ret = xenHypervisorDoOp(domain->conn->handle, &op);
|
2005-12-08 17:16:24 +00:00
|
|
|
|
|
|
|
if (ret < 0)
|
2006-03-15 12:13:25 +00:00
|
|
|
return (-1);
|
|
|
|
return (0);
|
2005-12-08 17:16:24 +00:00
|
|
|
}
|
|
|
|
|
2005-12-12 13:22:20 +00:00
|
|
|
/**
|
|
|
|
* xenHypervisorSetMaxMemory:
|
2006-03-20 17:49:28 +00:00
|
|
|
* @domain: pointer to the domain block
|
2005-12-12 13:22:20 +00:00
|
|
|
* @memory: the max memory size in kilobytes.
|
|
|
|
*
|
|
|
|
* Do an hypervisor call to change the maximum amount of memory used
|
|
|
|
*
|
|
|
|
* Returns 0 in case of success, -1 in case of error.
|
|
|
|
*/
|
|
|
|
int
|
2006-03-20 17:49:28 +00:00
|
|
|
xenHypervisorSetMaxMemory(virDomainPtr domain, unsigned long memory)
|
2006-03-15 12:13:25 +00:00
|
|
|
{
|
2005-12-12 13:22:20 +00:00
|
|
|
dom0_op_t op;
|
|
|
|
int ret;
|
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
if ((domain == NULL) || (domain->conn == NULL) ||
|
|
|
|
(domain->conn->handle < 0))
|
|
|
|
return (-1);
|
|
|
|
|
2005-12-12 13:22:20 +00:00
|
|
|
op.cmd = DOM0_SETDOMAINMAXMEM;
|
2006-03-20 17:49:28 +00:00
|
|
|
op.u.setdomainmaxmem.domain = (domid_t) domain->handle;
|
2005-12-12 13:22:20 +00:00
|
|
|
op.u.setdomainmaxmem.max_memkb = memory;
|
|
|
|
|
2006-03-20 17:49:28 +00:00
|
|
|
ret = xenHypervisorDoOp(domain->conn->handle, &op);
|
2005-12-12 13:22:20 +00:00
|
|
|
|
|
|
|
if (ret < 0)
|
2006-03-15 12:13:25 +00:00
|
|
|
return (-1);
|
|
|
|
return (0);
|
2005-12-12 13:22:20 +00:00
|
|
|
}
|