1 //===-- powitf2_test.cpp - Test __powitf2 ---------------------------------===//
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 __powitf2 for the compiler_rt library.
12 //===----------------------------------------------------------------------===//
22 long double __powitf2(long double a
, si_int b
);
24 int test__powitf2(long double a
, si_int b
, long double expected
)
26 long double x
= __powitf2(a
, b
);
27 int correct
= (x
== expected
) && (signbit(x
) == signbit(expected
));
29 printf("error in __powitf2(%Lf, %d) = %Lf, expected %Lf\n",
39 if (test__powitf2(0, 0, 1))
41 if (test__powitf2(1, 0, 1))
43 if (test__powitf2(1.5, 0, 1))
45 if (test__powitf2(2, 0, 1))
47 if (test__powitf2(INFINITY
, 0, 1))
50 if (test__powitf2(-0., 0, 1))
52 if (test__powitf2(-1, 0, 1))
54 if (test__powitf2(-1.5, 0, 1))
56 if (test__powitf2(-2, 0, 1))
58 if (test__powitf2(-INFINITY
, 0, 1))
61 if (test__powitf2(0, 1, 0))
63 if (test__powitf2(0, 2, 0))
65 if (test__powitf2(0, 3, 0))
67 if (test__powitf2(0, 4, 0))
69 if (test__powitf2(0, 0x7FFFFFFE, 0))
71 if (test__powitf2(0, 0x7FFFFFFF, 0))
74 if (test__powitf2(-0., 1, -0.))
76 if (test__powitf2(-0., 2, 0))
78 if (test__powitf2(-0., 3, -0.))
80 if (test__powitf2(-0., 4, 0))
82 if (test__powitf2(-0., 0x7FFFFFFE, 0))
84 if (test__powitf2(-0., 0x7FFFFFFF, -0.))
87 if (test__powitf2(1, 1, 1))
89 if (test__powitf2(1, 2, 1))
91 if (test__powitf2(1, 3, 1))
93 if (test__powitf2(1, 4, 1))
95 if (test__powitf2(1, 0x7FFFFFFE, 1))
97 if (test__powitf2(1, 0x7FFFFFFF, 1))
100 if (test__powitf2(INFINITY
, 1, INFINITY
))
102 if (test__powitf2(INFINITY
, 2, INFINITY
))
104 if (test__powitf2(INFINITY
, 3, INFINITY
))
106 if (test__powitf2(INFINITY
, 4, INFINITY
))
108 if (test__powitf2(INFINITY
, 0x7FFFFFFE, INFINITY
))
110 if (test__powitf2(INFINITY
, 0x7FFFFFFF, INFINITY
))
113 if (test__powitf2(-INFINITY
, 1, -INFINITY
))
115 if (test__powitf2(-INFINITY
, 2, INFINITY
))
117 if (test__powitf2(-INFINITY
, 3, -INFINITY
))
119 if (test__powitf2(-INFINITY
, 4, INFINITY
))
121 if (test__powitf2(-INFINITY
, 0x7FFFFFFE, INFINITY
))
123 if (test__powitf2(-INFINITY
, 0x7FFFFFFF, -INFINITY
))
126 if (test__powitf2(0, -1, INFINITY
))
128 if (test__powitf2(0, -2, INFINITY
))
130 if (test__powitf2(0, -3, INFINITY
))
132 if (test__powitf2(0, -4, INFINITY
))
134 if (test__powitf2(0, 0x80000002, INFINITY
))
136 if (test__powitf2(0, 0x80000001, INFINITY
))
138 if (test__powitf2(0, 0x80000000, INFINITY
))
141 if (test__powitf2(-0., -1, -INFINITY
))
143 if (test__powitf2(-0., -2, INFINITY
))
145 if (test__powitf2(-0., -3, -INFINITY
))
147 if (test__powitf2(-0., -4, INFINITY
))
149 if (test__powitf2(-0., 0x80000002, INFINITY
))
151 if (test__powitf2(-0., 0x80000001, -INFINITY
))
153 if (test__powitf2(-0., 0x80000000, INFINITY
))
156 if (test__powitf2(1, -1, 1))
158 if (test__powitf2(1, -2, 1))
160 if (test__powitf2(1, -3, 1))
162 if (test__powitf2(1, -4, 1))
164 if (test__powitf2(1, 0x80000002, 1))
166 if (test__powitf2(1, 0x80000001, 1))
168 if (test__powitf2(1, 0x80000000, 1))
171 if (test__powitf2(INFINITY
, -1, 0))
173 if (test__powitf2(INFINITY
, -2, 0))
175 if (test__powitf2(INFINITY
, -3, 0))
177 if (test__powitf2(INFINITY
, -4, 0))
179 if (test__powitf2(INFINITY
, 0x80000002, 0))
181 if (test__powitf2(INFINITY
, 0x80000001, 0))
183 if (test__powitf2(INFINITY
, 0x80000000, 0))
186 if (test__powitf2(-INFINITY
, -1, -0.))
188 if (test__powitf2(-INFINITY
, -2, 0))
190 if (test__powitf2(-INFINITY
, -3, -0.))
192 if (test__powitf2(-INFINITY
, -4, 0))
194 if (test__powitf2(-INFINITY
, 0x80000002, 0))
196 if (test__powitf2(-INFINITY
, 0x80000001, -0.))
198 if (test__powitf2(-INFINITY
, 0x80000000, 0))
201 if (test__powitf2(2, 10, 1024.))
203 if (test__powitf2(-2, 10, 1024.))
205 if (test__powitf2(2, -10, 1/1024.))
207 if (test__powitf2(-2, -10, 1/1024.))
210 if (test__powitf2(2, 19, 524288.))
212 if (test__powitf2(-2, 19, -524288.))
214 if (test__powitf2(2, -19, 1/524288.))
216 if (test__powitf2(-2, -19, -1/524288.))
219 if (test__powitf2(2, 31, 2147483648.))
221 if (test__powitf2(-2, 31, -2147483648.))
223 if (test__powitf2(2, -31, 1/2147483648.))
225 if (test__powitf2(-2, -31, -1/2147483648.))