[PATCH 22/57][Arm][GAS] Add support for MVE instructions: vmlaldav, vmlalv, vmlsldav...
[binutils-gdb.git] / sim / ppc / dp-bit.c
blob5318ec1ed4e1534136188d7467f36f8dc737d939
1 /* This is a software floating point library which can be used instead of
2 the floating point routines in libgcc1.c for targets without hardware
3 floating point. */
5 /* Copyright (C) 1994-2019 Free Software Foundation, Inc.
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
20 /* As a special exception, if you link this library with other files,
21 some of which are compiled with GCC, to produce an executable,
22 this library does not by itself cause the resulting executable
23 to be covered by the GNU General Public License.
24 This exception does not however invalidate any other reasons why
25 the executable file might be covered by the GNU General Public License. */
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.
31 The original code by Steve Chamberlain, hacked by Mark Eichin and Jim
32 Wilson, all of Cygnus Support. */
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. */
37 /* The following macros can be defined to change the behaviour of this file:
38 FLOAT: Implement a `float', aka SFmode, fp library. If this is not
39 defined, then this file implements a `double', aka DFmode, fp library.
40 FLOAT_ONLY: Used with FLOAT, to implement a `float' only library, i.e.
41 don't include float->double conversion which requires the double library.
42 This is useful only for machines which can't support doubles, e.g. some
43 8-bit processors.
44 CMPtype: Specify the type that floating point compares should return.
45 This defaults to SItype, aka int.
46 US_SOFTWARE_GOFAST: This makes all entry points use the same names as the
47 US Software goFast library. If this is not defined, the entry points use
48 the same names as libgcc1.c.
49 _DEBUG_BITFLOAT: This makes debugging the code a little easier, by adding
50 two integers to the FLO_union_type.
51 NO_NANS: Disable nan and infinity handling
52 SMALL_MACHINE: Useful when operations on QIs and HIs are faster
53 than on an SI */
55 #ifndef SFtype
56 typedef SFtype __attribute__ ((mode (SF)));
57 #endif
58 #ifndef DFtype
59 typedef DFtype __attribute__ ((mode (DF)));
60 #endif
62 #ifndef HItype
63 typedef int HItype __attribute__ ((mode (HI)));
64 #endif
65 #ifndef SItype
66 typedef int SItype __attribute__ ((mode (SI)));
67 #endif
68 #ifndef DItype
69 typedef int DItype __attribute__ ((mode (DI)));
70 #endif
72 /* The type of the result of a fp compare */
73 #ifndef CMPtype
74 #define CMPtype SItype
75 #endif
77 #ifndef UHItype
78 typedef unsigned int UHItype __attribute__ ((mode (HI)));
79 #endif
80 #ifndef USItype
81 typedef unsigned int USItype __attribute__ ((mode (SI)));
82 #endif
83 #ifndef UDItype
84 typedef unsigned int UDItype __attribute__ ((mode (DI)));
85 #endif
87 #define MAX_SI_INT ((SItype) ((unsigned) (~0)>>1))
88 #define MAX_USI_INT ((USItype) ~0)
91 #ifdef FLOAT_ONLY
92 #define NO_DI_MODE
93 #endif
95 #ifdef FLOAT
96 # define NGARDS 7L
97 # define GARDROUND 0x3f
98 # define GARDMASK 0x7f
99 # define GARDMSB 0x40
100 # define EXPBITS 8
101 # define EXPBIAS 127
102 # define FRACBITS 23
103 # define EXPMAX (0xff)
104 # define QUIET_NAN 0x100000L
105 # define FRAC_NBITS 32
106 # define FRACHIGH 0x80000000L
107 # define FRACHIGH2 0xc0000000L
108 typedef USItype fractype;
109 typedef UHItype halffractype;
110 typedef SFtype FLO_type;
111 typedef SItype intfrac;
113 #else
114 # define PREFIXFPDP dp
115 # define PREFIXSFDF df
116 # define NGARDS 8L
117 # define GARDROUND 0x7f
118 # define GARDMASK 0xff
119 # define GARDMSB 0x80
120 # define EXPBITS 11
121 # define EXPBIAS 1023
122 # define FRACBITS 52
123 # define EXPMAX (0x7ff)
124 # define QUIET_NAN 0x8000000000000LL
125 # define FRAC_NBITS 64
126 # define FRACHIGH 0x8000000000000000LL
127 # define FRACHIGH2 0xc000000000000000LL
128 typedef UDItype fractype;
129 typedef USItype halffractype;
130 typedef DFtype FLO_type;
131 typedef DItype intfrac;
132 #endif
134 #ifdef US_SOFTWARE_GOFAST
135 # ifdef FLOAT
136 # define add fpadd
137 # define sub fpsub
138 # define multiply fpmul
139 # define divide fpdiv
140 # define compare fpcmp
141 # define si_to_float sitofp
142 # define float_to_si fptosi
143 # define float_to_usi fptoui
144 # define negate __negsf2
145 # define sf_to_df fptodp
146 # define dptofp dptofp
147 #else
148 # define add dpadd
149 # define sub dpsub
150 # define multiply dpmul
151 # define divide dpdiv
152 # define compare dpcmp
153 # define si_to_float litodp
154 # define float_to_si dptoli
155 # define float_to_usi dptoul
156 # define negate __negdf2
157 # define df_to_sf dptofp
158 #endif
159 #else
160 # ifdef FLOAT
161 # define add __addsf3
162 # define sub __subsf3
163 # define multiply __mulsf3
164 # define divide __divsf3
165 # define compare __cmpsf2
166 # define _eq_f2 __eqsf2
167 # define _ne_f2 __nesf2
168 # define _gt_f2 __gtsf2
169 # define _ge_f2 __gesf2
170 # define _lt_f2 __ltsf2
171 # define _le_f2 __lesf2
172 # define si_to_float __floatsisf
173 # define float_to_si __fixsfsi
174 # define float_to_usi __fixunssfsi
175 # define negate __negsf2
176 # define sf_to_df __extendsfdf2
177 #else
178 # define add __adddf3
179 # define sub __subdf3
180 # define multiply __muldf3
181 # define divide __divdf3
182 # define compare __cmpdf2
183 # define _eq_f2 __eqdf2
184 # define _ne_f2 __nedf2
185 # define _gt_f2 __gtdf2
186 # define _ge_f2 __gedf2
187 # define _lt_f2 __ltdf2
188 # define _le_f2 __ledf2
189 # define si_to_float __floatsidf
190 # define float_to_si __fixdfsi
191 # define float_to_usi __fixunsdfsi
192 # define negate __negdf2
193 # define df_to_sf __truncdfsf2
194 # endif
195 #endif
198 #ifndef INLINE
199 #define INLINE __inline__
200 #endif
202 /* Preserve the sticky-bit when shifting fractions to the right. */
203 #define LSHIFT(a) { a = (a & 1) | (a >> 1); }
205 /* numeric parameters */
206 /* F_D_BITOFF is the number of bits offset between the MSB of the mantissa
207 of a float and of a double. Assumes there are only two float types.
208 (double::FRAC_BITS+double::NGARGS-(float::FRAC_BITS-float::NGARDS))
210 #define F_D_BITOFF (52+8-(23+7))
213 #define NORMAL_EXPMIN (-(EXPBIAS)+1)
214 #define IMPLICIT_1 (1LL<<(FRACBITS+NGARDS))
215 #define IMPLICIT_2 (1LL<<(FRACBITS+1+NGARDS))
217 /* common types */
219 typedef enum
221 CLASS_SNAN,
222 CLASS_QNAN,
223 CLASS_ZERO,
224 CLASS_NUMBER,
225 CLASS_INFINITY
226 } fp_class_type;
228 typedef struct
230 #ifdef SMALL_MACHINE
231 char class;
232 unsigned char sign;
233 short normal_exp;
234 #else
235 fp_class_type class;
236 unsigned int sign;
237 int normal_exp;
238 #endif
240 union
242 fractype ll;
243 halffractype l[2];
244 } fraction;
245 } fp_number_type;
247 typedef union
249 FLO_type value;
250 #ifdef _DEBUG_BITFLOAT
251 int l[2];
252 #endif
253 struct
255 #ifndef FLOAT_BIT_ORDER_MISMATCH
256 unsigned int sign:1 __attribute__ ((packed));
257 unsigned int exp:EXPBITS __attribute__ ((packed));
258 fractype fraction:FRACBITS __attribute__ ((packed));
259 #else
260 fractype fraction:FRACBITS __attribute__ ((packed));
261 unsigned int exp:EXPBITS __attribute__ ((packed));
262 unsigned int sign:1 __attribute__ ((packed));
263 #endif
265 bits;
267 FLO_union_type;
270 /* end of header */
272 /* IEEE "special" number predicates */
274 #ifdef NO_NANS
276 #define nan() 0
277 #define isnan(x) 0
278 #define isinf(x) 0
279 #else
281 INLINE
282 static fp_number_type *
283 nan ()
285 static fp_number_type thenan;
287 return &thenan;
290 INLINE
291 static int
292 isnan ( fp_number_type * x)
294 return x->class == CLASS_SNAN || x->class == CLASS_QNAN;
297 INLINE
298 static int
299 isinf ( fp_number_type * x)
301 return x->class == CLASS_INFINITY;
304 #endif
306 INLINE
307 static int
308 iszero ( fp_number_type * x)
310 return x->class == CLASS_ZERO;
313 INLINE
314 static void
315 flip_sign ( fp_number_type * x)
317 x->sign = !x->sign;
320 static FLO_type
321 pack_d ( fp_number_type * src)
323 FLO_union_type dst;
324 fractype fraction = src->fraction.ll; /* wasn't unsigned before? */
326 dst.bits.sign = src->sign;
328 if (isnan (src))
330 dst.bits.exp = EXPMAX;
331 dst.bits.fraction = src->fraction.ll;
332 if (src->class == CLASS_QNAN || 1)
334 dst.bits.fraction |= QUIET_NAN;
337 else if (isinf (src))
339 dst.bits.exp = EXPMAX;
340 dst.bits.fraction = 0;
342 else if (iszero (src))
344 dst.bits.exp = 0;
345 dst.bits.fraction = 0;
347 else if (fraction == 0)
349 dst.value = 0;
351 else
353 if (src->normal_exp < NORMAL_EXPMIN)
355 /* This number's exponent is too low to fit into the bits
356 available in the number, so we'll store 0 in the exponent and
357 shift the fraction to the right to make up for it. */
359 int shift = NORMAL_EXPMIN - src->normal_exp;
361 dst.bits.exp = 0;
363 if (shift > FRAC_NBITS - NGARDS)
365 /* No point shifting, since it's more that 64 out. */
366 fraction = 0;
368 else
370 /* Shift by the value */
371 fraction >>= shift;
373 fraction >>= NGARDS;
374 dst.bits.fraction = fraction;
376 else if (src->normal_exp > EXPBIAS)
378 dst.bits.exp = EXPMAX;
379 dst.bits.fraction = 0;
381 else
383 dst.bits.exp = src->normal_exp + EXPBIAS;
384 /* IF the gard bits are the all zero, but the first, then we're
385 half way between two numbers, choose the one which makes the
386 lsb of the answer 0. */
387 if ((fraction & GARDMASK) == GARDMSB)
389 if (fraction & (1 << NGARDS))
390 fraction += GARDROUND + 1;
392 else
394 /* Add a one to the guards to round up */
395 fraction += GARDROUND;
397 if (fraction >= IMPLICIT_2)
399 fraction >>= 1;
400 dst.bits.exp += 1;
402 fraction >>= NGARDS;
403 dst.bits.fraction = fraction;
406 return dst.value;
409 static void
410 unpack_d (FLO_union_type * src, fp_number_type * dst)
412 fractype fraction = src->bits.fraction;
414 dst->sign = src->bits.sign;
415 if (src->bits.exp == 0)
417 /* Hmm. Looks like 0 */
418 if (fraction == 0)
420 /* tastes like zero */
421 dst->class = CLASS_ZERO;
423 else
425 /* Zero exponent with non zero fraction - it's denormalized,
426 so there isn't a leading implicit one - we'll shift it so
427 it gets one. */
428 dst->normal_exp = src->bits.exp - EXPBIAS + 1;
429 fraction <<= NGARDS;
431 dst->class = CLASS_NUMBER;
432 #if 1
433 while (fraction < IMPLICIT_1)
435 fraction <<= 1;
436 dst->normal_exp--;
438 #endif
439 dst->fraction.ll = fraction;
442 else if (src->bits.exp == EXPMAX)
444 /* Huge exponent*/
445 if (fraction == 0)
447 /* Attached to a zero fraction - means infinity */
448 dst->class = CLASS_INFINITY;
450 else
452 /* Non zero fraction, means nan */
453 if (dst->sign)
455 dst->class = CLASS_SNAN;
457 else
459 dst->class = CLASS_QNAN;
461 /* Keep the fraction part as the nan number */
462 dst->fraction.ll = fraction;
465 else
467 /* Nothing strange about this number */
468 dst->normal_exp = src->bits.exp - EXPBIAS;
469 dst->class = CLASS_NUMBER;
470 dst->fraction.ll = (fraction << NGARDS) | IMPLICIT_1;
474 static fp_number_type *
475 _fpadd_parts (fp_number_type * a,
476 fp_number_type * b,
477 fp_number_type * tmp)
479 intfrac tfraction;
481 /* Put commonly used fields in local variables. */
482 int a_normal_exp;
483 int b_normal_exp;
484 fractype a_fraction;
485 fractype b_fraction;
487 if (isnan (a))
489 return a;
491 if (isnan (b))
493 return b;
495 if (isinf (a))
497 /* Adding infinities with opposite signs yields a NaN. */
498 if (isinf (b) && a->sign != b->sign)
499 return nan ();
500 return a;
502 if (isinf (b))
504 return b;
506 if (iszero (b))
508 return a;
510 if (iszero (a))
512 return b;
515 /* Got two numbers. shift the smaller and increment the exponent till
516 they're the same */
518 int diff;
520 a_normal_exp = a->normal_exp;
521 b_normal_exp = b->normal_exp;
522 a_fraction = a->fraction.ll;
523 b_fraction = b->fraction.ll;
525 diff = a_normal_exp - b_normal_exp;
527 if (diff < 0)
528 diff = -diff;
529 if (diff < FRAC_NBITS)
531 /* ??? This does shifts one bit at a time. Optimize. */
532 while (a_normal_exp > b_normal_exp)
534 b_normal_exp++;
535 LSHIFT (b_fraction);
537 while (b_normal_exp > a_normal_exp)
539 a_normal_exp++;
540 LSHIFT (a_fraction);
543 else
545 /* Somethings's up.. choose the biggest */
546 if (a_normal_exp > b_normal_exp)
548 b_normal_exp = a_normal_exp;
549 b_fraction = 0;
551 else
553 a_normal_exp = b_normal_exp;
554 a_fraction = 0;
559 if (a->sign != b->sign)
561 if (a->sign)
563 tfraction = -a_fraction + b_fraction;
565 else
567 tfraction = a_fraction - b_fraction;
569 if (tfraction > 0)
571 tmp->sign = 0;
572 tmp->normal_exp = a_normal_exp;
573 tmp->fraction.ll = tfraction;
575 else
577 tmp->sign = 1;
578 tmp->normal_exp = a_normal_exp;
579 tmp->fraction.ll = -tfraction;
581 /* and renormalize it */
583 while (tmp->fraction.ll < IMPLICIT_1 && tmp->fraction.ll)
585 tmp->fraction.ll <<= 1;
586 tmp->normal_exp--;
589 else
591 tmp->sign = a->sign;
592 tmp->normal_exp = a_normal_exp;
593 tmp->fraction.ll = a_fraction + b_fraction;
595 tmp->class = CLASS_NUMBER;
596 /* Now the fraction is added, we have to shift down to renormalize the
597 number */
599 if (tmp->fraction.ll >= IMPLICIT_2)
601 LSHIFT (tmp->fraction.ll);
602 tmp->normal_exp++;
604 return tmp;
608 FLO_type
609 add (FLO_type arg_a, FLO_type arg_b)
611 fp_number_type a;
612 fp_number_type b;
613 fp_number_type tmp;
614 fp_number_type *res;
616 unpack_d ((FLO_union_type *) & arg_a, &a);
617 unpack_d ((FLO_union_type *) & arg_b, &b);
619 res = _fpadd_parts (&a, &b, &tmp);
621 return pack_d (res);
624 FLO_type
625 sub (FLO_type arg_a, FLO_type arg_b)
627 fp_number_type a;
628 fp_number_type b;
629 fp_number_type tmp;
630 fp_number_type *res;
632 unpack_d ((FLO_union_type *) & arg_a, &a);
633 unpack_d ((FLO_union_type *) & arg_b, &b);
635 b.sign ^= 1;
637 res = _fpadd_parts (&a, &b, &tmp);
639 return pack_d (res);
642 static fp_number_type *
643 _fpmul_parts ( fp_number_type * a,
644 fp_number_type * b,
645 fp_number_type * tmp)
647 fractype low = 0;
648 fractype high = 0;
650 if (isnan (a))
652 a->sign = a->sign != b->sign;
653 return a;
655 if (isnan (b))
657 b->sign = a->sign != b->sign;
658 return b;
660 if (isinf (a))
662 if (iszero (b))
663 return nan ();
664 a->sign = a->sign != b->sign;
665 return a;
667 if (isinf (b))
669 if (iszero (a))
671 return nan ();
673 b->sign = a->sign != b->sign;
674 return b;
676 if (iszero (a))
678 a->sign = a->sign != b->sign;
679 return a;
681 if (iszero (b))
683 b->sign = a->sign != b->sign;
684 return b;
687 /* Calculate the mantissa by multiplying both 64bit numbers to get a
688 128 bit number */
690 fractype x = a->fraction.ll;
691 fractype ylow = b->fraction.ll;
692 fractype yhigh = 0;
693 int bit;
695 #if defined(NO_DI_MODE)
697 /* ??? This does multiplies one bit at a time. Optimize. */
698 for (bit = 0; bit < FRAC_NBITS; bit++)
700 int carry;
702 if (x & 1)
704 carry = (low += ylow) < ylow;
705 high += yhigh + carry;
707 yhigh <<= 1;
708 if (ylow & FRACHIGH)
710 yhigh |= 1;
712 ylow <<= 1;
713 x >>= 1;
716 #elif defined(FLOAT)
718 /* Multiplying two 32 bit numbers to get a 64 bit number on
719 a machine with DI, so we're safe */
721 DItype answer = (DItype)(a->fraction.ll) * (DItype)(b->fraction.ll);
723 high = answer >> 32;
724 low = answer;
726 #else
727 /* Doing a 64*64 to 128 */
729 UDItype nl = a->fraction.ll & 0xffffffff;
730 UDItype nh = a->fraction.ll >> 32;
731 UDItype ml = b->fraction.ll & 0xffffffff;
732 UDItype mh = b->fraction.ll >>32;
733 UDItype pp_ll = ml * nl;
734 UDItype pp_hl = mh * nl;
735 UDItype pp_lh = ml * nh;
736 UDItype pp_hh = mh * nh;
737 UDItype res2 = 0;
738 UDItype res0 = 0;
739 UDItype ps_hh__ = pp_hl + pp_lh;
740 if (ps_hh__ < pp_hl)
741 res2 += 0x100000000LL;
742 pp_hl = (ps_hh__ << 32) & 0xffffffff00000000LL;
743 res0 = pp_ll + pp_hl;
744 if (res0 < pp_ll)
745 res2++;
746 res2 += ((ps_hh__ >> 32) & 0xffffffffL) + pp_hh;
747 high = res2;
748 low = res0;
750 #endif
753 tmp->normal_exp = a->normal_exp + b->normal_exp;
754 tmp->sign = a->sign != b->sign;
755 #ifdef FLOAT
756 tmp->normal_exp += 2; /* ??????????????? */
757 #else
758 tmp->normal_exp += 4; /* ??????????????? */
759 #endif
760 while (high >= IMPLICIT_2)
762 tmp->normal_exp++;
763 if (high & 1)
765 low >>= 1;
766 low |= FRACHIGH;
768 high >>= 1;
770 while (high < IMPLICIT_1)
772 tmp->normal_exp--;
774 high <<= 1;
775 if (low & FRACHIGH)
776 high |= 1;
777 low <<= 1;
779 /* rounding is tricky. if we only round if it won't make us round later. */
780 #if 0
781 if (low & FRACHIGH2)
783 if (((high & GARDMASK) != GARDMSB)
784 && (((high + 1) & GARDMASK) == GARDMSB))
786 /* don't round, it gets done again later. */
788 else
790 high++;
793 #endif
794 if ((high & GARDMASK) == GARDMSB)
796 if (high & (1 << NGARDS))
798 /* half way, so round to even */
799 high += GARDROUND + 1;
801 else if (low)
803 /* but we really weren't half way */
804 high += GARDROUND + 1;
807 tmp->fraction.ll = high;
808 tmp->class = CLASS_NUMBER;
809 return tmp;
812 FLO_type
813 multiply (FLO_type arg_a, FLO_type arg_b)
815 fp_number_type a;
816 fp_number_type b;
817 fp_number_type tmp;
818 fp_number_type *res;
820 unpack_d ((FLO_union_type *) & arg_a, &a);
821 unpack_d ((FLO_union_type *) & arg_b, &b);
823 res = _fpmul_parts (&a, &b, &tmp);
825 return pack_d (res);
828 static fp_number_type *
829 _fpdiv_parts (fp_number_type * a,
830 fp_number_type * b,
831 fp_number_type * tmp)
833 fractype low = 0;
834 fractype high = 0;
835 fractype r0, r1, y0, y1, bit;
836 fractype q;
837 fractype numerator;
838 fractype denominator;
839 fractype quotient;
840 fractype remainder;
842 if (isnan (a))
844 return a;
846 if (isnan (b))
848 return b;
850 if (isinf (a) || iszero (a))
852 if (a->class == b->class)
853 return nan ();
854 return a;
856 a->sign = a->sign ^ b->sign;
858 if (isinf (b))
860 a->fraction.ll = 0;
861 a->normal_exp = 0;
862 return a;
864 if (iszero (b))
866 a->class = CLASS_INFINITY;
867 return b;
870 /* Calculate the mantissa by multiplying both 64bit numbers to get a
871 128 bit number */
873 int carry;
874 intfrac d0, d1; /* weren't unsigned before ??? */
876 /* quotient =
877 ( numerator / denominator) * 2^(numerator exponent - denominator exponent)
880 a->normal_exp = a->normal_exp - b->normal_exp;
881 numerator = a->fraction.ll;
882 denominator = b->fraction.ll;
884 if (numerator < denominator)
886 /* Fraction will be less than 1.0 */
887 numerator *= 2;
888 a->normal_exp--;
890 bit = IMPLICIT_1;
891 quotient = 0;
892 /* ??? Does divide one bit at a time. Optimize. */
893 while (bit)
895 if (numerator >= denominator)
897 quotient |= bit;
898 numerator -= denominator;
900 bit >>= 1;
901 numerator *= 2;
904 if ((quotient & GARDMASK) == GARDMSB)
906 if (quotient & (1 << NGARDS))
908 /* half way, so round to even */
909 quotient += GARDROUND + 1;
911 else if (numerator)
913 /* but we really weren't half way, more bits exist */
914 quotient += GARDROUND + 1;
918 a->fraction.ll = quotient;
919 return (a);
923 FLO_type
924 divide (FLO_type arg_a, FLO_type arg_b)
926 fp_number_type a;
927 fp_number_type b;
928 fp_number_type tmp;
929 fp_number_type *res;
931 unpack_d ((FLO_union_type *) & arg_a, &a);
932 unpack_d ((FLO_union_type *) & arg_b, &b);
934 res = _fpdiv_parts (&a, &b, &tmp);
936 return pack_d (res);
939 /* according to the demo, fpcmp returns a comparison with 0... thus
940 a<b -> -1
941 a==b -> 0
942 a>b -> +1
945 static int
946 _fpcmp_parts (fp_number_type * a, fp_number_type * b)
948 #if 0
949 /* either nan -> unordered. Must be checked outside of this routine. */
950 if (isnan (a) && isnan (b))
952 return 1; /* still unordered! */
954 #endif
956 if (isnan (a) || isnan (b))
958 return 1; /* how to indicate unordered compare? */
960 if (isinf (a) && isinf (b))
962 /* +inf > -inf, but +inf != +inf */
963 /* b \a| +inf(0)| -inf(1)
964 ______\+--------+--------
965 +inf(0)| a==b(0)| a<b(-1)
966 -------+--------+--------
967 -inf(1)| a>b(1) | a==b(0)
968 -------+--------+--------
969 So since unordered must be non zero, just line up the columns...
971 return b->sign - a->sign;
973 /* but not both... */
974 if (isinf (a))
976 return a->sign ? -1 : 1;
978 if (isinf (b))
980 return b->sign ? 1 : -1;
982 if (iszero (a) && iszero (b))
984 return 0;
986 if (iszero (a))
988 return b->sign ? 1 : -1;
990 if (iszero (b))
992 return a->sign ? -1 : 1;
994 /* now both are "normal". */
995 if (a->sign != b->sign)
997 /* opposite signs */
998 return a->sign ? -1 : 1;
1000 /* same sign; exponents? */
1001 if (a->normal_exp > b->normal_exp)
1003 return a->sign ? -1 : 1;
1005 if (a->normal_exp < b->normal_exp)
1007 return a->sign ? 1 : -1;
1009 /* same exponents; check size. */
1010 if (a->fraction.ll > b->fraction.ll)
1012 return a->sign ? -1 : 1;
1014 if (a->fraction.ll < b->fraction.ll)
1016 return a->sign ? 1 : -1;
1018 /* after all that, they're equal. */
1019 return 0;
1022 CMPtype
1023 compare (FLO_type arg_a, FLO_type arg_b)
1025 fp_number_type a;
1026 fp_number_type b;
1028 unpack_d ((FLO_union_type *) & arg_a, &a);
1029 unpack_d ((FLO_union_type *) & arg_b, &b);
1031 return _fpcmp_parts (&a, &b);
1034 #ifndef US_SOFTWARE_GOFAST
1036 /* These should be optimized for their specific tasks someday. */
1038 CMPtype
1039 _eq_f2 (FLO_type arg_a, FLO_type arg_b)
1041 fp_number_type a;
1042 fp_number_type b;
1044 unpack_d ((FLO_union_type *) & arg_a, &a);
1045 unpack_d ((FLO_union_type *) & arg_b, &b);
1047 if (isnan (&a) || isnan (&b))
1048 return 1; /* false, truth == 0 */
1050 return _fpcmp_parts (&a, &b) ;
1053 CMPtype
1054 _ne_f2 (FLO_type arg_a, FLO_type arg_b)
1056 fp_number_type a;
1057 fp_number_type b;
1059 unpack_d ((FLO_union_type *) & arg_a, &a);
1060 unpack_d ((FLO_union_type *) & arg_b, &b);
1062 if (isnan (&a) || isnan (&b))
1063 return 1; /* true, truth != 0 */
1065 return _fpcmp_parts (&a, &b) ;
1068 CMPtype
1069 _gt_f2 (FLO_type arg_a, FLO_type arg_b)
1071 fp_number_type a;
1072 fp_number_type b;
1074 unpack_d ((FLO_union_type *) & arg_a, &a);
1075 unpack_d ((FLO_union_type *) & arg_b, &b);
1077 if (isnan (&a) || isnan (&b))
1078 return -1; /* false, truth > 0 */
1080 return _fpcmp_parts (&a, &b);
1083 CMPtype
1084 _ge_f2 (FLO_type arg_a, FLO_type arg_b)
1086 fp_number_type a;
1087 fp_number_type b;
1089 unpack_d ((FLO_union_type *) & arg_a, &a);
1090 unpack_d ((FLO_union_type *) & arg_b, &b);
1092 if (isnan (&a) || isnan (&b))
1093 return -1; /* false, truth >= 0 */
1094 return _fpcmp_parts (&a, &b) ;
1097 CMPtype
1098 _lt_f2 (FLO_type arg_a, FLO_type arg_b)
1100 fp_number_type a;
1101 fp_number_type b;
1103 unpack_d ((FLO_union_type *) & arg_a, &a);
1104 unpack_d ((FLO_union_type *) & arg_b, &b);
1106 if (isnan (&a) || isnan (&b))
1107 return 1; /* false, truth < 0 */
1109 return _fpcmp_parts (&a, &b);
1112 CMPtype
1113 _le_f2 (FLO_type arg_a, FLO_type arg_b)
1115 fp_number_type a;
1116 fp_number_type b;
1118 unpack_d ((FLO_union_type *) & arg_a, &a);
1119 unpack_d ((FLO_union_type *) & arg_b, &b);
1121 if (isnan (&a) || isnan (&b))
1122 return 1; /* false, truth <= 0 */
1124 return _fpcmp_parts (&a, &b) ;
1127 #endif /* ! US_SOFTWARE_GOFAST */
1129 FLO_type
1130 si_to_float (SItype arg_a)
1132 fp_number_type in;
1134 in.class = CLASS_NUMBER;
1135 in.sign = arg_a < 0;
1136 if (!arg_a)
1138 in.class = CLASS_ZERO;
1140 else
1142 in.normal_exp = FRACBITS + NGARDS;
1143 if (in.sign)
1145 /* Special case for minint, since there is no +ve integer
1146 representation for it */
1147 if (arg_a == 0x80000000)
1149 return -2147483648.0;
1151 in.fraction.ll = (-arg_a);
1153 else
1154 in.fraction.ll = arg_a;
1156 while (in.fraction.ll < (1LL << (FRACBITS + NGARDS)))
1158 in.fraction.ll <<= 1;
1159 in.normal_exp -= 1;
1162 return pack_d (&in);
1165 SItype
1166 float_to_si (FLO_type arg_a)
1168 fp_number_type a;
1169 SItype tmp;
1171 unpack_d ((FLO_union_type *) & arg_a, &a);
1172 if (iszero (&a))
1173 return 0;
1174 if (isnan (&a))
1175 return 0;
1176 /* get reasonable MAX_SI_INT... */
1177 if (isinf (&a))
1178 return a.sign ? MAX_SI_INT : (-MAX_SI_INT)-1;
1179 /* it is a number, but a small one */
1180 if (a.normal_exp < 0)
1181 return 0;
1182 if (a.normal_exp > 30)
1183 return a.sign ? (-MAX_SI_INT)-1 : MAX_SI_INT;
1184 tmp = a.fraction.ll >> ((FRACBITS + NGARDS) - a.normal_exp);
1185 return a.sign ? (-tmp) : (tmp);
1188 #ifdef US_SOFTWARE_GOFAST
1189 /* While libgcc2.c defines its own __fixunssfsi and __fixunsdfsi routines,
1190 we also define them for GOFAST because the ones in libgcc2.c have the
1191 wrong names and I'd rather define these here and keep GOFAST CYG-LOC's
1192 out of libgcc2.c. We can't define these here if not GOFAST because then
1193 there'd be duplicate copies. */
1195 USItype
1196 float_to_usi (FLO_type arg_a)
1198 fp_number_type a;
1200 unpack_d ((FLO_union_type *) & arg_a, &a);
1201 if (iszero (&a))
1202 return 0;
1203 if (isnan (&a))
1204 return 0;
1205 /* get reasonable MAX_USI_INT... */
1206 if (isinf (&a))
1207 return a.sign ? MAX_USI_INT : 0;
1208 /* it is a negative number */
1209 if (a.sign)
1210 return 0;
1211 /* it is a number, but a small one */
1212 if (a.normal_exp < 0)
1213 return 0;
1214 if (a.normal_exp > 31)
1215 return MAX_USI_INT;
1216 else if (a.normal_exp > (FRACBITS + NGARDS))
1217 return a.fraction.ll << ((FRACBITS + NGARDS) - a.normal_exp);
1218 else
1219 return a.fraction.ll >> ((FRACBITS + NGARDS) - a.normal_exp);
1221 #endif
1223 FLO_type
1224 negate (FLO_type arg_a)
1226 fp_number_type a;
1228 unpack_d ((FLO_union_type *) & arg_a, &a);
1229 flip_sign (&a);
1230 return pack_d (&a);
1233 #ifdef FLOAT
1235 SFtype
1236 __make_fp(fp_class_type class,
1237 unsigned int sign,
1238 int exp,
1239 USItype frac)
1241 fp_number_type in;
1243 in.class = class;
1244 in.sign = sign;
1245 in.normal_exp = exp;
1246 in.fraction.ll = frac;
1247 return pack_d (&in);
1250 #ifndef FLOAT_ONLY
1252 /* This enables one to build an fp library that supports float but not double.
1253 Otherwise, we would get an undefined reference to __make_dp.
1254 This is needed for some 8-bit ports that can't handle well values that
1255 are 8-bytes in size, so we just don't support double for them at all. */
1257 extern DFtype __make_dp (fp_class_type, unsigned int, int, UDItype frac);
1259 DFtype
1260 sf_to_df (SFtype arg_a)
1262 fp_number_type in;
1264 unpack_d ((FLO_union_type *) & arg_a, &in);
1265 return __make_dp (in.class, in.sign, in.normal_exp,
1266 ((UDItype) in.fraction.ll) << F_D_BITOFF);
1269 #endif
1270 #endif
1272 #ifndef FLOAT
1274 extern SFtype __make_fp (fp_class_type, unsigned int, int, USItype);
1276 DFtype
1277 __make_dp (fp_class_type class, unsigned int sign, int exp, UDItype frac)
1279 fp_number_type in;
1281 in.class = class;
1282 in.sign = sign;
1283 in.normal_exp = exp;
1284 in.fraction.ll = frac;
1285 return pack_d (&in);
1288 SFtype
1289 df_to_sf (DFtype arg_a)
1291 fp_number_type in;
1293 unpack_d ((FLO_union_type *) & arg_a, &in);
1294 return __make_fp (in.class, in.sign, in.normal_exp,
1295 in.fraction.ll >> F_D_BITOFF);
1298 #endif