gas reloc rewrite.
[deliverable/binutils-gdb.git] / gas / config / obj-coff.h
index 351fdb46824834e4ebcb3b7f0678c94a39e55f63..e90dd70f0418fbd6a54034c210d3b263576b5356 100644 (file)
@@ -1,5 +1,6 @@
 /* coff object file format
-   Copyright (C) 1989, 90, 91, 92, 94, 95, 96, 97, 1998
+   Copyright 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
+   1999, 2000, 2002
    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
 #define TARGET_FORMAT "coff-a29k-big"
 #endif
 
+#ifdef TC_OR32
+#include "coff/or32.h"
+#define TARGET_FORMAT "coff-or32-big"
+#endif
+
 #ifdef TC_I960
 #include "coff/i960.h"
 #define TARGET_FORMAT "coff-Intel-little"
 #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                                                 \
+  (!target_big_endian                                  \
    ? (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-tic30"
 #endif
 
-/* start-sanitize-tic80 */
+#ifdef TC_TIC4X
+#include "coff/tic4x.h"
+#define TARGET_FORMAT "coff2-c4x"
+#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));
 #define obj_read_begin_hook coff_obj_read_begin_hook
 
-/* ***********************************************************************
-
-   This file really contains two implementations of the COFF back end.
+/* This file really contains two implementations of the COFF back end.
    They are in the process of being merged, but this is only a
    preliminary, mechanical merging.  Many definitions that are
    identical between the two are still found in both versions.
@@ -191,9 +229,7 @@ extern void coff_obj_read_begin_hook PARAMS ((void));
    See doc/internals.texi for a brief discussion of the history, if
    you care.
 
-   Ken Raeburn, 5 May 1994
-
-   *********************************************************************** */
+   Ken Raeburn, 5 May 1994.  */
 
 #ifdef BFD_ASSEMBLER
 
@@ -206,36 +242,45 @@ 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_AUXINFO(S) (&coffsymbol ((S)->bsym)->native[1])
+/* We can't use the predefined section symbols in bfd/section.c, as
+   COFF symbols have extra fields.  See bfd/libcoff.h:coff_symbol_type.  */
+#ifndef obj_sec_sym_ok_for_reloc
+#define obj_sec_sym_ok_for_reloc(SEC)  ((SEC)->owner != 0)
+#endif
+
+#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)
-/* The number of auxiliary entries */
+/* The number of auxiliary entries.  */
+#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 */
-/* Accessors */
+/* Auxiliary entry macros. SA_ stands for symbol auxiliary */
+/* Omit the tv related fields */
+/* Accessors */
 
 #define SA_GET_SYM_TAGNDX(s)   (SYM_AUXENT (s)->x_sym.x_tagndx.l)
 #define SA_GET_SYM_LNNO(s)     (SYM_AUXENT (s)->x_sym.x_misc.x_lnsz.x_lnno)
@@ -259,23 +304,21 @@ extern void SA_SET_SYM_ENDNDX PARAMS ((struct symbol *, struct symbol *));
 #define SA_SET_SCN_NRELOC(s,v) (SYM_AUXENT (s)->x_scn.x_nreloc=(v))
 #define SA_SET_SCN_NLINNO(s,v) (SYM_AUXENT (s)->x_scn.x_nlinno=(v))
 
-/*
- * Internal use only definitions. SF_ stands for symbol flags.
- *
- * These values can be assigned to sy_symbol.ost_flags field of a symbolS.
- *
- * You'll break i960 if you shift the SYSPROC bits anywhere else.  for
- * more on the balname/callname hack, see tc-i960.h.  b.out is done
- * differently.
- */
-
-#define SF_I960_MASK   (0x000001ff)    /* Bits 0-8 are used by the i960 port. */
+/* Internal use only definitions. SF_ stands for symbol flags.
+
+   These values can be assigned to sy_symbol.ost_flags field of a symbolS.
+
+   You'll break i960 if you shift the SYSPROC bits anywhere else.  for
+   more on the balname/callname hack, see tc-i960.h.  b.out is done
+   differently.  */
+
+#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 */
@@ -289,13 +332,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)
+/* Accessors */
+#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)
@@ -314,9 +357,9 @@ extern void SA_SET_SYM_ENDNDX PARAMS ((struct symbol *, struct symbol *));
 #define SF_GET_IS_SYSPROC(s)   (SF_GET (s) & SF_IS_SYSPROC)    /* used by i960 */
 #define SF_GET_SYSPROC(s)      (SF_GET (s) & SF_SYSPROC)       /* used by i960 */
 
