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

Reply via email to