Преглед изворни кода

* TARMAsmOptimizer.USxtOp2Op sets register size if needed

florian пре 1 година
родитељ
комит
fd74c26707
1 измењених фајлова са 2 додато и 0 уклоњено
  1. 2 0
      compiler/armgen/aoptarm.pas

+ 2 - 0
compiler/armgen/aoptarm.pas

@@ -231,6 +231,8 @@ Implementation
           else
             opoffset:=1;
           taicpu(hp1).loadReg(opoffset+1,taicpu(p).oper[1]^.reg);
+          if not(shiftmode in [SM_SXTX,SM_UXTX,SM_LSL]) then
+            setsubreg(taicpu(hp1).oper[opoffset+1]^.reg,R_SUBD);
           taicpu(hp1).ops:=opoffset+3;
           shifterop_reset(so);
           so.shiftmode:=shiftmode;