This allows the Spice block driver to eject the associated device. Signed-off-by: Marc-André Lureau <marcandre.lureau@xxxxxxxxxx> --- block.c | 46 +++++++++++++++++++++++++++++----------------- include/block/block_int.h | 1 + 2 files changed, 30 insertions(+), 17 deletions(-) diff --git a/block.c b/block.c index b88ad2f..f502eed 100644 --- a/block.c +++ b/block.c @@ -294,7 +294,8 @@ void bdrv_register(BlockDriver *bdrv) } /* create a new block device (by default it is empty) */ -BlockDriverState *bdrv_new(const char *device_name) +static BlockDriverState *bdrv_new_int(const char *device_name, + BlockDriverState *child) { BlockDriverState *bs; @@ -305,10 +306,16 @@ BlockDriverState *bdrv_new(const char *device_name) } bdrv_iostatus_disable(bs); notifier_list_init(&bs->close_notifiers); + bs->child = child; return bs; } +BlockDriverState *bdrv_new(const char *device_name) +{ + return bdrv_new_int(device_name, NULL); +} + void bdrv_add_close_notifier(BlockDriverState *bs, Notifier *notify) { notifier_list_add(&bs->close_notifiers, notify); @@ -769,16 +776,8 @@ free_and_fail: return ret; } -/* - * Opens a file using a protocol (file, host_device, nbd, ...) - * - * options is a QDict of options to pass to the block drivers, or NULL for an - * empty set of options. The reference to the QDict belongs to the block layer - * after the call (even on failure), so if the caller intends to reuse the - * dictionary, it needs to use QINCREF() before calling bdrv_file_open. - */ -int bdrv_file_open(BlockDriverState **pbs, const char *filename, - QDict *options, int flags) +static int bdrv_file_open_int(BlockDriverState **pbs, const char *filename, + QDict *options, int flags, BlockDriverState *child) { BlockDriverState *bs; BlockDriver *drv; @@ -790,7 +789,7 @@ int bdrv_file_open(BlockDriverState **pbs, const char *filename, options = qdict_new(); } - bs = bdrv_new(""); + bs = bdrv_new_int("", child); bs->options = options; options = qdict_clone_shallow(options); @@ -873,6 +872,20 @@ fail: } /* + * Opens a file using a protocol (file, host_device, nbd, ...) + * + * options is a QDict of options to pass to the block drivers, or NULL for an + * empty set of options. The reference to the QDict belongs to the block layer + * after the call (even on failure), so if the caller intends to reuse the + * dictionary, it needs to use QINCREF() before calling bdrv_file_open. + */ +int bdrv_file_open(BlockDriverState **pbs, const char *filename, + QDict *options, int flags) +{ + return bdrv_file_open_int(pbs, filename, options, flags, NULL); +} + +/* * Opens the backing file for a BlockDriverState if not yet open * * options is a QDict of options to pass to the block drivers, or NULL for an @@ -904,7 +917,7 @@ int bdrv_open_backing_file(BlockDriverState *bs, QDict *options) return 0; } - bs->backing_hd = bdrv_new(""); + bs->backing_hd = bdrv_new_int("", bs); bdrv_get_full_backing_filename(bs, backing_filename, sizeof(backing_filename)); @@ -990,7 +1003,7 @@ int bdrv_open(BlockDriverState *bs, const char *filename, QDict *options, instead of opening 'filename' directly */ /* if there is a backing file, use it */ - bs1 = bdrv_new(""); + bs1 = bdrv_new_int("", bs); ret = bdrv_open(bs1, filename, NULL, 0, drv); if (ret < 0) { bdrv_delete(bs1); @@ -1043,9 +1056,8 @@ int bdrv_open(BlockDriverState *bs, const char *filename, QDict *options, } extract_subqdict(options, &file_options, "file."); - - ret = bdrv_file_open(&file, filename, file_options, - bdrv_open_flags(bs, flags)); + ret = bdrv_file_open_int(&file, filename, file_options, + bdrv_open_flags(bs, flags), bs); if (ret < 0) { goto fail; } diff --git a/include/block/block_int.h b/include/block/block_int.h index ba52247..9c72b32 100644 --- a/include/block/block_int.h +++ b/include/block/block_int.h @@ -245,6 +245,7 @@ struct BlockDriverState { BlockDriverState *backing_hd; BlockDriverState *file; + BlockDriverState *child; NotifierList close_notifiers; -- 1.8.3.rc1.49.g8d97506 _______________________________________________ Spice-devel mailing list Spice-devel@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/spice-devel