| ; SPIR-V |
| ; Version: 1.3 |
| ; Generator: Google Tint Compiler; 0 |
| ; Bound: 333 |
| ; Schema: 0 |
| OpCapability Shader |
| OpMemoryModel Logical GLSL450 |
| OpEntryPoint Fragment %main "main" %gl_FragCoord_param_1 %x_GLF_color_1_1 |
| OpExecutionMode %main OriginUpperLeft |
| OpName %gl_FragCoord_param_1 "gl_FragCoord_param_1" |
| OpName %x_GLF_color_1_1 "x_GLF_color_1_1" |
| OpName %BST "BST" |
| OpMemberName %BST 0 "data" |
| OpMemberName %BST 1 "leftIndex" |
| OpMemberName %BST 2 "rightIndex" |
| OpName %tree_1 "tree_1" |
| OpName %gl_FragCoord "gl_FragCoord" |
| OpName %x_GLF_color "x_GLF_color" |
| OpName %makeTreeNode_struct_BST_i1_i1_i11_i1_ "makeTreeNode_struct_BST_i1_i1_i11_i1_" |
| OpName %tree "tree" |
| OpName %data "data" |
| OpName %insert_i1_i1_ "insert_i1_i1_" |
| OpName %treeIndex "treeIndex" |
| OpName %data_1 "data_1" |
| OpName %baseIndex "baseIndex" |
| OpName %param "param" |
| OpName %param_1 "param_1" |
| OpName %param_2 "param_2" |
| OpName %param_3 "param_3" |
| OpName %search_i1_ "search_i1_" |
| OpName %target "target" |
| OpName %index "index" |
| OpName %currentNode "currentNode" |
| OpName %x_231 "x_231" |
| OpName %main_1 "main_1" |
| OpName %treeIndex_1 "treeIndex_1" |
| OpName %param_4 "param_4" |
| OpName %param_5 "param_5" |
| OpName %param_6 "param_6" |
| OpName %param_7 "param_7" |
| OpName %param_8 "param_8" |
| OpName %param_9 "param_9" |
| OpName %param_10 "param_10" |
| OpName %param_11 "param_11" |
| OpName %param_12 "param_12" |
| OpName %param_13 "param_13" |
| OpName %param_14 "param_14" |
| OpName %param_15 "param_15" |
| OpName %param_16 "param_16" |
| OpName %param_17 "param_17" |
| OpName %param_18 "param_18" |
| OpName %param_19 "param_19" |
| OpName %param_20 "param_20" |
| OpName %param_21 "param_21" |
| OpName %param_22 "param_22" |
| OpName %param_23 "param_23" |
| OpName %count "count" |
| OpName %i "i" |
| OpName %result "result" |
| OpName %param_24 "param_24" |
| OpName %x_155 "x_155" |
| OpName %x_156_phi "x_156_phi" |
| OpName %main_out "main_out" |
| OpMemberName %main_out 0 "x_GLF_color_1" |
| OpName %main_inner "main_inner" |
| OpName %gl_FragCoord_param "gl_FragCoord_param" |
| OpName %main "main" |
| OpDecorate %gl_FragCoord_param_1 BuiltIn FragCoord |
| OpDecorate %x_GLF_color_1_1 Location 0 |
| OpMemberDecorate %BST 0 Offset 0 |
| OpMemberDecorate %BST 1 Offset 4 |
| OpMemberDecorate %BST 2 Offset 8 |
| OpDecorate %_arr_BST_uint_10 ArrayStride 12 |
| OpMemberDecorate %main_out 0 Offset 0 |
| %float = OpTypeFloat 32 |
| %v4float = OpTypeVector %float 4 |
| %_ptr_Input_v4float = OpTypePointer Input %v4float |
| %gl_FragCoord_param_1 = OpVariable %_ptr_Input_v4float Input |
| %_ptr_Output_v4float = OpTypePointer Output %v4float |
| %7 = OpConstantNull %v4float |
| %x_GLF_color_1_1 = OpVariable %_ptr_Output_v4float Output %7 |
| %int = OpTypeInt 32 1 |
| %BST = OpTypeStruct %int %int %int |
| %uint = OpTypeInt 32 0 |
| %uint_10 = OpConstant %uint 10 |
| %_arr_BST_uint_10 = OpTypeArray %BST %uint_10 |
| %_ptr_Private__arr_BST_uint_10 = OpTypePointer Private %_arr_BST_uint_10 |
| %15 = OpConstantNull %_arr_BST_uint_10 |
| %tree_1 = OpVariable %_ptr_Private__arr_BST_uint_10 Private %15 |
| %_ptr_Private_v4float = OpTypePointer Private %v4float |
| %gl_FragCoord = OpVariable %_ptr_Private_v4float Private %7 |
| %x_GLF_color = OpVariable %_ptr_Private_v4float Private %7 |
| %void = OpTypeVoid |
| %_ptr_Function_BST = OpTypePointer Function %BST |
| %_ptr_Function_int = OpTypePointer Function %int |
| %19 = OpTypeFunction %void %_ptr_Function_BST %_ptr_Function_int |
| %uint_0 = OpConstant %uint 0 |
| %uint_1 = OpConstant %uint 1 |
| %int_n1 = OpConstant %int -1 |
| %uint_2 = OpConstant %uint 2 |
| %39 = OpTypeFunction %void %_ptr_Function_int %_ptr_Function_int |
| %45 = OpConstantNull %int |
| %47 = OpConstantNull %BST |
| %int_0 = OpConstant %int 0 |
| %bool = OpTypeBool |
| %_ptr_Private_int = OpTypePointer Private %int |
| %_ptr_Private_BST = OpTypePointer Private %BST |
| %125 = OpTypeFunction %int %_ptr_Function_int |
| %166 = OpTypeFunction %void |
| %int_9 = OpConstant %int 9 |
| %int_1 = OpConstant %int 1 |
| %int_5 = OpConstant %int 5 |
| %int_12 = OpConstant %int 12 |
| %int_15 = OpConstant %int 15 |
| %int_7 = OpConstant %int 7 |
| %int_8 = OpConstant %int 8 |
| %int_2 = OpConstant %int 2 |
| %int_6 = OpConstant %int 6 |
| %int_17 = OpConstant %int 17 |
| %int_13 = OpConstant %int 13 |
| %int_20 = OpConstant %int 20 |
| %_ptr_Function_bool = OpTypePointer Function %bool |
| %278 = OpConstantNull %bool |
| %_ptr_Private_float = OpTypePointer Private %float |
| %float_0 = OpConstant %float 0 |
| %float_1 = OpConstant %float 1 |
| %318 = OpConstantComposite %v4float %float_1 %float_0 %float_0 %float_1 |
| %319 = OpConstantComposite %v4float %float_0 %float_0 %float_1 %float_1 |
| %main_out = OpTypeStruct %v4float |
| %320 = OpTypeFunction %main_out %v4float |
| %makeTreeNode_struct_BST_i1_i1_i11_i1_ = OpFunction %void None %19 |
| %tree = OpFunctionParameter %_ptr_Function_BST |
| %data = OpFunctionParameter %_ptr_Function_int |
| %26 = OpLabel |
| %28 = OpLoad %int %data |
| %31 = OpAccessChain %_ptr_Function_int %tree %uint_0 |
| OpStore %31 %28 |
| %34 = OpAccessChain %_ptr_Function_int %tree %uint_1 |
| OpStore %34 %int_n1 |
| %38 = OpAccessChain %_ptr_Function_int %tree %uint_2 |
| OpStore %38 %int_n1 |
| OpReturn |
| OpFunctionEnd |
| %insert_i1_i1_ = OpFunction %void None %39 |
| %treeIndex = OpFunctionParameter %_ptr_Function_int |
| %data_1 = OpFunctionParameter %_ptr_Function_int |
| %43 = OpLabel |
| %baseIndex = OpVariable %_ptr_Function_int Function %45 |
| %param = OpVariable %_ptr_Function_BST Function %47 |
| %param_1 = OpVariable %_ptr_Function_int Function %45 |
| %param_2 = OpVariable %_ptr_Function_BST Function %47 |
| %param_3 = OpVariable %_ptr_Function_int Function %45 |
| OpStore %baseIndex %int_0 |
| OpBranch %52 |
| %52 = OpLabel |
| OpLoopMerge %53 %54 None |
| OpBranch %55 |
| %55 = OpLabel |
| %56 = OpLoad %int %baseIndex |
| %58 = OpLoad %int %treeIndex |
| %59 = OpSLessThanEqual %bool %56 %58 |
| OpSelectionMerge %61 None |
| OpBranchConditional %59 %62 %63 |
| %62 = OpLabel |
| OpBranch %61 |
| %63 = OpLabel |
| OpBranch %53 |
| %61 = OpLabel |
| %65 = OpLoad %int %data_1 |
| %66 = OpLoad %int %baseIndex |
| %68 = OpAccessChain %_ptr_Private_int %tree_1 %66 %uint_0 |
| %69 = OpLoad %int %68 |
| %70 = OpSLessThanEqual %bool %65 %69 |
| OpSelectionMerge %71 None |
| OpBranchConditional %70 %72 %73 |
| %72 = OpLabel |
| %74 = OpLoad %int %baseIndex |
| %75 = OpAccessChain %_ptr_Private_int %tree_1 %74 %uint_1 |
| %76 = OpLoad %int %75 |
| %77 = OpIEqual %bool %76 %int_n1 |
| OpSelectionMerge %78 None |
| OpBranchConditional %77 %79 %80 |
| %79 = OpLabel |
| %81 = OpLoad %int %baseIndex |
| %83 = OpLoad %int %treeIndex |
| %84 = OpAccessChain %_ptr_Private_int %tree_1 %81 %uint_1 |
| OpStore %84 %83 |
| %86 = OpLoad %int %treeIndex |
| %88 = OpAccessChain %_ptr_Private_BST %tree_1 %86 |
| %89 = OpLoad %BST %88 |
| OpStore %param %89 |
| %91 = OpLoad %int %data_1 |
| OpStore %param_1 %91 |
| %92 = OpFunctionCall %void %makeTreeNode_struct_BST_i1_i1_i11_i1_ %param %param_1 |
| %95 = OpLoad %BST %param |
| %96 = OpAccessChain %_ptr_Private_BST %tree_1 %86 |
| OpStore %96 %95 |
| OpReturn |
| %80 = OpLabel |
| %97 = OpLoad %int %baseIndex |
| %98 = OpAccessChain %_ptr_Private_int %tree_1 %97 %uint_1 |
| %99 = OpLoad %int %98 |
| OpStore %baseIndex %99 |
| OpBranch %54 |
| %78 = OpLabel |
| OpReturn |
| %73 = OpLabel |
| %100 = OpLoad %int %baseIndex |
| %101 = OpAccessChain %_ptr_Private_int %tree_1 %100 %uint_2 |
| %102 = OpLoad %int %101 |
| %103 = OpIEqual %bool %102 %int_n1 |
| OpSelectionMerge %104 None |
| OpBranchConditional %103 %105 %106 |
| %105 = OpLabel |
| %107 = OpLoad %int %baseIndex |
| %109 = OpLoad %int %treeIndex |
| %110 = OpAccessChain %_ptr_Private_int %tree_1 %107 %uint_2 |
| OpStore %110 %109 |
| %112 = OpLoad %int %treeIndex |
| %113 = OpAccessChain %_ptr_Private_BST %tree_1 %112 |
| %114 = OpLoad %BST %113 |
| OpStore %param_2 %114 |
| %116 = OpLoad %int %data_1 |
| OpStore %param_3 %116 |
| %117 = OpFunctionCall %void %makeTreeNode_struct_BST_i1_i1_i11_i1_ %param_2 %param_3 |
| %120 = OpLoad %BST %param_2 |
| %121 = OpAccessChain %_ptr_Private_BST %tree_1 %112 |
| OpStore %121 %120 |
| OpReturn |
| %106 = OpLabel |
| %122 = OpLoad %int %baseIndex |
| %123 = OpAccessChain %_ptr_Private_int %tree_1 %122 %uint_2 |
| %124 = OpLoad %int %123 |
| OpStore %baseIndex %124 |
| OpBranch %54 |
| %104 = OpLabel |
| OpReturn |
| %71 = OpLabel |
| OpReturn |
| %54 = OpLabel |
| OpBranch %52 |
| %53 = OpLabel |
| OpReturn |
| OpFunctionEnd |
| %search_i1_ = OpFunction %int None %125 |
| %target = OpFunctionParameter %_ptr_Function_int |
| %128 = OpLabel |
| %index = OpVariable %_ptr_Function_int Function %45 |
| %currentNode = OpVariable %_ptr_Function_BST Function %47 |
| %x_231 = OpVariable %_ptr_Function_int Function %45 |
| OpStore %index %int_0 |
| OpBranch %132 |
| %132 = OpLabel |
| OpLoopMerge %133 %134 None |
| OpBranch %135 |
| %135 = OpLabel |
| %136 = OpLoad %int %index |
| %137 = OpINotEqual %bool %136 %int_n1 |
| OpSelectionMerge %138 None |
| OpBranchConditional %137 %139 %140 |
| %139 = OpLabel |
| OpBranch %138 |
| %140 = OpLabel |
| OpBranch %133 |
| %138 = OpLabel |
| %141 = OpLoad %int %index |
| %142 = OpAccessChain %_ptr_Private_BST %tree_1 %141 |
| %143 = OpLoad %BST %142 |
| OpStore %currentNode %143 |
| %144 = OpAccessChain %_ptr_Function_int %currentNode %uint_0 |
| %145 = OpLoad %int %144 |
| %147 = OpLoad %int %target |
| %148 = OpIEqual %bool %145 %147 |
| OpSelectionMerge %149 None |
| OpBranchConditional %148 %150 %149 |
| %150 = OpLabel |
| %152 = OpLoad %int %target |
| OpReturnValue %152 |
| %149 = OpLabel |
| %154 = OpLoad %int %target |
| %155 = OpAccessChain %_ptr_Function_int %currentNode %uint_0 |
| %156 = OpLoad %int %155 |
| %157 = OpSGreaterThan %bool %154 %156 |
| OpSelectionMerge %158 None |
| OpBranchConditional %157 %159 %160 |
| %159 = OpLabel |
| %161 = OpAccessChain %_ptr_Function_int %currentNode %uint_2 |
| %162 = OpLoad %int %161 |
| OpStore %x_231 %162 |
| OpBranch %158 |
| %160 = OpLabel |
| %163 = OpAccessChain %_ptr_Function_int %currentNode %uint_1 |
| %164 = OpLoad %int %163 |
| OpStore %x_231 %164 |
| OpBranch %158 |
| %158 = OpLabel |
| %165 = OpLoad %int %x_231 |
| OpStore %index %165 |
| OpBranch %134 |
| %134 = OpLabel |
| OpBranch %132 |
| %133 = OpLabel |
| OpReturnValue %int_n1 |
| OpFunctionEnd |
| %main_1 = OpFunction %void None %166 |
| %168 = OpLabel |
| %treeIndex_1 = OpVariable %_ptr_Function_int Function %45 |
| %param_4 = OpVariable %_ptr_Function_BST Function %47 |
| %param_5 = OpVariable %_ptr_Function_int Function %45 |
| %param_6 = OpVariable %_ptr_Function_int Function %45 |
| %param_7 = OpVariable %_ptr_Function_int Function %45 |
| %param_8 = OpVariable %_ptr_Function_int Function %45 |
| %param_9 = OpVariable %_ptr_Function_int Function %45 |
| %param_10 = OpVariable %_ptr_Function_int Function %45 |
| %param_11 = OpVariable %_ptr_Function_int Function %45 |
| %param_12 = OpVariable %_ptr_Function_int Function %45 |
| %param_13 = OpVariable %_ptr_Function_int Function %45 |
| %param_14 = OpVariable %_ptr_Function_int Function %45 |
| %param_15 = OpVariable %_ptr_Function_int Function %45 |
| %param_16 = OpVariable %_ptr_Function_int Function %45 |
| %param_17 = OpVariable %_ptr_Function_int Function %45 |
| %param_18 = OpVariable %_ptr_Function_int Function %45 |
| %param_19 = OpVariable %_ptr_Function_int Function %45 |
| %param_20 = OpVariable %_ptr_Function_int Function %45 |
| %param_21 = OpVariable %_ptr_Function_int Function %45 |
| %param_22 = OpVariable %_ptr_Function_int Function %45 |
| %param_23 = OpVariable %_ptr_Function_int Function %45 |
| %count = OpVariable %_ptr_Function_int Function %45 |
| %i = OpVariable %_ptr_Function_int Function %45 |
| %result = OpVariable %_ptr_Function_int Function %45 |
| %param_24 = OpVariable %_ptr_Function_int Function %45 |
| %x_155 = OpVariable %_ptr_Function_bool Function %278 |
| %x_156_phi = OpVariable %_ptr_Function_bool Function %278 |
| OpStore %treeIndex_1 %int_0 |
| %194 = OpAccessChain %_ptr_Private_BST %tree_1 %int_0 |
| %195 = OpLoad %BST %194 |
| OpStore %param_4 %195 |
| OpStore %param_5 %int_9 |
| %197 = OpFunctionCall %void %makeTreeNode_struct_BST_i1_i1_i11_i1_ %param_4 %param_5 |
| %200 = OpLoad %BST %param_4 |
| %201 = OpAccessChain %_ptr_Private_BST %tree_1 %int_0 |
| OpStore %201 %200 |
| %202 = OpLoad %int %treeIndex_1 |
| %204 = OpIAdd %int %202 %int_1 |
| OpStore %treeIndex_1 %204 |
| %205 = OpLoad %int %treeIndex_1 |
| OpStore %param_6 %205 |
| OpStore %param_7 %int_5 |
| %207 = OpFunctionCall %void %insert_i1_i1_ %param_6 %param_7 |
| %210 = OpLoad %int %treeIndex_1 |
| %211 = OpIAdd %int %210 %int_1 |
| OpStore %treeIndex_1 %211 |
| %212 = OpLoad %int %treeIndex_1 |
| OpStore %param_8 %212 |
| OpStore %param_9 %int_12 |
| %214 = OpFunctionCall %void %insert_i1_i1_ %param_8 %param_9 |
| %217 = OpLoad %int %treeIndex_1 |
| %218 = OpIAdd %int %217 %int_1 |
| OpStore %treeIndex_1 %218 |
| %219 = OpLoad %int %treeIndex_1 |
| OpStore %param_10 %219 |
| OpStore %param_11 %int_15 |
| %221 = OpFunctionCall %void %insert_i1_i1_ %param_10 %param_11 |
| %224 = OpLoad %int %treeIndex_1 |
| %225 = OpIAdd %int %224 %int_1 |
| OpStore %treeIndex_1 %225 |
| %226 = OpLoad %int %treeIndex_1 |
| OpStore %param_12 %226 |
| OpStore %param_13 %int_7 |
| %228 = OpFunctionCall %void %insert_i1_i1_ %param_12 %param_13 |
| %231 = OpLoad %int %treeIndex_1 |
| %232 = OpIAdd %int %231 %int_1 |
| OpStore %treeIndex_1 %232 |
| %233 = OpLoad %int %treeIndex_1 |
| OpStore %param_14 %233 |
| OpStore %param_15 %int_8 |
| %235 = OpFunctionCall %void %insert_i1_i1_ %param_14 %param_15 |
| %238 = OpLoad %int %treeIndex_1 |
| %239 = OpIAdd %int %238 %int_1 |
| OpStore %treeIndex_1 %239 |
| %240 = OpLoad %int %treeIndex_1 |
| OpStore %param_16 %240 |
| OpStore %param_17 %int_2 |
| %242 = OpFunctionCall %void %insert_i1_i1_ %param_16 %param_17 |
| %245 = OpLoad %int %treeIndex_1 |
| %246 = OpIAdd %int %245 %int_1 |
| OpStore %treeIndex_1 %246 |
| %247 = OpLoad %int %treeIndex_1 |
| OpStore %param_18 %247 |
| OpStore %param_19 %int_6 |
| %249 = OpFunctionCall %void %insert_i1_i1_ %param_18 %param_19 |
| %252 = OpLoad %int %treeIndex_1 |
| %253 = OpIAdd %int %252 %int_1 |
| OpStore %treeIndex_1 %253 |
| %254 = OpLoad %int %treeIndex_1 |
| OpStore %param_20 %254 |
| OpStore %param_21 %int_17 |
| %256 = OpFunctionCall %void %insert_i1_i1_ %param_20 %param_21 |
| %259 = OpLoad %int %treeIndex_1 |
| %260 = OpIAdd %int %259 %int_1 |
| OpStore %treeIndex_1 %260 |
| %261 = OpLoad %int %treeIndex_1 |
| OpStore %param_22 %261 |
| OpStore %param_23 %int_13 |
| %263 = OpFunctionCall %void %insert_i1_i1_ %param_22 %param_23 |
| OpStore %count %int_0 |
| OpStore %i %int_0 |
| OpBranch %266 |
| %266 = OpLabel |
| OpLoopMerge %267 %268 None |
| OpBranch %269 |
| %269 = OpLabel |
| %270 = OpLoad %int %i |
| %272 = OpSLessThan %bool %270 %int_20 |
| OpSelectionMerge %273 None |
| OpBranchConditional %272 %274 %275 |
| %274 = OpLabel |
| OpBranch %273 |
| %275 = OpLabel |
| OpBranch %267 |
| %273 = OpLabel |
| %280 = OpLoad %int %i |
| OpStore %param_24 %280 |
| %281 = OpFunctionCall %int %search_i1_ %param_24 |
| OpStore %result %281 |
| %283 = OpLoad %int %i |
| OpSelectionMerge %284 None |
| OpSwitch %283 %285 2 %286 5 %286 6 %286 7 %286 8 %286 9 %286 12 %286 13 %286 15 %286 17 %286 |
| %286 = OpLabel |
| %287 = OpLoad %int %result |
| %288 = OpLoad %int %i |
| %289 = OpIEqual %bool %287 %288 |
| OpStore %x_156_phi %289 |
| %290 = OpLogicalNot %bool %289 |
| OpSelectionMerge %291 None |
| OpBranchConditional %290 %292 %291 |
| %292 = OpLabel |
| %294 = OpAccessChain %_ptr_Private_float %gl_FragCoord %uint_0 |
| %295 = OpLoad %float %294 |
| %297 = OpFOrdLessThan %bool %295 %float_0 |
| OpStore %x_155 %297 |
| %298 = OpLoad %bool %x_155 |
| OpStore %x_156_phi %298 |
| OpBranch %291 |
| %291 = OpLabel |
| %299 = OpLoad %bool %x_156_phi |
| OpSelectionMerge %300 None |
| OpBranchConditional %299 %301 %300 |
| %301 = OpLabel |
| %302 = OpLoad %int %count |
| %303 = OpIAdd %int %302 %int_1 |
| OpStore %count %303 |
| OpBranch %300 |
| %300 = OpLabel |
| OpBranch %284 |
| %285 = OpLabel |
| %304 = OpLoad %int %result |
| %305 = OpIEqual %bool %304 %int_n1 |
| OpSelectionMerge %306 None |
| OpBranchConditional %305 %307 %306 |
| %307 = OpLabel |
| %308 = OpLoad %int %count |
| %309 = OpIAdd %int %308 %int_1 |
| OpStore %count %309 |
| OpBranch %306 |
| %306 = OpLabel |
| OpBranch %284 |
| %284 = OpLabel |
| OpBranch %268 |
| %268 = OpLabel |
| %310 = OpLoad %int %i |
| %311 = OpIAdd %int %310 %int_1 |
| OpStore %i %311 |
| OpBranch %266 |
| %267 = OpLabel |
| %312 = OpLoad %int %count |
| %313 = OpIEqual %bool %312 %int_20 |
| OpSelectionMerge %314 None |
| OpBranchConditional %313 %315 %316 |
| %315 = OpLabel |
| OpStore %x_GLF_color %318 |
| OpBranch %314 |
| %316 = OpLabel |
| OpStore %x_GLF_color %319 |
| OpBranch %314 |
| %314 = OpLabel |
| OpReturn |
| OpFunctionEnd |
| %main_inner = OpFunction %main_out None %320 |
| %gl_FragCoord_param = OpFunctionParameter %v4float |
| %324 = OpLabel |
| OpStore %gl_FragCoord %gl_FragCoord_param |
| %325 = OpFunctionCall %void %main_1 |
| %326 = OpLoad %v4float %x_GLF_color |
| %327 = OpCompositeConstruct %main_out %326 |
| OpReturnValue %327 |
| OpFunctionEnd |
| %main = OpFunction %void None %166 |
| %329 = OpLabel |
| %331 = OpLoad %v4float %gl_FragCoord_param_1 |
| %330 = OpFunctionCall %main_out %main_inner %331 |
| %332 = OpCompositeExtract %v4float %330 0 |
| OpStore %x_GLF_color_1_1 %332 |
| OpReturn |
| OpFunctionEnd |