|
|
5544c1 |
From 16f29b266435c7eaffc5081c6bba4651d56a8ce8 Mon Sep 17 00:00:00 2001
|
|
|
5544c1 |
From: Aurelien Jarno <aurelien@aurel32.net>
|
|
|
5544c1 |
Date: Thu, 6 Sep 2012 16:47:13 +0200
|
|
|
5544c1 |
Subject: [PATCH] tcg/optimize: split expression simplification
|
|
|
5544c1 |
|
|
|
5544c1 |
Split expression simplification in multiple parts so that a given op
|
|
|
5544c1 |
can appear multiple times. This patch should not change anything.
|
|
|
5544c1 |
|
|
|
5544c1 |
Reviewed-by: Richard Henderson <rth@twiddle.net>
|
|
|
5544c1 |
Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>
|
|
|
5544c1 |
Signed-off-by: Michael Roth <mdroth@linux.vnet.ibm.com>
|
|
|
5544c1 |
---
|
|
|
5544c1 |
tcg/optimize.c | 14 +++++++++++++-
|
|
|
5544c1 |
1 file changed, 13 insertions(+), 1 deletion(-)
|
|
|
5544c1 |
|
|
|
5544c1 |
diff --git a/tcg/optimize.c b/tcg/optimize.c
|
|
|
5544c1 |
index 9c65474..63f970d 100644
|
|
|
5544c1 |
--- a/tcg/optimize.c
|
|
|
5544c1 |
+++ b/tcg/optimize.c
|
|
|
5544c1 |
@@ -322,7 +322,7 @@ static TCGArg *tcg_constant_folding(TCGContext *s, uint16_t *tcg_opc_ptr,
|
|
|
5544c1 |
break;
|
|
|
5544c1 |
}
|
|
|
5544c1 |
|
|
|
5544c1 |
- /* Simplify expression if possible. */
|
|
|
5544c1 |
+ /* Simplify expression for "op r, a, 0 => mov r, a" cases */
|
|
|
5544c1 |
switch (op) {
|
|
|
5544c1 |
CASE_OP_32_64(add):
|
|
|
5544c1 |
CASE_OP_32_64(sub):
|
|
|
5544c1 |
@@ -352,6 +352,12 @@ static TCGArg *tcg_constant_folding(TCGContext *s, uint16_t *tcg_opc_ptr,
|
|
|
5544c1 |
continue;
|
|
|
5544c1 |
}
|
|
|
5544c1 |
break;
|
|
|
5544c1 |
+ default:
|
|
|
5544c1 |
+ break;
|
|
|
5544c1 |
+ }
|
|
|
5544c1 |
+
|
|
|
5544c1 |
+ /* Simplify expression for "op r, a, 0 => movi r, 0" cases */
|
|
|
5544c1 |
+ switch (op) {
|
|
|
5544c1 |
CASE_OP_32_64(mul):
|
|
|
5544c1 |
if ((temps[args[2]].state == TCG_TEMP_CONST
|
|
|
5544c1 |
&& temps[args[2]].val == 0)) {
|
|
|
5544c1 |
@@ -362,6 +368,12 @@ static TCGArg *tcg_constant_folding(TCGContext *s, uint16_t *tcg_opc_ptr,
|
|
|
5544c1 |
continue;
|
|
|
5544c1 |
}
|
|
|
5544c1 |
break;
|
|
|
5544c1 |
+ default:
|
|
|
5544c1 |
+ break;
|
|
|
5544c1 |
+ }
|
|
|
5544c1 |
+
|
|
|
5544c1 |
+ /* Simplify expression for "op r, a, a => mov r, a" cases */
|
|
|
5544c1 |
+ switch (op) {
|
|
|
5544c1 |
CASE_OP_32_64(or):
|
|
|
5544c1 |
CASE_OP_32_64(and):
|
|
|
5544c1 |
if (args[1] == args[2]) {
|
|
|
5544c1 |
--
|
|
|
5544c1 |
1.7.12.1
|
|
|
5544c1 |
|