diff options
Diffstat (limited to 'test/Analysis/GlobalsModRef')
| -rw-r--r-- | test/Analysis/GlobalsModRef/aliastest.ll | 1 | ||||
| -rw-r--r-- | test/Analysis/GlobalsModRef/comdat-ipo.ll | 21 | ||||
| -rw-r--r-- | test/Analysis/GlobalsModRef/func-memattributes.ll | 31 | ||||
| -rw-r--r-- | test/Analysis/GlobalsModRef/indirect-global.ll | 1 | ||||
| -rw-r--r-- | test/Analysis/GlobalsModRef/no-escape.ll | 65 |
5 files changed, 119 insertions, 0 deletions
diff --git a/test/Analysis/GlobalsModRef/aliastest.ll b/test/Analysis/GlobalsModRef/aliastest.ll index ecc6bcc55d1d..3a0eee84e881 100644 --- a/test/Analysis/GlobalsModRef/aliastest.ll +++ b/test/Analysis/GlobalsModRef/aliastest.ll @@ -1,4 +1,5 @@ ; RUN: opt < %s -basicaa -globals-aa -gvn -S -enable-unsafe-globalsmodref-alias-results | FileCheck %s +; RUN: opt < %s -aa-pipeline=basic-aa,globals-aa -passes="require<globals-aa>,function(gvn)" -S -enable-unsafe-globalsmodref-alias-results | FileCheck %s ; ; Note that this test relies on an unsafe feature of GlobalsModRef. While this ; test is correct and safe, GMR's technique for handling this isn't generally. diff --git a/test/Analysis/GlobalsModRef/comdat-ipo.ll b/test/Analysis/GlobalsModRef/comdat-ipo.ll new file mode 100644 index 000000000000..a9cc821e7afb --- /dev/null +++ b/test/Analysis/GlobalsModRef/comdat-ipo.ll @@ -0,0 +1,21 @@ +; RUN: opt < %s -basicaa -globals-aa -gvn -S | FileCheck %s + +; See PR26774 + +@X = internal global i32 4 + +define i32 @test(i32* %P) { +; CHECK: @test +; CHECK-NEXT: store i32 12, i32* @X +; CHECK-NEXT: call void @doesnotmodX() +; CHECK-NEXT: %V = load i32, i32* @X +; CHECK-NEXT: ret i32 %V + store i32 12, i32* @X + call void @doesnotmodX( ) + %V = load i32, i32* @X + ret i32 %V +} + +define linkonce_odr void @doesnotmodX() { + ret void +} diff --git a/test/Analysis/GlobalsModRef/func-memattributes.ll b/test/Analysis/GlobalsModRef/func-memattributes.ll new file mode 100644 index 000000000000..5494512592e3 --- /dev/null +++ b/test/Analysis/GlobalsModRef/func-memattributes.ll @@ -0,0 +1,31 @@ +; RUN: opt < %s -disable-basicaa -globals-aa -dse -S | FileCheck %s + +@X = internal global i32 4 + +define void @test0() { +; CHECK-LABEL: @test0 +; CHECK: store i32 0, i32* @X +; CHECK-NEXT: call void @func_readonly() #0 +; CHECK-NEXT: store i32 1, i32* @X + store i32 0, i32* @X + call void @func_readonly() #0 + store i32 1, i32* @X + ret void +} + +define void @test1() { +; CHECK-LABEL: @test1 +; CHECK-NOT: store +; CHECK: call void @func_read_argmem_only() #1 +; CHECK-NEXT: store i32 3, i32* @X + store i32 2, i32* @X + call void @func_read_argmem_only() #1 + store i32 3, i32* @X + ret void +} + +declare void @func_readonly() #0 +declare void @func_read_argmem_only() #1 + +attributes #0 = { readonly } +attributes #1 = { readonly argmemonly } diff --git a/test/Analysis/GlobalsModRef/indirect-global.ll b/test/Analysis/GlobalsModRef/indirect-global.ll index a51f54b07503..39d5260b950a 100644 --- a/test/Analysis/GlobalsModRef/indirect-global.ll +++ b/test/Analysis/GlobalsModRef/indirect-global.ll @@ -1,4 +1,5 @@ ; RUN: opt < %s -basicaa -globals-aa -gvn -instcombine -S -enable-unsafe-globalsmodref-alias-results | FileCheck %s +; RUN: opt < %s -aa-pipeline=basic-aa,globals-aa -passes="require<globals-aa>,function(gvn,instcombine)" -S -enable-unsafe-globalsmodref-alias-results | FileCheck %s ; ; Note that this test relies on an unsafe feature of GlobalsModRef. While this ; test is correct and safe, GMR's technique for handling this isn't generally. diff --git a/test/Analysis/GlobalsModRef/no-escape.ll b/test/Analysis/GlobalsModRef/no-escape.ll new file mode 100644 index 000000000000..d813a92268c6 --- /dev/null +++ b/test/Analysis/GlobalsModRef/no-escape.ll @@ -0,0 +1,65 @@ +; RUN: opt < %s -basicaa -globals-aa -S -enable-non-lto-gmr=true -licm | FileCheck %s + +target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128" +target triple = "x86_64-apple-macosx10.10.0" + +@b = common global i32 0, align 4 +@c = internal global i32 0, align 4 +@d = common global i32 0, align 4 +@e = common global i32* null, align 4 + +define void @foo(i32* %P) noinline { +; CHECK: define void @foo + %loadp = load i32, i32* %P, align 4 + store i32 %loadp, i32* @d, align 4 + ret void +} + +define void @bar() noinline { +; CHECK: define void @bar + %loadp = load i32, i32* @d, align 4 + store i32 %loadp, i32* @c, align 4 + ret void +} + +define i32 @main() { +entry: + %retval = alloca i32, align 4 + %c = alloca [1 x i32], align 4 + store i32 0, i32* %retval, align 4 + call void @bar() + store i32 0, i32* @b, align 4 + br label %for.cond + ;; Check that @c is LICM'ed out. +; CHECK: load i32, i32* @c +for.cond: ; preds = %for.inc, %entry +; CHECK-LABEL: for.cond: +; CHECK: load i32, i32* @b + %a1 = load i32, i32* @b, align 4 + %aa2 = load i32, i32* @c, align 4 + %add = add nsw i32 %a1, %aa2 + %p1 = load i32*, i32** @e, align 4 + call void @foo(i32* %p1) + %cmp = icmp slt i32 %add, 3 + br i1 %cmp, label %for.body, label %for.end + +for.body: ; preds = %for.cond + %a2 = load i32, i32* @b, align 4 + %idxprom = sext i32 %a2 to i64 + br label %for.inc + +for.inc: ; preds = %for.body + %a3 = load i32, i32* @b, align 4 + %inc = add nsw i32 %a3, 1 + store i32 %inc, i32* @b, align 4 + br label %for.cond + +for.end: ; preds = %for.cond + ret i32 0 +} + +; Function Attrs: nounwind argmemonly +declare void @llvm.memset.p0i8.i64(i8* nocapture, i8, i64, i32, i1) nounwind argmemonly + +; Function Attrs: noreturn nounwind +declare void @abort() noreturn nounwind |
