Teach ScalarEvolution how to reason about no-wrap flags on loops
[llvm/avr.git] / test / CodeGen / PowerPC / 2008-07-15-Fabs.ll
blob17737d9d3b2dfcab1f4abe57f09da539e9d5f9fa
1 ; RUN: llc < %s
2 target datalayout = "E-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f128:64:128"
3 target triple = "powerpc-apple-darwin9"
5 define hidden i256 @__divtc3(ppc_fp128 %a, ppc_fp128 %b, ppc_fp128 %c, ppc_fp128 %d) nounwind readnone  {
6 entry:
7         call ppc_fp128 @fabsl( ppc_fp128 %d ) nounwind readnone                 ; <ppc_fp128>:0 [#uses=1]
8         fcmp olt ppc_fp128 0xM00000000000000000000000000000000, %0              ; <i1>:1 [#uses=1]
9         %.pn106 = select i1 %1, ppc_fp128 %a, ppc_fp128 0xM00000000000000000000000000000000             ; <ppc_fp128> [#uses=1]
10         %.pn = fsub ppc_fp128 0xM00000000000000000000000000000000, %.pn106              ; <ppc_fp128> [#uses=1]
11         %y.0 = fdiv ppc_fp128 %.pn, 0xM00000000000000000000000000000000         ; <ppc_fp128> [#uses=1]
12         fmul ppc_fp128 %y.0, 0xM3FF00000000000000000000000000000                ; <ppc_fp128>:2 [#uses=1]
13         fadd ppc_fp128 %2, fmul (ppc_fp128 0xM00000000000000000000000000000000, ppc_fp128 0xM00000000000000000000000000000000)          ; <ppc_fp128>:3 [#uses=1]
14         %tmpi = fadd ppc_fp128 %3, 0xM00000000000000000000000000000000          ; <ppc_fp128> [#uses=1]
15         store ppc_fp128 %tmpi, ppc_fp128* null, align 16
16         ret i256 0
19 declare ppc_fp128 @fabsl(ppc_fp128) nounwind readnone