about summary refs log tree commit diff stats
path: root/miasm/expression/simplifications_common.py
diff options
context:
space:
mode:
authorFabrice Desclaux <fabrice.desclaux@cea.fr>2020-06-25 13:41:24 +0200
committerFabrice Desclaux <fabrice.desclaux@cea.fr>2020-06-25 13:41:24 +0200
commitce175bb51b8d391ea0da2ef1396b79b495b8cdf5 (patch)
tree6fa89ff7a6e0df5df12e8b7801e9cfbbf01b2aed /miasm/expression/simplifications_common.py
parentb54727ab6a8c2764fd2f2e42cb3020f41c4cb772 (diff)
downloadfocaccia-miasm-ce175bb51b8d391ea0da2ef1396b79b495b8cdf5.tar.gz
focaccia-miasm-ce175bb51b8d391ea0da2ef1396b79b495b8cdf5.zip
Add cond CC flag simplification
Diffstat (limited to 'miasm/expression/simplifications_common.py')
-rw-r--r--miasm/expression/simplifications_common.py20
1 files changed, 20 insertions, 0 deletions
diff --git a/miasm/expression/simplifications_common.py b/miasm/expression/simplifications_common.py
index 932db49a..dc9fadea 100644
--- a/miasm/expression/simplifications_common.py
+++ b/miasm/expression/simplifications_common.py
@@ -919,6 +919,26 @@ def simp_sub_cf_zero(_, expr):
         return expr
     return ExprCond(expr.args[1], ExprInt(1, 1), ExprInt(0, 1))
 
+def simp_cond_cc_flag(expr_simp, expr):
+    """
+    ExprCond(CC_><(bit), X, Y) => ExprCond(bit, X, Y)
+    ExprCond(CC_U>=(bit), X, Y) => ExprCond(bit, Y, X)
+    """
+    if not expr.is_cond():
+        return expr
+    if not expr.cond.is_op():
+        return expr
+    expr_op = expr.cond
+    if expr_op.op not in ["CC_U<", "CC_U>="]:
+        return expr
+    arg = expr_op.args[0]
+    if arg.size != 1:
+        return expr
+    if expr_op.op == "CC_U<":
+        return ExprCond(arg, expr.src1, expr.src2)
+    if expr_op.op == "CC_U>=":
+        return ExprCond(arg, expr.src2, expr.src1)
+    return expr
 
 def simp_cmp_int(expr_simp, expr):
     """