From a38a2e96b002d6c07564920566539625d8e550a9 Mon Sep 17 00:00:00 2001 From: "H.J. Lu" Date: Wed, 10 Aug 2005 04:32:49 +0000 Subject: [PATCH] 2005-08-09 H.J. Lu * elfxx-ia64.c (elfNN_ia64_final_link): Reset gp. --- bfd/ChangeLog | 4 ++++ bfd/elfxx-ia64.c | 14 +++++++------- 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 875a2e935a..97c62c74ea 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,7 @@ +2005-08-09 H.J. Lu + + * elfxx-ia64.c (elfNN_ia64_final_link): Reset gp. + 2005-08-09 Rodney Brown Nick Clifton diff --git a/bfd/elfxx-ia64.c b/bfd/elfxx-ia64.c index 85f715ce2e..140a0c970e 100644 --- a/bfd/elfxx-ia64.c +++ b/bfd/elfxx-ia64.c @@ -3981,15 +3981,15 @@ elfNN_ia64_final_link (abfd, info) /* Make sure we've got ourselves a nice fat __gp value. */ if (!info->relocatable) { - bfd_vma gp_val = _bfd_get_gp_value (abfd); + bfd_vma gp_val; struct elf_link_hash_entry *gp; - if (gp_val == 0) - { - if (! elfNN_ia64_choose_gp (abfd, info)) - return FALSE; - gp_val = _bfd_get_gp_value (abfd); - } + /* We assume after gp is set, section size will only decrease. We + need to adjust gp for it. */ + _bfd_set_gp_value (abfd, 0); + if (! elfNN_ia64_choose_gp (abfd, info)) + return FALSE; + gp_val = _bfd_get_gp_value (abfd); gp = elf_link_hash_lookup (elf_hash_table (info), "__gp", FALSE, FALSE, FALSE);