diff options
| author | Vikas Gupta <vikasgupta.nit@gmail.com> | 2018-04-19 19:04:40 +0800 |
|---|---|---|
| committer | Vikas Gupta <vikasgupta.nit@gmail.com> | 2018-04-19 19:04:40 +0800 |
| commit | 398e7b72bded9e022ed39d32f38199fe079f082d (patch) | |
| tree | ee8bc0342de1fa1f137d5677b1de5905238535e8 | |
| parent | 26a551b57b7d8dd7e9a9245eef5dee1d16864c47 (diff) | |
| download | miasm-398e7b72bded9e022ed39d32f38199fe079f082d.tar.gz miasm-398e7b72bded9e022ed39d32f38199fe079f082d.zip | |
Fixed uxtw, uxth and sxtw, sxth register truncation
| -rw-r--r-- | miasm2/arch/aarch64/sem.py | 25 |
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: |