[Libclc-dev] [PATCH 1/2] rootn: Use denormal path only
Jan Vesely via Libclc-dev
libclc-dev at lists.llvm.org
Mon Apr 23 13:44:54 PDT 2018
It's OK to either flush to 0 or return denormal result if the device
does not support denormals. See sec 7.2 and 7.5.3 of OCL specs
Fixes CTS on carrizo.
Signed-off-by: Jan Vesely <jan.vesely at rutgers.edu>
---
generic/lib/math/clc_rootn.cl | 11 +----------
1 file changed, 1 insertion(+), 10 deletions(-)
diff --git a/generic/lib/math/clc_rootn.cl b/generic/lib/math/clc_rootn.cl
index d7ee185..9b1ef48 100644
--- a/generic/lib/math/clc_rootn.cl
+++ b/generic/lib/math/clc_rootn.cl
@@ -170,16 +170,7 @@ _CLC_DEF _CLC_OVERLOAD float __clc_rootn(float x, int ny)
tv = USE_TABLE(exp_tbl_ep, j);
float expylogx = mad(tv.s0, poly, mad(tv.s1, poly, tv.s1)) + tv.s0;
- float sexpylogx;
- if (!__clc_fp32_subnormals_supported()) {
- int explg = ((as_uint(expylogx) & EXPBITS_SP32 >> 23) - 127);
- m = (23-(m + 149)) == 0 ? 1: m;
- uint mantissa = ((as_uint(expylogx) & MANTBITS_SP32)|IMPBIT_SP32) >> (23-(m + 149));
- sexpylogx = as_float(mantissa);
- } else {
- sexpylogx = expylogx * as_float(0x1 << (m + 149));
- }
-
+ float sexpylogx = expylogx * as_float(0x1 << (m + 149));
float texpylogx = as_float(as_int(expylogx) + m2);
expylogx = m < -125 ? sexpylogx : texpylogx;
--
2.14.3
More information about the Libclc-dev
mailing list