Add tests derived from VK-GL-CTS
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>
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm
new file mode 100644
index 0000000..8767ee3
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm
@@ -0,0 +1,120 @@
+ OpCapability Shader
+ %1 = OpExtInstImport "GLSL.std.450"
+ OpMemoryModel Logical GLSL450
+ OpEntryPoint Fragment %main "main" %_GLF_color
+ OpExecutionMode %main OriginUpperLeft
+ OpSource ESSL 310
+ OpName %main "main"
+ OpName %S "S"
+ OpMemberName %S 0 "x"
+ OpMemberName %S 1 "y"
+ OpName %func_struct_S_i1_i11_ "func(struct-S-i1-i11;"
+ OpName %arg "arg"
+ OpName %a "a"
+ OpName %b "b"
+ OpName %buf0 "buf0"
+ OpMemberName %buf0 0 "one"
+ OpName %_ ""
+ OpName %param "param"
+ OpName %_GLF_color "_GLF_color"
+ OpMemberDecorate %buf0 0 Offset 0
+ OpDecorate %buf0 Block
+ OpDecorate %_ DescriptorSet 0
+ OpDecorate %_ Binding 0
+ OpDecorate %_GLF_color Location 0
+ %void = OpTypeVoid
+ %13 = OpTypeFunction %void
+ %int = OpTypeInt 32 1
+ %S = OpTypeStruct %int %int
+%_ptr_Function_S = OpTypePointer Function %S
+ %16 = OpTypeFunction %void %_ptr_Function_S
+ %int_1 = OpConstant %int 1
+%_ptr_Function_int = OpTypePointer Function %int
+ %float = OpTypeFloat 32
+%_ptr_Function_float = OpTypePointer Function %float
+ %float_5 = OpConstant %float 5
+ %uint = OpTypeInt 32 0
+ %uint_2 = OpConstant %uint 2
+%_arr_S_uint_2 = OpTypeArray %S %uint_2
+%_ptr_Function__arr_S_uint_2 = OpTypePointer Function %_arr_S_uint_2
+ %buf0 = OpTypeStruct %int
+%_ptr_Uniform_buf0 = OpTypePointer Uniform %buf0
+ %_ = OpVariable %_ptr_Uniform_buf0 Uniform
+ %int_0 = OpConstant %int 0
+%_ptr_Uniform_int = OpTypePointer Uniform %int
+ %bool = OpTypeBool
+ %float_0 = OpConstant %float 0
+ %false = OpConstantFalse %bool
+ %v4float = OpTypeVector %float 4
+%_ptr_Output_v4float = OpTypePointer Output %v4float
+ %_GLF_color = OpVariable %_ptr_Output_v4float Output
+ %float_1 = OpConstant %float 1
+ %35 = OpConstantComposite %v4float %float_1 %float_0 %float_0 %float_1
+ %36 = OpConstantComposite %v4float %float_0 %float_0 %float_0 %float_0
+ %main = OpFunction %void None %13
+ %37 = OpLabel
+ %a = OpVariable %_ptr_Function_float Function
+ %b = OpVariable %_ptr_Function__arr_S_uint_2 Function
+ %param = OpVariable %_ptr_Function_S Function
+ OpStore %a %float_5
+ OpBranch %38
+ %38 = OpLabel
+ OpLoopMerge %39 %40 None
+ OpBranch %41
+ %41 = OpLabel
+ %42 = OpAccessChain %_ptr_Uniform_int %_ %int_0
+ %43 = OpLoad %int %42
+ %44 = OpAccessChain %_ptr_Function_int %b %43 %int_0
+ OpStore %44 %int_1
+ %45 = OpAccessChain %_ptr_Function_int %b %int_1 %int_0
+ %46 = OpLoad %int %45
+ %47 = OpIEqual %bool %46 %int_1
+ OpSelectionMerge %48 None
+ OpBranchConditional %47 %49 %48
+ %49 = OpLabel
+ %50 = OpAccessChain %_ptr_Uniform_int %_ %int_0
+ %51 = OpLoad %int %50
+ %52 = OpIEqual %bool %51 %int_1
+ OpSelectionMerge %53 None
+ OpBranchConditional %52 %54 %53
+ %54 = OpLabel
+ OpBranch %39
+ %53 = OpLabel
+ %55 = OpAccessChain %_ptr_Function_S %b %int_1
+ %56 = OpLoad %S %55
+ OpStore %param %56
+ %57 = OpFunctionCall %void %func_struct_S_i1_i11_ %param
+ %58 = OpLoad %S %param
+ %59 = OpAccessChain %_ptr_Function_S %b %int_1
+ OpStore %59 %58
+ %60 = OpAccessChain %_ptr_Function_int %b %int_1 %int_1
+ %61 = OpLoad %int %60
+ %62 = OpConvertSToF %float %61
+ OpStore %a %62
+ OpBranch %48
+ %48 = OpLabel
+ OpStore %a %float_0
+ OpBranch %40
+ %40 = OpLabel
+ OpBranchConditional %false %38 %39
+ %39 = OpLabel
+ %63 = OpLoad %float %a
+ %64 = OpFOrdEqual %bool %63 %float_5
+ OpSelectionMerge %65 None
+ OpBranchConditional %64 %66 %67
+ %66 = OpLabel
+ OpStore %_GLF_color %35
+ OpBranch %65
+ %67 = OpLabel
+ OpStore %_GLF_color %36
+ OpBranch %65
+ %65 = OpLabel
+ OpReturn
+ OpFunctionEnd
+%func_struct_S_i1_i11_ = OpFunction %void None %16
+ %arg = OpFunctionParameter %_ptr_Function_S
+ %68 = OpLabel
+ %69 = OpAccessChain %_ptr_Function_int %arg %int_1
+ OpStore %69 %int_1
+ OpReturn
+ OpFunctionEnd
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm.expected.hlsl b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm.expected.hlsl
new file mode 100644
index 0000000..0adcd37
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm.expected.hlsl
@@ -0,0 +1,65 @@
+struct S {
+ int x;
+ int y;
+};
+
+cbuffer cbuffer_x_10 : register(b0, space0) {
+ uint4 x_10[1];
+};
+static float4 x_GLF_color = float4(0.0f, 0.0f, 0.0f, 0.0f);
+
+void func_struct_S_i1_i11_(inout S arg) {
+ arg.y = 1;
+ return;
+}
+
+void main_1() {
+ float a = 0.0f;
+ S b[2] = (S[2])0;
+ S param = (S)0;
+ a = 5.0f;
+ while (true) {
+ const int x_43 = asint(x_10[0].x);
+ b[x_43].x = 1;
+ const int x_46 = b[1].x;
+ if ((x_46 == 1)) {
+ const int x_51 = asint(x_10[0].x);
+ if ((x_51 == 1)) {
+ break;
+ }
+ const S x_56 = b[1];
+ param = x_56;
+ func_struct_S_i1_i11_(param);
+ b[1] = param;
+ const int x_61 = b[1].y;
+ a = float(x_61);
+ }
+ a = 0.0f;
+ {
+ if (false) {
+ } else {
+ break;
+ }
+ }
+ }
+ if ((a == 5.0f)) {
+ x_GLF_color = float4(1.0f, 0.0f, 0.0f, 1.0f);
+ } else {
+ x_GLF_color = float4(0.0f, 0.0f, 0.0f, 0.0f);
+ }
+ return;
+}
+
+struct main_out {
+ float4 x_GLF_color_1;
+};
+struct tint_symbol {
+ float4 x_GLF_color_1 : SV_Target0;
+};
+
+tint_symbol main() {
+ main_1();
+ const main_out tint_symbol_1 = {x_GLF_color};
+ const tint_symbol tint_symbol_3 = {tint_symbol_1.x_GLF_color_1};
+ return tint_symbol_3;
+}
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm.expected.msl b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm.expected.msl
new file mode 100644
index 0000000..a0d65d8
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm.expected.msl
@@ -0,0 +1,72 @@
+#include <metal_stdlib>
+
+using namespace metal;
+struct S {
+ int x;
+ int y;
+};
+struct buf0 {
+ /* 0x0000 */ int one;
+};
+struct tint_array_wrapper {
+ S arr[2];
+};
+struct main_out {
+ float4 x_GLF_color_1;
+};
+struct tint_symbol_1 {
+ float4 x_GLF_color_1 [[color(0)]];
+};
+
+void func_struct_S_i1_i11_(thread S* const arg) {
+ (*(arg)).y = 1;
+ return;
+}
+
+void main_1(constant buf0& x_10, thread float4* const tint_symbol_4) {
+ float a = 0.0f;
+ tint_array_wrapper b = {};
+ S param = {};
+ a = 5.0f;
+ while (true) {
+ int const x_43 = x_10.one;
+ b.arr[x_43].x = 1;
+ int const x_46 = b.arr[1].x;
+ if ((x_46 == 1)) {
+ int const x_51 = x_10.one;
+ if ((x_51 == 1)) {
+ break;
+ }
+ S const x_56 = b.arr[1];
+ param = x_56;
+ func_struct_S_i1_i11_(&(param));
+ S const x_58 = param;
+ b.arr[1] = x_58;
+ int const x_61 = b.arr[1].y;
+ a = float(x_61);
+ }
+ a = 0.0f;
+ {
+ if (false) {
+ } else {
+ break;
+ }
+ }
+ }
+ float const x_63 = a;
+ if ((x_63 == 5.0f)) {
+ *(tint_symbol_4) = float4(1.0f, 0.0f, 0.0f, 1.0f);
+ } else {
+ *(tint_symbol_4) = float4(0.0f, 0.0f, 0.0f, 0.0f);
+ }
+ return;
+}
+
+fragment tint_symbol_1 tint_symbol(constant buf0& x_10 [[buffer(0)]]) {
+ thread float4 tint_symbol_5 = 0.0f;
+ main_1(x_10, &(tint_symbol_5));
+ main_out const tint_symbol_2 = {.x_GLF_color_1=tint_symbol_5};
+ tint_symbol_1 const tint_symbol_3 = {.x_GLF_color_1=tint_symbol_2.x_GLF_color_1};
+ return tint_symbol_3;
+}
+
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm.expected.spvasm b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm.expected.spvasm
new file mode 100644
index 0000000..5969228
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm.expected.spvasm
@@ -0,0 +1,170 @@
+SKIP: FAILED
+
+; SPIR-V
+; Version: 1.3
+; Generator: Google Tint Compiler; 0
+; Bound: 93
+; Schema: 0
+ OpCapability Shader
+ OpMemoryModel Logical GLSL450
+ OpEntryPoint Fragment %main "main" %tint_symbol_1
+ OpExecutionMode %main OriginUpperLeft
+ OpName %buf0 "buf0"
+ OpMemberName %buf0 0 "one"
+ OpName %x_10 "x_10"
+ OpName %x_GLF_color "x_GLF_color"
+ OpName %tint_symbol_1 "tint_symbol_1"
+ OpName %S "S"
+ OpMemberName %S 0 "x"
+ OpMemberName %S 1 "y"
+ OpName %func_struct_S_i1_i11_ "func_struct_S_i1_i11_"
+ OpName %arg "arg"
+ OpName %main_1 "main_1"
+ OpName %a "a"
+ OpName %b "b"
+ OpName %param "param"
+ OpName %main_out "main_out"
+ OpMemberName %main_out 0 "x_GLF_color_1"
+ OpName %tint_symbol_2 "tint_symbol_2"
+ OpName %tint_symbol "tint_symbol"
+ OpName %main "main"
+ OpDecorate %buf0 Block
+ OpMemberDecorate %buf0 0 Offset 0
+ OpDecorate %x_10 NonWritable
+ OpDecorate %x_10 DescriptorSet 0
+ OpDecorate %x_10 Binding 0
+ OpDecorate %tint_symbol_1 Location 0
+ OpMemberDecorate %S 0 Offset 0
+ OpMemberDecorate %S 1 Offset 4
+ OpDecorate %_arr_S_uint_2 ArrayStride 8
+ OpMemberDecorate %main_out 0 Offset 0
+ %int = OpTypeInt 32 1
+ %buf0 = OpTypeStruct %int
+%_ptr_Uniform_buf0 = OpTypePointer Uniform %buf0
+ %x_10 = OpVariable %_ptr_Uniform_buf0 Uniform
+ %float = OpTypeFloat 32
+ %v4float = OpTypeVector %float 4
+%_ptr_Private_v4float = OpTypePointer Private %v4float
+ %9 = OpConstantNull %v4float
+%x_GLF_color = OpVariable %_ptr_Private_v4float Private %9
+%_ptr_Output_v4float = OpTypePointer Output %v4float
+%tint_symbol_1 = OpVariable %_ptr_Output_v4float Output %9
+ %void = OpTypeVoid
+ %S = OpTypeStruct %int %int
+%_ptr_Function_S = OpTypePointer Function %S
+ %12 = OpTypeFunction %void %_ptr_Function_S
+ %uint = OpTypeInt 32 0
+ %uint_1 = OpConstant %uint 1
+%_ptr_Function_int = OpTypePointer Function %int
+ %int_1 = OpConstant %int 1
+ %25 = OpTypeFunction %void
+%_ptr_Function_float = OpTypePointer Function %float
+ %30 = OpConstantNull %float
+ %uint_2 = OpConstant %uint 2
+%_arr_S_uint_2 = OpTypeArray %S %uint_2
+%_ptr_Function__arr_S_uint_2 = OpTypePointer Function %_arr_S_uint_2
+ %35 = OpConstantNull %_arr_S_uint_2
+ %37 = OpConstantNull %S
+ %float_5 = OpConstant %float 5
+ %uint_0 = OpConstant %uint 0
+%_ptr_Uniform_int = OpTypePointer Uniform %int
+ %bool = OpTypeBool
+ %float_0 = OpConstant %float 0
+ %false = OpConstantFalse %bool
+ %float_1 = OpConstant %float 1
+ %79 = OpConstantComposite %v4float %float_1 %float_0 %float_0 %float_1
+ %80 = OpConstantComposite %v4float %float_0 %float_0 %float_0 %float_0
+ %main_out = OpTypeStruct %v4float
+ %81 = OpTypeFunction %void %main_out
+%func_struct_S_i1_i11_ = OpFunction %void None %12
+ %arg = OpFunctionParameter %_ptr_Function_S
+ %18 = OpLabel
+ %23 = OpAccessChain %_ptr_Function_int %arg %uint_1
+ OpStore %23 %int_1
+ OpReturn
+ OpFunctionEnd
+ %main_1 = OpFunction %void None %25
+ %27 = OpLabel
+ %a = OpVariable %_ptr_Function_float Function %30
+ %b = OpVariable %_ptr_Function__arr_S_uint_2 Function %35
+ %param = OpVariable %_ptr_Function_S Function %37
+ OpStore %a %float_5
+ OpBranch %39
+ %39 = OpLabel
+ OpLoopMerge %40 %41 None
+ OpBranch %42
+ %42 = OpLabel
+ %45 = OpAccessChain %_ptr_Uniform_int %x_10 %uint_0
+ %46 = OpLoad %int %45
+ %47 = OpAccessChain %_ptr_Function_int %b %46 %uint_0
+ OpStore %47 %int_1
+ %48 = OpAccessChain %_ptr_Function_int %b %int_1 %uint_0
+ %49 = OpLoad %int %48
+ %50 = OpIEqual %bool %49 %int_1
+ OpSelectionMerge %52 None
+ OpBranchConditional %50 %53 %52
+ %53 = OpLabel
+ %54 = OpAccessChain %_ptr_Uniform_int %x_10 %uint_0
+ %55 = OpLoad %int %54
+ %56 = OpIEqual %bool %55 %int_1
+ OpSelectionMerge %57 None
+ OpBranchConditional %56 %58 %57
+ %58 = OpLabel
+ OpBranch %40
+ %57 = OpLabel
+ %59 = OpAccessChain %_ptr_Function_S %b %int_1
+ %60 = OpLoad %S %59
+ OpStore %param %60
+ %61 = OpFunctionCall %void %func_struct_S_i1_i11_ %param
+ %63 = OpLoad %S %param
+ %64 = OpAccessChain %_ptr_Function_S %b %int_1
+ OpStore %64 %63
+ %65 = OpAccessChain %_ptr_Function_int %b %int_1 %uint_1
+ %66 = OpLoad %int %65
+ %67 = OpConvertSToF %float %66
+ OpStore %a %67
+ OpBranch %52
+ %52 = OpLabel
+ OpStore %a %float_0
+ OpBranch %41
+ %41 = OpLabel
+ OpSelectionMerge %70 None
+ OpBranchConditional %false %71 %72
+ %71 = OpLabel
+ OpBranch %70
+ %72 = OpLabel
+ OpBranch %40
+ %70 = OpLabel
+ OpBranch %39
+ %40 = OpLabel
+ %73 = OpLoad %float %a
+ %74 = OpFOrdEqual %bool %73 %float_5
+ OpSelectionMerge %75 None
+ OpBranchConditional %74 %76 %77
+ %76 = OpLabel
+ OpStore %x_GLF_color %79
+ OpBranch %75
+ %77 = OpLabel
+ OpStore %x_GLF_color %80
+ OpBranch %75
+ %75 = OpLabel
+ OpReturn
+ OpFunctionEnd
+%tint_symbol_2 = OpFunction %void None %81
+%tint_symbol = OpFunctionParameter %main_out
+ %85 = OpLabel
+ %86 = OpCompositeExtract %v4float %tint_symbol 0
+ OpStore %tint_symbol_1 %86
+ OpReturn
+ OpFunctionEnd
+ %main = OpFunction %void None %25
+ %88 = OpLabel
+ %89 = OpFunctionCall %void %main_1
+ %91 = OpLoad %v4float %x_GLF_color
+ %92 = OpCompositeConstruct %main_out %91
+ %90 = OpFunctionCall %void %tint_symbol_2 %92
+ OpReturn
+ OpFunctionEnd
+1:1: The continue construct with the continue target 41[%41] is not post dominated by the back-edge block 70[%70]
+ %70 = OpLabel
+
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm.expected.wgsl b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm.expected.wgsl
new file mode 100644
index 0000000..779fafc
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.spvasm.expected.wgsl
@@ -0,0 +1,69 @@
+struct S {
+ x : i32;
+ y : i32;
+};
+
+[[block]]
+struct buf0 {
+ one : i32;
+};
+
+[[group(0), binding(0)]] var<uniform> x_10 : buf0;
+
+var<private> x_GLF_color : vec4<f32>;
+
+fn func_struct_S_i1_i11_(arg : ptr<function, S>) {
+ (*(arg)).y = 1;
+ return;
+}
+
+fn main_1() {
+ var a : f32;
+ var b : array<S, 2>;
+ var param : S;
+ a = 5.0;
+ loop {
+ let x_43 : i32 = x_10.one;
+ b[x_43].x = 1;
+ let x_46 : i32 = b[1].x;
+ if ((x_46 == 1)) {
+ let x_51 : i32 = x_10.one;
+ if ((x_51 == 1)) {
+ break;
+ }
+ let x_56 : S = b[1];
+ param = x_56;
+ func_struct_S_i1_i11_(&(param));
+ let x_58 : S = param;
+ b[1] = x_58;
+ let x_61 : i32 = b[1].y;
+ a = f32(x_61);
+ }
+ a = 0.0;
+
+ continuing {
+ if (false) {
+ } else {
+ break;
+ }
+ }
+ }
+ let x_63 : f32 = a;
+ if ((x_63 == 5.0)) {
+ x_GLF_color = vec4<f32>(1.0, 0.0, 0.0, 1.0);
+ } else {
+ x_GLF_color = vec4<f32>(0.0, 0.0, 0.0, 0.0);
+ }
+ return;
+}
+
+struct main_out {
+ [[location(0)]]
+ x_GLF_color_1 : vec4<f32>;
+};
+
+[[stage(fragment)]]
+fn main() -> main_out {
+ main_1();
+ return main_out(x_GLF_color);
+}
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl
new file mode 100644
index 0000000..779fafc
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl
@@ -0,0 +1,69 @@
+struct S {
+ x : i32;
+ y : i32;
+};
+
+[[block]]
+struct buf0 {
+ one : i32;
+};
+
+[[group(0), binding(0)]] var<uniform> x_10 : buf0;
+
+var<private> x_GLF_color : vec4<f32>;
+
+fn func_struct_S_i1_i11_(arg : ptr<function, S>) {
+ (*(arg)).y = 1;
+ return;
+}
+
+fn main_1() {
+ var a : f32;
+ var b : array<S, 2>;
+ var param : S;
+ a = 5.0;
+ loop {
+ let x_43 : i32 = x_10.one;
+ b[x_43].x = 1;
+ let x_46 : i32 = b[1].x;
+ if ((x_46 == 1)) {
+ let x_51 : i32 = x_10.one;
+ if ((x_51 == 1)) {
+ break;
+ }
+ let x_56 : S = b[1];
+ param = x_56;
+ func_struct_S_i1_i11_(&(param));
+ let x_58 : S = param;
+ b[1] = x_58;
+ let x_61 : i32 = b[1].y;
+ a = f32(x_61);
+ }
+ a = 0.0;
+
+ continuing {
+ if (false) {
+ } else {
+ break;
+ }
+ }
+ }
+ let x_63 : f32 = a;
+ if ((x_63 == 5.0)) {
+ x_GLF_color = vec4<f32>(1.0, 0.0, 0.0, 1.0);
+ } else {
+ x_GLF_color = vec4<f32>(0.0, 0.0, 0.0, 0.0);
+ }
+ return;
+}
+
+struct main_out {
+ [[location(0)]]
+ x_GLF_color_1 : vec4<f32>;
+};
+
+[[stage(fragment)]]
+fn main() -> main_out {
+ main_1();
+ return main_out(x_GLF_color);
+}
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl.expected.hlsl b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl.expected.hlsl
new file mode 100644
index 0000000..0adcd37
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl.expected.hlsl
@@ -0,0 +1,65 @@
+struct S {
+ int x;
+ int y;
+};
+
+cbuffer cbuffer_x_10 : register(b0, space0) {
+ uint4 x_10[1];
+};
+static float4 x_GLF_color = float4(0.0f, 0.0f, 0.0f, 0.0f);
+
+void func_struct_S_i1_i11_(inout S arg) {
+ arg.y = 1;
+ return;
+}
+
+void main_1() {
+ float a = 0.0f;
+ S b[2] = (S[2])0;
+ S param = (S)0;
+ a = 5.0f;
+ while (true) {
+ const int x_43 = asint(x_10[0].x);
+ b[x_43].x = 1;
+ const int x_46 = b[1].x;
+ if ((x_46 == 1)) {
+ const int x_51 = asint(x_10[0].x);
+ if ((x_51 == 1)) {
+ break;
+ }
+ const S x_56 = b[1];
+ param = x_56;
+ func_struct_S_i1_i11_(param);
+ b[1] = param;
+ const int x_61 = b[1].y;
+ a = float(x_61);
+ }
+ a = 0.0f;
+ {
+ if (false) {
+ } else {
+ break;
+ }
+ }
+ }
+ if ((a == 5.0f)) {
+ x_GLF_color = float4(1.0f, 0.0f, 0.0f, 1.0f);
+ } else {
+ x_GLF_color = float4(0.0f, 0.0f, 0.0f, 0.0f);
+ }
+ return;
+}
+
+struct main_out {
+ float4 x_GLF_color_1;
+};
+struct tint_symbol {
+ float4 x_GLF_color_1 : SV_Target0;
+};
+
+tint_symbol main() {
+ main_1();
+ const main_out tint_symbol_1 = {x_GLF_color};
+ const tint_symbol tint_symbol_3 = {tint_symbol_1.x_GLF_color_1};
+ return tint_symbol_3;
+}
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl.expected.msl b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl.expected.msl
new file mode 100644
index 0000000..a0d65d8
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl.expected.msl
@@ -0,0 +1,72 @@
+#include <metal_stdlib>
+
+using namespace metal;
+struct S {
+ int x;
+ int y;
+};
+struct buf0 {
+ /* 0x0000 */ int one;
+};
+struct tint_array_wrapper {
+ S arr[2];
+};
+struct main_out {
+ float4 x_GLF_color_1;
+};
+struct tint_symbol_1 {
+ float4 x_GLF_color_1 [[color(0)]];
+};
+
+void func_struct_S_i1_i11_(thread S* const arg) {
+ (*(arg)).y = 1;
+ return;
+}
+
+void main_1(constant buf0& x_10, thread float4* const tint_symbol_4) {
+ float a = 0.0f;
+ tint_array_wrapper b = {};
+ S param = {};
+ a = 5.0f;
+ while (true) {
+ int const x_43 = x_10.one;
+ b.arr[x_43].x = 1;
+ int const x_46 = b.arr[1].x;
+ if ((x_46 == 1)) {
+ int const x_51 = x_10.one;
+ if ((x_51 == 1)) {
+ break;
+ }
+ S const x_56 = b.arr[1];
+ param = x_56;
+ func_struct_S_i1_i11_(&(param));
+ S const x_58 = param;
+ b.arr[1] = x_58;
+ int const x_61 = b.arr[1].y;
+ a = float(x_61);
+ }
+ a = 0.0f;
+ {
+ if (false) {
+ } else {
+ break;
+ }
+ }
+ }
+ float const x_63 = a;
+ if ((x_63 == 5.0f)) {
+ *(tint_symbol_4) = float4(1.0f, 0.0f, 0.0f, 1.0f);
+ } else {
+ *(tint_symbol_4) = float4(0.0f, 0.0f, 0.0f, 0.0f);
+ }
+ return;
+}
+
+fragment tint_symbol_1 tint_symbol(constant buf0& x_10 [[buffer(0)]]) {
+ thread float4 tint_symbol_5 = 0.0f;
+ main_1(x_10, &(tint_symbol_5));
+ main_out const tint_symbol_2 = {.x_GLF_color_1=tint_symbol_5};
+ tint_symbol_1 const tint_symbol_3 = {.x_GLF_color_1=tint_symbol_2.x_GLF_color_1};
+ return tint_symbol_3;
+}
+
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl.expected.spvasm b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl.expected.spvasm
new file mode 100644
index 0000000..5969228
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl.expected.spvasm
@@ -0,0 +1,170 @@
+SKIP: FAILED
+
+; SPIR-V
+; Version: 1.3
+; Generator: Google Tint Compiler; 0
+; Bound: 93
+; Schema: 0
+ OpCapability Shader
+ OpMemoryModel Logical GLSL450
+ OpEntryPoint Fragment %main "main" %tint_symbol_1
+ OpExecutionMode %main OriginUpperLeft
+ OpName %buf0 "buf0"
+ OpMemberName %buf0 0 "one"
+ OpName %x_10 "x_10"
+ OpName %x_GLF_color "x_GLF_color"
+ OpName %tint_symbol_1 "tint_symbol_1"
+ OpName %S "S"
+ OpMemberName %S 0 "x"
+ OpMemberName %S 1 "y"
+ OpName %func_struct_S_i1_i11_ "func_struct_S_i1_i11_"
+ OpName %arg "arg"
+ OpName %main_1 "main_1"
+ OpName %a "a"
+ OpName %b "b"
+ OpName %param "param"
+ OpName %main_out "main_out"
+ OpMemberName %main_out 0 "x_GLF_color_1"
+ OpName %tint_symbol_2 "tint_symbol_2"
+ OpName %tint_symbol "tint_symbol"
+ OpName %main "main"
+ OpDecorate %buf0 Block
+ OpMemberDecorate %buf0 0 Offset 0
+ OpDecorate %x_10 NonWritable
+ OpDecorate %x_10 DescriptorSet 0
+ OpDecorate %x_10 Binding 0
+ OpDecorate %tint_symbol_1 Location 0
+ OpMemberDecorate %S 0 Offset 0
+ OpMemberDecorate %S 1 Offset 4
+ OpDecorate %_arr_S_uint_2 ArrayStride 8
+ OpMemberDecorate %main_out 0 Offset 0
+ %int = OpTypeInt 32 1
+ %buf0 = OpTypeStruct %int
+%_ptr_Uniform_buf0 = OpTypePointer Uniform %buf0
+ %x_10 = OpVariable %_ptr_Uniform_buf0 Uniform
+ %float = OpTypeFloat 32
+ %v4float = OpTypeVector %float 4
+%_ptr_Private_v4float = OpTypePointer Private %v4float
+ %9 = OpConstantNull %v4float
+%x_GLF_color = OpVariable %_ptr_Private_v4float Private %9
+%_ptr_Output_v4float = OpTypePointer Output %v4float
+%tint_symbol_1 = OpVariable %_ptr_Output_v4float Output %9
+ %void = OpTypeVoid
+ %S = OpTypeStruct %int %int
+%_ptr_Function_S = OpTypePointer Function %S
+ %12 = OpTypeFunction %void %_ptr_Function_S
+ %uint = OpTypeInt 32 0
+ %uint_1 = OpConstant %uint 1
+%_ptr_Function_int = OpTypePointer Function %int
+ %int_1 = OpConstant %int 1
+ %25 = OpTypeFunction %void
+%_ptr_Function_float = OpTypePointer Function %float
+ %30 = OpConstantNull %float
+ %uint_2 = OpConstant %uint 2
+%_arr_S_uint_2 = OpTypeArray %S %uint_2
+%_ptr_Function__arr_S_uint_2 = OpTypePointer Function %_arr_S_uint_2
+ %35 = OpConstantNull %_arr_S_uint_2
+ %37 = OpConstantNull %S
+ %float_5 = OpConstant %float 5
+ %uint_0 = OpConstant %uint 0
+%_ptr_Uniform_int = OpTypePointer Uniform %int
+ %bool = OpTypeBool
+ %float_0 = OpConstant %float 0
+ %false = OpConstantFalse %bool
+ %float_1 = OpConstant %float 1
+ %79 = OpConstantComposite %v4float %float_1 %float_0 %float_0 %float_1
+ %80 = OpConstantComposite %v4float %float_0 %float_0 %float_0 %float_0
+ %main_out = OpTypeStruct %v4float
+ %81 = OpTypeFunction %void %main_out
+%func_struct_S_i1_i11_ = OpFunction %void None %12
+ %arg = OpFunctionParameter %_ptr_Function_S
+ %18 = OpLabel
+ %23 = OpAccessChain %_ptr_Function_int %arg %uint_1
+ OpStore %23 %int_1
+ OpReturn
+ OpFunctionEnd
+ %main_1 = OpFunction %void None %25
+ %27 = OpLabel
+ %a = OpVariable %_ptr_Function_float Function %30
+ %b = OpVariable %_ptr_Function__arr_S_uint_2 Function %35
+ %param = OpVariable %_ptr_Function_S Function %37
+ OpStore %a %float_5
+ OpBranch %39
+ %39 = OpLabel
+ OpLoopMerge %40 %41 None
+ OpBranch %42
+ %42 = OpLabel
+ %45 = OpAccessChain %_ptr_Uniform_int %x_10 %uint_0
+ %46 = OpLoad %int %45
+ %47 = OpAccessChain %_ptr_Function_int %b %46 %uint_0
+ OpStore %47 %int_1
+ %48 = OpAccessChain %_ptr_Function_int %b %int_1 %uint_0
+ %49 = OpLoad %int %48
+ %50 = OpIEqual %bool %49 %int_1
+ OpSelectionMerge %52 None
+ OpBranchConditional %50 %53 %52
+ %53 = OpLabel
+ %54 = OpAccessChain %_ptr_Uniform_int %x_10 %uint_0
+ %55 = OpLoad %int %54
+ %56 = OpIEqual %bool %55 %int_1
+ OpSelectionMerge %57 None
+ OpBranchConditional %56 %58 %57
+ %58 = OpLabel
+ OpBranch %40
+ %57 = OpLabel
+ %59 = OpAccessChain %_ptr_Function_S %b %int_1
+ %60 = OpLoad %S %59
+ OpStore %param %60
+ %61 = OpFunctionCall %void %func_struct_S_i1_i11_ %param
+ %63 = OpLoad %S %param
+ %64 = OpAccessChain %_ptr_Function_S %b %int_1
+ OpStore %64 %63
+ %65 = OpAccessChain %_ptr_Function_int %b %int_1 %uint_1
+ %66 = OpLoad %int %65
+ %67 = OpConvertSToF %float %66
+ OpStore %a %67
+ OpBranch %52
+ %52 = OpLabel
+ OpStore %a %float_0
+ OpBranch %41
+ %41 = OpLabel
+ OpSelectionMerge %70 None
+ OpBranchConditional %false %71 %72
+ %71 = OpLabel
+ OpBranch %70
+ %72 = OpLabel
+ OpBranch %40
+ %70 = OpLabel
+ OpBranch %39
+ %40 = OpLabel
+ %73 = OpLoad %float %a
+ %74 = OpFOrdEqual %bool %73 %float_5
+ OpSelectionMerge %75 None
+ OpBranchConditional %74 %76 %77
+ %76 = OpLabel
+ OpStore %x_GLF_color %79
+ OpBranch %75
+ %77 = OpLabel
+ OpStore %x_GLF_color %80
+ OpBranch %75
+ %75 = OpLabel
+ OpReturn
+ OpFunctionEnd
+%tint_symbol_2 = OpFunction %void None %81
+%tint_symbol = OpFunctionParameter %main_out
+ %85 = OpLabel
+ %86 = OpCompositeExtract %v4float %tint_symbol 0
+ OpStore %tint_symbol_1 %86
+ OpReturn
+ OpFunctionEnd
+ %main = OpFunction %void None %25
+ %88 = OpLabel
+ %89 = OpFunctionCall %void %main_1
+ %91 = OpLoad %v4float %x_GLF_color
+ %92 = OpCompositeConstruct %main_out %91
+ %90 = OpFunctionCall %void %tint_symbol_2 %92
+ OpReturn
+ OpFunctionEnd
+1:1: The continue construct with the continue target 41[%41] is not post dominated by the back-edge block 70[%70]
+ %70 = OpLabel
+
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl.expected.wgsl b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl.expected.wgsl
new file mode 100644
index 0000000..779fafc
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-reduce-load-replace-extract/0-opt.wgsl.expected.wgsl
@@ -0,0 +1,69 @@
+struct S {
+ x : i32;
+ y : i32;
+};
+
+[[block]]
+struct buf0 {
+ one : i32;
+};
+
+[[group(0), binding(0)]] var<uniform> x_10 : buf0;
+
+var<private> x_GLF_color : vec4<f32>;
+
+fn func_struct_S_i1_i11_(arg : ptr<function, S>) {
+ (*(arg)).y = 1;
+ return;
+}
+
+fn main_1() {
+ var a : f32;
+ var b : array<S, 2>;
+ var param : S;
+ a = 5.0;
+ loop {
+ let x_43 : i32 = x_10.one;
+ b[x_43].x = 1;
+ let x_46 : i32 = b[1].x;
+ if ((x_46 == 1)) {
+ let x_51 : i32 = x_10.one;
+ if ((x_51 == 1)) {
+ break;
+ }
+ let x_56 : S = b[1];
+ param = x_56;
+ func_struct_S_i1_i11_(&(param));
+ let x_58 : S = param;
+ b[1] = x_58;
+ let x_61 : i32 = b[1].y;
+ a = f32(x_61);
+ }
+ a = 0.0;
+
+ continuing {
+ if (false) {
+ } else {
+ break;
+ }
+ }
+ }
+ let x_63 : f32 = a;
+ if ((x_63 == 5.0)) {
+ x_GLF_color = vec4<f32>(1.0, 0.0, 0.0, 1.0);
+ } else {
+ x_GLF_color = vec4<f32>(0.0, 0.0, 0.0, 0.0);
+ }
+ return;
+}
+
+struct main_out {
+ [[location(0)]]
+ x_GLF_color_1 : vec4<f32>;
+};
+
+[[stage(fragment)]]
+fn main() -> main_out {
+ main_1();
+ return main_out(x_GLF_color);
+}