[llvm-dev] InstCombine, graph rewriting, Equality saturation
Hal Finkel via llvm-dev
llvm-dev at lists.llvm.org
Fri Sep 8 17:32:44 PDT 2017
On 09/05/2017 05:57 PM, (IIIT) Siddharth Bhat via llvm-dev wrote:
> Hello all,
>
> I've seen some discussion that InstCombine is "too general" and that
> llvm should implement a proper graph rewrite mechanism:
>
> Link to llvm-dev discussion about this:
> http://lists.llvm.org/pipermail/llvm-dev/2017-May/113219.html,
> Link to review where this came up (and I first heard about it):
> https://reviews.llvm.org/D37195.
>
> I wanted to understand what the current issues with InstCombine are,
> and if a graph rewriter prototype is something people are interested
> in. I find the idea appealing, from what little I know it, so I'd be
> interested in hacking something up.
>
> What would such a framework look like? Is there past literature on the
> subject? From what I know, many functional compilers using combinator
> based compilation were graph rewriting. Is there other prior art?
I'm not sure that I'd describe it as "too general", but I suspect that
it could be made much more efficient. Currently, the patterns are
implemented in C++, which is often fairly verbose, and because many of
the checks are implemented separately, we end up touching instructions
many times as we attempt to match different patterns. Worse, for many of
these instructions we end up checking properties, such as known bits,
that are computed by further backward instructions visiting. It is also
hard to automatically check the correctness of the transformations, and
moreover, it is hard to prove that we'll eventually reach a fixed point
(we've certainly had problems in the past where some inputs would cause
an endless loop between two different InstCombine patterns).
I'd love to see a solution where most of the transformations were
specified in TableGen files and:
1. We, as a result, had an easy way to convert these into a form where
some SMT-solver-based checker could certify correctness.
2. We, as a result, has an easy way to somehow check soundness, as a
rewrite system, so we'd know it would reach a fixed point for all inputs.
3. We, as a result, reduced the number of lines of code we need to
maintain for these peephole optimizations.
4. We, as a result, could generate efficient code for matching the
patterns using some automaton technique for minimizing unnecessary
visiting of instructions.
I'm not sure how closely it matches what we would need, but Stratego/XT
comes to mind in terms of prior art (now here:
http://www.metaborg.org/en/latest/). There's been a lot of work over the
years on terminating graph rewriting systems in compilers.
-Hal
>
> Also, there is the idea of Equality Saturation
> (http://www.cs.cornell.edu/~ross/publications/eqsat/
> <http://www.cs.cornell.edu/%7Eross/publications/eqsat/>) that I found
> out about recently. Could this be used to augment the InstCombine
> infrastructure?
>
> Thanks,
> ~Siddharth
>
> --
> Sending this from my phone, please excuse any typos!
>
>
> _______________________________________________
> LLVM Developers mailing list
> llvm-dev at lists.llvm.org
> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev
--
Hal Finkel
Lead, Compiler Technology and Programming Languages
Leadership Computing Facility
Argonne National Laboratory
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20170908/cfec3a54/attachment.html>
More information about the llvm-dev
mailing list