mirror of
git://sourceware.org/git/newlib-cygwin.git
synced 2025-01-25 16:47:20 +08:00
1671fbe1ca
* libm/machine/spu/headers/dom_chkd_less_than.h: New file. * libm/machine/spu/headers/dom_chkd_negone_one.h: Ditto. * libm/machine/spu/headers/dom_chkf_less_than.h: Ditto. * libm/machine/spu/headers/dom_chkf_negone_one.h: Ditto. * libm/machine/spu/headers/acos.h: Add domain check. * libm/machine/spu/headers/acosf.h: Ditto. * libm/machine/spu/headers/acosh.h: Ditto. * libm/machine/spu/headers/acoshf.h: Ditto. * libm/machine/spu/headers/asin.h: Ditto. * libm/machine/spu/headers/asinf.h: Ditto. * libm/machine/spu/headers/atanh.h: Ditto. * libm/machine/spu/headers/atanhf.h: Ditto. * libm/machine/spu/headers/fmod.h: Ditto. * libm/machine/spu/headers/fmodf.h: Ditto. * libm/machine/spu/headers/log.h: Ditto. * libm/machine/spu/headers/log10.h: Ditto. * libm/machine/spu/headers/log1p.h: Ditto. * libm/machine/spu/headers/log1pf.h: Ditto. * libm/machine/spu/headers/log2.h: Ditto. * libm/machine/spu/headers/log2f.h: Ditto. * libm/machine/spu/headers/sqrt.h: Ditto. * libm/machine/spu/headers/sqrtf.h: Ditto. * libm/machine/spu/headers/tgamma.h: Ditto. * libm/machine/spu/headers/tgammaf.h: Ditto.
31 lines
789 B
C
31 lines
789 B
C
#include <errno.h>
|
|
#include "headers/truncd2.h"
|
|
#include "headers/tgammad2.h"
|
|
|
|
static __inline double _tgamma(double x)
|
|
{
|
|
double res;
|
|
vector double vx;
|
|
vector double truncx;
|
|
vector double vc = { 0.0, 0.0 };
|
|
vector unsigned long long cmpres;
|
|
vector signed int verrno, ferrno;
|
|
vector signed int fail = { EDOM, EDOM, EDOM, EDOM };
|
|
|
|
vx = spu_promote(x, 0);
|
|
res = spu_extract(_tgammad2(vx), 0);
|
|
|
|
#ifndef _IEEE_LIBM
|
|
/*
|
|
* use vector truncd2 rather than splat x, and splat truncx.
|
|
*/
|
|
truncx = _truncd2(vx);
|
|
cmpres = spu_cmpeq(truncx, vx);
|
|
verrno = spu_splats(errno);
|
|
ferrno = spu_sel(verrno, fail, (vector unsigned int) cmpres);
|
|
cmpres = spu_cmpgt(vc, vx);
|
|
errno = spu_extract(spu_sel(verrno, ferrno, (vector unsigned int) cmpres), 0);
|
|
#endif
|
|
return res;
|
|
}
|