* config/tc-s390.c (s390_elf_cons): Correct fixups for PLT
[deliverable/binutils-gdb.git] / gas / config / obj-coff.h
index 8ab4b090e754fc29affff9b4a0871e8c80c0675c..f862f7725ea1c3a13be2c23ab32442b293a52d58 100644 (file)
@@ -1,5 +1,6 @@
 /* coff object file format
-   Copyright (C) 1989, 90, 91, 92, 94, 95, 96, 1997
+   Copyright 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
+   1999, 2000
    Free Software Foundation, Inc.
 
    This file is part of GAS.
@@ -39,7 +40,7 @@
 #include "bfd.h"
 
 /* This internal_lineno crap is to stop namespace pollution from the
-   bfd internal coff headerfile. */
+   bfd internal coff headerfile.  */
 #define internal_lineno bfd_internal_lineno
 #include "coff/internal.h"
 #undef internal_lineno
 #endif
 
 #ifdef TC_SH
+
+#ifdef TE_PE
+#define COFF_WITH_PE
+#endif
+
 #include "coff/sh.h"
-#define TARGET_FORMAT (shl ? "coff-shl" : "coff-sh")
+
+#ifdef TE_PE
+#define TARGET_FORMAT "pe-shl"
+#else
+#define TARGET_FORMAT                                  \
+  (shl                                                 \
+   ? (sh_small ? "coff-shl-small" : "coff-shl")                \
+   : (sh_small ? "coff-sh-small" : "coff-sh"))
+#endif
+#endif
+
+#ifdef TC_MIPS
+#define COFF_WITH_PE
+#include "coff/mipspe.h"
+#undef  TARGET_FORMAT
+#define TARGET_FORMAT "pe-mips"
 #endif
 
 #ifdef TC_M88K
 #define TARGET_FORMAT "coff-w65"
 #endif
 
-/* start-sanitize-tic80 */
+#ifdef TC_TIC30
+#include "coff/tic30.h"
+#define TARGET_FORMAT "coff-tic30"
+#endif
+
+#ifdef TC_TIC54X
+#include "coff/tic54x.h"
+#define TARGET_FORMAT "coff1-c54x"
+#endif
+
 #ifdef TC_TIC80
 #include "coff/tic80.h"
 #define TARGET_FORMAT "coff-tic80"
 #define ALIGNMENT_IN_S_FLAGS 1
 #endif
-/* end-sanitize-tic80 */
+
+#ifdef TC_MCORE
+#include "coff/mcore.h"
+#ifndef TARGET_FORMAT
+#define TARGET_FORMAT "pe-mcore"
+#endif
+#endif
 
 /* Targets may also set this.  Also, if BFD_ASSEMBLER is defined, this
    will already have been defined.  */
 #define OBJ_COFF_MAX_AUXENTRIES 1
 #endif /* OBJ_COFF_MAX_AUXENTRIES */
 
-extern void coff_obj_symbol_new_hook PARAMS ((struct symbol *));
+extern void coff_obj_symbol_new_hook PARAMS ((symbolS *));
 #define obj_symbol_new_hook coff_obj_symbol_new_hook
 
 extern void coff_obj_read_begin_hook PARAMS ((void));
@@ -198,31 +234,35 @@ extern void coff_obj_read_begin_hook PARAMS ((void));
 /* Alter the field names, for now, until we've fixed up the other
    references to use the new name.  */
 #ifdef TC_I960
-#define TC_SYMFIELD_TYPE       struct symbol *
+#define TC_SYMFIELD_TYPE       symbolS *
 #define sy_tc                  bal
 #endif
 
 #define OBJ_SYMFIELD_TYPE      unsigned long
 #define sy_obj                 sy_flags
 
-#define SYM_AUXENT(S)  (&coffsymbol ((S)->bsym)->native[1].u.auxent)
+#define SYM_AUXENT(S) \
+  (&coffsymbol (symbol_get_bfdsym (S))->native[1].u.auxent)
+#define SYM_AUXINFO(S) \
+  (&coffsymbol (symbol_get_bfdsym (S))->native[1])
 
 #define DO_NOT_STRIP   0
 
 extern void obj_coff_section PARAMS ((int));
 
 /* The number of auxiliary entries */
