Modifies MipsAsmPrinter::isBlockOnlyReachableByFallthrough so that it handles delay...
authorAkira Hatanaka <ahatanak@gmail.com>
Fri, 1 Apr 2011 18:57:38 +0000 (18:57 +0000)
committerAkira Hatanaka <ahatanak@gmail.com>
Fri, 1 Apr 2011 18:57:38 +0000 (18:57 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@128724 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/Mips/MipsAsmPrinter.cpp

index 24f2e89aa5962fb3f2e909dc2a09b552588e94e2..8dd6a37e75d01f94dd8a0e30b6f0f666d7293b21 100644 (file)
@@ -247,7 +247,32 @@ bool MipsAsmPrinter::isBlockOnlyReachableByFallthrough(const MachineBasicBlock *
     if (isa<SwitchInst>(bb->getTerminator()))
       return false;
 
-  return AsmPrinter::isBlockOnlyReachableByFallthrough(MBB);
+  // If this is a landing pad, it isn't a fall through.  If it has no preds,
+  // then nothing falls through to it.
+  if (MBB->isLandingPad() || MBB->pred_empty())
+    return false;
+
+  // If there isn't exactly one predecessor, it can't be a fall through.
+  MachineBasicBlock::const_pred_iterator PI = MBB->pred_begin(), PI2 = PI;
+  ++PI2;
+  if (PI2 != MBB->pred_end())
+    return false;  
+
+  // The predecessor has to be immediately before this block.
+  if (!Pred->isLayoutSuccessor(MBB))
+    return false;
+   
+  // If the block is completely empty, then it definitely does fall through.
+  if (Pred->empty())
+    return true;
+  
+  // Otherwise, check the last instruction.
+  // Check if the last terminator is an unconditional branch.
+  MachineBasicBlock::const_iterator I = Pred->end();
+  while (I != Pred->begin() && !(--I)->getDesc().isTerminator());
+
+  return !I->getDesc().isBarrier();
 }
 
 // Print out an operand for an inline asm expression.