diff options
| author | Gordon Henriksen <gordonhenriksen@mac.com> | 2007-12-22 23:32:32 +0000 |
|---|---|---|
| committer | Gordon Henriksen <gordonhenriksen@mac.com> | 2007-12-22 23:32:32 +0000 |
| commit | 8790a22a30596f2abd2c726fd67fb33ec6cb7c96 (patch) | |
| tree | 24f5820a7ad51db9dedd11736534e7f2bb1c97c8 | |
| parent | 00602f6105adbbf8572da458e1685d6fc355cee0 (diff) | |
| download | bcm5719-llvm-8790a22a30596f2abd2c726fd67fb33ec6cb7c96.tar.gz bcm5719-llvm-8790a22a30596f2abd2c726fd67fb33ec6cb7c96.zip | |
Document a more robust implementation of performCustomLowering.
llvm-svn: 45326
| -rw-r--r-- | llvm/docs/GarbageCollection.html | 30 |
1 files changed, 14 insertions, 16 deletions
diff --git a/llvm/docs/GarbageCollection.html b/llvm/docs/GarbageCollection.html index 4b5bd50aca1..c9324859ba9 100644 --- a/llvm/docs/GarbageCollection.html +++ b/llvm/docs/GarbageCollection.html @@ -1084,37 +1084,35 @@ href="WritingAnLLVMPass.html#doInitialization_mod"><tt>doInitialization(Module <blockquote><pre >#include "llvm/Module.h" -#include "llvm/Instructions.h" +#include "llvm/IntrinsicInst.h" bool MyCollector::initializeCustomLowering(Module &M) { return false; } bool MyCollector::performCustomLowering(Function &F) { - const Module *M = F.getParent(); - - Function *GCReadInt = M->getFunction("llvm.gcread"), - *GCWriteInt = M->getFunction("llvm.gcwrite"), - *GCRootInt = M->getFunction("llvm.gcroot"); - bool MadeChange = false; for (Function::iterator BB = F.begin(), E = F.end(); BB != E; ++BB) - for (BasicBlock::iterator II = BB->begin(), E = BB->end(); II != E;) - if (CallInst *CI = dyn_cast<CallInst>(II++)) - if (Function *F = CI->getCalledFunction()) - if (F == GCWriteInt) { + for (BasicBlock::iterator II = BB->begin(), E = BB->end(); II != E; ++II) + if (IntrinsicInst *CI = dyn_cast<IntrinsicInst>(II)) + if (Function *F = CI->getCalledFunction()) + switch (F->getIntrinsicID()) { + case Intrinsic::gcwrite: // Handle llvm.gcwrite. - CI->eraseFromParent(); + CI->eraseFromParent(); MadeChange = true; - } else if (F == GCReadInt) { + break; + case Intrinsic::gcread: // Handle llvm.gcread. - CI->eraseFromParent(); + CI->eraseFromParent(); MadeChange = true; - } else if (F == GCRootInt) { + break; + case Intrinsic::gcroot: // Handle llvm.gcroot. - CI->eraseFromParent(); + CI->eraseFromParent(); MadeChange = true; + break; } return MadeChange; |

