Since the main-loop and iothread classes are derived from the
same class (EventLoopBaseClass) we don't need new capability and
can use QEMU_CAPS_IOTHREAD_THREAD_POOL_MAX directly to check
whether QEMU's capable of setting defaultiothread pool size.
Signed-off-by: Michal Privoznik <mprivozn(a)redhat.com>
Reviewed-by: Peter Krempa <pkrempa(a)redhat.com>
---
src/qemu/qemu_validate.c | 22 +++++++++++++++++-----
1 file changed, 17 insertions(+), 5 deletions(-)
diff --git a/src/qemu/qemu_validate.c b/src/qemu/qemu_validate.c
index 7d11ae2c92..654850f925 100644
--- a/src/qemu/qemu_validate.c
+++ b/src/qemu/qemu_validate.c
@@ -389,18 +389,30 @@ qemuValidateDomainDefIOThreads(const virDomainDef *def,
virQEMUCaps *qemuCaps)
{
size_t i;
+ bool needsThreadPoolCap = false;
for (i = 0; i < def->niothreadids; i++) {
virDomainIOThreadIDDef *iothread = def->iothreadids[i];
- if ((iothread->thread_pool_min != -1 || iothread->thread_pool_max != -1)
&&
- !virQEMUCapsGet(qemuCaps, QEMU_CAPS_IOTHREAD_THREAD_POOL_MAX)) {
- virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
- _("thread_pool_min and thread_pool_max is not supported
by this QEMU binary"));
- return -1;
+ if (iothread->thread_pool_min != -1 || iothread->thread_pool_max != -1) {
+ needsThreadPoolCap = true;
+ break;
}
}
+ if (def->defaultIOThread &&
+ (def->defaultIOThread->thread_pool_min >= 0 ||
+ def->defaultIOThread->thread_pool_max >= 0)) {
+ needsThreadPoolCap = true;
+ }
+
+ if (needsThreadPoolCap &&
+ !virQEMUCapsGet(qemuCaps, QEMU_CAPS_IOTHREAD_THREAD_POOL_MAX)) {
+ virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
+ _("thread_pool_min and thread_pool_max is not supported by
this QEMU binary"));
+ return -1;
+ }
+
return 0;
}
--
2.35.1