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

ARM: Fix register allocation for ldrd-optimized HREFK.

Mike Pall пре 13 година
родитељ
комит
0522f74f69
1 измењених фајлова са 2 додато и 1 уклоњено
  1. 2 1
      src/lj_asm_arm.h

+ 2 - 1
src/lj_asm_arm.h

@@ -656,7 +656,8 @@ static void asm_hrefk(ASMState *as, IRIns *ir)
   }
   asm_guardcc(as, CC_NE);
   if (!irt_ispri(irkey->t)) {
-    RegSet even = (as->freeset & (as->freeset >> 1) & allow & RSET_GPREVEN);
+    RegSet even = (as->freeset & allow);
+    even = even & (even >> 1) & RSET_GPREVEN;
     if (even) {
       key = ra_scratch(as, even);
       if (rset_test(as->freeset, key+1)) {