[Beignet] [PATCH] fix builtin function "nextafter"
Homer Hsing
homer.xing at intel.com
Mon Nov 11 22:36:52 PST 2013
fix for some corner cases
Signed-off-by: Homer Hsing <homer.xing at intel.com>
---
backend/src/ocl_stdlib.tmpl.h | 40 ++++++++++++++++++++++++++++------------
1 file changed, 28 insertions(+), 12 deletions(-)
diff --git a/backend/src/ocl_stdlib.tmpl.h b/backend/src/ocl_stdlib.tmpl.h
index bedfe02..e23da86 100644
--- a/backend/src/ocl_stdlib.tmpl.h
+++ b/backend/src/ocl_stdlib.tmpl.h
@@ -1686,18 +1686,34 @@ INLINE_OVERLOADABLE float frexp(float x, private int *exp) { BODY; }
#undef BODY
INLINE_OVERLOADABLE float nextafter(float x, float y) {
- uint hx = as_uint(x), ix = hx & 0x7FFFFFFF;
- uint hy = as_uint(y), iy = hy & 0x7FFFFFFF;
- if (ix > 0x7F800000 || iy > 0x7F800000)
- return nan(0u);
- if (hx == hy)
- return x;
- if (ix == 0)
- return as_float((hy & 0x80000000u) | 1);
- if (((0 == (hx & 0x80000000u)) && y > x) || ((hx & 0x80000000u) && y < x))
- hx ++;
- else
- hx --;
+ int hx, hy, ix, iy;
+ hx = as_int(x);
+ hy = as_int(y);
+ ix = hx & 0x7fffffff;
+ iy = hy & 0x7fffffff;
+ if(ix>0x7f800000 || iy>0x7f800000)
+ return x+y;
+ if(hx == hy)
+ return y;
+ if(ix == 0) {
+ if(iy == 0)
+ return y;
+ else
+ return as_float((hy&0x80000000) | 1);
+ }
+ if(hx >= 0) {
+ if(hx > hy) {
+ hx -= 1;
+ } else {
+ hx += 1;
+ }
+ } else {
+ if(hy >= 0 || hx > hy){
+ hx -= 1;
+ } else {
+ hx += 1;
+ }
+ }
return as_float(hx);
}
--
1.8.3.2
More information about the Beignet
mailing list