@@ -557,11 +557,11 @@ define amdgpu_kernel void @introduced_copy_to_sgpr(i64 %arg, i32 %arg1, i32 %arg
557
557
; GFX908-NEXT: s_mul_hi_u32 s9, s0, s5
558
558
; GFX908-NEXT: s_mul_i32 s0, s0, s5
559
559
; GFX908-NEXT: s_add_i32 s1, s9, s1
560
- ; GFX908-NEXT: s_lshl_b64 s[0:1 ], s[0:1], 5
560
+ ; GFX908-NEXT: s_lshl_b64 s[14:15 ], s[0:1], 5
561
561
; GFX908-NEXT: s_branch .LBB3_2
562
562
; GFX908-NEXT: .LBB3_1: ; %Flow20
563
563
; GFX908-NEXT: ; in Loop: Header=BB3_2 Depth=1
564
- ; GFX908-NEXT: s_andn2_b64 vcc, exec, s[14:15 ]
564
+ ; GFX908-NEXT: s_andn2_b64 vcc, exec, s[0:1 ]
565
565
; GFX908-NEXT: s_cbranch_vccz .LBB3_12
566
566
; GFX908-NEXT: .LBB3_2: ; %bb9
567
567
; GFX908-NEXT: ; =>This Loop Header: Depth=1
@@ -571,15 +571,17 @@ define amdgpu_kernel void @introduced_copy_to_sgpr(i64 %arg, i32 %arg1, i32 %arg
571
571
; GFX908-NEXT: ; %bb.3: ; %bb14
572
572
; GFX908-NEXT: ; in Loop: Header=BB3_2 Depth=1
573
573
; GFX908-NEXT: global_load_dwordx2 v[2:3], v[0:1], off
574
+ ; GFX908-NEXT: v_cmp_gt_i64_e64 s[0:1], s[6:7], -1
574
575
; GFX908-NEXT: s_mov_b32 s9, s8
576
+ ; GFX908-NEXT: v_cndmask_b32_e64 v6, 0, 1, s[0:1]
575
577
; GFX908-NEXT: v_mov_b32_e32 v4, s8
578
+ ; GFX908-NEXT: v_cmp_ne_u32_e64 s[0:1], 1, v6
576
579
; GFX908-NEXT: v_mov_b32_e32 v8, s8
577
580
; GFX908-NEXT: v_mov_b32_e32 v6, s8
578
581
; GFX908-NEXT: v_mov_b32_e32 v5, s9
579
582
; GFX908-NEXT: v_mov_b32_e32 v9, s9
580
583
; GFX908-NEXT: v_mov_b32_e32 v7, s9
581
- ; GFX908-NEXT: v_cmp_lt_i64_e64 s[14:15], s[6:7], 0
582
- ; GFX908-NEXT: v_cmp_gt_i64_e64 s[16:17], s[6:7], -1
584
+ ; GFX908-NEXT: v_cmp_lt_i64_e64 s[16:17], s[6:7], 0
583
585
; GFX908-NEXT: v_mov_b32_e32 v11, v5
584
586
; GFX908-NEXT: s_mov_b64 s[20:21], s[10:11]
585
587
; GFX908-NEXT: v_mov_b32_e32 v10, v4
@@ -599,9 +601,9 @@ define amdgpu_kernel void @introduced_copy_to_sgpr(i64 %arg, i32 %arg1, i32 %arg
599
601
; GFX908-NEXT: ; in Loop: Header=BB3_5 Depth=2
600
602
; GFX908-NEXT: v_add_co_u32_sdwa v2, vcc, v2, v16 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:WORD_0
601
603
; GFX908-NEXT: v_addc_co_u32_e32 v3, vcc, 0, v3, vcc
602
- ; GFX908-NEXT: s_add_u32 s20, s20, s0
604
+ ; GFX908-NEXT: s_add_u32 s20, s20, s14
603
605
; GFX908-NEXT: v_cmp_lt_i64_e64 s[24:25], -1, v[2:3]
604
- ; GFX908-NEXT: s_addc_u32 s21, s21, s1
606
+ ; GFX908-NEXT: s_addc_u32 s21, s21, s15
605
607
; GFX908-NEXT: s_mov_b64 s[22:23], 0
606
608
; GFX908-NEXT: s_andn2_b64 vcc, exec, s[24:25]
607
609
; GFX908-NEXT: s_cbranch_vccz .LBB3_9
@@ -620,7 +622,7 @@ define amdgpu_kernel void @introduced_copy_to_sgpr(i64 %arg, i32 %arg1, i32 %arg
620
622
; GFX908-NEXT: s_waitcnt vmcnt(0)
621
623
; GFX908-NEXT: ds_read_b64 v[12:13], v19
622
624
; GFX908-NEXT: ds_read_b64 v[14:15], v0
623
- ; GFX908-NEXT: s_andn2_b64 vcc, exec, s[16:17 ]
625
+ ; GFX908-NEXT: s_and_b64 vcc, exec, s[0:1 ]
624
626
; GFX908-NEXT: s_waitcnt lgkmcnt(0)
625
627
; GFX908-NEXT: s_cbranch_vccnz .LBB3_7
626
628
; GFX908-NEXT: ; %bb.6: ; %bb51
@@ -648,7 +650,7 @@ define amdgpu_kernel void @introduced_copy_to_sgpr(i64 %arg, i32 %arg1, i32 %arg
648
650
; GFX908-NEXT: s_mov_b64 s[22:23], -1
649
651
; GFX908-NEXT: s_branch .LBB3_4
650
652
; GFX908-NEXT: .LBB3_7: ; in Loop: Header=BB3_5 Depth=2
651
- ; GFX908-NEXT: s_mov_b64 s[22:23], s[14:15 ]
653
+ ; GFX908-NEXT: s_mov_b64 s[22:23], s[16:17 ]
652
654
; GFX908-NEXT: s_andn2_b64 vcc, exec, s[22:23]
653
655
; GFX908-NEXT: s_cbranch_vccz .LBB3_4
654
656
; GFX908-NEXT: ; %bb.8: ; in Loop: Header=BB3_2 Depth=1
@@ -663,7 +665,7 @@ define amdgpu_kernel void @introduced_copy_to_sgpr(i64 %arg, i32 %arg1, i32 %arg
663
665
; GFX908-NEXT: s_xor_b64 s[16:17], s[22:23], -1
664
666
; GFX908-NEXT: .LBB3_10: ; %Flow19
665
667
; GFX908-NEXT: ; in Loop: Header=BB3_2 Depth=1
666
- ; GFX908-NEXT: s_mov_b64 s[14:15 ], -1
668
+ ; GFX908-NEXT: s_mov_b64 s[0:1 ], -1
667
669
; GFX908-NEXT: s_and_b64 vcc, exec, s[16:17]
668
670
; GFX908-NEXT: s_cbranch_vccz .LBB3_1
669
671
; GFX908-NEXT: ; %bb.11: ; %bb12
@@ -672,7 +674,7 @@ define amdgpu_kernel void @introduced_copy_to_sgpr(i64 %arg, i32 %arg1, i32 %arg
672
674
; GFX908-NEXT: s_addc_u32 s7, s7, 0
673
675
; GFX908-NEXT: s_add_u32 s10, s10, s12
674
676
; GFX908-NEXT: s_addc_u32 s11, s11, s13
675
- ; GFX908-NEXT: s_mov_b64 s[14:15 ], 0
677
+ ; GFX908-NEXT: s_mov_b64 s[0:1 ], 0
676
678
; GFX908-NEXT: s_branch .LBB3_1
677
679
; GFX908-NEXT: .LBB3_12: ; %DummyReturnBlock
678
680
; GFX908-NEXT: s_endpgm
@@ -722,11 +724,11 @@ define amdgpu_kernel void @introduced_copy_to_sgpr(i64 %arg, i32 %arg1, i32 %arg
722
724
; GFX90A-NEXT: s_mul_hi_u32 s9, s0, s5
723
725
; GFX90A-NEXT: s_mul_i32 s0, s0, s5
724
726
; GFX90A-NEXT: s_add_i32 s1, s9, s1
725
- ; GFX90A-NEXT: s_lshl_b64 s[0:1 ], s[0:1], 5
727
+ ; GFX90A-NEXT: s_lshl_b64 s[14:15 ], s[0:1], 5
726
728
; GFX90A-NEXT: s_branch .LBB3_2
727
729
; GFX90A-NEXT: .LBB3_1: ; %Flow20
728
730
; GFX90A-NEXT: ; in Loop: Header=BB3_2 Depth=1
729
- ; GFX90A-NEXT: s_andn2_b64 vcc, exec, s[14:15 ]
731
+ ; GFX90A-NEXT: s_andn2_b64 vcc, exec, s[0:1 ]
730
732
; GFX90A-NEXT: s_cbranch_vccz .LBB3_12
731
733
; GFX90A-NEXT: .LBB3_2: ; %bb9
732
734
; GFX90A-NEXT: ; =>This Loop Header: Depth=1
@@ -736,12 +738,14 @@ define amdgpu_kernel void @introduced_copy_to_sgpr(i64 %arg, i32 %arg1, i32 %arg
736
738
; GFX90A-NEXT: ; %bb.3: ; %bb14
737
739
; GFX90A-NEXT: ; in Loop: Header=BB3_2 Depth=1
738
740
; GFX90A-NEXT: global_load_dwordx2 v[4:5], v[2:3], off
741
+ ; GFX90A-NEXT: v_cmp_gt_i64_e64 s[0:1], s[6:7], -1
739
742
; GFX90A-NEXT: s_mov_b32 s9, s8
743
+ ; GFX90A-NEXT: v_cndmask_b32_e64 v8, 0, 1, s[0:1]
740
744
; GFX90A-NEXT: v_pk_mov_b32 v[6:7], s[8:9], s[8:9] op_sel:[0,1]
745
+ ; GFX90A-NEXT: v_cmp_ne_u32_e64 s[0:1], 1, v8
741
746
; GFX90A-NEXT: v_pk_mov_b32 v[10:11], s[8:9], s[8:9] op_sel:[0,1]
742
747
; GFX90A-NEXT: v_pk_mov_b32 v[8:9], s[8:9], s[8:9] op_sel:[0,1]
743
- ; GFX90A-NEXT: v_cmp_lt_i64_e64 s[14:15], s[6:7], 0
744
- ; GFX90A-NEXT: v_cmp_gt_i64_e64 s[16:17], s[6:7], -1
748
+ ; GFX90A-NEXT: v_cmp_lt_i64_e64 s[16:17], s[6:7], 0
745
749
; GFX90A-NEXT: s_mov_b64 s[20:21], s[10:11]
746
750
; GFX90A-NEXT: v_pk_mov_b32 v[12:13], v[6:7], v[6:7] op_sel:[0,1]
747
751
; GFX90A-NEXT: s_waitcnt vmcnt(0)
@@ -760,8 +764,8 @@ define amdgpu_kernel void @introduced_copy_to_sgpr(i64 %arg, i32 %arg1, i32 %arg
760
764
; GFX90A-NEXT: ; in Loop: Header=BB3_5 Depth=2
761
765
; GFX90A-NEXT: v_add_co_u32_sdwa v4, vcc, v4, v18 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:WORD_0
762
766
; GFX90A-NEXT: v_addc_co_u32_e32 v5, vcc, 0, v5, vcc
763
- ; GFX90A-NEXT: s_add_u32 s20, s20, s0
764
- ; GFX90A-NEXT: s_addc_u32 s21, s21, s1
767
+ ; GFX90A-NEXT: s_add_u32 s20, s20, s14
768
+ ; GFX90A-NEXT: s_addc_u32 s21, s21, s15
765
769
; GFX90A-NEXT: v_cmp_lt_i64_e64 s[24:25], -1, v[4:5]
766
770
; GFX90A-NEXT: s_mov_b64 s[22:23], 0
767
771
; GFX90A-NEXT: s_andn2_b64 vcc, exec, s[24:25]
@@ -781,7 +785,7 @@ define amdgpu_kernel void @introduced_copy_to_sgpr(i64 %arg, i32 %arg1, i32 %arg
781
785
; GFX90A-NEXT: s_waitcnt vmcnt(0)
782
786
; GFX90A-NEXT: ds_read_b64 v[14:15], v19
783
787
; GFX90A-NEXT: ds_read_b64 v[16:17], v0
784
- ; GFX90A-NEXT: s_andn2_b64 vcc, exec, s[16:17 ]
788
+ ; GFX90A-NEXT: s_and_b64 vcc, exec, s[0:1 ]
785
789
; GFX90A-NEXT: ; kill: killed $sgpr22 killed $sgpr23
786
790
; GFX90A-NEXT: s_waitcnt lgkmcnt(0)
787
791
; GFX90A-NEXT: s_cbranch_vccnz .LBB3_7
@@ -802,7 +806,7 @@ define amdgpu_kernel void @introduced_copy_to_sgpr(i64 %arg, i32 %arg1, i32 %arg
802
806
; GFX90A-NEXT: s_mov_b64 s[22:23], -1
803
807
; GFX90A-NEXT: s_branch .LBB3_4
804
808
; GFX90A-NEXT: .LBB3_7: ; in Loop: Header=BB3_5 Depth=2
805
- ; GFX90A-NEXT: s_mov_b64 s[22:23], s[14:15 ]
809
+ ; GFX90A-NEXT: s_mov_b64 s[22:23], s[16:17 ]
806
810
; GFX90A-NEXT: s_andn2_b64 vcc, exec, s[22:23]
807
811
; GFX90A-NEXT: s_cbranch_vccz .LBB3_4
808
812
; GFX90A-NEXT: ; %bb.8: ; in Loop: Header=BB3_2 Depth=1
@@ -817,7 +821,7 @@ define amdgpu_kernel void @introduced_copy_to_sgpr(i64 %arg, i32 %arg1, i32 %arg
817
821
; GFX90A-NEXT: s_xor_b64 s[16:17], s[22:23], -1
818
822
; GFX90A-NEXT: .LBB3_10: ; %Flow19
819
823
; GFX90A-NEXT: ; in Loop: Header=BB3_2 Depth=1
820
- ; GFX90A-NEXT: s_mov_b64 s[14:15 ], -1
824
+ ; GFX90A-NEXT: s_mov_b64 s[0:1 ], -1
821
825
; GFX90A-NEXT: s_and_b64 vcc, exec, s[16:17]
822
826
; GFX90A-NEXT: s_cbranch_vccz .LBB3_1
823
827
; GFX90A-NEXT: ; %bb.11: ; %bb12
@@ -826,7 +830,7 @@ define amdgpu_kernel void @introduced_copy_to_sgpr(i64 %arg, i32 %arg1, i32 %arg
826
830
; GFX90A-NEXT: s_addc_u32 s7, s7, 0
827
831
; GFX90A-NEXT: s_add_u32 s10, s10, s12
828
832
; GFX90A-NEXT: s_addc_u32 s11, s11, s13
829
- ; GFX90A-NEXT: s_mov_b64 s[14:15 ], 0
833
+ ; GFX90A-NEXT: s_mov_b64 s[0:1 ], 0
830
834
; GFX90A-NEXT: s_branch .LBB3_1
831
835
; GFX90A-NEXT: .LBB3_12: ; %DummyReturnBlock
832
836
; GFX90A-NEXT: s_endpgm
0 commit comments