From c6885fc369945a8fe196301b7c2357e11a4c5f20 Mon Sep 17 00:00:00 2001 From: Eli Friedman Date: Wed, 7 Dec 2016 19:55:59 +0000 Subject: [GVNHoist] Invalidate MemDep when an instruction is moved. See also r279907. Fixes https://llvm.org/bugs/show_bug.cgi?id=30991 . Differential Revision: https://reviews.llvm.org/D27493 llvm-svn: 288968 --- llvm/test/Transforms/GVNHoist/hoist.ll | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) (limited to 'llvm/test') diff --git a/llvm/test/Transforms/GVNHoist/hoist.ll b/llvm/test/Transforms/GVNHoist/hoist.ll index 8e189418d72..d4b4afdd5ad 100644 --- a/llvm/test/Transforms/GVNHoist/hoist.ll +++ b/llvm/test/Transforms/GVNHoist/hoist.ll @@ -711,3 +711,36 @@ return: ; preds = %if.end, %if.then ; CHECK: %[[load:.*]] = load i32, i32* %y, align 1 ; CHECK: %[[phi:.*]] = phi i32 [ %[[load]], %{{.*}} ], [ %[[load]], %{{.*}} ] ; CHECK: i32 %[[phi]] + + +declare i8 @pr30991_f() nounwind readonly +declare void @pr30991_f1(i8) +define i8 @pr30991(i8* %sp, i8* %word, i1 %b1, i1 %b2) { +entry: + br i1 %b1, label %a, label %b + +a: + %r0 = load i8, i8* %word, align 1 + %incdec.ptr = getelementptr i8, i8* %sp, i32 1 + %rr0 = call i8 @pr30991_f() nounwind readonly + call void @pr30991_f1(i8 %r0) + ret i8 %rr0 + +b: + br i1 %b2, label %c, label %x + +c: + %r1 = load i8, i8* %word, align 1 + %incdec.ptr115 = getelementptr i8, i8* %sp, i32 1 + %rr1 = call i8 @pr30991_f() nounwind readonly + call void @pr30991_f1(i8 %r1) + ret i8 %rr1 + +x: + %r2 = load i8, i8* %word, align 1 + ret i8 %r2 +} + +; CHECK-LABEL: define i8 @pr30991 +; CHECK: %r0 = load i8, i8* %word, align 1 +; CHECK-NEXT: br i1 %b1, label %a, label %b -- cgit v1.2.3