diff options
author | Nick Lewycky <nicholas@mxc.ca> | 2014-07-14 18:52:02 +0000 |
---|---|---|
committer | Nick Lewycky <nicholas@mxc.ca> | 2014-07-14 18:52:02 +0000 |
commit | 703e488ed9229ac50a54c69f207074e7ec0715bd (patch) | |
tree | 90f71c39d5a340714f87f54c9a7a81c3bf8698bd /llvm/test/Transforms/MemCpyOpt/capturing-func.ll | |
parent | 0e767b16f92174dfa831fc7bd910394dddbb6016 (diff) | |
download | bcm5719-llvm-703e488ed9229ac50a54c69f207074e7ec0715bd.tar.gz bcm5719-llvm-703e488ed9229ac50a54c69f207074e7ec0715bd.zip |
Don't eliminate memcpy's when the address of the pointer may itself be relevant. Fixes PR18304. Patch by David Wiberg!
llvm-svn: 212970
Diffstat (limited to 'llvm/test/Transforms/MemCpyOpt/capturing-func.ll')
-rw-r--r-- | llvm/test/Transforms/MemCpyOpt/capturing-func.ll | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/llvm/test/Transforms/MemCpyOpt/capturing-func.ll b/llvm/test/Transforms/MemCpyOpt/capturing-func.ll new file mode 100644 index 00000000000..17614fd181d --- /dev/null +++ b/llvm/test/Transforms/MemCpyOpt/capturing-func.ll @@ -0,0 +1,22 @@ +; RUN: opt < %s -basicaa -memcpyopt -S | FileCheck %s + +target datalayout = "e" + +declare void @foo(i8*) +declare void @llvm.memcpy.p0i8.p0i8.i32(i8* nocapture, i8* nocapture, i32, i32, i1) nounwind + +define void @test() { + %ptr1 = alloca i8 + %ptr2 = alloca i8 + call void @foo(i8* %ptr2) + call void @llvm.memcpy.p0i8.p0i8.i32(i8* %ptr1, i8* %ptr2, i32 1, i32 1, i1 false) + call void @foo(i8* %ptr1) + ret void + + ; Check that the transformation isn't applied if the called function can + ; capture the pointer argument (i.e. the nocapture attribute isn't present) + ; CHECK-LABEL: @test( + ; CHECK: call void @foo(i8* %ptr2) + ; CHECK-NEXT: call void @llvm.memcpy + ; CHECK-NEXT: call void @foo(i8* %ptr1) +} |