Blame gl/float+.h

Packit aea12f
/* Supplemental information about the floating-point formats.
Packit Service 991b93
   Copyright (C) 2007, 2009-2020 Free Software Foundation, Inc.
Packit aea12f
   Written by Bruno Haible <bruno@clisp.org>, 2007.
Packit aea12f
Packit aea12f
   This program is free software; you can redistribute it and/or modify
Packit Service 991b93
   it under the terms of the GNU Lesser General Public License as published by
Packit Service 991b93
   the Free Software Foundation; either version 2.1, or (at your option)
Packit aea12f
   any later version.
Packit aea12f
Packit aea12f
   This program is distributed in the hope that it will be useful,
Packit aea12f
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit aea12f
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service 991b93
   GNU Lesser General Public License for more details.
Packit aea12f
Packit Service 991b93
   You should have received a copy of the GNU Lesser General Public License
Packit aea12f
   along with this program; if not, see <https://www.gnu.org/licenses/>.  */
Packit aea12f
Packit aea12f
#ifndef _FLOATPLUS_H
Packit aea12f
#define _FLOATPLUS_H
Packit aea12f
Packit aea12f
#include <float.h>
Packit aea12f
#include <limits.h>
Packit aea12f
Packit aea12f
/* Number of bits in the mantissa of a floating-point number, including the
Packit aea12f
   "hidden bit".  */
Packit aea12f
#if FLT_RADIX == 2
Packit aea12f
# define FLT_MANT_BIT FLT_MANT_DIG
Packit aea12f
# define DBL_MANT_BIT DBL_MANT_DIG
Packit aea12f
# define LDBL_MANT_BIT LDBL_MANT_DIG
Packit aea12f
#elif FLT_RADIX == 4
Packit aea12f
# define FLT_MANT_BIT (FLT_MANT_DIG * 2)
Packit aea12f
# define DBL_MANT_BIT (DBL_MANT_DIG * 2)
Packit aea12f
# define LDBL_MANT_BIT (LDBL_MANT_DIG * 2)
Packit aea12f
#elif FLT_RADIX == 16
Packit aea12f
# define FLT_MANT_BIT (FLT_MANT_DIG * 4)
Packit aea12f
# define DBL_MANT_BIT (DBL_MANT_DIG * 4)
Packit aea12f
# define LDBL_MANT_BIT (LDBL_MANT_DIG * 4)
Packit aea12f
#endif
Packit aea12f
Packit aea12f
/* Bit mask that can be used to mask the exponent, as an unsigned number.  */
Packit aea12f
#define FLT_EXP_MASK ((FLT_MAX_EXP - FLT_MIN_EXP) | 7)
Packit aea12f
#define DBL_EXP_MASK ((DBL_MAX_EXP - DBL_MIN_EXP) | 7)
Packit aea12f
#define LDBL_EXP_MASK ((LDBL_MAX_EXP - LDBL_MIN_EXP) | 7)
Packit aea12f
Packit aea12f
/* Number of bits used for the exponent of a floating-point number, including
Packit aea12f
   the exponent's sign.  */
