diff options
-rw-r--r-- | llvm/lib/CodeGen/CodeGenPrepare.cpp | 1 | ||||
-rw-r--r-- | llvm/test/CodeGen/AArch64/cgp-trivial-phi-node.ll | 33 |
2 files changed, 34 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/CodeGenPrepare.cpp b/llvm/lib/CodeGen/CodeGenPrepare.cpp index af1b65253f8..1d61d326372 100644 --- a/llvm/lib/CodeGen/CodeGenPrepare.cpp +++ b/llvm/lib/CodeGen/CodeGenPrepare.cpp @@ -6849,6 +6849,7 @@ bool CodeGenPrepare::optimizeInst(Instruction *I, DominatorTree &DT, // to introduce PHI nodes too late to be cleaned up. If we detect such a // trivial PHI, go ahead and zap it here. if (Value *V = SimplifyInstruction(P, {*DL, TLInfo})) { + LargeOffsetGEPMap.erase(P); P->replaceAllUsesWith(V); P->eraseFromParent(); ++NumPHIsElim; diff --git a/llvm/test/CodeGen/AArch64/cgp-trivial-phi-node.ll b/llvm/test/CodeGen/AArch64/cgp-trivial-phi-node.ll new file mode 100644 index 00000000000..6e2d4a251ab --- /dev/null +++ b/llvm/test/CodeGen/AArch64/cgp-trivial-phi-node.ll @@ -0,0 +1,33 @@ +; Checks that case when GEP is bound to trivial PHI node is correctly handled. +; RUN: opt %s -mtriple=aarch64-linux-gnu -codegenprepare -S -o - | FileCheck %s + +; CHECK: define void @crash([65536 x i32]** %s, i32 %n) { +; CHECK-NEXT: entry: +; CHECK-NEXT: %struct = load [65536 x i32]*, [65536 x i32]** %s +; CHECK-NEXT: %gep0 = getelementptr [65536 x i32], [65536 x i32]* %struct, i64 0, i32 20000 +; CHECK-NEXT: store i32 %n, i32* %gep0 +; CHECK-NEXT: ret void +; CHECK-NEXT: } + +define void @crash([65536 x i32]** %s, i32 %n) { +entry: + %struct = load [65536 x i32]*, [65536 x i32]** %s + %cmp = icmp slt i32 0, %n + br i1 %cmp, label %baz, label %bar +baz: + br label %bar + +foo: + %gep0 = getelementptr [65536 x i32], [65536 x i32]* %phi2, i64 0, i32 20000 + br label %st + +st: + store i32 %n, i32* %gep0 + br label %out + +bar: + %phi2 = phi [65536 x i32]* [ %struct, %baz ], [ %struct, %entry ] + br label %foo +out: + ret void +} |