* symbols.c (S_SET_THREAD_LOCAL): New function.
authorJakub Jelinek <jakub@redhat.com>
Thu, 28 Nov 2002 14:15:55 +0000 (14:15 +0000)
committerJakub Jelinek <jakub@redhat.com>
Thu, 28 Nov 2002 14:15:55 +0000 (14:15 +0000)
* symbols.h (S_SET_THREAD_LOCAL): New prototype.
* config/tc-i386.c (md_apply_fix3): Call S_SET_THREAD_LOCAL
for TLS relocations.
* config/tc-ia64.c (md_apply_fix3): Likewise.
* config/tc-alpha.c (md_apply_fix3): Likewise.

* ld-i386/tlsnopic.rd: Change NOTYPE to TLS for UND sg* symbols.

gas/ChangeLog
gas/config/tc-alpha.c
gas/config/tc-i386.c
gas/config/tc-ia64.c
gas/symbols.c
gas/symbols.h
ld/testsuite/ChangeLog
ld/testsuite/ld-i386/tlsnopic.rd

index 588c39d7ba4b8bb427bdc956d49f4e7b7f188ba8..81b352c28d0fd1590848f22b88d71d21f20c0429 100644 (file)
@@ -1,3 +1,12 @@
+2002-11-28  Jakub Jelinek  <jakub@redhat.com>
+
+       * symbols.c (S_SET_THREAD_LOCAL): New function.
+       * symbols.h (S_SET_THREAD_LOCAL): New prototype.
+       * config/tc-i386.c (md_apply_fix3): Call S_SET_THREAD_LOCAL
+       for TLS relocations.
+       * config/tc-ia64.c (md_apply_fix3): Likewise.
+       * config/tc-alpha.c (md_apply_fix3): Likewise.
+
 2002-11-28  Jakub Jelinek  <jakub@redhat.com>
 
        * write.c (subsegs_finish): For SEC_MERGE sections pad last fragment
index c54594b6e6f8597c60fd95341ca2b293118ceaee..e546dcf58583f458f540d9eeb413e3ddeac212d2 100644 (file)
@@ -1261,6 +1261,8 @@ md_apply_fix3 (fixP, valP, seg)
 
 #ifdef OBJ_ELF
     case BFD_RELOC_ALPHA_BRSGP:
+      return;
+
     case BFD_RELOC_ALPHA_TLSGD:
     case BFD_RELOC_ALPHA_TLSLDM:
     case BFD_RELOC_ALPHA_GOTDTPREL16:
@@ -1271,6 +1273,8 @@ md_apply_fix3 (fixP, valP, seg)
     case BFD_RELOC_ALPHA_TPREL_HI16:
     case BFD_RELOC_ALPHA_TPREL_LO16:
     case BFD_RELOC_ALPHA_TPREL16:
+      if (fixP->fx_addsy)
+       S_SET_THREAD_LOCAL (fixP->fx_addsy);
       return;
 #endif
 
index c7af77c77819bc8c64f2b0348231dbdd43b6a3ea..b17d39f8b8bcb161fae83b74516f274f8eb721cb 100644 (file)
@@ -4679,16 +4679,26 @@ md_apply_fix3 (fixP, valP, seg)
        value = -4;
        break;
 
-      case BFD_RELOC_386_GOT32:
       case BFD_RELOC_386_TLS_GD:
       case BFD_RELOC_386_TLS_LDM:
       case BFD_RELOC_386_TLS_IE_32:
       case BFD_RELOC_386_TLS_IE:
       case BFD_RELOC_386_TLS_GOTIE:
-      case BFD_RELOC_X86_64_GOT32:
       case BFD_RELOC_X86_64_TLSGD:
       case BFD_RELOC_X86_64_TLSLD:
       case BFD_RELOC_X86_64_GOTTPOFF:
+       value = 0; /* Fully resolved at runtime.  No addend.  */
+       /* Fallthrough */
+      case BFD_RELOC_386_TLS_LE:
+      case BFD_RELOC_386_TLS_LDO_32:
+      case BFD_RELOC_386_TLS_LE_32:
+      case BFD_RELOC_X86_64_DTPOFF32:
+      case BFD_RELOC_X86_64_TPOFF32:
+       S_SET_THREAD_LOCAL (fixP->fx_addsy);
+       break;
+
+      case BFD_RELOC_386_GOT32:
+      case BFD_RELOC_X86_64_GOT32:
        value = 0; /* Fully resolved at runtime.  No addend.  */
        break;
 
