diff options
author | Peter Collingbourne <peter@pcc.me.uk> | 2012-05-28 20:42:54 +0000 |
---|---|---|
committer | Peter Collingbourne <peter@pcc.me.uk> | 2012-05-28 20:42:54 +0000 |
commit | 9b95fc79c210b69f60f8c226c94789c3d4b5000c (patch) | |
tree | 2515c01a2c38d0c2fbfb481330b78afc5c6fb770 /generic | |
parent | 5ea05cf610d3c536ec370879b6424a89156d2004 (diff) |
Explicit conversions.
git-svn-id: https://llvm.org/svn/llvm-project/libclc/trunk@157590 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'generic')
-rw-r--r-- | generic/include/clc/clc.h | 3 | ||||
-rw-r--r-- | generic/include/clc/convert.h | 82 | ||||
-rw-r--r-- | generic/lib/SOURCES | 1 | ||||
-rw-r--r-- | generic/lib/convert.cl | 122 |
4 files changed, 208 insertions, 0 deletions
diff --git a/generic/include/clc/clc.h b/generic/include/clc/clc.h index 983884b..f2536bc 100644 --- a/generic/include/clc/clc.h +++ b/generic/include/clc/clc.h @@ -17,6 +17,9 @@ /* 6.1 Supported Data Types */ #include <clc/clctypes.h> +/* 6.2.3 Explicit Conversions */ +#include <clc/convert.h> + /* 6.2.4.2 Reinterpreting Types Using as_type() and as_typen() */ #include <clc/as_type.h> diff --git a/generic/include/clc/convert.h b/generic/include/clc/convert.h new file mode 100644 index 0000000..0d45891 --- /dev/null +++ b/generic/include/clc/convert.h @@ -0,0 +1,82 @@ +#define _CLC_CONVERT_DECL(FROM_TYPE, TO_TYPE, SUFFIX) \ + _CLC_OVERLOAD _CLC_DECL TO_TYPE convert_##TO_TYPE##SUFFIX(FROM_TYPE x); + +_CLC_CONVERT_DECL(long, char, ) +_CLC_CONVERT_DECL(ulong, uchar, ) +_CLC_CONVERT_DECL(long, short, ) +_CLC_CONVERT_DECL(ulong, ushort, ) +_CLC_CONVERT_DECL(long, int, ) +_CLC_CONVERT_DECL(ulong, uint, ) +_CLC_CONVERT_DECL(long, long, ) +_CLC_CONVERT_DECL(ulong, ulong, ) +#ifdef cl_khr_fp64 +_CLC_CONVERT_DECL(double, float, ) +_CLC_CONVERT_DECL(double, double, ) +#else +_CLC_CONVERT_DECL(float, float, ) +#endif + +_CLC_CONVERT_DECL(long, char, _sat) +_CLC_CONVERT_DECL(ulong, uchar, _sat) +_CLC_CONVERT_DECL(long, short, _sat) +_CLC_CONVERT_DECL(ulong, ushort, _sat) +_CLC_CONVERT_DECL(long, int, _sat) +_CLC_CONVERT_DECL(ulong, uint, _sat) +_CLC_CONVERT_DECL(long, long, _sat) +_CLC_CONVERT_DECL(ulong, ulong, _sat) +#ifdef cl_khr_fp64 +_CLC_CONVERT_DECL(double, float, _sat) +_CLC_CONVERT_DECL(double, double, _sat) +#else +_CLC_CONVERT_DECL(float, float, _sat) +#endif + +#define _CLC_VECTOR_CONVERT_DECL(FROM_TYPE, TO_TYPE, SUFFIX) \ + _CLC_CONVERT_DECL(FROM_TYPE##2, TO_TYPE##2, SUFFIX) \ + _CLC_CONVERT_DECL(FROM_TYPE##3, TO_TYPE##3, SUFFIX) \ + _CLC_CONVERT_DECL(FROM_TYPE##4, TO_TYPE##4, SUFFIX) \ + _CLC_CONVERT_DECL(FROM_TYPE##8, TO_TYPE##8, SUFFIX) \ + _CLC_CONVERT_DECL(FROM_TYPE##16, TO_TYPE##16, SUFFIX) + +#define _CLC_VECTOR_CONVERT_FROM1(FROM_TYPE, SUFFIX) \ + _CLC_VECTOR_CONVERT_DECL(FROM_TYPE, char, SUFFIX) \ + _CLC_VECTOR_CONVERT_DECL(FROM_TYPE, uchar, SUFFIX) \ + _CLC_VECTOR_CONVERT_DECL(FROM_TYPE, int, SUFFIX) \ + _CLC_VECTOR_CONVERT_DECL(FROM_TYPE, uint, SUFFIX) \ + _CLC_VECTOR_CONVERT_DECL(FROM_TYPE, short, SUFFIX) \ + _CLC_VECTOR_CONVERT_DECL(FROM_TYPE, ushort, SUFFIX) \ + _CLC_VECTOR_CONVERT_DECL(FROM_TYPE, long, SUFFIX) \ + _CLC_VECTOR_CONVERT_DECL(FROM_TYPE, ulong, SUFFIX) \ + _CLC_VECTOR_CONVERT_DECL(FROM_TYPE, float, SUFFIX) + +#ifdef cl_khr_fp64 +#define _CLC_VECTOR_CONVERT_FROM(FROM_TYPE, SUFFIX) \ + _CLC_VECTOR_CONVERT_FROM1(FROM_TYPE, SUFFIX) \ + _CLC_VECTOR_CONVERT(FROM_TYPE, double, SUFFIX) +#else +#define _CLC_VECTOR_CONVERT_FROM(FROM_TYPE, SUFFIX) \ + _CLC_VECTOR_CONVERT_FROM1(FROM_TYPE, SUFFIX) +#endif + +#define _CLC_VECTOR_CONVERT_TO1(SUFFIX) \ + _CLC_VECTOR_CONVERT_FROM(char, SUFFIX) \ + _CLC_VECTOR_CONVERT_FROM(uchar, SUFFIX) \ + _CLC_VECTOR_CONVERT_FROM(int, SUFFIX) \ + _CLC_VECTOR_CONVERT_FROM(uint, SUFFIX) \ + _CLC_VECTOR_CONVERT_FROM(short, SUFFIX) \ + _CLC_VECTOR_CONVERT_FROM(ushort, SUFFIX) \ + _CLC_VECTOR_CONVERT_FROM(long, SUFFIX) \ + _CLC_VECTOR_CONVERT_FROM(ulong, SUFFIX) \ + _CLC_VECTOR_CONVERT_FROM(float, SUFFIX) + +#ifdef cl_khr_fp64 +#define _CLC_VECTOR_CONVERT_TO(SUFFIX) \ + _CLC_VECTOR_CONVERT_TO1(SUFFIX) \ + _CLC_VECTOR_CONVERT_FROM(double, SUFFIX) +#else +#define _CLC_VECTOR_CONVERT_TO(SUFFIX) \ + _CLC_VECTOR_CONVERT_TO1(SUFFIX) +#endif + +_CLC_VECTOR_CONVERT_TO() +_CLC_VECTOR_CONVERT_TO(_sat) diff --git a/generic/lib/SOURCES b/generic/lib/SOURCES index 11531fc..022abcf 100644 --- a/generic/lib/SOURCES +++ b/generic/lib/SOURCES @@ -1,3 +1,4 @@ +convert.cl geometric/cross.cl geometric/dot.cl geometric/length.cl diff --git a/generic/lib/convert.cl b/generic/lib/convert.cl new file mode 100644 index 0000000..d5a6f31 --- /dev/null +++ b/generic/lib/convert.cl @@ -0,0 +1,122 @@ +#include <clc/clc.h> + +#ifdef cl_khr_fp64 +#pragma OPENCL EXTENSION cl_khr_fp64 : enable +#endif + +#define CONVERT_ID(FROM_TYPE, TO_TYPE, SUFFIX) \ + _CLC_OVERLOAD _CLC_DEF TO_TYPE convert_##TO_TYPE##SUFFIX(FROM_TYPE x) { \ + return x; \ + } + +#define CONVERT_VECTORIZE(FROM_TYPE, TO_TYPE, SUFFIX) \ + _CLC_OVERLOAD _CLC_DEF TO_TYPE##2 convert_##TO_TYPE##2##SUFFIX(FROM_TYPE##2 x) { \ + return (TO_TYPE##2)(convert_##TO_TYPE##SUFFIX(x.x), convert_##TO_TYPE##SUFFIX(x.y)); \ + } \ +\ + _CLC_OVERLOAD _CLC_DEF TO_TYPE##3 convert_##TO_TYPE##3##SUFFIX(FROM_TYPE##3 x) { \ + return (TO_TYPE##3)(convert_##TO_TYPE##SUFFIX(x.x), convert_##TO_TYPE##SUFFIX(x.y), convert_##TO_TYPE##SUFFIX(x.z)); \ + } \ +\ + _CLC_OVERLOAD _CLC_DEF TO_TYPE##4 convert_##TO_TYPE##4##SUFFIX(FROM_TYPE##4 x) { \ + return (TO_TYPE##4)(convert_##TO_TYPE##2##SUFFIX(x.lo), convert_##TO_TYPE##2##SUFFIX(x.hi)); \ + } \ +\ + _CLC_OVERLOAD _CLC_DEF TO_TYPE##8 convert_##TO_TYPE##8##SUFFIX(FROM_TYPE##8 x) { \ + return (TO_TYPE##8)(convert_##TO_TYPE##4##SUFFIX(x.lo), convert_##TO_TYPE##4##SUFFIX(x.hi)); \ + } \ +\ + _CLC_OVERLOAD _CLC_DEF TO_TYPE##16 convert_##TO_TYPE##16##SUFFIX(FROM_TYPE##16 x) { \ + return (TO_TYPE##16)(convert_##TO_TYPE##8##SUFFIX(x.lo), convert_##TO_TYPE##8##SUFFIX(x.hi)); \ + } + +CONVERT_ID(long, char, ) +CONVERT_ID(ulong, uchar, ) +CONVERT_ID(long, short, ) +CONVERT_ID(ulong, ushort, ) +CONVERT_ID(long, int, ) +CONVERT_ID(ulong, uint, ) +CONVERT_ID(long, long, ) +CONVERT_ID(ulong, ulong, ) +#ifdef cl_khr_fp64 +CONVERT_ID(double, float, ) +CONVERT_ID(double, double, ) +#else +CONVERT_ID(float, float, ) +#endif + +_CLC_OVERLOAD _CLC_DEF char convert_char_sat(long l) { + return l > 127 ? 127 : l < -128 ? -128 : l; +} + +_CLC_OVERLOAD _CLC_DEF uchar convert_uchar_sat(ulong l) { + return l > 255U ? 255U : l; +} + +_CLC_OVERLOAD _CLC_DEF short convert_short_sat(long l) { + return l > 32767 ? 32767 : l < -32768 ? -32768 : l; +} + +_CLC_OVERLOAD _CLC_DEF ushort convert_ushort_sat(ulong l) { + return l > 65535U ? 65535U : l; +} + +_CLC_OVERLOAD _CLC_DEF int convert_int_sat(long l) { + return l > ((1L<<31)-1) ? ((1L<<31L)-1) : l < -(1L<<31) ? -(1L<<31) : l; +} + +_CLC_OVERLOAD _CLC_DEF uint convert_uint_sat(ulong l) { + return l > ((1UL<<32)-1) ? ((1UL<<32)-1) : l; +} + +CONVERT_ID(long, long, _sat) +CONVERT_ID(ulong, ulong, _sat) +#ifdef cl_khr_fp64 +CONVERT_ID(double, float, _sat) +CONVERT_ID(double, double, _sat) +#else +CONVERT_ID(float, float, _sat) +#endif + +#define CONVERT_VECTORIZE_FROM1(FROM_TYPE, SUFFIX) \ + CONVERT_VECTORIZE(FROM_TYPE, char, SUFFIX) \ + CONVERT_VECTORIZE(FROM_TYPE, uchar, SUFFIX) \ + CONVERT_VECTORIZE(FROM_TYPE, int, SUFFIX) \ + CONVERT_VECTORIZE(FROM_TYPE, uint, SUFFIX) \ + CONVERT_VECTORIZE(FROM_TYPE, short, SUFFIX) \ + CONVERT_VECTORIZE(FROM_TYPE, ushort, SUFFIX) \ + CONVERT_VECTORIZE(FROM_TYPE, long, SUFFIX) \ + CONVERT_VECTORIZE(FROM_TYPE, ulong, SUFFIX) \ + CONVERT_VECTORIZE(FROM_TYPE, float, SUFFIX) + +#ifdef cl_khr_fp64 +#define CONVERT_VECTORIZE_FROM(FROM_TYPE, SUFFIX) \ + CONVERT_VECTORIZE_FROM1(FROM_TYPE, SUFFIX) \ + CONVERT_VECTORIZE(FROM_TYPE, double, SUFFIX) +#else +#define CONVERT_VECTORIZE_FROM(FROM_TYPE, SUFFIX) \ + CONVERT_VECTORIZE_FROM1(FROM_TYPE, SUFFIX) +#endif + +#define CONVERT_VECTORIZE_TO1(SUFFIX) \ + CONVERT_VECTORIZE_FROM(char, SUFFIX) \ + CONVERT_VECTORIZE_FROM(uchar, SUFFIX) \ + CONVERT_VECTORIZE_FROM(int, SUFFIX) \ + CONVERT_VECTORIZE_FROM(uint, SUFFIX) \ + CONVERT_VECTORIZE_FROM(short, SUFFIX) \ + CONVERT_VECTORIZE_FROM(ushort, SUFFIX) \ + CONVERT_VECTORIZE_FROM(long, SUFFIX) \ + CONVERT_VECTORIZE_FROM(ulong, SUFFIX) \ + CONVERT_VECTORIZE_FROM(float, SUFFIX) + +#ifdef cl_khr_fp64 +#define CONVERT_VECTORIZE_TO(SUFFIX) \ + CONVERT_VECTORIZE_TO1(SUFFIX) \ + CONVERT_VECTORIZE_FROM(double, SUFFIX) +#else +#define CONVERT_VECTORIZE_TO(SUFFIX) \ + CONVERT_VECTORIZE_TO1(SUFFIX) +#endif + +CONVERT_VECTORIZE_TO() +CONVERT_VECTORIZE_TO(_sat) |