1 /* w_powl.c -- long double version of w_pow.c.
2 * Conversion to long double by Ulrich Drepper,
3 * Cygnus Support, drepper@cygnus.com.
7 * ====================================================
8 * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
10 * Developed at SunPro, a Sun Microsystems, Inc. business.
11 * Permission to use, copy, modify, and distribute this
12 * software is freely granted, provided that this notice
14 * ====================================================
18 * wrapper powl(x,y) return x**y
22 #include "math_private.h"
26 long double __powl(long double x
, long double y
)/* wrapper powl */
28 long double __powl(x
,y
) /* wrapper powl */
33 return __ieee754_powl(x
,y
);
36 z
=__ieee754_powl(x
,y
);
37 if(_LIB_VERSION
== _IEEE_
|| __isnanl(y
)) return z
;
40 return __kernel_standard(x
,y
,242); /* pow(NaN,0.0) */
46 return __kernel_standard(x
,y
,220); /* pow(0.0,0.0) */
47 if(__finitel(y
)&&y
<0.0) {
48 if (signbit (x
) && signbit (z
))
49 return __kernel_standard(x
,y
,223); /* pow(-0.0,negative) */
51 return __kernel_standard(x
,y
,243); /* pow(+0.0,negative) */
56 if(__finitel(x
)&&__finitel(y
)) {
58 return __kernel_standard(x
,y
,224); /* pow neg**non-int */
60 return __kernel_standard(x
,y
,221); /* pow overflow */
63 if(z
==0.0&&__finitel(x
)&&__finitel(y
))
64 return __kernel_standard(x
,y
,222); /* pow underflow */
68 weak_alias (__powl
, powl
)