about summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorVikas Gupta <vikasgupta.nit@gmail.com>2018-04-19 19:04:40 +0800
committerVikas Gupta <vikasgupta.nit@gmail.com>2018-04-19 19:04:40 +0800
commit398e7b72bded9e022ed39d32f38199fe079f082d (patch)
treeee8bc0342de1fa1f137d5677b1de5905238535e8
parent26a551b57b7d8dd7e9a9245eef5dee1d16864c47 (diff)
downloadmiasm-398e7b72bded9e022ed39d32f38199fe079f082d.tar.gz
miasm-398e7b72bded9e022ed39d32f38199fe079f082d.zip
Fixed uxtw, uxth and sxtw, sxth register truncation
-rw-r--r--miasm2/arch/aarch64/sem.py25
1 files changed, 24 insertions, 1 deletions
diff --git a/miasm2/arch/aarch64/sem.py b/miasm2/arch/aarch64/sem.py
index 2799df7a..88b0d0a7 100644
--- a/miasm2/arch/aarch64/sem.py
+++ b/miasm2/arch/aarch64/sem.py
@@ -124,9 +124,32 @@ def extend_arg(dst, arg):
         return arg
 
     op, (reg, shift) = arg.op, arg.args
-    if op == 'SXTW':
+    if op == "SXTB":
+        base = reg[:8].signExtend(dst.size)
+        op = "<<"
+    elif op == "SXTH":
+        base = reg[:16].signExtend(dst.size)
+        op = "<<"
+    elif op == 'SXTW':
+        base = reg[:32].signExtend(dst.size)
+        op = "<<"
+    elif op == "SXTX":
         base = reg.signExtend(dst.size)
         op = "<<"
+
+    elif op == "UXTB":
+        base = reg[:8].zeroExtend(dst.size)
+        op = "<<"
+    elif op == "UXTH":
+        base = reg[:16].zeroExtend(dst.size)
+        op = "<<"
+    elif op == 'UXTW':
+        base = reg[:32].zeroExtend(dst.size)
+        op = "<<"
+    elif op == "UXTX":
+        base = reg.zeroExtend(dst.size)
+        op = "<<"
+
     elif op in ['<<', '>>', '<<a', 'a>>', '<<<', '>>>']:
         base = reg.zeroExtend(dst.size)
     else: