Tweak to ignoring reserved regs. The allocator was occasionally still looking
authorJim Grosbach <grosbach@apple.com>
Wed, 1 Sep 2010 22:48:34 +0000 (22:48 +0000)
committerJim Grosbach <grosbach@apple.com>
Wed, 1 Sep 2010 22:48:34 +0000 (22:48 +0000)
at them since they'd end up in the register weights list. Tell it to stop
doing that.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@112756 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/RegAllocLinearScan.cpp

index 32dda273d089ac81dd63ac70465bad87cffaaefd..5c62354a8872cf484819058209b1c8276a82d5fd 100644 (file)
@@ -1147,9 +1147,11 @@ void RALinScan::assignRegOrStackSlotAtInterval(LiveInterval* cur) {
            e = RC->allocation_order_end(*mf_); i != e; ++i) {
       unsigned reg = *i;
       float regWeight = SpillWeights[reg];
+      // Don't even consider reserved regs.
+      if (reservedRegs_.test(reg))
+        continue;
       // Skip recently allocated registers and reserved registers.
-      if (minWeight > regWeight && !isRecentlyUsed(reg) &&
-          !reservedRegs_.test(reg))
+      if (minWeight > regWeight && !isRecentlyUsed(reg))
         Found = true;
       RegsWeights.push_back(std::make_pair(reg, regWeight));
     }