diff options
| author | Devang Patel <dpatel@apple.com> | 2009-10-26 17:09:00 +0000 |
|---|---|---|
| committer | Devang Patel <dpatel@apple.com> | 2009-10-26 17:09:00 +0000 |
| commit | d6dd2a0840565be5da799c341a15c5db09f63655 (patch) | |
| tree | d551bd94a0703bf20c2e3c7e72cf18843030071f | |
| parent | 4afb7c58a4cfd261423e0bfb16eddab1b2f9d9cd (diff) | |
| download | bcm5719-llvm-d6dd2a0840565be5da799c341a15c5db09f63655.tar.gz bcm5719-llvm-d6dd2a0840565be5da799c341a15c5db09f63655.zip | |
Do not use expensive sort().
llvm-svn: 85130
| -rw-r--r-- | llvm/lib/VMCore/Metadata.cpp | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/llvm/lib/VMCore/Metadata.cpp b/llvm/lib/VMCore/Metadata.cpp index ad9653f1b95..4fadfed503b 100644 --- a/llvm/lib/VMCore/Metadata.cpp +++ b/llvm/lib/VMCore/Metadata.cpp @@ -344,20 +344,22 @@ getMDs(const Instruction *Inst, SmallVectorImpl<MDPairTy> &MDs) const { MDStoreTy::iterator I = MetadataStore.find(Inst); if (I == MetadataStore.end()) return; + MDs.resize(I->second.size()); for (MDMapTy::iterator MI = I->second.begin(), ME = I->second.end(); MI != ME; ++MI) - MDs.push_back(std::make_pair(MI->first, MI->second)); - std::sort(MDs.begin(), MDs.end()); + // MD kinds are numbered from 1. + MDs[MI->first - 1] = std::make_pair(MI->first, MI->second); } /// getHandlerNames - Populate client supplied smallvector using custome /// metadata name and ID. void MetadataContextImpl:: getHandlerNames(SmallVectorImpl<std::pair<unsigned, StringRef> >&Names) const { + Names.resize(MDHandlerNames.size()); for (StringMap<unsigned>::const_iterator I = MDHandlerNames.begin(), E = MDHandlerNames.end(); I != E; ++I) - Names.push_back(std::make_pair(I->second, I->first())); - std::sort(Names.begin(), Names.end()); + // MD Handlers are numbered from 1. + Names[I->second - 1] = std::make_pair(I->second, I->first()); } /// ValueIsCloned - This handler is used to update metadata store |

