rbd: make qemu's cache setting override any ceph setting
To be safe, when cache=none is used ceph settings should not be able to override it to turn on caching. This was previously possible with rbd_cache=true in the rbd device configuration or a ceph configuration file. Similarly, rbd settings could have turned off caching when qemu requested it, although this would just be a performance problem. Fix this by changing rbd's cache setting to match qemu after all other ceph settings have been applied. Signed-off-by: Josh Durgin <jdurgin@redhat.com> Reviewed-by: Jeff Cody <jcody@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
parent
5a8ac6d9d7
commit
99a3c89d5d
24
block/rbd.c
24
block/rbd.c
@ -460,6 +460,18 @@ static int qemu_rbd_open(BlockDriverState *bs, QDict *options, int flags,
|
|||||||
s->snap = g_strdup(snap_buf);
|
s->snap = g_strdup(snap_buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (strstr(conf, "conf=") == NULL) {
|
||||||
|
/* try default location, but ignore failure */
|
||||||
|
rados_conf_read_file(s->cluster, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (conf[0] != '\0') {
|
||||||
|
r = qemu_rbd_set_conf(s->cluster, conf, errp);
|
||||||
|
if (r < 0) {
|
||||||
|
goto failed_shutdown;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Fallback to more conservative semantics if setting cache
|
* Fallback to more conservative semantics if setting cache
|
||||||
* options fails. Ignore errors from setting rbd_cache because the
|
* options fails. Ignore errors from setting rbd_cache because the
|
||||||
@ -473,18 +485,6 @@ static int qemu_rbd_open(BlockDriverState *bs, QDict *options, int flags,
|
|||||||
rados_conf_set(s->cluster, "rbd_cache", "true");
|
rados_conf_set(s->cluster, "rbd_cache", "true");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strstr(conf, "conf=") == NULL) {
|
|
||||||
/* try default location, but ignore failure */
|
|
||||||
rados_conf_read_file(s->cluster, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (conf[0] != '\0') {
|
|
||||||
r = qemu_rbd_set_conf(s->cluster, conf, errp);
|
|
||||||
if (r < 0) {
|
|
||||||
goto failed_shutdown;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
r = rados_connect(s->cluster);
|
r = rados_connect(s->cluster);
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
error_setg(errp, "error connecting");
|
error_setg(errp, "error connecting");
|
||||||
|
Loading…
Reference in New Issue
Block a user