summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--llvm/include/llvm/MC/MCSymbol.h14
-rw-r--r--llvm/lib/MC/MCSymbol.cpp1
2 files changed, 7 insertions, 8 deletions
diff --git a/llvm/include/llvm/MC/MCSymbol.h b/llvm/include/llvm/MC/MCSymbol.h
index 544cf8abe60..78b7c516e83 100644
--- a/llvm/include/llvm/MC/MCSymbol.h
+++ b/llvm/include/llvm/MC/MCSymbol.h
@@ -136,7 +136,7 @@ protected: // MCContext creates and uniques these.
Kind(Kind) {
Offset = 0;
if (Name)
- getNameEntryPtr().NameEntry = Name;
+ getNameEntryPtr() = Name;
}
// Provide custom new/delete as we will only allocate space for a name
@@ -169,15 +169,13 @@ private:
}
/// \brief Get a reference to the name field. Requires that we have a name
- NameEntryStorageTy &getNameEntryPtr() {
+ const StringMapEntry<bool> *&getNameEntryPtr() {
assert(HasName && "Name is required");
NameEntryStorageTy *Name = reinterpret_cast<NameEntryStorageTy *>(this);
- return *(Name - 1);
+ return (*(Name - 1)).NameEntry;
}
- const NameEntryStorageTy &getNameEntryPtr() const {
- assert(HasName && "Name is required");
- const auto *Name = reinterpret_cast<const NameEntryStorageTy *>(this);
- return *(Name - 1);
+ const StringMapEntry<bool> *&getNameEntryPtr() const {
+ return const_cast<MCSymbol*>(this)->getNameEntryPtr();
}
public:
@@ -186,7 +184,7 @@ public:
if (!HasName)
return StringRef();
- return getNameEntryPtr().NameEntry->first();
+ return getNameEntryPtr()->first();
}
bool isRegistered() const { return IsRegistered; }
diff --git a/llvm/lib/MC/MCSymbol.cpp b/llvm/lib/MC/MCSymbol.cpp
index a5097bc90f6..f0f35f7b29e 100644
--- a/llvm/lib/MC/MCSymbol.cpp
+++ b/llvm/lib/MC/MCSymbol.cpp
@@ -28,6 +28,7 @@ void *MCSymbol::operator new(size_t s, const StringMapEntry<bool> *Name,
// For safety, ensure that the alignment of a pointer is enough for an
// MCSymbol. This also ensures we don't need padding between the name and
// symbol.
+ // FIXME: Use static_assert when constexpr is supported.
assert(alignOf<MCSymbol>() <= alignOf<NameEntryStorageTy>() &&
"Bad alignment of MCSymbol");
void *Storage = Ctx.allocate(Size, alignOf<NameEntryStorageTy>());
OpenPOWER on IntegriCloud