[clang] [llvm] [Transforms][Utils][PromoteMem2Reg] Propagate nnan flag on par with the nsz flag (PR #114271)
Nikita Popov via llvm-commits
llvm-commits at lists.llvm.org
Tue Nov 5 11:27:32 PST 2024
================
@@ -1140,6 +1148,15 @@ void PromoteMem2Reg::RenamePass(BasicBlock *BB, BasicBlock *Pred,
if (isa<FPMathOperator>(APN) && NoSignedZeros)
APN->setHasNoSignedZeros(true);
+ // This allows select instruction folding relevant to floating point
+ // reductions whose operand is a PHI.
+ if (isa<FPMathOperator>(APN) && NoNaNs)
+ APN->setHasNoNaNs(true);
+
+ // Handle NoInfs flag too.
+ if (isa<FPMathOperator>(APN) && NoInfs)
+ APN->setHasNoInfs(true);
----------------
nikic wrote:
I'd suggest to extract a common `if (isa<FPMathOperator>(APN))` around all three.
https://github.com/llvm/llvm-project/pull/114271
More information about the llvm-commits
mailing list