diff options
| author | Mark Wielaard <[email protected]> | 2014-07-04 14:30:48 +0200 |
|---|---|---|
| committer | Mark Wielaard <[email protected]> | 2014-07-04 14:30:48 +0200 |
| commit | a95c4ad24cf83b2b0273fee73162bf476cebec8f (patch) | |
| tree | a50510b5ef12ec3ea8a68bf73e38f0e5f818ae17 /backends | |
| parent | 16e2d351bf31d0ce09ce9632ff196cbd973b656b (diff) | |
Add ppc64le ELFv2 abi support to backends and elflint.
The big endian vs little endian changes are already handled by detecting
the EI_DATA data encoding. And the function descriptors are already not
used when we see there is no .opd section. This change adds new checks
for st_other bits, new relocations and recognizes DT_PPC64_OPT.
Signed-off-by: Menanteau Guy <[email protected]>
Signed-off-by: Mark Wielaard <[email protected]>
Diffstat (limited to 'backends')
| -rw-r--r-- | backends/ChangeLog | 11 | ||||
| -rw-r--r-- | backends/ppc64_init.c | 1 | ||||
| -rw-r--r-- | backends/ppc64_reloc.def | 15 | ||||
| -rw-r--r-- | backends/ppc64_symbol.c | 11 |
4 files changed, 37 insertions, 1 deletions
diff --git a/backends/ChangeLog b/backends/ChangeLog index c590ed6d..d29a80f6 100644 --- a/backends/ChangeLog +++ b/backends/ChangeLog @@ -1,3 +1,14 @@ +2014-07-04 Menanteau Guy <[email protected]> + Mark Wielaard <[email protected]> + + * ppc64_init.c (ppc64_init): Hook check_st_other_bits. + * ppc64_reloc.def: TLSGD, TLSLD, TOCSAVE, ADDR16_HIGH, ADDR16_HIGHA, + TPREL16_HIGH, TPREL16_HIGHA, DTPREL16_HIGH, DTPREL16_HIGHA, JMP_IREL, + IRELATIVE, REL16, REL16_LO, REL16_HI and REL16_HA. + * ppc64_symbol.c (ppc64_dynamic_tag_name): Recognize DT_PPC64_OPT. + (ppc64_dynamic_tag_check): Likewise. + (ppc64_check_st_other_bits): New function. + 2014-07-04 Mark Wielaard <[email protected]> * aarch64_retval.c (aarch64_return_value_location): Handle diff --git a/backends/ppc64_init.c b/backends/ppc64_init.c index e52231c9..7ea2b236 100644 --- a/backends/ppc64_init.c +++ b/backends/ppc64_init.c @@ -61,6 +61,7 @@ ppc64_init (elf, machine, eh, ehlen) HOOK (eh, machine_flag_check); HOOK (eh, copy_reloc_p); HOOK (eh, check_special_symbol); + HOOK (eh, check_st_other_bits); HOOK (eh, bss_plt_p); HOOK (eh, return_value_location); HOOK (eh, register_info); diff --git a/backends/ppc64_reloc.def b/backends/ppc64_reloc.def index 6366f46e..3a693cf6 100644 --- a/backends/ppc64_reloc.def +++ b/backends/ppc64_reloc.def @@ -132,6 +132,21 @@ RELOC_TYPE (DTPREL16_HIGHER, REL) RELOC_TYPE (DTPREL16_HIGHERA, REL) RELOC_TYPE (DTPREL16_HIGHEST, REL) RELOC_TYPE (DTPREL16_HIGHESTA, REL) +RELOC_TYPE (TLSGD, REL) +RELOC_TYPE (TLSLD, REL) +RELOC_TYPE (TOCSAVE, REL) +RELOC_TYPE (ADDR16_HIGH, REL) +RELOC_TYPE (ADDR16_HIGHA, REL) +RELOC_TYPE (TPREL16_HIGH, REL) +RELOC_TYPE (TPREL16_HIGHA, REL) +RELOC_TYPE (DTPREL16_HIGH, REL) +RELOC_TYPE (DTPREL16_HIGHA, REL) +RELOC_TYPE (JMP_IREL, REL) +RELOC_TYPE (IRELATIVE, REL) +RELOC_TYPE (REL16, REL) +RELOC_TYPE (REL16_LO, REL) +RELOC_TYPE (REL16_HI, REL) +RELOC_TYPE (REL16_HA, REL) /* Notes from Alan Modra: diff --git a/backends/ppc64_symbol.c b/backends/ppc64_symbol.c index 212d4145..5a020d8d 100644 --- a/backends/ppc64_symbol.c +++ b/backends/ppc64_symbol.c @@ -72,6 +72,8 @@ ppc64_dynamic_tag_name (int64_t tag, char *buf __attribute__ ((unused)), return "PPC64_OPD"; case DT_PPC64_OPDSZ: return "PPC64_OPDSZ"; + case DT_PPC64_OPT: + return "PPC64_OPT"; default: break; } @@ -84,7 +86,8 @@ ppc64_dynamic_tag_check (int64_t tag) { return (tag == DT_PPC64_GLINK || tag == DT_PPC64_OPD - || tag == DT_PPC64_OPDSZ); + || tag == DT_PPC64_OPDSZ + || tag == DT_PPC64_OPT); } @@ -120,3 +123,9 @@ ppc64_machine_flag_check (GElf_Word flags) { return flags == 0 || flags == 1 || flags == 2; } + +bool +ppc64_check_st_other_bits (unsigned char st_other) +{ + return (PPC64_LOCAL_ENTRY_OFFSET (st_other) != 0); +} |
