mirror of
				https://github.com/encounter/dawn-cmake.git
				synced 2025-10-26 03:30:30 +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>
		
			
				
	
	
		
			60 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| ; SPIR-V
 | |
| ; Version: 1.3
 | |
| ; Generator: Google Tint Compiler; 0
 | |
| ; Bound: 27
 | |
| ; Schema: 0
 | |
|                OpCapability Shader
 | |
|                OpCapability Float16
 | |
|                OpCapability UniformAndStorageBuffer16BitAccess
 | |
|                OpCapability StorageBuffer16BitAccess
 | |
|                OpCapability StorageInputOutput16
 | |
|                OpMemoryModel Logical GLSL450
 | |
|                OpEntryPoint GLCompute %unused_entry_point "unused_entry_point"
 | |
|                OpExecutionMode %unused_entry_point LocalSize 1 1 1
 | |
|                OpName %U_block "U_block"
 | |
|                OpMemberName %U_block 0 "inner"
 | |
|                OpName %S "S"
 | |
|                OpMemberName %S 0 "v"
 | |
|                OpName %U "U"
 | |
|                OpName %unused_entry_point "unused_entry_point"
 | |
|                OpName %f "f"
 | |
|                OpDecorate %U_block Block
 | |
|                OpMemberDecorate %U_block 0 Offset 0
 | |
|                OpMemberDecorate %S 0 Offset 0
 | |
|                OpDecorate %U DescriptorSet 0
 | |
|                OpDecorate %U Binding 0
 | |
|        %half = OpTypeFloat 16
 | |
|      %v3half = OpTypeVector %half 3
 | |
|           %S = OpTypeStruct %v3half
 | |
|     %U_block = OpTypeStruct %S
 | |
| %_ptr_StorageBuffer_U_block = OpTypePointer StorageBuffer %U_block
 | |
|           %U = OpVariable %_ptr_StorageBuffer_U_block StorageBuffer
 | |
|        %void = OpTypeVoid
 | |
|           %7 = OpTypeFunction %void
 | |
|        %uint = OpTypeInt 32 0
 | |
|      %uint_0 = OpConstant %uint 0
 | |
| %_ptr_StorageBuffer_v3half = OpTypePointer StorageBuffer %v3half
 | |
| %half_0x1p_0 = OpConstant %half 0x1p+0
 | |
| %half_0x1p_1 = OpConstant %half 0x1p+1
 | |
| %half_0x1_8p_1 = OpConstant %half 0x1.8p+1
 | |
|          %20 = OpConstantComposite %v3half %half_0x1p_0 %half_0x1p_1 %half_0x1_8p_1
 | |
| %_ptr_StorageBuffer_half = OpTypePointer StorageBuffer %half
 | |
|      %uint_1 = OpConstant %uint 1
 | |
|      %uint_2 = OpConstant %uint 2
 | |
| %unused_entry_point = OpFunction %void None %7
 | |
|          %10 = OpLabel
 | |
|                OpReturn
 | |
|                OpFunctionEnd
 | |
|           %f = OpFunction %void None %7
 | |
|          %12 = OpLabel
 | |
|          %16 = OpAccessChain %_ptr_StorageBuffer_v3half %U %uint_0 %uint_0
 | |
|                OpStore %16 %20
 | |
|          %22 = OpAccessChain %_ptr_StorageBuffer_half %U %uint_0 %uint_0 %uint_0
 | |
|                OpStore %22 %half_0x1p_0
 | |
|          %24 = OpAccessChain %_ptr_StorageBuffer_half %U %uint_0 %uint_0 %uint_1
 | |
|                OpStore %24 %half_0x1p_1
 | |
|          %26 = OpAccessChain %_ptr_StorageBuffer_half %U %uint_0 %uint_0 %uint_2
 | |
|                OpStore %26 %half_0x1_8p_1
 | |
|                OpReturn
 | |
|                OpFunctionEnd
 |