summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/SCCP
diff options
context:
space:
mode:
authorEli Friedman <eli.friedman@gmail.com>2011-08-31 21:37:06 +0000
committerEli Friedman <eli.friedman@gmail.com>2011-08-31 21:37:06 +0000
commit293c31b81c0b486558eb24e235aa669b3f474718 (patch)
tree78b689a04e70955488dfe89b0929bb4dc0880fb2 /llvm/test/Transforms/SCCP
parent7df940d66080a35d321da6ad4ad151c8271feaed (diff)
downloadbcm5719-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.ll30
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
OpenPOWER on IntegriCloud