bfd/
authorJakub Jelinek <jakub@redhat.com>
Mon, 19 Apr 2004 14:25:49 +0000 (14:25 +0000)
committerJakub Jelinek <jakub@redhat.com>
Mon, 19 Apr 2004 14:25:49 +0000 (14:25 +0000)
* elf32-sparc.c (elf32_sparc_relocate_section): Handle
relocs against hidden/protected undefweak symbols properly.
* elf64-sparc.c (sparc64_elf_relocate_section): Likewise.
gas/testsuite/
* gas/cfi/cfi-sparc64-1.d: Update.
ld/testsuite/
* ld-elfvsb/elfvsb.exp: XFAIL some tests on sparc64.
* ld-shared/shared.exp: Likewise.

bfd/ChangeLog
bfd/elf32-sparc.c
bfd/elf64-sparc.c
gas/testsuite/ChangeLog
gas/testsuite/gas/cfi/cfi-sparc64-1.d
ld/testsuite/ChangeLog
ld/testsuite/ld-elfvsb/elfvsb.exp
ld/testsuite/ld-shared/shared.exp

index a454433..dda65cd 100644 (file)
@@ -1,3 +1,9 @@
+2004-04-19  Jakub Jelinek  <jakub@redhat.com>
+
+       * elf32-sparc.c (elf32_sparc_relocate_section): Handle
+       relocs against hidden/protected undefweak symbols properly.
+       * elf64-sparc.c (sparc64_elf_relocate_section): Likewise.
+
 2004-04-18  Mark Kettenis  <kettenis@gnu.org>
 
        * libaout.h (enum machine_type): Add M_POWERPC_NETBSD.
