From 17177280669918513b259c6830774dd99d5d7901 Mon Sep 17 00:00:00 2001 From: "Duncan P. N. Exon Smith" Date: Sun, 24 May 2015 16:33:33 +0000 Subject: [PATCH] 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. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@238116 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/CodeGen/DwarfStringPoolEntry.h | 45 +++++++++++++++++++++ lib/CodeGen/AsmPrinter/DwarfStringPool.cpp | 9 +++-- lib/CodeGen/AsmPrinter/DwarfStringPool.h | 19 +++++---- 3 files changed, 59 insertions(+), 14 deletions(-) create mode 100644 include/llvm/CodeGen/DwarfStringPoolEntry.h diff --git a/include/llvm/CodeGen/DwarfStringPoolEntry.h b/include/llvm/CodeGen/DwarfStringPoolEntry.h new file mode 100644 index 00000000000..19fbbff0399 --- /dev/null +++ b/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 *I = nullptr; + +public: + DwarfStringPoolEntryRef() = default; + explicit DwarfStringPoolEntryRef( + const StringMapEntry &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/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp b/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp index a599126f0b7..9dd233a67ab 100644 --- a/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp +++ b/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/lib/CodeGen/AsmPrinter/DwarfStringPool.h b/lib/CodeGen/AsmPrinter/DwarfStringPool.h index 77b6ffaa9f1..28c73033a5c 100644 --- a/lib/CodeGen/AsmPrinter/DwarfStringPool.h +++ b/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 @@ -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 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