53b56ca781
Changes to other patches are all just metadata/context changes except for pvebackup_co_prepare() needing to call bdrv_co_unref() rather than bdrv_unref(), because it is a coroutine itself. This is documented in d6ee2e324e ("block-coroutine-wrapper: Introduce no_co_wrapper"). The change is necessary, because one of the stable fixes converts bdrv_unref and blk_unref into no_co_wrappers (in preparation for a second patch to fix a hang with the block resize QMP command). Signed-off-by: Fiona Ebner <f.ebner@proxmox.com>
42 lines
1.5 KiB
Diff
42 lines
1.5 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Richard Henderson <richard.henderson@linaro.org>
|
|
Date: Thu, 4 May 2023 11:42:32 +0100
|
|
Subject: [PATCH] target/arm: Fix vd == vm overlap in sve_ldff1_z
|
|
|
|
If vd == vm, copy vm to scratch, so that we can pre-zero
|
|
the output and still access the gather indicies.
|
|
|
|
Cc: qemu-stable@nongnu.org
|
|
Resolves: https://gitlab.com/qemu-project/qemu/-/issues/1612
|
|
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
|
|
(picked up from https://lists.nongnu.org/archive/html/qemu-devel/2023-05/msg00961.html)
|
|
Signed-off-by: Fiona Ebner <f.ebner@proxmox.com>
|
|
---
|
|
target/arm/tcg/sve_helper.c | 6 ++++++
|
|
1 file changed, 6 insertions(+)
|
|
|
|
diff --git a/target/arm/tcg/sve_helper.c b/target/arm/tcg/sve_helper.c
|
|
index ccf5e5beca..0097522470 100644
|
|
--- a/target/arm/tcg/sve_helper.c
|
|
+++ b/target/arm/tcg/sve_helper.c
|
|
@@ -6727,6 +6727,7 @@ void sve_ldff1_z(CPUARMState *env, void *vd, uint64_t *vg, void *vm,
|
|
intptr_t reg_off;
|
|
SVEHostPage info;
|
|
target_ulong addr, in_page;
|
|
+ ARMVectorReg scratch;
|
|
|
|
/* Skip to the first true predicate. */
|
|
reg_off = find_next_active(vg, 0, reg_max, esz);
|
|
@@ -6736,6 +6737,11 @@ void sve_ldff1_z(CPUARMState *env, void *vd, uint64_t *vg, void *vm,
|
|
return;
|
|
}
|
|
|
|
+ /* Protect against overlap between vd and vm. */
|
|
+ if (unlikely(vd == vm)) {
|
|
+ vm = memcpy(&scratch, vm, reg_max);
|
|
+ }
|
|
+
|
|
/*
|
|
* Probe the first element, allowing faults.
|
|
*/
|