diff options
author | Julien Lerouge <jlerouge@apple.com> | 2014-04-15 18:06:46 +0000 |
---|---|---|
committer | Julien Lerouge <jlerouge@apple.com> | 2014-04-15 18:06:46 +0000 |
commit | be4fe32eb8ad20e47fecf7e85e57c7e522ec5143 (patch) | |
tree | e909fbebe7866d3c9a820d943bc4de21a72b7b84 /llvm/test/Transforms/Inline | |
parent | 957e91c4d8191c186ba41c25c5ad763a569a60f3 (diff) | |
download | bcm5719-llvm-be4fe32eb8ad20e47fecf7e85e57c7e522ec5143.tar.gz bcm5719-llvm-be4fe32eb8ad20e47fecf7e85e57c7e522ec5143.zip |
Add lifetime markers for allocas created to hold byval arguments, make them
appear in the InlineFunctionInfo.
llvm-svn: 206308
Diffstat (limited to 'llvm/test/Transforms/Inline')
-rw-r--r-- | llvm/test/Transforms/Inline/2010-05-31-ByvalTailcall.ll | 3 | ||||
-rw-r--r-- | llvm/test/Transforms/Inline/byval_lifetime.ll | 26 |
2 files changed, 28 insertions, 1 deletions
diff --git a/llvm/test/Transforms/Inline/2010-05-31-ByvalTailcall.ll b/llvm/test/Transforms/Inline/2010-05-31-ByvalTailcall.ll index b37b9f2ffa2..07ea5fc6cc1 100644 --- a/llvm/test/Transforms/Inline/2010-05-31-ByvalTailcall.ll +++ b/llvm/test/Transforms/Inline/2010-05-31-ByvalTailcall.ll @@ -18,7 +18,8 @@ define void @bar(i32* byval %x) { define void @foo(i32* %x) { ; CHECK-LABEL: define void @foo( -; CHECK: store i32 %1, i32* %x +; CHECK: llvm.lifetime.start +; CHECK: store i32 %2, i32* %x call void @bar(i32* byval %x) ret void } diff --git a/llvm/test/Transforms/Inline/byval_lifetime.ll b/llvm/test/Transforms/Inline/byval_lifetime.ll new file mode 100644 index 00000000000..e8dff2aa711 --- /dev/null +++ b/llvm/test/Transforms/Inline/byval_lifetime.ll @@ -0,0 +1,26 @@ +; RUN: opt -S -inline < %s | FileCheck %s +; END. + +; By inlining foo, an alloca is created in main to hold the byval argument, so +; a lifetime marker should be generated as well by default. + +%struct.foo = type { i32, [16 x i32] } + +@gFoo = global %struct.foo zeroinitializer, align 8 + +define i32 @foo(%struct.foo* byval align 8 %f, i32 %a) { +entry: + %a1 = getelementptr inbounds %struct.foo* %f, i32 0, i32 1 + %arrayidx = getelementptr inbounds [16 x i32]* %a1, i32 0, i32 %a + %tmp2 = load i32* %arrayidx, align 1 + ret i32 %tmp2 +} + +define i32 @main(i32 %argc, i8** %argv) { +; CHECK-LABEL: @main +; CHECK: llvm.lifetime.start +; CHECK: memcpy +entry: + %call = call i32 @foo(%struct.foo* byval align 8 @gFoo, i32 %argc) + ret i32 %call +} |