blob: 2a95fd356f2c849ce4b47be4386627c78dc60746 [file] [log] [blame]
#!amber
# Copyright 2020 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# A test for a bug found by GraphicsFuzz.
# Short description: A fragment shader with nested if and conditional statement
# The test passes because both shaders render the same image.
SHADER vertex reference_vertex_shader PASSTHROUGH
# reference_fragment_shader is derived from the following GLSL:
# #version 320 es
# precision highp float;
#
# precision highp int;
#
# layout(location = 0) out vec4 _GLF_color;
#
# struct BST
# {
# int data;
# int leftIndex;
# int rightIndex;
# };
#
# BST tree[10];
#
# void makeTreeNode(inout BST tree, int data)
# {
# tree.data = data;
# tree.leftIndex = -1;
# tree.rightIndex = -1;
# }
# void insert(int treeIndex, int data)
# {
# int baseIndex = 0;
# while (baseIndex <= treeIndex)
# {
# if (data <= tree[baseIndex].data)
# {
# if (tree[baseIndex].leftIndex == -1)
# {
# tree[baseIndex].leftIndex = treeIndex;
# makeTreeNode(tree[treeIndex], data);
# return;
# }
# else
# {
# baseIndex = tree[baseIndex].leftIndex;
# continue;
# }
# }
# else
# {
# if (tree[baseIndex].rightIndex == -1)
# {
# tree[baseIndex].rightIndex = treeIndex;
# makeTreeNode(tree[treeIndex], data);
# return;
# }
# else
# {
# baseIndex = tree[baseIndex].rightIndex;
# continue;
# }
# }
# }
# }
# int search(int target)
# {
# BST currentNode;
# int index = 0;
# while (index != -1)
# {
# currentNode = tree[index];
# if (currentNode.data == target)
# {
# return target;
# }
# index = target > currentNode.data ? currentNode.rightIndex : currentNode.leftIndex;
# }
# return -1;
# }
# void main()
# {
# int treeIndex = 0;
# makeTreeNode(tree[0], 9);
# treeIndex++;
# insert(treeIndex, 5);
# treeIndex++;
# insert(treeIndex, 12);
# treeIndex++;
# insert(treeIndex, 15);
# treeIndex++;
# insert(treeIndex, 7);
# treeIndex++;
# insert(treeIndex, 8);
# treeIndex++;
# insert(treeIndex, 2);
# treeIndex++;
# insert(treeIndex, 6);
# treeIndex++;
# insert(treeIndex, 17);
# treeIndex++;
# insert(treeIndex, 13);
# int count = 0;
# for (int i = 0; i < 20; i++)
# {
# int result = search(i);
# switch (i)
# {
# case 9:
# case 5:
# case 12:
# case 15:
# case 7:
# case 8:
# case 2:
# case 6:
# case 17:
# case 13:
# if (result == i)
# {
# count++;
# }
# break;
# default:
# if (result == -1)
# {
# count++;
# }
# break;
# }
# }
# if (count == 20)
# {
# _GLF_color = vec4(1.0, 0.0, 0.0, 1.0);
# }
# else
# {
# _GLF_color = vec4(0.0, 0.0, 1.0, 1.0);
# }
# }
SHADER fragment reference_fragment_shader SPIRV-ASM TARGET_ENV spv1.0
; SPIR-V
; Version: 1.0
; Generator: Khronos Glslang Reference Front End; 10
; Bound: 260
; Schema: 0
OpCapability Shader
%1 = OpExtInstImport "GLSL.std.450"
OpMemoryModel Logical GLSL450
OpEntryPoint Fragment %4 "main" %254
OpExecutionMode %4 OriginUpperLeft
OpSource ESSL 320
OpName %4 "main"
OpName %7 "BST"
OpMemberName %7 0 "data"
OpMemberName %7 1 "leftIndex"
OpMemberName %7 2 "rightIndex"
OpName %13 "makeTreeNode(struct-BST-i1-i1-i11;i1;"
OpName %11 "tree"
OpName %12 "data"
OpName %18 "insert(i1;i1;"
OpName %16 "treeIndex"
OpName %17 "data"
OpName %22 "search(i1;"
OpName %21 "target"
OpName %32 "baseIndex"
OpName %47 "tree"
OpName %65 "param"
OpName %69 "param"
OpName %91 "param"
OpName %94 "param"
OpName %105 "index"
OpName %113 "currentNode"
OpName %140 "treeIndex"
OpName %142 "param"
OpName %145 "param"
OpName %152 "param"
OpName %154 "param"
OpName %159 "param"
OpName %161 "param"
OpName %166 "param"
OpName %168 "param"
OpName %173 "param"
OpName %175 "param"
OpName %180 "param"
OpName %182 "param"
OpName %186 "param"
OpName %188 "param"
OpName %193 "param"
OpName %195 "param"
OpName %200 "param"
OpName %202 "param"
OpName %207 "param"
OpName %209 "param"
OpName %211 "count"
OpName %212 "i"
OpName %221 "result"
OpName %222 "param"
OpName %254 "_GLF_color"
OpDecorate %254 Location 0
%2 = OpTypeVoid
%3 = OpTypeFunction %2
%6 = OpTypeInt 32 1
%7 = OpTypeStruct %6 %6 %6
%8 = OpTypePointer Function %7
%9 = OpTypePointer Function %6
%10 = OpTypeFunction %2 %8 %9
%15 = OpTypeFunction %2 %9 %9
%20 = OpTypeFunction %6 %9
%24 = OpConstant %6 0
%27 = OpConstant %6 1
%28 = OpConstant %6 -1
%30 = OpConstant %6 2
%40 = OpTypeBool
%43 = OpTypeInt 32 0
%44 = OpConstant %43 10
%45 = OpTypeArray %7 %44
%46 = OpTypePointer Private %45
%47 = OpVariable %46 Private
%49 = OpTypePointer Private %6
%66 = OpTypePointer Private %7
%141 = OpConstant %6 9
%151 = OpConstant %6 5
%158 = OpConstant %6 12
%165 = OpConstant %6 15
%172 = OpConstant %6 7
%179 = OpConstant %6 8
%192 = OpConstant %6 6
%199 = OpConstant %6 17
%206 = OpConstant %6 13
%219 = OpConstant %6 20
%251 = OpTypeFloat 32
%252 = OpTypeVector %251 4
%253 = OpTypePointer Output %252
%254 = OpVariable %253 Output
%255 = OpConstant %251 1
%256 = OpConstant %251 0
%257 = OpConstantComposite %252 %255 %256 %256 %255
%259 = OpConstantComposite %252 %256 %256 %255 %255
%4 = OpFunction %2 None %3
%5 = OpLabel
%140 = OpVariable %9 Function
%142 = OpVariable %8 Function
%145 = OpVariable %9 Function
%152 = OpVariable %9 Function
%154 = OpVariable %9 Function
%159 = OpVariable %9 Function
%161 = OpVariable %9 Function
%166 = OpVariable %9 Function
%168 = OpVariable %9 Function
%173 = OpVariable %9 Function
%175 = OpVariable %9 Function
%180 = OpVariable %9 Function
%182 = OpVariable %9 Function
%186 = OpVariable %9 Function
%188 = OpVariable %9 Function
%193 = OpVariable %9 Function
%195 = OpVariable %9 Function
%200 = OpVariable %9 Function
%202 = OpVariable %9 Function
%207 = OpVariable %9 Function
%209 = OpVariable %9 Function
%211 = OpVariable %9 Function
%212 = OpVariable %9 Function
%221 = OpVariable %9 Function
%222 = OpVariable %9 Function
OpStore %140 %24
%143 = OpAccessChain %66 %47 %24
%144 = OpLoad %7 %143
OpStore %142 %144
OpStore %145 %141
%146 = OpFunctionCall %2 %13 %142 %145
%147 = OpLoad %7 %142
%148 = OpAccessChain %66 %47 %24
OpStore %148 %147
%149 = OpLoad %6 %140
%150 = OpIAdd %6 %149 %27
OpStore %140 %150
%153 = OpLoad %6 %140
OpStore %152 %153
OpStore %154 %151
%155 = OpFunctionCall %2 %18 %152 %154
%156 = OpLoad %6 %140
%157 = OpIAdd %6 %156 %27
OpStore %140 %157
%160 = OpLoad %6 %140
OpStore %159 %160
OpStore %161 %158
%162 = OpFunctionCall %2 %18 %159 %161
%163 = OpLoad %6 %140
%164 = OpIAdd %6 %163 %27
OpStore %140 %164
%167 = OpLoad %6 %140
OpStore %166 %167
OpStore %168 %165
%169 = OpFunctionCall %2 %18 %166 %168
%170 = OpLoad %6 %140
%171 = OpIAdd %6 %170 %27
OpStore %140 %171
%174 = OpLoad %6 %140
OpStore %173 %174
OpStore %175 %172
%176 = OpFunctionCall %2 %18 %173 %175
%177 = OpLoad %6 %140
%178 = OpIAdd %6 %177 %27
OpStore %140 %178
%181 = OpLoad %6 %140
OpStore %180 %181
OpStore %182 %179
%183 = OpFunctionCall %2 %18 %180 %182
%184 = OpLoad %6 %140
%185 = OpIAdd %6 %184 %27
OpStore %140 %185
%187 = OpLoad %6 %140
OpStore %186 %187
OpStore %188 %30
%189 = OpFunctionCall %2 %18 %186 %188
%190 = OpLoad %6 %140
%191 = OpIAdd %6 %190 %27
OpStore %140 %191
%194 = OpLoad %6 %140
OpStore %193 %194
OpStore %195 %192
%196 = OpFunctionCall %2 %18 %193 %195
%197 = OpLoad %6 %140
%198 = OpIAdd %6 %197 %27
OpStore %140 %198
%201 = OpLoad %6 %140
OpStore %200 %201
OpStore %202 %199
%203 = OpFunctionCall %2 %18 %200 %202
%204 = OpLoad %6 %140
%205 = OpIAdd %6 %204 %27
OpStore %140 %205
%208 = OpLoad %6 %140
OpStore %207 %208
OpStore %209 %206
%210 = OpFunctionCall %2 %18 %207 %209
OpStore %211 %24
OpStore %212 %24
OpBranch %213
%213 = OpLabel
OpLoopMerge %215 %216 None
OpBranch %217
%217 = OpLabel
%218 = OpLoad %6 %212
%220 = OpSLessThan %40 %218 %219
OpBranchConditional %220 %214 %215
%214 = OpLabel
%223 = OpLoad %6 %212
OpStore %222 %223
%224 = OpFunctionCall %6 %22 %222
OpStore %221 %224
%225 = OpLoad %6 %212
OpSelectionMerge %228 None
OpSwitch %225 %227 9 %226 5 %226 12 %226 15 %226 7 %226 8 %226 2 %226 6 %226 17 %226 13 %226
%227 = OpLabel
%237 = OpLoad %6 %221
%238 = OpIEqual %40 %237 %28
OpSelectionMerge %240 None
OpBranchConditional %238 %239 %240
%239 = OpLabel
%241 = OpLoad %6 %211
%242 = OpIAdd %6 %241 %27
OpStore %211 %242
OpBranch %240
%240 = OpLabel
OpBranch %228
%226 = OpLabel
%229 = OpLoad %6 %221
%230 = OpLoad %6 %212
%231 = OpIEqual %40 %229 %230
OpSelectionMerge %233 None
OpBranchConditional %231 %232 %233
%232 = OpLabel
%234 = OpLoad %6 %211
%235 = OpIAdd %6 %234 %27
OpStore %211 %235
OpBranch %233
%233 = OpLabel
OpBranch %228
%228 = OpLabel
OpBranch %216
%216 = OpLabel
%245 = OpLoad %6 %212
%246 = OpIAdd %6 %245 %27
OpStore %212 %246
OpBranch %213
%215 = OpLabel
%247 = OpLoad %6 %211
%248 = OpIEqual %40 %247 %219
OpSelectionMerge %250 None
OpBranchConditional %248 %249 %258
%249 = OpLabel
OpStore %254 %257
OpBranch %250
%258 = OpLabel
OpStore %254 %259
OpBranch %250
%250 = OpLabel
OpReturn
OpFunctionEnd
%13 = OpFunction %2 None %10
%11 = OpFunctionParameter %8
%12 = OpFunctionParameter %9
%14 = OpLabel
%25 = OpLoad %6 %12
%26 = OpAccessChain %9 %11 %24
OpStore %26 %25
%29 = OpAccessChain %9 %11 %27
OpStore %29 %28
%31 = OpAccessChain %9 %11 %30
OpStore %31 %28
OpReturn
OpFunctionEnd
%18 = OpFunction %2 None %15
%16 = OpFunctionParameter %9
%17 = OpFunctionParameter %9
%19 = OpLabel
%32 = OpVariable %9 Function
%65 = OpVariable %8 Function
%69 = OpVariable %9 Function
%91 = OpVariable %8 Function
%94 = OpVariable %9 Function
OpStore %32 %24
OpBranch %33
%33 = OpLabel
OpLoopMerge %35 %36 None
OpBranch %37
%37 = OpLabel
%38 = OpLoad %6 %32
%39 = OpLoad %6 %16
%41 = OpSLessThanEqual %40 %38 %39
OpBranchConditional %41 %34 %35
%34 = OpLabel
%42 = OpLoad %6 %17
%48 = OpLoad %6 %32
%50 = OpAccessChain %49 %47 %48 %24
%51 = OpLoad %6 %50
%52 = OpSLessThanEqual %40 %42 %51
OpSelectionMerge %54 None
OpBranchConditional %52 %53 %80
%53 = OpLabel
%55 = OpLoad %6 %32
%56 = OpAccessChain %49 %47 %55 %27
%57 = OpLoad %6 %56
%58 = OpIEqual %40 %57 %28
OpSelectionMerge %60 None
OpBranchConditional %58 %59 %75
%59 = OpLabel
%61 = OpLoad %6 %32
%62 = OpLoad %6 %16
%63 = OpAccessChain %49 %47 %61 %27
OpStore %63 %62
%64 = OpLoad %6 %16
%67 = OpAccessChain %66 %47 %64
%68 = OpLoad %7 %67
OpStore %65 %68
%70 = OpLoad %6 %17
OpStore %69 %70
%71 = OpFunctionCall %2 %13 %65 %69
%72 = OpLoad %7 %65
%73 = OpAccessChain %66 %47 %64
OpStore %73 %72
OpReturn
%75 = OpLabel
%76 = OpLoad %6 %32
%77 = OpAccessChain %49 %47 %76 %27
%78 = OpLoad %6 %77
OpStore %32 %78
OpBranch %36
%60 = OpLabel
OpUnreachable
%80 = OpLabel
%81 = OpLoad %6 %32
%82 = OpAccessChain %49 %47 %81 %30
%83 = OpLoad %6 %82
%84 = OpIEqual %40 %83 %28
OpSelectionMerge %86 None
OpBranchConditional %84 %85 %100
%85 = OpLabel
%87 = OpLoad %6 %32
%88 = OpLoad %6 %16
%89 = OpAccessChain %49 %47 %87 %30
OpStore %89 %88
%90 = OpLoad %6 %16
%92 = OpAccessChain %66 %47 %90
%93 = OpLoad %7 %92
OpStore %91 %93
%95 = OpLoad %6 %17
OpStore %94 %95
%96 = OpFunctionCall %2 %13 %91 %94
%97 = OpLoad %7 %91
%98 = OpAccessChain %66 %47 %90
OpStore %98 %97
OpReturn
%100 = OpLabel
%101 = OpLoad %6 %32
%102 = OpAccessChain %49 %47 %101 %30
%103 = OpLoad %6 %102
OpStore %32 %103
OpBranch %36
%86 = OpLabel
OpUnreachable
%54 = OpLabel
OpUnreachable
%36 = OpLabel
OpBranch %33
%35 = OpLabel
OpReturn
OpFunctionEnd
%22 = OpFunction %6 None %20
%21 = OpFunctionParameter %9
%23 = OpLabel
%105 = OpVariable %9 Function
%113 = OpVariable %8 Function
%129 = OpVariable %9 Function
OpStore %105 %24
OpBranch %106
%106 = OpLabel
OpLoopMerge %108 %109 None
OpBranch %110
%110 = OpLabel
%111 = OpLoad %6 %105
%112 = OpINotEqual %40 %111 %28
OpBranchConditional %112 %107 %108
%107 = OpLabel
%114 = OpLoad %6 %105
%115 = OpAccessChain %66 %47 %114
%116 = OpLoad %7 %115
OpStore %113 %116
%117 = OpAccessChain %9 %113 %24
%118 = OpLoad %6 %117
%119 = OpLoad %6 %21
%120 = OpIEqual %40 %118 %119
OpSelectionMerge %122 None
OpBranchConditional %120 %121 %122
%121 = OpLabel
%123 = OpLoad %6 %21
OpReturnValue %123
%122 = OpLabel
%125 = OpLoad %6 %21
%126 = OpAccessChain %9 %113 %24
%127 = OpLoad %6 %126
%128 = OpSGreaterThan %40 %125 %127
OpSelectionMerge %131 None
OpBranchConditional %128 %130 %134
%130 = OpLabel
%132 = OpAccessChain %9 %113 %30
%133 = OpLoad %6 %132
OpStore %129 %133
OpBranch %131
%134 = OpLabel
%135 = OpAccessChain %9 %113 %27
%136 = OpLoad %6 %135
OpStore %129 %136
OpBranch %131
%131 = OpLabel
%137 = OpLoad %6 %129
OpStore %105 %137
OpBranch %109
%109 = OpLabel
OpBranch %106
%108 = OpLabel
OpReturnValue %28
OpFunctionEnd
END
BUFFER reference_framebuffer FORMAT B8G8R8A8_UNORM
PIPELINE graphics reference_pipeline
ATTACH reference_vertex_shader
ATTACH reference_fragment_shader
FRAMEBUFFER_SIZE 256 256
BIND BUFFER reference_framebuffer AS color LOCATION 0
END
CLEAR_COLOR reference_pipeline 0 0 0 255
CLEAR reference_pipeline
RUN reference_pipeline DRAW_RECT POS 0 0 SIZE 256 256
SHADER vertex variant_vertex_shader PASSTHROUGH
# variant_fragment_shader is derived from the following GLSL:
# #version 320 es
# precision highp float;
#
# precision highp int;
#
# layout(set = 0, binding = 0) uniform buf0
# {
# vec2 injectionSwitch; // x == 0.0, y == 1.0
# };
# layout(location = 0) out vec4 _GLF_color;
#
# struct BST
# {
# int data;
# int leftIndex;
# int rightIndex;
# };
#
# BST tree[10];
#
# void makeTreeNode(inout BST tree, int data)
# {
# tree.data = data;
# tree.leftIndex = -1;
# tree.rightIndex = -1;
# }
# void insert(int treeIndex, int data)
# {
# int baseIndex = 0;
# while (baseIndex <= treeIndex)
# {
# if (data <= tree[baseIndex].data)
# {
# if (tree[baseIndex].leftIndex == -1)
# {
# tree[baseIndex].leftIndex = treeIndex;
# // Always true.
# if (injectionSwitch.x < injectionSwitch.y)
# {
# makeTreeNode(tree[treeIndex], data);
# }
# // Always true.
# if (injectionSwitch.x < injectionSwitch.y)
# {
# return;
# }
# }
# else
# {
# baseIndex = tree[baseIndex].leftIndex;
# continue;
# }
# }
# else
# {
# // Conditional statement's result is irrelevant.
# if ((injectionSwitch.x < injectionSwitch.y ? tree[baseIndex].rightIndex : tree[baseIndex].rightIndex) == -1)
# {
# tree[baseIndex].rightIndex = treeIndex;
# makeTreeNode(tree[treeIndex], data);
# return;
# }
# else
# {
# baseIndex = tree[baseIndex].rightIndex;
# continue;
# }
# }
# // Always false.
# if (injectionSwitch.x > injectionSwitch.y)
# {
# return;
# }
# }
# }
# int search(int target)
# {
# BST currentNode;
# int index = 0;
# while (index != -1)
# {
# currentNode = tree[index];
# if (currentNode.data == target)
# {
# return target;
# }
# index = target > currentNode.data ? currentNode.rightIndex : currentNode.leftIndex;
# }
# return -1;
# }
# void main()
# {
# int treeIndex = 0;
# makeTreeNode(tree[0], 9);
# treeIndex++;
# insert(treeIndex, 5);
# treeIndex++;
# insert(treeIndex, 12);
# treeIndex++;
# insert(treeIndex, 15);
# treeIndex++;
# insert(treeIndex, 7);
# treeIndex++;
# insert(treeIndex, 8);
# treeIndex++;
# insert(treeIndex, 2);
# treeIndex++;
# insert(treeIndex, 6);
# treeIndex++;
# insert(treeIndex, 17);
# treeIndex++;
# insert(treeIndex, 13);
# int count = 0;
# for (int i = 0; i < 20; i++)
# {
# int result = search(i);
# switch (i)
# {
# case 9:
# case 5:
# case 12:
# case 15:
# case 7:
# case 8:
# case 2:
# case 6:
# case 17:
# case 13:
# if (result == i)
# {
# count++;
# }
# break;
# default:
# if (result == -1)
# {
# count++;
# }
# break;
# }
# }
# if (count == 20)
# {
# _GLF_color = vec4(1.0, 0.0, 0.0, 1.0);
# }
# else
# {
# _GLF_color = vec4(0.0, 0.0, 1.0, 1.0);
# }
# }
SHADER fragment variant_fragment_shader SPIRV-ASM TARGET_ENV spv1.0
; SPIR-V
; Version: 1.0
; Generator: Khronos Glslang Reference Front End; 10
; Bound: 302
; Schema: 0
OpCapability Shader
%1 = OpExtInstImport "GLSL.std.450"
OpMemoryModel Logical GLSL450
OpEntryPoint Fragment %4 "main" %296
OpExecutionMode %4 OriginUpperLeft
OpSource ESSL 320
OpName %4 "main"
OpName %7 "BST"
OpMemberName %7 0 "data"
OpMemberName %7 1 "leftIndex"
OpMemberName %7 2 "rightIndex"
OpName %13 "makeTreeNode(struct-BST-i1-i1-i11;i1;"
OpName %11 "tree"
OpName %12 "data"
OpName %18 "insert(i1;i1;"
OpName %16 "treeIndex"
OpName %17 "data"
OpName %22 "search(i1;"
OpName %21 "target"
OpName %32 "baseIndex"
OpName %47 "tree"
OpName %66 "buf0"
OpMemberName %66 0 "injectionSwitch"
OpName %68 ""
OpName %80 "param"
OpName %84 "param"
OpName %126 "param"
OpName %129 "param"
OpName %148 "index"
OpName %156 "currentNode"
OpName %183 "treeIndex"
OpName %185 "param"
OpName %188 "param"
OpName %195 "param"
OpName %197 "param"
OpName %202 "param"
OpName %204 "param"
OpName %209 "param"
OpName %211 "param"
OpName %216 "param"
OpName %218 "param"
OpName %223 "param"
OpName %225 "param"
OpName %229 "param"
OpName %231 "param"
OpName %236 "param"
OpName %238 "param"
OpName %243 "param"
OpName %245 "param"
OpName %250 "param"
OpName %252 "param"
OpName %254 "count"
OpName %255 "i"
OpName %264 "result"
OpName %265 "param"
OpName %296 "_GLF_color"
OpMemberDecorate %66 0 Offset 0
OpDecorate %66 Block
OpDecorate %68 DescriptorSet 0
OpDecorate %68 Binding 0
OpDecorate %296 Location 0
%2 = OpTypeVoid
%3 = OpTypeFunction %2
%6 = OpTypeInt 32 1
%7 = OpTypeStruct %6 %6 %6
%8 = OpTypePointer Function %7
%9 = OpTypePointer Function %6
%10 = OpTypeFunction %2 %8 %9
%15 = OpTypeFunction %2 %9 %9
%20 = OpTypeFunction %6 %9
%24 = OpConstant %6 0
%27 = OpConstant %6 1
%28 = OpConstant %6 -1
%30 = OpConstant %6 2
%40 = OpTypeBool
%43 = OpTypeInt 32 0
%44 = OpConstant %43 10
%45 = OpTypeArray %7 %44
%46 = OpTypePointer Private %45
%47 = OpVariable %46 Private
%49 = OpTypePointer Private %6
%64 = OpTypeFloat 32
%65 = OpTypeVector %64 2
%66 = OpTypeStruct %65
%67 = OpTypePointer Uniform %66
%68 = OpVariable %67 Uniform
%69 = OpConstant %43 0
%70 = OpTypePointer Uniform %64
%73 = OpConstant %43 1
%81 = OpTypePointer Private %7
%184 = OpConstant %6 9
%194 = OpConstant %6 5
%201 = OpConstant %6 12
%208 = OpConstant %6 15
%215 = OpConstant %6 7
%222 = OpConstant %6 8
%235 = OpConstant %6 6
%242 = OpConstant %6 17
%249 = OpConstant %6 13
%262 = OpConstant %6 20
%294 = OpTypeVector %64 4
%295 = OpTypePointer Output %294
%296 = OpVariable %295 Output
%297 = OpConstant %64 1
%298 = OpConstant %64 0
%299 = OpConstantComposite %294 %297 %298 %298 %297
%301 = OpConstantComposite %294 %298 %298 %297 %297
%4 = OpFunction %2 None %3
%5 = OpLabel
%183 = OpVariable %9 Function
%185 = OpVariable %8 Function
%188 = OpVariable %9 Function
%195 = OpVariable %9 Function
%197 = OpVariable %9 Function
%202 = OpVariable %9 Function
%204 = OpVariable %9 Function
%209 = OpVariable %9 Function
%211 = OpVariable %9 Function
%216 = OpVariable %9 Function
%218 = OpVariable %9 Function
%223 = OpVariable %9 Function
%225 = OpVariable %9 Function
%229 = OpVariable %9 Function
%231 = OpVariable %9 Function
%236 = OpVariable %9 Function
%238 = OpVariable %9 Function
%243 = OpVariable %9 Function
%245 = OpVariable %9 Function
%250 = OpVariable %9 Function
%252 = OpVariable %9 Function
%254 = OpVariable %9 Function
%255 = OpVariable %9 Function
%264 = OpVariable %9 Function
%265 = OpVariable %9 Function
OpStore %183 %24
%186 = OpAccessChain %81 %47 %24
%187 = OpLoad %7 %186
OpStore %185 %187
OpStore %188 %184
%189 = OpFunctionCall %2 %13 %185 %188
%190 = OpLoad %7 %185
%191 = OpAccessChain %81 %47 %24
OpStore %191 %190
%192 = OpLoad %6 %183
%193 = OpIAdd %6 %192 %27
OpStore %183 %193
%196 = OpLoad %6 %183
OpStore %195 %196
OpStore %197 %194
%198 = OpFunctionCall %2 %18 %195 %197
%199 = OpLoad %6 %183
%200 = OpIAdd %6 %199 %27
OpStore %183 %200
%203 = OpLoad %6 %183
OpStore %202 %203
OpStore %204 %201
%205 = OpFunctionCall %2 %18 %202 %204
%206 = OpLoad %6 %183
%207 = OpIAdd %6 %206 %27
OpStore %183 %207
%210 = OpLoad %6 %183
OpStore %209 %210
OpStore %211 %208
%212 = OpFunctionCall %2 %18 %209 %211
%213 = OpLoad %6 %183
%214 = OpIAdd %6 %213 %27
OpStore %183 %214
%217 = OpLoad %6 %183
OpStore %216 %217
OpStore %218 %215
%219 = OpFunctionCall %2 %18 %216 %218
%220 = OpLoad %6 %183
%221 = OpIAdd %6 %220 %27
OpStore %183 %221
%224 = OpLoad %6 %183
OpStore %223 %224
OpStore %225 %222
%226 = OpFunctionCall %2 %18 %223 %225
%227 = OpLoad %6 %183
%228 = OpIAdd %6 %227 %27
OpStore %183 %228
%230 = OpLoad %6 %183
OpStore %229 %230
OpStore %231 %30
%232 = OpFunctionCall %2 %18 %229 %231
%233 = OpLoad %6 %183
%234 = OpIAdd %6 %233 %27
OpStore %183 %234
%237 = OpLoad %6 %183
OpStore %236 %237
OpStore %238 %235
%239 = OpFunctionCall %2 %18 %236 %238
%240 = OpLoad %6 %183
%241 = OpIAdd %6 %240 %27
OpStore %183 %241
%244 = OpLoad %6 %183
OpStore %243 %244
OpStore %245 %242
%246 = OpFunctionCall %2 %18 %243 %245
%247 = OpLoad %6 %183
%248 = OpIAdd %6 %247 %27
OpStore %183 %248
%251 = OpLoad %6 %183
OpStore %250 %251
OpStore %252 %249
%253 = OpFunctionCall %2 %18 %250 %252
OpStore %254 %24
OpStore %255 %24
OpBranch %256
%256 = OpLabel
OpLoopMerge %258 %259 None
OpBranch %260
%260 = OpLabel
%261 = OpLoad %6 %255
%263 = OpSLessThan %40 %261 %262
OpBranchConditional %263 %257 %258
%257 = OpLabel
%266 = OpLoad %6 %255
OpStore %265 %266
%267 = OpFunctionCall %6 %22 %265
OpStore %264 %267
%268 = OpLoad %6 %255
OpSelectionMerge %271 None
OpSwitch %268 %270 9 %269 5 %269 12 %269 15 %269 7 %269 8 %269 2 %269 6 %269 17 %269 13 %269
%270 = OpLabel
%280 = OpLoad %6 %264
%281 = OpIEqual %40 %280 %28
OpSelectionMerge %283 None
OpBranchConditional %281 %282 %283
%282 = OpLabel
%284 = OpLoad %6 %254
%285 = OpIAdd %6 %284 %27
OpStore %254 %285
OpBranch %283
%283 = OpLabel
OpBranch %271
%269 = OpLabel
%272 = OpLoad %6 %264
%273 = OpLoad %6 %255
%274 = OpIEqual %40 %272 %273
OpSelectionMerge %276 None
OpBranchConditional %274 %275 %276
%275 = OpLabel
%277 = OpLoad %6 %254
%278 = OpIAdd %6 %277 %27
OpStore %254 %278
OpBranch %276
%276 = OpLabel
OpBranch %271
%271 = OpLabel
OpBranch %259
%259 = OpLabel
%288 = OpLoad %6 %255
%289 = OpIAdd %6 %288 %27
OpStore %255 %289
OpBranch %256
%258 = OpLabel
%290 = OpLoad %6 %254
%291 = OpIEqual %40 %290 %262
OpSelectionMerge %293 None
OpBranchConditional %291 %292 %300
%292 = OpLabel
OpStore %296 %299
OpBranch %293
%300 = OpLabel
OpStore %296 %301
OpBranch %293
%293 = OpLabel
OpReturn
OpFunctionEnd
%13 = OpFunction %2 None %10
%11 = OpFunctionParameter %8
%12 = OpFunctionParameter %9
%14 = OpLabel
%25 = OpLoad %6 %12
%26 = OpAccessChain %9 %11 %24
OpStore %26 %25
%29 = OpAccessChain %9 %11 %27
OpStore %29 %28
%31 = OpAccessChain %9 %11 %30
OpStore %31 %28
OpReturn
OpFunctionEnd
%18 = OpFunction %2 None %15
%16 = OpFunctionParameter %9
%17 = OpFunctionParameter %9
%19 = OpLabel
%32 = OpVariable %9 Function
%80 = OpVariable %8 Function
%84 = OpVariable %9 Function
%108 = OpVariable %9 Function
%126 = OpVariable %8 Function
%129 = OpVariable %9 Function
OpStore %32 %24
OpBranch %33
%33 = OpLabel
OpLoopMerge %35 %36 None
OpBranch %37
%37 = OpLabel
%38 = OpLoad %6 %32
%39 = OpLoad %6 %16
%41 = OpSLessThanEqual %40 %38 %39
OpBranchConditional %41 %34 %35
%34 = OpLabel
%42 = OpLoad %6 %17
%48 = OpLoad %6 %32
%50 = OpAccessChain %49 %47 %48 %24
%51 = OpLoad %6 %50
%52 = OpSLessThanEqual %40 %42 %51
OpSelectionMerge %54 None
OpBranchConditional %52 %53 %102
%53 = OpLabel
%55 = OpLoad %6 %32
%56 = OpAccessChain %49 %47 %55 %27
%57 = OpLoad %6 %56
%58 = OpIEqual %40 %57 %28
OpSelectionMerge %60 None
OpBranchConditional %58 %59 %97
%59 = OpLabel
%61 = OpLoad %6 %32
%62 = OpLoad %6 %16
%63 = OpAccessChain %49 %47 %61 %27
OpStore %63 %62
%71 = OpAccessChain %70 %68 %24 %69
%72 = OpLoad %64 %71
%74 = OpAccessChain %70 %68 %24 %73
%75 = OpLoad %64 %74
%76 = OpFOrdLessThan %40 %72 %75
OpSelectionMerge %78 None
OpBranchConditional %76 %77 %78
%77 = OpLabel
%79 = OpLoad %6 %16
%82 = OpAccessChain %81 %47 %79
%83 = OpLoad %7 %82
OpStore %80 %83
%85 = OpLoad %6 %17
OpStore %84 %85
%86 = OpFunctionCall %2 %13 %80 %84
%87 = OpLoad %7 %80
%88 = OpAccessChain %81 %47 %79
OpStore %88 %87
OpBranch %78
%78 = OpLabel
%89 = OpAccessChain %70 %68 %24 %69
%90 = OpLoad %64 %89
%91 = OpAccessChain %70 %68 %24 %73
%92 = OpLoad %64 %91
%93 = OpFOrdLessThan %40 %90 %92
OpSelectionMerge %95 None
OpBranchConditional %93 %94 %95
%94 = OpLabel
OpReturn
%95 = OpLabel
OpBranch %60
%97 = OpLabel
%98 = OpLoad %6 %32
%99 = OpAccessChain %49 %47 %98 %27
%100 = OpLoad %6 %99
OpStore %32 %100
OpBranch %36
%60 = OpLabel
OpBranch %54
%102 = OpLabel
%103 = OpAccessChain %70 %68 %24 %69
%104 = OpLoad %64 %103
%105 = OpAccessChain %70 %68 %24 %73
%106 = OpLoad %64 %105
%107 = OpFOrdLessThan %40 %104 %106
OpSelectionMerge %110 None
OpBranchConditional %107 %109 %114
%109 = OpLabel
%111 = OpLoad %6 %32
%112 = OpAccessChain %49 %47 %111 %30
%113 = OpLoad %6 %112
OpStore %108 %113
OpBranch %110
%114 = OpLabel
%115 = OpLoad %6 %32
%116 = OpAccessChain %49 %47 %115 %30
%117 = OpLoad %6 %116
OpStore %108 %117
OpBranch %110
%110 = OpLabel
%118 = OpLoad %6 %108
%119 = OpIEqual %40 %118 %28
OpSelectionMerge %121 None
OpBranchConditional %119 %120 %135
%120 = OpLabel
%122 = OpLoad %6 %32
%123 = OpLoad %6 %16
%124 = OpAccessChain %49 %47 %122 %30
OpStore %124 %123
%125 = OpLoad %6 %16
%127 = OpAccessChain %81 %47 %125
%128 = OpLoad %7 %127
OpStore %126 %128
%130 = OpLoad %6 %17
OpStore %129 %130
%131 = OpFunctionCall %2 %13 %126 %129
%132 = OpLoad %7 %126
%133 = OpAccessChain %81 %47 %125
OpStore %133 %132
OpReturn
%135 = OpLabel
%136 = OpLoad %6 %32
%137 = OpAccessChain %49 %47 %136 %30
%138 = OpLoad %6 %137
OpStore %32 %138
OpBranch %36
%121 = OpLabel
OpUnreachable
%54 = OpLabel
%140 = OpAccessChain %70 %68 %24 %69
%141 = OpLoad %64 %140
%142 = OpAccessChain %70 %68 %24 %73
%143 = OpLoad %64 %142
%144 = OpFOrdGreaterThan %40 %141 %143
OpSelectionMerge %146 None
OpBranchConditional %144 %145 %146
%145 = OpLabel
OpReturn
%146 = OpLabel
OpBranch %36
%36 = OpLabel
OpBranch %33
%35 = OpLabel
OpReturn
OpFunctionEnd
%22 = OpFunction %6 None %20
%21 = OpFunctionParameter %9
%23 = OpLabel
%148 = OpVariable %9 Function
%156 = OpVariable %8 Function
%172 = OpVariable %9 Function
OpStore %148 %24
OpBranch %149
%149 = OpLabel
OpLoopMerge %151 %152 None
OpBranch %153
%153 = OpLabel
%154 = OpLoad %6 %148
%155 = OpINotEqual %40 %154 %28
OpBranchConditional %155 %150 %151
%150 = OpLabel
%157 = OpLoad %6 %148
%158 = OpAccessChain %81 %47 %157
%159 = OpLoad %7 %158
OpStore %156 %159
%160 = OpAccessChain %9 %156 %24
%161 = OpLoad %6 %160
%162 = OpLoad %6 %21
%163 = OpIEqual %40 %161 %162
OpSelectionMerge %165 None
OpBranchConditional %163 %164 %165
%164 = OpLabel
%166 = OpLoad %6 %21
OpReturnValue %166
%165 = OpLabel
%168 = OpLoad %6 %21
%169 = OpAccessChain %9 %156 %24
%170 = OpLoad %6 %169
%171 = OpSGreaterThan %40 %168 %170
OpSelectionMerge %174 None
OpBranchConditional %171 %173 %177
%173 = OpLabel
%175 = OpAccessChain %9 %156 %30
%176 = OpLoad %6 %175
OpStore %172 %176
OpBranch %174
%177 = OpLabel
%178 = OpAccessChain %9 %156 %27
%179 = OpLoad %6 %178
OpStore %172 %179
OpBranch %174
%174 = OpLabel
%180 = OpLoad %6 %172
OpStore %148 %180
OpBranch %152
%152 = OpLabel
OpBranch %149
%151 = OpLabel
OpReturnValue %28
OpFunctionEnd
END
# uniforms for variant
# injectionSwitch
BUFFER variant_injectionSwitch DATA_TYPE vec2<float> DATA
0.0 1.0
END
BUFFER variant_framebuffer FORMAT B8G8R8A8_UNORM
PIPELINE graphics variant_pipeline
ATTACH variant_vertex_shader
ATTACH variant_fragment_shader
FRAMEBUFFER_SIZE 256 256
BIND BUFFER variant_framebuffer AS color LOCATION 0
BIND BUFFER variant_injectionSwitch AS uniform DESCRIPTOR_SET 0 BINDING 0
END
CLEAR_COLOR variant_pipeline 0 0 0 255
CLEAR variant_pipeline
RUN variant_pipeline DRAW_RECT POS 0 0 SIZE 256 256
EXPECT reference_framebuffer EQ_HISTOGRAM_EMD_BUFFER variant_framebuffer TOLERANCE 0.005