diff --git a/libclc/clc/include/clc/integer/clc_ctz.h b/libclc/clc/include/clc/integer/clc_ctz.h new file mode 100644 index 0000000000000..1e6365100827b --- /dev/null +++ b/libclc/clc/include/clc/integer/clc_ctz.h @@ -0,0 +1,20 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +#ifndef __CLC_INTEGER_CLC_CTZ_H__ +#define __CLC_INTEGER_CLC_CTZ_H__ + +#define __CLC_FUNCTION __clc_ctz +#define __CLC_BODY + +#include + +#undef __CLC_BODY +#undef __CLC_FUNCTION + +#endif // __CLC_INTEGER_CLC_CTZ_H__ diff --git a/libclc/clc/lib/generic/SOURCES b/libclc/clc/lib/generic/SOURCES index 2e9878e6eaa4e..6960ed39045d4 100644 --- a/libclc/clc/lib/generic/SOURCES +++ b/libclc/clc/lib/generic/SOURCES @@ -7,6 +7,7 @@ integer/clc_abs.cl integer/clc_abs_diff.cl integer/clc_add_sat.cl integer/clc_clz.cl +integer/clc_ctz.cl integer/clc_hadd.cl integer/clc_mad24.cl integer/clc_mad_sat.cl diff --git a/libclc/clc/lib/generic/integer/clc_ctz.cl b/libclc/clc/lib/generic/integer/clc_ctz.cl new file mode 100644 index 0000000000000..50fda4a214b24 --- /dev/null +++ b/libclc/clc/lib/generic/integer/clc_ctz.cl @@ -0,0 +1,48 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +#include +#include +#include + +_CLC_OVERLOAD _CLC_DEF char __clc_ctz(char x) { + return __clc_ctz(__clc_as_uchar(x)); +} + +_CLC_OVERLOAD _CLC_DEF uchar __clc_ctz(uchar x) { return __builtin_ctzg(x, 8); } + +_CLC_OVERLOAD _CLC_DEF short __clc_ctz(short x) { + return __clc_ctz(__clc_as_ushort(x)); +} + +_CLC_OVERLOAD _CLC_DEF ushort __clc_ctz(ushort x) { + return __builtin_ctzg(x, 16); +} + +_CLC_OVERLOAD _CLC_DEF int __clc_ctz(int x) { + return __clc_ctz(__clc_as_uint(x)); +} + +_CLC_OVERLOAD _CLC_DEF uint __clc_ctz(uint x) { return __builtin_ctzg(x, 32); } + +_CLC_OVERLOAD _CLC_DEF long __clc_ctz(long x) { + return __clc_ctz(__clc_as_ulong(x)); +} + +_CLC_OVERLOAD _CLC_DEF ulong __clc_ctz(ulong x) { + return __builtin_ctzg(x, 64); +} + +_CLC_UNARY_VECTORIZE(_CLC_OVERLOAD _CLC_DEF, char, __clc_ctz, char) +_CLC_UNARY_VECTORIZE(_CLC_OVERLOAD _CLC_DEF, uchar, __clc_ctz, uchar) +_CLC_UNARY_VECTORIZE(_CLC_OVERLOAD _CLC_DEF, short, __clc_ctz, short) +_CLC_UNARY_VECTORIZE(_CLC_OVERLOAD _CLC_DEF, ushort, __clc_ctz, ushort) +_CLC_UNARY_VECTORIZE(_CLC_OVERLOAD _CLC_DEF, int, __clc_ctz, int) +_CLC_UNARY_VECTORIZE(_CLC_OVERLOAD _CLC_DEF, uint, __clc_ctz, uint) +_CLC_UNARY_VECTORIZE(_CLC_OVERLOAD _CLC_DEF, long, __clc_ctz, long) +_CLC_UNARY_VECTORIZE(_CLC_OVERLOAD _CLC_DEF, ulong, __clc_ctz, ulong) diff --git a/libclc/generic/include/clc/clc.h b/libclc/generic/include/clc/clc.h index 5b194696dcfc4..c2f40f4324040 100644 --- a/libclc/generic/include/clc/clc.h +++ b/libclc/generic/include/clc/clc.h @@ -171,6 +171,7 @@ #include #include #include +#include #include #include #include diff --git a/libclc/generic/include/clc/integer/ctz.h b/libclc/generic/include/clc/integer/ctz.h new file mode 100644 index 0000000000000..7c6da17a39d56 --- /dev/null +++ b/libclc/generic/include/clc/integer/ctz.h @@ -0,0 +1,19 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +#if __OPENCL_C_VERSION__ >= CL_VERSION_2_0 + +#define __CLC_FUNCTION ctz +#define __CLC_BODY + +#include + +#undef __CLC_BODY +#undef __CLC_FUNCTION + +#endif // __OPENCL_C_VERSION__ >= CL_VERSION_2_0 diff --git a/libclc/generic/lib/SOURCES b/libclc/generic/lib/SOURCES index bd74b6b444cac..95b896d927d98 100644 --- a/libclc/generic/lib/SOURCES +++ b/libclc/generic/lib/SOURCES @@ -64,6 +64,7 @@ integer/abs.cl integer/abs_diff.cl integer/add_sat.cl integer/clz.cl +integer/ctz.cl integer/hadd.cl integer/mad24.cl integer/mad_hi.cl diff --git a/libclc/generic/lib/integer/ctz.cl b/libclc/generic/lib/integer/ctz.cl new file mode 100644 index 0000000000000..44978e1617403 --- /dev/null +++ b/libclc/generic/lib/integer/ctz.cl @@ -0,0 +1,19 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +#if __OPENCL_C_VERSION__ >= CL_VERSION_2_0 + +#include +#include + +#define FUNCTION ctz +#define __CLC_BODY + +#include + +#endif // __OPENCL_C_VERSION__ >= CL_VERSION_2_0