[PATCH] D105730: [SLP] match logical and/or as reduction candidates
Sanjay Patel via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Mon Jul 12 07:09:49 PDT 2021
spatel marked an inline comment as done.
spatel added inline comments.
================
Comment at: llvm/test/Transforms/PhaseOrdering/X86/vector-reductions-logical.ll:448
+; CHECK-NEXT: [[CMP20:%.*]] = icmp sgt i32 [[TMP0]], 255
+; CHECK-NEXT: [[OR_COND6:%.*]] = select i1 [[TMP10]], i1 true, i1 [[CMP20]]
+; CHECK-NEXT: [[ADD:%.*]] = add nsw i32 [[TMP3]], [[TMP2]]
----------------
ABataev wrote:
> spatel wrote:
> > spatel wrote:
> > > RKSimon wrote:
> > > > any idea why we only match one of the reduction chains?
> > > I haven't stepped through yet. We did make some adjustments for sorting the reduction ops in previous patches, but I doubt that extended to creating multiple reductions and/or re-running analysis after forming a reduction.
> > To be more specific, this test should be adapted into an SLP-only test - the enhancement will need to happen within SLP to handle mapping reduction ops into multiple reductions in some way.
> Investigated it, looks like inefficiency in multi-node analysis (we're forming mixed operand nodes, like `{extract 0, extract 1, extract 2, extract 3, 0.0, 0.0, 0.0, 0.0}` and `{1.0, 1.0, 1.0, 1.0, extract 0, extract 1, extract 2, extract 3}`, which are considered as gathers). I hope this can be fixed by D101109.
Thanks for checking. I'll add a basic SLP test to this patch, so we have minimal test coverage, and we can add more as needed.
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D105730/new/
https://reviews.llvm.org/D105730
More information about the llvm-commits
mailing list