#!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 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