================ @@ -806,6 +806,19 @@ static unsigned getOpcodeForRecipe(VPRecipeBase &R) { /// Try to simplify recipe \p R. static void simplifyRecipe(VPRecipeBase &R, VPTypeAnalysis &TypeInfo) { + // Try to remove redundant blend recipes. + if (auto *Blend = dyn_cast<VPBlendRecipe>(&R)) { + bool AllEqual = true; + for (unsigned I = 1; I != Blend->getNumIncomingValues(); ++I) + AllEqual &= Blend->getIncomingValue(0) == Blend->getIncomingValue(I); + if (AllEqual) { + Blend->replaceAllUsesWith(Blend->getIncomingValue(0)); + Blend->eraseFromParent(); + return; + } + return; + } ---------------- ayalz wrote:
Can be simplified? ```suggestion if (auto *Blend = dyn_cast<VPBlendRecipe>(&R)) { for (unsigned I = 1; I != Blend->getNumIncomingValues(); ++I) if (Blend->getIncomingValue(0) != Blend->getIncomingValue(I)) return; Blend->replaceAllUsesWith(Blend->getIncomingValue(0)); Blend->eraseFromParent(); return; } ``` https://github.com/llvm/llvm-project/pull/76090 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits