mirror of
https://github.com/KhronosGroup/OpenCL-CTS.git
synced 2026-03-25 00:09:02 +00:00
Added cl_khr_fp16 extension support for test_op_negate from spirv_new (#1762)
* Added cl_khr_fp16 extension support for test_op_negate from spirv_new (issue #142) * Added clang format fix
This commit is contained in:
35
test_conformance/spirv_new/spirv_asm/op_neg_half.spvasm32
Normal file
35
test_conformance/spirv_new/spirv_asm/op_neg_half.spvasm32
Normal file
@@ -0,0 +1,35 @@
|
||||
; SPIR-V
|
||||
; Version: 1.0
|
||||
; Generator: Khronos SPIR-V Tools Assembler; 0
|
||||
; Bound: 17
|
||||
; Schema: 0
|
||||
OpCapability Addresses
|
||||
OpCapability Linkage
|
||||
OpCapability Kernel
|
||||
OpCapability Float16
|
||||
OpMemoryModel Physical32 OpenCL
|
||||
OpEntryPoint Kernel %1 "op_neg_half" %gl_GlobalInvocationID
|
||||
OpName %in "in"
|
||||
OpDecorate %gl_GlobalInvocationID BuiltIn GlobalInvocationId
|
||||
OpDecorate %gl_GlobalInvocationID Constant
|
||||
OpDecorate %in FuncParamAttr NoCapture
|
||||
OpDecorate %gl_GlobalInvocationID LinkageAttributes "__spirv_GlobalInvocationId" Import
|
||||
%uint = OpTypeInt 32 0
|
||||
%v3uint = OpTypeVector %uint 3
|
||||
%_ptr_Input_v3uint = OpTypePointer Input %v3uint
|
||||
%void = OpTypeVoid
|
||||
%half = OpTypeFloat 16
|
||||
%_ptr_CrossWorkgroup_half = OpTypePointer CrossWorkgroup %half
|
||||
%10 = OpTypeFunction %void %_ptr_CrossWorkgroup_half
|
||||
%gl_GlobalInvocationID = OpVariable %_ptr_Input_v3uint Input
|
||||
%1 = OpFunction %void None %10
|
||||
%in = OpFunctionParameter %_ptr_CrossWorkgroup_half
|
||||
%11 = OpLabel
|
||||
%12 = OpLoad %v3uint %gl_GlobalInvocationID Aligned 0
|
||||
%13 = OpCompositeExtract %uint %12 0
|
||||
%14 = OpInBoundsPtrAccessChain %_ptr_CrossWorkgroup_half %in %13
|
||||
%15 = OpLoad %half %14
|
||||
%16 = OpFNegate %half %15
|
||||
OpStore %14 %16
|
||||
OpReturn
|
||||
OpFunctionEnd
|
||||
39
test_conformance/spirv_new/spirv_asm/op_neg_half.spvasm64
Normal file
39
test_conformance/spirv_new/spirv_asm/op_neg_half.spvasm64
Normal file
@@ -0,0 +1,39 @@
|
||||
; SPIR-V
|
||||
; Version: 1.0
|
||||
; Generator: Khronos SPIR-V Tools Assembler; 0
|
||||
; Bound: 20
|
||||
; Schema: 0
|
||||
OpCapability Addresses
|
||||
OpCapability Linkage
|
||||
OpCapability Kernel
|
||||
OpCapability Int64
|
||||
OpCapability Float16
|
||||
OpMemoryModel Physical64 OpenCL
|
||||
OpEntryPoint Kernel %1 "op_neg_half" %gl_GlobalInvocationID
|
||||
OpName %in "in"
|
||||
OpDecorate %gl_GlobalInvocationID BuiltIn GlobalInvocationId
|
||||
OpDecorate %gl_GlobalInvocationID Constant
|
||||
OpDecorate %in FuncParamAttr NoCapture
|
||||
OpDecorate %gl_GlobalInvocationID LinkageAttributes "__spirv_GlobalInvocationId" Import
|
||||
%ulong = OpTypeInt 64 0
|
||||
%v3ulong = OpTypeVector %ulong 3
|
||||
%_ptr_Input_v3ulong = OpTypePointer Input %v3ulong
|
||||
%void = OpTypeVoid
|
||||
%half = OpTypeFloat 16
|
||||
%_ptr_CrossWorkgroup_half = OpTypePointer CrossWorkgroup %half
|
||||
%10 = OpTypeFunction %void %_ptr_CrossWorkgroup_half
|
||||
%ulong_32 = OpConstant %ulong 32
|
||||
%gl_GlobalInvocationID = OpVariable %_ptr_Input_v3ulong Input
|
||||
%1 = OpFunction %void None %10
|
||||
%in = OpFunctionParameter %_ptr_CrossWorkgroup_half
|
||||
%12 = OpLabel
|
||||
%13 = OpLoad %v3ulong %gl_GlobalInvocationID Aligned 0
|
||||
%14 = OpCompositeExtract %ulong %13 0
|
||||
%15 = OpShiftLeftLogical %ulong %14 %ulong_32
|
||||
%16 = OpShiftRightArithmetic %ulong %15 %ulong_32
|
||||
%17 = OpInBoundsPtrAccessChain %_ptr_CrossWorkgroup_half %in %16
|
||||
%18 = OpLoad %half %17
|
||||
%19 = OpFNegate %half %18
|
||||
OpStore %17 %19
|
||||
OpReturn
|
||||
OpFunctionEnd
|
||||
Reference in New Issue
Block a user