Julien Lerouge
2009-Feb-27 02:01 UTC
[LLVMdev] AnalysisUsage & Call Graph SCC Pass Manager
Hello,
I have the following sequence of passes (using --debug-pass=Structure):
...
ModulePass Manager
FunctionPass Manager
Preliminary module verification
Dominator Tree Construction
Module Verifier
MyModulePass0
MyAnalysis
Basic CallGraph Construction
MyModulePass1
MyAnalysis
MyModulePass2
Basic CallGraph Construction
Call Graph SCC Pass Manager
MyCallGraphSCCPass
MyModulePass3
...
I have the following analysis usages:
MyModulePass0 does not require anything and does not preserve anything.
MyModulePass1 requires MyAnalysis & Callgraph but does not preserve them.
MyModulePass2 requires MyAnalysis and preserves it.
MyCallGraphSCCPass requires MyAnalysis but does not preserve it.
MyModulePass3 requires MyAnalysis and preserves it.
I am expecting MyAnalysis to be re-scheduled between MyCallGraphSCCPass and
MyModulePass3 but it's not happening.
If I set MyModulePass3 to not preserve MyAnalysis, then I see MyAnalysis
re-scheduled after MyModulePass3.
It seems like the fact that MyAnalysis is not preserved by MyCallGraphSCCPass
is somehow not propagated outside the Call Graph SCC Pass Manager.
Is there something wrong with that sequence ?
Thanks,
Julien
--
Julien Lerouge
PGP Key Id: 0xB1964A62
PGP Fingerprint: 392D 4BAD DB8B CE7F 4E5F FA3C 62DB 4AA7 B196 4A62
PGP Public Key from: keyserver.pgp.com
On Feb 26, 2009, at 6:01 PM, Julien Lerouge wrote:> Hello, > > I have the following sequence of passes (using --debug- > pass=Structure): > > ... > ModulePass Manager > FunctionPass Manager > Preliminary module verification > Dominator Tree Construction > Module Verifier > MyModulePass0 > MyAnalysis > Basic CallGraph Construction > MyModulePass1 > MyAnalysis > MyModulePass2 > Basic CallGraph Construction > Call Graph SCC Pass Manager > MyCallGraphSCCPass > MyModulePass3 > ... > > I have the following analysis usages: > > MyModulePass0 does not require anything and does not preserve > anything. > MyModulePass1 requires MyAnalysis & Callgraph but does not preserve > them. > MyModulePass2 requires MyAnalysis and preserves it. > MyCallGraphSCCPass requires MyAnalysis but does not preserve it. > MyModulePass3 requires MyAnalysis and preserves it. > > I am expecting MyAnalysis to be re-scheduled between > MyCallGraphSCCPass and > MyModulePass3 but it's not happening. > > If I set MyModulePass3 to not preserve MyAnalysis, then I see > MyAnalysis > re-scheduled after MyModulePass3. > > It seems like the fact that MyAnalysis is not preserved by > MyCallGraphSCCPass > is somehow not propagated outside the Call Graph SCC Pass Manager. > > Is there something wrong with that sequence ?It is a bug. CGPassManager is incorrectly claiming that it is preserving all analysis info. - Devang> > > Thanks, > Julien > > -- > Julien Lerouge > PGP Key Id: 0xB1964A62 > PGP Fingerprint: 392D 4BAD DB8B CE7F 4E5F FA3C 62DB 4AA7 B196 4A62 > PGP Public Key from: keyserver.pgp.com > _______________________________________________ > LLVM Developers mailing list > LLVMdev at cs.uiuc.edu http://llvm.cs.uiuc.edu > http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev- Devang
Julien Lerouge
2009-Mar-03 19:55 UTC
[LLVMdev] AnalysisUsage & Call Graph SCC Pass Manager
On Tue, Mar 03, 2009 at 11:13:22AM -0800, Devang Patel wrote:> It is a bug. CGPassManager is incorrectly claiming that it is > preserving all analysis info. > - > DevangThanks, I filed http://llvm.org/bugs/show_bug.cgi?id=3703 with a simple test case. Julien -- Julien Lerouge PGP Key Id: 0xB1964A62 PGP Fingerprint: 392D 4BAD DB8B CE7F 4E5F FA3C 62DB 4AA7 B196 4A62 PGP Public Key from: keyserver.pgp.com