diff options
author | Sanjoy Das <sanjoy@playingwithpointers.com> | 2019-03-11 21:36:41 +0000 |
---|---|---|
committer | Sanjoy Das <sanjoy@playingwithpointers.com> | 2019-03-11 21:36:41 +0000 |
commit | 93f8cc186ace5965a826dd2a11a359f661ba75a3 (patch) | |
tree | e27c171096642183d3e121b6a1a16b44cf11afea /llvm/lib/CodeGen | |
parent | b6d322bdc25e67d538c1d14d3ead9724837f057c (diff) | |
download | bcm5719-llvm-93f8cc186ace5965a826dd2a11a359f661ba75a3.tar.gz bcm5719-llvm-93f8cc186ace5965a826dd2a11a359f661ba75a3.zip |
Relax constraints for reduction vectorization
Summary:
Gating vectorizing reductions on *all* fastmath flags seems unnecessary;
`reassoc` should be sufficient.
Reviewers: tvvikram, mkuper, kristof.beyls, sdesmalen, Ayal
Reviewed By: sdesmalen
Subscribers: dcaballe, huntergr, jmolloy, mcrosier, jlebar, bixia, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D57728
llvm-svn: 355868
Diffstat (limited to 'llvm/lib/CodeGen')
-rw-r--r-- | llvm/lib/CodeGen/ExpandReductions.cpp | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/ExpandReductions.cpp b/llvm/lib/CodeGen/ExpandReductions.cpp index f44d89156b6..34858883298 100644 --- a/llvm/lib/CodeGen/ExpandReductions.cpp +++ b/llvm/lib/CodeGen/ExpandReductions.cpp @@ -118,9 +118,11 @@ bool expandReductions(Function &F, const TargetTransformInfo *TTI) { } if (!TTI->shouldExpandReduction(II)) continue; + FastMathFlags FMF = + isa<FPMathOperator>(II) ? II->getFastMathFlags() : FastMathFlags{}; Value *Rdx = IsOrdered ? getOrderedReduction(Builder, Acc, Vec, getOpcode(ID), MRK) - : getShuffleReduction(Builder, Vec, getOpcode(ID), MRK); + : getShuffleReduction(Builder, Vec, getOpcode(ID), MRK, FMF); II->replaceAllUsesWith(Rdx); II->eraseFromParent(); Changed = true; |