[BACK]Return to quad_float.h CVS log [TXT][DIR] Up to [local] / sys / arch / hppa / spmath

Annotation of sys/arch/hppa/spmath/quad_float.h, Revision 1.1.1.1

1.1       nbrk        1: /*     $OpenBSD: quad_float.h,v 1.8 2003/04/10 17:27:58 mickey Exp $   */
                      2: /*
                      3:   (c) Copyright 1986 HEWLETT-PACKARD COMPANY
                      4:   To anyone who acknowledges that this file is provided "AS IS"
                      5:   without any express or implied warranty:
                      6:       permission to use, copy, modify, and distribute this file
                      7:   for any purpose is hereby granted without fee, provided that
                      8:   the above copyright notice and this notice appears in all
                      9:   copies, and that the name of Hewlett-Packard Company not be
                     10:   used in advertising or publicity pertaining to distribution
                     11:   of the software without specific, written prior permission.
                     12:   Hewlett-Packard Company makes no representations about the
                     13:   suitability of this software for any purpose.
                     14: */
                     15: /* @(#)quad_float.h: Revision: 1.7.88.1 Date: 93/12/07 15:06:55 */
                     16:
                     17: /******************************
                     18:  *  Quad precision functions  *
                     19:  ******************************/
                     20:
                     21: /* 32-bit word grabing functions */
                     22: #define Quad_firstword(value) Qallp1(value)
                     23: #define Quad_secondword(value) Qallp2(value)
                     24: #define Quad_thirdword(value)  Qallp3(value)
                     25: #define Quad_fourthword(value)  Qallp4(value)
                     26:
                     27:
                     28: /* This magnitude comparison uses the signless first words and
                     29:  * the regular part2 words.  The comparison is graphically:
                     30:  *
                     31:  *       1st greater?  ----------->|
                     32:  *                                 |
                     33:  *       1st less?-----------------+------->|
                     34:  *                                 |        |
                     35:  *       2nd greater?------------->|        |
                     36:  *                                 |        |
                     37:  *       2nd less?-----------------+------->|
                     38:  *                                 |        |
                     39:  *       3rd greater?------------->|        |
                     40:  *                                 |        |
                     41:  *       3rd less?-----------------+------->|
                     42:  *                                 |        |
                     43:  *       4th greater or equal?---->|        |
                     44:  *                                 |        |
                     45:  *                               False     True
                     46:  */
                     47: #define Quad_ismagnitudeless(leftp3,leftp4,rightp1,rightp2,rightp3,rightp4,signlessleft,signlessright) \
                     48: /*  Quad_floating_point left, right;          *                                \
                     49:  *  unsigned int signlessleft, signlessright; */                       \
                     50:       ( signlessleft<=signlessright &&                                 \
                     51:        (signlessleft<signlessright || (Qallp2(leftp2)<=Qallp2(rightp2) && \
                     52:        (Qallp2(leftp2)<Qallp2(rightp2) || (Qallp3(leftp3)<=Qallp3(rightp3) && \
                     53:         (Qallp3(leftp3)<Qallp3(rightp3) || Qallp4(leftp4)<Qallp4(rightp4)))))))
                     54:
                     55: #define Quad_xor_to_intp1(leftp1,rightp1,result)               \
                     56:     /* quad_floating_point left, right;                                \
                     57:      * unsigned int result; */                                 \
                     58:     result = Qallp1(leftp1) XOR Qallp1(rightp1);
                     59:
                     60: #define Quad_xor_from_intp1(leftp1,rightp1,result)             \
                     61:     /* quad_floating_point right, result;                      \
                     62:      * unsigned int left; */                                   \
                     63:     Qallp1(resultp1) = left XOR Qallp1(rightp1)
                     64:
                     65: #define Quad_swap_lower(leftp1,leftp2,leftp3,leftp4,rightp1,rightp2,rightp3,rightp4)  \
                     66:     /* quad_floating_point left, right; */                     \
                     67:     Qallp2(leftp2)  = Qallp2(leftp2) XOR Qallp2(rightp2)       \
                     68:     Qallp2(rightp2) = Qallp2(leftp2) XOR Qallp2(rightp2)       \
                     69:     Qallp2(leftp2)  = Qallp2(leftp2) XOR Qallp2(rightp2)       \
                     70:     Qallp3(leftp3)  = Qallp3(leftp3) XOR Qallp3(rightp3)       \
                     71:     Qallp3(rightp3) = Qallp3(leftp3) XOR Qallp3(rightp3)       \
                     72:     Qallp3(leftp3)  = Qallp3(leftp3) XOR Qallp3(rightp3)       \
                     73:     Qallp4(leftp4)  = Qallp4(leftp4) XOR Qallp4(rightp4)       \
                     74:     Qallp4(rightp4) = Qallp4(leftp4) XOR Qallp4(rightp4)       \
                     75:     Qallp4(leftp4)  = Qallp4(leftp4) XOR Qallp4(rightp4)
                     76:
                     77: int quad_frnd(quad_floating_point *, quad_floating_point *, quad_floating_point *, unsigned int *);

CVSweb