Merge remote-tracking branch 'kwolf/for-anthony' into staging
# By Stefan Hajnoczi (2) and others # Via Kevin Wolf * kwolf/for-anthony: virtio-blk: Do not segfault fault if failed to initialize dataplane qemu-iotests: add 052 BDRV_O_SNAPSHOT test block: fix BDRV_O_SNAPSHOT protocol detection qcow2: Fix segfault in qcow2_invalidate_cache sheepdog: show error message for halt status
This commit is contained in:
commit
277ba8a6d7
6
block.c
6
block.c
@ -830,7 +830,6 @@ int bdrv_open(BlockDriverState *bs, const char *filename, QDict *options,
|
|||||||
if (flags & BDRV_O_SNAPSHOT) {
|
if (flags & BDRV_O_SNAPSHOT) {
|
||||||
BlockDriverState *bs1;
|
BlockDriverState *bs1;
|
||||||
int64_t total_size;
|
int64_t total_size;
|
||||||
int is_protocol = 0;
|
|
||||||
BlockDriver *bdrv_qcow2;
|
BlockDriver *bdrv_qcow2;
|
||||||
QEMUOptionParameter *options;
|
QEMUOptionParameter *options;
|
||||||
char backing_filename[PATH_MAX];
|
char backing_filename[PATH_MAX];
|
||||||
@ -847,9 +846,6 @@ int bdrv_open(BlockDriverState *bs, const char *filename, QDict *options,
|
|||||||
}
|
}
|
||||||
total_size = bdrv_getlength(bs1) & BDRV_SECTOR_MASK;
|
total_size = bdrv_getlength(bs1) & BDRV_SECTOR_MASK;
|
||||||
|
|
||||||
if (bs1->drv && bs1->drv->protocol_name)
|
|
||||||
is_protocol = 1;
|
|
||||||
|
|
||||||
bdrv_delete(bs1);
|
bdrv_delete(bs1);
|
||||||
|
|
||||||
ret = get_tmp_filename(tmp_filename, sizeof(tmp_filename));
|
ret = get_tmp_filename(tmp_filename, sizeof(tmp_filename));
|
||||||
@ -858,7 +854,7 @@ int bdrv_open(BlockDriverState *bs, const char *filename, QDict *options,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Real path is meaningless for protocols */
|
/* Real path is meaningless for protocols */
|
||||||
if (is_protocol) {
|
if (path_has_protocol(filename)) {
|
||||||
snprintf(backing_filename, sizeof(backing_filename),
|
snprintf(backing_filename, sizeof(backing_filename),
|
||||||
"%s", filename);
|
"%s", filename);
|
||||||
} else if (!realpath(filename, backing_filename)) {
|
} else if (!realpath(filename, backing_filename)) {
|
||||||
|
@ -29,6 +29,7 @@
|
|||||||
#include "block/qcow2.h"
|
#include "block/qcow2.h"
|
||||||
#include "qemu/error-report.h"
|
#include "qemu/error-report.h"
|
||||||
#include "qapi/qmp/qerror.h"
|
#include "qapi/qmp/qerror.h"
|
||||||
|
#include "qapi/qmp/qbool.h"
|
||||||
#include "trace.h"
|
#include "trace.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -520,7 +521,7 @@ static int qcow2_open(BlockDriverState *bs, QDict *options, int flags)
|
|||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
s->use_lazy_refcounts = qemu_opt_get_bool(opts, "lazy_refcounts",
|
s->use_lazy_refcounts = qemu_opt_get_bool(opts, QCOW2_OPT_LAZY_REFCOUNTS,
|
||||||
(s->compatible_features & QCOW2_COMPAT_LAZY_REFCOUNTS));
|
(s->compatible_features & QCOW2_COMPAT_LAZY_REFCOUNTS));
|
||||||
|
|
||||||
qemu_opts_del(opts);
|
qemu_opts_del(opts);
|
||||||
@ -930,6 +931,7 @@ static void qcow2_invalidate_cache(BlockDriverState *bs)
|
|||||||
AES_KEY aes_encrypt_key;
|
AES_KEY aes_encrypt_key;
|
||||||
AES_KEY aes_decrypt_key;
|
AES_KEY aes_decrypt_key;
|
||||||
uint32_t crypt_method = 0;
|
uint32_t crypt_method = 0;
|
||||||
|
QDict *options;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Backing files are read-only which makes all of their metadata immutable,
|
* Backing files are read-only which makes all of their metadata immutable,
|
||||||
@ -944,8 +946,14 @@ static void qcow2_invalidate_cache(BlockDriverState *bs)
|
|||||||
|
|
||||||
qcow2_close(bs);
|
qcow2_close(bs);
|
||||||
|
|
||||||
|
options = qdict_new();
|
||||||
|
qdict_put(options, QCOW2_OPT_LAZY_REFCOUNTS,
|
||||||
|
qbool_from_int(s->use_lazy_refcounts));
|
||||||
|
|
||||||
memset(s, 0, sizeof(BDRVQcowState));
|
memset(s, 0, sizeof(BDRVQcowState));
|
||||||
qcow2_open(bs, NULL, flags);
|
qcow2_open(bs, options, flags);
|
||||||
|
|
||||||
|
QDECREF(options);
|
||||||
|
|
||||||
if (crypt_method) {
|
if (crypt_method) {
|
||||||
s->crypt_method = crypt_method;
|
s->crypt_method = crypt_method;
|
||||||
|
@ -58,6 +58,9 @@
|
|||||||
|
|
||||||
#define DEFAULT_CLUSTER_SIZE 65536
|
#define DEFAULT_CLUSTER_SIZE 65536
|
||||||
|
|
||||||
|
|
||||||
|
#define QCOW2_OPT_LAZY_REFCOUNTS "lazy_refcounts"
|
||||||
|
|
||||||
typedef struct QCowHeader {
|
typedef struct QCowHeader {
|
||||||
uint32_t magic;
|
uint32_t magic;
|
||||||
uint32_t version;
|
uint32_t version;
|
||||||
|
@ -65,6 +65,7 @@
|
|||||||
#define SD_RES_WAIT_FOR_FORMAT 0x16 /* Waiting for a format operation */
|
#define SD_RES_WAIT_FOR_FORMAT 0x16 /* Waiting for a format operation */
|
||||||
#define SD_RES_WAIT_FOR_JOIN 0x17 /* Waiting for other nodes joining */
|
#define SD_RES_WAIT_FOR_JOIN 0x17 /* Waiting for other nodes joining */
|
||||||
#define SD_RES_JOIN_FAILED 0x18 /* Target node had failed to join sheepdog */
|
#define SD_RES_JOIN_FAILED 0x18 /* Target node had failed to join sheepdog */
|
||||||
|
#define SD_RES_HALT 0x19 /* Sheepdog is stopped serving IO request */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Object ID rules
|
* Object ID rules
|
||||||
@ -344,6 +345,7 @@ static const char * sd_strerror(int err)
|
|||||||
{SD_RES_WAIT_FOR_FORMAT, "Sheepdog is waiting for a format operation"},
|
{SD_RES_WAIT_FOR_FORMAT, "Sheepdog is waiting for a format operation"},
|
||||||
{SD_RES_WAIT_FOR_JOIN, "Sheepdog is waiting for other nodes joining"},
|
{SD_RES_WAIT_FOR_JOIN, "Sheepdog is waiting for other nodes joining"},
|
||||||
{SD_RES_JOIN_FAILED, "Target node had failed to join sheepdog"},
|
{SD_RES_JOIN_FAILED, "Target node had failed to join sheepdog"},
|
||||||
|
{SD_RES_HALT, "Sheepdog is stopped serving IO request"},
|
||||||
};
|
};
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_SIZE(errors); ++i) {
|
for (i = 0; i < ARRAY_SIZE(errors); ++i) {
|
||||||
|
@ -663,7 +663,7 @@ static int virtio_blk_device_init(VirtIODevice *vdev)
|
|||||||
s->vq = virtio_add_queue(vdev, 128, virtio_blk_handle_output);
|
s->vq = virtio_add_queue(vdev, 128, virtio_blk_handle_output);
|
||||||
#ifdef CONFIG_VIRTIO_BLK_DATA_PLANE
|
#ifdef CONFIG_VIRTIO_BLK_DATA_PLANE
|
||||||
if (!virtio_blk_data_plane_create(vdev, blk, &s->dataplane)) {
|
if (!virtio_blk_data_plane_create(vdev, blk, &s->dataplane)) {
|
||||||
virtio_cleanup(vdev);
|
virtio_common_cleanup(vdev);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
61
tests/qemu-iotests/052
Executable file
61
tests/qemu-iotests/052
Executable file
@ -0,0 +1,61 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
#
|
||||||
|
# Test bdrv_read/bdrv_write using BDRV_O_SNAPSHOT
|
||||||
|
#
|
||||||
|
# Copyright (C) 2013 Red Hat, Inc.
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; either version 2 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
#
|
||||||
|
|
||||||
|
# creator
|
||||||
|
owner=stefanha@redhat.com
|
||||||
|
|
||||||
|
seq=`basename $0`
|
||||||
|
echo "QA output created by $seq"
|
||||||
|
|
||||||
|
here=`pwd`
|
||||||
|
tmp=/tmp/$$
|
||||||
|
status=1 # failure is the default!
|
||||||
|
|
||||||
|
_cleanup()
|
||||||
|
{
|
||||||
|
_cleanup_test_img
|
||||||
|
}
|
||||||
|
trap "_cleanup; exit \$status" 0 1 2 3 15
|
||||||
|
|
||||||
|
# get standard environment, filters and checks
|
||||||
|
. ./common.rc
|
||||||
|
. ./common.filter
|
||||||
|
|
||||||
|
_supported_fmt generic
|
||||||
|
_supported_proto generic
|
||||||
|
_supported_os Linux
|
||||||
|
|
||||||
|
|
||||||
|
size=128M
|
||||||
|
_make_test_img $size
|
||||||
|
|
||||||
|
echo
|
||||||
|
echo "== reading whole image =="
|
||||||
|
$QEMU_IO -s -c "read 0 $size" $TEST_IMG | _filter_qemu_io
|
||||||
|
|
||||||
|
echo
|
||||||
|
echo "== writing whole image does not modify image =="
|
||||||
|
$QEMU_IO -s -c "write -P 0xa 0 $size" $TEST_IMG | _filter_qemu_io
|
||||||
|
$QEMU_IO -c "read -P 0 0 $size" $TEST_IMG | _filter_qemu_io
|
||||||
|
|
||||||
|
# success, all done
|
||||||
|
echo "*** done"
|
||||||
|
rm -f $seq.full
|
||||||
|
status=0
|
13
tests/qemu-iotests/052.out
Normal file
13
tests/qemu-iotests/052.out
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
QA output created by 052
|
||||||
|
Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=134217728
|
||||||
|
|
||||||
|
== reading whole image ==
|
||||||
|
read 134217728/134217728 bytes at offset 0
|
||||||
|
128 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
||||||
|
|
||||||
|
== writing whole image does not modify image ==
|
||||||
|
wrote 134217728/134217728 bytes at offset 0
|
||||||
|
128 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
||||||
|
read 134217728/134217728 bytes at offset 0
|
||||||
|
128 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
||||||
|
*** done
|
@ -57,3 +57,4 @@
|
|||||||
048 img auto quick
|
048 img auto quick
|
||||||
049 rw auto
|
049 rw auto
|
||||||
050 rw auto backing quick
|
050 rw auto backing quick
|
||||||
|
052 rw auto backing
|
||||||
|
Loading…
x
Reference in New Issue
Block a user