bfd: xtensa: fix shrink_dynamic_reloc_sections for export-dynamic
[external/binutils.git] / bfd / ecoffswap.h
1 /* Generic ECOFF swapping routines, for BFD.
2    Copyright (C) 1992-2019 Free Software Foundation, Inc.
3    Written by Cygnus Support.
4
5    This file is part of BFD, the Binary File Descriptor library.
6
7    This program is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 3 of the License, or
10    (at your option) any later version.
11
12    This program is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15    GNU General Public License for more details.
16
17    You should have received a copy of the GNU General Public License
18    along with this program; if not, write to the Free Software
19    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
20    MA 02110-1301, USA.  */
21
22
23 /* NOTE: This is a header file, but it contains executable routines.
24    This is done this way because these routines are substantially
25    similar, but are not identical, for all ECOFF targets.
26
27    These are routines to swap the ECOFF symbolic information in and
28    out.  The routines are defined statically.  You can set breakpoints
29    on them in gdb by naming the including source file; e.g.,
30    'coff-mips.c':ecoff_swap_hdr_in.
31
32    Before including this header file, one of ECOFF_32, ECOFF_64,
33    ECOFF_SIGNED_32 or ECOFF_SIGNED_64 must be defined.  These are
34    checked when swapping information that depends upon the target
35    size.  This code works for 32 bit and 64 bit ECOFF, but may need to
36    be generalized in the future.
37
38    Some header file which defines the external forms of these
39    structures must also be included before including this header file.
40    Currently this is either coff/mips.h or coff/alpha.h.
41
42    If the symbol TEST is defined when this file is compiled, a
43    comparison is made to ensure that, in fact, the output is
44    bit-for-bit the same as the input.  Of course, this symbol should
45    only be defined when deliberately testing the code on a machine
46    with the proper byte sex and such.  */
47
48 #ifdef ECOFF_32
49 #define ECOFF_GET_OFF H_GET_32
50 #define ECOFF_PUT_OFF H_PUT_32
51 #endif
52 #ifdef ECOFF_64
53 #define ECOFF_GET_OFF H_GET_64
54 #define ECOFF_PUT_OFF H_PUT_64
55 #endif
56 #ifdef ECOFF_SIGNED_32
57 #define ECOFF_GET_OFF H_GET_S32
58 #define ECOFF_PUT_OFF H_PUT_S32
59 #endif
60 #ifdef ECOFF_SIGNED_64
61 #define ECOFF_GET_OFF H_GET_S64
62 #define ECOFF_PUT_OFF H_PUT_S64
63 #endif
64
65 /* ECOFF auxiliary information swapping routines.  These are the same
66    for all ECOFF targets, so they are defined in ecofflink.c.  */
67
68 extern void _bfd_ecoff_swap_tir_in
69   (int, const struct tir_ext *, TIR *);
70 extern void _bfd_ecoff_swap_tir_out
71   (int, const TIR *, struct tir_ext *);
72 extern void _bfd_ecoff_swap_rndx_in
73   (int, const struct rndx_ext *, RNDXR *);
74 extern void _bfd_ecoff_swap_rndx_out
75   (int, const RNDXR *, struct rndx_ext *);
76
77 /* Prototypes for functions defined in this file.  */
78
79 static void ecoff_swap_hdr_in (bfd *, void *, HDRR *);
80 static void ecoff_swap_hdr_out (bfd *, const HDRR *, void *);
81 static void ecoff_swap_fdr_in (bfd *, void *, FDR *);
82 static void ecoff_swap_fdr_out (bfd *, const FDR *, void *);
83 static void ecoff_swap_pdr_in (bfd *, void *, PDR *);
84 static void ecoff_swap_pdr_out (bfd *, const PDR *, void *);
85 static void ecoff_swap_sym_in (bfd *, void *, SYMR *);
86 static void ecoff_swap_sym_out (bfd *, const SYMR *, void *);
87 static void ecoff_swap_ext_in (bfd *, void *, EXTR *);
88 static void ecoff_swap_ext_out (bfd *, const EXTR *, void *);
89 static void ecoff_swap_rfd_in (bfd *, void *, RFDT *);
90 static void ecoff_swap_rfd_out (bfd *, const RFDT *, void *);
91 static void ecoff_swap_opt_in (bfd *, void *, OPTR *);
92 static void ecoff_swap_opt_out (bfd *, const OPTR *, void *);
93 static void ecoff_swap_dnr_in (bfd *, void *, DNR *);
94 static void ecoff_swap_dnr_out (bfd *, const DNR *, void *);
95
96 /* Swap in the symbolic header.  */
97
98 static void
99 ecoff_swap_hdr_in (bfd *abfd, void * ext_copy, HDRR *intern)
100 {
101   struct hdr_ext ext[1];
102
103   *ext = *(struct hdr_ext *) ext_copy;
104
105   intern->magic         = H_GET_S16     (abfd, ext->h_magic);
106   intern->vstamp        = H_GET_S16     (abfd, ext->h_vstamp);
107   intern->ilineMax      = H_GET_32      (abfd, ext->h_ilineMax);
108   intern->cbLine        = ECOFF_GET_OFF (abfd, ext->h_cbLine);
109   intern->cbLineOffset  = ECOFF_GET_OFF (abfd, ext->h_cbLineOffset);
110   intern->idnMax        = H_GET_32      (abfd, ext->h_idnMax);
111   intern->cbDnOffset    = ECOFF_GET_OFF (abfd, ext->h_cbDnOffset);
112   intern->ipdMax        = H_GET_32      (abfd, ext->h_ipdMax);
113   intern->cbPdOffset    = ECOFF_GET_OFF (abfd, ext->h_cbPdOffset);
114   intern->isymMax       = H_GET_32      (abfd, ext->h_isymMax);
115   intern->cbSymOffset   = ECOFF_GET_OFF (abfd, ext->h_cbSymOffset);
116   intern->ioptMax       = H_GET_32      (abfd, ext->h_ioptMax);
117   intern->cbOptOffset   = ECOFF_GET_OFF (abfd, ext->h_cbOptOffset);
118   intern->iauxMax       = H_GET_32      (abfd, ext->h_iauxMax);
119   intern->cbAuxOffset   = ECOFF_GET_OFF (abfd, ext->h_cbAuxOffset);
120   intern->issMax        = H_GET_32      (abfd, ext->h_issMax);
121   intern->cbSsOffset    = ECOFF_GET_OFF (abfd, ext->h_cbSsOffset);
122   intern->issExtMax     = H_GET_32      (abfd, ext->h_issExtMax);
123   intern->cbSsExtOffset = ECOFF_GET_OFF (abfd, ext->h_cbSsExtOffset);
124   intern->ifdMax        = H_GET_32      (abfd, ext->h_ifdMax);
125   intern->cbFdOffset    = ECOFF_GET_OFF (abfd, ext->h_cbFdOffset);
126   intern->crfd          = H_GET_32      (abfd, ext->h_crfd);
127   intern->cbRfdOffset   = ECOFF_GET_OFF (abfd, ext->h_cbRfdOffset);
128   intern->iextMax       = H_GET_32      (abfd, ext->h_iextMax);
129   intern->cbExtOffset   = ECOFF_GET_OFF (abfd, ext->h_cbExtOffset);
130
131 #ifdef TEST
132   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
133     abort ();
134 #endif
135 }
136
137 /* Swap out the symbolic header.  */
138
139 static void
140 ecoff_swap_hdr_out (bfd *abfd, const HDRR *intern_copy, void * ext_ptr)
141 {
142   struct hdr_ext *ext = (struct hdr_ext *) ext_ptr;
143   HDRR intern[1];
144
145   *intern = *intern_copy;
146
147   H_PUT_S16     (abfd, intern->magic,         ext->h_magic);
148   H_PUT_S16     (abfd, intern->vstamp,        ext->h_vstamp);
149   H_PUT_32      (abfd, intern->ilineMax,      ext->h_ilineMax);
150   ECOFF_PUT_OFF (abfd, intern->cbLine,        ext->h_cbLine);
151   ECOFF_PUT_OFF (abfd, intern->cbLineOffset,  ext->h_cbLineOffset);
152   H_PUT_32      (abfd, intern->idnMax,        ext->h_idnMax);
153   ECOFF_PUT_OFF (abfd, intern->cbDnOffset,    ext->h_cbDnOffset);
154   H_PUT_32      (abfd, intern->ipdMax,        ext->h_ipdMax);
155   ECOFF_PUT_OFF (abfd, intern->cbPdOffset,    ext->h_cbPdOffset);
156   H_PUT_32      (abfd, intern->isymMax,       ext->h_isymMax);
157   ECOFF_PUT_OFF (abfd, intern->cbSymOffset,   ext->h_cbSymOffset);
158   H_PUT_32      (abfd, intern->ioptMax,       ext->h_ioptMax);
159   ECOFF_PUT_OFF (abfd, intern->cbOptOffset,   ext->h_cbOptOffset);
160   H_PUT_32      (abfd, intern->iauxMax,       ext->h_iauxMax);
161   ECOFF_PUT_OFF (abfd, intern->cbAuxOffset,   ext->h_cbAuxOffset);
162   H_PUT_32      (abfd, intern->issMax,        ext->h_issMax);
163   ECOFF_PUT_OFF (abfd, intern->cbSsOffset,    ext->h_cbSsOffset);
164   H_PUT_32      (abfd, intern->issExtMax,     ext->h_issExtMax);
165   ECOFF_PUT_OFF (abfd, intern->cbSsExtOffset, ext->h_cbSsExtOffset);
166   H_PUT_32      (abfd, intern->ifdMax,        ext->h_ifdMax);
167   ECOFF_PUT_OFF (abfd, intern->cbFdOffset,    ext->h_cbFdOffset);
168   H_PUT_32      (abfd, intern->crfd,          ext->h_crfd);
169   ECOFF_PUT_OFF (abfd, intern->cbRfdOffset,   ext->h_cbRfdOffset);
170   H_PUT_32      (abfd, intern->iextMax,       ext->h_iextMax);
171   ECOFF_PUT_OFF (abfd, intern->cbExtOffset,   ext->h_cbExtOffset);
172
173 #ifdef TEST
174   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
175     abort ();
176 #endif
177 }
178
179 /* Swap in the file descriptor record.  */
180
181 static void
182 ecoff_swap_fdr_in (bfd *abfd, void * ext_copy, FDR *intern)
183 {
184   struct fdr_ext ext[1];
185
186   *ext = *(struct fdr_ext *) ext_copy;
187
188   intern->adr           = ECOFF_GET_OFF (abfd, ext->f_adr);
189   intern->rss           = H_GET_32 (abfd, ext->f_rss);
190 #if defined (ECOFF_64) || defined (ECOFF_SIGNED_64)
191   if (intern->rss == (signed long) 0xffffffff)
192     intern->rss = -1;
193 #endif
194   intern->issBase       = H_GET_32 (abfd, ext->f_issBase);
195   intern->cbSs          = ECOFF_GET_OFF (abfd, ext->f_cbSs);
196   intern->isymBase      = H_GET_32 (abfd, ext->f_isymBase);
197   intern->csym          = H_GET_32 (abfd, ext->f_csym);
198   intern->ilineBase     = H_GET_32 (abfd, ext->f_ilineBase);
199   intern->cline         = H_GET_32 (abfd, ext->f_cline);
200   intern->ioptBase      = H_GET_32 (abfd, ext->f_ioptBase);
201   intern->copt          = H_GET_32 (abfd, ext->f_copt);
202 #if defined (ECOFF_32) || defined (ECOFF_SIGNED_32)
203   intern->ipdFirst      = H_GET_16 (abfd, ext->f_ipdFirst);
204   intern->cpd           = H_GET_16 (abfd, ext->f_cpd);
205 #endif
206 #if defined (ECOFF_64) || defined (ECOFF_SIGNED_64)
207   intern->ipdFirst      = H_GET_32 (abfd, ext->f_ipdFirst);
208   intern->cpd           = H_GET_32 (abfd, ext->f_cpd);
209 #endif
210   intern->iauxBase      = H_GET_32 (abfd, ext->f_iauxBase);
211   intern->caux          = H_GET_32 (abfd, ext->f_caux);
212   intern->rfdBase       = H_GET_32 (abfd, ext->f_rfdBase);
213   intern->crfd          = H_GET_32 (abfd, ext->f_crfd);
214
215   /* Now the fun stuff...  */
216   if (bfd_header_big_endian (abfd))
217     {
218       intern->lang       = ((ext->f_bits1[0] & FDR_BITS1_LANG_BIG)
219                             >> FDR_BITS1_LANG_SH_BIG);
220       intern->fMerge     = 0 != (ext->f_bits1[0] & FDR_BITS1_FMERGE_BIG);
221       intern->fReadin    = 0 != (ext->f_bits1[0] & FDR_BITS1_FREADIN_BIG);
222       intern->fBigendian = 0 != (ext->f_bits1[0] & FDR_BITS1_FBIGENDIAN_BIG);
223       intern->glevel     = ((ext->f_bits2[0] & FDR_BITS2_GLEVEL_BIG)
224                             >> FDR_BITS2_GLEVEL_SH_BIG);
225     }
226   else
227     {
228       intern->lang       = ((ext->f_bits1[0] & FDR_BITS1_LANG_LITTLE)
229                             >> FDR_BITS1_LANG_SH_LITTLE);
230       intern->fMerge     = 0 != (ext->f_bits1[0] & FDR_BITS1_FMERGE_LITTLE);
231       intern->fReadin    = 0 != (ext->f_bits1[0] & FDR_BITS1_FREADIN_LITTLE);
232       intern->fBigendian = 0 != (ext->f_bits1[0] & FDR_BITS1_FBIGENDIAN_LITTLE);
233       intern->glevel     = ((ext->f_bits2[0] & FDR_BITS2_GLEVEL_LITTLE)
234                             >> FDR_BITS2_GLEVEL_SH_LITTLE);
235     }
236   intern->reserved = 0;
237
238   intern->cbLineOffset  = ECOFF_GET_OFF (abfd, ext->f_cbLineOffset);
239   intern->cbLine        = ECOFF_GET_OFF (abfd, ext->f_cbLine);
240
241 #ifdef TEST
242   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
243     abort ();
244 #endif
245 }
246
247 /* Swap out the file descriptor record.  */
248
249 static void
250 ecoff_swap_fdr_out (bfd *abfd, const FDR *intern_copy, void * ext_ptr)
251 {
252   struct fdr_ext *ext = (struct fdr_ext *) ext_ptr;
253   FDR intern[1];
254
255   /* Make it reasonable to do in-place.  */
256   *intern = *intern_copy;
257
258   ECOFF_PUT_OFF (abfd, intern->adr,       ext->f_adr);
259   H_PUT_32      (abfd, intern->rss,       ext->f_rss);
260   H_PUT_32      (abfd, intern->issBase,   ext->f_issBase);
261   ECOFF_PUT_OFF (abfd, intern->cbSs,      ext->f_cbSs);
262   H_PUT_32      (abfd, intern->isymBase,  ext->f_isymBase);
263   H_PUT_32      (abfd, intern->csym,      ext->f_csym);
264   H_PUT_32      (abfd, intern->ilineBase, ext->f_ilineBase);
265   H_PUT_32      (abfd, intern->cline,     ext->f_cline);
266   H_PUT_32      (abfd, intern->ioptBase,  ext->f_ioptBase);
267   H_PUT_32      (abfd, intern->copt,      ext->f_copt);
268 #if defined (ECOFF_32) || defined (ECOFF_SIGNED_32)
269   H_PUT_16      (abfd, intern->ipdFirst,  ext->f_ipdFirst);
270   H_PUT_16      (abfd, intern->cpd,       ext->f_cpd);
271 #endif
272 #if defined (ECOFF_64) || defined (ECOFF_SIGNED_64)
273   H_PUT_32      (abfd, intern->ipdFirst,  ext->f_ipdFirst);
274   H_PUT_32      (abfd, intern->cpd,       ext->f_cpd);
275 #endif
276   H_PUT_32      (abfd, intern->iauxBase,  ext->f_iauxBase);
277   H_PUT_32      (abfd, intern->caux,      ext->f_caux);
278   H_PUT_32      (abfd, intern->rfdBase,   ext->f_rfdBase);
279   H_PUT_32      (abfd, intern->crfd,      ext->f_crfd);
280
281   /* Now the fun stuff...  */
282   if (bfd_header_big_endian (abfd))
283     {
284       ext->f_bits1[0] = (((intern->lang << FDR_BITS1_LANG_SH_BIG)
285                           & FDR_BITS1_LANG_BIG)
286                          | (intern->fMerge ? FDR_BITS1_FMERGE_BIG : 0)
287                          | (intern->fReadin ? FDR_BITS1_FREADIN_BIG : 0)
288                          | (intern->fBigendian ? FDR_BITS1_FBIGENDIAN_BIG : 0));
289       ext->f_bits2[0] = ((intern->glevel << FDR_BITS2_GLEVEL_SH_BIG)
290                          & FDR_BITS2_GLEVEL_BIG);
291       ext->f_bits2[1] = 0;
292       ext->f_bits2[2] = 0;
293     }
294   else
295     {
296       ext->f_bits1[0] = (((intern->lang << FDR_BITS1_LANG_SH_LITTLE)
297                           & FDR_BITS1_LANG_LITTLE)
298                          | (intern->fMerge ? FDR_BITS1_FMERGE_LITTLE : 0)
299                          | (intern->fReadin ? FDR_BITS1_FREADIN_LITTLE : 0)
300                          | (intern->fBigendian ? FDR_BITS1_FBIGENDIAN_LITTLE : 0));
301       ext->f_bits2[0] = ((intern->glevel << FDR_BITS2_GLEVEL_SH_LITTLE)
302                          & FDR_BITS2_GLEVEL_LITTLE);
303       ext->f_bits2[1] = 0;
304       ext->f_bits2[2] = 0;
305     }
306
307   ECOFF_PUT_OFF (abfd, intern->cbLineOffset, ext->f_cbLineOffset);
308   ECOFF_PUT_OFF (abfd, intern->cbLine, ext->f_cbLine);
309
310 #ifdef TEST
311   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
312     abort ();
313 #endif
314 }
315
316 /* Swap in the procedure descriptor record.  */
317
318 static void
319 ecoff_swap_pdr_in (bfd *abfd, void * ext_copy, PDR *intern)
320 {
321   struct pdr_ext ext[1];
322
323   *ext = *(struct pdr_ext *) ext_copy;
324
325   memset ((void *) intern, 0, sizeof (*intern));
326
327   intern->adr           = ECOFF_GET_OFF (abfd, ext->p_adr);
328   intern->isym          = H_GET_32 (abfd, ext->p_isym);
329   intern->iline         = H_GET_32 (abfd, ext->p_iline);
330   intern->regmask       = H_GET_32 (abfd, ext->p_regmask);
331   intern->regoffset     = H_GET_S32 (abfd, ext->p_regoffset);
332   intern->iopt          = H_GET_S32 (abfd, ext->p_iopt);
333   intern->fregmask      = H_GET_32 (abfd, ext->p_fregmask);
334   intern->fregoffset    = H_GET_S32 (abfd, ext->p_fregoffset);
335   intern->frameoffset   = H_GET_S32 (abfd, ext->p_frameoffset);
336   intern->framereg      = H_GET_16 (abfd, ext->p_framereg);
337   intern->pcreg         = H_GET_16 (abfd, ext->p_pcreg);
338   intern->lnLow         = H_GET_32 (abfd, ext->p_lnLow);
339   intern->lnHigh        = H_GET_32 (abfd, ext->p_lnHigh);
340   intern->cbLineOffset  = ECOFF_GET_OFF (abfd, ext->p_cbLineOffset);
341
342 #if defined (ECOFF_64) || defined (ECOFF_SIGNED_64)
343   if (intern->isym == (signed long) 0xffffffff)
344     intern->isym = -1;
345   if (intern->iline == (signed long) 0xffffffff)
346     intern->iline = -1;
347
348   intern->gp_prologue = H_GET_8 (abfd, ext->p_gp_prologue);
349   if (bfd_header_big_endian (abfd))
350     {
351       intern->gp_used = 0 != (ext->p_bits1[0] & PDR_BITS1_GP_USED_BIG);
352       intern->reg_frame = 0 != (ext->p_bits1[0] & PDR_BITS1_REG_FRAME_BIG);
353       intern->prof = 0 != (ext->p_bits1[0] & PDR_BITS1_PROF_BIG);
354       intern->reserved = (((ext->p_bits1[0] & PDR_BITS1_RESERVED_BIG)
355                            << PDR_BITS1_RESERVED_SH_LEFT_BIG)
356                           | ((ext->p_bits2[0] & PDR_BITS2_RESERVED_BIG)
357                              >> PDR_BITS2_RESERVED_SH_BIG));
358     }
359   else
360     {
361       intern->gp_used = 0 != (ext->p_bits1[0] & PDR_BITS1_GP_USED_LITTLE);
362       intern->reg_frame = 0 != (ext->p_bits1[0] & PDR_BITS1_REG_FRAME_LITTLE);
363       intern->prof = 0 != (ext->p_bits1[0] & PDR_BITS1_PROF_LITTLE);
364       intern->reserved = (((ext->p_bits1[0] & PDR_BITS1_RESERVED_LITTLE)
365                            >> PDR_BITS1_RESERVED_SH_LITTLE)
366                           | ((ext->p_bits2[0] & PDR_BITS2_RESERVED_LITTLE)
367                              << PDR_BITS2_RESERVED_SH_LEFT_LITTLE));
368     }
369   intern->localoff = H_GET_8 (abfd, ext->p_localoff);
370 #endif
371
372 #ifdef TEST
373   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
374     abort ();
375 #endif
376 }
377
378 /* Swap out the procedure descriptor record.  */
379
380 static void
381 ecoff_swap_pdr_out (bfd *abfd, const PDR *intern_copy, void * ext_ptr)
382 {
383   struct pdr_ext *ext = (struct pdr_ext *) ext_ptr;
384   PDR intern[1];
385
386   /* Make it reasonable to do in-place.  */
387   *intern = *intern_copy;
388
389   ECOFF_PUT_OFF (abfd, intern->adr,          ext->p_adr);
390   H_PUT_32      (abfd, intern->isym,         ext->p_isym);
391   H_PUT_32      (abfd, intern->iline,        ext->p_iline);
392   H_PUT_32      (abfd, intern->regmask,      ext->p_regmask);
393   H_PUT_32      (abfd, intern->regoffset,    ext->p_regoffset);
394   H_PUT_32      (abfd, intern->iopt,         ext->p_iopt);
395   H_PUT_32      (abfd, intern->fregmask,     ext->p_fregmask);
396   H_PUT_32      (abfd, intern->fregoffset,   ext->p_fregoffset);
397   H_PUT_32      (abfd, intern->frameoffset,  ext->p_frameoffset);
398   H_PUT_16      (abfd, intern->framereg,     ext->p_framereg);
399   H_PUT_16      (abfd, intern->pcreg,        ext->p_pcreg);
400   H_PUT_32      (abfd, intern->lnLow,        ext->p_lnLow);
401   H_PUT_32      (abfd, intern->lnHigh,       ext->p_lnHigh);
402   ECOFF_PUT_OFF (abfd, intern->cbLineOffset, ext->p_cbLineOffset);
403
404 #if defined (ECOFF_64) || defined (ECOFF_SIGNED_64)
405   H_PUT_8       (abfd, intern->gp_prologue,  ext->p_gp_prologue);
406
407   if (bfd_header_big_endian (abfd))
408     {
409       ext->p_bits1[0] = ((intern->gp_used ? PDR_BITS1_GP_USED_BIG : 0)
410                          | (intern->reg_frame ? PDR_BITS1_REG_FRAME_BIG : 0)
411                          | (intern->prof ? PDR_BITS1_PROF_BIG : 0)
412                          | ((intern->reserved
413                              >> PDR_BITS1_RESERVED_SH_LEFT_BIG)
414                             & PDR_BITS1_RESERVED_BIG));
415       ext->p_bits2[0] = ((intern->reserved << PDR_BITS2_RESERVED_SH_BIG)
416                          & PDR_BITS2_RESERVED_BIG);
417     }
418   else
419     {
420       ext->p_bits1[0] = ((intern->gp_used ? PDR_BITS1_GP_USED_LITTLE : 0)
421                          | (intern->reg_frame ? PDR_BITS1_REG_FRAME_LITTLE : 0)
422                          | (intern->prof ? PDR_BITS1_PROF_LITTLE : 0)
423                          | ((intern->reserved << PDR_BITS1_RESERVED_SH_LITTLE)
424                             & PDR_BITS1_RESERVED_LITTLE));
425       ext->p_bits2[0] = ((intern->reserved >>
426                           PDR_BITS2_RESERVED_SH_LEFT_LITTLE)
427                          & PDR_BITS2_RESERVED_LITTLE);
428     }
429   H_PUT_8 (abfd, intern->localoff, ext->p_localoff);
430 #endif
431
432 #ifdef TEST
433   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
434     abort ();
435 #endif
436 }
437
438 /* Swap in a symbol record.  */
439
440 static void
441 ecoff_swap_sym_in (bfd *abfd, void * ext_copy, SYMR *intern)
442 {
443   struct sym_ext ext[1];
444
445   *ext = *(struct sym_ext *) ext_copy;
446
447   intern->iss           = H_GET_32 (abfd, ext->s_iss);
448   intern->value         = ECOFF_GET_OFF (abfd, ext->s_value);
449
450 #if defined (ECOFF_64) || defined (ECOFF_SIGNED_64)
451   if (intern->iss == (signed long) 0xffffffff)
452     intern->iss = -1;
453 #endif
454
455   /* Now the fun stuff...  */
456   if (bfd_header_big_endian (abfd))
457     {
458       intern->st          =  (ext->s_bits1[0] & SYM_BITS1_ST_BIG)
459                                              >> SYM_BITS1_ST_SH_BIG;
460       intern->sc          = ((ext->s_bits1[0] & SYM_BITS1_SC_BIG)
461                                              << SYM_BITS1_SC_SH_LEFT_BIG)
462                           | ((ext->s_bits2[0] & SYM_BITS2_SC_BIG)
463                                              >> SYM_BITS2_SC_SH_BIG);
464       intern->reserved    = 0 != (ext->s_bits2[0] & SYM_BITS2_RESERVED_BIG);
465       intern->index       = ((ext->s_bits2[0] & SYM_BITS2_INDEX_BIG)
466                                              << SYM_BITS2_INDEX_SH_LEFT_BIG)
467                           | (ext->s_bits3[0] << SYM_BITS3_INDEX_SH_LEFT_BIG)
468                           | (ext->s_bits4[0] << SYM_BITS4_INDEX_SH_LEFT_BIG);
469     }
470   else
471     {
472       intern->st          =  (ext->s_bits1[0] & SYM_BITS1_ST_LITTLE)
473                                              >> SYM_BITS1_ST_SH_LITTLE;
474       intern->sc          = ((ext->s_bits1[0] & SYM_BITS1_SC_LITTLE)
475                                              >> SYM_BITS1_SC_SH_LITTLE)
476                           | ((ext->s_bits2[0] & SYM_BITS2_SC_LITTLE)
477                                              << SYM_BITS2_SC_SH_LEFT_LITTLE);
478       intern->reserved    = 0 != (ext->s_bits2[0] & SYM_BITS2_RESERVED_LITTLE);
479       intern->index       = ((ext->s_bits2[0] & SYM_BITS2_INDEX_LITTLE)
480                                              >> SYM_BITS2_INDEX_SH_LITTLE)
481                           | (ext->s_bits3[0] << SYM_BITS3_INDEX_SH_LEFT_LITTLE)
482                           | ((unsigned int) ext->s_bits4[0]
483                              << SYM_BITS4_INDEX_SH_LEFT_LITTLE);
484     }
485
486 #ifdef TEST
487   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
488     abort ();
489 #endif
490 }
491
492 /* Swap out a symbol record.  */
493
494 static void
495 ecoff_swap_sym_out (bfd *abfd, const SYMR *intern_copy, void * ext_ptr)
496 {
497   struct sym_ext *ext = (struct sym_ext *) ext_ptr;
498   SYMR intern[1];
499
500   /* Make it reasonable to do in-place.  */
501   *intern = *intern_copy;
502
503   H_PUT_32 (abfd, intern->iss, ext->s_iss);
504   ECOFF_PUT_OFF (abfd, intern->value, ext->s_value);
505
506   /* Now the fun stuff...  */
507   if (bfd_header_big_endian (abfd))
508     {
509       ext->s_bits1[0] = (((intern->st << SYM_BITS1_ST_SH_BIG)
510                           & SYM_BITS1_ST_BIG)
511                          | ((intern->sc >> SYM_BITS1_SC_SH_LEFT_BIG)
512                             & SYM_BITS1_SC_BIG));
513       ext->s_bits2[0] = (((intern->sc << SYM_BITS2_SC_SH_BIG)
514                           & SYM_BITS2_SC_BIG)
515                          | (intern->reserved ? SYM_BITS2_RESERVED_BIG : 0)
516                          | ((intern->index >> SYM_BITS2_INDEX_SH_LEFT_BIG)
517                             & SYM_BITS2_INDEX_BIG));
518       ext->s_bits3[0] = (intern->index >> SYM_BITS3_INDEX_SH_LEFT_BIG) & 0xff;
519       ext->s_bits4[0] = (intern->index >> SYM_BITS4_INDEX_SH_LEFT_BIG) & 0xff;
520     }
521   else
522     {
523       ext->s_bits1[0] = (((intern->st << SYM_BITS1_ST_SH_LITTLE)
524                           & SYM_BITS1_ST_LITTLE)
525                          | ((intern->sc << SYM_BITS1_SC_SH_LITTLE)
526                             & SYM_BITS1_SC_LITTLE));
527       ext->s_bits2[0] = (((intern->sc >> SYM_BITS2_SC_SH_LEFT_LITTLE)
528                           & SYM_BITS2_SC_LITTLE)
529                          | (intern->reserved ? SYM_BITS2_RESERVED_LITTLE : 0)
530                          | ((intern->index << SYM_BITS2_INDEX_SH_LITTLE)
531                             & SYM_BITS2_INDEX_LITTLE));
532       ext->s_bits3[0] = (intern->index >> SYM_BITS3_INDEX_SH_LEFT_LITTLE) & 0xff;
533       ext->s_bits4[0] = (intern->index >> SYM_BITS4_INDEX_SH_LEFT_LITTLE) & 0xff;
534     }
535
536 #ifdef TEST
537   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
538     abort ();
539 #endif
540 }
541
542 /* Swap in an external symbol record.  */
543
544 static void
545 ecoff_swap_ext_in (bfd *abfd, void * ext_copy, EXTR *intern)
546 {
547   struct ext_ext ext[1];
548
549   *ext = *(struct ext_ext *) ext_copy;
550
551   /* Now the fun stuff...  */
552   if (bfd_header_big_endian (abfd))
553     {
554       intern->jmptbl      = 0 != (ext->es_bits1[0] & EXT_BITS1_JMPTBL_BIG);
555       intern->cobol_main  = 0 != (ext->es_bits1[0] & EXT_BITS1_COBOL_MAIN_BIG);
556       intern->weakext     = 0 != (ext->es_bits1[0] & EXT_BITS1_WEAKEXT_BIG);
557     }
558   else
559     {
560       intern->jmptbl      = 0 != (ext->es_bits1[0] & EXT_BITS1_JMPTBL_LITTLE);
561       intern->cobol_main  = 0 != (ext->es_bits1[0] & EXT_BITS1_COBOL_MAIN_LITTLE);
562       intern->weakext     = 0 != (ext->es_bits1[0] & EXT_BITS1_WEAKEXT_LITTLE);
563     }
564   intern->reserved = 0;
565
566 #if defined (ECOFF_32) || defined (ECOFF_SIGNED_32)
567   intern->ifd = H_GET_S16 (abfd, ext->es_ifd);
568 #endif
569 #if defined (ECOFF_64) || defined (ECOFF_SIGNED_64)
570   intern->ifd = H_GET_S32 (abfd, ext->es_ifd);
571 #endif
572
573   ecoff_swap_sym_in (abfd, &ext->es_asym, &intern->asym);
574
575 #ifdef TEST
576   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
577     abort ();
578 #endif
579 }
580
581 /* Swap out an external symbol record.  */
582
583 static void
584 ecoff_swap_ext_out (bfd *abfd, const EXTR *intern_copy, void * ext_ptr)
585 {
586   struct ext_ext *ext = (struct ext_ext *) ext_ptr;
587   EXTR intern[1];
588
589   /* Make it reasonable to do in-place.  */
590   *intern = *intern_copy;
591
592   /* Now the fun stuff...  */
593   if (bfd_header_big_endian (abfd))
594     {
595       ext->es_bits1[0] = ((intern->jmptbl ? EXT_BITS1_JMPTBL_BIG : 0)
596                           | (intern->cobol_main ? EXT_BITS1_COBOL_MAIN_BIG : 0)
597                           | (intern->weakext ? EXT_BITS1_WEAKEXT_BIG : 0));
598       ext->es_bits2[0] = 0;
599 #if defined (ECOFF_64) || defined (ECOFF_SIGNED_64)
600       ext->es_bits2[1] = 0;
601       ext->es_bits2[2] = 0;
602 #endif
603     }
604   else
605     {
606       ext->es_bits1[0] = ((intern->jmptbl ? EXT_BITS1_JMPTBL_LITTLE : 0)
607                           | (intern->cobol_main ? EXT_BITS1_COBOL_MAIN_LITTLE : 0)
608                           | (intern->weakext ? EXT_BITS1_WEAKEXT_LITTLE : 0));
609       ext->es_bits2[0] = 0;
610 #if defined (ECOFF_64) || defined (ECOFF_SIGNED_64)
611       ext->es_bits2[1] = 0;
612       ext->es_bits2[2] = 0;
613 #endif
614     }
615
616 #if defined (ECOFF_32) || defined (ECOFF_SIGNED_32)
617   H_PUT_S16 (abfd, intern->ifd, ext->es_ifd);
618 #endif
619 #if defined (ECOFF_64) || defined (ECOFF_SIGNED_64)
620   H_PUT_S32 (abfd, intern->ifd, ext->es_ifd);
621 #endif
622
623   ecoff_swap_sym_out (abfd, &intern->asym, &ext->es_asym);
624
625 #ifdef TEST
626   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
627     abort ();
628 #endif
629 }
630
631 /* Swap in a relative file descriptor.  */
632
633 static void
634 ecoff_swap_rfd_in (bfd *abfd, void * ext_ptr, RFDT *intern)
635 {
636   struct rfd_ext *ext = (struct rfd_ext *) ext_ptr;
637
638   *intern = H_GET_32 (abfd, ext->rfd);
639
640 #ifdef TEST
641   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
642     abort ();
643 #endif
644 }
645
646 /* Swap out a relative file descriptor.  */
647
648 static void
649 ecoff_swap_rfd_out (bfd *abfd, const RFDT *intern, void * ext_ptr)
650 {
651   struct rfd_ext *ext = (struct rfd_ext *) ext_ptr;
652
653   H_PUT_32 (abfd, *intern, ext->rfd);
654
655 #ifdef TEST
656   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
657     abort ();
658 #endif
659 }
660
661 /* Swap in an optimization symbol.  */
662
663 static void
664 ecoff_swap_opt_in (bfd *abfd, void * ext_copy, OPTR * intern)
665 {
666   struct opt_ext ext[1];
667
668   *ext = *(struct opt_ext *) ext_copy;
669
670   if (bfd_header_big_endian (abfd))
671     {
672       intern->ot = ext->o_bits1[0];
673       intern->value = (((unsigned int) ext->o_bits2[0]
674                         << OPT_BITS2_VALUE_SH_LEFT_BIG)
675                        | ((unsigned int) ext->o_bits3[0]
676                           << OPT_BITS2_VALUE_SH_LEFT_BIG)
677                        | ((unsigned int) ext->o_bits4[0]
678                           << OPT_BITS2_VALUE_SH_LEFT_BIG));
679     }
680   else
681     {
682       intern->ot = ext->o_bits1[0];
683       intern->value = ((ext->o_bits2[0] << OPT_BITS2_VALUE_SH_LEFT_LITTLE)
684                        | (ext->o_bits3[0] << OPT_BITS2_VALUE_SH_LEFT_LITTLE)
685                        | (ext->o_bits4[0] << OPT_BITS2_VALUE_SH_LEFT_LITTLE));
686     }
687
688   _bfd_ecoff_swap_rndx_in (bfd_header_big_endian (abfd),
689                            &ext->o_rndx, &intern->rndx);
690
691   intern->offset = H_GET_32 (abfd, ext->o_offset);
692
693 #ifdef TEST
694   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
695     abort ();
696 #endif
697 }
698
699 /* Swap out an optimization symbol.  */
700
701 static void
702 ecoff_swap_opt_out (bfd *abfd, const OPTR *intern_copy, void * ext_ptr)
703 {
704   struct opt_ext *ext = (struct opt_ext *) ext_ptr;
705   OPTR intern[1];
706
707   /* Make it reasonable to do in-place.  */
708   *intern = *intern_copy;
709
710   if (bfd_header_big_endian (abfd))
711     {
712       ext->o_bits1[0] = intern->ot;
713       ext->o_bits2[0] = intern->value >> OPT_BITS2_VALUE_SH_LEFT_BIG;
714       ext->o_bits3[0] = intern->value >> OPT_BITS3_VALUE_SH_LEFT_BIG;
715       ext->o_bits4[0] = intern->value >> OPT_BITS4_VALUE_SH_LEFT_BIG;
716     }
717   else
718     {
719       ext->o_bits1[0] = intern->ot;
720       ext->o_bits2[0] = intern->value >> OPT_BITS2_VALUE_SH_LEFT_LITTLE;
721       ext->o_bits3[0] = intern->value >> OPT_BITS3_VALUE_SH_LEFT_LITTLE;
722       ext->o_bits4[0] = intern->value >> OPT_BITS4_VALUE_SH_LEFT_LITTLE;
723     }
724
725   _bfd_ecoff_swap_rndx_out (bfd_header_big_endian (abfd),
726                             &intern->rndx, &ext->o_rndx);
727
728   H_PUT_32 (abfd, intern->value, ext->o_offset);
729
730 #ifdef TEST
731   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
732     abort ();
733 #endif
734 }
735
736 /* Swap in a dense number.  */
737
738 static void
739 ecoff_swap_dnr_in (bfd *abfd, void * ext_copy, DNR *intern)
740 {
741   struct dnr_ext ext[1];
742
743   *ext = *(struct dnr_ext *) ext_copy;
744
745   intern->rfd = H_GET_32 (abfd, ext->d_rfd);
746   intern->index = H_GET_32 (abfd, ext->d_index);
747
748 #ifdef TEST
749   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
750     abort ();
751 #endif
752 }
753
754 /* Swap out a dense number.  */
755
756 static void
757 ecoff_swap_dnr_out (bfd *abfd, const DNR *intern_copy, void * ext_ptr)
758 {
759   struct dnr_ext *ext = (struct dnr_ext *) ext_ptr;
760   DNR intern[1];
761
762   /* Make it reasonable to do in-place.  */
763   *intern = *intern_copy;
764
765   H_PUT_32 (abfd, intern->rfd, ext->d_rfd);
766   H_PUT_32 (abfd, intern->index, ext->d_index);
767
768 #ifdef TEST
769   if (memcmp ((char *) ext, (char *) intern, sizeof (*intern)) != 0)
770     abort ();
771 #endif
772 }