summary refs log tree commit diff stats
path: root/monitor.c
diff options
context:
space:
mode:
authorKevin Wolf <kwolf@redhat.com>2015-02-06 18:00:14 +0100
committerKevin Wolf <kwolf@redhat.com>2015-02-06 18:00:14 +0100
commit8333c0dff14a8a16c8ad3a95c6ea09f9d6f395b3 (patch)
tree76aa97eea763dd725edada2b3d210f27b8f7af5a /monitor.c
parent8c44dfbc62a50a8bc4113f199b8662861f757591 (diff)
parentb1ca639184d93984551b423d8e538ad4add5eb15 (diff)
downloadfocaccia-qemu-8333c0dff14a8a16c8ad3a95c6ea09f9d6f395b3.tar.gz
focaccia-qemu-8333c0dff14a8a16c8ad3a95c6ea09f9d6f395b3.zip
Merge remote-tracking branch 'mreitz/block' into queue-block
* mreitz/block:
  block: Eliminate silly QERR_ macros used for encryption keys
  block: New bdrv_add_key(), convert monitor to use it
  blockdev: Eliminate silly QERR_BLOCK_JOB_NOT_ACTIVE macro
  blockdev: Give find_block_job() an Error ** parameter
Diffstat (limited to 'monitor.c')
-rw-r--r--monitor.c16
1 files changed, 11 insertions, 5 deletions
diff --git a/monitor.c b/monitor.c
index 5a24311844..c3cc060b45 100644
--- a/monitor.c
+++ b/monitor.c
@@ -5368,9 +5368,12 @@ static void bdrv_password_cb(void *opaque, const char *password,
     Monitor *mon = opaque;
     BlockDriverState *bs = readline_opaque;
     int ret = 0;
+    Error *local_err = NULL;
 
-    if (bdrv_set_key(bs, password) != 0) {
-        monitor_printf(mon, "invalid password\n");
+    bdrv_add_key(bs, password, &local_err);
+    if (local_err) {
+        monitor_printf(mon, "%s\n", error_get_pretty(local_err));
+        error_free(local_err);
         ret = -EPERM;
     }
     if (mon->password_completion_cb)
@@ -5388,17 +5391,20 @@ int monitor_read_bdrv_key_start(Monitor *mon, BlockDriverState *bs,
                                 BlockCompletionFunc *completion_cb,
                                 void *opaque)
 {
+    Error *local_err = NULL;
     int err;
 
-    if (!bdrv_key_required(bs)) {
+    bdrv_add_key(bs, NULL, &local_err);
+    if (!local_err) {
         if (completion_cb)
             completion_cb(opaque, 0);
         return 0;
     }
 
+    /* Need a key for @bs */
+
     if (monitor_ctrl_mode(mon)) {
-        qerror_report(QERR_DEVICE_ENCRYPTED, bdrv_get_device_name(bs),
-                      bdrv_get_encrypted_filename(bs));
+        qerror_report_err(local_err);
         return -1;
     }