diff options
author | Devang Patel <dpatel@apple.com> | 2009-09-03 01:39:20 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2009-09-03 01:39:20 +0000 |
commit | f7188325efa1b94a8c43de02d92e4d9967e0a6b1 (patch) | |
tree | f19dbbdf57399a7f8aa3c59e17737b3459dc4bfd /llvm/lib/VMCore/LLVMContext.cpp | |
parent | 116b4a0cb37d2906c5000e7cd635b5807f09ed41 (diff) | |
download | bcm5719-llvm-f7188325efa1b94a8c43de02d92e4d9967e0a6b1.tar.gz bcm5719-llvm-f7188325efa1b94a8c43de02d92e4d9967e0a6b1.zip |
Now Bitcode reader bug is fixed. Reapply 80839.
Use CallbackVH, instead of WeakVH, to hold MDNode elements.
Use FoldingSetNode to unique MDNodes in a context.
Use CallbackVH hooks to update context's MDNodeSet appropriately.
llvm-svn: 80868
Diffstat (limited to 'llvm/lib/VMCore/LLVMContext.cpp')
-rw-r--r-- | llvm/lib/VMCore/LLVMContext.cpp | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/llvm/lib/VMCore/LLVMContext.cpp b/llvm/lib/VMCore/LLVMContext.cpp index 1803a9a6666..0ed21fb754e 100644 --- a/llvm/lib/VMCore/LLVMContext.cpp +++ b/llvm/lib/VMCore/LLVMContext.cpp @@ -13,6 +13,7 @@ //===----------------------------------------------------------------------===// #include "llvm/LLVMContext.h" +#include "llvm/Metadata.h" #include "llvm/Constants.h" #include "llvm/Instruction.h" #include "llvm/Support/ManagedStatic.h" @@ -48,10 +49,10 @@ bool LLVMContext::RemoveDeadMetadata() { bool Changed = false; while (1) { - for (SmallPtrSet<const MDNode *, 8>::iterator - I = pImpl->MDNodes.begin(), - E = pImpl->MDNodes.end(); I != E; ++I) { - const MDNode *N = cast<MDNode>(*I); + for (FoldingSet<MDNode>::iterator + I = pImpl->MDNodeSet.begin(), + E = pImpl->MDNodeSet.end(); I != E; ++I) { + const MDNode *N = &(*I); if (N->use_empty()) DeadMDNodes.push_back(N); } |