Add default architecture.
[oota-llvm.git] / test / Transforms / SCCP / calltest.ll
index e88914d8dc8f6dc021a02a6ec1a4e41fb465ab7b..ee6eb8e4a803762c9d91c9e76f6d4aec59c48188 100644 (file)
@@ -1,24 +1,22 @@
-; RUN: llvm-as < %s | opt -sccp -adce -simplifycfg | llvm-dis | not grep br
+; RUN: llvm-as < %s | opt -sccp -loop-deletion -simplifycfg | llvm-dis | \
+; RUN:   not grep br
 
 ; No matter how hard you try, sqrt(1.0) is always 1.0.  This allows the
 ; optimizer to delete this loop.
 
-declare double %sqrt(double)
+declare double @sqrt(double)
 
-double %test(uint %param) {
+define double @test(i32 %param) {
 entry:
        br label %Loop
-
-Loop:
-       %I2 = phi uint [ 0, %entry ], [ %I3, %Loop ]
-       %V  = phi double [ 1.0, %entry], [ %V2, %Loop ]
-
-       %V2 = call double %sqrt(double %V)
-
-       %I3 = add uint %I2, 1
-       %tmp.7 = setne uint %I3, %param
-       br bool %tmp.7, label %Loop, label %Exit
-
-Exit:
+Loop:          ; preds = %Loop, %entry
+       %I2 = phi i32 [ 0, %entry ], [ %I3, %Loop ]             ; <i32> [#uses=1]
+       %V = phi double [ 1.000000e+00, %entry ], [ %V2, %Loop ]                ; <double> [#uses=2]
+       %V2 = call double @sqrt( double %V )            ; <double> [#uses=1]
+       %I3 = add i32 %I2, 1            ; <i32> [#uses=2]
+       %tmp.7 = icmp ne i32 %I3, %param                ; <i1> [#uses=1]
+       br i1 %tmp.7, label %Loop, label %Exit
+Exit:          ; preds = %Loop
        ret double %V
 }
+