2019-05-31 01:09:55 -07:00
// SPDX-License-Identifier: GPL-2.0-only
2005-04-16 15:20:36 -07:00
/* ieee754 floating point arithmetic
* single and double precision
*
* BUGS
* not much dp done
* doesn ' t generate IEEE754_INEXACT
*/
/*
* MIPS floating point support
* Copyright ( C ) 1994 - 2000 Algorithmics Ltd .
*/
2014-04-16 00:47:59 +02:00
# include <linux/compiler.h>
2005-04-16 15:20:36 -07:00
2014-04-25 15:48:40 +02:00
# include "ieee754.h"
2005-10-23 13:46:25 +01:00
# include "ieee754sp.h"
# include "ieee754dp.h"
2005-04-16 15:20:36 -07:00
2014-04-26 01:49:14 +02:00
/*
* Special constants
*/
2005-04-16 15:20:36 -07:00
2014-06-13 15:26:14 +01:00
/*
* Older GCC requires the inner braces for initialization of union ieee754dp ' s
* anonymous struct member . Without an error will result .
*/
2014-06-13 15:36:45 +01:00
# define xPCNST(s, b, m, ebias) \
2014-04-25 03:19:57 +02:00
{ \
2014-06-13 15:26:14 +01:00
{ \
. sign = ( s ) , \
2014-06-13 15:36:45 +01:00
. bexp = ( b ) + ebias , \
2014-06-13 15:26:14 +01:00
. mant = ( m ) \
} \
2014-04-25 03:19:57 +02:00
}
2005-04-16 15:20:36 -07:00
2014-06-13 15:36:45 +01:00
# define DPCNST(s, b, m) \
xPCNST ( s , b , m , DP_EBIAS )
2014-04-25 15:48:40 +02:00
const union ieee754dp __ieee754dp_spcvals [ ] = {
DPCNST ( 0 , DP_EMIN - 1 , 0x0000000000000ULL ) , /* + zero */
DPCNST ( 1 , DP_EMIN - 1 , 0x0000000000000ULL ) , /* - zero */
DPCNST ( 0 , 0 , 0x0000000000000ULL ) , /* + 1.0 */
DPCNST ( 1 , 0 , 0x0000000000000ULL ) , /* - 1.0 */
DPCNST ( 0 , 3 , 0x4000000000000ULL ) , /* + 10.0 */
DPCNST ( 1 , 3 , 0x4000000000000ULL ) , /* - 10.0 */
DPCNST ( 0 , DP_EMAX + 1 , 0x0000000000000ULL ) , /* + infinity */
DPCNST ( 1 , DP_EMAX + 1 , 0x0000000000000ULL ) , /* - infinity */
2015-11-13 00:47:28 +00:00
DPCNST ( 0 , DP_EMAX + 1 , 0x7FFFFFFFFFFFFULL ) , /* + ind legacy qNaN */
DPCNST ( 0 , DP_EMAX + 1 , 0x8000000000000ULL ) , /* + indef 2008 qNaN */
2014-04-25 15:48:40 +02:00
DPCNST ( 0 , DP_EMAX , 0xFFFFFFFFFFFFFULL ) , /* + max */
DPCNST ( 1 , DP_EMAX , 0xFFFFFFFFFFFFFULL ) , /* - max */
DPCNST ( 0 , DP_EMIN , 0x0000000000000ULL ) , /* + min normal */
DPCNST ( 1 , DP_EMIN , 0x0000000000000ULL ) , /* - min normal */
DPCNST ( 0 , DP_EMIN - 1 , 0x0000000000001ULL ) , /* + min denormal */
DPCNST ( 1 , DP_EMIN - 1 , 0x0000000000001ULL ) , /* - min denormal */
DPCNST ( 0 , 31 , 0x0000000000000ULL ) , /* + 1.0e31 */
DPCNST ( 0 , 63 , 0x0000000000000ULL ) , /* + 1.0e63 */
2005-04-16 15:20:36 -07:00
} ;
2014-04-25 15:48:40 +02:00
# define SPCNST(s, b, m) \
2014-06-13 15:36:45 +01:00
xPCNST ( s , b , m , SP_EBIAS )
2014-04-25 03:19:57 +02:00
2014-04-25 15:48:40 +02:00
const union ieee754sp __ieee754sp_spcvals [ ] = {
SPCNST ( 0 , SP_EMIN - 1 , 0x000000 ) , /* + zero */
SPCNST ( 1 , SP_EMIN - 1 , 0x000000 ) , /* - zero */
SPCNST ( 0 , 0 , 0x000000 ) , /* + 1.0 */
SPCNST ( 1 , 0 , 0x000000 ) , /* - 1.0 */
SPCNST ( 0 , 3 , 0x200000 ) , /* + 10.0 */
SPCNST ( 1 , 3 , 0x200000 ) , /* - 10.0 */
SPCNST ( 0 , SP_EMAX + 1 , 0x000000 ) , /* + infinity */
SPCNST ( 1 , SP_EMAX + 1 , 0x000000 ) , /* - infinity */
2015-11-13 00:47:28 +00:00
SPCNST ( 0 , SP_EMAX + 1 , 0x3FFFFF ) , /* + indef legacy quiet NaN */
SPCNST ( 0 , SP_EMAX + 1 , 0x400000 ) , /* + indef 2008 quiet NaN */
2014-04-25 15:48:40 +02:00
SPCNST ( 0 , SP_EMAX , 0x7FFFFF ) , /* + max normal */
SPCNST ( 1 , SP_EMAX , 0x7FFFFF ) , /* - max normal */
SPCNST ( 0 , SP_EMIN , 0x000000 ) , /* + min normal */
SPCNST ( 1 , SP_EMIN , 0x000000 ) , /* - min normal */
SPCNST ( 0 , SP_EMIN - 1 , 0x000001 ) , /* + min denormal */
SPCNST ( 1 , SP_EMIN - 1 , 0x000001 ) , /* - min denormal */
SPCNST ( 0 , 31 , 0x000000 ) , /* + 1.0e31 */
SPCNST ( 0 , 63 , 0x000000 ) , /* + 1.0e63 */
2005-04-16 15:20:36 -07:00
} ;