aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/Transforms/Scalar/GVNPRE.cpp2
-rw-r--r--test/Transforms/GVNPRE/2007-07-03-PhiTranslateGEP.ll14
2 files changed, 15 insertions, 1 deletions
diff --git a/lib/Transforms/Scalar/GVNPRE.cpp b/lib/Transforms/Scalar/GVNPRE.cpp
index be86f3a797..33926ea127 100644
--- a/lib/Transforms/Scalar/GVNPRE.cpp
+++ b/lib/Transforms/Scalar/GVNPRE.cpp
@@ -836,7 +836,7 @@ Value* GVNPRE::phi_translate(Value* V, BasicBlock* pred, BasicBlock* succ) {
}
if (newOp1 != U->getPointerOperand() || changed_idx) {
- Instruction* newVal = new GetElementPtrInst(U->getPointerOperand(),
+ Instruction* newVal = new GetElementPtrInst(newOp1,
&newIdx[0], newIdx.size(),
U->getName()+".expr");
diff --git a/test/Transforms/GVNPRE/2007-07-03-PhiTranslateGEP.ll b/test/Transforms/GVNPRE/2007-07-03-PhiTranslateGEP.ll
new file mode 100644
index 0000000000..65d70d9582
--- /dev/null
+++ b/test/Transforms/GVNPRE/2007-07-03-PhiTranslateGEP.ll
@@ -0,0 +1,14 @@
+; RUN: llvm-as < %s | opt -gvnpre | llvm-dis
+
+define i64 @foo({ i32, i32 }** %__v) {
+entry:
+ br label %bb
+
+bb: ; preds = %bb, %entry
+ %__x.066.0 = phi { i32, i32 }* [ null, %entry ], [ null, %bb ]
+ %tmp2.i.i63 = getelementptr { i32, i32 }* %__x.066.0, i32 0, i32 1
+ br i1 false, label %bb, label %cond_true
+
+cond_true: ; preds = %bb
+ ret i64 0
+}