mirror of
https://git.planet-casio.com/Lephenixnoir/OpenLibm.git
synced 2025-01-03 23:43:41 +01:00
commit
0b2a647742
9 changed files with 31 additions and 32 deletions
|
@ -38,10 +38,6 @@
|
||||||
#ifndef _MACHINE_IEEEFP_H_
|
#ifndef _MACHINE_IEEEFP_H_
|
||||||
#define _MACHINE_IEEEFP_H_
|
#define _MACHINE_IEEEFP_H_
|
||||||
|
|
||||||
#if !defined(_SYS_CDEFS_H) && !defined(_SYS_CDEFS_H_) && !defined(_CDEFS_H_)
|
|
||||||
#error this file needs sys/cdefs.h as a prerequisite
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* FP rounding modes
|
* FP rounding modes
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -152,13 +152,13 @@ double x, c;
|
||||||
c= x - z*(p1+z*(p2+z*(p3+z*(p4+z*p5))));
|
c= x - z*(p1+z*(p2+z*(p3+z*(p4+z*p5))));
|
||||||
c = (x*c)/(2.0-c);
|
c = (x*c)/(2.0-c);
|
||||||
|
|
||||||
return scalb(1.+(hi-(lo - c)), k);
|
return scalbn(1.+(hi-(lo - c)), k);
|
||||||
}
|
}
|
||||||
/* end of x > lntiny */
|
/* end of x > lntiny */
|
||||||
|
|
||||||
else
|
else
|
||||||
/* exp(-big#) underflows to zero */
|
/* exp(-big#) underflows to zero */
|
||||||
if(finite(x)) return(scalb(1.0,-5000));
|
if(isfinite(x)) return(scalbn(1.0,-5000));
|
||||||
|
|
||||||
/* exp(-INF) is zero */
|
/* exp(-INF) is zero */
|
||||||
else return(0.0);
|
else return(0.0);
|
||||||
|
@ -167,5 +167,5 @@ double x, c;
|
||||||
|
|
||||||
else
|
else
|
||||||
/* exp(INF) is INF, exp(+big#) overflows to INF */
|
/* exp(INF) is INF, exp(+big#) overflows to INF */
|
||||||
return( finite(x) ? scalb(1.0,5000) : x);
|
return( isfinite(x) ? scalbn(1.0,5000) : x);
|
||||||
}
|
}
|
||||||
|
|
|
@ -140,7 +140,7 @@ tgamma(x)
|
||||||
if (x != 0.0)
|
if (x != 0.0)
|
||||||
u.a = one - tiny; /* raise inexact */
|
u.a = one - tiny; /* raise inexact */
|
||||||
return (one/x);
|
return (one/x);
|
||||||
} else if (!finite(x))
|
} else if (!isfinite(x))
|
||||||
return (x - x); /* x is NaN or -Inf */
|
return (x - x); /* x is NaN or -Inf */
|
||||||
else
|
else
|
||||||
return (neg_gam(x));
|
return (neg_gam(x));
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
#ifndef _CDEFS_COMPAT_H_
|
#ifndef _CDEFS_COMPAT_H_
|
||||||
#define _CDEFS_COMPAT_H_
|
#define _CDEFS_COMPAT_H_
|
||||||
|
|
||||||
#ifndef _WIN32
|
/*
|
||||||
#include "sys/cdefs.h"
|
* We cannot be certain that this operating system has <sys/cdefs.h>.
|
||||||
#else /* _WIN32 */
|
* Instead, include a header file that is likely to pull in this header.
|
||||||
|
*/
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
#if defined(__cplusplus)
|
#if defined(__cplusplus)
|
||||||
#define __BEGIN_DECLS extern "C" {
|
#define __BEGIN_DECLS extern "C" {
|
||||||
|
@ -13,13 +15,6 @@
|
||||||
#define __END_DECLS
|
#define __END_DECLS
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define _SYS_CDEFS_H_
|
|
||||||
|
|
||||||
#endif /* _WIN32 */
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __GNUC__
|
#ifdef __GNUC__
|
||||||
#ifndef __strong_reference
|
#ifndef __strong_reference
|
||||||
#ifdef __APPLE__
|
#ifdef __APPLE__
|
||||||
|
|
|
@ -38,28 +38,37 @@
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef __linux
|
#if defined(__BYTE_ORDER__) && defined(__ORDER_LITTLE_ENDIAN__)
|
||||||
|
|
||||||
|
/* Definitions provided directly by GCC and Clang. */
|
||||||
|
#define _LITTLE_ENDIAN __ORDER_LITTLE_ENDIAN__
|
||||||
|
#define _BIG_ENDIAN __ORDER_BIG_ENDIAN__
|
||||||
|
#define _PDP_ENDIAN __ORDER_PDP_ENDIAN__
|
||||||
|
#define _BYTE_ORDER __BYTE_ORDER__
|
||||||
|
|
||||||
|
#elif defined(__linux)
|
||||||
|
|
||||||
#include <features.h>
|
#include <features.h>
|
||||||
#include <endian.h>
|
#include <endian.h>
|
||||||
#define _LITTLE_ENDIAN __LITTLE_ENDIAN
|
#define _LITTLE_ENDIAN __LITTLE_ENDIAN
|
||||||
#define _BIG_ENDIAN __BIG_ENDIAN
|
#define _BIG_ENDIAN __BIG_ENDIAN
|
||||||
#define _PDP_ENDIAN __PDP_ENDIAN
|
#define _PDP_ENDIAN __PDP_ENDIAN
|
||||||
#define _BYTE_ORDER __BYTE_ORDER
|
#define _BYTE_ORDER __BYTE_ORDER
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __APPLE__
|
#elif defined(__APPLE__)
|
||||||
|
|
||||||
#include <machine/endian.h>
|
#include <machine/endian.h>
|
||||||
#define _LITTLE_ENDIAN LITTLE_ENDIAN
|
#define _LITTLE_ENDIAN LITTLE_ENDIAN
|
||||||
#define _BIG_ENDIAN BIG_ENDIAN
|
#define _BIG_ENDIAN BIG_ENDIAN
|
||||||
#define _PDP_ENDIAN PDP_ENDIAN
|
#define _PDP_ENDIAN PDP_ENDIAN
|
||||||
#define _BYTE_ORDER BYTE_ORDER
|
#define _BYTE_ORDER BYTE_ORDER
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __FreeBSD__
|
#elif defined(__FreeBSD__)
|
||||||
|
|
||||||
#include <machine/endian.h>
|
#include <machine/endian.h>
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
#elif defined(_WIN32)
|
||||||
|
|
||||||
#define _LITTLE_ENDIAN 1234
|
#define _LITTLE_ENDIAN 1234
|
||||||
#define _BIG_ENDIAN 4321
|
#define _BIG_ENDIAN 4321
|
||||||
#define _PDP_ENDIAN 3412
|
#define _PDP_ENDIAN 3412
|
||||||
|
@ -69,6 +78,7 @@
|
||||||
#define BIG_ENDIAN _BIG_ENDIAN
|
#define BIG_ENDIAN _BIG_ENDIAN
|
||||||
#define PDP_ENDIAN _PDP_ENDIAN
|
#define PDP_ENDIAN _PDP_ENDIAN
|
||||||
#define BYTE_ORDER _BYTE_ORDER
|
#define BYTE_ORDER _BYTE_ORDER
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef _IEEE_WORD_ORDER
|
#ifndef _IEEE_WORD_ORDER
|
||||||
|
|
|
@ -35,7 +35,7 @@ __ieee754_scalb(double x, double fn)
|
||||||
return scalbn(x,fn);
|
return scalbn(x,fn);
|
||||||
#else
|
#else
|
||||||
if (isnan(x)||isnan(fn)) return x*fn;
|
if (isnan(x)||isnan(fn)) return x*fn;
|
||||||
if (!finite(fn)) {
|
if (!isfinite(fn)) {
|
||||||
if(fn>0.0) return x*fn;
|
if(fn>0.0) return x*fn;
|
||||||
else return x/(-fn);
|
else return x/(-fn);
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,8 +30,8 @@ __ieee754_scalbf(float x, float fn)
|
||||||
#ifdef _SCALB_INT
|
#ifdef _SCALB_INT
|
||||||
return scalbnf(x,fn);
|
return scalbnf(x,fn);
|
||||||
#else
|
#else
|
||||||
if ((__isnanf)(x)||(__isnanf)(fn)) return x*fn;
|
if (isnan(x)||isnan(fn)) return x*fn;
|
||||||
if (!finitef(fn)) {
|
if (!isfinite(fn)) {
|
||||||
if(fn>(float)0.0) return x*fn;
|
if(fn>(float)0.0) return x*fn;
|
||||||
else return x/(-fn);
|
else return x/(-fn);
|
||||||
}
|
}
|
||||||
|
|
|
@ -333,9 +333,7 @@ double __kernel_sin(double,double,int);
|
||||||
double __kernel_cos(double,double);
|
double __kernel_cos(double,double);
|
||||||
double __kernel_tan(double,double,int);
|
double __kernel_tan(double,double,int);
|
||||||
double __ldexp_exp(double,int);
|
double __ldexp_exp(double,int);
|
||||||
#ifdef _COMPLEX_H
|
|
||||||
double complex __ldexp_cexp(double complex,int);
|
double complex __ldexp_cexp(double complex,int);
|
||||||
#endif
|
|
||||||
|
|
||||||
/* float precision kernel functions */
|
/* float precision kernel functions */
|
||||||
#ifdef INLINE_REM_PIO2F
|
#ifdef INLINE_REM_PIO2F
|
||||||
|
@ -355,9 +353,7 @@ __inline
|
||||||
#endif
|
#endif
|
||||||
float __kernel_tandf(double,int);
|
float __kernel_tandf(double,int);
|
||||||
float __ldexp_expf(float,int);
|
float __ldexp_expf(float,int);
|
||||||
#ifdef _COMPLEX_H
|
|
||||||
float complex __ldexp_cexpf(float complex,int);
|
float complex __ldexp_cexpf(float complex,int);
|
||||||
#endif
|
|
||||||
|
|
||||||
/* long double precision kernel functions */
|
/* long double precision kernel functions */
|
||||||
long double __kernel_sinl(long double, long double, int);
|
long double __kernel_sinl(long double, long double, int);
|
||||||
|
|
|
@ -57,7 +57,9 @@ extern const union __nan_un {
|
||||||
//VBS begin
|
//VBS begin
|
||||||
#define __MATH_BUILTIN_CONSTANTS
|
#define __MATH_BUILTIN_CONSTANTS
|
||||||
#define __MATH_BUILTIN_RELOPS
|
#define __MATH_BUILTIN_RELOPS
|
||||||
|
#ifndef __ISO_C_VISIBLE
|
||||||
#define __ISO_C_VISIBLE 1999
|
#define __ISO_C_VISIBLE 1999
|
||||||
|
#endif
|
||||||
//VBS end
|
//VBS end
|
||||||
|
|
||||||
#ifdef __MATH_BUILTIN_CONSTANTS
|
#ifdef __MATH_BUILTIN_CONSTANTS
|
||||||
|
|
Loading…
Reference in a new issue