forked from KhronosGroup/SPIRV-LLVM-Translator
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathatomic_explicit_arguments.spt
108 lines (100 loc) · 3.07 KB
/
atomic_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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
119734787 65536 393230 11 0
2 Capability Addresses
2 Capability Linkage
2 Capability Kernel
2 Capability GenericPointer
5 ExtInstImport 1 "OpenCL.std"
3 MemoryModel 1 2
3 Source 3 200000
4 Name 5 "load"
3 Name 6 "obj"
4 Name 7 "order"
4 Name 8 "scope"
4 Name 9 "entry"
4 Name 10 "call"
6 Decorate 5 LinkageAttributes "load" Export
4 TypeInt 2 32 0
4 TypePointer 3 8 2
6 TypeFunction 4 2 3 2 2
5 Function 2 5 0 4
3 FunctionParameter 3 6
3 FunctionParameter 2 7
3 FunctionParameter 2 8
2 Label 9
6 AtomicLoad 2 10 6 8 7
2 ReturnValue 10
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: define spir_func i32 @load(ptr addrspace(4) %obj, i32 %order, i32 %scope) #0 {
; CHECK: entry:
; CHECK: %call1 = call spir_func i32 @__translate_spirv_memory_scope(i32 %scope)
; CHECK: %call2 = call spir_func i32 @__translate_spirv_memory_order(i32 %order)
; CHECK: %call = call spir_func i32 @_Z20atomic_load_explicitPU3AS4VU7_Atomici12memory_order12memory_scope(ptr addrspace(4) %obj, i32 %call2, i32 %call1)
; CHECK: ret i32 %call
; CHECK: }
; CHECK: define private spir_func i32 @__translate_spirv_memory_scope(i32 %key) {
; CHECK: entry:
; CHECK: %result = alloca i32, align 4
; CHECK: switch i32 %key, label %default [
; CHECK: i32 4, label %case.4
; CHECK: i32 2, label %case.2
; CHECK: i32 1, label %case.1
; CHECK: i32 0, label %case.0
; CHECK: i32 3, label %case.3
; CHECK: ]
; CHECK: default:
; CHECK: unreachable
; CHECK: case.4:
; CHECK: store i32 0, ptr %result, align 4
; CHECK: br label %exit
; CHECK: case.2:
; CHECK: store i32 1, ptr %result, align 4
; CHECK: br label %exit
; CHECK: case.1:
; CHECK: store i32 2, ptr %result, align 4
; CHECK: br label %exit
; CHECK: case.0:
; CHECK: store i32 3, ptr %result, align 4
; CHECK: br label %exit
; CHECK: case.3:
; CHECK: store i32 4, ptr %result, align 4
; CHECK: br label %exit
; CHECK: exit:
; CHECK: %retVal = load i32, ptr %result, align 4
; CHECK: ret i32 %retVal
; CHECK: }
; CHECK: define private spir_func i32 @__translate_spirv_memory_order(i32 %key) {
; CHECK: entry:
; CHECK: %result = alloca i32, align 4
; CHECK: %key.masked = and i32 30, %key
; CHECK: switch i32 %key.masked, label %default [
; CHECK: i32 0, label %case.0
; CHECK: i32 2, label %case.2
; CHECK: i32 4, label %case.4
; CHECK: i32 8, label %case.8
; CHECK: i32 16, label %case.16
; CHECK: ]
; CHECK: default:
; CHECK: unreachable
; CHECK: case.0:
; CHECK: store i32 0, ptr %result, align 4
; CHECK: br label %exit
; CHECK: case.2:
; CHECK: store i32 2, ptr %result, align 4
; CHECK: br label %exit
; CHECK: case.4:
; CHECK: store i32 3, ptr %result, align 4
; CHECK: br label %exit
; CHECK: case.8:
; CHECK: store i32 4, ptr %result, align 4
; CHECK: br label %exit
; CHECK: case.16:
; CHECK: store i32 5, ptr %result, align 4
; CHECK: br label %exit
; CHECK: exit:
; CHECK: %retVal = load i32, ptr %result, align 4
; CHECK: ret i32 %retVal
; CHECK: }