Home | History | Annotate | Line # | Download | only in sparc64
bfd.h revision 1.8
      1 /* This file is automatically generated.  DO NOT EDIT! */
      2 /* Generated from: NetBSD: mknative-binutils,v 1.14 2022/12/24 20:17:46 christos Exp  */
      3 /* Generated from: NetBSD: mknative.common,v 1.16 2018/04/15 15:13:37 christos Exp  */
      4 
      5 /* DO NOT EDIT!  -*- buffer-read-only: t -*-  This file is automatically
      6    generated from "bfd-in.h", "init.c", "opncls.c", "libbfd.c",
      7    "bfdio.c", "bfdwin.c", "section.c", "archures.c", "reloc.c",
      8    "syms.c", "bfd.c", "archive.c", "corefile.c", "targets.c", "format.c",
      9    "linker.c", "simple.c" and "compress.c".
     10    Run "make headers" in your build bfd/ to regenerate.  */
     11 
     12 /* Main header file for the bfd library -- portable access to object files.
     13 
     14    Copyright (C) 1990-2022 Free Software Foundation, Inc.
     15 
     16    Contributed by Cygnus Support.
     17 
     18    This file is part of BFD, the Binary File Descriptor library.
     19 
     20    This program is free software; you can redistribute it and/or modify
     21    it under the terms of the GNU General Public License as published by
     22    the Free Software Foundation; either version 3 of the License, or
     23    (at your option) any later version.
     24 
     25    This program is distributed in the hope that it will be useful,
     26    but WITHOUT ANY WARRANTY; without even the implied warranty of
     27    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     28    GNU General Public License for more details.
     29 
     30    You should have received a copy of the GNU General Public License
     31    along with this program; if not, write to the Free Software
     32    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.  */
     33 
     34 #ifndef __BFD_H_SEEN__
     35 #define __BFD_H_SEEN__
     36 
     37 /* PR 14072: Ensure that config.h is included first.  */
     38 #if !defined PACKAGE && !defined PACKAGE_VERSION
     39 #error config.h must be included before this header
     40 #endif
     41 
     42 #ifdef __cplusplus
     43 extern "C" {
     44 #endif
     45 
     46 #include "ansidecl.h"
     47 #include "symcat.h"
     48 #include <stdint.h>
     49 #include <stdbool.h>
     50 #include "diagnostics.h"
     51 #include <stdarg.h>
     52 #include <string.h>
     53 #include <sys/stat.h>
     54 
     55 #if defined (__STDC__) || defined (ALMOST_STDC) || defined (HAVE_STRINGIZE)
     56 #ifndef SABER
     57 /* This hack is to avoid a problem with some strict ANSI C preprocessors.
     58    The problem is, "32_" is not a valid preprocessing token, and we don't
     59    want extra underscores (e.g., "nlm_32_").  The XCONCAT2 macro will
     60    cause the inner CONCAT2 macros to be evaluated first, producing
     61    still-valid pp-tokens.  Then the final concatenation can be done.  */
     62 #undef CONCAT4
     63 #define CONCAT4(a,b,c,d) XCONCAT2(CONCAT2(a,b),CONCAT2(c,d))
     64 #endif
     65 #endif
     66 
     67 /* This is a utility macro to handle the situation where the code
     68    wants to place a constant string into the code, followed by a
     69    comma and then the length of the string.  Doing this by hand
     70    is error prone, so using this macro is safer.  */
     71 #define STRING_COMMA_LEN(STR) (STR), (sizeof (STR) - 1)
     72 
     73 #define BFD_SUPPORTS_PLUGINS 1
     74 
     75 /* The word size used by BFD on the host.  This may be 64 with a 32
     76    bit target if the host is 64 bit, or if other 64 bit targets have
     77    been selected with --enable-targets, or if --enable-64-bit-bfd.  */
     78 #define BFD_ARCH_SIZE 64
     79 
     80 /* The word size of the default bfd target.  */
     81 #define BFD_DEFAULT_TARGET_SIZE 64
     82 
     83 #include <inttypes.h>
     84 
     85 #if BFD_ARCH_SIZE >= 64
     86 #define BFD64
     87 #endif
     88 
     89 /* Forward declaration.  */
     90 typedef struct bfd bfd;
     91 
     92 /* Boolean type used in bfd.
     93    General rule: Functions which are bfd_boolean return TRUE on
     94    success and FALSE on failure (unless they're a predicate).  */
     95 
     96 #ifdef POISON_BFD_BOOLEAN
     97 # pragma GCC poison bfd_boolean
     98 #else
     99 # define bfd_boolean bool
    100 # undef FALSE
    101 # undef TRUE
    102 # define FALSE 0
    103 # define TRUE 1
    104 #endif
    105 
    106 /* Silence "applying zero offset to null pointer" UBSAN warnings.  */
    107 #define PTR_ADD(P,A) ((A) != 0 ? (P) + (A) : (P))
    108 /* Also prevent non-zero offsets from being applied to a null pointer.  */
    109 #define NPTR_ADD(P,A) ((P) != NULL ? (P) + (A) : (P))
    110 
    111 #ifdef BFD64
    112 
    113 /* Represent a target address.  Also used as a generic unsigned type
    114    which is guaranteed to be big enough to hold any arithmetic types
    115    we need to deal with.  */
    116 typedef uint64_t bfd_vma;
    117 
    118 /* A generic signed type which is guaranteed to be big enough to hold any
    119    arithmetic types we need to deal with.  Can be assumed to be compatible
    120    with bfd_vma in the same way that signed and unsigned ints are compatible
    121    (as parameters, in assignment, etc).  */
    122 typedef int64_t bfd_signed_vma;
    123 
    124 typedef uint64_t bfd_size_type;
    125 typedef uint64_t symvalue;
    126 
    127 #define BFD_VMA_FMT "l"
    128 
    129 #define fprintf_vma(f,x) fprintf (f, "%016" BFD_VMA_FMT "x", x)
    130 #define sprintf_vma(s,x) sprintf (s, "%016" BFD_VMA_FMT "x", x)
    131 
    132 #else /* not BFD64  */
    133 
    134 typedef unsigned long bfd_vma;
    135 typedef long bfd_signed_vma;
    136 typedef unsigned long symvalue;
    137 typedef unsigned long bfd_size_type;
    138 
    139 #define BFD_VMA_FMT "l"
    140 
    141 #define fprintf_vma(s,x) fprintf (s, "%08" BFD_VMA_FMT "x", x)
    142 #define sprintf_vma(s,x) sprintf (s, "%08" BFD_VMA_FMT "x", x)
    143 
    144 #endif /* not BFD64  */
    145 
    146 #define HALF_BFD_SIZE_TYPE \
    147   (((bfd_size_type) 1) << (8 * sizeof (bfd_size_type) / 2))
    148 
    149 /* An offset into a file.  BFD always uses the largest possible offset
    150    based on the build time availability of fseek, fseeko, or fseeko64.  */
    151 typedef int64_t file_ptr;
    152 typedef uint64_t ufile_ptr;
    153 
    154 extern void bfd_sprintf_vma (bfd *, char *, bfd_vma);
    155 extern void bfd_fprintf_vma (bfd *, void *, bfd_vma);
    156 
    157 #define printf_vma(x) fprintf_vma(stdout,x)
    158 #define bfd_printf_vma(abfd,x) bfd_fprintf_vma (abfd,stdout,x)
    159 
    160 typedef unsigned int flagword;	/* 32 bits of flags */
    161 typedef unsigned char bfd_byte;
    162 
    163 /* File formats.  */
    165 
    166 typedef enum bfd_format
    167 {
    168   bfd_unknown = 0,	/* File format is unknown.  */
    169   bfd_object,		/* Linker/assembler/compiler output.  */
    170   bfd_archive,		/* Object archive file.  */
    171   bfd_core,		/* Core dump.  */
    172   bfd_type_end		/* Marks the end; don't use it!  */
    173 }
    174 bfd_format;
    175 
    176 /* Symbols and relocation.  */
    178 
    179 /* A count of carsyms (canonical archive symbols).  */
    180 typedef unsigned long symindex;
    181 
    182 #define BFD_NO_MORE_SYMBOLS ((symindex) ~0)
    183 
    184 /* A canonical archive symbol.  */
    185 /* This is a type pun with struct ranlib on purpose!  */
    186 typedef struct carsym
    187 {
    188   const char *name;
    189   file_ptr file_offset;	/* Look here to find the file.  */
    190 }
    191 carsym;			/* To make these you call a carsymogen.  */
    192 
    193 /* Used in generating armaps (archive tables of contents).
    194    Perhaps just a forward definition would do?  */
    195 struct orl		/* Output ranlib.  */
    196 {
    197   char **name;		/* Symbol name.  */
    198   union
    199   {
    200     file_ptr pos;
    201     bfd *abfd;
    202   } u;			/* bfd* or file position.  */
    203   int namidx;		/* Index into string table.  */
    204 };
    205 
    206 /* Linenumber stuff.  */
    207 typedef struct lineno_cache_entry
    208 {
    209   unsigned int line_number;	/* Linenumber from start of function.  */
    210   union
    211   {
    212     struct bfd_symbol *sym;	/* Function name.  */
    213     bfd_vma offset;		/* Offset into section.  */
    214   } u;
    215 }
    216 alent;
    217 
    218 /* Object and core file sections.  */
    220 typedef struct bfd_section *sec_ptr;
    221 
    222 #define	align_power(addr, align)	\
    223   (((addr) + ((bfd_vma) 1 << (align)) - 1) & (-((bfd_vma) 1 << (align))))
    224 
    225 /* Align an address upward to a boundary, expressed as a number of bytes.
    226    E.g. align to an 8-byte boundary with argument of 8.  Take care never
    227    to wrap around if the address is within boundary-1 of the end of the
    228    address space.  */
    229 #define BFD_ALIGN(this, boundary)					  \
    230   ((((bfd_vma) (this) + (boundary) - 1) >= (bfd_vma) (this))		  \
    231    ? (((bfd_vma) (this) + ((boundary) - 1)) & ~ (bfd_vma) ((boundary)-1)) \
    232    : ~ (bfd_vma) 0)
    233 
    234 typedef enum bfd_print_symbol
    236 {
    237   bfd_print_symbol_name,
    238   bfd_print_symbol_more,
    239   bfd_print_symbol_all
    240 } bfd_print_symbol_type;
    241 
    242 /* Information about a symbol that nm needs.  */
    243 
    244 typedef struct _symbol_info
    245 {
    246   symvalue value;
    247   char type;
    248   const char *name;		/* Symbol name.  */
    249   unsigned char stab_type;	/* Stab type.  */
    250   char stab_other;		/* Stab other.  */
    251   short stab_desc;		/* Stab desc.  */
    252   const char *stab_name;	/* String for stab type.  */
    253 } symbol_info;
    254 
    255 /* Get the name of a stabs type code.  */
    256 
    257 extern const char *bfd_get_stab_name (int);
    258 
    259 /* Hash table routines.  There is no way to free up a hash table.  */
    261 
    262 /* An element in the hash table.  Most uses will actually use a larger
    263    structure, and an instance of this will be the first field.  */
    264 
    265 struct bfd_hash_entry
    266 {
    267   /* Next entry for this hash code.  */
    268   struct bfd_hash_entry *next;
    269   /* String being hashed.  */
    270   const char *string;
    271   /* Hash code.  This is the full hash code, not the index into the
    272      table.  */
    273   unsigned long hash;
    274 };
    275 
    276 /* A hash table.  */
    277 
    278 struct bfd_hash_table
    279 {
    280   /* The hash array.  */
    281   struct bfd_hash_entry **table;
    282   /* A function used to create new elements in the hash table.  The
    283      first entry is itself a pointer to an element.  When this
    284      function is first invoked, this pointer will be NULL.  However,
    285      having the pointer permits a hierarchy of method functions to be
    286      built each of which calls the function in the superclass.  Thus
    287      each function should be written to allocate a new block of memory
    288      only if the argument is NULL.  */
    289   struct bfd_hash_entry *(*newfunc)
    290     (struct bfd_hash_entry *, struct bfd_hash_table *, const char *);
    291   /* An objalloc for this hash table.  This is a struct objalloc *,
    292      but we use void * to avoid requiring the inclusion of objalloc.h.  */
    293   void *memory;
    294   /* The number of slots in the hash table.  */
    295   unsigned int size;
    296   /* The number of entries in the hash table.  */
    297   unsigned int count;
    298   /* The size of elements.  */
    299   unsigned int entsize;
    300   /* If non-zero, don't grow the hash table.  */
    301   unsigned int frozen:1;
    302 };
    303 
    304 /* Initialize a hash table.  */
    305 extern bool bfd_hash_table_init
    306   (struct bfd_hash_table *,
    307    struct bfd_hash_entry *(*) (struct bfd_hash_entry *,
    308 			       struct bfd_hash_table *,
    309 			       const char *),
    310    unsigned int);
    311 
    312 /* Initialize a hash table specifying a size.  */
    313 extern bool bfd_hash_table_init_n
    314   (struct bfd_hash_table *,
    315    struct bfd_hash_entry *(*) (struct bfd_hash_entry *,
    316 			       struct bfd_hash_table *,
    317 			       const char *),
    318    unsigned int, unsigned int);
    319 
    320 /* Free up a hash table.  */
    321 extern void bfd_hash_table_free
    322   (struct bfd_hash_table *);
    323 
    324 /* Look up a string in a hash table.  If CREATE is TRUE, a new entry
    325    will be created for this string if one does not already exist.  The
    326    COPY argument must be TRUE if this routine should copy the string
    327    into newly allocated memory when adding an entry.  */
    328 extern struct bfd_hash_entry *bfd_hash_lookup
    329   (struct bfd_hash_table *, const char *, bool create, bool copy);
    330 
    331 /* Insert an entry in a hash table.  */
    332 extern struct bfd_hash_entry *bfd_hash_insert
    333   (struct bfd_hash_table *, const char *, unsigned long);
    334 
    335 /* Rename an entry in a hash table.  */
    336 extern void bfd_hash_rename
    337   (struct bfd_hash_table *, const char *, struct bfd_hash_entry *);
    338 
    339 /* Replace an entry in a hash table.  */
    340 extern void bfd_hash_replace
    341   (struct bfd_hash_table *, struct bfd_hash_entry *old,
    342    struct bfd_hash_entry *nw);
    343 
    344 /* Base method for creating a hash table entry.  */
    345 extern struct bfd_hash_entry *bfd_hash_newfunc
    346   (struct bfd_hash_entry *, struct bfd_hash_table *, const char *);
    347 
    348 /* Grab some space for a hash table entry.  */
    349 extern void *bfd_hash_allocate
    350   (struct bfd_hash_table *, unsigned int);
    351 
    352 /* Traverse a hash table in a random order, calling a function on each
    353    element.  If the function returns FALSE, the traversal stops.  The
    354    INFO argument is passed to the function.  */
    355 extern void bfd_hash_traverse
    356   (struct bfd_hash_table *,
    357    bool (*) (struct bfd_hash_entry *, void *),
    358    void *info);
    359 
    360 /* Allows the default size of a hash table to be configured. New hash
    361    tables allocated using bfd_hash_table_init will be created with
    362    this size.  */
    363 extern unsigned long bfd_hash_set_default_size (unsigned long);
    364 
    365 /* Types of compressed DWARF debug sections.  We currently support
    366    zlib.  */
    367 enum compressed_debug_section_type
    368 {
    369   COMPRESS_DEBUG_NONE = 0,
    370   COMPRESS_DEBUG = 1 << 0,
    371   COMPRESS_DEBUG_GNU_ZLIB = COMPRESS_DEBUG | 1 << 1,
    372   COMPRESS_DEBUG_GABI_ZLIB = COMPRESS_DEBUG | 1 << 2
    373 };
    374 
    375 /* This structure is used to keep track of stabs in sections
    376    information while linking.  */
    377 
    378 struct stab_info
    379 {
    380   /* A hash table used to hold stabs strings.  */
    381   struct bfd_strtab_hash *strings;
    382   /* The header file hash table.  */
    383   struct bfd_hash_table includes;
    384   /* The first .stabstr section.  */
    385   struct bfd_section *stabstr;
    386 };
    387 
    388 #define COFF_SWAP_TABLE (void *) &bfd_coff_std_swap_table
    389 
    390 /* User program access to BFD facilities.  */
    391 
    392 /* Direct I/O routines, for programs which know more about the object
    393    file than BFD does.  Use higher level routines if possible.  */
    394 
    395 extern bfd_size_type bfd_bread (void *, bfd_size_type, bfd *);
    396 extern bfd_size_type bfd_bwrite (const void *, bfd_size_type, bfd *);
    397 extern int bfd_seek (bfd *, file_ptr, int);
    398 extern file_ptr bfd_tell (bfd *);
    399 extern int bfd_flush (bfd *);
    400 extern int bfd_stat (bfd *, struct stat *);
    401 
    402 /* Deprecated old routines.  */
    403 #if __GNUC__
    404 #define bfd_read(BUF, ELTSIZE, NITEMS, ABFD)				\
    405   (_bfd_warn_deprecated ("bfd_read", __FILE__, __LINE__, __FUNCTION__),	\
    406    bfd_bread ((BUF), (ELTSIZE) * (NITEMS), (ABFD)))
    407 #define bfd_write(BUF, ELTSIZE, NITEMS, ABFD)				\
    408   (_bfd_warn_deprecated ("bfd_write", __FILE__, __LINE__, __FUNCTION__), \
    409    bfd_bwrite ((BUF), (ELTSIZE) * (NITEMS), (ABFD)))
    410 #else
    411 #define bfd_read(BUF, ELTSIZE, NITEMS, ABFD)				\
    412   (_bfd_warn_deprecated ("bfd_read", (const char *) 0, 0, (const char *) 0), \
    413    bfd_bread ((BUF), (ELTSIZE) * (NITEMS), (ABFD)))
    414 #define bfd_write(BUF, ELTSIZE, NITEMS, ABFD)				\
    415   (_bfd_warn_deprecated ("bfd_write", (const char *) 0, 0, (const char *) 0),\
    416    bfd_bwrite ((BUF), (ELTSIZE) * (NITEMS), (ABFD)))
    417 #endif
    418 extern void _bfd_warn_deprecated (const char *, const char *, int, const char *);
    419 
    420 extern bool bfd_cache_close
    421   (bfd *abfd);
    422 /* NB: This declaration should match the autogenerated one in libbfd.h.  */
    423 
    424 extern bool bfd_cache_close_all (void);
    425 
    426 extern bool bfd_record_phdr
    427   (bfd *, unsigned long, bool, flagword, bool, bfd_vma,
    428    bool, bool, unsigned int, struct bfd_section **);
    429 
    430 /* Byte swapping routines.  */
    431 
    432 uint64_t bfd_getb64 (const void *);
    433 uint64_t bfd_getl64 (const void *);
    434 int64_t bfd_getb_signed_64 (const void *);
    435 int64_t bfd_getl_signed_64 (const void *);
    436 bfd_vma bfd_getb32 (const void *);
    437 bfd_vma bfd_getl32 (const void *);
    438 bfd_signed_vma bfd_getb_signed_32 (const void *);
    439 bfd_signed_vma bfd_getl_signed_32 (const void *);
    440 bfd_vma bfd_getb16 (const void *);
    441 bfd_vma bfd_getl16 (const void *);
    442 bfd_signed_vma bfd_getb_signed_16 (const void *);
    443 bfd_signed_vma bfd_getl_signed_16 (const void *);
    444 void bfd_putb64 (uint64_t, void *);
    445 void bfd_putl64 (uint64_t, void *);
    446 void bfd_putb32 (bfd_vma, void *);
    447 void bfd_putl32 (bfd_vma, void *);
    448 void bfd_putb24 (bfd_vma, void *);
    449 void bfd_putl24 (bfd_vma, void *);
    450 void bfd_putb16 (bfd_vma, void *);
    451 void bfd_putl16 (bfd_vma, void *);
    452 
    453 /* Byte swapping routines which take size and endiannes as arguments.  */
    454 
    455 uint64_t bfd_get_bits (const void *, int, bool);
    456 void bfd_put_bits (uint64_t, void *, int, bool);
    457 
    458 
    459 /* mmap hacks */
    460 
    461 struct _bfd_window_internal;
    462 typedef struct _bfd_window_internal bfd_window_internal;
    463 
    464 typedef struct _bfd_window
    465 {
    466   /* What the user asked for.  */
    467   void *data;
    468   bfd_size_type size;
    469   /* The actual window used by BFD.  Small user-requested read-only
    470      regions sharing a page may share a single window into the object
    471      file.  Read-write versions shouldn't until I've fixed things to
    472      keep track of which portions have been claimed by the
    473      application; don't want to give the same region back when the
    474      application wants two writable copies!  */
    475   struct _bfd_window_internal *i;
    476 }
    477 bfd_window;
    478 
    479 extern void bfd_init_window
    480   (bfd_window *);
    481 extern void bfd_free_window
    482   (bfd_window *);
    483 extern bool bfd_get_file_window
    484   (bfd *, file_ptr, bfd_size_type, bfd_window *, bool);
    485 
    486 /* Externally visible ELF routines.  */
    488 
    489 /* Create a new BFD as if by bfd_openr.  Rather than opening a file,
    490    reconstruct an ELF file by reading the segments out of remote
    491    memory based on the ELF file header at EHDR_VMA and the ELF program
    492    headers it points to.  If non-zero, SIZE is the known extent of the
    493    object.  If not null, *LOADBASEP is filled in with the difference
    494    between the VMAs from which the segments were read, and the VMAs
    495    the file headers (and hence BFD's idea of each section's VMA) put
    496    them at.
    497 
    498    The function TARGET_READ_MEMORY is called to copy LEN bytes from
    499    the remote memory at target address VMA into the local buffer at
    500    MYADDR; it should return zero on success or an `errno' code on
    501    failure.  TEMPL must be a BFD for a target with the word size and
    502    byte order found in the remote memory.  */
    503 extern bfd *bfd_elf_bfd_from_remote_memory
    504   (bfd *templ, bfd_vma ehdr_vma, bfd_size_type size, bfd_vma *loadbasep,
    505    int (*target_read_memory) (bfd_vma vma, bfd_byte *myaddr,
    506 			      bfd_size_type len));
    507 
    508 /* Forward declarations.  */
    509 struct ecoff_debug_info;
    510 struct ecoff_debug_swap;
    511 struct ecoff_extr;
    512 struct bfd_link_info;
    513 struct bfd_link_hash_entry;
    514 
    515 /* Return TRUE if the start of STR matches PREFIX, FALSE otherwise.  */
    516 
    517 static inline bool
    518 startswith (const char *str, const char *prefix)
    519 {
    520   return strncmp (str, prefix, strlen (prefix)) == 0;
    521 }
    522 /* Extracted from init.c.  */
    523 unsigned int bfd_init (void);
    524 
    525 
    526 /* Value returned by bfd_init.  */
    527 
    528 #define BFD_INIT_MAGIC (sizeof (struct bfd_section))
    529 /* Extracted from opncls.c.  */
    530 /* Set to N to open the next N BFDs using an alternate id space.  */
    531 extern unsigned int bfd_use_reserved_id;
    532 bfd *bfd_fopen (const char *filename, const char *target,
    533     const char *mode, int fd);
    534 
    535 bfd *bfd_openr (const char *filename, const char *target);
    536 
    537 bfd *bfd_fdopenr (const char *filename, const char *target, int fd);
    538 
    539 bfd *bfd_fdopenw (const char *filename, const char *target, int fd);
    540 
    541 bfd *bfd_openstreamr (const char * filename, const char * target,
    542     void * stream);
    543 
    544 bfd *bfd_openr_iovec (const char *filename, const char *target,
    545     void *(*open_func) (struct bfd *nbfd,
    546     void *open_closure),
    547     void *open_closure,
    548     file_ptr (*pread_func) (struct bfd *nbfd,
    549     void *stream,
    550     void *buf,
    551     file_ptr nbytes,
    552     file_ptr offset),
    553     int (*close_func) (struct bfd *nbfd,
    554     void *stream),
    555     int (*stat_func) (struct bfd *abfd,
    556     void *stream,
    557     struct stat *sb));
    558 
    559 bfd *bfd_openw (const char *filename, const char *target);
    560 
    561 bool bfd_close (bfd *abfd);
    562 
    563 bool bfd_close_all_done (bfd *);
    564 
    565 bfd *bfd_create (const char *filename, bfd *templ);
    566 
    567 bool bfd_make_writable (bfd *abfd);
    568 
    569 bool bfd_make_readable (bfd *abfd);
    570 
    571 void *bfd_alloc (bfd *abfd, bfd_size_type wanted);
    572 
    573 void *bfd_zalloc (bfd *abfd, bfd_size_type wanted);
    574 
    575 unsigned long bfd_calc_gnu_debuglink_crc32
    576    (unsigned long crc, const unsigned char *buf, bfd_size_type len);
    577 
    578 char *bfd_get_debug_link_info (bfd *abfd, unsigned long *crc32_out);
    579 
    580 char *bfd_get_alt_debug_link_info (bfd * abfd,
    581     bfd_size_type *buildid_len,
    582     bfd_byte **buildid_out);
    583 
    584 char *bfd_follow_gnu_debuglink (bfd *abfd, const char *dir);
    585 
    586 char *bfd_follow_gnu_debugaltlink (bfd *abfd, const char *dir);
    587 
    588 struct bfd_section *bfd_create_gnu_debuglink_section
    589    (bfd *abfd, const char *filename);
    590 
    591 bool bfd_fill_in_gnu_debuglink_section
    592    (bfd *abfd, struct bfd_section *sect, const char *filename);
    593 
    594 char *bfd_follow_build_id_debuglink (bfd *abfd, const char *dir);
    595 
    596 const char *bfd_set_filename (bfd *abfd, const char *filename);
    597 
    598 /* Extracted from libbfd.c.  */
    599 
    600 /* Byte swapping macros for user section data.  */
    601 
    602 #define bfd_put_8(abfd, val, ptr) \
    603   ((void) (*((unsigned char *) (ptr)) = (val) & 0xff))
    604 #define bfd_put_signed_8 \
    605   bfd_put_8
    606 #define bfd_get_8(abfd, ptr) \
    607   ((bfd_vma) *(const unsigned char *) (ptr) & 0xff)
    608 #define bfd_get_signed_8(abfd, ptr) \
    609   ((((bfd_signed_vma) *(const unsigned char *) (ptr) & 0xff) ^ 0x80) - 0x80)
    610 
    611 #define bfd_put_16(abfd, val, ptr) \
    612   BFD_SEND (abfd, bfd_putx16, ((val),(ptr)))
    613 #define bfd_put_signed_16 \
    614   bfd_put_16
    615 #define bfd_get_16(abfd, ptr) \
    616   BFD_SEND (abfd, bfd_getx16, (ptr))
    617 #define bfd_get_signed_16(abfd, ptr) \
    618   BFD_SEND (abfd, bfd_getx_signed_16, (ptr))
    619 
    620 #define bfd_put_24(abfd, val, ptr) \
    621   do                                   \
    622     if (bfd_big_endian (abfd))         \
    623       bfd_putb24 ((val), (ptr));       \
    624     else                               \
    625       bfd_putl24 ((val), (ptr));       \
    626   while (0)
    627 
    628 bfd_vma bfd_getb24 (const void *p);
    629 bfd_vma bfd_getl24 (const void *p);
    630 
    631 #define bfd_get_24(abfd, ptr) \
    632   (bfd_big_endian (abfd) ? bfd_getb24 (ptr) : bfd_getl24 (ptr))
    633 
    634 #define bfd_put_32(abfd, val, ptr) \
    635   BFD_SEND (abfd, bfd_putx32, ((val),(ptr)))
    636 #define bfd_put_signed_32 \
    637   bfd_put_32
    638 #define bfd_get_32(abfd, ptr) \
    639   BFD_SEND (abfd, bfd_getx32, (ptr))
    640 #define bfd_get_signed_32(abfd, ptr) \
    641   BFD_SEND (abfd, bfd_getx_signed_32, (ptr))
    642 
    643 #define bfd_put_64(abfd, val, ptr) \
    644   BFD_SEND (abfd, bfd_putx64, ((val), (ptr)))
    645 #define bfd_put_signed_64 \
    646   bfd_put_64
    647 #define bfd_get_64(abfd, ptr) \
    648   BFD_SEND (abfd, bfd_getx64, (ptr))
    649 #define bfd_get_signed_64(abfd, ptr) \
    650   BFD_SEND (abfd, bfd_getx_signed_64, (ptr))
    651 
    652 #define bfd_get(bits, abfd, ptr)                       \
    653   ((bits) == 8 ? bfd_get_8 (abfd, ptr)                 \
    654    : (bits) == 16 ? bfd_get_16 (abfd, ptr)             \
    655    : (bits) == 32 ? bfd_get_32 (abfd, ptr)             \
    656    : (bits) == 64 ? bfd_get_64 (abfd, ptr)             \
    657    : (abort (), (bfd_vma) - 1))
    658 
    659 #define bfd_put(bits, abfd, val, ptr)                  \
    660   ((bits) == 8 ? bfd_put_8  (abfd, val, ptr)           \
    661    : (bits) == 16 ? bfd_put_16 (abfd, val, ptr)        \
    662    : (bits) == 32 ? bfd_put_32 (abfd, val, ptr)        \
    663    : (bits) == 64 ? bfd_put_64 (abfd, val, ptr)        \
    664    : (abort (), (void) 0))
    665 
    666 
    667 /* Byte swapping macros for file header data.  */
    668 
    669 #define bfd_h_put_8(abfd, val, ptr) \
    670   bfd_put_8 (abfd, val, ptr)
    671 #define bfd_h_put_signed_8(abfd, val, ptr) \
    672   bfd_put_8 (abfd, val, ptr)
    673 #define bfd_h_get_8(abfd, ptr) \
    674   bfd_get_8 (abfd, ptr)
    675 #define bfd_h_get_signed_8(abfd, ptr) \
    676   bfd_get_signed_8 (abfd, ptr)
    677 
    678 #define bfd_h_put_16(abfd, val, ptr) \
    679   BFD_SEND (abfd, bfd_h_putx16, (val, ptr))
    680 #define bfd_h_put_signed_16 \
    681   bfd_h_put_16
    682 #define bfd_h_get_16(abfd, ptr) \
    683   BFD_SEND (abfd, bfd_h_getx16, (ptr))
    684 #define bfd_h_get_signed_16(abfd, ptr) \
    685   BFD_SEND (abfd, bfd_h_getx_signed_16, (ptr))
    686 
    687 #define bfd_h_put_32(abfd, val, ptr) \
    688   BFD_SEND (abfd, bfd_h_putx32, (val, ptr))
    689 #define bfd_h_put_signed_32 \
    690   bfd_h_put_32
    691 #define bfd_h_get_32(abfd, ptr) \
    692   BFD_SEND (abfd, bfd_h_getx32, (ptr))
    693 #define bfd_h_get_signed_32(abfd, ptr) \
    694   BFD_SEND (abfd, bfd_h_getx_signed_32, (ptr))
    695 
    696 #define bfd_h_put_64(abfd, val, ptr) \
    697   BFD_SEND (abfd, bfd_h_putx64, (val, ptr))
    698 #define bfd_h_put_signed_64 \
    699   bfd_h_put_64
    700 #define bfd_h_get_64(abfd, ptr) \
    701   BFD_SEND (abfd, bfd_h_getx64, (ptr))
    702 #define bfd_h_get_signed_64(abfd, ptr) \
    703   BFD_SEND (abfd, bfd_h_getx_signed_64, (ptr))
    704 
    705 /* Aliases for the above, which should eventually go away.  */
    706 
    707 #define H_PUT_64  bfd_h_put_64
    708 #define H_PUT_32  bfd_h_put_32
    709 #define H_PUT_16  bfd_h_put_16
    710 #define H_PUT_8   bfd_h_put_8
    711 #define H_PUT_S64 bfd_h_put_signed_64
    712 #define H_PUT_S32 bfd_h_put_signed_32
    713 #define H_PUT_S16 bfd_h_put_signed_16
    714 #define H_PUT_S8  bfd_h_put_signed_8
    715 #define H_GET_64  bfd_h_get_64
    716 #define H_GET_32  bfd_h_get_32
    717 #define H_GET_16  bfd_h_get_16
    718 #define H_GET_8   bfd_h_get_8
    719 #define H_GET_S64 bfd_h_get_signed_64
    720 #define H_GET_S32 bfd_h_get_signed_32
    721 #define H_GET_S16 bfd_h_get_signed_16
    722 #define H_GET_S8  bfd_h_get_signed_8
    723 
    724 
    725 /* Extracted from bfdio.c.  */
    726 long bfd_get_mtime (bfd *abfd);
    727 
    728 ufile_ptr bfd_get_size (bfd *abfd);
    729 
    730 ufile_ptr bfd_get_file_size (bfd *abfd);
    731 
    732 void *bfd_mmap (bfd *abfd, void *addr, bfd_size_type len,
    733     int prot, int flags, file_ptr offset,
    734     void **map_addr, bfd_size_type *map_len);
    735 
    736 /* Extracted from bfdwin.c.  */
    737 /* Extracted from section.c.  */
    738 
    739 typedef struct bfd_section
    740 {
    741   /* The name of the section; the name isn't a copy, the pointer is
    742      the same as that passed to bfd_make_section.  */
    743   const char *name;
    744 
    745   /* The next section in the list belonging to the BFD, or NULL.  */
    746   struct bfd_section *next;
    747 
    748   /* The previous section in the list belonging to the BFD, or NULL.  */
    749   struct bfd_section *prev;
    750 
    751   /* A unique sequence number.  */
    752   unsigned int id;
    753 
    754   /* A unique section number which can be used by assembler to
    755      distinguish different sections with the same section name.  */
    756   unsigned int section_id;
    757 
    758   /* Which section in the bfd; 0..n-1 as sections are created in a bfd.  */
    759   unsigned int index;
    760 
    761   /* The field flags contains attributes of the section. Some
    762      flags are read in from the object file, and some are
    763      synthesized from other information.  */
    764   flagword flags;
    765 
    766 #define SEC_NO_FLAGS                      0x0
    767 
    768   /* Tells the OS to allocate space for this section when loading.
    769      This is clear for a section containing debug information only.  */
    770 #define SEC_ALLOC                         0x1
    771 
    772   /* Tells the OS to load the section from the file when loading.
    773      This is clear for a .bss section.  */
    774 #define SEC_LOAD                          0x2
    775 
    776   /* The section contains data still to be relocated, so there is
    777      some relocation information too.  */
    778 #define SEC_RELOC                         0x4
    779 
    780   /* A signal to the OS that the section contains read only data.  */
    781 #define SEC_READONLY                      0x8
    782 
    783   /* The section contains code only.  */
    784 #define SEC_CODE                         0x10
    785 
    786   /* The section contains data only.  */
    787 #define SEC_DATA                         0x20
    788 
    789   /* The section will reside in ROM.  */
    790 #define SEC_ROM                          0x40
    791 
    792   /* The section contains constructor information. This section
    793      type is used by the linker to create lists of constructors and
    794      destructors used by <<g++>>. When a back end sees a symbol
    795      which should be used in a constructor list, it creates a new
    796      section for the type of name (e.g., <<__CTOR_LIST__>>), attaches
    797      the symbol to it, and builds a relocation. To build the lists
    798      of constructors, all the linker has to do is catenate all the
    799      sections called <<__CTOR_LIST__>> and relocate the data
    800      contained within - exactly the operations it would peform on
    801      standard data.  */
    802 #define SEC_CONSTRUCTOR                  0x80
    803 
    804   /* The section has contents - a data section could be
    805      <<SEC_ALLOC>> | <<SEC_HAS_CONTENTS>>; a debug section could be
    806      <<SEC_HAS_CONTENTS>>  */
    807 #define SEC_HAS_CONTENTS                0x100
    808 
    809   /* An instruction to the linker to not output the section
    810      even if it has information which would normally be written.  */
    811 #define SEC_NEVER_LOAD                  0x200
    812 
    813   /* The section contains thread local data.  */
    814 #define SEC_THREAD_LOCAL                0x400
    815 
    816   /* The section's size is fixed.  Generic linker code will not
    817      recalculate it and it is up to whoever has set this flag to
    818      get the size right.  */
    819 #define SEC_FIXED_SIZE                  0x800
    820 
    821   /* The section contains common symbols (symbols may be defined
    822      multiple times, the value of a symbol is the amount of
    823      space it requires, and the largest symbol value is the one
    824      used).  Most targets have exactly one of these (which we
    825      translate to bfd_com_section_ptr), but ECOFF has two.  */
    826 #define SEC_IS_COMMON                  0x1000
    827 
    828   /* The section contains only debugging information.  For
    829      example, this is set for ELF .debug and .stab sections.
    830      strip tests this flag to see if a section can be
    831      discarded.  */
    832 #define SEC_DEBUGGING                  0x2000
    833 
    834   /* The contents of this section are held in memory pointed to
    835      by the contents field.  This is checked by bfd_get_section_contents,
    836      and the data is retrieved from memory if appropriate.  */
    837 #define SEC_IN_MEMORY                  0x4000
    838 
    839   /* The contents of this section are to be excluded by the
    840      linker for executable and shared objects unless those
    841      objects are to be further relocated.  */
    842 #define SEC_EXCLUDE                    0x8000
    843 
    844   /* The contents of this section are to be sorted based on the sum of
    845      the symbol and addend values specified by the associated relocation
    846      entries.  Entries without associated relocation entries will be
    847      appended to the end of the section in an unspecified order.  */
    848 #define SEC_SORT_ENTRIES              0x10000
    849 
    850   /* When linking, duplicate sections of the same name should be
    851      discarded, rather than being combined into a single section as
    852      is usually done.  This is similar to how common symbols are
    853      handled.  See SEC_LINK_DUPLICATES below.  */
    854 #define SEC_LINK_ONCE                 0x20000
    855 
    856   /* If SEC_LINK_ONCE is set, this bitfield describes how the linker
    857      should handle duplicate sections.  */
    858 #define SEC_LINK_DUPLICATES           0xc0000
    859 
    860   /* This value for SEC_LINK_DUPLICATES means that duplicate
    861      sections with the same name should simply be discarded.  */
    862 #define SEC_LINK_DUPLICATES_DISCARD       0x0
    863 
    864   /* This value for SEC_LINK_DUPLICATES means that the linker
    865      should warn if there are any duplicate sections, although
    866      it should still only link one copy.  */
    867 #define SEC_LINK_DUPLICATES_ONE_ONLY  0x40000
    868 
    869   /* This value for SEC_LINK_DUPLICATES means that the linker
    870      should warn if any duplicate sections are a different size.  */
    871 #define SEC_LINK_DUPLICATES_SAME_SIZE 0x80000
    872 
    873   /* This value for SEC_LINK_DUPLICATES means that the linker
    874      should warn if any duplicate sections contain different
    875      contents.  */
    876 #define SEC_LINK_DUPLICATES_SAME_CONTENTS \
    877   (SEC_LINK_DUPLICATES_ONE_ONLY | SEC_LINK_DUPLICATES_SAME_SIZE)
    878 
    879   /* This section was created by the linker as part of dynamic
    880      relocation or other arcane processing.  It is skipped when
    881      going through the first-pass output, trusting that someone
    882      else up the line will take care of it later.  */
    883 #define SEC_LINKER_CREATED           0x100000
    884 
    885   /* This section contains a section ID to distinguish different
    886      sections with the same section name.  */
    887 #define SEC_ASSEMBLER_SECTION_ID     0x100000
    888 
    889   /* This section should not be subject to garbage collection.
    890      Also set to inform the linker that this section should not be
    891      listed in the link map as discarded.  */
    892 #define SEC_KEEP                     0x200000
    893 
    894   /* This section contains "short" data, and should be placed
    895      "near" the GP.  */
    896 #define SEC_SMALL_DATA               0x400000
    897 
    898   /* Attempt to merge identical entities in the section.
    899      Entity size is given in the entsize field.  */
    900 #define SEC_MERGE                    0x800000
    901 
    902   /* If given with SEC_MERGE, entities to merge are zero terminated
    903      strings where entsize specifies character size instead of fixed
    904      size entries.  */
    905 #define SEC_STRINGS                 0x1000000
    906 
    907   /* This section contains data about section groups.  */
    908 #define SEC_GROUP                   0x2000000
    909 
    910   /* The section is a COFF shared library section.  This flag is
    911      only for the linker.  If this type of section appears in
    912      the input file, the linker must copy it to the output file
    913      without changing the vma or size.  FIXME: Although this
    914      was originally intended to be general, it really is COFF
    915      specific (and the flag was renamed to indicate this).  It
    916      might be cleaner to have some more general mechanism to
    917      allow the back end to control what the linker does with
    918      sections.  */
    919 #define SEC_COFF_SHARED_LIBRARY     0x4000000
    920 
    921   /* This input section should be copied to output in reverse order
    922      as an array of pointers.  This is for ELF linker internal use
    923      only.  */
    924 #define SEC_ELF_REVERSE_COPY        0x4000000
    925 
    926   /* This section contains data which may be shared with other
    927      executables or shared objects. This is for COFF only.  */
    928 #define SEC_COFF_SHARED             0x8000000
    929 
    930   /* This section should be compressed.  This is for ELF linker
    931      internal use only.  */
    932 #define SEC_ELF_COMPRESS            0x8000000
    933 
    934   /* When a section with this flag is being linked, then if the size of
    935      the input section is less than a page, it should not cross a page
    936      boundary.  If the size of the input section is one page or more,
    937      it should be aligned on a page boundary.  This is for TI
    938      TMS320C54X only.  */
    939 #define SEC_TIC54X_BLOCK           0x10000000
    940 
    941   /* This section should be renamed.  This is for ELF linker
    942      internal use only.  */
    943 #define SEC_ELF_RENAME             0x10000000
    944 
    945   /* Conditionally link this section; do not link if there are no
    946      references found to any symbol in the section.  This is for TI
    947      TMS320C54X only.  */
    948 #define SEC_TIC54X_CLINK           0x20000000
    949 
    950   /* This section contains vliw code.  This is for Toshiba MeP only.  */
    951 #define SEC_MEP_VLIW               0x20000000
    952 
    953   /* All symbols, sizes and relocations in this section are octets
    954      instead of bytes.  Required for DWARF debug sections as DWARF
    955      information is organized in octets, not bytes.  */
    956 #define SEC_ELF_OCTETS             0x40000000
    957 
    958   /* Indicate that section has the no read flag set. This happens
    959      when memory read flag isn't set. */
    960 #define SEC_COFF_NOREAD            0x40000000
    961 
    962   /* Indicate that section has the purecode flag set.  */
    963 #define SEC_ELF_PURECODE           0x80000000
    964 
    965   /*  End of section flags.  */
    966 
    967   /* Some internal packed boolean fields.  */
    968 
    969   /* See the vma field.  */
    970   unsigned int user_set_vma : 1;
    971 
    972   /* A mark flag used by some of the linker backends.  */
    973   unsigned int linker_mark : 1;
    974 
    975   /* Another mark flag used by some of the linker backends.  Set for
    976      output sections that have an input section.  */
    977   unsigned int linker_has_input : 1;
    978 
    979   /* Mark flag used by some linker backends for garbage collection.  */
    980   unsigned int gc_mark : 1;
    981 
    982   /* Section compression status.  */
    983   unsigned int compress_status : 2;
    984 #define COMPRESS_SECTION_NONE    0
    985 #define COMPRESS_SECTION_DONE    1
    986 #define DECOMPRESS_SECTION_SIZED 2
    987 
    988   /* The following flags are used by the ELF linker. */
    989 
    990   /* Mark sections which have been allocated to segments.  */
    991   unsigned int segment_mark : 1;
    992 
    993   /* Type of sec_info information.  */
    994   unsigned int sec_info_type:3;
    995 #define SEC_INFO_TYPE_NONE      0
    996 #define SEC_INFO_TYPE_STABS     1
    997 #define SEC_INFO_TYPE_MERGE     2
    998 #define SEC_INFO_TYPE_EH_FRAME  3
    999 #define SEC_INFO_TYPE_JUST_SYMS 4
   1000 #define SEC_INFO_TYPE_TARGET    5
   1001 #define SEC_INFO_TYPE_EH_FRAME_ENTRY 6
   1002 
   1003   /* Nonzero if this section uses RELA relocations, rather than REL.  */
   1004   unsigned int use_rela_p:1;
   1005 
   1006   /* Bits used by various backends.  The generic code doesn't touch
   1007      these fields.  */
   1008 
   1009   unsigned int sec_flg0:1;
   1010   unsigned int sec_flg1:1;
   1011   unsigned int sec_flg2:1;
   1012   unsigned int sec_flg3:1;
   1013   unsigned int sec_flg4:1;
   1014   unsigned int sec_flg5:1;
   1015 
   1016   /* End of internal packed boolean fields.  */
   1017 
   1018   /*  The virtual memory address of the section - where it will be
   1019       at run time.  The symbols are relocated against this.  The
   1020       user_set_vma flag is maintained by bfd; if it's not set, the
   1021       backend can assign addresses (for example, in <<a.out>>, where
   1022       the default address for <<.data>> is dependent on the specific
   1023       target and various flags).  */
   1024   bfd_vma vma;
   1025 
   1026   /*  The load address of the section - where it would be in a
   1027       rom image; really only used for writing section header
   1028       information.  */
   1029   bfd_vma lma;
   1030 
   1031   /* The size of the section in *octets*, as it will be output.
   1032      Contains a value even if the section has no contents (e.g., the
   1033      size of <<.bss>>).  */
   1034   bfd_size_type size;
   1035 
   1036   /* For input sections, the original size on disk of the section, in
   1037      octets.  This field should be set for any section whose size is
   1038      changed by linker relaxation.  It is required for sections where
   1039      the linker relaxation scheme doesn't cache altered section and
   1040      reloc contents (stabs, eh_frame, SEC_MERGE, some coff relaxing
   1041      targets), and thus the original size needs to be kept to read the
   1042      section multiple times.  For output sections, rawsize holds the
   1043      section size calculated on a previous linker relaxation pass.  */
   1044   bfd_size_type rawsize;
   1045 
   1046   /* The compressed size of the section in octets.  */
   1047   bfd_size_type compressed_size;
   1048 
   1049   /* If this section is going to be output, then this value is the
   1050      offset in *bytes* into the output section of the first byte in the
   1051      input section (byte ==> smallest addressable unit on the
   1052      target).  In most cases, if this was going to start at the
   1053      100th octet (8-bit quantity) in the output section, this value
   1054      would be 100.  However, if the target byte size is 16 bits
   1055      (bfd_octets_per_byte is "2"), this value would be 50.  */
   1056   bfd_vma output_offset;
   1057 
   1058   /* The output section through which to map on output.  */
   1059   struct bfd_section *output_section;
   1060 
   1061   /* If an input section, a pointer to a vector of relocation
   1062      records for the data in this section.  */
   1063   struct reloc_cache_entry *relocation;
   1064 
   1065   /* If an output section, a pointer to a vector of pointers to
   1066      relocation records for the data in this section.  */
   1067   struct reloc_cache_entry **orelocation;
   1068 
   1069   /* The number of relocation records in one of the above.  */
   1070   unsigned reloc_count;
   1071 
   1072   /* The alignment requirement of the section, as an exponent of 2 -
   1073      e.g., 3 aligns to 2^3 (or 8).  */
   1074   unsigned int alignment_power;
   1075 
   1076   /* Information below is back end specific - and not always used
   1077      or updated.  */
   1078 
   1079   /* File position of section data.  */
   1080   file_ptr filepos;
   1081 
   1082   /* File position of relocation info.  */
   1083   file_ptr rel_filepos;
   1084 
   1085   /* File position of line data.  */
   1086   file_ptr line_filepos;
   1087 
   1088   /* Pointer to data for applications.  */
   1089   void *userdata;
   1090 
   1091   /* If the SEC_IN_MEMORY flag is set, this points to the actual
   1092      contents.  */
   1093   unsigned char *contents;
   1094 
   1095   /* Attached line number information.  */
   1096   alent *lineno;
   1097 
   1098   /* Number of line number records.  */
   1099   unsigned int lineno_count;
   1100 
   1101   /* Entity size for merging purposes.  */
   1102   unsigned int entsize;
   1103 
   1104   /* Points to the kept section if this section is a link-once section,
   1105      and is discarded.  */
   1106   struct bfd_section *kept_section;
   1107 
   1108   /* When a section is being output, this value changes as more
   1109      linenumbers are written out.  */
   1110   file_ptr moving_line_filepos;
   1111 
   1112   /* What the section number is in the target world.  */
   1113   int target_index;
   1114 
   1115   void *used_by_bfd;
   1116 
   1117   /* If this is a constructor section then here is a list of the
   1118      relocations created to relocate items within it.  */
   1119   struct relent_chain *constructor_chain;
   1120 
   1121   /* The BFD which owns the section.  */
   1122   bfd *owner;
   1123 
   1124   /* A symbol which points at this section only.  */
   1125   struct bfd_symbol *symbol;
   1126   struct bfd_symbol **symbol_ptr_ptr;
   1127 
   1128   /* Early in the link process, map_head and map_tail are used to build
   1129      a list of input sections attached to an output section.  Later,
   1130      output sections use these fields for a list of bfd_link_order
   1131      structs.  The linked_to_symbol_name field is for ELF assembler
   1132      internal use.  */
   1133   union {
   1134     struct bfd_link_order *link_order;
   1135     struct bfd_section *s;
   1136     const char *linked_to_symbol_name;
   1137   } map_head, map_tail;
   1138 
   1139   /* Points to the output section this section is already assigned to,
   1140      if any.  This is used when support for non-contiguous memory
   1141      regions is enabled.  */
   1142   struct bfd_section *already_assigned;
   1143 
   1144   /* Explicitly specified section type, if non-zero.  */
   1145   unsigned int type;
   1146 
   1147 } asection;
   1148 
   1149 static inline const char *
   1150 bfd_section_name (const asection *sec)
   1151 {
   1152   return sec->name;
   1153 }
   1154 
   1155 static inline bfd_size_type
   1156 bfd_section_size (const asection *sec)
   1157 {
   1158   return sec->size;
   1159 }
   1160 
   1161 static inline bfd_vma
   1162 bfd_section_vma (const asection *sec)
   1163 {
   1164   return sec->vma;
   1165 }
   1166 
   1167 static inline bfd_vma
   1168 bfd_section_lma (const asection *sec)
   1169 {
   1170   return sec->lma;
   1171 }
   1172 
   1173 static inline unsigned int
   1174 bfd_section_alignment (const asection *sec)
   1175 {
   1176   return sec->alignment_power;
   1177 }
   1178 
   1179 static inline flagword
   1180 bfd_section_flags (const asection *sec)
   1181 {
   1182   return sec->flags;
   1183 }
   1184 
   1185 static inline void *
   1186 bfd_section_userdata (const asection *sec)
   1187 {
   1188   return sec->userdata;
   1189 }
   1190 static inline bool
   1191 bfd_is_com_section (const asection *sec)
   1192 {
   1193   return (sec->flags & SEC_IS_COMMON) != 0;
   1194 }
   1195 
   1196 /* Note: the following are provided as inline functions rather than macros
   1197    because not all callers use the return value.  A macro implementation
   1198    would use a comma expression, eg: "((ptr)->foo = val, TRUE)" and some
   1199    compilers will complain about comma expressions that have no effect.  */
   1200 static inline bool
   1201 bfd_set_section_userdata (asection *sec, void *val)
   1202 {
   1203   sec->userdata = val;
   1204   return true;
   1205 }
   1206 
   1207 static inline bool
   1208 bfd_set_section_vma (asection *sec, bfd_vma val)
   1209 {
   1210   sec->vma = sec->lma = val;
   1211   sec->user_set_vma = true;
   1212   return true;
   1213 }
   1214 
   1215 static inline bool
   1216 bfd_set_section_lma (asection *sec, bfd_vma val)
   1217 {
   1218   sec->lma = val;
   1219   return true;
   1220 }
   1221 
   1222 static inline bool
   1223 bfd_set_section_alignment (asection *sec, unsigned int val)
   1224 {
   1225   sec->alignment_power = val;
   1226   return true;
   1227 }
   1228 
   1229 /* These sections are global, and are managed by BFD.  The application
   1230    and target back end are not permitted to change the values in
   1231    these sections.  */
   1232 extern asection _bfd_std_section[4];
   1233 
   1234 #define BFD_ABS_SECTION_NAME "*ABS*"
   1235 #define BFD_UND_SECTION_NAME "*UND*"
   1236 #define BFD_COM_SECTION_NAME "*COM*"
   1237 #define BFD_IND_SECTION_NAME "*IND*"
   1238 
   1239 /* Pointer to the common section.  */
   1240 #define bfd_com_section_ptr (&_bfd_std_section[0])
   1241 /* Pointer to the undefined section.  */
   1242 #define bfd_und_section_ptr (&_bfd_std_section[1])
   1243 /* Pointer to the absolute section.  */
   1244 #define bfd_abs_section_ptr (&_bfd_std_section[2])
   1245 /* Pointer to the indirect section.  */
   1246 #define bfd_ind_section_ptr (&_bfd_std_section[3])
   1247 
   1248 static inline bool
   1249 bfd_is_und_section (const asection *sec)
   1250 {
   1251   return sec == bfd_und_section_ptr;
   1252 }
   1253 
   1254 static inline bool
   1255 bfd_is_abs_section (const asection *sec)
   1256 {
   1257   return sec == bfd_abs_section_ptr;
   1258 }
   1259 
   1260 static inline bool
   1261 bfd_is_ind_section (const asection *sec)
   1262 {
   1263   return sec == bfd_ind_section_ptr;
   1264 }
   1265 
   1266 static inline bool
   1267 bfd_is_const_section (const asection *sec)
   1268 {
   1269   return (sec >= _bfd_std_section
   1270           && sec < _bfd_std_section + (sizeof (_bfd_std_section)
   1271                                        / sizeof (_bfd_std_section[0])));
   1272 }
   1273 
   1274 /* Return TRUE if input section SEC has been discarded.  */
   1275 static inline bool
   1276 discarded_section (const asection *sec)
   1277 {
   1278   return (!bfd_is_abs_section (sec)
   1279           && bfd_is_abs_section (sec->output_section)
   1280           && sec->sec_info_type != SEC_INFO_TYPE_MERGE
   1281           && sec->sec_info_type != SEC_INFO_TYPE_JUST_SYMS);
   1282 }
   1283 
   1284 #define BFD_FAKE_SECTION(SEC, SYM, NAME, IDX, FLAGS)                   \
   1285   /* name, next, prev, id,  section_id, index, flags, user_set_vma, */ \
   1286   {  NAME, NULL, NULL, IDX, 0,          0,     FLAGS, 0,               \
   1287                                                                        \
   1288   /* linker_mark, linker_has_input, gc_mark, decompress_status,     */ \
   1289      0,           0,                1,       0,                        \
   1290                                                                        \
   1291   /* segment_mark, sec_info_type, use_rela_p,                       */ \
   1292      0,            0,             0,                                   \
   1293                                                                        \
   1294   /* sec_flg0, sec_flg1, sec_flg2, sec_flg3, sec_flg4, sec_flg5,    */ \
   1295      0,        0,        0,        0,        0,        0,              \
   1296                                                                        \
   1297   /* vma, lma, size, rawsize, compressed_size,                      */ \
   1298      0,   0,   0,    0,       0,                                       \
   1299                                                                        \
   1300   /* output_offset, output_section, relocation, orelocation,        */ \
   1301      0,             &SEC,           NULL,       NULL,                  \
   1302                                                                        \
   1303   /* reloc_count, alignment_power, filepos, rel_filepos,            */ \
   1304      0,           0,               0,       0,                         \
   1305                                                                        \
   1306   /* line_filepos, userdata, contents, lineno, lineno_count,        */ \
   1307      0,            NULL,     NULL,     NULL,   0,                      \
   1308                                                                        \
   1309   /* entsize, kept_section, moving_line_filepos,                    */ \
   1310      0,       NULL,         0,                                         \
   1311                                                                        \
   1312   /* target_index, used_by_bfd, constructor_chain, owner,           */ \
   1313      0,            NULL,        NULL,              NULL,               \
   1314                                                                        \
   1315   /* symbol,                    symbol_ptr_ptr,                     */ \
   1316      (struct bfd_symbol *) SYM, &SEC.symbol,                           \
   1317                                                                        \
   1318   /* map_head, map_tail, already_assigned, type                     */ \
   1319      { NULL }, { NULL }, NULL,             0                           \
   1320                                                                        \
   1321     }
   1322 
   1323 /* We use a macro to initialize the static asymbol structures because
   1324    traditional C does not permit us to initialize a union member while
   1325    gcc warns if we don't initialize it.
   1326    the_bfd, name, value, attr, section [, udata]  */
   1327 #ifdef __STDC__
   1328 #define GLOBAL_SYM_INIT(NAME, SECTION) \
   1329   { 0, NAME, 0, BSF_SECTION_SYM, SECTION, { 0 }}
   1330 #else
   1331 #define GLOBAL_SYM_INIT(NAME, SECTION) \
   1332   { 0, NAME, 0, BSF_SECTION_SYM, SECTION }
   1333 #endif
   1334 
   1335 void bfd_section_list_clear (bfd *);
   1336 
   1337 asection *bfd_get_section_by_name (bfd *abfd, const char *name);
   1338 
   1339 asection *bfd_get_next_section_by_name (bfd *ibfd, asection *sec);
   1340 
   1341 asection *bfd_get_linker_section (bfd *abfd, const char *name);
   1342 
   1343 asection *bfd_get_section_by_name_if
   1344    (bfd *abfd,
   1345     const char *name,
   1346     bool (*func) (bfd *abfd, asection *sect, void *obj),
   1347     void *obj);
   1348 
   1349 char *bfd_get_unique_section_name
   1350    (bfd *abfd, const char *templat, int *count);
   1351 
   1352 asection *bfd_make_section_old_way (bfd *abfd, const char *name);
   1353 
   1354 asection *bfd_make_section_anyway_with_flags
   1355    (bfd *abfd, const char *name, flagword flags);
   1356 
   1357 asection *bfd_make_section_anyway (bfd *abfd, const char *name);
   1358 
   1359 asection *bfd_make_section_with_flags
   1360    (bfd *, const char *name, flagword flags);
   1361 
   1362 asection *bfd_make_section (bfd *, const char *name);
   1363 
   1364 bool bfd_set_section_flags (asection *sec, flagword flags);
   1365 
   1366 void bfd_rename_section
   1367    (asection *sec, const char *newname);
   1368 
   1369 void bfd_map_over_sections
   1370    (bfd *abfd,
   1371     void (*func) (bfd *abfd, asection *sect, void *obj),
   1372     void *obj);
   1373 
   1374 asection *bfd_sections_find_if
   1375    (bfd *abfd,
   1376     bool (*operation) (bfd *abfd, asection *sect, void *obj),
   1377     void *obj);
   1378 
   1379 bool bfd_set_section_size (asection *sec, bfd_size_type val);
   1380 
   1381 bool bfd_set_section_contents
   1382    (bfd *abfd, asection *section, const void *data,
   1383     file_ptr offset, bfd_size_type count);
   1384 
   1385 bool bfd_get_section_contents
   1386    (bfd *abfd, asection *section, void *location, file_ptr offset,
   1387     bfd_size_type count);
   1388 
   1389 bool bfd_malloc_and_get_section
   1390    (bfd *abfd, asection *section, bfd_byte **buf);
   1391 
   1392 bool bfd_copy_private_section_data
   1393    (bfd *ibfd, asection *isec, bfd *obfd, asection *osec);
   1394 
   1395 #define bfd_copy_private_section_data(ibfd, isection, obfd, osection) \
   1396        BFD_SEND (obfd, _bfd_copy_private_section_data, \
   1397                  (ibfd, isection, obfd, osection))
   1398 bool bfd_generic_is_group_section (bfd *, const asection *sec);
   1399 
   1400 const char *bfd_generic_group_name (bfd *, const asection *sec);
   1401 
   1402 bool bfd_generic_discard_group (bfd *abfd, asection *group);
   1403 
   1404 /* Extracted from archures.c.  */
   1405 enum bfd_architecture
   1406 {
   1407   bfd_arch_unknown,   /* File arch not known.  */
   1408   bfd_arch_obscure,   /* Arch known, not one of these.  */
   1409   bfd_arch_m68k,      /* Motorola 68xxx.  */
   1410 #define bfd_mach_m68000                1
   1411 #define bfd_mach_m68008                2
   1412 #define bfd_mach_m68010                3
   1413 #define bfd_mach_m68020                4
   1414 #define bfd_mach_m68030                5
   1415 #define bfd_mach_m68040                6
   1416 #define bfd_mach_m68060                7
   1417 #define bfd_mach_cpu32                 8
   1418 #define bfd_mach_fido                  9
   1419 #define bfd_mach_mcf_isa_a_nodiv       10
   1420 #define bfd_mach_mcf_isa_a             11
   1421 #define bfd_mach_mcf_isa_a_mac         12
   1422 #define bfd_mach_mcf_isa_a_emac        13
   1423 #define bfd_mach_mcf_isa_aplus         14
   1424 #define bfd_mach_mcf_isa_aplus_mac     15
   1425 #define bfd_mach_mcf_isa_aplus_emac    16
   1426 #define bfd_mach_mcf_isa_b_nousp       17
   1427 #define bfd_mach_mcf_isa_b_nousp_mac   18
   1428 #define bfd_mach_mcf_isa_b_nousp_emac  19
   1429 #define bfd_mach_mcf_isa_b             20
   1430 #define bfd_mach_mcf_isa_b_mac         21
   1431 #define bfd_mach_mcf_isa_b_emac        22
   1432 #define bfd_mach_mcf_isa_b_float       23
   1433 #define bfd_mach_mcf_isa_b_float_mac   24
   1434 #define bfd_mach_mcf_isa_b_float_emac  25
   1435 #define bfd_mach_mcf_isa_c             26
   1436 #define bfd_mach_mcf_isa_c_mac         27
   1437 #define bfd_mach_mcf_isa_c_emac        28
   1438 #define bfd_mach_mcf_isa_c_nodiv       29
   1439 #define bfd_mach_mcf_isa_c_nodiv_mac   30
   1440 #define bfd_mach_mcf_isa_c_nodiv_emac  31
   1441   bfd_arch_vax,       /* DEC Vax.  */
   1442 
   1443   bfd_arch_or1k,      /* OpenRISC 1000.  */
   1444 #define bfd_mach_or1k          1
   1445 #define bfd_mach_or1knd        2
   1446 
   1447   bfd_arch_sparc,     /* SPARC.  */
   1448 #define bfd_mach_sparc                 1
   1449 /* The difference between v8plus and v9 is that v9 is a true 64 bit env.  */
   1450 #define bfd_mach_sparc_sparclet        2
   1451 #define bfd_mach_sparc_sparclite       3
   1452 #define bfd_mach_sparc_v8plus          4
   1453 #define bfd_mach_sparc_v8plusa         5 /* with ultrasparc add'ns.  */
   1454 #define bfd_mach_sparc_sparclite_le    6
   1455 #define bfd_mach_sparc_v9              7
   1456 #define bfd_mach_sparc_v9a             8 /* with ultrasparc add'ns.  */
   1457 #define bfd_mach_sparc_v8plusb         9 /* with cheetah add'ns.  */
   1458 #define bfd_mach_sparc_v9b             10 /* with cheetah add'ns.  */
   1459 #define bfd_mach_sparc_v8plusc         11 /* with UA2005 and T1 add'ns.  */
   1460 #define bfd_mach_sparc_v9c             12 /* with UA2005 and T1 add'ns.  */
   1461 #define bfd_mach_sparc_v8plusd         13 /* with UA2007 and T3 add'ns.  */
   1462 #define bfd_mach_sparc_v9d             14 /* with UA2007 and T3 add'ns.  */
   1463 #define bfd_mach_sparc_v8pluse         15 /* with OSA2001 and T4 add'ns (no IMA).  */
   1464 #define bfd_mach_sparc_v9e             16 /* with OSA2001 and T4 add'ns (no IMA).  */
   1465 #define bfd_mach_sparc_v8plusv         17 /* with OSA2011 and T4 and IMA and FJMAU add'ns.  */
   1466 #define bfd_mach_sparc_v9v             18 /* with OSA2011 and T4 and IMA and FJMAU add'ns.  */
   1467 #define bfd_mach_sparc_v8plusm         19 /* with OSA2015 and M7 add'ns.  */
   1468 #define bfd_mach_sparc_v9m             20 /* with OSA2015 and M7 add'ns.  */
   1469 #define bfd_mach_sparc_v8plusm8        21 /* with OSA2017 and M8 add'ns.  */
   1470 #define bfd_mach_sparc_v9m8            22 /* with OSA2017 and M8 add'ns.  */
   1471 /* Nonzero if MACH has the v9 instruction set.  */
   1472 #define bfd_mach_sparc_v9_p(mach) \
   1473   ((mach) >= bfd_mach_sparc_v8plus && (mach) <= bfd_mach_sparc_v9m8 \
   1474    && (mach) != bfd_mach_sparc_sparclite_le)
   1475 /* Nonzero if MACH is a 64 bit sparc architecture.  */
   1476 #define bfd_mach_sparc_64bit_p(mach) \
   1477   ((mach) >= bfd_mach_sparc_v9 \
   1478    && (mach) != bfd_mach_sparc_v8plusb \
   1479    && (mach) != bfd_mach_sparc_v8plusc \
   1480    && (mach) != bfd_mach_sparc_v8plusd \
   1481    && (mach) != bfd_mach_sparc_v8pluse \
   1482    && (mach) != bfd_mach_sparc_v8plusv \
   1483    && (mach) != bfd_mach_sparc_v8plusm \
   1484    && (mach) != bfd_mach_sparc_v8plusm8)
   1485   bfd_arch_spu,       /* PowerPC SPU.  */
   1486 #define bfd_mach_spu           256
   1487   bfd_arch_mips,      /* MIPS Rxxxx.  */
   1488 #define bfd_mach_mips3000              3000
   1489 #define bfd_mach_mips3900              3900
   1490 #define bfd_mach_mips4000              4000
   1491 #define bfd_mach_mips4010              4010
   1492 #define bfd_mach_mips4100              4100
   1493 #define bfd_mach_mips4111              4111
   1494 #define bfd_mach_mips4120              4120
   1495 #define bfd_mach_mips4300              4300
   1496 #define bfd_mach_mips4400              4400
   1497 #define bfd_mach_mips4600              4600
   1498 #define bfd_mach_mips4650              4650
   1499 #define bfd_mach_mips5000              5000
   1500 #define bfd_mach_mips5400              5400
   1501 #define bfd_mach_mips5500              5500
   1502 #define bfd_mach_mips5900              5900
   1503 #define bfd_mach_mips6000              6000
   1504 #define bfd_mach_mips7000              7000
   1505 #define bfd_mach_mips8000              8000
   1506 #define bfd_mach_mips9000              9000
   1507 #define bfd_mach_mips10000             10000
   1508 #define bfd_mach_mips12000             12000
   1509 #define bfd_mach_mips14000             14000
   1510 #define bfd_mach_mips16000             16000
   1511 #define bfd_mach_mips16                16
   1512 #define bfd_mach_mips5                 5
   1513 #define bfd_mach_mips_loongson_2e      3001
   1514 #define bfd_mach_mips_loongson_2f      3002
   1515 #define bfd_mach_mips_gs464            3003
   1516 #define bfd_mach_mips_gs464e           3004
   1517 #define bfd_mach_mips_gs264e           3005
   1518 #define bfd_mach_mips_sb1              12310201 /* octal 'SB', 01.  */
   1519 #define bfd_mach_mips_octeon           6501
   1520 #define bfd_mach_mips_octeonp          6601
   1521 #define bfd_mach_mips_octeon2          6502
   1522 #define bfd_mach_mips_octeon3          6503
   1523 #define bfd_mach_mips_xlr              887682   /* decimal 'XLR'.  */
   1524 #define bfd_mach_mips_interaptiv_mr2   736550   /* decimal 'IA2'.  */
   1525 #define bfd_mach_mipsisa32             32
   1526 #define bfd_mach_mipsisa32r2           33
   1527 #define bfd_mach_mipsisa32r3           34
   1528 #define bfd_mach_mipsisa32r5           36
   1529 #define bfd_mach_mipsisa32r6           37
   1530 #define bfd_mach_mipsisa64             64
   1531 #define bfd_mach_mipsisa64r2           65
   1532 #define bfd_mach_mipsisa64r3           66
   1533 #define bfd_mach_mipsisa64r5           68
   1534 #define bfd_mach_mipsisa64r6           69
   1535 #define bfd_mach_mips_micromips        96
   1536   bfd_arch_i386,      /* Intel 386.  */
   1537 #define bfd_mach_i386_intel_syntax     (1 << 0)
   1538 #define bfd_mach_i386_i8086            (1 << 1)
   1539 #define bfd_mach_i386_i386             (1 << 2)
   1540 #define bfd_mach_x86_64                (1 << 3)
   1541 #define bfd_mach_x64_32                (1 << 4)
   1542 #define bfd_mach_i386_i386_intel_syntax (bfd_mach_i386_i386 | bfd_mach_i386_intel_syntax)
   1543 #define bfd_mach_x86_64_intel_syntax   (bfd_mach_x86_64 | bfd_mach_i386_intel_syntax)
   1544 #define bfd_mach_x64_32_intel_syntax   (bfd_mach_x64_32 | bfd_mach_i386_intel_syntax)
   1545   bfd_arch_iamcu,     /* Intel MCU.  */
   1546 #define bfd_mach_iamcu                 (1 << 8)
   1547 #define bfd_mach_i386_iamcu            (bfd_mach_i386_i386 | bfd_mach_iamcu)
   1548 #define bfd_mach_i386_iamcu_intel_syntax (bfd_mach_i386_iamcu | bfd_mach_i386_intel_syntax)
   1549   bfd_arch_romp,      /* IBM ROMP PC/RT.  */
   1550   bfd_arch_convex,    /* Convex.  */
   1551   bfd_arch_m98k,      /* Motorola 98xxx.  */
   1552   bfd_arch_pyramid,   /* Pyramid Technology.  */
   1553   bfd_arch_h8300,     /* Renesas H8/300 (formerly Hitachi H8/300).  */
   1554 #define bfd_mach_h8300         1
   1555 #define bfd_mach_h8300h        2
   1556 #define bfd_mach_h8300s        3
   1557 #define bfd_mach_h8300hn       4
   1558 #define bfd_mach_h8300sn       5
   1559 #define bfd_mach_h8300sx       6
   1560 #define bfd_mach_h8300sxn      7
   1561   bfd_arch_pdp11,     /* DEC PDP-11.  */
   1562   bfd_arch_powerpc,   /* PowerPC.  */
   1563 #define bfd_mach_ppc           32
   1564 #define bfd_mach_ppc64         64
   1565 #define bfd_mach_ppc_403       403
   1566 #define bfd_mach_ppc_403gc     4030
   1567 #define bfd_mach_ppc_405       405
   1568 #define bfd_mach_ppc_505       505
   1569 #define bfd_mach_ppc_601       601
   1570 #define bfd_mach_ppc_602       602
   1571 #define bfd_mach_ppc_603       603
   1572 #define bfd_mach_ppc_ec603e    6031
   1573 #define bfd_mach_ppc_604       604
   1574 #define bfd_mach_ppc_620       620
   1575 #define bfd_mach_ppc_630       630
   1576 #define bfd_mach_ppc_750       750
   1577 #define bfd_mach_ppc_860       860
   1578 #define bfd_mach_ppc_a35       35
   1579 #define bfd_mach_ppc_rs64ii    642
   1580 #define bfd_mach_ppc_rs64iii   643
   1581 #define bfd_mach_ppc_7400      7400
   1582 #define bfd_mach_ppc_e500      500
   1583 #define bfd_mach_ppc_e500mc    5001
   1584 #define bfd_mach_ppc_e500mc64  5005
   1585 #define bfd_mach_ppc_e5500     5006
   1586 #define bfd_mach_ppc_e6500     5007
   1587 #define bfd_mach_ppc_titan     83
   1588 #define bfd_mach_ppc_vle       84
   1589   bfd_arch_rs6000,    /* IBM RS/6000.  */
   1590 #define bfd_mach_rs6k          6000
   1591 #define bfd_mach_rs6k_rs1      6001
   1592 #define bfd_mach_rs6k_rsc      6003
   1593 #define bfd_mach_rs6k_rs2      6002
   1594   bfd_arch_hppa,      /* HP PA RISC.  */
   1595 #define bfd_mach_hppa10        10
   1596 #define bfd_mach_hppa11        11
   1597 #define bfd_mach_hppa20        20
   1598 #define bfd_mach_hppa20w       25
   1599   bfd_arch_d10v,      /* Mitsubishi D10V.  */
   1600 #define bfd_mach_d10v          1
   1601 #define bfd_mach_d10v_ts2      2
   1602 #define bfd_mach_d10v_ts3      3
   1603   bfd_arch_d30v,      /* Mitsubishi D30V.  */
   1604   bfd_arch_dlx,       /* DLX.  */
   1605   bfd_arch_m68hc11,   /* Motorola 68HC11.  */
   1606   bfd_arch_m68hc12,   /* Motorola 68HC12.  */
   1607 #define bfd_mach_m6812_default 0
   1608 #define bfd_mach_m6812         1
   1609 #define bfd_mach_m6812s        2
   1610   bfd_arch_m9s12x,    /* Freescale S12X.  */
   1611   bfd_arch_m9s12xg,   /* Freescale XGATE.  */
   1612   bfd_arch_s12z,    /* Freescale S12Z.  */
   1613 #define bfd_mach_s12z_default 0
   1614   bfd_arch_z8k,       /* Zilog Z8000.  */
   1615 #define bfd_mach_z8001         1
   1616 #define bfd_mach_z8002         2
   1617   bfd_arch_sh,        /* Renesas / SuperH SH (formerly Hitachi SH).  */
   1618 #define bfd_mach_sh                            1
   1619 #define bfd_mach_sh2                           0x20
   1620 #define bfd_mach_sh_dsp                        0x2d
   1621 #define bfd_mach_sh2a                          0x2a
   1622 #define bfd_mach_sh2a_nofpu                    0x2b
   1623 #define bfd_mach_sh2a_nofpu_or_sh4_nommu_nofpu 0x2a1
   1624 #define bfd_mach_sh2a_nofpu_or_sh3_nommu       0x2a2
   1625 #define bfd_mach_sh2a_or_sh4                   0x2a3
   1626 #define bfd_mach_sh2a_or_sh3e                  0x2a4
   1627 #define bfd_mach_sh2e                          0x2e
   1628 #define bfd_mach_sh3                           0x30
   1629 #define bfd_mach_sh3_nommu                     0x31
   1630 #define bfd_mach_sh3_dsp                       0x3d
   1631 #define bfd_mach_sh3e                          0x3e
   1632 #define bfd_mach_sh4                           0x40
   1633 #define bfd_mach_sh4_nofpu                     0x41
   1634 #define bfd_mach_sh4_nommu_nofpu               0x42
   1635 #define bfd_mach_sh4a                          0x4a
   1636 #define bfd_mach_sh4a_nofpu                    0x4b
   1637 #define bfd_mach_sh4al_dsp                     0x4d
   1638   bfd_arch_alpha,     /* Dec Alpha.  */
   1639 #define bfd_mach_alpha_ev4     0x10
   1640 #define bfd_mach_alpha_ev5     0x20
   1641 #define bfd_mach_alpha_ev6     0x30
   1642   bfd_arch_arm,       /* Advanced Risc Machines ARM.  */
   1643 #define bfd_mach_arm_unknown   0
   1644 #define bfd_mach_arm_2         1
   1645 #define bfd_mach_arm_2a        2
   1646 #define bfd_mach_arm_3         3
   1647 #define bfd_mach_arm_3M        4
   1648 #define bfd_mach_arm_4         5
   1649 #define bfd_mach_arm_4T        6
   1650 #define bfd_mach_arm_5         7
   1651 #define bfd_mach_arm_5T        8
   1652 #define bfd_mach_arm_5TE       9
   1653 #define bfd_mach_arm_XScale    10
   1654 #define bfd_mach_arm_ep9312    11
   1655 #define bfd_mach_arm_iWMMXt    12
   1656 #define bfd_mach_arm_iWMMXt2   13
   1657 #define bfd_mach_arm_5TEJ      14
   1658 #define bfd_mach_arm_6         15
   1659 #define bfd_mach_arm_6KZ       16
   1660 #define bfd_mach_arm_6T2       17
   1661 #define bfd_mach_arm_6K        18
   1662 #define bfd_mach_arm_7         19
   1663 #define bfd_mach_arm_6M        20
   1664 #define bfd_mach_arm_6SM       21
   1665 #define bfd_mach_arm_7EM       22
   1666 #define bfd_mach_arm_8         23
   1667 #define bfd_mach_arm_8R        24
   1668 #define bfd_mach_arm_8M_BASE   25
   1669 #define bfd_mach_arm_8M_MAIN   26
   1670 #define bfd_mach_arm_8_1M_MAIN 27
   1671 #define bfd_mach_arm_9         28
   1672   bfd_arch_nds32,     /* Andes NDS32.  */
   1673 #define bfd_mach_n1            1
   1674 #define bfd_mach_n1h           2
   1675 #define bfd_mach_n1h_v2        3
   1676 #define bfd_mach_n1h_v3        4
   1677 #define bfd_mach_n1h_v3m       5
   1678   bfd_arch_ns32k,     /* National Semiconductors ns32000.  */
   1679   bfd_arch_tic30,     /* Texas Instruments TMS320C30.  */
   1680   bfd_arch_tic4x,     /* Texas Instruments TMS320C3X/4X.  */
   1681 #define bfd_mach_tic3x         30
   1682 #define bfd_mach_tic4x         40
   1683   bfd_arch_tic54x,    /* Texas Instruments TMS320C54X.  */
   1684   bfd_arch_tic6x,     /* Texas Instruments TMS320C6X.  */
   1685   bfd_arch_v850,      /* NEC V850.  */
   1686   bfd_arch_v850_rh850,/* NEC V850 (using RH850 ABI).  */
   1687 #define bfd_mach_v850          1
   1688 #define bfd_mach_v850e         'E'
   1689 #define bfd_mach_v850e1        '1'
   1690 #define bfd_mach_v850e2        0x4532
   1691 #define bfd_mach_v850e2v3      0x45325633
   1692 #define bfd_mach_v850e3v5      0x45335635 /* ('E'|'3'|'V'|'5').  */
   1693   bfd_arch_arc,       /* ARC Cores.  */
   1694 #define bfd_mach_arc_a4        0
   1695 #define bfd_mach_arc_a5        1
   1696 #define bfd_mach_arc_arc600    2
   1697 #define bfd_mach_arc_arc601    4
   1698 #define bfd_mach_arc_arc700    3
   1699 #define bfd_mach_arc_arcv2     5
   1700  bfd_arch_m32c,       /* Renesas M16C/M32C.  */
   1701 #define bfd_mach_m16c          0x75
   1702 #define bfd_mach_m32c          0x78
   1703   bfd_arch_m32r,      /* Renesas M32R (formerly Mitsubishi M32R/D).  */
   1704 #define bfd_mach_m32r          1 /* For backwards compatibility.  */
   1705 #define bfd_mach_m32rx         'x'
   1706 #define bfd_mach_m32r2         '2'
   1707   bfd_arch_mn10200,   /* Matsushita MN10200.  */
   1708   bfd_arch_mn10300,   /* Matsushita MN10300.  */
   1709 #define bfd_mach_mn10300       300
   1710 #define bfd_mach_am33          330
   1711 #define bfd_mach_am33_2        332
   1712   bfd_arch_fr30,
   1713 #define bfd_mach_fr30          0x46523330
   1714   bfd_arch_frv,
   1715 #define bfd_mach_frv           1
   1716 #define bfd_mach_frvsimple     2
   1717 #define bfd_mach_fr300         300
   1718 #define bfd_mach_fr400         400
   1719 #define bfd_mach_fr450         450
   1720 #define bfd_mach_frvtomcat     499     /* fr500 prototype.  */
   1721 #define bfd_mach_fr500         500
   1722 #define bfd_mach_fr550         550
   1723   bfd_arch_moxie,     /* The moxie processor.  */
   1724 #define bfd_mach_moxie         1
   1725   bfd_arch_ft32,      /* The ft32 processor.  */
   1726 #define bfd_mach_ft32          1
   1727 #define bfd_mach_ft32b         2
   1728   bfd_arch_mcore,
   1729   bfd_arch_mep,
   1730 #define bfd_mach_mep           1
   1731 #define bfd_mach_mep_h1        0x6831
   1732 #define bfd_mach_mep_c5        0x6335
   1733   bfd_arch_metag,
   1734 #define bfd_mach_metag         1
   1735   bfd_arch_ia64,      /* HP/Intel ia64.  */
   1736 #define bfd_mach_ia64_elf64    64
   1737 #define bfd_mach_ia64_elf32    32
   1738   bfd_arch_ip2k,      /* Ubicom IP2K microcontrollers. */
   1739 #define bfd_mach_ip2022        1
   1740 #define bfd_mach_ip2022ext     2
   1741  bfd_arch_iq2000,     /* Vitesse IQ2000.  */
   1742 #define bfd_mach_iq2000        1
   1743 #define bfd_mach_iq10          2
   1744   bfd_arch_bpf,       /* Linux eBPF.  */
   1745 #define bfd_mach_bpf           1
   1746 #define bfd_mach_xbpf          2
   1747   bfd_arch_epiphany,  /* Adapteva EPIPHANY.  */
   1748 #define bfd_mach_epiphany16    1
   1749 #define bfd_mach_epiphany32    2
   1750   bfd_arch_mt,
   1751 #define bfd_mach_ms1           1
   1752 #define bfd_mach_mrisc2        2
   1753 #define bfd_mach_ms2           3
   1754   bfd_arch_pj,
   1755   bfd_arch_avr,       /* Atmel AVR microcontrollers.  */
   1756 #define bfd_mach_avr1          1
   1757 #define bfd_mach_avr2          2
   1758 #define bfd_mach_avr25         25
   1759 #define bfd_mach_avr3          3
   1760 #define bfd_mach_avr31         31
   1761 #define bfd_mach_avr35         35
   1762 #define bfd_mach_avr4          4
   1763 #define bfd_mach_avr5          5
   1764 #define bfd_mach_avr51         51
   1765 #define bfd_mach_avr6          6
   1766 #define bfd_mach_avrtiny       100
   1767 #define bfd_mach_avrxmega1     101
   1768 #define bfd_mach_avrxmega2     102
   1769 #define bfd_mach_avrxmega3     103
   1770 #define bfd_mach_avrxmega4     104
   1771 #define bfd_mach_avrxmega5     105
   1772 #define bfd_mach_avrxmega6     106
   1773 #define bfd_mach_avrxmega7     107
   1774   bfd_arch_bfin,      /* ADI Blackfin.  */
   1775 #define bfd_mach_bfin          1
   1776   bfd_arch_cr16,      /* National Semiconductor CompactRISC (ie CR16).  */
   1777 #define bfd_mach_cr16          1
   1778   bfd_arch_crx,       /*  National Semiconductor CRX.  */
   1779 #define bfd_mach_crx           1
   1780   bfd_arch_cris,      /* Axis CRIS.  */
   1781 #define bfd_mach_cris_v0_v10   255
   1782 #define bfd_mach_cris_v32      32
   1783 #define bfd_mach_cris_v10_v32  1032
   1784   bfd_arch_riscv,
   1785 #define bfd_mach_riscv32       132
   1786 #define bfd_mach_riscv64       164
   1787   bfd_arch_rl78,
   1788 #define bfd_mach_rl78          0x75
   1789   bfd_arch_rx,        /* Renesas RX.  */
   1790 #define bfd_mach_rx            0x75
   1791 #define bfd_mach_rx_v2         0x76
   1792 #define bfd_mach_rx_v3         0x77
   1793   bfd_arch_s390,      /* IBM s390.  */
   1794 #define bfd_mach_s390_31       31
   1795 #define bfd_mach_s390_64       64
   1796   bfd_arch_score,     /* Sunplus score.  */
   1797 #define bfd_mach_score3        3
   1798 #define bfd_mach_score7        7
   1799   bfd_arch_mmix,      /* Donald Knuth's educational processor.  */
   1800   bfd_arch_xstormy16,
   1801 #define bfd_mach_xstormy16     1
   1802   bfd_arch_msp430,    /* Texas Instruments MSP430 architecture.  */
   1803 #define bfd_mach_msp11         11
   1804 #define bfd_mach_msp110        110
   1805 #define bfd_mach_msp12         12
   1806 #define bfd_mach_msp13         13
   1807 #define bfd_mach_msp14         14
   1808 #define bfd_mach_msp15         15
   1809 #define bfd_mach_msp16         16
   1810 #define bfd_mach_msp20         20
   1811 #define bfd_mach_msp21         21
   1812 #define bfd_mach_msp22         22
   1813 #define bfd_mach_msp23         23
   1814 #define bfd_mach_msp24         24
   1815 #define bfd_mach_msp26         26
   1816 #define bfd_mach_msp31         31
   1817 #define bfd_mach_msp32         32
   1818 #define bfd_mach_msp33         33
   1819 #define bfd_mach_msp41         41
   1820 #define bfd_mach_msp42         42
   1821 #define bfd_mach_msp43         43
   1822 #define bfd_mach_msp44         44
   1823 #define bfd_mach_msp430x       45
   1824 #define bfd_mach_msp46         46
   1825 #define bfd_mach_msp47         47
   1826 #define bfd_mach_msp54         54
   1827   bfd_arch_xgate,     /* Freescale XGATE.  */
   1828 #define bfd_mach_xgate         1
   1829   bfd_arch_xtensa,    /* Tensilica's Xtensa cores.  */
   1830 #define bfd_mach_xtensa        1
   1831   bfd_arch_z80,
   1832 /* Zilog Z80 without undocumented opcodes.  */
   1833 #define bfd_mach_z80strict     1
   1834 /* Zilog Z180: successor with additional instructions, but without
   1835  halves of ix and iy.  */
   1836 #define bfd_mach_z180          2
   1837 /* Zilog Z80 with ixl, ixh, iyl, and iyh.  */
   1838 #define bfd_mach_z80           3
   1839 /* Zilog eZ80 (successor of Z80 & Z180) in Z80 (16-bit address) mode.  */
   1840 #define bfd_mach_ez80_z80      4
   1841 /* Zilog eZ80 (successor of Z80 & Z180) in ADL (24-bit address) mode.  */
   1842 #define bfd_mach_ez80_adl      5
   1843 /* Z80N */
   1844 #define bfd_mach_z80n          6
   1845 /* Zilog Z80 with all undocumented instructions.  */
   1846 #define bfd_mach_z80full       7
   1847 /* GameBoy Z80 (reduced instruction set).  */
   1848 #define bfd_mach_gbz80         8
   1849 /* ASCII R800: successor with multiplication.  */
   1850 #define bfd_mach_r800          11
   1851   bfd_arch_lm32,      /* Lattice Mico32.  */
   1852 #define bfd_mach_lm32          1
   1853   bfd_arch_microblaze,/* Xilinx MicroBlaze.  */
   1854   bfd_arch_tilepro,   /* Tilera TILEPro.  */
   1855   bfd_arch_tilegx,    /* Tilera TILE-Gx.  */
   1856 #define bfd_mach_tilepro       1
   1857 #define bfd_mach_tilegx        1
   1858 #define bfd_mach_tilegx32      2
   1859   bfd_arch_aarch64,   /* AArch64.  */
   1860 #define bfd_mach_aarch64 0
   1861 #define bfd_mach_aarch64_8R    1
   1862 #define bfd_mach_aarch64_ilp32 32
   1863   bfd_arch_nios2,     /* Nios II.  */
   1864 #define bfd_mach_nios2         0
   1865 #define bfd_mach_nios2r1       1
   1866 #define bfd_mach_nios2r2       2
   1867   bfd_arch_visium,    /* Visium.  */
   1868 #define bfd_mach_visium        1
   1869   bfd_arch_wasm32,    /* WebAssembly.  */
   1870 #define bfd_mach_wasm32        1
   1871   bfd_arch_pru,       /* PRU.  */
   1872 #define bfd_mach_pru           0
   1873   bfd_arch_nfp,       /* Netronome Flow Processor */
   1874 #define bfd_mach_nfp3200       0x3200
   1875 #define bfd_mach_nfp6000       0x6000
   1876   bfd_arch_csky,      /* C-SKY.  */
   1877 #define bfd_mach_ck_unknown    0
   1878 #define bfd_mach_ck510         1
   1879 #define bfd_mach_ck610         2
   1880 #define bfd_mach_ck801         3
   1881 #define bfd_mach_ck802         4
   1882 #define bfd_mach_ck803         5
   1883 #define bfd_mach_ck807         6
   1884 #define bfd_mach_ck810         7
   1885 #define bfd_mach_ck860         8
   1886   bfd_arch_loongarch,       /* LoongArch */
   1887 #define bfd_mach_loongarch32   1
   1888 #define bfd_mach_loongarch64   2
   1889   bfd_arch_amdgcn,     /* AMDGCN */
   1890 #define bfd_mach_amdgcn_unknown 0x000
   1891 #define bfd_mach_amdgcn_gfx900  0x02c
   1892 #define bfd_mach_amdgcn_gfx904  0x02e
   1893 #define bfd_mach_amdgcn_gfx906  0x02f
   1894 #define bfd_mach_amdgcn_gfx908  0x030
   1895 #define bfd_mach_amdgcn_gfx90a  0x03f
   1896 #define bfd_mach_amdgcn_gfx1010 0x033
   1897 #define bfd_mach_amdgcn_gfx1011 0x034
   1898 #define bfd_mach_amdgcn_gfx1012 0x035
   1899 #define bfd_mach_amdgcn_gfx1030 0x036
   1900 #define bfd_mach_amdgcn_gfx1031 0x037
   1901 #define bfd_mach_amdgcn_gfx1032 0x038
   1902   bfd_arch_last
   1903   };
   1904 
   1905 typedef struct bfd_arch_info
   1906 {
   1907   int bits_per_word;
   1908   int bits_per_address;
   1909   int bits_per_byte;
   1910   enum bfd_architecture arch;
   1911   unsigned long mach;
   1912   const char *arch_name;
   1913   const char *printable_name;
   1914   unsigned int section_align_power;
   1915   /* TRUE if this is the default machine for the architecture.
   1916      The default arch should be the first entry for an arch so that
   1917      all the entries for that arch can be accessed via <<next>>.  */
   1918   bool the_default;
   1919   const struct bfd_arch_info * (*compatible) (const struct bfd_arch_info *,
   1920                                               const struct bfd_arch_info *);
   1921 
   1922   bool (*scan) (const struct bfd_arch_info *, const char *);
   1923 
   1924   /* Allocate via bfd_malloc and return a fill buffer of size COUNT.  If
   1925      IS_BIGENDIAN is TRUE, the order of bytes is big endian.  If CODE is
   1926      TRUE, the buffer contains code.  */
   1927   void *(*fill) (bfd_size_type count, bool is_bigendian, bool code);
   1928 
   1929   const struct bfd_arch_info *next;
   1930 
   1931   /* On some architectures the offset for a relocation can point into
   1932      the middle of an instruction.  This field specifies the maximum
   1933      offset such a relocation can have (in octets).  This affects the
   1934      behaviour of the disassembler, since a value greater than zero
   1935      means that it may need to disassemble an instruction twice, once
   1936      to get its length and then a second time to display it.  If the
   1937      value is negative then this has to be done for every single
   1938      instruction, regardless of the offset of the reloc.  */
   1939   signed int max_reloc_offset_into_insn;
   1940 }
   1941 bfd_arch_info_type;
   1942 
   1943 const char *bfd_printable_name (bfd *abfd);
   1944 
   1945 const bfd_arch_info_type *bfd_scan_arch (const char *string);
   1946 
   1947 const char **bfd_arch_list (void);
   1948 
   1949 const bfd_arch_info_type *bfd_arch_get_compatible
   1950    (const bfd *abfd, const bfd *bbfd, bool accept_unknowns);
   1951 
   1952 void bfd_set_arch_info (bfd *abfd, const bfd_arch_info_type *arg);
   1953 
   1954 bool bfd_default_set_arch_mach
   1955    (bfd *abfd, enum bfd_architecture arch, unsigned long mach);
   1956 
   1957 enum bfd_architecture bfd_get_arch (const bfd *abfd);
   1958 
   1959 unsigned long bfd_get_mach (const bfd *abfd);
   1960 
   1961 unsigned int bfd_arch_bits_per_byte (const bfd *abfd);
   1962 
   1963 unsigned int bfd_arch_bits_per_address (const bfd *abfd);
   1964 
   1965 const bfd_arch_info_type *bfd_get_arch_info (bfd *abfd);
   1966 
   1967 const bfd_arch_info_type *bfd_lookup_arch
   1968    (enum bfd_architecture arch, unsigned long machine);
   1969 
   1970 const char *bfd_printable_arch_mach
   1971    (enum bfd_architecture arch, unsigned long machine);
   1972 
   1973 unsigned int bfd_octets_per_byte (const bfd *abfd,
   1974     const asection *sec);
   1975 
   1976 unsigned int bfd_arch_mach_octets_per_byte
   1977    (enum bfd_architecture arch, unsigned long machine);
   1978 
   1979 /* Extracted from reloc.c.  */
   1980 
   1981 typedef enum bfd_reloc_status
   1982 {
   1983   /* No errors detected.  Note - the value 2 is used so that it
   1984      will not be mistaken for the boolean TRUE or FALSE values.  */
   1985   bfd_reloc_ok = 2,
   1986 
   1987   /* The relocation was performed, but there was an overflow.  */
   1988   bfd_reloc_overflow,
   1989 
   1990   /* The address to relocate was not within the section supplied.  */
   1991   bfd_reloc_outofrange,
   1992 
   1993   /* Used by special functions.  */
   1994   bfd_reloc_continue,
   1995 
   1996   /* Unsupported relocation size requested.  */
   1997   bfd_reloc_notsupported,
   1998 
   1999   /* Unused.  */
   2000   bfd_reloc_other,
   2001 
   2002   /* The symbol to relocate against was undefined.  */
   2003   bfd_reloc_undefined,
   2004 
   2005   /* The relocation was performed, but may not be ok.  If this type is
   2006      returned, the error_message argument to bfd_perform_relocation
   2007      will be set.  */
   2008   bfd_reloc_dangerous
   2009  }
   2010  bfd_reloc_status_type;
   2011 
   2012 typedef const struct reloc_howto_struct reloc_howto_type;
   2013 
   2014 typedef struct reloc_cache_entry
   2015 {
   2016   /* A pointer into the canonical table of pointers.  */
   2017   struct bfd_symbol **sym_ptr_ptr;
   2018 
   2019   /* offset in section.  */
   2020   bfd_size_type address;
   2021 
   2022   /* addend for relocation value.  */
   2023   bfd_vma addend;
   2024 
   2025   /* Pointer to how to perform the required relocation.  */
   2026   reloc_howto_type *howto;
   2027 
   2028 }
   2029 arelent;
   2030 
   2031 
   2032 enum complain_overflow
   2033 {
   2034   /* Do not complain on overflow.  */
   2035   complain_overflow_dont,
   2036 
   2037   /* Complain if the value overflows when considered as a signed
   2038      number one bit larger than the field.  ie. A bitfield of N bits
   2039      is allowed to represent -2**n to 2**n-1.  */
   2040   complain_overflow_bitfield,
   2041 
   2042   /* Complain if the value overflows when considered as a signed
   2043      number.  */
   2044   complain_overflow_signed,
   2045 
   2046   /* Complain if the value overflows when considered as an
   2047      unsigned number.  */
   2048   complain_overflow_unsigned
   2049 };
   2050 struct reloc_howto_struct
   2051 {
   2052   /* The type field has mainly a documentary use - the back end can
   2053      do what it wants with it, though normally the back end's idea of
   2054      an external reloc number is stored in this field.  */
   2055   unsigned int type;
   2056 
   2057   /* The size of the item to be relocated in bytes.  */
   2058   unsigned int size:4;
   2059 
   2060   /* The number of bits in the field to be relocated.  This is used
   2061      when doing overflow checking.  */
   2062   unsigned int bitsize:7;
   2063 
   2064   /* The value the final relocation is shifted right by.  This drops
   2065      unwanted data from the relocation.  */
   2066   unsigned int rightshift:6;
   2067 
   2068   /* The bit position of the reloc value in the destination.
   2069      The relocated value is left shifted by this amount.  */
   2070   unsigned int bitpos:6;
   2071 
   2072   /* What type of overflow error should be checked for when
   2073      relocating.  */
   2074   ENUM_BITFIELD (complain_overflow) complain_on_overflow:2;
   2075 
   2076   /* The relocation value should be negated before applying.  */
   2077   unsigned int negate:1;
   2078 
   2079   /* The relocation is relative to the item being relocated.  */
   2080   unsigned int pc_relative:1;
   2081 
   2082   /* Some formats record a relocation addend in the section contents
   2083      rather than with the relocation.  For ELF formats this is the
   2084      distinction between USE_REL and USE_RELA (though the code checks
   2085      for USE_REL == 1/0).  The value of this field is TRUE if the
   2086      addend is recorded with the section contents; when performing a
   2087      partial link (ld -r) the section contents (the data) will be
   2088      modified.  The value of this field is FALSE if addends are
   2089      recorded with the relocation (in arelent.addend); when performing
   2090      a partial link the relocation will be modified.
   2091      All relocations for all ELF USE_RELA targets should set this field
   2092      to FALSE (values of TRUE should be looked on with suspicion).
   2093      However, the converse is not true: not all relocations of all ELF
   2094      USE_REL targets set this field to TRUE.  Why this is so is peculiar
   2095      to each particular target.  For relocs that aren't used in partial
   2096      links (e.g. GOT stuff) it doesn't matter what this is set to.  */
   2097   unsigned int partial_inplace:1;
   2098 
   2099   /* When some formats create PC relative instructions, they leave
   2100      the value of the pc of the place being relocated in the offset
   2101      slot of the instruction, so that a PC relative relocation can
   2102      be made just by adding in an ordinary offset (e.g., sun3 a.out).
   2103      Some formats leave the displacement part of an instruction
   2104      empty (e.g., ELF); this flag signals the fact.  */
   2105   unsigned int pcrel_offset:1;
   2106 
   2107   /* src_mask selects the part of the instruction (or data) to be used
   2108      in the relocation sum.  If the target relocations don't have an
   2109      addend in the reloc, eg. ELF USE_REL, src_mask will normally equal
   2110      dst_mask to extract the addend from the section contents.  If
   2111      relocations do have an addend in the reloc, eg. ELF USE_RELA, this
   2112      field should normally be zero.  Non-zero values for ELF USE_RELA
   2113      targets should be viewed with suspicion as normally the value in
   2114      the dst_mask part of the section contents should be ignored.  */
   2115   bfd_vma src_mask;
   2116 
   2117   /* dst_mask selects which parts of the instruction (or data) are
   2118      replaced with a relocated value.  */
   2119   bfd_vma dst_mask;
   2120 
   2121   /* If this field is non null, then the supplied function is
   2122      called rather than the normal function.  This allows really
   2123      strange relocation methods to be accommodated.  */
   2124   bfd_reloc_status_type (*special_function)
   2125     (bfd *, arelent *, struct bfd_symbol *, void *, asection *,
   2126      bfd *, char **);
   2127 
   2128   /* The textual name of the relocation type.  */
   2129   const char *name;
   2130 };
   2131 
   2132 #define HOWTO_RSIZE(sz) ((sz) < 0 ? -(sz) : (sz))
   2133 #define HOWTO(type, right, size, bits, pcrel, left, ovf, func, name,   \
   2134               inplace, src_mask, dst_mask, pcrel_off)                  \
   2135   { (unsigned) type, HOWTO_RSIZE (size), bits, right, left, ovf,       \
   2136     size < 0, pcrel, inplace, pcrel_off, src_mask, dst_mask, func, name }
   2137 #define EMPTY_HOWTO(C) \
   2138   HOWTO ((C), 0, 1, 0, false, 0, complain_overflow_dont, NULL, \
   2139          NULL, false, 0, 0, false)
   2140 
   2141 static inline unsigned int
   2142 bfd_get_reloc_size (reloc_howto_type *howto)
   2143 {
   2144   return howto->size;
   2145 }
   2146 
   2147 typedef struct relent_chain
   2148 {
   2149   arelent relent;
   2150   struct relent_chain *next;
   2151 }
   2152 arelent_chain;
   2153 
   2154 bfd_reloc_status_type bfd_check_overflow
   2155    (enum complain_overflow how,
   2156     unsigned int bitsize,
   2157     unsigned int rightshift,
   2158     unsigned int addrsize,
   2159     bfd_vma relocation);
   2160 
   2161 bool bfd_reloc_offset_in_range
   2162    (reloc_howto_type *howto,
   2163     bfd *abfd,
   2164     asection *section,
   2165     bfd_size_type offset);
   2166 
   2167 bfd_reloc_status_type bfd_perform_relocation
   2168    (bfd *abfd,
   2169     arelent *reloc_entry,
   2170     void *data,
   2171     asection *input_section,
   2172     bfd *output_bfd,
   2173     char **error_message);
   2174 
   2175 bfd_reloc_status_type bfd_install_relocation
   2176    (bfd *abfd,
   2177     arelent *reloc_entry,
   2178     void *data, bfd_vma data_start,
   2179     asection *input_section,
   2180     char **error_message);
   2181 
   2182 enum bfd_reloc_code_real {
   2183   _dummy_first_bfd_reloc_code_real,
   2184 
   2185 
   2186 /* Basic absolute relocations of N bits.  */
   2187   BFD_RELOC_64,
   2188   BFD_RELOC_32,
   2189   BFD_RELOC_26,
   2190   BFD_RELOC_24,
   2191   BFD_RELOC_16,
   2192   BFD_RELOC_14,
   2193   BFD_RELOC_8,
   2194 
   2195 /* PC-relative relocations.  Sometimes these are relative to the address
   2196 of the relocation itself; sometimes they are relative to the start of
   2197 the section containing the relocation.  It depends on the specific target.  */
   2198   BFD_RELOC_64_PCREL,
   2199   BFD_RELOC_32_PCREL,
   2200   BFD_RELOC_24_PCREL,
   2201   BFD_RELOC_16_PCREL,
   2202   BFD_RELOC_12_PCREL,
   2203   BFD_RELOC_8_PCREL,
   2204 
   2205 /* Section relative relocations.  Some targets need this for DWARF2.  */
   2206   BFD_RELOC_32_SECREL,
   2207   BFD_RELOC_16_SECIDX,
   2208 
   2209 /* For ELF.  */
   2210   BFD_RELOC_32_GOT_PCREL,
   2211   BFD_RELOC_16_GOT_PCREL,
   2212   BFD_RELOC_8_GOT_PCREL,
   2213   BFD_RELOC_32_GOTOFF,
   2214   BFD_RELOC_16_GOTOFF,
   2215   BFD_RELOC_LO16_GOTOFF,
   2216   BFD_RELOC_HI16_GOTOFF,
   2217   BFD_RELOC_HI16_S_GOTOFF,
   2218   BFD_RELOC_8_GOTOFF,
   2219   BFD_RELOC_64_PLT_PCREL,
   2220   BFD_RELOC_32_PLT_PCREL,
   2221   BFD_RELOC_24_PLT_PCREL,
   2222   BFD_RELOC_16_PLT_PCREL,
   2223   BFD_RELOC_8_PLT_PCREL,
   2224   BFD_RELOC_64_PLTOFF,
   2225   BFD_RELOC_32_PLTOFF,
   2226   BFD_RELOC_16_PLTOFF,
   2227   BFD_RELOC_LO16_PLTOFF,
   2228   BFD_RELOC_HI16_PLTOFF,
   2229   BFD_RELOC_HI16_S_PLTOFF,
   2230   BFD_RELOC_8_PLTOFF,
   2231 
   2232 /* Size relocations.  */
   2233   BFD_RELOC_SIZE32,
   2234   BFD_RELOC_SIZE64,
   2235 
   2236 /* Relocations used by 68K ELF.  */
   2237   BFD_RELOC_68K_GLOB_DAT,
   2238   BFD_RELOC_68K_JMP_SLOT,
   2239   BFD_RELOC_68K_RELATIVE,
   2240   BFD_RELOC_68K_TLS_GD32,
   2241   BFD_RELOC_68K_TLS_GD16,
   2242   BFD_RELOC_68K_TLS_GD8,
   2243   BFD_RELOC_68K_TLS_LDM32,
   2244   BFD_RELOC_68K_TLS_LDM16,
   2245   BFD_RELOC_68K_TLS_LDM8,
   2246   BFD_RELOC_68K_TLS_LDO32,
   2247   BFD_RELOC_68K_TLS_LDO16,
   2248   BFD_RELOC_68K_TLS_LDO8,
   2249   BFD_RELOC_68K_TLS_IE32,
   2250   BFD_RELOC_68K_TLS_IE16,
   2251   BFD_RELOC_68K_TLS_IE8,
   2252   BFD_RELOC_68K_TLS_LE32,
   2253   BFD_RELOC_68K_TLS_LE16,
   2254   BFD_RELOC_68K_TLS_LE8,
   2255 
   2256 /* Linkage-table relative.  */
   2257   BFD_RELOC_32_BASEREL,
   2258   BFD_RELOC_16_BASEREL,
   2259   BFD_RELOC_LO16_BASEREL,
   2260   BFD_RELOC_HI16_BASEREL,
   2261   BFD_RELOC_HI16_S_BASEREL,
   2262   BFD_RELOC_8_BASEREL,
   2263   BFD_RELOC_RVA,
   2264 
   2265 /* Absolute 8-bit relocation, but used to form an address like 0xFFnn.  */
   2266   BFD_RELOC_8_FFnn,
   2267 
   2268 /* These PC-relative relocations are stored as word displacements --
   2269 i.e., byte displacements shifted right two bits.  The 30-bit word
   2270 displacement (<<32_PCREL_S2>> -- 32 bits, shifted 2) is used on the
   2271 SPARC.  (SPARC tools generally refer to this as <<WDISP30>>.)  The
   2272 signed 16-bit displacement is used on the MIPS, and the 23-bit
   2273 displacement is used on the Alpha.  */
   2274   BFD_RELOC_32_PCREL_S2,
   2275   BFD_RELOC_16_PCREL_S2,
   2276   BFD_RELOC_23_PCREL_S2,
   2277 
   2278 /* High 22 bits and low 10 bits of 32-bit value, placed into lower bits of
   2279 the target word.  These are used on the SPARC.  */
   2280   BFD_RELOC_HI22,
   2281   BFD_RELOC_LO10,
   2282 
   2283 /* For systems that allocate a Global Pointer register, these are
   2284 displacements off that register.  These relocation types are
   2285 handled specially, because the value the register will have is
   2286 decided relatively late.  */
   2287   BFD_RELOC_GPREL16,
   2288   BFD_RELOC_GPREL32,
   2289 
   2290 /* SPARC ELF relocations.  There is probably some overlap with other
   2291 relocation types already defined.  */
   2292   BFD_RELOC_NONE,
   2293   BFD_RELOC_SPARC_WDISP22,
   2294   BFD_RELOC_SPARC22,
   2295   BFD_RELOC_SPARC13,
   2296   BFD_RELOC_SPARC_GOT10,
   2297   BFD_RELOC_SPARC_GOT13,
   2298   BFD_RELOC_SPARC_GOT22,
   2299   BFD_RELOC_SPARC_PC10,
   2300   BFD_RELOC_SPARC_PC22,
   2301   BFD_RELOC_SPARC_WPLT30,
   2302   BFD_RELOC_SPARC_COPY,
   2303   BFD_RELOC_SPARC_GLOB_DAT,
   2304   BFD_RELOC_SPARC_JMP_SLOT,
   2305   BFD_RELOC_SPARC_RELATIVE,
   2306   BFD_RELOC_SPARC_UA16,
   2307   BFD_RELOC_SPARC_UA32,
   2308   BFD_RELOC_SPARC_UA64,
   2309   BFD_RELOC_SPARC_GOTDATA_HIX22,
   2310   BFD_RELOC_SPARC_GOTDATA_LOX10,
   2311   BFD_RELOC_SPARC_GOTDATA_OP_HIX22,
   2312   BFD_RELOC_SPARC_GOTDATA_OP_LOX10,
   2313   BFD_RELOC_SPARC_GOTDATA_OP,
   2314   BFD_RELOC_SPARC_JMP_IREL,
   2315   BFD_RELOC_SPARC_IRELATIVE,
   2316 
   2317 /* I think these are specific to SPARC a.out (e.g., Sun 4).  */
   2318   BFD_RELOC_SPARC_BASE13,
   2319   BFD_RELOC_SPARC_BASE22,
   2320 
   2321 /* SPARC64 relocations  */
   2322 #define BFD_RELOC_SPARC_64 BFD_RELOC_64
   2323   BFD_RELOC_SPARC_10,
   2324   BFD_RELOC_SPARC_11,
   2325   BFD_RELOC_SPARC_OLO10,
   2326   BFD_RELOC_SPARC_HH22,
   2327   BFD_RELOC_SPARC_HM10,
   2328   BFD_RELOC_SPARC_LM22,
   2329   BFD_RELOC_SPARC_PC_HH22,
   2330   BFD_RELOC_SPARC_PC_HM10,
   2331   BFD_RELOC_SPARC_PC_LM22,
   2332   BFD_RELOC_SPARC_WDISP16,
   2333   BFD_RELOC_SPARC_WDISP19,
   2334   BFD_RELOC_SPARC_7,
   2335   BFD_RELOC_SPARC_6,
   2336   BFD_RELOC_SPARC_5,
   2337 #define BFD_RELOC_SPARC_DISP64 BFD_RELOC_64_PCREL
   2338   BFD_RELOC_SPARC_PLT32,
   2339   BFD_RELOC_SPARC_PLT64,
   2340   BFD_RELOC_SPARC_HIX22,
   2341   BFD_RELOC_SPARC_LOX10,
   2342   BFD_RELOC_SPARC_H44,
   2343   BFD_RELOC_SPARC_M44,
   2344   BFD_RELOC_SPARC_L44,
   2345   BFD_RELOC_SPARC_REGISTER,
   2346   BFD_RELOC_SPARC_H34,
   2347   BFD_RELOC_SPARC_SIZE32,
   2348   BFD_RELOC_SPARC_SIZE64,
   2349   BFD_RELOC_SPARC_WDISP10,
   2350 
   2351 /* SPARC little endian relocation  */
   2352   BFD_RELOC_SPARC_REV32,
   2353 
   2354 /* SPARC TLS relocations  */
   2355   BFD_RELOC_SPARC_TLS_GD_HI22,
   2356   BFD_RELOC_SPARC_TLS_GD_LO10,
   2357   BFD_RELOC_SPARC_TLS_GD_ADD,
   2358   BFD_RELOC_SPARC_TLS_GD_CALL,
   2359   BFD_RELOC_SPARC_TLS_LDM_HI22,
   2360   BFD_RELOC_SPARC_TLS_LDM_LO10,
   2361   BFD_RELOC_SPARC_TLS_LDM_ADD,
   2362   BFD_RELOC_SPARC_TLS_LDM_CALL,
   2363   BFD_RELOC_SPARC_TLS_LDO_HIX22,
   2364   BFD_RELOC_SPARC_TLS_LDO_LOX10,
   2365   BFD_RELOC_SPARC_TLS_LDO_ADD,
   2366   BFD_RELOC_SPARC_TLS_IE_HI22,
   2367   BFD_RELOC_SPARC_TLS_IE_LO10,
   2368   BFD_RELOC_SPARC_TLS_IE_LD,
   2369   BFD_RELOC_SPARC_TLS_IE_LDX,
   2370   BFD_RELOC_SPARC_TLS_IE_ADD,
   2371   BFD_RELOC_SPARC_TLS_LE_HIX22,
   2372   BFD_RELOC_SPARC_TLS_LE_LOX10,
   2373   BFD_RELOC_SPARC_TLS_DTPMOD32,
   2374   BFD_RELOC_SPARC_TLS_DTPMOD64,
   2375   BFD_RELOC_SPARC_TLS_DTPOFF32,
   2376   BFD_RELOC_SPARC_TLS_DTPOFF64,
   2377   BFD_RELOC_SPARC_TLS_TPOFF32,
   2378   BFD_RELOC_SPARC_TLS_TPOFF64,
   2379 
   2380 /* SPU Relocations.  */
   2381   BFD_RELOC_SPU_IMM7,
   2382   BFD_RELOC_SPU_IMM8,
   2383   BFD_RELOC_SPU_IMM10,
   2384   BFD_RELOC_SPU_IMM10W,
   2385   BFD_RELOC_SPU_IMM16,
   2386   BFD_RELOC_SPU_IMM16W,
   2387   BFD_RELOC_SPU_IMM18,
   2388   BFD_RELOC_SPU_PCREL9a,
   2389   BFD_RELOC_SPU_PCREL9b,
   2390   BFD_RELOC_SPU_PCREL16,
   2391   BFD_RELOC_SPU_LO16,
   2392   BFD_RELOC_SPU_HI16,
   2393   BFD_RELOC_SPU_PPU32,
   2394   BFD_RELOC_SPU_PPU64,
   2395   BFD_RELOC_SPU_ADD_PIC,
   2396 
   2397 /* Alpha ECOFF and ELF relocations.  Some of these treat the symbol or
   2398 "addend" in some special way.
   2399 For GPDISP_HI16 ("gpdisp") relocations, the symbol is ignored when
   2400 writing; when reading, it will be the absolute section symbol.  The
   2401 addend is the displacement in bytes of the "lda" instruction from
   2402 the "ldah" instruction (which is at the address of this reloc).  */
   2403   BFD_RELOC_ALPHA_GPDISP_HI16,
   2404 
   2405 /* For GPDISP_LO16 ("ignore") relocations, the symbol is handled as
   2406 with GPDISP_HI16 relocs.  The addend is ignored when writing the
   2407 relocations out, and is filled in with the file's GP value on
   2408 reading, for convenience.  */
   2409   BFD_RELOC_ALPHA_GPDISP_LO16,
   2410 
   2411 /* The ELF GPDISP relocation is exactly the same as the GPDISP_HI16
   2412 relocation except that there is no accompanying GPDISP_LO16
   2413 relocation.  */
   2414   BFD_RELOC_ALPHA_GPDISP,
   2415 
   2416 /* The Alpha LITERAL/LITUSE relocs are produced by a symbol reference;
   2417 the assembler turns it into a LDQ instruction to load the address of
   2418 the symbol, and then fills in a register in the real instruction.
   2419 
   2420 The LITERAL reloc, at the LDQ instruction, refers to the .lita
   2421 section symbol.  The addend is ignored when writing, but is filled
   2422 in with the file's GP value on reading, for convenience, as with the
   2423 GPDISP_LO16 reloc.
   2424 
   2425 The ELF_LITERAL reloc is somewhere between 16_GOTOFF and GPDISP_LO16.
   2426 It should refer to the symbol to be referenced, as with 16_GOTOFF,
   2427 but it generates output not based on the position within the .got
   2428 section, but relative to the GP value chosen for the file during the
   2429 final link stage.
   2430 
   2431 The LITUSE reloc, on the instruction using the loaded address, gives
   2432 information to the linker that it might be able to use to optimize
   2433 away some literal section references.  The symbol is ignored (read
   2434 as the absolute section symbol), and the "addend" indicates the type
   2435 of instruction using the register:
   2436 1 - "memory" fmt insn
   2437 2 - byte-manipulation (byte offset reg)
   2438 3 - jsr (target of branch)  */
   2439   BFD_RELOC_ALPHA_LITERAL,
   2440   BFD_RELOC_ALPHA_ELF_LITERAL,
   2441   BFD_RELOC_ALPHA_LITUSE,
   2442 
   2443 /* The HINT relocation indicates a value that should be filled into the
   2444 "hint" field of a jmp/jsr/ret instruction, for possible branch-
   2445 prediction logic which may be provided on some processors.  */
   2446   BFD_RELOC_ALPHA_HINT,
   2447 
   2448 /* The LINKAGE relocation outputs a linkage pair in the object file,
   2449 which is filled by the linker.  */
   2450   BFD_RELOC_ALPHA_LINKAGE,
   2451 
   2452 /* The CODEADDR relocation outputs a STO_CA in the object file,
   2453 which is filled by the linker.  */
   2454   BFD_RELOC_ALPHA_CODEADDR,
   2455 
   2456 /* The GPREL_HI/LO relocations together form a 32-bit offset from the
   2457 GP register.  */
   2458   BFD_RELOC_ALPHA_GPREL_HI16,
   2459   BFD_RELOC_ALPHA_GPREL_LO16,
   2460 
   2461 /* Like BFD_RELOC_23_PCREL_S2, except that the source and target must
   2462 share a common GP, and the target address is adjusted for
   2463 STO_ALPHA_STD_GPLOAD.  */
   2464   BFD_RELOC_ALPHA_BRSGP,
   2465 
   2466 /* The NOP relocation outputs a NOP if the longword displacement
   2467 between two procedure entry points is < 2^21.  */
   2468   BFD_RELOC_ALPHA_NOP,
   2469 
   2470 /* The BSR relocation outputs a BSR if the longword displacement
   2471 between two procedure entry points is < 2^21.  */
   2472   BFD_RELOC_ALPHA_BSR,
   2473 
   2474 /* The LDA relocation outputs a LDA if the longword displacement
   2475 between two procedure entry points is < 2^16.  */
   2476   BFD_RELOC_ALPHA_LDA,
   2477 
   2478 /* The BOH relocation outputs a BSR if the longword displacement
   2479 between two procedure entry points is < 2^21, or else a hint.  */
   2480   BFD_RELOC_ALPHA_BOH,
   2481 
   2482 /* Alpha thread-local storage relocations.  */
   2483   BFD_RELOC_ALPHA_TLSGD,
   2484   BFD_RELOC_ALPHA_TLSLDM,
   2485   BFD_RELOC_ALPHA_DTPMOD64,
   2486   BFD_RELOC_ALPHA_GOTDTPREL16,
   2487   BFD_RELOC_ALPHA_DTPREL64,
   2488   BFD_RELOC_ALPHA_DTPREL_HI16,
   2489   BFD_RELOC_ALPHA_DTPREL_LO16,
   2490   BFD_RELOC_ALPHA_DTPREL16,
   2491   BFD_RELOC_ALPHA_GOTTPREL16,
   2492   BFD_RELOC_ALPHA_TPREL64,
   2493   BFD_RELOC_ALPHA_TPREL_HI16,
   2494   BFD_RELOC_ALPHA_TPREL_LO16,
   2495   BFD_RELOC_ALPHA_TPREL16,
   2496 
   2497 /* The MIPS jump instruction.  */
   2498   BFD_RELOC_MIPS_JMP,
   2499   BFD_RELOC_MICROMIPS_JMP,
   2500 
   2501 /* The MIPS16 jump instruction.  */
   2502   BFD_RELOC_MIPS16_JMP,
   2503 
   2504 /* MIPS16 GP relative reloc.  */
   2505   BFD_RELOC_MIPS16_GPREL,
   2506 
   2507 /* High 16 bits of 32-bit value; simple reloc.  */
   2508   BFD_RELOC_HI16,
   2509 
   2510 /* High 16 bits of 32-bit value but the low 16 bits will be sign
   2511 extended and added to form the final result.  If the low 16
   2512 bits form a negative number, we need to add one to the high value
   2513 to compensate for the borrow when the low bits are added.  */
   2514   BFD_RELOC_HI16_S,
   2515 
   2516 /* Low 16 bits.  */
   2517   BFD_RELOC_LO16,
   2518 
   2519 /* High 16 bits of 32-bit pc-relative value  */
   2520   BFD_RELOC_HI16_PCREL,
   2521 
   2522 /* High 16 bits of 32-bit pc-relative value, adjusted  */
   2523   BFD_RELOC_HI16_S_PCREL,
   2524 
   2525 /* Low 16 bits of pc-relative value  */
   2526   BFD_RELOC_LO16_PCREL,
   2527 
   2528 /* Equivalent of BFD_RELOC_MIPS_*, but with the MIPS16 layout of
   2529 16-bit immediate fields  */
   2530   BFD_RELOC_MIPS16_GOT16,
   2531   BFD_RELOC_MIPS16_CALL16,
   2532 
   2533 /* MIPS16 high 16 bits of 32-bit value.  */
   2534   BFD_RELOC_MIPS16_HI16,
   2535 
   2536 /* MIPS16 high 16 bits of 32-bit value but the low 16 bits will be sign
   2537 extended and added to form the final result.  If the low 16
   2538 bits form a negative number, we need to add one to the high value
   2539 to compensate for the borrow when the low bits are added.  */
   2540   BFD_RELOC_MIPS16_HI16_S,
   2541 
   2542 /* MIPS16 low 16 bits.  */
   2543   BFD_RELOC_MIPS16_LO16,
   2544 
   2545 /* MIPS16 TLS relocations  */
   2546   BFD_RELOC_MIPS16_TLS_GD,
   2547   BFD_RELOC_MIPS16_TLS_LDM,
   2548   BFD_RELOC_MIPS16_TLS_DTPREL_HI16,
   2549   BFD_RELOC_MIPS16_TLS_DTPREL_LO16,
   2550   BFD_RELOC_MIPS16_TLS_GOTTPREL,
   2551   BFD_RELOC_MIPS16_TLS_TPREL_HI16,
   2552   BFD_RELOC_MIPS16_TLS_TPREL_LO16,
   2553 
   2554 /* Relocation against a MIPS literal section.  */
   2555   BFD_RELOC_MIPS_LITERAL,
   2556   BFD_RELOC_MICROMIPS_LITERAL,
   2557 
   2558 /* microMIPS PC-relative relocations.  */
   2559   BFD_RELOC_MICROMIPS_7_PCREL_S1,
   2560   BFD_RELOC_MICROMIPS_10_PCREL_S1,
   2561   BFD_RELOC_MICROMIPS_16_PCREL_S1,
   2562 
   2563 /* MIPS16 PC-relative relocation.  */
   2564   BFD_RELOC_MIPS16_16_PCREL_S1,
   2565 
   2566 /* MIPS PC-relative relocations.  */
   2567   BFD_RELOC_MIPS_21_PCREL_S2,
   2568   BFD_RELOC_MIPS_26_PCREL_S2,
   2569   BFD_RELOC_MIPS_18_PCREL_S3,
   2570   BFD_RELOC_MIPS_19_PCREL_S2,
   2571 
   2572 /* microMIPS versions of generic BFD relocs.  */
   2573   BFD_RELOC_MICROMIPS_GPREL16,
   2574   BFD_RELOC_MICROMIPS_HI16,
   2575   BFD_RELOC_MICROMIPS_HI16_S,
   2576   BFD_RELOC_MICROMIPS_LO16,
   2577 
   2578 /* MIPS ELF relocations.  */
   2579   BFD_RELOC_MIPS_GOT16,
   2580   BFD_RELOC_MICROMIPS_GOT16,
   2581   BFD_RELOC_MIPS_CALL16,
   2582   BFD_RELOC_MICROMIPS_CALL16,
   2583   BFD_RELOC_MIPS_GOT_HI16,
   2584   BFD_RELOC_MICROMIPS_GOT_HI16,
   2585   BFD_RELOC_MIPS_GOT_LO16,
   2586   BFD_RELOC_MICROMIPS_GOT_LO16,
   2587   BFD_RELOC_MIPS_CALL_HI16,
   2588   BFD_RELOC_MICROMIPS_CALL_HI16,
   2589   BFD_RELOC_MIPS_CALL_LO16,
   2590   BFD_RELOC_MICROMIPS_CALL_LO16,
   2591   BFD_RELOC_MIPS_SUB,
   2592   BFD_RELOC_MICROMIPS_SUB,
   2593   BFD_RELOC_MIPS_GOT_PAGE,
   2594   BFD_RELOC_MICROMIPS_GOT_PAGE,
   2595   BFD_RELOC_MIPS_GOT_OFST,
   2596   BFD_RELOC_MICROMIPS_GOT_OFST,
   2597   BFD_RELOC_MIPS_GOT_DISP,
   2598   BFD_RELOC_MICROMIPS_GOT_DISP,
   2599   BFD_RELOC_MIPS_SHIFT5,
   2600   BFD_RELOC_MIPS_SHIFT6,
   2601   BFD_RELOC_MIPS_INSERT_A,
   2602   BFD_RELOC_MIPS_INSERT_B,
   2603   BFD_RELOC_MIPS_DELETE,
   2604   BFD_RELOC_MIPS_HIGHEST,
   2605   BFD_RELOC_MICROMIPS_HIGHEST,
   2606   BFD_RELOC_MIPS_HIGHER,
   2607   BFD_RELOC_MICROMIPS_HIGHER,
   2608   BFD_RELOC_MIPS_SCN_DISP,
   2609   BFD_RELOC_MICROMIPS_SCN_DISP,
   2610   BFD_RELOC_MIPS_16,
   2611   BFD_RELOC_MIPS_RELGOT,
   2612   BFD_RELOC_MIPS_JALR,
   2613   BFD_RELOC_MICROMIPS_JALR,
   2614   BFD_RELOC_MIPS_TLS_DTPMOD32,
   2615   BFD_RELOC_MIPS_TLS_DTPREL32,
   2616   BFD_RELOC_MIPS_TLS_DTPMOD64,
   2617   BFD_RELOC_MIPS_TLS_DTPREL64,
   2618   BFD_RELOC_MIPS_TLS_GD,
   2619   BFD_RELOC_MICROMIPS_TLS_GD,
   2620   BFD_RELOC_MIPS_TLS_LDM,
   2621   BFD_RELOC_MICROMIPS_TLS_LDM,
   2622   BFD_RELOC_MIPS_TLS_DTPREL_HI16,
   2623   BFD_RELOC_MICROMIPS_TLS_DTPREL_HI16,
   2624   BFD_RELOC_MIPS_TLS_DTPREL_LO16,
   2625   BFD_RELOC_MICROMIPS_TLS_DTPREL_LO16,
   2626   BFD_RELOC_MIPS_TLS_GOTTPREL,
   2627   BFD_RELOC_MICROMIPS_TLS_GOTTPREL,
   2628   BFD_RELOC_MIPS_TLS_TPREL32,
   2629   BFD_RELOC_MIPS_TLS_TPREL64,
   2630   BFD_RELOC_MIPS_TLS_TPREL_HI16,
   2631   BFD_RELOC_MICROMIPS_TLS_TPREL_HI16,
   2632   BFD_RELOC_MIPS_TLS_TPREL_LO16,
   2633   BFD_RELOC_MICROMIPS_TLS_TPREL_LO16,
   2634   BFD_RELOC_MIPS_EH,
   2635 
   2636 
   2637 /* MIPS ELF relocations (VxWorks and PLT extensions).  */
   2638   BFD_RELOC_MIPS_COPY,
   2639   BFD_RELOC_MIPS_JUMP_SLOT,
   2640 
   2641 
   2642 /* Moxie ELF relocations.  */
   2643   BFD_RELOC_MOXIE_10_PCREL,
   2644 
   2645 
   2646 /* FT32 ELF relocations.  */
   2647   BFD_RELOC_FT32_10,
   2648   BFD_RELOC_FT32_20,
   2649   BFD_RELOC_FT32_17,
   2650   BFD_RELOC_FT32_18,
   2651   BFD_RELOC_FT32_RELAX,
   2652   BFD_RELOC_FT32_SC0,
   2653   BFD_RELOC_FT32_SC1,
   2654   BFD_RELOC_FT32_15,
   2655   BFD_RELOC_FT32_DIFF32,
   2656 
   2657 
   2658 /* Fujitsu Frv Relocations.  */
   2659   BFD_RELOC_FRV_LABEL16,
   2660   BFD_RELOC_FRV_LABEL24,
   2661   BFD_RELOC_FRV_LO16,
   2662   BFD_RELOC_FRV_HI16,
   2663   BFD_RELOC_FRV_GPREL12,
   2664   BFD_RELOC_FRV_GPRELU12,
   2665   BFD_RELOC_FRV_GPREL32,
   2666   BFD_RELOC_FRV_GPRELHI,
   2667   BFD_RELOC_FRV_GPRELLO,
   2668   BFD_RELOC_FRV_GOT12,
   2669   BFD_RELOC_FRV_GOTHI,
   2670   BFD_RELOC_FRV_GOTLO,
   2671   BFD_RELOC_FRV_FUNCDESC,
   2672   BFD_RELOC_FRV_FUNCDESC_GOT12,
   2673   BFD_RELOC_FRV_FUNCDESC_GOTHI,
   2674   BFD_RELOC_FRV_FUNCDESC_GOTLO,
   2675   BFD_RELOC_FRV_FUNCDESC_VALUE,
   2676   BFD_RELOC_FRV_FUNCDESC_GOTOFF12,
   2677   BFD_RELOC_FRV_FUNCDESC_GOTOFFHI,
   2678   BFD_RELOC_FRV_FUNCDESC_GOTOFFLO,
   2679   BFD_RELOC_FRV_GOTOFF12,
   2680   BFD_RELOC_FRV_GOTOFFHI,
   2681   BFD_RELOC_FRV_GOTOFFLO,
   2682   BFD_RELOC_FRV_GETTLSOFF,
   2683   BFD_RELOC_FRV_TLSDESC_VALUE,
   2684   BFD_RELOC_FRV_GOTTLSDESC12,
   2685   BFD_RELOC_FRV_GOTTLSDESCHI,
   2686   BFD_RELOC_FRV_GOTTLSDESCLO,
   2687   BFD_RELOC_FRV_TLSMOFF12,
   2688   BFD_RELOC_FRV_TLSMOFFHI,
   2689   BFD_RELOC_FRV_TLSMOFFLO,
   2690   BFD_RELOC_FRV_GOTTLSOFF12,
   2691   BFD_RELOC_FRV_GOTTLSOFFHI,
   2692   BFD_RELOC_FRV_GOTTLSOFFLO,
   2693   BFD_RELOC_FRV_TLSOFF,
   2694   BFD_RELOC_FRV_TLSDESC_RELAX,
   2695   BFD_RELOC_FRV_GETTLSOFF_RELAX,
   2696   BFD_RELOC_FRV_TLSOFF_RELAX,
   2697   BFD_RELOC_FRV_TLSMOFF,
   2698 
   2699 
   2700 /* This is a 24bit GOT-relative reloc for the mn10300.  */
   2701   BFD_RELOC_MN10300_GOTOFF24,
   2702 
   2703 /* This is a 32bit GOT-relative reloc for the mn10300, offset by two bytes
   2704 in the instruction.  */
   2705   BFD_RELOC_MN10300_GOT32,
   2706 
   2707 /* This is a 24bit GOT-relative reloc for the mn10300, offset by two bytes
   2708 in the instruction.  */
   2709   BFD_RELOC_MN10300_GOT24,
   2710 
   2711 /* This is a 16bit GOT-relative reloc for the mn10300, offset by two bytes
   2712 in the instruction.  */
   2713   BFD_RELOC_MN10300_GOT16,
   2714 
   2715 /* Copy symbol at runtime.  */
   2716   BFD_RELOC_MN10300_COPY,
   2717 
   2718 /* Create GOT entry.  */
   2719   BFD_RELOC_MN10300_GLOB_DAT,
   2720 
   2721 /* Create PLT entry.  */
   2722   BFD_RELOC_MN10300_JMP_SLOT,
   2723 
   2724 /* Adjust by program base.  */
   2725   BFD_RELOC_MN10300_RELATIVE,
   2726 
   2727 /* Together with another reloc targeted at the same location,
   2728 allows for a value that is the difference of two symbols
   2729 in the same section.  */
   2730   BFD_RELOC_MN10300_SYM_DIFF,
   2731 
   2732 /* The addend of this reloc is an alignment power that must
   2733 be honoured at the offset's location, regardless of linker
   2734 relaxation.  */
   2735   BFD_RELOC_MN10300_ALIGN,
   2736 
   2737 /* Various TLS-related relocations.  */
   2738   BFD_RELOC_MN10300_TLS_GD,
   2739   BFD_RELOC_MN10300_TLS_LD,
   2740   BFD_RELOC_MN10300_TLS_LDO,
   2741   BFD_RELOC_MN10300_TLS_GOTIE,
   2742   BFD_RELOC_MN10300_TLS_IE,
   2743   BFD_RELOC_MN10300_TLS_LE,
   2744   BFD_RELOC_MN10300_TLS_DTPMOD,
   2745   BFD_RELOC_MN10300_TLS_DTPOFF,
   2746   BFD_RELOC_MN10300_TLS_TPOFF,
   2747 
   2748 /* This is a 32bit pcrel reloc for the mn10300, offset by two bytes in the
   2749 instruction.  */
   2750   BFD_RELOC_MN10300_32_PCREL,
   2751 
   2752 /* This is a 16bit pcrel reloc for the mn10300, offset by two bytes in the
   2753 instruction.  */
   2754   BFD_RELOC_MN10300_16_PCREL,
   2755 
   2756 
   2757 /* i386/elf relocations  */
   2758   BFD_RELOC_386_GOT32,
   2759   BFD_RELOC_386_PLT32,
   2760   BFD_RELOC_386_COPY,
   2761   BFD_RELOC_386_GLOB_DAT,
   2762   BFD_RELOC_386_JUMP_SLOT,
   2763   BFD_RELOC_386_RELATIVE,
   2764   BFD_RELOC_386_GOTOFF,
   2765   BFD_RELOC_386_GOTPC,
   2766   BFD_RELOC_386_TLS_TPOFF,
   2767   BFD_RELOC_386_TLS_IE,
   2768   BFD_RELOC_386_TLS_GOTIE,
   2769   BFD_RELOC_386_TLS_LE,
   2770   BFD_RELOC_386_TLS_GD,
   2771   BFD_RELOC_386_TLS_LDM,
   2772   BFD_RELOC_386_TLS_LDO_32,
   2773   BFD_RELOC_386_TLS_IE_32,
   2774   BFD_RELOC_386_TLS_LE_32,
   2775   BFD_RELOC_386_TLS_DTPMOD32,
   2776   BFD_RELOC_386_TLS_DTPOFF32,
   2777   BFD_RELOC_386_TLS_TPOFF32,
   2778   BFD_RELOC_386_TLS_GOTDESC,
   2779   BFD_RELOC_386_TLS_DESC_CALL,
   2780   BFD_RELOC_386_TLS_DESC,
   2781   BFD_RELOC_386_IRELATIVE,
   2782   BFD_RELOC_386_GOT32X,
   2783 
   2784 /* x86-64/elf relocations  */
   2785   BFD_RELOC_X86_64_GOT32,
   2786   BFD_RELOC_X86_64_PLT32,
   2787   BFD_RELOC_X86_64_COPY,
   2788   BFD_RELOC_X86_64_GLOB_DAT,
   2789   BFD_RELOC_X86_64_JUMP_SLOT,
   2790   BFD_RELOC_X86_64_RELATIVE,
   2791   BFD_RELOC_X86_64_GOTPCREL,
   2792   BFD_RELOC_X86_64_32S,
   2793   BFD_RELOC_X86_64_DTPMOD64,
   2794   BFD_RELOC_X86_64_DTPOFF64,
   2795   BFD_RELOC_X86_64_TPOFF64,
   2796   BFD_RELOC_X86_64_TLSGD,
   2797   BFD_RELOC_X86_64_TLSLD,
   2798   BFD_RELOC_X86_64_DTPOFF32,
   2799   BFD_RELOC_X86_64_GOTTPOFF,
   2800   BFD_RELOC_X86_64_TPOFF32,
   2801   BFD_RELOC_X86_64_GOTOFF64,
   2802   BFD_RELOC_X86_64_GOTPC32,
   2803   BFD_RELOC_X86_64_GOT64,
   2804   BFD_RELOC_X86_64_GOTPCREL64,
   2805   BFD_RELOC_X86_64_GOTPC64,
   2806   BFD_RELOC_X86_64_GOTPLT64,
   2807   BFD_RELOC_X86_64_PLTOFF64,
   2808   BFD_RELOC_X86_64_GOTPC32_TLSDESC,
   2809   BFD_RELOC_X86_64_TLSDESC_CALL,
   2810   BFD_RELOC_X86_64_TLSDESC,
   2811   BFD_RELOC_X86_64_IRELATIVE,
   2812   BFD_RELOC_X86_64_PC32_BND,
   2813   BFD_RELOC_X86_64_PLT32_BND,
   2814   BFD_RELOC_X86_64_GOTPCRELX,
   2815   BFD_RELOC_X86_64_REX_GOTPCRELX,
   2816 
   2817 /* ns32k relocations  */
   2818   BFD_RELOC_NS32K_IMM_8,
   2819   BFD_RELOC_NS32K_IMM_16,
   2820   BFD_RELOC_NS32K_IMM_32,
   2821   BFD_RELOC_NS32K_IMM_8_PCREL,
   2822   BFD_RELOC_NS32K_IMM_16_PCREL,
   2823   BFD_RELOC_NS32K_IMM_32_PCREL,
   2824   BFD_RELOC_NS32K_DISP_8,
   2825   BFD_RELOC_NS32K_DISP_16,
   2826   BFD_RELOC_NS32K_DISP_32,
   2827   BFD_RELOC_NS32K_DISP_8_PCREL,
   2828   BFD_RELOC_NS32K_DISP_16_PCREL,
   2829   BFD_RELOC_NS32K_DISP_32_PCREL,
   2830 
   2831 /* PDP11 relocations  */
   2832   BFD_RELOC_PDP11_DISP_8_PCREL,
   2833   BFD_RELOC_PDP11_DISP_6_PCREL,
   2834 
   2835 /* Picojava relocs.  Not all of these appear in object files.  */
   2836   BFD_RELOC_PJ_CODE_HI16,
   2837   BFD_RELOC_PJ_CODE_LO16,
   2838   BFD_RELOC_PJ_CODE_DIR16,
   2839   BFD_RELOC_PJ_CODE_DIR32,
   2840   BFD_RELOC_PJ_CODE_REL16,
   2841   BFD_RELOC_PJ_CODE_REL32,
   2842 
   2843 /* Power(rs6000) and PowerPC relocations.  */
   2844   BFD_RELOC_PPC_B26,
   2845   BFD_RELOC_PPC_BA26,
   2846   BFD_RELOC_PPC_TOC16,
   2847   BFD_RELOC_PPC_TOC16_LO,
   2848   BFD_RELOC_PPC_TOC16_HI,
   2849   BFD_RELOC_PPC_B16,
   2850   BFD_RELOC_PPC_B16_BRTAKEN,
   2851   BFD_RELOC_PPC_B16_BRNTAKEN,
   2852   BFD_RELOC_PPC_BA16,
   2853   BFD_RELOC_PPC_BA16_BRTAKEN,
   2854   BFD_RELOC_PPC_BA16_BRNTAKEN,
   2855   BFD_RELOC_PPC_COPY,
   2856   BFD_RELOC_PPC_GLOB_DAT,
   2857   BFD_RELOC_PPC_JMP_SLOT,
   2858   BFD_RELOC_PPC_RELATIVE,
   2859   BFD_RELOC_PPC_LOCAL24PC,
   2860   BFD_RELOC_PPC_EMB_NADDR32,
   2861   BFD_RELOC_PPC_EMB_NADDR16,
   2862   BFD_RELOC_PPC_EMB_NADDR16_LO,
   2863   BFD_RELOC_PPC_EMB_NADDR16_HI,
   2864   BFD_RELOC_PPC_EMB_NADDR16_HA,
   2865   BFD_RELOC_PPC_EMB_SDAI16,
   2866   BFD_RELOC_PPC_EMB_SDA2I16,
   2867   BFD_RELOC_PPC_EMB_SDA2REL,
   2868   BFD_RELOC_PPC_EMB_SDA21,
   2869   BFD_RELOC_PPC_EMB_MRKREF,
   2870   BFD_RELOC_PPC_EMB_RELSEC16,
   2871   BFD_RELOC_PPC_EMB_RELST_LO,
   2872   BFD_RELOC_PPC_EMB_RELST_HI,
   2873   BFD_RELOC_PPC_EMB_RELST_HA,
   2874   BFD_RELOC_PPC_EMB_BIT_FLD,
   2875   BFD_RELOC_PPC_EMB_RELSDA,
   2876   BFD_RELOC_PPC_VLE_REL8,
   2877   BFD_RELOC_PPC_VLE_REL15,
   2878   BFD_RELOC_PPC_VLE_REL24,
   2879   BFD_RELOC_PPC_VLE_LO16A,
   2880   BFD_RELOC_PPC_VLE_LO16D,
   2881   BFD_RELOC_PPC_VLE_HI16A,
   2882   BFD_RELOC_PPC_VLE_HI16D,
   2883   BFD_RELOC_PPC_VLE_HA16A,
   2884   BFD_RELOC_PPC_VLE_HA16D,
   2885   BFD_RELOC_PPC_VLE_SDA21,
   2886   BFD_RELOC_PPC_VLE_SDA21_LO,
   2887   BFD_RELOC_PPC_VLE_SDAREL_LO16A,
   2888   BFD_RELOC_PPC_VLE_SDAREL_LO16D,
   2889   BFD_RELOC_PPC_VLE_SDAREL_HI16A,
   2890   BFD_RELOC_PPC_VLE_SDAREL_HI16D,
   2891   BFD_RELOC_PPC_VLE_SDAREL_HA16A,
   2892   BFD_RELOC_PPC_VLE_SDAREL_HA16D,
   2893   BFD_RELOC_PPC_16DX_HA,
   2894   BFD_RELOC_PPC_REL16DX_HA,
   2895   BFD_RELOC_PPC_NEG,
   2896   BFD_RELOC_PPC64_HIGHER,
   2897   BFD_RELOC_PPC64_HIGHER_S,
   2898   BFD_RELOC_PPC64_HIGHEST,
   2899   BFD_RELOC_PPC64_HIGHEST_S,
   2900   BFD_RELOC_PPC64_TOC16_LO,
   2901   BFD_RELOC_PPC64_TOC16_HI,
   2902   BFD_RELOC_PPC64_TOC16_HA,
   2903   BFD_RELOC_PPC64_TOC,
   2904   BFD_RELOC_PPC64_PLTGOT16,
   2905   BFD_RELOC_PPC64_PLTGOT16_LO,
   2906   BFD_RELOC_PPC64_PLTGOT16_HI,
   2907   BFD_RELOC_PPC64_PLTGOT16_HA,
   2908   BFD_RELOC_PPC64_ADDR16_DS,
   2909   BFD_RELOC_PPC64_ADDR16_LO_DS,
   2910   BFD_RELOC_PPC64_GOT16_DS,
   2911   BFD_RELOC_PPC64_GOT16_LO_DS,
   2912   BFD_RELOC_PPC64_PLT16_LO_DS,
   2913   BFD_RELOC_PPC64_SECTOFF_DS,
   2914   BFD_RELOC_PPC64_SECTOFF_LO_DS,
   2915   BFD_RELOC_PPC64_TOC16_DS,
   2916   BFD_RELOC_PPC64_TOC16_LO_DS,
   2917   BFD_RELOC_PPC64_PLTGOT16_DS,
   2918   BFD_RELOC_PPC64_PLTGOT16_LO_DS,
   2919   BFD_RELOC_PPC64_ADDR16_HIGH,
   2920   BFD_RELOC_PPC64_ADDR16_HIGHA,
   2921   BFD_RELOC_PPC64_REL16_HIGH,
   2922   BFD_RELOC_PPC64_REL16_HIGHA,
   2923   BFD_RELOC_PPC64_REL16_HIGHER,
   2924   BFD_RELOC_PPC64_REL16_HIGHERA,
   2925   BFD_RELOC_PPC64_REL16_HIGHEST,
   2926   BFD_RELOC_PPC64_REL16_HIGHESTA,
   2927   BFD_RELOC_PPC64_ADDR64_LOCAL,
   2928   BFD_RELOC_PPC64_ENTRY,
   2929   BFD_RELOC_PPC64_REL24_NOTOC,
   2930   BFD_RELOC_PPC64_REL24_P9NOTOC,
   2931   BFD_RELOC_PPC64_D34,
   2932   BFD_RELOC_PPC64_D34_LO,
   2933   BFD_RELOC_PPC64_D34_HI30,
   2934   BFD_RELOC_PPC64_D34_HA30,
   2935   BFD_RELOC_PPC64_PCREL34,
   2936   BFD_RELOC_PPC64_GOT_PCREL34,
   2937   BFD_RELOC_PPC64_PLT_PCREL34,
   2938   BFD_RELOC_PPC64_ADDR16_HIGHER34,
   2939   BFD_RELOC_PPC64_ADDR16_HIGHERA34,
   2940   BFD_RELOC_PPC64_ADDR16_HIGHEST34,
   2941   BFD_RELOC_PPC64_ADDR16_HIGHESTA34,
   2942   BFD_RELOC_PPC64_REL16_HIGHER34,
   2943   BFD_RELOC_PPC64_REL16_HIGHERA34,
   2944   BFD_RELOC_PPC64_REL16_HIGHEST34,
   2945   BFD_RELOC_PPC64_REL16_HIGHESTA34,
   2946   BFD_RELOC_PPC64_D28,
   2947   BFD_RELOC_PPC64_PCREL28,
   2948 
   2949 /* PowerPC and PowerPC64 thread-local storage relocations.  */
   2950   BFD_RELOC_PPC_TLS,
   2951   BFD_RELOC_PPC_TLSGD,
   2952   BFD_RELOC_PPC_TLSLD,
   2953   BFD_RELOC_PPC_TLSLE,
   2954   BFD_RELOC_PPC_TLSIE,
   2955   BFD_RELOC_PPC_TLSM,
   2956   BFD_RELOC_PPC_TLSML,
   2957   BFD_RELOC_PPC_DTPMOD,
   2958   BFD_RELOC_PPC_TPREL16,
   2959   BFD_RELOC_PPC_TPREL16_LO,
   2960   BFD_RELOC_PPC_TPREL16_HI,
   2961   BFD_RELOC_PPC_TPREL16_HA,
   2962   BFD_RELOC_PPC_TPREL,
   2963   BFD_RELOC_PPC_DTPREL16,
   2964   BFD_RELOC_PPC_DTPREL16_LO,
   2965   BFD_RELOC_PPC_DTPREL16_HI,
   2966   BFD_RELOC_PPC_DTPREL16_HA,
   2967   BFD_RELOC_PPC_DTPREL,
   2968   BFD_RELOC_PPC_GOT_TLSGD16,
   2969   BFD_RELOC_PPC_GOT_TLSGD16_LO,
   2970   BFD_RELOC_PPC_GOT_TLSGD16_HI,
   2971   BFD_RELOC_PPC_GOT_TLSGD16_HA,
   2972   BFD_RELOC_PPC_GOT_TLSLD16,
   2973   BFD_RELOC_PPC_GOT_TLSLD16_LO,
   2974   BFD_RELOC_PPC_GOT_TLSLD16_HI,
   2975   BFD_RELOC_PPC_GOT_TLSLD16_HA,
   2976   BFD_RELOC_PPC_GOT_TPREL16,
   2977   BFD_RELOC_PPC_GOT_TPREL16_LO,
   2978   BFD_RELOC_PPC_GOT_TPREL16_HI,
   2979   BFD_RELOC_PPC_GOT_TPREL16_HA,
   2980   BFD_RELOC_PPC_GOT_DTPREL16,
   2981   BFD_RELOC_PPC_GOT_DTPREL16_LO,
   2982   BFD_RELOC_PPC_GOT_DTPREL16_HI,
   2983   BFD_RELOC_PPC_GOT_DTPREL16_HA,
   2984   BFD_RELOC_PPC64_TLSGD,
   2985   BFD_RELOC_PPC64_TLSLD,
   2986   BFD_RELOC_PPC64_TLSLE,
   2987   BFD_RELOC_PPC64_TLSIE,
   2988   BFD_RELOC_PPC64_TLSM,
   2989   BFD_RELOC_PPC64_TLSML,
   2990   BFD_RELOC_PPC64_TPREL16_DS,
   2991   BFD_RELOC_PPC64_TPREL16_LO_DS,
   2992   BFD_RELOC_PPC64_TPREL16_HIGH,
   2993   BFD_RELOC_PPC64_TPREL16_HIGHA,
   2994   BFD_RELOC_PPC64_TPREL16_HIGHER,
   2995   BFD_RELOC_PPC64_TPREL16_HIGHERA,
   2996   BFD_RELOC_PPC64_TPREL16_HIGHEST,
   2997   BFD_RELOC_PPC64_TPREL16_HIGHESTA,
   2998   BFD_RELOC_PPC64_DTPREL16_DS,
   2999   BFD_RELOC_PPC64_DTPREL16_LO_DS,
   3000   BFD_RELOC_PPC64_DTPREL16_HIGH,
   3001   BFD_RELOC_PPC64_DTPREL16_HIGHA,
   3002   BFD_RELOC_PPC64_DTPREL16_HIGHER,
   3003   BFD_RELOC_PPC64_DTPREL16_HIGHERA,
   3004   BFD_RELOC_PPC64_DTPREL16_HIGHEST,
   3005   BFD_RELOC_PPC64_DTPREL16_HIGHESTA,
   3006   BFD_RELOC_PPC64_TPREL34,
   3007   BFD_RELOC_PPC64_DTPREL34,
   3008   BFD_RELOC_PPC64_GOT_TLSGD_PCREL34,
   3009   BFD_RELOC_PPC64_GOT_TLSLD_PCREL34,
   3010   BFD_RELOC_PPC64_GOT_TPREL_PCREL34,
   3011   BFD_RELOC_PPC64_GOT_DTPREL_PCREL34,
   3012   BFD_RELOC_PPC64_TLS_PCREL,
   3013 
   3014 /* IBM 370/390 relocations  */
   3015   BFD_RELOC_I370_D12,
   3016 
   3017 /* The type of reloc used to build a constructor table - at the moment
   3018 probably a 32 bit wide absolute relocation, but the target can choose.
   3019 It generally does map to one of the other relocation types.  */
   3020   BFD_RELOC_CTOR,
   3021 
   3022 /* ARM 26 bit pc-relative branch.  The lowest two bits must be zero and are
   3023 not stored in the instruction.  */
   3024   BFD_RELOC_ARM_PCREL_BRANCH,
   3025 
   3026 /* ARM 26 bit pc-relative branch.  The lowest bit must be zero and is
   3027 not stored in the instruction.  The 2nd lowest bit comes from a 1 bit
   3028 field in the instruction.  */
   3029   BFD_RELOC_ARM_PCREL_BLX,
   3030 
   3031 /* Thumb 22 bit pc-relative branch.  The lowest bit must be zero and is
   3032 not stored in the instruction.  The 2nd lowest bit comes from a 1 bit
   3033 field in the instruction.  */
   3034   BFD_RELOC_THUMB_PCREL_BLX,
   3035 
   3036 /* ARM 26-bit pc-relative branch for an unconditional BL or BLX instruction.  */
   3037   BFD_RELOC_ARM_PCREL_CALL,
   3038 
   3039 /* ARM 26-bit pc-relative branch for B or conditional BL instruction.  */
   3040   BFD_RELOC_ARM_PCREL_JUMP,
   3041 
   3042 /* ARM 5-bit pc-relative branch for Branch Future instructions.  */
   3043   BFD_RELOC_THUMB_PCREL_BRANCH5,
   3044 
   3045 /* ARM 6-bit pc-relative branch for BFCSEL instruction.  */
   3046   BFD_RELOC_THUMB_PCREL_BFCSEL,
   3047 
   3048 /* ARM 17-bit pc-relative branch for Branch Future instructions.  */
   3049   BFD_RELOC_ARM_THUMB_BF17,
   3050 
   3051 /* ARM 13-bit pc-relative branch for BFCSEL instruction.  */
   3052   BFD_RELOC_ARM_THUMB_BF13,
   3053 
   3054 /* ARM 19-bit pc-relative branch for Branch Future Link instruction.  */
   3055   BFD_RELOC_ARM_THUMB_BF19,
   3056 
   3057 /* ARM 12-bit pc-relative branch for Low Overhead Loop instructions.  */
   3058   BFD_RELOC_ARM_THUMB_LOOP12,
   3059 
   3060 /* Thumb 7-, 9-, 12-, 20-, 23-, and 25-bit pc-relative branches.
   3061 The lowest bit must be zero and is not stored in the instruction.
   3062 Note that the corresponding ELF R_ARM_THM_JUMPnn constant has an
   3063 "nn" one smaller in all cases.  Note further that BRANCH23
   3064 corresponds to R_ARM_THM_CALL.  */
   3065   BFD_RELOC_THUMB_PCREL_BRANCH7,
   3066   BFD_RELOC_THUMB_PCREL_BRANCH9,
   3067   BFD_RELOC_THUMB_PCREL_BRANCH12,
   3068   BFD_RELOC_THUMB_PCREL_BRANCH20,
   3069   BFD_RELOC_THUMB_PCREL_BRANCH23,
   3070   BFD_RELOC_THUMB_PCREL_BRANCH25,
   3071 
   3072 /* 12-bit immediate offset, used in ARM-format ldr and str instructions.  */
   3073   BFD_RELOC_ARM_OFFSET_IMM,
   3074 
   3075 /* 5-bit immediate offset, used in Thumb-format ldr and str instructions.  */
   3076   BFD_RELOC_ARM_THUMB_OFFSET,
   3077 
   3078 /* Pc-relative or absolute relocation depending on target.  Used for
   3079 entries in .init_array sections.  */
   3080   BFD_RELOC_ARM_TARGET1,
   3081 
   3082 /* Read-only segment base relative address.  */
   3083   BFD_RELOC_ARM_ROSEGREL32,
   3084 
   3085 /* Data segment base relative address.  */
   3086   BFD_RELOC_ARM_SBREL32,
   3087 
   3088 /* This reloc is used for references to RTTI data from exception handling
   3089 tables.  The actual definition depends on the target.  It may be a
   3090 pc-relative or some form of GOT-indirect relocation.  */
   3091   BFD_RELOC_ARM_TARGET2,
   3092 
   3093 /* 31-bit PC relative address.  */
   3094   BFD_RELOC_ARM_PREL31,
   3095 
   3096 /* Low and High halfword relocations for MOVW and MOVT instructions.  */
   3097   BFD_RELOC_ARM_MOVW,
   3098   BFD_RELOC_ARM_MOVT,
   3099   BFD_RELOC_ARM_MOVW_PCREL,
   3100   BFD_RELOC_ARM_MOVT_PCREL,
   3101   BFD_RELOC_ARM_THUMB_MOVW,
   3102   BFD_RELOC_ARM_THUMB_MOVT,
   3103   BFD_RELOC_ARM_THUMB_MOVW_PCREL,
   3104   BFD_RELOC_ARM_THUMB_MOVT_PCREL,
   3105 
   3106 /* ARM FDPIC specific relocations.  */
   3107   BFD_RELOC_ARM_GOTFUNCDESC,
   3108   BFD_RELOC_ARM_GOTOFFFUNCDESC,
   3109   BFD_RELOC_ARM_FUNCDESC,
   3110   BFD_RELOC_ARM_FUNCDESC_VALUE,
   3111   BFD_RELOC_ARM_TLS_GD32_FDPIC,
   3112   BFD_RELOC_ARM_TLS_LDM32_FDPIC,
   3113   BFD_RELOC_ARM_TLS_IE32_FDPIC,
   3114 
   3115 /* Relocations for setting up GOTs and PLTs for shared libraries.  */
   3116   BFD_RELOC_ARM_JUMP_SLOT,
   3117   BFD_RELOC_ARM_GLOB_DAT,
   3118   BFD_RELOC_ARM_GOT32,
   3119   BFD_RELOC_ARM_PLT32,
   3120   BFD_RELOC_ARM_RELATIVE,
   3121   BFD_RELOC_ARM_GOTOFF,
   3122   BFD_RELOC_ARM_GOTPC,
   3123   BFD_RELOC_ARM_GOT_PREL,
   3124 
   3125 /* ARM thread-local storage relocations.  */
   3126   BFD_RELOC_ARM_TLS_GD32,
   3127   BFD_RELOC_ARM_TLS_LDO32,
   3128   BFD_RELOC_ARM_TLS_LDM32,
   3129   BFD_RELOC_ARM_TLS_DTPOFF32,
   3130   BFD_RELOC_ARM_TLS_DTPMOD32,
   3131   BFD_RELOC_ARM_TLS_TPOFF32,
   3132   BFD_RELOC_ARM_TLS_IE32,
   3133   BFD_RELOC_ARM_TLS_LE32,
   3134   BFD_RELOC_ARM_TLS_GOTDESC,
   3135   BFD_RELOC_ARM_TLS_CALL,
   3136   BFD_RELOC_ARM_THM_TLS_CALL,
   3137   BFD_RELOC_ARM_TLS_DESCSEQ,
   3138   BFD_RELOC_ARM_THM_TLS_DESCSEQ,
   3139   BFD_RELOC_ARM_TLS_DESC,
   3140 
   3141 /* ARM group relocations.  */
   3142   BFD_RELOC_ARM_ALU_PC_G0_NC,
   3143   BFD_RELOC_ARM_ALU_PC_G0,
   3144   BFD_RELOC_ARM_ALU_PC_G1_NC,
   3145   BFD_RELOC_ARM_ALU_PC_G1,
   3146   BFD_RELOC_ARM_ALU_PC_G2,
   3147   BFD_RELOC_ARM_LDR_PC_G0,
   3148   BFD_RELOC_ARM_LDR_PC_G1,
   3149   BFD_RELOC_ARM_LDR_PC_G2,
   3150   BFD_RELOC_ARM_LDRS_PC_G0,
   3151   BFD_RELOC_ARM_LDRS_PC_G1,
   3152   BFD_RELOC_ARM_LDRS_PC_G2,
   3153   BFD_RELOC_ARM_LDC_PC_G0,
   3154   BFD_RELOC_ARM_LDC_PC_G1,
   3155   BFD_RELOC_ARM_LDC_PC_G2,
   3156   BFD_RELOC_ARM_ALU_SB_G0_NC,
   3157   BFD_RELOC_ARM_ALU_SB_G0,
   3158   BFD_RELOC_ARM_ALU_SB_G1_NC,
   3159   BFD_RELOC_ARM_ALU_SB_G1,
   3160   BFD_RELOC_ARM_ALU_SB_G2,
   3161   BFD_RELOC_ARM_LDR_SB_G0,
   3162   BFD_RELOC_ARM_LDR_SB_G1,
   3163   BFD_RELOC_ARM_LDR_SB_G2,
   3164   BFD_RELOC_ARM_LDRS_SB_G0,
   3165   BFD_RELOC_ARM_LDRS_SB_G1,
   3166   BFD_RELOC_ARM_LDRS_SB_G2,
   3167   BFD_RELOC_ARM_LDC_SB_G0,
   3168   BFD_RELOC_ARM_LDC_SB_G1,
   3169   BFD_RELOC_ARM_LDC_SB_G2,
   3170 
   3171 /* Annotation of BX instructions.  */
   3172   BFD_RELOC_ARM_V4BX,
   3173 
   3174 /* ARM support for STT_GNU_IFUNC.  */
   3175   BFD_RELOC_ARM_IRELATIVE,
   3176 
   3177 /* Thumb1 relocations to support execute-only code.  */
   3178   BFD_RELOC_ARM_THUMB_ALU_ABS_G0_NC,
   3179   BFD_RELOC_ARM_THUMB_ALU_ABS_G1_NC,
   3180   BFD_RELOC_ARM_THUMB_ALU_ABS_G2_NC,
   3181   BFD_RELOC_ARM_THUMB_ALU_ABS_G3_NC,
   3182 
   3183 /* These relocs are only used within the ARM assembler.  They are not
   3184 (at present) written to any object files.  */
   3185   BFD_RELOC_ARM_IMMEDIATE,
   3186   BFD_RELOC_ARM_ADRL_IMMEDIATE,
   3187   BFD_RELOC_ARM_T32_IMMEDIATE,
   3188   BFD_RELOC_ARM_T32_ADD_IMM,
   3189   BFD_RELOC_ARM_T32_IMM12,
   3190   BFD_RELOC_ARM_T32_ADD_PC12,
   3191   BFD_RELOC_ARM_SHIFT_IMM,
   3192   BFD_RELOC_ARM_SMC,
   3193   BFD_RELOC_ARM_HVC,
   3194   BFD_RELOC_ARM_SWI,
   3195   BFD_RELOC_ARM_MULTI,
   3196   BFD_RELOC_ARM_CP_OFF_IMM,
   3197   BFD_RELOC_ARM_CP_OFF_IMM_S2,
   3198   BFD_RELOC_ARM_T32_CP_OFF_IMM,
   3199   BFD_RELOC_ARM_T32_CP_OFF_IMM_S2,
   3200   BFD_RELOC_ARM_T32_VLDR_VSTR_OFF_IMM,
   3201   BFD_RELOC_ARM_ADR_IMM,
   3202   BFD_RELOC_ARM_LDR_IMM,
   3203   BFD_RELOC_ARM_LITERAL,
   3204   BFD_RELOC_ARM_IN_POOL,
   3205   BFD_RELOC_ARM_OFFSET_IMM8,
   3206   BFD_RELOC_ARM_T32_OFFSET_U8,
   3207   BFD_RELOC_ARM_T32_OFFSET_IMM,
   3208   BFD_RELOC_ARM_HWLITERAL,
   3209   BFD_RELOC_ARM_THUMB_ADD,
   3210   BFD_RELOC_ARM_THUMB_IMM,
   3211   BFD_RELOC_ARM_THUMB_SHIFT,
   3212 
   3213 /* Renesas / SuperH SH relocs.  Not all of these appear in object files.  */
   3214   BFD_RELOC_SH_PCDISP8BY2,
   3215   BFD_RELOC_SH_PCDISP12BY2,
   3216   BFD_RELOC_SH_IMM3,
   3217   BFD_RELOC_SH_IMM3U,
   3218   BFD_RELOC_SH_DISP12,
   3219   BFD_RELOC_SH_DISP12BY2,
   3220   BFD_RELOC_SH_DISP12BY4,
   3221   BFD_RELOC_SH_DISP12BY8,
   3222   BFD_RELOC_SH_DISP20,
   3223   BFD_RELOC_SH_DISP20BY8,
   3224   BFD_RELOC_SH_IMM4,
   3225   BFD_RELOC_SH_IMM4BY2,
   3226   BFD_RELOC_SH_IMM4BY4,
   3227   BFD_RELOC_SH_IMM8,
   3228   BFD_RELOC_SH_IMM8BY2,
   3229   BFD_RELOC_SH_IMM8BY4,
   3230   BFD_RELOC_SH_PCRELIMM8BY2,
   3231   BFD_RELOC_SH_PCRELIMM8BY4,
   3232   BFD_RELOC_SH_SWITCH16,
   3233   BFD_RELOC_SH_SWITCH32,
   3234   BFD_RELOC_SH_USES,
   3235   BFD_RELOC_SH_COUNT,
   3236   BFD_RELOC_SH_ALIGN,
   3237   BFD_RELOC_SH_CODE,
   3238   BFD_RELOC_SH_DATA,
   3239   BFD_RELOC_SH_LABEL,
   3240   BFD_RELOC_SH_LOOP_START,
   3241   BFD_RELOC_SH_LOOP_END,
   3242   BFD_RELOC_SH_COPY,
   3243   BFD_RELOC_SH_GLOB_DAT,
   3244   BFD_RELOC_SH_JMP_SLOT,
   3245   BFD_RELOC_SH_RELATIVE,
   3246   BFD_RELOC_SH_GOTPC,
   3247   BFD_RELOC_SH_GOT_LOW16,
   3248   BFD_RELOC_SH_GOT_MEDLOW16,
   3249   BFD_RELOC_SH_GOT_MEDHI16,
   3250   BFD_RELOC_SH_GOT_HI16,
   3251   BFD_RELOC_SH_GOTPLT_LOW16,
   3252   BFD_RELOC_SH_GOTPLT_MEDLOW16,
   3253   BFD_RELOC_SH_GOTPLT_MEDHI16,
   3254   BFD_RELOC_SH_GOTPLT_HI16,
   3255   BFD_RELOC_SH_PLT_LOW16,
   3256   BFD_RELOC_SH_PLT_MEDLOW16,
   3257   BFD_RELOC_SH_PLT_MEDHI16,
   3258   BFD_RELOC_SH_PLT_HI16,
   3259   BFD_RELOC_SH_GOTOFF_LOW16,
   3260   BFD_RELOC_SH_GOTOFF_MEDLOW16,
   3261   BFD_RELOC_SH_GOTOFF_MEDHI16,
   3262   BFD_RELOC_SH_GOTOFF_HI16,
   3263   BFD_RELOC_SH_GOTPC_LOW16,
   3264   BFD_RELOC_SH_GOTPC_MEDLOW16,
   3265   BFD_RELOC_SH_GOTPC_MEDHI16,
   3266   BFD_RELOC_SH_GOTPC_HI16,
   3267   BFD_RELOC_SH_COPY64,
   3268   BFD_RELOC_SH_GLOB_DAT64,
   3269   BFD_RELOC_SH_JMP_SLOT64,
   3270   BFD_RELOC_SH_RELATIVE64,
   3271   BFD_RELOC_SH_GOT10BY4,
   3272   BFD_RELOC_SH_GOT10BY8,
   3273   BFD_RELOC_SH_GOTPLT10BY4,
   3274   BFD_RELOC_SH_GOTPLT10BY8,
   3275   BFD_RELOC_SH_GOTPLT32,
   3276   BFD_RELOC_SH_SHMEDIA_CODE,
   3277   BFD_RELOC_SH_IMMU5,
   3278   BFD_RELOC_SH_IMMS6,
   3279   BFD_RELOC_SH_IMMS6BY32,
   3280   BFD_RELOC_SH_IMMU6,
   3281   BFD_RELOC_SH_IMMS10,
   3282   BFD_RELOC_SH_IMMS10BY2,
   3283   BFD_RELOC_SH_IMMS10BY4,
   3284   BFD_RELOC_SH_IMMS10BY8,
   3285   BFD_RELOC_SH_IMMS16,
   3286   BFD_RELOC_SH_IMMU16,
   3287   BFD_RELOC_SH_IMM_LOW16,
   3288   BFD_RELOC_SH_IMM_LOW16_PCREL,
   3289   BFD_RELOC_SH_IMM_MEDLOW16,
   3290   BFD_RELOC_SH_IMM_MEDLOW16_PCREL,
   3291   BFD_RELOC_SH_IMM_MEDHI16,
   3292   BFD_RELOC_SH_IMM_MEDHI16_PCREL,
   3293   BFD_RELOC_SH_IMM_HI16,
   3294   BFD_RELOC_SH_IMM_HI16_PCREL,
   3295   BFD_RELOC_SH_PT_16,
   3296   BFD_RELOC_SH_TLS_GD_32,
   3297   BFD_RELOC_SH_TLS_LD_32,
   3298   BFD_RELOC_SH_TLS_LDO_32,
   3299   BFD_RELOC_SH_TLS_IE_32,
   3300   BFD_RELOC_SH_TLS_LE_32,
   3301   BFD_RELOC_SH_TLS_DTPMOD32,
   3302   BFD_RELOC_SH_TLS_DTPOFF32,
   3303   BFD_RELOC_SH_TLS_TPOFF32,
   3304   BFD_RELOC_SH_GOT20,
   3305   BFD_RELOC_SH_GOTOFF20,
   3306   BFD_RELOC_SH_GOTFUNCDESC,
   3307   BFD_RELOC_SH_GOTFUNCDESC20,
   3308   BFD_RELOC_SH_GOTOFFFUNCDESC,
   3309   BFD_RELOC_SH_GOTOFFFUNCDESC20,
   3310   BFD_RELOC_SH_FUNCDESC,
   3311 
   3312 /* ARC relocs.  */
   3313   BFD_RELOC_ARC_NONE,
   3314   BFD_RELOC_ARC_8,
   3315   BFD_RELOC_ARC_16,
   3316   BFD_RELOC_ARC_24,
   3317   BFD_RELOC_ARC_32,
   3318   BFD_RELOC_ARC_N8,
   3319   BFD_RELOC_ARC_N16,
   3320   BFD_RELOC_ARC_N24,
   3321   BFD_RELOC_ARC_N32,
   3322   BFD_RELOC_ARC_SDA,
   3323   BFD_RELOC_ARC_SECTOFF,
   3324   BFD_RELOC_ARC_S21H_PCREL,
   3325   BFD_RELOC_ARC_S21W_PCREL,
   3326   BFD_RELOC_ARC_S25H_PCREL,
   3327   BFD_RELOC_ARC_S25W_PCREL,
   3328   BFD_RELOC_ARC_SDA32,
   3329   BFD_RELOC_ARC_SDA_LDST,
   3330   BFD_RELOC_ARC_SDA_LDST1,
   3331   BFD_RELOC_ARC_SDA_LDST2,
   3332   BFD_RELOC_ARC_SDA16_LD,
   3333   BFD_RELOC_ARC_SDA16_LD1,
   3334   BFD_RELOC_ARC_SDA16_LD2,
   3335   BFD_RELOC_ARC_S13_PCREL,
   3336   BFD_RELOC_ARC_W,
   3337   BFD_RELOC_ARC_32_ME,
   3338   BFD_RELOC_ARC_32_ME_S,
   3339   BFD_RELOC_ARC_N32_ME,
   3340   BFD_RELOC_ARC_SECTOFF_ME,
   3341   BFD_RELOC_ARC_SDA32_ME,
   3342   BFD_RELOC_ARC_W_ME,
   3343   BFD_RELOC_AC_SECTOFF_U8,
   3344   BFD_RELOC_AC_SECTOFF_U8_1,
   3345   BFD_RELOC_AC_SECTOFF_U8_2,
   3346   BFD_RELOC_AC_SECTOFF_S9,
   3347   BFD_RELOC_AC_SECTOFF_S9_1,
   3348   BFD_RELOC_AC_SECTOFF_S9_2,
   3349   BFD_RELOC_ARC_SECTOFF_ME_1,
   3350   BFD_RELOC_ARC_SECTOFF_ME_2,
   3351   BFD_RELOC_ARC_SECTOFF_1,
   3352   BFD_RELOC_ARC_SECTOFF_2,
   3353   BFD_RELOC_ARC_SDA_12,
   3354   BFD_RELOC_ARC_SDA16_ST2,
   3355   BFD_RELOC_ARC_32_PCREL,
   3356   BFD_RELOC_ARC_PC32,
   3357   BFD_RELOC_ARC_GOT32,
   3358   BFD_RELOC_ARC_GOTPC32,
   3359   BFD_RELOC_ARC_PLT32,
   3360   BFD_RELOC_ARC_COPY,
   3361   BFD_RELOC_ARC_GLOB_DAT,
   3362   BFD_RELOC_ARC_JMP_SLOT,
   3363   BFD_RELOC_ARC_RELATIVE,
   3364   BFD_RELOC_ARC_GOTOFF,
   3365   BFD_RELOC_ARC_GOTPC,
   3366   BFD_RELOC_ARC_S21W_PCREL_PLT,
   3367   BFD_RELOC_ARC_S25H_PCREL_PLT,
   3368   BFD_RELOC_ARC_TLS_DTPMOD,
   3369   BFD_RELOC_ARC_TLS_TPOFF,
   3370   BFD_RELOC_ARC_TLS_GD_GOT,
   3371   BFD_RELOC_ARC_TLS_GD_LD,
   3372   BFD_RELOC_ARC_TLS_GD_CALL,
   3373   BFD_RELOC_ARC_TLS_IE_GOT,
   3374   BFD_RELOC_ARC_TLS_DTPOFF,
   3375   BFD_RELOC_ARC_TLS_DTPOFF_S9,
   3376   BFD_RELOC_ARC_TLS_LE_S9,
   3377   BFD_RELOC_ARC_TLS_LE_32,
   3378   BFD_RELOC_ARC_S25W_PCREL_PLT,
   3379   BFD_RELOC_ARC_S21H_PCREL_PLT,
   3380   BFD_RELOC_ARC_NPS_CMEM16,
   3381   BFD_RELOC_ARC_JLI_SECTOFF,
   3382 
   3383 /* ADI Blackfin 16 bit immediate absolute reloc.  */
   3384   BFD_RELOC_BFIN_16_IMM,
   3385 
   3386 /* ADI Blackfin 16 bit immediate absolute reloc higher 16 bits.  */
   3387   BFD_RELOC_BFIN_16_HIGH,
   3388 
   3389 /* ADI Blackfin 'a' part of LSETUP.  */
   3390   BFD_RELOC_BFIN_4_PCREL,
   3391 
   3392 /* ADI Blackfin.  */
   3393   BFD_RELOC_BFIN_5_PCREL,
   3394 
   3395 /* ADI Blackfin 16 bit immediate absolute reloc lower 16 bits.  */
   3396   BFD_RELOC_BFIN_16_LOW,
   3397 
   3398 /* ADI Blackfin.  */
   3399   BFD_RELOC_BFIN_10_PCREL,
   3400 
   3401 /* ADI Blackfin 'b' part of LSETUP.  */
   3402   BFD_RELOC_BFIN_11_PCREL,
   3403 
   3404 /* ADI Blackfin.  */
   3405   BFD_RELOC_BFIN_12_PCREL_JUMP,
   3406 
   3407 /* ADI Blackfin Short jump, pcrel.  */
   3408   BFD_RELOC_BFIN_12_PCREL_JUMP_S,
   3409 
   3410 /* ADI Blackfin Call.x not implemented.  */
   3411   BFD_RELOC_BFIN_24_PCREL_CALL_X,
   3412 
   3413 /* ADI Blackfin Long Jump pcrel.  */
   3414   BFD_RELOC_BFIN_24_PCREL_JUMP_L,
   3415 
   3416 /* ADI Blackfin FD-PIC relocations.  */
   3417   BFD_RELOC_BFIN_GOT17M4,
   3418   BFD_RELOC_BFIN_GOTHI,
   3419   BFD_RELOC_BFIN_GOTLO,
   3420   BFD_RELOC_BFIN_FUNCDESC,
   3421   BFD_RELOC_BFIN_FUNCDESC_GOT17M4,
   3422   BFD_RELOC_BFIN_FUNCDESC_GOTHI,
   3423   BFD_RELOC_BFIN_FUNCDESC_GOTLO,
   3424   BFD_RELOC_BFIN_FUNCDESC_VALUE,
   3425   BFD_RELOC_BFIN_FUNCDESC_GOTOFF17M4,
   3426   BFD_RELOC_BFIN_FUNCDESC_GOTOFFHI,
   3427   BFD_RELOC_BFIN_FUNCDESC_GOTOFFLO,
   3428   BFD_RELOC_BFIN_GOTOFF17M4,
   3429   BFD_RELOC_BFIN_GOTOFFHI,
   3430   BFD_RELOC_BFIN_GOTOFFLO,
   3431 
   3432 /* ADI Blackfin GOT relocation.  */
   3433   BFD_RELOC_BFIN_GOT,
   3434 
   3435 /* ADI Blackfin PLTPC relocation.  */
   3436   BFD_RELOC_BFIN_PLTPC,
   3437 
   3438 /* ADI Blackfin arithmetic relocation.  */
   3439   BFD_ARELOC_BFIN_PUSH,
   3440 
   3441 /* ADI Blackfin arithmetic relocation.  */
   3442   BFD_ARELOC_BFIN_CONST,
   3443 
   3444 /* ADI Blackfin arithmetic relocation.  */
   3445   BFD_ARELOC_BFIN_ADD,
   3446 
   3447 /* ADI Blackfin arithmetic relocation.  */
   3448   BFD_ARELOC_BFIN_SUB,
   3449 
   3450 /* ADI Blackfin arithmetic relocation.  */
   3451   BFD_ARELOC_BFIN_MULT,
   3452 
   3453 /* ADI Blackfin arithmetic relocation.  */
   3454   BFD_ARELOC_BFIN_DIV,
   3455 
   3456 /* ADI Blackfin arithmetic relocation.  */
   3457   BFD_ARELOC_BFIN_MOD,
   3458 
   3459 /* ADI Blackfin arithmetic relocation.  */
   3460   BFD_ARELOC_BFIN_LSHIFT,
   3461 
   3462 /* ADI Blackfin arithmetic relocation.  */
   3463   BFD_ARELOC_BFIN_RSHIFT,
   3464 
   3465 /* ADI Blackfin arithmetic relocation.  */
   3466   BFD_ARELOC_BFIN_AND,
   3467 
   3468 /* ADI Blackfin arithmetic relocation.  */
   3469   BFD_ARELOC_BFIN_OR,
   3470 
   3471 /* ADI Blackfin arithmetic relocation.  */
   3472   BFD_ARELOC_BFIN_XOR,
   3473 
   3474 /* ADI Blackfin arithmetic relocation.  */
   3475   BFD_ARELOC_BFIN_LAND,
   3476 
   3477 /* ADI Blackfin arithmetic relocation.  */
   3478   BFD_ARELOC_BFIN_LOR,
   3479 
   3480 /* ADI Blackfin arithmetic relocation.  */
   3481   BFD_ARELOC_BFIN_LEN,
   3482 
   3483 /* ADI Blackfin arithmetic relocation.  */
   3484   BFD_ARELOC_BFIN_NEG,
   3485 
   3486 /* ADI Blackfin arithmetic relocation.  */
   3487   BFD_ARELOC_BFIN_COMP,
   3488 
   3489 /* ADI Blackfin arithmetic relocation.  */
   3490   BFD_ARELOC_BFIN_PAGE,
   3491 
   3492 /* ADI Blackfin arithmetic relocation.  */
   3493   BFD_ARELOC_BFIN_HWPAGE,
   3494 
   3495 /* ADI Blackfin arithmetic relocation.  */
   3496   BFD_ARELOC_BFIN_ADDR,
   3497 
   3498 /* Mitsubishi D10V relocs.
   3499 This is a 10-bit reloc with the right 2 bits
   3500 assumed to be 0.  */
   3501   BFD_RELOC_D10V_10_PCREL_R,
   3502 
   3503 /* Mitsubishi D10V relocs.
   3504 This is a 10-bit reloc with the right 2 bits
   3505 assumed to be 0.  This is the same as the previous reloc
   3506 except it is in the left container, i.e.,
   3507 shifted left 15 bits.  */
   3508   BFD_RELOC_D10V_10_PCREL_L,
   3509 
   3510 /* This is an 18-bit reloc with the right 2 bits
   3511 assumed to be 0.  */
   3512   BFD_RELOC_D10V_18,
   3513 
   3514 /* This is an 18-bit reloc with the right 2 bits
   3515 assumed to be 0.  */
   3516   BFD_RELOC_D10V_18_PCREL,
   3517 
   3518 /* Mitsubishi D30V relocs.
   3519 This is a 6-bit absolute reloc.  */
   3520   BFD_RELOC_D30V_6,
   3521 
   3522 /* This is a 6-bit pc-relative reloc with
   3523 the right 3 bits assumed to be 0.  */
   3524   BFD_RELOC_D30V_9_PCREL,
   3525 
   3526 /* This is a 6-bit pc-relative reloc with
   3527 the right 3 bits assumed to be 0. Same
   3528 as the previous reloc but on the right side
   3529 of the container.  */
   3530   BFD_RELOC_D30V_9_PCREL_R,
   3531 
   3532 /* This is a 12-bit absolute reloc with the
   3533 right 3 bitsassumed to be 0.  */
   3534   BFD_RELOC_D30V_15,
   3535 
   3536 /* This is a 12-bit pc-relative reloc with
   3537 the right 3 bits assumed to be 0.  */
   3538   BFD_RELOC_D30V_15_PCREL,
   3539 
   3540 /* This is a 12-bit pc-relative reloc with
   3541 the right 3 bits assumed to be 0. Same
   3542 as the previous reloc but on the right side
   3543 of the container.  */
   3544   BFD_RELOC_D30V_15_PCREL_R,
   3545 
   3546 /* This is an 18-bit absolute reloc with
   3547 the right 3 bits assumed to be 0.  */
   3548   BFD_RELOC_D30V_21,
   3549 
   3550 /* This is an 18-bit pc-relative reloc with
   3551 the right 3 bits assumed to be 0.  */
   3552   BFD_RELOC_D30V_21_PCREL,
   3553 
   3554 /* This is an 18-bit pc-relative reloc with
   3555 the right 3 bits assumed to be 0. Same
   3556 as the previous reloc but on the right side
   3557 of the container.  */
   3558   BFD_RELOC_D30V_21_PCREL_R,
   3559 
   3560 /* This is a 32-bit absolute reloc.  */
   3561   BFD_RELOC_D30V_32,
   3562 
   3563 /* This is a 32-bit pc-relative reloc.  */
   3564   BFD_RELOC_D30V_32_PCREL,
   3565 
   3566 /* DLX relocs  */
   3567   BFD_RELOC_DLX_HI16_S,
   3568 
   3569 /* DLX relocs  */
   3570   BFD_RELOC_DLX_LO16,
   3571 
   3572 /* DLX relocs  */
   3573   BFD_RELOC_DLX_JMP26,
   3574 
   3575 /* Renesas M16C/M32C Relocations.  */
   3576   BFD_RELOC_M32C_HI8,
   3577   BFD_RELOC_M32C_RL_JUMP,
   3578   BFD_RELOC_M32C_RL_1ADDR,
   3579   BFD_RELOC_M32C_RL_2ADDR,
   3580 
   3581 /* Renesas M32R (formerly Mitsubishi M32R) relocs.
   3582 This is a 24 bit absolute address.  */
   3583   BFD_RELOC_M32R_24,
   3584 
   3585 /* This is a 10-bit pc-relative reloc with the right 2 bits assumed to be 0.  */
   3586   BFD_RELOC_M32R_10_PCREL,
   3587 
   3588 /* This is an 18-bit reloc with the right 2 bits assumed to be 0.  */
   3589   BFD_RELOC_M32R_18_PCREL,
   3590 
   3591 /* This is a 26-bit reloc with the right 2 bits assumed to be 0.  */
   3592   BFD_RELOC_M32R_26_PCREL,
   3593 
   3594 /* This is a 16-bit reloc containing the high 16 bits of an address
   3595 used when the lower 16 bits are treated as unsigned.  */
   3596   BFD_RELOC_M32R_HI16_ULO,
   3597 
   3598 /* This is a 16-bit reloc containing the high 16 bits of an address
   3599 used when the lower 16 bits are treated as signed.  */
   3600   BFD_RELOC_M32R_HI16_SLO,
   3601 
   3602 /* This is a 16-bit reloc containing the lower 16 bits of an address.  */
   3603   BFD_RELOC_M32R_LO16,
   3604 
   3605 /* This is a 16-bit reloc containing the small data area offset for use in
   3606 add3, load, and store instructions.  */
   3607   BFD_RELOC_M32R_SDA16,
   3608 
   3609 /* For PIC.  */
   3610   BFD_RELOC_M32R_GOT24,
   3611   BFD_RELOC_M32R_26_PLTREL,
   3612   BFD_RELOC_M32R_COPY,
   3613   BFD_RELOC_M32R_GLOB_DAT,
   3614   BFD_RELOC_M32R_JMP_SLOT,
   3615   BFD_RELOC_M32R_RELATIVE,
   3616   BFD_RELOC_M32R_GOTOFF,
   3617   BFD_RELOC_M32R_GOTOFF_HI_ULO,
   3618   BFD_RELOC_M32R_GOTOFF_HI_SLO,
   3619   BFD_RELOC_M32R_GOTOFF_LO,
   3620   BFD_RELOC_M32R_GOTPC24,
   3621   BFD_RELOC_M32R_GOT16_HI_ULO,
   3622   BFD_RELOC_M32R_GOT16_HI_SLO,
   3623   BFD_RELOC_M32R_GOT16_LO,
   3624   BFD_RELOC_M32R_GOTPC_HI_ULO,
   3625   BFD_RELOC_M32R_GOTPC_HI_SLO,
   3626   BFD_RELOC_M32R_GOTPC_LO,
   3627 
   3628 /* NDS32 relocs.
   3629 This is a 20 bit absolute address.  */
   3630   BFD_RELOC_NDS32_20,
   3631 
   3632 /* This is a 9-bit pc-relative reloc with the right 1 bit assumed to be 0.  */
   3633   BFD_RELOC_NDS32_9_PCREL,
   3634 
   3635 /* This is a 9-bit pc-relative reloc with the right 1 bit assumed to be 0.  */
   3636   BFD_RELOC_NDS32_WORD_9_PCREL,
   3637 
   3638 /* This is an 15-bit reloc with the right 1 bit assumed to be 0.  */
   3639   BFD_RELOC_NDS32_15_PCREL,
   3640 
   3641 /* This is an 17-bit reloc with the right 1 bit assumed to be 0.  */
   3642   BFD_RELOC_NDS32_17_PCREL,
   3643 
   3644 /* This is a 25-bit reloc with the right 1 bit assumed to be 0.  */
   3645   BFD_RELOC_NDS32_25_PCREL,
   3646 
   3647 /* This is a 20-bit reloc containing the high 20 bits of an address
   3648 used with the lower 12 bits  */
   3649   BFD_RELOC_NDS32_HI20,
   3650 
   3651 /* This is a 12-bit reloc containing the lower 12 bits of an address
   3652 then shift right by 3. This is used with ldi,sdi...  */
   3653   BFD_RELOC_NDS32_LO12S3,
   3654 
   3655 /* This is a 12-bit reloc containing the lower 12 bits of an address
   3656 then shift left by 2. This is used with lwi,swi...  */
   3657   BFD_RELOC_NDS32_LO12S2,
   3658 
   3659 /* This is a 12-bit reloc containing the lower 12 bits of an address
   3660 then shift left by 1. This is used with lhi,shi...  */
   3661   BFD_RELOC_NDS32_LO12S1,
   3662 
   3663 /* This is a 12-bit reloc containing the lower 12 bits of an address
   3664 then shift left by 0. This is used with lbisbi...  */
   3665   BFD_RELOC_NDS32_LO12S0,
   3666 
   3667 /* This is a 12-bit reloc containing the lower 12 bits of an address
   3668 then shift left by 0. This is only used with branch relaxations  */
   3669   BFD_RELOC_NDS32_LO12S0_ORI,
   3670 
   3671 /* This is a 15-bit reloc containing the small data area 18-bit signed offset
   3672 and shift left by 3 for use in ldi, sdi...  */
   3673   BFD_RELOC_NDS32_SDA15S3,
   3674 
   3675 /* This is a 15-bit reloc containing the small data area 17-bit signed offset
   3676 and shift left by 2 for use in lwi, swi...  */
   3677   BFD_RELOC_NDS32_SDA15S2,
   3678 
   3679 /* This is a 15-bit reloc containing the small data area 16-bit signed offset
   3680 and shift left by 1 for use in lhi, shi...  */
   3681   BFD_RELOC_NDS32_SDA15S1,
   3682 
   3683 /* This is a 15-bit reloc containing the small data area 15-bit signed offset
   3684 and shift left by 0 for use in lbi, sbi...  */
   3685   BFD_RELOC_NDS32_SDA15S0,
   3686 
   3687 /* This is a 16-bit reloc containing the small data area 16-bit signed offset
   3688 and shift left by 3  */
   3689   BFD_RELOC_NDS32_SDA16S3,
   3690 
   3691 /* This is a 17-bit reloc containing the small data area 17-bit signed offset
   3692 and shift left by 2 for use in lwi.gp, swi.gp...  */
   3693   BFD_RELOC_NDS32_SDA17S2,
   3694 
   3695 /* This is a 18-bit reloc containing the small data area 18-bit signed offset
   3696 and shift left by 1 for use in lhi.gp, shi.gp...  */
   3697   BFD_RELOC_NDS32_SDA18S1,
   3698 
   3699 /* This is a 19-bit reloc containing the small data area 19-bit signed offset
   3700 and shift left by 0 for use in lbi.gp, sbi.gp...  */
   3701   BFD_RELOC_NDS32_SDA19S0,
   3702 
   3703 /* for PIC  */
   3704   BFD_RELOC_NDS32_GOT20,
   3705   BFD_RELOC_NDS32_9_PLTREL,
   3706   BFD_RELOC_NDS32_25_PLTREL,
   3707   BFD_RELOC_NDS32_COPY,
   3708   BFD_RELOC_NDS32_GLOB_DAT,
   3709   BFD_RELOC_NDS32_JMP_SLOT,
   3710   BFD_RELOC_NDS32_RELATIVE,
   3711   BFD_RELOC_NDS32_GOTOFF,
   3712   BFD_RELOC_NDS32_GOTOFF_HI20,
   3713   BFD_RELOC_NDS32_GOTOFF_LO12,
   3714   BFD_RELOC_NDS32_GOTPC20,
   3715   BFD_RELOC_NDS32_GOT_HI20,
   3716   BFD_RELOC_NDS32_GOT_LO12,
   3717   BFD_RELOC_NDS32_GOTPC_HI20,
   3718   BFD_RELOC_NDS32_GOTPC_LO12,
   3719 
   3720 /* for relax  */
   3721   BFD_RELOC_NDS32_INSN16,
   3722   BFD_RELOC_NDS32_LABEL,
   3723   BFD_RELOC_NDS32_LONGCALL1,
   3724   BFD_RELOC_NDS32_LONGCALL2,
   3725   BFD_RELOC_NDS32_LONGCALL3,
   3726   BFD_RELOC_NDS32_LONGJUMP1,
   3727   BFD_RELOC_NDS32_LONGJUMP2,
   3728   BFD_RELOC_NDS32_LONGJUMP3,
   3729   BFD_RELOC_NDS32_LOADSTORE,
   3730   BFD_RELOC_NDS32_9_FIXED,
   3731   BFD_RELOC_NDS32_15_FIXED,
   3732   BFD_RELOC_NDS32_17_FIXED,
   3733   BFD_RELOC_NDS32_25_FIXED,
   3734   BFD_RELOC_NDS32_LONGCALL4,
   3735   BFD_RELOC_NDS32_LONGCALL5,
   3736   BFD_RELOC_NDS32_LONGCALL6,
   3737   BFD_RELOC_NDS32_LONGJUMP4,
   3738   BFD_RELOC_NDS32_LONGJUMP5,
   3739   BFD_RELOC_NDS32_LONGJUMP6,
   3740   BFD_RELOC_NDS32_LONGJUMP7,
   3741 
   3742 /* for PIC  */
   3743   BFD_RELOC_NDS32_PLTREL_HI20,
   3744   BFD_RELOC_NDS32_PLTREL_LO12,
   3745   BFD_RELOC_NDS32_PLT_GOTREL_HI20,
   3746   BFD_RELOC_NDS32_PLT_GOTREL_LO12,
   3747 
   3748 /* for floating point  */
   3749   BFD_RELOC_NDS32_SDA12S2_DP,
   3750   BFD_RELOC_NDS32_SDA12S2_SP,
   3751   BFD_RELOC_NDS32_LO12S2_DP,
   3752   BFD_RELOC_NDS32_LO12S2_SP,
   3753 
   3754 /* for dwarf2 debug_line.  */
   3755   BFD_RELOC_NDS32_DWARF2_OP1,
   3756   BFD_RELOC_NDS32_DWARF2_OP2,
   3757   BFD_RELOC_NDS32_DWARF2_LEB,
   3758 
   3759 /* for eliminate 16-bit instructions  */
   3760   BFD_RELOC_NDS32_UPDATE_TA,
   3761 
   3762 /* for PIC object relaxation  */
   3763   BFD_RELOC_NDS32_PLT_GOTREL_LO20,
   3764   BFD_RELOC_NDS32_PLT_GOTREL_LO15,
   3765   BFD_RELOC_NDS32_PLT_GOTREL_LO19,
   3766   BFD_RELOC_NDS32_GOT_LO15,
   3767   BFD_RELOC_NDS32_GOT_LO19,
   3768   BFD_RELOC_NDS32_GOTOFF_LO15,
   3769   BFD_RELOC_NDS32_GOTOFF_LO19,
   3770   BFD_RELOC_NDS32_GOT15S2,
   3771   BFD_RELOC_NDS32_GOT17S2,
   3772 
   3773 /* NDS32 relocs.
   3774 This is a 5 bit absolute address.  */
   3775   BFD_RELOC_NDS32_5,
   3776 
   3777 /* This is a 10-bit unsigned pc-relative reloc with the right 1 bit assumed to be 0.  */
   3778   BFD_RELOC_NDS32_10_UPCREL,
   3779 
   3780 /* If fp were omitted, fp can used as another gp.  */
   3781   BFD_RELOC_NDS32_SDA_FP7U2_RELA,
   3782 
   3783 /* relaxation relative relocation types  */
   3784   BFD_RELOC_NDS32_RELAX_ENTRY,
   3785   BFD_RELOC_NDS32_GOT_SUFF,
   3786   BFD_RELOC_NDS32_GOTOFF_SUFF,
   3787   BFD_RELOC_NDS32_PLT_GOT_SUFF,
   3788   BFD_RELOC_NDS32_MULCALL_SUFF,
   3789   BFD_RELOC_NDS32_PTR,
   3790   BFD_RELOC_NDS32_PTR_COUNT,
   3791   BFD_RELOC_NDS32_PTR_RESOLVED,
   3792   BFD_RELOC_NDS32_PLTBLOCK,
   3793   BFD_RELOC_NDS32_RELAX_REGION_BEGIN,
   3794   BFD_RELOC_NDS32_RELAX_REGION_END,
   3795   BFD_RELOC_NDS32_MINUEND,
   3796   BFD_RELOC_NDS32_SUBTRAHEND,
   3797   BFD_RELOC_NDS32_DIFF8,
   3798   BFD_RELOC_NDS32_DIFF16,
   3799   BFD_RELOC_NDS32_DIFF32,
   3800   BFD_RELOC_NDS32_DIFF_ULEB128,
   3801   BFD_RELOC_NDS32_EMPTY,
   3802 
   3803 /* This is a 25 bit absolute address.  */
   3804   BFD_RELOC_NDS32_25_ABS,
   3805 
   3806 /* For ex9 and ifc using.  */
   3807   BFD_RELOC_NDS32_DATA,
   3808   BFD_RELOC_NDS32_TRAN,
   3809   BFD_RELOC_NDS32_17IFC_PCREL,
   3810   BFD_RELOC_NDS32_10IFCU_PCREL,
   3811 
   3812 /* For TLS.  */
   3813   BFD_RELOC_NDS32_TPOFF,
   3814   BFD_RELOC_NDS32_GOTTPOFF,
   3815   BFD_RELOC_NDS32_TLS_LE_HI20,
   3816   BFD_RELOC_NDS32_TLS_LE_LO12,
   3817   BFD_RELOC_NDS32_TLS_LE_20,
   3818   BFD_RELOC_NDS32_TLS_LE_15S0,
   3819   BFD_RELOC_NDS32_TLS_LE_15S1,
   3820   BFD_RELOC_NDS32_TLS_LE_15S2,
   3821   BFD_RELOC_NDS32_TLS_LE_ADD,
   3822   BFD_RELOC_NDS32_TLS_LE_LS,
   3823   BFD_RELOC_NDS32_TLS_IE_HI20,
   3824   BFD_RELOC_NDS32_TLS_IE_LO12,
   3825   BFD_RELOC_NDS32_TLS_IE_LO12S2,
   3826   BFD_RELOC_NDS32_TLS_IEGP_HI20,
   3827   BFD_RELOC_NDS32_TLS_IEGP_LO12,
   3828   BFD_RELOC_NDS32_TLS_IEGP_LO12S2,
   3829   BFD_RELOC_NDS32_TLS_IEGP_LW,
   3830   BFD_RELOC_NDS32_TLS_DESC,
   3831   BFD_RELOC_NDS32_TLS_DESC_HI20,
   3832   BFD_RELOC_NDS32_TLS_DESC_LO12,
   3833   BFD_RELOC_NDS32_TLS_DESC_20,
   3834   BFD_RELOC_NDS32_TLS_DESC_SDA17S2,
   3835   BFD_RELOC_NDS32_TLS_DESC_ADD,
   3836   BFD_RELOC_NDS32_TLS_DESC_FUNC,
   3837   BFD_RELOC_NDS32_TLS_DESC_CALL,
   3838   BFD_RELOC_NDS32_TLS_DESC_MEM,
   3839   BFD_RELOC_NDS32_REMOVE,
   3840   BFD_RELOC_NDS32_GROUP,
   3841 
   3842 /* For floating load store relaxation.  */
   3843   BFD_RELOC_NDS32_LSI,
   3844 
   3845 /* This is a 9-bit reloc  */
   3846   BFD_RELOC_V850_9_PCREL,
   3847 
   3848 /* This is a 22-bit reloc  */
   3849   BFD_RELOC_V850_22_PCREL,
   3850 
   3851 /* This is a 16 bit offset from the short data area pointer.  */
   3852   BFD_RELOC_V850_SDA_16_16_OFFSET,
   3853 
   3854 /* This is a 16 bit offset (of which only 15 bits are used) from the
   3855 short data area pointer.  */
   3856   BFD_RELOC_V850_SDA_15_16_OFFSET,
   3857 
   3858 /* This is a 16 bit offset from the zero data area pointer.  */
   3859   BFD_RELOC_V850_ZDA_16_16_OFFSET,
   3860 
   3861 /* This is a 16 bit offset (of which only 15 bits are used) from the
   3862 zero data area pointer.  */
   3863   BFD_RELOC_V850_ZDA_15_16_OFFSET,
   3864 
   3865 /* This is an 8 bit offset (of which only 6 bits are used) from the
   3866 tiny data area pointer.  */
   3867   BFD_RELOC_V850_TDA_6_8_OFFSET,
   3868 
   3869 /* This is an 8bit offset (of which only 7 bits are used) from the tiny
   3870 data area pointer.  */
   3871   BFD_RELOC_V850_TDA_7_8_OFFSET,
   3872 
   3873 /* This is a 7 bit offset from the tiny data area pointer.  */
   3874   BFD_RELOC_V850_TDA_7_7_OFFSET,
   3875 
   3876 /* This is a 16 bit offset from the tiny data area pointer.  */
   3877   BFD_RELOC_V850_TDA_16_16_OFFSET,
   3878 
   3879 /* This is a 5 bit offset (of which only 4 bits are used) from the tiny
   3880 data area pointer.  */
   3881   BFD_RELOC_V850_TDA_4_5_OFFSET,
   3882 
   3883 /* This is a 4 bit offset from the tiny data area pointer.  */
   3884   BFD_RELOC_V850_TDA_4_4_OFFSET,
   3885 
   3886 /* This is a 16 bit offset from the short data area pointer, with the
   3887 bits placed non-contiguously in the instruction.  */
   3888   BFD_RELOC_V850_SDA_16_16_SPLIT_OFFSET,
   3889 
   3890 /* This is a 16 bit offset from the zero data area pointer, with the
   3891 bits placed non-contiguously in the instruction.  */
   3892   BFD_RELOC_V850_ZDA_16_16_SPLIT_OFFSET,
   3893 
   3894 /* This is a 6 bit offset from the call table base pointer.  */
   3895   BFD_RELOC_V850_CALLT_6_7_OFFSET,
   3896 
   3897 /* This is a 16 bit offset from the call table base pointer.  */
   3898   BFD_RELOC_V850_CALLT_16_16_OFFSET,
   3899 
   3900 /* Used for relaxing indirect function calls.  */
   3901   BFD_RELOC_V850_LONGCALL,
   3902 
   3903 /* Used for relaxing indirect jumps.  */
   3904   BFD_RELOC_V850_LONGJUMP,
   3905 
   3906 /* Used to maintain alignment whilst relaxing.  */
   3907   BFD_RELOC_V850_ALIGN,
   3908 
   3909 /* This is a variation of BFD_RELOC_LO16 that can be used in v850e ld.bu
   3910 instructions.  */
   3911   BFD_RELOC_V850_LO16_SPLIT_OFFSET,
   3912 
   3913 /* This is a 16-bit reloc.  */
   3914   BFD_RELOC_V850_16_PCREL,
   3915 
   3916 /* This is a 17-bit reloc.  */
   3917   BFD_RELOC_V850_17_PCREL,
   3918 
   3919 /* This is a 23-bit reloc.  */
   3920   BFD_RELOC_V850_23,
   3921 
   3922 /* This is a 32-bit reloc.  */
   3923   BFD_RELOC_V850_32_PCREL,
   3924 
   3925 /* This is a 32-bit reloc.  */
   3926   BFD_RELOC_V850_32_ABS,
   3927 
   3928 /* This is a 16-bit reloc.  */
   3929   BFD_RELOC_V850_16_SPLIT_OFFSET,
   3930 
   3931 /* This is a 16-bit reloc.  */
   3932   BFD_RELOC_V850_16_S1,
   3933 
   3934 /* Low 16 bits. 16 bit shifted by 1.  */
   3935   BFD_RELOC_V850_LO16_S1,
   3936 
   3937 /* This is a 16 bit offset from the call table base pointer.  */
   3938   BFD_RELOC_V850_CALLT_15_16_OFFSET,
   3939 
   3940 /* DSO relocations.  */
   3941   BFD_RELOC_V850_32_GOTPCREL,
   3942 
   3943 /* DSO relocations.  */
   3944   BFD_RELOC_V850_16_GOT,
   3945 
   3946 /* DSO relocations.  */
   3947   BFD_RELOC_V850_32_GOT,
   3948 
   3949 /* DSO relocations.  */
   3950   BFD_RELOC_V850_22_PLT_PCREL,
   3951 
   3952 /* DSO relocations.  */
   3953   BFD_RELOC_V850_32_PLT_PCREL,
   3954 
   3955 /* DSO relocations.  */
   3956   BFD_RELOC_V850_COPY,
   3957 
   3958 /* DSO relocations.  */
   3959   BFD_RELOC_V850_GLOB_DAT,
   3960 
   3961 /* DSO relocations.  */
   3962   BFD_RELOC_V850_JMP_SLOT,
   3963 
   3964 /* DSO relocations.  */
   3965   BFD_RELOC_V850_RELATIVE,
   3966 
   3967 /* DSO relocations.  */
   3968   BFD_RELOC_V850_16_GOTOFF,
   3969 
   3970 /* DSO relocations.  */
   3971   BFD_RELOC_V850_32_GOTOFF,
   3972 
   3973 /* start code.  */
   3974   BFD_RELOC_V850_CODE,
   3975 
   3976 /* start data in text.  */
   3977   BFD_RELOC_V850_DATA,
   3978 
   3979 /* This is a 8bit DP reloc for the tms320c30, where the most
   3980 significant 8 bits of a 24 bit word are placed into the least
   3981 significant 8 bits of the opcode.  */
   3982   BFD_RELOC_TIC30_LDP,
   3983 
   3984 /* This is a 7bit reloc for the tms320c54x, where the least
   3985 significant 7 bits of a 16 bit word are placed into the least
   3986 significant 7 bits of the opcode.  */
   3987   BFD_RELOC_TIC54X_PARTLS7,
   3988 
   3989 /* This is a 9bit DP reloc for the tms320c54x, where the most
   3990 significant 9 bits of a 16 bit word are placed into the least
   3991 significant 9 bits of the opcode.  */
   3992   BFD_RELOC_TIC54X_PARTMS9,
   3993 
   3994 /* This is an extended address 23-bit reloc for the tms320c54x.  */
   3995   BFD_RELOC_TIC54X_23,
   3996 
   3997 /* This is a 16-bit reloc for the tms320c54x, where the least
   3998 significant 16 bits of a 23-bit extended address are placed into
   3999 the opcode.  */
   4000   BFD_RELOC_TIC54X_16_OF_23,
   4001 
   4002 /* This is a reloc for the tms320c54x, where the most
   4003 significant 7 bits of a 23-bit extended address are placed into
   4004 the opcode.  */
   4005   BFD_RELOC_TIC54X_MS7_OF_23,
   4006 
   4007 /* TMS320C6000 relocations.  */
   4008   BFD_RELOC_C6000_PCR_S21,
   4009   BFD_RELOC_C6000_PCR_S12,
   4010   BFD_RELOC_C6000_PCR_S10,
   4011   BFD_RELOC_C6000_PCR_S7,
   4012   BFD_RELOC_C6000_ABS_S16,
   4013   BFD_RELOC_C6000_ABS_L16,
   4014   BFD_RELOC_C6000_ABS_H16,
   4015   BFD_RELOC_C6000_SBR_U15_B,
   4016   BFD_RELOC_C6000_SBR_U15_H,
   4017   BFD_RELOC_C6000_SBR_U15_W,
   4018   BFD_RELOC_C6000_SBR_S16,
   4019   BFD_RELOC_C6000_SBR_L16_B,
   4020   BFD_RELOC_C6000_SBR_L16_H,
   4021   BFD_RELOC_C6000_SBR_L16_W,
   4022   BFD_RELOC_C6000_SBR_H16_B,
   4023   BFD_RELOC_C6000_SBR_H16_H,
   4024   BFD_RELOC_C6000_SBR_H16_W,
   4025   BFD_RELOC_C6000_SBR_GOT_U15_W,
   4026   BFD_RELOC_C6000_SBR_GOT_L16_W,
   4027   BFD_RELOC_C6000_SBR_GOT_H16_W,
   4028   BFD_RELOC_C6000_DSBT_INDEX,
   4029   BFD_RELOC_C6000_PREL31,
   4030   BFD_RELOC_C6000_COPY,
   4031   BFD_RELOC_C6000_JUMP_SLOT,
   4032   BFD_RELOC_C6000_EHTYPE,
   4033   BFD_RELOC_C6000_PCR_H16,
   4034   BFD_RELOC_C6000_PCR_L16,
   4035   BFD_RELOC_C6000_ALIGN,
   4036   BFD_RELOC_C6000_FPHEAD,
   4037   BFD_RELOC_C6000_NOCMP,
   4038 
   4039 /* This is a 48 bit reloc for the FR30 that stores 32 bits.  */
   4040   BFD_RELOC_FR30_48,
   4041 
   4042 /* This is a 32 bit reloc for the FR30 that stores 20 bits split up into
   4043 two sections.  */
   4044   BFD_RELOC_FR30_20,
   4045 
   4046 /* This is a 16 bit reloc for the FR30 that stores a 6 bit word offset in
   4047 4 bits.  */
   4048   BFD_RELOC_FR30_6_IN_4,
   4049 
   4050 /* This is a 16 bit reloc for the FR30 that stores an 8 bit byte offset
   4051 into 8 bits.  */
   4052   BFD_RELOC_FR30_8_IN_8,
   4053 
   4054 /* This is a 16 bit reloc for the FR30 that stores a 9 bit short offset
   4055 into 8 bits.  */
   4056   BFD_RELOC_FR30_9_IN_8,
   4057 
   4058 /* This is a 16 bit reloc for the FR30 that stores a 10 bit word offset
   4059 into 8 bits.  */
   4060   BFD_RELOC_FR30_10_IN_8,
   4061 
   4062 /* This is a 16 bit reloc for the FR30 that stores a 9 bit pc relative
   4063 short offset into 8 bits.  */
   4064   BFD_RELOC_FR30_9_PCREL,
   4065 
   4066 /* This is a 16 bit reloc for the FR30 that stores a 12 bit pc relative
   4067 short offset into 11 bits.  */
   4068   BFD_RELOC_FR30_12_PCREL,
   4069 
   4070 /* Motorola Mcore relocations.  */
   4071   BFD_RELOC_MCORE_PCREL_IMM8BY4,
   4072   BFD_RELOC_MCORE_PCREL_IMM11BY2,
   4073   BFD_RELOC_MCORE_PCREL_IMM4BY2,
   4074   BFD_RELOC_MCORE_PCREL_32,
   4075   BFD_RELOC_MCORE_PCREL_JSR_IMM11BY2,
   4076   BFD_RELOC_MCORE_RVA,
   4077 
   4078 /* Toshiba Media Processor Relocations.  */
   4079   BFD_RELOC_MEP_8,
   4080   BFD_RELOC_MEP_16,
   4081   BFD_RELOC_MEP_32,
   4082   BFD_RELOC_MEP_PCREL8A2,
   4083   BFD_RELOC_MEP_PCREL12A2,
   4084   BFD_RELOC_MEP_PCREL17A2,
   4085   BFD_RELOC_MEP_PCREL24A2,
   4086   BFD_RELOC_MEP_PCABS24A2,
   4087   BFD_RELOC_MEP_LOW16,
   4088   BFD_RELOC_MEP_HI16U,
   4089   BFD_RELOC_MEP_HI16S,
   4090   BFD_RELOC_MEP_GPREL,
   4091   BFD_RELOC_MEP_TPREL,
   4092   BFD_RELOC_MEP_TPREL7,
   4093   BFD_RELOC_MEP_TPREL7A2,
   4094   BFD_RELOC_MEP_TPREL7A4,
   4095   BFD_RELOC_MEP_UIMM24,
   4096   BFD_RELOC_MEP_ADDR24A4,
   4097   BFD_RELOC_MEP_GNU_VTINHERIT,
   4098   BFD_RELOC_MEP_GNU_VTENTRY,
   4099 
   4100 
   4101 /* Imagination Technologies Meta relocations.  */
   4102   BFD_RELOC_METAG_HIADDR16,
   4103   BFD_RELOC_METAG_LOADDR16,
   4104   BFD_RELOC_METAG_RELBRANCH,
   4105   BFD_RELOC_METAG_GETSETOFF,
   4106   BFD_RELOC_METAG_HIOG,
   4107   BFD_RELOC_METAG_LOOG,
   4108   BFD_RELOC_METAG_REL8,
   4109   BFD_RELOC_METAG_REL16,
   4110   BFD_RELOC_METAG_HI16_GOTOFF,
   4111   BFD_RELOC_METAG_LO16_GOTOFF,
   4112   BFD_RELOC_METAG_GETSET_GOTOFF,
   4113   BFD_RELOC_METAG_GETSET_GOT,
   4114   BFD_RELOC_METAG_HI16_GOTPC,
   4115   BFD_RELOC_METAG_LO16_GOTPC,
   4116   BFD_RELOC_METAG_HI16_PLT,
   4117   BFD_RELOC_METAG_LO16_PLT,
   4118   BFD_RELOC_METAG_RELBRANCH_PLT,
   4119   BFD_RELOC_METAG_GOTOFF,
   4120   BFD_RELOC_METAG_PLT,
   4121   BFD_RELOC_METAG_COPY,
   4122   BFD_RELOC_METAG_JMP_SLOT,
   4123   BFD_RELOC_METAG_RELATIVE,
   4124   BFD_RELOC_METAG_GLOB_DAT,
   4125   BFD_RELOC_METAG_TLS_GD,
   4126   BFD_RELOC_METAG_TLS_LDM,
   4127   BFD_RELOC_METAG_TLS_LDO_HI16,
   4128   BFD_RELOC_METAG_TLS_LDO_LO16,
   4129   BFD_RELOC_METAG_TLS_LDO,
   4130   BFD_RELOC_METAG_TLS_IE,
   4131   BFD_RELOC_METAG_TLS_IENONPIC,
   4132   BFD_RELOC_METAG_TLS_IENONPIC_HI16,
   4133   BFD_RELOC_METAG_TLS_IENONPIC_LO16,
   4134   BFD_RELOC_METAG_TLS_TPOFF,
   4135   BFD_RELOC_METAG_TLS_DTPMOD,
   4136   BFD_RELOC_METAG_TLS_DTPOFF,
   4137   BFD_RELOC_METAG_TLS_LE,
   4138   BFD_RELOC_METAG_TLS_LE_HI16,
   4139   BFD_RELOC_METAG_TLS_LE_LO16,
   4140 
   4141 /* These are relocations for the GETA instruction.  */
   4142   BFD_RELOC_MMIX_GETA,
   4143   BFD_RELOC_MMIX_GETA_1,
   4144   BFD_RELOC_MMIX_GETA_2,
   4145   BFD_RELOC_MMIX_GETA_3,
   4146 
   4147 /* These are relocations for a conditional branch instruction.  */
   4148   BFD_RELOC_MMIX_CBRANCH,
   4149   BFD_RELOC_MMIX_CBRANCH_J,
   4150   BFD_RELOC_MMIX_CBRANCH_1,
   4151   BFD_RELOC_MMIX_CBRANCH_2,
   4152   BFD_RELOC_MMIX_CBRANCH_3,
   4153 
   4154 /* These are relocations for the PUSHJ instruction.  */
   4155   BFD_RELOC_MMIX_PUSHJ,
   4156   BFD_RELOC_MMIX_PUSHJ_1,
   4157   BFD_RELOC_MMIX_PUSHJ_2,
   4158   BFD_RELOC_MMIX_PUSHJ_3,
   4159   BFD_RELOC_MMIX_PUSHJ_STUBBABLE,
   4160 
   4161 /* These are relocations for the JMP instruction.  */
   4162   BFD_RELOC_MMIX_JMP,
   4163   BFD_RELOC_MMIX_JMP_1,
   4164   BFD_RELOC_MMIX_JMP_2,
   4165   BFD_RELOC_MMIX_JMP_3,
   4166 
   4167 /* This is a relocation for a relative address as in a GETA instruction or
   4168 a branch.  */
   4169   BFD_RELOC_MMIX_ADDR19,
   4170 
   4171 /* This is a relocation for a relative address as in a JMP instruction.  */
   4172   BFD_RELOC_MMIX_ADDR27,
   4173 
   4174 /* This is a relocation for an instruction field that may be a general
   4175 register or a value 0..255.  */
   4176   BFD_RELOC_MMIX_REG_OR_BYTE,
   4177 
   4178 /* This is a relocation for an instruction field that may be a general
   4179 register.  */
   4180   BFD_RELOC_MMIX_REG,
   4181 
   4182 /* This is a relocation for two instruction fields holding a register and
   4183 an offset, the equivalent of the relocation.  */
   4184   BFD_RELOC_MMIX_BASE_PLUS_OFFSET,
   4185 
   4186 /* This relocation is an assertion that the expression is not allocated as
   4187 a global register.  It does not modify contents.  */
   4188   BFD_RELOC_MMIX_LOCAL,
   4189 
   4190 /* This is a 16 bit reloc for the AVR that stores 8 bit pc relative
   4191 short offset into 7 bits.  */
   4192   BFD_RELOC_AVR_7_PCREL,
   4193 
   4194 /* This is a 16 bit reloc for the AVR that stores 13 bit pc relative
   4195 short offset into 12 bits.  */
   4196   BFD_RELOC_AVR_13_PCREL,
   4197 
   4198 /* This is a 16 bit reloc for the AVR that stores 17 bit value (usually
   4199 program memory address) into 16 bits.  */
   4200   BFD_RELOC_AVR_16_PM,
   4201 
   4202 /* This is a 16 bit reloc for the AVR that stores 8 bit value (usually
   4203 data memory address) into 8 bit immediate value of LDI insn.  */
   4204   BFD_RELOC_AVR_LO8_LDI,
   4205 
   4206 /* This is a 16 bit reloc for the AVR that stores 8 bit value (high 8 bit
   4207 of data memory address) into 8 bit immediate value of LDI insn.  */
   4208   BFD_RELOC_AVR_HI8_LDI,
   4209 
   4210 /* This is a 16 bit reloc for the AVR that stores 8 bit value (most high 8 bit
   4211 of program memory address) into 8 bit immediate value of LDI insn.  */
   4212   BFD_RELOC_AVR_HH8_LDI,
   4213 
   4214 /* This is a 16 bit reloc for the AVR that stores 8 bit value (most high 8 bit
   4215 of 32 bit value) into 8 bit immediate value of LDI insn.  */
   4216   BFD_RELOC_AVR_MS8_LDI,
   4217 
   4218 /* This is a 16 bit reloc for the AVR that stores negated 8 bit value
   4219 (usually data memory address) into 8 bit immediate value of SUBI insn.  */
   4220   BFD_RELOC_AVR_LO8_LDI_NEG,
   4221 
   4222 /* This is a 16 bit reloc for the AVR that stores negated 8 bit value
   4223 (high 8 bit of data memory address) into 8 bit immediate value of
   4224 SUBI insn.  */
   4225   BFD_RELOC_AVR_HI8_LDI_NEG,
   4226 
   4227 /* This is a 16 bit reloc for the AVR that stores negated 8 bit value
   4228 (most high 8 bit of program memory address) into 8 bit immediate value
   4229 of LDI or SUBI insn.  */
   4230   BFD_RELOC_AVR_HH8_LDI_NEG,
   4231 
   4232 /* This is a 16 bit reloc for the AVR that stores negated 8 bit value (msb
   4233 of 32 bit value) into 8 bit immediate value of LDI insn.  */
   4234   BFD_RELOC_AVR_MS8_LDI_NEG,
   4235 
   4236 /* This is a 16 bit reloc for the AVR that stores 8 bit value (usually
   4237 command address) into 8 bit immediate value of LDI insn.  */
   4238   BFD_RELOC_AVR_LO8_LDI_PM,
   4239 
   4240 /* This is a 16 bit reloc for the AVR that stores 8 bit value
   4241 (command address) into 8 bit immediate value of LDI insn. If the address
   4242 is beyond the 128k boundary, the linker inserts a jump stub for this reloc
   4243 in the lower 128k.  */
   4244   BFD_RELOC_AVR_LO8_LDI_GS,
   4245 
   4246 /* This is a 16 bit reloc for the AVR that stores 8 bit value (high 8 bit
   4247 of command address) into 8 bit immediate value of LDI insn.  */
   4248   BFD_RELOC_AVR_HI8_LDI_PM,
   4249 
   4250 /* This is a 16 bit reloc for the AVR that stores 8 bit value (high 8 bit
   4251 of command address) into 8 bit immediate value of LDI insn.  If the address
   4252 is beyond the 128k boundary, the linker inserts a jump stub for this reloc
   4253 below 128k.  */
   4254   BFD_RELOC_AVR_HI8_LDI_GS,
   4255 
   4256 /* This is a 16 bit reloc for the AVR that stores 8 bit value (most high 8 bit
   4257 of command address) into 8 bit immediate value of LDI insn.  */
   4258   BFD_RELOC_AVR_HH8_LDI_PM,
   4259 
   4260 /* This is a 16 bit reloc for the AVR that stores negated 8 bit value
   4261 (usually command address) into 8 bit immediate value of SUBI insn.  */
   4262   BFD_RELOC_AVR_LO8_LDI_PM_NEG,
   4263 
   4264 /* This is a 16 bit reloc for the AVR that stores negated 8 bit value
   4265 (high 8 bit of 16 bit command address) into 8 bit immediate value
   4266 of SUBI insn.  */
   4267   BFD_RELOC_AVR_HI8_LDI_PM_NEG,
   4268 
   4269 /* This is a 16 bit reloc for the AVR that stores negated 8 bit value
   4270 (high 6 bit of 22 bit command address) into 8 bit immediate
   4271 value of SUBI insn.  */
   4272   BFD_RELOC_AVR_HH8_LDI_PM_NEG,
   4273 
   4274 /* This is a 32 bit reloc for the AVR that stores 23 bit value
   4275 into 22 bits.  */
   4276   BFD_RELOC_AVR_CALL,
   4277 
   4278 /* This is a 16 bit reloc for the AVR that stores all needed bits
   4279 for absolute addressing with ldi with overflow check to linktime  */
   4280   BFD_RELOC_AVR_LDI,
   4281 
   4282 /* This is a 6 bit reloc for the AVR that stores offset for ldd/std
   4283 instructions  */
   4284   BFD_RELOC_AVR_6,
   4285 
   4286 /* This is a 6 bit reloc for the AVR that stores offset for adiw/sbiw
   4287 instructions  */
   4288   BFD_RELOC_AVR_6_ADIW,
   4289 
   4290 /* This is a 8 bit reloc for the AVR that stores bits 0..7 of a symbol
   4291 in .byte lo8(symbol)  */
   4292   BFD_RELOC_AVR_8_LO,
   4293 
   4294 /* This is a 8 bit reloc for the AVR that stores bits 8..15 of a symbol
   4295 in .byte hi8(symbol)  */
   4296   BFD_RELOC_AVR_8_HI,
   4297 
   4298 /* This is a 8 bit reloc for the AVR that stores bits 16..23 of a symbol
   4299 in .byte hlo8(symbol)  */
   4300   BFD_RELOC_AVR_8_HLO,
   4301 
   4302 /* AVR relocations to mark the difference of two local symbols.
   4303 These are only needed to support linker relaxation and can be ignored
   4304 when not relaxing.  The field is set to the value of the difference
   4305 assuming no relaxation.  The relocation encodes the position of the
   4306 second symbol so the linker can determine whether to adjust the field
   4307 value.  */
   4308   BFD_RELOC_AVR_DIFF8,
   4309   BFD_RELOC_AVR_DIFF16,
   4310   BFD_RELOC_AVR_DIFF32,
   4311 
   4312 /* This is a 7 bit reloc for the AVR that stores SRAM address for 16bit
   4313 lds and sts instructions supported only tiny core.  */
   4314   BFD_RELOC_AVR_LDS_STS_16,
   4315 
   4316 /* This is a 6 bit reloc for the AVR that stores an I/O register
   4317 number for the IN and OUT instructions  */
   4318   BFD_RELOC_AVR_PORT6,
   4319 
   4320 /* This is a 5 bit reloc for the AVR that stores an I/O register
   4321 number for the SBIC, SBIS, SBI and CBI instructions  */
   4322   BFD_RELOC_AVR_PORT5,
   4323 
   4324 /* RISC-V relocations.  */
   4325   BFD_RELOC_RISCV_HI20,
   4326   BFD_RELOC_RISCV_PCREL_HI20,
   4327   BFD_RELOC_RISCV_PCREL_LO12_I,
   4328   BFD_RELOC_RISCV_PCREL_LO12_S,
   4329   BFD_RELOC_RISCV_LO12_I,
   4330   BFD_RELOC_RISCV_LO12_S,
   4331   BFD_RELOC_RISCV_GPREL12_I,
   4332   BFD_RELOC_RISCV_GPREL12_S,
   4333   BFD_RELOC_RISCV_TPREL_HI20,
   4334   BFD_RELOC_RISCV_TPREL_LO12_I,
   4335   BFD_RELOC_RISCV_TPREL_LO12_S,
   4336   BFD_RELOC_RISCV_TPREL_ADD,
   4337   BFD_RELOC_RISCV_CALL,
   4338   BFD_RELOC_RISCV_CALL_PLT,
   4339   BFD_RELOC_RISCV_ADD8,
   4340   BFD_RELOC_RISCV_ADD16,
   4341   BFD_RELOC_RISCV_ADD32,
   4342   BFD_RELOC_RISCV_ADD64,
   4343   BFD_RELOC_RISCV_SUB8,
   4344   BFD_RELOC_RISCV_SUB16,
   4345   BFD_RELOC_RISCV_SUB32,
   4346   BFD_RELOC_RISCV_SUB64,
   4347   BFD_RELOC_RISCV_GOT_HI20,
   4348   BFD_RELOC_RISCV_TLS_GOT_HI20,
   4349   BFD_RELOC_RISCV_TLS_GD_HI20,
   4350   BFD_RELOC_RISCV_JMP,
   4351   BFD_RELOC_RISCV_TLS_DTPMOD32,
   4352   BFD_RELOC_RISCV_TLS_DTPREL32,
   4353   BFD_RELOC_RISCV_TLS_DTPMOD64,
   4354   BFD_RELOC_RISCV_TLS_DTPREL64,
   4355   BFD_RELOC_RISCV_TLS_TPREL32,
   4356   BFD_RELOC_RISCV_TLS_TPREL64,
   4357   BFD_RELOC_RISCV_ALIGN,
   4358   BFD_RELOC_RISCV_RVC_BRANCH,
   4359   BFD_RELOC_RISCV_RVC_JUMP,
   4360   BFD_RELOC_RISCV_RVC_LUI,
   4361   BFD_RELOC_RISCV_GPREL_I,
   4362   BFD_RELOC_RISCV_GPREL_S,
   4363   BFD_RELOC_RISCV_TPREL_I,
   4364   BFD_RELOC_RISCV_TPREL_S,
   4365   BFD_RELOC_RISCV_RELAX,
   4366   BFD_RELOC_RISCV_CFA,
   4367   BFD_RELOC_RISCV_SUB6,
   4368   BFD_RELOC_RISCV_SET6,
   4369   BFD_RELOC_RISCV_SET8,
   4370   BFD_RELOC_RISCV_SET16,
   4371   BFD_RELOC_RISCV_SET32,
   4372   BFD_RELOC_RISCV_32_PCREL,
   4373 
   4374 /* Renesas RL78 Relocations.  */
   4375   BFD_RELOC_RL78_NEG8,
   4376   BFD_RELOC_RL78_NEG16,
   4377   BFD_RELOC_RL78_NEG24,
   4378   BFD_RELOC_RL78_NEG32,
   4379   BFD_RELOC_RL78_16_OP,
   4380   BFD_RELOC_RL78_24_OP,
   4381   BFD_RELOC_RL78_32_OP,
   4382   BFD_RELOC_RL78_8U,
   4383   BFD_RELOC_RL78_16U,
   4384   BFD_RELOC_RL78_24U,
   4385   BFD_RELOC_RL78_DIR3U_PCREL,
   4386   BFD_RELOC_RL78_DIFF,
   4387   BFD_RELOC_RL78_GPRELB,
   4388   BFD_RELOC_RL78_GPRELW,
   4389   BFD_RELOC_RL78_GPRELL,
   4390   BFD_RELOC_RL78_SYM,
   4391   BFD_RELOC_RL78_OP_SUBTRACT,
   4392   BFD_RELOC_RL78_OP_NEG,
   4393   BFD_RELOC_RL78_OP_AND,
   4394   BFD_RELOC_RL78_OP_SHRA,
   4395   BFD_RELOC_RL78_ABS8,
   4396   BFD_RELOC_RL78_ABS16,
   4397   BFD_RELOC_RL78_ABS16_REV,
   4398   BFD_RELOC_RL78_ABS32,
   4399   BFD_RELOC_RL78_ABS32_REV,
   4400   BFD_RELOC_RL78_ABS16U,
   4401   BFD_RELOC_RL78_ABS16UW,
   4402   BFD_RELOC_RL78_ABS16UL,
   4403   BFD_RELOC_RL78_RELAX,
   4404   BFD_RELOC_RL78_HI16,
   4405   BFD_RELOC_RL78_HI8,
   4406   BFD_RELOC_RL78_LO16,
   4407   BFD_RELOC_RL78_CODE,
   4408   BFD_RELOC_RL78_SADDR,
   4409 
   4410 /* Renesas RX Relocations.  */
   4411   BFD_RELOC_RX_NEG8,
   4412   BFD_RELOC_RX_NEG16,
   4413   BFD_RELOC_RX_NEG24,
   4414   BFD_RELOC_RX_NEG32,
   4415   BFD_RELOC_RX_16_OP,
   4416   BFD_RELOC_RX_24_OP,
   4417   BFD_RELOC_RX_32_OP,
   4418   BFD_RELOC_RX_8U,
   4419   BFD_RELOC_RX_16U,
   4420   BFD_RELOC_RX_24U,
   4421   BFD_RELOC_RX_DIR3U_PCREL,
   4422   BFD_RELOC_RX_DIFF,
   4423   BFD_RELOC_RX_GPRELB,
   4424   BFD_RELOC_RX_GPRELW,
   4425   BFD_RELOC_RX_GPRELL,
   4426   BFD_RELOC_RX_SYM,
   4427   BFD_RELOC_RX_OP_SUBTRACT,
   4428   BFD_RELOC_RX_OP_NEG,
   4429   BFD_RELOC_RX_ABS8,
   4430   BFD_RELOC_RX_ABS16,
   4431   BFD_RELOC_RX_ABS16_REV,
   4432   BFD_RELOC_RX_ABS32,
   4433   BFD_RELOC_RX_ABS32_REV,
   4434   BFD_RELOC_RX_ABS16U,
   4435   BFD_RELOC_RX_ABS16UW,
   4436   BFD_RELOC_RX_ABS16UL,
   4437   BFD_RELOC_RX_RELAX,
   4438 
   4439 /* Direct 12 bit.  */
   4440   BFD_RELOC_390_12,
   4441 
   4442 /* 12 bit GOT offset.  */
   4443   BFD_RELOC_390_GOT12,
   4444 
   4445 /* 32 bit PC relative PLT address.  */
   4446   BFD_RELOC_390_PLT32,
   4447 
   4448 /* Copy symbol at runtime.  */
   4449   BFD_RELOC_390_COPY,
   4450 
   4451 /* Create GOT entry.  */
   4452   BFD_RELOC_390_GLOB_DAT,
   4453 
   4454 /* Create PLT entry.  */
   4455   BFD_RELOC_390_JMP_SLOT,
   4456 
   4457 /* Adjust by program base.  */
   4458   BFD_RELOC_390_RELATIVE,
   4459 
   4460 /* 32 bit PC relative offset to GOT.  */
   4461   BFD_RELOC_390_GOTPC,
   4462 
   4463 /* 16 bit GOT offset.  */
   4464   BFD_RELOC_390_GOT16,
   4465 
   4466 /* PC relative 12 bit shifted by 1.  */
   4467   BFD_RELOC_390_PC12DBL,
   4468 
   4469 /* 12 bit PC rel. PLT shifted by 1.  */
   4470   BFD_RELOC_390_PLT12DBL,
   4471 
   4472 /* PC relative 16 bit shifted by 1.  */
   4473   BFD_RELOC_390_PC16DBL,
   4474 
   4475 /* 16 bit PC rel. PLT shifted by 1.  */
   4476   BFD_RELOC_390_PLT16DBL,
   4477 
   4478 /* PC relative 24 bit shifted by 1.  */
   4479   BFD_RELOC_390_PC24DBL,
   4480 
   4481 /* 24 bit PC rel. PLT shifted by 1.  */
   4482   BFD_RELOC_390_PLT24DBL,
   4483 
   4484 /* PC relative 32 bit shifted by 1.  */
   4485   BFD_RELOC_390_PC32DBL,
   4486 
   4487 /* 32 bit PC rel. PLT shifted by 1.  */
   4488   BFD_RELOC_390_PLT32DBL,
   4489 
   4490 /* 32 bit PC rel. GOT shifted by 1.  */
   4491   BFD_RELOC_390_GOTPCDBL,
   4492 
   4493 /* 64 bit GOT offset.  */
   4494   BFD_RELOC_390_GOT64,
   4495 
   4496 /* 64 bit PC relative PLT address.  */
   4497   BFD_RELOC_390_PLT64,
   4498 
   4499 /* 32 bit rel. offset to GOT entry.  */
   4500   BFD_RELOC_390_GOTENT,
   4501 
   4502 /* 64 bit offset to GOT.  */
   4503   BFD_RELOC_390_GOTOFF64,
   4504 
   4505 /* 12-bit offset to symbol-entry within GOT, with PLT handling.  */
   4506   BFD_RELOC_390_GOTPLT12,
   4507 
   4508 /* 16-bit offset to symbol-entry within GOT, with PLT handling.  */
   4509   BFD_RELOC_390_GOTPLT16,
   4510 
   4511 /* 32-bit offset to symbol-entry within GOT, with PLT handling.  */
   4512   BFD_RELOC_390_GOTPLT32,
   4513 
   4514 /* 64-bit offset to symbol-entry within GOT, with PLT handling.  */
   4515   BFD_RELOC_390_GOTPLT64,
   4516 
   4517 /* 32-bit rel. offset to symbol-entry within GOT, with PLT handling.  */
   4518   BFD_RELOC_390_GOTPLTENT,
   4519 
   4520 /* 16-bit rel. offset from the GOT to a PLT entry.  */
   4521   BFD_RELOC_390_PLTOFF16,
   4522 
   4523 /* 32-bit rel. offset from the GOT to a PLT entry.  */
   4524   BFD_RELOC_390_PLTOFF32,
   4525 
   4526 /* 64-bit rel. offset from the GOT to a PLT entry.  */
   4527   BFD_RELOC_390_PLTOFF64,
   4528 
   4529 /* s390 tls relocations.  */
   4530   BFD_RELOC_390_TLS_LOAD,
   4531   BFD_RELOC_390_TLS_GDCALL,
   4532   BFD_RELOC_390_TLS_LDCALL,
   4533   BFD_RELOC_390_TLS_GD32,
   4534   BFD_RELOC_390_TLS_GD64,
   4535   BFD_RELOC_390_TLS_GOTIE12,
   4536   BFD_RELOC_390_TLS_GOTIE32,
   4537   BFD_RELOC_390_TLS_GOTIE64,
   4538   BFD_RELOC_390_TLS_LDM32,
   4539   BFD_RELOC_390_TLS_LDM64,
   4540   BFD_RELOC_390_TLS_IE32,
   4541   BFD_RELOC_390_TLS_IE64,
   4542   BFD_RELOC_390_TLS_IEENT,
   4543   BFD_RELOC_390_TLS_LE32,
   4544   BFD_RELOC_390_TLS_LE64,
   4545   BFD_RELOC_390_TLS_LDO32,
   4546   BFD_RELOC_390_TLS_LDO64,
   4547   BFD_RELOC_390_TLS_DTPMOD,
   4548   BFD_RELOC_390_TLS_DTPOFF,
   4549   BFD_RELOC_390_TLS_TPOFF,
   4550 
   4551 /* Long displacement extension.  */
   4552   BFD_RELOC_390_20,
   4553   BFD_RELOC_390_GOT20,
   4554   BFD_RELOC_390_GOTPLT20,
   4555   BFD_RELOC_390_TLS_GOTIE20,
   4556 
   4557 /* STT_GNU_IFUNC relocation.  */
   4558   BFD_RELOC_390_IRELATIVE,
   4559 
   4560 /* Score relocations
   4561 Low 16 bit for load/store  */
   4562   BFD_RELOC_SCORE_GPREL15,
   4563 
   4564 /* This is a 24-bit reloc with the right 1 bit assumed to be 0  */
   4565   BFD_RELOC_SCORE_DUMMY2,
   4566   BFD_RELOC_SCORE_JMP,
   4567 
   4568 /* This is a 19-bit reloc with the right 1 bit assumed to be 0  */
   4569   BFD_RELOC_SCORE_BRANCH,
   4570 
   4571 /* This is a 32-bit reloc for 48-bit instructions.  */
   4572   BFD_RELOC_SCORE_IMM30,
   4573 
   4574 /* This is a 32-bit reloc for 48-bit instructions.  */
   4575   BFD_RELOC_SCORE_IMM32,
   4576 
   4577 /* This is a 11-bit reloc with the right 1 bit assumed to be 0  */
   4578   BFD_RELOC_SCORE16_JMP,
   4579 
   4580 /* This is a 8-bit reloc with the right 1 bit assumed to be 0  */
   4581   BFD_RELOC_SCORE16_BRANCH,
   4582 
   4583 /* This is a 9-bit reloc with the right 1 bit assumed to be 0  */
   4584   BFD_RELOC_SCORE_BCMP,
   4585 
   4586 /* Undocumented Score relocs  */
   4587   BFD_RELOC_SCORE_GOT15,
   4588   BFD_RELOC_SCORE_GOT_LO16,
   4589   BFD_RELOC_SCORE_CALL15,
   4590   BFD_RELOC_SCORE_DUMMY_HI16,
   4591 
   4592 /* Scenix IP2K - 9-bit register number / data address  */
   4593   BFD_RELOC_IP2K_FR9,
   4594 
   4595 /* Scenix IP2K - 4-bit register/data bank number  */
   4596   BFD_RELOC_IP2K_BANK,
   4597 
   4598 /* Scenix IP2K - low 13 bits of instruction word address  */
   4599   BFD_RELOC_IP2K_ADDR16CJP,
   4600 
   4601 /* Scenix IP2K - high 3 bits of instruction word address  */
   4602   BFD_RELOC_IP2K_PAGE3,
   4603 
   4604 /* Scenix IP2K - ext/low/high 8 bits of data address  */
   4605   BFD_RELOC_IP2K_LO8DATA,
   4606   BFD_RELOC_IP2K_HI8DATA,
   4607   BFD_RELOC_IP2K_EX8DATA,
   4608 
   4609 /* Scenix IP2K - low/high 8 bits of instruction word address  */
   4610   BFD_RELOC_IP2K_LO8INSN,
   4611   BFD_RELOC_IP2K_HI8INSN,
   4612 
   4613 /* Scenix IP2K - even/odd PC modifier to modify snb pcl.0  */
   4614   BFD_RELOC_IP2K_PC_SKIP,
   4615 
   4616 /* Scenix IP2K - 16 bit word address in text section.  */
   4617   BFD_RELOC_IP2K_TEXT,
   4618 
   4619 /* Scenix IP2K - 7-bit sp or dp offset  */
   4620   BFD_RELOC_IP2K_FR_OFFSET,
   4621 
   4622 /* Scenix VPE4K coprocessor - data/insn-space addressing  */
   4623   BFD_RELOC_VPE4KMATH_DATA,
   4624   BFD_RELOC_VPE4KMATH_INSN,
   4625 
   4626 /* These two relocations are used by the linker to determine which of
   4627 the entries in a C++ virtual function table are actually used.  When
   4628 the --gc-sections option is given, the linker will zero out the entries
   4629 that are not used, so that the code for those functions need not be
   4630 included in the output.
   4631 
   4632 VTABLE_INHERIT is a zero-space relocation used to describe to the
   4633 linker the inheritance tree of a C++ virtual function table.  The
   4634 relocation's symbol should be the parent class' vtable, and the
   4635 relocation should be located at the child vtable.
   4636 
   4637 VTABLE_ENTRY is a zero-space relocation that describes the use of a
   4638 virtual function table entry.  The reloc's symbol should refer to the
   4639 table of the class mentioned in the code.  Off of that base, an offset
   4640 describes the entry that is being used.  For Rela hosts, this offset
   4641 is stored in the reloc's addend.  For Rel hosts, we are forced to put
   4642 this offset in the reloc's section offset.  */
   4643   BFD_RELOC_VTABLE_INHERIT,
   4644   BFD_RELOC_VTABLE_ENTRY,
   4645 
   4646 /* Intel IA64 Relocations.  */
   4647   BFD_RELOC_IA64_IMM14,
   4648   BFD_RELOC_IA64_IMM22,
   4649   BFD_RELOC_IA64_IMM64,
   4650   BFD_RELOC_IA64_DIR32MSB,
   4651   BFD_RELOC_IA64_DIR32LSB,
   4652   BFD_RELOC_IA64_DIR64MSB,
   4653   BFD_RELOC_IA64_DIR64LSB,
   4654   BFD_RELOC_IA64_GPREL22,
   4655   BFD_RELOC_IA64_GPREL64I,
   4656   BFD_RELOC_IA64_GPREL32MSB,
   4657   BFD_RELOC_IA64_GPREL32LSB,
   4658   BFD_RELOC_IA64_GPREL64MSB,
   4659   BFD_RELOC_IA64_GPREL64LSB,
   4660   BFD_RELOC_IA64_LTOFF22,
   4661   BFD_RELOC_IA64_LTOFF64I,
   4662   BFD_RELOC_IA64_PLTOFF22,
   4663   BFD_RELOC_IA64_PLTOFF64I,
   4664   BFD_RELOC_IA64_PLTOFF64MSB,
   4665   BFD_RELOC_IA64_PLTOFF64LSB,
   4666   BFD_RELOC_IA64_FPTR64I,
   4667   BFD_RELOC_IA64_FPTR32MSB,
   4668   BFD_RELOC_IA64_FPTR32LSB,
   4669   BFD_RELOC_IA64_FPTR64MSB,
   4670   BFD_RELOC_IA64_FPTR64LSB,
   4671   BFD_RELOC_IA64_PCREL21B,
   4672   BFD_RELOC_IA64_PCREL21BI,
   4673   BFD_RELOC_IA64_PCREL21M,
   4674   BFD_RELOC_IA64_PCREL21F,
   4675   BFD_RELOC_IA64_PCREL22,
   4676   BFD_RELOC_IA64_PCREL60B,
   4677   BFD_RELOC_IA64_PCREL64I,
   4678   BFD_RELOC_IA64_PCREL32MSB,
   4679   BFD_RELOC_IA64_PCREL32LSB,
   4680   BFD_RELOC_IA64_PCREL64MSB,
   4681   BFD_RELOC_IA64_PCREL64LSB,
   4682   BFD_RELOC_IA64_LTOFF_FPTR22,
   4683   BFD_RELOC_IA64_LTOFF_FPTR64I,
   4684   BFD_RELOC_IA64_LTOFF_FPTR32MSB,
   4685   BFD_RELOC_IA64_LTOFF_FPTR32LSB,
   4686   BFD_RELOC_IA64_LTOFF_FPTR64MSB,
   4687   BFD_RELOC_IA64_LTOFF_FPTR64LSB,
   4688   BFD_RELOC_IA64_SEGREL32MSB,
   4689   BFD_RELOC_IA64_SEGREL32LSB,
   4690   BFD_RELOC_IA64_SEGREL64MSB,
   4691   BFD_RELOC_IA64_SEGREL64LSB,
   4692   BFD_RELOC_IA64_SECREL32MSB,
   4693   BFD_RELOC_IA64_SECREL32LSB,
   4694   BFD_RELOC_IA64_SECREL64MSB,
   4695   BFD_RELOC_IA64_SECREL64LSB,
   4696   BFD_RELOC_IA64_REL32MSB,
   4697   BFD_RELOC_IA64_REL32LSB,
   4698   BFD_RELOC_IA64_REL64MSB,
   4699   BFD_RELOC_IA64_REL64LSB,
   4700   BFD_RELOC_IA64_LTV32MSB,
   4701   BFD_RELOC_IA64_LTV32LSB,
   4702   BFD_RELOC_IA64_LTV64MSB,
   4703   BFD_RELOC_IA64_LTV64LSB,
   4704   BFD_RELOC_IA64_IPLTMSB,
   4705   BFD_RELOC_IA64_IPLTLSB,
   4706   BFD_RELOC_IA64_COPY,
   4707   BFD_RELOC_IA64_LTOFF22X,
   4708   BFD_RELOC_IA64_LDXMOV,
   4709   BFD_RELOC_IA64_TPREL14,
   4710   BFD_RELOC_IA64_TPREL22,
   4711   BFD_RELOC_IA64_TPREL64I,
   4712   BFD_RELOC_IA64_TPREL64MSB,
   4713   BFD_RELOC_IA64_TPREL64LSB,
   4714   BFD_RELOC_IA64_LTOFF_TPREL22,
   4715   BFD_RELOC_IA64_DTPMOD64MSB,
   4716   BFD_RELOC_IA64_DTPMOD64LSB,
   4717   BFD_RELOC_IA64_LTOFF_DTPMOD22,
   4718   BFD_RELOC_IA64_DTPREL14,
   4719   BFD_RELOC_IA64_DTPREL22,
   4720   BFD_RELOC_IA64_DTPREL64I,
   4721   BFD_RELOC_IA64_DTPREL32MSB,
   4722   BFD_RELOC_IA64_DTPREL32LSB,
   4723   BFD_RELOC_IA64_DTPREL64MSB,
   4724   BFD_RELOC_IA64_DTPREL64LSB,
   4725   BFD_RELOC_IA64_LTOFF_DTPREL22,
   4726 
   4727 /* Motorola 68HC11 reloc.
   4728 This is the 8 bit high part of an absolute address.  */
   4729   BFD_RELOC_M68HC11_HI8,
   4730 
   4731 /* Motorola 68HC11 reloc.
   4732 This is the 8 bit low part of an absolute address.  */
   4733   BFD_RELOC_M68HC11_LO8,
   4734 
   4735 /* Motorola 68HC11 reloc.
   4736 This is the 3 bit of a value.  */
   4737   BFD_RELOC_M68HC11_3B,
   4738 
   4739 /* Motorola 68HC11 reloc.
   4740 This reloc marks the beginning of a jump/call instruction.
   4741 It is used for linker relaxation to correctly identify beginning
   4742 of instruction and change some branches to use PC-relative
   4743 addressing mode.  */
   4744   BFD_RELOC_M68HC11_RL_JUMP,
   4745 
   4746 /* Motorola 68HC11 reloc.
   4747 This reloc marks a group of several instructions that gcc generates
   4748 and for which the linker relaxation pass can modify and/or remove
   4749 some of them.  */
   4750   BFD_RELOC_M68HC11_RL_GROUP,
   4751 
   4752 /* Motorola 68HC11 reloc.
   4753 This is the 16-bit lower part of an address.  It is used for 'call'
   4754 instruction to specify the symbol address without any special
   4755 transformation (due to memory bank window).  */
   4756   BFD_RELOC_M68HC11_LO16,
   4757 
   4758 /* Motorola 68HC11 reloc.
   4759 This is a 8-bit reloc that specifies the page number of an address.
   4760 It is used by 'call' instruction to specify the page number of
   4761 the symbol.  */
   4762   BFD_RELOC_M68HC11_PAGE,
   4763 
   4764 /* Motorola 68HC11 reloc.
   4765 This is a 24-bit reloc that represents the address with a 16-bit
   4766 value and a 8-bit page number.  The symbol address is transformed
   4767 to follow the 16K memory bank of 68HC12 (seen as mapped in the window).  */
   4768   BFD_RELOC_M68HC11_24,
   4769 
   4770 /* Motorola 68HC12 reloc.
   4771 This is the 5 bits of a value.  */
   4772   BFD_RELOC_M68HC12_5B,
   4773 
   4774 /* Freescale XGATE reloc.
   4775 This reloc marks the beginning of a bra/jal instruction.  */
   4776   BFD_RELOC_XGATE_RL_JUMP,
   4777 
   4778 /* Freescale XGATE reloc.
   4779 This reloc marks a group of several instructions that gcc generates
   4780 and for which the linker relaxation pass can modify and/or remove
   4781 some of them.  */
   4782   BFD_RELOC_XGATE_RL_GROUP,
   4783 
   4784 /* Freescale XGATE reloc.
   4785 This is the 16-bit lower part of an address.  It is used for the '16-bit'
   4786 instructions.  */
   4787   BFD_RELOC_XGATE_LO16,
   4788 
   4789 /* Freescale XGATE reloc.  */
   4790   BFD_RELOC_XGATE_GPAGE,
   4791 
   4792 /* Freescale XGATE reloc.  */
   4793   BFD_RELOC_XGATE_24,
   4794 
   4795 /* Freescale XGATE reloc.
   4796 This is a 9-bit pc-relative reloc.  */
   4797   BFD_RELOC_XGATE_PCREL_9,
   4798 
   4799 /* Freescale XGATE reloc.
   4800 This is a 10-bit pc-relative reloc.  */
   4801   BFD_RELOC_XGATE_PCREL_10,
   4802 
   4803 /* Freescale XGATE reloc.
   4804 This is the 16-bit lower part of an address.  It is used for the '16-bit'
   4805 instructions.  */
   4806   BFD_RELOC_XGATE_IMM8_LO,
   4807 
   4808 /* Freescale XGATE reloc.
   4809 This is the 16-bit higher part of an address.  It is used for the '16-bit'
   4810 instructions.  */
   4811   BFD_RELOC_XGATE_IMM8_HI,
   4812 
   4813 /* Freescale XGATE reloc.
   4814 This is a 3-bit pc-relative reloc.  */
   4815   BFD_RELOC_XGATE_IMM3,
   4816 
   4817 /* Freescale XGATE reloc.
   4818 This is a 4-bit pc-relative reloc.  */
   4819   BFD_RELOC_XGATE_IMM4,
   4820 
   4821 /* Freescale XGATE reloc.
   4822 This is a 5-bit pc-relative reloc.  */
   4823   BFD_RELOC_XGATE_IMM5,
   4824 
   4825 /* Motorola 68HC12 reloc.
   4826 This is the 9 bits of a value.  */
   4827   BFD_RELOC_M68HC12_9B,
   4828 
   4829 /* Motorola 68HC12 reloc.
   4830 This is the 16 bits of a value.  */
   4831   BFD_RELOC_M68HC12_16B,
   4832 
   4833 /* Motorola 68HC12/XGATE reloc.
   4834 This is a PCREL9 branch.  */
   4835   BFD_RELOC_M68HC12_9_PCREL,
   4836 
   4837 /* Motorola 68HC12/XGATE reloc.
   4838 This is a PCREL10 branch.  */
   4839   BFD_RELOC_M68HC12_10_PCREL,
   4840 
   4841 /* Motorola 68HC12/XGATE reloc.
   4842 This is the 8 bit low part of an absolute address and immediately precedes
   4843 a matching HI8XG part.  */
   4844   BFD_RELOC_M68HC12_LO8XG,
   4845 
   4846 /* Motorola 68HC12/XGATE reloc.
   4847 This is the 8 bit high part of an absolute address and immediately follows
   4848 a matching LO8XG part.  */
   4849   BFD_RELOC_M68HC12_HI8XG,
   4850 
   4851 /* Freescale S12Z reloc.
   4852 This is a 15 bit relative address.  If the most significant bits are all zero
   4853 then it may be truncated to 8 bits.  */
   4854   BFD_RELOC_S12Z_15_PCREL,
   4855 
   4856 /* NS CR16 Relocations.  */
   4857   BFD_RELOC_CR16_NUM8,
   4858   BFD_RELOC_CR16_NUM16,
   4859   BFD_RELOC_CR16_NUM32,
   4860   BFD_RELOC_CR16_NUM32a,
   4861   BFD_RELOC_CR16_REGREL0,
   4862   BFD_RELOC_CR16_REGREL4,
   4863   BFD_RELOC_CR16_REGREL4a,
   4864   BFD_RELOC_CR16_REGREL14,
   4865   BFD_RELOC_CR16_REGREL14a,
   4866   BFD_RELOC_CR16_REGREL16,
   4867   BFD_RELOC_CR16_REGREL20,
   4868   BFD_RELOC_CR16_REGREL20a,
   4869   BFD_RELOC_CR16_ABS20,
   4870   BFD_RELOC_CR16_ABS24,
   4871   BFD_RELOC_CR16_IMM4,
   4872   BFD_RELOC_CR16_IMM8,
   4873   BFD_RELOC_CR16_IMM16,
   4874   BFD_RELOC_CR16_IMM20,
   4875   BFD_RELOC_CR16_IMM24,
   4876   BFD_RELOC_CR16_IMM32,
   4877   BFD_RELOC_CR16_IMM32a,
   4878   BFD_RELOC_CR16_DISP4,
   4879   BFD_RELOC_CR16_DISP8,
   4880   BFD_RELOC_CR16_DISP16,
   4881   BFD_RELOC_CR16_DISP20,
   4882   BFD_RELOC_CR16_DISP24,
   4883   BFD_RELOC_CR16_DISP24a,
   4884   BFD_RELOC_CR16_SWITCH8,
   4885   BFD_RELOC_CR16_SWITCH16,
   4886   BFD_RELOC_CR16_SWITCH32,
   4887   BFD_RELOC_CR16_GOT_REGREL20,
   4888   BFD_RELOC_CR16_GOTC_REGREL20,
   4889   BFD_RELOC_CR16_GLOB_DAT,
   4890 
   4891 /* NS CRX Relocations.  */
   4892   BFD_RELOC_CRX_REL4,
   4893   BFD_RELOC_CRX_REL8,
   4894   BFD_RELOC_CRX_REL8_CMP,
   4895   BFD_RELOC_CRX_REL16,
   4896   BFD_RELOC_CRX_REL24,
   4897   BFD_RELOC_CRX_REL32,
   4898   BFD_RELOC_CRX_REGREL12,
   4899   BFD_RELOC_CRX_REGREL22,
   4900   BFD_RELOC_CRX_REGREL28,
   4901   BFD_RELOC_CRX_REGREL32,
   4902   BFD_RELOC_CRX_ABS16,
   4903   BFD_RELOC_CRX_ABS32,
   4904   BFD_RELOC_CRX_NUM8,
   4905   BFD_RELOC_CRX_NUM16,
   4906   BFD_RELOC_CRX_NUM32,
   4907   BFD_RELOC_CRX_IMM16,
   4908   BFD_RELOC_CRX_IMM32,
   4909   BFD_RELOC_CRX_SWITCH8,
   4910   BFD_RELOC_CRX_SWITCH16,
   4911   BFD_RELOC_CRX_SWITCH32,
   4912 
   4913 /* These relocs are only used within the CRIS assembler.  They are not
   4914 (at present) written to any object files.  */
   4915   BFD_RELOC_CRIS_BDISP8,
   4916   BFD_RELOC_CRIS_UNSIGNED_5,
   4917   BFD_RELOC_CRIS_SIGNED_6,
   4918   BFD_RELOC_CRIS_UNSIGNED_6,
   4919   BFD_RELOC_CRIS_SIGNED_8,
   4920   BFD_RELOC_CRIS_UNSIGNED_8,
   4921   BFD_RELOC_CRIS_SIGNED_16,
   4922   BFD_RELOC_CRIS_UNSIGNED_16,
   4923   BFD_RELOC_CRIS_LAPCQ_OFFSET,
   4924   BFD_RELOC_CRIS_UNSIGNED_4,
   4925 
   4926 /* Relocs used in ELF shared libraries for CRIS.  */
   4927   BFD_RELOC_CRIS_COPY,
   4928   BFD_RELOC_CRIS_GLOB_DAT,
   4929   BFD_RELOC_CRIS_JUMP_SLOT,
   4930   BFD_RELOC_CRIS_RELATIVE,
   4931 
   4932 /* 32-bit offset to symbol-entry within GOT.  */
   4933   BFD_RELOC_CRIS_32_GOT,
   4934 
   4935 /* 16-bit offset to symbol-entry within GOT.  */
   4936   BFD_RELOC_CRIS_16_GOT,
   4937 
   4938 /* 32-bit offset to symbol-entry within GOT, with PLT handling.  */
   4939   BFD_RELOC_CRIS_32_GOTPLT,
   4940 
   4941 /* 16-bit offset to symbol-entry within GOT, with PLT handling.  */
   4942   BFD_RELOC_CRIS_16_GOTPLT,
   4943 
   4944 /* 32-bit offset to symbol, relative to GOT.  */
   4945   BFD_RELOC_CRIS_32_GOTREL,
   4946 
   4947 /* 32-bit offset to symbol with PLT entry, relative to GOT.  */
   4948   BFD_RELOC_CRIS_32_PLT_GOTREL,
   4949 
   4950 /* 32-bit offset to symbol with PLT entry, relative to this relocation.  */
   4951   BFD_RELOC_CRIS_32_PLT_PCREL,
   4952 
   4953 /* Relocs used in TLS code for CRIS.  */
   4954   BFD_RELOC_CRIS_32_GOT_GD,
   4955   BFD_RELOC_CRIS_16_GOT_GD,
   4956   BFD_RELOC_CRIS_32_GD,
   4957   BFD_RELOC_CRIS_DTP,
   4958   BFD_RELOC_CRIS_32_DTPREL,
   4959   BFD_RELOC_CRIS_16_DTPREL,
   4960   BFD_RELOC_CRIS_32_GOT_TPREL,
   4961   BFD_RELOC_CRIS_16_GOT_TPREL,
   4962   BFD_RELOC_CRIS_32_TPREL,
   4963   BFD_RELOC_CRIS_16_TPREL,
   4964   BFD_RELOC_CRIS_DTPMOD,
   4965   BFD_RELOC_CRIS_32_IE,
   4966 
   4967 /* OpenRISC 1000 Relocations.  */
   4968   BFD_RELOC_OR1K_REL_26,
   4969   BFD_RELOC_OR1K_SLO16,
   4970   BFD_RELOC_OR1K_PCREL_PG21,
   4971   BFD_RELOC_OR1K_LO13,
   4972   BFD_RELOC_OR1K_SLO13,
   4973   BFD_RELOC_OR1K_GOTPC_HI16,
   4974   BFD_RELOC_OR1K_GOTPC_LO16,
   4975   BFD_RELOC_OR1K_GOT_AHI16,
   4976   BFD_RELOC_OR1K_GOT16,
   4977   BFD_RELOC_OR1K_GOT_PG21,
   4978   BFD_RELOC_OR1K_GOT_LO13,
   4979   BFD_RELOC_OR1K_PLT26,
   4980   BFD_RELOC_OR1K_PLTA26,
   4981   BFD_RELOC_OR1K_GOTOFF_SLO16,
   4982   BFD_RELOC_OR1K_COPY,
   4983   BFD_RELOC_OR1K_GLOB_DAT,
   4984   BFD_RELOC_OR1K_JMP_SLOT,
   4985   BFD_RELOC_OR1K_RELATIVE,
   4986   BFD_RELOC_OR1K_TLS_GD_HI16,
   4987   BFD_RELOC_OR1K_TLS_GD_LO16,
   4988   BFD_RELOC_OR1K_TLS_GD_PG21,
   4989   BFD_RELOC_OR1K_TLS_GD_LO13,
   4990   BFD_RELOC_OR1K_TLS_LDM_HI16,
   4991   BFD_RELOC_OR1K_TLS_LDM_LO16,
   4992   BFD_RELOC_OR1K_TLS_LDM_PG21,
   4993   BFD_RELOC_OR1K_TLS_LDM_LO13,
   4994   BFD_RELOC_OR1K_TLS_LDO_HI16,
   4995   BFD_RELOC_OR1K_TLS_LDO_LO16,
   4996   BFD_RELOC_OR1K_TLS_IE_HI16,
   4997   BFD_RELOC_OR1K_TLS_IE_AHI16,
   4998   BFD_RELOC_OR1K_TLS_IE_LO16,
   4999   BFD_RELOC_OR1K_TLS_IE_PG21,
   5000   BFD_RELOC_OR1K_TLS_IE_LO13,
   5001   BFD_RELOC_OR1K_TLS_LE_HI16,
   5002   BFD_RELOC_OR1K_TLS_LE_AHI16,
   5003   BFD_RELOC_OR1K_TLS_LE_LO16,
   5004   BFD_RELOC_OR1K_TLS_LE_SLO16,
   5005   BFD_RELOC_OR1K_TLS_TPOFF,
   5006   BFD_RELOC_OR1K_TLS_DTPOFF,
   5007   BFD_RELOC_OR1K_TLS_DTPMOD,
   5008 
   5009 /* H8 elf Relocations.  */
   5010   BFD_RELOC_H8_DIR16A8,
   5011   BFD_RELOC_H8_DIR16R8,
   5012   BFD_RELOC_H8_DIR24A8,
   5013   BFD_RELOC_H8_DIR24R8,
   5014   BFD_RELOC_H8_DIR32A16,
   5015   BFD_RELOC_H8_DISP32A16,
   5016 
   5017 /* Sony Xstormy16 Relocations.  */
   5018   BFD_RELOC_XSTORMY16_REL_12,
   5019   BFD_RELOC_XSTORMY16_12,
   5020   BFD_RELOC_XSTORMY16_24,
   5021   BFD_RELOC_XSTORMY16_FPTR16,
   5022 
   5023 /* Self-describing complex relocations.  */
   5024   BFD_RELOC_RELC,
   5025 
   5026 
   5027 /* Relocations used by VAX ELF.  */
   5028   BFD_RELOC_VAX_GLOB_DAT,
   5029   BFD_RELOC_VAX_JMP_SLOT,
   5030   BFD_RELOC_VAX_RELATIVE,
   5031 
   5032 /* Morpho MT - 16 bit immediate relocation.  */
   5033   BFD_RELOC_MT_PC16,
   5034 
   5035 /* Morpho MT - Hi 16 bits of an address.  */
   5036   BFD_RELOC_MT_HI16,
   5037 
   5038 /* Morpho MT - Low 16 bits of an address.  */
   5039   BFD_RELOC_MT_LO16,
   5040 
   5041 /* Morpho MT - Used to tell the linker which vtable entries are used.  */
   5042   BFD_RELOC_MT_GNU_VTINHERIT,
   5043 
   5044 /* Morpho MT - Used to tell the linker which vtable entries are used.  */
   5045   BFD_RELOC_MT_GNU_VTENTRY,
   5046 
   5047 /* Morpho MT - 8 bit immediate relocation.  */
   5048   BFD_RELOC_MT_PCINSN8,
   5049 
   5050 /* msp430 specific relocation codes  */
   5051   BFD_RELOC_MSP430_10_PCREL,
   5052   BFD_RELOC_MSP430_16_PCREL,
   5053   BFD_RELOC_MSP430_16,
   5054   BFD_RELOC_MSP430_16_PCREL_BYTE,
   5055   BFD_RELOC_MSP430_16_BYTE,
   5056   BFD_RELOC_MSP430_2X_PCREL,
   5057   BFD_RELOC_MSP430_RL_PCREL,
   5058   BFD_RELOC_MSP430_ABS8,
   5059   BFD_RELOC_MSP430X_PCR20_EXT_SRC,
   5060   BFD_RELOC_MSP430X_PCR20_EXT_DST,
   5061   BFD_RELOC_MSP430X_PCR20_EXT_ODST,
   5062   BFD_RELOC_MSP430X_ABS20_EXT_SRC,
   5063   BFD_RELOC_MSP430X_ABS20_EXT_DST,
   5064   BFD_RELOC_MSP430X_ABS20_EXT_ODST,
   5065   BFD_RELOC_MSP430X_ABS20_ADR_SRC,
   5066   BFD_RELOC_MSP430X_ABS20_ADR_DST,
   5067   BFD_RELOC_MSP430X_PCR16,
   5068   BFD_RELOC_MSP430X_PCR20_CALL,
   5069   BFD_RELOC_MSP430X_ABS16,
   5070   BFD_RELOC_MSP430_ABS_HI16,
   5071   BFD_RELOC_MSP430_PREL31,
   5072   BFD_RELOC_MSP430_SYM_DIFF,
   5073   BFD_RELOC_MSP430_SET_ULEB128,
   5074   BFD_RELOC_MSP430_SUB_ULEB128,
   5075 
   5076 /* Relocations used by the Altera Nios II core.  */
   5077   BFD_RELOC_NIOS2_S16,
   5078   BFD_RELOC_NIOS2_U16,
   5079   BFD_RELOC_NIOS2_CALL26,
   5080   BFD_RELOC_NIOS2_IMM5,
   5081   BFD_RELOC_NIOS2_CACHE_OPX,
   5082   BFD_RELOC_NIOS2_IMM6,
   5083   BFD_RELOC_NIOS2_IMM8,
   5084   BFD_RELOC_NIOS2_HI16,
   5085   BFD_RELOC_NIOS2_LO16,
   5086   BFD_RELOC_NIOS2_HIADJ16,
   5087   BFD_RELOC_NIOS2_GPREL,
   5088   BFD_RELOC_NIOS2_UJMP,
   5089   BFD_RELOC_NIOS2_CJMP,
   5090   BFD_RELOC_NIOS2_CALLR,
   5091   BFD_RELOC_NIOS2_ALIGN,
   5092   BFD_RELOC_NIOS2_GOT16,
   5093   BFD_RELOC_NIOS2_CALL16,
   5094   BFD_RELOC_NIOS2_GOTOFF_LO,
   5095   BFD_RELOC_NIOS2_GOTOFF_HA,
   5096   BFD_RELOC_NIOS2_PCREL_LO,
   5097   BFD_RELOC_NIOS2_PCREL_HA,
   5098   BFD_RELOC_NIOS2_TLS_GD16,
   5099   BFD_RELOC_NIOS2_TLS_LDM16,
   5100   BFD_RELOC_NIOS2_TLS_LDO16,
   5101   BFD_RELOC_NIOS2_TLS_IE16,
   5102   BFD_RELOC_NIOS2_TLS_LE16,
   5103   BFD_RELOC_NIOS2_TLS_DTPMOD,
   5104   BFD_RELOC_NIOS2_TLS_DTPREL,
   5105   BFD_RELOC_NIOS2_TLS_TPREL,
   5106   BFD_RELOC_NIOS2_COPY,
   5107   BFD_RELOC_NIOS2_GLOB_DAT,
   5108   BFD_RELOC_NIOS2_JUMP_SLOT,
   5109   BFD_RELOC_NIOS2_RELATIVE,
   5110   BFD_RELOC_NIOS2_GOTOFF,
   5111   BFD_RELOC_NIOS2_CALL26_NOAT,
   5112   BFD_RELOC_NIOS2_GOT_LO,
   5113   BFD_RELOC_NIOS2_GOT_HA,
   5114   BFD_RELOC_NIOS2_CALL_LO,
   5115   BFD_RELOC_NIOS2_CALL_HA,
   5116   BFD_RELOC_NIOS2_R2_S12,
   5117   BFD_RELOC_NIOS2_R2_I10_1_PCREL,
   5118   BFD_RELOC_NIOS2_R2_T1I7_1_PCREL,
   5119   BFD_RELOC_NIOS2_R2_T1I7_2,
   5120   BFD_RELOC_NIOS2_R2_T2I4,
   5121   BFD_RELOC_NIOS2_R2_T2I4_1,
   5122   BFD_RELOC_NIOS2_R2_T2I4_2,
   5123   BFD_RELOC_NIOS2_R2_X1I7_2,
   5124   BFD_RELOC_NIOS2_R2_X2L5,
   5125   BFD_RELOC_NIOS2_R2_F1I5_2,
   5126   BFD_RELOC_NIOS2_R2_L5I4X1,
   5127   BFD_RELOC_NIOS2_R2_T1X1I6,
   5128   BFD_RELOC_NIOS2_R2_T1X1I6_2,
   5129 
   5130 /* PRU LDI 16-bit unsigned data-memory relocation.  */
   5131   BFD_RELOC_PRU_U16,
   5132 
   5133 /* PRU LDI 16-bit unsigned instruction-memory relocation.  */
   5134   BFD_RELOC_PRU_U16_PMEMIMM,
   5135 
   5136 /* PRU relocation for two consecutive LDI load instructions that load a
   5137 32 bit value into a register. If the higher bits are all zero, then
   5138 the second instruction may be relaxed.  */
   5139   BFD_RELOC_PRU_LDI32,
   5140 
   5141 /* PRU QBBx 10-bit signed PC-relative relocation.  */
   5142   BFD_RELOC_PRU_S10_PCREL,
   5143 
   5144 /* PRU 8-bit unsigned relocation used for the LOOP instruction.  */
   5145   BFD_RELOC_PRU_U8_PCREL,
   5146 
   5147 /* PRU Program Memory relocations.  Used to convert from byte addressing to
   5148 32-bit word addressing.  */
   5149   BFD_RELOC_PRU_32_PMEM,
   5150   BFD_RELOC_PRU_16_PMEM,
   5151 
   5152 /* PRU relocations to mark the difference of two local symbols.
   5153 These are only needed to support linker relaxation and can be ignored
   5154 when not relaxing.  The field is set to the value of the difference
   5155 assuming no relaxation.  The relocation encodes the position of the
   5156 second symbol so the linker can determine whether to adjust the field
   5157 value. The PMEM variants encode the word difference, instead of byte
   5158 difference between symbols.  */
   5159   BFD_RELOC_PRU_GNU_DIFF8,
   5160   BFD_RELOC_PRU_GNU_DIFF16,
   5161   BFD_RELOC_PRU_GNU_DIFF32,
   5162   BFD_RELOC_PRU_GNU_DIFF16_PMEM,
   5163   BFD_RELOC_PRU_GNU_DIFF32_PMEM,
   5164 
   5165 /* IQ2000 Relocations.  */
   5166   BFD_RELOC_IQ2000_OFFSET_16,
   5167   BFD_RELOC_IQ2000_OFFSET_21,
   5168   BFD_RELOC_IQ2000_UHI16,
   5169 
   5170 /* Special Xtensa relocation used only by PLT entries in ELF shared
   5171 objects to indicate that the runtime linker should set the value
   5172 to one of its own internal functions or data structures.  */
   5173   BFD_RELOC_XTENSA_RTLD,
   5174 
   5175 /* Xtensa relocations for ELF shared objects.  */
   5176   BFD_RELOC_XTENSA_GLOB_DAT,
   5177   BFD_RELOC_XTENSA_JMP_SLOT,
   5178   BFD_RELOC_XTENSA_RELATIVE,
   5179 
   5180 /* Xtensa relocation used in ELF object files for symbols that may require
   5181 PLT entries.  Otherwise, this is just a generic 32-bit relocation.  */
   5182   BFD_RELOC_XTENSA_PLT,
   5183 
   5184 /* Xtensa relocations for backward compatibility.  These have been replaced
   5185 by BFD_RELOC_XTENSA_PDIFF and BFD_RELOC_XTENSA_NDIFF.
   5186 Xtensa relocations to mark the difference of two local symbols.
   5187 These are only needed to support linker relaxation and can be ignored
   5188 when not relaxing.  The field is set to the value of the difference
   5189 assuming no relaxation.  The relocation encodes the position of the
   5190 first symbol so the linker can determine whether to adjust the field
   5191 value.  */
   5192   BFD_RELOC_XTENSA_DIFF8,
   5193   BFD_RELOC_XTENSA_DIFF16,
   5194   BFD_RELOC_XTENSA_DIFF32,
   5195 
   5196 /* Generic Xtensa relocations for instruction operands.  Only the slot
   5197 number is encoded in the relocation.  The relocation applies to the
   5198 last PC-relative immediate operand, or if there are no PC-relative
   5199 immediates, to the last immediate operand.  */
   5200   BFD_RELOC_XTENSA_SLOT0_OP,
   5201   BFD_RELOC_XTENSA_SLOT1_OP,
   5202   BFD_RELOC_XTENSA_SLOT2_OP,
   5203   BFD_RELOC_XTENSA_SLOT3_OP,
   5204   BFD_RELOC_XTENSA_SLOT4_OP,
   5205   BFD_RELOC_XTENSA_SLOT5_OP,
   5206   BFD_RELOC_XTENSA_SLOT6_OP,
   5207   BFD_RELOC_XTENSA_SLOT7_OP,
   5208   BFD_RELOC_XTENSA_SLOT8_OP,
   5209   BFD_RELOC_XTENSA_SLOT9_OP,
   5210   BFD_RELOC_XTENSA_SLOT10_OP,
   5211   BFD_RELOC_XTENSA_SLOT11_OP,
   5212   BFD_RELOC_XTENSA_SLOT12_OP,
   5213   BFD_RELOC_XTENSA_SLOT13_OP,
   5214   BFD_RELOC_XTENSA_SLOT14_OP,
   5215 
   5216 /* Alternate Xtensa relocations.  Only the slot is encoded in the
   5217 relocation.  The meaning of these relocations is opcode-specific.  */
   5218   BFD_RELOC_XTENSA_SLOT0_ALT,
   5219   BFD_RELOC_XTENSA_SLOT1_ALT,
   5220   BFD_RELOC_XTENSA_SLOT2_ALT,
   5221   BFD_RELOC_XTENSA_SLOT3_ALT,
   5222   BFD_RELOC_XTENSA_SLOT4_ALT,
   5223   BFD_RELOC_XTENSA_SLOT5_ALT,
   5224   BFD_RELOC_XTENSA_SLOT6_ALT,
   5225   BFD_RELOC_XTENSA_SLOT7_ALT,
   5226   BFD_RELOC_XTENSA_SLOT8_ALT,
   5227   BFD_RELOC_XTENSA_SLOT9_ALT,
   5228   BFD_RELOC_XTENSA_SLOT10_ALT,
   5229   BFD_RELOC_XTENSA_SLOT11_ALT,
   5230   BFD_RELOC_XTENSA_SLOT12_ALT,
   5231   BFD_RELOC_XTENSA_SLOT13_ALT,
   5232   BFD_RELOC_XTENSA_SLOT14_ALT,
   5233 
   5234 /* Xtensa relocations for backward compatibility.  These have all been
   5235 replaced by BFD_RELOC_XTENSA_SLOT0_OP.  */
   5236   BFD_RELOC_XTENSA_OP0,
   5237   BFD_RELOC_XTENSA_OP1,
   5238   BFD_RELOC_XTENSA_OP2,
   5239 
   5240 /* Xtensa relocation to mark that the assembler expanded the
   5241 instructions from an original target.  The expansion size is
   5242 encoded in the reloc size.  */
   5243   BFD_RELOC_XTENSA_ASM_EXPAND,
   5244 
   5245 /* Xtensa relocation to mark that the linker should simplify
   5246 assembler-expanded instructions.  This is commonly used
   5247 internally by the linker after analysis of a
   5248 BFD_RELOC_XTENSA_ASM_EXPAND.  */
   5249   BFD_RELOC_XTENSA_ASM_SIMPLIFY,
   5250 
   5251 /* Xtensa TLS relocations.  */
   5252   BFD_RELOC_XTENSA_TLSDESC_FN,
   5253   BFD_RELOC_XTENSA_TLSDESC_ARG,
   5254   BFD_RELOC_XTENSA_TLS_DTPOFF,
   5255   BFD_RELOC_XTENSA_TLS_TPOFF,
   5256   BFD_RELOC_XTENSA_TLS_FUNC,
   5257   BFD_RELOC_XTENSA_TLS_ARG,
   5258   BFD_RELOC_XTENSA_TLS_CALL,
   5259 
   5260 /* Xtensa relocations to mark the difference of two local symbols.
   5261 These are only needed to support linker relaxation and can be ignored
   5262 when not relaxing.  The field is set to the value of the difference
   5263 assuming no relaxation.  The relocation encodes the position of the
   5264 subtracted symbol so the linker can determine whether to adjust the field
   5265 value.  PDIFF relocations are used for positive differences, NDIFF
   5266 relocations are used for negative differences.  The difference value
   5267 is treated as unsigned with these relocation types, giving full
   5268 8/16 value ranges.  */
   5269   BFD_RELOC_XTENSA_PDIFF8,
   5270   BFD_RELOC_XTENSA_PDIFF16,
   5271   BFD_RELOC_XTENSA_PDIFF32,
   5272   BFD_RELOC_XTENSA_NDIFF8,
   5273   BFD_RELOC_XTENSA_NDIFF16,
   5274   BFD_RELOC_XTENSA_NDIFF32,
   5275 
   5276 /* 8 bit signed offset in (ix+d) or (iy+d).  */
   5277   BFD_RELOC_Z80_DISP8,
   5278 
   5279 /* First 8 bits of multibyte (32, 24 or 16 bit) value.  */
   5280   BFD_RELOC_Z80_BYTE0,
   5281 
   5282 /* Second 8 bits of multibyte (32, 24 or 16 bit) value.  */
   5283   BFD_RELOC_Z80_BYTE1,
   5284 
   5285 /* Third 8 bits of multibyte (32 or 24 bit) value.  */
   5286   BFD_RELOC_Z80_BYTE2,
   5287 
   5288 /* Fourth 8 bits of multibyte (32 bit) value.  */
   5289   BFD_RELOC_Z80_BYTE3,
   5290 
   5291 /* Lowest 16 bits of multibyte (32 or 24 bit) value.  */
   5292   BFD_RELOC_Z80_WORD0,
   5293 
   5294 /* Highest 16 bits of multibyte (32 or 24 bit) value.  */
   5295   BFD_RELOC_Z80_WORD1,
   5296 
   5297 /* Like BFD_RELOC_16 but big-endian.  */
   5298   BFD_RELOC_Z80_16_BE,
   5299 
   5300 /* DJNZ offset.  */
   5301   BFD_RELOC_Z8K_DISP7,
   5302 
   5303 /* CALR offset.  */
   5304   BFD_RELOC_Z8K_CALLR,
   5305 
   5306 /* 4 bit value.  */
   5307   BFD_RELOC_Z8K_IMM4L,
   5308 
   5309 /* Lattice Mico32 relocations.  */
   5310   BFD_RELOC_LM32_CALL,
   5311   BFD_RELOC_LM32_BRANCH,
   5312   BFD_RELOC_LM32_16_GOT,
   5313   BFD_RELOC_LM32_GOTOFF_HI16,
   5314   BFD_RELOC_LM32_GOTOFF_LO16,
   5315   BFD_RELOC_LM32_COPY,
   5316   BFD_RELOC_LM32_GLOB_DAT,
   5317   BFD_RELOC_LM32_JMP_SLOT,
   5318   BFD_RELOC_LM32_RELATIVE,
   5319 
   5320 /* Difference between two section addreses.  Must be followed by a
   5321 BFD_RELOC_MACH_O_PAIR.  */
   5322   BFD_RELOC_MACH_O_SECTDIFF,
   5323 
   5324 /* Like BFD_RELOC_MACH_O_SECTDIFF but with a local symbol.  */
   5325   BFD_RELOC_MACH_O_LOCAL_SECTDIFF,
   5326 
   5327 /* Pair of relocation.  Contains the first symbol.  */
   5328   BFD_RELOC_MACH_O_PAIR,
   5329 
   5330 /* Symbol will be substracted.  Must be followed by a BFD_RELOC_32.  */
   5331   BFD_RELOC_MACH_O_SUBTRACTOR32,
   5332 
   5333 /* Symbol will be substracted.  Must be followed by a BFD_RELOC_64.  */
   5334   BFD_RELOC_MACH_O_SUBTRACTOR64,
   5335 
   5336 /* PCREL relocations.  They are marked as branch to create PLT entry if
   5337 required.  */
   5338   BFD_RELOC_MACH_O_X86_64_BRANCH32,
   5339   BFD_RELOC_MACH_O_X86_64_BRANCH8,
   5340 
   5341 /* Used when referencing a GOT entry.  */
   5342   BFD_RELOC_MACH_O_X86_64_GOT,
   5343 
   5344 /* Used when loading a GOT entry with movq.  It is specially marked so that
   5345 the linker could optimize the movq to a leaq if possible.  */
   5346   BFD_RELOC_MACH_O_X86_64_GOT_LOAD,
   5347 
   5348 /* Same as BFD_RELOC_32_PCREL but with an implicit -1 addend.  */
   5349   BFD_RELOC_MACH_O_X86_64_PCREL32_1,
   5350 
   5351 /* Same as BFD_RELOC_32_PCREL but with an implicit -2 addend.  */
   5352   BFD_RELOC_MACH_O_X86_64_PCREL32_2,
   5353 
   5354 /* Same as BFD_RELOC_32_PCREL but with an implicit -4 addend.  */
   5355   BFD_RELOC_MACH_O_X86_64_PCREL32_4,
   5356 
   5357 /* Used when referencing a TLV entry.  */
   5358   BFD_RELOC_MACH_O_X86_64_TLV,
   5359 
   5360 /* Addend for PAGE or PAGEOFF.  */
   5361   BFD_RELOC_MACH_O_ARM64_ADDEND,
   5362 
   5363 /* Relative offset to page of GOT slot.  */
   5364   BFD_RELOC_MACH_O_ARM64_GOT_LOAD_PAGE21,
   5365 
   5366 /* Relative offset within page of GOT slot.  */
   5367   BFD_RELOC_MACH_O_ARM64_GOT_LOAD_PAGEOFF12,
   5368 
   5369 /* Address of a GOT entry.  */
   5370   BFD_RELOC_MACH_O_ARM64_POINTER_TO_GOT,
   5371 
   5372 /* This is a 32 bit reloc for the microblaze that stores the
   5373 low 16 bits of a value  */
   5374   BFD_RELOC_MICROBLAZE_32_LO,
   5375 
   5376 /* This is a 32 bit pc-relative reloc for the microblaze that
   5377 stores the low 16 bits of a value  */
   5378   BFD_RELOC_MICROBLAZE_32_LO_PCREL,
   5379 
   5380 /* This is a 32 bit reloc for the microblaze that stores a
   5381 value relative to the read-only small data area anchor  */
   5382   BFD_RELOC_MICROBLAZE_32_ROSDA,
   5383 
   5384 /* This is a 32 bit reloc for the microblaze that stores a
   5385 value relative to the read-write small data area anchor  */
   5386   BFD_RELOC_MICROBLAZE_32_RWSDA,
   5387 
   5388 /* This is a 32 bit reloc for the microblaze to handle
   5389 expressions of the form "Symbol Op Symbol"  */
   5390   BFD_RELOC_MICROBLAZE_32_SYM_OP_SYM,
   5391 
   5392 /* This is a 64 bit reloc that stores the 32 bit pc relative
   5393 value in two words (with an imm instruction).  No relocation is
   5394 done here - only used for relaxing  */
   5395   BFD_RELOC_MICROBLAZE_64_NONE,
   5396 
   5397 /* This is a 64 bit reloc that stores the 32 bit pc relative
   5398 value in two words (with an imm instruction).  The relocation is
   5399 PC-relative GOT offset  */
   5400   BFD_RELOC_MICROBLAZE_64_GOTPC,
   5401 
   5402 /* This is a 64 bit reloc that stores the 32 bit pc relative
   5403 value in two words (with an imm instruction).  The relocation is
   5404 GOT offset  */
   5405   BFD_RELOC_MICROBLAZE_64_GOT,
   5406 
   5407 /* This is a 64 bit reloc that stores the 32 bit pc relative
   5408 value in two words (with an imm instruction).  The relocation is
   5409 PC-relative offset into PLT  */
   5410   BFD_RELOC_MICROBLAZE_64_PLT,
   5411 
   5412 /* This is a 64 bit reloc that stores the 32 bit GOT relative
   5413 value in two words (with an imm instruction).  The relocation is
   5414 relative offset from _GLOBAL_OFFSET_TABLE_  */
   5415   BFD_RELOC_MICROBLAZE_64_GOTOFF,
   5416 
   5417 /* This is a 32 bit reloc that stores the 32 bit GOT relative
   5418 value in a word.  The relocation is relative offset from  */
   5419   BFD_RELOC_MICROBLAZE_32_GOTOFF,
   5420 
   5421 /* This is used to tell the dynamic linker to copy the value out of
   5422 the dynamic object into the runtime process image.  */
   5423   BFD_RELOC_MICROBLAZE_COPY,
   5424 
   5425 /* Unused Reloc  */
   5426   BFD_RELOC_MICROBLAZE_64_TLS,
   5427 
   5428 /* This is a 64 bit reloc that stores the 32 bit GOT relative value
   5429 of the GOT TLS GD info entry in two words (with an imm instruction). The
   5430 relocation is GOT offset.  */
   5431   BFD_RELOC_MICROBLAZE_64_TLSGD,
   5432 
   5433 /* This is a 64 bit reloc that stores the 32 bit GOT relative value
   5434 of the GOT TLS LD info entry in two words (with an imm instruction). The
   5435 relocation is GOT offset.  */
   5436   BFD_RELOC_MICROBLAZE_64_TLSLD,
   5437 
   5438 /* This is a 32 bit reloc that stores the Module ID to GOT(n).  */
   5439   BFD_RELOC_MICROBLAZE_32_TLSDTPMOD,
   5440 
   5441 /* This is a 32 bit reloc that stores TLS offset to GOT(n+1).  */
   5442   BFD_RELOC_MICROBLAZE_32_TLSDTPREL,
   5443 
   5444 /* This is a 32 bit reloc for storing TLS offset to two words (uses imm
   5445 instruction)  */
   5446   BFD_RELOC_MICROBLAZE_64_TLSDTPREL,
   5447 
   5448 /* This is a 64 bit reloc that stores 32-bit thread pointer relative offset
   5449 to two words (uses imm instruction).  */
   5450   BFD_RELOC_MICROBLAZE_64_TLSGOTTPREL,
   5451 
   5452 /* This is a 64 bit reloc that stores 32-bit thread pointer relative offset
   5453 to two words (uses imm instruction).  */
   5454   BFD_RELOC_MICROBLAZE_64_TLSTPREL,
   5455 
   5456 /* This is a 64 bit reloc that stores the 32 bit pc relative
   5457 value in two words (with an imm instruction).  The relocation is
   5458 PC-relative offset from start of TEXT.  */
   5459   BFD_RELOC_MICROBLAZE_64_TEXTPCREL,
   5460 
   5461 /* This is a 64 bit reloc that stores the 32 bit offset
   5462 value in two words (with an imm instruction).  The relocation is
   5463 relative offset from start of TEXT.  */
   5464   BFD_RELOC_MICROBLAZE_64_TEXTREL,
   5465 
   5466 /* AArch64 pseudo relocation code to mark the start of the AArch64
   5467 relocation enumerators.  N.B. the order of the enumerators is
   5468 important as several tables in the AArch64 bfd backend are indexed
   5469 by these enumerators; make sure they are all synced.  */
   5470   BFD_RELOC_AARCH64_RELOC_START,
   5471 
   5472 /* Deprecated AArch64 null relocation code.  */
   5473   BFD_RELOC_AARCH64_NULL,
   5474 
   5475 /* AArch64 null relocation code.  */
   5476   BFD_RELOC_AARCH64_NONE,
   5477 
   5478 /* Basic absolute relocations of N bits.  These are equivalent to
   5479 BFD_RELOC_N and they were added to assist the indexing of the howto
   5480 table.  */
   5481   BFD_RELOC_AARCH64_64,
   5482   BFD_RELOC_AARCH64_32,
   5483   BFD_RELOC_AARCH64_16,
   5484 
   5485 /* PC-relative relocations.  These are equivalent to BFD_RELOC_N_PCREL
   5486 and they were added to assist the indexing of the howto table.  */
   5487   BFD_RELOC_AARCH64_64_PCREL,
   5488   BFD_RELOC_AARCH64_32_PCREL,
   5489   BFD_RELOC_AARCH64_16_PCREL,
   5490 
   5491 /* AArch64 MOV[NZK] instruction with most significant bits 0 to 15
   5492 of an unsigned address/value.  */
   5493   BFD_RELOC_AARCH64_MOVW_G0,
   5494 
   5495 /* AArch64 MOV[NZK] instruction with less significant bits 0 to 15 of
   5496 an address/value.  No overflow checking.  */
   5497   BFD_RELOC_AARCH64_MOVW_G0_NC,
   5498 
   5499 /* AArch64 MOV[NZK] instruction with most significant bits 16 to 31
   5500 of an unsigned address/value.  */
   5501   BFD_RELOC_AARCH64_MOVW_G1,
   5502 
   5503 /* AArch64 MOV[NZK] instruction with less significant bits 16 to 31
   5504 of an address/value.  No overflow checking.  */
   5505   BFD_RELOC_AARCH64_MOVW_G1_NC,
   5506 
   5507 /* AArch64 MOV[NZK] instruction with most significant bits 32 to 47
   5508 of an unsigned address/value.  */
   5509   BFD_RELOC_AARCH64_MOVW_G2,
   5510 
   5511 /* AArch64 MOV[NZK] instruction with less significant bits 32 to 47
   5512 of an address/value.  No overflow checking.  */
   5513   BFD_RELOC_AARCH64_MOVW_G2_NC,
   5514 
   5515 /* AArch64 MOV[NZK] instruction with most signficant bits 48 to 64
   5516 of a signed or unsigned address/value.  */
   5517   BFD_RELOC_AARCH64_MOVW_G3,
   5518 
   5519 /* AArch64 MOV[NZ] instruction with most significant bits 0 to 15
   5520 of a signed value.  Changes instruction to MOVZ or MOVN depending on the
   5521 value's sign.  */
   5522   BFD_RELOC_AARCH64_MOVW_G0_S,
   5523 
   5524 /* AArch64 MOV[NZ] instruction with most significant bits 16 to 31
   5525 of a signed value.  Changes instruction to MOVZ or MOVN depending on the
   5526 value's sign.  */
   5527   BFD_RELOC_AARCH64_MOVW_G1_S,
   5528 
   5529 /* AArch64 MOV[NZ] instruction with most significant bits 32 to 47
   5530 of a signed value.  Changes instruction to MOVZ or MOVN depending on the
   5531 value's sign.  */
   5532   BFD_RELOC_AARCH64_MOVW_G2_S,
   5533 
   5534 /* AArch64 MOV[NZ] instruction with most significant bits 0 to 15
   5535 of a signed value.  Changes instruction to MOVZ or MOVN depending on the
   5536 value's sign.  */
   5537   BFD_RELOC_AARCH64_MOVW_PREL_G0,
   5538 
   5539 /* AArch64 MOV[NZ] instruction with most significant bits 0 to 15
   5540 of a signed value.  Changes instruction to MOVZ or MOVN depending on the
   5541 value's sign.  */
   5542   BFD_RELOC_AARCH64_MOVW_PREL_G0_NC,
   5543 
   5544 /* AArch64 MOVK instruction with most significant bits 16 to 31
   5545 of a signed value.  */
   5546   BFD_RELOC_AARCH64_MOVW_PREL_G1,
   5547 
   5548 /* AArch64 MOVK instruction with most significant bits 16 to 31
   5549 of a signed value.  */
   5550   BFD_RELOC_AARCH64_MOVW_PREL_G1_NC,
   5551 
   5552 /* AArch64 MOVK instruction with most significant bits 32 to 47
   5553 of a signed value.  */
   5554   BFD_RELOC_AARCH64_MOVW_PREL_G2,
   5555 
   5556 /* AArch64 MOVK instruction with most significant bits 32 to 47
   5557 of a signed value.  */
   5558   BFD_RELOC_AARCH64_MOVW_PREL_G2_NC,
   5559 
   5560 /* AArch64 MOVK instruction with most significant bits 47 to 63
   5561 of a signed value.  */
   5562   BFD_RELOC_AARCH64_MOVW_PREL_G3,
   5563 
   5564 /* AArch64 Load Literal instruction, holding a 19 bit pc-relative word
   5565 offset.  The lowest two bits must be zero and are not stored in the
   5566 instruction, giving a 21 bit signed byte offset.  */
   5567   BFD_RELOC_AARCH64_LD_LO19_PCREL,
   5568 
   5569 /* AArch64 ADR instruction, holding a simple 21 bit pc-relative byte offset.  */
   5570   BFD_RELOC_AARCH64_ADR_LO21_PCREL,
   5571 
   5572 /* AArch64 ADRP instruction, with bits 12 to 32 of a pc-relative page
   5573 offset, giving a 4KB aligned page base address.  */
   5574   BFD_RELOC_AARCH64_ADR_HI21_PCREL,
   5575 
   5576 /* AArch64 ADRP instruction, with bits 12 to 32 of a pc-relative page
   5577 offset, giving a 4KB aligned page base address, but with no overflow
   5578 checking.  */
   5579   BFD_RELOC_AARCH64_ADR_HI21_NC_PCREL,
   5580 
   5581 /* AArch64 ADD immediate instruction, holding bits 0 to 11 of the address.
   5582 Used in conjunction with BFD_RELOC_AARCH64_ADR_HI21_PCREL.  */
   5583   BFD_RELOC_AARCH64_ADD_LO12,
   5584 
   5585 /* AArch64 8-bit load/store instruction, holding bits 0 to 11 of the
   5586 address.  Used in conjunction with BFD_RELOC_AARCH64_ADR_HI21_PCREL.  */
   5587   BFD_RELOC_AARCH64_LDST8_LO12,
   5588 
   5589 /* AArch64 14 bit pc-relative test bit and branch.
   5590 The lowest two bits must be zero and are not stored in the instruction,
   5591 giving a 16 bit signed byte offset.  */
   5592   BFD_RELOC_AARCH64_TSTBR14,
   5593 
   5594 /* AArch64 19 bit pc-relative conditional branch and compare & branch.
   5595 The lowest two bits must be zero and are not stored in the instruction,
   5596 giving a 21 bit signed byte offset.  */
   5597   BFD_RELOC_AARCH64_BRANCH19,
   5598 
   5599 /* AArch64 26 bit pc-relative unconditional branch.
   5600 The lowest two bits must be zero and are not stored in the instruction,
   5601 giving a 28 bit signed byte offset.  */
   5602   BFD_RELOC_AARCH64_JUMP26,
   5603 
   5604 /* AArch64 26 bit pc-relative unconditional branch and link.
   5605 The lowest two bits must be zero and are not stored in the instruction,
   5606 giving a 28 bit signed byte offset.  */
   5607   BFD_RELOC_AARCH64_CALL26,
   5608 
   5609 /* AArch64 16-bit load/store instruction, holding bits 0 to 11 of the
   5610 address.  Used in conjunction with BFD_RELOC_AARCH64_ADR_HI21_PCREL.  */
   5611   BFD_RELOC_AARCH64_LDST16_LO12,
   5612 
   5613 /* AArch64 32-bit load/store instruction, holding bits 0 to 11 of the
   5614 address.  Used in conjunction with BFD_RELOC_AARCH64_ADR_HI21_PCREL.  */
   5615   BFD_RELOC_AARCH64_LDST32_LO12,
   5616 
   5617 /* AArch64 64-bit load/store instruction, holding bits 0 to 11 of the
   5618 address.  Used in conjunction with BFD_RELOC_AARCH64_ADR_HI21_PCREL.  */
   5619   BFD_RELOC_AARCH64_LDST64_LO12,
   5620 
   5621 /* AArch64 128-bit load/store instruction, holding bits 0 to 11 of the
   5622 address.  Used in conjunction with BFD_RELOC_AARCH64_ADR_HI21_PCREL.  */
   5623   BFD_RELOC_AARCH64_LDST128_LO12,
   5624 
   5625 /* AArch64 Load Literal instruction, holding a 19 bit PC relative word
   5626 offset of the global offset table entry for a symbol.  The lowest two
   5627 bits must be zero and are not stored in the instruction, giving a 21
   5628 bit signed byte offset.  This relocation type requires signed overflow
   5629 checking.  */
   5630   BFD_RELOC_AARCH64_GOT_LD_PREL19,
   5631 
   5632 /* Get to the page base of the global offset table entry for a symbol as
   5633 part of an ADRP instruction using a 21 bit PC relative value.Used in
   5634 conjunction with BFD_RELOC_AARCH64_LD64_GOT_LO12_NC.  */
   5635   BFD_RELOC_AARCH64_ADR_GOT_PAGE,
   5636 
   5637 /* Unsigned 12 bit byte offset for 64 bit load/store from the page of
   5638 the GOT entry for this symbol.  Used in conjunction with
   5639 BFD_RELOC_AARCH64_ADR_GOT_PAGE.  Valid in LP64 ABI only.  */
   5640   BFD_RELOC_AARCH64_LD64_GOT_LO12_NC,
   5641 
   5642 /* Unsigned 12 bit byte offset for 32 bit load/store from the page of
   5643 the GOT entry for this symbol.  Used in conjunction with
   5644 BFD_RELOC_AARCH64_ADR_GOT_PAGE.  Valid in ILP32 ABI only.  */
   5645   BFD_RELOC_AARCH64_LD32_GOT_LO12_NC,
   5646 
   5647 /* Unsigned 16 bit byte offset for 64 bit load/store from the GOT entry
   5648 for this symbol.  Valid in LP64 ABI only.  */
   5649   BFD_RELOC_AARCH64_MOVW_GOTOFF_G0_NC,
   5650 
   5651 /* Unsigned 16 bit byte higher offset for 64 bit load/store from the GOT entry
   5652 for this symbol.  Valid in LP64 ABI only.  */
   5653   BFD_RELOC_AARCH64_MOVW_GOTOFF_G1,
   5654 
   5655 /* Unsigned 15 bit byte offset for 64 bit load/store from the page of
   5656 the GOT entry for this symbol.  Valid in LP64 ABI only.  */
   5657   BFD_RELOC_AARCH64_LD64_GOTOFF_LO15,
   5658 
   5659 /* Scaled 14 bit byte offset to the page base of the global offset table.  */
   5660   BFD_RELOC_AARCH64_LD32_GOTPAGE_LO14,
   5661 
   5662 /* Scaled 15 bit byte offset to the page base of the global offset table.  */
   5663   BFD_RELOC_AARCH64_LD64_GOTPAGE_LO15,
   5664 
   5665 /* Get to the page base of the global offset table entry for a symbols
   5666 tls_index structure as part of an adrp instruction using a 21 bit PC
   5667 relative value.  Used in conjunction with
   5668 BFD_RELOC_AARCH64_TLSGD_ADD_LO12_NC.  */
   5669   BFD_RELOC_AARCH64_TLSGD_ADR_PAGE21,
   5670 
   5671 /* AArch64 TLS General Dynamic  */
   5672   BFD_RELOC_AARCH64_TLSGD_ADR_PREL21,
   5673 
   5674 /* Unsigned 12 bit byte offset to global offset table entry for a symbols
   5675 tls_index structure.  Used in conjunction with
   5676 BFD_RELOC_AARCH64_TLSGD_ADR_PAGE21.  */
   5677   BFD_RELOC_AARCH64_TLSGD_ADD_LO12_NC,
   5678 
   5679 /* AArch64 TLS General Dynamic relocation.  */
   5680   BFD_RELOC_AARCH64_TLSGD_MOVW_G0_NC,
   5681 
   5682 /* AArch64 TLS General Dynamic relocation.  */
   5683   BFD_RELOC_AARCH64_TLSGD_MOVW_G1,
   5684 
   5685 /* AArch64 TLS INITIAL EXEC relocation.  */
   5686   BFD_RELOC_AARCH64_TLSIE_ADR_GOTTPREL_PAGE21,
   5687 
   5688 /* AArch64 TLS INITIAL EXEC relocation.  */
   5689   BFD_RELOC_AARCH64_TLSIE_LD64_GOTTPREL_LO12_NC,
   5690 
   5691 /* AArch64 TLS INITIAL EXEC relocation.  */
   5692   BFD_RELOC_AARCH64_TLSIE_LD32_GOTTPREL_LO12_NC,
   5693 
   5694 /* AArch64 TLS INITIAL EXEC relocation.  */
   5695   BFD_RELOC_AARCH64_TLSIE_LD_GOTTPREL_PREL19,
   5696 
   5697 /* AArch64 TLS INITIAL EXEC relocation.  */
   5698   BFD_RELOC_AARCH64_TLSIE_MOVW_GOTTPREL_G0_NC,
   5699 
   5700 /* AArch64 TLS INITIAL EXEC relocation.  */
   5701   BFD_RELOC_AARCH64_TLSIE_MOVW_GOTTPREL_G1,
   5702 
   5703 /* bit[23:12] of byte offset to module TLS base address.  */
   5704   BFD_RELOC_AARCH64_TLSLD_ADD_DTPREL_HI12,
   5705 
   5706 /* Unsigned 12 bit byte offset to module TLS base address.  */
   5707   BFD_RELOC_AARCH64_TLSLD_ADD_DTPREL_LO12,
   5708 
   5709 /* No overflow check version of BFD_RELOC_AARCH64_TLSLD_ADD_DTPREL_LO12.  */
   5710   BFD_RELOC_AARCH64_TLSLD_ADD_DTPREL_LO12_NC,
   5711 
   5712 /* Unsigned 12 bit byte offset to global offset table entry for a symbols
   5713 tls_index structure.  Used in conjunction with
   5714 BFD_RELOC_AARCH64_TLSLD_ADR_PAGE21.  */
   5715   BFD_RELOC_AARCH64_TLSLD_ADD_LO12_NC,
   5716 
   5717 /* GOT entry page address for AArch64 TLS Local Dynamic, used with ADRP
   5718 instruction.  */
   5719   BFD_RELOC_AARCH64_TLSLD_ADR_PAGE21,
   5720 
   5721 /* GOT entry address for AArch64 TLS Local Dynamic, used with ADR instruction.  */
   5722   BFD_RELOC_AARCH64_TLSLD_ADR_PREL21,
   5723 
   5724 /* bit[11:1] of byte offset to module TLS base address, encoded in ldst
   5725 instructions.  */
   5726   BFD_RELOC_AARCH64_TLSLD_LDST16_DTPREL_LO12,
   5727 
   5728 /* Similar as BFD_RELOC_AARCH64_TLSLD_LDST16_DTPREL_LO12, but no overflow check.  */
   5729   BFD_RELOC_AARCH64_TLSLD_LDST16_DTPREL_LO12_NC,
   5730 
   5731 /* bit[11:2] of byte offset to module TLS base address, encoded in ldst
   5732 instructions.  */
   5733   BFD_RELOC_AARCH64_TLSLD_LDST32_DTPREL_LO12,
   5734 
   5735 /* Similar as BFD_RELOC_AARCH64_TLSLD_LDST32_DTPREL_LO12, but no overflow check.  */
   5736   BFD_RELOC_AARCH64_TLSLD_LDST32_DTPREL_LO12_NC,
   5737 
   5738 /* bit[11:3] of byte offset to module TLS base address, encoded in ldst
   5739 instructions.  */
   5740   BFD_RELOC_AARCH64_TLSLD_LDST64_DTPREL_LO12,
   5741 
   5742 /* Similar as BFD_RELOC_AARCH64_TLSLD_LDST64_DTPREL_LO12, but no overflow check.  */
   5743   BFD_RELOC_AARCH64_TLSLD_LDST64_DTPREL_LO12_NC,
   5744 
   5745 /* bit[11:0] of byte offset to module TLS base address, encoded in ldst
   5746 instructions.  */
   5747   BFD_RELOC_AARCH64_TLSLD_LDST8_DTPREL_LO12,
   5748 
   5749 /* Similar as BFD_RELOC_AARCH64_TLSLD_LDST8_DTPREL_LO12, but no overflow check.  */
   5750   BFD_RELOC_AARCH64_TLSLD_LDST8_DTPREL_LO12_NC,
   5751 
   5752 /* bit[15:0] of byte offset to module TLS base address.  */
   5753   BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G0,
   5754 
   5755 /* No overflow check version of BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G0  */
   5756   BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G0_NC,
   5757 
   5758 /* bit[31:16] of byte offset to module TLS base address.  */
   5759   BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G1,
   5760 
   5761 /* No overflow check version of BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G1  */
   5762   BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G1_NC,
   5763 
   5764 /* bit[47:32] of byte offset to module TLS base address.  */
   5765   BFD_RELOC_AARCH64_TLSLD_MOVW_DTPREL_G2,
   5766 
   5767 /* AArch64 TLS LOCAL EXEC relocation.  */
   5768   BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G2,
   5769 
   5770 /* AArch64 TLS LOCAL EXEC relocation.  */
   5771   BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1,
   5772 
   5773 /* AArch64 TLS LOCAL EXEC relocation.  */
   5774   BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1_NC,
   5775 
   5776 /* AArch64 TLS LOCAL EXEC relocation.  */
   5777   BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0,
   5778 
   5779 /* AArch64 TLS LOCAL EXEC relocation.  */
   5780   BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0_NC,
   5781 
   5782 /* AArch64 TLS LOCAL EXEC relocation.  */
   5783   BFD_RELOC_AARCH64_TLSLE_ADD_TPREL_HI12,
   5784 
   5785 /* AArch64 TLS LOCAL EXEC relocation.  */
   5786   BFD_RELOC_AARCH64_TLSLE_ADD_TPREL_LO12,
   5787 
   5788 /* AArch64 TLS LOCAL EXEC relocation.  */
   5789   BFD_RELOC_AARCH64_TLSLE_ADD_TPREL_LO12_NC,
   5790 
   5791 /* bit[11:1] of byte offset to module TLS base address, encoded in ldst
   5792 instructions.  */
   5793   BFD_RELOC_AARCH64_TLSLE_LDST16_TPREL_LO12,
   5794 
   5795 /* Similar as BFD_RELOC_AARCH64_TLSLE_LDST16_TPREL_LO12, but no overflow check.  */
   5796   BFD_RELOC_AARCH64_TLSLE_LDST16_TPREL_LO12_NC,
   5797 
   5798 /* bit[11:2] of byte offset to module TLS base address, encoded in ldst
   5799 instructions.  */
   5800   BFD_RELOC_AARCH64_TLSLE_LDST32_TPREL_LO12,
   5801 
   5802 /* Similar as BFD_RELOC_AARCH64_TLSLE_LDST32_TPREL_LO12, but no overflow check.  */
   5803   BFD_RELOC_AARCH64_TLSLE_LDST32_TPREL_LO12_NC,
   5804 
   5805 /* bit[11:3] of byte offset to module TLS base address, encoded in ldst
   5806 instructions.  */
   5807   BFD_RELOC_AARCH64_TLSLE_LDST64_TPREL_LO12,
   5808 
   5809 /* Similar as BFD_RELOC_AARCH64_TLSLE_LDST64_TPREL_LO12, but no overflow check.  */
   5810   BFD_RELOC_AARCH64_TLSLE_LDST64_TPREL_LO12_NC,
   5811 
   5812 /* bit[11:0] of byte offset to module TLS base address, encoded in ldst
   5813 instructions.  */
   5814   BFD_RELOC_AARCH64_TLSLE_LDST8_TPREL_LO12,
   5815 
   5816 /* Similar as BFD_RELOC_AARCH64_TLSLE_LDST8_TPREL_LO12, but no overflow check.  */
   5817   BFD_RELOC_AARCH64_TLSLE_LDST8_TPREL_LO12_NC,
   5818 
   5819 /* AArch64 TLS DESC relocation.  */
   5820   BFD_RELOC_AARCH64_TLSDESC_LD_PREL19,
   5821 
   5822 /* AArch64 TLS DESC relocation.  */
   5823   BFD_RELOC_AARCH64_TLSDESC_ADR_PREL21,
   5824 
   5825 /* AArch64 TLS DESC relocation.  */
   5826   BFD_RELOC_AARCH64_TLSDESC_ADR_PAGE21,
   5827 
   5828 /* AArch64 TLS DESC relocation.  */
   5829   BFD_RELOC_AARCH64_TLSDESC_LD64_LO12,
   5830 
   5831 /* AArch64 TLS DESC relocation.  */
   5832   BFD_RELOC_AARCH64_TLSDESC_LD32_LO12_NC,
   5833 
   5834 /* AArch64 TLS DESC relocation.  */
   5835   BFD_RELOC_AARCH64_TLSDESC_ADD_LO12,
   5836 
   5837 /* AArch64 TLS DESC relocation.  */
   5838   BFD_RELOC_AARCH64_TLSDESC_OFF_G1,
   5839 
   5840 /* AArch64 TLS DESC relocation.  */
   5841   BFD_RELOC_AARCH64_TLSDESC_OFF_G0_NC,
   5842 
   5843 /* AArch64 TLS DESC relocation.  */
   5844   BFD_RELOC_AARCH64_TLSDESC_LDR,
   5845 
   5846 /* AArch64 TLS DESC relocation.  */
   5847   BFD_RELOC_AARCH64_TLSDESC_ADD,
   5848 
   5849 /* AArch64 TLS DESC relocation.  */
   5850   BFD_RELOC_AARCH64_TLSDESC_CALL,
   5851 
   5852 /* AArch64 TLS relocation.  */
   5853   BFD_RELOC_AARCH64_COPY,
   5854 
   5855 /* AArch64 TLS relocation.  */
   5856   BFD_RELOC_AARCH64_GLOB_DAT,
   5857 
   5858 /* AArch64 TLS relocation.  */
   5859   BFD_RELOC_AARCH64_JUMP_SLOT,
   5860 
   5861 /* AArch64 TLS relocation.  */
   5862   BFD_RELOC_AARCH64_RELATIVE,
   5863 
   5864 /* AArch64 TLS relocation.  */
   5865   BFD_RELOC_AARCH64_TLS_DTPMOD,
   5866 
   5867 /* AArch64 TLS relocation.  */
   5868   BFD_RELOC_AARCH64_TLS_DTPREL,
   5869 
   5870 /* AArch64 TLS relocation.  */
   5871   BFD_RELOC_AARCH64_TLS_TPREL,
   5872 
   5873 /* AArch64 TLS relocation.  */
   5874   BFD_RELOC_AARCH64_TLSDESC,
   5875 
   5876 /* AArch64 support for STT_GNU_IFUNC.  */
   5877   BFD_RELOC_AARCH64_IRELATIVE,
   5878 
   5879 /* AArch64 pseudo relocation code to mark the end of the AArch64
   5880 relocation enumerators that have direct mapping to ELF reloc codes.
   5881 There are a few more enumerators after this one; those are mainly
   5882 used by the AArch64 assembler for the internal fixup or to select
   5883 one of the above enumerators.  */
   5884   BFD_RELOC_AARCH64_RELOC_END,
   5885 
   5886 /* AArch64 pseudo relocation code to be used internally by the AArch64
   5887 assembler and not (currently) written to any object files.  */
   5888   BFD_RELOC_AARCH64_GAS_INTERNAL_FIXUP,
   5889 
   5890 /* AArch64 unspecified load/store instruction, holding bits 0 to 11 of the
   5891 address.  Used in conjunction with BFD_RELOC_AARCH64_ADR_HI21_PCREL.  */
   5892   BFD_RELOC_AARCH64_LDST_LO12,
   5893 
   5894 /* AArch64 pseudo relocation code for TLS local dynamic mode.  It's to be
   5895 used internally by the AArch64 assembler and not (currently) written to
   5896 any object files.  */
   5897   BFD_RELOC_AARCH64_TLSLD_LDST_DTPREL_LO12,
   5898 
   5899 /* Similar as BFD_RELOC_AARCH64_TLSLD_LDST_DTPREL_LO12, but no overflow check.  */
   5900   BFD_RELOC_AARCH64_TLSLD_LDST_DTPREL_LO12_NC,
   5901 
   5902 /* AArch64 pseudo relocation code for TLS local exec mode.  It's to be
   5903 used internally by the AArch64 assembler and not (currently) written to
   5904 any object files.  */
   5905   BFD_RELOC_AARCH64_TLSLE_LDST_TPREL_LO12,
   5906 
   5907 /* Similar as BFD_RELOC_AARCH64_TLSLE_LDST_TPREL_LO12, but no overflow check.  */
   5908   BFD_RELOC_AARCH64_TLSLE_LDST_TPREL_LO12_NC,
   5909 
   5910 /* AArch64 pseudo relocation code to be used internally by the AArch64
   5911 assembler and not (currently) written to any object files.  */
   5912   BFD_RELOC_AARCH64_LD_GOT_LO12_NC,
   5913 
   5914 /* AArch64 pseudo relocation code to be used internally by the AArch64
   5915 assembler and not (currently) written to any object files.  */
   5916   BFD_RELOC_AARCH64_TLSIE_LD_GOTTPREL_LO12_NC,
   5917 
   5918 /* AArch64 pseudo relocation code to be used internally by the AArch64
   5919 assembler and not (currently) written to any object files.  */
   5920   BFD_RELOC_AARCH64_TLSDESC_LD_LO12_NC,
   5921 
   5922 /* Tilera TILEPro Relocations.  */
   5923   BFD_RELOC_TILEPRO_COPY,
   5924   BFD_RELOC_TILEPRO_GLOB_DAT,
   5925   BFD_RELOC_TILEPRO_JMP_SLOT,
   5926   BFD_RELOC_TILEPRO_RELATIVE,
   5927   BFD_RELOC_TILEPRO_BROFF_X1,
   5928   BFD_RELOC_TILEPRO_JOFFLONG_X1,
   5929   BFD_RELOC_TILEPRO_JOFFLONG_X1_PLT,
   5930   BFD_RELOC_TILEPRO_IMM8_X0,
   5931   BFD_RELOC_TILEPRO_IMM8_Y0,
   5932   BFD_RELOC_TILEPRO_IMM8_X1,
   5933   BFD_RELOC_TILEPRO_IMM8_Y1,
   5934   BFD_RELOC_TILEPRO_DEST_IMM8_X1,
   5935   BFD_RELOC_TILEPRO_MT_IMM15_X1,
   5936   BFD_RELOC_TILEPRO_MF_IMM15_X1,
   5937   BFD_RELOC_TILEPRO_IMM16_X0,
   5938   BFD_RELOC_TILEPRO_IMM16_X1,
   5939   BFD_RELOC_TILEPRO_IMM16_X0_LO,
   5940   BFD_RELOC_TILEPRO_IMM16_X1_LO,
   5941   BFD_RELOC_TILEPRO_IMM16_X0_HI,
   5942   BFD_RELOC_TILEPRO_IMM16_X1_HI,
   5943   BFD_RELOC_TILEPRO_IMM16_X0_HA,
   5944   BFD_RELOC_TILEPRO_IMM16_X1_HA,
   5945   BFD_RELOC_TILEPRO_IMM16_X0_PCREL,
   5946   BFD_RELOC_TILEPRO_IMM16_X1_PCREL,
   5947   BFD_RELOC_TILEPRO_IMM16_X0_LO_PCREL,
   5948   BFD_RELOC_TILEPRO_IMM16_X1_LO_PCREL,
   5949   BFD_RELOC_TILEPRO_IMM16_X0_HI_PCREL,
   5950   BFD_RELOC_TILEPRO_IMM16_X1_HI_PCREL,
   5951   BFD_RELOC_TILEPRO_IMM16_X0_HA_PCREL,
   5952   BFD_RELOC_TILEPRO_IMM16_X1_HA_PCREL,
   5953   BFD_RELOC_TILEPRO_IMM16_X0_GOT,
   5954   BFD_RELOC_TILEPRO_IMM16_X1_GOT,
   5955   BFD_RELOC_TILEPRO_IMM16_X0_GOT_LO,
   5956   BFD_RELOC_TILEPRO_IMM16_X1_GOT_LO,
   5957   BFD_RELOC_TILEPRO_IMM16_X0_GOT_HI,
   5958   BFD_RELOC_TILEPRO_IMM16_X1_GOT_HI,
   5959   BFD_RELOC_TILEPRO_IMM16_X0_GOT_HA,
   5960   BFD_RELOC_TILEPRO_IMM16_X1_GOT_HA,
   5961   BFD_RELOC_TILEPRO_MMSTART_X0,
   5962   BFD_RELOC_TILEPRO_MMEND_X0,
   5963   BFD_RELOC_TILEPRO_MMSTART_X1,
   5964   BFD_RELOC_TILEPRO_MMEND_X1,
   5965   BFD_RELOC_TILEPRO_SHAMT_X0,
   5966   BFD_RELOC_TILEPRO_SHAMT_X1,
   5967   BFD_RELOC_TILEPRO_SHAMT_Y0,
   5968   BFD_RELOC_TILEPRO_SHAMT_Y1,
   5969   BFD_RELOC_TILEPRO_TLS_GD_CALL,
   5970   BFD_RELOC_TILEPRO_IMM8_X0_TLS_GD_ADD,
   5971   BFD_RELOC_TILEPRO_IMM8_X1_TLS_GD_ADD,
   5972   BFD_RELOC_TILEPRO_IMM8_Y0_TLS_GD_ADD,
   5973   BFD_RELOC_TILEPRO_IMM8_Y1_TLS_GD_ADD,
   5974   BFD_RELOC_TILEPRO_TLS_IE_LOAD,
   5975   BFD_RELOC_TILEPRO_IMM16_X0_TLS_GD,
   5976   BFD_RELOC_TILEPRO_IMM16_X1_TLS_GD,
   5977   BFD_RELOC_TILEPRO_IMM16_X0_TLS_GD_LO,
   5978   BFD_RELOC_TILEPRO_IMM16_X1_TLS_GD_LO,
   5979   BFD_RELOC_TILEPRO_IMM16_X0_TLS_GD_HI,
   5980   BFD_RELOC_TILEPRO_IMM16_X1_TLS_GD_HI,
   5981   BFD_RELOC_TILEPRO_IMM16_X0_TLS_GD_HA,
   5982   BFD_RELOC_TILEPRO_IMM16_X1_TLS_GD_HA,
   5983   BFD_RELOC_TILEPRO_IMM16_X0_TLS_IE,
   5984   BFD_RELOC_TILEPRO_IMM16_X1_TLS_IE,
   5985   BFD_RELOC_TILEPRO_IMM16_X0_TLS_IE_LO,
   5986   BFD_RELOC_TILEPRO_IMM16_X1_TLS_IE_LO,
   5987   BFD_RELOC_TILEPRO_IMM16_X0_TLS_IE_HI,
   5988   BFD_RELOC_TILEPRO_IMM16_X1_TLS_IE_HI,
   5989   BFD_RELOC_TILEPRO_IMM16_X0_TLS_IE_HA,
   5990   BFD_RELOC_TILEPRO_IMM16_X1_TLS_IE_HA,
   5991   BFD_RELOC_TILEPRO_TLS_DTPMOD32,
   5992   BFD_RELOC_TILEPRO_TLS_DTPOFF32,
   5993   BFD_RELOC_TILEPRO_TLS_TPOFF32,
   5994   BFD_RELOC_TILEPRO_IMM16_X0_TLS_LE,
   5995   BFD_RELOC_TILEPRO_IMM16_X1_TLS_LE,
   5996   BFD_RELOC_TILEPRO_IMM16_X0_TLS_LE_LO,
   5997   BFD_RELOC_TILEPRO_IMM16_X1_TLS_LE_LO,
   5998   BFD_RELOC_TILEPRO_IMM16_X0_TLS_LE_HI,
   5999   BFD_RELOC_TILEPRO_IMM16_X1_TLS_LE_HI,
   6000   BFD_RELOC_TILEPRO_IMM16_X0_TLS_LE_HA,
   6001   BFD_RELOC_TILEPRO_IMM16_X1_TLS_LE_HA,
   6002 
   6003 /* Tilera TILE-Gx Relocations.  */
   6004   BFD_RELOC_TILEGX_HW0,
   6005   BFD_RELOC_TILEGX_HW1,
   6006   BFD_RELOC_TILEGX_HW2,
   6007   BFD_RELOC_TILEGX_HW3,
   6008   BFD_RELOC_TILEGX_HW0_LAST,
   6009   BFD_RELOC_TILEGX_HW1_LAST,
   6010   BFD_RELOC_TILEGX_HW2_LAST,
   6011   BFD_RELOC_TILEGX_COPY,
   6012   BFD_RELOC_TILEGX_GLOB_DAT,
   6013   BFD_RELOC_TILEGX_JMP_SLOT,
   6014   BFD_RELOC_TILEGX_RELATIVE,
   6015   BFD_RELOC_TILEGX_BROFF_X1,
   6016   BFD_RELOC_TILEGX_JUMPOFF_X1,
   6017   BFD_RELOC_TILEGX_JUMPOFF_X1_PLT,
   6018   BFD_RELOC_TILEGX_IMM8_X0,
   6019   BFD_RELOC_TILEGX_IMM8_Y0,
   6020   BFD_RELOC_TILEGX_IMM8_X1,
   6021   BFD_RELOC_TILEGX_IMM8_Y1,
   6022   BFD_RELOC_TILEGX_DEST_IMM8_X1,
   6023   BFD_RELOC_TILEGX_MT_IMM14_X1,
   6024   BFD_RELOC_TILEGX_MF_IMM14_X1,
   6025   BFD_RELOC_TILEGX_MMSTART_X0,
   6026   BFD_RELOC_TILEGX_MMEND_X0,
   6027   BFD_RELOC_TILEGX_SHAMT_X0,
   6028   BFD_RELOC_TILEGX_SHAMT_X1,
   6029   BFD_RELOC_TILEGX_SHAMT_Y0,
   6030   BFD_RELOC_TILEGX_SHAMT_Y1,
   6031   BFD_RELOC_TILEGX_IMM16_X0_HW0,
   6032   BFD_RELOC_TILEGX_IMM16_X1_HW0,
   6033   BFD_RELOC_TILEGX_IMM16_X0_HW1,
   6034   BFD_RELOC_TILEGX_IMM16_X1_HW1,
   6035   BFD_RELOC_TILEGX_IMM16_X0_HW2,
   6036   BFD_RELOC_TILEGX_IMM16_X1_HW2,
   6037   BFD_RELOC_TILEGX_IMM16_X0_HW3,
   6038   BFD_RELOC_TILEGX_IMM16_X1_HW3,
   6039   BFD_RELOC_TILEGX_IMM16_X0_HW0_LAST,
   6040   BFD_RELOC_TILEGX_IMM16_X1_HW0_LAST,
   6041   BFD_RELOC_TILEGX_IMM16_X0_HW1_LAST,
   6042   BFD_RELOC_TILEGX_IMM16_X1_HW1_LAST,
   6043   BFD_RELOC_TILEGX_IMM16_X0_HW2_LAST,
   6044   BFD_RELOC_TILEGX_IMM16_X1_HW2_LAST,
   6045   BFD_RELOC_TILEGX_IMM16_X0_HW0_PCREL,
   6046   BFD_RELOC_TILEGX_IMM16_X1_HW0_PCREL,
   6047   BFD_RELOC_TILEGX_IMM16_X0_HW1_PCREL,
   6048   BFD_RELOC_TILEGX_IMM16_X1_HW1_PCREL,
   6049   BFD_RELOC_TILEGX_IMM16_X0_HW2_PCREL,
   6050   BFD_RELOC_TILEGX_IMM16_X1_HW2_PCREL,
   6051   BFD_RELOC_TILEGX_IMM16_X0_HW3_PCREL,
   6052   BFD_RELOC_TILEGX_IMM16_X1_HW3_PCREL,
   6053   BFD_RELOC_TILEGX_IMM16_X0_HW0_LAST_PCREL,
   6054   BFD_RELOC_TILEGX_IMM16_X1_HW0_LAST_PCREL,
   6055   BFD_RELOC_TILEGX_IMM16_X0_HW1_LAST_PCREL,
   6056   BFD_RELOC_TILEGX_IMM16_X1_HW1_LAST_PCREL,
   6057   BFD_RELOC_TILEGX_IMM16_X0_HW2_LAST_PCREL,
   6058   BFD_RELOC_TILEGX_IMM16_X1_HW2_LAST_PCREL,
   6059   BFD_RELOC_TILEGX_IMM16_X0_HW0_GOT,
   6060   BFD_RELOC_TILEGX_IMM16_X1_HW0_GOT,
   6061   BFD_RELOC_TILEGX_IMM16_X0_HW0_PLT_PCREL,
   6062   BFD_RELOC_TILEGX_IMM16_X1_HW0_PLT_PCREL,
   6063   BFD_RELOC_TILEGX_IMM16_X0_HW1_PLT_PCREL,
   6064   BFD_RELOC_TILEGX_IMM16_X1_HW1_PLT_PCREL,
   6065   BFD_RELOC_TILEGX_IMM16_X0_HW2_PLT_PCREL,
   6066   BFD_RELOC_TILEGX_IMM16_X1_HW2_PLT_PCREL,
   6067   BFD_RELOC_TILEGX_IMM16_X0_HW0_LAST_GOT,
   6068   BFD_RELOC_TILEGX_IMM16_X1_HW0_LAST_GOT,
   6069   BFD_RELOC_TILEGX_IMM16_X0_HW1_LAST_GOT,
   6070   BFD_RELOC_TILEGX_IMM16_X1_HW1_LAST_GOT,
   6071   BFD_RELOC_TILEGX_IMM16_X0_HW3_PLT_PCREL,
   6072   BFD_RELOC_TILEGX_IMM16_X1_HW3_PLT_PCREL,
   6073   BFD_RELOC_TILEGX_IMM16_X0_HW0_TLS_GD,
   6074   BFD_RELOC_TILEGX_IMM16_X1_HW0_TLS_GD,
   6075   BFD_RELOC_TILEGX_IMM16_X0_HW0_TLS_LE,
   6076   BFD_RELOC_TILEGX_IMM16_X1_HW0_TLS_LE,
   6077   BFD_RELOC_TILEGX_IMM16_X0_HW0_LAST_TLS_LE,
   6078   BFD_RELOC_TILEGX_IMM16_X1_HW0_LAST_TLS_LE,
   6079   BFD_RELOC_TILEGX_IMM16_X0_HW1_LAST_TLS_LE,
   6080   BFD_RELOC_TILEGX_IMM16_X1_HW1_LAST_TLS_LE,
   6081   BFD_RELOC_TILEGX_IMM16_X0_HW0_LAST_TLS_GD,
   6082   BFD_RELOC_TILEGX_IMM16_X1_HW0_LAST_TLS_GD,
   6083   BFD_RELOC_TILEGX_IMM16_X0_HW1_LAST_TLS_GD,
   6084   BFD_RELOC_TILEGX_IMM16_X1_HW1_LAST_TLS_GD,
   6085   BFD_RELOC_TILEGX_IMM16_X0_HW0_TLS_IE,
   6086   BFD_RELOC_TILEGX_IMM16_X1_HW0_TLS_IE,
   6087   BFD_RELOC_TILEGX_IMM16_X0_HW0_LAST_PLT_PCREL,
   6088   BFD_RELOC_TILEGX_IMM16_X1_HW0_LAST_PLT_PCREL,
   6089   BFD_RELOC_TILEGX_IMM16_X0_HW1_LAST_PLT_PCREL,
   6090   BFD_RELOC_TILEGX_IMM16_X1_HW1_LAST_PLT_PCREL,
   6091   BFD_RELOC_TILEGX_IMM16_X0_HW2_LAST_PLT_PCREL,
   6092   BFD_RELOC_TILEGX_IMM16_X1_HW2_LAST_PLT_PCREL,
   6093   BFD_RELOC_TILEGX_IMM16_X0_HW0_LAST_TLS_IE,
   6094   BFD_RELOC_TILEGX_IMM16_X1_HW0_LAST_TLS_IE,
   6095   BFD_RELOC_TILEGX_IMM16_X0_HW1_LAST_TLS_IE,
   6096   BFD_RELOC_TILEGX_IMM16_X1_HW1_LAST_TLS_IE,
   6097   BFD_RELOC_TILEGX_TLS_DTPMOD64,
   6098   BFD_RELOC_TILEGX_TLS_DTPOFF64,
   6099   BFD_RELOC_TILEGX_TLS_TPOFF64,
   6100   BFD_RELOC_TILEGX_TLS_DTPMOD32,
   6101   BFD_RELOC_TILEGX_TLS_DTPOFF32,
   6102   BFD_RELOC_TILEGX_TLS_TPOFF32,
   6103   BFD_RELOC_TILEGX_TLS_GD_CALL,
   6104   BFD_RELOC_TILEGX_IMM8_X0_TLS_GD_ADD,
   6105   BFD_RELOC_TILEGX_IMM8_X1_TLS_GD_ADD,
   6106   BFD_RELOC_TILEGX_IMM8_Y0_TLS_GD_ADD,
   6107   BFD_RELOC_TILEGX_IMM8_Y1_TLS_GD_ADD,
   6108   BFD_RELOC_TILEGX_TLS_IE_LOAD,
   6109   BFD_RELOC_TILEGX_IMM8_X0_TLS_ADD,
   6110   BFD_RELOC_TILEGX_IMM8_X1_TLS_ADD,
   6111   BFD_RELOC_TILEGX_IMM8_Y0_TLS_ADD,
   6112   BFD_RELOC_TILEGX_IMM8_Y1_TLS_ADD,
   6113 
   6114 /* Linux eBPF relocations.  */
   6115   BFD_RELOC_BPF_64,
   6116   BFD_RELOC_BPF_32,
   6117   BFD_RELOC_BPF_16,
   6118   BFD_RELOC_BPF_DISP16,
   6119   BFD_RELOC_BPF_DISP32,
   6120 
   6121 /* Adapteva EPIPHANY - 8 bit signed pc-relative displacement  */
   6122   BFD_RELOC_EPIPHANY_SIMM8,
   6123 
   6124 /* Adapteva EPIPHANY - 24 bit signed pc-relative displacement  */
   6125   BFD_RELOC_EPIPHANY_SIMM24,
   6126 
   6127 /* Adapteva EPIPHANY - 16 most-significant bits of absolute address  */
   6128   BFD_RELOC_EPIPHANY_HIGH,
   6129 
   6130 /* Adapteva EPIPHANY - 16 least-significant bits of absolute address  */
   6131   BFD_RELOC_EPIPHANY_LOW,
   6132 
   6133 /* Adapteva EPIPHANY - 11 bit signed number - add/sub immediate  */
   6134   BFD_RELOC_EPIPHANY_SIMM11,
   6135 
   6136 /* Adapteva EPIPHANY - 11 bit sign-magnitude number (ld/st displacement)  */
   6137   BFD_RELOC_EPIPHANY_IMM11,
   6138 
   6139 /* Adapteva EPIPHANY - 8 bit immediate for 16 bit mov instruction.  */
   6140   BFD_RELOC_EPIPHANY_IMM8,
   6141 
   6142 /* Visium Relocations.  */
   6143   BFD_RELOC_VISIUM_HI16,
   6144   BFD_RELOC_VISIUM_LO16,
   6145   BFD_RELOC_VISIUM_IM16,
   6146   BFD_RELOC_VISIUM_REL16,
   6147   BFD_RELOC_VISIUM_HI16_PCREL,
   6148   BFD_RELOC_VISIUM_LO16_PCREL,
   6149   BFD_RELOC_VISIUM_IM16_PCREL,
   6150 
   6151 /* WebAssembly relocations.  */
   6152   BFD_RELOC_WASM32_LEB128,
   6153   BFD_RELOC_WASM32_LEB128_GOT,
   6154   BFD_RELOC_WASM32_LEB128_GOT_CODE,
   6155   BFD_RELOC_WASM32_LEB128_PLT,
   6156   BFD_RELOC_WASM32_PLT_INDEX,
   6157   BFD_RELOC_WASM32_ABS32_CODE,
   6158   BFD_RELOC_WASM32_COPY,
   6159   BFD_RELOC_WASM32_CODE_POINTER,
   6160   BFD_RELOC_WASM32_INDEX,
   6161   BFD_RELOC_WASM32_PLT_SIG,
   6162 
   6163 /* C-SKY relocations.  */
   6164   BFD_RELOC_CKCORE_NONE,
   6165   BFD_RELOC_CKCORE_ADDR32,
   6166   BFD_RELOC_CKCORE_PCREL_IMM8BY4,
   6167   BFD_RELOC_CKCORE_PCREL_IMM11BY2,
   6168   BFD_RELOC_CKCORE_PCREL_IMM4BY2,
   6169   BFD_RELOC_CKCORE_PCREL32,
   6170   BFD_RELOC_CKCORE_PCREL_JSR_IMM11BY2,
   6171   BFD_RELOC_CKCORE_GNU_VTINHERIT,
   6172   BFD_RELOC_CKCORE_GNU_VTENTRY,
   6173   BFD_RELOC_CKCORE_RELATIVE,
   6174   BFD_RELOC_CKCORE_COPY,
   6175   BFD_RELOC_CKCORE_GLOB_DAT,
   6176   BFD_RELOC_CKCORE_JUMP_SLOT,
   6177   BFD_RELOC_CKCORE_GOTOFF,
   6178   BFD_RELOC_CKCORE_GOTPC,
   6179   BFD_RELOC_CKCORE_GOT32,
   6180   BFD_RELOC_CKCORE_PLT32,
   6181   BFD_RELOC_CKCORE_ADDRGOT,
   6182   BFD_RELOC_CKCORE_ADDRPLT,
   6183   BFD_RELOC_CKCORE_PCREL_IMM26BY2,
   6184   BFD_RELOC_CKCORE_PCREL_IMM16BY2,
   6185   BFD_RELOC_CKCORE_PCREL_IMM16BY4,
   6186   BFD_RELOC_CKCORE_PCREL_IMM10BY2,
   6187   BFD_RELOC_CKCORE_PCREL_IMM10BY4,
   6188   BFD_RELOC_CKCORE_ADDR_HI16,
   6189   BFD_RELOC_CKCORE_ADDR_LO16,
   6190   BFD_RELOC_CKCORE_GOTPC_HI16,
   6191   BFD_RELOC_CKCORE_GOTPC_LO16,
   6192   BFD_RELOC_CKCORE_GOTOFF_HI16,
   6193   BFD_RELOC_CKCORE_GOTOFF_LO16,
   6194   BFD_RELOC_CKCORE_GOT12,
   6195   BFD_RELOC_CKCORE_GOT_HI16,
   6196   BFD_RELOC_CKCORE_GOT_LO16,
   6197   BFD_RELOC_CKCORE_PLT12,
   6198   BFD_RELOC_CKCORE_PLT_HI16,
   6199   BFD_RELOC_CKCORE_PLT_LO16,
   6200   BFD_RELOC_CKCORE_ADDRGOT_HI16,
   6201   BFD_RELOC_CKCORE_ADDRGOT_LO16,
   6202   BFD_RELOC_CKCORE_ADDRPLT_HI16,
   6203   BFD_RELOC_CKCORE_ADDRPLT_LO16,
   6204   BFD_RELOC_CKCORE_PCREL_JSR_IMM26BY2,
   6205   BFD_RELOC_CKCORE_TOFFSET_LO16,
   6206   BFD_RELOC_CKCORE_DOFFSET_LO16,
   6207   BFD_RELOC_CKCORE_PCREL_IMM18BY2,
   6208   BFD_RELOC_CKCORE_DOFFSET_IMM18,
   6209   BFD_RELOC_CKCORE_DOFFSET_IMM18BY2,
   6210   BFD_RELOC_CKCORE_DOFFSET_IMM18BY4,
   6211   BFD_RELOC_CKCORE_GOTOFF_IMM18,
   6212   BFD_RELOC_CKCORE_GOT_IMM18BY4,
   6213   BFD_RELOC_CKCORE_PLT_IMM18BY4,
   6214   BFD_RELOC_CKCORE_PCREL_IMM7BY4,
   6215   BFD_RELOC_CKCORE_TLS_LE32,
   6216   BFD_RELOC_CKCORE_TLS_IE32,
   6217   BFD_RELOC_CKCORE_TLS_GD32,
   6218   BFD_RELOC_CKCORE_TLS_LDM32,
   6219   BFD_RELOC_CKCORE_TLS_LDO32,
   6220   BFD_RELOC_CKCORE_TLS_DTPMOD32,
   6221   BFD_RELOC_CKCORE_TLS_DTPOFF32,
   6222   BFD_RELOC_CKCORE_TLS_TPOFF32,
   6223   BFD_RELOC_CKCORE_PCREL_FLRW_IMM8BY4,
   6224   BFD_RELOC_CKCORE_NOJSRI,
   6225   BFD_RELOC_CKCORE_CALLGRAPH,
   6226   BFD_RELOC_CKCORE_IRELATIVE,
   6227   BFD_RELOC_CKCORE_PCREL_BLOOP_IMM4BY4,
   6228   BFD_RELOC_CKCORE_PCREL_BLOOP_IMM12BY4,
   6229 
   6230 /* S12Z relocations.  */
   6231   BFD_RELOC_S12Z_OPR,
   6232 
   6233 /* LARCH relocations.  */
   6234   BFD_RELOC_LARCH_TLS_DTPMOD32,
   6235   BFD_RELOC_LARCH_TLS_DTPREL32,
   6236   BFD_RELOC_LARCH_TLS_DTPMOD64,
   6237   BFD_RELOC_LARCH_TLS_DTPREL64,
   6238   BFD_RELOC_LARCH_TLS_TPREL32,
   6239   BFD_RELOC_LARCH_TLS_TPREL64,
   6240   BFD_RELOC_LARCH_MARK_LA,
   6241   BFD_RELOC_LARCH_MARK_PCREL,
   6242   BFD_RELOC_LARCH_SOP_PUSH_PCREL,
   6243   BFD_RELOC_LARCH_SOP_PUSH_ABSOLUTE,
   6244   BFD_RELOC_LARCH_SOP_PUSH_DUP,
   6245   BFD_RELOC_LARCH_SOP_PUSH_GPREL,
   6246   BFD_RELOC_LARCH_SOP_PUSH_TLS_TPREL,
   6247   BFD_RELOC_LARCH_SOP_PUSH_TLS_GOT,
   6248   BFD_RELOC_LARCH_SOP_PUSH_TLS_GD,
   6249   BFD_RELOC_LARCH_SOP_PUSH_PLT_PCREL,
   6250   BFD_RELOC_LARCH_SOP_ASSERT,
   6251   BFD_RELOC_LARCH_SOP_NOT,
   6252   BFD_RELOC_LARCH_SOP_SUB,
   6253   BFD_RELOC_LARCH_SOP_SL,
   6254   BFD_RELOC_LARCH_SOP_SR,
   6255   BFD_RELOC_LARCH_SOP_ADD,
   6256   BFD_RELOC_LARCH_SOP_AND,
   6257   BFD_RELOC_LARCH_SOP_IF_ELSE,
   6258   BFD_RELOC_LARCH_SOP_POP_32_S_10_5,
   6259   BFD_RELOC_LARCH_SOP_POP_32_U_10_12,
   6260   BFD_RELOC_LARCH_SOP_POP_32_S_10_12,
   6261   BFD_RELOC_LARCH_SOP_POP_32_S_10_16,
   6262   BFD_RELOC_LARCH_SOP_POP_32_S_10_16_S2,
   6263   BFD_RELOC_LARCH_SOP_POP_32_S_5_20,
   6264   BFD_RELOC_LARCH_SOP_POP_32_S_0_5_10_16_S2,
   6265   BFD_RELOC_LARCH_SOP_POP_32_S_0_10_10_16_S2,
   6266   BFD_RELOC_LARCH_SOP_POP_32_U,
   6267   BFD_RELOC_LARCH_ADD8,
   6268   BFD_RELOC_LARCH_ADD16,
   6269   BFD_RELOC_LARCH_ADD24,
   6270   BFD_RELOC_LARCH_ADD32,
   6271   BFD_RELOC_LARCH_ADD64,
   6272   BFD_RELOC_LARCH_SUB8,
   6273   BFD_RELOC_LARCH_SUB16,
   6274   BFD_RELOC_LARCH_SUB24,
   6275   BFD_RELOC_LARCH_SUB32,
   6276   BFD_RELOC_LARCH_SUB64,
   6277   BFD_RELOC_UNUSED };
   6278 
   6279 typedef enum bfd_reloc_code_real bfd_reloc_code_real_type;
   6280 reloc_howto_type *bfd_reloc_type_lookup
   6281    (bfd *abfd, bfd_reloc_code_real_type code);
   6282 reloc_howto_type *bfd_reloc_name_lookup
   6283    (bfd *abfd, const char *reloc_name);
   6284 
   6285 const char *bfd_get_reloc_code_name (bfd_reloc_code_real_type code);
   6286 
   6287 /* Extracted from syms.c.  */
   6288 
   6289 typedef struct bfd_symbol
   6290 {
   6291   /* A pointer to the BFD which owns the symbol. This information
   6292      is necessary so that a back end can work out what additional
   6293      information (invisible to the application writer) is carried
   6294      with the symbol.
   6295 
   6296      This field is *almost* redundant, since you can use section->owner
   6297      instead, except that some symbols point to the global sections
   6298      bfd_{abs,com,und}_section.  This could be fixed by making
   6299      these globals be per-bfd (or per-target-flavor).  FIXME.  */
   6300   struct bfd *the_bfd; /* Use bfd_asymbol_bfd(sym) to access this field.  */
   6301 
   6302   /* The text of the symbol. The name is left alone, and not copied; the
   6303      application may not alter it.  */
   6304   const char *name;
   6305 
   6306   /* The value of the symbol.  This really should be a union of a
   6307      numeric value with a pointer, since some flags indicate that
   6308      a pointer to another symbol is stored here.  */
   6309   symvalue value;
   6310 
   6311   /* Attributes of a symbol.  */
   6312 #define BSF_NO_FLAGS            0
   6313 
   6314   /* The symbol has local scope; <<static>> in <<C>>. The value
   6315      is the offset into the section of the data.  */
   6316 #define BSF_LOCAL               (1 << 0)
   6317 
   6318   /* The symbol has global scope; initialized data in <<C>>. The
   6319      value is the offset into the section of the data.  */
   6320 #define BSF_GLOBAL              (1 << 1)
   6321 
   6322   /* The symbol has global scope and is exported. The value is
   6323      the offset into the section of the data.  */
   6324 #define BSF_EXPORT              BSF_GLOBAL /* No real difference.  */
   6325 
   6326   /* A normal C symbol would be one of:
   6327      <<BSF_LOCAL>>, <<BSF_UNDEFINED>> or <<BSF_GLOBAL>>.  */
   6328 
   6329   /* The symbol is a debugging record. The value has an arbitrary
   6330      meaning, unless BSF_DEBUGGING_RELOC is also set.  */
   6331 #define BSF_DEBUGGING           (1 << 2)
   6332 
   6333   /* The symbol denotes a function entry point.  Used in ELF,
   6334      perhaps others someday.  */
   6335 #define BSF_FUNCTION            (1 << 3)
   6336 
   6337   /* Used by the linker.  */
   6338 #define BSF_KEEP                (1 << 5)
   6339 
   6340   /* An ELF common symbol.  */
   6341 #define BSF_ELF_COMMON          (1 << 6)
   6342 
   6343   /* A weak global symbol, overridable without warnings by
   6344      a regular global symbol of the same name.  */
   6345 #define BSF_WEAK                (1 << 7)
   6346 
   6347   /* This symbol was created to point to a section, e.g. ELF's
   6348      STT_SECTION symbols.  */
   6349 #define BSF_SECTION_SYM         (1 << 8)
   6350 
   6351   /* The symbol used to be a common symbol, but now it is
   6352      allocated.  */
   6353 #define BSF_OLD_COMMON          (1 << 9)
   6354 
   6355   /* In some files the type of a symbol sometimes alters its
   6356      location in an output file - ie in coff a <<ISFCN>> symbol
   6357      which is also <<C_EXT>> symbol appears where it was
   6358      declared and not at the end of a section.  This bit is set
   6359      by the target BFD part to convey this information.  */
   6360 #define BSF_NOT_AT_END          (1 << 10)
   6361 
   6362   /* Signal that the symbol is the label of constructor section.  */
   6363 #define BSF_CONSTRUCTOR         (1 << 11)
   6364 
   6365   /* Signal that the symbol is a warning symbol.  The name is a
   6366      warning.  The name of the next symbol is the one to warn about;
   6367      if a reference is made to a symbol with the same name as the next
   6368      symbol, a warning is issued by the linker.  */
   6369 #define BSF_WARNING             (1 << 12)
   6370 
   6371   /* Signal that the symbol is indirect.  This symbol is an indirect
   6372      pointer to the symbol with the same name as the next symbol.  */
   6373 #define BSF_INDIRECT            (1 << 13)
   6374 
   6375   /* BSF_FILE marks symbols that contain a file name.  This is used
   6376      for ELF STT_FILE symbols.  */
   6377 #define BSF_FILE                (1 << 14)
   6378 
   6379   /* Symbol is from dynamic linking information.  */
   6380 #define BSF_DYNAMIC             (1 << 15)
   6381 
   6382   /* The symbol denotes a data object.  Used in ELF, and perhaps
   6383      others someday.  */
   6384 #define BSF_OBJECT              (1 << 16)
   6385 
   6386   /* This symbol is a debugging symbol.  The value is the offset
   6387      into the section of the data.  BSF_DEBUGGING should be set
   6388      as well.  */
   6389 #define BSF_DEBUGGING_RELOC     (1 << 17)
   6390 
   6391   /* This symbol is thread local.  Used in ELF.  */
   6392 #define BSF_THREAD_LOCAL        (1 << 18)
   6393 
   6394   /* This symbol represents a complex relocation expression,
   6395      with the expression tree serialized in the symbol name.  */
   6396 #define BSF_RELC                (1 << 19)
   6397 
   6398   /* This symbol represents a signed complex relocation expression,
   6399      with the expression tree serialized in the symbol name.  */
   6400 #define BSF_SRELC               (1 << 20)
   6401 
   6402   /* This symbol was created by bfd_get_synthetic_symtab.  */
   6403 #define BSF_SYNTHETIC           (1 << 21)
   6404 
   6405   /* This symbol is an indirect code object.  Unrelated to BSF_INDIRECT.
   6406      The dynamic linker will compute the value of this symbol by
   6407      calling the function that it points to.  BSF_FUNCTION must
   6408      also be also set.  */
   6409 #define BSF_GNU_INDIRECT_FUNCTION (1 << 22)
   6410   /* This symbol is a globally unique data object.  The dynamic linker
   6411      will make sure that in the entire process there is just one symbol
   6412      with this name and type in use.  BSF_OBJECT must also be set.  */
   6413 #define BSF_GNU_UNIQUE          (1 << 23)
   6414 
   6415   /* This section symbol should be included in the symbol table.  */
   6416 #define BSF_SECTION_SYM_USED    (1 << 24)
   6417 
   6418   flagword flags;
   6419 
   6420   /* A pointer to the section to which this symbol is
   6421      relative.  This will always be non NULL, there are special
   6422      sections for undefined and absolute symbols.  */
   6423   struct bfd_section *section;
   6424 
   6425   /* Back end special data.  */
   6426   union
   6427     {
   6428       void *p;
   6429       bfd_vma i;
   6430     }
   6431   udata;
   6432 }
   6433 asymbol;
   6434 
   6435 #define bfd_get_symtab_upper_bound(abfd) \
   6436        BFD_SEND (abfd, _bfd_get_symtab_upper_bound, (abfd))
   6437 
   6438 bool bfd_is_local_label (bfd *abfd, asymbol *sym);
   6439 
   6440 bool bfd_is_local_label_name (bfd *abfd, const char *name);
   6441 
   6442 #define bfd_is_local_label_name(abfd, name) \
   6443        BFD_SEND (abfd, _bfd_is_local_label_name, (abfd, name))
   6444 
   6445 bool bfd_is_target_special_symbol (bfd *abfd, asymbol *sym);
   6446 
   6447 #define bfd_is_target_special_symbol(abfd, sym) \
   6448        BFD_SEND (abfd, _bfd_is_target_special_symbol, (abfd, sym))
   6449 
   6450 #define bfd_canonicalize_symtab(abfd, location) \
   6451        BFD_SEND (abfd, _bfd_canonicalize_symtab, (abfd, location))
   6452 
   6453 bool bfd_set_symtab
   6454    (bfd *abfd, asymbol **location, unsigned int count);
   6455 
   6456 void bfd_print_symbol_vandf (bfd *abfd, void *file, asymbol *symbol);
   6457 
   6458 #define bfd_make_empty_symbol(abfd) \
   6459        BFD_SEND (abfd, _bfd_make_empty_symbol, (abfd))
   6460 
   6461 asymbol *_bfd_generic_make_empty_symbol (bfd *);
   6462 
   6463 #define bfd_make_debug_symbol(abfd,ptr,size) \
   6464        BFD_SEND (abfd, _bfd_make_debug_symbol, (abfd, ptr, size))
   6465 
   6466 int bfd_decode_symclass (asymbol *symbol);
   6467 
   6468 bool bfd_is_undefined_symclass (int symclass);
   6469 
   6470 void bfd_symbol_info (asymbol *symbol, symbol_info *ret);
   6471 
   6472 bool bfd_copy_private_symbol_data
   6473    (bfd *ibfd, asymbol *isym, bfd *obfd, asymbol *osym);
   6474 
   6475 #define bfd_copy_private_symbol_data(ibfd, isymbol, obfd, osymbol) \
   6476        BFD_SEND (obfd, _bfd_copy_private_symbol_data, \
   6477                  (ibfd, isymbol, obfd, osymbol))
   6478 
   6479 /* Extracted from bfd.c.  */
   6480 
   6481 enum bfd_direction
   6482   {
   6483     no_direction = 0,
   6484     read_direction = 1,
   6485     write_direction = 2,
   6486     both_direction = 3
   6487   };
   6488 
   6489 enum bfd_plugin_format
   6490   {
   6491     bfd_plugin_unknown = 0,
   6492     bfd_plugin_yes = 1,
   6493     bfd_plugin_no = 2
   6494   };
   6495 
   6496 struct bfd_build_id
   6497   {
   6498     bfd_size_type size;
   6499     bfd_byte data[1];
   6500   };
   6501 
   6502 struct bfd
   6503 {
   6504   /* The filename the application opened the BFD with.  */
   6505   const char *filename;
   6506 
   6507   /* A pointer to the target jump table.  */
   6508   const struct bfd_target *xvec;
   6509 
   6510   /* The IOSTREAM, and corresponding IO vector that provide access
   6511      to the file backing the BFD.  */
   6512   void *iostream;
   6513   const struct bfd_iovec *iovec;
   6514 
   6515   /* The caching routines use these to maintain a
   6516      least-recently-used list of BFDs.  */
   6517   struct bfd *lru_prev, *lru_next;
   6518 
   6519   /* Track current file position (or current buffer offset for
   6520      in-memory BFDs).  When a file is closed by the caching routines,
   6521      BFD retains state information on the file here.  */
   6522   ufile_ptr where;
   6523 
   6524   /* File modified time, if mtime_set is TRUE.  */
   6525   long mtime;
   6526 
   6527   /* A unique identifier of the BFD  */
   6528   unsigned int id;
   6529 
   6530   /* Format_specific flags.  */
   6531   flagword flags;
   6532 
   6533   /* Values that may appear in the flags field of a BFD.  These also
   6534      appear in the object_flags field of the bfd_target structure, where
   6535      they indicate the set of flags used by that backend (not all flags
   6536      are meaningful for all object file formats) (FIXME: at the moment,
   6537      the object_flags values have mostly just been copied from backend
   6538      to another, and are not necessarily correct).  */
   6539 
   6540 #define BFD_NO_FLAGS                0x0
   6541 
   6542   /* BFD contains relocation entries.  */
   6543 #define HAS_RELOC                   0x1
   6544 
   6545   /* BFD is directly executable.  */
   6546 #define EXEC_P                      0x2
   6547 
   6548   /* BFD has line number information (basically used for F_LNNO in a
   6549      COFF header).  */
   6550 #define HAS_LINENO                  0x4
   6551 
   6552   /* BFD has debugging information.  */
   6553 #define HAS_DEBUG                  0x08
   6554 
   6555   /* BFD has symbols.  */
   6556 #define HAS_SYMS                   0x10
   6557 
   6558   /* BFD has local symbols (basically used for F_LSYMS in a COFF
   6559      header).  */
   6560 #define HAS_LOCALS                 0x20
   6561 
   6562   /* BFD is a dynamic object.  */
   6563 #define DYNAMIC                    0x40
   6564 
   6565   /* Text section is write protected (if D_PAGED is not set, this is
   6566      like an a.out NMAGIC file) (the linker sets this by default, but
   6567      clears it for -r or -N).  */
   6568 #define WP_TEXT                    0x80
   6569 
   6570   /* BFD is dynamically paged (this is like an a.out ZMAGIC file) (the
   6571      linker sets this by default, but clears it for -r or -n or -N).  */
   6572 #define D_PAGED                   0x100
   6573 
   6574   /* BFD is relaxable (this means that bfd_relax_section may be able to
   6575      do something) (sometimes bfd_relax_section can do something even if
   6576      this is not set).  */
   6577 #define BFD_IS_RELAXABLE          0x200
   6578 
   6579   /* This may be set before writing out a BFD to request using a
   6580      traditional format.  For example, this is used to request that when
   6581      writing out an a.out object the symbols not be hashed to eliminate
   6582      duplicates.  */
   6583 #define BFD_TRADITIONAL_FORMAT    0x400
   6584 
   6585   /* This flag indicates that the BFD contents are actually cached
   6586      in memory.  If this is set, iostream points to a bfd_in_memory
   6587      struct.  */
   6588 #define BFD_IN_MEMORY             0x800
   6589 
   6590   /* This BFD has been created by the linker and doesn't correspond
   6591      to any input file.  */
   6592 #define BFD_LINKER_CREATED       0x1000
   6593 
   6594   /* This may be set before writing out a BFD to request that it
   6595      be written using values for UIDs, GIDs, timestamps, etc. that
   6596      will be consistent from run to run.  */
   6597 #define BFD_DETERMINISTIC_OUTPUT 0x2000
   6598 
   6599   /* Compress sections in this BFD.  */
   6600 #define BFD_COMPRESS             0x4000
   6601 
   6602   /* Decompress sections in this BFD.  */
   6603 #define BFD_DECOMPRESS           0x8000
   6604 
   6605   /* BFD is a dummy, for plugins.  */
   6606 #define BFD_PLUGIN              0x10000
   6607 
   6608   /* Compress sections in this BFD with SHF_COMPRESSED from gABI.  */
   6609 #define BFD_COMPRESS_GABI       0x20000
   6610 
   6611   /* Convert ELF common symbol type to STT_COMMON or STT_OBJECT in this
   6612      BFD.  */
   6613 #define BFD_CONVERT_ELF_COMMON  0x40000
   6614 
   6615   /* Use the ELF STT_COMMON type in this BFD.  */
   6616 #define BFD_USE_ELF_STT_COMMON  0x80000
   6617 
   6618   /* Put pathnames into archives (non-POSIX).  */
   6619 #define BFD_ARCHIVE_FULL_PATH  0x100000
   6620 
   6621   /* Flags bits to be saved in bfd_preserve_save.  */
   6622 #define BFD_FLAGS_SAVED \
   6623   (BFD_IN_MEMORY | BFD_COMPRESS | BFD_DECOMPRESS | BFD_LINKER_CREATED \
   6624    | BFD_PLUGIN | BFD_COMPRESS_GABI | BFD_CONVERT_ELF_COMMON \
   6625    | BFD_USE_ELF_STT_COMMON)
   6626 
   6627   /* Flags bits which are for BFD use only.  */
   6628 #define BFD_FLAGS_FOR_BFD_USE_MASK \
   6629   (BFD_IN_MEMORY | BFD_COMPRESS | BFD_DECOMPRESS | BFD_LINKER_CREATED \
   6630    | BFD_PLUGIN | BFD_TRADITIONAL_FORMAT | BFD_DETERMINISTIC_OUTPUT \
   6631    | BFD_COMPRESS_GABI | BFD_CONVERT_ELF_COMMON | BFD_USE_ELF_STT_COMMON)
   6632 
   6633   /* The format which belongs to the BFD. (object, core, etc.)  */
   6634   ENUM_BITFIELD (bfd_format) format : 3;
   6635 
   6636   /* The direction with which the BFD was opened.  */
   6637   ENUM_BITFIELD (bfd_direction) direction : 2;
   6638 
   6639   /* Is the file descriptor being cached?  That is, can it be closed as
   6640      needed, and re-opened when accessed later?  */
   6641   unsigned int cacheable : 1;
   6642 
   6643   /* Marks whether there was a default target specified when the
   6644      BFD was opened. This is used to select which matching algorithm
   6645      to use to choose the back end.  */
   6646   unsigned int target_defaulted : 1;
   6647 
   6648   /* ... and here: (``once'' means at least once).  */
   6649   unsigned int opened_once : 1;
   6650 
   6651   /* Set if we have a locally maintained mtime value, rather than
   6652      getting it from the file each time.  */
   6653   unsigned int mtime_set : 1;
   6654 
   6655   /* Flag set if symbols from this BFD should not be exported.  */
   6656   unsigned int no_export : 1;
   6657 
   6658   /* Remember when output has begun, to stop strange things
   6659      from happening.  */
   6660   unsigned int output_has_begun : 1;
   6661 
   6662   /* Have archive map.  */
   6663   unsigned int has_armap : 1;
   6664 
   6665   /* Set if this is a thin archive.  */
   6666   unsigned int is_thin_archive : 1;
   6667 
   6668   /* Set if this archive should not cache element positions.  */
   6669   unsigned int no_element_cache : 1;
   6670 
   6671   /* Set if only required symbols should be added in the link hash table for
   6672      this object.  Used by VMS linkers.  */
   6673   unsigned int selective_search : 1;
   6674 
   6675   /* Set if this is the linker output BFD.  */
   6676   unsigned int is_linker_output : 1;
   6677 
   6678   /* Set if this is the linker input BFD.  */
   6679   unsigned int is_linker_input : 1;
   6680 
   6681   /* If this is an input for a compiler plug-in library.  */
   6682   ENUM_BITFIELD (bfd_plugin_format) plugin_format : 2;
   6683 
   6684   /* Set if this is a plugin output file.  */
   6685   unsigned int lto_output : 1;
   6686 
   6687   /* Set if this is a slim LTO object not loaded with a compiler plugin.  */
   6688   unsigned int lto_slim_object : 1;
   6689 
   6690   /* Do not attempt to modify this file.  Set when detecting errors
   6691      that BFD is not prepared to handle for objcopy/strip.  */
   6692   unsigned int read_only : 1;
   6693 
   6694   /* Set to dummy BFD created when claimed by a compiler plug-in
   6695      library.  */
   6696   bfd *plugin_dummy_bfd;
   6697 
   6698   /* The offset of this bfd in the file, typically 0 if it is not
   6699      contained in an archive.  */
   6700   ufile_ptr origin;
   6701 
   6702   /* The origin in the archive of the proxy entry.  This will
   6703      normally be the same as origin, except for thin archives,
   6704      when it will contain the current offset of the proxy in the
   6705      thin archive rather than the offset of the bfd in its actual
   6706      container.  */
   6707   ufile_ptr proxy_origin;
   6708 
   6709   /* A hash table for section names.  */
   6710   struct bfd_hash_table section_htab;
   6711 
   6712   /* Pointer to linked list of sections.  */
   6713   struct bfd_section *sections;
   6714 
   6715   /* The last section on the section list.  */
   6716   struct bfd_section *section_last;
   6717 
   6718   /* The number of sections.  */
   6719   unsigned int section_count;
   6720 
   6721   /* The archive plugin file descriptor.  */
   6722   int archive_plugin_fd;
   6723 
   6724   /* The number of opens on the archive plugin file descriptor.  */
   6725   unsigned int archive_plugin_fd_open_count;
   6726 
   6727   /* A field used by _bfd_generic_link_add_archive_symbols.  This will
   6728      be used only for archive elements.  */
   6729   int archive_pass;
   6730 
   6731   /* The total size of memory from bfd_alloc.  */
   6732   bfd_size_type alloc_size;
   6733 
   6734   /* Stuff only useful for object files:
   6735      The start address.  */
   6736   bfd_vma start_address;
   6737 
   6738   /* Symbol table for output BFD (with symcount entries).
   6739      Also used by the linker to cache input BFD symbols.  */
   6740   struct bfd_symbol **outsymbols;
   6741 
   6742   /* Used for input and output.  */
   6743   unsigned int symcount;
   6744 
   6745   /* Used for slurped dynamic symbol tables.  */
   6746   unsigned int dynsymcount;
   6747 
   6748   /* Pointer to structure which contains architecture information.  */
   6749   const struct bfd_arch_info *arch_info;
   6750 
   6751   /* Cached length of file for bfd_get_size.  0 until bfd_get_size is
   6752      called, 1 if stat returns an error or the file size is too large to
   6753      return in ufile_ptr.  Both 0 and 1 should be treated as "unknown".  */
   6754   ufile_ptr size;
   6755 
   6756   /* Stuff only useful for archives.  */
   6757   void *arelt_data;
   6758   struct bfd *my_archive;      /* The containing archive BFD.  */
   6759   struct bfd *archive_next;    /* The next BFD in the archive.  */
   6760   struct bfd *archive_head;    /* The first BFD in the archive.  */
   6761   struct bfd *nested_archives; /* List of nested archive in a flattened
   6762                                   thin archive.  */
   6763 
   6764   union {
   6765     /* For input BFDs, a chain of BFDs involved in a link.  */
   6766     struct bfd *next;
   6767     /* For output BFD, the linker hash table.  */
   6768     struct bfd_link_hash_table *hash;
   6769   } link;
   6770 
   6771   /* Used by the back end to hold private data.  */
   6772   union
   6773     {
   6774       struct aout_data_struct *aout_data;
   6775       struct artdata *aout_ar_data;
   6776       struct coff_tdata *coff_obj_data;
   6777       struct pe_tdata *pe_obj_data;
   6778       struct xcoff_tdata *xcoff_obj_data;
   6779       struct ecoff_tdata *ecoff_obj_data;
   6780       struct srec_data_struct *srec_data;
   6781       struct verilog_data_struct *verilog_data;
   6782       struct ihex_data_struct *ihex_data;
   6783       struct tekhex_data_struct *tekhex_data;
   6784       struct elf_obj_tdata *elf_obj_data;
   6785       struct mmo_data_struct *mmo_data;
   6786       struct sun_core_struct *sun_core_data;
   6787       struct sco5_core_struct *sco5_core_data;
   6788       struct trad_core_struct *trad_core_data;
   6789       struct som_data_struct *som_data;
   6790       struct hpux_core_struct *hpux_core_data;
   6791       struct hppabsd_core_struct *hppabsd_core_data;
   6792       struct sgi_core_struct *sgi_core_data;
   6793       struct lynx_core_struct *lynx_core_data;
   6794       struct osf_core_struct *osf_core_data;
   6795       struct cisco_core_struct *cisco_core_data;
   6796       struct versados_data_struct *versados_data;
   6797       struct netbsd_core_struct *netbsd_core_data;
   6798       struct mach_o_data_struct *mach_o_data;
   6799       struct mach_o_fat_data_struct *mach_o_fat_data;
   6800       struct plugin_data_struct *plugin_data;
   6801       struct bfd_pef_data_struct *pef_data;
   6802       struct bfd_pef_xlib_data_struct *pef_xlib_data;
   6803       struct bfd_sym_data_struct *sym_data;
   6804       void *any;
   6805     }
   6806   tdata;
   6807 
   6808   /* Used by the application to hold private data.  */
   6809   void *usrdata;
   6810 
   6811   /* Where all the allocated stuff under this BFD goes.  This is a
   6812      struct objalloc *, but we use void * to avoid requiring the inclusion
   6813      of objalloc.h.  */
   6814   void *memory;
   6815 
   6816   /* For input BFDs, the build ID, if the object has one. */
   6817   const struct bfd_build_id *build_id;
   6818 };
   6819 
   6820 static inline const char *
   6821 bfd_get_filename (const bfd *abfd)
   6822 {
   6823   return abfd->filename;
   6824 }
   6825 
   6826 static inline bool
   6827 bfd_get_cacheable (const bfd *abfd)
   6828 {
   6829   return abfd->cacheable;
   6830 }
   6831 
   6832 static inline enum bfd_format
   6833 bfd_get_format (const bfd *abfd)
   6834 {
   6835   return abfd->format;
   6836 }
   6837 
   6838 static inline flagword
   6839 bfd_get_file_flags (const bfd *abfd)
   6840 {
   6841   return abfd->flags;
   6842 }
   6843 
   6844 static inline bfd_vma
   6845 bfd_get_start_address (const bfd *abfd)
   6846 {
   6847   return abfd->start_address;
   6848 }
   6849 
   6850 static inline unsigned int
   6851 bfd_get_symcount (const bfd *abfd)
   6852 {
   6853   return abfd->symcount;
   6854 }
   6855 
   6856 static inline unsigned int
   6857 bfd_get_dynamic_symcount (const bfd *abfd)
   6858 {
   6859   return abfd->dynsymcount;
   6860 }
   6861 
   6862 static inline struct bfd_symbol **
   6863 bfd_get_outsymbols (const bfd *abfd)
   6864 {
   6865   return abfd->outsymbols;
   6866 }
   6867 
   6868 static inline unsigned int
   6869 bfd_count_sections (const bfd *abfd)
   6870 {
   6871   return abfd->section_count;
   6872 }
   6873 
   6874 static inline bool
   6875 bfd_has_map (const bfd *abfd)
   6876 {
   6877   return abfd->has_armap;
   6878 }
   6879 
   6880 static inline bool
   6881 bfd_is_thin_archive (const bfd *abfd)
   6882 {
   6883   return abfd->is_thin_archive;
   6884 }
   6885 
   6886 static inline void *
   6887 bfd_usrdata (const bfd *abfd)
   6888 {
   6889   return abfd->usrdata;
   6890 }
   6891 
   6892 /* See note beside bfd_set_section_userdata.  */
   6893 static inline bool
   6894 bfd_set_cacheable (bfd * abfd, bool val)
   6895 {
   6896   abfd->cacheable = val;
   6897   return true;
   6898 }
   6899 
   6900 static inline void
   6901 bfd_set_thin_archive (bfd *abfd, bool val)
   6902 {
   6903   abfd->is_thin_archive = val;
   6904 }
   6905 
   6906 static inline void
   6907 bfd_set_usrdata (bfd *abfd, void *val)
   6908 {
   6909   abfd->usrdata = val;
   6910 }
   6911 
   6912 static inline asection *
   6913 bfd_asymbol_section (const asymbol *sy)
   6914 {
   6915   return sy->section;
   6916 }
   6917 
   6918 static inline bfd_vma
   6919 bfd_asymbol_value (const asymbol *sy)
   6920 {
   6921   return sy->section->vma + sy->value;
   6922 }
   6923 
   6924 static inline const char *
   6925 bfd_asymbol_name (const asymbol *sy)
   6926 {
   6927   return sy->name;
   6928 }
   6929 
   6930 static inline struct bfd *
   6931 bfd_asymbol_bfd (const asymbol *sy)
   6932 {
   6933   return sy->the_bfd;
   6934 }
   6935 
   6936 static inline void
   6937 bfd_set_asymbol_name (asymbol *sy, const char *name)
   6938 {
   6939   sy->name = name;
   6940 }
   6941 
   6942 static inline bfd_size_type
   6943 bfd_get_section_limit_octets (const bfd *abfd, const asection *sec)
   6944 {
   6945   if (abfd->direction != write_direction && sec->rawsize != 0)
   6946     return sec->rawsize;
   6947   return sec->size;
   6948 }
   6949 
   6950 /* Find the address one past the end of SEC.  */
   6951 static inline bfd_size_type
   6952 bfd_get_section_limit (const bfd *abfd, const asection *sec)
   6953 {
   6954   return (bfd_get_section_limit_octets (abfd, sec)
   6955           / bfd_octets_per_byte (abfd, sec));
   6956 }
   6957 
   6958 /* Functions to handle insertion and deletion of a bfd's sections.  These
   6959    only handle the list pointers, ie. do not adjust section_count,
   6960    target_index etc.  */
   6961 static inline void
   6962 bfd_section_list_remove (bfd *abfd, asection *s)
   6963 {
   6964   asection *next = s->next;
   6965   asection *prev = s->prev;
   6966   if (prev)
   6967     prev->next = next;
   6968   else
   6969     abfd->sections = next;
   6970   if (next)
   6971     next->prev = prev;
   6972   else
   6973     abfd->section_last = prev;
   6974 }
   6975 
   6976 static inline void
   6977 bfd_section_list_append (bfd *abfd, asection *s)
   6978 {
   6979   s->next = 0;
   6980   if (abfd->section_last)
   6981     {
   6982       s->prev = abfd->section_last;
   6983       abfd->section_last->next = s;
   6984     }
   6985   else
   6986     {
   6987       s->prev = 0;
   6988       abfd->sections = s;
   6989     }
   6990   abfd->section_last = s;
   6991 }
   6992 
   6993 static inline void
   6994 bfd_section_list_prepend (bfd *abfd, asection *s)
   6995 {
   6996   s->prev = 0;
   6997   if (abfd->sections)
   6998     {
   6999       s->next = abfd->sections;
   7000       abfd->sections->prev = s;
   7001     }
   7002   else
   7003     {
   7004       s->next = 0;
   7005       abfd->section_last = s;
   7006     }
   7007   abfd->sections = s;
   7008 }
   7009 
   7010 static inline void
   7011 bfd_section_list_insert_after (bfd *abfd, asection *a, asection *s)
   7012 {
   7013   asection *next = a->next;
   7014   s->next = next;
   7015   s->prev = a;
   7016   a->next = s;
   7017   if (next)
   7018     next->prev = s;
   7019   else
   7020     abfd->section_last = s;
   7021 }
   7022 
   7023 static inline void
   7024 bfd_section_list_insert_before (bfd *abfd, asection *b, asection *s)
   7025 {
   7026   asection *prev = b->prev;
   7027   s->prev = prev;
   7028   s->next = b;
   7029   b->prev = s;
   7030   if (prev)
   7031     prev->next = s;
   7032   else
   7033     abfd->sections = s;
   7034 }
   7035 
   7036 static inline bool
   7037 bfd_section_removed_from_list (const bfd *abfd, const asection *s)
   7038 {
   7039   return s->next ? s->next->prev != s : abfd->section_last != s;
   7040 }
   7041 
   7042 
   7043 typedef enum bfd_error
   7044 {
   7045   bfd_error_no_error = 0,
   7046   bfd_error_system_call,
   7047   bfd_error_invalid_target,
   7048   bfd_error_wrong_format,
   7049   bfd_error_wrong_object_format,
   7050   bfd_error_invalid_operation,
   7051   bfd_error_no_memory,
   7052   bfd_error_no_symbols,
   7053   bfd_error_no_armap,
   7054   bfd_error_no_more_archived_files,
   7055   bfd_error_malformed_archive,
   7056   bfd_error_missing_dso,
   7057   bfd_error_file_not_recognized,
   7058   bfd_error_file_ambiguously_recognized,
   7059   bfd_error_no_contents,
   7060   bfd_error_nonrepresentable_section,
   7061   bfd_error_no_debug_section,
   7062   bfd_error_bad_value,
   7063   bfd_error_file_truncated,
   7064   bfd_error_file_too_big,
   7065   bfd_error_sorry,
   7066   bfd_error_on_input,
   7067   bfd_error_invalid_error_code
   7068 }
   7069 bfd_error_type;
   7070 
   7071 bfd_error_type bfd_get_error (void);
   7072 
   7073 void bfd_set_error (bfd_error_type error_tag);
   7074 
   7075 void bfd_set_input_error (bfd *input, bfd_error_type error_tag);
   7076 
   7077 const char *bfd_errmsg (bfd_error_type error_tag);
   7078 
   7079 void bfd_perror (const char *message);
   7080 
   7081 
   7082 typedef void (*bfd_error_handler_type) (const char *, va_list);
   7083 
   7084 void _bfd_error_handler (const char *fmt, ...) ATTRIBUTE_PRINTF_1;
   7085 
   7086 bfd_error_handler_type bfd_set_error_handler (bfd_error_handler_type);
   7087 
   7088 void bfd_set_error_program_name (const char *);
   7089 
   7090 
   7091 typedef void (*bfd_assert_handler_type) (const char *bfd_formatmsg,
   7092                                          const char *bfd_version,
   7093                                          const char *bfd_file,
   7094                                          int bfd_line);
   7095 
   7096 bfd_assert_handler_type bfd_set_assert_handler (bfd_assert_handler_type);
   7097 
   7098 long bfd_get_reloc_upper_bound (bfd *abfd, asection *sect);
   7099 
   7100 long bfd_canonicalize_reloc
   7101    (bfd *abfd, asection *sec, arelent **loc, asymbol **syms);
   7102 
   7103 void bfd_set_reloc
   7104    (bfd *abfd, asection *sec, arelent **rel, unsigned int count);
   7105 
   7106 #define bfd_set_reloc(abfd, asect, location, count) \
   7107        BFD_SEND (abfd, _bfd_set_reloc, (abfd, asect, location, count))
   7108 bool bfd_set_file_flags (bfd *abfd, flagword flags);
   7109 
   7110 int bfd_get_arch_size (bfd *abfd);
   7111 
   7112 int bfd_get_sign_extend_vma (bfd *abfd);
   7113 
   7114 bool bfd_set_start_address (bfd *abfd, bfd_vma vma);
   7115 
   7116 unsigned int bfd_get_gp_size (bfd *abfd);
   7117 
   7118 void bfd_set_gp_size (bfd *abfd, unsigned int i);
   7119 
   7120 void bfd_set_gp_value (bfd *abfd, bfd_vma v);
   7121 
   7122 bfd_vma bfd_scan_vma (const char *string, const char **end, int base);
   7123 
   7124 bool bfd_copy_private_header_data (bfd *ibfd, bfd *obfd);
   7125 
   7126 #define bfd_copy_private_header_data(ibfd, obfd) \
   7127        BFD_SEND (obfd, _bfd_copy_private_header_data, \
   7128                  (ibfd, obfd))
   7129 bool bfd_copy_private_bfd_data (bfd *ibfd, bfd *obfd);
   7130 
   7131 #define bfd_copy_private_bfd_data(ibfd, obfd) \
   7132        BFD_SEND (obfd, _bfd_copy_private_bfd_data, \
   7133                  (ibfd, obfd))
   7134 bool bfd_set_private_flags (bfd *abfd, flagword flags);
   7135 
   7136 #define bfd_set_private_flags(abfd, flags) \
   7137        BFD_SEND (abfd, _bfd_set_private_flags, (abfd, flags))
   7138 #define bfd_sizeof_headers(abfd, info) \
   7139        BFD_SEND (abfd, _bfd_sizeof_headers, (abfd, info))
   7140 
   7141 #define bfd_find_nearest_line(abfd, sec, syms, off, file, func, line) \
   7142        BFD_SEND (abfd, _bfd_find_nearest_line, \
   7143                  (abfd, syms, sec, off, file, func, line, NULL))
   7144 
   7145 #define bfd_find_nearest_line_discriminator(abfd, sec, syms, off, file, func, \
   7146                                            line, disc) \
   7147        BFD_SEND (abfd, _bfd_find_nearest_line, \
   7148                  (abfd, syms, sec, off, file, func, line, disc))
   7149 
   7150 #define bfd_find_line(abfd, syms, sym, file, line) \
   7151        BFD_SEND (abfd, _bfd_find_line, \
   7152                  (abfd, syms, sym, file, line))
   7153 
   7154 #define bfd_find_inliner_info(abfd, file, func, line) \
   7155        BFD_SEND (abfd, _bfd_find_inliner_info, \
   7156                  (abfd, file, func, line))
   7157 
   7158 #define bfd_debug_info_start(abfd) \
   7159        BFD_SEND (abfd, _bfd_debug_info_start, (abfd))
   7160 
   7161 #define bfd_debug_info_end(abfd) \
   7162        BFD_SEND (abfd, _bfd_debug_info_end, (abfd))
   7163 
   7164 #define bfd_debug_info_accumulate(abfd, section) \
   7165        BFD_SEND (abfd, _bfd_debug_info_accumulate, (abfd, section))
   7166 
   7167 #define bfd_stat_arch_elt(abfd, stat) \
   7168        BFD_SEND (abfd->my_archive ? abfd->my_archive : abfd, \
   7169                  _bfd_stat_arch_elt, (abfd, stat))
   7170 
   7171 #define bfd_update_armap_timestamp(abfd) \
   7172        BFD_SEND (abfd, _bfd_update_armap_timestamp, (abfd))
   7173 
   7174 #define bfd_set_arch_mach(abfd, arch, mach)\
   7175        BFD_SEND ( abfd, _bfd_set_arch_mach, (abfd, arch, mach))
   7176 
   7177 #define bfd_relax_section(abfd, section, link_info, again) \
   7178        BFD_SEND (abfd, _bfd_relax_section, (abfd, section, link_info, again))
   7179 
   7180 #define bfd_gc_sections(abfd, link_info) \
   7181        BFD_SEND (abfd, _bfd_gc_sections, (abfd, link_info))
   7182 
   7183 #define bfd_lookup_section_flags(link_info, flag_info, section) \
   7184        BFD_SEND (abfd, _bfd_lookup_section_flags, (link_info, flag_info, section))
   7185 
   7186 #define bfd_merge_sections(abfd, link_info) \
   7187        BFD_SEND (abfd, _bfd_merge_sections, (abfd, link_info))
   7188 
   7189 #define bfd_is_group_section(abfd, sec) \
   7190        BFD_SEND (abfd, _bfd_is_group_section, (abfd, sec))
   7191 
   7192 #define bfd_group_name(abfd, sec) \
   7193        BFD_SEND (abfd, _bfd_group_name, (abfd, sec))
   7194 
   7195 #define bfd_discard_group(abfd, sec) \
   7196        BFD_SEND (abfd, _bfd_discard_group, (abfd, sec))
   7197 
   7198 #define bfd_link_hash_table_create(abfd) \
   7199        BFD_SEND (abfd, _bfd_link_hash_table_create, (abfd))
   7200 
   7201 #define bfd_link_add_symbols(abfd, info) \
   7202        BFD_SEND (abfd, _bfd_link_add_symbols, (abfd, info))
   7203 
   7204 #define bfd_link_just_syms(abfd, sec, info) \
   7205        BFD_SEND (abfd, _bfd_link_just_syms, (sec, info))
   7206 
   7207 #define bfd_final_link(abfd, info) \
   7208        BFD_SEND (abfd, _bfd_final_link, (abfd, info))
   7209 
   7210 #define bfd_free_cached_info(abfd) \
   7211        BFD_SEND (abfd, _bfd_free_cached_info, (abfd))
   7212 
   7213 #define bfd_get_dynamic_symtab_upper_bound(abfd) \
   7214        BFD_SEND (abfd, _bfd_get_dynamic_symtab_upper_bound, (abfd))
   7215 
   7216 #define bfd_print_private_bfd_data(abfd, file)\
   7217        BFD_SEND (abfd, _bfd_print_private_bfd_data, (abfd, file))
   7218 
   7219 #define bfd_canonicalize_dynamic_symtab(abfd, asymbols) \
   7220        BFD_SEND (abfd, _bfd_canonicalize_dynamic_symtab, (abfd, asymbols))
   7221 
   7222 #define bfd_get_synthetic_symtab(abfd, count, syms, dyncount, dynsyms, ret) \
   7223        BFD_SEND (abfd, _bfd_get_synthetic_symtab, (abfd, count, syms, \
   7224                                                    dyncount, dynsyms, ret))
   7225 
   7226 #define bfd_get_dynamic_reloc_upper_bound(abfd) \
   7227        BFD_SEND (abfd, _bfd_get_dynamic_reloc_upper_bound, (abfd))
   7228 
   7229 #define bfd_canonicalize_dynamic_reloc(abfd, arels, asyms) \
   7230        BFD_SEND (abfd, _bfd_canonicalize_dynamic_reloc, (abfd, arels, asyms))
   7231 
   7232 extern bfd_byte *bfd_get_relocated_section_contents
   7233   (bfd *, struct bfd_link_info *, struct bfd_link_order *, bfd_byte *,
   7234    bool, asymbol **);
   7235 
   7236 bool bfd_alt_mach_code (bfd *abfd, int alternative);
   7237 
   7238 bfd_vma bfd_emul_get_maxpagesize (const char *);
   7239 
   7240 bfd_vma bfd_emul_get_commonpagesize (const char *);
   7241 
   7242 char *bfd_demangle (bfd *, const char *, int);
   7243 
   7244 void bfd_update_compression_header
   7245    (bfd *abfd, bfd_byte *contents, asection *sec);
   7246 
   7247 bool bfd_check_compression_header
   7248    (bfd *abfd, bfd_byte *contents, asection *sec,
   7249     bfd_size_type *uncompressed_size,
   7250     unsigned int *uncompressed_alignment_power);
   7251 
   7252 int bfd_get_compression_header_size (bfd *abfd, asection *sec);
   7253 
   7254 bfd_size_type bfd_convert_section_size
   7255    (bfd *ibfd, asection *isec, bfd *obfd, bfd_size_type size);
   7256 
   7257 bool bfd_convert_section_contents
   7258    (bfd *ibfd, asection *isec, bfd *obfd,
   7259     bfd_byte **ptr, bfd_size_type *ptr_size);
   7260 
   7261 /* Extracted from archive.c.  */
   7262 symindex bfd_get_next_mapent
   7263    (bfd *abfd, symindex previous, carsym **sym);
   7264 
   7265 bool bfd_set_archive_head (bfd *output, bfd *new_head);
   7266 
   7267 bfd *bfd_openr_next_archived_file (bfd *archive, bfd *previous);
   7268 
   7269 /* Extracted from corefile.c.  */
   7270 const char *bfd_core_file_failing_command (bfd *abfd);
   7271 
   7272 int bfd_core_file_failing_signal (bfd *abfd);
   7273 
   7274 int bfd_core_file_pid (bfd *abfd);
   7275 
   7276 bool core_file_matches_executable_p
   7277    (bfd *core_bfd, bfd *exec_bfd);
   7278 
   7279 bool generic_core_file_matches_executable_p
   7280    (bfd *core_bfd, bfd *exec_bfd);
   7281 
   7282 /* Extracted from targets.c.  */
   7283 #define BFD_SEND(bfd, message, arglist) \
   7284   ((*((bfd)->xvec->message)) arglist)
   7285 
   7286 #ifdef DEBUG_BFD_SEND
   7287 #undef BFD_SEND
   7288 #define BFD_SEND(bfd, message, arglist) \
   7289   (((bfd) && (bfd)->xvec && (bfd)->xvec->message) ? \
   7290     ((*((bfd)->xvec->message)) arglist) : \
   7291     (bfd_assert (__FILE__,__LINE__), NULL))
   7292 #endif
   7293 #define BFD_SEND_FMT(bfd, message, arglist) \
   7294   (((bfd)->xvec->message[(int) ((bfd)->format)]) arglist)
   7295 
   7296 #ifdef DEBUG_BFD_SEND
   7297 #undef BFD_SEND_FMT
   7298 #define BFD_SEND_FMT(bfd, message, arglist) \
   7299   (((bfd) && (bfd)->xvec && (bfd)->xvec->message) ? \
   7300    (((bfd)->xvec->message[(int) ((bfd)->format)]) arglist) : \
   7301    (bfd_assert (__FILE__,__LINE__), NULL))
   7302 #endif
   7303 
   7304 /* Defined to TRUE if unused section symbol should be kept.  */
   7305 #ifndef TARGET_KEEP_UNUSED_SECTION_SYMBOLS
   7306 #define TARGET_KEEP_UNUSED_SECTION_SYMBOLS true
   7307 #endif
   7308 
   7309 enum bfd_flavour
   7310 {
   7311   /* N.B. Update bfd_flavour_name if you change this.  */
   7312   bfd_target_unknown_flavour,
   7313   bfd_target_aout_flavour,
   7314   bfd_target_coff_flavour,
   7315   bfd_target_ecoff_flavour,
   7316   bfd_target_xcoff_flavour,
   7317   bfd_target_elf_flavour,
   7318   bfd_target_tekhex_flavour,
   7319   bfd_target_srec_flavour,
   7320   bfd_target_verilog_flavour,
   7321   bfd_target_ihex_flavour,
   7322   bfd_target_som_flavour,
   7323   bfd_target_os9k_flavour,
   7324   bfd_target_versados_flavour,
   7325   bfd_target_msdos_flavour,
   7326   bfd_target_ovax_flavour,
   7327   bfd_target_evax_flavour,
   7328   bfd_target_mmo_flavour,
   7329   bfd_target_mach_o_flavour,
   7330   bfd_target_pef_flavour,
   7331   bfd_target_pef_xlib_flavour,
   7332   bfd_target_sym_flavour
   7333 };
   7334 
   7335 enum bfd_endian { BFD_ENDIAN_BIG, BFD_ENDIAN_LITTLE, BFD_ENDIAN_UNKNOWN };
   7336 
   7337 /* Forward declaration.  */
   7338 typedef struct bfd_link_info _bfd_link_info;
   7339 
   7340 /* Forward declaration.  */
   7341 typedef struct flag_info flag_info;
   7342 
   7343 typedef void (*bfd_cleanup) (bfd *);
   7344 
   7345 typedef struct bfd_target
   7346 {
   7347   /* Identifies the kind of target, e.g., SunOS4, Ultrix, etc.  */
   7348   const char *name;
   7349 
   7350  /* The "flavour" of a back end is a general indication about
   7351     the contents of a file.  */
   7352   enum bfd_flavour flavour;
   7353 
   7354   /* The order of bytes within the data area of a file.  */
   7355   enum bfd_endian byteorder;
   7356 
   7357  /* The order of bytes within the header parts of a file.  */
   7358   enum bfd_endian header_byteorder;
   7359 
   7360   /* A mask of all the flags which an executable may have set -
   7361      from the set <<BFD_NO_FLAGS>>, <<HAS_RELOC>>, ...<<D_PAGED>>.  */
   7362   flagword object_flags;
   7363 
   7364  /* A mask of all the flags which a section may have set - from
   7365     the set <<SEC_NO_FLAGS>>, <<SEC_ALLOC>>, ...<<SET_NEVER_LOAD>>.  */
   7366   flagword section_flags;
   7367 
   7368  /* The character normally found at the front of a symbol.
   7369     (if any), perhaps `_'.  */
   7370   char symbol_leading_char;
   7371 
   7372  /* The pad character for file names within an archive header.  */
   7373   char ar_pad_char;
   7374 
   7375   /* The maximum number of characters in an archive header.  */
   7376   unsigned char ar_max_namelen;
   7377 
   7378   /* How well this target matches, used to select between various
   7379      possible targets when more than one target matches.  */
   7380   unsigned char match_priority;
   7381 
   7382  /* TRUE if unused section symbols should be kept.  */
   7383   bool keep_unused_section_symbols;
   7384 
   7385   /* Entries for byte swapping for data. These are different from the
   7386      other entry points, since they don't take a BFD as the first argument.
   7387      Certain other handlers could do the same.  */
   7388   uint64_t       (*bfd_getx64) (const void *);
   7389   int64_t        (*bfd_getx_signed_64) (const void *);
   7390   void           (*bfd_putx64) (uint64_t, void *);
   7391   bfd_vma        (*bfd_getx32) (const void *);
   7392   bfd_signed_vma (*bfd_getx_signed_32) (const void *);
   7393   void           (*bfd_putx32) (bfd_vma, void *);
   7394   bfd_vma        (*bfd_getx16) (const void *);
   7395   bfd_signed_vma (*bfd_getx_signed_16) (const void *);
   7396   void           (*bfd_putx16) (bfd_vma, void *);
   7397 
   7398   /* Byte swapping for the headers.  */
   7399   uint64_t       (*bfd_h_getx64) (const void *);
   7400   int64_t        (*bfd_h_getx_signed_64) (const void *);
   7401   void           (*bfd_h_putx64) (uint64_t, void *);
   7402   bfd_vma        (*bfd_h_getx32) (const void *);
   7403   bfd_signed_vma (*bfd_h_getx_signed_32) (const void *);
   7404   void           (*bfd_h_putx32) (bfd_vma, void *);
   7405   bfd_vma        (*bfd_h_getx16) (const void *);
   7406   bfd_signed_vma (*bfd_h_getx_signed_16) (const void *);
   7407   void           (*bfd_h_putx16) (bfd_vma, void *);
   7408 
   7409   /* Format dependent routines: these are vectors of entry points
   7410      within the target vector structure, one for each format to check.  */
   7411 
   7412   /* Check the format of a file being read.  Return a <<bfd_cleanup>> on
   7413      success or zero on failure.  */
   7414   bfd_cleanup (*_bfd_check_format[bfd_type_end]) (bfd *);
   7415 
   7416   /* Set the format of a file being written.  */
   7417   bool (*_bfd_set_format[bfd_type_end]) (bfd *);
   7418 
   7419   /* Write cached information into a file being written, at <<bfd_close>>.  */
   7420   bool (*_bfd_write_contents[bfd_type_end]) (bfd *);
   7421 
   7422 
   7423   /* Generic entry points.  */
   7424 #define BFD_JUMP_TABLE_GENERIC(NAME) \
   7425   NAME##_close_and_cleanup, \
   7426   NAME##_bfd_free_cached_info, \
   7427   NAME##_new_section_hook, \
   7428   NAME##_get_section_contents, \
   7429   NAME##_get_section_contents_in_window
   7430 
   7431   /* Called when the BFD is being closed to do any necessary cleanup.  */
   7432   bool (*_close_and_cleanup) (bfd *);
   7433   /* Ask the BFD to free all cached information.  */
   7434   bool (*_bfd_free_cached_info) (bfd *);
   7435   /* Called when a new section is created.  */
   7436   bool (*_new_section_hook) (bfd *, sec_ptr);
   7437   /* Read the contents of a section.  */
   7438   bool (*_bfd_get_section_contents) (bfd *, sec_ptr, void *, file_ptr,
   7439                                      bfd_size_type);
   7440   bool (*_bfd_get_section_contents_in_window) (bfd *, sec_ptr, bfd_window *,
   7441                                                file_ptr, bfd_size_type);
   7442 
   7443   /* Entry points to copy private data.  */
   7444 #define BFD_JUMP_TABLE_COPY(NAME) \
   7445   NAME##_bfd_copy_private_bfd_data, \
   7446   NAME##_bfd_merge_private_bfd_data, \
   7447   _bfd_generic_init_private_section_data, \
   7448   NAME##_bfd_copy_private_section_data, \
   7449   NAME##_bfd_copy_private_symbol_data, \
   7450   NAME##_bfd_copy_private_header_data, \
   7451   NAME##_bfd_set_private_flags, \
   7452   NAME##_bfd_print_private_bfd_data
   7453 
   7454   /* Called to copy BFD general private data from one object file
   7455      to another.  */
   7456   bool (*_bfd_copy_private_bfd_data) (bfd *, bfd *);
   7457   /* Called to merge BFD general private data from one object file
   7458      to a common output file when linking.  */
   7459   bool (*_bfd_merge_private_bfd_data) (bfd *, struct bfd_link_info *);
   7460   /* Called to initialize BFD private section data from one object file
   7461      to another.  */
   7462 #define bfd_init_private_section_data(ibfd, isec, obfd, osec, link_info) \
   7463        BFD_SEND (obfd, _bfd_init_private_section_data, \
   7464                  (ibfd, isec, obfd, osec, link_info))
   7465   bool (*_bfd_init_private_section_data) (bfd *, sec_ptr, bfd *, sec_ptr,
   7466                                           struct bfd_link_info *);
   7467   /* Called to copy BFD private section data from one object file
   7468      to another.  */
   7469   bool (*_bfd_copy_private_section_data) (bfd *, sec_ptr, bfd *, sec_ptr);
   7470   /* Called to copy BFD private symbol data from one symbol
   7471      to another.  */
   7472   bool (*_bfd_copy_private_symbol_data) (bfd *, asymbol *,
   7473                                          bfd *, asymbol *);
   7474   /* Called to copy BFD private header data from one object file
   7475      to another.  */
   7476   bool (*_bfd_copy_private_header_data) (bfd *, bfd *);
   7477   /* Called to set private backend flags.  */
   7478   bool (*_bfd_set_private_flags) (bfd *, flagword);
   7479 
   7480   /* Called to print private BFD data.  */
   7481   bool (*_bfd_print_private_bfd_data) (bfd *, void *);
   7482 
   7483   /* Core file entry points.  */
   7484 #define BFD_JUMP_TABLE_CORE(NAME) \
   7485   NAME##_core_file_failing_command, \
   7486   NAME##_core_file_failing_signal, \
   7487   NAME##_core_file_matches_executable_p, \
   7488   NAME##_core_file_pid
   7489 
   7490   char *(*_core_file_failing_command) (bfd *);
   7491   int   (*_core_file_failing_signal) (bfd *);
   7492   bool  (*_core_file_matches_executable_p) (bfd *, bfd *);
   7493   int   (*_core_file_pid) (bfd *);
   7494 
   7495   /* Archive entry points.  */
   7496 #define BFD_JUMP_TABLE_ARCHIVE(NAME) \
   7497   NAME##_slurp_armap, \
   7498   NAME##_slurp_extended_name_table, \
   7499   NAME##_construct_extended_name_table, \
   7500   NAME##_truncate_arname, \
   7501   NAME##_write_armap, \
   7502   NAME##_read_ar_hdr, \
   7503   NAME##_write_ar_hdr, \
   7504   NAME##_openr_next_archived_file, \
   7505   NAME##_get_elt_at_index, \
   7506   NAME##_generic_stat_arch_elt, \
   7507   NAME##_update_armap_timestamp
   7508 
   7509   bool (*_bfd_slurp_armap) (bfd *);
   7510   bool (*_bfd_slurp_extended_name_table) (bfd *);
   7511   bool (*_bfd_construct_extended_name_table) (bfd *, char **,
   7512                                               bfd_size_type *,
   7513                                               const char **);
   7514   void (*_bfd_truncate_arname) (bfd *, const char *, char *);
   7515   bool (*write_armap) (bfd *, unsigned, struct orl *, unsigned, int);
   7516   void *(*_bfd_read_ar_hdr_fn) (bfd *);
   7517   bool (*_bfd_write_ar_hdr_fn) (bfd *, bfd *);
   7518   bfd *(*openr_next_archived_file) (bfd *, bfd *);
   7519 #define bfd_get_elt_at_index(b,i) \
   7520        BFD_SEND (b, _bfd_get_elt_at_index, (b,i))
   7521   bfd *(*_bfd_get_elt_at_index) (bfd *, symindex);
   7522   int  (*_bfd_stat_arch_elt) (bfd *, struct stat *);
   7523   bool (*_bfd_update_armap_timestamp) (bfd *);
   7524 
   7525   /* Entry points used for symbols.  */
   7526 #define BFD_JUMP_TABLE_SYMBOLS(NAME) \
   7527   NAME##_get_symtab_upper_bound, \
   7528   NAME##_canonicalize_symtab, \
   7529   NAME##_make_empty_symbol, \
   7530   NAME##_print_symbol, \
   7531   NAME##_get_symbol_info, \
   7532   NAME##_get_symbol_version_string, \
   7533   NAME##_bfd_is_local_label_name, \
   7534   NAME##_bfd_is_target_special_symbol, \
   7535   NAME##_get_lineno, \
   7536   NAME##_find_nearest_line, \
   7537   NAME##_find_line, \
   7538   NAME##_find_inliner_info, \
   7539   NAME##_bfd_make_debug_symbol, \
   7540   NAME##_read_minisymbols, \
   7541   NAME##_minisymbol_to_symbol
   7542 
   7543   long (*_bfd_get_symtab_upper_bound) (bfd *);
   7544   long (*_bfd_canonicalize_symtab) (bfd *, struct bfd_symbol **);
   7545   struct bfd_symbol *
   7546        (*_bfd_make_empty_symbol) (bfd *);
   7547   void (*_bfd_print_symbol) (bfd *, void *, struct bfd_symbol *,
   7548                              bfd_print_symbol_type);
   7549 #define bfd_print_symbol(b,p,s,e) \
   7550        BFD_SEND (b, _bfd_print_symbol, (b,p,s,e))
   7551   void  (*_bfd_get_symbol_info) (bfd *, struct bfd_symbol *, symbol_info *);
   7552 #define bfd_get_symbol_info(b,p,e) \
   7553        BFD_SEND (b, _bfd_get_symbol_info, (b,p,e))
   7554   const char *
   7555        (*_bfd_get_symbol_version_string) (bfd *, struct bfd_symbol *,
   7556                                           bool, bool *);
   7557 #define bfd_get_symbol_version_string(b,s,p,h) \
   7558        BFD_SEND (b, _bfd_get_symbol_version_string, (b,s,p,h))
   7559   bool (*_bfd_is_local_label_name) (bfd *, const char *);
   7560   bool (*_bfd_is_target_special_symbol) (bfd *, asymbol *);
   7561   alent *
   7562        (*_get_lineno) (bfd *, struct bfd_symbol *);
   7563   bool (*_bfd_find_nearest_line) (bfd *, struct bfd_symbol **,
   7564                                   struct bfd_section *, bfd_vma,
   7565                                   const char **, const char **,
   7566                                   unsigned int *, unsigned int *);
   7567   bool (*_bfd_find_line) (bfd *, struct bfd_symbol **,
   7568                           struct bfd_symbol *, const char **,
   7569                           unsigned int *);
   7570   bool (*_bfd_find_inliner_info)
   7571     (bfd *, const char **, const char **, unsigned int *);
   7572  /* Back-door to allow format-aware applications to create debug symbols
   7573     while using BFD for everything else.  Currently used by the assembler
   7574     when creating COFF files.  */
   7575   asymbol *
   7576        (*_bfd_make_debug_symbol) (bfd *, void *, unsigned long size);
   7577 #define bfd_read_minisymbols(b, d, m, s) \
   7578        BFD_SEND (b, _read_minisymbols, (b, d, m, s))
   7579   long (*_read_minisymbols) (bfd *, bool, void **, unsigned int *);
   7580 #define bfd_minisymbol_to_symbol(b, d, m, f) \
   7581        BFD_SEND (b, _minisymbol_to_symbol, (b, d, m, f))
   7582   asymbol *
   7583        (*_minisymbol_to_symbol) (bfd *, bool, const void *, asymbol *);
   7584 
   7585   /* Routines for relocs.  */
   7586 #define BFD_JUMP_TABLE_RELOCS(NAME) \
   7587   NAME##_get_reloc_upper_bound, \
   7588   NAME##_canonicalize_reloc, \
   7589   NAME##_set_reloc, \
   7590   NAME##_bfd_reloc_type_lookup, \
   7591   NAME##_bfd_reloc_name_lookup
   7592 
   7593   long (*_get_reloc_upper_bound) (bfd *, sec_ptr);
   7594   long (*_bfd_canonicalize_reloc) (bfd *, sec_ptr, arelent **,
   7595                                    struct bfd_symbol **);
   7596   void (*_bfd_set_reloc) (bfd *, sec_ptr, arelent **, unsigned int);
   7597   /* See documentation on reloc types.  */
   7598   reloc_howto_type *
   7599        (*reloc_type_lookup) (bfd *, bfd_reloc_code_real_type);
   7600   reloc_howto_type *
   7601        (*reloc_name_lookup) (bfd *, const char *);
   7602 
   7603   /* Routines used when writing an object file.  */
   7604 #define BFD_JUMP_TABLE_WRITE(NAME) \
   7605   NAME##_set_arch_mach, \
   7606   NAME##_set_section_contents
   7607 
   7608   bool (*_bfd_set_arch_mach) (bfd *, enum bfd_architecture,
   7609                                      unsigned long);
   7610   bool (*_bfd_set_section_contents) (bfd *, sec_ptr, const void *,
   7611                                      file_ptr, bfd_size_type);
   7612 
   7613   /* Routines used by the linker.  */
   7614 #define BFD_JUMP_TABLE_LINK(NAME) \
   7615   NAME##_sizeof_headers, \
   7616   NAME##_bfd_get_relocated_section_contents, \
   7617   NAME##_bfd_relax_section, \
   7618   NAME##_bfd_link_hash_table_create, \
   7619   NAME##_bfd_link_add_symbols, \
   7620   NAME##_bfd_link_just_syms, \
   7621   NAME##_bfd_copy_link_hash_symbol_type, \
   7622   NAME##_bfd_final_link, \
   7623   NAME##_bfd_link_split_section, \
   7624   NAME##_bfd_link_check_relocs, \
   7625   NAME##_bfd_gc_sections, \
   7626   NAME##_bfd_lookup_section_flags, \
   7627   NAME##_bfd_merge_sections, \
   7628   NAME##_bfd_is_group_section, \
   7629   NAME##_bfd_group_name, \
   7630   NAME##_bfd_discard_group, \
   7631   NAME##_section_already_linked, \
   7632   NAME##_bfd_define_common_symbol, \
   7633   NAME##_bfd_link_hide_symbol, \
   7634   NAME##_bfd_define_start_stop
   7635 
   7636   int  (*_bfd_sizeof_headers) (bfd *, struct bfd_link_info *);
   7637   bfd_byte *
   7638        (*_bfd_get_relocated_section_contents) (bfd *,
   7639                                                struct bfd_link_info *,
   7640                                                struct bfd_link_order *,
   7641                                                bfd_byte *, bool,
   7642                                                struct bfd_symbol **);
   7643 
   7644   bool (*_bfd_relax_section) (bfd *, struct bfd_section *,
   7645                               struct bfd_link_info *, bool *);
   7646 
   7647   /* Create a hash table for the linker.  Different backends store
   7648      different information in this table.  */
   7649   struct bfd_link_hash_table *
   7650        (*_bfd_link_hash_table_create) (bfd *);
   7651 
   7652   /* Add symbols from this object file into the hash table.  */
   7653   bool (*_bfd_link_add_symbols) (bfd *, struct bfd_link_info *);
   7654 
   7655   /* Indicate that we are only retrieving symbol values from this section.  */
   7656   void (*_bfd_link_just_syms) (asection *, struct bfd_link_info *);
   7657 
   7658   /* Copy the symbol type and other attributes for a linker script
   7659      assignment of one symbol to another.  */
   7660 #define bfd_copy_link_hash_symbol_type(b, t, f) \
   7661        BFD_SEND (b, _bfd_copy_link_hash_symbol_type, (b, t, f))
   7662   void (*_bfd_copy_link_hash_symbol_type) (bfd *,
   7663                                            struct bfd_link_hash_entry *,
   7664                                            struct bfd_link_hash_entry *);
   7665 
   7666   /* Do a link based on the link_order structures attached to each
   7667      section of the BFD.  */
   7668   bool (*_bfd_final_link) (bfd *, struct bfd_link_info *);
   7669 
   7670   /* Should this section be split up into smaller pieces during linking.  */
   7671   bool (*_bfd_link_split_section) (bfd *, struct bfd_section *);
   7672 
   7673   /* Check the relocations in the bfd for validity.  */
   7674   bool (* _bfd_link_check_relocs)(bfd *, struct bfd_link_info *);
   7675 
   7676   /* Remove sections that are not referenced from the output.  */
   7677   bool (*_bfd_gc_sections) (bfd *, struct bfd_link_info *);
   7678 
   7679   /* Sets the bitmask of allowed and disallowed section flags.  */
   7680   bool (*_bfd_lookup_section_flags) (struct bfd_link_info *,
   7681                                      struct flag_info *, asection *);
   7682 
   7683   /* Attempt to merge SEC_MERGE sections.  */
   7684   bool (*_bfd_merge_sections) (bfd *, struct bfd_link_info *);
   7685 
   7686   /* Is this section a member of a group?  */
   7687   bool (*_bfd_is_group_section) (bfd *, const struct bfd_section *);
   7688 
   7689   /* The group name, if section is a member of a group.  */
   7690   const char *(*_bfd_group_name) (bfd *, const struct bfd_section *);
   7691 
   7692   /* Discard members of a group.  */
   7693   bool (*_bfd_discard_group) (bfd *, struct bfd_section *);
   7694 
   7695   /* Check if SEC has been already linked during a reloceatable or
   7696      final link.  */
   7697   bool (*_section_already_linked) (bfd *, asection *,
   7698                                    struct bfd_link_info *);
   7699 
   7700   /* Define a common symbol.  */
   7701   bool (*_bfd_define_common_symbol) (bfd *, struct bfd_link_info *,
   7702                                      struct bfd_link_hash_entry *);
   7703 
   7704   /* Hide a symbol.  */
   7705   void (*_bfd_link_hide_symbol) (bfd *, struct bfd_link_info *,
   7706                                  struct bfd_link_hash_entry *);
   7707 
   7708   /* Define a __start, __stop, .startof. or .sizeof. symbol.  */
   7709   struct bfd_link_hash_entry *
   7710        (*_bfd_define_start_stop) (struct bfd_link_info *, const char *,
   7711                                   asection *);
   7712 
   7713   /* Routines to handle dynamic symbols and relocs.  */
   7714 #define BFD_JUMP_TABLE_DYNAMIC(NAME) \
   7715   NAME##_get_dynamic_symtab_upper_bound, \
   7716   NAME##_canonicalize_dynamic_symtab, \
   7717   NAME##_get_synthetic_symtab, \
   7718   NAME##_get_dynamic_reloc_upper_bound, \
   7719   NAME##_canonicalize_dynamic_reloc
   7720 
   7721   /* Get the amount of memory required to hold the dynamic symbols.  */
   7722   long (*_bfd_get_dynamic_symtab_upper_bound) (bfd *);
   7723   /* Read in the dynamic symbols.  */
   7724   long (*_bfd_canonicalize_dynamic_symtab) (bfd *, struct bfd_symbol **);
   7725   /* Create synthetized symbols.  */
   7726   long (*_bfd_get_synthetic_symtab) (bfd *, long, struct bfd_symbol **,
   7727                                      long, struct bfd_symbol **,
   7728                                      struct bfd_symbol **);
   7729   /* Get the amount of memory required to hold the dynamic relocs.  */
   7730   long (*_bfd_get_dynamic_reloc_upper_bound) (bfd *);
   7731   /* Read in the dynamic relocs.  */
   7732   long (*_bfd_canonicalize_dynamic_reloc) (bfd *, arelent **,
   7733                                            struct bfd_symbol **);
   7734 
   7735   /* Opposite endian version of this target.  */
   7736   const struct bfd_target *alternative_target;
   7737 
   7738   /* Data for use by back-end routines, which isn't
   7739      generic enough to belong in this structure.  */
   7740   const void *backend_data;
   7741 
   7742 } bfd_target;
   7743 
   7744 static inline const char *
   7745 bfd_get_target (const bfd *abfd)
   7746 {
   7747   return abfd->xvec->name;
   7748 }
   7749 
   7750 static inline enum bfd_flavour
   7751 bfd_get_flavour (const bfd *abfd)
   7752 {
   7753   return abfd->xvec->flavour;
   7754 }
   7755 
   7756 static inline flagword
   7757 bfd_applicable_file_flags (const bfd *abfd)
   7758 {
   7759   return abfd->xvec->object_flags;
   7760 }
   7761 
   7762 static inline bool
   7763 bfd_family_coff (const bfd *abfd)
   7764 {
   7765   return (bfd_get_flavour (abfd) == bfd_target_coff_flavour
   7766           || bfd_get_flavour (abfd) == bfd_target_xcoff_flavour);
   7767 }
   7768 
   7769 static inline bool
   7770 bfd_big_endian (const bfd *abfd)
   7771 {
   7772   return abfd->xvec->byteorder == BFD_ENDIAN_BIG;
   7773 }
   7774 static inline bool
   7775 bfd_little_endian (const bfd *abfd)
   7776 {
   7777   return abfd->xvec->byteorder == BFD_ENDIAN_LITTLE;
   7778 }
   7779 
   7780 static inline bool
   7781 bfd_header_big_endian (const bfd *abfd)
   7782 {
   7783   return abfd->xvec->header_byteorder == BFD_ENDIAN_BIG;
   7784 }
   7785 
   7786 static inline bool
   7787 bfd_header_little_endian (const bfd *abfd)
   7788 {
   7789   return abfd->xvec->header_byteorder == BFD_ENDIAN_LITTLE;
   7790 }
   7791 
   7792 static inline flagword
   7793 bfd_applicable_section_flags (const bfd *abfd)
   7794 {
   7795   return abfd->xvec->section_flags;
   7796 }
   7797 
   7798 static inline char
   7799 bfd_get_symbol_leading_char (const bfd *abfd)
   7800 {
   7801   return abfd->xvec->symbol_leading_char;
   7802 }
   7803 
   7804 static inline enum bfd_flavour
   7805 bfd_asymbol_flavour (const asymbol *sy)
   7806 {
   7807   if ((sy->flags & BSF_SYNTHETIC) != 0)
   7808     return bfd_target_unknown_flavour;
   7809   return sy->the_bfd->xvec->flavour;
   7810 }
   7811 
   7812 static inline bool
   7813 bfd_keep_unused_section_symbols (const bfd *abfd)
   7814 {
   7815   return abfd->xvec->keep_unused_section_symbols;
   7816 }
   7817 
   7818 bool bfd_set_default_target (const char *name);
   7819 
   7820 const bfd_target *bfd_find_target (const char *target_name, bfd *abfd);
   7821 
   7822 const bfd_target *bfd_get_target_info (const char *target_name,
   7823     bfd *abfd,
   7824     bool *is_bigendian,
   7825     int *underscoring,
   7826     const char **def_target_arch);
   7827 const char ** bfd_target_list (void);
   7828 
   7829 const bfd_target *bfd_iterate_over_targets
   7830    (int (*func) (const bfd_target *, void *),
   7831     void *data);
   7832 
   7833 const char *bfd_flavour_name (enum bfd_flavour flavour);
   7834 
   7835 /* Extracted from format.c.  */
   7836 bool bfd_check_format (bfd *abfd, bfd_format format);
   7837 
   7838 bool bfd_check_format_matches
   7839    (bfd *abfd, bfd_format format, char ***matching);
   7840 
   7841 bool bfd_set_format (bfd *abfd, bfd_format format);
   7842 
   7843 const char *bfd_format_string (bfd_format format);
   7844 
   7845 /* Extracted from linker.c.  */
   7846 /* Return TRUE if the symbol described by a linker hash entry H
   7847    is going to be absolute.  Linker-script defined symbols can be
   7848    converted from absolute to section-relative ones late in the
   7849    link.  Use this macro to correctly determine whether the symbol
   7850    will actually end up absolute in output.  */
   7851 #define bfd_is_abs_symbol(H) \
   7852   (((H)->type == bfd_link_hash_defined \
   7853     || (H)->type == bfd_link_hash_defweak) \
   7854    && bfd_is_abs_section ((H)->u.def.section) \
   7855    && !(H)->rel_from_abs)
   7856 
   7857 bool bfd_link_split_section (bfd *abfd, asection *sec);
   7858 
   7859 #define bfd_link_split_section(abfd, sec) \
   7860        BFD_SEND (abfd, _bfd_link_split_section, (abfd, sec))
   7861 
   7862 bool bfd_section_already_linked (bfd *abfd,
   7863     asection *sec,
   7864     struct bfd_link_info *info);
   7865 
   7866 #define bfd_section_already_linked(abfd, sec, info) \
   7867        BFD_SEND (abfd, _section_already_linked, (abfd, sec, info))
   7868 
   7869 bool bfd_generic_define_common_symbol
   7870    (bfd *output_bfd, struct bfd_link_info *info,
   7871     struct bfd_link_hash_entry *h);
   7872 
   7873 #define bfd_define_common_symbol(output_bfd, info, h) \
   7874        BFD_SEND (output_bfd, _bfd_define_common_symbol, (output_bfd, info, h))
   7875 
   7876 void _bfd_generic_link_hide_symbol
   7877    (bfd *output_bfd, struct bfd_link_info *info,
   7878     struct bfd_link_hash_entry *h);
   7879 
   7880 #define bfd_link_hide_symbol(output_bfd, info, h) \
   7881        BFD_SEND (output_bfd, _bfd_link_hide_symbol, (output_bfd, info, h))
   7882 
   7883 struct bfd_link_hash_entry *bfd_generic_define_start_stop
   7884    (struct bfd_link_info *info,
   7885     const char *symbol, asection *sec);
   7886 
   7887 #define bfd_define_start_stop(output_bfd, info, symbol, sec) \
   7888        BFD_SEND (output_bfd, _bfd_define_start_stop, (info, symbol, sec))
   7889 
   7890 struct bfd_elf_version_tree * bfd_find_version_for_sym
   7891    (struct bfd_elf_version_tree *verdefs,
   7892     const char *sym_name, bool *hide);
   7893 
   7894 bool bfd_hide_sym_by_version
   7895    (struct bfd_elf_version_tree *verdefs, const char *sym_name);
   7896 
   7897 bool bfd_link_check_relocs
   7898    (bfd *abfd, struct bfd_link_info *info);
   7899 
   7900 bool _bfd_generic_link_check_relocs
   7901    (bfd *abfd, struct bfd_link_info *info);
   7902 
   7903 bool bfd_merge_private_bfd_data
   7904    (bfd *ibfd, struct bfd_link_info *info);
   7905 
   7906 #define bfd_merge_private_bfd_data(ibfd, info) \
   7907        BFD_SEND ((info)->output_bfd, _bfd_merge_private_bfd_data, \
   7908                  (ibfd, info))
   7909 /* Extracted from simple.c.  */
   7910 bfd_byte *bfd_simple_get_relocated_section_contents
   7911    (bfd *abfd, asection *sec, bfd_byte *outbuf, asymbol **symbol_table);
   7912 
   7913 /* Extracted from compress.c.  */
   7914 bool bfd_get_full_section_contents
   7915    (bfd *abfd, asection *section, bfd_byte **ptr);
   7916 
   7917 void bfd_cache_section_contents
   7918    (asection *sec, void *contents);
   7919 
   7920 bool bfd_is_section_compressed_with_header
   7921    (bfd *abfd, asection *section,
   7922     int *compression_header_size_p,
   7923     bfd_size_type *uncompressed_size_p,
   7924     unsigned int *uncompressed_alignment_power_p);
   7925 
   7926 bool bfd_is_section_compressed
   7927    (bfd *abfd, asection *section);
   7928 
   7929 bool bfd_init_section_decompress_status
   7930    (bfd *abfd, asection *section);
   7931 
   7932 bool bfd_init_section_compress_status
   7933    (bfd *abfd, asection *section);
   7934 
   7935 bool bfd_compress_section
   7936    (bfd *abfd, asection *section, bfd_byte *uncompressed_buffer);
   7937 
   7938 #ifdef __cplusplus
   7939 }
   7940 #endif
   7941 #endif
   7942