summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDevang Patel <dpatel@apple.com>2009-10-26 17:09:00 +0000
committerDevang Patel <dpatel@apple.com>2009-10-26 17:09:00 +0000
commitd6dd2a0840565be5da799c341a15c5db09f63655 (patch)
treed551bd94a0703bf20c2e3c7e72cf18843030071f
parent4afb7c58a4cfd261423e0bfb16eddab1b2f9d9cd (diff)
downloadbcm5719-llvm-d6dd2a0840565be5da799c341a15c5db09f63655.tar.gz
bcm5719-llvm-d6dd2a0840565be5da799c341a15c5db09f63655.zip
Do not use expensive sort().
llvm-svn: 85130
-rw-r--r--llvm/lib/VMCore/Metadata.cpp10
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
OpenPOWER on IntegriCloud