diff options
author | Tom Stellard <thomas.stellard@amd.com> | 2013-07-08 17:26:39 +0000 |
---|---|---|
committer | Tom Stellard <thomas.stellard@amd.com> | 2013-07-08 17:26:39 +0000 |
commit | 3a81b5d083b0d025de71013fbf68003ebd28cf30 (patch) | |
tree | 463da2b6214fc02b4db1d5d3fae5b12b8f05dde1 /libclc | |
parent | a4cadba551a9ccc36c82a3f3884fc4d60514fac5 (diff) | |
download | bcm5719-llvm-3a81b5d083b0d025de71013fbf68003ebd28cf30.tar.gz bcm5719-llvm-3a81b5d083b0d025de71013fbf68003ebd28cf30.zip |
Implement barrier() builtin
Reviewed and Tested-by: Aaron Watry <awatry@gmail.com>
llvm-svn: 185837
Diffstat (limited to 'libclc')
-rw-r--r-- | libclc/r600/lib/SOURCES | 2 | ||||
-rw-r--r-- | libclc/r600/lib/synchronization/barrier.cl | 15 | ||||
-rw-r--r-- | libclc/r600/lib/synchronization/barrier_impl.ll | 12 |
3 files changed, 29 insertions, 0 deletions
diff --git a/libclc/r600/lib/SOURCES b/libclc/r600/lib/SOURCES index af8c8c80822..16ef3ac3a9b 100644 --- a/libclc/r600/lib/SOURCES +++ b/libclc/r600/lib/SOURCES @@ -2,3 +2,5 @@ workitem/get_group_id.ll workitem/get_local_size.ll workitem/get_local_id.ll workitem/get_global_size.ll +synchronization/barrier.cl +synchronization/barrier_impl.ll diff --git a/libclc/r600/lib/synchronization/barrier.cl b/libclc/r600/lib/synchronization/barrier.cl new file mode 100644 index 00000000000..ac0b4b3b2be --- /dev/null +++ b/libclc/r600/lib/synchronization/barrier.cl @@ -0,0 +1,15 @@ + +#include <clc/clc.h> + +void barrier_local(void); +void barrier_global(void); + +void barrier(cl_mem_fence_flags flags) { + if (flags & CLK_LOCAL_MEM_FENCE) { + barrier_local(); + } + + if (flags & CLK_GLOBAL_MEM_FENCE) { + barrier_global(); + } +} diff --git a/libclc/r600/lib/synchronization/barrier_impl.ll b/libclc/r600/lib/synchronization/barrier_impl.ll new file mode 100644 index 00000000000..99ac01856e2 --- /dev/null +++ b/libclc/r600/lib/synchronization/barrier_impl.ll @@ -0,0 +1,12 @@ +declare void @llvm.AMDGPU.barrier.local() nounwind +declare void @llvm.AMDGPU.barrier.global() nounwind + +define void @barrier_local() nounwind alwaysinline { + call void @llvm.AMDGPU.barrier.local() + ret void +} + +define void @barrier_global() nounwind alwaysinline { + call void @llvm.AMDGPU.barrier.global() + ret void +} |