mirror of
https://github.com/libvirt/libvirt.git
synced 2025-02-25 18:55:26 -06:00
add new API virDomain{G, S}etNumaParameters
Set up the types for the numa functions and insert them into the virDriver structure definition.
This commit is contained in:
parent
9d3a721ad5
commit
c57ca57034
@ -1344,6 +1344,45 @@ typedef enum {
|
|||||||
} virDomainMemoryModFlags;
|
} virDomainMemoryModFlags;
|
||||||
|
|
||||||
|
|
||||||
|
/* Manage numa parameters */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* virDomainNumatuneMemMode:
|
||||||
|
* Representation of the various modes in the <numatune> element of
|
||||||
|
* a domain.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
VIR_DOMAIN_NUMATUNE_MEM_STRICT = 0,
|
||||||
|
VIR_DOMAIN_NUMATUNE_MEM_PREFERRED = 1,
|
||||||
|
VIR_DOMAIN_NUMATUNE_MEM_INTERLEAVE = 2,
|
||||||
|
|
||||||
|
/* This constant is subject to change */
|
||||||
|
VIR_DOMAIN_NUMATUNE_MEM_LAST
|
||||||
|
} virDomainNumatuneMemMode;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* VIR_DOMAIN_NUMA_NODESET:
|
||||||
|
*
|
||||||
|
* Macro for typed parameter name that lists the numa nodeset of a
|
||||||
|
* domain, as a string.
|
||||||
|
*/
|
||||||
|
#define VIR_DOMAIN_NUMA_NODESET "numa_nodeset"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* VIR_DOMAIN_NUMA_MODE:
|
||||||
|
*
|
||||||
|
* Macro for typed parameter name that lists the numa mode of a domain,
|
||||||
|
* as an int containing a virDomainNumatuneMemMode value.
|
||||||
|
*/
|
||||||
|
#define VIR_DOMAIN_NUMA_MODE "numa_mode"
|
||||||
|
|
||||||
|
int virDomainSetNumaParameters(virDomainPtr domain,
|
||||||
|
virTypedParameterPtr params,
|
||||||
|
int nparams, unsigned int flags);
|
||||||
|
int virDomainGetNumaParameters(virDomainPtr domain,
|
||||||
|
virTypedParameterPtr params,
|
||||||
|
int *nparams, unsigned int flags);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Dynamic control of domains
|
* Dynamic control of domains
|
||||||
*/
|
*/
|
||||||
|
@ -383,6 +383,8 @@ skip_impl = (
|
|||||||
'virDomainGetBlkioParameters',
|
'virDomainGetBlkioParameters',
|
||||||
'virDomainSetMemoryParameters',
|
'virDomainSetMemoryParameters',
|
||||||
'virDomainGetMemoryParameters',
|
'virDomainGetMemoryParameters',
|
||||||
|
'virDomainSetNumaParameters',
|
||||||
|
'virDomainGetNumaParameters',
|
||||||
'virDomainGetVcpus',
|
'virDomainGetVcpus',
|
||||||
'virDomainPinVcpu',
|
'virDomainPinVcpu',
|
||||||
'virDomainPinVcpuFlags',
|
'virDomainPinVcpuFlags',
|
||||||
|
@ -1355,14 +1355,6 @@ virDomainVcpuPinDefPtr virDomainVcpuPinFindByVcpu(virDomainVcpuPinDefPtr *def,
|
|||||||
int nvcpupin,
|
int nvcpupin,
|
||||||
int vcpu);
|
int vcpu);
|
||||||
|
|
||||||
enum virDomainNumatuneMemMode {
|
|
||||||
VIR_DOMAIN_NUMATUNE_MEM_STRICT,
|
|
||||||
VIR_DOMAIN_NUMATUNE_MEM_PREFERRED,
|
|
||||||
VIR_DOMAIN_NUMATUNE_MEM_INTERLEAVE,
|
|
||||||
|
|
||||||
VIR_DOMAIN_NUMATUNE_MEM_LAST
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef struct _virDomainNumatuneDef virDomainNumatuneDef;
|
typedef struct _virDomainNumatuneDef virDomainNumatuneDef;
|
||||||
typedef virDomainNumatuneDef *virDomainNumatuneDefPtr;
|
typedef virDomainNumatuneDef *virDomainNumatuneDefPtr;
|
||||||
struct _virDomainNumatuneDef {
|
struct _virDomainNumatuneDef {
|
||||||
|
15
src/driver.h
15
src/driver.h
@ -157,6 +157,19 @@ typedef int
|
|||||||
virTypedParameterPtr params,
|
virTypedParameterPtr params,
|
||||||
int *nparams,
|
int *nparams,
|
||||||
unsigned int flags);
|
unsigned int flags);
|
||||||
|
typedef int
|
||||||
|
(*virDrvDomainSetNumaParameters)
|
||||||
|
(virDomainPtr domain,
|
||||||
|
virTypedParameterPtr params,
|
||||||
|
int nparams,
|
||||||
|
unsigned int flags);
|
||||||
|
typedef int
|
||||||
|
(*virDrvDomainGetNumaParameters)
|
||||||
|
(virDomainPtr domain,
|
||||||
|
virTypedParameterPtr params,
|
||||||
|
int *nparams,
|
||||||
|
unsigned int flags);
|
||||||
|
|
||||||
typedef int
|
typedef int
|
||||||
(*virDrvDomainSetBlkioParameters)
|
(*virDrvDomainSetBlkioParameters)
|
||||||
(virDomainPtr domain,
|
(virDomainPtr domain,
|
||||||
@ -816,6 +829,8 @@ struct _virDriver {
|
|||||||
virDrvDomainSetMemoryFlags domainSetMemoryFlags;
|
virDrvDomainSetMemoryFlags domainSetMemoryFlags;
|
||||||
virDrvDomainSetMemoryParameters domainSetMemoryParameters;
|
virDrvDomainSetMemoryParameters domainSetMemoryParameters;
|
||||||
virDrvDomainGetMemoryParameters domainGetMemoryParameters;
|
virDrvDomainGetMemoryParameters domainGetMemoryParameters;
|
||||||
|
virDrvDomainSetNumaParameters domainSetNumaParameters;
|
||||||
|
virDrvDomainGetNumaParameters domainGetNumaParameters;
|
||||||
virDrvDomainSetBlkioParameters domainSetBlkioParameters;
|
virDrvDomainSetBlkioParameters domainSetBlkioParameters;
|
||||||
virDrvDomainGetBlkioParameters domainGetBlkioParameters;
|
virDrvDomainGetBlkioParameters domainGetBlkioParameters;
|
||||||
virDrvDomainGetInfo domainGetInfo;
|
virDrvDomainGetInfo domainGetInfo;
|
||||||
|
129
src/libvirt.c
129
src/libvirt.c
@ -3768,6 +3768,135 @@ error:
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* virDomainSetNumaParameters:
|
||||||
|
* @domain: pointer to domain object
|
||||||
|
* @params: pointer to numa parameter objects
|
||||||
|
* @nparams: number of numa parameters (this value can be the same or
|
||||||
|
* less than the number of parameters supported)
|
||||||
|
* @flags: bitwise-OR of virDomainModificationImpact
|
||||||
|
*
|
||||||
|
* Change all or a subset of the numa tunables.
|
||||||
|
* This function may require privileged access to the hypervisor.
|
||||||
|
*
|
||||||
|
* Returns -1 in case of error, 0 in case of success.
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
virDomainSetNumaParameters(virDomainPtr domain,
|
||||||
|
virTypedParameterPtr params,
|
||||||
|
int nparams, unsigned int flags)
|
||||||
|
{
|
||||||
|
virConnectPtr conn;
|
||||||
|
|
||||||
|
VIR_DOMAIN_DEBUG(domain, "params=%p, nparams=%d, flags=%x",
|
||||||
|
params, nparams, flags);
|
||||||
|
|
||||||
|
virResetLastError();
|
||||||
|
|
||||||
|
if (!VIR_IS_CONNECTED_DOMAIN(domain)) {
|
||||||
|
virLibDomainError(VIR_ERR_INVALID_DOMAIN, __FUNCTION__);
|
||||||
|
virDispatchError(NULL);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if (domain->conn->flags & VIR_CONNECT_RO) {
|
||||||
|
virLibDomainError(VIR_ERR_OPERATION_DENIED, __FUNCTION__);
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
if ((nparams <= 0) || (params == NULL)) {
|
||||||
|
virLibDomainError(VIR_ERR_INVALID_ARG, __FUNCTION__);
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
if (virTypedParameterValidateSet(domain, params, nparams) < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
conn = domain->conn;
|
||||||
|
|
||||||
|
if (conn->driver->domainSetNumaParameters) {
|
||||||
|
int ret;
|
||||||
|
ret = conn->driver->domainSetNumaParameters(domain, params, nparams,
|
||||||
|
flags);
|
||||||
|
if (ret < 0)
|
||||||
|
goto error;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
virLibConnError(VIR_ERR_NO_SUPPORT, __FUNCTION__);
|
||||||
|
|
||||||
|
error:
|
||||||
|
virDispatchError(domain->conn);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* virDomainGetNumaParameters:
|
||||||
|
* @domain: pointer to domain object
|
||||||
|
* @params: pointer to numa parameter object
|
||||||
|
* (return value, allocated by the caller)
|
||||||
|
* @nparams: pointer to number of numa parameters
|
||||||
|
* @flags: bitwise-OR of virDomainModificationImpact and virTypedParameterFlags
|
||||||
|
*
|
||||||
|
* Get all numa parameters. On input, @nparams gives the size of the
|
||||||
|
* @params array; on output, @nparams gives how many slots were filled
|
||||||
|
* with parameter information, which might be less but will not exceed
|
||||||
|
* the input value.
|
||||||
|
*
|
||||||
|
* As a special case, calling with @params as NULL and @nparams as 0 on
|
||||||
|
* input will cause @nparams on output to contain the number of parameters
|
||||||
|
* supported by the hypervisor. The caller should then allocate @params
|
||||||
|
* array, i.e. (sizeof(@virTypedParameter) * @nparams) bytes and call the API
|
||||||
|
* again.
|
||||||
|
*
|
||||||
|
* See virDomainGetMemoryParameters() for an equivalent usage example.
|
||||||
|
*
|
||||||
|
* This function may require privileged access to the hypervisor. This function
|
||||||
|
* expects the caller to allocate the @params.
|
||||||
|
*
|
||||||
|
* Returns -1 in case of error, 0 in case of success.
|
||||||
|
*/
|
||||||
|
|
||||||
|
int
|
||||||
|
virDomainGetNumaParameters(virDomainPtr domain,
|
||||||
|
virTypedParameterPtr params,
|
||||||
|
int *nparams, unsigned int flags)
|
||||||
|
{
|
||||||
|
virConnectPtr conn;
|
||||||
|
|
||||||
|
VIR_DOMAIN_DEBUG(domain, "params=%p, nparams=%d, flags=%x",
|
||||||
|
params, (nparams) ? *nparams : -1, flags);
|
||||||
|
|
||||||
|
virResetLastError();
|
||||||
|
|
||||||
|
if (!VIR_IS_CONNECTED_DOMAIN(domain)) {
|
||||||
|
virLibDomainError(VIR_ERR_INVALID_DOMAIN, __FUNCTION__);
|
||||||
|
virDispatchError(NULL);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if ((nparams == NULL) || (*nparams < 0) ||
|
||||||
|
(params == NULL && *nparams != 0)) {
|
||||||
|
virLibDomainError(VIR_ERR_INVALID_ARG, __FUNCTION__);
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
if (VIR_DRV_SUPPORTS_FEATURE(domain->conn->driver, domain->conn,
|
||||||
|
VIR_DRV_FEATURE_TYPED_PARAM_STRING))
|
||||||
|
flags |= VIR_TYPED_PARAM_STRING_OKAY;
|
||||||
|
|
||||||
|
conn = domain->conn;
|
||||||
|
|
||||||
|
if (conn->driver->domainGetNumaParameters) {
|
||||||
|
int ret;
|
||||||
|
ret = conn->driver->domainGetNumaParameters(domain, params, nparams,
|
||||||
|
flags);
|
||||||
|
if (ret < 0)
|
||||||
|
goto error;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
virLibConnError(VIR_ERR_NO_SUPPORT, __FUNCTION__);
|
||||||
|
|
||||||
|
error:
|
||||||
|
virDispatchError(domain->conn);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* virDomainSetBlkioParameters:
|
* virDomainSetBlkioParameters:
|
||||||
* @domain: pointer to domain object
|
* @domain: pointer to domain object
|
||||||
|
@ -508,4 +508,10 @@ LIBVIRT_0.9.8 {
|
|||||||
virNodeSuspendForDuration;
|
virNodeSuspendForDuration;
|
||||||
} LIBVIRT_0.9.7;
|
} LIBVIRT_0.9.7;
|
||||||
|
|
||||||
|
LIBVIRT_0.9.9 {
|
||||||
|
global:
|
||||||
|
virDomainGetNumaParameters;
|
||||||
|
virDomainSetNumaParameters;
|
||||||
|
} LIBVIRT_0.9.8;
|
||||||
|
|
||||||
# .... define new API here using predicted next version number ....
|
# .... define new API here using predicted next version number ....
|
||||||
|
Loading…
Reference in New Issue
Block a user