-#define S_GET_NUMBER_AUXILIARY(s)      (coffsymbol((s)->bsym)->native->u.syment.n_numaux)
+#define S_GET_NUMBER_AUXILIARY(s) \
+  (coffsymbol (symbol_get_bfdsym (s))->native->u.syment.n_numaux)
 /* The number of auxiliary entries */
 #define S_SET_NUMBER_AUXILIARY(s,v)    (S_GET_NUMBER_AUXILIARY (s) = (v))
 
-/* True if a symbol name is in the string table, i.e. its length is > 8. */
+/* True if a symbol name is in the string table, i.e. its length is > 8.  */
 #define S_IS_STRING(s)         (strlen(S_GET_NAME(s)) > 8 ? 1 : 0)
 
-extern int S_SET_DATA_TYPE PARAMS ((struct symbol *, int));
-extern int S_SET_STORAGE_CLASS PARAMS ((struct symbol *, int));
-extern int S_GET_STORAGE_CLASS PARAMS ((struct symbol *));
-extern void SA_SET_SYM_ENDNDX PARAMS ((struct symbol *, struct symbol *));
+extern int S_SET_DATA_TYPE PARAMS ((symbolS *, int));
+extern int S_SET_STORAGE_CLASS PARAMS ((symbolS *, int));
+extern int S_GET_STORAGE_CLASS PARAMS ((symbolS *));
+extern void SA_SET_SYM_ENDNDX PARAMS ((symbolS *, symbolS *));
 
 /* Auxiliary entry macros. SA_ stands for symbol auxiliary */
 /* Omit the tv related fields */
@@ -260,13 +300,13 @@ extern void SA_SET_SYM_ENDNDX PARAMS ((struct symbol *, struct symbol *));
  * differently.
  */
 
-#define SF_I960_MASK   (0x000001ff)    /* Bits 0-8 are used by the i960 port. */
+#define SF_I960_MASK   (0x000001ff)    /* Bits 0-8 are used by the i960 port.  */
 #define SF_SYSPROC     (0x0000003f)    /* bits 0-5 are used to store the sysproc number */
 #define SF_IS_SYSPROC  (0x00000040)    /* bit 6 marks symbols that are sysprocs */
 #define SF_BALNAME     (0x00000080)    /* bit 7 marks BALNAME symbols */
 #define SF_CALLNAME    (0x00000100)    /* bit 8 marks CALLNAME symbols */
 
-#define SF_NORMAL_MASK (0x0000ffff)    /* bits 12-15 are general purpose. */
+#define SF_NORMAL_MASK (0x0000ffff)    /* bits 12-15 are general purpose.  */
 
 #define SF_STATICS     (0x00001000)    /* Mark the .text & all symbols */
 #define SF_DEFINED     (0x00002000)    /* Symbol is defined in this file */
@@ -280,13 +320,13 @@ extern void SA_SET_SYM_ENDNDX PARAMS ((struct symbol *, struct symbol *));
 #define SF_TAGGED      (0x00040000)    /* Is associated with a tag */
 #define SF_TAG         (0x00080000)    /* Is a tag */
 #define SF_DEBUG       (0x00100000)    /* Is in debug or abs section */
-#define SF_GET_SEGMENT (0x00200000)    /* Get the section of the forward symbol. */
-/* All other bits are unused. */
+#define SF_GET_SEGMENT (0x00200000)    /* Get the section of the forward symbol.  */
+/* All other bits are unused.  */
 
 /* Accessors */
-#define SF_GET(s)              ((s)->sy_flags)
-#define SF_GET_DEBUG(s)                ((s)->bsym->flags & BSF_DEBUGGING)
-#define SF_SET_DEBUG(s)                ((s)->bsym->flags |= BSF_DEBUGGING)
+#define SF_GET(s)              (*symbol_get_obj (s))
+#define SF_GET_DEBUG(s)                (symbol_get_bfdsym (s)->flags & BSF_DEBUGGING)
+#define SF_SET_DEBUG(s)                (symbol_get_bfdsym (s)->flags |= BSF_DEBUGGING)
 #define SF_GET_NORMAL_FIELD(s) (SF_GET (s) & SF_NORMAL_MASK)
 #define SF_GET_DEBUG_FIELD(s)  (SF_GET (s) & SF_DEBUG_MASK)
 #define SF_GET_FILE(s)         (SF_GET (s) & SF_FILE)
