mirror of
https://github.com/KhronosGroup/OpenCL-CTS.git
synced 2026-03-26 00:39:03 +00:00
Reformat SPIR-V assembly and fix validation errors (#472)
* Reformat SPIR-V assembly using spirv-dis Signed-off-by: Stuart Brady <stuart.brady@arm.com> * Fix duplicate non-aggregate type decls in SPIR-V as reported by spirv-val Signed-off-by: Stuart Brady <stuart.brady@arm.com> * Reposition OpExtensions correctly in SPIR-V as reported by spirv-val Signed-off-by: Stuart Brady <stuart.brady@arm.com> * Reposition OpVariables correctly in SPIR-V as reported by spirv-val Signed-off-by: Stuart Brady <stuart.brady@arm.com> * Add missing OpTypeImage access qualifiers in SPIR-V as reported by spirv-val Signed-off-by: Stuart Brady <stuart.brady@arm.com> * Remove same-width OpSConverts in SPIR-V as reported by spirv-val Signed-off-by: Stuart Brady <stuart.brady@arm.com> * Replace -ILPath with --spirv-binaries-path in README Signed-off-by: Stuart Brady <stuart.brady@arm.com>
This commit is contained in:
committed by
Kévin Petit
parent
60101c24cf
commit
2398587980
70
test_conformance/spirv_new/spirv_asm/phi_4.spvasm64
Normal file
70
test_conformance/spirv_new/spirv_asm/phi_4.spvasm64
Normal file
@@ -0,0 +1,70 @@
|
||||
; SPIR-V
|
||||
; Version: 1.0
|
||||
; Generator: Khronos SPIR-V Tools Assembler; 0
|
||||
; Bound: 42
|
||||
; Schema: 0
|
||||
OpCapability Addresses
|
||||
OpCapability Linkage
|
||||
OpCapability Kernel
|
||||
OpCapability Int64
|
||||
OpMemoryModel Physical64 OpenCL
|
||||
OpEntryPoint Kernel %1 "phi_4"
|
||||
OpName %res "res"
|
||||
OpName %lhs "lhs"
|
||||
OpName %rhs "rhs"
|
||||
OpDecorate %5 FuncParamAttr NoCapture
|
||||
%5 = OpDecorationGroup
|
||||
OpDecorate %gl_GlobalInvocationID BuiltIn GlobalInvocationId
|
||||
OpDecorate %gl_GlobalInvocationID Constant
|
||||
OpDecorate %gl_GlobalInvocationID LinkageAttributes "__spirv_GlobalInvocationId" Import
|
||||
OpGroupDecorate %5 %res %lhs %rhs
|
||||
%ulong = OpTypeInt 64 0
|
||||
%v3ulong = OpTypeVector %ulong 3
|
||||
%_ptr_UniformConstant_v3ulong = OpTypePointer UniformConstant %v3ulong
|
||||
%ulong_32 = OpConstant %ulong 32
|
||||
%bool = OpTypeBool
|
||||
%void = OpTypeVoid
|
||||
%uint = OpTypeInt 32 0
|
||||
%uint_0 = OpConstant %uint 0
|
||||
%_ptr_CrossWorkgroup_uint = OpTypePointer CrossWorkgroup %uint
|
||||
%16 = OpTypeFunction %void %_ptr_CrossWorkgroup_uint %_ptr_CrossWorkgroup_uint %_ptr_CrossWorkgroup_uint
|
||||
%gl_GlobalInvocationID = OpVariable %_ptr_UniformConstant_v3ulong UniformConstant
|
||||
%1 = OpFunction %void None %16
|
||||
%res = OpFunctionParameter %_ptr_CrossWorkgroup_uint
|
||||
%lhs = OpFunctionParameter %_ptr_CrossWorkgroup_uint
|
||||
%rhs = OpFunctionParameter %_ptr_CrossWorkgroup_uint
|
||||
%17 = OpLabel
|
||||
%18 = OpLoad %v3ulong %gl_GlobalInvocationID Aligned 0
|
||||
%19 = OpCompositeExtract %ulong %18 0
|
||||
%20 = OpShiftLeftLogical %ulong %19 %ulong_32
|
||||
%21 = OpShiftRightArithmetic %ulong %20 %ulong_32
|
||||
%22 = OpInBoundsPtrAccessChain %_ptr_CrossWorkgroup_uint %lhs %21
|
||||
%23 = OpLoad %uint %22 Aligned 4
|
||||
%24 = OpInBoundsPtrAccessChain %_ptr_CrossWorkgroup_uint %rhs %21
|
||||
%25 = OpLoad %uint %24 Aligned 4
|
||||
%26 = OpSLessThan %bool %23 %25
|
||||
OpBranchConditional %26 %27 %28
|
||||
%27 = OpLabel
|
||||
%29 = OpSLessThan %bool %23 %uint_0
|
||||
OpBranchConditional %29 %30 %31
|
||||
%30 = OpLabel
|
||||
%32 = OpISub %uint %uint_0 %23
|
||||
OpBranch %33
|
||||
%31 = OpLabel
|
||||
%34 = OpISub %uint %23 %uint_0
|
||||
OpBranch %33
|
||||
%28 = OpLabel
|
||||
%35 = OpSLessThan %bool %25 %uint_0
|
||||
OpBranchConditional %35 %36 %37
|
||||
%36 = OpLabel
|
||||
%38 = OpISub %uint %uint_0 %25
|
||||
OpBranch %33
|
||||
%37 = OpLabel
|
||||
%39 = OpISub %uint %25 %uint_0
|
||||
OpBranch %33
|
||||
%33 = OpLabel
|
||||
%40 = OpPhi %uint %32 %30 %34 %31 %38 %36 %39 %37
|
||||
%41 = OpInBoundsPtrAccessChain %_ptr_CrossWorkgroup_uint %res %21
|
||||
OpStore %41 %40 Aligned 4
|
||||
OpReturn
|
||||
OpFunctionEnd
|
||||
Reference in New Issue
Block a user