modifications: * avoid unsigned->signed conversions * removed various volatile hacks * use FORCE_EVAL when evaluating only for side-effects * factor out R() rational approximation instead of manual inline * __invtrigl.h now only provides __invtrigl_R, __pio2_hi and __pio2_lo * use 2*pio2_hi, 2*pio2_lo instead of pi_hi, pi_lo otherwise the logic is not changed, long double versions will need a revisit when a genaral long double cleanup happens
10 lines
253 B
C
10 lines
253 B
C
#include <float.h>
|
|
|
|
#if LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
|
|
/* shared by acosl, asinl and atan2l */
|
|
#define pio2_hi __pio2_hi
|
|
#define pio2_lo __pio2_lo
|
|
extern const long double pio2_hi, pio2_lo;
|
|
|
|
long double __invtrigl_R(long double z);
|
|
#endif
|