Blame include/math-narrow-eval.h

Packit Service 82fcde
/* Narrow floating-point values to their semantic type.
Packit Service 82fcde
   Copyright (C) 2015-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 _MATH_NARROW_EVAL_H
Packit Service 82fcde
#define _MATH_NARROW_EVAL_H	1
Packit Service 82fcde
Packit Service 82fcde
#include <float.h>
Packit Service 82fcde
Packit Service 82fcde
/* math_narrow_eval reduces its floating-point argument to the range
Packit Service 82fcde
   and precision of its semantic type.  (The original evaluation may
Packit Service 82fcde
   still occur with excess range and precision, so the result may be
Packit Service 82fcde
   affected by double rounding.)  */
Packit Service 82fcde
#if FLT_EVAL_METHOD == 0
Packit Service 82fcde
# define math_narrow_eval(x) (x)
Packit Service 82fcde
#else
Packit Service 82fcde
# if FLT_EVAL_METHOD == 1
Packit Service 82fcde
#  define excess_precision(type) __builtin_types_compatible_p (type, float)
Packit Service 82fcde
# else
Packit Service 82fcde
#  define excess_precision(type) (__builtin_types_compatible_p (type, float) \
Packit Service 82fcde
				  || __builtin_types_compatible_p (type, \
Packit Service 82fcde
								   double))
Packit Service 82fcde
# endif
Packit Service 82fcde
# define math_narrow_eval(x)					\
Packit Service 82fcde
  ({								\
Packit Service 82fcde
    __typeof (x) math_narrow_eval_tmp = (x);			\
Packit Service 82fcde
    if (excess_precision (__typeof (math_narrow_eval_tmp)))	\
Packit Service 82fcde
      __asm__ ("" : "+m" (math_narrow_eval_tmp));		\
Packit Service 82fcde
    math_narrow_eval_tmp;					\
Packit Service 82fcde
   })
Packit Service 82fcde
#endif
Packit Service 82fcde
Packit Service 82fcde
#endif /* math-narrow-eval.h */