From 1de42a8b4b5404d4031db08a90d1e35bf2f1d880 Mon Sep 17 00:00:00 2001 From: Jo Van Bulck Date: Wed, 8 May 2024 12:19:44 +0200 Subject: [PATCH] msp430: fix dadd operation and types for .b instructions Fixes assertion errors in vex_helper.py, e.g. below: AssertionError: operation needs to be well typed: Xor16(t6,t9) types: t0:Ity_I16 t1:Ity_I16 t2:Ity_I16 t3:Ity_I8 t4:Ity_I16 t5:Ity_I16 t6:Ity_I16 t7:Ity_I8 t8:Ity_I8 t9:Ity_I8 --- angr_platforms/msp430/instrs_msp430.py | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/angr_platforms/msp430/instrs_msp430.py b/angr_platforms/msp430/instrs_msp430.py index 86244bd..924e599 100644 --- a/angr_platforms/msp430/instrs_msp430.py +++ b/angr_platforms/msp430/instrs_msp430.py @@ -475,7 +475,7 @@ class Instruction_RRC(Type1Instruction): def compute_result(self, src): # Get carry-in - carryin = self.get_carry() + carryin = self.get_carry().cast_to(src.ty) # Do it src >>= 1 # Put the carry-in in the right place @@ -729,7 +729,7 @@ class Instruction_SUBC(Instruction_SUB): name = 'subc' def compute_result(self, src, dst): - return dst - src - self.constant(1, src.ty) + self.get_carry() + return dst - src - self.constant(1, src.ty) + self.get_carry().cast_to(src.ty) def carry(self, src, dst, ret): # Works for .w and .b mode @@ -761,17 +761,17 @@ def compute_result(self, src, dst): for x in range(0, bits, 4): srcs += src[x:x+3] dsts += dst[x:x+3] - carry = self.get_carry() + carry = self.get_carry().cast_to(src.ty) rets = [] for s, d in zip(srcs, dsts): r = s + d + carry - carry = r / 10 + carry = r // 10 r %= 10 - rets += r + rets.append(r) self._carry = carry #Carry computed in-line. save it. # Smash the digits back together for r, x in zip(rets, range(0, bits, 4)): - ret |= (r << x).cast_to(Type.int_16) + ret |= (r << x).cast_to(src.ty) return ret def carry(self, src, dst, ret):