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 08/12] block: introduce bdrv_can_set_read_only()
Date: Mon, 24 Apr 2017 15:19:58 -0400 [thread overview]
Message-ID: <20170424192002.18622-9-jcody@redhat.com> (raw)
In-Reply-To: <20170424192002.18622-1-jcody@redhat.com>
Introduce check function for setting read_only flags. Will return < 0 on
error, with appropriate Error value set. Does not alter any flags.
Signed-off-by: Jeff Cody <jcody@redhat.com>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
Reviewed-by: John Snow <jsnow@redhat.com>
Message-id: e2bba34ac3bc76a0c42adc390413f358ae0566e8.1491597120.git.jcody@redhat.com
---
block.c | 14 +++++++++++++-
include/block/block.h | 1 +
2 files changed, 14 insertions(+), 1 deletion(-)
diff --git a/block.c b/block.c
index 123c982..1ac05c1 100644
--- a/block.c
+++ b/block.c
@@ -197,7 +197,7 @@ bool bdrv_is_read_only(BlockDriverState *bs)
return bs->read_only;
}
-int bdrv_set_read_only(BlockDriverState *bs, bool read_only, Error **errp)
+int bdrv_can_set_read_only(BlockDriverState *bs, bool read_only, Error **errp)
{
/* Do not set read_only if copy_on_read is enabled */
if (bs->copy_on_read && read_only) {
@@ -213,6 +213,18 @@ int bdrv_set_read_only(BlockDriverState *bs, bool read_only, Error **errp)
return -EPERM;
}
+ return 0;
+}
+
+int bdrv_set_read_only(BlockDriverState *bs, bool read_only, Error **errp)
+{
+ int ret = 0;
+
+ ret = bdrv_can_set_read_only(bs, read_only, errp);
+ if (ret < 0) {
+ return ret;
+ }
+
bs->read_only = read_only;
return 0;
}
diff --git a/include/block/block.h b/include/block/block.h
index 1d7fd19..144df0d 100644
--- a/include/block/block.h
+++ b/include/block/block.h
@@ -434,6 +434,7 @@ int bdrv_is_allocated_above(BlockDriverState *top, BlockDriverState *base,
int64_t sector_num, int nb_sectors, int *pnum);
bool bdrv_is_read_only(BlockDriverState *bs);
+int bdrv_can_set_read_only(BlockDriverState *bs, bool read_only, Error **errp);
int bdrv_set_read_only(BlockDriverState *bs, bool read_only, Error **errp);
bool bdrv_is_sg(BlockDriverState *bs);
bool bdrv_is_inserted(BlockDriverState *bs);
--
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 ` [Qemu-devel] [PULL v2 06/12] block: honor BDRV_O_ALLOW_RDWR when clearing bs->read_only Jeff Cody
2017-04-24 19:19 ` [Qemu-devel] [PULL v2 07/12] block: code movement Jeff Cody
2017-04-24 19:19 ` Jeff Cody [this message]
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-9-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).