Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / ExecutionEngine / test-fp.ll
blob4ebcf6f7aa7c196cd81286f6029ec62ef1a03469
1 ; RUN: llvm-as %s -o %t.bc
2 ; RUN: lli %t.bc > /dev/null
4 define double @test(double* %DP, double %Arg) {
5         %D = load double* %DP           ; <double> [#uses=1]
6         %V = fadd double %D, 1.000000e+00               ; <double> [#uses=2]
7         %W = fsub double %V, %V         ; <double> [#uses=3]
8         %X = fmul double %W, %W         ; <double> [#uses=2]
9         %Y = fdiv double %X, %X         ; <double> [#uses=2]
10         %Z = frem double %Y, %Y         ; <double> [#uses=3]
11         %Z1 = fdiv double %Z, %W                ; <double> [#uses=0]
12         %Q = fadd double %Z, %Arg               ; <double> [#uses=1]
13         %R = bitcast double %Q to double                ; <double> [#uses=1]
14         store double %R, double* %DP
15         ret double %Z
18 define i32 @main() {
19         %X = alloca double              ; <double*> [#uses=2]
20         store double 0.000000e+00, double* %X
21         call double @test( double* %X, double 2.000000e+00 )            ; <double>:1 [#uses=0]
22         ret i32 0