summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRuiling Song <ruiling.song@intel.com>2014-12-22 10:00:40 +0800
committerZhigang Gong <zhigang.gong@intel.com>2014-12-22 12:19:39 +0800
commit576f02591edaa51e5736d9584b614c58123df5e7 (patch)
tree32dcf6dfc7e3c5289a8e48d3c76640cdf249c10f
parentc661cd104e007fc71f06badca7d99a29ae3ccc59 (diff)
libocl: Flush denorm input into zero in rootn()
Gen does not support denorm. We have to flush input to zero. Signed-off-by: Ruiling Song <ruiling.song@intel.com> Reviewed-by: Zhigang Gong <zhigang.gong@linux.intel.com>
-rw-r--r--backend/src/libocl/tmpl/ocl_math.tmpl.cl8
1 files changed, 8 insertions, 0 deletions
diff --git a/backend/src/libocl/tmpl/ocl_math.tmpl.cl b/backend/src/libocl/tmpl/ocl_math.tmpl.cl
index c7be47e7..248ddd05 100644
--- a/backend/src/libocl/tmpl/ocl_math.tmpl.cl
+++ b/backend/src/libocl/tmpl/ocl_math.tmpl.cl
@@ -3414,7 +3414,15 @@ OVERLOADABLE float pow(float x, float y) {
OVERLOADABLE float rootn(float x, int n) {
float ax,re;
int sign = 0;
+ int hx;
if( n == 0 )return NAN;
+
+ GEN_OCL_GET_FLOAT_WORD(hx, x);
+ // Gen does not support denorm, flush to zero
+ if ((hx & 0x7fffffff) < 0x00800000) {
+ x = hx < 0 ? -0.0f : 0.0f;
+ }
+
//rootn ( x, n ) returns a NaN for x < 0 and n is even.
if( x < 0 && 0 == (n&1) )
return NAN;