[PATCH] D50465: [InstCombine] Optimize redundant 'signed truncation check pattern'.
Roman Lebedev via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Mon Aug 13 13:08:19 PDT 2018
lebedev.ri added a comment.
Thank you for taking a look!
In https://reviews.llvm.org/D50465#1197796, @spatel wrote:
> LGTM.
(i'm not sure if you've meant to accept this, because you have only posted the comment, not clicked 'accept')
To be noted, i still don't quite like this code, but i'm not sure how to improve this.
In https://reviews.llvm.org/D50465#1197796, @spatel wrote:
> About the autogen script problem - we could hack that to use something less likely than 'TMP' as its regex string (eg, 'AUTOGEN'), but that will result in significant test file churn if someone updates an existing file.
Yeah... I think some note in the docs would be good-enough, too.
================
Comment at: lib/Transforms/InstCombine/InstCombineAndOrXor.cpp:1311-1316
+ assert(I.getOpcode() == Instruction::And);
+ // We are looking for an 'and' of two icmp's
+ auto *ICmp0 = dyn_cast<ICmpInst>(I.getOperand(0));
+ auto *ICmp1 = dyn_cast<ICmpInst>(I.getOperand(1));
+ if (!(ICmp0 && ICmp1))
+ return nullptr;
----------------
spatel wrote:
> lebedev.ri wrote:
> > spatel wrote:
> > > Can this be moved within InstCombiner::foldAndOfICmps() to eliminate these preliminary checks?
> > >
> > > Any chance for shared functionality with foldAndOrOfICmpsOfAndWithPow2() or simplifyRangeCheck()?
> > I don't think i should squeeze it into `InstCombiner::foldAndOrOfICmpsOfAndWithPow2()`,
> > as that looks for a *very* specific, different pattern.
> >
> > `InstCombiner::simplifyRangeCheck()` also does not look too promising,
> > we will then only handle the extreme cases (which is, admittedly, probably
> > sufficient for my needs right now), but not the general case :/
> >
> > None of those handle this case because they mostly require for the both icmp's
> > to operate on the same value, and don't understand what
> > ```
> > %t = add i32 %arg, 128
> > %r = icmp ult i32 %t, 256
> > ```
> > (and similar patterns) mean.
> >
> > So i have sunk it down into `InstCombiner::foldAndOfICmps()` for now..
> Ok, thanks for checking. I think we've noted this before - the whole thing is a complicated mess, and there should be some better way to generalize it, but it's not clear how to do it.
Auto-generated (souper) tablegen-driven transforms would be The Solution :)
Else i suspect we'll be hitting missing corner cases and patterns for eternities to come.
Repository:
rL LLVM
https://reviews.llvm.org/D50465
More information about the llvm-commits
mailing list