1116 instructions 2 3[immutable slots] 4i0 = 0x40400000 (3.0) 5i1 = 0x40000000 (2.0) 6i2 = 0x3F800000 (1.0) 7i3 = 0x00000002 (2.802597e-45) 8i4 = 0x00000001 (1.401298e-45) 9i5 = 0 10i6 = 0x40800000 (4.0) 11i7 = 0x40400000 (3.0) 12i8 = 0x40000000 (2.0) 13i9 = 0x3F800000 (1.0) 14i10 = 0x00000003 (4.203895e-45) 15i11 = 0x00000002 (2.802597e-45) 16i12 = 0x00000001 (1.401298e-45) 17i13 = 0 18 19store_src_rg coords = src.rg 20init_lane_masks CondMask = LoopMask = RetMask = true 21store_condition_mask $12 = CondMask 22branch_if_no_lanes_active branch_if_no_lanes_active +58 (label 2 at #62) 23store_return_mask $13 = RetMask 24copy_3_immutables_unmasked expected = i0..2 [0x40400000 (3.0), 0x40000000 (2.0), 0x3F800000 (1.0)] 25copy_constant c = 0 26store_loop_mask $14 = LoopMask 27jump jump +41 (label 4 at #50) 28label label 0x00000005 29copy_slot_unmasked $21 = c 30mul_imm_int $21 *= 0x00000003 31copy_from_indirect_uniform_unm $15..17 = Indirect(testMatrix3x3(0..2) + $21) 32copy_3_slots_unmasked vec = $15..17 33copy_constant r = 0 34store_loop_mask $15 = LoopMask 35jump jump +18 (label 7 at #35) 36label label 0x00000008 37store_condition_mask $16 = CondMask 38copy_slot_unmasked $22 = r 39copy_3_immutables_unmasked $26..28 = i3..5 [0x00000002 (2.802597e-45), 0x00000001 (1.401298e-45), 0] 40copy_from_indirect_unmasked $21 = Indirect($26 + $22) 41copy_from_indirect_unmasked $17 = Indirect(vec(0) + $21) 42copy_slot_unmasked $21 = r 43copy_from_indirect_unmasked $18 = Indirect(expected(0) + $21) 44cmpne_float $17 = notEqual($17, $18) 45merge_condition_mask CondMask = $16 & $17 46copy_constant $18 = 0 47copy_slot_masked [test3x3].result = Mask($18) 48mask_off_return_mask RetMask &= ~(CondMask & LoopMask & RetMask) 49load_condition_mask CondMask = $16 50copy_slot_unmasked $16 = r 51add_imm_int $16 += 0x00000001 52copy_slot_masked r = Mask($16) 53label label 0x00000007 54copy_slot_unmasked $16 = r 55cmplt_imm_int $16 = lessThan($16, 0x00000003) 56merge_loop_mask LoopMask &= $16 57stack_rewind 58branch_if_any_lanes_active branch_if_any_lanes_active -22 (label 8 at #18) 59label label 0x00000006 60load_loop_mask LoopMask = $15 61copy_3_slots_unmasked $15..17 = expected 62splat_3_constants $18..20 = 0x40400000 (3.0) 63add_3_floats $15..17 += $18..20 64copy_3_slots_masked expected = Mask($15..17) 65copy_slot_unmasked $15 = c 66add_imm_int $15 += 0x00000001 67copy_slot_masked c = Mask($15) 68label label 0x00000004 69copy_slot_unmasked $15 = c 70cmplt_imm_int $15 = lessThan($15, 0x00000003) 71merge_loop_mask LoopMask &= $15 72stack_rewind 73branch_if_any_lanes_active branch_if_any_lanes_active -45 (label 5 at #10) 74label label 0x00000003 75load_loop_mask LoopMask = $14 76copy_constant $14 = 0xFFFFFFFF 77copy_slot_masked [test3x3].result = Mask($14) 78load_return_mask RetMask = $13 79copy_slot_unmasked $13 = [test3x3].result 80label label 0x00000002 81copy_constant $0 = 0 82merge_condition_mask CondMask = $12 & $13 83branch_if_no_lanes_active branch_if_no_lanes_active +60 (label 1 at #125) 84store_return_mask $1 = RetMask 85copy_4_immutables_unmasked expected₁ = i6..9 [0x40800000 (4.0), 0x40400000 (3.0), 0x40000000 (2.0), 0x3F800000 (1.0)] 86copy_constant c₁ = 0 87store_loop_mask $2 = LoopMask 88jump jump +41 (label 11 at #111) 89label label 0x0000000C 90copy_slot_unmasked $21 = c₁ 91mul_imm_int $21 *= 0x00000004 92copy_from_indirect_uniform_unm $3..6 = Indirect(testMatrix4x4(0..3) + $21) 93copy_4_slots_unmasked vec₁ = $3..6 94copy_constant r₁ = 0 95store_loop_mask $3 = LoopMask 96jump jump +18 (label 14 at #96) 97label label 0x0000000F 98store_condition_mask $4 = CondMask 99copy_slot_unmasked $26 = r₁ 100copy_4_immutables_unmasked $22..25 = i10..13 [0x00000003 (4.203895e-45), 0x00000002 (2.802597e-45), 0x00000001 (1.401298e-45), 0] 101copy_from_indirect_unmasked $21 = Indirect($22 + $26) 102copy_from_indirect_unmasked $5 = Indirect(vec₁(0) + $21) 103copy_slot_unmasked $21 = r₁ 104copy_from_indirect_unmasked $6 = Indirect(expected₁(0) + $21) 105cmpne_float $5 = notEqual($5, $6) 106merge_condition_mask CondMask = $4 & $5 107copy_constant $6 = 0 108copy_slot_masked [test4x4].result = Mask($6) 109mask_off_return_mask RetMask &= ~(CondMask & LoopMask & RetMask) 110load_condition_mask CondMask = $4 111copy_slot_unmasked $4 = r₁ 112add_imm_int $4 += 0x00000001 113copy_slot_masked r₁ = Mask($4) 114label label 0x0000000E 115copy_slot_unmasked $4 = r₁ 116cmplt_imm_int $4 = lessThan($4, 0x00000004) 117merge_loop_mask LoopMask &= $4 118stack_rewind 119branch_if_any_lanes_active branch_if_any_lanes_active -22 (label 15 at #79) 120label label 0x0000000D 121load_loop_mask LoopMask = $3 122copy_4_slots_unmasked $3..6 = expected₁ 123splat_4_constants $7..10 = 0x40800000 (4.0) 124add_4_floats $3..6 += $7..10 125copy_4_slots_masked expected₁ = Mask($3..6) 126copy_slot_unmasked $3 = c₁ 127add_imm_int $3 += 0x00000001 128copy_slot_masked c₁ = Mask($3) 129label label 0x0000000B 130copy_slot_unmasked $3 = c₁ 131cmplt_imm_int $3 = lessThan($3, 0x00000004) 132merge_loop_mask LoopMask &= $3 133stack_rewind 134branch_if_any_lanes_active branch_if_any_lanes_active -45 (label 12 at #71) 135label label 0x0000000A 136load_loop_mask LoopMask = $2 137copy_constant $2 = 0xFFFFFFFF 138copy_slot_masked [test4x4].result = Mask($2) 139load_return_mask RetMask = $1 140copy_slot_unmasked $1 = [test4x4].result 141label label 0x00000009 142copy_slot_masked $0 = Mask($1) 143label label 0x00000001 144load_condition_mask CondMask = $12 145swizzle_4 $0..3 = ($0..3).xxxx 146copy_4_uniforms $4..7 = colorRed 147copy_4_uniforms $8..11 = colorGreen 148mix_4_ints $0..3 = mix($4..7, $8..11, $0..3) 149load_src src.rgba = $0..3 150