summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorDavid Blaikie <dblaikie@gmail.com>2013-06-28 18:47:19 +0000
committerDavid Blaikie <dblaikie@gmail.com>2013-06-28 18:47:19 +0000
commitb8ef7851dcd2313f37497086ba8d237585a95acd (patch)
tree2ef32cc3c76794ddd32795aa9b4733572e0c8add /llvm/lib
parentdea547b94dda5629fb241716c94ffd9ffdfc3999 (diff)
downloadbcm5719-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.cpp25
-rw-r--r--llvm/lib/CodeGen/AsmPrinter/DwarfDebug.h5
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.
OpenPOWER on IntegriCloud