* config/tc-s390.c (s390_elf_cons): Correct fixups for PLT
[deliverable/binutils-gdb.git] / gas / config / obj-coff.h
index a8799a318e31590ddbeac7bb5ea08dc98dc3eb0c..f862f7725ea1c3a13be2c23ab32442b293a52d58 100644 (file)
@@ -1,5 +1,6 @@
 /* coff object file format
-   Copyright (C) 1989, 90, 91, 92, 94, 95, 96, 97, 98, 1999
+   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"
+
+#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
 #include "coff/m88k.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"
@@ -233,7 +256,7 @@ extern void obj_coff_section PARAMS ((int));
 /* 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 ((symbolS *, int));
@@ -277,13 +300,13 @@ extern void SA_SET_SYM_ENDNDX PARAMS ((symbolS *, symbolS *));
  * 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 */
@@ -297,8 +320,8 @@ extern void SA_SET_SYM_ENDNDX PARAMS ((symbolS *, symbolS *));
 #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)              (*symbol_get_obj (s))
@@ -324,7 +347,7 @@ extern void SA_SET_SYM_ENDNDX PARAMS ((symbolS *, symbolS *));
 
 /* 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)
@@ -351,8 +374,7 @@ extern int coff_n_line_nos;
 #define obj_emit_lineno(WHERE,LINE,FILE_START) abort ()
 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 ((symbolS *, int *));
@@ -371,6 +393,7 @@ 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) \
@@ -382,6 +405,7 @@ extern symbolS *coff_last_function;
    ? (S_SET_SEGMENT (dest, S_GET_SEGMENT (src)), 0) \
    : 0)
 #endif
+#endif
 
 /* sanity check */
 
@@ -411,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 */
@@ -423,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;
@@ -483,7 +506,7 @@ 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.  */
@@ -498,7 +521,7 @@ typedef struct
 
 /* 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 */
@@ -512,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 */
@@ -572,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 */
@@ -592,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)
@@ -620,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)
@@ -655,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))
@@ -709,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 */
 
@@ -748,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;
@@ -766,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)
@@ -821,6 +839,12 @@ 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,
@@ -841,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.027468 seconds and 4 git commands to generate.