|
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