summaryrefslogtreecommitdiffstats
path: root/newlib/libm/machine/spu/headers/fmodf.h
diff options
context:
space:
mode:
authorJeff Johnston <jjohnstn@redhat.com>2007-09-28 18:58:10 +0000
committerJeff Johnston <jjohnstn@redhat.com>2007-09-28 18:58:10 +0000
commit1671fbe1ca0825a77cb9137a08cf4ad8a48d0f95 (patch)
tree79e8a71cd7363e82effb317acda5cd10c04050c7 /newlib/libm/machine/spu/headers/fmodf.h
parente30a7b84aa1527df63f20fe0cb3605afab652d94 (diff)
downloadcygnal-1671fbe1ca0825a77cb9137a08cf4ad8a48d0f95.tar.gz
cygnal-1671fbe1ca0825a77cb9137a08cf4ad8a48d0f95.tar.bz2
cygnal-1671fbe1ca0825a77cb9137a08cf4ad8a48d0f95.zip
2007-09-28 Patrick Mansfield <patmans@us.ibm.com>
* 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.
Diffstat (limited to 'newlib/libm/machine/spu/headers/fmodf.h')
-rw-r--r--newlib/libm/machine/spu/headers/fmodf.h14
1 files changed, 14 insertions, 0 deletions
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 <errno.h>
#include <spu_intrinsics.h>
#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 */
}