[llvm-dev] [IDF][analyzer] Generalizing IDFCalculator to be used for Clang's CFG

Jakub (Kuba) Kuderski via llvm-dev llvm-dev at lists.llvm.org
Mon Jun 17 08:00:57 PDT 2019


Hi Kristóf,


> 1. I read the article IDFCalculator is based on[1], but I found no
> references to IDFCalculator::setLiveInBlocks, and the file header seems to
> confirm that it's an implementation specific thing. Could I get away
> restricting the clang::CFG tailored version to not contain this function?
>
What's stopping you from implementing it for clang CFG? I looked at the
code and it seems like your new implementation handles it.

2. I didn't really manage to understand the logic for GraphDiff. What does
> it really do in IDFCalculator's context? I dag out the patch[2] that added
> an extra constructor to use a snapshot of the CFG, but it seems to be
> unused. Is it also unlikely that we find any use for this? Mind you, the
> patch size grew a lot because I also "templatized" GraphDiff and all
> related classes to handle clang's CFG.
>

GraphDiff is just a wrapper that was created to represent intermediate
states of CFG updates based on fully updated IR. For example, you can have
a transformation that replaces all uses of a basic block with another basic
block in one operation, and yet you want to have a way to perform some
analysis as if the transformation happened one change at a time. This was,
at least originally, used for the incremental domtree updater and for
memssa. (+cc Alina, as she is most familiar with GraphDiff)


> I'd separate out a base of IDFCalculator, to a new class called
> IDFCalculatorBase that wouldn't contain either of said functions.
>
If #2 if a lot of work/code, I'd say that separating it doesn't sound that
bad. It's not that complicated, then I wouldn't split it.


On Sun, Jun 16, 2019 at 10:56 AM Kristóf Umann <dkszelethus at gmail.com>
wrote:

> A polite ping, could someone please share a thought about this?
>
> On Sat, 8 Jun 2019 at 21:21, Kristóf Umann <dkszelethus at gmail.com> wrote:
>
>> A polite ping on this matter :)
>>
>> On Tue, 4 Jun 2019 at 01:51, Kristóf Umann <dkszelethus at gmail.com> wrote:
>>
>>> Hi!
>>>
>>> As the title suggests, I'd like to generalize llvm::IDFCalculator to be
>>> able to calculate control dependencies on clang's CFG. The issue is
>>> however, that many data structures it uses are "hardcoded" to use
>>> llvm::BasicBlock, and requires a lot of code to turn it into template
>>> arguments.
>>>
>>> I managed to pull this off by hammering the code until it compiled, and
>>> it works perfectly, but I'm not really happy with how the patch came out:
>>>
>>> https://github.com/Szelethus/llvm-project/compare/domtree_unittest...Szelethus:control_dependency?expand=1
>>>
>>> Sadly, my knowledge on LLVM IR and phi nodes in general is very limited.
>>> My questions are:
>>>
>>> 1. I read the article IDFCalculator is based on[1], but I found no
>>> references to IDFCalculator::setLiveInBlocks, and the file header seems to
>>> confirm that it's an implementation specific thing. Could I get away
>>> restricting the clang::CFG tailored version to not contain this function?
>>>
>>> 2. I didn't really manage to understand the logic for GraphDiff. What
>>> does it really do in IDFCalculator's context? I dag out the patch[2] that
>>> added an extra constructor to use a snapshot of the CFG, but it seems to be
>>> unused. Is it also unlikely that we find any use for this? Mind you, the
>>> patch size grew a lot because I also "templatized" GraphDiff and all
>>> related classes to handle clang's CFG.
>>>
>>> If the answer to both of these questions is "no", I'd separate out a
>>> base of IDFCalculator, to a new class called IDFCalculatorBase that
>>> wouldn't contain either of said functions.
>>>
>>> Cheers!
>>> Kristóf
>>>
>>>
>>> [1] Sreedhar, Vugranam C., and Guang R. Gao. "A linear time algorithm
>>> for placing ϕ-nodes." Proceedings of the 22nd ACM SIGPLAN-SIGACT symposium
>>> on Principles of programming languages. ACM, 1995.
>>> [2] [IDF] Teach Iterated Dominance Frontier to use a snapshot CFG based
>>> on a GraphDiff. https://reviews.llvm.org/D50675
>>>
>>

-- 
Jakub Kuderski
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20190617/ddd4c097/attachment.html>


More information about the llvm-dev mailing list