|
| 1 | +; RUN: llc -O0 -mtriple=spirv-unknown-vulkan-compute %s -o - | FileCheck %s |
| 2 | +; RUN: %if spirv-tools %{ llc -O0 -mtriple=spirv-unknown-vulkan-compute %s -o - -filetype=obj | spirv-val %} |
| 3 | + |
| 4 | +; CHECK-DAG: OpDecorate %[[ARRAY:[0-9]+]] ArrayStride 16 |
| 5 | +; CHECK-DAG: OpMemberDecorate %[[CBLAYOUT:[0-9]+]] 0 Offset 0 |
| 6 | +; CHECK-DAG: OpMemberDecorate %[[CBLAYOUT]] 1 Offset 52 |
| 7 | +; CHECK-DAG: OpMemberDecorate %[[WRAPPER:[0-9]+]] 0 Offset 0 |
| 8 | +; CHECK-DAG: OpDecorate %[[WRAPPER]] Block |
| 9 | +; CHECK-DAG: OpMemberDecorate %[[STRUCT:[0-9]+]] 0 Offset 0 |
| 10 | +; CHECK-DAG: OpMemberDecorate %[[STRUCT_PAD:[0-9]+]] 0 Offset 0 |
| 11 | +; CHECK-DAG: OpMemberDecorate %[[STRUCT_PAD]] 1 Offset 4 |
| 12 | + |
| 13 | +; CHECK-DAG: %[[FLOAT:[0-9]+]] = OpTypeFloat 32 |
| 14 | +; CHECK-DAG: %[[STRUCT]] = OpTypeStruct %[[FLOAT]] |
| 15 | +; CHECK-DAG: %[[I8:[0-9]+]] = OpTypeInt 8 0 |
| 16 | +; CHECK-DAG: %[[STRUCT_PAD]] = OpTypeStruct %[[STRUCT]] %[[I8]] |
| 17 | +; CHECK-DAG: %[[UINT:[0-9]+]] = OpTypeInt 32 0 |
| 18 | +; CHECK-DAG: %[[CONST_4:[0-9]+]] = OpConstant %[[UINT]] 4 |
| 19 | +; CHECK-DAG: %[[ARRAY]] = OpTypeArray %[[STRUCT_PAD]] %[[CONST_4]] |
| 20 | +; CHECK-DAG: %[[CBLAYOUT]] = OpTypeStruct %[[ARRAY]] %[[FLOAT]] |
| 21 | +; CHECK-DAG: %[[WRAPPER]] = OpTypeStruct %[[CBLAYOUT]] |
| 22 | +; CHECK-DAG: %[[PTR_WRAPPER:[0-9]+]] = OpTypePointer Uniform %[[WRAPPER]] |
| 23 | +; CHECK-DAG: %[[ZERO:[0-9]+]] = OpConstant %[[UINT]] 0 |
| 24 | +; CHECK-DAG: %[[MYCBUFFER:[0-9]+]] = OpVariable %[[PTR_WRAPPER]] Uniform |
| 25 | + |
| 26 | +; CHECK-DAG: %[[I64:[0-9]+]] = OpTypeInt 64 0 |
| 27 | +; CHECK-DAG: %[[STRUCT2:[0-9]+]] = OpTypeStruct %[[I64]] %[[UINT]] |
| 28 | +; CHECK-DAG: %[[CONST_3:[0-9]+]] = OpConstant %[[UINT]] 3 |
| 29 | +; CHECK-DAG: %[[ARRAY2:[0-9]+]] = OpTypeArray %[[STRUCT2]] %[[CONST_3]] |
| 30 | +; CHECK-DAG: %[[CBLAYOUT2:[0-9]+]] = OpTypeStruct %[[ARRAY2]] %[[I64]] |
| 31 | +; CHECK-DAG: %[[PTR_PRIVATE:[0-9]+]] = OpTypePointer Private %[[CBLAYOUT2]] |
| 32 | +; CHECK-DAG: %[[MYPRIVATEVAR:[0-9]+]] = OpVariable %[[PTR_PRIVATE]] Private |
| 33 | + |
| 34 | +%__cblayout_MyCBuffer = type <{ <{ [3 x <{ %OrigType, target("spirv.Padding", 12) }>], %OrigType }>, float }> |
| 35 | +%OrigType = type <{ float }> |
| 36 | + |
| 37 | +%__cblayout_MyCBuffer2 = type <{ [ 3 x <{ i64, i32 }> ], i64 }> |
| 38 | + |
| 39 | +@MyCBuffer.cb = local_unnamed_addr global target("spirv.VulkanBuffer", %__cblayout_MyCBuffer, 2, 0) poison |
| 40 | +@myPrivateVar = internal addrspace(10) global %__cblayout_MyCBuffer2 poison |
| 41 | + |
| 42 | +@myArray = external hidden local_unnamed_addr addrspace(12) global <{ [3 x <{ %OrigType, target("spirv.Padding", 12) }>], %OrigType }>, align 1 |
| 43 | +@MyCBuffer.str = private unnamed_addr constant [10 x i8] c"MyCBuffer\00", align 1 |
| 44 | +@.str = private unnamed_addr constant [7 x i8] c"output\00", align 1 |
| 45 | + |
| 46 | +declare target("spirv.VulkanBuffer", %__cblayout_MyCBuffer, 2, 0) @llvm.spv.resource.handlefromimplicitbinding.tspirv.VulkanBuffer_s___cblayout_MyCBuffers_2_0t(i32, i32, i32, i32, ptr) |
| 47 | + |
| 48 | +define void @main() #1 { |
| 49 | +entry: |
| 50 | +; CHECK: %[[BUFFER_HANDLE:[0-9]+]] = OpCopyObject %[[PTR_WRAPPER]] %[[MYCBUFFER]] |
| 51 | +; CHECK: %[[ACCESS_ARRAY:[0-9]+]] = OpAccessChain {{%[0-9]+}} %[[BUFFER_HANDLE]] %[[ZERO]] %[[ZERO]] |
| 52 | + %MyCBuffer.cb_h.i.i = tail call target("spirv.VulkanBuffer", %__cblayout_MyCBuffer, 2, 0) @llvm.spv.resource.handlefromimplicitbinding.tspirv.VulkanBuffer_s___cblayout_MyCBuffers_2_0t(i32 0, i32 0, i32 1, i32 0, ptr nonnull @MyCBuffer.str) |
| 53 | + store target("spirv.VulkanBuffer", %__cblayout_MyCBuffer, 2, 0) %MyCBuffer.cb_h.i.i, ptr @MyCBuffer.cb, align 8 |
| 54 | + |
| 55 | + %0 = tail call target("spirv.Image", float, 5, 2, 0, 0, 2, 1) @llvm.spv.resource.handlefromimplicitbinding.tspirv.Image_f32_5_2_0_0_2_1t(i32 1, i32 0, i32 1, i32 0, ptr nonnull @.str) |
| 56 | + %1 = tail call i32 @llvm.spv.thread.id.i32(i32 0) |
| 57 | + %rem.i = and i32 %1, 3 |
| 58 | + |
| 59 | +; CHECK: %[[IDX_CONV:[0-9]+]] = OpUConvert {{.*}} |
| 60 | + %idxprom.i = zext nneg i32 %rem.i to i64 |
| 61 | + |
| 62 | +; CHECK: %[[PTR_ELEM:[0-9]+]] = OpAccessChain {{%[0-9]+}} %[[ACCESS_ARRAY]] %[[IDX_CONV]] |
| 63 | + %cbufferidx.i = getelementptr <{ %OrigType, target("spirv.Padding", 12) }>, ptr addrspace(12) @myArray, i64 %idxprom.i |
| 64 | + |
| 65 | +; CHECK: %[[PTR_FIELD:[0-9]+]] = OpAccessChain {{%[0-9]+}} %[[PTR_ELEM]] %[[ZERO]] %[[ZERO]] |
| 66 | +; CHECK: %[[VAL_FLOAT:[0-9]+]] = OpLoad %[[FLOAT]] %[[PTR_FIELD]] Aligned 4 |
| 67 | + %2 = load float, ptr addrspace(12) %cbufferidx.i, align 4 |
| 68 | + |
| 69 | + %val = load i64, ptr addrspace(10) getelementptr (%__cblayout_MyCBuffer2, ptr addrspace(10) @myPrivateVar, i32 0, i32 1), align 8 |
| 70 | + %val.float = sitofp i64 %val to float |
| 71 | + |
| 72 | + %vecinit4.i = insertelement <4 x float> <float poison, float 0.000000e+00, float 0.000000e+00, float 0.000000e+00>, float %2, i64 0 |
| 73 | + %vecinit4.i.2 = insertelement <4 x float> %vecinit4.i, float %val.float, i64 1 |
| 74 | + %3 = tail call noundef align 16 dereferenceable(16) ptr addrspace(11) @llvm.spv.resource.getpointer.p11.tspirv.Image_f32_5_2_0_0_2_1t(target("spirv.Image", float, 5, 2, 0, 0, 2, 1) %0, i32 0) |
| 75 | + store <4 x float> %vecinit4.i.2, ptr addrspace(11) %3, align 16 |
| 76 | +; CHECK: OpImageWrite {{%[0-9]+}} {{%[0-9]+}} {{%[0-9]+}} |
| 77 | + ret void |
| 78 | +} |
| 79 | + |
| 80 | +declare i32 @llvm.spv.thread.id.i32(i32) |
| 81 | + |
| 82 | +declare target("spirv.Image", float, 5, 2, 0, 0, 2, 1) @llvm.spv.resource.handlefromimplicitbinding.tspirv.Image_f32_5_2_0_0_2_1t(i32, i32, i32, i32, ptr) |
| 83 | + |
| 84 | +declare ptr addrspace(11) @llvm.spv.resource.getpointer.p11.tspirv.Image_f32_5_2_0_0_2_1t(target("spirv.Image", float, 5, 2, 0, 0, 2, 1), i32) |
| 85 | + |
| 86 | +attributes #1 = { "hlsl.numthreads"="1,1,1" "hlsl.shader"="compute" } |
| 87 | + |
| 88 | +!hlsl.cbs = !{!0} |
| 89 | + |
| 90 | +!0 = distinct !{ptr @MyCBuffer.cb, ptr addrspace(12) @myArray, null} |
0 commit comments