mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-26 06:04:47 +00:00
llvm-ar: Pad the symbol table to 4 bytes.
It looks like ld64 requires it. With this we seem to be able to bootstrap using llvm-ar+/usr/bin/true instead of ar+ranlib (currently on stage2). llvm-svn: 241842
This commit is contained in:
parent
6e942cb09c
commit
282d12d41c
@ -237,8 +237,11 @@ writeSymbolTable(raw_fd_ostream &Out, object::Archive::Kind Kind,
|
||||
print32(Out, Kind, StringTable.size()); // byte count of the string table
|
||||
Out << StringTable;
|
||||
|
||||
if (Out.tell() % 2)
|
||||
Out << '\0';
|
||||
// ld64 requires the next member header to start at an offset that is
|
||||
// 4 bytes aligned.
|
||||
unsigned Pad = OffsetToAlignment(Out.tell(), 4);
|
||||
while (Pad--)
|
||||
Out.write(uint8_t(0));
|
||||
|
||||
// Patch up the size of the symbol table now that we know how big it is.
|
||||
unsigned Pos = Out.tell();
|
||||
|
@ -87,3 +87,11 @@ MACHO: trivial-object-test2.macho-x86-64
|
||||
MACHO-NEXT: 0000000000000000 t _bar
|
||||
MACHO-NEXT: 0000000000000001 T _foo
|
||||
MACHO-NEXT: 0000000000000002 T _main
|
||||
|
||||
Test that we pad the symbol table so that it ends in a multiple of 4 bytes:
|
||||
8 + 60 + 36 == 104
|
||||
RUN: rm -f %t.a
|
||||
RUN: llvm-ar --format=bsd rcs %t.a %p/Inputs/trivial-object-test.macho-x86-64
|
||||
RUN: FileCheck --check-prefix=MACHO-SYMTAB-ALIGN %s < %t.a
|
||||
MACHO-SYMTAB-ALIGN: !<arch>
|
||||
MACHO-SYMTAB-ALIGN-NEXT: #1/12 {{..........}} 0 0 0 36 `
|
||||
|
Loading…
x
Reference in New Issue
Block a user