diff options
| author | Duncan P. N. Exon Smith <dexonsmith@apple.com> | 2015-05-24 16:33:33 +0000 |
|---|---|---|
| committer | Duncan P. N. Exon Smith <dexonsmith@apple.com> | 2015-05-24 16:33:33 +0000 |
| commit | 03b7a1cf93b215ce99cd4eadfba3b08f3242a4db (patch) | |
| tree | f780d73dc33532dbe9fa9d216deb42ee0fa1d214 /llvm | |
| parent | 0b223598587590dbf52ec7b0842a69e65b5a8f3a (diff) | |
| download | bcm5719-llvm-03b7a1cf93b215ce99cd4eadfba3b08f3242a4db.tar.gz bcm5719-llvm-03b7a1cf93b215ce99cd4eadfba3b08f3242a4db.zip | |
AsmPrinter: Extract DwarfStringPoolEntry from DwarfStringPool, NFC
Extract out `DwarfStringPoolEntry` and `DwarfStringPoolRef` from
`DwarfStringPool` so that downstream users can start using
`DwarfStringPool::getEntry()` directly. This will allow users to delay
the decision between emitting a symbol or an offset until later.
llvm-svn: 238116
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/include/llvm/CodeGen/DwarfStringPoolEntry.h | 45 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp | 9 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.h | 19 |
3 files changed, 59 insertions, 14 deletions
diff --git a/llvm/include/llvm/CodeGen/DwarfStringPoolEntry.h b/llvm/include/llvm/CodeGen/DwarfStringPoolEntry.h new file mode 100644 index 00000000000..19fbbff0399 --- /dev/null +++ b/llvm/include/llvm/CodeGen/DwarfStringPoolEntry.h @@ -0,0 +1,45 @@ +//===- llvm/CodeGen/DwarfStringPoolEntry.h - String pool entry --*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +#ifndef LLVM_CODEGEN_DWARFSTRINGPOOLENTRY_H +#define LLVM_CODEGEN_DWARFSTRINGPOOLENTRY_H + +#include "llvm/ADT/StringMap.h" + +namespace llvm { + +class MCSymbol; + +/// Data for a string pool entry. +struct DwarfStringPoolEntry { + MCSymbol *Symbol; + unsigned Offset; + unsigned Index; +}; + +/// String pool entry reference. +struct DwarfStringPoolEntryRef { + const StringMapEntry<DwarfStringPoolEntry> *I = nullptr; + +public: + DwarfStringPoolEntryRef() = default; + explicit DwarfStringPoolEntryRef( + const StringMapEntry<DwarfStringPoolEntry> &I) + : I(&I) {} + + explicit operator bool() const { return I; } + MCSymbol *getSymbol() const { return I->second.Symbol; } + unsigned getOffset() const { return I->second.Offset; } + unsigned getIndex() const { return I->second.Index; } + StringRef getString() const { return I->first(); } +}; + +} // end namespace llvm + +#endif diff --git a/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp b/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp index a599126f0b7..9dd233a67ab 100644 --- a/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp @@ -12,10 +12,11 @@ using namespace llvm; -DwarfStringPool::EntryTy &DwarfStringPool::getEntry(AsmPrinter &Asm, +DwarfStringPool::EntryRef DwarfStringPool::getEntry(AsmPrinter &Asm, StringRef Str) { - auto &Entry = Pool[Str]; - if (!Entry.Symbol) { + auto I = Pool.insert(std::make_pair(Str, EntryTy())); + if (I.second) { + auto &Entry = I.first->second; Entry.Index = Pool.size() - 1; Entry.Offset = NumBytes; Entry.Symbol = Asm.createTempSymbol(Prefix); @@ -23,7 +24,7 @@ DwarfStringPool::EntryTy &DwarfStringPool::getEntry(AsmPrinter &Asm, NumBytes += Str.size() + 1; assert(NumBytes > Entry.Offset && "Unexpected overflow"); } - return Entry; + return EntryRef(*I.first); } void DwarfStringPool::emit(AsmPrinter &Asm, MCSection *StrSection, diff --git a/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.h b/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.h index 77b6ffaa9f1..28c73033a5c 100644 --- a/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.h +++ b/llvm/lib/CodeGen/AsmPrinter/DwarfStringPool.h @@ -12,6 +12,7 @@ #include "llvm/ADT/StringMap.h" #include "llvm/CodeGen/AsmPrinter.h" +#include "llvm/CodeGen/DwarfStringPoolEntry.h" #include "llvm/Support/Allocator.h" #include <utility> @@ -25,16 +26,14 @@ class StringRef; // A String->Symbol mapping of strings used by indirect // references. class DwarfStringPool { - struct EntryTy { - MCSymbol *Symbol; - unsigned Offset; - unsigned Index; - }; + typedef DwarfStringPoolEntry EntryTy; StringMap<EntryTy, BumpPtrAllocator &> Pool; StringRef Prefix; unsigned NumBytes = 0; public: + typedef DwarfStringPoolEntryRef EntryRef; + DwarfStringPool(BumpPtrAllocator &A, AsmPrinter &Asm, StringRef Prefix) : Pool(A), Prefix(Prefix) {} @@ -44,24 +43,24 @@ public: /// \brief Returns an entry into the string pool with the given /// string text. MCSymbol *getSymbol(AsmPrinter &Asm, StringRef Str) { - return getEntry(Asm, Str).Symbol; + return getEntry(Asm, Str).getSymbol(); } /// Get a byte offset into the string pool with the given text. unsigned getOffset(AsmPrinter &Asm, StringRef Str) { - return getEntry(Asm, Str).Offset; + return getEntry(Asm, Str).getOffset(); } /// \brief Returns the index into the string pool with the given /// string text. unsigned getIndex(AsmPrinter &Asm, StringRef Str) { - return getEntry(Asm, Str).Index; + return getEntry(Asm, Str).getIndex(); } bool empty() const { return Pool.empty(); } -private: - EntryTy &getEntry(AsmPrinter &Asm, StringRef Str); + /// Get a reference to an entry in the string pool. + EntryRef getEntry(AsmPrinter &Asm, StringRef Str); }; } #endif |

