Files
OpenCL-CTS/test_conformance/spirv_new/spirv_asm/fdiv_double.spvasm64
Stuart Brady 2398587980 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>
2019-11-19 09:05:28 +00:00

51 lines
2.3 KiB
Plaintext

; SPIR-V
; Version: 1.0
; Generator: Khronos SPIR-V Tools Assembler; 0
; Bound: 27
; Schema: 0
OpCapability Float64
OpCapability Addresses
OpCapability Linkage
OpCapability Kernel
OpCapability Int64
%1 = OpExtInstImport "OpenCL.std"
OpMemoryModel Physical64 OpenCL
OpEntryPoint Kernel %2 "fmath_spv"
OpName %res "res"
OpName %lhs "lhs"
OpName %rhs "rhs"
OpName %entry "entry"
OpDecorate %7 FuncParamAttr NoCapture
%7 = OpDecorationGroup
OpDecorate %gl_GlobalInvocationID BuiltIn GlobalInvocationId
OpDecorate %gl_GlobalInvocationID Constant
OpDecorate %gl_GlobalInvocationID LinkageAttributes "__spirv_GlobalInvocationId" Import
OpGroupDecorate %7 %res %lhs %rhs
%ulong = OpTypeInt 64 0
%v3ulong = OpTypeVector %ulong 3
%_ptr_UniformConstant_v3ulong = OpTypePointer UniformConstant %v3ulong
%void = OpTypeVoid
%double = OpTypeFloat 64
%_ptr_CrossWorkgroup_double = OpTypePointer CrossWorkgroup %double
%15 = OpTypeFunction %void %_ptr_CrossWorkgroup_double %_ptr_CrossWorkgroup_double %_ptr_CrossWorkgroup_double
%ulong_32 = OpConstant %ulong 32
%gl_GlobalInvocationID = OpVariable %_ptr_UniformConstant_v3ulong UniformConstant
%2 = OpFunction %void None %15
%res = OpFunctionParameter %_ptr_CrossWorkgroup_double
%lhs = OpFunctionParameter %_ptr_CrossWorkgroup_double
%rhs = OpFunctionParameter %_ptr_CrossWorkgroup_double
%entry = OpLabel
%17 = OpLoad %v3ulong %gl_GlobalInvocationID Aligned 0
%18 = OpCompositeExtract %ulong %17 0
%19 = OpShiftLeftLogical %ulong %18 %ulong_32
%20 = OpShiftRightArithmetic %ulong %19 %ulong_32
%21 = OpInBoundsPtrAccessChain %_ptr_CrossWorkgroup_double %lhs %20
%22 = OpLoad %double %21 Aligned 8
%23 = OpInBoundsPtrAccessChain %_ptr_CrossWorkgroup_double %rhs %20
%24 = OpLoad %double %23 Aligned 8
%25 = OpFDiv %double %22 %24
%26 = OpInBoundsPtrAccessChain %_ptr_CrossWorkgroup_double %res %20
OpStore %26 %25 Aligned 8
OpReturn
OpFunctionEnd