-/* Modifiers */
+/* 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)
@@ -341,26 +384,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) \
@@ -372,8 +417,9 @@ extern struct symbol *coff_last_function;
    ? (S_SET_SEGMENT (dest, S_GET_SEGMENT (src)), 0) \
    : 0)
 #endif
+#endif
 
-/* sanity check */
+/* Sanity check.  */
 
 #ifdef TC_I960
 #ifndef C_LEAFSTAT
@@ -383,8 +429,8 @@ hey ! Where is the C_LEAFSTAT definition ? i960 - coff support is depending on i
 
 #else /* not BFD_ASSEMBLER */
 
-#ifdef TC_A29K
-/* Allow translate from aout relocs to coff relocs */
+#if defined TC_A29K || defined TC_OR32
+/* Allow translate from aout relocs to coff relocs */
 #define NO_RELOC 20
 #define RELOC_32 1
 #define RELOC_8 2
@@ -401,32 +447,30 @@ 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 */
+/* Symbol table entry data type */
 
 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 */
+  /* obj_coff internal use only flags */
   unsigned int ost_flags;
 } obj_symbol_type;
 
 #ifndef DO_NOT_STRIP
 #define DO_NOT_STRIP   0
 #endif
-/* Symbol table macros and constants */
+/* Symbol table macros and constants */
 
 /* Possible and usefull section number in symbol table
- * The values of TEXT, DATA and BSS may not be portable.
- */
+   The values of TEXT, DATA and BSS may not be portable.  */
 
 #define C_ABS_SECTION          N_ABS
 #define C_UNDEF_SECTION                N_UNDEF
@@ -435,27 +479,36 @@ typedef struct
 #define C_PTV_SECTION          P_TV
 #define C_REGISTER_SECTION     50
 
-/*
- *  Macros to extract information from a symbol table entry.
- *  This syntaxic indirection allows independence regarding a.out or coff.
- *  The argument (s) of all these macros is a pointer to a symbol table entry.
- */
+/* Macros to extract information from a symbol table entry.
+   This syntaxic indirection allows independence regarding a.out or coff.
+   The argument (s) of all these macros is a pointer to a symbol table entry.  */
+
+/* Predicates.  */
+/* True if the symbol is external.  */
+#define S_IS_EXTERNAL(s)  \
+  ((s)->sy_symbol.ost_entry.n_scnum == C_UNDEF_SECTION)
 
-/* Predicates */
-/* True if the symbol is external */
-#define S_IS_EXTERNAL(s)        ((s)->sy_symbol.ost_entry.n_scnum == C_UNDEF_SECTION)
 /* True if symbol has been defined, ie :
    section > 0 (DATA, TEXT or BSS)
-   section == 0 and value > 0 (external bss symbol) */
+   section == 0 and value > 0 (external bss symbol) */
 #define S_IS_DEFINED(s) \
   ((s)->sy_symbol.ost_entry.n_scnum > C_UNDEF_SECTION \
    || ((s)->sy_symbol.ost_entry.n_scnum == C_UNDEF_SECTION \
        && S_GET_VALUE (s) > 0) \
    || ((s)->sy_symbol.ost_entry.n_scnum == C_ABS_SECTION))