Packit aea12f
#define FLT_EXP_BIT \
Packit aea12f
  (FLT_EXP_MASK < 0x100 ? 8 : \
Packit aea12f
   FLT_EXP_MASK < 0x200 ? 9 : \
Packit aea12f
   FLT_EXP_MASK < 0x400 ? 10 : \
Packit aea12f
   FLT_EXP_MASK < 0x800 ? 11 : \
Packit aea12f
   FLT_EXP_MASK < 0x1000 ? 12 : \
Packit aea12f
   FLT_EXP_MASK < 0x2000 ? 13 : \
Packit aea12f
   FLT_EXP_MASK < 0x4000 ? 14 : \
Packit aea12f
   FLT_EXP_MASK < 0x8000 ? 15 : \
Packit aea12f
   FLT_EXP_MASK < 0x10000 ? 16 : \
Packit aea12f
   FLT_EXP_MASK < 0x20000 ? 17 : \
Packit aea12f
   FLT_EXP_MASK < 0x40000 ? 18 : \
Packit aea12f
   FLT_EXP_MASK < 0x80000 ? 19 : \
Packit aea12f
   FLT_EXP_MASK < 0x100000 ? 20 : \
Packit aea12f
   FLT_EXP_MASK < 0x200000 ? 21 : \
Packit aea12f
   FLT_EXP_MASK < 0x400000 ? 22 : \
Packit aea12f
   FLT_EXP_MASK < 0x800000 ? 23 : \
Packit aea12f
   FLT_EXP_MASK < 0x1000000 ? 24 : \
Packit aea12f
   FLT_EXP_MASK < 0x2000000 ? 25 : \
Packit aea12f
   FLT_EXP_MASK < 0x4000000 ? 26 : \
Packit aea12f
   FLT_EXP_MASK < 0x8000000 ? 27 : \
Packit aea12f
   FLT_EXP_MASK < 0x10000000 ? 28 : \
Packit aea12f
   FLT_EXP_MASK < 0x20000000 ? 29 : \
Packit aea12f
   FLT_EXP_MASK < 0x40000000 ? 30 : \
Packit aea12f
   FLT_EXP_MASK <= 0x7fffffff ? 31 : \
Packit aea12f
   32)
Packit aea12f
#define DBL_EXP_BIT \
Packit aea12f
  (DBL_EXP_MASK < 0x100 ? 8 : \
Packit aea12f
   DBL_EXP_MASK < 0x200 ? 9 : \
Packit aea12f
   DBL_EXP_MASK < 0x400 ? 10 : \
Packit aea12f
   DBL_EXP_MASK < 0x800 ? 11 : \
Packit aea12f
   DBL_EXP_MASK < 0x1000 ? 12 : \
Packit aea12f
   DBL_EXP_MASK < 0x2000 ? 13 : \
Packit aea12f
   DBL_EXP_MASK < 0x4000 ? 14 : \
Packit aea12f
   DBL_EXP_MASK < 0x8000 ? 15 : \
Packit aea12f
   DBL_EXP_MASK < 0x10000 ? 16 : \
Packit aea12f
   DBL_EXP_MASK < 0x20000 ? 17 : \
Packit aea12f
   DBL_EXP_MASK < 0x40000 ? 18 : \
Packit aea12f
   DBL_EXP_MASK < 0x80000 ? 19 : \
Packit aea12f
   DBL_EXP_MASK < 0x100000 ? 20 : \
Packit aea12f
   DBL_EXP_MASK < 0x200000 ? 21 : \
Packit aea12f
   DBL_EXP_MASK < 0x400000 ? 22 : \
Packit aea12f
   DBL_EXP_MASK < 0x800000 ? 23 : \
Packit aea12f
   DBL_EXP_MASK < 0x1000000 ? 24 : \
Packit aea12f
   DBL_EXP_MASK < 0x2000000 ? 25 : \
Packit aea12f
   DBL_EXP_MASK < 0x4000000 ? 26 : \
Packit aea12f
   DBL_EXP_MASK < 0x8000000 ? 27 : \
Packit aea12f
   DBL_EXP_MASK < 0x10000000 ? 28 : \
Packit aea12f
   DBL_EXP_MASK < 0x20000000 ? 29 : \
Packit aea12f
   DBL_EXP_MASK < 0x40000000 ? 30 : \
Packit aea12f
   DBL_EXP_MASK <= 0x7fffffff ? 31 : \
Packit aea12f
   32)
