]> git.proxmox.com Git - mirror_qemu.git/commitdiff
tcg/arm: Fix SIGILL in tcg_out_qemu_st_direct
authorJoseph Burt <caseorum@gmail.com>
Sun, 21 Jan 2024 21:14:39 +0000 (21:14 +0000)
committerRichard Henderson <richard.henderson@linaro.org>
Tue, 23 Jan 2024 03:32:10 +0000 (13:32 +1000)
When tcg_out_qemu_st_{index,direct} were merged, the direct case for
MO_64 was omitted, causing qemu_st_i64 to be encoded as 0xffffffff due
to underflow when adding h.base and h.index.

Fixes: 1df6d611bdc2 ("tcg/arm: Introduce HostAddress")
Signed-off-by: Joseph Burt <caseorum@gmail.com>
Message-Id: <20240121211439.100829-1-caseorum@gmail.com>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
tcg/arm/tcg-target.c.inc

index fc785664946155982ed7a3421d5009fa3a3bff57..a9aa8aa91c9a63bfd57909cbfd2a161d3ec5cedd 100644 (file)
@@ -1662,6 +1662,9 @@ static void tcg_out_qemu_st_direct(TCGContext *s, MemOp opc, TCGReg datalo,
             } else {
                 tcg_out_strd_r(s, h.cond, datalo, h.base, h.index);
             }
+        } else if (h.index < 0) {
+            tcg_out_st32_12(s, h.cond, datalo, h.base, 0);
+            tcg_out_st32_12(s, h.cond, datahi, h.base, 4);
         } else if (h.index_scratch) {
             tcg_out_st32_rwb(s, h.cond, datalo, h.index, h.base);
             tcg_out_st32_12(s, h.cond, datahi, h.index, 4);