mirror of
				https://github.com/encounter/dawn-cmake.git
				synced 2025-10-25 11:10:29 +00:00 
			
		
		
		
	- When storing to sample_mask output, write to the 0th element - Only make a return struct if it has members - Adjust type signedness coercion when loading special builtins. - Adapt tests - Update expectations for end-to-end tests - Handle sample_mask with stride Input variables normally don't have layout. But they can have it up through SPIR-V 1.4. Handle this case in the SPIR-V reader, by seeing through the intermediate alias type created for the strided array type. Bug: tint:508 Change-Id: I0f19dc1305d3f250dbbc0698a602288c34245274 Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/54743 Auto-Submit: David Neto <dneto@google.com> Commit-Queue: Ben Clayton <bclayton@google.com> Reviewed-by: James Price <jrprice@google.com> Reviewed-by: Ben Clayton <bclayton@google.com> Kokoro: Kokoro <noreply+kokoro@google.com>
		
			
				
	
	
		
			54 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| ; SPIR-V
 | |
| ; Version: 1.3
 | |
| ; Generator: Google Tint Compiler; 0
 | |
| ; Bound: 35
 | |
| ; Schema: 0
 | |
|                OpCapability Shader
 | |
|                OpMemoryModel Logical GLSL450
 | |
|                OpEntryPoint GLCompute %main "main"
 | |
|                OpExecutionMode %main LocalSize 1 1 1
 | |
|                OpName %main_1 "main_1"
 | |
|                OpName %m "m"
 | |
|                OpName %main "main"
 | |
|        %void = OpTypeVoid
 | |
|           %1 = OpTypeFunction %void
 | |
|       %float = OpTypeFloat 32
 | |
|     %v3float = OpTypeVector %float 3
 | |
| %mat3v3float = OpTypeMatrix %v3float 3
 | |
|     %float_0 = OpConstant %float 0
 | |
|           %9 = OpConstantComposite %v3float %float_0 %float_0 %float_0
 | |
|          %10 = OpConstantComposite %mat3v3float %9 %9 %9
 | |
| %_ptr_Function_mat3v3float = OpTypePointer Function %mat3v3float
 | |
|          %13 = OpConstantNull %mat3v3float
 | |
|     %float_1 = OpConstant %float 1
 | |
|     %float_2 = OpConstant %float 2
 | |
|     %float_3 = OpConstant %float 3
 | |
|          %17 = OpConstantComposite %v3float %float_1 %float_2 %float_3
 | |
|     %float_4 = OpConstant %float 4
 | |
|     %float_5 = OpConstant %float 5
 | |
|     %float_6 = OpConstant %float 6
 | |
|          %21 = OpConstantComposite %v3float %float_4 %float_5 %float_6
 | |
|     %float_7 = OpConstant %float 7
 | |
|     %float_8 = OpConstant %float 8
 | |
|     %float_9 = OpConstant %float 9
 | |
|          %25 = OpConstantComposite %v3float %float_7 %float_8 %float_9
 | |
|          %26 = OpConstantComposite %mat3v3float %17 %21 %25
 | |
|         %int = OpTypeInt 32 1
 | |
|       %int_1 = OpConstant %int 1
 | |
| %_ptr_Function_v3float = OpTypePointer Function %v3float
 | |
|          %31 = OpConstantComposite %v3float %float_5 %float_5 %float_5
 | |
|      %main_1 = OpFunction %void None %1
 | |
|           %4 = OpLabel
 | |
|           %m = OpVariable %_ptr_Function_mat3v3float Function %13
 | |
|                OpStore %m %10
 | |
|                OpStore %m %26
 | |
|          %30 = OpAccessChain %_ptr_Function_v3float %m %int_1
 | |
|                OpStore %30 %31
 | |
|                OpReturn
 | |
|                OpFunctionEnd
 | |
|        %main = OpFunction %void None %1
 | |
|          %33 = OpLabel
 | |
|          %34 = OpFunctionCall %void %main_1
 | |
|                OpReturn
 | |
|                OpFunctionEnd
 |