xref: /llvm-project/llvm/test/CodeGen/SPIRV/transcoding/BuildNDRange.ll (revision 0a443f13b49b3f392461a0bb60b0146cfc4607c7)
1; RUN: llc -O0 -mtriple=spirv32-unknown-unknown %s -o - | FileCheck %s --check-prefix=CHECK-SPIRV
2; RUN: %if spirv-tools %{ llc -O0 -mtriple=spirv32-unknown-unknown %s -o - -filetype=obj | spirv-val %}
3
4; CHECK-SPIRV-DAG: %[[#]] = OpBuildNDRange %[[#]] %[[#GWS:]] %[[#LWS:]] %[[#GWO:]]
5; CHECK-SPIRV-DAG: %[[#GWS]] = OpConstant %[[#]] 123
6; CHECK-SPIRV-DAG: %[[#LWS]] = OpConstant %[[#]] 456
7; CHECK-SPIRV-DAG: %[[#GWO]] = OpConstant %[[#]] 0
8
9%struct.ndrange_t = type { i32, [3 x i32], [3 x i32], [3 x i32] }
10
11define spir_kernel void @test() {
12  %ndrange = alloca %struct.ndrange_t, align 4
13  call spir_func void @_Z10ndrange_1Djj(%struct.ndrange_t* sret(%struct.ndrange_t*) %ndrange, i32 123, i32 456)
14  ret void
15}
16
17declare spir_func void @_Z10ndrange_1Djj(%struct.ndrange_t* sret(%struct.ndrange_t*), i32, i32)
18