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
|
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(i32 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(i32 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: 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: ret i32 0
; CHECK: case.2:
; CHECK: ret i32 1
; CHECK: case.1:
; CHECK: ret i32 2
; CHECK: case.0:
; CHECK: ret i32 3
; CHECK: case.3:
; CHECK: ret i32 4
; CHECK: }
; CHECK: define private spir_func i32 @__translate_spirv_memory_order(i32 %key) {
; CHECK: entry:
; 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: ret i32 0
; CHECK: case.2:
; CHECK: ret i32 2
; CHECK: case.4:
; CHECK: ret i32 3
; CHECK: case.8:
; CHECK: ret i32 4
; CHECK: case.16:
; CHECK: ret i32 5
; CHECK: }
|