[llvm] [InstCombine] Missing optimization: fold mul (select a, b), (select b, a) to mul a, b (PR #74953)
Nikita Popov via llvm-commits
llvm-commits at lists.llvm.org
Sun Dec 10 14:37:30 PST 2023
================
@@ -1132,6 +1132,13 @@ Value *InstCombinerImpl::SimplifySelectsFeedingBinaryOp(BinaryOperator &I,
};
if (LHSIsSelect && RHSIsSelect && A == D) {
+ // op(select(%v, %x, %y), select(%v, %y, %x)) --> op(%x, %y)
+ if (I.isCommutative() && B == F && C == E) {
+ Value *BI = Builder.CreateBinOp(I.getOpcode(), B, E);
+ BI->takeName(&I);
----------------
nikic wrote:
It doesn't -- dropping poison generating flags undoes the preceding flag copy. You should only call copyIRFlags(), not dropPoisonGeneratingFlags().
https://github.com/llvm/llvm-project/pull/74953
More information about the llvm-commits
mailing list