Patchwork [v2,02/16] block: make bdrv_set_enable_write_cache() modify open_flags

login
register
mail settings
Submitter Jeff Cody
Date Sept. 13, 2012, 3:49 p.m.
Message ID <984108651fa38ec104770e7c3b1130f5d16ac478.1347548248.git.jcody@redhat.com>
Download mbox | patch
Permalink /patch/183659/
State New
Headers show

Comments

Jeff Cody - Sept. 13, 2012, 3:49 p.m.
bdrv_set_enable_write_cache() sets the bs->enable_write_cache flag,
but without the flag recorded in bs->open_flags, then next time
a reopen() is performed the enable_write_cache setting may be
inadvertently lost.

This will set the flag in open_flags, so it is preserved across
reopens.

Signed-off-by: Jeff Cody <jcody@redhat.com>
---
 block.c | 7 +++++++
 1 file changed, 7 insertions(+)

Patch

diff --git a/block.c b/block.c
index c3eb585..2b96c8e 100644
--- a/block.c
+++ b/block.c
@@ -2164,6 +2164,13 @@  int bdrv_enable_write_cache(BlockDriverState *bs)
 void bdrv_set_enable_write_cache(BlockDriverState *bs, bool wce)
 {
     bs->enable_write_cache = wce;
+
+    /* so a reopen() will preserve wce */
+    if (wce) {
+        bs->open_flags |= BDRV_O_CACHE_WB;
+    } else {
+        bs->open_flags &= ~BDRV_O_CACHE_WB;
+    }
 }
 
 int bdrv_is_encrypted(BlockDriverState *bs)