blob: afc5976383af422e6ffbcb9bb3278096e0730e3a [file] [log] [blame]
; SPIR-V
; Version: 1.3
; Generator: Google Tint Compiler; 1
; Bound: 40
; 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"
OpName %subgroupMatrixMultiplyAccumulate_edc1aa "subgroupMatrixMultiplyAccumulate_edc1aa"
OpName %res "res"
OpName %compute_main "compute_main"
OpDecorate %_arr_int_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
%int = OpTypeInt 32 1
%uint = OpTypeInt 32 0
%uint_1024 = OpConstant %uint 1024
%_arr_int_uint_1024 = OpTypeArray %int %uint_1024
%prevent_dce_block_tint_explicit_layout = OpTypeStruct %_arr_int_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
%uint_3 = OpConstant %uint 3
%uint_8 = OpConstant %uint 8
%uint_2 = OpConstant %uint 2
%9 = OpTypeCooperativeMatrixKHR %int %uint_3 %uint_8 %uint_8 %uint_2
%13 = OpTypeFunction %9
%char = OpTypeInt 8 1
%uint_0 = OpConstant %uint 0
%16 = OpTypeCooperativeMatrixKHR %char %uint_3 %uint_8 %uint_8 %uint_0
%char_0 = OpConstant %char 0
%15 = OpConstantComposite %16 %char_0
%uint_1 = OpConstant %uint 1
%21 = OpTypeCooperativeMatrixKHR %char %uint_3 %uint_8 %uint_8 %uint_1
%20 = OpConstantComposite %21 %char_0
%int_0 = OpConstant %int 0
%23 = OpConstantComposite %9 %int_0
%_ptr_Function_9 = OpTypePointer Function %9
%void = OpTypeVoid
%31 = OpTypeFunction %void
%_ptr_StorageBuffer__arr_int_uint_1024 = OpTypePointer StorageBuffer %_arr_int_uint_1024
%_ptr_StorageBuffer_int = OpTypePointer StorageBuffer %int
%uint_64 = OpConstant %uint 64
%subgroupMatrixMultiplyAccumulate_edc1aa = OpFunction %9 None %13
%14 = OpLabel
%res = OpVariable %_ptr_Function_9 Function
%25 = OpCooperativeMatrixMulAddKHR %9 %15 %20 %23 MatrixASignedComponentsKHR|MatrixBSignedComponentsKHR|MatrixCSignedComponentsKHR|MatrixResultSignedComponentsKHR
OpStore %res %25
%28 = OpLoad %9 %res None
OpReturnValue %28
OpFunctionEnd
%compute_main = OpFunction %void None %31
%32 = OpLabel
%33 = OpFunctionCall %9 %subgroupMatrixMultiplyAccumulate_edc1aa
%34 = OpAccessChain %_ptr_StorageBuffer__arr_int_uint_1024 %1 %uint_0
%36 = OpAccessChain %_ptr_StorageBuffer_int %34 %uint_0
OpCooperativeMatrixStoreKHR %36 %33 %uint_0 %uint_64 NonPrivatePointer
OpReturn
OpFunctionEnd