diff options
author | Matthijs Kooijman <matthijs@stdin.nl> | 2008-06-24 16:30:26 +0000 |
---|---|---|
committer | Matthijs Kooijman <matthijs@stdin.nl> | 2008-06-24 16:30:26 +0000 |
commit | 1d9a27776101ed4c2b71b6b910803c63100209f4 (patch) | |
tree | 2c4bacdf5aa354e749226768f75c51453933edbf /test/Transforms/DeadArgElim/multdeadretval.ll | |
parent | 5b80c663e7662fcf24c764f0cd1b2671958689b8 (diff) | |
download | external_llvm-1d9a27776101ed4c2b71b6b910803c63100209f4.zip external_llvm-1d9a27776101ed4c2b71b6b910803c63100209f4.tar.gz external_llvm-1d9a27776101ed4c2b71b6b910803c63100209f4.tar.bz2 |
Commit the new DeadArgElim pass again, this time with the gcc bootstrap failures fixed.
Also add a testcase to reproduce the gcc bootstrap failure in very much reduced form.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@52677 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Transforms/DeadArgElim/multdeadretval.ll')
-rw-r--r-- | test/Transforms/DeadArgElim/multdeadretval.ll | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/test/Transforms/DeadArgElim/multdeadretval.ll b/test/Transforms/DeadArgElim/multdeadretval.ll new file mode 100644 index 0000000..bccd0df --- /dev/null +++ b/test/Transforms/DeadArgElim/multdeadretval.ll @@ -0,0 +1,39 @@ +; This test sees if return values (and arguments) are properly removed when they +; are unused. All unused values are typed i16, so we can easily check. We also +; run instcombine to fold insert/extractvalue chains and we run dce to clean up +; any remaining dead stuff. +; RUN: llvm-as < %s | opt -deadargelim -instcombine -dce | llvm-dis | not grep i16 + +define internal {i16, i32} @test(i16 %DEADARG) { + %A = insertvalue {i16,i32} undef, i16 1, 0 + %B = insertvalue {i16,i32} %A, i32 1001, 1 + ret {i16,i32} %B +} + +define internal {i32, i16} @test2() { + %DEAD = call i16 @test4() + %A = insertvalue {i32,i16} undef, i32 1, 0 + %B = insertvalue {i32,i16} %A, i16 %DEAD, 1 + ret {i32,i16} %B +} + +define internal i32 @test3(i16 %A) { + %ret = call {i16, i32} @test( i16 %A ) ; <i32> [#uses=0] + %DEAD = extractvalue {i16, i32} %ret, 0 + %LIVE = extractvalue {i16, i32} %ret, 1 + ret i32 %LIVE +} + +define internal i16 @test4() { + ret i16 0 +} + +define i32 @main() { + %ret = call {i32, i16} @test2() ; <i32> [#uses=1] + %LIVE = extractvalue {i32, i16} %ret, 0 + %DEAD = extractvalue {i32, i16} %ret, 1 + %Y = add i32 %LIVE, -123 ; <i32> [#uses=1] + %LIVE2 = call i32 @test3(i16 %DEAD) ; <i32> [#uses=1] + %Z = add i32 %LIVE2, %Y ; <i32> [#uses=1] + ret i32 %Z +} |