Replace bfd_alloc/bfd_malloc + memset with bfd_zalloc/bfd_zmalloc
[platform/upstream/binutils.git] / bfd / coff64-rs6000.c
1 /* BFD back-end for IBM RS/6000 "XCOFF64" files.
2    Copyright 2000, 2001, 2002
3    Free Software Foundation, Inc.
4    Written Clinton Popetz.
5    Contributed by Cygnus Support.
6
7    This file is part of BFD, the Binary File Descriptor library.
8
9    This program is free software; you can redistribute it and/or modify
10    it under the terms of the GNU General Public License as published by
11    the Free Software Foundation; either version 2 of the License, or
12    (at your option) any later version.
13
14    This program is distributed in the hope that it will be useful,
15    but WITHOUT ANY WARRANTY; without even the implied warranty of
16    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17    GNU General Public License for more details.
18
19    You should have received a copy of the GNU General Public License
20    along with this program; if not, write to the Free Software
21    Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
22
23 #include "bfd.h"
24 #include "sysdep.h"
25 #include "bfdlink.h"
26 #include "libbfd.h"
27 #include "coff/internal.h"
28 #include "coff/xcoff.h"
29 #include "coff/rs6k64.h"
30 #include "libcoff.h"
31 #include "libxcoff.h"
32
33 #define GET_FILEHDR_SYMPTR H_GET_64
34 #define PUT_FILEHDR_SYMPTR H_PUT_64
35 #define GET_AOUTHDR_DATA_START H_GET_64
36 #define PUT_AOUTHDR_DATA_START H_PUT_64
37 #define GET_AOUTHDR_TEXT_START H_GET_64
38 #define PUT_AOUTHDR_TEXT_START H_PUT_64
39 #define GET_AOUTHDR_TSIZE H_GET_64
40 #define PUT_AOUTHDR_TSIZE H_PUT_64
41 #define GET_AOUTHDR_DSIZE H_GET_64
42 #define PUT_AOUTHDR_DSIZE H_PUT_64
43 #define GET_AOUTHDR_BSIZE H_GET_64
44 #define PUT_AOUTHDR_BSIZE H_PUT_64
45 #define GET_AOUTHDR_ENTRY H_GET_64
46 #define PUT_AOUTHDR_ENTRY H_PUT_64
47 #define GET_SCNHDR_PADDR H_GET_64
48 #define PUT_SCNHDR_PADDR H_PUT_64
49 #define GET_SCNHDR_VADDR H_GET_64
50 #define PUT_SCNHDR_VADDR H_PUT_64
51 #define GET_SCNHDR_SIZE H_GET_64
52 #define PUT_SCNHDR_SIZE H_PUT_64
53 #define GET_SCNHDR_SCNPTR H_GET_64
54 #define PUT_SCNHDR_SCNPTR H_PUT_64
55 #define GET_SCNHDR_RELPTR H_GET_64
56 #define PUT_SCNHDR_RELPTR H_PUT_64
57 #define GET_SCNHDR_LNNOPTR H_GET_64
58 #define PUT_SCNHDR_LNNOPTR H_PUT_64
59 #define GET_SCNHDR_NRELOC H_GET_32
60 #define MAX_SCNHDR_NRELOC 0xffffffff
61 #define PUT_SCNHDR_NRELOC H_PUT_32
62 #define GET_SCNHDR_NLNNO H_GET_32
63 #define MAX_SCNHDR_NLNNO 0xffffffff
64 #define PUT_SCNHDR_NLNNO H_PUT_32
65 #define GET_RELOC_VADDR H_GET_64
66 #define PUT_RELOC_VADDR H_PUT_64
67
68 #define COFF_FORCE_SYMBOLS_IN_STRINGS
69 #define COFF_DEBUG_STRING_WIDE_PREFIX
70
71
72 #define COFF_ADJUST_SCNHDR_OUT_POST(ABFD, INT, EXT)                     \
73   do                                                                    \
74     {                                                                   \
75       memset (((SCNHDR *) EXT)->s_pad, 0,                               \
76               sizeof (((SCNHDR *) EXT)->s_pad));                        \
77     }                                                                   \
78   while (0)
79
80 #define NO_COFF_LINENOS
81
82 #define coff_SWAP_lineno_in _bfd_xcoff64_swap_lineno_in
83 #define coff_SWAP_lineno_out _bfd_xcoff64_swap_lineno_out
84
85 static void _bfd_xcoff64_swap_lineno_in PARAMS ((bfd *, PTR, PTR));
86 static unsigned int _bfd_xcoff64_swap_lineno_out PARAMS ((bfd *, PTR, PTR));
87 static boolean _bfd_xcoff64_put_symbol_name
88   PARAMS ((bfd *, struct bfd_strtab_hash *, struct internal_syment *,
89            const char *));
90 static boolean _bfd_xcoff64_put_ldsymbol_name
91   PARAMS ((bfd *, struct xcoff_loader_info *, struct internal_ldsym *,
92            const char *));
93 static void _bfd_xcoff64_swap_sym_in PARAMS ((bfd *, PTR, PTR));
94 static unsigned int _bfd_xcoff64_swap_sym_out PARAMS ((bfd *, PTR, PTR));
95 static void _bfd_xcoff64_swap_aux_in
96   PARAMS ((bfd *, PTR, int, int, int, int, PTR));
97 static unsigned int _bfd_xcoff64_swap_aux_out
98   PARAMS ((bfd *, PTR, int, int, int, int, PTR));
99 static void xcoff64_swap_reloc_in PARAMS ((bfd *, PTR, PTR));
100 static unsigned int xcoff64_swap_reloc_out PARAMS ((bfd *, PTR, PTR));
101 extern boolean _bfd_xcoff_mkobject PARAMS ((bfd *));
102 extern boolean _bfd_xcoff_copy_private_bfd_data PARAMS ((bfd *, bfd *));
103 extern boolean _bfd_xcoff_is_local_label_name PARAMS ((bfd *, const char *));
104 extern void xcoff64_rtype2howto
105   PARAMS ((arelent *, struct internal_reloc *));
106 extern reloc_howto_type * xcoff64_reloc_type_lookup
107   PARAMS ((bfd *, bfd_reloc_code_real_type));
108 extern boolean _bfd_xcoff_slurp_armap PARAMS ((bfd *));
109 extern PTR _bfd_xcoff_read_ar_hdr PARAMS ((bfd *));
110 extern bfd *_bfd_xcoff_openr_next_archived_file PARAMS ((bfd *, bfd *));
111 extern int _bfd_xcoff_stat_arch_elt PARAMS ((bfd *, struct stat *));
112 extern boolean _bfd_xcoff_write_armap
113   PARAMS ((bfd *, unsigned int, struct orl *, unsigned int, int));
114 extern boolean _bfd_xcoff_write_archive_contents PARAMS ((bfd *));
115 extern int _bfd_xcoff_sizeof_headers PARAMS ((bfd *, boolean));
116 extern void _bfd_xcoff_swap_sym_in PARAMS ((bfd *, PTR, PTR));
117 extern unsigned int _bfd_xcoff_swap_sym_out PARAMS ((bfd *, PTR, PTR));
118 extern void _bfd_xcoff_swap_aux_in
119   PARAMS ((bfd *, PTR, int, int, int, int, PTR));
120 extern unsigned int _bfd_xcoff_swap_aux_out
121   PARAMS ((bfd *, PTR, int, int, int, int, PTR));
122 static void xcoff64_swap_ldhdr_in
123   PARAMS ((bfd *, const PTR, struct internal_ldhdr *));
124 static void xcoff64_swap_ldhdr_out
125   PARAMS ((bfd *, const struct internal_ldhdr *, PTR d));
126 static void xcoff64_swap_ldsym_in
127   PARAMS ((bfd *, const PTR, struct internal_ldsym *));
128 static void xcoff64_swap_ldsym_out
129   PARAMS ((bfd *, const struct internal_ldsym *, PTR d));
130 static void xcoff64_swap_ldrel_in
131   PARAMS ((bfd *, const PTR, struct internal_ldrel *));
132 static void xcoff64_swap_ldrel_out
133   PARAMS ((bfd *, const struct internal_ldrel *, PTR d));
134 static boolean xcoff64_write_object_contents PARAMS ((bfd *));
135 static boolean xcoff64_ppc_relocate_section
136   PARAMS ((bfd *, struct bfd_link_info *, bfd *, asection *, bfd_byte *,
137            struct internal_reloc *, struct internal_syment *,
138            asection **));
139 static boolean xcoff64_slurp_armap PARAMS ((bfd *));
140 static const bfd_target *xcoff64_archive_p PARAMS ((bfd *));
141 static bfd *xcoff64_openr_next_archived_file PARAMS ((bfd *, bfd *));
142 static int xcoff64_sizeof_headers PARAMS ((bfd *, boolean));
143 static asection *xcoff64_create_csect_from_smclas
144   PARAMS ((bfd *, union internal_auxent *, const char *));
145 static boolean xcoff64_is_lineno_count_overflow PARAMS ((bfd *, bfd_vma));
146 static boolean xcoff64_is_reloc_count_overflow PARAMS ((bfd *, bfd_vma));
147 static bfd_vma xcoff64_loader_symbol_offset
148   PARAMS ((bfd *, struct internal_ldhdr *));
149 static bfd_vma xcoff64_loader_reloc_offset
150   PARAMS ((bfd *, struct internal_ldhdr *));
151 static boolean xcoff64_generate_rtinit
152   PARAMS ((bfd *, const char *, const char *, boolean));
153 static boolean xcoff64_bad_format_hook PARAMS ((bfd *, PTR ));
154
155 /* Relocation functions */
156 static boolean xcoff64_reloc_type_br PARAMS ((XCOFF_RELOC_FUNCTION_ARGS));
157
158 boolean (*xcoff64_calculate_relocation[XCOFF_MAX_CALCULATE_RELOCATION])
159      (XCOFF_RELOC_FUNCTION_ARGS) =
160 {
161   xcoff_reloc_type_pos,  /* R_POS   (0x00) */
162   xcoff_reloc_type_neg,  /* R_NEG   (0x01) */
163   xcoff_reloc_type_rel,  /* R_REL   (0x02) */
164   xcoff_reloc_type_toc,  /* R_TOC   (0x03) */
165   xcoff_reloc_type_fail, /* R_RTB   (0x04) */
166   xcoff_reloc_type_toc,  /* R_GL    (0x05) */
167   xcoff_reloc_type_toc,  /* R_TCL   (0x06) */
168   xcoff_reloc_type_fail, /*         (0x07) */
169   xcoff_reloc_type_ba,   /* R_BA    (0x08) */
170   xcoff_reloc_type_fail, /*         (0x09) */
171   xcoff64_reloc_type_br, /* R_BR    (0x0a) */
172   xcoff_reloc_type_fail, /*         (0x0b) */
173   xcoff_reloc_type_pos,  /* R_RL    (0x0c) */
174   xcoff_reloc_type_pos,  /* R_RLA   (0x0d) */
175   xcoff_reloc_type_fail, /*         (0x0e) */
176   xcoff_reloc_type_noop, /* R_REF   (0x0f) */
177   xcoff_reloc_type_fail, /*         (0x10) */
178   xcoff_reloc_type_fail, /*         (0x11) */
179   xcoff_reloc_type_toc,  /* R_TRL   (0x12) */
180   xcoff_reloc_type_toc,  /* R_TRLA  (0x13) */
181   xcoff_reloc_type_fail, /* R_RRTBI (0x14) */
182   xcoff_reloc_type_fail, /* R_RRTBA (0x15) */
183   xcoff_reloc_type_ba,   /* R_CAI   (0x16) */
184   xcoff_reloc_type_crel, /* R_CREL  (0x17) */
185   xcoff_reloc_type_ba,   /* R_RBA   (0x18) */
186   xcoff_reloc_type_ba,   /* R_RBAC  (0x19) */
187   xcoff64_reloc_type_br, /* R_RBR   (0x1a) */
188   xcoff_reloc_type_ba,   /* R_RBRC  (0x1b) */
189 };
190
191 /* coffcode.h needs these to be defined.  */
192 /* Internalcoff.h and coffcode.h modify themselves based on these flags.  */
193 #define XCOFF64
194 #define RS6000COFF_C 1
195
196 #define SELECT_RELOC(internal, howto)                                   \
197   {                                                                     \
198     internal.r_type = howto->type;                                      \
199     internal.r_size =                                                   \
200       ((howto->complain_on_overflow == complain_overflow_signed         \
201         ? 0x80                                                          \
202         : 0)                                                            \
203        | (howto->bitsize - 1));                                         \
204   }
205
206 #define COFF_DEFAULT_SECTION_ALIGNMENT_POWER (3)
207 #define COFF_LONG_FILENAMES
208 #define NO_COFF_SYMBOLS
209 #define RTYPE2HOWTO(cache_ptr, dst) xcoff64_rtype2howto (cache_ptr, dst)
210 #define coff_mkobject _bfd_xcoff_mkobject
211 #define coff_bfd_copy_private_bfd_data _bfd_xcoff_copy_private_bfd_data
212 #define coff_bfd_is_local_label_name _bfd_xcoff_is_local_label_name
213 #define coff_bfd_reloc_type_lookup xcoff64_reloc_type_lookup
214 #ifdef AIX_CORE
215 extern const bfd_target * rs6000coff_core_p PARAMS ((bfd *abfd));
216 extern boolean rs6000coff_core_file_matches_executable_p
217   PARAMS((bfd *cbfd, bfd *ebfd));
218 extern char *rs6000coff_core_file_failing_command PARAMS ((bfd *abfd));
219 extern int rs6000coff_core_file_failing_signal PARAMS ((bfd *abfd));
220 #define CORE_FILE_P rs6000coff_core_p
221 #define coff_core_file_failing_command \
222   rs6000coff_core_file_failing_command
223 #define coff_core_file_failing_signal \
224   rs6000coff_core_file_failing_signal
225 #define coff_core_file_matches_executable_p \
226   rs6000coff_core_file_matches_executable_p
227 #else
228 #define CORE_FILE_P _bfd_dummy_target
229 #define coff_core_file_failing_command \
230   _bfd_nocore_core_file_failing_command
231 #define coff_core_file_failing_signal \
232   _bfd_nocore_core_file_failing_signal
233 #define coff_core_file_matches_executable_p \
234   _bfd_nocore_core_file_matches_executable_p
235 #endif
236 #define coff_SWAP_sym_in _bfd_xcoff64_swap_sym_in
237 #define coff_SWAP_sym_out _bfd_xcoff64_swap_sym_out
238 #define coff_SWAP_aux_in _bfd_xcoff64_swap_aux_in
239 #define coff_SWAP_aux_out _bfd_xcoff64_swap_aux_out
240 #define coff_swap_reloc_in xcoff64_swap_reloc_in
241 #define coff_swap_reloc_out xcoff64_swap_reloc_out
242 #define NO_COFF_RELOCS
243
244 #include "coffcode.h"
245
246 /* For XCOFF64, the effective width of symndx changes depending on
247    whether we are the first entry.  Sigh.  */
248 static void
249 _bfd_xcoff64_swap_lineno_in (abfd, ext1, in1)
250      bfd *abfd;
251      PTR ext1;
252      PTR in1;
253 {
254   LINENO *ext = (LINENO *) ext1;
255   struct internal_lineno *in = (struct internal_lineno *) in1;
256
257   in->l_lnno = H_GET_32 (abfd, (ext->l_lnno));
258   if (in->l_lnno == 0)
259     in->l_addr.l_symndx = H_GET_32 (abfd, ext->l_addr.l_symndx);
260   else
261     in->l_addr.l_paddr = H_GET_64 (abfd, ext->l_addr.l_paddr);
262 }
263
264 static unsigned int
265 _bfd_xcoff64_swap_lineno_out (abfd, inp, outp)
266      bfd *abfd;
267      PTR inp;
268      PTR outp;
269 {
270   struct internal_lineno *in = (struct internal_lineno *) inp;
271   struct external_lineno *ext = (struct external_lineno *) outp;
272
273   H_PUT_32 (abfd, in->l_addr.l_symndx, ext->l_addr.l_symndx);
274   H_PUT_32 (abfd, in->l_lnno, (ext->l_lnno));
275
276   if (in->l_lnno == 0)
277     H_PUT_32 (abfd, in->l_addr.l_symndx, ext->l_addr.l_symndx);
278   else
279     H_PUT_64 (abfd, in->l_addr.l_paddr, ext->l_addr.l_paddr);
280
281   return bfd_coff_linesz (abfd);
282 }
283
284 static void
285 _bfd_xcoff64_swap_sym_in (abfd, ext1, in1)
286      bfd *abfd;
287      PTR ext1;
288      PTR in1;
289 {
290   struct external_syment *ext = (struct external_syment *) ext1;
291   struct internal_syment *in = (struct internal_syment *) in1;
292
293   in->_n._n_n._n_zeroes = 0;
294   in->_n._n_n._n_offset = H_GET_32 (abfd, ext->e_offset);
295   in->n_value = H_GET_64 (abfd, ext->e_value);
296   in->n_scnum = H_GET_16 (abfd, ext->e_scnum);
297   in->n_type = H_GET_16 (abfd, ext->e_type);
298   in->n_sclass = H_GET_8 (abfd, ext->e_sclass);
299   in->n_numaux = H_GET_8 (abfd, ext->e_numaux);
300 }
301
302 static unsigned int
303 _bfd_xcoff64_swap_sym_out (abfd, inp, extp)
304      bfd *abfd;
305      PTR inp;
306      PTR extp;
307 {
308   struct internal_syment *in = (struct internal_syment *) inp;
309   struct external_syment *ext = (struct external_syment *) extp;
310
311   H_PUT_32 (abfd, in->_n._n_n._n_offset, ext->e_offset);
312   H_PUT_64 (abfd, in->n_value, ext->e_value);
313   H_PUT_16 (abfd, in->n_scnum, ext->e_scnum);
314   H_PUT_16 (abfd, in->n_type, ext->e_type);
315   H_PUT_8 (abfd, in->n_sclass, ext->e_sclass);
316   H_PUT_8 (abfd, in->n_numaux, ext->e_numaux);
317   return bfd_coff_symesz (abfd);
318 }
319
320 static void
321 _bfd_xcoff64_swap_aux_in (abfd, ext1, type, class, indx, numaux, in1)
322      bfd *abfd;
323      PTR ext1;
324      int type;
325      int class;
326      int indx;
327      int numaux;
328      PTR in1;
329 {
330   union external_auxent *ext = (union external_auxent *) ext1;
331   union internal_auxent *in = (union internal_auxent *) in1;
332
333   switch (class)
334     {
335     case C_FILE:
336       if (ext->x_file.x_n.x_zeroes[0] == 0)
337         {
338           in->x_file.x_n.x_zeroes = 0;
339           in->x_file.x_n.x_offset = H_GET_32 (abfd, ext->x_file.x_n.x_offset);
340         }
341       else
342         {
343           memcpy (in->x_file.x_fname, ext->x_file.x_fname, FILNMLEN);
344         }
345       goto end;
346
347       /* RS/6000 "csect" auxents */
348     case C_EXT:
349     case C_HIDEXT:
350       if (indx + 1 == numaux)
351         {
352           bfd_signed_vma h = 0;
353           bfd_vma l = 0;
354
355           h = H_GET_S32 (abfd, ext->x_csect.x_scnlen_hi);
356           l = H_GET_32 (abfd, ext->x_csect.x_scnlen_lo);
357
358           in->x_csect.x_scnlen.l = h << 32 | (l & 0xffffffff);
359
360           in->x_csect.x_parmhash = H_GET_32 (abfd, ext->x_csect.x_parmhash);
361           in->x_csect.x_snhash = H_GET_16 (abfd, ext->x_csect.x_snhash);
362           /* We don't have to hack bitfields in x_smtyp because it's
363              defined by shifts-and-ands, which are equivalent on all
364              byte orders.  */
365           in->x_csect.x_smtyp = H_GET_8 (abfd, ext->x_csect.x_smtyp);
366           in->x_csect.x_smclas = H_GET_8 (abfd, ext->x_csect.x_smclas);
367           goto end;
368         }
369       break;
370
371     case C_STAT:
372     case C_LEAFSTAT:
373     case C_HIDDEN:
374       if (type == T_NULL)
375         {
376           /* PE defines some extra fields; we zero them out for
377              safety.  */
378           in->x_scn.x_checksum = 0;
379           in->x_scn.x_associated = 0;
380           in->x_scn.x_comdat = 0;
381
382           goto end;
383         }
384       break;
385     }
386
387   if (class == C_BLOCK || class == C_FCN || ISFCN (type) || ISTAG (class))
388     {
389       in->x_sym.x_fcnary.x_fcn.x_lnnoptr
390         = H_GET_64 (abfd, ext->x_sym.x_fcnary.x_fcn.x_lnnoptr);
391       in->x_sym.x_fcnary.x_fcn.x_endndx.l
392         = H_GET_32 (abfd, ext->x_sym.x_fcnary.x_fcn.x_endndx);
393     }
394   if (ISFCN (type))
395     {
396       in->x_sym.x_misc.x_fsize
397         = H_GET_32 (abfd, ext->x_sym.x_fcnary.x_fcn.x_fsize);
398     }
399   else
400     {
401       in->x_sym.x_misc.x_lnsz.x_lnno
402         = H_GET_32 (abfd, ext->x_sym.x_fcnary.x_lnsz.x_lnno);
403       in->x_sym.x_misc.x_lnsz.x_size
404         = H_GET_16 (abfd, ext->x_sym.x_fcnary.x_lnsz.x_size);
405     }
406
407  end: ;
408 }
409
410 static unsigned int
411 _bfd_xcoff64_swap_aux_out (abfd, inp, type, class, indx, numaux, extp)
412      bfd *abfd;
413      PTR inp;
414      int type;
415      int class;
416      int indx ATTRIBUTE_UNUSED;
417      int numaux ATTRIBUTE_UNUSED;
418      PTR extp;
419 {
420   union internal_auxent *in = (union internal_auxent *) inp;
421   union external_auxent *ext = (union external_auxent *) extp;
422
423   memset ((PTR) ext, 0, bfd_coff_auxesz (abfd));
424   switch (class)
425     {
426     case C_FILE:
427       if (in->x_file.x_n.x_zeroes == 0)
428         {
429           H_PUT_32 (abfd, 0, ext->x_file.x_n.x_zeroes);
430           H_PUT_32 (abfd, in->x_file.x_n.x_offset, ext->x_file.x_n.x_offset);
431         }
432       else
433         {
434           memcpy (ext->x_file.x_fname, in->x_file.x_fname, FILNMLEN);
435         }
436       H_PUT_8 (abfd, _AUX_FILE, ext->x_auxtype.x_auxtype);
437       goto end;
438
439       /* RS/6000 "csect" auxents */
440     case C_EXT:
441     case C_HIDEXT:
442       if (indx + 1 == numaux)
443         {
444           bfd_vma temp;
445
446           temp = in->x_csect.x_scnlen.l & 0xffffffff;
447           H_PUT_32 (abfd, temp, ext->x_csect.x_scnlen_lo);
448           temp = in->x_csect.x_scnlen.l >> 32;
449           H_PUT_32 (abfd, temp, ext->x_csect.x_scnlen_hi);
450           H_PUT_32 (abfd, in->x_csect.x_parmhash, ext->x_csect.x_parmhash);
451           H_PUT_16 (abfd, in->x_csect.x_snhash, ext->x_csect.x_snhash);
452           /* We don't have to hack bitfields in x_smtyp because it's
453              defined by shifts-and-ands, which are equivalent on all
454              byte orders.  */
455           H_PUT_8 (abfd, in->x_csect.x_smtyp, ext->x_csect.x_smtyp);
456           H_PUT_8 (abfd, in->x_csect.x_smclas, ext->x_csect.x_smclas);
457           H_PUT_8 (abfd, _AUX_CSECT, ext->x_auxtype.x_auxtype);
458           goto end;
459         }
460       break;
461
462     case C_STAT:
463     case C_LEAFSTAT:
464     case C_HIDDEN:
465       if (type == T_NULL)
466         {
467           goto end;
468         }
469       break;
470     }
471
472   if (class == C_BLOCK || class == C_FCN || ISFCN (type) || ISTAG (class))
473     {
474       H_PUT_64 (abfd, in->x_sym.x_fcnary.x_fcn.x_lnnoptr,
475                ext->x_sym.x_fcnary.x_fcn.x_lnnoptr);
476       H_PUT_8 (abfd, _AUX_FCN,
477                ext->x_auxtype.x_auxtype);
478       H_PUT_32 (abfd, in->x_sym.x_fcnary.x_fcn.x_endndx.l,
479                ext->x_sym.x_fcnary.x_fcn.x_endndx);
480     }
481   if (ISFCN (type))
482     {
483       H_PUT_32 (abfd, in->x_sym.x_misc.x_fsize,
484                ext->x_sym.x_fcnary.x_fcn.x_fsize);
485     }
486   else
487     {
488       H_PUT_32 (abfd, in->x_sym.x_misc.x_lnsz.x_lnno,
489                ext->x_sym.x_fcnary.x_lnsz.x_lnno);
490       H_PUT_16 (abfd, in->x_sym.x_misc.x_lnsz.x_size,
491                ext->x_sym.x_fcnary.x_lnsz.x_size);
492     }
493
494  end:
495
496   return bfd_coff_auxesz (abfd);
497 }
498
499 static boolean
500 _bfd_xcoff64_put_symbol_name (abfd, strtab, sym, name)
501      bfd *abfd;
502      struct bfd_strtab_hash *strtab;
503      struct internal_syment *sym;
504      const char *name;
505 {
506   boolean hash;
507   bfd_size_type indx;
508
509   hash = true;
510
511   if ((abfd->flags & BFD_TRADITIONAL_FORMAT) != 0)
512     hash = false;
513
514   indx = _bfd_stringtab_add (strtab, name, hash, false);
515
516   if (indx == (bfd_size_type) -1)
517     return false;
518
519   sym->_n._n_n._n_zeroes = 0;
520   sym->_n._n_n._n_offset = STRING_SIZE_SIZE + indx;
521
522   return true;
523 }
524
525 static boolean
526 _bfd_xcoff64_put_ldsymbol_name (abfd, ldinfo, ldsym, name)
527      bfd *abfd ATTRIBUTE_UNUSED;
528      struct xcoff_loader_info *ldinfo;
529      struct internal_ldsym *ldsym;
530      const char *name;
531 {
532   size_t len;
533   len = strlen (name);
534
535   if (ldinfo->string_size + len + 3 > ldinfo->string_alc)
536     {
537       bfd_size_type newalc;
538       bfd_byte *newstrings;
539
540       newalc = ldinfo->string_alc * 2;
541       if (newalc == 0)
542         newalc = 32;
543       while (ldinfo->string_size + len + 3 > newalc)
544         newalc *= 2;
545
546       newstrings = ((bfd_byte *)
547                     bfd_realloc ((PTR) ldinfo->strings, newalc));
548       if (newstrings == NULL)
549         {
550           ldinfo->failed = true;
551           return false;
552         }
553       ldinfo->string_alc = newalc;
554       ldinfo->strings = newstrings;
555     }
556
557   bfd_put_16 (ldinfo->output_bfd, (bfd_vma) (len + 1),
558               ldinfo->strings + ldinfo->string_size);
559   strcpy (ldinfo->strings + ldinfo->string_size + 2, name);
560   ldsym->_l._l_l._l_zeroes = 0;
561   ldsym->_l._l_l._l_offset = ldinfo->string_size + 2;
562   ldinfo->string_size += len + 3;
563
564   return true;
565 }
566
567 /* Routines to swap information in the XCOFF .loader section.  If we
568    ever need to write an XCOFF loader, this stuff will need to be
569    moved to another file shared by the linker (which XCOFF calls the
570    ``binder'') and the loader.  */
571
572 /* Swap in the ldhdr structure.  */
573
574 static void
575 xcoff64_swap_ldhdr_in (abfd, s, dst)
576      bfd *abfd;
577      const PTR s;
578      struct internal_ldhdr *dst;
579 {
580   const struct external_ldhdr *src = (const struct external_ldhdr *) s;
581
582   dst->l_version = bfd_get_32 (abfd, src->l_version);
583   dst->l_nsyms = bfd_get_32 (abfd, src->l_nsyms);
584   dst->l_nreloc = bfd_get_32 (abfd, src->l_nreloc);
585   dst->l_istlen = bfd_get_32 (abfd, src->l_istlen);
586   dst->l_nimpid = bfd_get_32 (abfd, src->l_nimpid);
587   dst->l_stlen = bfd_get_32 (abfd, src->l_stlen);
588   dst->l_impoff = bfd_get_64 (abfd, src->l_impoff);
589   dst->l_stoff = bfd_get_64 (abfd, src->l_stoff);
590   dst->l_symoff = bfd_get_64 (abfd, src->l_symoff);
591   dst->l_rldoff = bfd_get_64 (abfd, src->l_rldoff);
592 }
593
594 /* Swap out the ldhdr structure.  */
595
596 static void
597 xcoff64_swap_ldhdr_out (abfd, src, d)
598      bfd *abfd;
599      const struct internal_ldhdr *src;
600      PTR d;
601 {
602   struct external_ldhdr *dst = (struct external_ldhdr *) d;
603
604   bfd_put_32 (abfd, (bfd_vma) src->l_version, dst->l_version);
605   bfd_put_32 (abfd, src->l_nsyms, dst->l_nsyms);
606   bfd_put_32 (abfd, src->l_nreloc, dst->l_nreloc);
607   bfd_put_32 (abfd, src->l_istlen, dst->l_istlen);
608   bfd_put_32 (abfd, src->l_nimpid, dst->l_nimpid);
609   bfd_put_32 (abfd, src->l_stlen, dst->l_stlen);
610   bfd_put_64 (abfd, src->l_impoff, dst->l_impoff);
611   bfd_put_64 (abfd, src->l_stoff, dst->l_stoff);
612   bfd_put_64 (abfd, src->l_symoff, dst->l_symoff);
613   bfd_put_64 (abfd, src->l_rldoff, dst->l_rldoff);
614 }
615
616 /* Swap in the ldsym structure.  */
617
618 static void
619 xcoff64_swap_ldsym_in (abfd, s, dst)
620      bfd *abfd;
621      const PTR s;
622      struct internal_ldsym *dst;
623 {
624   const struct external_ldsym *src = (const struct external_ldsym *) s;
625   /* XCOFF64 does not use l_zeroes like XCOFF32
626      Set the internal l_zeroes to 0 so the common 32/64 code uses l_value
627      as an offset into the loader symbol table.  */
628   dst->_l._l_l._l_zeroes = 0;
629   dst->_l._l_l._l_offset = bfd_get_32 (abfd, src->l_offset);
630   dst->l_value = bfd_get_64 (abfd, src->l_value);
631   dst->l_scnum = bfd_get_16 (abfd, src->l_scnum);
632   dst->l_smtype = bfd_get_8 (abfd, src->l_smtype);
633   dst->l_smclas = bfd_get_8 (abfd, src->l_smclas);
634   dst->l_ifile = bfd_get_32 (abfd, src->l_ifile);
635   dst->l_parm = bfd_get_32 (abfd, src->l_parm);
636 }
637
638 /* Swap out the ldsym structure.  */
639
640 static void
641 xcoff64_swap_ldsym_out (abfd, src, d)
642      bfd *abfd;
643      const struct internal_ldsym *src;
644      PTR d;
645 {
646   struct external_ldsym *dst = (struct external_ldsym *) d;
647
648   bfd_put_64 (abfd, src->l_value, dst->l_value);
649   bfd_put_32 (abfd, (bfd_vma) src->_l._l_l._l_offset, dst->l_offset);
650   bfd_put_16 (abfd, (bfd_vma) src->l_scnum, dst->l_scnum);
651   bfd_put_8 (abfd, src->l_smtype, dst->l_smtype);
652   bfd_put_8 (abfd, src->l_smclas, dst->l_smclas);
653   bfd_put_32 (abfd, src->l_ifile, dst->l_ifile);
654   bfd_put_32 (abfd, src->l_parm, dst->l_parm);
655 }
656
657 static void
658 xcoff64_swap_reloc_in (abfd, s, d)
659      bfd *abfd;
660      PTR s;
661      PTR d;
662 {
663   struct external_reloc *src = (struct external_reloc *) s;
664   struct internal_reloc *dst = (struct internal_reloc *) d;
665
666   memset (dst, 0, sizeof (struct internal_reloc));
667
668   dst->r_vaddr = bfd_get_64 (abfd, src->r_vaddr);
669   dst->r_symndx = bfd_get_32 (abfd, src->r_symndx);
670   dst->r_size = bfd_get_8 (abfd, src->r_size);
671   dst->r_type = bfd_get_8 (abfd, src->r_type);
672 }
673
674 static unsigned int
675 xcoff64_swap_reloc_out (abfd, s, d)
676      bfd *abfd;
677      PTR s;
678      PTR d;
679 {
680   struct internal_reloc *src = (struct internal_reloc *) s;
681   struct external_reloc *dst = (struct external_reloc *) d;
682
683   bfd_put_64 (abfd, src->r_vaddr, dst->r_vaddr);
684   bfd_put_32 (abfd, src->r_symndx, dst->r_symndx);
685   bfd_put_8 (abfd, src->r_type, dst->r_type);
686   bfd_put_8 (abfd, src->r_size, dst->r_size);
687
688   return bfd_coff_relsz (abfd);
689 }
690
691 /* Swap in the ldrel structure.  */
692
693 static void
694 xcoff64_swap_ldrel_in (abfd, s, dst)
695      bfd *abfd;
696      const PTR s;
697      struct internal_ldrel *dst;
698 {
699   const struct external_ldrel *src = (const struct external_ldrel *) s;
700
701   dst->l_vaddr = bfd_get_64 (abfd, src->l_vaddr);
702   dst->l_symndx = bfd_get_32 (abfd, src->l_symndx);
703   dst->l_rtype = bfd_get_16 (abfd, src->l_rtype);
704   dst->l_rsecnm = bfd_get_16 (abfd, src->l_rsecnm);
705 }
706
707 /* Swap out the ldrel structure.  */
708
709 static void
710 xcoff64_swap_ldrel_out (abfd, src, d)
711      bfd *abfd;
712      const struct internal_ldrel *src;
713      PTR d;
714 {
715   struct external_ldrel *dst = (struct external_ldrel *) d;
716
717   bfd_put_64 (abfd, src->l_vaddr, dst->l_vaddr);
718   bfd_put_16 (abfd, (bfd_vma) src->l_rtype, dst->l_rtype);
719   bfd_put_16 (abfd, (bfd_vma) src->l_rsecnm, dst->l_rsecnm);
720   bfd_put_32 (abfd, src->l_symndx, dst->l_symndx);
721 }
722
723 static boolean
724 xcoff64_write_object_contents (abfd)
725      bfd * abfd;
726 {
727   asection *current;
728   boolean hasrelocs = false;
729   boolean haslinno = false;
730   file_ptr scn_base;
731   file_ptr reloc_base;
732   file_ptr lineno_base;
733   file_ptr sym_base;
734   unsigned long reloc_size = 0;
735   unsigned long lnno_size = 0;
736   boolean long_section_names;
737   asection *text_sec = ((void *) 0);
738   asection *data_sec = ((void *) 0);
739   asection *bss_sec = ((void *) 0);
740   struct internal_filehdr internal_f;
741   struct internal_aouthdr internal_a;
742
743   bfd_set_error (bfd_error_system_call);
744
745   if (abfd->output_has_begun == false)
746     {
747       if (! bfd_coff_compute_section_file_positions (abfd))
748         return false;
749     }
750
751   /* Work out the size of the reloc and linno areas.  */
752   reloc_base = obj_relocbase (abfd);
753
754   for (current = abfd->sections; current != NULL; current = current->next)
755     reloc_size += current->reloc_count * bfd_coff_relsz (abfd);
756
757   lineno_base = reloc_base + reloc_size;
758
759   /* Make a pass through the symbol table to count line number entries and
760      put them into the correct asections.  */
761   lnno_size = coff_count_linenumbers (abfd) * bfd_coff_linesz (abfd);
762
763   sym_base = lineno_base + lnno_size;
764
765   /* Indicate in each section->line_filepos its actual file address.  */
766   for (current = abfd->sections; current != NULL; current =  current->next)
767     {
768       if (current->lineno_count)
769         {
770           current->line_filepos = lineno_base;
771           current->moving_line_filepos = lineno_base;
772           lineno_base += current->lineno_count * bfd_coff_linesz (abfd);
773         }
774       else
775         {
776           current->line_filepos = 0;
777         }
778
779       if (current->reloc_count)
780         {
781           current->rel_filepos = reloc_base;
782           reloc_base += current->reloc_count * bfd_coff_relsz (abfd);
783         }
784       else
785         {
786           current->rel_filepos = 0;
787         }
788     }
789
790   if ((abfd->flags & EXEC_P) != 0)
791     {
792       scn_base = bfd_coff_filhsz (abfd) + bfd_coff_aoutsz (abfd);
793       internal_f.f_opthdr = bfd_coff_aoutsz (abfd);
794     }
795   else
796     {
797       scn_base = bfd_coff_filhsz (abfd);
798       internal_f.f_opthdr = 0;
799     }
800
801   internal_f.f_nscns = 0;
802
803   if (bfd_seek (abfd, scn_base, SEEK_SET) != 0)
804     return false;
805
806   long_section_names = false;
807   for (current = abfd->sections; current != NULL; current = current->next)
808     {
809       struct internal_scnhdr section;
810       struct external_scnhdr buff;
811       bfd_size_type amount;
812
813       internal_f.f_nscns++;
814
815       strncpy (section.s_name, current->name, SCNNMLEN);
816
817       section.s_vaddr = current->vma;
818       section.s_paddr = current->lma;
819       section.s_size =  current->_raw_size;
820
821       /* If this section has no size or is unloadable then the scnptr
822          will be 0 too.  */
823       if (current->_raw_size == 0
824           || (current->flags & (SEC_LOAD | SEC_HAS_CONTENTS)) == 0)
825         {
826           section.s_scnptr = 0;
827         }
828       else
829         {
830           section.s_scnptr = current->filepos;
831         }
832
833       section.s_relptr = current->rel_filepos;
834       section.s_lnnoptr = current->line_filepos;
835       section.s_nreloc = current->reloc_count;
836
837       section.s_nlnno = current->lineno_count;
838       if (current->reloc_count != 0)
839         hasrelocs = true;
840       if (current->lineno_count != 0)
841         haslinno = true;
842
843       section.s_flags = sec_to_styp_flags (current->name, current->flags);
844
845       if (!strcmp (current->name, _TEXT))
846         {
847           text_sec = current;
848         }
849       else if (!strcmp (current->name, _DATA))
850         {
851           data_sec = current;
852         }
853       else if (!strcmp (current->name, _BSS))
854         {
855           bss_sec = current;
856         }
857
858       amount = bfd_coff_scnhsz (abfd);
859       if (bfd_coff_swap_scnhdr_out (abfd, &section, &buff) == 0
860           || bfd_bwrite ((PTR) (&buff), amount, abfd) != amount)
861         return false;
862     }
863
864   internal_f.f_timdat = 0;
865
866   internal_f.f_flags = 0;
867
868   if (!hasrelocs)
869     internal_f.f_flags |= F_RELFLG;
870   if (!haslinno)
871     internal_f.f_flags |= F_LNNO;
872   if (abfd->flags & EXEC_P)
873     internal_f.f_flags |= F_EXEC;
874
875   /* FIXME: this is wrong for PPC_PE!  */
876   if (bfd_little_endian (abfd))
877     internal_f.f_flags |= F_AR32WR;
878   else
879     internal_f.f_flags |= F_AR32W;
880
881   if ((abfd->flags & DYNAMIC) != 0)
882     internal_f.f_flags |= F_SHROBJ;
883   if (bfd_get_section_by_name (abfd, _LOADER) != NULL)
884     internal_f.f_flags |= F_DYNLOAD;
885
886   memset (&internal_a, 0, sizeof internal_a);
887
888   internal_f.f_magic = bfd_xcoff_magic_number (abfd);
889   internal_a.magic = (abfd->flags & D_PAGED) ? RS6K_AOUTHDR_ZMAGIC :
890     (abfd->flags & WP_TEXT) ? RS6K_AOUTHDR_NMAGIC :
891     RS6K_AOUTHDR_OMAGIC;
892
893   /* FIXME: Does anybody ever set this to another value?  */
894   internal_a.vstamp = 0;
895
896   /* Now should write relocs, strings, syms.  */
897   obj_sym_filepos (abfd) = sym_base;
898
899   internal_f.f_symptr = 0;
900   internal_f.f_nsyms = 0;
901
902   /* If bfd_get_symcount (abfd) != 0, then we are not using the COFF
903      backend linker, and obj_raw_syment_count is not valid until after
904      coff_write_symbols is called.  */
905   if (bfd_get_symcount (abfd) != 0)
906     {
907       int firstundef;
908
909       if (!coff_renumber_symbols (abfd, &firstundef))
910         return false;
911       coff_mangle_symbols (abfd);
912       if (! coff_write_symbols (abfd))
913         return false;
914       if (! coff_write_linenumbers (abfd))
915         return false;
916       if (! coff_write_relocs (abfd, firstundef))
917         return false;
918
919       internal_f.f_symptr = sym_base;
920       internal_f.f_nsyms = bfd_get_symcount (abfd);
921     }
922   else if (obj_raw_syment_count (abfd) != 0)
923     {
924       internal_f.f_symptr = sym_base;
925
926       /* AIX appears to require that F_RELFLG not be set if there are
927          local symbols but no relocations.  */
928       internal_f.f_flags &=~ F_RELFLG;
929     }
930   else
931     {
932       internal_f.f_flags |= F_LSYMS;
933     }
934
935   if (text_sec)
936     {
937       internal_a.tsize = bfd_get_section_size_before_reloc (text_sec);
938       internal_a.text_start = internal_a.tsize ? text_sec->vma : 0;
939     }
940
941   if (data_sec)
942     {
943       internal_a.dsize = bfd_get_section_size_before_reloc (data_sec);
944       internal_a.data_start = internal_a.dsize ? data_sec->vma : 0;
945     }
946
947   if (bss_sec)
948     {
949       internal_a.bsize = bfd_get_section_size_before_reloc (bss_sec);
950       if (internal_a.bsize && bss_sec->vma < internal_a.data_start)
951         internal_a.data_start = bss_sec->vma;
952     }
953
954   internal_a.entry = bfd_get_start_address (abfd);
955   internal_f.f_nsyms = obj_raw_syment_count (abfd);
956
957   if (xcoff_data (abfd)->full_aouthdr)
958     {
959       bfd_vma toc;
960       asection *loader_sec;
961
962       internal_a.vstamp = 1;
963
964       internal_a.o_snentry = xcoff_data (abfd)->snentry;
965       if (internal_a.o_snentry == 0)
966         internal_a.entry = (bfd_vma) -1;
967
968       if (text_sec != NULL)
969         {
970           internal_a.o_sntext = text_sec->target_index;
971           internal_a.o_algntext = bfd_get_section_alignment (abfd, text_sec);
972         }
973       else
974         {
975           internal_a.o_sntext = 0;
976           internal_a.o_algntext = 0;
977         }
978
979       if (data_sec != NULL)
980         {
981           internal_a.o_sndata = data_sec->target_index;
982           internal_a.o_algndata = bfd_get_section_alignment (abfd, data_sec);
983         }
984       else
985         {
986           internal_a.o_sndata = 0;
987           internal_a.o_algndata = 0;
988         }
989
990       loader_sec = bfd_get_section_by_name (abfd, ".loader");
991       if (loader_sec != NULL)
992         internal_a.o_snloader = loader_sec->target_index;
993       else
994         internal_a.o_snloader = 0;
995       if (bss_sec != NULL)
996         internal_a.o_snbss = bss_sec->target_index;
997       else
998         internal_a.o_snbss = 0;
999
1000       toc = xcoff_data (abfd)->toc;
1001       internal_a.o_toc = toc;
1002       internal_a.o_sntoc = xcoff_data (abfd)->sntoc;
1003
1004       internal_a.o_modtype = xcoff_data (abfd)->modtype;
1005       if (xcoff_data (abfd)->cputype != -1)
1006         internal_a.o_cputype = xcoff_data (abfd)->cputype;
1007       else
1008         {
1009           switch (bfd_get_arch (abfd))
1010             {
1011             case bfd_arch_rs6000:
1012               internal_a.o_cputype = 4;
1013               break;
1014             case bfd_arch_powerpc:
1015               if (bfd_get_mach (abfd) == 0)
1016                 internal_a.o_cputype = 3;
1017               else
1018                 internal_a.o_cputype = 1;
1019               break;
1020             default:
1021               abort ();
1022             }
1023         }
1024       internal_a.o_maxstack = xcoff_data (abfd)->maxstack;
1025       internal_a.o_maxdata = xcoff_data (abfd)->maxdata;
1026     }
1027
1028   if (bfd_seek (abfd, (file_ptr) 0, 0) != 0)
1029     return false;
1030
1031   {
1032     char * buff;
1033     bfd_size_type amount = bfd_coff_filhsz (abfd);
1034
1035     buff = bfd_malloc (amount);
1036     if (buff == NULL)
1037       return false;
1038
1039     bfd_coff_swap_filehdr_out (abfd, (PTR) &internal_f, (PTR) buff);
1040     amount = bfd_bwrite ((PTR) buff, amount, abfd);
1041
1042     free (buff);
1043
1044     if (amount != bfd_coff_filhsz (abfd))
1045       return false;
1046   }
1047
1048   if (abfd->flags & EXEC_P)
1049     {
1050       char * buff;
1051       bfd_size_type amount = bfd_coff_aoutsz (abfd);
1052
1053       buff = bfd_malloc (amount);
1054       if (buff == NULL)
1055         return false;
1056
1057       bfd_coff_swap_aouthdr_out (abfd, (PTR) & internal_a, (PTR) buff);
1058       amount = bfd_bwrite ((PTR) buff, amount, abfd);
1059
1060       free (buff);
1061
1062       if (amount != bfd_coff_aoutsz (abfd))
1063         return false;
1064     }
1065
1066   return true;
1067 }
1068
1069 static boolean 
1070 xcoff64_reloc_type_br (input_bfd, input_section, output_bfd, rel, sym, howto, 
1071                        val, addend, relocation, contents)
1072      bfd *input_bfd;
1073      asection *input_section;
1074      bfd *output_bfd ATTRIBUTE_UNUSED;
1075      struct internal_reloc *rel;
1076      struct internal_syment *sym ATTRIBUTE_UNUSED;
1077      struct reloc_howto_struct *howto;
1078      bfd_vma val;
1079      bfd_vma addend;
1080      bfd_vma *relocation;
1081      bfd_byte *contents;
1082 {
1083   struct xcoff_link_hash_entry *h;
1084
1085   if (0 > rel->r_symndx) 
1086     return false;
1087
1088   h = obj_xcoff_sym_hashes (input_bfd)[rel->r_symndx];
1089
1090   /* If we see an R_BR or R_RBR reloc which is jumping to global
1091      linkage code, and it is followed by an appropriate cror nop
1092      instruction, we replace the cror with ld r2,40(r1).  This
1093      restores the TOC after the glink code.  Contrariwise, if the
1094      call is followed by a ld r2,40(r1), but the call is not
1095      going to global linkage code, we can replace the load with a
1096      cror.  */
1097   if (NULL != h 
1098       && bfd_link_hash_defined == h->root.type 
1099       && (rel->r_vaddr - input_section->vma + 8 <= 
1100           input_section->_cooked_size)) 
1101     {
1102       bfd_byte *pnext;
1103       unsigned long next;
1104       
1105       pnext = contents + (rel->r_vaddr - input_section->vma) + 4;
1106       next = bfd_get_32 (input_bfd, pnext);
1107       
1108       /* The _ptrgl function is magic.  It is used by the AIX compiler to call 
1109          a function through a pointer.  */
1110       if (h->smclas == XMC_GL || strcmp (h->root.root.string, "._ptrgl") == 0) 
1111         {
1112           if (next == 0x4def7b82                       /* cror 15,15,15  */
1113               || next == 0x4ffffb82                    /* cror 31,31,31  */
1114               || next == 0x60000000)                   /* ori  r0,r0,0   */
1115             bfd_put_32 (input_bfd, 0xe8410028, pnext); /* ld   r2,40(r1) */
1116         } 
1117       else 
1118         {
1119           if (next == 0xe8410028)                      /* ld r2,40(r1)   */
1120             bfd_put_32 (input_bfd, 0x60000000, pnext); /* ori r0,r0,0    */
1121         }
1122     } 
1123   else if (NULL != h && bfd_link_hash_undefined == h->root.type) 
1124     {
1125       /* Normally, this relocation is against a defined symbol.  In the
1126          case where this is a partial link and the output section offset
1127          is greater than 2^25, the linker will return an invalid error 
1128          message that the relocation has been truncated.  Yes it has been
1129          truncated but no it not important.  For this case, disable the 
1130          overflow checking. */
1131       howto->complain_on_overflow = complain_overflow_dont;
1132     }
1133   
1134   howto->pc_relative = true;
1135   howto->src_mask &= ~3;
1136   howto->dst_mask = howto->src_mask;
1137   
1138   /* A PC relative reloc includes the section address.  */
1139   addend += input_section->vma;
1140   
1141   *relocation = val + addend;
1142   *relocation -= (input_section->output_section->vma + 
1143                   input_section->output_offset);
1144   return true;
1145 }
1146
1147 /* This is the relocation function for the PowerPC64.
1148    See xcoff_ppc_relocation_section for more information. */
1149
1150 boolean
1151 xcoff64_ppc_relocate_section (output_bfd, info, input_bfd,
1152                               input_section, contents, relocs, syms,
1153                               sections)
1154      bfd *output_bfd;
1155      struct bfd_link_info *info;
1156      bfd *input_bfd;
1157      asection *input_section;
1158      bfd_byte *contents;
1159      struct internal_reloc *relocs;
1160      struct internal_syment *syms;
1161      asection **sections;
1162 {
1163   struct internal_reloc *rel;
1164   struct internal_reloc *relend;
1165
1166   rel = relocs;
1167   relend = rel + input_section->reloc_count;
1168   for (; rel < relend; rel++)
1169     {
1170       long symndx;
1171       struct xcoff_link_hash_entry *h;
1172       struct internal_syment *sym;
1173       bfd_vma addend;
1174       bfd_vma val;
1175       struct reloc_howto_struct howto;
1176       bfd_vma relocation;
1177       bfd_vma value_to_relocate;
1178       bfd_vma address;
1179       bfd_byte *location;
1180
1181       /* Relocation type R_REF is a special relocation type which is
1182          merely used to prevent garbage collection from occurring for
1183          the csect including the symbol which it references.  */
1184       if (rel->r_type == R_REF)
1185         continue;
1186
1187       /* howto */
1188       howto.type = rel->r_type;
1189       howto.rightshift = 0;
1190       howto.bitsize = (rel->r_size & 0x3f) + 1;
1191       howto.size = howto.bitsize > 16 ? (howto.bitsize > 32 ? 4 : 2) : 1;
1192       howto.pc_relative = false;
1193       howto.bitpos = 0;
1194       howto.complain_on_overflow = rel->r_size & 0x80 ? 
1195         complain_overflow_signed : complain_overflow_bitfield;
1196       howto.special_function = NULL;
1197       howto.name = "internal";
1198       howto.partial_inplace = true;
1199       howto.src_mask = howto.dst_mask = N_ONES(howto.bitsize);
1200       howto.pcrel_offset = false;
1201
1202       /* symbol */
1203       val = 0;
1204       addend = 0;
1205       h = NULL;
1206       sym = NULL;
1207       symndx = rel->r_symndx;      
1208
1209       if (-1 != symndx) 
1210         {
1211           asection *sec;
1212           
1213           h = obj_xcoff_sym_hashes (input_bfd)[symndx];
1214           sym = syms + symndx;
1215           addend = - sym->n_value;
1216           
1217           if (NULL == h) 
1218             {
1219               sec = sections[symndx];
1220               /* Hack to make sure we use the right TOC anchor value
1221                  if this reloc is against the TOC anchor.  */
1222               if (sec->name[3] == '0'
1223                   && strcmp (sec->name, ".tc0") == 0)
1224                 val = xcoff_data (output_bfd)->toc;
1225               else
1226                 val = (sec->output_section->vma
1227                        + sec->output_offset
1228                        + sym->n_value
1229                        - sec->vma);
1230             } 
1231           else 
1232             {
1233               if (h->root.type == bfd_link_hash_defined 
1234                   || h->root.type == bfd_link_hash_defweak) 
1235                 {
1236                   sec = h->root.u.def.section;
1237                   val = (h->root.u.def.value
1238                          + sec->output_section->vma
1239                          + sec->output_offset);
1240                 } 
1241               else if (h->root.type == bfd_link_hash_common) 
1242                 {
1243                   sec = h->root.u.c.p->section;
1244                   val = (sec->output_section->vma
1245                          + sec->output_offset);
1246                 } 
1247               else if ((0 == (h->flags & (XCOFF_DEF_DYNAMIC | XCOFF_IMPORT))) 
1248                        && ! info->relocateable) 
1249                 {
1250                   if (! ((*info->callbacks->undefined_symbol)
1251                          (info, h->root.root.string, input_bfd, input_section,
1252                           rel->r_vaddr - input_section->vma, true)))
1253                     return false;
1254                   
1255                   /* Don't try to process the reloc.  It can't help, and
1256                      it may generate another error.  */
1257                   continue;
1258                 }
1259             }
1260         }
1261       
1262       if (rel->r_type >= XCOFF_MAX_CALCULATE_RELOCATION 
1263           || (false == xcoff64_calculate_relocation[rel->r_type]
1264               (input_bfd, input_section, output_bfd, rel, sym, &howto, val, 
1265                addend, &relocation, contents))) 
1266         return false;
1267       
1268       /* address */
1269       address = rel->r_vaddr - input_section->vma;
1270       location = contents + address;
1271       
1272       if (address > input_section->_raw_size)
1273         abort();
1274       
1275       /* Get the value we are going to relocate.  */
1276       if (1 == howto.size)
1277         value_to_relocate = bfd_get_16 (input_bfd, location);
1278       else if (2 == howto.size)
1279         value_to_relocate = bfd_get_32 (input_bfd, location);
1280       else 
1281         value_to_relocate = bfd_get_64 (input_bfd, location);
1282       
1283       /* overflow.  
1284          
1285          FIXME: We may drop bits during the addition
1286          which we don't check for.  We must either check at every single
1287          operation, which would be tedious, or we must do the computations
1288          in a type larger than bfd_vma, which would be inefficient.  */
1289       
1290       if ((unsigned int) howto.complain_on_overflow >= 
1291           XCOFF_MAX_COMPLAIN_OVERFLOW)
1292         abort();
1293       
1294       if ((true == xcoff_complain_overflow[howto.complain_on_overflow]
1295            (input_bfd, value_to_relocate, relocation, &howto))) 
1296         {
1297           const char *name;
1298           char buf[SYMNMLEN + 1];
1299           char reloc_type_name[10];
1300           
1301           if (symndx == -1) 
1302             {
1303               name = "*ABS*";
1304             } 
1305           else if (h != NULL) 
1306             {
1307               name = h->root.root.string;
1308             } 
1309           else 
1310             {
1311               name = _bfd_coff_internal_syment_name (input_bfd, sym, buf);
1312               if (name == NULL)
1313                 name = "UNKNOWN";
1314             }
1315           sprintf (reloc_type_name, "0x%02x", rel->r_type);
1316           
1317           if (! ((*info->callbacks->reloc_overflow)
1318                  (info, name, reloc_type_name, (bfd_vma) 0, input_bfd,
1319                   input_section, rel->r_vaddr - input_section->vma)))
1320             return false;
1321         }
1322
1323       /* Add RELOCATION to the right bits of VALUE_TO_RELOCATE.  */
1324       value_to_relocate = ((value_to_relocate & ~howto.dst_mask) | 
1325                            (((value_to_relocate & howto.src_mask) + 
1326                              relocation) & howto.dst_mask));
1327       
1328       /* Put the value back in the object file.  */
1329       if (1 == howto.size)
1330         bfd_put_16 (input_bfd, value_to_relocate, location);
1331       else if (2 == howto.size)
1332         bfd_put_32 (input_bfd, value_to_relocate, location);
1333       else
1334         bfd_put_64 (input_bfd, value_to_relocate, location);
1335       
1336     }
1337   return true;
1338 }
1339
1340 \f
1341 /* The XCOFF reloc table.  Actually, XCOFF relocations specify the
1342    bitsize and whether they are signed or not, along with a
1343    conventional type.  This table is for the types, which are used for
1344    different algorithms for putting in the reloc.  Many of these
1345    relocs need special_function entries, which I have not written.  */
1346
1347 reloc_howto_type xcoff64_howto_table[] =
1348 {
1349   /* Standard 64 bit relocation.  */
1350   HOWTO (R_POS,                 /* type */
1351          0,                     /* rightshift */
1352          4,                     /* size (0 = byte, 1 = short, 2 = long) */
1353          64,                    /* bitsize */
1354          false,                 /* pc_relative */
1355          0,                     /* bitpos */
1356          complain_overflow_bitfield, /* complain_on_overflow */
1357          0,                     /* special_function */
1358          "R_POS_64",            /* name */
1359          true,                  /* partial_inplace */
1360          MINUS_ONE,             /* src_mask */
1361          MINUS_ONE,             /* dst_mask */
1362          false),                /* pcrel_offset */
1363
1364   /* 64 bit relocation, but store negative value.  */
1365   HOWTO (R_NEG,                 /* type */
1366          0,                     /* rightshift */
1367          -4,                    /* size (0 = byte, 1 = short, 2 = long) */
1368          64,                    /* bitsize */
1369          false,                 /* pc_relative */
1370          0,                     /* bitpos */
1371          complain_overflow_bitfield, /* complain_on_overflow */
1372          0,                     /* special_function */
1373          "R_NEG",               /* name */
1374          true,                  /* partial_inplace */
1375          MINUS_ONE,             /* src_mask */
1376          MINUS_ONE,             /* dst_mask */
1377          false),                /* pcrel_offset */
1378
1379   /* 32 bit PC relative relocation.  */
1380   HOWTO (R_REL,                 /* type */
1381          0,                     /* rightshift */
1382          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1383          32,                    /* bitsize */
1384          true,                  /* pc_relative */
1385          0,                     /* bitpos */
1386          complain_overflow_signed, /* complain_on_overflow */
1387          0,                     /* special_function */
1388          "R_REL",               /* name */
1389          true,                  /* partial_inplace */
1390          0xffffffff,            /* src_mask */
1391          0xffffffff,            /* dst_mask */
1392          false),                /* pcrel_offset */
1393
1394   /* 16 bit TOC relative relocation.  */
1395   HOWTO (R_TOC,                 /* type */
1396          0,                     /* rightshift */
1397          1,                     /* size (0 = byte, 1 = short, 2 = long) */
1398          16,                    /* bitsize */
1399          false,                 /* pc_relative */
1400          0,                     /* bitpos */
1401          complain_overflow_bitfield, /* complain_on_overflow */
1402          0,                     /* special_function */
1403          "R_TOC",               /* name */
1404          true,                  /* partial_inplace */
1405          0xffff,                /* src_mask */
1406          0xffff,                /* dst_mask */
1407          false),                /* pcrel_offset */
1408
1409   /* I don't really know what this is.  */
1410   HOWTO (R_RTB,                 /* type */
1411          1,                     /* rightshift */
1412          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1413          32,                    /* bitsize */
1414          false,                 /* pc_relative */
1415          0,                     /* bitpos */
1416          complain_overflow_bitfield, /* complain_on_overflow */
1417          0,                     /* special_function */
1418          "R_RTB",               /* name */
1419          true,                  /* partial_inplace */
1420          0xffffffff,            /* src_mask */
1421          0xffffffff,            /* dst_mask */
1422          false),                /* pcrel_offset */
1423
1424   /* External TOC relative symbol.  */
1425   HOWTO (R_GL,                  /* type */
1426          0,                     /* rightshift */
1427          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1428          16,                    /* bitsize */
1429          false,                 /* pc_relative */
1430          0,                     /* bitpos */
1431          complain_overflow_bitfield, /* complain_on_overflow */
1432          0,                     /* special_function */
1433          "R_GL",                /* name */
1434          true,                  /* partial_inplace */
1435          0xffff,                /* src_mask */
1436          0xffff,                /* dst_mask */
1437          false),                /* pcrel_offset */
1438
1439   /* Local TOC relative symbol.  */
1440   HOWTO (R_TCL,                 /* type */
1441          0,                     /* rightshift */
1442          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1443          16,                    /* bitsize */
1444          false,                 /* pc_relative */
1445          0,                     /* bitpos */
1446          complain_overflow_bitfield, /* complain_on_overflow */
1447          0,                     /* special_function */
1448          "R_TCL",               /* name */
1449          true,                  /* partial_inplace */
1450          0xffff,                /* src_mask */
1451          0xffff,                /* dst_mask */
1452          false),                /* pcrel_offset */
1453
1454   EMPTY_HOWTO (7),
1455
1456   /* Non modifiable absolute branch.  */
1457   HOWTO (R_BA,                  /* type */
1458          0,                     /* rightshift */
1459          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1460          26,                    /* bitsize */
1461          false,                 /* pc_relative */
1462          0,                     /* bitpos */
1463          complain_overflow_bitfield, /* complain_on_overflow */
1464          0,                     /* special_function */
1465          "R_BA_26",             /* name */
1466          true,                  /* partial_inplace */
1467          0x3fffffc,             /* src_mask */
1468          0x3fffffc,             /* dst_mask */
1469          false),                /* pcrel_offset */
1470
1471   EMPTY_HOWTO (9),
1472
1473   /* Non modifiable relative branch.  */
1474   HOWTO (R_BR,                  /* type */
1475          0,                     /* rightshift */
1476          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1477          26,                    /* bitsize */
1478          true,                  /* pc_relative */
1479          0,                     /* bitpos */
1480          complain_overflow_signed, /* complain_on_overflow */
1481          0,                     /* special_function */
1482          "R_BR",                /* name */
1483          true,                  /* partial_inplace */
1484          0x3fffffc,             /* src_mask */
1485          0x3fffffc,             /* dst_mask */
1486          false),                /* pcrel_offset */
1487
1488   EMPTY_HOWTO (0xb),
1489
1490   /* Indirect load.  */
1491   HOWTO (R_RL,                  /* type */
1492          0,                     /* rightshift */
1493          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1494          16,                    /* bitsize */
1495          false,                 /* pc_relative */
1496          0,                     /* bitpos */
1497          complain_overflow_bitfield, /* complain_on_overflow */
1498          0,                     /* special_function */
1499          "R_RL",                /* name */
1500          true,                  /* partial_inplace */
1501          0xffff,                /* src_mask */
1502          0xffff,                /* dst_mask */
1503          false),                /* pcrel_offset */
1504
1505   /* Load address.  */
1506   HOWTO (R_RLA,                 /* type */
1507          0,                     /* rightshift */
1508          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1509          16,                    /* bitsize */
1510          false,                 /* pc_relative */
1511          0,                     /* bitpos */
1512          complain_overflow_bitfield, /* complain_on_overflow */
1513          0,                     /* special_function */
1514          "R_RLA",               /* name */
1515          true,                  /* partial_inplace */
1516          0xffff,                /* src_mask */
1517          0xffff,                /* dst_mask */
1518          false),                /* pcrel_offset */
1519
1520   EMPTY_HOWTO (0xe),
1521
1522   /* Non-relocating reference.  */
1523   HOWTO (R_REF,                 /* type */
1524          0,                     /* rightshift */
1525          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1526          32,                    /* bitsize */
1527          false,                 /* pc_relative */
1528          0,                     /* bitpos */
1529          complain_overflow_bitfield, /* complain_on_overflow */
1530          0,                     /* special_function */
1531          "R_REF",               /* name */
1532          false,                 /* partial_inplace */
1533          0,                     /* src_mask */
1534          0,                     /* dst_mask */
1535          false),                /* pcrel_offset */
1536
1537   EMPTY_HOWTO (0x10),
1538   EMPTY_HOWTO (0x11),
1539
1540   /* TOC relative indirect load.  */
1541   HOWTO (R_TRL,                 /* type */
1542          0,                     /* rightshift */
1543          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1544          16,                    /* bitsize */
1545          false,                 /* pc_relative */
1546          0,                     /* bitpos */
1547          complain_overflow_bitfield, /* complain_on_overflow */
1548          0,                     /* special_function */
1549          "R_TRL",               /* name */
1550          true,                  /* partial_inplace */
1551          0xffff,                /* src_mask */
1552          0xffff,                /* dst_mask */
1553          false),                /* pcrel_offset */
1554
1555   /* TOC relative load address.  */
1556   HOWTO (R_TRLA,                /* type */
1557          0,                     /* rightshift */
1558          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1559          16,                    /* bitsize */
1560          false,                 /* pc_relative */
1561          0,                     /* bitpos */
1562          complain_overflow_bitfield, /* complain_on_overflow */
1563          0,                     /* special_function */
1564          "R_TRLA",              /* name */
1565          true,                  /* partial_inplace */
1566          0xffff,                /* src_mask */
1567          0xffff,                /* dst_mask */
1568          false),                /* pcrel_offset */
1569
1570   /* Modifiable relative branch.  */
1571   HOWTO (R_RRTBI,               /* type */
1572          1,                     /* rightshift */
1573          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1574          32,                    /* bitsize */
1575          false,                 /* pc_relative */
1576          0,                     /* bitpos */
1577          complain_overflow_bitfield, /* complain_on_overflow */
1578          0,                     /* special_function */
1579          "R_RRTBI",             /* name */
1580          true,                  /* partial_inplace */
1581          0xffffffff,            /* src_mask */
1582          0xffffffff,            /* dst_mask */
1583          false),                /* pcrel_offset */
1584
1585   /* Modifiable absolute branch.  */
1586   HOWTO (R_RRTBA,               /* type */
1587          1,                     /* rightshift */
1588          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1589          32,                    /* bitsize */
1590          false,                 /* pc_relative */
1591          0,                     /* bitpos */
1592          complain_overflow_bitfield, /* complain_on_overflow */
1593          0,                     /* special_function */
1594          "R_RRTBA",             /* name */
1595          true,                  /* partial_inplace */
1596          0xffffffff,            /* src_mask */
1597          0xffffffff,            /* dst_mask */
1598          false),                /* pcrel_offset */
1599
1600   /* Modifiable call absolute indirect.  */
1601   HOWTO (R_CAI,                 /* type */
1602          0,                     /* rightshift */
1603          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1604          16,                    /* bitsize */
1605          false,                 /* pc_relative */
1606          0,                     /* bitpos */
1607          complain_overflow_bitfield, /* complain_on_overflow */
1608          0,                     /* special_function */
1609          "R_CAI",               /* name */
1610          true,                  /* partial_inplace */
1611          0xffff,                /* src_mask */
1612          0xffff,                /* dst_mask */
1613          false),                /* pcrel_offset */
1614
1615   /* Modifiable call relative.  */
1616   HOWTO (R_CREL,                /* type */
1617          0,                     /* rightshift */
1618          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1619          16,                    /* bitsize */
1620          false,                 /* pc_relative */
1621          0,                     /* bitpos */
1622          complain_overflow_bitfield, /* complain_on_overflow */
1623          0,                     /* special_function */
1624          "R_CREL",              /* name */
1625          true,                  /* partial_inplace */
1626          0xffff,                /* src_mask */
1627          0xffff,                /* dst_mask */
1628          false),                /* pcrel_offset */
1629
1630   /* Modifiable branch absolute.  */
1631   HOWTO (R_RBA,                 /* type */
1632          0,                     /* rightshift */
1633          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1634          26,                    /* bitsize */
1635          false,                 /* pc_relative */
1636          0,                     /* bitpos */
1637          complain_overflow_bitfield, /* complain_on_overflow */
1638          0,                     /* special_function */
1639          "R_RBA",               /* name */
1640          true,                  /* partial_inplace */
1641          0xffff,                /* src_mask */
1642          0xffff,                /* dst_mask */
1643          false),                /* pcrel_offset */
1644
1645   /* Modifiable branch absolute.  */
1646   HOWTO (R_RBAC,                /* type */
1647          0,                     /* rightshift */
1648          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1649          32,                    /* bitsize */
1650          false,                 /* pc_relative */
1651          0,                     /* bitpos */
1652          complain_overflow_bitfield, /* complain_on_overflow */
1653          0,                     /* special_function */
1654          "R_RBAC",              /* name */
1655          true,                  /* partial_inplace */
1656          0xffff,                /* src_mask */
1657          0xffff,                /* dst_mask */
1658          false),                /* pcrel_offset */
1659
1660   /* Modifiable branch relative.  */
1661   HOWTO (R_RBR,                 /* type */
1662          0,                     /* rightshift */
1663          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1664          26,                    /* bitsize */
1665          false,                 /* pc_relative */
1666          0,                     /* bitpos */
1667          complain_overflow_signed, /* complain_on_overflow */
1668          0,                     /* special_function */
1669          "R_RBR_26",            /* name */
1670          true,                  /* partial_inplace */
1671          0xffff,                /* src_mask */
1672          0xffff,                /* dst_mask */
1673          false),                /* pcrel_offset */
1674
1675   /* Modifiable branch absolute.  */
1676   HOWTO (R_RBRC,                /* type */
1677          0,                     /* rightshift */
1678          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1679          16,                    /* bitsize */
1680          false,                 /* pc_relative */
1681          0,                     /* bitpos */
1682          complain_overflow_bitfield, /* complain_on_overflow */
1683          0,                     /* special_function */
1684          "R_RBRC",              /* name */
1685          true,                  /* partial_inplace */
1686          0xffff,                /* src_mask */
1687          0xffff,                /* dst_mask */
1688          false),                /* pcrel_offset */
1689
1690   HOWTO (R_POS,                 /* type */
1691          0,                     /* rightshift */
1692          2,                     /* size (0 = byte, 1 = short, 2 = long) */
1693          32,                    /* bitsize */
1694          false,                 /* pc_relative */
1695          0,                     /* bitpos */
1696          complain_overflow_bitfield, /* complain_on_overflow */
1697          0,                     /* special_function */
1698          "R_POS_32",            /* name */
1699          true,                  /* partial_inplace */
1700          0xffffffff,            /* src_mask */
1701          0xffffffff,            /* dst_mask */
1702          false),                /* pcrel_offset */
1703
1704   /* 16 bit Non modifiable absolute branch.  */
1705   HOWTO (R_BA,                  /* type */
1706          0,                     /* rightshift */
1707          1,                     /* size (0 = byte, 1 = short, 2 = long) */
1708          16,                    /* bitsize */
1709          false,                 /* pc_relative */
1710          0,                     /* bitpos */
1711          complain_overflow_bitfield, /* complain_on_overflow */
1712          0,                     /* special_function */
1713          "R_BA_16",             /* name */
1714          true,                  /* partial_inplace */
1715          0xfffc,                /* src_mask */
1716          0xfffc,                /* dst_mask */
1717          false),                /* pcrel_offset */
1718
1719   /* Modifiable branch relative.  */
1720   HOWTO (R_RBR,                 /* type */
1721          0,                     /* rightshift */
1722          1,                     /* size (0 = byte, 1 = short, 2 = long) */
1723          16,                    /* bitsize */
1724          false,                 /* pc_relative */
1725          0,                     /* bitpos */
1726          complain_overflow_signed, /* complain_on_overflow */
1727          0,                     /* special_function */
1728          "R_RBR_16",            /* name */
1729          true,                  /* partial_inplace */
1730          0xffff,                /* src_mask */
1731          0xffff,                /* dst_mask */
1732          false),                /* pcrel_offset */
1733
1734   /* Modifiable branch absolute.  */
1735   HOWTO (R_RBA,                 /* type */
1736          0,                     /* rightshift */
1737          1,                     /* size (0 = byte, 1 = short, 2 = long) */
1738          16,                    /* bitsize */
1739          false,                 /* pc_relative */
1740          0,                     /* bitpos */
1741          complain_overflow_bitfield, /* complain_on_overflow */
1742          0,                     /* special_function */
1743          "R_RBA_16",            /* name */
1744          true,                  /* partial_inplace */
1745          0xffff,                /* src_mask */
1746          0xffff,                /* dst_mask */
1747          false),                /* pcrel_offset */
1748
1749 };
1750
1751 void
1752 xcoff64_rtype2howto (relent, internal)
1753      arelent *relent;
1754      struct internal_reloc *internal;
1755 {
1756   if (internal->r_type > R_RBRC)
1757     abort ();
1758
1759   /* Default howto layout works most of the time */
1760   relent->howto = &xcoff64_howto_table[internal->r_type];
1761   
1762   /* Special case some 16 bit reoloc */
1763   if (15 == (internal->r_size & 0x3f))
1764     {
1765       if (R_BA == internal->r_type) 
1766         relent->howto = &xcoff64_howto_table[0x1d];
1767       else if (R_RBR == internal->r_type) 
1768         relent->howto = &xcoff64_howto_table[0x1e];
1769       else if (R_RBA == internal->r_type) 
1770         relent->howto = &xcoff64_howto_table[0x1f];
1771     }
1772   /* Special case 32 bit */
1773   else if (31 == (internal->r_size & 0x3f))
1774     {
1775       if (R_POS == internal->r_type) 
1776         relent->howto = &xcoff64_howto_table[0x1c];
1777     }
1778   
1779   /* The r_size field of an XCOFF reloc encodes the bitsize of the
1780      relocation, as well as indicating whether it is signed or not.
1781      Doublecheck that the relocation information gathered from the
1782      type matches this information.  The bitsize is not significant
1783      for R_REF relocs.  */
1784   if (relent->howto->dst_mask != 0
1785       && (relent->howto->bitsize
1786           != ((unsigned int) internal->r_size & 0x3f) + 1))
1787     abort ();
1788
1789   /* Put a meaningful value in addend */
1790   relent->addend = (internal->r_size & 0x80) ? - internal->r_vaddr 
1791     : internal->r_vaddr;
1792 }
1793
1794 reloc_howto_type *
1795 xcoff64_reloc_type_lookup (abfd, code)
1796      bfd *abfd ATTRIBUTE_UNUSED;
1797      bfd_reloc_code_real_type code;
1798 {
1799   switch (code)
1800     {
1801     case BFD_RELOC_PPC_B26:
1802       return &xcoff64_howto_table[0xa];
1803     case BFD_RELOC_PPC_BA16:
1804       return &xcoff64_howto_table[0x1d];
1805     case BFD_RELOC_PPC_BA26:
1806       return &xcoff64_howto_table[8];
1807     case BFD_RELOC_PPC_TOC16:
1808       return &xcoff64_howto_table[3];
1809     case BFD_RELOC_32:
1810     case BFD_RELOC_CTOR:
1811       return &xcoff64_howto_table[0x1c];
1812     case BFD_RELOC_64:
1813       return &xcoff64_howto_table[0];
1814     default:
1815       return NULL;
1816     }
1817 }
1818
1819 /* Read in the armap of an XCOFF archive.  */
1820
1821 static boolean
1822 xcoff64_slurp_armap (abfd)
1823      bfd *abfd;
1824 {
1825   file_ptr off;
1826   size_t namlen;
1827   bfd_size_type sz, amt;
1828   bfd_byte *contents, *cend;
1829   bfd_vma c, i;
1830   carsym *arsym;
1831   bfd_byte *p;
1832   file_ptr pos;
1833
1834   /* This is for the new format.  */
1835   struct xcoff_ar_hdr_big hdr;
1836
1837   if (xcoff_ardata (abfd) == NULL)
1838     {
1839       bfd_has_map (abfd) = false;
1840       return true;
1841     }
1842
1843   off = strtol (xcoff_ardata_big (abfd)->symoff64, (char **) NULL, 10);
1844   if (off == 0)
1845     {
1846       bfd_has_map (abfd) = false;
1847       return true;
1848     }
1849
1850   if (bfd_seek (abfd, off, SEEK_SET) != 0)
1851     return false;
1852
1853   /* The symbol table starts with a normal archive header.  */
1854   if (bfd_bread ((PTR) &hdr, (bfd_size_type) SIZEOF_AR_HDR_BIG, abfd)
1855       != SIZEOF_AR_HDR_BIG)
1856     return false;
1857
1858   /* Skip the name (normally empty).  */
1859   namlen = strtol (hdr.namlen, (char **) NULL, 10);
1860   pos = ((namlen + 1) & ~(size_t) 1) + SXCOFFARFMAG;
1861   if (bfd_seek (abfd, pos, SEEK_CUR) != 0)
1862     return false;
1863
1864   /* XXX This actually has to be a call to strtoll (at least on 32-bit
1865      machines) since the field width is 20 and there numbers with more
1866      than 32 bits can be represented.  */
1867   sz = strtol (hdr.size, (char **) NULL, 10);
1868
1869   /* Read in the entire symbol table.  */
1870   contents = (bfd_byte *) bfd_alloc (abfd, sz);
1871   if (contents == NULL)
1872     return false;
1873   if (bfd_bread ((PTR) contents, sz, abfd) != sz)
1874     return false;
1875
1876   /* The symbol table starts with an eight byte count.  */
1877   c = H_GET_64 (abfd, contents);
1878
1879   if (c * 8 >= sz)
1880     {
1881       bfd_set_error (bfd_error_bad_value);
1882       return false;
1883     }
1884   amt = c;
1885   amt *= sizeof (carsym);
1886   bfd_ardata (abfd)->symdefs = (carsym *) bfd_alloc (abfd, amt);
1887   if (bfd_ardata (abfd)->symdefs == NULL)
1888     return false;
1889
1890   /* After the count comes a list of eight byte file offsets.  */
1891   for (i = 0, arsym = bfd_ardata (abfd)->symdefs, p = contents + 8;
1892        i < c;
1893        ++i, ++arsym, p += 8)
1894     arsym->file_offset = H_GET_64 (abfd, p);
1895
1896   /* After the file offsets come null terminated symbol names.  */
1897   cend = contents + sz;
1898   for (i = 0, arsym = bfd_ardata (abfd)->symdefs;
1899        i < c;
1900        ++i, ++arsym, p += strlen ((char *) p) + 1)
1901     {
1902       if (p >= cend)
1903         {
1904           bfd_set_error (bfd_error_bad_value);
1905           return false;
1906         }
1907       arsym->name = (char *) p;
1908     }
1909
1910   bfd_ardata (abfd)->symdef_count = c;
1911   bfd_has_map (abfd) = true;
1912
1913   return true;
1914 }
1915
1916
1917 /* See if this is an NEW XCOFF archive.  */
1918
1919 static const bfd_target *
1920 xcoff64_archive_p (abfd)
1921      bfd *abfd;
1922 {
1923   char magic[SXCOFFARMAG];
1924   /* This is the new format.  */
1925   struct xcoff_ar_file_hdr_big hdr;
1926   bfd_size_type amt = SXCOFFARMAG;
1927
1928   if (bfd_bread ((PTR) magic, amt, abfd) != amt)
1929     {
1930       if (bfd_get_error () != bfd_error_system_call)
1931         bfd_set_error (bfd_error_wrong_format);
1932       return NULL;
1933     }
1934
1935   if (strncmp (magic, XCOFFARMAGBIG, SXCOFFARMAG) != 0)
1936     {
1937       bfd_set_error (bfd_error_wrong_format);
1938       return NULL;
1939     }
1940
1941   /* We are setting bfd_ardata(abfd) here, but since bfd_ardata
1942      involves a cast, we can't do it as the left operand of
1943      assignment.  */
1944   amt = sizeof (struct artdata);
1945   abfd->tdata.aout_ar_data = (struct artdata *) bfd_zalloc (abfd, amt);
1946
1947   if (bfd_ardata (abfd) == (struct artdata *) NULL)
1948     return NULL;
1949
1950   bfd_ardata (abfd)->cache = NULL;
1951   bfd_ardata (abfd)->archive_head = NULL;
1952   bfd_ardata (abfd)->symdefs = NULL;
1953   bfd_ardata (abfd)->extended_names = NULL;
1954
1955   /* Copy over the magic string.  */
1956   memcpy (hdr.magic, magic, SXCOFFARMAG);
1957
1958   /* Now read the rest of the file header.  */
1959   if (bfd_bread ((PTR) &hdr.memoff,
1960                 (bfd_size_type) (SIZEOF_AR_FILE_HDR_BIG - SXCOFFARMAG),
1961                 abfd) != SIZEOF_AR_FILE_HDR_BIG - SXCOFFARMAG)
1962     {
1963       if (bfd_get_error () != bfd_error_system_call)
1964         bfd_set_error (bfd_error_wrong_format);
1965       return NULL;
1966     }
1967
1968   /* XXX This actually has to be a call to strtoll (at least on 32-bit
1969      machines) since the field width is 20 and there numbers with more
1970      than 32 bits can be represented.  */
1971   bfd_ardata (abfd)->first_file_filepos = strtol (hdr.firstmemoff,
1972                                                   (char **) NULL, 10);
1973
1974   amt = SIZEOF_AR_FILE_HDR_BIG;
1975   bfd_ardata (abfd)->tdata = bfd_zalloc (abfd, amt);
1976   if (bfd_ardata (abfd)->tdata == NULL)
1977     return NULL;
1978
1979   memcpy (bfd_ardata (abfd)->tdata, &hdr, SIZEOF_AR_FILE_HDR_BIG);
1980
1981   if (! xcoff64_slurp_armap (abfd))
1982     {
1983       bfd_release (abfd, bfd_ardata (abfd));
1984       abfd->tdata.aout_ar_data = (struct artdata *) NULL;
1985       return NULL;
1986     }
1987
1988   return abfd->xvec;
1989 }
1990
1991
1992 /* Open the next element in an XCOFF archive.  */
1993
1994 static bfd *
1995 xcoff64_openr_next_archived_file (archive, last_file)
1996      bfd *archive;
1997      bfd *last_file;
1998 {
1999   file_ptr filestart;
2000
2001   if ((xcoff_ardata (archive) == NULL)
2002       || ! xcoff_big_format_p (archive))
2003     {
2004       bfd_set_error (bfd_error_invalid_operation);
2005       return NULL;
2006     }
2007
2008   if (last_file == NULL)
2009     {
2010       filestart = bfd_ardata (archive)->first_file_filepos;
2011     }
2012   else
2013     {
2014       /* XXX These actually have to be a calls to strtoll (at least
2015          on 32-bit machines) since the fields's width is 20 and
2016          there numbers with more than 32 bits can be represented.  */
2017       filestart = strtol (arch_xhdr_big (last_file)->nextoff, (char **) NULL,
2018                           10);
2019     }
2020   /* XXX These actually have to be calls to strtoll (at least on 32-bit
2021      machines) since the fields's width is 20 and there numbers with more
2022      than 32 bits can be represented.  */
2023   if (filestart == 0
2024       || filestart == strtol (xcoff_ardata_big (archive)->memoff,
2025                               (char **) NULL, 10)
2026       || filestart == strtol (xcoff_ardata_big (archive)->symoff,
2027                               (char **) NULL, 10))
2028     {
2029       bfd_set_error (bfd_error_no_more_archived_files);
2030       return NULL;
2031     }
2032
2033   return _bfd_get_elt_at_filepos (archive, filestart);
2034 }
2035
2036 /* We can't use the usual coff_sizeof_headers routine, because AIX
2037    always uses an a.out header.  */
2038
2039 /*ARGSUSED*/
2040 static int
2041 xcoff64_sizeof_headers (abfd, reloc)
2042      bfd *abfd;
2043      boolean reloc ATTRIBUTE_UNUSED;
2044 {
2045   int size;
2046
2047   size = bfd_coff_filhsz (abfd);
2048
2049   /* Don't think the small aout header can be used since some of the
2050      old elements have been reordered past the end of the old coff
2051      small aout size.  */
2052
2053   if (xcoff_data (abfd)->full_aouthdr)
2054     size += bfd_coff_aoutsz (abfd);
2055
2056   size += abfd->section_count * bfd_coff_scnhsz (abfd);
2057   return size;
2058 }
2059
2060
2061
2062 static asection *
2063 xcoff64_create_csect_from_smclas (abfd, aux, symbol_name)
2064      bfd *abfd;
2065      union internal_auxent *aux;
2066      const char *symbol_name;
2067 {
2068   asection *return_value = NULL;
2069
2070   /* Changes from 32 :
2071      .sv == 8, is only for 32 bit programs
2072      .ti == 12 and .tb == 13 are now reserved.  */
2073   static const char *names[19] =
2074   {
2075     ".pr", ".ro", ".db", ".tc", ".ua", ".rw", ".gl", ".xo",
2076     NULL, ".bs", ".ds", ".uc", NULL,  NULL,  NULL,  ".tc0",
2077     ".td", ".sv64", ".sv3264"
2078   };
2079
2080   if ((19 >= aux->x_csect.x_smclas)
2081       && (NULL != names[aux->x_csect.x_smclas]))
2082     {
2083
2084       return_value = bfd_make_section_anyway
2085         (abfd, names[aux->x_csect.x_smclas]);
2086
2087     }
2088   else
2089     {
2090       (*_bfd_error_handler)
2091         (_("%s: symbol `%s' has unrecognized smclas %d"),
2092          bfd_archive_filename (abfd), symbol_name, aux->x_csect.x_smclas);
2093       bfd_set_error (bfd_error_bad_value);
2094     }
2095
2096   return return_value;
2097 }
2098
2099 static boolean
2100 xcoff64_is_lineno_count_overflow (abfd, value)
2101      bfd *abfd ATTRIBUTE_UNUSED;
2102      bfd_vma value ATTRIBUTE_UNUSED;
2103 {
2104   return false;
2105 }
2106
2107 static boolean
2108 xcoff64_is_reloc_count_overflow (abfd, value)
2109      bfd *abfd ATTRIBUTE_UNUSED;
2110      bfd_vma value ATTRIBUTE_UNUSED;
2111 {
2112   return false;
2113 }
2114
2115 static bfd_vma
2116 xcoff64_loader_symbol_offset (abfd, ldhdr)
2117      bfd *abfd ATTRIBUTE_UNUSED;
2118      struct internal_ldhdr *ldhdr;
2119 {
2120   return (ldhdr->l_symoff);
2121 }
2122
2123 static bfd_vma
2124 xcoff64_loader_reloc_offset (abfd, ldhdr)
2125      bfd *abfd ATTRIBUTE_UNUSED;
2126      struct internal_ldhdr *ldhdr;
2127 {
2128   return (ldhdr->l_rldoff);
2129 }
2130
2131 static boolean
2132 xcoff64_bad_format_hook (abfd, filehdr)
2133      bfd * abfd;
2134      PTR filehdr;
2135 {
2136   struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2137
2138   /* Check flavor first.  */
2139   if (bfd_get_flavour (abfd) != bfd_target_xcoff_flavour)
2140     return false;
2141
2142   if (bfd_xcoff_magic_number (abfd) != internal_f->f_magic)
2143     return false;
2144
2145   return true;
2146 }
2147
2148 static boolean
2149 xcoff64_generate_rtinit (abfd, init, fini, rtld)
2150      bfd *abfd;
2151      const char *init;
2152      const char *fini;
2153      boolean rtld;
2154 {
2155   bfd_byte filehdr_ext[FILHSZ];
2156   bfd_byte scnhdr_ext[SCNHSZ * 3];
2157   bfd_byte syment_ext[SYMESZ * 10];
2158   bfd_byte reloc_ext[RELSZ * 3];
2159   bfd_byte *data_buffer;
2160   bfd_size_type data_buffer_size;
2161   bfd_byte *string_table, *st_tmp;
2162   bfd_size_type string_table_size;
2163   bfd_vma val;
2164   size_t initsz, finisz;
2165   struct internal_filehdr filehdr;
2166   struct internal_scnhdr text_scnhdr;
2167   struct internal_scnhdr data_scnhdr;
2168   struct internal_scnhdr bss_scnhdr;
2169   struct internal_syment syment;
2170   union internal_auxent auxent;
2171   struct internal_reloc reloc;
2172
2173   char *text_name = ".text";
2174   char *data_name = ".data";
2175   char *bss_name = ".bss";
2176   char *rtinit_name = "__rtinit";
2177   char *rtld_name = "__rtld";
2178
2179   if (! bfd_xcoff_rtinit_size (abfd))
2180     return false;
2181
2182   initsz = (init == NULL ? 0 : 1 + strlen (init));
2183   finisz = (fini == NULL ? 0 : 1 + strlen (fini));
2184
2185   /* File header.  */
2186   memset (filehdr_ext, 0, FILHSZ);
2187   memset (&filehdr, 0, sizeof (struct internal_filehdr));
2188   filehdr.f_magic = bfd_xcoff_magic_number (abfd);
2189   filehdr.f_nscns = 3;
2190   filehdr.f_timdat = 0;
2191   filehdr.f_nsyms = 0;  /* at least 6, no more than 8 */
2192   filehdr.f_symptr = 0; /* set below */
2193   filehdr.f_opthdr = 0;
2194   filehdr.f_flags = 0;
2195
2196   /* Section headers.  */
2197   memset (scnhdr_ext, 0, 3 * SCNHSZ);
2198
2199   /* Text.  */
2200   memset (&text_scnhdr, 0, sizeof (struct internal_scnhdr));
2201   memcpy (text_scnhdr.s_name, text_name, strlen (text_name));
2202   text_scnhdr.s_paddr = 0;
2203   text_scnhdr.s_vaddr = 0;
2204   text_scnhdr.s_size = 0;
2205   text_scnhdr.s_scnptr = 0;
2206   text_scnhdr.s_relptr = 0;
2207   text_scnhdr.s_lnnoptr = 0;
2208   text_scnhdr.s_nreloc = 0;
2209   text_scnhdr.s_nlnno = 0;
2210   text_scnhdr.s_flags = STYP_TEXT;
2211
2212   /* Data.  */
2213   memset (&data_scnhdr, 0, sizeof (struct internal_scnhdr));
2214   memcpy (data_scnhdr.s_name, data_name, strlen (data_name));
2215   data_scnhdr.s_paddr = 0;
2216   data_scnhdr.s_vaddr = 0;
2217   data_scnhdr.s_size = 0;    /* set below */
2218   data_scnhdr.s_scnptr = FILHSZ + 3 * SCNHSZ;
2219   data_scnhdr.s_relptr = 0;  /* set below */
2220   data_scnhdr.s_lnnoptr = 0;
2221   data_scnhdr.s_nreloc = 0;  /* either 1 or 2 */
2222   data_scnhdr.s_nlnno = 0;
2223   data_scnhdr.s_flags = STYP_DATA;
2224
2225   /* Bss.  */
2226   memset (&bss_scnhdr, 0, sizeof (struct internal_scnhdr));
2227   memcpy (bss_scnhdr.s_name, bss_name, strlen (bss_name));
2228   bss_scnhdr.s_paddr = 0; /* set below */
2229   bss_scnhdr.s_vaddr = 0; /* set below */
2230   bss_scnhdr.s_size = 0;  /* set below */
2231   bss_scnhdr.s_scnptr = 0;
2232   bss_scnhdr.s_relptr = 0;
2233   bss_scnhdr.s_lnnoptr = 0;
2234   bss_scnhdr.s_nreloc = 0;
2235   bss_scnhdr.s_nlnno = 0;
2236   bss_scnhdr.s_flags = STYP_BSS;
2237
2238   /* .data
2239      0x0000           0x00000000 : rtl
2240      0x0004           0x00000000 :
2241      0x0008           0x00000018 : offset to init, or 0
2242      0x000C           0x00000038 : offset to fini, or 0
2243      0x0010           0x00000010 : size of descriptor
2244      0x0014           0x00000000 : pad
2245      0x0018           0x00000000 : init, needs a reloc
2246      0x001C           0x00000000 :
2247      0x0020           0x00000058 : offset to init name
2248      0x0024           0x00000000 : flags, padded to a word
2249      0x0028           0x00000000 : empty init
2250      0x002C           0x00000000 :
2251      0x0030           0x00000000 :
2252      0x0034           0x00000000 :
2253      0x0038           0x00000000 : fini, needs a reloc
2254      0x003C           0x00000000 :
2255      0x0040           0x00000??? : offset to fini name
2256      0x0044           0x00000000 : flags, padded to a word
2257      0x0048           0x00000000 : empty fini
2258      0x004C           0x00000000 :
2259      0x0050           0x00000000 :
2260      0x0054           0x00000000 :
2261      0x0058           init name
2262      0x0058 + initsz  fini name */
2263
2264   data_buffer_size = 0x0058 + initsz + finisz;
2265   data_buffer_size += (data_buffer_size & 7) ? 8 - (data_buffer_size & 7) : 0;
2266   data_buffer = NULL;
2267   data_buffer = (bfd_byte *) bfd_zmalloc (data_buffer_size);
2268   if (data_buffer == NULL)
2269     return false;
2270
2271   if (initsz)
2272     {
2273       val = 0x18;
2274       bfd_put_32 (abfd, val, &data_buffer[0x08]);
2275       val = 0x58;
2276       bfd_put_32 (abfd, val, &data_buffer[0x20]);
2277       memcpy (&data_buffer[val], init, initsz);
2278     }
2279
2280   if (finisz)
2281     {
2282       val = 0x38;
2283       bfd_put_32 (abfd, val, &data_buffer[0x0C]);
2284       val = 0x58 + initsz;
2285       bfd_put_32 (abfd, val, &data_buffer[0x40]);
2286       memcpy (&data_buffer[val], fini, finisz);
2287     }
2288
2289   val = 0x10;
2290   bfd_put_32 (abfd, val, &data_buffer[0x10]);
2291   data_scnhdr.s_size = data_buffer_size;
2292   bss_scnhdr.s_paddr = bss_scnhdr.s_vaddr = data_scnhdr.s_size;
2293
2294   /* String table.  */
2295   string_table_size = 4;
2296   string_table_size += strlen (data_name) + 1;
2297   string_table_size += strlen (rtinit_name) + 1;
2298   string_table_size += initsz;
2299   string_table_size += finisz;
2300   if (true == rtld)
2301     string_table_size += strlen (rtld_name) + 1;
2302
2303   string_table = (bfd_byte *) bfd_zmalloc (string_table_size);
2304   if (string_table == NULL)
2305     return false;
2306
2307   val = string_table_size;
2308   bfd_put_32 (abfd, val, &string_table[0]);
2309   st_tmp = string_table + 4;
2310
2311   /* symbols
2312      0. .data csect
2313      2. __rtinit
2314      4. init function
2315      6. fini function
2316      8. __rtld  */
2317   memset (syment_ext, 0, 10 * SYMESZ);
2318   memset (reloc_ext, 0, 3 * RELSZ);
2319
2320   /* .data csect */
2321   memset (&syment, 0, sizeof (struct internal_syment));
2322   memset (&auxent, 0, sizeof (union internal_auxent));
2323
2324   syment._n._n_n._n_offset = st_tmp - string_table;
2325   memcpy (st_tmp, data_name, strlen (data_name));
2326   st_tmp += strlen (data_name) + 1;
2327
2328   syment.n_scnum = 2;
2329   syment.n_sclass = C_HIDEXT;
2330   syment.n_numaux = 1;
2331   auxent.x_csect.x_scnlen.l = data_buffer_size;
2332   auxent.x_csect.x_smtyp = 3 << 3 | XTY_SD;
2333   auxent.x_csect.x_smclas = XMC_RW;
2334   bfd_coff_swap_sym_out (abfd, &syment,
2335                          &syment_ext[filehdr.f_nsyms * SYMESZ]);
2336   bfd_coff_swap_aux_out (abfd, &auxent, syment.n_type, syment.n_sclass, 0,
2337                          syment.n_numaux,
2338                          &syment_ext[(filehdr.f_nsyms + 1) * SYMESZ]);
2339   filehdr.f_nsyms += 2;
2340
2341   /* __rtinit */
2342   memset (&syment, 0, sizeof (struct internal_syment));
2343   memset (&auxent, 0, sizeof (union internal_auxent));
2344   syment._n._n_n._n_offset = st_tmp - string_table;
2345   memcpy (st_tmp, rtinit_name, strlen (rtinit_name));
2346   st_tmp += strlen (rtinit_name) + 1;
2347
2348   syment.n_scnum = 2;
2349   syment.n_sclass = C_EXT;
2350   syment.n_numaux = 1;
2351   auxent.x_csect.x_smtyp = XTY_LD;
2352   auxent.x_csect.x_smclas = XMC_RW;
2353   bfd_coff_swap_sym_out (abfd, &syment,
2354                          &syment_ext[filehdr.f_nsyms * SYMESZ]);
2355   bfd_coff_swap_aux_out (abfd, &auxent, syment.n_type, syment.n_sclass, 0,
2356                          syment.n_numaux,
2357                          &syment_ext[(filehdr.f_nsyms + 1) * SYMESZ]);
2358   filehdr.f_nsyms += 2;
2359
2360   /* Init.  */
2361   if (initsz)
2362     {
2363       memset (&syment, 0, sizeof (struct internal_syment));
2364       memset (&auxent, 0, sizeof (union internal_auxent));
2365
2366       syment._n._n_n._n_offset = st_tmp - string_table;
2367       memcpy (st_tmp, init, initsz);
2368       st_tmp += initsz;
2369
2370       syment.n_sclass = C_EXT;
2371       syment.n_numaux = 1;
2372       bfd_coff_swap_sym_out (abfd, &syment,
2373                              &syment_ext[filehdr.f_nsyms * SYMESZ]);
2374       bfd_coff_swap_aux_out (abfd, &auxent, syment.n_type, syment.n_sclass, 0,
2375                              syment.n_numaux,
2376                              &syment_ext[(filehdr.f_nsyms + 1) * SYMESZ]);
2377       /* Reloc.  */
2378       memset (&reloc, 0, sizeof (struct internal_reloc));
2379       reloc.r_vaddr = 0x0018;
2380       reloc.r_symndx = filehdr.f_nsyms;
2381       reloc.r_type = R_POS;
2382       reloc.r_size = 63;
2383       bfd_coff_swap_reloc_out (abfd, &reloc, &reloc_ext[0]);
2384
2385       filehdr.f_nsyms += 2;
2386       data_scnhdr.s_nreloc += 1;
2387     }
2388
2389   /* Finit.  */
2390   if (finisz)
2391     {
2392       memset (&syment, 0, sizeof (struct internal_syment));
2393       memset (&auxent, 0, sizeof (union internal_auxent));
2394
2395       syment._n._n_n._n_offset = st_tmp - string_table;
2396       memcpy (st_tmp, fini, finisz);
2397       st_tmp += finisz;
2398
2399       syment.n_sclass = C_EXT;
2400       syment.n_numaux = 1;
2401       bfd_coff_swap_sym_out (abfd, &syment,
2402                              &syment_ext[filehdr.f_nsyms * SYMESZ]);
2403       bfd_coff_swap_aux_out (abfd, &auxent, syment.n_type, syment.n_sclass, 0,
2404                              syment.n_numaux,
2405                              &syment_ext[(filehdr.f_nsyms + 1) * SYMESZ]);
2406
2407       /* Reloc.  */
2408       memset (&reloc, 0, sizeof (struct internal_reloc));
2409       reloc.r_vaddr = 0x0038;
2410       reloc.r_symndx = filehdr.f_nsyms;
2411       reloc.r_type = R_POS;
2412       reloc.r_size = 63;
2413       bfd_coff_swap_reloc_out (abfd, &reloc,
2414                                &reloc_ext[data_scnhdr.s_nreloc * RELSZ]);
2415
2416       filehdr.f_nsyms += 2;
2417       data_scnhdr.s_nreloc += 1;
2418     }
2419
2420   if (rtld)
2421     {
2422       memset (&syment, 0, sizeof (struct internal_syment));
2423       memset (&auxent, 0, sizeof (union internal_auxent));
2424
2425       syment._n._n_n._n_offset = st_tmp - string_table;
2426       memcpy (st_tmp, rtld_name, strlen (rtld_name));
2427       st_tmp += strlen (rtld_name) + 1;
2428
2429       syment.n_sclass = C_EXT;
2430       syment.n_numaux = 1;
2431       bfd_coff_swap_sym_out (abfd, &syment,
2432                              &syment_ext[filehdr.f_nsyms * SYMESZ]);
2433       bfd_coff_swap_aux_out (abfd, &auxent, syment.n_type, syment.n_sclass, 0,
2434                              syment.n_numaux,
2435                              &syment_ext[(filehdr.f_nsyms + 1) * SYMESZ]);
2436
2437       /* Reloc.  */
2438       memset (&reloc, 0, sizeof (struct internal_reloc));
2439       reloc.r_vaddr = 0x0000;
2440       reloc.r_symndx = filehdr.f_nsyms;
2441       reloc.r_type = R_POS;
2442       reloc.r_size = 63;
2443       bfd_coff_swap_reloc_out (abfd, &reloc,
2444                                &reloc_ext[data_scnhdr.s_nreloc * RELSZ]);
2445
2446       filehdr.f_nsyms += 2;
2447       data_scnhdr.s_nreloc += 1;
2448
2449       bss_scnhdr.s_size = 0;
2450     }
2451
2452   data_scnhdr.s_relptr = data_scnhdr.s_scnptr + data_buffer_size;
2453   filehdr.f_symptr = data_scnhdr.s_relptr + data_scnhdr.s_nreloc * RELSZ;
2454
2455   bfd_coff_swap_filehdr_out (abfd, &filehdr, filehdr_ext);
2456   bfd_bwrite (filehdr_ext, FILHSZ, abfd);
2457   bfd_coff_swap_scnhdr_out (abfd, &text_scnhdr, &scnhdr_ext[SCNHSZ * 0]);
2458   bfd_coff_swap_scnhdr_out (abfd, &data_scnhdr, &scnhdr_ext[SCNHSZ * 1]);
2459   bfd_coff_swap_scnhdr_out (abfd, &bss_scnhdr, &scnhdr_ext[SCNHSZ * 2]);
2460   bfd_bwrite (scnhdr_ext, 3 * SCNHSZ, abfd);
2461   bfd_bwrite (data_buffer, data_buffer_size, abfd);
2462   bfd_bwrite (reloc_ext, data_scnhdr.s_nreloc * RELSZ, abfd);
2463   bfd_bwrite (syment_ext, filehdr.f_nsyms * SYMESZ, abfd);
2464   bfd_bwrite (string_table, string_table_size, abfd);
2465
2466   free (data_buffer);
2467   data_buffer = NULL;
2468
2469   return true;
2470 }
2471
2472 /* The typical dynamic reloc.  */
2473
2474 static reloc_howto_type xcoff64_dynamic_reloc =
2475 HOWTO (0,                       /* type */
2476        0,                       /* rightshift */
2477        4,                       /* size (0 = byte, 1 = short, 2 = long) */
2478        64,                      /* bitsize */
2479        false,                   /* pc_relative */
2480        0,                       /* bitpos */
2481        complain_overflow_bitfield, /* complain_on_overflow */
2482        0,                       /* special_function */
2483        "R_POS",                 /* name */
2484        true,                    /* partial_inplace */
2485        MINUS_ONE,               /* src_mask */
2486        MINUS_ONE,               /* dst_mask */
2487        false);                  /* pcrel_offset */
2488
2489 static unsigned long xcoff64_glink_code[10] =
2490 {
2491   0xe9820000,   /* ld r12,0(r2) */
2492   0xf8410028,   /* std r2,40(r1) */
2493   0xe80c0000,   /* ld r0,0(r12) */
2494   0xe84c0008,   /* ld r0,8(r12) */
2495   0x7c0903a6,   /* mtctr r0 */
2496   0x4e800420,   /* bctr */
2497   0x00000000,   /* start of traceback table */
2498   0x000ca000,   /* traceback table */
2499   0x00000000,   /* traceback table */
2500   0x00000018,   /* ??? */
2501 };
2502
2503 static const struct xcoff_backend_data_rec bfd_xcoff_backend_data =
2504 {
2505   { /* COFF backend, defined in libcoff.h.  */
2506     _bfd_xcoff64_swap_aux_in,           /* _bfd_coff_swap_aux_in */
2507     _bfd_xcoff64_swap_sym_in,           /* _bfd_coff_swap_sym_in */
2508     _bfd_xcoff64_swap_lineno_in,        /* _bfd_coff_swap_lineno_in */
2509     _bfd_xcoff64_swap_aux_out,          /* _bfd_swap_aux_out */
2510     _bfd_xcoff64_swap_sym_out,          /* _bfd_swap_sym_out */
2511     _bfd_xcoff64_swap_lineno_out,       /* _bfd_swap_lineno_out */
2512     xcoff64_swap_reloc_out,             /* _bfd_swap_reloc_out */
2513     coff_swap_filehdr_out,              /* _bfd_swap_filehdr_out */
2514     coff_swap_aouthdr_out,              /* _bfd_swap_aouthdr_out */
2515     coff_swap_scnhdr_out,               /* _bfd_swap_scnhdr_out */
2516     FILHSZ,                             /* _bfd_filhsz */
2517     AOUTSZ,                             /* _bfd_aoutsz */
2518     SCNHSZ,                             /* _bfd_scnhsz */
2519     SYMESZ,                             /* _bfd_symesz */
2520     AUXESZ,                             /* _bfd_auxesz */
2521     RELSZ,                              /* _bfd_relsz */
2522     LINESZ,                             /* _bfd_linesz */
2523     FILNMLEN,                           /* _bfd_filnmlen */
2524     true,                               /* _bfd_coff_long_filenames */
2525     false,                              /* _bfd_coff_long_section_names */
2526     (3),                        /* _bfd_coff_default_section_alignment_power */
2527     true,                       /* _bfd_coff_force_symnames_in_strings */
2528     4,                          /* _bfd_coff_debug_string_prefix_length */
2529     coff_swap_filehdr_in,               /* _bfd_coff_swap_filehdr_in */
2530     coff_swap_aouthdr_in,               /* _bfd_swap_aouthdr_in */
2531     coff_swap_scnhdr_in,                /* _bfd_swap_scnhdr_in */
2532     xcoff64_swap_reloc_in,              /* _bfd_reloc_in */
2533     xcoff64_bad_format_hook,            /* _bfd_bad_format_hook */
2534     coff_set_arch_mach_hook,            /* _bfd_set_arch_mach_hook */
2535     coff_mkobject_hook,                 /* _bfd_mkobject_hook */
2536     styp_to_sec_flags,                  /* _bfd_syp_to_sec_flags */
2537     coff_set_alignment_hook,            /* _bfd_set_alignment_hook */
2538     coff_slurp_symbol_table,            /* _bfd_coff_slurp_symbol_table */
2539     symname_in_debug_hook,              /* _coff_symname_in_debug_hook */
2540     coff_pointerize_aux_hook,           /* _bfd_coff_pointerize_aux_hook */
2541     coff_print_aux,                     /* bfd_coff_print_aux */
2542     dummy_reloc16_extra_cases,          /* _bfd_coff_reloc16_extra_cases */
2543     dummy_reloc16_estimate,             /* _bfd_coff_reloc16_estimate */
2544     NULL,                               /* bfd_coff_sym_is_global */
2545     /* _bfd_coff_compute_section_file_positions */
2546     coff_compute_section_file_positions,
2547     NULL ,                              /* _bfd_coff_start_final_link */
2548     xcoff64_ppc_relocate_section,       /* _bfd_coff_relocate_section */
2549     coff_rtype_to_howto,                /* _bfd_coff_rtype_to_howto */
2550     NULL ,                              /* _bfd_coff_addust_symndx */
2551     _bfd_generic_link_add_one_symbol,   /* _bfd_coff_add_one_symbol */
2552     coff_link_output_has_begun,         /* _bfd_coff_link_output_has_begun */
2553     coff_final_link_postscript          /* _bfd_coff_final_link_postscript */
2554   },
2555
2556   0x01EF,                               /* magic number */
2557   bfd_arch_powerpc,                     /* architecture */
2558   bfd_mach_ppc_620,                     /* machine */
2559
2560   /* Function pointers to xcoff specific swap routines.  */
2561   xcoff64_swap_ldhdr_in,                /* _xcoff_swap_ldhdr_in */
2562   xcoff64_swap_ldhdr_out,               /* _xcoff_swap_ldhdr_out */
2563   xcoff64_swap_ldsym_in,                /* _xcoff_swap_ldsym_in */
2564   xcoff64_swap_ldsym_out,               /* _xcoff_swap_ldsym_out */
2565   xcoff64_swap_ldrel_in,                /* _xcoff_swap_ldrel_in */
2566   xcoff64_swap_ldrel_out,               /* _xcoff_swap_ldrel_out */
2567
2568   /* Sizes.  */
2569   LDHDRSZ,                              /* _xcoff_ldhdrsz */
2570   LDSYMSZ,                              /* _xcoff_ldsymsz */
2571   LDRELSZ,                              /* _xcoff_ldrelsz */
2572   24,                                   /* _xcoff_function_descriptor_size */
2573   0,                                    /* _xcoff_small_aout_header_size */
2574
2575   /* Versions.  */
2576   2,                                    /* _xcoff_ldhdr_version */
2577
2578   /* xcoff vs xcoff64 putting symbol names.  */
2579   _bfd_xcoff64_put_symbol_name,         /* _xcoff_put_symbol_name */
2580   _bfd_xcoff64_put_ldsymbol_name,       /* _xcoff_put_ldsymbol_name */
2581
2582   /* Dynamic reloc howto.  */
2583   &xcoff64_dynamic_reloc,
2584
2585   xcoff64_create_csect_from_smclas,
2586
2587   /* Lineno and reloc count overflow.  */
2588   xcoff64_is_lineno_count_overflow,
2589   xcoff64_is_reloc_count_overflow,
2590
2591   xcoff64_loader_symbol_offset,
2592   xcoff64_loader_reloc_offset,
2593
2594   /* glink.  */
2595   &xcoff64_glink_code[0],
2596   40,                                   /* _xcoff_glink_size */
2597
2598   /* rtinit.  */
2599   88,                                   /* _xcoff_rtinit_size */
2600   xcoff64_generate_rtinit,              /* _xcoff_generate_rtinit */
2601 };
2602
2603 /* The transfer vector that leads the outside world to all of the above.  */
2604 const bfd_target rs6000coff64_vec =
2605 {
2606   "aixcoff64-rs6000",
2607   bfd_target_xcoff_flavour,
2608   BFD_ENDIAN_BIG,               /* data byte order is big */
2609   BFD_ENDIAN_BIG,               /* header byte order is big */
2610
2611   (HAS_RELOC | EXEC_P |         /* object flags */
2612    HAS_LINENO | HAS_DEBUG | DYNAMIC |
2613    HAS_SYMS | HAS_LOCALS | WP_TEXT),
2614
2615   (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC), /* section flags */
2616   0,                            /* leading char */
2617   '/',                          /* ar_pad_char */
2618   15,                           /* ar_max_namelen??? FIXMEmgo */
2619
2620   /* data */
2621   bfd_getb64,                   /* bfd_getx64 */
2622   bfd_getb_signed_64,           /* bfd_getx_signed_64 */
2623   bfd_putb64,                   /* bfd_putx64 */
2624   bfd_getb32,                   /* bfd_getx32 */
2625   bfd_getb_signed_32,           /* bfd_getx_signed_32 */
2626   bfd_putb32,                   /* bfd_putx32 */
2627   bfd_getb16,                   /* bfd_getx16 */
2628   bfd_getb_signed_16,           /* bfd_getx_signed_16 */
2629   bfd_putb16,                   /* bfd_putx16 */
2630
2631   /* hdrs */
2632   bfd_getb64,                   /* bfd_h_getx64 */
2633   bfd_getb_signed_64,           /* bfd_h_getx_signed_64 */
2634   bfd_putb64,                   /* bfd_h_putx64 */
2635   bfd_getb32,                   /* bfd_h_getx32 */
2636   bfd_getb_signed_32,           /* bfd_h_getx_signed_32 */
2637   bfd_putb32,                   /* bfd_h_putx32 */
2638   bfd_getb16,                   /* bfd_h_getx16 */
2639   bfd_getb_signed_16,           /* bfd_h_getx_signed_16 */
2640   bfd_putb16,                   /* bfd_h_putx16 */
2641
2642   { /* bfd_check_format */
2643     _bfd_dummy_target,
2644     coff_object_p,
2645     xcoff64_archive_p,
2646     CORE_FILE_P
2647   },
2648
2649   { /* bfd_set_format */
2650     bfd_false,
2651     coff_mkobject,
2652     _bfd_generic_mkarchive,
2653     bfd_false
2654   },
2655
2656   {/* bfd_write_contents */
2657     bfd_false,
2658     xcoff64_write_object_contents,
2659     _bfd_xcoff_write_archive_contents,
2660     bfd_false
2661   },
2662
2663   /* Generic */
2664   bfd_true,                             /* _close_and_cleanup */
2665   bfd_true,                             /* _bfd_free_cached_info */
2666   coff_new_section_hook,                /* _new_section_hook */
2667   _bfd_generic_get_section_contents,    /* _bfd_get_section_contents */
2668   /* _bfd_get_section_contents_in_window */
2669   _bfd_generic_get_section_contents_in_window,
2670
2671   /* Copy */
2672   _bfd_xcoff_copy_private_bfd_data,     /* _bfd_copy_private_bfd */
2673   /* _bfd_merge_private_bfd_data */
2674   ((boolean (*) (bfd *, bfd *)) bfd_true),
2675   /* _bfd_copy_pivate_section_data */
2676   ((boolean (*) (bfd *, asection *, bfd *, asection *)) bfd_true),
2677   /* _bfd_copy_private_symbol_data */
2678   ((boolean (*) (bfd *, asymbol *, bfd *, asymbol *)) bfd_true),
2679   ((boolean (*) (bfd *, flagword)) bfd_true), /* _bfd_set_private_flags */
2680   ((boolean (*) (bfd *, void * )) bfd_true),  /* _bfd_print_private_bfd_data */
2681
2682   /* Core */
2683   coff_core_file_failing_command,       /* _core_file_failing_command */
2684   coff_core_file_failing_signal,        /* _core_file_failing_signal */
2685   coff_core_file_matches_executable_p,  /* _core_file_matches_executable_p */
2686
2687   /* Archive */
2688   xcoff64_slurp_armap,                  /* _slurp_armap */
2689   /* XCOFF archives do not have anything which corresponds to an
2690      extended name table.  */
2691   bfd_false,                            /* _slurp_extended_name_table */
2692   /* _construct_extended_name_table */
2693   ((boolean (*) (bfd *, char **, bfd_size_type *, const char **)) bfd_false),
2694   bfd_dont_truncate_arname,             /* _truncate_arname */
2695   _bfd_xcoff_write_armap,               /* _write_armap */
2696   _bfd_xcoff_read_ar_hdr,               /* _read_ar_hdr */
2697   xcoff64_openr_next_archived_file,     /* _openr_next_archived_file */
2698   _bfd_generic_get_elt_at_index,        /* _get_elt_at_index */
2699   _bfd_xcoff_stat_arch_elt,             /* _generic_stat_arch_elt */
2700   /* XCOFF archives do not have a timestamp.  */
2701   bfd_true,                             /* _update_armap_timestamp */
2702
2703   /* Symbols */
2704   coff_get_symtab_upper_bound,          /* _get_symtab_upper_bound */
2705   coff_get_symtab,                      /* _get_symtab */
2706   coff_make_empty_symbol,               /* _make_empty_symbol */
2707   coff_print_symbol,                    /* _print_symbol */
2708   coff_get_symbol_info,                 /* _get_symbol_info */
2709   _bfd_xcoff_is_local_label_name,       /* _bfd_is_local_label_name */
2710   coff_get_lineno,                      /* _get_lineno */
2711   coff_find_nearest_line,               /* _find_nearest_line */
2712   coff_bfd_make_debug_symbol,           /* _bfd_make_debug_symbol */
2713   _bfd_generic_read_minisymbols,        /* _read_minisymbols */
2714   _bfd_generic_minisymbol_to_symbol,    /* _minsymbol_to_symbol */
2715
2716   /* Reloc */
2717   coff_get_reloc_upper_bound,           /* _get_reloc_upper_bound */
2718   coff_canonicalize_reloc,              /* _cononicalize_reloc */
2719   xcoff64_reloc_type_lookup,            /* _bfd_reloc_type_lookup */
2720
2721   /* Write */
2722   coff_set_arch_mach,                   /* _set_arch_mach */
2723   coff_set_section_contents,            /* _set_section_contents */
2724
2725   /* Link */
2726   xcoff64_sizeof_headers,               /* _sizeof_headers */
2727   /* _bfd_get_relocated_section_contents */
2728   bfd_generic_get_relocated_section_contents,
2729   bfd_generic_relax_section,            /* _bfd_relax_section */
2730   _bfd_xcoff_bfd_link_hash_table_create,/* _bfd_link_hash_table_create */
2731   _bfd_generic_link_hash_table_free,    /* _bfd_link_hash_table_free */
2732   _bfd_xcoff_bfd_link_add_symbols,      /* _bfd_link_add_symbols */
2733   _bfd_generic_link_just_syms,          /* _bfd_link_just_syms */
2734   _bfd_xcoff_bfd_final_link,            /* _bfd_final_link */
2735   _bfd_generic_link_split_section,      /* _bfd_link_split_section */
2736   bfd_generic_gc_sections,              /* _bfd_gc_sections */
2737   bfd_generic_merge_sections,           /* _bfd_merge_sections */
2738   bfd_generic_discard_group,            /* _bfd_discard_group */
2739
2740   /* Dynamic */
2741   /* _get_dynamic_symtab_upper_bound */
2742   _bfd_xcoff_get_dynamic_symtab_upper_bound,
2743   _bfd_xcoff_canonicalize_dynamic_symtab,  /* _cononicalize_dynamic_symtab */
2744   _bfd_xcoff_get_dynamic_reloc_upper_bound,/* _get_dynamic_reloc_upper_bound */
2745   _bfd_xcoff_canonicalize_dynamic_reloc,   /* _cononicalize_dynamic_reloc */
2746
2747   /* Opposite endian version, none exists */
2748   NULL,
2749
2750   /* back end data */
2751   (void *) &bfd_xcoff_backend_data,
2752 };
2753
2754 extern const bfd_target *xcoff64_core_p PARAMS ((bfd *));
2755 extern boolean xcoff64_core_file_matches_executable_p PARAMS((bfd *, bfd *));
2756 extern char *xcoff64_core_file_failing_command PARAMS ((bfd *));
2757 extern int xcoff64_core_file_failing_signal PARAMS ((bfd *));
2758
2759 /* AIX 5 */
2760 static const struct xcoff_backend_data_rec bfd_xcoff_aix5_backend_data =
2761 {
2762   { /* COFF backend, defined in libcoff.h.  */
2763     _bfd_xcoff64_swap_aux_in,           /* _bfd_coff_swap_aux_in */
2764     _bfd_xcoff64_swap_sym_in,           /* _bfd_coff_swap_sym_in */
2765     _bfd_xcoff64_swap_lineno_in,        /* _bfd_coff_swap_lineno_in */
2766     _bfd_xcoff64_swap_aux_out,          /* _bfd_swap_aux_out */
2767     _bfd_xcoff64_swap_sym_out,          /* _bfd_swap_sym_out */
2768     _bfd_xcoff64_swap_lineno_out,       /* _bfd_swap_lineno_out */
2769     xcoff64_swap_reloc_out,             /* _bfd_swap_reloc_out */
2770     coff_swap_filehdr_out,              /* _bfd_swap_filehdr_out */
2771     coff_swap_aouthdr_out,              /* _bfd_swap_aouthdr_out */
2772     coff_swap_scnhdr_out,               /* _bfd_swap_scnhdr_out */
2773     FILHSZ,                             /* _bfd_filhsz */
2774     AOUTSZ,                             /* _bfd_aoutsz */
2775     SCNHSZ,                             /* _bfd_scnhsz */
2776     SYMESZ,                             /* _bfd_symesz */
2777     AUXESZ,                             /* _bfd_auxesz */
2778     RELSZ,                              /* _bfd_relsz */
2779     LINESZ,                             /* _bfd_linesz */
2780     FILNMLEN,                           /* _bfd_filnmlen */
2781     true,                               /* _bfd_coff_long_filenames */
2782     false,                              /* _bfd_coff_long_section_names */
2783     (3),                        /* _bfd_coff_default_section_alignment_power */
2784     true,                       /* _bfd_coff_force_symnames_in_strings */
2785     4,                          /* _bfd_coff_debug_string_prefix_length */
2786     coff_swap_filehdr_in,               /* _bfd_coff_swap_filehdr_in */
2787     coff_swap_aouthdr_in,               /* _bfd_swap_aouthdr_in */
2788     coff_swap_scnhdr_in,                /* _bfd_swap_scnhdr_in */
2789     xcoff64_swap_reloc_in,              /* _bfd_reloc_in */
2790     xcoff64_bad_format_hook,            /* _bfd_bad_format_hook */
2791     coff_set_arch_mach_hook,            /* _bfd_set_arch_mach_hook */
2792     coff_mkobject_hook,                 /* _bfd_mkobject_hook */
2793     styp_to_sec_flags,                  /* _bfd_syp_to_sec_flags */
2794     coff_set_alignment_hook,            /* _bfd_set_alignment_hook */
2795     coff_slurp_symbol_table,            /* _bfd_coff_slurp_symbol_table */
2796     symname_in_debug_hook,              /* _coff_symname_in_debug_hook */
2797     coff_pointerize_aux_hook,           /* _bfd_coff_pointerize_aux_hook */
2798     coff_print_aux,                     /* bfd_coff_print_aux */
2799     dummy_reloc16_extra_cases,          /* _bfd_coff_reloc16_extra_cases */
2800     dummy_reloc16_estimate,             /* _bfd_coff_reloc16_estimate */
2801     NULL,                               /* bfd_coff_sym_is_global */
2802     /* _bfd_coff_compute_section_file_positions */
2803     coff_compute_section_file_positions,
2804     NULL ,                              /* _bfd_coff_start_final_link */
2805     xcoff64_ppc_relocate_section,       /* _bfd_coff_relocate_section */
2806     coff_rtype_to_howto,                /* _bfd_coff_rtype_to_howto */
2807     NULL ,                              /* _bfd_coff_addust_symndx */
2808     _bfd_generic_link_add_one_symbol,   /* _bfd_coff_add_one_symbol */
2809     coff_link_output_has_begun,         /* _bfd_coff_link_output_has_begun */
2810     coff_final_link_postscript          /* _bfd_coff_final_link_postscript */
2811   },
2812
2813   U64_TOCMAGIC,                         /* magic number */
2814   bfd_arch_powerpc,                     /* architecture */
2815   bfd_mach_ppc_620,                     /* machine */
2816
2817   /* Function pointers to xcoff specific swap routines.  */
2818   xcoff64_swap_ldhdr_in,                /* _xcoff_swap_ldhdr_in */
2819   xcoff64_swap_ldhdr_out,               /* _xcoff_swap_ldhdr_out */
2820   xcoff64_swap_ldsym_in,                /* _xcoff_swap_ldsym_in */
2821   xcoff64_swap_ldsym_out,               /* _xcoff_swap_ldsym_out */
2822   xcoff64_swap_ldrel_in,                /* _xcoff_swap_ldrel_in */
2823   xcoff64_swap_ldrel_out,               /* _xcoff_swap_ldrel_out */
2824
2825   /* Sizes.  */
2826   LDHDRSZ,                              /* _xcoff_ldhdrsz */
2827   LDSYMSZ,                              /* _xcoff_ldsymsz */
2828   LDRELSZ,                              /* _xcoff_ldrelsz */
2829   24,                                   /* _xcoff_function_descriptor_size */
2830   0,                                    /* _xcoff_small_aout_header_size */
2831   /* Versions.  */
2832   2,                                    /* _xcoff_ldhdr_version */
2833
2834   _bfd_xcoff64_put_symbol_name,         /* _xcoff_put_symbol_name */
2835   _bfd_xcoff64_put_ldsymbol_name,       /* _xcoff_put_ldsymbol_name */
2836
2837   /* Dynamic reloc howto.  */
2838   &xcoff64_dynamic_reloc,
2839   xcoff64_create_csect_from_smclas,
2840
2841   /* Lineno and reloc count overflow.  */
2842   xcoff64_is_lineno_count_overflow,
2843   xcoff64_is_reloc_count_overflow,
2844
2845   xcoff64_loader_symbol_offset,
2846   xcoff64_loader_reloc_offset,
2847
2848   /* glink.  */
2849   &xcoff64_glink_code[0],
2850   40,                                   /* _xcoff_glink_size */
2851
2852   /* rtinit.  */
2853   88,                                   /* _xcoff_rtinit_size */
2854   xcoff64_generate_rtinit,              /* _xcoff_generate_rtinit */
2855 };
2856
2857 /* The transfer vector that leads the outside world to all of the above.  */
2858 const bfd_target aix5coff64_vec =
2859 {
2860   "aix5coff64-rs6000",
2861   bfd_target_xcoff_flavour,
2862   BFD_ENDIAN_BIG,               /* data byte order is big */
2863   BFD_ENDIAN_BIG,               /* header byte order is big */
2864
2865   (HAS_RELOC | EXEC_P |         /* object flags */
2866    HAS_LINENO | HAS_DEBUG | DYNAMIC |
2867    HAS_SYMS | HAS_LOCALS | WP_TEXT),
2868
2869   (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC), /* section flags */
2870   0,                            /* leading char */
2871   '/',                          /* ar_pad_char */
2872   15,                           /* ar_max_namelen??? FIXMEmgo */
2873
2874   /* data */
2875   bfd_getb64,                   /* bfd_getx64 */
2876   bfd_getb_signed_64,           /* bfd_getx_signed_64 */
2877   bfd_putb64,                   /* bfd_putx64 */
2878   bfd_getb32,                   /* bfd_getx32 */
2879   bfd_getb_signed_32,           /* bfd_getx_signed_32 */
2880   bfd_putb32,                   /* bfd_putx32 */
2881   bfd_getb16,                   /* bfd_getx16 */
2882   bfd_getb_signed_16,           /* bfd_getx_signed_16 */
2883   bfd_putb16,                   /* bfd_putx16 */
2884
2885   /* hdrs */
2886   bfd_getb64,                   /* bfd_h_getx64 */
2887   bfd_getb_signed_64,           /* bfd_h_getx_signed_64 */
2888   bfd_putb64,                   /* bfd_h_putx64 */
2889   bfd_getb32,                   /* bfd_h_getx32 */
2890   bfd_getb_signed_32,           /* bfd_h_getx_signed_32 */
2891   bfd_putb32,                   /* bfd_h_putx32 */
2892   bfd_getb16,                   /* bfd_h_getx16 */
2893   bfd_getb_signed_16,           /* bfd_h_getx_signed_16 */
2894   bfd_putb16,                   /* bfd_h_putx16 */
2895
2896   { /* bfd_check_format */
2897     _bfd_dummy_target,
2898     coff_object_p,
2899     xcoff64_archive_p,
2900     xcoff64_core_p
2901   },
2902
2903   { /* bfd_set_format */
2904     bfd_false,
2905     coff_mkobject,
2906     _bfd_generic_mkarchive,
2907     bfd_false
2908   },
2909
2910   {/* bfd_write_contents */
2911     bfd_false,
2912     xcoff64_write_object_contents,
2913     _bfd_xcoff_write_archive_contents,
2914     bfd_false
2915   },
2916
2917   /* Generic */
2918   bfd_true,                             /* _close_and_cleanup */
2919   bfd_true,                             /* _bfd_free_cached_info */
2920   coff_new_section_hook,                /* _new_section_hook */
2921   _bfd_generic_get_section_contents,    /* _bfd_get_section_contents */
2922   /* _bfd_get_section_contents_in_window */
2923   _bfd_generic_get_section_contents_in_window,
2924
2925   /* Copy */
2926   _bfd_xcoff_copy_private_bfd_data,     /* _bfd_copy_private_bfd */
2927   /* _bfd_merge_private_bfd_data */
2928   ((boolean (*) (bfd *, bfd *)) bfd_true),
2929   /* _bfd_copy_pivate_section_data */
2930   ((boolean (*) (bfd *, asection *, bfd *, asection *)) bfd_true),
2931   /* _bfd_copy_private_symbol_data */
2932   ((boolean (*) (bfd *, asymbol *, bfd *, asymbol *)) bfd_true),
2933   ((boolean (*) (bfd *, flagword)) bfd_true), /* _bfd_set_private_flags */
2934   ((boolean (*) (bfd *, void * )) bfd_true),  /* _bfd_print_private_bfd_data */
2935
2936   /* Core */
2937   xcoff64_core_file_failing_command,    /* _core_file_failing_command */
2938   xcoff64_core_file_failing_signal,     /* _core_file_failing_signal */
2939   xcoff64_core_file_matches_executable_p, /* _core_file_matches_executable_p */
2940
2941   /* Archive */
2942   xcoff64_slurp_armap,                  /* _slurp_armap */
2943   /* XCOFF archives do not have anything which corresponds to an
2944      extended name table.  */
2945   bfd_false,                            /* _slurp_extended_name_table */
2946   /* _construct_extended_name_table */
2947   ((boolean (*) (bfd *, char **, bfd_size_type *, const char **)) bfd_false),
2948   bfd_dont_truncate_arname,             /* _truncate_arname */
2949   _bfd_xcoff_write_armap,               /* _write_armap */
2950   _bfd_xcoff_read_ar_hdr,               /* _read_ar_hdr */
2951   xcoff64_openr_next_archived_file,     /* _openr_next_archived_file */
2952   _bfd_generic_get_elt_at_index,        /* _get_elt_at_index */
2953   _bfd_xcoff_stat_arch_elt,             /* _generic_stat_arch_elt */
2954   /* XCOFF archives do not have a timestamp.  */
2955   bfd_true,                             /* _update_armap_timestamp */
2956
2957   /* Symbols */
2958   coff_get_symtab_upper_bound,          /* _get_symtab_upper_bound */
2959   coff_get_symtab,                      /* _get_symtab */
2960   coff_make_empty_symbol,               /* _make_empty_symbol */
2961   coff_print_symbol,                    /* _print_symbol */
2962   coff_get_symbol_info,                 /* _get_symbol_info */
2963   _bfd_xcoff_is_local_label_name,       /* _bfd_is_local_label_name */
2964   coff_get_lineno,                      /* _get_lineno */
2965   coff_find_nearest_line,               /* _find_nearest_line */
2966   coff_bfd_make_debug_symbol,           /* _bfd_make_debug_symbol */
2967   _bfd_generic_read_minisymbols,        /* _read_minisymbols */
2968   _bfd_generic_minisymbol_to_symbol,    /* _minsymbol_to_symbol */
2969
2970   /* Reloc */
2971   coff_get_reloc_upper_bound,           /* _get_reloc_upper_bound */
2972   coff_canonicalize_reloc,              /* _cononicalize_reloc */
2973   xcoff64_reloc_type_lookup,            /* _bfd_reloc_type_lookup */
2974
2975   /* Write */
2976   coff_set_arch_mach,                   /* _set_arch_mach */
2977   coff_set_section_contents,            /* _set_section_contents */
2978
2979   /* Link */
2980   xcoff64_sizeof_headers,               /* _sizeof_headers */
2981   /* _bfd_get_relocated_section_contents */
2982   bfd_generic_get_relocated_section_contents,
2983   bfd_generic_relax_section,            /* _bfd_relax_section */
2984   _bfd_xcoff_bfd_link_hash_table_create,/* _bfd_link_hash_table_create */
2985   _bfd_generic_link_hash_table_free,    /* _bfd_link_hash_table_free */
2986   _bfd_xcoff_bfd_link_add_symbols,      /* _bfd_link_add_symbols */
2987   _bfd_generic_link_just_syms,          /* _bfd_link_just_syms */
2988   _bfd_xcoff_bfd_final_link,            /* _bfd_final_link */
2989   _bfd_generic_link_split_section,      /* _bfd_link_split_section */
2990   bfd_generic_gc_sections,              /* _bfd_gc_sections */
2991   bfd_generic_merge_sections,           /* _bfd_merge_sections */
2992   bfd_generic_discard_group,            /* _bfd_discard_group */
2993
2994   /* Dynamic */
2995   /* _get_dynamic_symtab_upper_bound */
2996   _bfd_xcoff_get_dynamic_symtab_upper_bound,
2997   _bfd_xcoff_canonicalize_dynamic_symtab,  /* _cononicalize_dynamic_symtab */
2998   _bfd_xcoff_get_dynamic_reloc_upper_bound,/* _get_dynamic_reloc_upper_bound */
2999   _bfd_xcoff_canonicalize_dynamic_reloc,   /* _cononicalize_dynamic_reloc */
3000
3001   /* Opposite endian version, none exists.  */
3002   NULL,
3003
3004   /* back end data */
3005   (void *) & bfd_xcoff_aix5_backend_data,
3006 };