From: Jeff Cody <jcody@redhat.com>
To: qemu-block@nongnu.org
Cc: peter.maydell@linaro.org, jcody@redhat.com, qemu-devel@nongnu.org
Subject: [Qemu-devel] [PULL v2 06/12] block: honor BDRV_O_ALLOW_RDWR when clearing bs->read_only
Date: Mon, 24 Apr 2017 15:19:56 -0400 [thread overview]
Message-ID: <20170424192002.18622-7-jcody@redhat.com> (raw)
In-Reply-To: <20170424192002.18622-1-jcody@redhat.com>
The BDRV_O_ALLOW_RDWR flag allows / prohibits the changing of
the BDS 'read_only' state, but there are a few places where it
is ignored. In the bdrv_set_read_only() helper, make sure to
honor the flag.
Signed-off-by: Jeff Cody <jcody@redhat.com>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
Reviewed-by: John Snow <jsnow@redhat.com>
Message-id: be2e5fb2d285cbece2b6d06bed54a6f56520d251.1491597120.git.jcody@redhat.com
---
block.c | 7 +++++++
1 file changed, 7 insertions(+)
diff --git a/block.c b/block.c
index 67ae35a..4752fee 100644
--- a/block.c
+++ b/block.c
@@ -201,6 +201,13 @@ int bdrv_set_read_only(BlockDriverState *bs, bool read_only, Error **errp)
return -EINVAL;
}
+ /* Do not clear read_only if it is prohibited */
+ if (!read_only && !(bs->open_flags & BDRV_O_ALLOW_RDWR)) {
+ error_setg(errp, "Node '%s' is read only",
+ bdrv_get_device_or_node_name(bs));
+ return -EPERM;
+ }
+
bs->read_only = read_only;
return 0;
}
--
2.9.3
next prev parent reply other threads:[~2017-04-24 19:20 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-04-24 19:19 [Qemu-devel] [PULL v2 00/12] Block patches Jeff Cody
2017-04-24 19:19 ` [Qemu-devel] [PULL v2 01/12] block/vxhs.c: Add support for a new block device type called "vxhs" Jeff Cody
2017-04-24 19:19 ` [Qemu-devel] [PULL v2 02/12] block/vxhs.c: Add qemu-iotests for new block device type "vxhs" Jeff Cody
2017-04-24 19:19 ` [Qemu-devel] [PULL v2 03/12] qemu-iotests: exclude vxhs from image creation via protocol Jeff Cody
2017-04-24 19:19 ` [Qemu-devel] [PULL v2 04/12] block: add bdrv_set_read_only() helper function Jeff Cody
2017-04-24 19:19 ` [Qemu-devel] [PULL v2 05/12] block: do not set BDS read_only if copy_on_read enabled Jeff Cody
2017-04-24 19:19 ` Jeff Cody [this message]
2017-04-24 19:19 ` [Qemu-devel] [PULL v2 07/12] block: code movement Jeff Cody
2017-04-24 19:19 ` [Qemu-devel] [PULL v2 08/12] block: introduce bdrv_can_set_read_only() Jeff Cody
2017-04-24 19:19 ` [Qemu-devel] [PULL v2 09/12] block: use bdrv_can_set_read_only() during reopen Jeff Cody
2017-04-24 19:20 ` [Qemu-devel] [PULL v2 10/12] block/rbd - update variable names to more apt names Jeff Cody
2017-04-24 19:20 ` [Qemu-devel] [PULL v2 11/12] block/rbd: Add support for reopen() Jeff Cody
2017-04-24 19:20 ` [Qemu-devel] [PULL v2 12/12] qemu-iotests: _cleanup_qemu must be called on exit Jeff Cody
2017-04-25 10:15 ` [Qemu-devel] [PULL v2 00/12] Block patches Peter Maydell
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20170424192002.18622-7-jcody@redhat.com \
--to=jcody@redhat.com \
--cc=peter.maydell@linaro.org \
--cc=qemu-block@nongnu.org \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).