fix operator register usage

which makes inter math work
surprise!
This commit is contained in:
Torsten 2020-03-25 18:38:32 +02:00
parent bc558d1f0d
commit 7572e27869
2 changed files with 12 additions and 8 deletions

3
.gdbinit Normal file
View File

@ -0,0 +1,3 @@
set disassemble-next-line on
file a.out
break *0x10054

View File

@ -93,21 +93,22 @@ module Arm
def translate_OperatorInstruction( code ) def translate_OperatorInstruction( code )
left = code.left left = code.left
right = code.right right = code.right
result = code.result
case code.operator.to_s case code.operator.to_s
when "+" when "+"
c = ArmMachine.add(left , left , right) c = ArmMachine.add(result , left , right)
when "-" when "-"
c = ArmMachine.sub(left , left , right) c = ArmMachine.sub(result , left , right)
when "&" when "&"
c = ArmMachine.and(left , left , right) c = ArmMachine.and(result , left , right)
when "|" when "|"
c = ArmMachine.orr(left , left , right) c = ArmMachine.orr(result , left , right)
when "*" when "*"
c = ArmMachine.mul(left , right , left) #arm rule about left not being result, lukily commutative c = ArmMachine.mul(result , right , left) #arm rule about left not being result, lukily commutative
when ">>" when ">>"
c = ArmMachine.mov(left , left , :shift_asr => right) #arm rule about left not being result, lukily commutative c = ArmMachine.mov(result , left , :shift_asr => right) #arm rule about left not being result, lukily commutative
when "<<" when "<<"
c = ArmMachine.mov(left , left , :shift_lsl => right) #arm rule about left not being result, lukily commutative c = ArmMachine.mov(result , left , :shift_lsl => right) #arm rule about left not being result, lukily commutative
else else
raise "unimplemented '#{code.operator}' #{code}" raise "unimplemented '#{code.operator}' #{code}"
end end