mirror of
https://sourceware.org/git/glibc.git
synced 2024-12-29 05:51:10 +00:00
efeb2bd1ab
Both float, double, and _Float128 are assumed to be supported (float and double already only uses builtins). Only long double is parametrized due GCC bug 29253 which prevents its usage on powerpc. It allows to remove i686, ia64, x86_64, powerpc, and sparc arch specific implementation. On ia64 it also fixes the sNAN handling: math/test-float64x-fabs math/test-ldouble-fabs Checked on x86_64-linux-gnu, i686-linux-gnu, powerpc-linux-gnu, powerpc64-linux-gnu, sparc64-linux-gnu, and ia64-linux-gnu.
42 lines
1.6 KiB
C
42 lines
1.6 KiB
C
/* Using math gcc builtins instead of generic implementation. Generic version.
|
|
Copyright (C) 2019-2022 Free Software Foundation, Inc.
|
|
This file is part of the GNU C Library.
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2.1 of the License, or (at your option) any later version.
|
|
|
|
The GNU C Library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with the GNU C Library; if not, see
|
|
<https://www.gnu.org/licenses/>. */
|
|
|
|
#ifndef MATH_USE_BUILTINS_H
|
|
#define MATH_USE_BUILTINS_H 1
|
|
|
|
#include <features.h> /* For __GNUC_PREREQ. */
|
|
|
|
/* Define these macros to 1 to use __builtin_xyz instead of the
|
|
generic implementation. */
|
|
|
|
#include <math-use-builtins-nearbyint.h>
|
|
#include <math-use-builtins-rint.h>
|
|
#include <math-use-builtins-floor.h>
|
|
#include <math-use-builtins-ceil.h>
|
|
#include <math-use-builtins-trunc.h>
|
|
#include <math-use-builtins-round.h>
|
|
#include <math-use-builtins-roundeven.h>
|
|
#include <math-use-builtins-copysign.h>
|
|
#include <math-use-builtins-sqrt.h>
|
|
#include <math-use-builtins-fma.h>
|
|
#include <math-use-builtins-fmax.h>
|
|
#include <math-use-builtins-fmin.h>
|
|
#include <math-use-builtins-fabs.h>
|
|
|
|
#endif /* MATH_USE_BUILTINS_H */
|