From 12c660827e561d42fb3cfc9a7ed5f00af4975c9a Mon Sep 17 00:00:00 2001 From: Jan Vesely Date: Fri, 1 Aug 2014 21:50:59 +0000 Subject: [PATCH] relational: Add islessequal(floatN) builtin v2: remove the initial undef Signed-off-by: Jan Vesely Reviewed-by: Aaron Watry llvm-svn: 214568 --- libclc/generic/include/clc/clc.h | 1 + .../generic/include/clc/relational/islessequal.h | 7 +++++++ libclc/generic/lib/SOURCES | 1 + libclc/generic/lib/relational/islessequal.cl | 22 ++++++++++++++++++++++ 4 files changed, 31 insertions(+) create mode 100644 libclc/generic/include/clc/relational/islessequal.h create mode 100644 libclc/generic/lib/relational/islessequal.cl diff --git a/libclc/generic/include/clc/clc.h b/libclc/generic/include/clc/clc.h index 83bf8fa..9815c56 100644 --- a/libclc/generic/include/clc/clc.h +++ b/libclc/generic/include/clc/clc.h @@ -116,6 +116,7 @@ #include #include #include +#include #include #include #include diff --git a/libclc/generic/include/clc/relational/islessequal.h b/libclc/generic/include/clc/relational/islessequal.h new file mode 100644 index 0000000..e6a99d7 --- /dev/null +++ b/libclc/generic/include/clc/relational/islessequal.h @@ -0,0 +1,7 @@ +#define __CLC_FUNCTION islessequal +#define __CLC_BODY + +#include + +#undef __CLC_BODY +#undef __CLC_FUNCTION diff --git a/libclc/generic/lib/SOURCES b/libclc/generic/lib/SOURCES index 7faba40..bfdec7b 100644 --- a/libclc/generic/lib/SOURCES +++ b/libclc/generic/lib/SOURCES @@ -49,6 +49,7 @@ relational/isequal.cl relational/isgreater.cl relational/isgreaterequal.cl relational/isless.cl +relational/islessequal.cl relational/isnan.cl relational/isnotequal.cl relational/signbit.cl diff --git a/libclc/generic/lib/relational/islessequal.cl b/libclc/generic/lib/relational/islessequal.cl new file mode 100644 index 0000000..259c307 --- /dev/null +++ b/libclc/generic/lib/relational/islessequal.cl @@ -0,0 +1,22 @@ +#include +#include "relational.h" + +//Note: It would be nice to use __builtin_islessequal 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, islessequal, __builtin_islessequal, float, float) + +#ifdef cl_khr_fp64 + +#pragma OPENCL EXTENSION cl_khr_fp64 : enable + +// The scalar version of islessequal(double, double) returns an int, but the vector versions +// return long. + +_CLC_DEF _CLC_OVERLOAD int islessequal(double x, double y){ + return __builtin_islessequal(x, y); +} + +_CLC_DEFINE_RELATIONAL_BINARY_VEC_ALL(long, islessequal, double, double) + +#endif -- 2.7.4