index cac7d0a493fce97230c6792187fee5477e336d8d..1c3fba0e2c828ccf19a924484d8082d24685c6ac 100644 (file)
@@ -10413,8 +10413,9 @@ md_apply_fix3 (fix, valP, seg)
     }
   if (fix->fx_addsy)
     {
-      if (fix->fx_r_type == (int) BFD_RELOC_UNUSED)
+      switch (fix->fx_r_type)
        {
+       case BFD_RELOC_UNUSED:
          /* This must be a TAG13 or TAG13b operand.  There are no external
             relocs defined for them, so we must give an error.  */
          as_bad_where (fix->fx_file, fix->fx_line,
@@ -10422,6 +10423,18 @@ md_apply_fix3 (fix, valP, seg)
                        elf64_ia64_operands[fix->tc_fix_data.opnd].desc);
          fix->fx_done = 1;
          return;
+
+       case BFD_RELOC_IA64_TPREL14:
+       case BFD_RELOC_IA64_TPREL22:
+       case BFD_RELOC_IA64_TPREL64I:
+       case BFD_RELOC_IA64_LTOFF_TPREL22:
+       case BFD_RELOC_IA64_LTOFF_DTPMOD22:
+       case BFD_RELOC_IA64_DTPREL14:
+       case BFD_RELOC_IA64_DTPREL22:
+       case BFD_RELOC_IA64_DTPREL64I:
+       case BFD_RELOC_IA64_LTOFF_DTPREL22:
+         S_SET_THREAD_LOCAL (fix->fx_addsy);
+         break;
        }
 
       /* ??? This is a hack copied from tc-i386.c to make PCREL relocs
index feed3592049963290c1ccc105d81656eba4d41f2..ccad71b2cd1f24591b63b08f94b647e8b0b9c27d 100644 (file)
@@ -1950,6 +1950,25 @@ S_SET_WEAK (s)
   s->bsym->flags &= ~(BSF_GLOBAL | BSF_LOCAL);
 }
 
+void
+S_SET_THREAD_LOCAL (s)
+     symbolS *s;
+{
+  if (LOCAL_SYMBOL_CHECK (s))
+    s = local_symbol_convert ((struct local_symbol *) s);
+  if (bfd_is_com_section (s->bsym->section)
+      && (s->bsym->flags & BSF_THREAD_LOCAL) != 0)
+    return;
+  s->bsym->flags |= BSF_THREAD_LOCAL;
+  if ((s->bsym->flags & BSF_FUNCTION) != 0)
+    as_bad (_("Accessing function `%s' as thread-local object"),
+           S_GET_NAME (s));
+  else if (! bfd_is_und_section (s->bsym->section)
+          && (s->bsym->section->flags & SEC_THREAD_LOCAL) == 0)
+    as_bad (_("Accessing `%s' as thread-local object"),
+           S_GET_NAME (s));
+}
+
 void
 S_SET_NAME (s, name)
      symbolS *s;
index 3c63d1b0fdf56481a1a3f77f49ceee8e4d10e332..914a9308f23a6eb36ac69f99e09435f0dc50f7df 100644 (file)
@@ -102,6 +102,7 @@ extern void S_SET_EXTERNAL PARAMS ((symbolS *));
 extern void S_SET_NAME PARAMS ((symbolS *, char *));
 extern void S_CLEAR_EXTERNAL PARAMS ((symbolS *));
 extern void S_SET_WEAK PARAMS ((symbolS *));
+extern void S_SET_THREAD_LOCAL PARAMS ((symbolS *));
 #endif
 
 #ifndef WORKING_DOT_WORD
index 27a09ff8e431692455a234705bf6cdcd186bdc31..0d835d40a8b7e387ea97b45c864122dd1288251d 100644 (file)
@@ -1,3 +1,7 @@
+2002-11-28  Jakub Jelinek  <jakub@redhat.com>
+
+       * ld-i386/tlsnopic.rd: Change NOTYPE to TLS for UND sg* symbols.
+
 2002-11-28  Kaz Kojima  <kkojima@rr.iij4u.or.jp>
 
        * ld-sh/refdbg-0-dso.d: New test.
index 3c6f3725e071fdf37af4031781353d026be35daa..5ac242c8f727e1106ce36743e396be2727364ab4 100644 (file)
@@ -84,13 +84,13 @@ Symbol table '.dynsym' contains 22 entries:
  +9: [0-9a-f]+ +0 SECTION LOCAL  DEFAULT +9 *
  +10: [0-9a-f]+ +0 SECTION LOCAL  DEFAULT +10 *
  +11: [0-9a-f]+ +0 OBJECT  GLOBAL DEFAULT  ABS _DYNAMIC
- +12: 0+ +0 NOTYPE  GLOBAL DEFAULT  UND sg3
- +13: 0+ +0 NOTYPE  GLOBAL DEFAULT  UND sg4
+ +12: 0+ +0 TLS +GLOBAL DEFAULT  UND sg3
+ +13: 0+ +0 TLS +GLOBAL DEFAULT  UND sg4
  +14: 0+1000 +0 FUNC +GLOBAL DEFAULT +5 fn3
- +15: 0+ +0 NOTYPE  GLOBAL DEFAULT  UND sg5
- +16: 0+ +0 NOTYPE  GLOBAL DEFAULT  UND sg1
+ +15: 0+ +0 TLS +GLOBAL DEFAULT  UND sg5
+ +16: 0+ +0 TLS +GLOBAL DEFAULT  UND sg1
  +17: [0-9a-f]+ +0 NOTYPE  GLOBAL DEFAULT  ABS __bss_start
- +18: 0+ +0 NOTYPE  GLOBAL DEFAULT  UND sg2
+ +18: 0+ +0 TLS +GLOBAL DEFAULT  UND sg2
  +19: [0-9a-f]+ +0 NOTYPE  GLOBAL DEFAULT  ABS _edata
  +20: 0+2080 +0 OBJECT  GLOBAL DEFAULT  ABS _GLOBAL_OFFSET_TABLE_
  +21: [0-9a-f]+ +0 NOTYPE  GLOBAL DEFAULT  ABS _end
@@ -121,13 +121,13 @@ Symbol table '.symtab' contains 34 entries:
  +21: 0+14 +0 TLS +LOCAL  HIDDEN +7 sh1
  +22: 0+18 +0 TLS +LOCAL  HIDDEN +7 sh2
  +23: [0-9a-f]+ +0 OBJECT  GLOBAL DEFAULT  ABS _DYNAMIC
- +24: 0+ +0 NOTYPE  GLOBAL DEFAULT  UND sg3
- +25: 0+ +0 NOTYPE  GLOBAL DEFAULT  UND sg4
+ +24: 0+ +0 TLS +GLOBAL DEFAULT  UND sg3
+ +25: 0+ +0 TLS +GLOBAL DEFAULT  UND sg4
  +26: 0+1000 +0 FUNC +GLOBAL DEFAULT +5 fn3
- +27: 0+ +0 NOTYPE  GLOBAL DEFAULT  UND sg5
- +28: 0+ +0 NOTYPE  GLOBAL DEFAULT  UND sg1
+ +27: 0+ +0 TLS +GLOBAL DEFAULT  UND sg5
+ +28: 0+ +0 TLS +GLOBAL DEFAULT  UND sg1
  +29: [0-9a-f]+ +0 NOTYPE  GLOBAL DEFAULT  ABS __bss_start
- +30: 0+ +0 NOTYPE  GLOBAL DEFAULT  UND sg2
+ +30: 0+ +0 TLS +GLOBAL DEFAULT  UND sg2
  +31: [0-9a-f]+ +0 NOTYPE  GLOBAL DEFAULT  ABS _edata
  +32: 0+2080 +0 OBJECT  GLOBAL DEFAULT  ABS _GLOBAL_OFFSET_TABLE_
  +33: [0-9a-f]+ +0 NOTYPE  GLOBAL DEFAULT  ABS _end