Sfoglia il codice sorgente

* ARM: (V)LDM do not load from the registers in the reg. set

git-svn-id: trunk@45525 -
florian 5 anni fa
parent
commit
651f5cb8a1
1 ha cambiato i file con 5 aggiunte e 1 eliminazioni
  1. 5 1
      compiler/arm/aoptcpu.pas

+ 5 - 1
compiler/arm/aoptcpu.pas

@@ -191,7 +191,11 @@ Implementation
             else
               ;
           end;
-          if instructionLoadsFromReg then exit; {Bailout if we found something}
+          if (i=0) and (p.opcode in [A_LDM,A_VLDM]) then
+            exit;
+
+          if instructionLoadsFromReg then
+            exit; {Bailout if we found something}
           Inc(I);
         end;
     end;