From 1671fbe1ca0825a77cb9137a08cf4ad8a48d0f95 Mon Sep 17 00:00:00 2001 From: Jeff Johnston Date: Fri, 28 Sep 2007 18:58:10 +0000 Subject: 2007-09-28 Patrick Mansfield * 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. --- newlib/libm/machine/spu/headers/fmodf.h | 14 ++++++++++++++ 1 file changed, 14 insertions(+) (limited to 'newlib/libm/machine/spu/headers/fmodf.h') diff --git a/newlib/libm/machine/spu/headers/fmodf.h b/newlib/libm/machine/spu/headers/fmodf.h index 496ada490..a62141f97 100644 --- a/newlib/libm/machine/spu/headers/fmodf.h +++ b/newlib/libm/machine/spu/headers/fmodf.h @@ -33,6 +33,7 @@ #ifndef _FMODF_H_ #define _FMODF_H_ 1 +#include #include #include "headers/vec_literal.h" @@ -83,6 +84,10 @@ static __inline float _fmodf(float x, float y) vec_uint4 sign_mask = VEC_SPLAT_U32(0x80000000); vec_uint4 implied_1 = VEC_SPLAT_U32(0x00800000); vec_uint4 mant_mask = VEC_SPLAT_U32(0x007FFFFF); + vec_uint4 domain; + vec_int4 verrno; + vec_float4 vc = { 0.0, 0.0, 0.0, 0.0 }; + vec_int4 fail = { EDOM, EDOM, EDOM, EDOM }; vx = (vec_uint4)spu_promote(x, 0); vy = (vec_uint4)spu_promote(y, 0); @@ -150,6 +155,15 @@ static __inline float _fmodf(float x, float y) result = spu_sel(spu_andc(result, spu_rlmask(result0, -1)), vx, resultx); +#ifndef _IEEE_LIBM + /* + * If y is zero, set errno to EDOM + */ + domain = spu_cmpeq(vc, (vec_float4) vy); + verrno = spu_splats(errno); + errno = spu_extract(spu_sel(verrno, fail, (vector unsigned int) domain), 0); +#endif + return (spu_extract((vec_float4)result, 0)); #endif /* FMODF_INTEGER_RANGE */ } -- cgit v1.2.3