]> CyberLeo.Net >> Repos - FreeBSD/releng/9.0.git/blob - contrib/compiler-rt/lib/powidf2.c
Copy stable/9 to releng/9.0 as part of the FreeBSD 9.0-RELEASE release
[FreeBSD/releng/9.0.git] / contrib / compiler-rt / lib / powidf2.c
1 /* ===-- powidf2.cpp - Implement __powidf2 ---------------------------------===
2  *
3  *                     The LLVM Compiler Infrastructure
4  *
5  * This file is dual licensed under the MIT and the University of Illinois Open
6  * Source Licenses. See LICENSE.TXT for details.
7  *
8  * ===----------------------------------------------------------------------===
9  *
10  * This file implements __powidf2 for the compiler_rt library.
11  *
12  * ===----------------------------------------------------------------------===
13  */
14 #include "abi.h"
15
16 #include "int_lib.h"
17
18 /* Returns: a ^ b */
19
20 COMPILER_RT_ABI double
21 __powidf2(double a, si_int b)
22 {
23     const int recip = b < 0;
24     double r = 1;
25     while (1)
26     {
27         if (b & 1)
28             r *= a;
29         b /= 2;
30         if (b == 0)
31             break;
32         a *= a;
33     }
34     return recip ? 1/r : r;
35 }