mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-02 23:33:54 -06:00
monitor usb: Inline monitor_read_bdrv_key_start()'s first part
monitor_read_bdrv_key_start() does several things: 1. If no key is needed, call completion_cb() and succeed 2. If we're in QMP context, call qerror_report_err() and fail 3. Start reading the key in the monitor. This is two things too many. Inline 1. and 2. into its callers monitor_read_block_device_key() and usb_msd_realize_storage(). Since monitor_read_block_device_key() only ever runs in HMP context, drop 2. there. The next commit will clean up the result in usb_msd_realize_storage(). Signed-off-by: Markus Armbruster <armbru@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
This commit is contained in:
parent
988e0f0662
commit
9b14e0efcc
2 changed files with 22 additions and 20 deletions
|
@ -641,8 +641,17 @@ static void usb_msd_realize_storage(USBDevice *dev, Error **errp)
|
|||
|
||||
if (bdrv_key_required(blk_bs(blk))) {
|
||||
if (cur_mon) {
|
||||
monitor_read_bdrv_key_start(cur_mon, blk_bs(blk),
|
||||
usb_msd_password_cb, s);
|
||||
bdrv_add_key(blk_bs(blk), NULL, &err);
|
||||
if (!err) {
|
||||
usb_msd_password_cb(s, 0);
|
||||
} else if (monitor_cur_is_qmp()) {
|
||||
qerror_report_err(err);
|
||||
error_free(err);
|
||||
} else {
|
||||
error_free(err);
|
||||
monitor_read_bdrv_key_start(cur_mon, blk_bs(blk),
|
||||
usb_msd_password_cb, s);
|
||||
}
|
||||
s->dev.auto_attach = 0;
|
||||
} else {
|
||||
autostart = 0;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue