aboutsummaryrefslogtreecommitdiff
path: root/qom/cpu.c
diff options
context:
space:
mode:
authorDong Jia Shi <bjsdjshi@linux.vnet.ibm.com>2017-04-05 11:19:09 +0200
committerMax Reitz <mreitz@redhat.com>2017-04-11 15:33:00 +0200
commit7a9e51198c24a576275cf509a110d24d7c6ca664 (patch)
treebabdbdcd2c8a486836005c78066c3fc3b8e8ed48 /qom/cpu.c
parentaa388ddc36e8032f41cd17bef88cc3ebaeba77c9 (diff)
downloadqemu-7a9e51198c24a576275cf509a110d24d7c6ca664.zip
qemu-7a9e51198c24a576275cf509a110d24d7c6ca664.tar.gz
qemu-7a9e51198c24a576275cf509a110d24d7c6ca664.tar.bz2
block: pass the right options for BlockDriver.bdrv_open()
raw_open() expects the caller always passing in the right actual @options parameter. But when trying to applying snapshot on a RBD image, bdrv_snapshot_goto() calls raw_open() (by calling the bdrv_open callback on the BlockDriver) with a NULL @options, and that will result in a Segmentation fault. For the other non-raw format drivers, it also makes sense to passing in the actual options, althought they don't trigger the problem so far. Let's prepare a @options by adding the "file" key-value pair to a copy of the actual options that were given for the node (i.e. bs->options), and pass it to the callback. BlockDriver.bdrv_open() expects bs->file to be NULL and just overwrites it with the result from bdrv_open_child(). That means we should actually make sure it's NULL because otherwise the child BDS will have a reference count that is 1 too high. So we unconditionally invoke bdrv_unref_child() before calling BlockDriver.bdrv_open(), and we wrap everything in bdrv_ref()/bdrv_unref() so the BDS isn't deleted in the meantime. Suggested-by: Max Reitz <mreitz@redhat.com> Signed-off-by: Dong Jia Shi <bjsdjshi@linux.vnet.ibm.com> Message-id: 20170405091909.36357-2-bjsdjshi@linux.vnet.ibm.com Signed-off-by: Max Reitz <mreitz@redhat.com>
Diffstat (limited to 'qom/cpu.c')
0 files changed, 0 insertions, 0 deletions