[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH 34/35] tcg/optimize: Canonicalize sub2 with constants to add2
|
From: |
Richard Henderson |
|
Subject: |
[PATCH 34/35] tcg/optimize: Canonicalize sub2 with constants to add2 |
|
Date: |
Mon, 6 Nov 2023 18:48:41 -0800 |
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Message-Id: <20231026013945.1152174-4-richard.henderson@linaro.org>
---
tcg/optimize.c | 21 +++++++++++++++++++--
1 file changed, 19 insertions(+), 2 deletions(-)
diff --git a/tcg/optimize.c b/tcg/optimize.c
index 468f827399..f2d01654c5 100644
--- a/tcg/optimize.c
+++ b/tcg/optimize.c
@@ -1044,8 +1044,10 @@ static bool fold_add_vec(OptContext *ctx, TCGOp *op)
static bool fold_addsub2(OptContext *ctx, TCGOp *op, bool add)
{
- if (arg_is_const(op->args[2]) && arg_is_const(op->args[3]) &&
- arg_is_const(op->args[4]) && arg_is_const(op->args[5])) {
+ bool a_const = arg_is_const(op->args[2]) && arg_is_const(op->args[3]);
+ bool b_const = arg_is_const(op->args[4]) && arg_is_const(op->args[5]);
+
+ if (a_const && b_const) {
uint64_t al = arg_info(op->args[2])->val;
uint64_t ah = arg_info(op->args[3])->val;
uint64_t bl = arg_info(op->args[4])->val;
@@ -1089,6 +1091,21 @@ static bool fold_addsub2(OptContext *ctx, TCGOp *op,
bool add)
tcg_opt_gen_movi(ctx, op2, rh, ah);
return true;
}
+
+ /* Fold sub2 r,x,i to add2 r,x,-i */
+ if (!add && b_const) {
+ uint64_t bl = arg_info(op->args[4])->val;
+ uint64_t bh = arg_info(op->args[5])->val;
+
+ /* Negate the two parts without assembling and disassembling. */
+ bl = -bl;
+ bh = ~bh + !bl;
+
+ op->opc = (ctx->type == TCG_TYPE_I32
+ ? INDEX_op_add2_i32 : INDEX_op_add2_i64);
+ op->args[4] = arg_new_constant(ctx, bl);
+ op->args[5] = arg_new_constant(ctx, bh);
+ }
return false;
}
--
2.34.1
- [PATCH 24/35] tcg/loongarch64: Implement neg opcodes, (continued)
- [PATCH 24/35] tcg/loongarch64: Implement neg opcodes, Richard Henderson, 2023/11/06
- [PATCH 26/35] tcg: Don't free vector results, Richard Henderson, 2023/11/06
- [PATCH 27/35] tcg/optimize: Pipe OptContext into reset_ts, Richard Henderson, 2023/11/06
- [PATCH 29/35] tcg/optimize: Optimize env memory operations, Richard Henderson, 2023/11/06
- [PATCH 30/35] tcg: Eliminate duplicate env store operations, Richard Henderson, 2023/11/06
- [PATCH 25/35] tcg: Remove TCG_TARGET_HAS_neg_{i32,i64}, Richard Henderson, 2023/11/06
- [PATCH 28/35] tcg/optimize: Split out cmp_better_copy, Richard Henderson, 2023/11/06
- [PATCH 31/35] tcg/optimize: Split out arg_new_constant, Richard Henderson, 2023/11/06
- [PATCH 32/35] tcg: Canonicalize subi to addi during opcode generation, Richard Henderson, 2023/11/06
- [PATCH 33/35] tcg/optimize: Canonicalize subi to addi during optimization, Richard Henderson, 2023/11/06
- [PATCH 34/35] tcg/optimize: Canonicalize sub2 with constants to add2,
Richard Henderson <=
- [PATCH 35/35] tcg/sparc64: Implement tcg_out_extrl_i64_i32, Richard Henderson, 2023/11/06
- [PULL 00/35] tcg patch queue, Richard Henderson, 2023/11/06
- Re: [PATCH 00/35] tcg patch queue, Stefan Hajnoczi, 2023/11/07