diff options
| author | Kevin Wolf <kwolf@redhat.com> | 2015-02-06 18:00:14 +0100 |
|---|---|---|
| committer | Kevin Wolf <kwolf@redhat.com> | 2015-02-06 18:00:14 +0100 |
| commit | 8333c0dff14a8a16c8ad3a95c6ea09f9d6f395b3 (patch) | |
| tree | 76aa97eea763dd725edada2b3d210f27b8f7af5a /monitor.c | |
| parent | 8c44dfbc62a50a8bc4113f199b8662861f757591 (diff) | |
| parent | b1ca639184d93984551b423d8e538ad4add5eb15 (diff) | |
| download | focaccia-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.c | 16 |
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; } |