In some rare cases, the register allocator can spill registers but end up not utilizi...
[llvm/msp430.git] / test / Transforms / SCCP / calltest.ll
blobee6eb8e4a803762c9d91c9e76f6d4aec59c48188
1 ; RUN: llvm-as < %s | opt -sccp -loop-deletion -simplifycfg | llvm-dis | \
2 ; RUN:   not grep br
4 ; No matter how hard you try, sqrt(1.0) is always 1.0.  This allows the
5 ; optimizer to delete this loop.
7 declare double @sqrt(double)
9 define double @test(i32 %param) {
10 entry:
11         br label %Loop
12 Loop:           ; preds = %Loop, %entry
13         %I2 = phi i32 [ 0, %entry ], [ %I3, %Loop ]             ; <i32> [#uses=1]
14         %V = phi double [ 1.000000e+00, %entry ], [ %V2, %Loop ]                ; <double> [#uses=2]
15         %V2 = call double @sqrt( double %V )            ; <double> [#uses=1]
16         %I3 = add i32 %I2, 1            ; <i32> [#uses=2]
17         %tmp.7 = icmp ne i32 %I3, %param                ; <i1> [#uses=1]
18         br i1 %tmp.7, label %Loop, label %Exit
19 Exit:           ; preds = %Loop
20         ret double %V