diff options
author | das <das@FreeBSD.org> | 2005-01-15 02:55:10 +0000 |
---|---|---|
committer | das <das@FreeBSD.org> | 2005-01-15 02:55:10 +0000 |
commit | c7466a47fff371436e5e36d5eb6e489e6a39aa3b (patch) | |
tree | a90e1a55dd5be03abe7196cbb1535b30e054cddc | |
parent | 1df25ecd79325dade12d1a56dc9fb90982a51413 (diff) | |
download | FreeBSD-src-c7466a47fff371436e5e36d5eb6e489e6a39aa3b.zip FreeBSD-src-c7466a47fff371436e5e36d5eb6e489e6a39aa3b.tar.gz |
Most libm routines depend on the rounding mode and/or set exception
flags, so they are not pure. Remove the __pure2 annotation from them.
I believe that the following routines and their float and long double
counterparts are the only ones here that can be __pure2:
copysign is* fabs finite fmax fmin fpclassify ilogb nan signbit
When gcc supports FENV_ACCESS, perhaps there will be a new annotation
that allows the other functions to be considered pure when FENV_ACCESS
is off.
Discussed with: bde
-rw-r--r-- | lib/msun/src/math.h | 60 |
1 files changed, 29 insertions, 31 deletions
diff --git a/lib/msun/src/math.h b/lib/msun/src/math.h index 4436927..58e845a 100644 --- a/lib/msun/src/math.h +++ b/lib/msun/src/math.h @@ -195,11 +195,9 @@ struct exception { #endif /* __BSD_VISIBLE */ /* - * Most of these functions have the side effect of setting errno, so they - * are not declared as __pure2. (XXX: this point needs to be revisited, - * since C99 doesn't require the mistake of setting errno, and we mostly - * don't set it anyway. In C99, pragmas and functions for changing the - * rounding mode affect the purity of these functions.) + * Most of these functions depend on the rounding mode and have the side + * effect of raising floating-point exceptions, so they are not declared + * as __pure2. In C99, FENV_ACCESS affects the purity of these functions. */ __BEGIN_DECLS /* @@ -244,36 +242,36 @@ double pow(double, double); double sqrt(double); double ceil(double); -double fabs(double); +double fabs(double) __pure2; double floor(double); double fmod(double, double); /* - * These functions are not in C90 so they can be "right". The ones that - * never set errno in lib/msun are declared as __pure2. + * These functions are not in C90. */ #if __BSD_VISIBLE || __ISO_C_VISIBLE >= 1999 || __XSI_VISIBLE double acosh(double); double asinh(double); double atanh(double); -double cbrt(double) __pure2; +double cbrt(double); double erf(double); -double erfc(double) __pure2; -double expm1(double) __pure2; +double erfc(double); +double expm1(double); double hypot(double, double); -int ilogb(double); +/* Our ilogb raises no exceptions; we side with IEEE-754R and C99, not POSIX */ +int ilogb(double) __pure2; int (isinf)(double) __pure2; int (isnan)(double) __pure2; double lgamma(double); long long llrint(double); long long llround(double); -double log1p(double) __pure2; -double logb(double) __pure2; +double log1p(double); +double logb(double); long lrint(double); long lround(double); double nextafter(double, double); double remainder(double, double); -double rint(double) __pure2; +double rint(double); #endif /* __BSD_VISIBLE || __ISO_C_VISIBLE >= 1999 || __XSI_VISIBLE */ #if __BSD_VISIBLE || __XSI_VISIBLE @@ -295,7 +293,7 @@ double copysign(double, double) __pure2; double fdim(double, double); double fmax(double, double) __pure2; double fmin(double, double) __pure2; -double nearbyint(double) __pure2; +double nearbyint(double); double round(double); double scalbln(double, long); double scalbn(double, int); @@ -343,12 +341,12 @@ float sinhf(float); float tanhf(float); float expf(float); -float expm1f(float) __pure2; +float expm1f(float); float frexpf(float, int *); /* fundamentally !__pure2 */ -int ilogbf(float); +int ilogbf(float) __pure2; float ldexpf(float, int); float log10f(float); -float log1pf(float) __pure2; +float log1pf(float); float logf(float); float modff(float, float *); /* fundamentally !__pure2 */ @@ -356,27 +354,27 @@ float powf(float, float); float sqrtf(float); float ceilf(float); -float fabsf(float); +float fabsf(float) __pure2; float floorf(float); float fmodf(float, float); float roundf(float); float erff(float); -float erfcf(float) __pure2; -float hypotf(float, float) __pure2; +float erfcf(float); +float hypotf(float, float); float lgammaf(float); float acoshf(float); float asinhf(float); float atanhf(float); -float cbrtf(float) __pure2; -float logbf(float) __pure2; +float cbrtf(float); +float logbf(float); float copysignf(float, float) __pure2; long long llrintf(float); long long llroundf(float); long lrintf(float); long lroundf(float); -float nearbyintf(float) __pure2; +float nearbyintf(float); float nextafterf(float, float); float remainderf(float, float); float rintf(float); @@ -433,7 +431,7 @@ long double atanl(long double); long double cbrtl(long double); #endif long double ceill(long double); -long double copysignl(long double, long double); +long double copysignl(long double, long double) __pure2; #if 0 long double coshl(long double); long double cosl(long double); @@ -443,7 +441,7 @@ long double exp2l(long double); long double expl(long double); long double expm1l(long double); #endif -long double fabsl(long double); +long double fabsl(long double) __pure2; long double fdiml(long double, long double); long double floorl(long double); #if 0 @@ -453,10 +451,10 @@ long double fmaxl(long double, long double) __pure2; long double fminl(long double, long double) __pure2; #if 0 long double fmodl(long double, long double); -long double frexpl(long double value, int *); +long double frexpl(long double value, int *); /* fundamentally !__pure2 */ long double hypotl(long double, long double); #endif -int ilogbl(long double); +int ilogbl(long double) __pure2; #if 0 long double ldexpl(long double, int); long double lgammal(long double); @@ -469,8 +467,8 @@ long double logbl(long double); long double logl(long double); long lrintl(long double); long lroundl(long double); -long double modfl(long double, long double *); -long double nanl(const char *); +long double modfl(long double, long double *); /* fundamentally !__pure2 */ +long double nanl(const char *) __pure2; long double nearbyintl(long double); long double nextafterl(long double, long double); double nexttoward(double, long double); |