diff options
| author | Victor Hernandez <vhernandez@apple.com> | 2010-01-14 19:38:44 +0000 |
|---|---|---|
| committer | Victor Hernandez <vhernandez@apple.com> | 2010-01-14 19:38:44 +0000 |
| commit | 7bc38e4c8cb3486f7e3574bd277b59d84f6ac94e (patch) | |
| tree | d757303271bb9007c96875a08ddf7bf720e89170 /lib/Bitcode | |
| parent | df0cdf4e5721593c1315edf47f3b96021767895a (diff) | |
| download | external_llvm-7bc38e4c8cb3486f7e3574bd277b59d84f6ac94e.zip external_llvm-7bc38e4c8cb3486f7e3574bd277b59d84f6ac94e.tar.gz external_llvm-7bc38e4c8cb3486f7e3574bd277b59d84f6ac94e.tar.bz2 | |
Avoid modifying ValueEnumerator's MD ValueList by choosing which function-local MD to write based on the function currently being written
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@93441 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Bitcode')
| -rw-r--r-- | lib/Bitcode/Writer/BitcodeWriter.cpp | 24 | ||||
| -rw-r--r-- | lib/Bitcode/Writer/ValueEnumerator.h | 1 |
2 files changed, 8 insertions, 17 deletions
diff --git a/lib/Bitcode/Writer/BitcodeWriter.cpp b/lib/Bitcode/Writer/BitcodeWriter.cpp index c71f676..5a4a1b2 100644 --- a/lib/Bitcode/Writer/BitcodeWriter.cpp +++ b/lib/Bitcode/Writer/BitcodeWriter.cpp @@ -554,30 +554,22 @@ static void WriteModuleMetadata(const ValueEnumerator &VE, 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 @@ static void WriteFunction(const Function &F, ValueEnumerator &VE, 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; diff --git a/lib/Bitcode/Writer/ValueEnumerator.h b/lib/Bitcode/Writer/ValueEnumerator.h index cf00e4c..78ea814 100644 --- a/lib/Bitcode/Writer/ValueEnumerator.h +++ b/lib/Bitcode/Writer/ValueEnumerator.h @@ -105,7 +105,6 @@ public: 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; |
