aboutsummaryrefslogtreecommitdiff
path: root/blockdev.c
diff options
context:
space:
mode:
authorMax Reitz <mreitz@redhat.com>2015-10-26 21:39:12 +0100
committerKevin Wolf <kwolf@redhat.com>2015-11-11 16:22:47 +0100
commit38f54bd1ee0ed0f13b7326eb79403e320c3a28d3 (patch)
tree5d55b4ee8638d21581bab0f2c4217f7aacd038ca /blockdev.c
parentd129988289a885e57aa8790097e2d814764571bd (diff)
downloadqemu-38f54bd1ee0ed0f13b7326eb79403e320c3a28d3.zip
qemu-38f54bd1ee0ed0f13b7326eb79403e320c3a28d3.tar.gz
qemu-38f54bd1ee0ed0f13b7326eb79403e320c3a28d3.tar.bz2
blockdev: Implement eject with basic operations
Implement 'eject' by calling blockdev-open-tray and blockdev-remove-medium. Signed-off-by: Max Reitz <mreitz@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
Diffstat (limited to 'blockdev.c')
-rw-r--r--blockdev.c11
1 files changed, 5 insertions, 6 deletions
diff --git a/blockdev.c b/blockdev.c
index 0f2a7e2..1624297 100644
--- a/blockdev.c
+++ b/blockdev.c
@@ -1980,16 +1980,15 @@ out:
void qmp_eject(const char *device, bool has_force, bool force, Error **errp)
{
- BlockBackend *blk;
+ Error *local_err = NULL;
- blk = blk_by_name(device);
- if (!blk) {
- error_set(errp, ERROR_CLASS_DEVICE_NOT_FOUND,
- "Device '%s' not found", device);
+ qmp_blockdev_open_tray(device, has_force, force, &local_err);
+ if (local_err) {
+ error_propagate(errp, local_err);
return;
}
- eject_device(blk, force, errp);
+ qmp_blockdev_remove_medium(device, errp);
}
void qmp_block_passwd(bool has_device, const char *device,