Co-authored-by: qinfan <qinfan.wang@terapines.com>
This commit is contained in:
parent
2ae501e91b
commit
e4c88939fe
|
@ -20,7 +20,7 @@
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
// Barrier function builtins
|
// Barrier function builtins
|
||||||
TARGET_BUILTIN(barrier, "vi", "n", "32bit")
|
TARGET_BUILTIN(barrier, "vi.", "n", "32bit")
|
||||||
TARGET_BUILTIN(work_group_barrier, "vi.", "n", "32bit")
|
TARGET_BUILTIN(work_group_barrier, "vi.", "n", "32bit")
|
||||||
// WORKAROUND: Disabled for now.
|
// WORKAROUND: Disabled for now.
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -19491,8 +19491,6 @@ Value *CodeGenFunction::EmitRISCVBuiltinExpr(unsigned BuiltinID,
|
||||||
|
|
||||||
// Ventus GPGPU workitem
|
// Ventus GPGPU workitem
|
||||||
case RISCV::BIbarrier:
|
case RISCV::BIbarrier:
|
||||||
ID = Intrinsic::riscv_ventus_barrier;
|
|
||||||
break;
|
|
||||||
case RISCV::BIwork_group_barrier: {
|
case RISCV::BIwork_group_barrier: {
|
||||||
unsigned NumArgs = E->getNumArgs();
|
unsigned NumArgs = E->getNumArgs();
|
||||||
switch (NumArgs) {
|
switch (NumArgs) {
|
||||||
|
|
|
@ -12397,6 +12397,7 @@ void __ovld vstorea_half16_rtn(double16, size_t, __private half *);
|
||||||
*/
|
*/
|
||||||
|
|
||||||
void __ovld __conv barrier(cl_mem_fence_flags);
|
void __ovld __conv barrier(cl_mem_fence_flags);
|
||||||
|
void __ovld __conv barrier(cl_mem_fence_flags, memory_scope);
|
||||||
|
|
||||||
#if defined(__OPENCL_CPP_VERSION__) || (__OPENCL_C_VERSION__ >= CL_VERSION_2_0)
|
#if defined(__OPENCL_CPP_VERSION__) || (__OPENCL_C_VERSION__ >= CL_VERSION_2_0)
|
||||||
void __ovld __conv work_group_barrier(cl_mem_fence_flags, memory_scope);
|
void __ovld __conv work_group_barrier(cl_mem_fence_flags, memory_scope);
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
// RUN: clang -no-opaque-pointers -triple riscv32-unknown-unknown -S -emit-llvm -o - %s | FileCheck %s
|
||||||
|
|
||||||
|
void test() {
|
||||||
|
// CHECK: call void @llvm.riscv.ventus.barrier(i32 1)
|
||||||
|
// CHECK-NEXT: call void @llvm.riscv.ventus.barrier.with.scope(i32 1, i32 2)
|
||||||
|
// CHECK-NEXT: call void @llvm.riscv.ventus.barrier(i32 1)
|
||||||
|
// CHECK-NEXT: call void @llvm.riscv.ventus.barrier.with.scope(i32 1, i32 2)
|
||||||
|
barrier(1);
|
||||||
|
barrier(1, 2);
|
||||||
|
work_group_barrier(1);
|
||||||
|
work_group_barrier(1, 2);
|
||||||
|
}
|
Loading…
Reference in New Issue