index 0f94f5f..6e1c40b 100644 (file)
@@ -2374,6 +2374,9 @@ elf32_sparc_relocate_section (output_bfd, info, input_bfd, input_section,
            break;
 
          if ((info->shared
+              && (h == NULL
+                  || ELF_ST_VISIBILITY (h->other) == STV_DEFAULT
+                  || h->root.type != bfd_link_hash_undefweak)
               && (! howto->pc_relative
                   || (h != NULL
                       && h->dynindx != -1
index 4568a22..4f28325 100644 (file)
@@ -2213,6 +2213,13 @@ sparc64_elf_relocate_section (output_bfd, info, input_bfd, input_section,
                    break;
                  }
 
+               /* FIXME: Dynamic reloc handling really needs to be rewritten.  */
+               if (!skip
+                   && h != NULL
+                   && ELF_ST_VISIBILITY (h->other) != STV_DEFAULT
+                   && h->root.type == bfd_link_hash_undefweak)
+                 skip = TRUE, relocate = TRUE;
+
                if (skip)
                  memset (&outrel, 0, sizeof outrel);
                /* h->dynindx may be -1 if the symbol was marked to
index 1e262f1..c99e91f 100644 (file)
@@ -1,3 +1,7 @@
+2004-04-19  Jakub Jelinek  <jakub@redhat.com>
+
+       * gas/cfi/cfi-sparc64-1.d: Update.
+
 2004-04-14  Richard Sandiford  <rsandifo@redhat.com>
 
        * gas/mips/vr4122.[sd]: Change option to -mfix-vr4120.
index ffe6239..10d3ea9 100644 (file)
@@ -4,7 +4,7 @@
 
 The section .eh_frame contains:
 
-00000000 00000011 00000000 CIE
+00000000 00000014 00000000 CIE
   Version:               1
   Augmentation:          "zR"
   Code alignment factor: 4
@@ -13,13 +13,13 @@ The section .eh_frame contains:
   Augmentation data:     1b
 
   DW_CFA_def_cfa: r14 ofs 2047
+  DW_CFA_nop
+  DW_CFA_nop
+  DW_CFA_nop
 
-00000015 00000017 00000019 FDE cie=00000000 pc=0000001d..0000004d
-  DW_CFA_advance_loc: 4 to 00000021
+00000018 00000014 0000001c FDE cie=00000000 pc=00000020..00000050
+  DW_CFA_advance_loc: 4 to 00000024
   DW_CFA_def_cfa_reg: r30
   DW_CFA_GNU_window_save
   DW_CFA_register: r15 in r31
-  DW_CFA_nop
-  DW_CFA_nop
-  DW_CFA_nop
 
index 9f9fab8..1849b20 100644 (file)
@@ -1,3 +1,8 @@
+2004-04-19  Jakub Jelinek  <jakub@redhat.com>
+
+       * ld-elfvsb/elfvsb.exp: XFAIL some tests on sparc64.
+       * ld-shared/shared.exp: Likewise.
+
 2004-04-14  H.J. Lu  <hongjiu.lu@intel.com>
 
        * ld-scripts/assert.s: Add a newline.
index f1f3f1f..cd7c15f 100644 (file)
@@ -1,5 +1,5 @@
 # Expect script for ld-visibility tests
-#   Copyright 2000, 2001, 2003 Free Software Foundation, Inc.
+#   Copyright 2000, 2001, 2003, 2004 Free Software Foundation, Inc.
 #
 # This file is free software; you can redistribute it and/or modify
 # it under the terms of the GNU General Public License as published by
@@ -261,6 +261,9 @@ proc visibility_run {visibility} {
                 && ![ string match $visibility "hidden_undef_def" ]
                 && ![ string match $visibility "protected_undef" ] } {
                setup_xfail "s390x-*-linux*"
+               if { [istarget sparc*-*-linux*] && [is_elf64 $tmpdir/mainnp.o] } {
+                   setup_xfail "sparc*-*-linux*"
+               }
            }
            setup_xfail "x86_64-*-linux*"
            if { ![istarget hppa*64*-*-linux*] } {
@@ -289,6 +292,9 @@ proc visibility_run {visibility} {
                 || [ string match $visibility "protected_weak" ]
                 || [ string match $visibility "normal" ] } {
                setup_xfail "powerpc-*-linux*"
+               if { [istarget sparc*-*-linux*] && [is_elf64 $tmpdir/mainnp.o] } {
+                   setup_xfail "sparc*-*-linux*"
+               }
            }
            if { ![ string match $visibility "hidden_undef" ]
                 && ![ string match $visibility "protected_undef" ] } {
@@ -358,6 +364,9 @@ proc visibility_run {visibility} {
                     && ![ string match $visibility "hidden_undef_def" ]
                     && ![ string match $visibility "protected_undef" ] } {
                    setup_xfail "s390x-*-linux*"
+                   if { [istarget sparc*-*-linux*] && [is_elf64 $tmpdir/mainp.o] } {
+                       setup_xfail "sparc*-*-linux*"
+                   }
                }
                setup_xfail "x86_64-*-linux*"
                if { ![istarget hppa*64*-*-linux*] } {
index 339d3a3..a88cd1c 100644 (file)
@@ -203,6 +203,9 @@ if ![ld_compile "$CC $CFLAGS $SHCFLAG" $srcdir/$subdir/main.c $tmpdir/mainnp.o]
        if { ![istarget hppa*64*-*-linux*] } {
            setup_xfail "hppa*-*-linux*"
        }
+       if { [istarget sparc*-*-linux*] && [is_elf64 $tmpdir/mainnp.o] } {
+           setup_xfail "sparc*-*-linux*"
+       }
        setup_xfail "x86_64-*-linux*"
        setup_xfail "s390x-*-linux*"
        shared_test shnp "shared (non PIC)" mainnp.o sh1np.o sh2np.o shared
@@ -220,6 +223,9 @@ if ![ld_compile "$CC $CFLAGS $SHCFLAG" $srcdir/$subdir/main.c $tmpdir/mainnp.o]
        if { ![istarget hppa*64*-*-linux*] } {
            setup_xfail "hppa*-*-linux*"
        }
+       if { [istarget sparc*-*-linux*] && [is_elf64 $tmpdir/mainnp.o] } {
+           setup_xfail "sparc*-*-linux*"
+       }
        setup_xfail "x86_64-*-linux*"
        shared_test shnp "shared (non PIC, load offset)" \
                mainnp.o sh1np.o sh2np.o shared \
@@ -265,6 +271,9 @@ if ![ld_compile "$CC $CFLAGS $SHCFLAG $picflag" $srcdir/$subdir/main.c $tmpdir/m
            if { ![istarget hppa*64*-*-linux*] } {
                setup_xfail "hppa*-*-linux*"
            }
+           if { [istarget sparc*-*-linux*] && [is_elf64 $tmpdir/mainp.o] } {
+               setup_xfail "sparc*-*-linux*"
+           }
            setup_xfail "x86_64-*-linux*"
            setup_xfail "s390x-*-linux*"
            shared_test shmpnp "shared (PIC main, non PIC so)" mainp.o sh1np.o sh2np.o shared