mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-13 16:15:19 +00:00
qemu_process: move video validation out of qemu_command
Runtime validation that depend on qemu capabilities should be moved into qemuProcessStartValidateXML. Signed-off-by: Pavel Hrdina <phrdina@redhat.com>
This commit is contained in:
parent
133fb1401f
commit
8fed30d004
@ -4271,26 +4271,12 @@ qemuBuildDeviceVideoStr(const virDomainDef *def,
|
|||||||
model = "virtio-gpu-pci";
|
model = "virtio-gpu-pci";
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (!virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_QXL)) {
|
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
|
||||||
"%s", _("only one video card is currently supported"));
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
|
|
||||||
model = "qxl";
|
model = "qxl";
|
||||||
}
|
}
|
||||||
|
|
||||||
virBufferAsprintf(&buf, "%s,id=%s", model, video->info.alias);
|
virBufferAsprintf(&buf, "%s,id=%s", model, video->info.alias);
|
||||||
|
|
||||||
if (video->accel && video->accel->accel3d == VIR_TRISTATE_SWITCH_ON) {
|
if (video->accel && video->accel->accel3d == VIR_TRISTATE_SWITCH_ON) {
|
||||||
if (video->type != VIR_DOMAIN_VIDEO_TYPE_VIRTIO ||
|
|
||||||
!virQEMUCapsGet(qemuCaps, QEMU_CAPS_VIRTIO_GPU_VIRGL)) {
|
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
|
||||||
_("%s 3d acceleration is not supported"),
|
|
||||||
virDomainVideoTypeToString(video->type));
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
|
|
||||||
virBufferAsprintf(&buf, ",virgl=%s",
|
virBufferAsprintf(&buf, ",virgl=%s",
|
||||||
virTristateSwitchTypeToString(video->accel->accel3d));
|
virTristateSwitchTypeToString(video->accel->accel3d));
|
||||||
}
|
}
|
||||||
@ -4356,17 +4342,7 @@ qemuBuildVideoCommandLine(virCommandPtr cmd,
|
|||||||
|
|
||||||
primaryVideoType = def->videos[0]->type;
|
primaryVideoType = def->videos[0]->type;
|
||||||
|
|
||||||
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_VIDEO_PRIMARY) &&
|
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_VIDEO_PRIMARY)) {
|
||||||
((primaryVideoType == VIR_DOMAIN_VIDEO_TYPE_VGA &&
|
|
||||||
virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_VGA)) ||
|
|
||||||
(primaryVideoType == VIR_DOMAIN_VIDEO_TYPE_CIRRUS &&
|
|
||||||
virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_CIRRUS_VGA)) ||
|
|
||||||
(primaryVideoType == VIR_DOMAIN_VIDEO_TYPE_VMVGA &&
|
|
||||||
virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_VMWARE_SVGA)) ||
|
|
||||||
(primaryVideoType == VIR_DOMAIN_VIDEO_TYPE_QXL &&
|
|
||||||
virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_QXL)) ||
|
|
||||||
(primaryVideoType == VIR_DOMAIN_VIDEO_TYPE_VIRTIO &&
|
|
||||||
virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_VIRTIO_GPU)))) {
|
|
||||||
for (i = 0; i < def->nvideos; i++) {
|
for (i = 0; i < def->nvideos; i++) {
|
||||||
char *str;
|
char *str;
|
||||||
virCommandAddArg(cmd, "-device");
|
virCommandAddArg(cmd, "-device");
|
||||||
@ -4378,13 +4354,6 @@ qemuBuildVideoCommandLine(virCommandPtr cmd,
|
|||||||
VIR_FREE(str);
|
VIR_FREE(str);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if ((primaryVideoType == VIR_DOMAIN_VIDEO_TYPE_QXL) &&
|
|
||||||
!virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_QXL)) {
|
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
|
||||||
_("This QEMU does not support QXL graphics adapters"));
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
const char *vgastr = qemuVideoTypeToString(primaryVideoType);
|
const char *vgastr = qemuVideoTypeToString(primaryVideoType);
|
||||||
if (!vgastr || STREQ(vgastr, "")) {
|
if (!vgastr || STREQ(vgastr, "")) {
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
virReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
|
@ -4447,6 +4447,50 @@ qemuProcessStartValidateGraphics(virDomainObjPtr vm)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int
|
||||||
|
qemuProcessStartValidateVideo(virDomainObjPtr vm,
|
||||||
|
virQEMUCapsPtr qemuCaps)
|
||||||
|
{
|
||||||
|
size_t i;
|
||||||
|
virDomainVideoDefPtr video;
|
||||||
|
|
||||||
|
for (i = 0; i < vm->def->nvideos; i++) {
|
||||||
|
video = vm->def->videos[i];
|
||||||
|
|
||||||
|
if (video->primary &&
|
||||||
|
virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_VIDEO_PRIMARY) &&
|
||||||
|
((video->type == VIR_DOMAIN_VIDEO_TYPE_VGA &&
|
||||||
|
!virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_VGA)) ||
|
||||||
|
(video->type == VIR_DOMAIN_VIDEO_TYPE_CIRRUS &&
|
||||||
|
!virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_CIRRUS_VGA)) ||
|
||||||
|
(video->type == VIR_DOMAIN_VIDEO_TYPE_VMVGA &&
|
||||||
|
!virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_VMWARE_SVGA)) ||
|
||||||
|
(video->type == VIR_DOMAIN_VIDEO_TYPE_QXL &&
|
||||||
|
!virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_QXL)) ||
|
||||||
|
(video->type == VIR_DOMAIN_VIDEO_TYPE_VIRTIO &&
|
||||||
|
!virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_VIRTIO_GPU)))) {
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||||
|
_("this QEMU does not support '%s' video device"),
|
||||||
|
virDomainVideoTypeToString(video->type));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (video->accel) {
|
||||||
|
if (video->accel->accel3d == VIR_TRISTATE_SWITCH_ON &&
|
||||||
|
(video->type != VIR_DOMAIN_VIDEO_TYPE_VIRTIO ||
|
||||||
|
!virQEMUCapsGet(qemuCaps, QEMU_CAPS_VIRTIO_GPU_VIRGL))) {
|
||||||
|
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||||
|
_("%s 3d acceleration is not supported"),
|
||||||
|
virDomainVideoTypeToString(video->type));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
qemuProcessStartValidateXML(virQEMUDriverPtr driver,
|
qemuProcessStartValidateXML(virQEMUDriverPtr driver,
|
||||||
virDomainObjPtr vm,
|
virDomainObjPtr vm,
|
||||||
@ -4520,6 +4564,9 @@ qemuProcessStartValidate(virQEMUDriverPtr driver,
|
|||||||
if (qemuProcessStartValidateGraphics(vm) < 0)
|
if (qemuProcessStartValidateGraphics(vm) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
if (qemuProcessStartValidateVideo(vm, qemuCaps) < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
VIR_DEBUG("Checking for any possible (non-fatal) issues");
|
VIR_DEBUG("Checking for any possible (non-fatal) issues");
|
||||||
|
|
||||||
qemuProcessStartWarnShmem(vm);
|
qemuProcessStartWarnShmem(vm);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user