@@ -307,7 +347,7 @@ extern void SA_SET_SYM_ENDNDX PARAMS ((struct symbol *, struct symbol *));
 
 /* Modifiers */
 #define SF_SET(s,v)            (SF_GET (s) = (v))
-#define SF_SET_NORMAL_FIELD(s,v)(SF_GET (s) |= ((v) & SF_NORMAL_MASK))
+#define SF_SET_NORMAL_FIELD(s,v) (SF_GET (s) |= ((v) & SF_NORMAL_MASK))
 #define SF_SET_DEBUG_FIELD(s,v)        (SF_GET (s) |= ((v) & SF_DEBUG_MASK))
 #define SF_SET_FILE(s)         (SF_GET (s) |= SF_FILE)
 #define SF_SET_STATICS(s)      (SF_GET (s) |= SF_STATICS)
@@ -332,26 +372,28 @@ extern int coff_line_base;
 extern int coff_n_line_nos;
 
 #define obj_emit_lineno(WHERE,LINE,FILE_START) abort ()
-extern void coff_add_linesym PARAMS ((struct symbol *));
+extern void coff_add_linesym PARAMS ((symbolS *));
 
-
-void c_dot_file_symbol PARAMS ((char *filename));
+void c_dot_file_symbol PARAMS ((const char *filename));
 #define obj_app_file c_dot_file_symbol
 
-extern void coff_frob_symbol PARAMS ((struct symbol *, int *));
+extern void coff_frob_symbol PARAMS ((symbolS *, int *));
 extern void coff_adjust_symtab PARAMS ((void));
 extern void coff_frob_section PARAMS ((segT));
 extern void coff_adjust_section_syms PARAMS ((bfd *, asection *, PTR));
 extern void coff_frob_file_after_relocs PARAMS ((void));
 #define obj_frob_symbol(S,P)   coff_frob_symbol(S,&P)
+#ifndef obj_adjust_symtab
 #define obj_adjust_symtab()    coff_adjust_symtab()
+#endif
 #define obj_frob_section(S)    coff_frob_section (S)
 #define obj_frob_file_after_relocs() coff_frob_file_after_relocs ()
 
-extern struct symbol *coff_last_function;
+extern symbolS *coff_last_function;
 
 /* Forward the segment of a forwarded symbol, handle assignments that
    just copy symbol values, etc.  */
+#ifndef OBJ_COPY_SYMBOL_ATTRIBUTES
 #ifndef TE_I386AIX
 #define OBJ_COPY_SYMBOL_ATTRIBUTES(dest,src) \
   (SF_GET_GET_SEGMENT (dest) \
@@ -363,6 +405,7 @@ extern struct symbol *coff_last_function;
    ? (S_SET_SEGMENT (dest, S_GET_SEGMENT (src)), 0) \
    : 0)
 #endif
+#endif
 
 /* sanity check */
 
@@ -392,10 +435,9 @@ hey ! Where is the C_LEAFSTAT definition ? i960 - coff support is depending on i
 
 extern const segT N_TYPE_seg[];
 
-/* Magic number of paged executable. */
+/* Magic number of paged executable.  */
 #define DEFAULT_MAGIC_NUMBER_FOR_OBJECT_FILE   0x8300
 
-
 /* SYMBOL TABLE */
 
 /* Symbol table entry data type */
@@ -404,7 +446,7 @@ typedef struct
 {
   /* Basic symbol */
   struct internal_syment ost_entry;
-  /* Auxiliary entry. */
+  /* Auxiliary entry.  */
   union internal_auxent ost_auxent[OBJ_COFF_MAX_AUXENTRIES];
   /* obj_coff internal use only flags */
   unsigned int ost_flags;
@@ -451,7 +493,10 @@ typedef struct
   ((s)->sy_symbol.ost_entry.n_scnum == C_REGISTER_SECTION \
    || (S_LOCAL_NAME(s) && ! flag_keep_locals && ! S_IS_DEBUG (s)) \
    || strchr (S_GET_NAME (s), '\001') != NULL \
-   || strchr (S_GET_NAME (s), '\002') != NULL)
+   || strchr (S_GET_NAME (s), '\002') != NULL \
+   || (flag_strip_local_absolute \
+       && !S_IS_EXTERNAL(s) \
+       && (s)->sy_symbol.ost_entry.n_scnum == C_ABS_SECTION))
 /* True if a symbol is not defined in this file */
 #define S_IS_EXTERN(s)         ((s)->sy_symbol.ost_entry.n_scnum == 0 \
                                 && S_GET_VALUE (s) == 0)