-/* True if a debug special symbol entry */
-#define S_IS_DEBUG(s)          ((s)->sy_symbol.ost_entry.n_scnum == C_DEBUG_SECTION)
-/* True if a symbol is local symbol name */
-/* A symbol name whose name includes ^A is a gas internal pseudo symbol */
+
+/* Return true for symbols that should not be reduced to section
+   symbols or eliminated from expressions, because they may be
+   overridden by the linker.  */
+#define S_FORCE_RELOC(s) \
+  (!SEG_NORMAL (S_GET_SEGMENT (s)) || S_IS_WEAK (s))
+
+/* True if a debug special symbol entry.  */
+#define S_IS_DEBUG(s) \
+  ((s)->sy_symbol.ost_entry.n_scnum == C_DEBUG_SECTION)
+
+/* True if a symbol is local symbol name.  */
+/* A symbol name whose name includes ^A is a gas internal pseudo symbol.  */
 #define S_IS_LOCAL(s) \
   ((s)->sy_symbol.ost_entry.n_scnum == C_REGISTER_SECTION \
    || (S_LOCAL_NAME(s) && ! flag_keep_locals && ! S_IS_DEBUG (s)) \
@@ -464,53 +517,81 @@ typedef struct
    || (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 */
+
+/* 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)
-/*
- * True if a symbol can be multiply defined (bss symbols have this def
- * though it is bad practice)
- */
+
+/* True if a symbol can be multiply defined (bss symbols have this def
+   though it is bad practice).  */
 #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)
 
-/* Accessors */
-/* The name of the symbol */
-#define S_GET_NAME(s)          ((char*)(s)->sy_symbol.ost_entry.n_offset)
-/* The pointer to the string table */
+/* 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)
+
+/* The pointer to the string table.  */
 #define S_GET_OFFSET(s)         ((s)->sy_symbol.ost_entry.n_offset)
-/* The numeric value of the segment */
+
+/* The numeric value of the segment.  */
 #define S_GET_SEGMENT(s)   s_get_segment(s)
-/* The data type */
+
+/* The data type.  */
 #define S_GET_DATA_TYPE(s)     ((s)->sy_symbol.ost_entry.n_type)
-/* The storage class */
+
+/* The storage class.  */
 #define S_GET_STORAGE_CLASS(s) ((s)->sy_symbol.ost_entry.n_sclass)
-/* The number of auxiliary entries */
+
+/* The number of auxiliary entries.  */
 #define S_GET_NUMBER_AUXILIARY(s)      ((s)->sy_symbol.ost_entry.n_numaux)
 
-/* Modifiers */
-/* Set the name of the symbol */
-#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 */
-#define S_SET_SEGMENT(s,v)     ((s)->sy_symbol.ost_entry.n_scnum = SEGMENT_TO_SYMBOL_TYPE(v))
-/* The data type */
-#define S_SET_DATA_TYPE(s,v)   ((s)->sy_symbol.ost_entry.n_type = (v))
-/* The storage class */
-#define S_SET_STORAGE_CLASS(s,v)       ((s)->sy_symbol.ost_entry.n_sclass = (v))
-/* The number of auxiliary entries */
-#define S_SET_NUMBER_AUXILIARY(s,v)    ((s)->sy_symbol.ost_entry.n_numaux = (v))
-
-/* Additional modifiers */
-/* The symbol is external (does not mean undefined) */
-#define S_SET_EXTERNAL(s)       { S_SET_STORAGE_CLASS(s, C_EXT) ; SF_CLEAR_LOCAL(s); }
-
-/* Auxiliary entry macros. SA_ stands for symbol auxiliary */
-/* Omit the tv related fields */
-/* Accessors */
+/* Modifiers.  */
+/* Set the name of the symbol.  */
+#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.  */
+#define S_SET_SEGMENT(s,v) \
+  ((s)->sy_symbol.ost_entry.n_scnum = SEGMENT_TO_SYMBOL_TYPE(v))
+
+/* The data type.  */
+#define S_SET_DATA_TYPE(s,v) \
+  ((s)->sy_symbol.ost_entry.n_type = (v))
+
+/* The storage class.  */
+#define S_SET_STORAGE_CLASS(s,v) \
+  ((s)->sy_symbol.ost_entry.n_sclass = (v))
+
+/* The number of auxiliary entries.  */
+#define S_SET_NUMBER_AUXILIARY(s,v) \
+  ((s)->sy_symbol.ost_entry.n_numaux = (v))
+
+/* Additional modifiers.  */
+/* The symbol is external (does not mean undefined).  */
+#define S_SET_EXTERNAL(s) \
+  { S_SET_STORAGE_CLASS(s, C_EXT) ; SF_CLEAR_LOCAL(s); }
+
+/* Auxiliary entry macros. SA_ stands for symbol auxiliary.  */
+/* Omit the tv related fields.  */
+/* Accessors.  */
 #define SYM_AUXENT(S)  (&(S)->sy_symbol.ost_auxent[0])
 
 #define SA_GET_SYM_TAGNDX(s)   (SYM_AUXENT (s)->x_sym.x_tagndx.l)
@@ -527,7 +608,7 @@ typedef struct
 #define SA_GET_SCN_NRELOC(s)   (SYM_AUXENT (s)->x_scn.x_nreloc)
 #define SA_GET_SCN_NLINNO(s)   (SYM_AUXENT (s)->x_scn.x_nlinno)
 
-/* Modifiers */
+/* Modifiers */
 #define SA_SET_SYM_TAGNDX(s,v) (SYM_AUXENT (s)->x_sym.x_tagndx.l=(v))
 #define SA_SET_SYM_LNNO(s,v)   (SYM_AUXENT (s)->x_sym.x_misc.x_lnsz.x_lnno=(v))
 #define SA_SET_SYM_SIZE(s,v)   (SYM_AUXENT (s)->x_sym.x_misc.x_lnsz.x_size=(v))
@@ -542,23 +623,21 @@ typedef struct
 #define SA_SET_SCN_NRELOC(s,v) (SYM_AUXENT (s)->x_scn.x_nreloc=(v))
 #define SA_SET_SCN_NLINNO(s,v) (SYM_AUXENT (s)->x_scn.x_nlinno=(v))
 
-/*
- * Internal use only definitions. SF_ stands for symbol flags.
- *
- * These values can be assigned to sy_symbol.ost_flags field of a symbolS.
- *
- * You'll break i960 if you shift the SYSPROC bits anywhere else.  for
- * more on the balname/callname hack, see tc-i960.h.  b.out is done
- * differently.
- */
-
-#define SF_I960_MASK   (0x000001ff)    /* Bits 0-8 are used by the i960 port. */
+/* Internal use only definitions. SF_ stands for symbol flags.
+
+   These values can be assigned to sy_symbol.ost_flags field of a symbolS.
+
+   You'll break i960 if you shift the SYSPROC bits anywhere else.  for
+   more on the balname/callname hack, see tc-i960.h.  b.out is done
+   differently.  */
+
+#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 */
@@ -572,11 +651,11 @@ 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 */
+/* Accessors */
 #define SF_GET(s)              ((s)->sy_symbol.ost_flags)
 #define SF_GET_NORMAL_FIELD(s) (SF_GET (s) & SF_NORMAL_MASK)
 #define SF_GET_DEBUG_FIELD(s)  (SF_GET (s) & SF_DEBUG_MASK)
@@ -598,9 +677,9 @@ typedef struct
 #define SF_GET_IS_SYSPROC(s)   (SF_GET (s) & SF_IS_SYSPROC)    /* used by i960 */
 #define SF_GET_SYSPROC(s)      (SF_GET (s) & SF_SYSPROC)       /* used by i960 */
 
-/* Modifiers */
+/* 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)
@@ -621,12 +700,10 @@ typedef struct
 #define SF_SET_IS_SYSPROC(s)   (SF_GET (s) |= SF_IS_SYSPROC)   /* used by i960 */
 #define SF_SET_SYSPROC(s,v)    (SF_GET (s) |= ((v) & SF_SYSPROC))      /* used by i960 */
 
-/* File header macro and type definition */
+/* File header macro and type definition */
 
-/*
- * File position calculators. Beware to use them when all the
- * appropriate fields are set in the header.
- */
+/* File position calculators. Beware to use them when all the
+   appropriate fields are set in the header.  */
 
 #ifdef OBJ_COFF_OMIT_OPTIONAL_HEADER
 #define OBJ_COFF_AOUTHDRSZ (0)
@@ -635,37 +712,37 @@ 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))
 
