Transform (x << (y&31)) -> (x << y). This takes advantage of the fact x86 shift instr...
[oota-llvm.git] / test / CodeGen / PowerPC / 2008-07-15-Fabs.ll
1 ; RUN: llvm-as < %s | llc
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"
4
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 = sub ppc_fp128 0xM00000000000000000000000000000000, %.pn106               ; <ppc_fp128> [#uses=1]
11         %y.0 = fdiv ppc_fp128 %.pn, 0xM00000000000000000000000000000000         ; <ppc_fp128> [#uses=1]
12         mul ppc_fp128 %y.0, 0xM3FF00000000000000000000000000000         ; <ppc_fp128>:2 [#uses=1]
13         add ppc_fp128 %2, mul (ppc_fp128 0xM00000000000000000000000000000000, ppc_fp128 0xM00000000000000000000000000000000)            ; <ppc_fp128>:3 [#uses=1]
14         %tmpi = add ppc_fp128 %3, 0xM00000000000000000000000000000000           ; <ppc_fp128> [#uses=1]
15         store ppc_fp128 %tmpi, ppc_fp128* null, align 16
16         ret i256 0
17 }
18
19 declare ppc_fp128 @fabsl(ppc_fp128) nounwind readnone