@@ -461,12 +506,22 @@ typedef struct
  */
 #define S_IS_COMMON(s)         ((s)->sy_symbol.ost_entry.n_scnum == 0 \
                                 && S_GET_VALUE (s) != 0)
-/* True if a symbol name is in the string table, i.e. its length is > 8. */
+/* True if a symbol name is in the string table, i.e. its length is > 8.  */
 #define S_IS_STRING(s)         (strlen(S_GET_NAME(s)) > 8 ? 1 : 0)
 
+/* True if a symbol is defined as weak.  */
+#ifdef TE_PE
+#define S_IS_WEAK(s) \
+  ((s)->sy_symbol.ost_entry.n_sclass == C_NT_WEAK \
+   || (s)->sy_symbol.ost_entry.n_sclass == C_WEAKEXT)
+#else
+#define S_IS_WEAK(s) \
+  ((s)->sy_symbol.ost_entry.n_sclass == C_WEAKEXT)
+#endif
+
 /* Accessors */
 /* The name of the symbol */
-#define S_GET_NAME(s)          ((char*)(s)->sy_symbol.ost_entry.n_offset)
+#define S_GET_NAME(s)          ((char*) (s)->sy_symbol.ost_entry.n_offset)
 /* The pointer to the string table */
 #define S_GET_OFFSET(s)         ((s)->sy_symbol.ost_entry.n_offset)
 /* The numeric value of the segment */
@@ -480,7 +535,7 @@ typedef struct
 
 /* Modifiers */
 /* Set the name of the symbol */
-#define S_SET_NAME(s,v)                ((s)->sy_symbol.ost_entry.n_offset = (unsigned long)(v))
+#define S_SET_NAME(s,v)                ((s)->sy_symbol.ost_entry.n_offset = (unsigned long) (v))
 /* Set the offset of the symbol */
 #define S_SET_OFFSET(s,v)      ((s)->sy_symbol.ost_entry.n_offset = (v))
 /* The numeric value of the segment */
@@ -540,13 +595,13 @@ typedef struct
  * differently.
  */
 
-#define SF_I960_MASK   (0x000001ff)    /* Bits 0-8 are used by the i960 port. */
+#define SF_I960_MASK   (0x000001ff)    /* Bits 0-8 are used by the i960 port.  */
 #define SF_SYSPROC     (0x0000003f)    /* bits 0-5 are used to store the sysproc number */
 #define SF_IS_SYSPROC  (0x00000040)    /* bit 6 marks symbols that are sysprocs */
 #define SF_BALNAME     (0x00000080)    /* bit 7 marks BALNAME symbols */
 #define SF_CALLNAME    (0x00000100)    /* bit 8 marks CALLNAME symbols */
 
-#define SF_NORMAL_MASK (0x0000ffff)    /* bits 12-15 are general purpose. */
+#define SF_NORMAL_MASK (0x0000ffff)    /* bits 12-15 are general purpose.  */
 
 #define SF_STATICS     (0x00001000)    /* Mark the .text & all symbols */
 #define SF_DEFINED     (0x00002000)    /* Symbol is defined in this file */
@@ -560,9 +615,9 @@ typedef struct
 #define SF_TAGGED      (0x00040000)    /* Is associated with a tag */
 #define SF_TAG         (0x00080000)    /* Is a tag */
 #define SF_DEBUG       (0x00100000)    /* Is in debug or abs section */
-#define SF_GET_SEGMENT (0x00200000)    /* Get the section of the forward symbol. */
+#define SF_GET_SEGMENT (0x00200000)    /* Get the section of the forward symbol.  */
 #define SF_ADJ_LNNOPTR (0x00400000)    /* Has a lnnoptr */
-/* All other bits are unused. */
+/* All other bits are unused.  */
 
 /* Accessors */
 #define SF_GET(s)              ((s)->sy_symbol.ost_flags)
