[llvm] [InstCombine] Pull extract through broadcast (PR #143380)
Nikita Popov via llvm-commits
llvm-commits at lists.llvm.org
Mon Jun 9 12:27:33 PDT 2025
================
@@ -542,6 +542,13 @@ Instruction *InstCombinerImpl::visitExtractElementInst(ExtractElementInst &EI) {
}
}
} else if (auto *SVI = dyn_cast<ShuffleVectorInst>(I)) {
+ // extractelt (shufflevector %v1, %v2, splat-mask) idx ->
+ // extractelt %v1, splat-mask[0]
+ auto Mask = SVI->getShuffleMask();
+ if (Mask[0] != PoisonMaskElem && all_equal(Mask))
----------------
nikic wrote:
Should also check `isa<PoisonValue>(SVI->getOperand(1))` to make sure the mask isn't a broadcast from the second operand. You won't be able to test this because it usually gets folded away earlier, but it can occur due to worklist order.
https://github.com/llvm/llvm-project/pull/143380
More information about the llvm-commits
mailing list