mirror of
https://git.yoctoproject.org/poky
synced 2026-04-20 00:32:13 +02:00
qemu: fix CVE-2021-3392
(From OE-Core rev: fe872d2edc160f48e57d3bdc82e5fc72f6dcbb72) Signed-off-by: Lee Chee Yang <chee.yang.lee@intel.com> Signed-off-by: Steve Sakoman <steve@sakoman.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
committed by
Richard Purdie
parent
766ba72f56
commit
60e33c1c4a
@@ -54,6 +54,7 @@ SRC_URI = "https://download.qemu.org/${BPN}-${PV}.tar.xz \
|
||||
file://CVE-2020-24352.patch \
|
||||
file://CVE-2020-25723.patch \
|
||||
file://CVE-2021-20203.patch \
|
||||
file://CVE-2021-3392.patch \
|
||||
"
|
||||
UPSTREAM_CHECK_REGEX = "qemu-(?P<pver>\d+(\.\d+)+)\.tar"
|
||||
|
||||
|
||||
92
meta/recipes-devtools/qemu/qemu/CVE-2021-3392.patch
Normal file
92
meta/recipes-devtools/qemu/qemu/CVE-2021-3392.patch
Normal file
@@ -0,0 +1,92 @@
|
||||
From 3791642c8d60029adf9b00bcb4e34d7d8a1aea4d Mon Sep 17 00:00:00 2001
|
||||
From: Michael Tokarev <mjt@tls.msk.ru>
|
||||
Date: Mon, 19 Apr 2021 15:42:47 +0200
|
||||
Subject: [PATCH] mptsas: Remove unused MPTSASState 'pending' field
|
||||
(CVE-2021-3392)
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=utf8
|
||||
Content-Transfer-Encoding: 8bit
|
||||
|
||||
While processing SCSI i/o requests in mptsas_process_scsi_io_request(),
|
||||
the Megaraid emulator appends new MPTSASRequest object 'req' to
|
||||
the 's->pending' queue. In case of an error, this same object gets
|
||||
dequeued in mptsas_free_request() only if SCSIRequest object
|
||||
'req->sreq' is initialised. This may lead to a use-after-free issue.
|
||||
|
||||
Since s->pending is actually not used, simply remove it from
|
||||
MPTSASState.
|
||||
|
||||
Cc: qemu-stable@nongnu.org
|
||||
Signed-off-by: Michael Tokarev <mjt@tls.msk.ru>
|
||||
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
|
||||
Signed-off-by: Philippe Mathieu-Daudé <philmd@redhat.com>
|
||||
Reported-by: Cheolwoo Myung <cwmyung@snu.ac.kr>
|
||||
Message-id: 20210419134247.1467982-1-f4bug@amsat.org
|
||||
Message-Id: <20210416102243.1293871-1-mjt@msgid.tls.msk.ru>
|
||||
Suggested-by: Paolo Bonzini <pbonzini@redhat.com>
|
||||
Reported-by: Cheolwoo Myung <cwmyung@snu.ac.kr>
|
||||
BugLink: https://bugs.launchpad.net/qemu/+bug/1914236 (CVE-2021-3392)
|
||||
Fixes: e351b826112 ("hw: Add support for LSI SAS1068 (mptsas) device")
|
||||
[PMD: Reworded description, added more tags]
|
||||
Signed-off-by: Philippe Mathieu-Daudé <philmd@redhat.com>
|
||||
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
|
||||
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
|
||||
|
||||
Upstream-Status: Backport [ https://git.qemu.org/?p=qemu.git;a=commit;h=3791642c8d60029adf9b00bcb4e34d7d8a1aea4d ]
|
||||
CVE: CVE-2021-3392
|
||||
Signed-off-by: Chee Yang Lee <chee.yang.lee@intel.com>
|
||||
---
|
||||
hw/scsi/mptsas.c | 6 ------
|
||||
hw/scsi/mptsas.h | 1 -
|
||||
2 files changed, 7 deletions(-)
|
||||
|
||||
diff --git a/hw/scsi/mptsas.c b/hw/scsi/mptsas.c
|
||||
index 7416e78..db3219e 100644
|
||||
--- a/hw/scsi/mptsas.c
|
||||
+++ b/hw/scsi/mptsas.c
|
||||
@@ -251,13 +251,10 @@ static int mptsas_build_sgl(MPTSASState *s, MPTSASRequest *req, hwaddr addr)
|
||||
|
||||
static void mptsas_free_request(MPTSASRequest *req)
|
||||
{
|
||||
- MPTSASState *s = req->dev;
|
||||
-
|
||||
if (req->sreq != NULL) {
|
||||
req->sreq->hba_private = NULL;
|
||||
scsi_req_unref(req->sreq);
|
||||
req->sreq = NULL;
|
||||
- QTAILQ_REMOVE(&s->pending, req, next);
|
||||
}
|
||||
qemu_sglist_destroy(&req->qsg);
|
||||
g_free(req);
|
||||
@@ -303,7 +300,6 @@ static int mptsas_process_scsi_io_request(MPTSASState *s,
|
||||
}
|
||||
|
||||
req = g_new0(MPTSASRequest, 1);
|
||||
- QTAILQ_INSERT_TAIL(&s->pending, req, next);
|
||||
req->scsi_io = *scsi_io;
|
||||
req->dev = s;
|
||||
|
||||
@@ -1319,8 +1315,6 @@ static void mptsas_scsi_realize(PCIDevice *dev, Error **errp)
|
||||
|
||||
s->request_bh = qemu_bh_new(mptsas_fetch_requests, s);
|
||||
|
||||
- QTAILQ_INIT(&s->pending);
|
||||
-
|
||||
scsi_bus_new(&s->bus, sizeof(s->bus), &dev->qdev, &mptsas_scsi_info, NULL);
|
||||
}
|
||||
|
||||
diff --git a/hw/scsi/mptsas.h b/hw/scsi/mptsas.h
|
||||
index b85ac1a..c046497 100644
|
||||
--- a/hw/scsi/mptsas.h
|
||||
+++ b/hw/scsi/mptsas.h
|
||||
@@ -79,7 +79,6 @@ struct MPTSASState {
|
||||
uint16_t reply_frame_size;
|
||||
|
||||
SCSIBus bus;
|
||||
- QTAILQ_HEAD(, MPTSASRequest) pending;
|
||||
};
|
||||
|
||||
void mptsas_fix_scsi_io_endianness(MPIMsgSCSIIORequest *req);
|
||||
--
|
||||
1.8.3.1
|
||||
|
||||
Reference in New Issue
Block a user