1
1
; RUN: llvm-as %s -o %t.bc
2
- ; RUN: llvm-spirv %t.bc -o %t.spv
3
- ; RUN: llvm-spirv %t.spv -o %t.spt --to-text
4
- ; RUN: llvm-spirv -r %t.spv -o %t.bc
5
- ; RUN: llvm-dis %t.bc -o %t.ll
2
+ ; RUN: llvm-spirv %t.bc --spirv-max-version=1.3 -o %t.spv
3
+ ; RUN: spirv-val %t.spv
4
+ ; RUN: llvm-spirv %t.spv --spirv-max-version=1.3 -o %t.spt --to-text
5
+ ; RUN: llvm-spirv -r %t.spv -o %t.rev.bc
6
+ ; RUN: llvm-dis %t.rev.bc
6
7
; RUN: FileCheck %s --input-file %t.spt -check-prefix=CHECK-SPIRV
7
- ; RUN: FileCheck %s --input-file %t.ll -check-prefix=CHECK-LLVM
8
+ ; RUN: FileCheck %s --input-file %t.rev.ll -check-prefix=CHECK-LLVM
9
+
10
+ ; RUN: llvm-spirv %t.bc -o %t.spv
8
11
; RUN: spirv-val %t.spv
12
+ ; RUN: llvm-spirv %t.spv -o %t.spt --to-text
13
+ ; RUN: llvm-spirv -r %t.spv -o %t.rev.bc
14
+ ; RUN: llvm-dis %t.rev.bc
15
+ ; RUN: FileCheck %s --input-file %t.spt -check-prefix=CHECK-SPIRV-14
16
+ ; RUN: FileCheck %s --input-file %t.rev.ll -check-prefix=CHECK-LLVM-14
17
+
9
18
10
19
target datalayout = "e-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024-n8:16:32:64"
11
20
target triple = "spir64"
@@ -16,6 +25,12 @@ target triple = "spir64"
16
25
; CHECK-SPIRV: TypePointer [[Ptr_Ty:[0-9]+]] 8
17
26
; CHECK-SPIRV: TypeFunction [[Func_Ty2:[0-9]+]] [[Void_Ty]] [[Ptr_Ty]] [[Ptr_Ty]]
18
27
28
+ ; CHECK-SPIRV-14: TypeInt [[Int_Ty:[0-9]+]] 8 0
29
+ ; CHECK-SPIRV-14: TypeVoid [[Void_Ty:[0-9]+]]
30
+ ; CHECK-SPIRV-14: TypeFunction [[Func_Ty1:[0-9]+]] [[Void_Ty]]
31
+ ; CHECK-SPIRV-14: TypePointer [[Ptr_Ty:[0-9]+]] 8
32
+ ; CHECK-SPIRV-14: TypeFunction [[Func_Ty2:[0-9]+]] [[Void_Ty]] [[Ptr_Ty]] [[Ptr_Ty]]
33
+
19
34
@.str.1 = private unnamed_addr addrspace (1 ) constant [1 x i8 ] zeroinitializer , align 1
20
35
21
36
define linkonce_odr hidden spir_func void @foo () {
@@ -27,13 +42,28 @@ entry:
27
42
; CHECK-SPIRV: ConvertUToPtr {{[0-9]+}} [[UToPtr:[0-9]+]]
28
43
; CHECK-SPIRV: Select {{[0-9]+}} [[Sel:[0-9]+]] [[IEq]] [[UToPtr]] [[Cast]]
29
44
; CHECK-SPIRV: FunctionCall [[Void_Ty]] {{[0-9]+}} [[Func:[0-9]+]] [[Cast]] [[Sel]]
45
+
46
+ ; CHECK-SPIRV-14: PtrCastToGeneric {{[0-9]+}} [[Cast:[0-9]+]]
47
+ ; CHECK-SPIRV-14: PtrEqual {{[0-9]+}} [[PtrEq:[0-9]+]] [[Cast]] [[#]]
48
+ ; CHECK-SPIRV-14: ConvertUToPtr {{[0-9]+}} [[UToPtr:[0-9]+]]
49
+ ; CHECK-SPIRV-14: Select {{[0-9]+}} [[Sel:[0-9]+]] [[PtrEq]] [[UToPtr]] [[Cast]]
50
+ ; CHECK-SPIRV-14: FunctionCall [[Void_Ty]] {{[0-9]+}} [[Func:[0-9]+]] [[Cast]] [[Sel]]
51
+
30
52
; CHECK-LLVM: %[[Cast:[0-9]+]] = addrspacecast ptr addrspace(1) @.str.1 to ptr addrspace(4)
31
53
; CHECK-LLVM: %[[PtrToU1:[0-9]+]] = ptrtoint ptr addrspace(4) %[[Cast]] to i64
32
54
; CHECK-LLVM: %[[PtrToU2:[0-9]+]] = ptrtoint ptr addrspace(4) null to i64
33
55
; CHECK-LLVM: %[[IEq:[0-9]+]] = icmp eq i64 %[[PtrToU1]], %[[PtrToU2]]
34
56
; CHECK-LLVM: %[[UToPtr:[0-9]+]] = inttoptr i64 -1 to ptr addrspace(4)
35
57
; CHECK-LLVM: %[[Sel:[0-9]+]] = select i1 %[[IEq]], ptr addrspace(4) %[[UToPtr]], ptr addrspace(4) %[[Cast]]
36
58
; CHECK-LLVM: call spir_func void @bar(ptr addrspace(4) %[[Cast]], ptr addrspace(4) %[[Sel]]) #0
59
+
60
+ ; CHECK-LLVM-14: %[[Cast:[0-9]+]] = addrspacecast ptr addrspace(1) @.str.1 to ptr addrspace(4)
61
+ ; CHECK-LLVM-14: %[[PtrToU1:[0-9]+]] = ptrtoint ptr addrspace(4) %[[Cast]] to i64
62
+ ; CHECK-LLVM-14: %[[IEq:[0-9]+]] = icmp eq i64 %[[PtrToU1]], 0
63
+ ; CHECK-LLVM-14: %[[UToPtr:[0-9]+]] = inttoptr i64 -1 to ptr addrspace(4)
64
+ ; CHECK-LLVM-14: %[[Sel:[0-9]+]] = select i1 %[[IEq]], ptr addrspace(4) %[[UToPtr]], ptr addrspace(4) %[[Cast]]
65
+ ; CHECK-LLVM-14: call spir_func void @bar(ptr addrspace(4) %[[Cast]], ptr addrspace(4) %[[Sel]]) #0
66
+
37
67
%0 = select i1 icmp eq (ptr addrspace (4 ) addrspacecast (ptr addrspace (1 ) @.str.1 to ptr addrspace (4 )), ptr addrspace (4 ) null ), ptr addrspace (4 ) inttoptr (i64 -1 to ptr addrspace (4 )), ptr addrspace (4 ) addrspacecast (ptr addrspace (1 ) @.str.1 to ptr addrspace (4 ))
38
68
call spir_func void @bar (ptr addrspace (4 ) addrspacecast (ptr addrspace (1 ) @.str.1 to ptr addrspace (4 )), ptr addrspace (4 ) %0 )
39
69
ret void
0 commit comments