diff options
author | Chris Lattner <sabre@nondot.org> | 2007-04-26 04:42:16 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2007-04-26 04:42:16 +0000 |
commit | c59c0afd7d24480f5a23d8fd6764ecfd6d4424cc (patch) | |
tree | ca44c4bdc29596b87100b7eb5dcb596bfd9c9200 /lib/Bitcode/Writer | |
parent | 0e72512a6c89622cca8dc31e2bde930a49cc4721 (diff) |
enumerate BB's separately from other function values.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@36467 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Bitcode/Writer')
-rw-r--r-- | lib/Bitcode/Writer/ValueEnumerator.cpp | 7 | ||||
-rw-r--r-- | lib/Bitcode/Writer/ValueEnumerator.h | 13 |
2 files changed, 16 insertions, 4 deletions
diff --git a/lib/Bitcode/Writer/ValueEnumerator.cpp b/lib/Bitcode/Writer/ValueEnumerator.cpp index d808e347dd..830ac612fb 100644 --- a/lib/Bitcode/Writer/ValueEnumerator.cpp +++ b/lib/Bitcode/Writer/ValueEnumerator.cpp @@ -178,11 +178,12 @@ void ValueEnumerator::incorporateFunction(const Function &F) { isa<InlineAsm>(*OI)) EnumerateValue(*OI); } + ValueMap[BB] = BasicBlocks.size(); + BasicBlocks.push_back(BB); } // Add all of the instructions. for (Function::const_iterator BB = F.begin(), E = F.end(); BB != E; ++BB) { - EnumerateValue(BB); for (BasicBlock::const_iterator I = BB->begin(), E = BB->end(); I!=E; ++I) { if (I->getType() != Type::VoidTy) EnumerateValue(I); @@ -194,6 +195,10 @@ void ValueEnumerator::purgeFunction() { /// Remove purged values from the ValueMap. for (unsigned i = ModuleLevel, e = Values.size(); i != e; ++i) ValueMap.erase(Values[i].first); + for (unsigned i = 0, e = BasicBlocks.size(); i != e; ++i) + ValueMap.erase(BasicBlocks[i]); + Values.resize(ModuleLevel); + BasicBlocks.clear(); } diff --git a/lib/Bitcode/Writer/ValueEnumerator.h b/lib/Bitcode/Writer/ValueEnumerator.h index c0db9d968e..d9839c6c83 100644 --- a/lib/Bitcode/Writer/ValueEnumerator.h +++ b/lib/Bitcode/Writer/ValueEnumerator.h @@ -19,13 +19,13 @@ namespace llvm { -class Value; class Type; -class Module; +class Value; +class BasicBlock; class Function; +class Module; class TypeSymbolTable; class ValueSymbolTable; -class ConstantArray; class ValueEnumerator { public: @@ -43,6 +43,10 @@ private: ValueMapType ValueMap; ValueList Values; + /// BasicBlocks - This contains all the basic blocks for the currently + /// incorporated function. Their reverse mapping is stored in ValueMap. + std::vector<const BasicBlock*> BasicBlocks; + /// When a function is incorporated, this is the size of the Values list /// before incorporation. unsigned ModuleLevel; @@ -66,6 +70,9 @@ public: const ValueList &getValues() const { return Values; } const TypeList &getTypes() const { return Types; } + const std::vector<const BasicBlock*> &getBasicBlocks() const { + return BasicBlocks; + } /// PurgeAggregateValues - If there are any aggregate values at the end of the /// value list, remove them and return the count of the remaining values. If |