Mercurial > hg > CbC > CbC_gcc
comparison gcc/config/fp-bit.c @ 0:a06113de4d67
first commit
author | kent <kent@cr.ie.u-ryukyu.ac.jp> |
---|---|
date | Fri, 17 Jul 2009 14:47:48 +0900 |
parents | |
children | f6334be47118 |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:a06113de4d67 |
---|---|
1 /* This is a software floating point library which can be used | |
2 for targets without hardware floating point. | |
3 Copyright (C) 1994, 1995, 1996, 1997, 1998, 2000, 2001, 2002, 2003, | |
4 2004, 2005, 2008, 2009 Free Software Foundation, Inc. | |
5 | |
6 This file is part of GCC. | |
7 | |
8 GCC is free software; you can redistribute it and/or modify it under | |
9 the terms of the GNU General Public License as published by the Free | |
10 Software Foundation; either version 3, or (at your option) any later | |
11 version. | |
12 | |
13 GCC is distributed in the hope that it will be useful, but WITHOUT ANY | |
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
16 for more details. | |
17 | |
18 Under Section 7 of GPL version 3, you are granted additional | |
19 permissions described in the GCC Runtime Library Exception, version | |
20 3.1, as published by the Free Software Foundation. | |
21 | |
22 You should have received a copy of the GNU General Public License and | |
23 a copy of the GCC Runtime Library Exception along with this program; | |
24 see the files COPYING3 and COPYING.RUNTIME respectively. If not, see | |
25 <http://www.gnu.org/licenses/>. */ | |
26 | |
27 /* This implements IEEE 754 format arithmetic, but does not provide a | |
28 mechanism for setting the rounding mode, or for generating or handling | |
29 exceptions. | |
30 | |
31 The original code by Steve Chamberlain, hacked by Mark Eichin and Jim | |
32 Wilson, all of Cygnus Support. */ | |
33 | |
34 /* The intended way to use this file is to make two copies, add `#define FLOAT' | |
35 to one copy, then compile both copies and add them to libgcc.a. */ | |
36 | |
37 #include "tconfig.h" | |
38 #include "coretypes.h" | |
39 #include "tm.h" | |
40 #include "config/fp-bit.h" | |
41 | |
42 /* The following macros can be defined to change the behavior of this file: | |
43 FLOAT: Implement a `float', aka SFmode, fp library. If this is not | |
44 defined, then this file implements a `double', aka DFmode, fp library. | |
45 FLOAT_ONLY: Used with FLOAT, to implement a `float' only library, i.e. | |
46 don't include float->double conversion which requires the double library. | |
47 This is useful only for machines which can't support doubles, e.g. some | |
48 8-bit processors. | |
49 CMPtype: Specify the type that floating point compares should return. | |
50 This defaults to SItype, aka int. | |
51 US_SOFTWARE_GOFAST: This makes all entry points use the same names as the | |
52 US Software goFast library. | |
53 _DEBUG_BITFLOAT: This makes debugging the code a little easier, by adding | |
54 two integers to the FLO_union_type. | |
55 NO_DENORMALS: Disable handling of denormals. | |
56 NO_NANS: Disable nan and infinity handling | |
57 SMALL_MACHINE: Useful when operations on QIs and HIs are faster | |
58 than on an SI */ | |
59 | |
60 /* We don't currently support extended floats (long doubles) on machines | |
61 without hardware to deal with them. | |
62 | |
63 These stubs are just to keep the linker from complaining about unresolved | |
64 references which can be pulled in from libio & libstdc++, even if the | |
65 user isn't using long doubles. However, they may generate an unresolved | |
66 external to abort if abort is not used by the function, and the stubs | |
67 are referenced from within libc, since libgcc goes before and after the | |
68 system library. */ | |
69 | |
70 #ifdef DECLARE_LIBRARY_RENAMES | |
71 DECLARE_LIBRARY_RENAMES | |
72 #endif | |
73 | |
74 #ifdef EXTENDED_FLOAT_STUBS | |
75 extern void abort (void); | |
76 void __extendsfxf2 (void) { abort(); } | |
77 void __extenddfxf2 (void) { abort(); } | |
78 void __truncxfdf2 (void) { abort(); } | |
79 void __truncxfsf2 (void) { abort(); } | |
80 void __fixxfsi (void) { abort(); } | |
81 void __floatsixf (void) { abort(); } | |
82 void __addxf3 (void) { abort(); } | |
83 void __subxf3 (void) { abort(); } | |
84 void __mulxf3 (void) { abort(); } | |
85 void __divxf3 (void) { abort(); } | |
86 void __negxf2 (void) { abort(); } | |
87 void __eqxf2 (void) { abort(); } | |
88 void __nexf2 (void) { abort(); } | |
89 void __gtxf2 (void) { abort(); } | |
90 void __gexf2 (void) { abort(); } | |
91 void __lexf2 (void) { abort(); } | |
92 void __ltxf2 (void) { abort(); } | |
93 | |
94 void __extendsftf2 (void) { abort(); } | |
95 void __extenddftf2 (void) { abort(); } | |
96 void __trunctfdf2 (void) { abort(); } | |
97 void __trunctfsf2 (void) { abort(); } | |
98 void __fixtfsi (void) { abort(); } | |
99 void __floatsitf (void) { abort(); } | |
100 void __addtf3 (void) { abort(); } | |
101 void __subtf3 (void) { abort(); } | |
102 void __multf3 (void) { abort(); } | |
103 void __divtf3 (void) { abort(); } | |
104 void __negtf2 (void) { abort(); } | |
105 void __eqtf2 (void) { abort(); } | |
106 void __netf2 (void) { abort(); } | |
107 void __gttf2 (void) { abort(); } | |
108 void __getf2 (void) { abort(); } | |
109 void __letf2 (void) { abort(); } | |
110 void __lttf2 (void) { abort(); } | |
111 #else /* !EXTENDED_FLOAT_STUBS, rest of file */ | |
112 | |
113 /* IEEE "special" number predicates */ | |
114 | |
115 #ifdef NO_NANS | |
116 | |
117 #define nan() 0 | |
118 #define isnan(x) 0 | |
119 #define isinf(x) 0 | |
120 #else | |
121 | |
122 #if defined L_thenan_sf | |
123 const fp_number_type __thenan_sf = { CLASS_SNAN, 0, 0, {(fractype) 0} }; | |
124 #elif defined L_thenan_df | |
125 const fp_number_type __thenan_df = { CLASS_SNAN, 0, 0, {(fractype) 0} }; | |
126 #elif defined L_thenan_tf | |
127 const fp_number_type __thenan_tf = { CLASS_SNAN, 0, 0, {(fractype) 0} }; | |
128 #elif defined TFLOAT | |
129 extern const fp_number_type __thenan_tf; | |
130 #elif defined FLOAT | |
131 extern const fp_number_type __thenan_sf; | |
132 #else | |
133 extern const fp_number_type __thenan_df; | |
134 #endif | |
135 | |
136 INLINE | |
137 static const fp_number_type * | |
138 makenan (void) | |
139 { | |
140 #ifdef TFLOAT | |
141 return & __thenan_tf; | |
142 #elif defined FLOAT | |
143 return & __thenan_sf; | |
144 #else | |
145 return & __thenan_df; | |
146 #endif | |
147 } | |
148 | |
149 INLINE | |
150 static int | |
151 isnan (const fp_number_type *x) | |
152 { | |
153 return __builtin_expect (x->class == CLASS_SNAN || x->class == CLASS_QNAN, | |
154 0); | |
155 } | |
156 | |
157 INLINE | |
158 static int | |
159 isinf (const fp_number_type * x) | |
160 { | |
161 return __builtin_expect (x->class == CLASS_INFINITY, 0); | |
162 } | |
163 | |
164 #endif /* NO_NANS */ | |
165 | |
166 INLINE | |
167 static int | |
168 iszero (const fp_number_type * x) | |
169 { | |
170 return x->class == CLASS_ZERO; | |
171 } | |
172 | |
173 INLINE | |
174 static void | |
175 flip_sign ( fp_number_type * x) | |
176 { | |
177 x->sign = !x->sign; | |
178 } | |
179 | |
180 /* Count leading zeroes in N. */ | |
181 INLINE | |
182 static int | |
183 clzusi (USItype n) | |
184 { | |
185 extern int __clzsi2 (USItype); | |
186 if (sizeof (USItype) == sizeof (unsigned int)) | |
187 return __builtin_clz (n); | |
188 else if (sizeof (USItype) == sizeof (unsigned long)) | |
189 return __builtin_clzl (n); | |
190 else if (sizeof (USItype) == sizeof (unsigned long long)) | |
191 return __builtin_clzll (n); | |
192 else | |
193 return __clzsi2 (n); | |
194 } | |
195 | |
196 extern FLO_type pack_d (const fp_number_type * ); | |
197 | |
198 #if defined(L_pack_df) || defined(L_pack_sf) || defined(L_pack_tf) | |
199 FLO_type | |
200 pack_d (const fp_number_type *src) | |
201 { | |
202 FLO_union_type dst; | |
203 fractype fraction = src->fraction.ll; /* wasn't unsigned before? */ | |
204 int sign = src->sign; | |
205 int exp = 0; | |
206 | |
207 if (LARGEST_EXPONENT_IS_NORMAL (FRAC_NBITS) && (isnan (src) || isinf (src))) | |
208 { | |
209 /* We can't represent these values accurately. By using the | |
210 largest possible magnitude, we guarantee that the conversion | |
211 of infinity is at least as big as any finite number. */ | |
212 exp = EXPMAX; | |
213 fraction = ((fractype) 1 << FRACBITS) - 1; | |
214 } | |
215 else if (isnan (src)) | |
216 { | |
217 exp = EXPMAX; | |
218 if (src->class == CLASS_QNAN || 1) | |
219 { | |
220 #ifdef QUIET_NAN_NEGATED | |
221 fraction |= QUIET_NAN - 1; | |
222 #else | |
223 fraction |= QUIET_NAN; | |
224 #endif | |
225 } | |
226 } | |
227 else if (isinf (src)) | |
228 { | |
229 exp = EXPMAX; | |
230 fraction = 0; | |
231 } | |
232 else if (iszero (src)) | |
233 { | |
234 exp = 0; | |
235 fraction = 0; | |
236 } | |
237 else if (fraction == 0) | |
238 { | |
239 exp = 0; | |
240 } | |
241 else | |
242 { | |
243 if (__builtin_expect (src->normal_exp < NORMAL_EXPMIN, 0)) | |
244 { | |
245 #ifdef NO_DENORMALS | |
246 /* Go straight to a zero representation if denormals are not | |
247 supported. The denormal handling would be harmless but | |
248 isn't unnecessary. */ | |
249 exp = 0; | |
250 fraction = 0; | |
251 #else /* NO_DENORMALS */ | |
252 /* This number's exponent is too low to fit into the bits | |
253 available in the number, so we'll store 0 in the exponent and | |
254 shift the fraction to the right to make up for it. */ | |
255 | |
256 int shift = NORMAL_EXPMIN - src->normal_exp; | |
257 | |
258 exp = 0; | |
259 | |
260 if (shift > FRAC_NBITS - NGARDS) | |
261 { | |
262 /* No point shifting, since it's more that 64 out. */ | |
263 fraction = 0; | |
264 } | |
265 else | |
266 { | |
267 int lowbit = (fraction & (((fractype)1 << shift) - 1)) ? 1 : 0; | |
268 fraction = (fraction >> shift) | lowbit; | |
269 } | |
270 if ((fraction & GARDMASK) == GARDMSB) | |
271 { | |
272 if ((fraction & (1 << NGARDS))) | |
273 fraction += GARDROUND + 1; | |
274 } | |
275 else | |
276 { | |
277 /* Add to the guards to round up. */ | |
278 fraction += GARDROUND; | |
279 } | |
280 /* Perhaps the rounding means we now need to change the | |
281 exponent, because the fraction is no longer denormal. */ | |
282 if (fraction >= IMPLICIT_1) | |
283 { | |
284 exp += 1; | |
285 } | |
286 fraction >>= NGARDS; | |
287 #endif /* NO_DENORMALS */ | |
288 } | |
289 else if (!LARGEST_EXPONENT_IS_NORMAL (FRAC_NBITS) | |
290 && __builtin_expect (src->normal_exp > EXPBIAS, 0)) | |
291 { | |
292 exp = EXPMAX; | |
293 fraction = 0; | |
294 } | |
295 else | |
296 { | |
297 exp = src->normal_exp + EXPBIAS; | |
298 if (!ROUND_TOWARDS_ZERO) | |
299 { | |
300 /* IF the gard bits are the all zero, but the first, then we're | |
301 half way between two numbers, choose the one which makes the | |
302 lsb of the answer 0. */ | |
303 if ((fraction & GARDMASK) == GARDMSB) | |
304 { | |
305 if (fraction & (1 << NGARDS)) | |
306 fraction += GARDROUND + 1; | |
307 } | |
308 else | |
309 { | |
310 /* Add a one to the guards to round up */ | |
311 fraction += GARDROUND; | |
312 } | |
313 if (fraction >= IMPLICIT_2) | |
314 { | |
315 fraction >>= 1; | |
316 exp += 1; | |
317 } | |
318 } | |
319 fraction >>= NGARDS; | |
320 | |
321 if (LARGEST_EXPONENT_IS_NORMAL (FRAC_NBITS) && exp > EXPMAX) | |
322 { | |
323 /* Saturate on overflow. */ | |
324 exp = EXPMAX; | |
325 fraction = ((fractype) 1 << FRACBITS) - 1; | |
326 } | |
327 } | |
328 } | |
329 | |
330 /* We previously used bitfields to store the number, but this doesn't | |
331 handle little/big endian systems conveniently, so use shifts and | |
332 masks */ | |
333 #ifdef FLOAT_BIT_ORDER_MISMATCH | |
334 dst.bits.fraction = fraction; | |
335 dst.bits.exp = exp; | |
336 dst.bits.sign = sign; | |
337 #else | |
338 # if defined TFLOAT && defined HALFFRACBITS | |
339 { | |
340 halffractype high, low, unity; | |
341 int lowsign, lowexp; | |
342 | |
343 unity = (halffractype) 1 << HALFFRACBITS; | |
344 | |
345 /* Set HIGH to the high double's significand, masking out the implicit 1. | |
346 Set LOW to the low double's full significand. */ | |
347 high = (fraction >> (FRACBITS - HALFFRACBITS)) & (unity - 1); | |
348 low = fraction & (unity * 2 - 1); | |
349 | |
350 /* Get the initial sign and exponent of the low double. */ | |
351 lowexp = exp - HALFFRACBITS - 1; | |
352 lowsign = sign; | |
353 | |
354 /* HIGH should be rounded like a normal double, making |LOW| <= | |
355 0.5 ULP of HIGH. Assume round-to-nearest. */ | |
356 if (exp < EXPMAX) | |
357 if (low > unity || (low == unity && (high & 1) == 1)) | |
358 { | |
359 /* Round HIGH up and adjust LOW to match. */ | |
360 high++; | |
361 if (high == unity) | |
362 { | |
363 /* May make it infinite, but that's OK. */ | |
364 high = 0; | |
365 exp++; | |
366 } | |
367 low = unity * 2 - low; | |
368 lowsign ^= 1; | |
369 } | |
370 | |
371 high |= (halffractype) exp << HALFFRACBITS; | |
372 high |= (halffractype) sign << (HALFFRACBITS + EXPBITS); | |
373 | |
374 if (exp == EXPMAX || exp == 0 || low == 0) | |
375 low = 0; | |
376 else | |
377 { | |
378 while (lowexp > 0 && low < unity) | |
379 { | |
380 low <<= 1; | |
381 lowexp--; | |
382 } | |
383 | |
384 if (lowexp <= 0) | |
385 { | |
386 halffractype roundmsb, round; | |
387 int shift; | |
388 | |
389 shift = 1 - lowexp; | |
390 roundmsb = (1 << (shift - 1)); | |
391 round = low & ((roundmsb << 1) - 1); | |
392 | |
393 low >>= shift; | |
394 lowexp = 0; | |
395 | |
396 if (round > roundmsb || (round == roundmsb && (low & 1) == 1)) | |
397 { | |
398 low++; | |
399 if (low == unity) | |
400 /* LOW rounds up to the smallest normal number. */ | |
401 lowexp++; | |
402 } | |
403 } | |
404 | |
405 low &= unity - 1; | |
406 low |= (halffractype) lowexp << HALFFRACBITS; | |
407 low |= (halffractype) lowsign << (HALFFRACBITS + EXPBITS); | |
408 } | |
409 dst.value_raw = ((fractype) high << HALFSHIFT) | low; | |
410 } | |
411 # else | |
412 dst.value_raw = fraction & ((((fractype)1) << FRACBITS) - (fractype)1); | |
413 dst.value_raw |= ((fractype) (exp & ((1 << EXPBITS) - 1))) << FRACBITS; | |
414 dst.value_raw |= ((fractype) (sign & 1)) << (FRACBITS | EXPBITS); | |
415 # endif | |
416 #endif | |
417 | |
418 #if defined(FLOAT_WORD_ORDER_MISMATCH) && !defined(FLOAT) | |
419 #ifdef TFLOAT | |
420 { | |
421 qrtrfractype tmp1 = dst.words[0]; | |
422 qrtrfractype tmp2 = dst.words[1]; | |
423 dst.words[0] = dst.words[3]; | |
424 dst.words[1] = dst.words[2]; | |
425 dst.words[2] = tmp2; | |
426 dst.words[3] = tmp1; | |
427 } | |
428 #else | |
429 { | |
430 halffractype tmp = dst.words[0]; | |
431 dst.words[0] = dst.words[1]; | |
432 dst.words[1] = tmp; | |
433 } | |
434 #endif | |
435 #endif | |
436 | |
437 return dst.value; | |
438 } | |
439 #endif | |
440 | |
441 #if defined(L_unpack_df) || defined(L_unpack_sf) || defined(L_unpack_tf) | |
442 void | |
443 unpack_d (FLO_union_type * src, fp_number_type * dst) | |
444 { | |
445 /* We previously used bitfields to store the number, but this doesn't | |
446 handle little/big endian systems conveniently, so use shifts and | |
447 masks */ | |
448 fractype fraction; | |
449 int exp; | |
450 int sign; | |
451 | |
452 #if defined(FLOAT_WORD_ORDER_MISMATCH) && !defined(FLOAT) | |
453 FLO_union_type swapped; | |
454 | |
455 #ifdef TFLOAT | |
456 swapped.words[0] = src->words[3]; | |
457 swapped.words[1] = src->words[2]; | |
458 swapped.words[2] = src->words[1]; | |
459 swapped.words[3] = src->words[0]; | |
460 #else | |
461 swapped.words[0] = src->words[1]; | |
462 swapped.words[1] = src->words[0]; | |
463 #endif | |
464 src = &swapped; | |
465 #endif | |
466 | |
467 #ifdef FLOAT_BIT_ORDER_MISMATCH | |
468 fraction = src->bits.fraction; | |
469 exp = src->bits.exp; | |
470 sign = src->bits.sign; | |
471 #else | |
472 # if defined TFLOAT && defined HALFFRACBITS | |
473 { | |
474 halffractype high, low; | |
475 | |
476 high = src->value_raw >> HALFSHIFT; | |
477 low = src->value_raw & (((fractype)1 << HALFSHIFT) - 1); | |
478 | |
479 fraction = high & ((((fractype)1) << HALFFRACBITS) - 1); | |
480 fraction <<= FRACBITS - HALFFRACBITS; | |
481 exp = ((int)(high >> HALFFRACBITS)) & ((1 << EXPBITS) - 1); | |
482 sign = ((int)(high >> (((HALFFRACBITS + EXPBITS))))) & 1; | |
483 | |
484 if (exp != EXPMAX && exp != 0 && low != 0) | |
485 { | |
486 int lowexp = ((int)(low >> HALFFRACBITS)) & ((1 << EXPBITS) - 1); | |
487 int lowsign = ((int)(low >> (((HALFFRACBITS + EXPBITS))))) & 1; | |
488 int shift; | |
489 fractype xlow; | |
490 | |
491 xlow = low & ((((fractype)1) << HALFFRACBITS) - 1); | |
492 if (lowexp) | |
493 xlow |= (((halffractype)1) << HALFFRACBITS); | |
494 else | |
495 lowexp = 1; | |
496 shift = (FRACBITS - HALFFRACBITS) - (exp - lowexp); | |
497 if (shift > 0) | |
498 xlow <<= shift; | |
499 else if (shift < 0) | |
500 xlow >>= -shift; | |
501 if (sign == lowsign) | |
502 fraction += xlow; | |
503 else if (fraction >= xlow) | |
504 fraction -= xlow; | |
505 else | |
506 { | |
507 /* The high part is a power of two but the full number is lower. | |
508 This code will leave the implicit 1 in FRACTION, but we'd | |
509 have added that below anyway. */ | |
510 fraction = (((fractype) 1 << FRACBITS) - xlow) << 1; | |
511 exp--; | |
512 } | |
513 } | |
514 } | |
515 # else | |
516 fraction = src->value_raw & ((((fractype)1) << FRACBITS) - 1); | |
517 exp = ((int)(src->value_raw >> FRACBITS)) & ((1 << EXPBITS) - 1); | |
518 sign = ((int)(src->value_raw >> (FRACBITS + EXPBITS))) & 1; | |
519 # endif | |
520 #endif | |
521 | |
522 dst->sign = sign; | |
523 if (exp == 0) | |
524 { | |
525 /* Hmm. Looks like 0 */ | |
526 if (fraction == 0 | |
527 #ifdef NO_DENORMALS | |
528 || 1 | |
529 #endif | |
530 ) | |
531 { | |
532 /* tastes like zero */ | |
533 dst->class = CLASS_ZERO; | |
534 } | |
535 else | |
536 { | |
537 /* Zero exponent with nonzero fraction - it's denormalized, | |
538 so there isn't a leading implicit one - we'll shift it so | |
539 it gets one. */ | |
540 dst->normal_exp = exp - EXPBIAS + 1; | |
541 fraction <<= NGARDS; | |
542 | |
543 dst->class = CLASS_NUMBER; | |
544 #if 1 | |
545 while (fraction < IMPLICIT_1) | |
546 { | |
547 fraction <<= 1; | |
548 dst->normal_exp--; | |
549 } | |
550 #endif | |
551 dst->fraction.ll = fraction; | |
552 } | |
553 } | |
554 else if (!LARGEST_EXPONENT_IS_NORMAL (FRAC_NBITS) | |
555 && __builtin_expect (exp == EXPMAX, 0)) | |
556 { | |
557 /* Huge exponent*/ | |
558 if (fraction == 0) | |
559 { | |
560 /* Attached to a zero fraction - means infinity */ | |
561 dst->class = CLASS_INFINITY; | |
562 } | |
563 else | |
564 { | |
565 /* Nonzero fraction, means nan */ | |
566 #ifdef QUIET_NAN_NEGATED | |
567 if ((fraction & QUIET_NAN) == 0) | |
568 #else | |
569 if (fraction & QUIET_NAN) | |
570 #endif | |
571 { | |
572 dst->class = CLASS_QNAN; | |
573 } | |
574 else | |
575 { | |
576 dst->class = CLASS_SNAN; | |
577 } | |
578 /* Keep the fraction part as the nan number */ | |
579 dst->fraction.ll = fraction; | |
580 } | |
581 } | |
582 else | |
583 { | |
584 /* Nothing strange about this number */ | |
585 dst->normal_exp = exp - EXPBIAS; | |
586 dst->class = CLASS_NUMBER; | |
587 dst->fraction.ll = (fraction << NGARDS) | IMPLICIT_1; | |
588 } | |
589 } | |
590 #endif /* L_unpack_df || L_unpack_sf */ | |
591 | |
592 #if defined(L_addsub_sf) || defined(L_addsub_df) || defined(L_addsub_tf) | |
593 static const fp_number_type * | |
594 _fpadd_parts (fp_number_type * a, | |
595 fp_number_type * b, | |
596 fp_number_type * tmp) | |
597 { | |
598 intfrac tfraction; | |
599 | |
600 /* Put commonly used fields in local variables. */ | |
601 int a_normal_exp; | |
602 int b_normal_exp; | |
603 fractype a_fraction; | |
604 fractype b_fraction; | |
605 | |
606 if (isnan (a)) | |
607 { | |
608 return a; | |
609 } | |
610 if (isnan (b)) | |
611 { | |
612 return b; | |
613 } | |
614 if (isinf (a)) | |
615 { | |
616 /* Adding infinities with opposite signs yields a NaN. */ | |
617 if (isinf (b) && a->sign != b->sign) | |
618 return makenan (); | |
619 return a; | |
620 } | |
621 if (isinf (b)) | |
622 { | |
623 return b; | |
624 } | |
625 if (iszero (b)) | |
626 { | |
627 if (iszero (a)) | |
628 { | |
629 *tmp = *a; | |
630 tmp->sign = a->sign & b->sign; | |
631 return tmp; | |
632 } | |
633 return a; | |
634 } | |
635 if (iszero (a)) | |
636 { | |
637 return b; | |
638 } | |
639 | |
640 /* Got two numbers. shift the smaller and increment the exponent till | |
641 they're the same */ | |
642 { | |
643 int diff; | |
644 int sdiff; | |
645 | |
646 a_normal_exp = a->normal_exp; | |
647 b_normal_exp = b->normal_exp; | |
648 a_fraction = a->fraction.ll; | |
649 b_fraction = b->fraction.ll; | |
650 | |
651 diff = a_normal_exp - b_normal_exp; | |
652 sdiff = diff; | |
653 | |
654 if (diff < 0) | |
655 diff = -diff; | |
656 if (diff < FRAC_NBITS) | |
657 { | |
658 if (sdiff > 0) | |
659 { | |
660 b_normal_exp += diff; | |
661 LSHIFT (b_fraction, diff); | |
662 } | |
663 else if (sdiff < 0) | |
664 { | |
665 a_normal_exp += diff; | |
666 LSHIFT (a_fraction, diff); | |
667 } | |
668 } | |
669 else | |
670 { | |
671 /* Somethings's up.. choose the biggest */ | |
672 if (a_normal_exp > b_normal_exp) | |
673 { | |
674 b_normal_exp = a_normal_exp; | |
675 b_fraction = 0; | |
676 } | |
677 else | |
678 { | |
679 a_normal_exp = b_normal_exp; | |
680 a_fraction = 0; | |
681 } | |
682 } | |
683 } | |
684 | |
685 if (a->sign != b->sign) | |
686 { | |
687 if (a->sign) | |
688 { | |
689 tfraction = -a_fraction + b_fraction; | |
690 } | |
691 else | |
692 { | |
693 tfraction = a_fraction - b_fraction; | |
694 } | |
695 if (tfraction >= 0) | |
696 { | |
697 tmp->sign = 0; | |
698 tmp->normal_exp = a_normal_exp; | |
699 tmp->fraction.ll = tfraction; | |
700 } | |
701 else | |
702 { | |
703 tmp->sign = 1; | |
704 tmp->normal_exp = a_normal_exp; | |
705 tmp->fraction.ll = -tfraction; | |
706 } | |
707 /* and renormalize it */ | |
708 | |
709 while (tmp->fraction.ll < IMPLICIT_1 && tmp->fraction.ll) | |
710 { | |
711 tmp->fraction.ll <<= 1; | |
712 tmp->normal_exp--; | |
713 } | |
714 } | |
715 else | |
716 { | |
717 tmp->sign = a->sign; | |
718 tmp->normal_exp = a_normal_exp; | |
719 tmp->fraction.ll = a_fraction + b_fraction; | |
720 } | |
721 tmp->class = CLASS_NUMBER; | |
722 /* Now the fraction is added, we have to shift down to renormalize the | |
723 number */ | |
724 | |
725 if (tmp->fraction.ll >= IMPLICIT_2) | |
726 { | |
727 LSHIFT (tmp->fraction.ll, 1); | |
728 tmp->normal_exp++; | |
729 } | |
730 return tmp; | |
731 } | |
732 | |
733 FLO_type | |
734 add (FLO_type arg_a, FLO_type arg_b) | |
735 { | |
736 fp_number_type a; | |
737 fp_number_type b; | |
738 fp_number_type tmp; | |
739 const fp_number_type *res; | |
740 FLO_union_type au, bu; | |
741 | |
742 au.value = arg_a; | |
743 bu.value = arg_b; | |
744 | |
745 unpack_d (&au, &a); | |
746 unpack_d (&bu, &b); | |
747 | |
748 res = _fpadd_parts (&a, &b, &tmp); | |
749 | |
750 return pack_d (res); | |
751 } | |
752 | |
753 FLO_type | |
754 sub (FLO_type arg_a, FLO_type arg_b) | |
755 { | |
756 fp_number_type a; | |
757 fp_number_type b; | |
758 fp_number_type tmp; | |
759 const fp_number_type *res; | |
760 FLO_union_type au, bu; | |
761 | |
762 au.value = arg_a; | |
763 bu.value = arg_b; | |
764 | |
765 unpack_d (&au, &a); | |
766 unpack_d (&bu, &b); | |
767 | |
768 b.sign ^= 1; | |
769 | |
770 res = _fpadd_parts (&a, &b, &tmp); | |
771 | |
772 return pack_d (res); | |
773 } | |
774 #endif /* L_addsub_sf || L_addsub_df */ | |
775 | |
776 #if defined(L_mul_sf) || defined(L_mul_df) || defined(L_mul_tf) | |
777 static inline __attribute__ ((__always_inline__)) const fp_number_type * | |
778 _fpmul_parts ( fp_number_type * a, | |
779 fp_number_type * b, | |
780 fp_number_type * tmp) | |
781 { | |
782 fractype low = 0; | |
783 fractype high = 0; | |
784 | |
785 if (isnan (a)) | |
786 { | |
787 a->sign = a->sign != b->sign; | |
788 return a; | |
789 } | |
790 if (isnan (b)) | |
791 { | |
792 b->sign = a->sign != b->sign; | |
793 return b; | |
794 } | |
795 if (isinf (a)) | |
796 { | |
797 if (iszero (b)) | |
798 return makenan (); | |
799 a->sign = a->sign != b->sign; | |
800 return a; | |
801 } | |
802 if (isinf (b)) | |
803 { | |
804 if (iszero (a)) | |
805 { | |
806 return makenan (); | |
807 } | |
808 b->sign = a->sign != b->sign; | |
809 return b; | |
810 } | |
811 if (iszero (a)) | |
812 { | |
813 a->sign = a->sign != b->sign; | |
814 return a; | |
815 } | |
816 if (iszero (b)) | |
817 { | |
818 b->sign = a->sign != b->sign; | |
819 return b; | |
820 } | |
821 | |
822 /* Calculate the mantissa by multiplying both numbers to get a | |
823 twice-as-wide number. */ | |
824 { | |
825 #if defined(NO_DI_MODE) || defined(TFLOAT) | |
826 { | |
827 fractype x = a->fraction.ll; | |
828 fractype ylow = b->fraction.ll; | |
829 fractype yhigh = 0; | |
830 int bit; | |
831 | |
832 /* ??? This does multiplies one bit at a time. Optimize. */ | |
833 for (bit = 0; bit < FRAC_NBITS; bit++) | |
834 { | |
835 int carry; | |
836 | |
837 if (x & 1) | |
838 { | |
839 carry = (low += ylow) < ylow; | |
840 high += yhigh + carry; | |
841 } | |
842 yhigh <<= 1; | |
843 if (ylow & FRACHIGH) | |
844 { | |
845 yhigh |= 1; | |
846 } | |
847 ylow <<= 1; | |
848 x >>= 1; | |
849 } | |
850 } | |
851 #elif defined(FLOAT) | |
852 /* Multiplying two USIs to get a UDI, we're safe. */ | |
853 { | |
854 UDItype answer = (UDItype)a->fraction.ll * (UDItype)b->fraction.ll; | |
855 | |
856 high = answer >> BITS_PER_SI; | |
857 low = answer; | |
858 } | |
859 #else | |
860 /* fractype is DImode, but we need the result to be twice as wide. | |
861 Assuming a widening multiply from DImode to TImode is not | |
862 available, build one by hand. */ | |
863 { | |
864 USItype nl = a->fraction.ll; | |
865 USItype nh = a->fraction.ll >> BITS_PER_SI; | |
866 USItype ml = b->fraction.ll; | |
867 USItype mh = b->fraction.ll >> BITS_PER_SI; | |
868 UDItype pp_ll = (UDItype) ml * nl; | |
869 UDItype pp_hl = (UDItype) mh * nl; | |
870 UDItype pp_lh = (UDItype) ml * nh; | |
871 UDItype pp_hh = (UDItype) mh * nh; | |
872 UDItype res2 = 0; | |
873 UDItype res0 = 0; | |
874 UDItype ps_hh__ = pp_hl + pp_lh; | |
875 if (ps_hh__ < pp_hl) | |
876 res2 += (UDItype)1 << BITS_PER_SI; | |
877 pp_hl = (UDItype)(USItype)ps_hh__ << BITS_PER_SI; | |
878 res0 = pp_ll + pp_hl; | |
879 if (res0 < pp_ll) | |
880 res2++; | |
881 res2 += (ps_hh__ >> BITS_PER_SI) + pp_hh; | |
882 high = res2; | |
883 low = res0; | |
884 } | |
885 #endif | |
886 } | |
887 | |
888 tmp->normal_exp = a->normal_exp + b->normal_exp | |
889 + FRAC_NBITS - (FRACBITS + NGARDS); | |
890 tmp->sign = a->sign != b->sign; | |
891 while (high >= IMPLICIT_2) | |
892 { | |
893 tmp->normal_exp++; | |
894 if (high & 1) | |
895 { | |
896 low >>= 1; | |
897 low |= FRACHIGH; | |
898 } | |
899 high >>= 1; | |
900 } | |
901 while (high < IMPLICIT_1) | |
902 { | |
903 tmp->normal_exp--; | |
904 | |
905 high <<= 1; | |
906 if (low & FRACHIGH) | |
907 high |= 1; | |
908 low <<= 1; | |
909 } | |
910 | |
911 if (!ROUND_TOWARDS_ZERO && (high & GARDMASK) == GARDMSB) | |
912 { | |
913 if (high & (1 << NGARDS)) | |
914 { | |
915 /* Because we're half way, we would round to even by adding | |
916 GARDROUND + 1, except that's also done in the packing | |
917 function, and rounding twice will lose precision and cause | |
918 the result to be too far off. Example: 32-bit floats with | |
919 bit patterns 0xfff * 0x3f800400 ~= 0xfff (less than 0.5ulp | |
920 off), not 0x1000 (more than 0.5ulp off). */ | |
921 } | |
922 else if (low) | |
923 { | |
924 /* We're a further than half way by a small amount corresponding | |
925 to the bits set in "low". Knowing that, we round here and | |
926 not in pack_d, because there we don't have "low" available | |
927 anymore. */ | |
928 high += GARDROUND + 1; | |
929 | |
930 /* Avoid further rounding in pack_d. */ | |
931 high &= ~(fractype) GARDMASK; | |
932 } | |
933 } | |
934 tmp->fraction.ll = high; | |
935 tmp->class = CLASS_NUMBER; | |
936 return tmp; | |
937 } | |
938 | |
939 FLO_type | |
940 multiply (FLO_type arg_a, FLO_type arg_b) | |
941 { | |
942 fp_number_type a; | |
943 fp_number_type b; | |
944 fp_number_type tmp; | |
945 const fp_number_type *res; | |
946 FLO_union_type au, bu; | |
947 | |
948 au.value = arg_a; | |
949 bu.value = arg_b; | |
950 | |
951 unpack_d (&au, &a); | |
952 unpack_d (&bu, &b); | |
953 | |
954 res = _fpmul_parts (&a, &b, &tmp); | |
955 | |
956 return pack_d (res); | |
957 } | |
958 #endif /* L_mul_sf || L_mul_df || L_mul_tf */ | |
959 | |
960 #if defined(L_div_sf) || defined(L_div_df) || defined(L_div_tf) | |
961 static inline __attribute__ ((__always_inline__)) const fp_number_type * | |
962 _fpdiv_parts (fp_number_type * a, | |
963 fp_number_type * b) | |
964 { | |
965 fractype bit; | |
966 fractype numerator; | |
967 fractype denominator; | |
968 fractype quotient; | |
969 | |
970 if (isnan (a)) | |
971 { | |
972 return a; | |
973 } | |
974 if (isnan (b)) | |
975 { | |
976 return b; | |
977 } | |
978 | |
979 a->sign = a->sign ^ b->sign; | |
980 | |
981 if (isinf (a) || iszero (a)) | |
982 { | |
983 if (a->class == b->class) | |
984 return makenan (); | |
985 return a; | |
986 } | |
987 | |
988 if (isinf (b)) | |
989 { | |
990 a->fraction.ll = 0; | |
991 a->normal_exp = 0; | |
992 return a; | |
993 } | |
994 if (iszero (b)) | |
995 { | |
996 a->class = CLASS_INFINITY; | |
997 return a; | |
998 } | |
999 | |
1000 /* Calculate the mantissa by multiplying both 64bit numbers to get a | |
1001 128 bit number */ | |
1002 { | |
1003 /* quotient = | |
1004 ( numerator / denominator) * 2^(numerator exponent - denominator exponent) | |
1005 */ | |
1006 | |
1007 a->normal_exp = a->normal_exp - b->normal_exp; | |
1008 numerator = a->fraction.ll; | |
1009 denominator = b->fraction.ll; | |
1010 | |
1011 if (numerator < denominator) | |
1012 { | |
1013 /* Fraction will be less than 1.0 */ | |
1014 numerator *= 2; | |
1015 a->normal_exp--; | |
1016 } | |
1017 bit = IMPLICIT_1; | |
1018 quotient = 0; | |
1019 /* ??? Does divide one bit at a time. Optimize. */ | |
1020 while (bit) | |
1021 { | |
1022 if (numerator >= denominator) | |
1023 { | |
1024 quotient |= bit; | |
1025 numerator -= denominator; | |
1026 } | |
1027 bit >>= 1; | |
1028 numerator *= 2; | |
1029 } | |
1030 | |
1031 if (!ROUND_TOWARDS_ZERO && (quotient & GARDMASK) == GARDMSB) | |
1032 { | |
1033 if (quotient & (1 << NGARDS)) | |
1034 { | |
1035 /* Because we're half way, we would round to even by adding | |
1036 GARDROUND + 1, except that's also done in the packing | |
1037 function, and rounding twice will lose precision and cause | |
1038 the result to be too far off. */ | |
1039 } | |
1040 else if (numerator) | |
1041 { | |
1042 /* We're a further than half way by the small amount | |
1043 corresponding to the bits set in "numerator". Knowing | |
1044 that, we round here and not in pack_d, because there we | |
1045 don't have "numerator" available anymore. */ | |
1046 quotient += GARDROUND + 1; | |
1047 | |
1048 /* Avoid further rounding in pack_d. */ | |
1049 quotient &= ~(fractype) GARDMASK; | |
1050 } | |
1051 } | |
1052 | |
1053 a->fraction.ll = quotient; | |
1054 return (a); | |
1055 } | |
1056 } | |
1057 | |
1058 FLO_type | |
1059 divide (FLO_type arg_a, FLO_type arg_b) | |
1060 { | |
1061 fp_number_type a; | |
1062 fp_number_type b; | |
1063 const fp_number_type *res; | |
1064 FLO_union_type au, bu; | |
1065 | |
1066 au.value = arg_a; | |
1067 bu.value = arg_b; | |
1068 | |
1069 unpack_d (&au, &a); | |
1070 unpack_d (&bu, &b); | |
1071 | |
1072 res = _fpdiv_parts (&a, &b); | |
1073 | |
1074 return pack_d (res); | |
1075 } | |
1076 #endif /* L_div_sf || L_div_df */ | |
1077 | |
1078 #if defined(L_fpcmp_parts_sf) || defined(L_fpcmp_parts_df) \ | |
1079 || defined(L_fpcmp_parts_tf) | |
1080 /* according to the demo, fpcmp returns a comparison with 0... thus | |
1081 a<b -> -1 | |
1082 a==b -> 0 | |
1083 a>b -> +1 | |
1084 */ | |
1085 | |
1086 int | |
1087 __fpcmp_parts (fp_number_type * a, fp_number_type * b) | |
1088 { | |
1089 #if 0 | |
1090 /* either nan -> unordered. Must be checked outside of this routine. */ | |
1091 if (isnan (a) && isnan (b)) | |
1092 { | |
1093 return 1; /* still unordered! */ | |
1094 } | |
1095 #endif | |
1096 | |
1097 if (isnan (a) || isnan (b)) | |
1098 { | |
1099 return 1; /* how to indicate unordered compare? */ | |
1100 } | |
1101 if (isinf (a) && isinf (b)) | |
1102 { | |
1103 /* +inf > -inf, but +inf != +inf */ | |
1104 /* b \a| +inf(0)| -inf(1) | |
1105 ______\+--------+-------- | |
1106 +inf(0)| a==b(0)| a<b(-1) | |
1107 -------+--------+-------- | |
1108 -inf(1)| a>b(1) | a==b(0) | |
1109 -------+--------+-------- | |
1110 So since unordered must be nonzero, just line up the columns... | |
1111 */ | |
1112 return b->sign - a->sign; | |
1113 } | |
1114 /* but not both... */ | |
1115 if (isinf (a)) | |
1116 { | |
1117 return a->sign ? -1 : 1; | |
1118 } | |
1119 if (isinf (b)) | |
1120 { | |
1121 return b->sign ? 1 : -1; | |
1122 } | |
1123 if (iszero (a) && iszero (b)) | |
1124 { | |
1125 return 0; | |
1126 } | |
1127 if (iszero (a)) | |
1128 { | |
1129 return b->sign ? 1 : -1; | |
1130 } | |
1131 if (iszero (b)) | |
1132 { | |
1133 return a->sign ? -1 : 1; | |
1134 } | |
1135 /* now both are "normal". */ | |
1136 if (a->sign != b->sign) | |
1137 { | |
1138 /* opposite signs */ | |
1139 return a->sign ? -1 : 1; | |
1140 } | |
1141 /* same sign; exponents? */ | |
1142 if (a->normal_exp > b->normal_exp) | |
1143 { | |
1144 return a->sign ? -1 : 1; | |
1145 } | |
1146 if (a->normal_exp < b->normal_exp) | |
1147 { | |
1148 return a->sign ? 1 : -1; | |
1149 } | |
1150 /* same exponents; check size. */ | |
1151 if (a->fraction.ll > b->fraction.ll) | |
1152 { | |
1153 return a->sign ? -1 : 1; | |
1154 } | |
1155 if (a->fraction.ll < b->fraction.ll) | |
1156 { | |
1157 return a->sign ? 1 : -1; | |
1158 } | |
1159 /* after all that, they're equal. */ | |
1160 return 0; | |
1161 } | |
1162 #endif | |
1163 | |
1164 #if defined(L_compare_sf) || defined(L_compare_df) || defined(L_compoare_tf) | |
1165 CMPtype | |
1166 compare (FLO_type arg_a, FLO_type arg_b) | |
1167 { | |
1168 fp_number_type a; | |
1169 fp_number_type b; | |
1170 FLO_union_type au, bu; | |
1171 | |
1172 au.value = arg_a; | |
1173 bu.value = arg_b; | |
1174 | |
1175 unpack_d (&au, &a); | |
1176 unpack_d (&bu, &b); | |
1177 | |
1178 return __fpcmp_parts (&a, &b); | |
1179 } | |
1180 #endif /* L_compare_sf || L_compare_df */ | |
1181 | |
1182 #ifndef US_SOFTWARE_GOFAST | |
1183 | |
1184 /* These should be optimized for their specific tasks someday. */ | |
1185 | |
1186 #if defined(L_eq_sf) || defined(L_eq_df) || defined(L_eq_tf) | |
1187 CMPtype | |
1188 _eq_f2 (FLO_type arg_a, FLO_type arg_b) | |
1189 { | |
1190 fp_number_type a; | |
1191 fp_number_type b; | |
1192 FLO_union_type au, bu; | |
1193 | |
1194 au.value = arg_a; | |
1195 bu.value = arg_b; | |
1196 | |
1197 unpack_d (&au, &a); | |
1198 unpack_d (&bu, &b); | |
1199 | |
1200 if (isnan (&a) || isnan (&b)) | |
1201 return 1; /* false, truth == 0 */ | |
1202 | |
1203 return __fpcmp_parts (&a, &b) ; | |
1204 } | |
1205 #endif /* L_eq_sf || L_eq_df */ | |
1206 | |
1207 #if defined(L_ne_sf) || defined(L_ne_df) || defined(L_ne_tf) | |
1208 CMPtype | |
1209 _ne_f2 (FLO_type arg_a, FLO_type arg_b) | |
1210 { | |
1211 fp_number_type a; | |
1212 fp_number_type b; | |
1213 FLO_union_type au, bu; | |
1214 | |
1215 au.value = arg_a; | |
1216 bu.value = arg_b; | |
1217 | |
1218 unpack_d (&au, &a); | |
1219 unpack_d (&bu, &b); | |
1220 | |
1221 if (isnan (&a) || isnan (&b)) | |
1222 return 1; /* true, truth != 0 */ | |
1223 | |
1224 return __fpcmp_parts (&a, &b) ; | |
1225 } | |
1226 #endif /* L_ne_sf || L_ne_df */ | |
1227 | |
1228 #if defined(L_gt_sf) || defined(L_gt_df) || defined(L_gt_tf) | |
1229 CMPtype | |
1230 _gt_f2 (FLO_type arg_a, FLO_type arg_b) | |
1231 { | |
1232 fp_number_type a; | |
1233 fp_number_type b; | |
1234 FLO_union_type au, bu; | |
1235 | |
1236 au.value = arg_a; | |
1237 bu.value = arg_b; | |
1238 | |
1239 unpack_d (&au, &a); | |
1240 unpack_d (&bu, &b); | |
1241 | |
1242 if (isnan (&a) || isnan (&b)) | |
1243 return -1; /* false, truth > 0 */ | |
1244 | |
1245 return __fpcmp_parts (&a, &b); | |
1246 } | |
1247 #endif /* L_gt_sf || L_gt_df */ | |
1248 | |
1249 #if defined(L_ge_sf) || defined(L_ge_df) || defined(L_ge_tf) | |
1250 CMPtype | |
1251 _ge_f2 (FLO_type arg_a, FLO_type arg_b) | |
1252 { | |
1253 fp_number_type a; | |
1254 fp_number_type b; | |
1255 FLO_union_type au, bu; | |
1256 | |
1257 au.value = arg_a; | |
1258 bu.value = arg_b; | |
1259 | |
1260 unpack_d (&au, &a); | |
1261 unpack_d (&bu, &b); | |
1262 | |
1263 if (isnan (&a) || isnan (&b)) | |
1264 return -1; /* false, truth >= 0 */ | |
1265 return __fpcmp_parts (&a, &b) ; | |
1266 } | |
1267 #endif /* L_ge_sf || L_ge_df */ | |
1268 | |
1269 #if defined(L_lt_sf) || defined(L_lt_df) || defined(L_lt_tf) | |
1270 CMPtype | |
1271 _lt_f2 (FLO_type arg_a, FLO_type arg_b) | |
1272 { | |
1273 fp_number_type a; | |
1274 fp_number_type b; | |
1275 FLO_union_type au, bu; | |
1276 | |
1277 au.value = arg_a; | |
1278 bu.value = arg_b; | |
1279 | |
1280 unpack_d (&au, &a); | |
1281 unpack_d (&bu, &b); | |
1282 | |
1283 if (isnan (&a) || isnan (&b)) | |
1284 return 1; /* false, truth < 0 */ | |
1285 | |
1286 return __fpcmp_parts (&a, &b); | |
1287 } | |
1288 #endif /* L_lt_sf || L_lt_df */ | |
1289 | |
1290 #if defined(L_le_sf) || defined(L_le_df) || defined(L_le_tf) | |
1291 CMPtype | |
1292 _le_f2 (FLO_type arg_a, FLO_type arg_b) | |
1293 { | |
1294 fp_number_type a; | |
1295 fp_number_type b; | |
1296 FLO_union_type au, bu; | |
1297 | |
1298 au.value = arg_a; | |
1299 bu.value = arg_b; | |
1300 | |
1301 unpack_d (&au, &a); | |
1302 unpack_d (&bu, &b); | |
1303 | |
1304 if (isnan (&a) || isnan (&b)) | |
1305 return 1; /* false, truth <= 0 */ | |
1306 | |
1307 return __fpcmp_parts (&a, &b) ; | |
1308 } | |
1309 #endif /* L_le_sf || L_le_df */ | |
1310 | |
1311 #endif /* ! US_SOFTWARE_GOFAST */ | |
1312 | |
1313 #if defined(L_unord_sf) || defined(L_unord_df) || defined(L_unord_tf) | |
1314 CMPtype | |
1315 _unord_f2 (FLO_type arg_a, FLO_type arg_b) | |
1316 { | |
1317 fp_number_type a; | |
1318 fp_number_type b; | |
1319 FLO_union_type au, bu; | |
1320 | |
1321 au.value = arg_a; | |
1322 bu.value = arg_b; | |
1323 | |
1324 unpack_d (&au, &a); | |
1325 unpack_d (&bu, &b); | |
1326 | |
1327 return (isnan (&a) || isnan (&b)); | |
1328 } | |
1329 #endif /* L_unord_sf || L_unord_df */ | |
1330 | |
1331 #if defined(L_si_to_sf) || defined(L_si_to_df) || defined(L_si_to_tf) | |
1332 FLO_type | |
1333 si_to_float (SItype arg_a) | |
1334 { | |
1335 fp_number_type in; | |
1336 | |
1337 in.class = CLASS_NUMBER; | |
1338 in.sign = arg_a < 0; | |
1339 if (!arg_a) | |
1340 { | |
1341 in.class = CLASS_ZERO; | |
1342 } | |
1343 else | |
1344 { | |
1345 USItype uarg; | |
1346 int shift; | |
1347 in.normal_exp = FRACBITS + NGARDS; | |
1348 if (in.sign) | |
1349 { | |
1350 /* Special case for minint, since there is no +ve integer | |
1351 representation for it */ | |
1352 if (arg_a == (- MAX_SI_INT - 1)) | |
1353 { | |
1354 return (FLO_type)(- MAX_SI_INT - 1); | |
1355 } | |
1356 uarg = (-arg_a); | |
1357 } | |
1358 else | |
1359 uarg = arg_a; | |
1360 | |
1361 in.fraction.ll = uarg; | |
1362 shift = clzusi (uarg) - (BITS_PER_SI - 1 - FRACBITS - NGARDS); | |
1363 if (shift > 0) | |
1364 { | |
1365 in.fraction.ll <<= shift; | |
1366 in.normal_exp -= shift; | |
1367 } | |
1368 } | |
1369 return pack_d (&in); | |
1370 } | |
1371 #endif /* L_si_to_sf || L_si_to_df */ | |
1372 | |
1373 #if defined(L_usi_to_sf) || defined(L_usi_to_df) || defined(L_usi_to_tf) | |
1374 FLO_type | |
1375 usi_to_float (USItype arg_a) | |
1376 { | |
1377 fp_number_type in; | |
1378 | |
1379 in.sign = 0; | |
1380 if (!arg_a) | |
1381 { | |
1382 in.class = CLASS_ZERO; | |
1383 } | |
1384 else | |
1385 { | |
1386 int shift; | |
1387 in.class = CLASS_NUMBER; | |
1388 in.normal_exp = FRACBITS + NGARDS; | |
1389 in.fraction.ll = arg_a; | |
1390 | |
1391 shift = clzusi (arg_a) - (BITS_PER_SI - 1 - FRACBITS - NGARDS); | |
1392 if (shift < 0) | |
1393 { | |
1394 fractype guard = in.fraction.ll & (((fractype)1 << -shift) - 1); | |
1395 in.fraction.ll >>= -shift; | |
1396 in.fraction.ll |= (guard != 0); | |
1397 in.normal_exp -= shift; | |
1398 } | |
1399 else if (shift > 0) | |
1400 { | |
1401 in.fraction.ll <<= shift; | |
1402 in.normal_exp -= shift; | |
1403 } | |
1404 } | |
1405 return pack_d (&in); | |
1406 } | |
1407 #endif | |
1408 | |
1409 #if defined(L_sf_to_si) || defined(L_df_to_si) || defined(L_tf_to_si) | |
1410 SItype | |
1411 float_to_si (FLO_type arg_a) | |
1412 { | |
1413 fp_number_type a; | |
1414 SItype tmp; | |
1415 FLO_union_type au; | |
1416 | |
1417 au.value = arg_a; | |
1418 unpack_d (&au, &a); | |
1419 | |
1420 if (iszero (&a)) | |
1421 return 0; | |
1422 if (isnan (&a)) | |
1423 return 0; | |
1424 /* get reasonable MAX_SI_INT... */ | |
1425 if (isinf (&a)) | |
1426 return a.sign ? (-MAX_SI_INT)-1 : MAX_SI_INT; | |
1427 /* it is a number, but a small one */ | |
1428 if (a.normal_exp < 0) | |
1429 return 0; | |
1430 if (a.normal_exp > BITS_PER_SI - 2) | |
1431 return a.sign ? (-MAX_SI_INT)-1 : MAX_SI_INT; | |
1432 tmp = a.fraction.ll >> ((FRACBITS + NGARDS) - a.normal_exp); | |
1433 return a.sign ? (-tmp) : (tmp); | |
1434 } | |
1435 #endif /* L_sf_to_si || L_df_to_si */ | |
1436 | |
1437 #if defined(L_sf_to_usi) || defined(L_df_to_usi) || defined(L_tf_to_usi) | |
1438 #if defined US_SOFTWARE_GOFAST || defined(L_tf_to_usi) | |
1439 /* While libgcc2.c defines its own __fixunssfsi and __fixunsdfsi routines, | |
1440 we also define them for GOFAST because the ones in libgcc2.c have the | |
1441 wrong names and I'd rather define these here and keep GOFAST CYG-LOC's | |
1442 out of libgcc2.c. We can't define these here if not GOFAST because then | |
1443 there'd be duplicate copies. */ | |
1444 | |
1445 USItype | |
1446 float_to_usi (FLO_type arg_a) | |
1447 { | |
1448 fp_number_type a; | |
1449 FLO_union_type au; | |
1450 | |
1451 au.value = arg_a; | |
1452 unpack_d (&au, &a); | |
1453 | |
1454 if (iszero (&a)) | |
1455 return 0; | |
1456 if (isnan (&a)) | |
1457 return 0; | |
1458 /* it is a negative number */ | |
1459 if (a.sign) | |
1460 return 0; | |
1461 /* get reasonable MAX_USI_INT... */ | |
1462 if (isinf (&a)) | |
1463 return MAX_USI_INT; | |
1464 /* it is a number, but a small one */ | |
1465 if (a.normal_exp < 0) | |
1466 return 0; | |
1467 if (a.normal_exp > BITS_PER_SI - 1) | |
1468 return MAX_USI_INT; | |
1469 else if (a.normal_exp > (FRACBITS + NGARDS)) | |
1470 return a.fraction.ll << (a.normal_exp - (FRACBITS + NGARDS)); | |
1471 else | |
1472 return a.fraction.ll >> ((FRACBITS + NGARDS) - a.normal_exp); | |
1473 } | |
1474 #endif /* US_SOFTWARE_GOFAST */ | |
1475 #endif /* L_sf_to_usi || L_df_to_usi */ | |
1476 | |
1477 #if defined(L_negate_sf) || defined(L_negate_df) || defined(L_negate_tf) | |
1478 FLO_type | |
1479 negate (FLO_type arg_a) | |
1480 { | |
1481 fp_number_type a; | |
1482 FLO_union_type au; | |
1483 | |
1484 au.value = arg_a; | |
1485 unpack_d (&au, &a); | |
1486 | |
1487 flip_sign (&a); | |
1488 return pack_d (&a); | |
1489 } | |
1490 #endif /* L_negate_sf || L_negate_df */ | |
1491 | |
1492 #ifdef FLOAT | |
1493 | |
1494 #if defined(L_make_sf) | |
1495 SFtype | |
1496 __make_fp(fp_class_type class, | |
1497 unsigned int sign, | |
1498 int exp, | |
1499 USItype frac) | |
1500 { | |
1501 fp_number_type in; | |
1502 | |
1503 in.class = class; | |
1504 in.sign = sign; | |
1505 in.normal_exp = exp; | |
1506 in.fraction.ll = frac; | |
1507 return pack_d (&in); | |
1508 } | |
1509 #endif /* L_make_sf */ | |
1510 | |
1511 #ifndef FLOAT_ONLY | |
1512 | |
1513 /* This enables one to build an fp library that supports float but not double. | |
1514 Otherwise, we would get an undefined reference to __make_dp. | |
1515 This is needed for some 8-bit ports that can't handle well values that | |
1516 are 8-bytes in size, so we just don't support double for them at all. */ | |
1517 | |
1518 #if defined(L_sf_to_df) | |
1519 DFtype | |
1520 sf_to_df (SFtype arg_a) | |
1521 { | |
1522 fp_number_type in; | |
1523 FLO_union_type au; | |
1524 | |
1525 au.value = arg_a; | |
1526 unpack_d (&au, &in); | |
1527 | |
1528 return __make_dp (in.class, in.sign, in.normal_exp, | |
1529 ((UDItype) in.fraction.ll) << F_D_BITOFF); | |
1530 } | |
1531 #endif /* L_sf_to_df */ | |
1532 | |
1533 #if defined(L_sf_to_tf) && defined(TMODES) | |
1534 TFtype | |
1535 sf_to_tf (SFtype arg_a) | |
1536 { | |
1537 fp_number_type in; | |
1538 FLO_union_type au; | |
1539 | |
1540 au.value = arg_a; | |
1541 unpack_d (&au, &in); | |
1542 | |
1543 return __make_tp (in.class, in.sign, in.normal_exp, | |
1544 ((UTItype) in.fraction.ll) << F_T_BITOFF); | |
1545 } | |
1546 #endif /* L_sf_to_df */ | |
1547 | |
1548 #endif /* ! FLOAT_ONLY */ | |
1549 #endif /* FLOAT */ | |
1550 | |
1551 #ifndef FLOAT | |
1552 | |
1553 extern SFtype __make_fp (fp_class_type, unsigned int, int, USItype); | |
1554 | |
1555 #if defined(L_make_df) | |
1556 DFtype | |
1557 __make_dp (fp_class_type class, unsigned int sign, int exp, UDItype frac) | |
1558 { | |
1559 fp_number_type in; | |
1560 | |
1561 in.class = class; | |
1562 in.sign = sign; | |
1563 in.normal_exp = exp; | |
1564 in.fraction.ll = frac; | |
1565 return pack_d (&in); | |
1566 } | |
1567 #endif /* L_make_df */ | |
1568 | |
1569 #if defined(L_df_to_sf) | |
1570 SFtype | |
1571 df_to_sf (DFtype arg_a) | |
1572 { | |
1573 fp_number_type in; | |
1574 USItype sffrac; | |
1575 FLO_union_type au; | |
1576 | |
1577 au.value = arg_a; | |
1578 unpack_d (&au, &in); | |
1579 | |
1580 sffrac = in.fraction.ll >> F_D_BITOFF; | |
1581 | |
1582 /* We set the lowest guard bit in SFFRAC if we discarded any non | |
1583 zero bits. */ | |
1584 if ((in.fraction.ll & (((USItype) 1 << F_D_BITOFF) - 1)) != 0) | |
1585 sffrac |= 1; | |
1586 | |
1587 return __make_fp (in.class, in.sign, in.normal_exp, sffrac); | |
1588 } | |
1589 #endif /* L_df_to_sf */ | |
1590 | |
1591 #if defined(L_df_to_tf) && defined(TMODES) \ | |
1592 && !defined(FLOAT) && !defined(TFLOAT) | |
1593 TFtype | |
1594 df_to_tf (DFtype arg_a) | |
1595 { | |
1596 fp_number_type in; | |
1597 FLO_union_type au; | |
1598 | |
1599 au.value = arg_a; | |
1600 unpack_d (&au, &in); | |
1601 | |
1602 return __make_tp (in.class, in.sign, in.normal_exp, | |
1603 ((UTItype) in.fraction.ll) << D_T_BITOFF); | |
1604 } | |
1605 #endif /* L_sf_to_df */ | |
1606 | |
1607 #ifdef TFLOAT | |
1608 #if defined(L_make_tf) | |
1609 TFtype | |
1610 __make_tp(fp_class_type class, | |
1611 unsigned int sign, | |
1612 int exp, | |
1613 UTItype frac) | |
1614 { | |
1615 fp_number_type in; | |
1616 | |
1617 in.class = class; | |
1618 in.sign = sign; | |
1619 in.normal_exp = exp; | |
1620 in.fraction.ll = frac; | |
1621 return pack_d (&in); | |
1622 } | |
1623 #endif /* L_make_tf */ | |
1624 | |
1625 #if defined(L_tf_to_df) | |
1626 DFtype | |
1627 tf_to_df (TFtype arg_a) | |
1628 { | |
1629 fp_number_type in; | |
1630 UDItype sffrac; | |
1631 FLO_union_type au; | |
1632 | |
1633 au.value = arg_a; | |
1634 unpack_d (&au, &in); | |
1635 | |
1636 sffrac = in.fraction.ll >> D_T_BITOFF; | |
1637 | |
1638 /* We set the lowest guard bit in SFFRAC if we discarded any non | |
1639 zero bits. */ | |
1640 if ((in.fraction.ll & (((UTItype) 1 << D_T_BITOFF) - 1)) != 0) | |
1641 sffrac |= 1; | |
1642 | |
1643 return __make_dp (in.class, in.sign, in.normal_exp, sffrac); | |
1644 } | |
1645 #endif /* L_tf_to_df */ | |
1646 | |
1647 #if defined(L_tf_to_sf) | |
1648 SFtype | |
1649 tf_to_sf (TFtype arg_a) | |
1650 { | |
1651 fp_number_type in; | |
1652 USItype sffrac; | |
1653 FLO_union_type au; | |
1654 | |
1655 au.value = arg_a; | |
1656 unpack_d (&au, &in); | |
1657 | |
1658 sffrac = in.fraction.ll >> F_T_BITOFF; | |
1659 | |
1660 /* We set the lowest guard bit in SFFRAC if we discarded any non | |
1661 zero bits. */ | |
1662 if ((in.fraction.ll & (((UTItype) 1 << F_T_BITOFF) - 1)) != 0) | |
1663 sffrac |= 1; | |
1664 | |
1665 return __make_fp (in.class, in.sign, in.normal_exp, sffrac); | |
1666 } | |
1667 #endif /* L_tf_to_sf */ | |
1668 #endif /* TFLOAT */ | |
1669 | |
1670 #endif /* ! FLOAT */ | |
1671 #endif /* !EXTENDED_FLOAT_STUBS */ |