@@ -588,7 +643,7 @@ typedef struct
 
 /* Modifiers */
 #define SF_SET(s,v)            (SF_GET (s) = (v))
-#define SF_SET_NORMAL_FIELD(s,v)(SF_GET (s) |= ((v) & SF_NORMAL_MASK))
+#define SF_SET_NORMAL_FIELD(s,v) (SF_GET (s) |= ((v) & SF_NORMAL_MASK))
 #define SF_SET_DEBUG_FIELD(s,v)        (SF_GET (s) |= ((v) & SF_DEBUG_MASK))
 #define SF_SET_FILE(s)         (SF_GET (s) |= SF_FILE)
 #define SF_SET_STATICS(s)      (SF_GET (s) |= SF_STATICS)
@@ -623,31 +678,31 @@ typedef struct
 #endif /* OBJ_COFF_OMIT_OPTIONAL_HEADER */
 
 #define H_GET_FILE_SIZE(h) \
-    (long)(FILHSZ + OBJ_COFF_AOUTHDRSZ + \
+    (long) (FILHSZ + OBJ_COFF_AOUTHDRSZ + \
           H_GET_NUMBER_OF_SECTIONS(h) * SCNHSZ + \
           H_GET_TEXT_SIZE(h) + H_GET_DATA_SIZE(h) + \
           H_GET_RELOCATION_SIZE(h) + H_GET_LINENO_SIZE(h) + \
           H_GET_SYMBOL_TABLE_SIZE(h) + \
           (h)->string_table_size)
 #define H_GET_TEXT_FILE_OFFSET(h) \
-    (long)(FILHSZ + OBJ_COFF_AOUTHDRSZ + \
+    (long) (FILHSZ + OBJ_COFF_AOUTHDRSZ + \
           H_GET_NUMBER_OF_SECTIONS(h) * SCNHSZ)
 #define H_GET_DATA_FILE_OFFSET(h) \
-    (long)(FILHSZ + OBJ_COFF_AOUTHDRSZ + \
+    (long) (FILHSZ + OBJ_COFF_AOUTHDRSZ + \
           H_GET_NUMBER_OF_SECTIONS(h) * SCNHSZ + \
           H_GET_TEXT_SIZE(h))
 #define H_GET_BSS_FILE_OFFSET(h) 0
 #define H_GET_RELOCATION_FILE_OFFSET(h) \
-    (long)(FILHSZ + OBJ_COFF_AOUTHDRSZ + \
+    (long) (FILHSZ + OBJ_COFF_AOUTHDRSZ + \
           H_GET_NUMBER_OF_SECTIONS(h) * SCNHSZ + \
           H_GET_TEXT_SIZE(h) + H_GET_DATA_SIZE(h))
 #define H_GET_LINENO_FILE_OFFSET(h) \
-    (long)(FILHSZ + OBJ_COFF_AOUTHDRSZ + \
+    (long) (FILHSZ + OBJ_COFF_AOUTHDRSZ + \
           H_GET_NUMBER_OF_SECTIONS(h) * SCNHSZ + \
           H_GET_TEXT_SIZE(h) + H_GET_DATA_SIZE(h) + \
           H_GET_RELOCATION_SIZE(h))
 #define H_GET_SYMBOL_TABLE_FILE_OFFSET(h) \
-    (long)(FILHSZ + OBJ_COFF_AOUTHDRSZ + \
+    (long) (FILHSZ + OBJ_COFF_AOUTHDRSZ + \
           H_GET_NUMBER_OF_SECTIONS(h) * SCNHSZ + \
           H_GET_TEXT_SIZE(h) + H_GET_DATA_SIZE(h) + \
           H_GET_RELOCATION_SIZE(h) + H_GET_LINENO_SIZE(h))
@@ -677,11 +732,11 @@ typedef struct
 #define H_GET_LINENO_SIZE(h)            ((h)->lineno_size)
 
 #ifndef OBJ_COFF_OMIT_OPTIONAL_HEADER
-#define H_GET_HEADER_SIZE(h)           (sizeof(FILHDR) \
-                                        + sizeof(AOUTHDR)\
+#define H_GET_HEADER_SIZE(h)           (sizeof (FILHDR) \
+                                        + sizeof (AOUTHDR)\
                                         + (H_GET_NUMBER_OF_SECTIONS(h) * SCNHSZ))
 #else /* OBJ_COFF_OMIT_OPTIONAL_HEADER */
-#define H_GET_HEADER_SIZE(h)           (sizeof(FILHDR) \
+#define H_GET_HEADER_SIZE(h)           (sizeof (FILHDR) \
                                         + (H_GET_NUMBER_OF_SECTIONS(h) * SCNHSZ))
 #endif /* OBJ_COFF_OMIT_OPTIONAL_HEADER */
 
@@ -716,17 +771,15 @@ typedef struct
 typedef struct
 {
   struct internal_aouthdr aouthdr;     /* a.out header */
-  struct internal_filehdr filehdr;     /* File header, not machine dep. */
-  long string_table_size;      /* names + '\0' + sizeof(int) */
+  struct internal_filehdr filehdr;     /* File header, not machine dep.  */
+  long string_table_size;      /* names + '\0' + sizeof (int) */
   long relocation_size;        /* Cumulated size of relocation
                           information for all sections in
-                          bytes. */
+                          bytes.  */
   long lineno_size;            /* Size of the line number information
                                   table in bytes */
 } object_headers;
 
-
-
 struct lineno_list
 {
   struct bfd_internal_lineno line;
@@ -734,9 +787,6 @@ struct lineno_list
   struct lineno_list *next;    /* Forward chain pointer */
 };
 
-
-
-
 #define obj_segment_name(i) (segment_info[(int) (i)].scnhdr.s_name)
 
 #define obj_add_segment(s) obj_coff_add_segment (s)
@@ -749,7 +799,7 @@ extern void c_dot_file_symbol PARAMS ((char *filename));
 #define obj_app_file c_dot_file_symbol
 extern void obj_extra_stuff PARAMS ((object_headers * headers));
 
-extern segT s_get_segment PARAMS ((struct symbol * ptr));
+extern segT s_get_segment PARAMS ((symbolS *ptr));
 
 extern void c_section_header PARAMS ((struct internal_scnhdr * header,
                                      char *name,
@@ -763,7 +813,7 @@ extern void c_section_header PARAMS ((struct internal_scnhdr * header,
                                      long alignment));
 
 #ifndef tc_coff_symbol_emit_hook
-void tc_coff_symbol_emit_hook PARAMS ((struct symbol *));
+void tc_coff_symbol_emit_hook PARAMS ((symbolS *));
 #endif
 
 /* sanity check */
@@ -789,6 +839,24 @@ extern void obj_coff_pe_handle_link_once ();
 
 #endif /* not BFD_ASSEMBLER */
 
+extern const pseudo_typeS coff_pseudo_table[];
+
+#ifndef obj_pop_insert
+#define obj_pop_insert() pop_insert (coff_pseudo_table)
+#endif
+
+/* In COFF, if a symbol is defined using .def/.val SYM/.endef, it's OK
+   to redefine the symbol later on.  This can happen if C symbols use
+   a prefix, and a symbol is defined both with and without the prefix,
+   as in start/_start/__start in gcc/libgcc1-test.c.  */
+#define RESOLVE_SYMBOL_REDEFINITION(sym)               \
+(SF_GET_GET_SEGMENT (sym)                              \
+ ? (sym->sy_frag = frag_now,                           \
+    S_SET_VALUE (sym, frag_now_fix ()),                        \
+    S_SET_SEGMENT (sym, now_seg),                      \
+    0)                                                 \
+ : 0)
+
 /* Stabs in a coff file go into their own section.  */
 #define SEPARATE_STAB_SECTIONS 1
 
@@ -797,4 +865,8 @@ extern void obj_coff_pe_handle_link_once ();
 extern void obj_coff_init_stab_section PARAMS ((segT));
 #define INIT_STAB_SECTION(seg) obj_coff_init_stab_section (seg)
 
+/* Store the number of relocations in the section aux entry.  */
+#define SET_SECTION_RELOCS(sec, relocs, n) \
+  SA_SET_SCN_NRELOC (section_symbol (sec), n)
+
 #endif /* OBJ_FORMAT_H */
This page took 0.029367 seconds and 4 git commands to generate.