mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-07-05 04:36:02 +00:00
This adds SPIR-V assembly and WGSL tests derived from VK-GL-CTS commit 571256871c2e2f03995373e1e4a02958d8cd8cf5. The following procedure was followed: - Those .amber files in VK-GL-CTS wholly owned by Google were identified - All GLSL and SPIR-V shaders were extracted from the Amber files and converted into SPIR-V binaries - The compact-ids pass of spirv-opt was applied to each binary - Duplicate binaries were removed - spirv-opt -O was used to obtain an optimized version of each remaining binary, with duplicates discarded - Binaries that failed validation using spirv-val with target environment SPIR-V 1.3 were discarded - Those binaries that tint could not successfully convert into WGSL were put aside for further investigation - SPIR-V assembly versions of the remaining binaries are included in this CL - test-runner with -generate-expected and -generate-skip was used to generate expected .spvasm, .msl, .hlsl and .wgsl outputs for these SPIR-V assembly tests - Each successfully-generated .expected.wgsl is included in this CL again, as a WGLSL test - test-runner with -generate-expected and -generate-skip was used again, to generate expected outputs for these WGSL tests Change-Id: Ibe9baf2729cf97e0b633db9a426f53362a5de540 Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/58842 Kokoro: Kokoro <noreply+kokoro@google.com> Commit-Queue: Ben Clayton <bclayton@google.com> Reviewed-by: Ben Clayton <bclayton@google.com>
65 lines
2.6 KiB
Plaintext
65 lines
2.6 KiB
Plaintext
OpCapability Shader
|
|
%1 = OpExtInstImport "GLSL.std.450"
|
|
OpMemoryModel Logical GLSL450
|
|
OpEntryPoint Fragment %main "main" %_GLF_color
|
|
OpExecutionMode %main OriginUpperLeft
|
|
OpSource ESSL 320
|
|
OpName %main "main"
|
|
OpName %m "m"
|
|
OpName %_GLF_color "_GLF_color"
|
|
OpDecorate %_GLF_color Location 0
|
|
%void = OpTypeVoid
|
|
%6 = OpTypeFunction %void
|
|
%float = OpTypeFloat 32
|
|
%v2float = OpTypeVector %float 2
|
|
%mat2v2float = OpTypeMatrix %v2float 2
|
|
%_ptr_Function_mat2v2float = OpTypePointer Function %mat2v2float
|
|
%float_1 = OpConstant %float 1
|
|
%float_2 = OpConstant %float 2
|
|
%13 = OpConstantComposite %v2float %float_1 %float_2
|
|
%float_3 = OpConstant %float 3
|
|
%float_4 = OpConstant %float 4
|
|
%16 = OpConstantComposite %v2float %float_3 %float_4
|
|
%17 = OpConstantComposite %mat2v2float %13 %16
|
|
%bool = OpTypeBool
|
|
%v2bool = OpTypeVector %bool 2
|
|
%v4float = OpTypeVector %float 4
|
|
%_ptr_Output_v4float = OpTypePointer Output %v4float
|
|
%_GLF_color = OpVariable %_ptr_Output_v4float Output
|
|
%float_0 = OpConstant %float 0
|
|
%23 = OpConstantComposite %v4float %float_1 %float_0 %float_0 %float_1
|
|
%24 = OpConstantComposite %v4float %float_0 %float_0 %float_0 %float_0
|
|
%main = OpFunction %void None %6
|
|
%25 = OpLabel
|
|
%m = OpVariable %_ptr_Function_mat2v2float Function
|
|
OpStore %m %17
|
|
%26 = OpLoad %mat2v2float %m
|
|
%27 = OpTranspose %mat2v2float %26
|
|
%28 = OpLoad %mat2v2float %m
|
|
%29 = OpTranspose %mat2v2float %28
|
|
%30 = OpMatrixTimesMatrix %mat2v2float %27 %29
|
|
%31 = OpLoad %mat2v2float %m
|
|
%32 = OpLoad %mat2v2float %m
|
|
%33 = OpMatrixTimesMatrix %mat2v2float %31 %32
|
|
%34 = OpTranspose %mat2v2float %33
|
|
%35 = OpCompositeExtract %v2float %30 0
|
|
%36 = OpCompositeExtract %v2float %34 0
|
|
%37 = OpFOrdEqual %v2bool %35 %36
|
|
%38 = OpAll %bool %37
|
|
%39 = OpCompositeExtract %v2float %30 1
|
|
%40 = OpCompositeExtract %v2float %34 1
|
|
%41 = OpFOrdEqual %v2bool %39 %40
|
|
%42 = OpAll %bool %41
|
|
%43 = OpLogicalAnd %bool %38 %42
|
|
OpSelectionMerge %44 None
|
|
OpBranchConditional %43 %45 %46
|
|
%45 = OpLabel
|
|
OpStore %_GLF_color %23
|
|
OpBranch %44
|
|
%46 = OpLabel
|
|
OpStore %_GLF_color %24
|
|
OpBranch %44
|
|
%44 = OpLabel
|
|
OpReturn
|
|
OpFunctionEnd
|