summaryrefslogtreecommitdiffstats
path: root/libclc/generic/lib/relational
diff options
context:
space:
mode:
authorJan Vesely <jan.vesely@rutgers.edu>2014-08-01 21:50:55 +0000
committerJan Vesely <jan.vesely@rutgers.edu>2014-08-01 21:50:55 +0000
commitacba2c98eb2ab1c96498f88c0a1bbbbfbcadb5b2 (patch)
tree0564a83caa2bb986d0364409f3945f876b647bb7 /libclc/generic/lib/relational
parentc16f73d7c5798e8f995ddec9e234edc5c18d60ab (diff)
downloadbcm5719-llvm-acba2c98eb2ab1c96498f88c0a1bbbbfbcadb5b2.tar.gz
bcm5719-llvm-acba2c98eb2ab1c96498f88c0a1bbbbfbcadb5b2.zip
relational: Add isless(floatN) builtin
v2: remove the initial undef Signed-off-by: Jan Vesely <jan.vesely@rutgers.edu> Reviewed-by: Aaron Watry <awatry@gmail.com> llvm-svn: 214567
Diffstat (limited to 'libclc/generic/lib/relational')
-rw-r--r--libclc/generic/lib/relational/isless.cl22
1 files changed, 22 insertions, 0 deletions
diff --git a/libclc/generic/lib/relational/isless.cl b/libclc/generic/lib/relational/isless.cl
new file mode 100644
index 00000000000..56a3e1329b4
--- /dev/null
+++ b/libclc/generic/lib/relational/isless.cl
@@ -0,0 +1,22 @@
+#include <clc/clc.h>
+#include "relational.h"
+
+//Note: It would be nice to use __builtin_isless with vector inputs, but it seems to only take scalar values as
+// input, which will produce incorrect output for vector input types.
+
+_CLC_DEFINE_RELATIONAL_BINARY(int, isless, __builtin_isless, float, float)
+
+#ifdef cl_khr_fp64
+
+#pragma OPENCL EXTENSION cl_khr_fp64 : enable
+
+// The scalar version of isless(double, double) returns an int, but the vector versions
+// return long.
+
+_CLC_DEF _CLC_OVERLOAD int isless(double x, double y){
+ return __builtin_isless(x, y);
+}
+
+_CLC_DEFINE_RELATIONAL_BINARY_VEC_ALL(long, isless, double, double)
+
+#endif
OpenPOWER on IntegriCloud