[llvm] [InstSimplify] Fix Inconsistent PHI Simplification (PR #113037)
Marius Kamp via llvm-commits
llvm-commits at lists.llvm.org
Tue Oct 22 03:14:27 PDT 2024
================
@@ -5288,6 +5288,54 @@ Value *llvm::simplifyExtractElementInst(Value *Vec, Value *Idx,
return ::simplifyExtractElementInst(Vec, Idx, Q, RecursionLimit);
}
+static Value *getCommonPHIValue(Value *PreviousCommon, Value *Current,
+ const SimplifyQuery &Q) {
+ if (!PreviousCommon)
+ return Current;
+
+ if (PreviousCommon == Current)
+ return PreviousCommon;
+
+ Constant *PreviousCommonC, *CurrentC;
+ if (match(PreviousCommon, m_Constant(PreviousCommonC)) &&
+ match(Current, m_Constant(CurrentC))) {
+ auto *VecTy = dyn_cast<FixedVectorType>(PreviousCommonC->getType());
+ if (VecTy) {
+ SmallVector<Constant *> NewCommonC;
+ unsigned NumElts = VecTy->getNumElements();
+ for (unsigned I = 0; I != NumElts; ++I) {
+ Constant *PrevElt = PreviousCommonC->getAggregateElement(I);
+ Constant *CurrElt = CurrentC->getAggregateElement(I);
+ if (!PrevElt || !CurrElt)
+ return nullptr;
----------------
mskamp wrote:
I've added some tests with constant expressions that survive simplification. These do indeed result in `!PrevElt` or `!CurrEllt` here.
https://github.com/llvm/llvm-project/pull/113037
More information about the llvm-commits
mailing list