diff options
author | Dale Johannesen <dalej@apple.com> | 2007-06-13 17:59:52 +0000 |
---|---|---|
committer | Dale Johannesen <dalej@apple.com> | 2007-06-13 17:59:52 +0000 |
commit | 13e8b51e3ec014c5d7ae83afdf3b8fd29c3a461d (patch) | |
tree | 99ad4ddf2f16711868c116de69c6e1240f0560ef /lib/Target/X86/X86InstrInfo.cpp | |
parent | ea632439d4259254670dc4a27b13d6f9370216a8 (diff) |
Handle blocks with 2 unconditional branches in AnalyzeBranch.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@37571 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/X86/X86InstrInfo.cpp')
-rw-r--r-- | lib/Target/X86/X86InstrInfo.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/lib/Target/X86/X86InstrInfo.cpp b/lib/Target/X86/X86InstrInfo.cpp index a3b3223611..57282d471f 100644 --- a/lib/Target/X86/X86InstrInfo.cpp +++ b/lib/Target/X86/X86InstrInfo.cpp @@ -427,6 +427,16 @@ bool X86InstrInfo::AnalyzeBranch(MachineBasicBlock &MBB, return false; } + // If the block ends with two X86::JMPs, handle it. The second one is not + // executed, so remove it. + if (SecondLastInst->getOpcode() == X86::JMP && + LastInst->getOpcode() == X86::JMP) { + TBB = SecondLastInst->getOperand(0).getMachineBasicBlock(); + I = LastInst; + I->eraseFromParent(); + return false; + } + // Otherwise, can't handle this. return true; } |