xref: /freebsd/lib/libc/include/fpmath.h (revision c774ad670ab9b7b685871969fe73e454b0c089e5)
18cf5ed51SMike Barcroft /*-
2d915a14eSPedro F. Giffuni  * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
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  * $FreeBSD$
308cf5ed51SMike Barcroft  */
318cf5ed51SMike Barcroft 
32*c774ad67SEitan Adler #ifndef _FPMATH_H_
33*c774ad67SEitan Adler #define _FPMATH_H_
34*c774ad67SEitan Adler 
358cf5ed51SMike Barcroft #include <sys/endian.h>
368cf5ed51SMike Barcroft #include "_fpmath.h"
378cf5ed51SMike Barcroft 
3874aed985SMarcel Moolenaar #ifndef _IEEE_WORD_ORDER
3974aed985SMarcel Moolenaar #define	_IEEE_WORD_ORDER	_BYTE_ORDER
4074aed985SMarcel Moolenaar #endif
4174aed985SMarcel Moolenaar 
428cf5ed51SMike Barcroft union IEEEf2bits {
438cf5ed51SMike Barcroft 	float	f;
448cf5ed51SMike Barcroft 	struct {
458cf5ed51SMike Barcroft #if _BYTE_ORDER == _LITTLE_ENDIAN
468cf5ed51SMike Barcroft 		unsigned int	man	:23;
478cf5ed51SMike Barcroft 		unsigned int	exp	:8;
488cf5ed51SMike Barcroft 		unsigned int	sign	:1;
498cf5ed51SMike Barcroft #else /* _BIG_ENDIAN */
508cf5ed51SMike Barcroft 		unsigned int	sign	:1;
518cf5ed51SMike Barcroft 		unsigned int	exp	:8;
528cf5ed51SMike Barcroft 		unsigned int	man	:23;
538cf5ed51SMike Barcroft #endif
548cf5ed51SMike Barcroft 	} bits;
558cf5ed51SMike Barcroft };
568cf5ed51SMike Barcroft 
572ad26506SDavid Schultz #define	DBL_MANH_SIZE	20
582ad26506SDavid Schultz #define	DBL_MANL_SIZE	32
592ad26506SDavid Schultz 
608cf5ed51SMike Barcroft union IEEEd2bits {
618cf5ed51SMike Barcroft 	double	d;
628cf5ed51SMike Barcroft 	struct {
638cf5ed51SMike Barcroft #if _BYTE_ORDER == _LITTLE_ENDIAN
6474aed985SMarcel Moolenaar #if _IEEE_WORD_ORDER == _LITTLE_ENDIAN
658cf5ed51SMike Barcroft 		unsigned int	manl	:32;
6674aed985SMarcel Moolenaar #endif
678cf5ed51SMike Barcroft 		unsigned int	manh	:20;
688cf5ed51SMike Barcroft 		unsigned int	exp	:11;
698cf5ed51SMike Barcroft 		unsigned int	sign	:1;
7074aed985SMarcel Moolenaar #if _IEEE_WORD_ORDER == _BIG_ENDIAN
7174aed985SMarcel Moolenaar 		unsigned int	manl	:32;
7274aed985SMarcel Moolenaar #endif
738cf5ed51SMike Barcroft #else /* _BIG_ENDIAN */
748cf5ed51SMike Barcroft 		unsigned int	sign	:1;
758cf5ed51SMike Barcroft 		unsigned int	exp	:11;
768cf5ed51SMike Barcroft 		unsigned int	manh	:20;
778cf5ed51SMike Barcroft 		unsigned int	manl	:32;
788cf5ed51SMike Barcroft #endif
798cf5ed51SMike Barcroft 	} bits;
808cf5ed51SMike Barcroft };
81*c774ad67SEitan Adler 
82*c774ad67SEitan Adler #endif /* !_FPMATH_H */
83