Packit aea12f
#define LDBL_EXP_BIT \
Packit aea12f
  (LDBL_EXP_MASK < 0x100 ? 8 : \
Packit aea12f
   LDBL_EXP_MASK < 0x200 ? 9 : \
Packit aea12f
   LDBL_EXP_MASK < 0x400 ? 10 : \
Packit aea12f
   LDBL_EXP_MASK < 0x800 ? 11 : \
Packit aea12f
   LDBL_EXP_MASK < 0x1000 ? 12 : \
Packit aea12f
   LDBL_EXP_MASK < 0x2000 ? 13 : \
Packit aea12f
   LDBL_EXP_MASK < 0x4000 ? 14 : \
Packit aea12f
   LDBL_EXP_MASK < 0x8000 ? 15 : \
Packit aea12f
   LDBL_EXP_MASK < 0x10000 ? 16 : \
Packit aea12f
   LDBL_EXP_MASK < 0x20000 ? 17 : \
Packit aea12f
   LDBL_EXP_MASK < 0x40000 ? 18 : \
Packit aea12f
   LDBL_EXP_MASK < 0x80000 ? 19 : \
Packit aea12f
   LDBL_EXP_MASK < 0x100000 ? 20 : \
Packit aea12f
   LDBL_EXP_MASK < 0x200000 ? 21 : \
Packit aea12f
   LDBL_EXP_MASK < 0x400000 ? 22 : \
Packit aea12f
   LDBL_EXP_MASK < 0x800000 ? 23 : \
Packit aea12f
   LDBL_EXP_MASK < 0x1000000 ? 24 : \
Packit aea12f
   LDBL_EXP_MASK < 0x2000000 ? 25 : \
Packit aea12f
   LDBL_EXP_MASK < 0x4000000 ? 26 : \
Packit aea12f
   LDBL_EXP_MASK < 0x8000000 ? 27 : \
Packit aea12f
   LDBL_EXP_MASK < 0x10000000 ? 28 : \
Packit aea12f
   LDBL_EXP_MASK < 0x20000000 ? 29 : \
Packit aea12f
   LDBL_EXP_MASK < 0x40000000 ? 30 : \
Packit aea12f
   LDBL_EXP_MASK <= 0x7fffffff ? 31 : \
Packit aea12f
   32)
Packit aea12f
Packit aea12f
/* Number of bits used for a floating-point number: the mantissa (not
Packit aea12f
   counting the "hidden bit", since it may or may not be explicit), the
Packit aea12f
   exponent, and the sign.  */
Packit aea12f
#define FLT_TOTAL_BIT ((FLT_MANT_BIT - 1) + FLT_EXP_BIT + 1)
Packit aea12f
#define DBL_TOTAL_BIT ((DBL_MANT_BIT - 1) + DBL_EXP_BIT + 1)
Packit aea12f
#define LDBL_TOTAL_BIT ((LDBL_MANT_BIT - 1) + LDBL_EXP_BIT + 1)
Packit aea12f
Packit aea12f
/* Number of bytes used for a floating-point number.
Packit aea12f
   This can be smaller than the 'sizeof'.  For example, on i386 systems,
Packit aea12f
   'long double' most often have LDBL_MANT_BIT = 64, LDBL_EXP_BIT = 16, hence
Packit aea12f
   LDBL_TOTAL_BIT = 80 bits, i.e. 10 bytes of consecutive memory, but
Packit aea12f
   sizeof (long double) = 12 or = 16.  */
Packit aea12f
#define SIZEOF_FLT ((FLT_TOTAL_BIT + CHAR_BIT - 1) / CHAR_BIT)
Packit aea12f
#define SIZEOF_DBL ((DBL_TOTAL_BIT + CHAR_BIT - 1) / CHAR_BIT)
Packit aea12f
#define SIZEOF_LDBL ((LDBL_TOTAL_BIT + CHAR_BIT - 1) / CHAR_BIT)
Packit aea12f
Packit aea12f
/* Verify that SIZEOF_FLT <= sizeof (float) etc.  */
Packit aea12f
typedef int verify_sizeof_flt[SIZEOF_FLT <= sizeof (float) ? 1 : -1];
Packit aea12f
typedef int verify_sizeof_dbl[SIZEOF_DBL <= sizeof (double) ? 1 : - 1];
Packit aea12f
typedef int verify_sizeof_ldbl[SIZEOF_LDBL <= sizeof (long double) ? 1 : - 1];
Packit aea12f
Packit aea12f
#endif /* _FLOATPLUS_H */