Fix PR5023: The instruction form of DominatorTree::dominates did not
authorChris Lattner <sabre@nondot.org>
Mon, 21 Sep 2009 22:39:35 +0000 (22:39 +0000)
committerChris Lattner <sabre@nondot.org>
Mon, 21 Sep 2009 22:39:35 +0000 (22:39 +0000)
take into consideration that the result of an invoke is only valid in
the normal dest, not the unwind dest.  This caused 'PHINode::hasConstantValue'
to return true in an invalid situation, causing mem2reg to delete a phi that
was actually needed.  This caused a crash building 483.xalancbmk.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@82491 91177308-0d34-0410-b5e6-96231b3b80d8

lib/VMCore/Dominators.cpp
test/Transforms/Mem2Reg/crash.ll [new file with mode: 0644]

index 6d0e23d6427b52c148226cbbac066a726f3bd7aa..1f172145c3b1ff6518a5b5f2f56ca6844d763c07 100644 (file)
@@ -52,10 +52,16 @@ void DominatorTree::print(raw_ostream &OS, const Module *) const {
   DT->print(OS);
 }
 
-// dominates - Return true if A dominates B. This performs the
+// dominates - Return true if A dominates a use in B. This performs the
 // special checks necessary if A and B are in the same basic block.
 bool DominatorTree::dominates(const Instruction *A, const Instruction *B) const{
   const BasicBlock *BBA = A->getParent(), *BBB = B->getParent();
+  
+  // If A is an invoke instruction, its value is only available in this normal
+  // successor block.
+  if (const InvokeInst *II = dyn_cast<InvokeInst>(A))
+    BBA = II->getNormalDest();
+  
   if (BBA != BBB) return dominates(BBA, BBB);
   
   // It is not possible to determine dominance between two PHI nodes 
diff --git a/test/Transforms/Mem2Reg/crash.ll b/test/Transforms/Mem2Reg/crash.ll
new file mode 100644 (file)
index 0000000..ce795aa
--- /dev/null
@@ -0,0 +1,24 @@
+; RUN: opt < %s -mem2reg -S
+; PR5023
+
+declare i32 @bar()
+
+define i32 @foo() {
+entry:
+  %whichFlag = alloca i32
+  %A = invoke i32 @bar()
+          to label %invcont2 unwind label %lpad86
+
+invcont2:
+  store i32 %A, i32* %whichFlag
+  br label %bb15
+
+bb15:
+  %B = load i32* %whichFlag
+  ret i32 %B
+
+lpad86:
+  br label %bb15
+  
+}
+