diff options
| author | Eli Friedman <eli.friedman@gmail.com> | 2011-08-31 21:37:06 +0000 |
|---|---|---|
| committer | Eli Friedman <eli.friedman@gmail.com> | 2011-08-31 21:37:06 +0000 |
| commit | 293c31b81c0b486558eb24e235aa669b3f474718 (patch) | |
| tree | 78b689a04e70955488dfe89b0929bb4dc0880fb2 /llvm/test/Transforms/SCCP | |
| parent | 7df940d66080a35d321da6ad4ad151c8271feaed (diff) | |
| download | bcm5719-llvm-293c31b81c0b486558eb24e235aa669b3f474718.tar.gz bcm5719-llvm-293c31b81c0b486558eb24e235aa669b3f474718.zip | |
Add tests for the transformations SCCP can do on atomic loads and stores (which are safe without any modifications).
llvm-svn: 138902
Diffstat (limited to 'llvm/test/Transforms/SCCP')
| -rw-r--r-- | llvm/test/Transforms/SCCP/atomic-load-store.ll | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/llvm/test/Transforms/SCCP/atomic-load-store.ll b/llvm/test/Transforms/SCCP/atomic-load-store.ll new file mode 100644 index 00000000000..f4ce01930cf --- /dev/null +++ b/llvm/test/Transforms/SCCP/atomic-load-store.ll @@ -0,0 +1,30 @@ +; RUN: opt < %s -ipsccp -S | FileCheck %s + +; This transformation is safe for atomic loads and stores; check that it works. + +@G = internal global i32 17 +@C = internal constant i32 222 + +define i32 @test1() { + %V = load atomic i32* @G seq_cst, align 4 + %C = icmp eq i32 %V, 17 + br i1 %C, label %T, label %F +T: + store atomic i32 17, i32* @G seq_cst, align 4 + ret i32 %V +F: + store atomic i32 123, i32* @G seq_cst, align 4 + ret i32 0 +} +; CHECK: define i32 @test1 +; CHECK-NOT: store +; CHECK: ret i32 17 + +define i32 @test2() { + %V = load atomic i32* @C seq_cst, align 4 + ret i32 %V +} + +; CHECK: define i32 @test2 +; CHECK-NOT: load +; CHECK: ret i32 222
\ No newline at end of file |

