blob: e67fb0902690082296b5b2d432ea183e9e2de4ce [file] [log] [blame]
; SPIR-V
; Version: 1.3
; Generator: Google Tint Compiler; 1
; Bound: 43
; 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_0cc7b0 "subgroupMatrixLoad_0cc7b0"
OpName %arg_1 "arg_1"
OpName %arg_3 "arg_3"
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_0 = OpConstant %uint 0
%13 = OpTypeCooperativeMatrixKHR %half %uint_3 %uint_8 %uint_8 %uint_0
%17 = OpTypeFunction %13
%_ptr_Function_uint = OpTypePointer Function %uint
%uint_1 = OpConstant %uint 1
%_ptr_StorageBuffer__runtimearr_half = OpTypePointer StorageBuffer %_runtimearr_half
%_ptr_StorageBuffer_half = OpTypePointer StorageBuffer %half
%_ptr_Function_13 = OpTypePointer Function %13
%void = OpTypeVoid
%35 = OpTypeFunction %void
%_ptr_StorageBuffer__arr_half_uint_1024 = OpTypePointer StorageBuffer %_arr_half_uint_1024
%uint_64 = OpConstant %uint 64
%subgroupMatrixLoad_0cc7b0 = OpFunction %13 None %17
%18 = OpLabel
%arg_1 = OpVariable %_ptr_Function_uint Function
%arg_3 = OpVariable %_ptr_Function_uint Function
%res = OpVariable %_ptr_Function_13 Function
OpStore %arg_1 %uint_1
OpStore %arg_3 %uint_1
%23 = OpAccessChain %_ptr_StorageBuffer__runtimearr_half %sb_rw %uint_0
%25 = OpLoad %uint %arg_1 None
%26 = OpLoad %uint %arg_3 None
%27 = OpAccessChain %_ptr_StorageBuffer_half %23 %25
%29 = OpCooperativeMatrixLoadKHR %13 %27 %uint_1 %26 NonPrivatePointer
OpStore %res %29
%32 = OpLoad %13 %res None
OpReturnValue %32
OpFunctionEnd
%compute_main = OpFunction %void None %35
%36 = OpLabel
%37 = OpFunctionCall %13 %subgroupMatrixLoad_0cc7b0
%38 = OpAccessChain %_ptr_StorageBuffer__arr_half_uint_1024 %1 %uint_0
%40 = OpAccessChain %_ptr_StorageBuffer_half %38 %uint_0
OpCooperativeMatrixStoreKHR %40 %37 %uint_0 %uint_64 NonPrivatePointer
OpReturn
OpFunctionEnd