[DebugInfo] Hold generic MCExpr in AddrPool

This changes the AddrPool infrastructure to enable it to hold
generic MCExpr expressions, not just MCSymbolRefExpr.

This is in preparation for supporting debug info for TLS variables
on PowerPC, where we need to describe the variable location using
a more complex expression than just MCSymbolRefExpr.



git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@185459 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Ulrich Weigand 2013-07-02 18:46:46 +00:00
parent 1f8aacd6af
commit 18dbe5029f
2 changed files with 9 additions and 9 deletions

View File

@ -251,8 +251,8 @@ unsigned DwarfUnits::getAddrPoolIndex(const MCSymbol *Sym) {
return getAddrPoolIndex(MCSymbolRefExpr::Create(Sym, Asm->OutContext)); return getAddrPoolIndex(MCSymbolRefExpr::Create(Sym, Asm->OutContext));
} }
unsigned DwarfUnits::getAddrPoolIndex(const MCSymbolRefExpr *Sym) { unsigned DwarfUnits::getAddrPoolIndex(const MCExpr *Sym) {
std::pair<DenseMap<const MCSymbolRefExpr *, unsigned>::iterator, bool> P = std::pair<DenseMap<const MCExpr *, unsigned>::iterator, bool> P =
AddressPool.insert(std::make_pair(Sym, NextAddrPoolNumber)); AddressPool.insert(std::make_pair(Sym, NextAddrPoolNumber));
if (P.second) if (P.second)
++NextAddrPoolNumber; ++NextAddrPoolNumber;
@ -2361,9 +2361,9 @@ void DwarfUnits::emitAddresses(const MCSection *AddrSection) {
// Get all of the address 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. // we can sort them.
SmallVector<std::pair<unsigned, const MCSymbolRefExpr *>, 64> Entries; SmallVector<std::pair<unsigned, const MCExpr *>, 64> Entries;
for (DenseMap<const MCSymbolRefExpr *, unsigned>::iterator for (DenseMap<const MCExpr *, unsigned>::iterator
I = AddressPool.begin(), I = AddressPool.begin(),
E = AddressPool.end(); E = AddressPool.end();
I != E; ++I) I != E; ++I)
@ -2372,9 +2372,9 @@ void DwarfUnits::emitAddresses(const MCSection *AddrSection) {
array_pod_sort(Entries.begin(), Entries.end()); array_pod_sort(Entries.begin(), Entries.end());
for (unsigned i = 0, e = Entries.size(); i != e; ++i) { for (unsigned i = 0, e = Entries.size(); i != e; ++i) {
// Emit a label for reference from debug information entries. // Emit an expression for reference from debug information entries.
if (const MCSymbolRefExpr *Sym = Entries[i].second) if (const MCExpr *Expr = Entries[i].second)
Asm->OutStreamer.EmitValue(Sym, Asm->getDataLayout().getPointerSize()); Asm->OutStreamer.EmitValue(Expr, Asm->getDataLayout().getPointerSize());
else else
Asm->OutStreamer.EmitIntValue(0, Asm->getDataLayout().getPointerSize()); Asm->OutStreamer.EmitIntValue(0, Asm->getDataLayout().getPointerSize());
} }

View File

@ -197,7 +197,7 @@ typedef StringMap<std::pair<MCSymbol*, unsigned>,
// A Symbol->unsigned mapping of addresses used by indirect // A Symbol->unsigned mapping of addresses used by indirect
// references. // references.
typedef DenseMap<const MCSymbolRefExpr *, unsigned> AddrPool; typedef DenseMap<const MCExpr *, unsigned> AddrPool;
/// \brief Collects and handles information specific to a particular /// \brief Collects and handles information specific to a particular
/// collection of units. /// collection of units.
@ -270,7 +270,7 @@ public:
/// \brief Returns the index into the address pool with the given /// \brief Returns the index into the address pool with the given
/// label/symbol. /// label/symbol.
unsigned getAddrPoolIndex(const MCSymbolRefExpr *); unsigned getAddrPoolIndex(const MCExpr *);
unsigned getAddrPoolIndex(const MCSymbol *); unsigned getAddrPoolIndex(const MCSymbol *);
/// \brief Returns the address pool. /// \brief Returns the address pool.