}
+static int
+virDomainDiskDefValidate(const virDomainDiskDef *def)
+{
+ if (def->bus != VIR_DOMAIN_DISK_BUS_VIRTIO) {
+ if (def->event_idx != VIR_TRISTATE_SWITCH_ABSENT) {
+ virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
+ _("disk event_idx mode supported only for virtio bus"));
+ return -1;
+ }
+
+ if (def->ioeventfd != VIR_TRISTATE_SWITCH_ABSENT) {
+ virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
+ _("disk ioeventfd mode supported only for virtio bus"));
+ return -1;
+ }
+ }
+
+ return 0;
+}
+
+
#define VENDOR_LEN 8
#define PRODUCT_LEN 16
if (ioeventfd) {
int val;
- if (def->bus != VIR_DOMAIN_DISK_BUS_VIRTIO) {
- virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
- _("disk ioeventfd mode supported "
- "only for virtio bus"));
- goto error;
- }
-
if ((val = virTristateSwitchTypeFromString(ioeventfd)) <= 0) {
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
_("unknown disk ioeventfd mode '%s'"),
}
if (event_idx) {
- if (def->bus != VIR_DOMAIN_DISK_BUS_VIRTIO) {
- virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
- _("disk event_idx mode supported "
- "only for virtio bus"));
- goto error;
- }
-
int idx;
if ((idx = virTristateSwitchTypeFromString(event_idx)) <= 0) {
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
goto error;
}
+ if (virDomainDiskDefValidate(def) < 0)
+ goto error;
+
cleanup:
VIR_FREE(bus);
VIR_FREE(type);