mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-03 03:25:20 +00:00
qemu: Add bps_max and friends qemu driver
Add support for bps_max and friends in the driver part. In the part checking if a qemu is running, check if the running binary support bps_max, if not print an error message, if yes add it to "info" variable Signed-off-by: Matthias Gatto <matthias.gatto@outscale.com> Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
c5b71619bd
commit
d506a51aeb
@ -3250,6 +3250,62 @@ typedef void (*virConnectDomainEventDeviceRemovedCallback)(virConnectPtr conn,
|
|||||||
*/
|
*/
|
||||||
# define VIR_DOMAIN_TUNABLE_BLKDEV_WRITE_IOPS_SEC "blkdeviotune.write_iops_sec"
|
# define VIR_DOMAIN_TUNABLE_BLKDEV_WRITE_IOPS_SEC "blkdeviotune.write_iops_sec"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* VIR_DOMAIN_TUNABLE_BLKDEV_TOTAL_BYTES_SEC_MAX:
|
||||||
|
*
|
||||||
|
* Marco represents the total throughput limit in maximum bytes per second,
|
||||||
|
* as VIR_TYPED_PARAM_ULLONG.
|
||||||
|
*/
|
||||||
|
# define VIR_DOMAIN_TUNABLE_BLKDEV_TOTAL_BYTES_SEC_MAX "blkdeviotune.total_bytes_sec_max"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* VIR_DOMAIN_TUNABLE_BLKDEV_READ_BYTES_SEC_MAX:
|
||||||
|
*
|
||||||
|
* Marco represents the read throughput limit in maximum bytes per second,
|
||||||
|
* as VIR_TYPED_PARAM_ULLONG.
|
||||||
|
*/
|
||||||
|
# define VIR_DOMAIN_TUNABLE_BLKDEV_READ_BYTES_SEC_MAX "blkdeviotune.read_bytes_sec_max"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* VIR_DOMAIN_TUNABLE_BLKDEV_WRITE_BYTES_SEC_MAX:
|
||||||
|
*
|
||||||
|
* Macro represents the write throughput limit in maximum bytes per second,
|
||||||
|
* as VIR_TYPED_PARAM_ULLONG.
|
||||||
|
*/
|
||||||
|
# define VIR_DOMAIN_TUNABLE_BLKDEV_WRITE_BYTES_SEC_MAX "blkdeviotune.write_bytes_sec_max"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* VIR_DOMAIN_TUNABLE_BLKDEV_TOTAL_IOPS_SEC_MAX:
|
||||||
|
*
|
||||||
|
* Macro represents the total maximum I/O operations per second,
|
||||||
|
* as VIR_TYPED_PARAM_ULLONG.
|
||||||
|
*/
|
||||||
|
# define VIR_DOMAIN_TUNABLE_BLKDEV_TOTAL_IOPS_SEC_MAX "blkdeviotune.total_iops_sec_max"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* VIR_DOMAIN_TUNABLE_BLKDEV_READ_IOPS_SEC_MAX:
|
||||||
|
*
|
||||||
|
* Macro represents the read maximum I/O operations per second,
|
||||||
|
* as VIR_TYPED_PARAM_ULLONG.
|
||||||
|
*/
|
||||||
|
# define VIR_DOMAIN_TUNABLE_BLKDEV_READ_IOPS_SEC_MAX "blkdeviotune.read_iops_sec_max"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* VIR_DOMAIN_TUNABLE_BLKDEV_WRITE_IOPS_SEC_MAX:
|
||||||
|
*
|
||||||
|
* Macro represents the write maximum I/O operations per second,
|
||||||
|
* as VIR_TYPED_PARAM_ULLONG.
|
||||||
|
*/
|
||||||
|
# define VIR_DOMAIN_TUNABLE_BLKDEV_WRITE_IOPS_SEC_MAX "blkdeviotune.write_iops_sec_max"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* VIR_DOMAIN_TUNABLE_BLKDEV_SIZE_IOPS_SEC:
|
||||||
|
*
|
||||||
|
* Macro represents the size maximum I/O operations per second,
|
||||||
|
* as VIR_TYPED_PARAM_ULLONG.
|
||||||
|
*/
|
||||||
|
# define VIR_DOMAIN_TUNABLE_BLKDEV_SIZE_IOPS_SEC "blkdeviotune.size_iops_sec"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* virConnectDomainEventTunableCallback:
|
* virConnectDomainEventTunableCallback:
|
||||||
* @conn: connection object
|
* @conn: connection object
|
||||||
|
@ -105,6 +105,7 @@ VIR_LOG_INIT("qemu.qemu_driver");
|
|||||||
#define QEMU_NB_MEM_PARAM 3
|
#define QEMU_NB_MEM_PARAM 3
|
||||||
|
|
||||||
#define QEMU_NB_BLOCK_IO_TUNE_PARAM 6
|
#define QEMU_NB_BLOCK_IO_TUNE_PARAM 6
|
||||||
|
#define QEMU_NB_BLOCK_IO_TUNE_PARAM_MAX 13
|
||||||
|
|
||||||
#define QEMU_NB_NUMA_PARAM 2
|
#define QEMU_NB_NUMA_PARAM 2
|
||||||
|
|
||||||
@ -16616,6 +16617,10 @@ qemuDomainSetBlockIoTune(virDomainPtr dom,
|
|||||||
int conf_idx = -1;
|
int conf_idx = -1;
|
||||||
bool set_bytes = false;
|
bool set_bytes = false;
|
||||||
bool set_iops = false;
|
bool set_iops = false;
|
||||||
|
bool set_bytes_max = false;
|
||||||
|
bool set_iops_max = false;
|
||||||
|
bool set_size_iops = false;
|
||||||
|
bool supportMaxOptions = true;
|
||||||
virQEMUDriverConfigPtr cfg = NULL;
|
virQEMUDriverConfigPtr cfg = NULL;
|
||||||
virCapsPtr caps = NULL;
|
virCapsPtr caps = NULL;
|
||||||
virObjectEventPtr event = NULL;
|
virObjectEventPtr event = NULL;
|
||||||
@ -16638,6 +16643,20 @@ qemuDomainSetBlockIoTune(virDomainPtr dom,
|
|||||||
VIR_TYPED_PARAM_ULLONG,
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
VIR_DOMAIN_BLOCK_IOTUNE_WRITE_IOPS_SEC,
|
VIR_DOMAIN_BLOCK_IOTUNE_WRITE_IOPS_SEC,
|
||||||
VIR_TYPED_PARAM_ULLONG,
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_TOTAL_BYTES_SEC_MAX,
|
||||||
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_READ_BYTES_SEC_MAX,
|
||||||
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_WRITE_BYTES_SEC_MAX,
|
||||||
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_TOTAL_IOPS_SEC_MAX,
|
||||||
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_READ_IOPS_SEC_MAX,
|
||||||
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_WRITE_IOPS_SEC_MAX,
|
||||||
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_SIZE_IOPS_SEC,
|
||||||
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
NULL) < 0)
|
NULL) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -16730,20 +16749,101 @@ qemuDomainSetBlockIoTune(virDomainPtr dom,
|
|||||||
VIR_DOMAIN_TUNABLE_BLKDEV_WRITE_IOPS_SEC,
|
VIR_DOMAIN_TUNABLE_BLKDEV_WRITE_IOPS_SEC,
|
||||||
param->value.ul) < 0)
|
param->value.ul) < 0)
|
||||||
goto endjob;
|
goto endjob;
|
||||||
|
} else if (STREQ(param->field,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_TOTAL_BYTES_SEC_MAX)) {
|
||||||
|
info.total_bytes_sec_max = param->value.ul;
|
||||||
|
set_bytes_max = true;
|
||||||
|
if (virTypedParamsAddULLong(&eventParams, &eventNparams,
|
||||||
|
&eventMaxparams,
|
||||||
|
VIR_DOMAIN_TUNABLE_BLKDEV_TOTAL_BYTES_SEC_MAX,
|
||||||
|
param->value.ul) < 0)
|
||||||
|
goto endjob;
|
||||||
|
} else if (STREQ(param->field,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_READ_BYTES_SEC_MAX)) {
|
||||||
|
info.read_bytes_sec_max = param->value.ul;
|
||||||
|
set_bytes_max = true;
|
||||||
|
if (virTypedParamsAddULLong(&eventParams, &eventNparams,
|
||||||
|
&eventMaxparams,
|
||||||
|
VIR_DOMAIN_TUNABLE_BLKDEV_READ_BYTES_SEC_MAX,
|
||||||
|
param->value.ul) < 0)
|
||||||
|
goto endjob;
|
||||||
|
} else if (STREQ(param->field,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_WRITE_BYTES_SEC_MAX)) {
|
||||||
|
info.write_bytes_sec_max = param->value.ul;
|
||||||
|
set_bytes_max = true;
|
||||||
|
if (virTypedParamsAddULLong(&eventParams, &eventNparams,
|
||||||
|
&eventMaxparams,
|
||||||
|
VIR_DOMAIN_TUNABLE_BLKDEV_WRITE_BYTES_SEC_MAX,
|
||||||
|
param->value.ul) < 0)
|
||||||
|
goto endjob;
|
||||||
|
} else if (STREQ(param->field,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_TOTAL_IOPS_SEC_MAX)) {
|
||||||
|
info.total_iops_sec_max = param->value.ul;
|
||||||
|
set_iops_max = true;
|
||||||
|
if (virTypedParamsAddULLong(&eventParams, &eventNparams,
|
||||||
|
&eventMaxparams,
|
||||||
|
VIR_DOMAIN_TUNABLE_BLKDEV_TOTAL_IOPS_SEC_MAX,
|
||||||
|
param->value.ul) < 0)
|
||||||
|
goto endjob;
|
||||||
|
} else if (STREQ(param->field,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_READ_IOPS_SEC_MAX)) {
|
||||||
|
info.read_iops_sec_max = param->value.ul;
|
||||||
|
set_iops_max = true;
|
||||||
|
if (virTypedParamsAddULLong(&eventParams, &eventNparams,
|
||||||
|
&eventMaxparams,
|
||||||
|
VIR_DOMAIN_TUNABLE_BLKDEV_READ_IOPS_SEC_MAX,
|
||||||
|
param->value.ul) < 0)
|
||||||
|
goto endjob;
|
||||||
|
} else if (STREQ(param->field,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_WRITE_IOPS_SEC_MAX)) {
|
||||||
|
info.write_iops_sec_max = param->value.ul;
|
||||||
|
set_iops_max = true;
|
||||||
|
if (virTypedParamsAddULLong(&eventParams, &eventNparams,
|
||||||
|
&eventMaxparams,
|
||||||
|
VIR_DOMAIN_TUNABLE_BLKDEV_WRITE_IOPS_SEC_MAX,
|
||||||
|
param->value.ul) < 0)
|
||||||
|
goto endjob;
|
||||||
|
} else if (STREQ(param->field,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_SIZE_IOPS_SEC)) {
|
||||||
|
info.size_iops_sec = param->value.ul;
|
||||||
|
set_size_iops = true;
|
||||||
|
if (virTypedParamsAddULLong(&eventParams, &eventNparams,
|
||||||
|
&eventMaxparams,
|
||||||
|
VIR_DOMAIN_TUNABLE_BLKDEV_SIZE_IOPS_SEC,
|
||||||
|
param->value.ul) < 0)
|
||||||
|
goto endjob;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((info.total_bytes_sec && info.read_bytes_sec) ||
|
if ((info.total_bytes_sec && info.read_bytes_sec) ||
|
||||||
(info.total_bytes_sec && info.write_bytes_sec)) {
|
(info.total_bytes_sec && info.write_bytes_sec)) {
|
||||||
virReportError(VIR_ERR_INVALID_ARG, "%s",
|
virReportError(VIR_ERR_INVALID_ARG, "%s",
|
||||||
_("total and read/write of bytes_sec cannot be set at the same time"));
|
_("total and read/write of bytes_sec "
|
||||||
|
"cannot be set at the same time"));
|
||||||
goto endjob;
|
goto endjob;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((info.total_iops_sec && info.read_iops_sec) ||
|
if ((info.total_iops_sec && info.read_iops_sec) ||
|
||||||
(info.total_iops_sec && info.write_iops_sec)) {
|
(info.total_iops_sec && info.write_iops_sec)) {
|
||||||
virReportError(VIR_ERR_INVALID_ARG, "%s",
|
virReportError(VIR_ERR_INVALID_ARG, "%s",
|
||||||
_("total and read/write of iops_sec cannot be set at the same time"));
|
_("total and read/write of iops_sec "
|
||||||
|
"cannot be set at the same time"));
|
||||||
|
goto endjob;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((info.total_bytes_sec_max && info.read_bytes_sec_max) ||
|
||||||
|
(info.total_bytes_sec_max && info.write_bytes_sec_max)) {
|
||||||
|
virReportError(VIR_ERR_INVALID_ARG, "%s",
|
||||||
|
_("total and read/write of bytes_sec_max "
|
||||||
|
"cannot be set at the same time"));
|
||||||
|
goto endjob;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((info.total_iops_sec_max && info.read_iops_sec_max) ||
|
||||||
|
(info.total_iops_sec_max && info.write_iops_sec_max)) {
|
||||||
|
virReportError(VIR_ERR_INVALID_ARG, "%s",
|
||||||
|
_("total and read/write of iops_sec_max "
|
||||||
|
"cannot be set at the same time"));
|
||||||
goto endjob;
|
goto endjob;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -16757,6 +16857,7 @@ qemuDomainSetBlockIoTune(virDomainPtr dom,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (flags & VIR_DOMAIN_AFFECT_LIVE) {
|
if (flags & VIR_DOMAIN_AFFECT_LIVE) {
|
||||||
|
supportMaxOptions = virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DRIVE_IOTUNE);
|
||||||
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DRIVE_IOTUNE)) {
|
if (!virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DRIVE_IOTUNE)) {
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
_("block I/O throttling not supported with this "
|
_("block I/O throttling not supported with this "
|
||||||
@ -16764,6 +16865,13 @@ qemuDomainSetBlockIoTune(virDomainPtr dom,
|
|||||||
goto endjob;
|
goto endjob;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!supportMaxOptions && (set_iops_max || set_bytes_max)) {
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
||||||
|
_("a block I/O throttling parameter is not "
|
||||||
|
"supported with this QEMU binary"));
|
||||||
|
goto endjob;
|
||||||
|
}
|
||||||
|
|
||||||
if (!(device = qemuDiskPathToAlias(vm, disk, &idx)))
|
if (!(device = qemuDiskPathToAlias(vm, disk, &idx)))
|
||||||
goto endjob;
|
goto endjob;
|
||||||
|
|
||||||
@ -16776,13 +16884,26 @@ qemuDomainSetBlockIoTune(virDomainPtr dom,
|
|||||||
info.read_bytes_sec = oldinfo->read_bytes_sec;
|
info.read_bytes_sec = oldinfo->read_bytes_sec;
|
||||||
info.write_bytes_sec = oldinfo->write_bytes_sec;
|
info.write_bytes_sec = oldinfo->write_bytes_sec;
|
||||||
}
|
}
|
||||||
|
if (!set_bytes_max) {
|
||||||
|
info.total_bytes_sec_max = oldinfo->total_bytes_sec_max;
|
||||||
|
info.read_bytes_sec_max = oldinfo->read_bytes_sec_max;
|
||||||
|
info.write_bytes_sec_max = oldinfo->write_bytes_sec_max;
|
||||||
|
}
|
||||||
if (!set_iops) {
|
if (!set_iops) {
|
||||||
info.total_iops_sec = oldinfo->total_iops_sec;
|
info.total_iops_sec = oldinfo->total_iops_sec;
|
||||||
info.read_iops_sec = oldinfo->read_iops_sec;
|
info.read_iops_sec = oldinfo->read_iops_sec;
|
||||||
info.write_iops_sec = oldinfo->write_iops_sec;
|
info.write_iops_sec = oldinfo->write_iops_sec;
|
||||||
}
|
}
|
||||||
|
if (!set_iops_max) {
|
||||||
|
info.total_iops_sec_max = oldinfo->total_iops_sec_max;
|
||||||
|
info.read_iops_sec_max = oldinfo->read_iops_sec_max;
|
||||||
|
info.write_iops_sec_max = oldinfo->write_iops_sec_max;
|
||||||
|
}
|
||||||
|
if (!set_size_iops)
|
||||||
|
info.size_iops_sec = oldinfo->size_iops_sec;
|
||||||
qemuDomainObjEnterMonitor(driver, vm);
|
qemuDomainObjEnterMonitor(driver, vm);
|
||||||
ret = qemuMonitorSetBlockIoThrottle(priv->mon, device, &info);
|
ret = qemuMonitorSetBlockIoThrottle(priv->mon, device,
|
||||||
|
&info, supportMaxOptions);
|
||||||
qemuDomainObjExitMonitor(driver, vm);
|
qemuDomainObjExitMonitor(driver, vm);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto endjob;
|
goto endjob;
|
||||||
@ -16826,6 +16947,7 @@ qemuDomainSetBlockIoTune(virDomainPtr dom,
|
|||||||
}
|
}
|
||||||
|
|
||||||
endjob:
|
endjob:
|
||||||
|
|
||||||
if (!qemuDomainObjEndJob(driver, vm))
|
if (!qemuDomainObjEndJob(driver, vm))
|
||||||
vm = NULL;
|
vm = NULL;
|
||||||
|
|
||||||
@ -16849,13 +16971,14 @@ qemuDomainGetBlockIoTune(virDomainPtr dom,
|
|||||||
{
|
{
|
||||||
virQEMUDriverPtr driver = dom->conn->privateData;
|
virQEMUDriverPtr driver = dom->conn->privateData;
|
||||||
virDomainObjPtr vm = NULL;
|
virDomainObjPtr vm = NULL;
|
||||||
qemuDomainObjPrivatePtr priv;
|
qemuDomainObjPrivatePtr priv = NULL;
|
||||||
virDomainDefPtr persistentDef = NULL;
|
virDomainDefPtr persistentDef = NULL;
|
||||||
virDomainBlockIoTuneInfo reply;
|
virDomainBlockIoTuneInfo reply;
|
||||||
char *device = NULL;
|
char *device = NULL;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
size_t i;
|
size_t i;
|
||||||
virCapsPtr caps = NULL;
|
virCapsPtr caps = NULL;
|
||||||
|
bool supportMaxOptions = true;
|
||||||
|
|
||||||
virCheckFlags(VIR_DOMAIN_AFFECT_LIVE |
|
virCheckFlags(VIR_DOMAIN_AFFECT_LIVE |
|
||||||
VIR_DOMAIN_AFFECT_CONFIG |
|
VIR_DOMAIN_AFFECT_CONFIG |
|
||||||
@ -16873,13 +16996,6 @@ qemuDomainGetBlockIoTune(virDomainPtr dom,
|
|||||||
if (!(caps = virQEMUDriverGetCapabilities(driver, false)))
|
if (!(caps = virQEMUDriverGetCapabilities(driver, false)))
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if ((*nparams) == 0) {
|
|
||||||
/* Current number of parameters supported by QEMU Block I/O Throttling */
|
|
||||||
*nparams = QEMU_NB_BLOCK_IO_TUNE_PARAM;
|
|
||||||
ret = 0;
|
|
||||||
goto cleanup;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (qemuDomainObjBeginJob(driver, vm, QEMU_JOB_MODIFY) < 0)
|
if (qemuDomainObjBeginJob(driver, vm, QEMU_JOB_MODIFY) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -16887,6 +17003,20 @@ qemuDomainGetBlockIoTune(virDomainPtr dom,
|
|||||||
&persistentDef) < 0)
|
&persistentDef) < 0)
|
||||||
goto endjob;
|
goto endjob;
|
||||||
|
|
||||||
|
if ((*nparams) == 0) {
|
||||||
|
if (flags & VIR_DOMAIN_AFFECT_LIVE) {
|
||||||
|
priv = vm->privateData;
|
||||||
|
/* If the VM is running, we can check if the current VM can use
|
||||||
|
* optional parameters or not. We didn't made this check sooner
|
||||||
|
* because we need the VM data to do so. */
|
||||||
|
supportMaxOptions = virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DRIVE_IOTUNE_MAX);
|
||||||
|
}
|
||||||
|
*nparams = supportMaxOptions ?
|
||||||
|
QEMU_NB_BLOCK_IO_TUNE_PARAM_MAX : QEMU_NB_BLOCK_IO_TUNE_PARAM;
|
||||||
|
ret = 0;
|
||||||
|
goto endjob;
|
||||||
|
}
|
||||||
|
|
||||||
device = qemuDiskPathToAlias(vm, disk, NULL);
|
device = qemuDiskPathToAlias(vm, disk, NULL);
|
||||||
if (!device) {
|
if (!device) {
|
||||||
goto endjob;
|
goto endjob;
|
||||||
@ -16895,7 +17025,7 @@ qemuDomainGetBlockIoTune(virDomainPtr dom,
|
|||||||
if (flags & VIR_DOMAIN_AFFECT_LIVE) {
|
if (flags & VIR_DOMAIN_AFFECT_LIVE) {
|
||||||
priv = vm->privateData;
|
priv = vm->privateData;
|
||||||
qemuDomainObjEnterMonitor(driver, vm);
|
qemuDomainObjEnterMonitor(driver, vm);
|
||||||
ret = qemuMonitorGetBlockIoThrottle(priv->mon, device, &reply);
|
ret = qemuMonitorGetBlockIoThrottle(priv->mon, device, &reply, supportMaxOptions);
|
||||||
qemuDomainObjExitMonitor(driver, vm);
|
qemuDomainObjExitMonitor(driver, vm);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto endjob;
|
goto endjob;
|
||||||
@ -16912,7 +17042,7 @@ qemuDomainGetBlockIoTune(virDomainPtr dom,
|
|||||||
reply = persistentDef->disks[idx]->blkdeviotune;
|
reply = persistentDef->disks[idx]->blkdeviotune;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < QEMU_NB_BLOCK_IO_TUNE_PARAM && i < *nparams; i++) {
|
for (i = 0; i < QEMU_NB_BLOCK_IO_TUNE_PARAM_MAX && i < *nparams; i++) {
|
||||||
virTypedParameterPtr param = ¶ms[i];
|
virTypedParameterPtr param = ¶ms[i];
|
||||||
|
|
||||||
switch (i) {
|
switch (i) {
|
||||||
@ -16958,14 +17088,64 @@ qemuDomainGetBlockIoTune(virDomainPtr dom,
|
|||||||
reply.write_iops_sec) < 0)
|
reply.write_iops_sec) < 0)
|
||||||
goto endjob;
|
goto endjob;
|
||||||
break;
|
break;
|
||||||
|
case 6:
|
||||||
|
if (virTypedParameterAssign(param,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_TOTAL_BYTES_SEC_MAX,
|
||||||
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
|
reply.total_bytes_sec_max) < 0)
|
||||||
|
goto endjob;
|
||||||
|
break;
|
||||||
|
case 7:
|
||||||
|
if (virTypedParameterAssign(param,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_READ_BYTES_SEC_MAX,
|
||||||
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
|
reply.read_bytes_sec_max) < 0)
|
||||||
|
goto endjob;
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
if (virTypedParameterAssign(param,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_WRITE_BYTES_SEC_MAX,
|
||||||
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
|
reply.write_bytes_sec_max) < 0)
|
||||||
|
goto endjob;
|
||||||
|
break;
|
||||||
|
case 9:
|
||||||
|
if (virTypedParameterAssign(param,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_TOTAL_IOPS_SEC_MAX,
|
||||||
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
|
reply.total_iops_sec_max) < 0)
|
||||||
|
goto endjob;
|
||||||
|
break;
|
||||||
|
case 10:
|
||||||
|
if (virTypedParameterAssign(param,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_READ_IOPS_SEC_MAX,
|
||||||
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
|
reply.read_iops_sec_max) < 0)
|
||||||
|
goto endjob;
|
||||||
|
break;
|
||||||
|
case 11:
|
||||||
|
if (virTypedParameterAssign(param,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_WRITE_IOPS_SEC_MAX,
|
||||||
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
|
reply.write_iops_sec_max) < 0)
|
||||||
|
goto endjob;
|
||||||
|
break;
|
||||||
|
case 12:
|
||||||
|
if (virTypedParameterAssign(param,
|
||||||
|
VIR_DOMAIN_BLOCK_IOTUNE_SIZE_IOPS_SEC,
|
||||||
|
VIR_TYPED_PARAM_ULLONG,
|
||||||
|
reply.size_iops_sec) < 0)
|
||||||
|
goto endjob;
|
||||||
/* coverity[dead_error_begin] */
|
/* coverity[dead_error_begin] */
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (*nparams > QEMU_NB_BLOCK_IO_TUNE_PARAM)
|
if (!supportMaxOptions && *nparams > QEMU_NB_BLOCK_IO_TUNE_PARAM)
|
||||||
*nparams = QEMU_NB_BLOCK_IO_TUNE_PARAM;
|
*nparams = QEMU_NB_BLOCK_IO_TUNE_PARAM;
|
||||||
|
else if (*nparams > QEMU_NB_BLOCK_IO_TUNE_PARAM_MAX)
|
||||||
|
*nparams = QEMU_NB_BLOCK_IO_TUNE_PARAM_MAX;
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
endjob:
|
endjob:
|
||||||
|
@ -3514,14 +3514,15 @@ qemuMonitorBlockJobInfo(qemuMonitorPtr mon,
|
|||||||
|
|
||||||
int qemuMonitorSetBlockIoThrottle(qemuMonitorPtr mon,
|
int qemuMonitorSetBlockIoThrottle(qemuMonitorPtr mon,
|
||||||
const char *device,
|
const char *device,
|
||||||
virDomainBlockIoTuneInfoPtr info)
|
virDomainBlockIoTuneInfoPtr info,
|
||||||
|
bool supportMaxOptions)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
VIR_DEBUG("mon=%p, device=%p, info=%p", mon, device, info);
|
VIR_DEBUG("mon=%p, device=%p, info=%p", mon, device, info);
|
||||||
|
|
||||||
if (mon->json) {
|
if (mon->json) {
|
||||||
ret = qemuMonitorJSONSetBlockIoThrottle(mon, device, info);
|
ret = qemuMonitorJSONSetBlockIoThrottle(mon, device, info, supportMaxOptions);
|
||||||
} else {
|
} else {
|
||||||
ret = qemuMonitorTextSetBlockIoThrottle(mon, device, info);
|
ret = qemuMonitorTextSetBlockIoThrottle(mon, device, info);
|
||||||
}
|
}
|
||||||
@ -3530,14 +3531,15 @@ int qemuMonitorSetBlockIoThrottle(qemuMonitorPtr mon,
|
|||||||
|
|
||||||
int qemuMonitorGetBlockIoThrottle(qemuMonitorPtr mon,
|
int qemuMonitorGetBlockIoThrottle(qemuMonitorPtr mon,
|
||||||
const char *device,
|
const char *device,
|
||||||
virDomainBlockIoTuneInfoPtr reply)
|
virDomainBlockIoTuneInfoPtr reply,
|
||||||
|
bool supportMaxOptions)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
VIR_DEBUG("mon=%p, device=%p, reply=%p", mon, device, reply);
|
VIR_DEBUG("mon=%p, device=%p, reply=%p", mon, device, reply);
|
||||||
|
|
||||||
if (mon->json) {
|
if (mon->json) {
|
||||||
ret = qemuMonitorJSONGetBlockIoThrottle(mon, device, reply);
|
ret = qemuMonitorJSONGetBlockIoThrottle(mon, device, reply, supportMaxOptions);
|
||||||
} else {
|
} else {
|
||||||
ret = qemuMonitorTextGetBlockIoThrottle(mon, device, reply);
|
ret = qemuMonitorTextGetBlockIoThrottle(mon, device, reply);
|
||||||
}
|
}
|
||||||
|
@ -771,11 +771,13 @@ int qemuMonitorOpenGraphics(qemuMonitorPtr mon,
|
|||||||
|
|
||||||
int qemuMonitorSetBlockIoThrottle(qemuMonitorPtr mon,
|
int qemuMonitorSetBlockIoThrottle(qemuMonitorPtr mon,
|
||||||
const char *device,
|
const char *device,
|
||||||
virDomainBlockIoTuneInfoPtr info);
|
virDomainBlockIoTuneInfoPtr info,
|
||||||
|
bool supportMaxOptions);
|
||||||
|
|
||||||
int qemuMonitorGetBlockIoThrottle(qemuMonitorPtr mon,
|
int qemuMonitorGetBlockIoThrottle(qemuMonitorPtr mon,
|
||||||
const char *device,
|
const char *device,
|
||||||
virDomainBlockIoTuneInfoPtr reply);
|
virDomainBlockIoTuneInfoPtr reply,
|
||||||
|
bool supportMaxOptions);
|
||||||
|
|
||||||
int qemuMonitorSystemWakeup(qemuMonitorPtr mon);
|
int qemuMonitorSystemWakeup(qemuMonitorPtr mon);
|
||||||
|
|
||||||
|
@ -4293,7 +4293,8 @@ int qemuMonitorJSONOpenGraphics(qemuMonitorPtr mon,
|
|||||||
static int
|
static int
|
||||||
qemuMonitorJSONBlockIoThrottleInfo(virJSONValuePtr result,
|
qemuMonitorJSONBlockIoThrottleInfo(virJSONValuePtr result,
|
||||||
const char *device,
|
const char *device,
|
||||||
virDomainBlockIoTuneInfoPtr reply)
|
virDomainBlockIoTuneInfoPtr reply,
|
||||||
|
bool supportMaxOptions ATTRIBUTE_UNUSED)
|
||||||
{
|
{
|
||||||
virJSONValuePtr io_throttle;
|
virJSONValuePtr io_throttle;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
@ -4364,7 +4365,8 @@ qemuMonitorJSONBlockIoThrottleInfo(virJSONValuePtr result,
|
|||||||
|
|
||||||
int qemuMonitorJSONSetBlockIoThrottle(qemuMonitorPtr mon,
|
int qemuMonitorJSONSetBlockIoThrottle(qemuMonitorPtr mon,
|
||||||
const char *device,
|
const char *device,
|
||||||
virDomainBlockIoTuneInfoPtr info)
|
virDomainBlockIoTuneInfoPtr info,
|
||||||
|
bool supportMaxOptions ATTRIBUTE_UNUSED)
|
||||||
{
|
{
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
virJSONValuePtr cmd = NULL;
|
virJSONValuePtr cmd = NULL;
|
||||||
@ -4404,7 +4406,8 @@ int qemuMonitorJSONSetBlockIoThrottle(qemuMonitorPtr mon,
|
|||||||
|
|
||||||
int qemuMonitorJSONGetBlockIoThrottle(qemuMonitorPtr mon,
|
int qemuMonitorJSONGetBlockIoThrottle(qemuMonitorPtr mon,
|
||||||
const char *device,
|
const char *device,
|
||||||
virDomainBlockIoTuneInfoPtr reply)
|
virDomainBlockIoTuneInfoPtr reply,
|
||||||
|
bool supportMaxOptions)
|
||||||
{
|
{
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
virJSONValuePtr cmd = NULL;
|
virJSONValuePtr cmd = NULL;
|
||||||
@ -4431,7 +4434,7 @@ int qemuMonitorJSONGetBlockIoThrottle(qemuMonitorPtr mon,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (ret == 0)
|
if (ret == 0)
|
||||||
ret = qemuMonitorJSONBlockIoThrottleInfo(result, device, reply);
|
ret = qemuMonitorJSONBlockIoThrottleInfo(result, device, reply, supportMaxOptions);
|
||||||
|
|
||||||
virJSONValueFree(cmd);
|
virJSONValueFree(cmd);
|
||||||
virJSONValueFree(result);
|
virJSONValueFree(result);
|
||||||
|
@ -325,11 +325,13 @@ int qemuMonitorJSONOpenGraphics(qemuMonitorPtr mon,
|
|||||||
|
|
||||||
int qemuMonitorJSONSetBlockIoThrottle(qemuMonitorPtr mon,
|
int qemuMonitorJSONSetBlockIoThrottle(qemuMonitorPtr mon,
|
||||||
const char *device,
|
const char *device,
|
||||||
virDomainBlockIoTuneInfoPtr info);
|
virDomainBlockIoTuneInfoPtr info,
|
||||||
|
bool supportMaxOptions);
|
||||||
|
|
||||||
int qemuMonitorJSONGetBlockIoThrottle(qemuMonitorPtr mon,
|
int qemuMonitorJSONGetBlockIoThrottle(qemuMonitorPtr mon,
|
||||||
const char *device,
|
const char *device,
|
||||||
virDomainBlockIoTuneInfoPtr reply);
|
virDomainBlockIoTuneInfoPtr reply,
|
||||||
|
bool supportMaxOptions);
|
||||||
|
|
||||||
int qemuMonitorJSONSystemWakeup(qemuMonitorPtr mon);
|
int qemuMonitorJSONSystemWakeup(qemuMonitorPtr mon);
|
||||||
|
|
||||||
|
@ -1847,7 +1847,7 @@ testQemuMonitorJSONqemuMonitorJSONSetBlockIoThrottle(const void *data)
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (qemuMonitorJSONGetBlockIoThrottle(qemuMonitorTestGetMonitor(test),
|
if (qemuMonitorJSONGetBlockIoThrottle(qemuMonitorTestGetMonitor(test),
|
||||||
"drive-virtio-disk0", &info) < 0)
|
"drive-virtio-disk0", &info, false) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (memcmp(&info, &expectedInfo, sizeof(info) != 0)) {
|
if (memcmp(&info, &expectedInfo, sizeof(info) != 0)) {
|
||||||
@ -1857,7 +1857,7 @@ testQemuMonitorJSONqemuMonitorJSONSetBlockIoThrottle(const void *data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (qemuMonitorJSONSetBlockIoThrottle(qemuMonitorTestGetMonitor(test),
|
if (qemuMonitorJSONSetBlockIoThrottle(qemuMonitorTestGetMonitor(test),
|
||||||
"drive-virtio-disk1", &info) < 0)
|
"drive-virtio-disk1", &info, false) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user