|
| 1 | +// RUN: %clang_cc1 -fsycl-is-host -emit-llvm -triple x86_64 %s -o - | FileCheck %s |
| 2 | + |
| 3 | +// Test IR generated by __builtin_sycl_kernel_name(). This builtin accepts a SYCL |
| 4 | +// kernel name type and returns it's mangled name. |
| 5 | + |
| 6 | +class kernel_name_1; |
| 7 | +class kernel_name_2; |
| 8 | +typedef kernel_name_2 kernel_name_TD; |
| 9 | +class kernel_name_3; |
| 10 | +class kernel_name_4; |
| 11 | +typedef kernel_name_4 kernel_name_TD2; |
| 12 | + |
| 13 | +template<typename KN> |
| 14 | +struct kernel_id_t { |
| 15 | + using type = KN; |
| 16 | +}; |
| 17 | + |
| 18 | +struct kernel_id_nt { |
| 19 | + using type = kernel_name_3; |
| 20 | +}; |
| 21 | + |
| 22 | +template <typename name, typename Func> |
| 23 | +__attribute__((sycl_kernel_entry_point(name))) void kernel_single_task(const Func kernelFunc) { |
| 24 | + kernelFunc(); |
| 25 | +} |
| 26 | + |
| 27 | +struct SYCLKernel { |
| 28 | + int m; |
| 29 | + public: |
| 30 | + void operator()() const {} |
| 31 | +}; |
| 32 | + |
| 33 | +void test() { |
| 34 | + SYCLKernel Obj; |
| 35 | + kernel_single_task<kernel_name_1>(Obj); |
| 36 | + kernel_single_task<kernel_name_TD>(Obj); |
| 37 | + kernel_single_task<kernel_name_3>(Obj); |
| 38 | + kernel_single_task<kernel_name_TD2>(Obj); |
| 39 | + const char* test1 = __builtin_sycl_kernel_name(kernel_id_t<kernel_name_1>()); |
| 40 | + const char* test2 = __builtin_sycl_kernel_name(kernel_id_t<kernel_name_TD>()); |
| 41 | + const char* test3 = __builtin_sycl_kernel_name(kernel_id_nt()); |
| 42 | + const char* test4 = __builtin_sycl_kernel_name(kernel_id_t<kernel_name_4>()); |
| 43 | +} |
| 44 | + |
| 45 | +// Kernel names retrieved from KernelInfo map |
| 46 | +// CHECK: @0 = private unnamed_addr constant [44 x i8] c"_Z20__sycl_kernel_callerI13kernel_name_1Evv\00", align 1 |
| 47 | +// CHECK: @1 = private unnamed_addr constant [44 x i8] c"_Z20__sycl_kernel_callerI13kernel_name_2Evv\00", align 1 |
| 48 | +// CHECK: @2 = private unnamed_addr constant [44 x i8] c"_Z20__sycl_kernel_callerI13kernel_name_3Evv\00", align 1 |
| 49 | +// CHECK: @3 = private unnamed_addr constant [44 x i8] c"_Z20__sycl_kernel_callerI13kernel_name_4Evv\00", align 1 |
| 50 | + |
| 51 | +// CHECK: define dso_local void @_Z4testv() |
| 52 | +// CHECK: %test1 = alloca ptr, align 8 |
| 53 | +// CHECK: %test2 = alloca ptr, align 8 |
| 54 | +// CHECK: %test3 = alloca ptr, align 8 |
| 55 | +// CHECK: %test4 = alloca ptr, align 8 |
| 56 | +// CHECK: store ptr @0, ptr %test1, align 8 |
| 57 | +// CHECK: store ptr @1, ptr %test2, align 8 |
| 58 | +// CHECK: store ptr @2, ptr %test3, align 8 |
| 59 | +// CHECK: store ptr @3, ptr %test4, align 8 |
| 60 | + |
0 commit comments