diff options
Diffstat (limited to 'llvm/lib/CodeGen/MachineBlockPlacement.cpp')
-rw-r--r-- | llvm/lib/CodeGen/MachineBlockPlacement.cpp | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/MachineBlockPlacement.cpp b/llvm/lib/CodeGen/MachineBlockPlacement.cpp index d3bf95b9a95..de0b572f2fe 100644 --- a/llvm/lib/CodeGen/MachineBlockPlacement.cpp +++ b/llvm/lib/CodeGen/MachineBlockPlacement.cpp @@ -839,8 +839,13 @@ bool MachineBlockPlacement::isTrellis( int PredCount = 0; for (auto SuccPred : Succ->predecessors()) { // Allow triangle successors, but don't count them. - if (Successors.count(SuccPred)) + if (Successors.count(SuccPred)) { + // Make sure that it is actually a triangle. + for (MachineBasicBlock *CheckSucc : SuccPred->successors()) + if (!Successors.count(CheckSucc)) + return false; continue; + } const BlockChain *PredChain = BlockToChain[SuccPred]; if (SuccPred == BB || (BlockFilter && !BlockFilter->count(SuccPred)) || PredChain == &Chain || PredChain == BlockToChain[Succ]) |