root/usr/src/head/iso/math_c99.h
/*
 * CDDL HEADER START
 *
 * The contents of this file are subject to the terms of the
 * Common Development and Distribution License (the "License").
 * You may not use this file except in compliance with the License.
 *
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
 * or http://www.opensolaris.org/os/licensing.
 * See the License for the specific language governing permissions
 * and limitations under the License.
 *
 * When distributing Covered Code, include this CDDL HEADER in each
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
 * If applicable, add the following below this CDDL HEADER, with the
 * fields enclosed by brackets "[]" replaced with your own identifying
 * information: Portions Copyright [yyyy] [name of copyright owner]
 *
 * CDDL HEADER END
 */
/*
 * Copyright 2011 Nexenta Systems, Inc.  All rights reserved.
 */
/*
 * Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
 * Use is subject to license terms.
 */

#ifndef _ISO_MATH_C99_H
#define _ISO_MATH_C99_H

#include <sys/isa_defs.h>
#include <sys/feature_tests.h>

#ifdef __cplusplus
extern "C" {
#endif

#undef  FP_ZERO
#define FP_ZERO         0
#undef  FP_SUBNORMAL
#define FP_SUBNORMAL    1
#undef  FP_NORMAL
#define FP_NORMAL       2
#undef  FP_INFINITE
#define FP_INFINITE     3
#undef  FP_NAN
#define FP_NAN          4

#if defined(_STDC_C99) || _XOPEN_SOURCE - 0 >= 600 || defined(__C99FEATURES__)
#if defined(__GNUC__)
#undef  HUGE_VAL
#define HUGE_VAL        (__builtin_huge_val())
#undef  HUGE_VALF
#define HUGE_VALF       (__builtin_huge_valf())
#undef  HUGE_VALL
#define HUGE_VALL       (__builtin_huge_vall())
#undef  INFINITY
#define INFINITY        (__builtin_inff())
#undef  NAN
#define NAN             (__builtin_nanf(""))

/*
 * C99 7.12.3 classification macros
 */
#undef  isnan
#undef  isinf
#if __GNUC__ >= 4
#define fpclassify(x)   __builtin_fpclassify(FP_NAN, FP_INFINITE, FP_NORMAL, \
    FP_SUBNORMAL, FP_ZERO, x)
#define isnan(x)        __builtin_isnan(x)
#define isinf(x)        __builtin_isinf(x)
#define isfinite(x)     (__builtin_isfinite(x) != 0)
#define isnormal(x)     (__builtin_isnormal(x) != 0)
#define signbit(x)      (__builtin_signbit(x) != 0)
#else  /* __GNUC__ >= 4 */
#define isnan(x)        __extension__( \
                        { __typeof(x) __x_n = (x); \
                        __builtin_isunordered(__x_n, __x_n); })
#define isinf(x)        __extension__( \
                        { __typeof(x) __x_i = (x); \
                        __x_i == (__typeof(__x_i)) INFINITY || \
                        __x_i == (__typeof(__x_i)) (-INFINITY); })
#undef  isfinite
#define isfinite(x)     __extension__( \
                        { __typeof(x) __x_f = (x); \
                        !isnan(__x_f) && !isinf(__x_f); })
#undef  isnormal
#define isnormal(x)     __extension__( \
                        { __typeof(x) __x_r = (x); isfinite(__x_r) && \
                        (sizeof (__x_r) == sizeof (float) ? \
                        __builtin_fabsf(__x_r) >= __FLT_MIN__ : \
                        sizeof (__x_r) == sizeof (double) ? \
                        __builtin_fabs(__x_r) >= __DBL_MIN__ : \
                        __builtin_fabsl(__x_r) >= __LDBL_MIN__); })
#undef  fpclassify
#define fpclassify(x)   __extension__( \
                        { __typeof(x) __x_c = (x); \
                        isnan(__x_c) ? FP_NAN : \
                        isinf(__x_c) ? FP_INFINITE : \
                        isnormal(__x_c) ? FP_NORMAL : \
                        __x_c == (__typeof(__x_c)) 0 ? FP_ZERO : \
                        FP_SUBNORMAL; })
#undef  signbit
#if defined(_BIG_ENDIAN)
#define signbit(x)      __extension__( \
                        { __typeof(x) __x_s = (x); \
                        (int)(*(unsigned *)&__x_s >> 31); })
