diff options
author | Aaron Watry <awatry@gmail.com> | 2014-07-17 22:05:25 +0000 |
---|---|---|
committer | Aaron Watry <awatry@gmail.com> | 2014-07-17 22:05:25 +0000 |
commit | 9335fe8eff5bfd0a5e71fe61416d4a0aad2c20cb (patch) | |
tree | 8269cd28384a7f35a68af24e9fe9e4024aac0407 /libclc | |
parent | d5aace48740d0134d147a1e270934d59b1fe5f47 (diff) | |
download | bcm5719-llvm-9335fe8eff5bfd0a5e71fe61416d4a0aad2c20cb.tar.gz bcm5719-llvm-9335fe8eff5bfd0a5e71fe61416d4a0aad2c20cb.zip |
relational/signbit: Refactor to use relational macros
Signed-off-by: Aaron Watry <awatry@gmail.com>
Reviewed-by: Tom Stellard <thomas.stellard@amd.com>
llvm-svn: 213317
Diffstat (limited to 'libclc')
-rw-r--r-- | libclc/generic/include/clc/relational/signbit.h | 21 | ||||
-rw-r--r-- | libclc/generic/lib/relational/signbit.cl | 72 |
2 files changed, 8 insertions, 85 deletions
diff --git a/libclc/generic/include/clc/relational/signbit.h b/libclc/generic/include/clc/relational/signbit.h index 774d6e0433e..41e5284bb34 100644 --- a/libclc/generic/include/clc/relational/signbit.h +++ b/libclc/generic/include/clc/relational/signbit.h @@ -1,18 +1,9 @@ +#undef signbit -#define _CLC_SIGNBIT_DECL(TYPE, RETTYPE) \ - _CLC_OVERLOAD _CLC_DECL RETTYPE signbit(TYPE x); +#define __CLC_FUNCTION signbit +#define __CLC_BODY <clc/relational/unary_decl.inc> -#define _CLC_VECTOR_SIGNBIT_DECL(TYPE, RETTYPE) \ - _CLC_SIGNBIT_DECL(TYPE##2, RETTYPE##2) \ - _CLC_SIGNBIT_DECL(TYPE##3, RETTYPE##3) \ - _CLC_SIGNBIT_DECL(TYPE##4, RETTYPE##4) \ - _CLC_SIGNBIT_DECL(TYPE##8, RETTYPE##8) \ - _CLC_SIGNBIT_DECL(TYPE##16, RETTYPE##16) +#include <clc/relational/floatn.inc> -_CLC_SIGNBIT_DECL(float, int) -_CLC_VECTOR_SIGNBIT_DECL(float, int) - -#ifdef cl_khr_fp64 -_CLC_SIGNBIT_DECL(double, int) -_CLC_VECTOR_SIGNBIT_DECL(double, long) -#endif
\ No newline at end of file +#undef __CLC_BODY +#undef __CLC_FUNCTION diff --git a/libclc/generic/lib/relational/signbit.cl b/libclc/generic/lib/relational/signbit.cl index f4299606828..ab37d2f1288 100644 --- a/libclc/generic/lib/relational/signbit.cl +++ b/libclc/generic/lib/relational/signbit.cl @@ -1,61 +1,5 @@ #include <clc/clc.h> - -#define _CLC_DEFINE_RELATIONAL_UNARY_SCALAR(RET_TYPE, FUNCTION, BUILTIN_NAME, ARG_TYPE) \ -_CLC_DEF _CLC_OVERLOAD RET_TYPE FUNCTION(ARG_TYPE x){ \ - return BUILTIN_NAME(x); \ -} \ - -#define _CLC_DEFINE_RELATIONAL_UNARY_VEC(RET_TYPE, FUNCTION, ARG_TYPE) \ -_CLC_DEF _CLC_OVERLOAD RET_TYPE FUNCTION(ARG_TYPE x) { \ - return (RET_TYPE)( (RET_TYPE){FUNCTION(x.lo), FUNCTION(x.hi)} != (RET_TYPE)0); \ -} \ - -#define _CLC_DEFINE_RELATIONAL_UNARY_VEC2(RET_TYPE, FUNCTION, ARG_TYPE) \ -_CLC_DEF _CLC_OVERLOAD RET_TYPE FUNCTION(ARG_TYPE x) { \ - return (RET_TYPE)( (RET_TYPE){FUNCTION(x.lo), FUNCTION(x.hi)} != (RET_TYPE)0); \ -} \ - -#define _CLC_DEFINE_RELATIONAL_UNARY_VEC3(RET_TYPE, FUNCTION, ARG_TYPE) \ -_CLC_DEF _CLC_OVERLOAD RET_TYPE FUNCTION(ARG_TYPE x) { \ - return (RET_TYPE)( (RET_TYPE){FUNCTION(x.s0), FUNCTION(x.s1), FUNCTION(x.s2)} != (RET_TYPE)0); \ -} \ - -#define _CLC_DEFINE_RELATIONAL_UNARY_VEC4(RET_TYPE, FUNCTION, ARG_TYPE) \ -_CLC_DEF _CLC_OVERLOAD RET_TYPE FUNCTION(ARG_TYPE x) { \ - return (RET_TYPE)( \ - (RET_TYPE){ \ - FUNCTION(x.s0), FUNCTION(x.s1), FUNCTION(x.s2), FUNCTION(x.s3) \ - } != (RET_TYPE)0); \ -} \ - -#define _CLC_DEFINE_RELATIONAL_UNARY_VEC8(RET_TYPE, FUNCTION, ARG_TYPE) \ -_CLC_DEF _CLC_OVERLOAD RET_TYPE FUNCTION(ARG_TYPE x) { \ - return (RET_TYPE)( \ - (RET_TYPE){ \ - FUNCTION(x.s0), FUNCTION(x.s1), FUNCTION(x.s2), FUNCTION(x.s3), \ - FUNCTION(x.s4), FUNCTION(x.s5), FUNCTION(x.s6), FUNCTION(x.s7) \ - } != (RET_TYPE)0); \ -} \ - -#define _CLC_DEFINE_RELATIONAL_UNARY_VEC16(RET_TYPE, FUNCTION, ARG_TYPE) \ -_CLC_DEF _CLC_OVERLOAD RET_TYPE FUNCTION(ARG_TYPE x) { \ - return (RET_TYPE)( \ - (RET_TYPE){ \ - FUNCTION(x.s0), FUNCTION(x.s1), FUNCTION(x.s2), FUNCTION(x.s3), \ - FUNCTION(x.s4), FUNCTION(x.s5), FUNCTION(x.s6), FUNCTION(x.s7), \ - FUNCTION(x.s8), FUNCTION(x.s9), FUNCTION(x.sa), FUNCTION(x.sb), \ - FUNCTION(x.sc), FUNCTION(x.sd), FUNCTION(x.se), FUNCTION(x.sf) \ - } != (RET_TYPE)0); \ -} \ - - -#define _CLC_DEFINE_RELATIONAL_UNARY(RET_TYPE, FUNCTION, BUILTIN_FUNCTION, ARG_TYPE) \ -_CLC_DEFINE_RELATIONAL_UNARY_SCALAR(RET_TYPE, FUNCTION, BUILTIN_FUNCTION, ARG_TYPE) \ -_CLC_DEFINE_RELATIONAL_UNARY_VEC2(RET_TYPE##2, FUNCTION, ARG_TYPE##2) \ -_CLC_DEFINE_RELATIONAL_UNARY_VEC3(RET_TYPE##3, FUNCTION, ARG_TYPE##3) \ -_CLC_DEFINE_RELATIONAL_UNARY_VEC4(RET_TYPE##4, FUNCTION, ARG_TYPE##4) \ -_CLC_DEFINE_RELATIONAL_UNARY_VEC8(RET_TYPE##8, FUNCTION, ARG_TYPE##8) \ -_CLC_DEFINE_RELATIONAL_UNARY_VEC16(RET_TYPE##16, FUNCTION, ARG_TYPE##16) \ +#include "relational.h" _CLC_DEFINE_RELATIONAL_UNARY(int, signbit, __builtin_signbitf, float) @@ -70,18 +14,6 @@ _CLC_DEF _CLC_OVERLOAD int signbit(double x){ return __builtin_signbit(x); } -_CLC_DEFINE_RELATIONAL_UNARY_VEC2(long2, signbit, double2) -_CLC_DEFINE_RELATIONAL_UNARY_VEC3(long3, signbit, double3) -_CLC_DEFINE_RELATIONAL_UNARY_VEC4(long4, signbit, double4) -_CLC_DEFINE_RELATIONAL_UNARY_VEC8(long8, signbit, double8) -_CLC_DEFINE_RELATIONAL_UNARY_VEC16(long16, signbit, double16) +_CLC_DEFINE_RELATIONAL_UNARY_VEC_ALL(long, signbit, double) #endif - -#undef _CLC_DEFINE_RELATIONAL_UNARY -#undef _CLC_DEFINE_RELATIONAL_UNARY_SCALAR -#undef _CLC_DEFINE_RELATIONAL_UNARY_VEC2 -#undef _CLC_DEFINE_RELATIONAL_UNARY_VEC3 -#undef _CLC_DEFINE_RELATIONAL_UNARY_VEC4 -#undef _CLC_DEFINE_RELATIONAL_UNARY_VEC8 -#undef _CLC_DEFINE_RELATIONAL_UNARY_VEC16
\ No newline at end of file |