|
1 | 1 | ; RUN: llvm-as %s -o %t.bc
|
2 | 2 | ; RUN: llvm-spirv %t.bc -o %t.spv
|
3 | 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 |
| 4 | +; RUN: llvm-spirv -r %t.spv -o %t.rev.bc |
| 5 | +; RUN: llvm-dis %t.rev.bc |
6 | 6 | ; 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: spirv-val %t.spv |
| 7 | +; RUN: FileCheck %s --input-file %t.rev.ll -check-prefix=CHECK-LLVM |
9 | 8 |
|
10 | 9 | 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 | 10 | target triple = "spir64"
|
12 | 11 |
|
13 |
| -; CHECK-SPIRV: TypeInt [[Int_Ty:[0-9]+]] 8 0 |
14 |
| -; CHECK-SPIRV: TypeVoid [[Void_Ty:[0-9]+]] |
15 |
| -; CHECK-SPIRV: TypeFunction [[Func_Ty1:[0-9]+]] [[Void_Ty]] |
16 |
| -; CHECK-SPIRV: TypePointer [[Ptr_Ty:[0-9]+]] 8 |
17 |
| -; CHECK-SPIRV: TypeFunction [[Func_Ty2:[0-9]+]] [[Void_Ty]] [[Ptr_Ty]] [[Ptr_Ty]] |
18 |
| - |
19 | 12 | @.str.1 = private unnamed_addr addrspace(1) constant [1 x i8] zeroinitializer, align 1
|
20 | 13 |
|
21 | 14 | define linkonce_odr hidden spir_func void @foo() {
|
22 | 15 | entry:
|
23 |
| -; CHECK-SPIRV: PtrCastToGeneric {{[0-9]+}} [[Cast:[0-9]+]] |
24 |
| -; CHECK-SPIRV: ConvertPtrToU {{[0-9]+}} [[PtrToU1:[0-9]+]] [[Cast]] |
25 |
| -; CHECK-SPIRV: ConvertPtrToU {{[0-9]+}} [[PtrToU2:[0-9]+]] |
26 |
| -; CHECK-SPIRV: IEqual {{[0-9]+}} [[IEq:[0-9]+]] [[PtrToU1]] [[PtrToU2]] |
27 |
| -; CHECK-SPIRV: ConvertUToPtr {{[0-9]+}} [[UToPtr:[0-9]+]] |
28 |
| -; CHECK-SPIRV: Select {{[0-9]+}} [[Sel:[0-9]+]] [[IEq]] [[UToPtr]] [[Cast]] |
29 |
| -; CHECK-SPIRV: FunctionCall [[Void_Ty]] {{[0-9]+}} [[Func:[0-9]+]] [[Cast]] [[Sel]] |
30 |
| -; CHECK-LLVM: %[[Cast:[0-9]+]] = addrspacecast ptr addrspace(1) @.str.1 to ptr addrspace(4) |
31 |
| -; CHECK-LLVM: %[[PtrToU1:[0-9]+]] = ptrtoint ptr addrspace(4) %[[Cast]] to i64 |
32 |
| -; CHECK-LLVM: %[[PtrToU2:[0-9]+]] = ptrtoint ptr addrspace(4) null to i64 |
33 |
| -; CHECK-LLVM: %[[IEq:[0-9]+]] = icmp eq i64 %[[PtrToU1]], %[[PtrToU2]] |
34 |
| -; CHECK-LLVM: %[[UToPtr:[0-9]+]] = inttoptr i64 -1 to ptr addrspace(4) |
35 |
| -; CHECK-LLVM: %[[Sel:[0-9]+]] = select i1 %[[IEq]], ptr addrspace(4) %[[UToPtr]], ptr addrspace(4) %[[Cast]] |
36 |
| -; CHECK-LLVM: call spir_func void @bar(ptr addrspace(4) %[[Cast]], ptr addrspace(4) %[[Sel]]) #0 |
37 |
| - %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)) |
| 16 | +; CHECK-SPIRV: Constant [[#]] [[#MinusOne:]] 4294967295 4294967295 |
| 17 | +; CHECK-SPIRV: ConvertUToPtr [[#]] [[#Ptr:]] [[#MinusOne:]] |
| 18 | +; CHECK-SPIRV: Bitcast [[#]] [[#BitCast:]] [[#Ptr]] |
| 19 | +; CHECK-SPIRV: FunctionCall [[#]] [[#]] [[#]] [[#]] [[#BitCast]] |
| 20 | + |
| 21 | +; CHECK-LLVM: %[[#Ptr:]] = inttoptr i64 -1 to ptr addrspace(4) |
| 22 | +; CHECK-LLVM: %[[#BitCast:]] = bitcast ptr addrspace(4) %[[#Ptr]] to ptr addrspace(4) |
| 23 | +; CHECK-LLVM: call spir_func void @bar({{.*}}, ptr addrspace(4) %[[#BitCast]]) #0 |
| 24 | + |
| 25 | + %0 = bitcast ptr addrspace(4) inttoptr (i64 -1 to ptr addrspace(4)) to ptr addrspace(4) |
38 | 26 | call spir_func void @bar(ptr addrspace(4) addrspacecast (ptr addrspace(1) @.str.1 to ptr addrspace(4)), ptr addrspace(4) %0)
|
39 | 27 | ret void
|
40 | 28 | }
|
41 | 29 |
|
42 |
| -; CHECK-SPIRV: Function [[Void_Ty]] [[Func]] 0 [[Func_Ty2]] |
43 |
| - |
44 | 30 | define linkonce_odr hidden spir_func void @bar(ptr addrspace(4) %__beg, ptr addrspace(4) %__end) {
|
45 | 31 | entry:
|
46 | 32 | ret void
|
|
0 commit comments