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, 2003 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
308cf5ed51SMike Barcroft #include <sys/endian.h>
318cf5ed51SMike Barcroft
325d8564aeSAndrew Turner #include <machine/float.h>
335d8564aeSAndrew Turner
348cf5ed51SMike Barcroft #include <math.h>
358cf5ed51SMike Barcroft #include <stdint.h>
368cf5ed51SMike Barcroft
378cf5ed51SMike Barcroft #include "fpmath.h"
388cf5ed51SMike Barcroft
398cf5ed51SMike Barcroft int
__fpclassifyf(float f)408cf5ed51SMike Barcroft __fpclassifyf(float f)
418cf5ed51SMike Barcroft {
428cf5ed51SMike Barcroft union IEEEf2bits u;
438cf5ed51SMike Barcroft
448cf5ed51SMike Barcroft u.f = f;
458cf5ed51SMike Barcroft if (u.bits.exp == 0) {
468cf5ed51SMike Barcroft if (u.bits.man == 0)
478cf5ed51SMike Barcroft return (FP_ZERO);
488cf5ed51SMike Barcroft return (FP_SUBNORMAL);
498cf5ed51SMike Barcroft }
508cf5ed51SMike Barcroft if (u.bits.exp == 255) {
518cf5ed51SMike Barcroft if (u.bits.man == 0)
528cf5ed51SMike Barcroft return (FP_INFINITE);
538cf5ed51SMike Barcroft return (FP_NAN);
548cf5ed51SMike Barcroft }
558cf5ed51SMike Barcroft return (FP_NORMAL);
568cf5ed51SMike Barcroft }
578cf5ed51SMike Barcroft
588cf5ed51SMike Barcroft int
__fpclassifyd(double d)598cf5ed51SMike Barcroft __fpclassifyd(double d)
608cf5ed51SMike Barcroft {
618cf5ed51SMike Barcroft union IEEEd2bits u;
628cf5ed51SMike Barcroft
638cf5ed51SMike Barcroft u.d = d;
648cf5ed51SMike Barcroft if (u.bits.exp == 0) {
658cf5ed51SMike Barcroft if ((u.bits.manl | u.bits.manh) == 0)
668cf5ed51SMike Barcroft return (FP_ZERO);
678cf5ed51SMike Barcroft return (FP_SUBNORMAL);
688cf5ed51SMike Barcroft }
698cf5ed51SMike Barcroft if (u.bits.exp == 2047) {
708cf5ed51SMike Barcroft if ((u.bits.manl | u.bits.manh) == 0)
718cf5ed51SMike Barcroft return (FP_INFINITE);
728cf5ed51SMike Barcroft return (FP_NAN);
738cf5ed51SMike Barcroft }
748cf5ed51SMike Barcroft return (FP_NORMAL);
758cf5ed51SMike Barcroft }
768cf5ed51SMike Barcroft
778cf5ed51SMike Barcroft int
__fpclassifyl(long double e)788cf5ed51SMike Barcroft __fpclassifyl(long double e)
798cf5ed51SMike Barcroft {
808cf5ed51SMike Barcroft union IEEEl2bits u;
818cf5ed51SMike Barcroft
828cf5ed51SMike Barcroft u.e = e;
838cf5ed51SMike Barcroft if (u.bits.exp == 0) {
848cf5ed51SMike Barcroft if ((u.bits.manl | u.bits.manh) == 0)
858cf5ed51SMike Barcroft return (FP_ZERO);
868cf5ed51SMike Barcroft return (FP_SUBNORMAL);
878cf5ed51SMike Barcroft }
888cf5ed51SMike Barcroft mask_nbit_l(u); /* Mask normalization bit if applicable. */
895d8564aeSAndrew Turner #if LDBL_MANT_DIG == 53
905d8564aeSAndrew Turner if (u.bits.exp == 2047) {
915d8564aeSAndrew Turner if ((u.bits.manl | u.bits.manh) == 0)
925d8564aeSAndrew Turner return (FP_INFINITE);
935d8564aeSAndrew Turner return (FP_NAN);
945d8564aeSAndrew Turner }
955d8564aeSAndrew Turner #else
968cf5ed51SMike Barcroft if (u.bits.exp == 32767) {
978cf5ed51SMike Barcroft if ((u.bits.manl | u.bits.manh) == 0)
988cf5ed51SMike Barcroft return (FP_INFINITE);
998cf5ed51SMike Barcroft return (FP_NAN);
1008cf5ed51SMike Barcroft }
1015d8564aeSAndrew Turner #endif
1028cf5ed51SMike Barcroft return (FP_NORMAL);
1038cf5ed51SMike Barcroft }
104