mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-12-22 05:35:25 +00:00
lib: Introduce virDomainSetIOThreadParams
Create a new API that will allow an adjustment of IOThread polling parameters for the specified IOThread. These parameters will not be saved in the guest XML. Currently the only parameters supported will allow the hypervisor to adjust the parameters used to limit and alter the scope of the polling interval. The polling interval allows the IOThread to spend more or less time processing in the guest. Based on code originally posted by Pavel Hrdina <phrdina@redhat.com> to add virDomainAddIOThreadParams and virDomainModIOThreadParams. Modification of those changes to use virDomainSetIOThreadParams instead and remove concepts related to saving the data in guest XML as well as the way to specifically enable the polling parameters. Signed-off-by: John Ferlan <jferlan@redhat.com> ACKed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
2c4df6c68b
commit
ae69bda5c2
@ -1913,6 +1913,50 @@ int virDomainDelIOThread(virDomainPtr domain,
|
||||
unsigned int iothread_id,
|
||||
unsigned int flags);
|
||||
|
||||
/* IOThread set parameters */
|
||||
|
||||
/**
|
||||
* VIR_DOMAIN_IOTHREAD_POLL_MAX_NS:
|
||||
*
|
||||
* The maximum polling time that can be used by polling algorithm in ns.
|
||||
* The polling time starts at 0 (zero) and is the time spent by the guest
|
||||
* to process IOThread data before returning the CPU to the host. The
|
||||
* polling time will be dynamically modified over time based on the
|
||||
* poll_grow and poll_shrink parameters provided. A value set too large
|
||||
* will cause more CPU time to be allocated the guest. A value set too
|
||||
* small will not provide enough cycles for the guest to process data.
|
||||
* The polling interval is not available for statistical purposes.
|
||||
*/
|
||||
# define VIR_DOMAIN_IOTHREAD_POLL_MAX_NS "poll_max_ns"
|
||||
|
||||
/**
|
||||
* VIR_DOMAIN_IOTHREAD_POLL_GROW:
|
||||
*
|
||||
* This provides a value for the dynamic polling adjustment algorithm to
|
||||
* use to grow its polling interval up to the poll_max_ns value. A value
|
||||
* of 0 (zero) allows the hypervisor to choose its own value. The algorithm
|
||||
* to use for adjustment is hypervisor specific.
|
||||
*/
|
||||
# define VIR_DOMAIN_IOTHREAD_POLL_GROW "poll_grow"
|
||||
|
||||
/**
|
||||
* VIR_DOMAIN_IOTHREAD_POLL_SHRINK:
|
||||
*
|
||||
* This provides a value for the dynamic polling adjustment algorithm to
|
||||
* use to shrink its polling interval when the polling interval exceeds
|
||||
* the poll_max_ns value. A value of 0 (zero) allows the hypervisor to
|
||||
* choose its own value. The algorithm to use for adjustment is hypervisor
|
||||
* specific.
|
||||
*/
|
||||
# define VIR_DOMAIN_IOTHREAD_POLL_SHRINK "poll_shrink"
|
||||
|
||||
int virDomainSetIOThreadParams(virDomainPtr domain,
|
||||
unsigned int iothread_id,
|
||||
virTypedParameterPtr params,
|
||||
int nparams,
|
||||
unsigned int flags);
|
||||
|
||||
|
||||
/**
|
||||
* VIR_USE_CPU:
|
||||
* @cpumap: pointer to a bit map of real CPUs (in 8-bit bytes) (IN/OUT)
|
||||
|
@ -406,6 +406,13 @@ typedef int
|
||||
unsigned int iothread_id,
|
||||
unsigned int flags);
|
||||
|
||||
typedef int
|
||||
(*virDrvDomainSetIOThreadParams)(virDomainPtr domain,
|
||||
unsigned int iothread_id,
|
||||
virTypedParameterPtr params,
|
||||
int nparams,
|
||||
unsigned int flags);
|
||||
|
||||
typedef int
|
||||
(*virDrvDomainGetSecurityLabel)(virDomainPtr domain,
|
||||
virSecurityLabelPtr seclabel);
|
||||
@ -1407,6 +1414,7 @@ struct _virHypervisorDriver {
|
||||
virDrvDomainPinIOThread domainPinIOThread;
|
||||
virDrvDomainAddIOThread domainAddIOThread;
|
||||
virDrvDomainDelIOThread domainDelIOThread;
|
||||
virDrvDomainSetIOThreadParams domainSetIOThreadParams;
|
||||
virDrvDomainGetSecurityLabel domainGetSecurityLabel;
|
||||
virDrvDomainGetSecurityLabelList domainGetSecurityLabelList;
|
||||
virDrvNodeGetSecurityModel nodeGetSecurityModel;
|
||||
|
@ -7812,6 +7812,76 @@ virDomainDelIOThread(virDomainPtr domain,
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* virDomainSetIOThreadParams:
|
||||
* @domain: a domain object
|
||||
* @iothread_id: the specific IOThread ID value to add
|
||||
* @params: pointer to IOThread parameter objects
|
||||
* @nparams: number of IOThread parameters
|
||||
* @flags: bitwise-OR of virDomainModificationImpact and virTypedParameterFlags
|
||||
*
|
||||
* Dynamically set IOThread parameters to the domain. It is left up to
|
||||
* the underlying virtual hypervisor to determine the valid range for an
|
||||
* @iothread_id, determining whether the @iothread_id already exists, and
|
||||
* determining the validity of the provided param values.
|
||||
*
|
||||
* See VIR_DOMAIN_IOTHREAD_* for detailed description of accepted IOThread
|
||||
* parameters.
|
||||
*
|
||||
* Since the purpose of this API is to dynamically modify the IOThread
|
||||
* @flags should only include the VIR_DOMAIN_AFFECT_CURRENT and/or
|
||||
* VIR_DOMAIN_AFFECT_LIVE virDomainMemoryModFlags. Setting other flags
|
||||
* may cause errors from the hypervisor.
|
||||
*
|
||||
* Note that this call can fail if the underlying virtualization hypervisor
|
||||
* does not support it or does not support setting the provided values.
|
||||
*
|
||||
* This function requires privileged access to the hypervisor.
|
||||
*
|
||||
* Returns 0 in case of success, -1 in case of failure.
|
||||
*/
|
||||
int
|
||||
virDomainSetIOThreadParams(virDomainPtr domain,
|
||||
unsigned int iothread_id,
|
||||
virTypedParameterPtr params,
|
||||
int nparams,
|
||||
unsigned int flags)
|
||||
{
|
||||
virConnectPtr conn;
|
||||
|
||||
VIR_DOMAIN_DEBUG(domain, "iothread_id=%u, params=%p, nparams=%d, flags=0x%x",
|
||||
iothread_id, params, nparams, flags);
|
||||
VIR_TYPED_PARAMS_DEBUG(params, nparams);
|
||||
|
||||
virResetLastError();
|
||||
|
||||
virCheckDomainReturn(domain, -1);
|
||||
conn = domain->conn;
|
||||
|
||||
virCheckReadOnlyGoto(conn->flags, error);
|
||||
virCheckNonNullArgGoto(params, error);
|
||||
virCheckPositiveArgGoto(nparams, error);
|
||||
|
||||
if (virTypedParameterValidateSet(conn, params, nparams) < 0)
|
||||
goto error;
|
||||
|
||||
if (conn->driver->domainSetIOThreadParams) {
|
||||
int ret;
|
||||
ret = conn->driver->domainSetIOThreadParams(domain, iothread_id,
|
||||
params, nparams, flags);
|
||||
if (ret < 0)
|
||||
goto error;
|
||||
return ret;
|
||||
}
|
||||
|
||||
virReportUnsupportedError();
|
||||
|
||||
error:
|
||||
virDispatchError(domain->conn);
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* virDomainGetSecurityLabel:
|
||||
* @domain: a domain object
|
||||
|
@ -809,4 +809,9 @@ LIBVIRT_4.5.0 {
|
||||
virNWFilterBindingGetFilterName;
|
||||
} LIBVIRT_4.4.0;
|
||||
|
||||
LIBVIRT_4.10.0 {
|
||||
global:
|
||||
virDomainSetIOThreadParams;
|
||||
} LIBVIRT_4.5.0;
|
||||
|
||||
# .... define new API here using predicted next version number ....
|
||||
|
@ -8371,6 +8371,7 @@ static virHypervisorDriver hypervisor_driver = {
|
||||
.domainPinIOThread = remoteDomainPinIOThread, /* 1.2.14 */
|
||||
.domainAddIOThread = remoteDomainAddIOThread, /* 1.2.15 */
|
||||
.domainDelIOThread = remoteDomainDelIOThread, /* 1.2.15 */
|
||||
.domainSetIOThreadParams = remoteDomainSetIOThreadParams, /* 4.10.0 */
|
||||
.domainGetSecurityLabel = remoteDomainGetSecurityLabel, /* 0.6.1 */
|
||||
.domainGetSecurityLabelList = remoteDomainGetSecurityLabelList, /* 0.10.0 */
|
||||
.nodeGetSecurityModel = remoteNodeGetSecurityModel, /* 0.6.1 */
|
||||
|
@ -256,6 +256,9 @@ const REMOTE_DOMAIN_IP_ADDR_MAX = 2048;
|
||||
/* Upper limit on number of guest vcpu information entries */
|
||||
const REMOTE_DOMAIN_GUEST_VCPU_PARAMS_MAX = 64;
|
||||
|
||||
/* Upper limit on number of IOThread parameter set entries */
|
||||
const REMOTE_DOMAIN_IOTHREAD_PARAMS_MAX = 64;
|
||||
|
||||
/* Upper limit on number of SEV parameters */
|
||||
const REMOTE_NODE_SEV_INFO_MAX = 64;
|
||||
|
||||
@ -1249,6 +1252,13 @@ struct remote_domain_del_iothread_args {
|
||||
unsigned int flags;
|
||||
};
|
||||
|
||||
struct remote_domain_set_iothread_params_args {
|
||||
remote_nonnull_domain dom;
|
||||
unsigned int iothread_id;
|
||||
remote_typed_param params<REMOTE_DOMAIN_IOTHREAD_PARAMS_MAX>;
|
||||
unsigned int flags;
|
||||
};
|
||||
|
||||
struct remote_domain_get_security_label_args {
|
||||
remote_nonnull_domain dom;
|
||||
};
|
||||
@ -6312,5 +6322,14 @@ enum remote_procedure {
|
||||
* @acl: connect:search_nwfilter_bindings
|
||||
* @aclfilter: nwfilter_binding:getattr
|
||||
*/
|
||||
REMOTE_PROC_CONNECT_LIST_ALL_NWFILTER_BINDINGS = 401
|
||||
REMOTE_PROC_CONNECT_LIST_ALL_NWFILTER_BINDINGS = 401,
|
||||
|
||||
/**
|
||||
* @generate: both
|
||||
* @acl: domain:write
|
||||
* @acl: domain:save:!VIR_DOMAIN_AFFECT_CONFIG|VIR_DOMAIN_AFFECT_LIVE
|
||||
* @acl: domain:save:VIR_DOMAIN_AFFECT_CONFIG
|
||||
*/
|
||||
REMOTE_PROC_DOMAIN_SET_IOTHREAD_PARAMS = 402
|
||||
|
||||
};
|
||||
|
@ -866,6 +866,15 @@ struct remote_domain_del_iothread_args {
|
||||
u_int iothread_id;
|
||||
u_int flags;
|
||||
};
|
||||
struct remote_domain_set_iothread_params_args {
|
||||
remote_nonnull_domain dom;
|
||||
u_int iothread_id;
|
||||
struct {
|
||||
u_int params_len;
|
||||
remote_typed_param * params_val;
|
||||
} params;
|
||||
u_int flags;
|
||||
};
|
||||
struct remote_domain_get_security_label_args {
|
||||
remote_nonnull_domain dom;
|
||||
};
|
||||
@ -3368,4 +3377,5 @@ enum remote_procedure {
|
||||
REMOTE_PROC_NWFILTER_BINDING_CREATE_XML = 399,
|
||||
REMOTE_PROC_NWFILTER_BINDING_DELETE = 400,
|
||||
REMOTE_PROC_CONNECT_LIST_ALL_NWFILTER_BINDINGS = 401,
|
||||
REMOTE_PROC_DOMAIN_SET_IOTHREAD_PARAMS = 402,
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user