
This patch is part of the upstreaming effort for supporting SYCL language front end. It makes the following changes: 1. Adds sycl_external attribute for functions with external linkage, which is intended for use to implement the SYCL_EXTERNAL macro as specified by the SYCL 2020 specification 2. Adds checks to avoid emitting device code when sycl_external and sycl_kernel_entry_point attributes are not enabled 3. Fixes test failures caused by the above changes This patch is missing diagnostics for the following diagnostics listed in the SYCL 2020 specification's section 5.10.1, which will be addressed in a subsequent PR: Functions that are declared using SYCL_EXTERNAL have the following additional restrictions beyond those imposed on other device functions: 1. If the SYCL backend does not support the generic address space then the function cannot use raw pointers as parameter or return types. Explicit pointer classes must be used instead; 2. The function cannot call group::parallel_for_work_item; 3. The function cannot be called from a parallel_for_work_group scope. In addition to that, the subsequent PR will also implement diagnostics for inline functions including virtual functions defined as inline. --------- Co-authored-by: Mariya Podchishchaeva <mariya.podchishchaeva@intel.com>
111 lines
6.5 KiB
C++
111 lines
6.5 KiB
C++
// RUN: %clang_cc1 -Wno-unused-value -O0 -internal-isystem %S/../../lib/Headers -include __clang_spirv_builtins.h -triple spirv64 -emit-llvm %s -fsycl-is-device -o - | FileCheck %s -check-prefixes=CHECK64
|
|
// RUN: %clang_cc1 -Wno-unused-value -O0 -internal-isystem %S/../../lib/Headers -include __clang_spirv_builtins.h -triple spirv64 -emit-llvm %s -x cl -o - | FileCheck %s -check-prefixes=CHECK64
|
|
// RUN: %clang_cc1 -Wno-unused-value -O0 -internal-isystem %S/../../lib/Headers -include __clang_spirv_builtins.h -triple spirv32 -emit-llvm %s -fsycl-is-device -o - | FileCheck %s -check-prefixes=CHECK32
|
|
// RUN: %clang_cc1 -Wno-unused-value -O0 -internal-isystem %S/../../lib/Headers -include __clang_spirv_builtins.h -triple spirv32 -emit-llvm %s -x cl -o - | FileCheck %s -check-prefixes=CHECK32
|
|
// RUN: %clang_cc1 -Wno-unused-value -O0 -internal-isystem %S/../../lib/Headers -include __clang_spirv_builtins.h -triple nvptx64 -emit-llvm %s -fsycl-is-device -o - | FileCheck %s -check-prefixes=NV
|
|
|
|
|
|
// CHECK64: call i64 @llvm.spv.num.workgroups.i64(i32 0)
|
|
// CHECK64: call i64 @llvm.spv.num.workgroups.i64(i32 1)
|
|
// CHECK64: call i64 @llvm.spv.num.workgroups.i64(i32 2)
|
|
// CHECK64: call i64 @llvm.spv.workgroup.size.i64(i32 0)
|
|
// CHECK64: call i64 @llvm.spv.workgroup.size.i64(i32 1)
|
|
// CHECK64: call i64 @llvm.spv.workgroup.size.i64(i32 2)
|
|
// CHECK64: call i64 @llvm.spv.group.id.i64(i32 0)
|
|
// CHECK64: call i64 @llvm.spv.group.id.i64(i32 1)
|
|
// CHECK64: call i64 @llvm.spv.group.id.i64(i32 2)
|
|
// CHECK64: call i64 @llvm.spv.thread.id.in.group.i64(i32 0)
|
|
// CHECK64: call i64 @llvm.spv.thread.id.in.group.i64(i32 1)
|
|
// CHECK64: call i64 @llvm.spv.thread.id.in.group.i64(i32 2)
|
|
// CHECK64: call i64 @llvm.spv.thread.id.i64(i32 0)
|
|
// CHECK64: call i64 @llvm.spv.thread.id.i64(i32 1)
|
|
// CHECK64: call i64 @llvm.spv.thread.id.i64(i32 2)
|
|
// CHECK64: call i64 @llvm.spv.global.size.i64(i32 0)
|
|
// CHECK64: call i64 @llvm.spv.global.size.i64(i32 1)
|
|
// CHECK64: call i64 @llvm.spv.global.size.i64(i32 2)
|
|
// CHECK64: call i64 @llvm.spv.global.offset.i64(i32 0)
|
|
// CHECK64: call i64 @llvm.spv.global.offset.i64(i32 1)
|
|
// CHECK64: call i64 @llvm.spv.global.offset.i64(i32 2)
|
|
// CHECK32: call i32 @llvm.spv.num.workgroups.i32(i32 0)
|
|
// CHECK32: call i32 @llvm.spv.num.workgroups.i32(i32 1)
|
|
// CHECK32: call i32 @llvm.spv.num.workgroups.i32(i32 2)
|
|
// CHECK32: call i32 @llvm.spv.workgroup.size.i32(i32 0)
|
|
// CHECK32: call i32 @llvm.spv.workgroup.size.i32(i32 1)
|
|
// CHECK32: call i32 @llvm.spv.workgroup.size.i32(i32 2)
|
|
// CHECK32: call i32 @llvm.spv.group.id.i32(i32 0)
|
|
// CHECK32: call i32 @llvm.spv.group.id.i32(i32 1)
|
|
// CHECK32: call i32 @llvm.spv.group.id.i32(i32 2)
|
|
// CHECK32: call i32 @llvm.spv.thread.id.in.group.i32(i32 0)
|
|
// CHECK32: call i32 @llvm.spv.thread.id.in.group.i32(i32 1)
|
|
// CHECK32: call i32 @llvm.spv.thread.id.in.group.i32(i32 2)
|
|
// CHECK32: call i32 @llvm.spv.thread.id.i32(i32 0)
|
|
// CHECK32: call i32 @llvm.spv.thread.id.i32(i32 1)
|
|
// CHECK32: call i32 @llvm.spv.thread.id.i32(i32 2)
|
|
// CHECK32: call i32 @llvm.spv.global.size.i32(i32 0)
|
|
// CHECK32: call i32 @llvm.spv.global.size.i32(i32 1)
|
|
// CHECK32: call i32 @llvm.spv.global.size.i32(i32 2)
|
|
// CHECK32: call i32 @llvm.spv.global.offset.i32(i32 0)
|
|
// CHECK32: call i32 @llvm.spv.global.offset.i32(i32 1)
|
|
// CHECK32: call i32 @llvm.spv.global.offset.i32(i32 2)
|
|
// CHECK: call i32 @llvm.spv.subgroup.size()
|
|
// CHECK: call i32 @llvm.spv.subgroup.max.size()
|
|
// CHECK: call i32 @llvm.spv.num.subgroups()
|
|
// CHECK: call i32 @llvm.spv.subgroup.id()
|
|
// CHECK: call i32 @llvm.spv.subgroup.local.invocation.id()
|
|
|
|
// NV: call noundef i64 @_Z28__spirv_BuiltInNumWorkgroupsi(i32 noundef 0) #2
|
|
// NV: call noundef i64 @_Z28__spirv_BuiltInNumWorkgroupsi(i32 noundef 1) #2
|
|
// NV: call noundef i64 @_Z28__spirv_BuiltInNumWorkgroupsi(i32 noundef 2) #2
|
|
// NV: call noundef i64 @_Z28__spirv_BuiltInWorkgroupSizei(i32 noundef 0) #2
|
|
// NV: call noundef i64 @_Z28__spirv_BuiltInWorkgroupSizei(i32 noundef 1) #2
|
|
// NV: call noundef i64 @_Z28__spirv_BuiltInWorkgroupSizei(i32 noundef 2) #2
|
|
// NV: call noundef i64 @_Z26__spirv_BuiltInWorkgroupIdi(i32 noundef 0) #2
|
|
// NV: call noundef i64 @_Z26__spirv_BuiltInWorkgroupIdi(i32 noundef 1) #2
|
|
// NV: call noundef i64 @_Z26__spirv_BuiltInWorkgroupIdi(i32 noundef 2) #2
|
|
// NV: call noundef i64 @_Z32__spirv_BuiltInLocalInvocationIdi(i32 noundef 0) #2
|
|
// NV: call noundef i64 @_Z32__spirv_BuiltInLocalInvocationIdi(i32 noundef 1) #2
|
|
// NV: call noundef i64 @_Z32__spirv_BuiltInLocalInvocationIdi(i32 noundef 2) #2
|
|
// NV: call noundef i64 @_Z33__spirv_BuiltInGlobalInvocationIdi(i32 noundef 0) #2
|
|
// NV: call noundef i64 @_Z33__spirv_BuiltInGlobalInvocationIdi(i32 noundef 1) #2
|
|
// NV: call noundef i64 @_Z33__spirv_BuiltInGlobalInvocationIdi(i32 noundef 2) #2
|
|
// NV: call noundef i64 @_Z25__spirv_BuiltInGlobalSizei(i32 noundef 0) #2
|
|
// NV: call noundef i64 @_Z25__spirv_BuiltInGlobalSizei(i32 noundef 1) #2
|
|
// NV: call noundef i64 @_Z25__spirv_BuiltInGlobalSizei(i32 noundef 2) #2
|
|
// NV: call noundef i64 @_Z27__spirv_BuiltInGlobalOffseti(i32 noundef 0) #2
|
|
// NV: call noundef i64 @_Z27__spirv_BuiltInGlobalOffseti(i32 noundef 1) #2
|
|
// NV: call noundef i64 @_Z27__spirv_BuiltInGlobalOffseti(i32 noundef 2) #2
|
|
// NV: call noundef i32 @_Z27__spirv_BuiltInSubgroupSizev() #2
|
|
// NV: call noundef i32 @_Z30__spirv_BuiltInSubgroupMaxSizev() #2
|
|
// NV: call noundef i32 @_Z27__spirv_BuiltInNumSubgroupsv() #2
|
|
// NV: call noundef i32 @_Z25__spirv_BuiltInSubgroupIdv() #2
|
|
// NV: call noundef i32 @_Z40__spirv_BuiltInSubgroupLocalInvocationIdv() #2
|
|
|
|
[[clang::sycl_external]] void test_id_and_range() {
|
|
__spirv_BuiltInNumWorkgroups(0);
|
|
__spirv_BuiltInNumWorkgroups(1);
|
|
__spirv_BuiltInNumWorkgroups(2);
|
|
__spirv_BuiltInWorkgroupSize(0);
|
|
__spirv_BuiltInWorkgroupSize(1);
|
|
__spirv_BuiltInWorkgroupSize(2);
|
|
__spirv_BuiltInWorkgroupId(0);
|
|
__spirv_BuiltInWorkgroupId(1);
|
|
__spirv_BuiltInWorkgroupId(2);
|
|
__spirv_BuiltInLocalInvocationId(0);
|
|
__spirv_BuiltInLocalInvocationId(1);
|
|
__spirv_BuiltInLocalInvocationId(2);
|
|
__spirv_BuiltInGlobalInvocationId(0);
|
|
__spirv_BuiltInGlobalInvocationId(1);
|
|
__spirv_BuiltInGlobalInvocationId(2);
|
|
__spirv_BuiltInGlobalSize(0);
|
|
__spirv_BuiltInGlobalSize(1);
|
|
__spirv_BuiltInGlobalSize(2);
|
|
__spirv_BuiltInGlobalOffset(0);
|
|
__spirv_BuiltInGlobalOffset(1);
|
|
__spirv_BuiltInGlobalOffset(2);
|
|
unsigned int ssize = __spirv_BuiltInSubgroupSize();
|
|
unsigned int smax = __spirv_BuiltInSubgroupMaxSize();
|
|
unsigned int snum = __spirv_BuiltInNumSubgroups();
|
|
unsigned int sid = __spirv_BuiltInSubgroupId();
|
|
unsigned int sinvocid = __spirv_BuiltInSubgroupLocalInvocationId();
|
|
}
|