Skip to content

Commit

Permalink
cmd/ld: set ELF ABI version for ppc64x
Browse files Browse the repository at this point in the history
On ppc64, there are three ELF ABI versions an ELF file can request.
Previously, we used 0, which means "unspecified".  On our test
machines, this meant to use the default (v1 for big endian and v2 for
little endian), but apparently some systems can pick the wrong ABI if
neither is requested.  Leaving this as 0 also confuses libbfd, which
confuses gdb, objdump, etc.

Fix these problems by specifying ABI v1 for big endian and v2 for
little endian.

Change-Id: I4d3d5478f37f11baab3681a07daff3da55802322
Reviewed-on: https://go-review.googlesource.com/1800
Reviewed-by: Minux Ma <[email protected]>
  • Loading branch information
aclements committed Dec 18, 2014
1 parent 2fc29a8 commit 15c67e2
Showing 1 changed file with 5 additions and 1 deletion.
6 changes: 5 additions & 1 deletion src/cmd/ld/elf.c
Original file line number Diff line number Diff line change
Expand Up @@ -44,8 +44,12 @@ elfinit(void)

switch(thechar) {
// 64-bit architectures
case '6':
case '9':
if(ctxt->arch->endian == BigEndian)
hdr.flags = 1; /* Version 1 ABI */
else
hdr.flags = 2; /* Version 2 ABI */
case '6':
elf64 = 1;
hdr.phoff = ELF64HDRSIZE; /* Must be be ELF64HDRSIZE: first PHdr must follow ELF header */
hdr.shoff = ELF64HDRSIZE; /* Will move as we add PHeaders */
Expand Down

0 comments on commit 15c67e2

Please sign in to comment.