forked from KhronosGroup/SPIRV-LLVM-Translator
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbarrier_explicit_arguments.spt
81 lines (76 loc) · 2.53 KB
/
barrier_explicit_arguments.spt
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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
119734787 65536 393230 10 0
2 Capability Addresses
2 Capability Linkage
2 Capability Kernel
5 ExtInstImport 1 "OpenCL.std"
3 MemoryModel 1 2
4 Name 5 "test"
3 Name 6 "val"
4 Name 7 "entry"
6 Decorate 5 LinkageAttributes "test" Export
4 TypeInt 3 32 0
4 Constant 3 8 2
2 TypeVoid 2
4 Constant 3 9 3
4 TypeFunction 4 2 3
5 Function 2 5 0 4
3 FunctionParameter 3 6
2 Label 7
4 ControlBarrier 8 8 6
4 ControlBarrier 9 9 6
1 Return
1 FunctionEnd
; RUN: llvm-spirv %s -to-binary -o %t.spv
; RUN: spirv-val %t.spv
; RUN: llvm-spirv -r --spirv-target-env=CL2.0 %t.spv -o %t.bc
; RUN: llvm-dis < %t.bc | FileCheck %s --check-prefixes=CHECK,CHECK-20
; RUN: llvm-spirv -r --spirv-target-env=CL1.2 %t.spv -o %t.bc
; RUN: llvm-dis < %t.bc | FileCheck %s --check-prefixes=CHECK,CHECK-12
; CHECK: define spir_func void @test(i32 %val)
; CHECK: %call = call spir_func i32 @__translate_spirv_memory_fence(i32 %val)
; CHECK-12: call spir_func void @_Z7barrierj(i32 %call)
; There is no support for sub-groups in OpenCL 1.2, so sub-group barrier is
; equal to regular barrier in there
; CHECK-12: call spir_func void @_Z7barrierj(i32 %call1)
; CHECK-20: call spir_func void @_Z18work_group_barrierj12memory_scope(i32 %call
; CHECK-20: call spir_func void @_Z17sub_group_barrierj12memory_scope(i32 %call
; CHECK: define private spir_func i32 @__translate_spirv_memory_fence(i32 %key) {
; CHECK: entry:
; CHECK: %result = alloca i32, align 4
; CHECK: %key.masked = and i32 2816, %key
; CHECK: switch i32 %key.masked, label %default [
; CHECK: i32 256, label %case.256
; CHECK: i32 512, label %case.512
; CHECK: i32 768, label %case.768
; CHECK: i32 2048, label %case.2048
; CHECK: i32 2304, label %case.2304
; CHECK: i32 2560, label %case.2560
; CHECK: i32 2816, label %case.2816
; CHECK: ]
; CHECK: default:
; CHECK: unreachable
; CHECK: case.256:
; CHECK: store i32 1, ptr %result, align 4
; CHECK: br label %exit
; CHECK: case.512:
; CHECK: store i32 2, ptr %result, align 4
; CHECK: br label %exit
; CHECK: case.768:
; CHECK: store i32 3, ptr %result, align 4
; CHECK: br label %exit
; CHECK: case.2048:
; CHECK: store i32 4, ptr %result, align 4
; CHECK: br label %exit
; CHECK: case.2304:
; CHECK: store i32 5, ptr %result, align 4
; CHECK: br label %exit
; CHECK: case.2560:
; CHECK: store i32 6, ptr %result, align 4
; CHECK: br label %exit
; CHECK: case.2816:
; CHECK: store i32 7, ptr %result, align 4
; CHECK: br label %exit
; CHECK: exit:
; CHECK: %retVal = load i32, ptr %result, align 4
; CHECK: ret i32 %retVal
; CHECK: }