#elif defined(_LITTLE_ENDIAN)
#define signbit(x)      __extension__( \
                        { __typeof(x) __x_s = (x); \
                        (sizeof (__x_s) == sizeof (float) ? \
                        (int)(*(unsigned *)&__x_s >> 31) : \
                        sizeof (__x_s) == sizeof (double) ? \
                        (int)(((unsigned *)&__x_s)[1] >> 31) : \
                        (int)(((unsigned short *)&__x_s)[4] >> 15)); })
#endif  /* defined(_BIG_ENDIAN) */
#endif  /* __GNUC__ >= 4 */

/*
 * C99 7.12.14 comparison macros
 */
#undef  isgreater
#define isgreater(x, y)         __builtin_isgreater(x, y)
#undef  isgreaterequal
#define isgreaterequal(x, y)    __builtin_isgreaterequal(x, y)
#undef  isless
#define isless(x, y)            __builtin_isless(x, y)
#undef  islessequal
#define islessequal(x, y)       __builtin_islessequal(x, y)
#undef  islessgreater
#define islessgreater(x, y)     __builtin_islessgreater(x, y)
#undef  isunordered
#define isunordered(x, y)       __builtin_isunordered(x, y)
#else   /* defined(__GNUC__) */
#undef  HUGE_VAL
#define HUGE_VAL        __builtin_huge_val
#undef  HUGE_VALF
#define HUGE_VALF       __builtin_huge_valf
#undef  HUGE_VALL
#define HUGE_VALL       __builtin_huge_vall
#undef  INFINITY
#define INFINITY        __builtin_infinity
#undef  NAN
#define NAN             __builtin_nan

/*
 * C99 7.12.3 classification macros
 */
#undef  fpclassify
#define fpclassify(x)   __builtin_fpclassify(x)
#undef  isfinite
#define isfinite(x)     __builtin_isfinite(x)
#undef  isinf
#define isinf(x)        __builtin_isinf(x)
#undef  isnan
#define isnan(x)        __builtin_isnan(x)
#undef  isnormal
#define isnormal(x)     __builtin_isnormal(x)
#undef  signbit
#define signbit(x)      __builtin_signbit(x)

/*
 * C99 7.12.14 comparison macros
 */
#undef  isgreater
#define isgreater(x, y)         ((x) __builtin_isgreater(y))
#undef  isgreaterequal
#define isgreaterequal(x, y)    ((x) __builtin_isgreaterequal(y))
#undef  isless
#define isless(x, y)            ((x) __builtin_isless(y))
#undef  islessequal
#define islessequal(x, y)       ((x) __builtin_islessequal(y))
#undef  islessgreater
#define islessgreater(x, y)     ((x) __builtin_islessgreater(y))
#undef  isunordered
#define isunordered(x, y)       ((x) __builtin_isunordered(y))
#endif  /* defined(__GNUC__) */
#endif  /* defined(_STDC_C99) || _XOPEN_SOURCE - 0 >= 600 || ... */

#if defined(__EXTENSIONS__) || defined(_STDC_C99) || \
        (!defined(_STRICT_STDC) && !defined(__XOPEN_OR_POSIX)) || \
        defined(__C99FEATURES__)
#if defined(__FLT_EVAL_METHOD__) && __FLT_EVAL_METHOD__ - 0 == 0
typedef float float_t;
typedef double double_t;
#elif __FLT_EVAL_METHOD__ - 0 == 1
typedef double float_t;
typedef double double_t;
#elif __FLT_EVAL_METHOD__ - 0 == 2
typedef long double float_t;
typedef long double double_t;
#elif defined(__sparc) || defined(__amd64)
typedef float float_t;
typedef double double_t;
#elif defined(__i386)
typedef long double float_t;
typedef long double double_t;
#endif

#undef  FP_ILOGB0
#define FP_ILOGB0       (-2147483647)
#undef  FP_ILOGBNAN
#define FP_ILOGBNAN     2147483647

#undef  MATH_ERRNO
#define MATH_ERRNO      1
#undef  MATH_ERREXCEPT
#define MATH_ERREXCEPT  2
#undef  math_errhandling
#define math_errhandling        MATH_ERREXCEPT

extern double acosh(double);
extern double asinh(double);
extern double atanh(double);

extern double exp2(double);
extern double expm1(double);
extern int ilogb(double);
extern double log1p(double);
extern double log2(double);
extern double logb(double);
extern double scalbn(double, int);
extern double scalbln(double, long int);

extern double cbrt(double);
extern double hypot(double, double);

extern double erf(double);
extern double erfc(double);
extern double lgamma(double);
extern double tgamma(double);

