[LLVMdev] loop passes vs call graph
Devang Patel
dpatel at apple.com
Mon Feb 16 11:45:24 PST 2009
On Feb 13, 2009, at 5:39 AM, Duncan Sands wrote:
> Hi,
>
>> I'm looking at bug 3367.
>>
>> If I run:
>>
>> $ opt b.bc -inline -loop-rotate -loop-unswitch -debug-pass=Executions
>>
>> ... it eventually crashes in the inliner, because the call graph
>> isn't
>> up to date. (NB if you want to reproduce this you'll have to apply my
>> patch from bug 3367 first.)
>>
>> The reason the call graph isn't up to date is that -loop-unswitch has
>> changed a function and not updated the call graph. But that seems OK,
>> because -loop-unswitch's getAnalysisUsage() method doesn't claim to
>> preserve the call graph.
>
> given the callgraph F -> G, the pass manager currently does the
> following:
> run inliner on G, run loop passes on G, run inliner on F, run loop
> passes on F. Presumably what is happening is this: the loop passes
> change
> the functions that G calls (but don't update the callgraph). Now the
> inliner visits F and decides to inline G into F. When it does this,
> it
> presumably merges the callgraph info for G (i.e. what G calls) into
> that of
> F. But this info is wrong, so F ends up having invalid callgraph
> info which
> at some point causes trouble.
>
> I think what should happen is: if a SCC pass (eg: inline) is followed
> by function passes that preserve the callgraph, then it should
> schedule
> them together like above. However if the SCC pass is followed by a
> function pass that does not preserve the callgraph then it should be
> scheduled entirely after the SCC pass.
>
> For example, imagine -inline -fpass -loop-unswitch, where fpass is a
> function pass that preserves the callgraph. Then the pass manager
> should do:
>
> run -inline on G
> run -fpass on G
> run -inline on F
> run -fpass on F
> run -loop-unswitch on G
> run -loop-unswitch on F.
This will defeat the goal of applying loop transformations before
inlining leaf functions. Note, Loop transformations are not aware of
call graph. They do not claim to preserve call graph. However, loop
passes are run by a loop pass manager (LPPassManager) which is itself
a function pass. The pass manager is not doing the right thing here
because LPPassManager is incorrectly claiming to preserve call graph.
The right approach is to teach LPPassManager to really preserve call
graph.
-
Devang
>
>
> Just my opinion of course.
>
> Ciao,
>
> Duncan.
>
More information about the llvm-dev
mailing list