From: Wang Guang Date: Wed, 25 Oct 2017 06:51:23 +0000 (+0800) Subject: replication: Fix replication open fail X-Git-Tag: v2.11.0-rc2~16^2~9 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=611e0653adfb2765b712ad8bd312f2fd9765d13c;p=thirdparty%2Fqemu.git replication: Fix replication open fail replication_child_perm request write permissions for all child which will lead bdrv_check_perm fail. replication_child_perm() should request write permissions only if it is writable itself. Signed-off-by: Wang Guang Signed-off-by: Wang Yong Reviewed-by: Xie Changlong Signed-off-by: Kevin Wolf --- diff --git a/block/replication.c b/block/replication.c index 3a4e6822e43..1c95d673ff3 100644 --- a/block/replication.c +++ b/block/replication.c @@ -161,10 +161,13 @@ static void replication_child_perm(BlockDriverState *bs, BdrvChild *c, uint64_t perm, uint64_t shared, uint64_t *nperm, uint64_t *nshared) { - *nperm = *nshared = BLK_PERM_CONSISTENT_READ \ - | BLK_PERM_WRITE \ - | BLK_PERM_WRITE_UNCHANGED; - + *nperm = BLK_PERM_CONSISTENT_READ; + if ((bs->open_flags & (BDRV_O_INACTIVE | BDRV_O_RDWR)) == BDRV_O_RDWR) { + *nperm |= BLK_PERM_WRITE; + } + *nshared = BLK_PERM_CONSISTENT_READ \ + | BLK_PERM_WRITE \ + | BLK_PERM_WRITE_UNCHANGED; return; }