mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-30 21:42:06 -06:00
vpc: Implement .bdrv_has_zero_init
Depending on the subformat, has_zero_init on VHD must behave like raw and query the underlying storage (fixed) or like other sparse formats that can always return 1 (dynamic, differencing). Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
parent
8ed610a1c9
commit
72c6cc94da
1 changed files with 19 additions and 6 deletions
25
block/vpc.c
25
block/vpc.c
|
@ -786,6 +786,18 @@ static int vpc_create(const char *filename, QEMUOptionParameter *options)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int vpc_has_zero_init(BlockDriverState *bs)
|
||||||
|
{
|
||||||
|
BDRVVPCState *s = bs->opaque;
|
||||||
|
struct vhd_footer *footer = (struct vhd_footer *) s->footer_buf;
|
||||||
|
|
||||||
|
if (cpu_to_be32(footer->type) == VHD_FIXED) {
|
||||||
|
return bdrv_has_zero_init(bs->file);
|
||||||
|
} else {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void vpc_close(BlockDriverState *bs)
|
static void vpc_close(BlockDriverState *bs)
|
||||||
{
|
{
|
||||||
BDRVVPCState *s = bs->opaque;
|
BDRVVPCState *s = bs->opaque;
|
||||||
|
@ -818,16 +830,17 @@ static BlockDriver bdrv_vpc = {
|
||||||
.format_name = "vpc",
|
.format_name = "vpc",
|
||||||
.instance_size = sizeof(BDRVVPCState),
|
.instance_size = sizeof(BDRVVPCState),
|
||||||
|
|
||||||
.bdrv_probe = vpc_probe,
|
.bdrv_probe = vpc_probe,
|
||||||
.bdrv_open = vpc_open,
|
.bdrv_open = vpc_open,
|
||||||
.bdrv_close = vpc_close,
|
.bdrv_close = vpc_close,
|
||||||
.bdrv_reopen_prepare = vpc_reopen_prepare,
|
.bdrv_reopen_prepare = vpc_reopen_prepare,
|
||||||
.bdrv_create = vpc_create,
|
.bdrv_create = vpc_create,
|
||||||
|
|
||||||
.bdrv_read = vpc_co_read,
|
.bdrv_read = vpc_co_read,
|
||||||
.bdrv_write = vpc_co_write,
|
.bdrv_write = vpc_co_write,
|
||||||
|
|
||||||
.create_options = vpc_create_options,
|
.create_options = vpc_create_options,
|
||||||
|
.bdrv_has_zero_init = vpc_has_zero_init,
|
||||||
};
|
};
|
||||||
|
|
||||||
static void bdrv_vpc_init(void)
|
static void bdrv_vpc_init(void)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue