diff options
author | Chris Lattner <sabre@nondot.org> | 2008-05-09 15:07:33 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-05-09 15:07:33 +0000 |
commit | bfc538c09ef619c2eac88c13ce32a94ca71694b9 (patch) | |
tree | 44c03633782e871adf7209436c34f145535b374c | |
parent | 33af59d0f021838c8e601cb300681f71ee31c47a (diff) |
don't sink invokes, even if they are readonly. This fixes a
crash on kimwitu++.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@50901 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Transforms/Scalar/InstructionCombining.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/lib/Transforms/Scalar/InstructionCombining.cpp b/lib/Transforms/Scalar/InstructionCombining.cpp index e8b60f890c..f3591879f7 100644 --- a/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/lib/Transforms/Scalar/InstructionCombining.cpp @@ -11233,7 +11233,8 @@ static bool TryToSinkInstruction(Instruction *I, BasicBlock *DestBlock) { assert(I->hasOneUse() && "Invariants didn't hold!"); // Cannot move control-flow-involving, volatile loads, vaarg, etc. - if (isa<PHINode>(I) || I->mayWriteToMemory()) return false; + if (isa<PHINode>(I) || I->mayWriteToMemory() || isa<TerminatorInst>(I)) + return false; // Do not sink alloca instructions out of the entry block. if (isa<AllocaInst>(I) && I->getParent() == |