blob: 2bee517aee5b6de13c48f273eb40e6ca7f332d32 [file] [log] [blame]
; SPIR-V
; Version: 1.3
; Generator: Google Tint Compiler; 1
; Bound: 58
; Schema: 0
OpCapability Shader
OpCapability VulkanMemoryModel
OpCapability VulkanMemoryModelDeviceScope
OpCapability CooperativeMatrixKHR
OpCapability Int8
OpExtension "SPV_KHR_vulkan_memory_model"
OpExtension "SPV_KHR_cooperative_matrix"
OpMemoryModel Logical Vulkan
OpEntryPoint GLCompute %compute_main "compute_main"
OpExecutionMode %compute_main LocalSize 1 1 1
OpMemberName %prevent_dce_block_tint_explicit_layout 0 "inner"
OpName %prevent_dce_block_tint_explicit_layout "prevent_dce_block_tint_explicit_layout"
OpMemberName %SB_RW_tint_explicit_layout 0 "arg_0"
OpName %SB_RW_tint_explicit_layout "SB_RW_tint_explicit_layout"
OpName %sb_rw "sb_rw"
OpName %subgroupMatrixLoad_e5381c "subgroupMatrixLoad_e5381c"
OpName %res "res"
OpName %compute_main "compute_main"
OpDecorate %_arr_uint_uint_1024 ArrayStride 4
OpMemberDecorate %prevent_dce_block_tint_explicit_layout 0 Offset 0
OpDecorate %prevent_dce_block_tint_explicit_layout Block
OpDecorate %1 DescriptorSet 0
OpDecorate %1 Binding 0
OpDecorate %_runtimearr_uint ArrayStride 4
OpMemberDecorate %SB_RW_tint_explicit_layout 0 Offset 0
OpDecorate %SB_RW_tint_explicit_layout Block
OpDecorate %sb_rw DescriptorSet 0
OpDecorate %sb_rw Binding 1
%uint = OpTypeInt 32 0
%uint_1024 = OpConstant %uint 1024
%_arr_uint_uint_1024 = OpTypeArray %uint %uint_1024
%prevent_dce_block_tint_explicit_layout = OpTypeStruct %_arr_uint_uint_1024
%_ptr_StorageBuffer_prevent_dce_block_tint_explicit_layout = OpTypePointer StorageBuffer %prevent_dce_block_tint_explicit_layout
%1 = OpVariable %_ptr_StorageBuffer_prevent_dce_block_tint_explicit_layout StorageBuffer
%_runtimearr_uint = OpTypeRuntimeArray %uint
%SB_RW_tint_explicit_layout = OpTypeStruct %_runtimearr_uint
%_ptr_StorageBuffer_SB_RW_tint_explicit_layout = OpTypePointer StorageBuffer %SB_RW_tint_explicit_layout
%sb_rw = OpVariable %_ptr_StorageBuffer_SB_RW_tint_explicit_layout StorageBuffer
%uint_3 = OpConstant %uint 3
%uint_8 = OpConstant %uint 8
%uchar = OpTypeInt 8 0
%uint_2 = OpConstant %uint 2
%12 = OpTypeCooperativeMatrixKHR %uchar %uint_3 %uint_8 %uint_8 %uint_2
%17 = OpTypeFunction %12
%_ptr_StorageBuffer__runtimearr_uint = OpTypePointer StorageBuffer %_runtimearr_uint
%uint_0 = OpConstant %uint 0
%uint_4 = OpConstant %uint 4
%uint_7 = OpConstant %uint 7
%uint_1 = OpConstant %uint 1
%bool = OpTypeBool
%_ptr_Function_12 = OpTypePointer Function %12
%uchar_0 = OpConstant %uchar 0
%34 = OpConstantComposite %12 %uchar_0
%_ptr_StorageBuffer_uint = OpTypePointer StorageBuffer %uint
%void = OpTypeVoid
%48 = OpTypeFunction %void
%_ptr_StorageBuffer__arr_uint_uint_1024 = OpTypePointer StorageBuffer %_arr_uint_uint_1024
%uint_64 = OpConstant %uint 64
%subgroupMatrixLoad_e5381c = OpFunction %12 None %17
%18 = OpLabel
%32 = OpVariable %_ptr_Function_12 Function %34
%res = OpVariable %_ptr_Function_12 Function
%19 = OpAccessChain %_ptr_StorageBuffer__runtimearr_uint %sb_rw %uint_0
%22 = OpArrayLength %uint %sb_rw 0
%23 = OpIMul %uint %22 %uint_4
%25 = OpIMul %uint %uint_8 %uint_7
%27 = OpIAdd %uint %uint_1 %25
%29 = OpIAdd %uint %27 %uint_8
%30 = OpULessThanEqual %bool %29 %23
OpSelectionMerge %36 None
OpBranchConditional %30 %37 %36
%37 = OpLabel
%41 = OpUDiv %uint %uint_8 %uint_4
%42 = OpUDiv %uint %uint_1 %uint_4
%43 = OpAccessChain %_ptr_StorageBuffer_uint %19 %42
%45 = OpCooperativeMatrixLoadKHR %12 %43 %uint_1 %41 NonPrivatePointer
OpStore %32 %45 None
OpBranch %36
%36 = OpLabel
%38 = OpLoad %12 %32 None
OpStore %res %38
%40 = OpLoad %12 %res None
OpReturnValue %40
OpFunctionEnd
%compute_main = OpFunction %void None %48
%49 = OpLabel
%50 = OpFunctionCall %12 %subgroupMatrixLoad_e5381c
%51 = OpAccessChain %_ptr_StorageBuffer__arr_uint_uint_1024 %1 %uint_0
%53 = OpUDiv %uint %uint_64 %uint_4
%55 = OpUDiv %uint %uint_0 %uint_4
%56 = OpAccessChain %_ptr_StorageBuffer_uint %51 %55
OpCooperativeMatrixStoreKHR %56 %50 %uint_0 %53 NonPrivatePointer
OpReturn
OpFunctionEnd