diff options
| author | Aaron Watry <awatry@gmail.com> | 2014-07-17 22:07:27 +0000 |
|---|---|---|
| committer | Aaron Watry <awatry@gmail.com> | 2014-07-17 22:07:27 +0000 |
| commit | 30102536c0712ef8e4220d665516bf9c1313a197 (patch) | |
| tree | eb959a18eaec5dd44c3f25576acac6d66eed413c /libclc | |
| parent | 803a992f045f7f88f29750592f460962d5633f46 (diff) | |
| download | bcm5719-llvm-30102536c0712ef8e4220d665516bf9c1313a197.tar.gz bcm5719-llvm-30102536c0712ef8e4220d665516bf9c1313a197.zip | |
relational: Implement isgreaterequal
v2: Use relational macros instead of hand-rolled macros
Signed-off-by: Aaron Watry <awatry@gmail.com>
Reviewed-by: Tom Stellard <thomas.stellard@amd.com>
llvm-svn: 213319
Diffstat (limited to 'libclc')
| -rw-r--r-- | libclc/generic/include/clc/clc.h | 1 | ||||
| -rw-r--r-- | libclc/generic/include/clc/relational/isgreaterequal.h | 9 | ||||
| -rw-r--r-- | libclc/generic/lib/SOURCES | 1 | ||||
| -rw-r--r-- | libclc/generic/lib/relational/isgreaterequal.cl | 22 |
4 files changed, 33 insertions, 0 deletions
diff --git a/libclc/generic/include/clc/clc.h b/libclc/generic/include/clc/clc.h index 34123d9effa..fd5c3231bfc 100644 --- a/libclc/generic/include/clc/clc.h +++ b/libclc/generic/include/clc/clc.h @@ -111,6 +111,7 @@ #include <clc/relational/bitselect.h> #include <clc/relational/isequal.h> #include <clc/relational/isgreater.h> +#include <clc/relational/isgreaterequal.h> #include <clc/relational/isnan.h> #include <clc/relational/select.h> #include <clc/relational/signbit.h> diff --git a/libclc/generic/include/clc/relational/isgreaterequal.h b/libclc/generic/include/clc/relational/isgreaterequal.h new file mode 100644 index 00000000000..835332858d2 --- /dev/null +++ b/libclc/generic/include/clc/relational/isgreaterequal.h @@ -0,0 +1,9 @@ +#undef isgreaterequal + +#define __CLC_FUNCTION isgreaterequal +#define __CLC_BODY <clc/relational/binary_decl.inc> + +#include <clc/relational/floatn.inc> + +#undef __CLC_BODY +#undef __CLC_FUNCTION diff --git a/libclc/generic/lib/SOURCES b/libclc/generic/lib/SOURCES index 671fff2028a..dfe10167fe8 100644 --- a/libclc/generic/lib/SOURCES +++ b/libclc/generic/lib/SOURCES @@ -42,6 +42,7 @@ relational/all.cl relational/any.cl relational/isequal.cl relational/isgreater.cl +relational/isgreaterequal.cl relational/isnan.cl relational/signbit.cl shared/clamp.cl diff --git a/libclc/generic/lib/relational/isgreaterequal.cl b/libclc/generic/lib/relational/isgreaterequal.cl new file mode 100644 index 00000000000..2d5ebe5770c --- /dev/null +++ b/libclc/generic/lib/relational/isgreaterequal.cl @@ -0,0 +1,22 @@ +#include <clc/clc.h> +#include "relational.h" + +//Note: It would be nice to use __builtin_isgreaterequal 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, isgreaterequal, __builtin_isgreaterequal, float, float) + +#ifdef cl_khr_fp64 + +#pragma OPENCL EXTENSION cl_khr_fp64 : enable + +// The scalar version of isgreaterequal(double, double) returns an int, but the vector versions +// return long. + +_CLC_DEF _CLC_OVERLOAD int isgreaterequal(double x, double y){ + return __builtin_isgreaterequal(x, y); +} + +_CLC_DEFINE_RELATIONAL_BINARY_VEC_ALL(long, isgreaterequal, double, double) + +#endif |

