1 // RUN: %clang_builtins %s %librt -o %t && %run %t
2 // REQUIRES: librt_has_powitf2
6 #if __LDBL_MANT_DIG__ == 113
13 COMPILER_RT_ABI
long double __powitf2(long double a
, int b
);
15 int test__powitf2(long double a
, int b
, long double expected
)
17 long double x
= __powitf2(a
, b
);
18 int correct
= (x
== expected
) && (signbit(x
) == signbit(expected
));
20 printf("error in __powitf2(%Lf, %d) = %Lf, expected %Lf\n",
29 #if __LDBL_MANT_DIG__ == 113
30 if (test__powitf2(0, 0, 1))
32 if (test__powitf2(1, 0, 1))
34 if (test__powitf2(1.5, 0, 1))
36 if (test__powitf2(2, 0, 1))
38 if (test__powitf2(INFINITY
, 0, 1))
41 if (test__powitf2(-0., 0, 1))
43 if (test__powitf2(-1, 0, 1))
45 if (test__powitf2(-1.5, 0, 1))
47 if (test__powitf2(-2, 0, 1))
49 if (test__powitf2(-INFINITY
, 0, 1))
52 if (test__powitf2(0, 1, 0))
54 if (test__powitf2(0, 2, 0))
56 if (test__powitf2(0, 3, 0))
58 if (test__powitf2(0, 4, 0))
60 if (test__powitf2(0, INT_MAX
- 1, 0))
62 if (test__powitf2(0, INT_MAX
, 0))
65 if (test__powitf2(-0., 1, -0.))
67 if (test__powitf2(-0., 2, 0))
69 if (test__powitf2(-0., 3, -0.))
71 if (test__powitf2(-0., 4, 0))
73 if (test__powitf2(-0., INT_MAX
- 1, 0))
75 if (test__powitf2(-0., INT_MAX
, -0.))
78 if (test__powitf2(1, 1, 1))
80 if (test__powitf2(1, 2, 1))
82 if (test__powitf2(1, 3, 1))
84 if (test__powitf2(1, 4, 1))
86 if (test__powitf2(1, INT_MAX
- 1, 1))
88 if (test__powitf2(1, INT_MAX
, 1))
91 if (test__powitf2(INFINITY
, 1, INFINITY
))
93 if (test__powitf2(INFINITY
, 2, INFINITY
))
95 if (test__powitf2(INFINITY
, 3, INFINITY
))
97 if (test__powitf2(INFINITY
, 4, INFINITY
))
99 if (test__powitf2(INFINITY
, INT_MAX
- 1, INFINITY
))
101 if (test__powitf2(INFINITY
, INT_MAX
, INFINITY
))
104 if (test__powitf2(-INFINITY
, 1, -INFINITY
))
106 if (test__powitf2(-INFINITY
, 2, INFINITY
))
108 if (test__powitf2(-INFINITY
, 3, -INFINITY
))
110 if (test__powitf2(-INFINITY
, 4, INFINITY
))
112 if (test__powitf2(-INFINITY
, INT_MAX
- 1, INFINITY
))
114 if (test__powitf2(-INFINITY
, INT_MAX
, -INFINITY
))
117 if (test__powitf2(0, -1, INFINITY
))
119 if (test__powitf2(0, -2, INFINITY
))
121 if (test__powitf2(0, -3, INFINITY
))
123 if (test__powitf2(0, -4, INFINITY
))
125 if (test__powitf2(0, INT_MIN
+ 2, INFINITY
))
127 if (test__powitf2(0, INT_MIN
+ 1, INFINITY
))
129 if (test__powitf2(0, INT_MIN
, INFINITY
))
132 if (test__powitf2(-0., -1, -INFINITY
))
134 if (test__powitf2(-0., -2, INFINITY
))
136 if (test__powitf2(-0., -3, -INFINITY
))
138 if (test__powitf2(-0., -4, INFINITY
))
140 if (test__powitf2(-0., INT_MIN
+ 2, INFINITY
))
142 if (test__powitf2(-0., INT_MIN
+ 1, -INFINITY
))
144 if (test__powitf2(-0., INT_MIN
, INFINITY
))
147 if (test__powitf2(1, -1, 1))
149 if (test__powitf2(1, -2, 1))
151 if (test__powitf2(1, -3, 1))
153 if (test__powitf2(1, -4, 1))
155 if (test__powitf2(1, INT_MIN
+ 2, 1))
157 if (test__powitf2(1, INT_MIN
+ 1, 1))
159 if (test__powitf2(1, INT_MIN
, 1))
162 if (test__powitf2(INFINITY
, -1, 0))
164 if (test__powitf2(INFINITY
, -2, 0))
166 if (test__powitf2(INFINITY
, -3, 0))
168 if (test__powitf2(INFINITY
, -4, 0))
170 if (test__powitf2(INFINITY
, INT_MIN
+ 2, 0))
172 if (test__powitf2(INFINITY
, INT_MIN
+ 1, 0))
174 if (test__powitf2(INFINITY
, INT_MIN
, 0))
177 if (test__powitf2(-INFINITY
, -1, -0.))
179 if (test__powitf2(-INFINITY
, -2, 0))
181 if (test__powitf2(-INFINITY
, -3, -0.))
183 if (test__powitf2(-INFINITY
, -4, 0))
185 if (test__powitf2(-INFINITY
, INT_MIN
+ 2, 0))
187 if (test__powitf2(-INFINITY
, INT_MIN
+ 1, -0.))
189 if (test__powitf2(-INFINITY
, INT_MIN
, 0))
192 if (test__powitf2(2, 10, 1024.))
194 if (test__powitf2(-2, 10, 1024.))
196 if (test__powitf2(2, -10, 1/1024.))
198 if (test__powitf2(-2, -10, 1/1024.))
201 if (test__powitf2(2, 19, 524288.))
203 if (test__powitf2(-2, 19, -524288.))
205 if (test__powitf2(2, -19, 1/524288.))
207 if (test__powitf2(-2, -19, -1/524288.))
210 if (test__powitf2(2, 31, 2147483648.))
212 if (test__powitf2(-2, 31, -2147483648.))
214 if (test__powitf2(2, -31, 1/2147483648.))
216 if (test__powitf2(-2, -31, -1/2147483648.))