[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 30/51] tcg/optimize: Return true from fold_qemu_st, fold_tcg_s
From: |
Richard Henderson |
Subject: |
[PATCH v2 30/51] tcg/optimize: Return true from fold_qemu_st, fold_tcg_st |
Date: |
Thu, 19 Dec 2024 20:10:42 -0800 |
Stores have no output operands, and so need no further work.
Reviewed-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
tcg/optimize.c | 11 +++++------
1 file changed, 5 insertions(+), 6 deletions(-)
diff --git a/tcg/optimize.c b/tcg/optimize.c
index b01929fccf..a5a57bb914 100644
--- a/tcg/optimize.c
+++ b/tcg/optimize.c
@@ -2160,7 +2160,7 @@ static bool fold_qemu_st(OptContext *ctx, TCGOp *op)
{
/* Opcodes that touch guest memory stop the mb optimization. */
ctx->prev_mb = NULL;
- return false;
+ return true;
}
static bool fold_remainder(OptContext *ctx, TCGOp *op)
@@ -2727,7 +2727,7 @@ static bool fold_tcg_st(OptContext *ctx, TCGOp *op)
if (op->args[1] != tcgv_ptr_arg(tcg_env)) {
remove_mem_copy_all(ctx);
- return false;
+ return true;
}
switch (op->opc) {
@@ -2751,7 +2751,7 @@ static bool fold_tcg_st(OptContext *ctx, TCGOp *op)
g_assert_not_reached();
}
remove_mem_copy_in(ctx, ofs, ofs + lm1);
- return false;
+ return true;
}
static bool fold_tcg_st_memcopy(OptContext *ctx, TCGOp *op)
@@ -2761,8 +2761,7 @@ static bool fold_tcg_st_memcopy(OptContext *ctx, TCGOp
*op)
TCGType type;
if (op->args[1] != tcgv_ptr_arg(tcg_env)) {
- fold_tcg_st(ctx, op);
- return false;
+ return fold_tcg_st(ctx, op);
}
src = arg_temp(op->args[0]);
@@ -2784,7 +2783,7 @@ static bool fold_tcg_st_memcopy(OptContext *ctx, TCGOp
*op)
last = ofs + tcg_type_size(type) - 1;
remove_mem_copy_in(ctx, ofs, last);
record_mem_copy(ctx, type, src, ofs, last);
- return false;
+ return true;
}
static bool fold_xor(OptContext *ctx, TCGOp *op)
--
2.43.0
- [PATCH v2 39/51] tcg/optimize: Use fold_masks_zs in fold_sextract, (continued)
- [PATCH v2 39/51] tcg/optimize: Use fold_masks_zs in fold_sextract, Richard Henderson, 2024/12/19
- [PATCH v2 21/51] tcg/optimize: Use fold_masks_zs in fold_movcond, Richard Henderson, 2024/12/19
- [PATCH v2 32/51] tcg/optimize: Distinguish simplification in fold_setcond_zmask, Richard Henderson, 2024/12/19
- [PATCH v2 19/51] tcg/optimize: Use fold_masks_zs in fold_exts, Richard Henderson, 2024/12/19
- [PATCH v2 24/51] tcg/optimize: Use fold_masks_z in fold_neg_no_const, Richard Henderson, 2024/12/19
- [PATCH v2 10/51] tcg/optimize: Use fold_masks_zs in fold_count_zeros, Richard Henderson, 2024/12/19
- [PATCH v2 18/51] tcg/optimize: Use finish_folding in fold_extract2, Richard Henderson, 2024/12/19
- [PATCH v2 27/51] tcg/optimize: Use fold_masks_zs in fold_or, Richard Henderson, 2024/12/19
- [PATCH v2 26/51] tcg/optimize: Use fold_masks_s in fold_not, Richard Henderson, 2024/12/19
- [PATCH v2 30/51] tcg/optimize: Return true from fold_qemu_st, fold_tcg_st,
Richard Henderson <=
- [PATCH v2 29/51] tcg/optimize: Use fold_masks_zs in fold_qemu_ld, Richard Henderson, 2024/12/19
- [PATCH v2 31/51] tcg/optimize: Use finish_folding in fold_remainder, Richard Henderson, 2024/12/19
- [PATCH v2 33/51] tcg/optimize: Use fold_masks_z in fold_setcond, Richard Henderson, 2024/12/19
- [PATCH v2 35/51] tcg/optimize: Fix sign mask in fold_negsetcond, Richard Henderson, 2024/12/19
- [PATCH v2 37/51] tcg/optimize: Use finish_folding in fold_cmp_vec, Richard Henderson, 2024/12/19
- [PATCH v2 38/51] tcg/optimize: Use finish_folding in fold_cmpsel_vec, Richard Henderson, 2024/12/19
- [PATCH v2 34/51] tcg/optimize: Use fold_masks_s in fold_negsetcond, Richard Henderson, 2024/12/19
- [PATCH v2 36/51] tcg/optimize: Use fold_masks_z in fold_setcond2, Richard Henderson, 2024/12/19