aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Henderson <richard.henderson@linaro.org>2022-02-25 15:44:55 -1000
committerRichard Henderson <richard.henderson@linaro.org>2022-02-28 08:04:10 -1000
commit2ccf40f00e3f29d85d4ff48a9a98870059002290 (patch)
tree32d9d708900e730ef0ba46358ef94b171c02b105
parent5b7b197c87cefbd24bd1936614fd4e00ccc279ab (diff)
downloadqemu-2ccf40f00e3f29d85d4ff48a9a98870059002290.zip
qemu-2ccf40f00e3f29d85d4ff48a9a98870059002290.tar.gz
qemu-2ccf40f00e3f29d85d4ff48a9a98870059002290.tar.bz2
tcg/tci: Use tcg_out_ldst in tcg_out_st
The tcg_out_ldst helper will handle out-of-range offsets. We haven't actually encountered any, since we haven't run across the assert within tcg_out_op_rrs, but an out-of-range offset would not be impossible in future. Fixes: 65089889183 ("tcg/tci: Change encoding to uint32_t units") Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
-rw-r--r--tcg/tci/tcg-target.c.inc5
1 files changed, 2 insertions, 3 deletions
diff --git a/tcg/tci/tcg-target.c.inc b/tcg/tci/tcg-target.c.inc
index 0cb16aa..9ff1fa0 100644
--- a/tcg/tci/tcg-target.c.inc
+++ b/tcg/tci/tcg-target.c.inc
@@ -790,14 +790,13 @@ static void tcg_out_op(TCGContext *s, TCGOpcode opc,
static void tcg_out_st(TCGContext *s, TCGType type, TCGReg val, TCGReg base,
intptr_t offset)
{
- stack_bounds_check(base, offset);
switch (type) {
case TCG_TYPE_I32:
- tcg_out_op_rrs(s, INDEX_op_st_i32, val, base, offset);
+ tcg_out_ldst(s, INDEX_op_st_i32, val, base, offset);
break;
#if TCG_TARGET_REG_BITS == 64
case TCG_TYPE_I64:
- tcg_out_op_rrs(s, INDEX_op_st_i64, val, base, offset);
+ tcg_out_ldst(s, INDEX_op_st_i64, val, base, offset);
break;
#endif
default: