1107 instructions 2 3[immutable slots] 4i0 = 0x3F800000 (1.0) 5i1 = 0x41200000 (10.0) 6i2 = 0x42C80000 (100.0) 7i3 = 0x40000000 (2.0) 8i4 = 0x41A00000 (20.0) 9i5 = 0x43480000 (200.0) 10i6 = 0x40400000 (3.0) 11i7 = 0x41F00000 (30.0) 12i8 = 0x43960000 (300.0) 13i9 = 0x40800000 (4.0) 14i10 = 0x42200000 (40.0) 15i11 = 0x43C80000 (400.0) 16i12 = 0x40A00000 (5.0) 17i13 = 0x42480000 (50.0) 18i14 = 0x43FA0000 (500.0) 19i15 = 0x40C00000 (6.0) 20i16 = 0x42700000 (60.0) 21i17 = 0x44160000 (600.0) 22i18 = 0x40E00000 (7.0) 23i19 = 0x428C0000 (70.0) 24i20 = 0x442F0000 (700.0) 25i21 = 0x41000000 (8.0) 26i22 = 0x42A00000 (80.0) 27i23 = 0x44480000 (800.0) 28i24 = 0x41100000 (9.0) 29i25 = 0x42B40000 (90.0) 30i26 = 0x44610000 (900.0) 31 32store_src_rg coords = src.rg 33init_lane_masks CondMask = LoopMask = RetMask = true 34splat_4_constants data.outer[0].inner[0].values, data.outer[0].inner[1].values(0) = 0 35splat_4_constants data.outer[0].inner[1].values(1..2), data.outer[0].inner[2].values(0..1) = 0 36splat_4_constants data.outer[0].inner[2].values(2), data.outer[1].inner[0].values = 0 37splat_4_constants data.outer[1].inner[1].values, data.outer[1].inner[2].values(0) = 0 38splat_4_constants data.outer[1].inner[2].values(1..2), data.outer[2].inner[0].values(0..1) = 0 39splat_4_constants data.outer[2].inner[0].values(2), data.outer[2].inner[1].values = 0 40splat_3_constants data.outer[2].inner[2].values = 0 41copy_3_immutables_unmasked $0..2 = i0..2 [0x3F800000 (1.0), 0x41200000 (10.0), 0x42C80000 (100.0)] 42copy_3_slots_masked data.outer[0].inner[0].values = Mask($0..2) 43copy_3_immutables_unmasked $0..2 = i3..5 [0x40000000 (2.0), 0x41A00000 (20.0), 0x43480000 (200.0)] 44copy_3_slots_masked data.outer[0].inner[1].values = Mask($0..2) 45copy_3_immutables_unmasked $0..2 = i6..8 [0x40400000 (3.0), 0x41F00000 (30.0), 0x43960000 (300.0)] 46copy_3_slots_masked data.outer[0].inner[2].values = Mask($0..2) 47copy_3_immutables_unmasked $0..2 = i9..11 [0x40800000 (4.0), 0x42200000 (40.0), 0x43C80000 (400.0)] 48copy_3_slots_masked data.outer[1].inner[0].values = Mask($0..2) 49copy_3_immutables_unmasked $0..2 = i12..14 [0x40A00000 (5.0), 0x42480000 (50.0), 0x43FA0000 (500.0)] 50copy_3_slots_masked data.outer[1].inner[1].values = Mask($0..2) 51copy_3_immutables_unmasked $0..2 = i15..17 [0x40C00000 (6.0), 0x42700000 (60.0), 0x44160000 (600.0)] 52copy_3_slots_masked data.outer[1].inner[2].values = Mask($0..2) 53copy_3_immutables_unmasked $0..2 = i18..20 [0x40E00000 (7.0), 0x428C0000 (70.0), 0x442F0000 (700.0)] 54copy_3_slots_masked data.outer[2].inner[0].values = Mask($0..2) 55copy_3_immutables_unmasked $0..2 = i21..23 [0x41000000 (8.0), 0x42A00000 (80.0), 0x44480000 (800.0)] 56copy_3_slots_masked data.outer[2].inner[1].values = Mask($0..2) 57copy_3_immutables_unmasked $0..2 = i24..26 [0x41100000 (9.0), 0x42B40000 (90.0), 0x44610000 (900.0)] 58copy_3_slots_masked data.outer[2].inner[2].values = Mask($0..2) 59splat_4_constants expected, i = 0 60store_loop_mask $0 = LoopMask 61jump jump +75 (label 1 at #105) 62label label 0x00000002 63copy_constant j = 0 64store_loop_mask $1 = LoopMask 65jump jump +60 (label 4 at #94) 66label label 0x00000005 67copy_3_slots_unmasked $2..4 = expected 68copy_3_immutables_unmasked $5..7 = i0..2 [0x3F800000 (1.0), 0x41200000 (10.0), 0x42C80000 (100.0)] 69add_3_floats $2..4 += $5..7 70copy_3_slots_masked expected = Mask($2..4) 71store_condition_mask $2 = CondMask 72copy_slot_unmasked $9 = i 73mul_imm_int $9 *= 0x00000009 74copy_slot_unmasked $10 = j 75mul_imm_int $10 *= 0x00000003 76copy_slot_unmasked $11 = $9 77add_int $10 += $11 78copy_from_indirect_unmasked $3..5 = Indirect(data.outer[0].inner[0].values + $10) 79copy_3_slots_unmasked $6..8 = expected 80cmpne_3_floats $3..5 = notEqual($3..5, $6..8) 81bitwise_or_int $4 |= $5 82bitwise_or_int $3 |= $4 83merge_condition_mask CondMask = $2 & $3 84copy_4_uniforms $4..7 = colorRed 85copy_4_slots_masked [main].result = Mask($4..7) 86mask_off_return_mask RetMask &= ~(CondMask & LoopMask & RetMask) 87load_condition_mask CondMask = $2 88copy_constant k = 0 89store_loop_mask $2 = LoopMask 90jump jump +24 (label 7 at #83) 91label label 0x00000008 92store_condition_mask $3 = CondMask 93copy_slot_unmasked $9 = i 94mul_imm_int $9 *= 0x00000009 95copy_slot_unmasked $10 = j 96mul_imm_int $10 *= 0x00000003 97copy_slot_unmasked $11 = $9 98add_int $10 += $11 99copy_slot_unmasked $12 = k 100copy_slot_unmasked $13 = $10 101add_int $12 += $13 102copy_from_indirect_unmasked $4 = Indirect(data.outer[0].inner[0].values(0) + $12) 103copy_slot_unmasked $9 = k 104copy_from_indirect_unmasked $5 = Indirect(expected(0) + $9) 105cmpne_float $4 = notEqual($4, $5) 106merge_condition_mask CondMask = $3 & $4 107copy_4_uniforms $5..8 = colorRed 108copy_4_slots_masked [main].result = Mask($5..8) 109mask_off_return_mask RetMask &= ~(CondMask & LoopMask & RetMask) 110load_condition_mask CondMask = $3 111copy_slot_unmasked $3 = k 112add_imm_int $3 += 0x00000001 113copy_slot_masked k = Mask($3) 114label label 0x00000007 115copy_slot_unmasked $3 = k 116cmplt_imm_int $3 = lessThan($3, 0x00000003) 117merge_loop_mask LoopMask &= $3 118stack_rewind 119branch_if_any_lanes_active branch_if_any_lanes_active -28 (label 8 at #60) 120label label 0x00000006 121load_loop_mask LoopMask = $2 122copy_slot_unmasked $2 = j 123add_imm_int $2 += 0x00000001 124copy_slot_masked j = Mask($2) 125label label 0x00000004 126copy_slot_unmasked $2 = j 127cmplt_imm_int $2 = lessThan($2, 0x00000003) 128merge_loop_mask LoopMask &= $2 129stack_rewind 130branch_if_any_lanes_active branch_if_any_lanes_active -64 (label 5 at #35) 131label label 0x00000003 132load_loop_mask LoopMask = $1 133copy_slot_unmasked $1 = i 134add_imm_int $1 += 0x00000001 135copy_slot_masked i = Mask($1) 136label label 0x00000001 137copy_slot_unmasked $1 = i 138cmplt_imm_int $1 = lessThan($1, 0x00000003) 139merge_loop_mask LoopMask &= $1 140stack_rewind 141branch_if_any_lanes_active branch_if_any_lanes_active -79 (label 2 at #31) 142label label 0 143load_loop_mask LoopMask = $0 144copy_4_uniforms $0..3 = colorGreen 145copy_4_slots_masked [main].result = Mask($0..3) 146mask_off_return_mask RetMask &= ~(CondMask & LoopMask & RetMask) 147load_src src.rgba = [main].result 148