blob: 1173db6f64fecd87c15082fb7af15f8954f7f474 [file] [log] [blame]
; 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