summaryrefslogtreecommitdiff
path: root/test/Transforms/SCCP/apint-load.ll
diff options
context:
space:
mode:
authorReid Spencer <rspencer@reidspencer.com>2007-04-13 22:33:10 +0000
committerReid Spencer <rspencer@reidspencer.com>2007-04-13 22:33:10 +0000
commitc6b9efabee934041f6461c4af255db9a0fd4a5d1 (patch)
tree514104dfaa098e795ef0856b95ad63ad4629e644 /test/Transforms/SCCP/apint-load.ll
parent4dcedf1e8505a094b031d3a72033a886c0e53da1 (diff)
downloadllvm-c6b9efabee934041f6461c4af255db9a0fd4a5d1.tar.gz
llvm-c6b9efabee934041f6461c4af255db9a0fd4a5d1.tar.bz2
llvm-c6b9efabee934041f6461c4af255db9a0fd4a5d1.tar.xz
Add the SCCP regression tests for APInt expressions. These test cases
turned up some regressions that have since been fixed. We don't want to loose the regression tests. Test cases by Guoling Han. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@35974 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Transforms/SCCP/apint-load.ll')
-rw-r--r--test/Transforms/SCCP/apint-load.ll38
1 files changed, 38 insertions, 0 deletions
diff --git a/test/Transforms/SCCP/apint-load.ll b/test/Transforms/SCCP/apint-load.ll
new file mode 100644
index 0000000000..b943236205
--- /dev/null
+++ b/test/Transforms/SCCP/apint-load.ll
@@ -0,0 +1,38 @@
+; This test makes sure that these instructions are properly constant propagated.
+;
+
+; RUN: llvm-as < %s | opt -ipsccp | llvm-dis -o /dev/null -f &&
+; RUN: llvm-as < %s | opt -ipsccp | llvm-dis | not grep load
+; RUN: llvm-as < %s | opt -ipsccp | llvm-dis | not grep fdiv
+
+@X = constant i212 42
+@Y = constant [2 x { i212, float }] [ { i212, float } { i212 12, float 1.0 },
+ { i212, float } { i212 37, float 1.2312 } ]
+define i212 @test1() {
+ %B = load i212* @X
+ ret i212 %B
+}
+
+define internal float @test2() {
+ %A = getelementptr [2 x { i212, float}]* @Y, i32 0, i32 1, i32 1
+ %B = load float* %A
+ ret float %B
+}
+
+define internal i212 @test3() {
+ %A = getelementptr [2 x { i212, float}]* @Y, i32 0, i32 0, i32 0
+ %B = load i212* %A
+ ret i212 %B
+}
+
+define float @All()
+{
+ %A = call float @test2()
+ %B = call i212 @test3()
+ %C = mul i212 %B, -1234567
+ %D = sitofp i212 %C to float
+ %E = fdiv float %A, %D
+ ret float %E
+}
+
+