diff options
author | Pete Cooper <peter_cooper@apple.com> | 2015-06-09 19:56:05 +0000 |
---|---|---|
committer | Pete Cooper <peter_cooper@apple.com> | 2015-06-09 19:56:05 +0000 |
commit | a9ecddbbe5dbb1f463065b38e37fbc0d3022bcc8 (patch) | |
tree | 699ac0b4580c1ed8aee80a663c511371558549a2 /llvm/lib/MC/MCSymbol.cpp | |
parent | d9699bc7bdf0362173fcd256690f61a4d47429c2 (diff) | |
download | bcm5719-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.cpp | 15 |
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; } |