From 83d22aa85543ae8a089b13cd6d0a26b21050bf1d Mon Sep 17 00:00:00 2001 From: Andreas Schwab Date: Tue, 20 Jan 2009 16:12:00 +0000 Subject: [PATCH] * powerpc.cc (Powerpc_relocate_functions::rel16_ha): Don't try to read the value in the contents, since we don't use it. Use the template endianness when writing. (Relocate::relocate): Use it for R_PPC_REL16_HA. --- gold/ChangeLog | 7 +++++++ gold/powerpc.cc | 10 ++-------- 2 files changed, 9 insertions(+), 8 deletions(-) diff --git a/gold/ChangeLog b/gold/ChangeLog index 8c9a97eef4d..ddfe7b3f938 100644 --- a/gold/ChangeLog +++ b/gold/ChangeLog @@ -1,3 +1,10 @@ +2009-01-20 Andreas Schwab + + * powerpc.cc (Powerpc_relocate_functions::rel16_ha): Don't try to + read the value in the contents, since we don't use it. Use the + template endianness when writing. + (Relocate::relocate): Use it for R_PPC_REL16_HA. + 2009-01-19 Andreas Schwab * configure.tgt (powerpc64-*): Fix targ_obj. diff --git a/gold/powerpc.cc b/gold/powerpc.cc index 05ce4fcc1ec..2d1d9844ca7 100644 --- a/gold/powerpc.cc +++ b/gold/powerpc.cc @@ -663,9 +663,6 @@ public: typename elfcpp::Elf_types::Elf_Addr addend, typename elfcpp::Elf_types::Elf_Addr address) { - typedef typename elfcpp::Swap<16, true>::Valtype Valtype; - Valtype* wv = reinterpret_cast(view); - Valtype val = elfcpp::Swap<16, true>::readval(wv); typename elfcpp::Elf_types::Elf_Addr reloc; reloc = (psymval->value(object, addend) - address); @@ -673,10 +670,7 @@ public: reloc += 0x10000; reloc >>= 16; - val &= ~static_cast(0xffff); - reloc &= static_cast(0xffff); - - elfcpp::Swap<16, true>::writeval(wv, val | reloc); + elfcpp::Swap<16, big_endian>::writeval(view, reloc); } }; @@ -1681,7 +1675,7 @@ Target_powerpc::Relocate::relocate( break; case elfcpp::R_PPC_REL16_HA: - Reloc::rel16_lo(view, object, psymval, addend, address); + Reloc::rel16_ha(view, object, psymval, addend, address); break; case elfcpp::R_POWERPC_GOT16: -- 2.30.2