blob: 6e4d14b484584639e5abeeb6da3b9a2dd4feff84 [file] [log] [blame] [edit]
; SPIR-V
; Version: 1.3
; Generator: Google Tint Compiler; 1
; Bound: 52
; Schema: 0
OpCapability Shader
OpCapability VulkanMemoryModel
OpCapability VulkanMemoryModelDeviceScope
OpCapability Float16
OpCapability UniformAndStorageBuffer16BitAccess
OpCapability StorageBuffer16BitAccess
OpCapability CooperativeMatrixKHR
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_128bf4 "subgroupMatrixLoad_128bf4"
OpName %res "res"
OpName %compute_main "compute_main"
OpDecorate %_arr_half_uint_1024 ArrayStride 2
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_half ArrayStride 2
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
%half = OpTypeFloat 16
%uint = OpTypeInt 32 0
%uint_1024 = OpConstant %uint 1024
%_arr_half_uint_1024 = OpTypeArray %half %uint_1024
%prevent_dce_block_tint_explicit_layout = OpTypeStruct %_arr_half_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_half = OpTypeRuntimeArray %half
%SB_RW_tint_explicit_layout = OpTypeStruct %_runtimearr_half
%_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
%uint_2 = OpConstant %uint 2
%13 = OpTypeCooperativeMatrixKHR %half %uint_3 %uint_8 %uint_8 %uint_2
%17 = OpTypeFunction %13
%_ptr_StorageBuffer__runtimearr_half = OpTypePointer StorageBuffer %_runtimearr_half
%uint_0 = OpConstant %uint 0
%uint_7 = OpConstant %uint 7
%uint_1 = OpConstant %uint 1
%bool = OpTypeBool
%_ptr_Function_13 = OpTypePointer Function %13
%half_0x0p_0 = OpConstant %half 0x0p+0
%32 = OpConstantComposite %13 %half_0x0p_0
%_ptr_StorageBuffer_half = OpTypePointer StorageBuffer %half
%void = OpTypeVoid
%44 = OpTypeFunction %void
%_ptr_StorageBuffer__arr_half_uint_1024 = OpTypePointer StorageBuffer %_arr_half_uint_1024
%uint_64 = OpConstant %uint 64
%subgroupMatrixLoad_128bf4 = OpFunction %13 None %17
%18 = OpLabel
%30 = OpVariable %_ptr_Function_13 Function %32
%res = OpVariable %_ptr_Function_13 Function
%19 = OpAccessChain %_ptr_StorageBuffer__runtimearr_half %sb_rw %uint_0
%22 = OpArrayLength %uint %sb_rw 0
%23 = OpIMul %uint %uint_8 %uint_7
%25 = OpIAdd %uint %uint_1 %23
%27 = OpIAdd %uint %25 %uint_8
%28 = OpULessThanEqual %bool %27 %22
OpSelectionMerge %34 None
OpBranchConditional %28 %35 %34
%35 = OpLabel
%39 = OpAccessChain %_ptr_StorageBuffer_half %19 %uint_1
%41 = OpCooperativeMatrixLoadKHR %13 %39 %uint_1 %uint_8 NonPrivatePointer
OpStore %30 %41 None
OpBranch %34
%34 = OpLabel
%36 = OpLoad %13 %30 None
OpStore %res %36
%38 = OpLoad %13 %res None
OpReturnValue %38
OpFunctionEnd
%compute_main = OpFunction %void None %44
%45 = OpLabel
%46 = OpFunctionCall %13 %subgroupMatrixLoad_128bf4
%47 = OpAccessChain %_ptr_StorageBuffer__arr_half_uint_1024 %1 %uint_0
%49 = OpAccessChain %_ptr_StorageBuffer_half %47 %uint_0
OpCooperativeMatrixStoreKHR %49 %46 %uint_0 %uint_64 NonPrivatePointer
OpReturn
OpFunctionEnd