[Libclc-dev] [PATCH 1/1] nan: Implement

Jan Vesely via Libclc-dev libclc-dev at lists.llvm.org
Thu Mar 8 14:39:29 PST 2018


Passes CTS on carrizo and turks
Signed-off-by: Jan Vesely <jan.vesely at rutgers.edu>
---
 generic/include/clc/clc.h        |  1 +
 generic/include/clc/math/nan.h   |  8 ++++++++
 generic/include/clc/math/nan.inc | 16 ++++++++++++++++
 generic/lib/SOURCES              |  1 +
 generic/lib/math/nan.cl          |  6 ++++++
 generic/lib/math/nan.inc         | 20 ++++++++++++++++++++
 6 files changed, 52 insertions(+)
 create mode 100644 generic/include/clc/math/nan.h
 create mode 100644 generic/include/clc/math/nan.inc
 create mode 100644 generic/lib/math/nan.cl
 create mode 100644 generic/lib/math/nan.inc

diff --git a/generic/include/clc/clc.h b/generic/include/clc/clc.h
index 4eb2a3a..75ca7d0 100644
--- a/generic/include/clc/clc.h
+++ b/generic/include/clc/clc.h
@@ -98,6 +98,7 @@
 #include <clc/math/maxmag.h>
 #include <clc/math/minmag.h>
 #include <clc/math/modf.h>
+#include <clc/math/nan.h>
 #include <clc/math/nextafter.h>
 #include <clc/math/pow.h>
 #include <clc/math/pown.h>
diff --git a/generic/include/clc/math/nan.h b/generic/include/clc/math/nan.h
new file mode 100644
index 0000000..0907493
--- /dev/null
+++ b/generic/include/clc/math/nan.h
@@ -0,0 +1,8 @@
+#define __CLC_CONCAT(x, y) x ## y
+#define __CLC_XCONCAT(x, y) __CLC_CONCAT(x, y)
+
+#define __CLC_BODY <clc/math/nan.inc>
+#include <clc/math/gentype.inc>
+
+#undef __CLC_XCONCAT
+#undef __CLC_CONCAT
diff --git a/generic/include/clc/math/nan.inc b/generic/include/clc/math/nan.inc
new file mode 100644
index 0000000..bf36ed2
--- /dev/null
+++ b/generic/include/clc/math/nan.inc
@@ -0,0 +1,16 @@
+#ifdef __CLC_SCALAR
+#define __CLC_VECSIZE
+#endif
+
+#if __CLC_FPSIZE == 64
+#define __CLC_NATN __CLC_XCONCAT(ulong, __CLC_VECSIZE)
+#else
+#define __CLC_NATN __CLC_XCONCAT(uint, __CLC_VECSIZE)
+#endif
+
+_CLC_OVERLOAD _CLC_DECL __CLC_GENTYPE nan(__CLC_NATN code);
+
+#undef __CLC_NATN
+#ifdef __CLC_SCALAR
+#undef __CLC_VECSIZE
+#endif
diff --git a/generic/lib/SOURCES b/generic/lib/SOURCES
index bff7733..9004186 100644
--- a/generic/lib/SOURCES
+++ b/generic/lib/SOURCES
@@ -135,6 +135,7 @@ math/mad.cl
 math/maxmag.cl
 math/minmag.cl
 math/modf.cl
+math/nan.cl
 math/native_cos.cl
 math/native_divide.cl
 math/native_exp.cl
diff --git a/generic/lib/math/nan.cl b/generic/lib/math/nan.cl
new file mode 100644
index 0000000..03752ab
--- /dev/null
+++ b/generic/lib/math/nan.cl
@@ -0,0 +1,6 @@
+#include <clc/clc.h>
+#include "utils.h"
+
+#define __CLC_AS_GENTYPE __CLC_XCONCAT(as_, __CLC_GENTYPE)
+#define __CLC_BODY <nan.inc>
+#include <clc/math/gentype.inc>
diff --git a/generic/lib/math/nan.inc b/generic/lib/math/nan.inc
new file mode 100644
index 0000000..6e4afc8
--- /dev/null
+++ b/generic/lib/math/nan.inc
@@ -0,0 +1,20 @@
+#ifdef __CLC_SCALAR
+#define __CLC_VECSIZE
+#endif
+
+#if __CLC_FPSIZE == 64
+_CLC_OVERLOAD _CLC_DEF __CLC_GENTYPE nan(__CLC_XCONCAT(ulong, __CLC_VECSIZE) code)
+{
+	return __CLC_AS_GENTYPE(code | 0x7ff0000000000000ul);
+}
+#else
+_CLC_OVERLOAD _CLC_DEF __CLC_GENTYPE nan(__CLC_XCONCAT(uint, __CLC_VECSIZE) code)
+{
+	return __CLC_AS_GENTYPE(code | 0x7fc00000);
+}
+#endif
+
+
+#ifdef __CLC_SCALAR
+#undef __CLC_VECSIZE
+#endif
-- 
2.14.3



More information about the Libclc-dev mailing list