mirror of
git://sourceware.org/git/newlib-cygwin.git
synced 2025-01-22 15:07:43 +08:00
a44bc679a4
When HAVE_FAST_FMAF is set, use the vfma.f32 instruction, when HAVE_FAST_FMA is set, use the vfma.f64 instruction. Usually the compiler built-ins will already have inlined these instructions, but provide these symbols for cases where that doesn't work instead of falling back to the (inaccurate) common code versions. Signed-off-by: Keith Packard <keithp@keithp.com>
61 lines
1.4 KiB
C
61 lines
1.4 KiB
C
/*
|
|
FUNCTION
|
|
<<fma>>, <<fmaf>>---floating multiply add
|
|
INDEX
|
|
fma
|
|
INDEX
|
|
fmaf
|
|
|
|
SYNOPSIS
|
|
#include <math.h>
|
|
double fma(double <[x]>, double <[y]>, double <[z]>);
|
|
float fmaf(float <[x]>, float <[y]>, float <[z]>);
|
|
|
|
DESCRIPTION
|
|
The <<fma>> functions compute (<[x]> * <[y]>) + <[z]>, rounded as one ternary
|
|
operation: they compute the value (as if) to infinite precision and round once
|
|
to the result format, according to the rounding mode characterized by the value
|
|
of FLT_ROUNDS. That is, they are supposed to do this: see below.
|
|
|
|
RETURNS
|
|
The <<fma>> functions return (<[x]> * <[y]>) + <[z]>, rounded as one ternary
|
|
operation.
|
|
|
|
BUGS
|
|
This implementation does not provide the function that it should, purely
|
|
returning "(<[x]> * <[y]>) + <[z]>;" with no attempt at all to provide the
|
|
simulated infinite precision intermediates which are required. DO NOT USE THEM.
|
|
|
|
If double has enough more precision than float, then <<fmaf>> should provide
|
|
the expected numeric results, as it does use double for the calculation. But
|
|
since this is not the case for all platforms, this manual cannot determine
|
|
if it is so for your case.
|
|
|
|
PORTABILITY
|
|
ANSI C, POSIX.
|
|
|
|
*/
|
|
|
|
#include "fdlibm.h"
|
|
|
|
#if !HAVE_FAST_FMA
|
|
|
|
#ifndef _DOUBLE_IS_32BITS
|
|
|
|
#ifdef __STDC__
|
|
double fma(double x, double y, double z)
|
|
#else
|
|
double fma(x,y)
|
|
double x;
|
|
double y;
|
|
double z;
|
|
#endif
|
|
{
|
|
/* Implementation defined. */
|
|
return (x * y) + z;
|
|
}
|
|
|
|
#endif /* _DOUBLE_IS_32BITS */
|
|
|
|
#endif /* !HAVE_FAST_FMA */
|