diff options
author | Ed Schouten <ed@FreeBSD.org> | 2009-06-02 17:52:33 +0000 |
---|---|---|
committer | Ed Schouten <ed@FreeBSD.org> | 2009-06-02 17:52:33 +0000 |
commit | 009b1c42aa6266385f2c37e227516b24077e6dd7 (patch) | |
tree | 64ba909838c23261cace781ece27d106134ea451 /test/Analysis/GlobalsModRef/purecse.ll |
Diffstat (limited to 'test/Analysis/GlobalsModRef/purecse.ll')
-rw-r--r-- | test/Analysis/GlobalsModRef/purecse.ll | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/test/Analysis/GlobalsModRef/purecse.ll b/test/Analysis/GlobalsModRef/purecse.ll new file mode 100644 index 0000000000000..dc3f6adda1435 --- /dev/null +++ b/test/Analysis/GlobalsModRef/purecse.ll @@ -0,0 +1,23 @@ +; Test that pure functions are cse'd away +; RUN: llvm-as < %s | opt -globalsmodref-aa -gvn -instcombine | \ +; RUN: llvm-dis | not grep sub + +define i32 @pure(i32 %X) { + %Y = add i32 %X, 1 ; <i32> [#uses=1] + ret i32 %Y +} + +define i32 @test1(i32 %X) { + %A = call i32 @pure( i32 %X ) ; <i32> [#uses=1] + %B = call i32 @pure( i32 %X ) ; <i32> [#uses=1] + %C = sub i32 %A, %B ; <i32> [#uses=1] + ret i32 %C +} + +define i32 @test2(i32 %X, i32* %P) { + %A = call i32 @pure( i32 %X ) ; <i32> [#uses=1] + store i32 %X, i32* %P ;; Does not invalidate 'pure' call. + %B = call i32 @pure( i32 %X ) ; <i32> [#uses=1] + %C = sub i32 %A, %B ; <i32> [#uses=1] + ret i32 %C +} |