diff options
| author | David Blaikie <dblaikie@gmail.com> | 2013-06-28 18:47:19 +0000 |
|---|---|---|
| committer | David Blaikie <dblaikie@gmail.com> | 2013-06-28 18:47:19 +0000 |
| commit | b8ef7851dcd2313f37497086ba8d237585a95acd (patch) | |
| tree | 2ef32cc3c76794ddd32795aa9b4733572e0c8add /llvm/lib | |
| parent | dea547b94dda5629fb241716c94ffd9ffdfc3999 (diff) | |
| download | bcm5719-llvm-b8ef7851dcd2313f37497086ba8d237585a95acd.tar.gz bcm5719-llvm-b8ef7851dcd2313f37497086ba8d237585a95acd.zip | |
DebugInfo: Simplify the AddressPool representation
llvm-svn: 185189
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp | 25 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/DwarfDebug.h | 5 |
2 files changed, 12 insertions, 18 deletions
diff --git a/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp b/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp index a6d2b17e3bd..c57cf310e69 100644 --- a/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp @@ -248,12 +248,10 @@ unsigned DwarfUnits::getStringPoolIndex(StringRef Str) { } unsigned DwarfUnits::getAddrPoolIndex(const MCSymbol *Sym) { - std::pair<const MCSymbol*, unsigned> &Entry = AddressPool[Sym]; - if (Entry.first) return Entry.second; - - Entry.second = NextAddrPoolNumber++; - Entry.first = Sym; - return Entry.second; + std::pair<DenseMap<const MCSymbol *, unsigned>::iterator, bool> P = + AddressPool.insert(std::make_pair(Sym, NextAddrPoolNumber)); + NextAddrPoolNumber += P.second; + return P.first->second; } // Define a unique number for the abbreviation. @@ -2356,23 +2354,20 @@ void DwarfUnits::emitAddresses(const MCSection *AddrSection) { // Start the dwarf addr section. Asm->OutStreamer.SwitchSection(AddrSection); - // Get all of the string pool entries and put them in an array by their ID so + // Get all of the address pool entries and put them in an array by their ID so // we can sort them. - SmallVector<std::pair<unsigned, std::pair<const MCSymbol *, unsigned> *>, 64> - Entries; + SmallVector<std::pair<unsigned, const MCSymbol *>, 64> Entries; - for (DenseMap<const MCSymbol *, - std::pair<const MCSymbol *, unsigned> >::iterator - I = AddressPool.begin(), - E = AddressPool.end(); + for (DenseMap<const MCSymbol *, unsigned>::iterator I = AddressPool.begin(), + E = AddressPool.end(); I != E; ++I) - Entries.push_back(std::make_pair(I->second.second, &(I->second))); + Entries.push_back(std::make_pair(I->second, I->first)); array_pod_sort(Entries.begin(), Entries.end()); for (unsigned i = 0, e = Entries.size(); i != e; ++i) { // Emit a label for reference from debug information entries. - if (const MCSymbol *Sym = Entries[i].second->first) + if (const MCSymbol *Sym = Entries[i].second) Asm->EmitLabelReference(Sym, Asm->getDataLayout().getPointerSize()); else Asm->OutStreamer.EmitIntValue(0, Asm->getDataLayout().getPointerSize()); diff --git a/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.h b/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.h index 4a395a336d3..00d48d7ecaa 100644 --- a/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.h +++ b/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.h @@ -195,10 +195,9 @@ public: typedef StringMap<std::pair<MCSymbol*, unsigned>, BumpPtrAllocator&> StrPool; -// A Symbol->pair<Symbol, unsigned> mapping of addresses used by indirect +// A Symbol->unsigned mapping of addresses used by indirect // references. -typedef DenseMap<const MCSymbol *, std::pair<const MCSymbol *, unsigned> > - AddrPool; +typedef DenseMap<const MCSymbol *, unsigned> AddrPool; /// \brief Collects and handles information specific to a particular /// collection of units. |

