diff options
author | Ramkumar Ramachandra <ramkumar.ramachandra@codasip.com> | 2024-12-13 14:18:33 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-12-13 14:18:33 +0000 |
commit | 4a0d53a0b0a58a3c6980a7c551357ac71ba3db10 (patch) | |
tree | ce56a6aab6c39c04d1f9b40cb2061c0f312e65cc /llvm/lib/CodeGen/CodeGenPrepare.cpp | |
parent | 89f1f32bff76c8cf4545ada34663c6a758214cf0 (diff) | |
download | llvm-4a0d53a0b0a58a3c6980a7c551357ac71ba3db10.zip llvm-4a0d53a0b0a58a3c6980a7c551357ac71ba3db10.tar.gz llvm-4a0d53a0b0a58a3c6980a7c551357ac71ba3db10.tar.bz2 |
PatternMatch: migrate to CmpPredicate (#118534)
With the introduction of CmpPredicate in 51a895a (IR: introduce struct
with CmpInst::Predicate and samesign), PatternMatch is one of the first
key pieces of infrastructure that must be updated to match a CmpInst
respecting samesign information. Implement this change to Cmp-matchers.
This is a preparatory step in migrating the codebase over to
CmpPredicate. Since we no functional changes are desired at this stage,
we have chosen not to migrate CmpPredicate::operator==(CmpPredicate)
calls to use CmpPredicate::getMatching(), as that would have visible
impact on tests that are not yet written: instead, we call
CmpPredicate::operator==(Predicate), preserving the old behavior, while
also inserting a few FIXME comments for follow-ups.
Diffstat (limited to 'llvm/lib/CodeGen/CodeGenPrepare.cpp')
-rw-r--r-- | llvm/lib/CodeGen/CodeGenPrepare.cpp | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/llvm/lib/CodeGen/CodeGenPrepare.cpp b/llvm/lib/CodeGen/CodeGenPrepare.cpp index 83c6ecd..5c712e4 100644 --- a/llvm/lib/CodeGen/CodeGenPrepare.cpp +++ b/llvm/lib/CodeGen/CodeGenPrepare.cpp @@ -1885,7 +1885,7 @@ static bool foldICmpWithDominatingICmp(CmpInst *Cmp, return false; Value *CmpOp0 = Cmp->getOperand(0), *CmpOp1 = Cmp->getOperand(1); - ICmpInst::Predicate DomPred; + CmpPredicate DomPred; if (!match(DomCond, m_ICmp(DomPred, m_Specific(CmpOp0), m_Specific(CmpOp1)))) return false; if (DomPred != ICmpInst::ICMP_SGT && DomPred != ICmpInst::ICMP_SLT) @@ -2155,7 +2155,7 @@ bool CodeGenPrepare::optimizeURem(Instruction *Rem) { static bool adjustIsPower2Test(CmpInst *Cmp, const TargetLowering &TLI, const TargetTransformInfo &TTI, const DataLayout &DL) { - ICmpInst::Predicate Pred; + CmpPredicate Pred; if (!match(Cmp, m_ICmp(Pred, m_Intrinsic<Intrinsic::ctpop>(), m_One()))) return false; if (!ICmpInst::isEquality(Pred)) |