xref: /freebsd/lib/libc/include/fpmath.h (revision b3e7694832e81d7a904a10f525f8797b753bf0d3)
18cf5ed51SMike Barcroft /*-
2*4d846d26SWarner Losh  * SPDX-License-Identifier: BSD-2-Clause
3d915a14eSPedro F. Giffuni  *
48cf5ed51SMike Barcroft  * Copyright (c) 2003 Mike Barcroft <mike@FreeBSD.org>
5f154b03bSDavid Schultz  * Copyright (c) 2002 David Schultz <das@FreeBSD.ORG>
68cf5ed51SMike Barcroft  * All rights reserved.
78cf5ed51SMike Barcroft  *
88cf5ed51SMike Barcroft  * Redistribution and use in source and binary forms, with or without
98cf5ed51SMike Barcroft  * modification, are permitted provided that the following conditions
108cf5ed51SMike Barcroft  * are met:
118cf5ed51SMike Barcroft  * 1. Redistributions of source code must retain the above copyright
128cf5ed51SMike Barcroft  *    notice, this list of conditions and the following disclaimer.
138cf5ed51SMike Barcroft  * 2. Redistributions in binary form must reproduce the above copyright
148cf5ed51SMike Barcroft  *    notice, this list of conditions and the following disclaimer in the
158cf5ed51SMike Barcroft  *    documentation and/or other materials provided with the distribution.
168cf5ed51SMike Barcroft  *
178cf5ed51SMike Barcroft  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
188cf5ed51SMike Barcroft  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
198cf5ed51SMike Barcroft  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
208cf5ed51SMike Barcroft  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
218cf5ed51SMike Barcroft  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
228cf5ed51SMike Barcroft  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
238cf5ed51SMike Barcroft  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
248cf5ed51SMike Barcroft  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
258cf5ed51SMike Barcroft  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
268cf5ed51SMike Barcroft  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
278cf5ed51SMike Barcroft  * SUCH DAMAGE.
288cf5ed51SMike Barcroft  */
298cf5ed51SMike Barcroft 
30c774ad67SEitan Adler #ifndef _FPMATH_H_
31c774ad67SEitan Adler #define _FPMATH_H_
32c774ad67SEitan Adler 
338cf5ed51SMike Barcroft #include <sys/endian.h>
348cf5ed51SMike Barcroft #include "_fpmath.h"
358cf5ed51SMike Barcroft 
3674aed985SMarcel Moolenaar #ifndef _IEEE_WORD_ORDER
3774aed985SMarcel Moolenaar #define	_IEEE_WORD_ORDER	_BYTE_ORDER
3874aed985SMarcel Moolenaar #endif
3974aed985SMarcel Moolenaar 
408cf5ed51SMike Barcroft union IEEEf2bits {
418cf5ed51SMike Barcroft 	float	f;
428cf5ed51SMike Barcroft 	struct {
438cf5ed51SMike Barcroft #if _BYTE_ORDER == _LITTLE_ENDIAN
448cf5ed51SMike Barcroft 		unsigned int	man	:23;
458cf5ed51SMike Barcroft 		unsigned int	exp	:8;
468cf5ed51SMike Barcroft 		unsigned int	sign	:1;
478cf5ed51SMike Barcroft #else /* _BIG_ENDIAN */
488cf5ed51SMike Barcroft 		unsigned int	sign	:1;
498cf5ed51SMike Barcroft 		unsigned int	exp	:8;
508cf5ed51SMike Barcroft 		unsigned int	man	:23;
518cf5ed51SMike Barcroft #endif
528cf5ed51SMike Barcroft 	} bits;
538cf5ed51SMike Barcroft };
548cf5ed51SMike Barcroft 
552ad26506SDavid Schultz #define	DBL_MANH_SIZE	20
562ad26506SDavid Schultz #define	DBL_MANL_SIZE	32
572ad26506SDavid Schultz 
588cf5ed51SMike Barcroft union IEEEd2bits {
598cf5ed51SMike Barcroft 	double	d;
608cf5ed51SMike Barcroft 	struct {
618cf5ed51SMike Barcroft #if _BYTE_ORDER == _LITTLE_ENDIAN
6274aed985SMarcel Moolenaar #if _IEEE_WORD_ORDER == _LITTLE_ENDIAN
638cf5ed51SMike Barcroft 		unsigned int	manl	:32;
6474aed985SMarcel Moolenaar #endif
658cf5ed51SMike Barcroft 		unsigned int	manh	:20;
668cf5ed51SMike Barcroft 		unsigned int	exp	:11;
678cf5ed51SMike Barcroft 		unsigned int	sign	:1;
6874aed985SMarcel Moolenaar #if _IEEE_WORD_ORDER == _BIG_ENDIAN
6974aed985SMarcel Moolenaar 		unsigned int	manl	:32;
7074aed985SMarcel Moolenaar #endif
718cf5ed51SMike Barcroft #else /* _BIG_ENDIAN */
728cf5ed51SMike Barcroft 		unsigned int	sign	:1;
738cf5ed51SMike Barcroft 		unsigned int	exp	:11;
748cf5ed51SMike Barcroft 		unsigned int	manh	:20;
758cf5ed51SMike Barcroft 		unsigned int	manl	:32;
768cf5ed51SMike Barcroft #endif
778cf5ed51SMike Barcroft 	} bits;
788cf5ed51SMike Barcroft };
79c774ad67SEitan Adler 
80c774ad67SEitan Adler #endif /* !_FPMATH_H */
81