-/* Accessors */
-/* aouthdr */
+/* Accessors */
+/* aouthdr */
 #define H_GET_MAGIC_NUMBER(h)           ((h)->aouthdr.magic)
 #define H_GET_VERSION_STAMP(h)         ((h)->aouthdr.vstamp)
 #define H_GET_TEXT_SIZE(h)              ((h)->aouthdr.tsize)
@@ -674,7 +751,7 @@ typedef struct
 #define H_GET_ENTRY_POINT(h)            ((h)->aouthdr.entry)
 #define H_GET_TEXT_START(h)            ((h)->aouthdr.text_start)
 #define H_GET_DATA_START(h)            ((h)->aouthdr.data_start)
-/* filehdr */
+/* filehdr */
 #define H_GET_FILE_MAGIC_NUMBER(h)     ((h)->filehdr.f_magic)
 #define H_GET_NUMBER_OF_SECTIONS(h)    ((h)->filehdr.f_nscns)
 #define H_GET_TIME_STAMP(h)            ((h)->filehdr.f_timdat)
@@ -683,25 +760,25 @@ typedef struct
 #define H_GET_SYMBOL_TABLE_SIZE(h)     (H_GET_SYMBOL_COUNT(h) * SYMESZ)
 #define H_GET_SIZEOF_OPTIONAL_HEADER(h)        ((h)->filehdr.f_opthdr)
 #define H_GET_FLAGS(h)                 ((h)->filehdr.f_flags)
