https://github.com/wenju-he updated https://github.com/llvm/llvm-project/pull/140679
>From 5015512439f6ba846223b1d04e71d8cdae36d3fa Mon Sep 17 00:00:00 2001 From: Wenju He <wenju...@intel.com> Date: Mon, 19 May 2025 22:14:55 -0700 Subject: [PATCH 1/2] [libclc] Re-use shuffle_decl.inc in OpenCL shuffle2 declaration Also internalize __clc_get_el_* symbols in clc_shuffle2. llvm-diff shows no change to amdgcn--amdhsa.bc. --- libclc/clc/lib/generic/misc/clc_shuffle.cl | 2 +- libclc/clc/lib/generic/misc/clc_shuffle2.cl | 5 +-- libclc/generic/include/clc/misc/shuffle2.h | 43 ++++----------------- 3 files changed, 11 insertions(+), 39 deletions(-) diff --git a/libclc/clc/lib/generic/misc/clc_shuffle.cl b/libclc/clc/lib/generic/misc/clc_shuffle.cl index 626a94df08131..f02e7aec9a0b8 100644 --- a/libclc/clc/lib/generic/misc/clc_shuffle.cl +++ b/libclc/clc/lib/generic/misc/clc_shuffle.cl @@ -52,7 +52,7 @@ return VAR.sF; #define _CLC_GET_ELEMENT_DEFINE(ARGTYPE, ARGSIZE, IDXTYPE) \ - inline ARGTYPE __clc_get_el_##ARGTYPE##ARGSIZE##_##IDXTYPE( \ + _CLC_INLINE ARGTYPE __clc_get_el_##ARGTYPE##ARGSIZE##_##IDXTYPE( \ ARGTYPE##ARGSIZE x, IDXTYPE idx) { \ switch (idx) { _CLC_ELEMENT_CASES##ARGSIZE(x) default : return 0; } \ } diff --git a/libclc/clc/lib/generic/misc/clc_shuffle2.cl b/libclc/clc/lib/generic/misc/clc_shuffle2.cl index 3626e67423193..db97f7c5cf960 100644 --- a/libclc/clc/lib/generic/misc/clc_shuffle2.cl +++ b/libclc/clc/lib/generic/misc/clc_shuffle2.cl @@ -52,9 +52,8 @@ return VAR.sF; #define _CLC_GET_ELEMENT_DEFINE(ARGTYPE, ARGSIZE, IDXTYPE) \ - __attribute__((always_inline)) ARGTYPE \ - __clc_get_el_##ARGTYPE##ARGSIZE##_##IDXTYPE( \ - ARGTYPE##ARGSIZE x, ARGTYPE##ARGSIZE y, IDXTYPE idx) { \ + _CLC_INLINE ARGTYPE __clc_get_el_##ARGTYPE##ARGSIZE##_##IDXTYPE( \ + ARGTYPE##ARGSIZE x, ARGTYPE##ARGSIZE y, IDXTYPE idx) { \ if (idx < ARGSIZE) \ switch (idx) { _CLC_ELEMENT_CASES##ARGSIZE(x) default : return 0; } \ else \ diff --git a/libclc/generic/include/clc/misc/shuffle2.h b/libclc/generic/include/clc/misc/shuffle2.h index 93845f89911bd..6ad814af164c0 100644 --- a/libclc/generic/include/clc/misc/shuffle2.h +++ b/libclc/generic/include/clc/misc/shuffle2.h @@ -6,41 +6,14 @@ // //===----------------------------------------------------------------------===// -#define _CLC_SHUFFLE2_DECL(TYPE, MASKTYPE, RETTYPE) \ - _CLC_OVERLOAD _CLC_DECL RETTYPE shuffle2(TYPE x, TYPE y, MASKTYPE mask); +#define __CLC_FUNCTION shuffle2 -//Return type is same base type as the input type, with the same vector size as the mask. -//Elements in the mask must be the same size (number of bits) as the input value. -//E.g. char8 ret = shuffle2(char2 x, char2 y, uchar8 mask); +// Integer-type decls +#define __CLC_BODY <clc/misc/shuffle_decl.inc> +#include <clc/integer/gentype.inc> -#define _CLC_VECTOR_SHUFFLE2_MASKSIZE(INBASE, INTYPE, MASKTYPE) \ - _CLC_SHUFFLE2_DECL(INTYPE, MASKTYPE##2, INBASE##2) \ - _CLC_SHUFFLE2_DECL(INTYPE, MASKTYPE##4, INBASE##4) \ - _CLC_SHUFFLE2_DECL(INTYPE, MASKTYPE##8, INBASE##8) \ - _CLC_SHUFFLE2_DECL(INTYPE, MASKTYPE##16, INBASE##16) \ +// Floating-point decls +#define __CLC_BODY <clc/misc/shuffle_decl.inc> +#include <clc/math/gentype.inc> -#define _CLC_VECTOR_SHUFFLE2_INSIZE(TYPE, MASKTYPE) \ - _CLC_VECTOR_SHUFFLE2_MASKSIZE(TYPE, TYPE##2, MASKTYPE) \ - _CLC_VECTOR_SHUFFLE2_MASKSIZE(TYPE, TYPE##4, MASKTYPE) \ - _CLC_VECTOR_SHUFFLE2_MASKSIZE(TYPE, TYPE##8, MASKTYPE) \ - _CLC_VECTOR_SHUFFLE2_MASKSIZE(TYPE, TYPE##16, MASKTYPE) \ - -_CLC_VECTOR_SHUFFLE2_INSIZE(char, uchar) -_CLC_VECTOR_SHUFFLE2_INSIZE(short, ushort) -_CLC_VECTOR_SHUFFLE2_INSIZE(int, uint) -_CLC_VECTOR_SHUFFLE2_INSIZE(long, ulong) -_CLC_VECTOR_SHUFFLE2_INSIZE(uchar, uchar) -_CLC_VECTOR_SHUFFLE2_INSIZE(ushort, ushort) -_CLC_VECTOR_SHUFFLE2_INSIZE(uint, uint) -_CLC_VECTOR_SHUFFLE2_INSIZE(ulong, ulong) -_CLC_VECTOR_SHUFFLE2_INSIZE(float, uint) -#ifdef cl_khr_fp64 -_CLC_VECTOR_SHUFFLE2_INSIZE(double, ulong) -#endif -#ifdef cl_khr_fp16 -_CLC_VECTOR_SHUFFLE2_INSIZE(half, ushort) -#endif - -#undef _CLC_SHUFFLE_DECL -#undef _CLC_VECTOR_SHUFFLE2_MASKSIZE -#undef _CLC_VECTOR_SHUFFLE2_INSIZE +#undef __CLC_FUNCTION >From 27fc7ea03bc32b86c609db84f8e90bdf3777f20c Mon Sep 17 00:00:00 2001 From: Wenju He <wenju...@intel.com> Date: Tue, 20 May 2025 23:20:23 -0700 Subject: [PATCH 2/2] shuffle_decl.inc -> shuffle2_decl.inc --- libclc/opencl/include/clc/opencl/misc/shuffle2.h | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/libclc/opencl/include/clc/opencl/misc/shuffle2.h b/libclc/opencl/include/clc/opencl/misc/shuffle2.h index 6ad814af164c0..91548ad784fbb 100644 --- a/libclc/opencl/include/clc/opencl/misc/shuffle2.h +++ b/libclc/opencl/include/clc/opencl/misc/shuffle2.h @@ -9,11 +9,11 @@ #define __CLC_FUNCTION shuffle2 // Integer-type decls -#define __CLC_BODY <clc/misc/shuffle_decl.inc> +#define __CLC_BODY <clc/misc/shuffle2_decl.inc> #include <clc/integer/gentype.inc> // Floating-point decls -#define __CLC_BODY <clc/misc/shuffle_decl.inc> +#define __CLC_BODY <clc/misc/shuffle2_decl.inc> #include <clc/math/gentype.inc> #undef __CLC_FUNCTION _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits