projects
/
tools
/
qemu-arm-static.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
| inline |
side by side
(parent:
4652e04
)
esp: ensure cmdfifo is not empty and current_dev is non-NULL
author
Mark Cave-Ayland
<mark.cave-ayland@ilande.co.uk>
Wed, 7 Apr 2021 19:57:55 +0000
(20:57 +0100)
committer
wanchao-xu
<wanchao.xu@samsung.com>
Tue, 9 Jan 2024 11:55:06 +0000
(19:55 +0800)
Git-commit:
99545751734035b76bd372c4e7215bb337428d89
References: bsc#
1180433
, CVE-2020-35504
bsc#
1180434
, CVE-2020-35505
bsc#
1180435
, CVE-2020-35506
When about to execute a SCSI command, ensure that cmdfifo is not empty and
current_dev is non-NULL. This can happen if the guest tries to execute a TI
(Transfer Information) command without issuing one of the select commands
first.
Buglink:
https://bugs.launchpad.net/qemu/+bug/1910723
Buglink:
https://bugs.launchpad.net/qemu/+bug/1909247
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Tested-by: Alexander Bulekov <alxndr@bu.edu>
Message-Id: <
20210407195801
.685-7-mark.cave-ayland@ilande.co.uk>
Signed-off-by: Jose R Ziviani <jose.ziviani@suse.com>
hw/scsi/esp.c
patch
|
blob
|
history
diff --git
a/hw/scsi/esp.c
b/hw/scsi/esp.c
index b5e6a50f5cb731a9815b655c9ae01d0f4438bbf4..0f88689eb8b0dfbec5654870f10ba8403fe7ab8d 100644
(file)
--- a/
hw/scsi/esp.c
+++ b/
hw/scsi/esp.c
@@
-193,6
+193,11
@@
static void do_busid_cmd(ESPState *s, uint8_t *buf, uint8_t busid)
trace_esp_do_busid_cmd(busid);
lun = busid & 7;
+
+ if (!s->current_dev) {
+ return;
+ }
+
current_lun = scsi_device_find(&s->bus, 0, s->current_dev->id, lun);
s->current_req = scsi_req_new(current_lun, 0, lun, buf, s);
datalen = scsi_req_enqueue(s->current_req);