summaryrefslogtreecommitdiffstats
path: root/llvm/lib/MC/MCSymbol.cpp
diff options
context:
space:
mode:
authorPete Cooper <peter_cooper@apple.com>2015-06-09 19:56:05 +0000
committerPete Cooper <peter_cooper@apple.com>2015-06-09 19:56:05 +0000
commita9ecddbbe5dbb1f463065b38e37fbc0d3022bcc8 (patch)
tree699ac0b4580c1ed8aee80a663c511371558549a2 /llvm/lib/MC/MCSymbol.cpp
parentd9699bc7bdf0362173fcd256690f61a4d47429c2 (diff)
downloadbcm5719-llvm-a9ecddbbe5dbb1f463065b38e37fbc0d3022bcc8.tar.gz
bcm5719-llvm-a9ecddbbe5dbb1f463065b38e37fbc0d3022bcc8.zip
Make MCSymbol::Name be a union of uint64_t and a pointer.
This should hopefully fix the 32-bit bots which were allocating space for a pointer but needed to be aligned to 64-bits. Now we allocate enough space for a uint64_t and a pointer and cast to the appropriate storage llvm-svn: 239428
Diffstat (limited to 'llvm/lib/MC/MCSymbol.cpp')
-rw-r--r--llvm/lib/MC/MCSymbol.cpp15
1 files changed, 9 insertions, 6 deletions
diff --git a/llvm/lib/MC/MCSymbol.cpp b/llvm/lib/MC/MCSymbol.cpp
index e82630640ba..a5097bc90f6 100644
--- a/llvm/lib/MC/MCSymbol.cpp
+++ b/llvm/lib/MC/MCSymbol.cpp
@@ -19,17 +19,20 @@ using namespace llvm;
// Sentinel value for the absolute pseudo section.
MCSection *MCSymbol::AbsolutePseudoSection = reinterpret_cast<MCSection *>(1);
-void *MCSymbol::operator new(size_t s, NameEntryTy *Name, MCContext &Ctx) {
- size_t Size = s + (Name ? sizeof(Name) : 0);
+void *MCSymbol::operator new(size_t s, const StringMapEntry<bool> *Name,
+ MCContext &Ctx) {
+ // We may need more space for a Name to account for alignment. So allocate
+ // space for the storage type and not the name pointer.
+ size_t Size = s + (Name ? sizeof(NameEntryStorageTy) : 0);
// 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.
- assert(alignOf<MCSymbol>() <= alignOf<NameEntryTy *>() &&
+ assert(alignOf<MCSymbol>() <= alignOf<NameEntryStorageTy>() &&
"Bad alignment of MCSymbol");
- void *Storage = Ctx.allocate(Size, alignOf<NameEntryTy *>());
- NameEntryTy **Start = static_cast<NameEntryTy**>(Storage);
- NameEntryTy **End = Start + (Name ? 1 : 0);
+ void *Storage = Ctx.allocate(Size, alignOf<NameEntryStorageTy>());
+ NameEntryStorageTy *Start = static_cast<NameEntryStorageTy*>(Storage);
+ NameEntryStorageTy *End = Start + (Name ? 1 : 0);
return End;
}
OpenPOWER on IntegriCloud