mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-18 16:03:17 +00:00
Try to clarify a point about getting DominatorTree info from a module pass.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@74668 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7074feab96
commit
b71725b468
@ -491,10 +491,15 @@ class is the most general of all superclasses that you can use. Deriving from
|
||||
<tt>ModulePass</tt> indicates that your pass uses the entire program as a unit,
|
||||
refering to function bodies in no predictable order, or adding and removing
|
||||
functions. Because nothing is known about the behavior of <tt>ModulePass</tt>
|
||||
subclasses, no optimization can be done for their execution. A module pass
|
||||
can use function level passes (e.g. dominators) using getAnalysis interface
|
||||
<tt> getAnalysis<DominatorTree>(Function)</tt>, if the function pass
|
||||
does not require any module passes. </p>
|
||||
subclasses, no optimization can be done for their execution.</p>
|
||||
|
||||
<p>A module pass can use function level passes (e.g. dominators) using
|
||||
the getAnalysis interface
|
||||
<tt>getAnalysis<DominatorTree>(llvm::Function *)</tt> to provide the
|
||||
function to retrieve analysis result for, if the function pass does not require
|
||||
any module passes. Note that this can only be done for functions for which the
|
||||
analysis ran, e.g. in the case of dominators you should only ask for the
|
||||
DominatorTree for function definitions, not declarations.</p>
|
||||
|
||||
<p>To write a correct <tt>ModulePass</tt> subclass, derive from
|
||||
<tt>ModulePass</tt> and overload the <tt>runOnModule</tt> method with the
|
||||
|
Loading…
x
Reference in New Issue
Block a user