|
| 1 | +// clang-format off |
| 2 | + |
1 | 3 | // RUN: %clang_cc1 -triple spir -cl-std=cl2.0 %s -fdeclare-opencl-builtins -finclude-default-header -emit-llvm-bc -o %t.bc |
2 | 4 | // RUN: llvm-spirv %t.bc -o %t.spv |
3 | 5 | // RUN: llvm-spirv %t.spv -to-text -o - | FileCheck %s --check-prefix=CHECK-SPIRV |
@@ -31,32 +33,50 @@ int load (volatile atomic_int* obj, memory_order order, memory_scope scope) { |
31 | 33 |
|
32 | 34 | // CHECK-SPIRV: Function [[int]] [[TRANS_MEM_SCOPE]] |
33 | 35 | // CHECK-SPIRV: FunctionParameter [[int]] [[KEY:[0-9]+]] |
| 36 | +// CHECK-SPIRV: Variable {{[0-9]+}} [[RES:[0-9]+]] |
34 | 37 | // CHECK-SPIRV: Switch [[KEY]] [[CASE_2:[0-9]+]] 0 [[CASE_0:[0-9]+]] 1 [[CASE_1:[0-9]+]] 2 [[CASE_2]] 3 [[CASE_3:[0-9]+]] 4 [[CASE_4:[0-9]+]] |
35 | 38 | // CHECK-SPIRV: Label [[CASE_0]] |
36 | | -// CHECK-SPIRV: ReturnValue [[FOUR]] |
| 39 | +// CHECK-SPIRV: Store [[RES]] [[FOUR]] |
| 40 | +// CHECK-SPIRV: Branch [[EXIT:[0-9]+]] |
37 | 41 | // CHECK-SPIRV: Label [[CASE_1]] |
38 | | -// CHECK-SPIRV: ReturnValue [[TWO]] |
| 42 | +// CHECK-SPIRV: Store [[RES]] [[TWO]] |
| 43 | +// CHECK-SPIRV: Branch [[EXIT]] |
39 | 44 | // CHECK-SPIRV: Label [[CASE_2]] |
40 | | -// CHECK-SPIRV: ReturnValue [[ONE]] |
| 45 | +// CHECK-SPIRV: Store [[RES]] [[ONE]] |
| 46 | +// CHECK-SPIRV: Branch [[EXIT]] |
41 | 47 | // CHECK-SPIRV: Label [[CASE_3]] |
42 | | -// CHECK-SPIRV: ReturnValue [[ZERO]] |
| 48 | +// CHECK-SPIRV: Store [[RES]] [[ZERO]] |
| 49 | +// CHECK-SPIRV: Branch [[EXIT]] |
43 | 50 | // CHECK-SPIRV: Label [[CASE_4]] |
44 | | -// CHECK-SPIRV: ReturnValue [[THREE]] |
| 51 | +// CHECK-SPIRV: Store [[RES]] [[THREE]] |
| 52 | +// CHECK-SPIRV: Branch [[EXIT]] |
| 53 | +// CHECK-SPIRV: Label [[EXIT]] |
| 54 | +// CHECK-SPIRV: Load [[int]] [[RET_VAR:[0-9]+]] [[RES]] |
| 55 | +// CHECK-SPIRV: ReturnValue [[RET_VAR]] |
45 | 56 | // CHECK-SPIRV: FunctionEnd |
46 | 57 |
|
47 | 58 | // CHECK-SPIRV: Function [[int]] [[TRANS_MEM_ORDER]] |
48 | 59 | // CHECK-SPIRV: FunctionParameter [[int]] [[KEY:[0-9]+]] |
| 60 | +// CHECK-SPIRV: Variable {{[0-9]+}} [[RES:[0-9]+]] |
49 | 61 | // CHECK-SPIRV: Switch [[KEY]] [[CASE_5:[0-9]+]] 0 [[CASE_0:[0-9]+]] 2 [[CASE_2:[0-9]+]] 3 [[CASE_3:[0-9]+]] 4 [[CASE_4:[0-9]+]] 5 [[CASE_5]] |
50 | 62 | // CHECK-SPIRV: Label [[CASE_0]] |
51 | | -// CHECK-SPIRV: ReturnValue [[ZERO]] |
| 63 | +// CHECK-SPIRV: Store [[RES]] [[ZERO]] |
| 64 | +// CHECK-SPIRV: Branch [[EXIT:[0-9]+]] |
52 | 65 | // CHECK-SPIRV: Label [[CASE_2]] |
53 | | -// CHECK-SPIRV: ReturnValue [[TWO]] |
| 66 | +// CHECK-SPIRV: Store [[RES]] [[TWO]] |
| 67 | +// CHECK-SPIRV: Branch [[EXIT]] |
54 | 68 | // CHECK-SPIRV: Label [[CASE_3]] |
55 | | -// CHECK-SPIRV: ReturnValue [[FOUR]] |
| 69 | +// CHECK-SPIRV: Store [[RES]] [[FOUR]] |
| 70 | +// CHECK-SPIRV: Branch [[EXIT]] |
56 | 71 | // CHECK-SPIRV: Label [[CASE_4]] |
57 | | -// CHECK-SPIRV: ReturnValue [[EIGHT]] |
| 72 | +// CHECK-SPIRV: Store [[RES]] [[EIGHT]] |
| 73 | +// CHECK-SPIRV: Branch [[EXIT]] |
58 | 74 | // CHECK-SPIRV: Label [[CASE_5]] |
59 | | -// CHECK-SPIRV: ReturnValue [[SIXTEEN]] |
| 75 | +// CHECK-SPIRV: Store [[RES]] [[SIXTEEN]] |
| 76 | +// CHECK-SPIRV: Branch [[EXIT]] |
| 77 | +// CHECK-SPIRV: Label [[EXIT]] |
| 78 | +// CHECK-SPIRV: Load [[int]] [[RET_VAR:[0-9]+]] [[RES]] |
| 79 | +// CHECK-SPIRV: ReturnValue [[RET_VAR]] |
60 | 80 | // CHECK-SPIRV: FunctionEnd |
61 | 81 |
|
62 | 82 |
|
|
0 commit comments