Blame sysdeps/generic/get-rounding-mode.h

Packit Service 82fcde
/* Determine floating-point rounding mode within libc.  Generic version.
Packit Service 82fcde
   Copyright (C) 2012-2018 Free Software Foundation, Inc.
Packit Service 82fcde
   This file is part of the GNU C Library.
Packit Service 82fcde
Packit Service 82fcde
   The GNU C Library is free software; you can redistribute it and/or
Packit Service 82fcde
   modify it under the terms of the GNU Lesser General Public
Packit Service 82fcde
   License as published by the Free Software Foundation; either
Packit Service 82fcde
   version 2.1 of the License, or (at your option) any later version.
Packit Service 82fcde
Packit Service 82fcde
   The GNU C Library is distributed in the hope that it will be useful,
Packit Service 82fcde
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 82fcde
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 82fcde
   Lesser General Public License for more details.
Packit Service 82fcde
Packit Service 82fcde
   You should have received a copy of the GNU Lesser General Public
Packit Service 82fcde
   License along with the GNU C Library; if not, see
Packit Service 82fcde
   <http://www.gnu.org/licenses/>.  */
Packit Service 82fcde
Packit Service 82fcde
#ifndef _GET_ROUNDING_MODE_H
Packit Service 82fcde
#define _GET_ROUNDING_MODE_H	1
Packit Service 82fcde
Packit Service 82fcde
#include <fpu_control.h>
Packit Service 82fcde
#include <stdlib.h>
Packit Service 82fcde
Packit Service 82fcde
/* Define values for FE_* modes not defined for this architecture.  */
Packit Service 82fcde
#ifdef FE_DOWNWARD
Packit Service 82fcde
# define ORIG_FE_DOWNWARD FE_DOWNWARD
Packit Service 82fcde
#else
Packit Service 82fcde
# define ORIG_FE_DOWNWARD 0
Packit Service 82fcde
#endif
Packit Service 82fcde
#ifdef FE_TONEAREST
Packit Service 82fcde
# define ORIG_FE_TONEAREST FE_TONEAREST
Packit Service 82fcde
#else
Packit Service 82fcde
# define ORIG_FE_TONEAREST 0
Packit Service 82fcde
#endif
Packit Service 82fcde
#ifdef FE_TOWARDZERO
Packit Service 82fcde
# define ORIG_FE_TOWARDZERO FE_TOWARDZERO
Packit Service 82fcde
#else
Packit Service 82fcde
# define ORIG_FE_TOWARDZERO 0
Packit Service 82fcde
#endif
Packit Service 82fcde
#ifdef FE_UPWARD
Packit Service 82fcde
# define ORIG_FE_UPWARD FE_UPWARD
Packit Service 82fcde
#else
Packit Service 82fcde
# define ORIG_FE_UPWARD 0
Packit Service 82fcde
#endif
Packit Service 82fcde
#define FE_CONSTRUCT_DISTINCT_VALUE(X, Y, Z) \
Packit Service 82fcde
  ((((X) & 1) | ((Y) & 2) | ((Z) & 4)) ^ 7)
Packit Service 82fcde
#ifndef FE_DOWNWARD
Packit Service 82fcde
# define FE_DOWNWARD FE_CONSTRUCT_DISTINCT_VALUE (ORIG_FE_TONEAREST,	\
Packit Service 82fcde
						  ORIG_FE_TOWARDZERO,	\
Packit Service 82fcde
						  ORIG_FE_UPWARD)
Packit Service 82fcde
#endif
Packit Service 82fcde
#ifndef FE_TONEAREST
Packit Service 82fcde
# define FE_TONEAREST FE_CONSTRUCT_DISTINCT_VALUE (FE_DOWNWARD,		\
Packit Service 82fcde
						   ORIG_FE_TOWARDZERO,	\
Packit Service 82fcde
						   ORIG_FE_UPWARD)
Packit Service 82fcde
#endif
Packit Service 82fcde
#ifndef FE_TOWARDZERO
Packit Service 82fcde
# define FE_TOWARDZERO FE_CONSTRUCT_DISTINCT_VALUE (FE_DOWNWARD,	\
Packit Service 82fcde
						    FE_TONEAREST,	\
Packit Service 82fcde
						    ORIG_FE_UPWARD)
Packit Service 82fcde
#endif
Packit Service 82fcde
#ifndef FE_UPWARD
Packit Service 82fcde
# define FE_UPWARD FE_CONSTRUCT_DISTINCT_VALUE (FE_DOWNWARD,	\
Packit Service 82fcde
						FE_TONEAREST,	\
Packit Service 82fcde
						FE_TOWARDZERO)
Packit Service 82fcde
#endif
Packit Service 82fcde
Packit Service 82fcde
/* Return the floating-point rounding mode.  */
Packit Service 82fcde
Packit Service 82fcde
static inline int
Packit Service 82fcde
get_rounding_mode (void)
Packit Service 82fcde
{
Packit Service 82fcde
#if (defined _FPU_RC_DOWN			\
Packit Service 82fcde
     || defined _FPU_RC_NEAREST			\
Packit Service 82fcde
     || defined _FPU_RC_ZERO			\
Packit Service 82fcde
     || defined _FPU_RC_UP)
Packit Service 82fcde
  fpu_control_t fc;
Packit Service 82fcde
  const fpu_control_t mask = (0
Packit Service 82fcde
# ifdef _FPU_RC_DOWN
Packit Service 82fcde
			      | _FPU_RC_DOWN
Packit Service 82fcde
# endif
Packit Service 82fcde
# ifdef _FPU_RC_NEAREST
Packit Service 82fcde
			      | _FPU_RC_NEAREST
Packit Service 82fcde
# endif
Packit Service 82fcde
# ifdef _FPU_RC_ZERO
Packit Service 82fcde
			      | _FPU_RC_ZERO
Packit Service 82fcde
# endif
Packit Service 82fcde
# ifdef _FPU_RC_UP
Packit Service 82fcde
			      | _FPU_RC_UP
Packit Service 82fcde
# endif
Packit Service 82fcde
			      );
Packit Service 82fcde
Packit Service 82fcde
  _FPU_GETCW (fc);
Packit Service 82fcde
  switch (fc & mask)
Packit Service 82fcde
    {
Packit Service 82fcde
# ifdef _FPU_RC_DOWN
Packit Service 82fcde
    case _FPU_RC_DOWN:
Packit Service 82fcde
      return FE_DOWNWARD;
Packit Service 82fcde
# endif
Packit Service 82fcde
Packit Service 82fcde
# ifdef _FPU_RC_NEAREST
Packit Service 82fcde
    case _FPU_RC_NEAREST:
Packit Service 82fcde
      return FE_TONEAREST;
Packit Service 82fcde
# endif
Packit Service 82fcde
Packit Service 82fcde
# ifdef _FPU_RC_ZERO
Packit Service 82fcde
    case _FPU_RC_ZERO:
Packit Service 82fcde
      return FE_TOWARDZERO;
Packit Service 82fcde
# endif
Packit Service 82fcde
Packit Service 82fcde
# ifdef _FPU_RC_UP
Packit Service 82fcde
    case _FPU_RC_UP:
Packit Service 82fcde
      return FE_UPWARD;
Packit Service 82fcde
# endif
Packit Service 82fcde
Packit Service 82fcde
    default:
Packit Service 82fcde
      abort ();
Packit Service 82fcde
    }
Packit Service 82fcde
#else
Packit Service 82fcde
  return FE_TONEAREST;
Packit Service 82fcde
#endif
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
#endif /* get-rounding-mode.h */