11; 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
67; 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
811; 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+
918
1019target 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"
1120target triple = "spir64"
@@ -16,6 +25,12 @@ target triple = "spir64"
1625; CHECK-SPIRV: TypePointer [[Ptr_Ty:[0-9]+]] 8
1726; CHECK-SPIRV: TypeFunction [[Func_Ty2:[0-9]+]] [[Void_Ty]] [[Ptr_Ty]] [[Ptr_Ty]]
1827
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+
1934@.str.1 = private unnamed_addr addrspace (1 ) constant [1 x i8 ] zeroinitializer , align 1
2035
2136define linkonce_odr hidden spir_func void @foo () {
@@ -27,13 +42,28 @@ entry:
2742; CHECK-SPIRV: ConvertUToPtr {{[0-9]+}} [[UToPtr:[0-9]+]]
2843; CHECK-SPIRV: Select {{[0-9]+}} [[Sel:[0-9]+]] [[IEq]] [[UToPtr]] [[Cast]]
2944; 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+
3052; CHECK-LLVM: %[[Cast:[0-9]+]] = addrspacecast ptr addrspace(1) @.str.1 to ptr addrspace(4)
3153; CHECK-LLVM: %[[PtrToU1:[0-9]+]] = ptrtoint ptr addrspace(4) %[[Cast]] to i64
3254; CHECK-LLVM: %[[PtrToU2:[0-9]+]] = ptrtoint ptr addrspace(4) null to i64
3355; CHECK-LLVM: %[[IEq:[0-9]+]] = icmp eq i64 %[[PtrToU1]], %[[PtrToU2]]
3456; CHECK-LLVM: %[[UToPtr:[0-9]+]] = inttoptr i64 -1 to ptr addrspace(4)
3557; CHECK-LLVM: %[[Sel:[0-9]+]] = select i1 %[[IEq]], ptr addrspace(4) %[[UToPtr]], ptr addrspace(4) %[[Cast]]
3658; 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+
3767 %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 ))
3868 call spir_func void @bar (ptr addrspace (4 ) addrspacecast (ptr addrspace (1 ) @.str.1 to ptr addrspace (4 )), ptr addrspace (4 ) %0 )
3969 ret void
0 commit comments