|
|
1bdc94 |
From 8d74e190054f8a2254f9da5a0eb2e17c66df94db Mon Sep 17 00:00:00 2001
|
|
|
4a2fec |
From: John Snow <jsnow@redhat.com>
|
|
|
4a2fec |
Date: Fri, 16 Sep 2016 22:06:28 +0200
|
|
|
4a2fec |
Subject: blockdev: ignore cache options for empty CDROM drives
|
|
|
4a2fec |
|
|
|
4a2fec |
RH-Author: John Snow <jsnow@redhat.com>
|
|
|
4a2fec |
Message-id: <1474063588-6370-2-git-send-email-jsnow@redhat.com>
|
|
|
4a2fec |
Patchwork-id: 72377
|
|
|
4a2fec |
O-Subject: [RHEV-7.3 qemu-kvm-rhev PATCH 1/1] blockdev: ignore cache options for empty CDROM drives
|
|
|
4a2fec |
Bugzilla: 1342999
|
|
|
4a2fec |
RH-Acked-by: Max Reitz <mreitz@redhat.com>
|
|
|
4a2fec |
RH-Acked-by: Kevin Wolf <kwolf@redhat.com>
|
|
|
4a2fec |
RH-Acked-by: Stefan Hajnoczi <stefanha@redhat.com>
|
|
|
4a2fec |
|
|
|
4a2fec |
In qemu-kvm-rhev-2.3.0, QEMU will accept cache options for empty CDROM
|
|
|
4a2fec |
devices, but silently ignore them as they will be overwritten when the
|
|
|
4a2fec |
next CDROM is inserted.
|
|
|
4a2fec |
|
|
|
4a2fec |
Libvirt and VMM are capable of generating XML configurations which
|
|
|
4a2fec |
attempt to specify these cache options to QEMU, though they don't have
|
|
|
4a2fec |
any effect.
|
|
|
4a2fec |
|
|
|
4a2fec |
Upstream, a refactoring of cache option mechanisms means that we have
|
|
|
4a2fec |
started rejecting invalid configurations where cache options are supplied
|
|
|
4a2fec |
without any target to actually apply them to.
|
|
|
4a2fec |
|
|
|
4a2fec |
This means that there are combinations of QEMU and libvirt that will fail
|
|
|
4a2fec |
to start a VM if a user selects a cache option.
|
|
|
4a2fec |
|
|
|
4a2fec |
This patch is a downstream-only workaround until libvirt can stop
|
|
|
4a2fec |
supplying cache settings for empty CDROMs and/or until libvirt can take
|
|
|
4a2fec |
advantage of the new QMP tray/medium manipulation mechanisms that will
|
|
|
4a2fec |
allow proper cache specification for removable media.
|
|
|
4a2fec |
|
|
|
4a2fec |
Signed-off-by: John Snow <jsnow@redhat.com>
|
|
|
4a2fec |
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
|
|
|
4a2fec |
(cherry picked from commit 89b162019bfd202bbbd00563d03a030c2f7c1395)
|
|
|
1bdc94 |
(cherry picked from commit 454f60447bfea904d561ef282fc0446229484c02)
|
|
|
1bdc94 |
(cherry picked from commit 50e4b1d94ce41a9c83034d372caea6ed20d6fcfb)
|
|
|
1bdc94 |
(cherry picked from commit 54994db40273e0b4bec5f703459fdb71a453a373)
|
|
|
1bdc94 |
(cherry picked from commit 0f4f6f39126ba96a4b288bb13bcd0f13eb46fa35)
|
|
|
4a2fec |
---
|
|
|
4a2fec |
blockdev.c | 28 +++++++++++++++++++++++++++-
|
|
|
4a2fec |
1 file changed, 27 insertions(+), 1 deletion(-)
|
|
|
4a2fec |
|
|
|
4a2fec |
diff --git a/blockdev.c b/blockdev.c
|
|
|
1bdc94 |
index e941b99..cf10108 100644
|
|
|
4a2fec |
--- a/blockdev.c
|
|
|
4a2fec |
+++ b/blockdev.c
|
|
|
1bdc94 |
@@ -460,6 +460,32 @@ static void extract_common_blockdev_options(QemuOpts *opts, int *bdrv_flags,
|
|
|
4a2fec |
}
|
|
|
4a2fec |
}
|
|
|
4a2fec |
|
|
|
4a2fec |
+/**
|
|
|
4a2fec |
+ * libvirt expects to be able to pass cache options for CDROM drives without
|
|
|
4a2fec |
+ * inserted media. Historically, QEMU eventually ignores these cache options as
|
|
|
4a2fec |
+ * they are lost when media is inserted. Recently, QEMU started rejecting these
|
|
|
4a2fec |
+ * configurations. Libvirt however still generates such configurations.
|
|
|
4a2fec |
+ *
|
|
|
4a2fec |
+ * To prevent QEMU from being unable to start, pretend there are no options
|
|
|
4a2fec |
+ * present if the only options present are cache options for the BDS.
|
|
|
4a2fec |
+ */
|
|
|
4a2fec |
+static bool __redhat_com_has_bs_opts(QDict *bs_opts)
|
|
|
4a2fec |
+{
|
|
|
4a2fec |
+ size_t n, s;
|
|
|
4a2fec |
+ s = qdict_size(bs_opts);
|
|
|
4a2fec |
+
|
|
|
4a2fec |
+ if (s == 0) {
|
|
|
4a2fec |
+ return false;
|
|
|
4a2fec |
+ } else if (s > 2) {
|
|
|
4a2fec |
+ return true;
|
|
|
4a2fec |
+ }
|
|
|
4a2fec |
+
|
|
|
4a2fec |
+ n = qdict_haskey(bs_opts, BDRV_OPT_CACHE_DIRECT);
|
|
|
4a2fec |
+ n += qdict_haskey(bs_opts, BDRV_OPT_CACHE_NO_FLUSH);
|
|
|
4a2fec |
+
|
|
|
4a2fec |
+ return s != n;
|
|
|
4a2fec |
+}
|
|
|
4a2fec |
+
|
|
|
4a2fec |
/* Takes the ownership of bs_opts */
|
|
|
4a2fec |
static BlockBackend *blockdev_init(const char *file, QDict *bs_opts,
|
|
|
4a2fec |
Error **errp)
|
|
|
1bdc94 |
@@ -567,7 +593,7 @@ static BlockBackend *blockdev_init(const char *file, QDict *bs_opts,
|
|
|
4a2fec |
read_only = qemu_opt_get_bool(opts, BDRV_OPT_READ_ONLY, false);
|
|
|
4a2fec |
|
|
|
4a2fec |
/* init */
|
|
|
4a2fec |
- if ((!file || !*file) && !qdict_size(bs_opts)) {
|
|
|
4a2fec |
+ if ((!file || !*file) && !__redhat_com_has_bs_opts(bs_opts)) {
|
|
|
4a2fec |
BlockBackendRootState *blk_rs;
|
|
|
4a2fec |
|
|
|
4a2fec |
blk = blk_new(0, BLK_PERM_ALL);
|
|
|
4a2fec |
--
|
|
|
4a2fec |
1.8.3.1
|
|
|
4a2fec |
|