1 //===-- powidf2_test.cpp - Test __powidf2 ---------------------------------===//
3 // The LLVM Compiler Infrastructure
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // This file tests __powidf2 for the compiler_rt library.
12 //===----------------------------------------------------------------------===//
20 double __powidf2(double a
, si_int b
);
22 int test__powidf2(double a
, si_int b
, double expected
)
24 double x
= __powidf2(a
, b
);
25 int correct
= (x
== expected
) && (signbit(x
) == signbit(expected
));
27 printf("error in __powidf2(%f, %d) = %f, expected %f\n",
34 if (test__powidf2(0, 0, 1))
36 if (test__powidf2(1, 0, 1))
38 if (test__powidf2(1.5, 0, 1))
40 if (test__powidf2(2, 0, 1))
42 if (test__powidf2(INFINITY
, 0, 1))
45 if (test__powidf2(-0., 0, 1))
47 if (test__powidf2(-1, 0, 1))
49 if (test__powidf2(-1.5, 0, 1))
51 if (test__powidf2(-2, 0, 1))
53 if (test__powidf2(-INFINITY
, 0, 1))
56 if (test__powidf2(0, 1, 0))
58 if (test__powidf2(0, 2, 0))
60 if (test__powidf2(0, 3, 0))
62 if (test__powidf2(0, 4, 0))
64 if (test__powidf2(0, 0x7FFFFFFE, 0))
66 if (test__powidf2(0, 0x7FFFFFFF, 0))
69 if (test__powidf2(-0., 1, -0.))
71 if (test__powidf2(-0., 2, 0))
73 if (test__powidf2(-0., 3, -0.))
75 if (test__powidf2(-0., 4, 0))
77 if (test__powidf2(-0., 0x7FFFFFFE, 0))
79 if (test__powidf2(-0., 0x7FFFFFFF, -0.))
82 if (test__powidf2(1, 1, 1))
84 if (test__powidf2(1, 2, 1))
86 if (test__powidf2(1, 3, 1))
88 if (test__powidf2(1, 4, 1))
90 if (test__powidf2(1, 0x7FFFFFFE, 1))
92 if (test__powidf2(1, 0x7FFFFFFF, 1))
95 if (test__powidf2(INFINITY
, 1, INFINITY
))
97 if (test__powidf2(INFINITY
, 2, INFINITY
))
99 if (test__powidf2(INFINITY
, 3, INFINITY
))
101 if (test__powidf2(INFINITY
, 4, INFINITY
))
103 if (test__powidf2(INFINITY
, 0x7FFFFFFE, INFINITY
))
105 if (test__powidf2(INFINITY
, 0x7FFFFFFF, INFINITY
))
108 if (test__powidf2(-INFINITY
, 1, -INFINITY
))
110 if (test__powidf2(-INFINITY
, 2, INFINITY
))
112 if (test__powidf2(-INFINITY
, 3, -INFINITY
))
114 if (test__powidf2(-INFINITY
, 4, INFINITY
))
116 if (test__powidf2(-INFINITY
, 0x7FFFFFFE, INFINITY
))
118 if (test__powidf2(-INFINITY
, 0x7FFFFFFF, -INFINITY
))
121 if (test__powidf2(0, -1, INFINITY
))
123 if (test__powidf2(0, -2, INFINITY
))
125 if (test__powidf2(0, -3, INFINITY
))
127 if (test__powidf2(0, -4, INFINITY
))
129 if (test__powidf2(0, 0x80000002, INFINITY
))
131 if (test__powidf2(0, 0x80000001, INFINITY
))
133 if (test__powidf2(0, 0x80000000, INFINITY
))
136 if (test__powidf2(-0., -1, -INFINITY
))
138 if (test__powidf2(-0., -2, INFINITY
))
140 if (test__powidf2(-0., -3, -INFINITY
))
142 if (test__powidf2(-0., -4, INFINITY
))
144 if (test__powidf2(-0., 0x80000002, INFINITY
))
146 if (test__powidf2(-0., 0x80000001, -INFINITY
))
148 if (test__powidf2(-0., 0x80000000, INFINITY
))
151 if (test__powidf2(1, -1, 1))
153 if (test__powidf2(1, -2, 1))
155 if (test__powidf2(1, -3, 1))
157 if (test__powidf2(1, -4, 1))
159 if (test__powidf2(1, 0x80000002, 1))
161 if (test__powidf2(1, 0x80000001, 1))
163 if (test__powidf2(1, 0x80000000, 1))
166 if (test__powidf2(INFINITY
, -1, 0))
168 if (test__powidf2(INFINITY
, -2, 0))
170 if (test__powidf2(INFINITY
, -3, 0))
172 if (test__powidf2(INFINITY
, -4, 0))
174 if (test__powidf2(INFINITY
, 0x80000002, 0))
176 if (test__powidf2(INFINITY
, 0x80000001, 0))
178 if (test__powidf2(INFINITY
, 0x80000000, 0))
181 if (test__powidf2(-INFINITY
, -1, -0.))
183 if (test__powidf2(-INFINITY
, -2, 0))
185 if (test__powidf2(-INFINITY
, -3, -0.))
187 if (test__powidf2(-INFINITY
, -4, 0))
189 if (test__powidf2(-INFINITY
, 0x80000002, 0))
191 if (test__powidf2(-INFINITY
, 0x80000001, -0.))
193 if (test__powidf2(-INFINITY
, 0x80000000, 0))
196 if (test__powidf2(2, 10, 1024.))
198 if (test__powidf2(-2, 10, 1024.))
200 if (test__powidf2(2, -10, 1/1024.))
202 if (test__powidf2(-2, -10, 1/1024.))
205 if (test__powidf2(2, 19, 524288.))
207 if (test__powidf2(-2, 19, -524288.))
209 if (test__powidf2(2, -19, 1/524288.))
211 if (test__powidf2(-2, -19, -1/524288.))
214 if (test__powidf2(2, 31, 2147483648.))
216 if (test__powidf2(-2, 31, -2147483648.))
218 if (test__powidf2(2, -31, 1/2147483648.))
220 if (test__powidf2(-2, -31, -1/2147483648.))