mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-05-28 10:11:33 +00:00
This CL implements f16 in uniform and storage address space, allowing using f16 types in uniform and storage buffers on all backends. Tint uint tests and Dawn E2E tests are added to validate the f16 types work as expected. Bug: tint:1473, tint:1502 Change-Id: I15e3de1033d3727f2ea33f4657f682c5f13c2153 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/106320 Kokoro: Kokoro <noreply+kokoro@google.com> Commit-Queue: Zhaoming Jiang <zhaoming.jiang@intel.com> Reviewed-by: Ben Clayton <bclayton@google.com>
84 lines
3.4 KiB
Plaintext
84 lines
3.4 KiB
Plaintext
; SPIR-V
|
|
; Version: 1.3
|
|
; Generator: Google Tint Compiler; 0
|
|
; Bound: 37
|
|
; Schema: 0
|
|
OpCapability Shader
|
|
OpCapability Float16
|
|
OpCapability UniformAndStorageBuffer16BitAccess
|
|
OpCapability StorageBuffer16BitAccess
|
|
OpCapability StorageInputOutput16
|
|
OpMemoryModel Logical GLSL450
|
|
OpEntryPoint Vertex %vertex_main "vertex_main" %value %vertex_point_size
|
|
OpEntryPoint Fragment %fragment_main "fragment_main"
|
|
OpEntryPoint GLCompute %compute_main "compute_main"
|
|
OpExecutionMode %fragment_main OriginUpperLeft
|
|
OpExecutionMode %compute_main LocalSize 1 1 1
|
|
OpName %value "value"
|
|
OpName %vertex_point_size "vertex_point_size"
|
|
OpName %SB_RW "SB_RW"
|
|
OpMemberName %SB_RW 0 "arg_0"
|
|
OpName %sb_rw "sb_rw"
|
|
OpName %arrayLength_cbd6b5 "arrayLength_cbd6b5"
|
|
OpName %res "res"
|
|
OpName %vertex_main_inner "vertex_main_inner"
|
|
OpName %vertex_main "vertex_main"
|
|
OpName %fragment_main "fragment_main"
|
|
OpName %compute_main "compute_main"
|
|
OpDecorate %value BuiltIn Position
|
|
OpDecorate %vertex_point_size BuiltIn PointSize
|
|
OpDecorate %SB_RW Block
|
|
OpMemberDecorate %SB_RW 0 Offset 0
|
|
OpDecorate %_runtimearr_half ArrayStride 2
|
|
OpDecorate %sb_rw DescriptorSet 0
|
|
OpDecorate %sb_rw Binding 0
|
|
%float = OpTypeFloat 32
|
|
%v4float = OpTypeVector %float 4
|
|
%_ptr_Output_v4float = OpTypePointer Output %v4float
|
|
%5 = OpConstantNull %v4float
|
|
%value = OpVariable %_ptr_Output_v4float Output %5
|
|
%_ptr_Output_float = OpTypePointer Output %float
|
|
%8 = OpConstantNull %float
|
|
%vertex_point_size = OpVariable %_ptr_Output_float Output %8
|
|
%half = OpTypeFloat 16
|
|
%_runtimearr_half = OpTypeRuntimeArray %half
|
|
%SB_RW = OpTypeStruct %_runtimearr_half
|
|
%_ptr_StorageBuffer_SB_RW = OpTypePointer StorageBuffer %SB_RW
|
|
%sb_rw = OpVariable %_ptr_StorageBuffer_SB_RW StorageBuffer
|
|
%void = OpTypeVoid
|
|
%14 = OpTypeFunction %void
|
|
%uint = OpTypeInt 32 0
|
|
%_ptr_Function_uint = OpTypePointer Function %uint
|
|
%22 = OpConstantNull %uint
|
|
%23 = OpTypeFunction %v4float
|
|
%float_1 = OpConstant %float 1
|
|
%arrayLength_cbd6b5 = OpFunction %void None %14
|
|
%17 = OpLabel
|
|
%res = OpVariable %_ptr_Function_uint Function %22
|
|
%18 = OpArrayLength %uint %sb_rw 0
|
|
OpStore %res %18
|
|
OpReturn
|
|
OpFunctionEnd
|
|
%vertex_main_inner = OpFunction %v4float None %23
|
|
%25 = OpLabel
|
|
%26 = OpFunctionCall %void %arrayLength_cbd6b5
|
|
OpReturnValue %5
|
|
OpFunctionEnd
|
|
%vertex_main = OpFunction %void None %14
|
|
%28 = OpLabel
|
|
%29 = OpFunctionCall %v4float %vertex_main_inner
|
|
OpStore %value %29
|
|
OpStore %vertex_point_size %float_1
|
|
OpReturn
|
|
OpFunctionEnd
|
|
%fragment_main = OpFunction %void None %14
|
|
%32 = OpLabel
|
|
%33 = OpFunctionCall %void %arrayLength_cbd6b5
|
|
OpReturn
|
|
OpFunctionEnd
|
|
%compute_main = OpFunction %void None %14
|
|
%35 = OpLabel
|
|
%36 = OpFunctionCall %void %arrayLength_cbd6b5
|
|
OpReturn
|
|
OpFunctionEnd
|