From 564fe9092faab46e2b479f4f1a7ee58b04054993 Mon Sep 17 00:00:00 2001 From: Matthijs Kooijman Date: Fri, 20 Jun 2008 15:38:22 +0000 Subject: [PATCH] Add testcase that checks that DeadArgElim doesn't touch stuff it shouldn't touch. llvm-svn: 52540 --- test/Transforms/DeadArgElim/keepalive.ll | 36 ++++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 test/Transforms/DeadArgElim/keepalive.ll diff --git a/test/Transforms/DeadArgElim/keepalive.ll b/test/Transforms/DeadArgElim/keepalive.ll new file mode 100644 index 00000000000..902c6d69cc4 --- /dev/null +++ b/test/Transforms/DeadArgElim/keepalive.ll @@ -0,0 +1,36 @@ +; RUN: llvm-as < %s | opt -deadargelim | llvm-dis > %t +; RUN: cat %t | grep {define internal \{ \} @test} +; RUN: cat %t | grep {define internal \{ i32 \} @test} +; RUN: cat %t | grep {define internal \<\{ i32, i32 \}\> @test} + +; Check if the pass doesn't modify anything that doesn't need changing. We feed +; an unused argument to each function to lure it into changing _something_ about +; the function and then changing to much. + + +; This checks if the struct retval isn't changed into a void +define internal { } @test(i32 %DEADARG1) { + ret { } { } +} + +; This checks if the struct retval isn't removed +define internal {i32} @test1(i32 %DEADARG1) { + ret { i32 } { i32 1 } +} + +; This checks if the struct doesn't get non-packed +define internal <{ i32, i32 }> @test2(i32 %DEADARG1) { + ret <{ i32, i32 }> <{ i32 1, i32 2 }> +} + +; We use this external function to make sure the return values don't become dead +declare void @user({ }, { i32 }, <{ i32, i32 }>) + +define void @caller() { + %A = call { } @test(i32 0) + %B = call { i32 } @test1(i32 1) + %C = call <{ i32, i32 }> @test2(i32 2) + call void @user({ } %A, { i32 } %B, <{ i32, i32 }> %C) + ret void +} +