summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2011-06-12 03:20:32 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2011-06-12 03:20:32 +0000
commitdefd4b0875f692e26b67b0851c7e63f922fcdcd0 (patch)
tree5789b967010a52d8877c01769f2e92a262c4be0c /llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
parentd2b4713e53a7667fa51b5aad17337bc6142d157d (diff)
downloadbcm5719-llvm-defd4b0875f692e26b67b0851c7e63f922fcdcd0.tar.gz
bcm5719-llvm-defd4b0875f692e26b67b0851c7e63f922fcdcd0.zip
AnalyzeBranch doesn't change which successors a bb has, just the order
we try to branch to them. Before we were creating successor lists with duplicated entries. Fixing that found a bug in isBlockOnlyReachableByFallthrough that would causes it to return the wrong answer for ----------- ... jne foo jmp bar foo: ---------- llvm-svn: 132882
Diffstat (limited to 'llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp')
-rw-r--r--llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp15
1 files changed, 11 insertions, 4 deletions
diff --git a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
index 161afbafb57..1fd724f9ca7 100644
--- a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
+++ b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
@@ -1925,7 +1925,7 @@ isBlockOnlyReachableByFallthrough(const MachineBasicBlock *MBB) const {
return false;
// The predecessor has to be immediately before this block.
- const MachineBasicBlock *Pred = *PI;
+ MachineBasicBlock *Pred = *PI;
if (!Pred->isLayoutSuccessor(MBB))
return false;
@@ -1934,9 +1934,16 @@ isBlockOnlyReachableByFallthrough(const MachineBasicBlock *MBB) const {
if (Pred->empty())
return true;
- // Otherwise, check the last instruction.
- const MachineInstr &LastInst = Pred->back();
- return !LastInst.getDesc().isBarrier();
+ // Otherwise, ask the backend.
+ const TargetInstrInfo *TII = MF->getTarget().getInstrInfo();
+ MachineBasicBlock *PredTBB = NULL, *PredFBB = NULL;
+ SmallVector<MachineOperand, 4> PredCond;
+ if (TII->AnalyzeBranch(*Pred, PredTBB, PredFBB, PredCond))
+ return false;
+
+ if (PredCond.empty())
+ return true;
+ return !PredFBB || PredFBB == MBB;
}
OpenPOWER on IntegriCloud