[llvm-commits] [llvm] r93441 - in /llvm/trunk/lib/Bitcode/Writer: BitcodeWriter.cpp ValueEnumerator.h
Victor Hernandez
vhernandez at apple.com
Thu Jan 14 11:38:44 PST 2010
Author: hernande
Date: Thu Jan 14 13:38:44 2010
New Revision: 93441
URL: http://llvm.org/viewvc/llvm-project?rev=93441&view=rev
Log:
Avoid modifying ValueEnumerator's MD ValueList by choosing which function-local MD to write based on the function currently being written
Modified:
llvm/trunk/lib/Bitcode/Writer/BitcodeWriter.cpp
llvm/trunk/lib/Bitcode/Writer/ValueEnumerator.h
Modified: llvm/trunk/lib/Bitcode/Writer/BitcodeWriter.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Bitcode/Writer/BitcodeWriter.cpp?rev=93441&r1=93440&r2=93441&view=diff
==============================================================================
--- llvm/trunk/lib/Bitcode/Writer/BitcodeWriter.cpp (original)
+++ llvm/trunk/lib/Bitcode/Writer/BitcodeWriter.cpp Thu Jan 14 13:38:44 2010
@@ -554,30 +554,22 @@
Stream.ExitBlock();
}
-static void WriteFunctionLocalMetadata(const ValueEnumerator &VE,
+static void WriteFunctionLocalMetadata(const Function &F,
+ const ValueEnumerator &VE,
BitstreamWriter &Stream) {
bool StartedMetadataBlock = false;
SmallVector<uint64_t, 64> Record;
- ValueEnumerator::ValueList Vals = VE.getMDValues();
- ValueEnumerator::ValueList::iterator it = Vals.begin();
- ValueEnumerator::ValueList::iterator end = Vals.end();
-
- while (it != end) {
- if (const MDNode *N = dyn_cast<MDNode>((*it).first)) {
- if (N->isFunctionLocal()) {
+ const ValueEnumerator::ValueList &Vals = VE.getMDValues();
+
+ for (unsigned i = 0, e = Vals.size(); i != e; ++i)
+ if (const MDNode *N = dyn_cast<MDNode>(Vals[i].first))
+ if (N->getFunction() == &F) {
if (!StartedMetadataBlock) {
Stream.EnterSubblock(bitc::METADATA_BLOCK_ID, 3);
StartedMetadataBlock = true;
}
WriteMDNode(N, VE, Stream, Record);
- // Remove function-local MD, since it is not used outside of function.
- it = Vals.erase(it);
- end = Vals.end();
- continue;
}
- }
- ++it;
- }
if (StartedMetadataBlock)
Stream.ExitBlock();
@@ -1227,7 +1219,7 @@
WriteConstants(CstStart, CstEnd, VE, Stream, false);
// If there is function-local metadata, emit it now.
- WriteFunctionLocalMetadata(VE, Stream);
+ WriteFunctionLocalMetadata(F, VE, Stream);
// Keep a running idea of what the instruction ID is.
unsigned InstID = CstEnd;
Modified: llvm/trunk/lib/Bitcode/Writer/ValueEnumerator.h
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Bitcode/Writer/ValueEnumerator.h?rev=93441&r1=93440&r2=93441&view=diff
==============================================================================
--- llvm/trunk/lib/Bitcode/Writer/ValueEnumerator.h (original)
+++ llvm/trunk/lib/Bitcode/Writer/ValueEnumerator.h Thu Jan 14 13:38:44 2010
@@ -105,7 +105,6 @@
const ValueList &getValues() const { return Values; }
const ValueList &getMDValues() const { return MDValues; }
- ValueList getMDValues() { return MDValues; }
const TypeList &getTypes() const { return Types; }
const std::vector<const BasicBlock*> &getBasicBlocks() const {
return BasicBlocks;
More information about the llvm-commits
mailing list