diff options
| author | Devang Patel <dpatel@apple.com> | 2007-04-16 21:28:14 +0000 |
|---|---|---|
| committer | Devang Patel <dpatel@apple.com> | 2007-04-16 21:28:14 +0000 |
| commit | 9b5e8e5c32b68e2f7c337f9a7e59de04c7fd5737 (patch) | |
| tree | df532d1d2175fba3d7eb1a357a82740b59b69f2f /llvm/docs/WritingAnLLVMPass.html | |
| parent | e0a060043bba758d2013ded761c18fb9d309c8bf (diff) | |
| download | bcm5719-llvm-9b5e8e5c32b68e2f7c337f9a7e59de04c7fd5737.tar.gz bcm5719-llvm-9b5e8e5c32b68e2f7c337f9a7e59de04c7fd5737.zip | |
Document how, module pass can require function pass.
llvm-svn: 36171
Diffstat (limited to 'llvm/docs/WritingAnLLVMPass.html')
| -rw-r--r-- | llvm/docs/WritingAnLLVMPass.html | 20 |
1 files changed, 18 insertions, 2 deletions
diff --git a/llvm/docs/WritingAnLLVMPass.html b/llvm/docs/WritingAnLLVMPass.html index 3b116074b71..c9813ef11c5 100644 --- a/llvm/docs/WritingAnLLVMPass.html +++ b/llvm/docs/WritingAnLLVMPass.html @@ -466,7 +466,9 @@ 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.</p> +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>. </p> <p>To write a correct <tt>ModulePass</tt> subclass, derive from <tt>ModulePass</tt> and overload the <tt>runOnModule</tt> method with the @@ -1127,7 +1129,21 @@ runtime assertion failure if you attempt to get an analysis that you did not declare as required in your <a href="#getAnalysisUsage"><tt>getAnalysisUsage</tt></a> implementation. This method can be called by your <tt>run*</tt> method implementation, or by any -other local method invoked by your <tt>run*</tt> method.</p> +other local method invoked by your <tt>run*</tt> method. + +A module level pass can use function level analysis info using this interface. +For example:</p> + +<div class="doc_code"><pre> + bool ModuleLevelPass::runOnModule(Module &M) { + ... + DominatorTree &DT = getAnalysis<DominatorTree>(Function &F); + ... + } +</pre></div> + +In above example, runOnFunction for DominatorTree is called by pass manager +before returning a reference to the desired pass.</p> <p> If your pass is capable of updating analyses if they exist (e.g., |

