diff options
author | Duncan Sands <baldrick@free.fr> | 2008-12-31 16:14:43 +0000 |
---|---|---|
committer | Duncan Sands <baldrick@free.fr> | 2008-12-31 16:14:43 +0000 |
commit | 9e89ba31f16a960239a750a26a982b4c9dfe8949 (patch) | |
tree | 4b985f2525e7c6470e7a9d345b5c7eb7ffa889fe /test/Transforms | |
parent | 0c913735c7f66d6bcf0807fac4018a867c3a77e0 (diff) | |
download | external_llvm-9e89ba31f16a960239a750a26a982b4c9dfe8949.zip external_llvm-9e89ba31f16a960239a750a26a982b4c9dfe8949.tar.gz external_llvm-9e89ba31f16a960239a750a26a982b4c9dfe8949.tar.bz2 |
Rename AddReadAttrs to FunctionAttrs, and teach it how
to work out (in a very simplistic way) which function
arguments (pointer arguments only) are only dereferenced
and so do not escape. Mark such arguments 'nocapture'.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@61525 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Transforms')
-rw-r--r-- | test/Transforms/FunctionAttrs/2008-09-03-Mutual.ll (renamed from test/Transforms/AddReadAttrs/2008-09-03-Mutual.ll) | 2 | ||||
-rw-r--r-- | test/Transforms/FunctionAttrs/2008-09-03-ReadNone.ll (renamed from test/Transforms/AddReadAttrs/2008-09-03-ReadNone.ll) | 2 | ||||
-rw-r--r-- | test/Transforms/FunctionAttrs/2008-09-03-ReadOnly.ll (renamed from test/Transforms/AddReadAttrs/2008-09-03-ReadOnly.ll) | 2 | ||||
-rw-r--r-- | test/Transforms/FunctionAttrs/2008-09-13-VolatileRead.ll (renamed from test/Transforms/AddReadAttrs/2008-09-13-VolatileRead.ll) | 2 | ||||
-rw-r--r-- | test/Transforms/FunctionAttrs/2008-10-04-LocalMemory.ll (renamed from test/Transforms/AddReadAttrs/2008-10-04-LocalMemory.ll) | 2 | ||||
-rw-r--r-- | test/Transforms/FunctionAttrs/2008-12-29-Constant.ll (renamed from test/Transforms/AddReadAttrs/2008-12-29-Constant.ll) | 2 | ||||
-rw-r--r-- | test/Transforms/FunctionAttrs/2008-12-31-NoCapture.ll | 34 | ||||
-rw-r--r-- | test/Transforms/FunctionAttrs/dg.exp (renamed from test/Transforms/AddReadAttrs/dg.exp) | 0 |
8 files changed, 40 insertions, 6 deletions
diff --git a/test/Transforms/AddReadAttrs/2008-09-03-Mutual.ll b/test/Transforms/FunctionAttrs/2008-09-03-Mutual.ll index 0a4f085..5261ac4 100644 --- a/test/Transforms/AddReadAttrs/2008-09-03-Mutual.ll +++ b/test/Transforms/FunctionAttrs/2008-09-03-Mutual.ll @@ -1,4 +1,4 @@ -; RUN: llvm-as < %s | opt -addreadattrs | llvm-dis | grep readnone +; RUN: llvm-as < %s | opt -functionattrs | llvm-dis | grep readnone define i32 @a() { %tmp = call i32 @b( ) ; <i32> [#uses=1] diff --git a/test/Transforms/AddReadAttrs/2008-09-03-ReadNone.ll b/test/Transforms/FunctionAttrs/2008-09-03-ReadNone.ll index 3c7b32d..a17d381 100644 --- a/test/Transforms/AddReadAttrs/2008-09-03-ReadNone.ll +++ b/test/Transforms/FunctionAttrs/2008-09-03-ReadNone.ll @@ -1,4 +1,4 @@ -; RUN: llvm-as < %s | opt -addreadattrs | llvm-dis | grep readnone | count 4 +; RUN: llvm-as < %s | opt -functionattrs | llvm-dis | grep readnone | count 4 @x = global i32 0 declare i32 @e() readnone diff --git a/test/Transforms/AddReadAttrs/2008-09-03-ReadOnly.ll b/test/Transforms/FunctionAttrs/2008-09-03-ReadOnly.ll index c08e7b1..cebfdac 100644 --- a/test/Transforms/AddReadAttrs/2008-09-03-ReadOnly.ll +++ b/test/Transforms/FunctionAttrs/2008-09-03-ReadOnly.ll @@ -1,4 +1,4 @@ -; RUN: llvm-as < %s | opt -addreadattrs | llvm-dis | grep readonly | count 2 +; RUN: llvm-as < %s | opt -functionattrs | llvm-dis | grep readonly | count 2 define i32 @f() { entry: diff --git a/test/Transforms/AddReadAttrs/2008-09-13-VolatileRead.ll b/test/Transforms/FunctionAttrs/2008-09-13-VolatileRead.ll index 0690083..b6077fd 100644 --- a/test/Transforms/AddReadAttrs/2008-09-13-VolatileRead.ll +++ b/test/Transforms/FunctionAttrs/2008-09-13-VolatileRead.ll @@ -1,4 +1,4 @@ -; RUN: llvm-as < %s | opt -addreadattrs | llvm-dis | not grep read +; RUN: llvm-as < %s | opt -functionattrs | llvm-dis | not grep read ; PR2792 @g = global i32 0 ; <i32*> [#uses=1] diff --git a/test/Transforms/AddReadAttrs/2008-10-04-LocalMemory.ll b/test/Transforms/FunctionAttrs/2008-10-04-LocalMemory.ll index 0f63c1a..50ca641 100644 --- a/test/Transforms/AddReadAttrs/2008-10-04-LocalMemory.ll +++ b/test/Transforms/FunctionAttrs/2008-10-04-LocalMemory.ll @@ -1,4 +1,4 @@ -; RUN: llvm-as < %s | opt -addreadattrs | llvm-dis | grep readnone | count 2 +; RUN: llvm-as < %s | opt -functionattrs | llvm-dis | grep readnone | count 2 declare i32 @g(i32*) readnone diff --git a/test/Transforms/AddReadAttrs/2008-12-29-Constant.ll b/test/Transforms/FunctionAttrs/2008-12-29-Constant.ll index fe038c1..d9c0117 100644 --- a/test/Transforms/AddReadAttrs/2008-12-29-Constant.ll +++ b/test/Transforms/FunctionAttrs/2008-12-29-Constant.ll @@ -1,4 +1,4 @@ -; RUN: llvm-as < %s | opt -addreadattrs | llvm-dis | grep readnone +; RUN: llvm-as < %s | opt -functionattrs | llvm-dis | grep readnone @s = external constant i8 ; <i8*> [#uses=1] diff --git a/test/Transforms/FunctionAttrs/2008-12-31-NoCapture.ll b/test/Transforms/FunctionAttrs/2008-12-31-NoCapture.ll new file mode 100644 index 0000000..6d2ca1e --- /dev/null +++ b/test/Transforms/FunctionAttrs/2008-12-31-NoCapture.ll @@ -0,0 +1,34 @@ +; RUN: llvm-as < %s | opt -functionattrs | llvm-dis | not grep {@c.*nocapture} +; RUN: llvm-as < %s | opt -functionattrs | llvm-dis | grep nocapture | count 3 +@g = global i32* null ; <i32**> [#uses=1] + +define i32* @c1(i32* %p) { + ret i32* %p +} + +define void @c2(i32* %p) { + store i32* %p, i32** @g + ret void +} + +define void @c3(i32* %p) { + call void @c2(i32* %p) + ret void +} + +define i32 @nc1(i32* %p) { + %tmp = bitcast i32* %p to i32* ; <i32*> [#uses=2] + %val = load i32* %tmp ; <i32> [#uses=1] + store i32 0, i32* %tmp + ret i32 %val +} + +define void @nc2(i32* %p) { + %1 = call i32 @nc1(i32* %p) ; <i32> [#uses=0] + ret void +} + +define void @nc3(void ()* %f) { + call void %f() + ret void +} diff --git a/test/Transforms/AddReadAttrs/dg.exp b/test/Transforms/FunctionAttrs/dg.exp index f200589..f200589 100644 --- a/test/Transforms/AddReadAttrs/dg.exp +++ b/test/Transforms/FunctionAttrs/dg.exp |