-/* Extra fields to achieve bsd a.out compatibility and for convenience */
+/* Extra fields to achieve bsd a.out compatibility and for convenience */
 #define H_GET_RELOCATION_SIZE(h)       ((h)->relocation_size)
 #define H_GET_STRING_SIZE(h)            ((h)->string_table_size)
 #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 */
 
 #define H_GET_TEXT_RELOCATION_SIZE(h)  (text_section_header.s_nreloc * RELSZ)
 #define H_GET_DATA_RELOCATION_SIZE(h)  (data_section_header.s_nreloc * RELSZ)
 
-/* Modifiers */
-/* aouthdr */
+/* Modifiers */
+/* aouthdr */
 #define H_SET_MAGIC_NUMBER(h,v)         ((h)->aouthdr.magic = (v))
 #define H_SET_VERSION_STAMP(h,v)       ((h)->aouthdr.vstamp = (v))
 #define H_SET_TEXT_SIZE(h,v)            ((h)->aouthdr.tsize = (v))
@@ -710,7 +787,7 @@ typedef struct
 #define H_SET_ENTRY_POINT(h,v)          ((h)->aouthdr.entry = (v))
 #define H_SET_TEXT_START(h,v)          ((h)->aouthdr.text_start = (v))
 #define H_SET_DATA_START(h,v)          ((h)->aouthdr.data_start = (v))
-/* filehdr */
+/* filehdr */
 #define H_SET_FILE_MAGIC_NUMBER(h,v)   ((h)->filehdr.f_magic = (v))
 #define H_SET_NUMBER_OF_SECTIONS(h,v)  ((h)->filehdr.f_nscns = (v))
 #define H_SET_TIME_STAMP(h,v)          ((h)->filehdr.f_timdat = (v))
@@ -718,37 +795,32 @@ typedef struct
 #define H_SET_SYMBOL_TABLE_SIZE(h,v)    ((h)->filehdr.f_nsyms = (v))
 #define H_SET_SIZEOF_OPTIONAL_HEADER(h,v) ((h)->filehdr.f_opthdr = (v))
 #define H_SET_FLAGS(h,v)               ((h)->filehdr.f_flags = (v))
-/* Extra fields to achieve bsd a.out compatibility and for convinience */
+/* Extra fields to achieve bsd a.out compatibility and for convinience */
 #define H_SET_RELOCATION_SIZE(h,t,d)   ((h)->relocation_size = (t)+(d))
 #define H_SET_STRING_SIZE(h,v)          ((h)->string_table_size = (v))
 #define H_SET_LINENO_SIZE(h,v)          ((h)->lineno_size = (v))
 
-/* Segment flipping */
+/* Segment flipping */
 
 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) */
-  long relocation_size;        /* Cumulated size of relocation
-                          information for all sections in
-                          bytes. */
-  long lineno_size;            /* Size of the line number information
-                                  table in bytes */
+  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.  */
+  long lineno_size;                    /* Size of the line number information
+                                          table in bytes.  */
 } object_headers;
 
-
-
 struct lineno_list
 {
   struct bfd_internal_lineno line;
-  char *frag;                  /* Frag to which the line number is related */
-  struct lineno_list *next;    /* Forward chain pointer */
+  char *frag;                  /* Frag to which the line number is related */
+  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)
@@ -761,7 +833,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,
@@ -775,10 +847,10 @@ 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 */
+/* Sanity check.  */
 
 #ifdef TC_I960
 #ifndef C_LEAFSTAT
@@ -801,6 +873,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,
@@ -821,4 +899,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.038489 seconds and 4 git commands to generate.