virtio-scsi: bugfix: fix qemu crash for hotplug scsi disk with dataplane
The vm will trigger a disk sweep operation after plugging a controller who's io type is iothread. If attach a scsi disk immediately, the sg_inqury request in vm will trigger the assert in virtio_scsi_ctx_check(), which is called by virtio_scsi_handle_cmd_req_prepare(). Add judgment in virtio_scsi_handle_cmd_req_prepare() and return IO Error directly if the device has not been initialized. Signed-off-by: Jinhua Cao <caojinhua1@huawei.com>
This commit is contained in:
parent
49f96694c5
commit
a55dd0838d
37
virtio-scsi-bugfix-fix-qemu-crash-for-hotplug-scsi-d.patch
Normal file
37
virtio-scsi-bugfix-fix-qemu-crash-for-hotplug-scsi-d.patch
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
From 98cbb6d13484e79b6f9da064a40a281f2983be1d Mon Sep 17 00:00:00 2001
|
||||||
|
From: Jinhua Cao <caojinhua1@huawei.com>
|
||||||
|
Date: Wed, 9 Feb 2022 19:58:21 +0800
|
||||||
|
Subject: [PATCH] virtio-scsi: bugfix: fix qemu crash for hotplug scsi disk
|
||||||
|
with dataplane
|
||||||
|
|
||||||
|
The vm will trigger a disk sweep operation after plugging
|
||||||
|
a controller who's io type is iothread. If attach a scsi
|
||||||
|
disk immediately, the sg_inqury request in vm will trigger
|
||||||
|
the assert in virtio_scsi_ctx_check(), which is called by
|
||||||
|
virtio_scsi_handle_cmd_req_prepare().
|
||||||
|
|
||||||
|
Add judgment in virtio_scsi_handle_cmd_req_prepare() and
|
||||||
|
return IO Error directly if the device has not been
|
||||||
|
initialized.
|
||||||
|
|
||||||
|
Signed-off-by: Jinhua Cao <caojinhua1@huawei.com>
|
||||||
|
---
|
||||||
|
hw/scsi/virtio-scsi.c | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/hw/scsi/virtio-scsi.c b/hw/scsi/virtio-scsi.c
|
||||||
|
index 51fd09522a..781a37fe89 100644
|
||||||
|
--- a/hw/scsi/virtio-scsi.c
|
||||||
|
+++ b/hw/scsi/virtio-scsi.c
|
||||||
|
@@ -638,7 +638,7 @@ static int virtio_scsi_handle_cmd_req_prepare(VirtIOSCSI *s, VirtIOSCSIReq *req)
|
||||||
|
req->req.cmd.tag, req->req.cmd.cdb[0]);
|
||||||
|
|
||||||
|
d = virtio_scsi_device_get(s, req->req.cmd.lun);
|
||||||
|
- if (!d) {
|
||||||
|
+ if (!d || !d->qdev.realized) {
|
||||||
|
req->resp.cmd.response = VIRTIO_SCSI_S_BAD_TARGET;
|
||||||
|
virtio_scsi_complete_cmd_req(req);
|
||||||
|
return -ENOENT;
|
||||||
|
--
|
||||||
|
2.27.0
|
||||||
|
|
||||||
Loading…
x
Reference in New Issue
Block a user