summaryrefslogtreecommitdiff
path: root/backend/src/libocl/src/ocl_barrier.ll
blob: 502ee6786cc755fede1a30c7c8ce6d5c2c659818 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
;XXX FIXME as llvm can't use macros, we hardcoded 3, 1, 2
;here, we may need to use a more grace way to handle this type
;of values latter.
;#define CLK_LOCAL_MEM_FENCE  (1 << 0)
;#define CLK_GLOBAL_MEM_FENCE (1 << 1)

target datalayout = "e-p:32:32-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024"
target triple = "spir"

declare i32 @_get_local_mem_fence() nounwind alwaysinline
declare i32 @_get_global_mem_fence() nounwind alwaysinline
declare void @__gen_ocl_barrier_local() nounwind alwaysinline noduplicate
declare void @__gen_ocl_barrier_global() nounwind alwaysinline noduplicate
declare void @__gen_ocl_debugwait() nounwind alwaysinline noduplicate
declare void @__gen_ocl_barrier(i32) nounwind alwaysinline noduplicate

define void @_Z7barrierj(i32 %flags) nounwind noduplicate alwaysinline {
  call void @__gen_ocl_barrier(i32 %flags)
  ret void
}

define void @_Z9debugwaitv() nounwind noduplicate alwaysinline {
  call void @__gen_ocl_debugwait()
  ret void
}