Skip to content

Commit 8019197

Browse files
JamesChestermanNickGuy-Arm
authored andcommitted
[DAGCombiner] Add DAG combine for PARTIAL_REDUCE_MLA when no mul op
Generic DAG combine for ISD::PARTIAL_REDUCE_U/SMLA to convert: PARTIAL_REDUCE_*MLA(Acc, ZEXT(UnextOp1), Splat(1)) into PARTIAL_REDUCE_UMLA(Acc, UnextOp1, TRUNC(Splat(1))) and PARTIAL_REDUCE_*MLA(Acc, SEXT(UnextOp1), Splat(1)) into PARTIAL_REDUCE_SMLA(Acc, UnextOp1, TRUNC(Splat(1))).
1 parent 364835d commit 8019197

File tree

2 files changed

+73
-83
lines changed

2 files changed

+73
-83
lines changed

llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp

Lines changed: 53 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -622,6 +622,8 @@ namespace {
622622
SDValue CombineConsecutiveLoads(SDNode *N, EVT VT);
623623
SDValue foldBitcastedFPLogic(SDNode *N, SelectionDAG &DAG,
624624
const TargetLowering &TLI);
625+
SDValue foldPartialReduceMLAMulOp(SDNode *N);
626+
SDValue foldPartialReduceMLANoMulOp(SDNode *N);
625627

626628
SDValue CombineExtLoad(SDNode *N);
627629
SDValue CombineZExtLogicopShiftLoad(SDNode *N);
@@ -12496,13 +12498,21 @@ SDValue DAGCombiner::visitMHISTOGRAM(SDNode *N) {
1249612498
return SDValue();
1249712499
}
1249812500

12501+
SDValue DAGCombiner::visitPARTIAL_REDUCE_MLA(SDNode *N) {
12502+
if (SDValue Res = foldPartialReduceMLAMulOp(N))
12503+
return Res;
12504+
if (SDValue Res = foldPartialReduceMLANoMulOp(N))
12505+
return Res;
12506+
return SDValue();
12507+
}
12508+
1249912509
// Makes PARTIAL_REDUCE_*MLA(Acc, MUL(ZEXT(LHSExtOp), ZEXT(RHSExtOp)),
1250012510
// Splat(1)) into
1250112511
// PARTIAL_REDUCE_UMLA(Acc, LHSExtOp, RHSExtOp).
1250212512
// Makes PARTIAL_REDUCE_*MLA(Acc, MUL(SEXT(LHSExtOp), SEXT(RHSExtOp)),
1250312513
// Splat(1)) into
1250412514
// PARTIAL_REDUCE_SMLA(Acc, LHSExtOp, RHSExtOp).
12505-
SDValue DAGCombiner::visitPARTIAL_REDUCE_MLA(SDNode *N) {
12515+
SDValue DAGCombiner::foldPartialReduceMLAMulOp(SDNode *N) {
1250612516
SDLoc DL(N);
1250712517

1250812518
SDValue Acc = N->getOperand(0);
@@ -12550,6 +12560,48 @@ SDValue DAGCombiner::visitPARTIAL_REDUCE_MLA(SDNode *N) {
1255012560
RHSExtOp);
1255112561
}
1255212562

12563+
// Makes PARTIAL_REDUCE_*MLA(Acc, ZEXT(UnextOp1), Splat(1)) into
12564+
// PARTIAL_REDUCE_UMLA(Acc, Op, TRUNC(Splat(1)))
12565+
// Makes PARTIAL_REDUCE_*MLA(Acc, SEXT(UnextOp1), Splat(1)) into
12566+
// PARTIAL_REDUCE_SMLA(Acc, Op, TRUNC(Splat(1)))
12567+
SDValue DAGCombiner::foldPartialReduceMLANoMulOp(SDNode *N) {
12568+
SDLoc DL(N);
12569+
SDValue Acc = N->getOperand(0);
12570+
SDValue Op1 = N->getOperand(1);
12571+
SDValue Op2 = N->getOperand(2);
12572+
12573+
APInt ConstantOne;
12574+
if (!ISD::isConstantSplatVector(Op2.getNode(), ConstantOne) ||
12575+
!ConstantOne.isOne())
12576+
return SDValue();
12577+
12578+
unsigned Op1Opcode = Op1.getOpcode();
12579+
if (!ISD::isExtOpcode(Op1Opcode))
12580+
return SDValue();
12581+
12582+
SDValue UnextOp1 = Op1.getOperand(0);
12583+
EVT UnextOp1VT = UnextOp1.getValueType();
12584+
12585+
if (!TLI.isPartialReduceMLALegalOrCustom(N->getValueType(0), UnextOp1VT))
12586+
return SDValue();
12587+
12588+
SDValue TruncOp2 = DAG.getNode(ISD::TRUNCATE, DL, UnextOp1VT, Op2);
12589+
12590+
bool Op1IsSigned = Op1Opcode == ISD::SIGN_EXTEND;
12591+
12592+
bool NodeIsSigned = N->getOpcode() == ISD::PARTIAL_REDUCE_SMLA;
12593+
EVT AccElemVT = Acc.getValueType().getVectorElementType();
12594+
if (Op1IsSigned != NodeIsSigned &&
12595+
(Op1.getValueType().getVectorElementType() != AccElemVT ||
12596+
Op2.getValueType().getVectorElementType() != AccElemVT))
12597+
return SDValue();
12598+
12599+
unsigned NewOpcode =
12600+
Op1IsSigned ? ISD::PARTIAL_REDUCE_SMLA : ISD::PARTIAL_REDUCE_UMLA;
12601+
return DAG.getNode(NewOpcode, DL, N->getValueType(0), Acc, UnextOp1,
12602+
TruncOp2);
12603+
}
12604+
1255312605
SDValue DAGCombiner::visitVP_STRIDED_LOAD(SDNode *N) {
1255412606
auto *SLD = cast<VPStridedLoadSDNode>(N);
1255512607
EVT EltVT = SLD->getValueType(0).getVectorElementType();

llvm/test/CodeGen/AArch64/sve-partial-reduce-dot-product.ll

Lines changed: 20 additions & 82 deletions
Original file line numberDiff line numberDiff line change
@@ -594,16 +594,8 @@ define <vscale x 4 x i32> @udot_no_bin_op(<vscale x 4 x i32> %acc, <vscale x 16
594594
;
595595
; CHECK-NEWLOWERING-LABEL: udot_no_bin_op:
596596
; CHECK-NEWLOWERING: // %bb.0:
597-
; CHECK-NEWLOWERING-NEXT: uunpklo z2.h, z1.b
598-
; CHECK-NEWLOWERING-NEXT: uunpkhi z1.h, z1.b
599-
; CHECK-NEWLOWERING-NEXT: uunpklo z3.s, z2.h
600-
; CHECK-NEWLOWERING-NEXT: uunpkhi z4.s, z1.h
601-
; CHECK-NEWLOWERING-NEXT: uunpklo z1.s, z1.h
602-
; CHECK-NEWLOWERING-NEXT: uunpkhi z2.s, z2.h
603-
; CHECK-NEWLOWERING-NEXT: add z0.s, z0.s, z3.s
604-
; CHECK-NEWLOWERING-NEXT: add z1.s, z2.s, z1.s
605-
; CHECK-NEWLOWERING-NEXT: add z0.s, z4.s, z0.s
606-
; CHECK-NEWLOWERING-NEXT: add z0.s, z1.s, z0.s
597+
; CHECK-NEWLOWERING-NEXT: mov z2.b, #1 // =0x1
598+
; CHECK-NEWLOWERING-NEXT: udot z0.s, z1.b, z2.b
607599
; CHECK-NEWLOWERING-NEXT: ret
608600
%a.ext = zext <vscale x 16 x i8> %a to <vscale x 16 x i32>
609601
%partial.reduce = tail call <vscale x 4 x i32> @llvm.experimental.vector.partial.reduce.add.nxv4i32.nxv16i32(<vscale x 4 x i32> %acc, <vscale x 16 x i32> %a.ext)
@@ -619,16 +611,8 @@ define <vscale x 4 x i32> @sdot_no_bin_op(<vscale x 4 x i32> %acc, <vscale x 16
619611
;
620612
; CHECK-NEWLOWERING-LABEL: sdot_no_bin_op:
621613
; CHECK-NEWLOWERING: // %bb.0:
622-
; CHECK-NEWLOWERING-NEXT: sunpklo z2.h, z1.b
623-
; CHECK-NEWLOWERING-NEXT: sunpkhi z1.h, z1.b
624-
; CHECK-NEWLOWERING-NEXT: sunpklo z3.s, z2.h
625-
; CHECK-NEWLOWERING-NEXT: sunpkhi z4.s, z1.h
626-
; CHECK-NEWLOWERING-NEXT: sunpklo z1.s, z1.h
627-
; CHECK-NEWLOWERING-NEXT: sunpkhi z2.s, z2.h
628-
; CHECK-NEWLOWERING-NEXT: add z0.s, z0.s, z3.s
629-
; CHECK-NEWLOWERING-NEXT: add z1.s, z2.s, z1.s
630-
; CHECK-NEWLOWERING-NEXT: add z0.s, z4.s, z0.s
631-
; CHECK-NEWLOWERING-NEXT: add z0.s, z1.s, z0.s
614+
; CHECK-NEWLOWERING-NEXT: mov z2.b, #1 // =0x1
615+
; CHECK-NEWLOWERING-NEXT: sdot z0.s, z1.b, z2.b
632616
; CHECK-NEWLOWERING-NEXT: ret
633617
%a.ext = sext <vscale x 16 x i8> %a to <vscale x 16 x i32>
634618
%partial.reduce = tail call <vscale x 4 x i32> @llvm.experimental.vector.partial.reduce.add.nxv4i32.nxv16i32(<vscale x 4 x i32> %acc, <vscale x 16 x i32> %a.ext)
@@ -644,16 +628,8 @@ define <vscale x 2 x i64> @udot_no_bin_op_wide(<vscale x 2 x i64> %acc, <vscale
644628
;
645629
; CHECK-NEWLOWERING-LABEL: udot_no_bin_op_wide:
646630
; CHECK-NEWLOWERING: // %bb.0: // %entry
647-
; CHECK-NEWLOWERING-NEXT: uunpklo z2.s, z1.h
648-
; CHECK-NEWLOWERING-NEXT: uunpkhi z1.s, z1.h
649-
; CHECK-NEWLOWERING-NEXT: uunpklo z3.d, z2.s
650-
; CHECK-NEWLOWERING-NEXT: uunpkhi z4.d, z1.s
651-
; CHECK-NEWLOWERING-NEXT: uunpklo z1.d, z1.s
652-
; CHECK-NEWLOWERING-NEXT: uunpkhi z2.d, z2.s
653-
; CHECK-NEWLOWERING-NEXT: add z0.d, z0.d, z3.d
654-
; CHECK-NEWLOWERING-NEXT: add z1.d, z2.d, z1.d
655-
; CHECK-NEWLOWERING-NEXT: add z0.d, z4.d, z0.d
656-
; CHECK-NEWLOWERING-NEXT: add z0.d, z1.d, z0.d
631+
; CHECK-NEWLOWERING-NEXT: mov z2.h, #1 // =0x1
632+
; CHECK-NEWLOWERING-NEXT: udot z0.d, z1.h, z2.h
657633
; CHECK-NEWLOWERING-NEXT: ret
658634
entry:
659635
%a.wide = zext <vscale x 8 x i16> %a to <vscale x 8 x i64>
@@ -670,16 +646,8 @@ define <vscale x 2 x i64> @sdot_no_bin_op_wide(<vscale x 2 x i64> %acc, <vscale
670646
;
671647
; CHECK-NEWLOWERING-LABEL: sdot_no_bin_op_wide:
672648
; CHECK-NEWLOWERING: // %bb.0: // %entry
673-
; CHECK-NEWLOWERING-NEXT: sunpklo z2.s, z1.h
674-
; CHECK-NEWLOWERING-NEXT: sunpkhi z1.s, z1.h
675-
; CHECK-NEWLOWERING-NEXT: sunpklo z3.d, z2.s
676-
; CHECK-NEWLOWERING-NEXT: sunpkhi z4.d, z1.s
677-
; CHECK-NEWLOWERING-NEXT: sunpklo z1.d, z1.s
678-
; CHECK-NEWLOWERING-NEXT: sunpkhi z2.d, z2.s
679-
; CHECK-NEWLOWERING-NEXT: add z0.d, z0.d, z3.d
680-
; CHECK-NEWLOWERING-NEXT: add z1.d, z2.d, z1.d
681-
; CHECK-NEWLOWERING-NEXT: add z0.d, z4.d, z0.d
682-
; CHECK-NEWLOWERING-NEXT: add z0.d, z1.d, z0.d
649+
; CHECK-NEWLOWERING-NEXT: mov z2.h, #1 // =0x1
650+
; CHECK-NEWLOWERING-NEXT: sdot z0.d, z1.h, z2.h
683651
; CHECK-NEWLOWERING-NEXT: ret
684652
entry:
685653
%a.wide = sext <vscale x 8 x i16> %a to <vscale x 8 x i64>
@@ -701,28 +669,13 @@ define <vscale x 4 x i64> @udot_no_bin_op_8to64(<vscale x 4 x i64> %acc, <vscale
701669
;
702670
; CHECK-NEWLOWERING-LABEL: udot_no_bin_op_8to64:
703671
; CHECK-NEWLOWERING: // %bb.0:
704-
; CHECK-NEWLOWERING-NEXT: uunpklo z3.h, z2.b
672+
; CHECK-NEWLOWERING-NEXT: mov z3.b, #1 // =0x1
673+
; CHECK-NEWLOWERING-NEXT: uunpklo z5.h, z2.b
705674
; CHECK-NEWLOWERING-NEXT: uunpkhi z2.h, z2.b
706-
; CHECK-NEWLOWERING-NEXT: uunpklo z4.s, z3.h
707-
; CHECK-NEWLOWERING-NEXT: uunpkhi z5.s, z2.h
708-
; CHECK-NEWLOWERING-NEXT: uunpklo z2.s, z2.h
709-
; CHECK-NEWLOWERING-NEXT: uunpkhi z3.s, z3.h
710-
; CHECK-NEWLOWERING-NEXT: uunpkhi z6.d, z4.s
711-
; CHECK-NEWLOWERING-NEXT: uunpklo z4.d, z4.s
712-
; CHECK-NEWLOWERING-NEXT: uunpkhi z7.d, z5.s
713-
; CHECK-NEWLOWERING-NEXT: uunpklo z24.d, z2.s
714-
; CHECK-NEWLOWERING-NEXT: uunpklo z25.d, z3.s
715-
; CHECK-NEWLOWERING-NEXT: uunpkhi z2.d, z2.s
716-
; CHECK-NEWLOWERING-NEXT: uunpkhi z3.d, z3.s
717-
; CHECK-NEWLOWERING-NEXT: uunpklo z5.d, z5.s
718-
; CHECK-NEWLOWERING-NEXT: add z0.d, z0.d, z4.d
719-
; CHECK-NEWLOWERING-NEXT: add z1.d, z1.d, z6.d
720-
; CHECK-NEWLOWERING-NEXT: add z4.d, z25.d, z24.d
721-
; CHECK-NEWLOWERING-NEXT: add z2.d, z3.d, z2.d
722-
; CHECK-NEWLOWERING-NEXT: add z0.d, z5.d, z0.d
723-
; CHECK-NEWLOWERING-NEXT: add z1.d, z7.d, z1.d
724-
; CHECK-NEWLOWERING-NEXT: add z0.d, z4.d, z0.d
725-
; CHECK-NEWLOWERING-NEXT: add z1.d, z2.d, z1.d
675+
; CHECK-NEWLOWERING-NEXT: uunpklo z4.h, z3.b
676+
; CHECK-NEWLOWERING-NEXT: uunpkhi z3.h, z3.b
677+
; CHECK-NEWLOWERING-NEXT: udot z0.d, z5.h, z4.h
678+
; CHECK-NEWLOWERING-NEXT: udot z1.d, z2.h, z3.h
726679
; CHECK-NEWLOWERING-NEXT: ret
727680
%a.ext = zext <vscale x 16 x i8> %a to <vscale x 16 x i64>
728681
%partial.reduce = tail call <vscale x 4 x i64> @llvm.experimental.vector.partial.reduce.add.nxv4i64.nxv16i64(<vscale x 4 x i64> %acc, <vscale x 16 x i64> %a.ext)
@@ -743,28 +696,13 @@ define <vscale x 4 x i64> @sdot_no_bin_op_8to64(<vscale x 4 x i64> %acc, <vscale
743696
;
744697
; CHECK-NEWLOWERING-LABEL: sdot_no_bin_op_8to64:
745698
; CHECK-NEWLOWERING: // %bb.0:
746-
; CHECK-NEWLOWERING-NEXT: sunpklo z3.h, z2.b
699+
; CHECK-NEWLOWERING-NEXT: mov z3.b, #1 // =0x1
700+
; CHECK-NEWLOWERING-NEXT: sunpklo z5.h, z2.b
747701
; CHECK-NEWLOWERING-NEXT: sunpkhi z2.h, z2.b
748-
; CHECK-NEWLOWERING-NEXT: sunpklo z4.s, z3.h
749-
; CHECK-NEWLOWERING-NEXT: sunpkhi z5.s, z2.h
750-
; CHECK-NEWLOWERING-NEXT: sunpklo z2.s, z2.h
751-
; CHECK-NEWLOWERING-NEXT: sunpkhi z3.s, z3.h
752-
; CHECK-NEWLOWERING-NEXT: sunpkhi z6.d, z4.s
753-
; CHECK-NEWLOWERING-NEXT: sunpklo z4.d, z4.s
754-
; CHECK-NEWLOWERING-NEXT: sunpkhi z7.d, z5.s
755-
; CHECK-NEWLOWERING-NEXT: sunpklo z24.d, z2.s
756-
; CHECK-NEWLOWERING-NEXT: sunpklo z25.d, z3.s
757-
; CHECK-NEWLOWERING-NEXT: sunpkhi z2.d, z2.s
758-
; CHECK-NEWLOWERING-NEXT: sunpkhi z3.d, z3.s
759-
; CHECK-NEWLOWERING-NEXT: sunpklo z5.d, z5.s
760-
; CHECK-NEWLOWERING-NEXT: add z0.d, z0.d, z4.d
761-
; CHECK-NEWLOWERING-NEXT: add z1.d, z1.d, z6.d
762-
; CHECK-NEWLOWERING-NEXT: add z4.d, z25.d, z24.d
763-
; CHECK-NEWLOWERING-NEXT: add z2.d, z3.d, z2.d
764-
; CHECK-NEWLOWERING-NEXT: add z0.d, z5.d, z0.d
765-
; CHECK-NEWLOWERING-NEXT: add z1.d, z7.d, z1.d
766-
; CHECK-NEWLOWERING-NEXT: add z0.d, z4.d, z0.d
767-
; CHECK-NEWLOWERING-NEXT: add z1.d, z2.d, z1.d
702+
; CHECK-NEWLOWERING-NEXT: sunpklo z4.h, z3.b
703+
; CHECK-NEWLOWERING-NEXT: sunpkhi z3.h, z3.b
704+
; CHECK-NEWLOWERING-NEXT: sdot z0.d, z5.h, z4.h
705+
; CHECK-NEWLOWERING-NEXT: sdot z1.d, z2.h, z3.h
768706
; CHECK-NEWLOWERING-NEXT: ret
769707
%a.ext = sext <vscale x 16 x i8> %a to <vscale x 16 x i64>
770708
%partial.reduce = tail call <vscale x 4 x i64> @llvm.experimental.vector.partial.reduce.add.nxv4i64.nxv16i64(<vscale x 4 x i64> %acc, <vscale x 16 x i64> %a.ext)

0 commit comments

Comments
 (0)