block/qcow2.c: rename qcow_ functions to qcow2_

It doesn't really make sense for functions in qcow2.c to be named
qcow_ so convert the names to match correctly.

Signed-off-by: Jes Sorensen <Jes.Sorensen@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
Jes Sorensen 2010-12-17 16:02:39 +01:00 committed by Kevin Wolf
parent 01979a98d7
commit 7c80ab3f21
3 changed files with 103 additions and 97 deletions

View File

@ -352,8 +352,8 @@ void qcow2_encrypt_sectors(BDRVQcowState *s, int64_t sector_num,
} }
static int qcow_read(BlockDriverState *bs, int64_t sector_num, static int qcow2_read(BlockDriverState *bs, int64_t sector_num,
uint8_t *buf, int nb_sectors) uint8_t *buf, int nb_sectors)
{ {
BDRVQcowState *s = bs->opaque; BDRVQcowState *s = bs->opaque;
int ret, index_in_cluster, n, n1; int ret, index_in_cluster, n, n1;
@ -419,7 +419,7 @@ static int copy_sectors(BlockDriverState *bs, uint64_t start_sect,
if (n <= 0) if (n <= 0)
return 0; return 0;
BLKDBG_EVENT(bs->file, BLKDBG_COW_READ); BLKDBG_EVENT(bs->file, BLKDBG_COW_READ);
ret = qcow_read(bs, start_sect + n_start, s->cluster_data, n); ret = qcow2_read(bs, start_sect + n_start, s->cluster_data, n);
if (ret < 0) if (ret < 0)
return ret; return ret;
if (s->crypt_method) { if (s->crypt_method) {

View File

@ -116,7 +116,7 @@ int qcow2_read_snapshots(BlockDriverState *bs)
} }
/* add at the end of the file a new list of snapshots */ /* add at the end of the file a new list of snapshots */
static int qcow_write_snapshots(BlockDriverState *bs) static int qcow2_write_snapshots(BlockDriverState *bs)
{ {
BDRVQcowState *s = bs->opaque; BDRVQcowState *s = bs->opaque;
QCowSnapshot *sn; QCowSnapshot *sn;
@ -300,7 +300,7 @@ int qcow2_snapshot_create(BlockDriverState *bs, QEMUSnapshotInfo *sn_info)
s->snapshots = snapshots1; s->snapshots = snapshots1;
s->snapshots[s->nb_snapshots++] = *sn; s->snapshots[s->nb_snapshots++] = *sn;
if (qcow_write_snapshots(bs) < 0) if (qcow2_write_snapshots(bs) < 0)
goto fail; goto fail;
#ifdef DEBUG_ALLOC #ifdef DEBUG_ALLOC
qcow2_check_refcounts(bs); qcow2_check_refcounts(bs);
@ -378,7 +378,7 @@ int qcow2_snapshot_delete(BlockDriverState *bs, const char *snapshot_id)
qemu_free(sn->name); qemu_free(sn->name);
memmove(sn, sn + 1, (s->nb_snapshots - snapshot_index - 1) * sizeof(*sn)); memmove(sn, sn + 1, (s->nb_snapshots - snapshot_index - 1) * sizeof(*sn));
s->nb_snapshots--; s->nb_snapshots--;
ret = qcow_write_snapshots(bs); ret = qcow2_write_snapshots(bs);
if (ret < 0) { if (ret < 0) {
/* XXX: restore snapshot if error ? */ /* XXX: restore snapshot if error ? */
return ret; return ret;

View File

@ -50,10 +50,10 @@ typedef struct {
uint32_t magic; uint32_t magic;
uint32_t len; uint32_t len;
} QCowExtension; } QCowExtension;
#define QCOW_EXT_MAGIC_END 0 #define QCOW2_EXT_MAGIC_END 0
#define QCOW_EXT_MAGIC_BACKING_FORMAT 0xE2792ACA #define QCOW2_EXT_MAGIC_BACKING_FORMAT 0xE2792ACA
static int qcow_probe(const uint8_t *buf, int buf_size, const char *filename) static int qcow2_probe(const uint8_t *buf, int buf_size, const char *filename)
{ {
const QCowHeader *cow_header = (const void *)buf; const QCowHeader *cow_header = (const void *)buf;
@ -73,14 +73,14 @@ static int qcow_probe(const uint8_t *buf, int buf_size, const char *filename)
* unknown magic is skipped (future extension this version knows nothing about) * unknown magic is skipped (future extension this version knows nothing about)
* return 0 upon success, non-0 otherwise * return 0 upon success, non-0 otherwise
*/ */
static int qcow_read_extensions(BlockDriverState *bs, uint64_t start_offset, static int qcow2_read_extensions(BlockDriverState *bs, uint64_t start_offset,
uint64_t end_offset) uint64_t end_offset)
{ {
QCowExtension ext; QCowExtension ext;
uint64_t offset; uint64_t offset;
#ifdef DEBUG_EXT #ifdef DEBUG_EXT
printf("qcow_read_extensions: start=%ld end=%ld\n", start_offset, end_offset); printf("qcow2_read_extensions: start=%ld end=%ld\n", start_offset, end_offset);
#endif #endif
offset = start_offset; offset = start_offset;
while (offset < end_offset) { while (offset < end_offset) {
@ -88,13 +88,13 @@ static int qcow_read_extensions(BlockDriverState *bs, uint64_t start_offset,
#ifdef DEBUG_EXT #ifdef DEBUG_EXT
/* Sanity check */ /* Sanity check */
if (offset > s->cluster_size) if (offset > s->cluster_size)
printf("qcow_handle_extension: suspicious offset %lu\n", offset); printf("qcow2_read_extension: suspicious offset %lu\n", offset);
printf("attemting to read extended header in offset %lu\n", offset); printf("attemting to read extended header in offset %lu\n", offset);
#endif #endif
if (bdrv_pread(bs->file, offset, &ext, sizeof(ext)) != sizeof(ext)) { if (bdrv_pread(bs->file, offset, &ext, sizeof(ext)) != sizeof(ext)) {
fprintf(stderr, "qcow_handle_extension: ERROR: " fprintf(stderr, "qcow2_read_extension: ERROR: "
"pread fail from offset %" PRIu64 "\n", "pread fail from offset %" PRIu64 "\n",
offset); offset);
return 1; return 1;
@ -106,10 +106,10 @@ static int qcow_read_extensions(BlockDriverState *bs, uint64_t start_offset,
printf("ext.magic = 0x%x\n", ext.magic); printf("ext.magic = 0x%x\n", ext.magic);
#endif #endif
switch (ext.magic) { switch (ext.magic) {
case QCOW_EXT_MAGIC_END: case QCOW2_EXT_MAGIC_END:
return 0; return 0;
case QCOW_EXT_MAGIC_BACKING_FORMAT: case QCOW2_EXT_MAGIC_BACKING_FORMAT:
if (ext.len >= sizeof(bs->backing_format)) { if (ext.len >= sizeof(bs->backing_format)) {
fprintf(stderr, "ERROR: ext_backing_format: len=%u too large" fprintf(stderr, "ERROR: ext_backing_format: len=%u too large"
" (>=%zu)\n", " (>=%zu)\n",
@ -137,7 +137,7 @@ static int qcow_read_extensions(BlockDriverState *bs, uint64_t start_offset,
} }
static int qcow_open(BlockDriverState *bs, int flags) static int qcow2_open(BlockDriverState *bs, int flags)
{ {
BDRVQcowState *s = bs->opaque; BDRVQcowState *s = bs->opaque;
int len, i; int len, i;
@ -222,7 +222,7 @@ static int qcow_open(BlockDriverState *bs, int flags)
ext_end = header.backing_file_offset; ext_end = header.backing_file_offset;
else else
ext_end = s->cluster_size; ext_end = s->cluster_size;
if (qcow_read_extensions(bs, sizeof(header), ext_end)) if (qcow2_read_extensions(bs, sizeof(header), ext_end))
goto fail; goto fail;
/* read the backing file name */ /* read the backing file name */
@ -252,7 +252,7 @@ static int qcow_open(BlockDriverState *bs, int flags)
return -1; return -1;
} }
static int qcow_set_key(BlockDriverState *bs, const char *key) static int qcow2_set_key(BlockDriverState *bs, const char *key)
{ {
BDRVQcowState *s = bs->opaque; BDRVQcowState *s = bs->opaque;
uint8_t keybuf[16]; uint8_t keybuf[16];
@ -294,8 +294,8 @@ static int qcow_set_key(BlockDriverState *bs, const char *key)
return 0; return 0;
} }
static int qcow_is_allocated(BlockDriverState *bs, int64_t sector_num, static int qcow2_is_allocated(BlockDriverState *bs, int64_t sector_num,
int nb_sectors, int *pnum) int nb_sectors, int *pnum)
{ {
uint64_t cluster_offset; uint64_t cluster_offset;
int ret; int ret;
@ -344,7 +344,7 @@ typedef struct QCowAIOCB {
QLIST_ENTRY(QCowAIOCB) next_depend; QLIST_ENTRY(QCowAIOCB) next_depend;
} QCowAIOCB; } QCowAIOCB;
static void qcow_aio_cancel(BlockDriverAIOCB *blockacb) static void qcow2_aio_cancel(BlockDriverAIOCB *blockacb)
{ {
QCowAIOCB *acb = container_of(blockacb, QCowAIOCB, common); QCowAIOCB *acb = container_of(blockacb, QCowAIOCB, common);
if (acb->hd_aiocb) if (acb->hd_aiocb)
@ -352,21 +352,21 @@ static void qcow_aio_cancel(BlockDriverAIOCB *blockacb)
qemu_aio_release(acb); qemu_aio_release(acb);
} }
static AIOPool qcow_aio_pool = { static AIOPool qcow2_aio_pool = {
.aiocb_size = sizeof(QCowAIOCB), .aiocb_size = sizeof(QCowAIOCB),
.cancel = qcow_aio_cancel, .cancel = qcow2_aio_cancel,
}; };
static void qcow_aio_read_cb(void *opaque, int ret); static void qcow2_aio_read_cb(void *opaque, int ret);
static void qcow_aio_read_bh(void *opaque) static void qcow2_aio_read_bh(void *opaque)
{ {
QCowAIOCB *acb = opaque; QCowAIOCB *acb = opaque;
qemu_bh_delete(acb->bh); qemu_bh_delete(acb->bh);
acb->bh = NULL; acb->bh = NULL;
qcow_aio_read_cb(opaque, 0); qcow2_aio_read_cb(opaque, 0);
} }
static int qcow_schedule_bh(QEMUBHFunc *cb, QCowAIOCB *acb) static int qcow2_schedule_bh(QEMUBHFunc *cb, QCowAIOCB *acb)
{ {
if (acb->bh) if (acb->bh)
return -EIO; return -EIO;
@ -380,7 +380,7 @@ static int qcow_schedule_bh(QEMUBHFunc *cb, QCowAIOCB *acb)
return 0; return 0;
} }
static void qcow_aio_read_cb(void *opaque, int ret) static void qcow2_aio_read_cb(void *opaque, int ret)
{ {
QCowAIOCB *acb = opaque; QCowAIOCB *acb = opaque;
BlockDriverState *bs = acb->common.bs; BlockDriverState *bs = acb->common.bs;
@ -447,18 +447,18 @@ static void qcow_aio_read_cb(void *opaque, int ret)
BLKDBG_EVENT(bs->file, BLKDBG_READ_BACKING_AIO); BLKDBG_EVENT(bs->file, BLKDBG_READ_BACKING_AIO);
acb->hd_aiocb = bdrv_aio_readv(bs->backing_hd, acb->sector_num, acb->hd_aiocb = bdrv_aio_readv(bs->backing_hd, acb->sector_num,
&acb->hd_qiov, acb->cur_nr_sectors, &acb->hd_qiov, acb->cur_nr_sectors,
qcow_aio_read_cb, acb); qcow2_aio_read_cb, acb);
if (acb->hd_aiocb == NULL) if (acb->hd_aiocb == NULL)
goto done; goto done;
} else { } else {
ret = qcow_schedule_bh(qcow_aio_read_bh, acb); ret = qcow2_schedule_bh(qcow2_aio_read_bh, acb);
if (ret < 0) if (ret < 0)
goto done; goto done;
} }
} else { } else {
/* Note: in this case, no need to wait */ /* Note: in this case, no need to wait */
qemu_iovec_memset(&acb->hd_qiov, 0, 512 * acb->cur_nr_sectors); qemu_iovec_memset(&acb->hd_qiov, 0, 512 * acb->cur_nr_sectors);
ret = qcow_schedule_bh(qcow_aio_read_bh, acb); ret = qcow2_schedule_bh(qcow2_aio_read_bh, acb);
if (ret < 0) if (ret < 0)
goto done; goto done;
} }
@ -471,7 +471,7 @@ static void qcow_aio_read_cb(void *opaque, int ret)
s->cluster_cache + index_in_cluster * 512, s->cluster_cache + index_in_cluster * 512,
512 * acb->cur_nr_sectors); 512 * acb->cur_nr_sectors);
ret = qcow_schedule_bh(qcow_aio_read_bh, acb); ret = qcow2_schedule_bh(qcow2_aio_read_bh, acb);
if (ret < 0) if (ret < 0)
goto done; goto done;
} else { } else {
@ -501,7 +501,7 @@ static void qcow_aio_read_cb(void *opaque, int ret)
acb->hd_aiocb = bdrv_aio_readv(bs->file, acb->hd_aiocb = bdrv_aio_readv(bs->file,
(acb->cluster_offset >> 9) + index_in_cluster, (acb->cluster_offset >> 9) + index_in_cluster,
&acb->hd_qiov, acb->cur_nr_sectors, &acb->hd_qiov, acb->cur_nr_sectors,
qcow_aio_read_cb, acb); qcow2_aio_read_cb, acb);
if (acb->hd_aiocb == NULL) { if (acb->hd_aiocb == NULL) {
ret = -EIO; ret = -EIO;
goto done; goto done;
@ -515,13 +515,14 @@ done:
qemu_aio_release(acb); qemu_aio_release(acb);
} }
static QCowAIOCB *qcow_aio_setup(BlockDriverState *bs, static QCowAIOCB *qcow2_aio_setup(BlockDriverState *bs, int64_t sector_num,
int64_t sector_num, QEMUIOVector *qiov, int nb_sectors, QEMUIOVector *qiov, int nb_sectors,
BlockDriverCompletionFunc *cb, void *opaque, int is_write) BlockDriverCompletionFunc *cb,
void *opaque, int is_write)
{ {
QCowAIOCB *acb; QCowAIOCB *acb;
acb = qemu_aio_get(&qcow_aio_pool, bs, cb, opaque); acb = qemu_aio_get(&qcow2_aio_pool, bs, cb, opaque);
if (!acb) if (!acb)
return NULL; return NULL;
acb->hd_aiocb = NULL; acb->hd_aiocb = NULL;
@ -539,21 +540,23 @@ static QCowAIOCB *qcow_aio_setup(BlockDriverState *bs,
return acb; return acb;
} }
static BlockDriverAIOCB *qcow_aio_readv(BlockDriverState *bs, static BlockDriverAIOCB *qcow2_aio_readv(BlockDriverState *bs,
int64_t sector_num, QEMUIOVector *qiov, int nb_sectors, int64_t sector_num,
BlockDriverCompletionFunc *cb, void *opaque) QEMUIOVector *qiov, int nb_sectors,
BlockDriverCompletionFunc *cb,
void *opaque)
{ {
QCowAIOCB *acb; QCowAIOCB *acb;
acb = qcow_aio_setup(bs, sector_num, qiov, nb_sectors, cb, opaque, 0); acb = qcow2_aio_setup(bs, sector_num, qiov, nb_sectors, cb, opaque, 0);
if (!acb) if (!acb)
return NULL; return NULL;
qcow_aio_read_cb(acb, 0); qcow2_aio_read_cb(acb, 0);
return &acb->common; return &acb->common;
} }
static void qcow_aio_write_cb(void *opaque, int ret); static void qcow2_aio_write_cb(void *opaque, int ret);
static void run_dependent_requests(QCowL2Meta *m) static void run_dependent_requests(QCowL2Meta *m)
{ {
@ -567,14 +570,14 @@ static void run_dependent_requests(QCowL2Meta *m)
/* Restart all dependent requests */ /* Restart all dependent requests */
QLIST_FOREACH_SAFE(req, &m->dependent_requests, next_depend, next) { QLIST_FOREACH_SAFE(req, &m->dependent_requests, next_depend, next) {
qcow_aio_write_cb(req, 0); qcow2_aio_write_cb(req, 0);
} }
/* Empty the list for the next part of the request */ /* Empty the list for the next part of the request */
QLIST_INIT(&m->dependent_requests); QLIST_INIT(&m->dependent_requests);
} }
static void qcow_aio_write_cb(void *opaque, int ret) static void qcow2_aio_write_cb(void *opaque, int ret)
{ {
QCowAIOCB *acb = opaque; QCowAIOCB *acb = opaque;
BlockDriverState *bs = acb->common.bs; BlockDriverState *bs = acb->common.bs;
@ -651,7 +654,7 @@ static void qcow_aio_write_cb(void *opaque, int ret)
acb->hd_aiocb = bdrv_aio_writev(bs->file, acb->hd_aiocb = bdrv_aio_writev(bs->file,
(acb->cluster_offset >> 9) + index_in_cluster, (acb->cluster_offset >> 9) + index_in_cluster,
&acb->hd_qiov, acb->cur_nr_sectors, &acb->hd_qiov, acb->cur_nr_sectors,
qcow_aio_write_cb, acb); qcow2_aio_write_cb, acb);
if (acb->hd_aiocb == NULL) { if (acb->hd_aiocb == NULL) {
ret = -EIO; ret = -EIO;
goto fail; goto fail;
@ -669,24 +672,26 @@ done:
qemu_aio_release(acb); qemu_aio_release(acb);
} }
static BlockDriverAIOCB *qcow_aio_writev(BlockDriverState *bs, static BlockDriverAIOCB *qcow2_aio_writev(BlockDriverState *bs,
int64_t sector_num, QEMUIOVector *qiov, int nb_sectors, int64_t sector_num,
BlockDriverCompletionFunc *cb, void *opaque) QEMUIOVector *qiov, int nb_sectors,
BlockDriverCompletionFunc *cb,
void *opaque)
{ {
BDRVQcowState *s = bs->opaque; BDRVQcowState *s = bs->opaque;
QCowAIOCB *acb; QCowAIOCB *acb;
s->cluster_cache_offset = -1; /* disable compressed cache */ s->cluster_cache_offset = -1; /* disable compressed cache */
acb = qcow_aio_setup(bs, sector_num, qiov, nb_sectors, cb, opaque, 1); acb = qcow2_aio_setup(bs, sector_num, qiov, nb_sectors, cb, opaque, 1);
if (!acb) if (!acb)
return NULL; return NULL;
qcow_aio_write_cb(acb, 0); qcow2_aio_write_cb(acb, 0);
return &acb->common; return &acb->common;
} }
static void qcow_close(BlockDriverState *bs) static void qcow2_close(BlockDriverState *bs)
{ {
BDRVQcowState *s = bs->opaque; BDRVQcowState *s = bs->opaque;
qemu_free(s->l1_table); qemu_free(s->l1_table);
@ -721,7 +726,7 @@ static int qcow2_update_ext_header(BlockDriverState *bs,
/* Prepare the backing file format extension if needed */ /* Prepare the backing file format extension if needed */
if (backing_fmt) { if (backing_fmt) {
ext_backing_fmt.len = cpu_to_be32(strlen(backing_fmt)); ext_backing_fmt.len = cpu_to_be32(strlen(backing_fmt));
ext_backing_fmt.magic = cpu_to_be32(QCOW_EXT_MAGIC_BACKING_FORMAT); ext_backing_fmt.magic = cpu_to_be32(QCOW2_EXT_MAGIC_BACKING_FORMAT);
backing_fmt_len = ((sizeof(ext_backing_fmt) backing_fmt_len = ((sizeof(ext_backing_fmt)
+ strlen(backing_fmt) + 7) & ~7); + strlen(backing_fmt) + 7) & ~7);
} }
@ -848,10 +853,10 @@ static int preallocate(BlockDriverState *bs)
return 0; return 0;
} }
static int qcow_create2(const char *filename, int64_t total_size, static int qcow2_create2(const char *filename, int64_t total_size,
const char *backing_file, const char *backing_format, const char *backing_file, const char *backing_format,
int flags, size_t cluster_size, int prealloc, int flags, size_t cluster_size, int prealloc,
QEMUOptionParameter *options) QEMUOptionParameter *options)
{ {
/* Calulate cluster_bits */ /* Calulate cluster_bits */
int cluster_bits; int cluster_bits;
@ -974,7 +979,7 @@ out:
return ret; return ret;
} }
static int qcow_create(const char *filename, QEMUOptionParameter *options) static int qcow2_create(const char *filename, QEMUOptionParameter *options)
{ {
const char *backing_file = NULL; const char *backing_file = NULL;
const char *backing_fmt = NULL; const char *backing_fmt = NULL;
@ -1017,11 +1022,11 @@ static int qcow_create(const char *filename, QEMUOptionParameter *options)
return -EINVAL; return -EINVAL;
} }
return qcow_create2(filename, sectors, backing_file, backing_fmt, flags, return qcow2_create2(filename, sectors, backing_file, backing_fmt, flags,
cluster_size, prealloc, options); cluster_size, prealloc, options);
} }
static int qcow_make_empty(BlockDriverState *bs) static int qcow2_make_empty(BlockDriverState *bs)
{ {
#if 0 #if 0
/* XXX: not correct */ /* XXX: not correct */
@ -1080,8 +1085,8 @@ static int qcow2_truncate(BlockDriverState *bs, int64_t offset)
/* XXX: put compressed sectors first, then all the cluster aligned /* XXX: put compressed sectors first, then all the cluster aligned
tables to avoid losing bytes in alignment */ tables to avoid losing bytes in alignment */
static int qcow_write_compressed(BlockDriverState *bs, int64_t sector_num, static int qcow2_write_compressed(BlockDriverState *bs, int64_t sector_num,
const uint8_t *buf, int nb_sectors) const uint8_t *buf, int nb_sectors)
{ {
BDRVQcowState *s = bs->opaque; BDRVQcowState *s = bs->opaque;
z_stream strm; z_stream strm;
@ -1148,32 +1153,33 @@ static int qcow_write_compressed(BlockDriverState *bs, int64_t sector_num,
return 0; return 0;
} }
static int qcow_flush(BlockDriverState *bs) static int qcow2_flush(BlockDriverState *bs)
{ {
return bdrv_flush(bs->file); return bdrv_flush(bs->file);
} }
static BlockDriverAIOCB *qcow_aio_flush(BlockDriverState *bs, static BlockDriverAIOCB *qcow2_aio_flush(BlockDriverState *bs,
BlockDriverCompletionFunc *cb, void *opaque) BlockDriverCompletionFunc *cb,
void *opaque)
{ {
return bdrv_aio_flush(bs->file, cb, opaque); return bdrv_aio_flush(bs->file, cb, opaque);
} }
static int64_t qcow_vm_state_offset(BDRVQcowState *s) static int64_t qcow2_vm_state_offset(BDRVQcowState *s)
{ {
return (int64_t)s->l1_vm_state_index << (s->cluster_bits + s->l2_bits); return (int64_t)s->l1_vm_state_index << (s->cluster_bits + s->l2_bits);
} }
static int qcow_get_info(BlockDriverState *bs, BlockDriverInfo *bdi) static int qcow2_get_info(BlockDriverState *bs, BlockDriverInfo *bdi)
{ {
BDRVQcowState *s = bs->opaque; BDRVQcowState *s = bs->opaque;
bdi->cluster_size = s->cluster_size; bdi->cluster_size = s->cluster_size;
bdi->vm_state_offset = qcow_vm_state_offset(s); bdi->vm_state_offset = qcow2_vm_state_offset(s);
return 0; return 0;
} }
static int qcow_check(BlockDriverState *bs, BdrvCheckResult *result) static int qcow2_check(BlockDriverState *bs, BdrvCheckResult *result)
{ {
return qcow2_check_refcounts(bs, result); return qcow2_check_refcounts(bs, result);
} }
@ -1199,8 +1205,8 @@ static void dump_refcounts(BlockDriverState *bs)
} }
#endif #endif
static int qcow_save_vmstate(BlockDriverState *bs, const uint8_t *buf, static int qcow2_save_vmstate(BlockDriverState *bs, const uint8_t *buf,
int64_t pos, int size) int64_t pos, int size)
{ {
BDRVQcowState *s = bs->opaque; BDRVQcowState *s = bs->opaque;
int growable = bs->growable; int growable = bs->growable;
@ -1208,14 +1214,14 @@ static int qcow_save_vmstate(BlockDriverState *bs, const uint8_t *buf,
BLKDBG_EVENT(bs->file, BLKDBG_VMSTATE_SAVE); BLKDBG_EVENT(bs->file, BLKDBG_VMSTATE_SAVE);
bs->growable = 1; bs->growable = 1;
ret = bdrv_pwrite(bs, qcow_vm_state_offset(s) + pos, buf, size); ret = bdrv_pwrite(bs, qcow2_vm_state_offset(s) + pos, buf, size);
bs->growable = growable; bs->growable = growable;
return ret; return ret;
} }
static int qcow_load_vmstate(BlockDriverState *bs, uint8_t *buf, static int qcow2_load_vmstate(BlockDriverState *bs, uint8_t *buf,
int64_t pos, int size) int64_t pos, int size)
{ {
BDRVQcowState *s = bs->opaque; BDRVQcowState *s = bs->opaque;
int growable = bs->growable; int growable = bs->growable;
@ -1223,13 +1229,13 @@ static int qcow_load_vmstate(BlockDriverState *bs, uint8_t *buf,
BLKDBG_EVENT(bs->file, BLKDBG_VMSTATE_LOAD); BLKDBG_EVENT(bs->file, BLKDBG_VMSTATE_LOAD);
bs->growable = 1; bs->growable = 1;
ret = bdrv_pread(bs, qcow_vm_state_offset(s) + pos, buf, size); ret = bdrv_pread(bs, qcow2_vm_state_offset(s) + pos, buf, size);
bs->growable = growable; bs->growable = growable;
return ret; return ret;
} }
static QEMUOptionParameter qcow_create_options[] = { static QEMUOptionParameter qcow2_create_options[] = {
{ {
.name = BLOCK_OPT_SIZE, .name = BLOCK_OPT_SIZE,
.type = OPT_SIZE, .type = OPT_SIZE,
@ -1264,38 +1270,38 @@ static QEMUOptionParameter qcow_create_options[] = {
}; };
static BlockDriver bdrv_qcow2 = { static BlockDriver bdrv_qcow2 = {
.format_name = "qcow2", .format_name = "qcow2",
.instance_size = sizeof(BDRVQcowState), .instance_size = sizeof(BDRVQcowState),
.bdrv_probe = qcow_probe, .bdrv_probe = qcow2_probe,
.bdrv_open = qcow_open, .bdrv_open = qcow2_open,
.bdrv_close = qcow_close, .bdrv_close = qcow2_close,
.bdrv_create = qcow_create, .bdrv_create = qcow2_create,
.bdrv_flush = qcow_flush, .bdrv_flush = qcow2_flush,
.bdrv_is_allocated = qcow_is_allocated, .bdrv_is_allocated = qcow2_is_allocated,
.bdrv_set_key = qcow_set_key, .bdrv_set_key = qcow2_set_key,
.bdrv_make_empty = qcow_make_empty, .bdrv_make_empty = qcow2_make_empty,
.bdrv_aio_readv = qcow_aio_readv, .bdrv_aio_readv = qcow2_aio_readv,
.bdrv_aio_writev = qcow_aio_writev, .bdrv_aio_writev = qcow2_aio_writev,
.bdrv_aio_flush = qcow_aio_flush, .bdrv_aio_flush = qcow2_aio_flush,
.bdrv_truncate = qcow2_truncate, .bdrv_truncate = qcow2_truncate,
.bdrv_write_compressed = qcow_write_compressed, .bdrv_write_compressed = qcow2_write_compressed,
.bdrv_snapshot_create = qcow2_snapshot_create, .bdrv_snapshot_create = qcow2_snapshot_create,
.bdrv_snapshot_goto = qcow2_snapshot_goto, .bdrv_snapshot_goto = qcow2_snapshot_goto,
.bdrv_snapshot_delete = qcow2_snapshot_delete, .bdrv_snapshot_delete = qcow2_snapshot_delete,
.bdrv_snapshot_list = qcow2_snapshot_list, .bdrv_snapshot_list = qcow2_snapshot_list,
.bdrv_snapshot_load_tmp = qcow2_snapshot_load_tmp, .bdrv_snapshot_load_tmp = qcow2_snapshot_load_tmp,
.bdrv_get_info = qcow_get_info, .bdrv_get_info = qcow2_get_info,
.bdrv_save_vmstate = qcow_save_vmstate, .bdrv_save_vmstate = qcow2_save_vmstate,
.bdrv_load_vmstate = qcow_load_vmstate, .bdrv_load_vmstate = qcow2_load_vmstate,
.bdrv_change_backing_file = qcow2_change_backing_file, .bdrv_change_backing_file = qcow2_change_backing_file,
.create_options = qcow_create_options, .create_options = qcow2_create_options,
.bdrv_check = qcow_check, .bdrv_check = qcow2_check,
}; };
static void bdrv_qcow2_init(void) static void bdrv_qcow2_init(void)