extern double nearbyint(double);
extern double rint(double);
extern long int lrint(double);
extern double round(double);
extern long int lround(double);
extern double trunc(double);

extern double remainder(double, double);
extern double remquo(double, double, int *);

extern double copysign(double, double);
extern double nan(const char *);
extern double nextafter(double, double);
extern double nexttoward(double, long double);

extern double fdim(double, double);
extern double fmax(double, double);
extern double fmin(double, double);

extern double fma(double, double, double);

extern float acosf(float);
extern float asinf(float);
extern float atanf(float);
extern float atan2f(float, float);
extern float cosf(float);
extern float sinf(float);
extern float tanf(float);

extern float acoshf(float);
extern float asinhf(float);
extern float atanhf(float);
extern float coshf(float);
extern float sinhf(float);
extern float tanhf(float);

extern float expf(float);
extern float exp2f(float);
extern float expm1f(float);
extern float frexpf(float, int *);
extern int ilogbf(float);
extern float ldexpf(float, int);
extern float logf(float);
extern float log10f(float);
extern float log1pf(float);
extern float log2f(float);
extern float logbf(float);
extern float modff(float, float *);
extern float scalbnf(float, int);
extern float scalblnf(float, long int);

extern float cbrtf(float);
extern float fabsf(float);
extern float hypotf(float, float);
extern float powf(float, float);
extern float sqrtf(float);

extern float erff(float);
extern float erfcf(float);
extern float lgammaf(float);
extern float tgammaf(float);

extern float ceilf(float);
extern float floorf(float);
extern float nearbyintf(float);
extern float rintf(float);
extern long int lrintf(float);
extern float roundf(float);
extern long int lroundf(float);
extern float truncf(float);

extern float fmodf(float, float);
extern float remainderf(float, float);
extern float remquof(float, float, int *);

extern float copysignf(float, float);
extern float nanf(const char *);
extern float nextafterf(float, float);
extern float nexttowardf(float, long double);

extern float fdimf(float, float);
extern float fmaxf(float, float);
extern float fminf(float, float);

extern float fmaf(float, float, float);

extern long double acosl(long double);
extern long double asinl(long double);
extern long double atanl(long double);
extern long double atan2l(long double, long double);
extern long double cosl(long double);
extern long double sinl(long double);
extern long double tanl(long double);

extern long double acoshl(long double);
extern long double asinhl(long double);
extern long double atanhl(long double);
extern long double coshl(long double);
extern long double sinhl(long double);
extern long double tanhl(long double);

extern long double expl(long double);
extern long double exp2l(long double);
extern long double expm1l(long double);
extern long double frexpl(long double, int *);
extern int ilogbl(long double);
extern long double ldexpl(long double, int);
extern long double logl(long double);
extern long double log10l(long double);
extern long double log1pl(long double);
extern long double log2l(long double);
extern long double logbl(long double);
extern long double modfl(long double, long double *);
extern long double scalbnl(long double, int);
extern long double scalblnl(long double, long int);

extern long double cbrtl(long double);
extern long double fabsl(long double);
extern long double hypotl(long double, long double);
extern long double powl(long double, long double);
extern long double sqrtl(long double);

extern long double erfl(long double);
extern long double erfcl(long double);
extern long double lgammal(long double);
extern long double tgammal(long double);

extern long double ceill(long double);
extern long double floorl(long double);
extern long double nearbyintl(long double);
extern long double rintl(long double);
extern long int lrintl(long double);
extern long double roundl(long double);
extern long int lroundl(long double);
extern long double truncl(long double);

extern long double fmodl(long double, long double);
extern long double remainderl(long double, long double);
extern long double remquol(long double, long double, int *);

extern long double copysignl(long double, long double);
extern long double nanl(const char *);
extern long double nextafterl(long double, long double);
extern long double nexttowardl(long double, long double);

extern long double fdiml(long double, long double);
extern long double fmaxl(long double, long double);
extern long double fminl(long double, long double);

extern long double fmal(long double, long double, long double);

#if !defined(_STRICT_STDC) && !defined(_NO_LONGLONG) || defined(_STDC_C99) || \
        defined(__C99FEATURES__)
extern long long int llrint(double);
extern long long int llround(double);

extern long long int llrintf(float);
extern long long int llroundf(float);

extern long long int llrintl(long double);
extern long long int llroundl(long double);
#endif

#endif  /* defined(__EXTENSIONS__) || defined(_STDC_C99) || ... */

#ifdef __cplusplus
}
#endif

#endif  /* _ISO_MATH_C99_H */