Coverage Report

Created: 2023-06-29 07:03

/src/binutils-gdb/bfd/coffcode.h
Line
Count
Source (jump to first uncovered line)
1
/* Support for the generic parts of most COFF variants, for BFD.
2
   Copyright (C) 1990-2023 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
/* Most of this hacked by  Steve Chamberlain,
23
      sac@cygnus.com.  */
24
/*
25
SECTION
26
  coff backends
27
28
  BFD supports a number of different flavours of coff format.
29
  The major differences between formats are the sizes and
30
  alignments of fields in structures on disk, and the occasional
31
  extra field.
32
33
  Coff in all its varieties is implemented with a few common
34
  files and a number of implementation specific files. For
35
  example, the i386 coff format is implemented in the file
36
  @file{coff-i386.c}.  This file @code{#include}s
37
  @file{coff/i386.h} which defines the external structure of the
38
  coff format for the i386, and @file{coff/internal.h} which
39
  defines the internal structure. @file{coff-i386.c} also
40
  defines the relocations used by the i386 coff format
41
  @xref{Relocations}.
42
43
SUBSECTION
44
  Porting to a new version of coff
45
46
  The recommended method is to select from the existing
47
  implementations the version of coff which is most like the one
48
  you want to use.  For example, we'll say that i386 coff is
49
  the one you select, and that your coff flavour is called foo.
50
  Copy @file{i386coff.c} to @file{foocoff.c}, copy
51
  @file{../include/coff/i386.h} to @file{../include/coff/foo.h},
52
  and add the lines to @file{targets.c} and @file{Makefile.in}
53
  so that your new back end is used. Alter the shapes of the
54
  structures in @file{../include/coff/foo.h} so that they match
55
  what you need. You will probably also have to add
56
  @code{#ifdef}s to the code in @file{coff/internal.h} and
57
  @file{coffcode.h} if your version of coff is too wild.
58
59
  You can verify that your new BFD backend works quite simply by
60
  building @file{objdump} from the @file{binutils} directory,
61
  and making sure that its version of what's going on and your
62
  host system's idea (assuming it has the pretty standard coff
63
  dump utility, usually called @code{att-dump} or just
64
  @code{dump}) are the same.  Then clean up your code, and send
65
  what you've done to Cygnus. Then your stuff will be in the
66
  next release, and you won't have to keep integrating it.
67
68
SUBSECTION
69
  How the coff backend works
70
71
SUBSUBSECTION
72
  File layout
73
74
  The Coff backend is split into generic routines that are
75
  applicable to any Coff target and routines that are specific
76
  to a particular target.  The target-specific routines are
77
  further split into ones which are basically the same for all
78
  Coff targets except that they use the external symbol format
79
  or use different values for certain constants.
80
81
  The generic routines are in @file{coffgen.c}.  These routines
82
  work for any Coff target.  They use some hooks into the target
83
  specific code; the hooks are in a @code{bfd_coff_backend_data}
84
  structure, one of which exists for each target.
85
86
  The essentially similar target-specific routines are in
87
  @file{coffcode.h}.  This header file includes executable C code.
88
  The various Coff targets first include the appropriate Coff
89
  header file, make any special defines that are needed, and
90
  then include @file{coffcode.h}.
91
92
  Some of the Coff targets then also have additional routines in
93
  the target source file itself.
94
95
SUBSUBSECTION
96
  Coff long section names
97
98
  In the standard Coff object format, section names are limited to
99
  the eight bytes available in the @code{s_name} field of the
100
  @code{SCNHDR} section header structure.  The format requires the
101
  field to be NUL-padded, but not necessarily NUL-terminated, so
102
  the longest section names permitted are a full eight characters.
103
104
  The Microsoft PE variants of the Coff object file format add
105
  an extension to support the use of long section names.  This
106
  extension is defined in section 4 of the Microsoft PE/COFF
107
  specification (rev 8.1).  If a section name is too long to fit
108
  into the section header's @code{s_name} field, it is instead
109
  placed into the string table, and the @code{s_name} field is
110
  filled with a slash ("/") followed by the ASCII decimal
111
  representation of the offset of the full name relative to the
112
  string table base.
113
114
  Note that this implies that the extension can only be used in object
115
  files, as executables do not contain a string table.  The standard
116
  specifies that long section names from objects emitted into executable
117
  images are to be truncated.
118
119
  However, as a GNU extension, BFD can generate executable images
120
  that contain a string table and long section names.  This
121
  would appear to be technically valid, as the standard only says
122
  that Coff debugging information is deprecated, not forbidden,
123
  and in practice it works, although some tools that parse PE files
124
  expecting the MS standard format may become confused; @file{PEview} is
125
  one known example.
126
127
  The functionality is supported in BFD by code implemented under
128
  the control of the macro @code{COFF_LONG_SECTION_NAMES}.  If not
129
  defined, the format does not support long section names in any way.
130
  If defined, it is used to initialise a flag,
131
  @code{_bfd_coff_long_section_names}, and a hook function pointer,
132
  @code{_bfd_coff_set_long_section_names}, in the Coff backend data
133
  structure.  The flag controls the generation of long section names
134
  in output BFDs at runtime; if it is false, as it will be by default
135
  when generating an executable image, long section names are truncated;
136
  if true, the long section names extension is employed.  The hook
137
  points to a function that allows the value of a copy of the flag
138
  in coff object tdata to be altered at runtime, on formats that
139
  support long section names at all; on other formats it points
140
  to a stub that returns an error indication.
141
142
  With input BFDs, the flag is set according to whether any long section
143
  names are detected while reading the section headers.  For a completely
144
  new BFD, the flag is set to the default for the target format.  This
145
  information can be used by a client of the BFD library when deciding
146
  what output format to generate, and means that a BFD that is opened
147
  for read and subsequently converted to a writeable BFD and modified
148
  in-place will retain whatever format it had on input.
149
150
  If @code{COFF_LONG_SECTION_NAMES} is simply defined (blank), or is
151
  defined to the value "1", then long section names are enabled by
152
  default; if it is defined to the value zero, they are disabled by
153
  default (but still accepted in input BFDs).  The header @file{coffcode.h}
154
  defines a macro, @code{COFF_DEFAULT_LONG_SECTION_NAMES}, which is
155
  used in the backends to initialise the backend data structure fields
156
  appropriately; see the comments for further detail.
157
158
SUBSUBSECTION
159
  Bit twiddling
160
161
  Each flavour of coff supported in BFD has its own header file
162
  describing the external layout of the structures. There is also
163
  an internal description of the coff layout, in
164
  @file{coff/internal.h}. A major function of the
165
  coff backend is swapping the bytes and twiddling the bits to
166
  translate the external form of the structures into the normal
167
  internal form. This is all performed in the
168
  @code{bfd_swap}_@i{thing}_@i{direction} routines. Some
169
  elements are different sizes between different versions of
170
  coff; it is the duty of the coff version specific include file
171
  to override the definitions of various packing routines in
172
  @file{coffcode.h}. E.g., the size of line number entry in coff is
173
  sometimes 16 bits, and sometimes 32 bits. @code{#define}ing
174
  @code{PUT_LNSZ_LNNO} and @code{GET_LNSZ_LNNO} will select the
175
  correct one. No doubt, some day someone will find a version of
176
  coff which has a varying field size not catered to at the
177
  moment. To port BFD, that person will have to add more @code{#defines}.
178
  Three of the bit twiddling routines are exported to
179
  @code{gdb}; @code{coff_swap_aux_in}, @code{coff_swap_sym_in}
180
  and @code{coff_swap_lineno_in}. @code{GDB} reads the symbol
181
  table on its own, but uses BFD to fix things up.  More of the
182
  bit twiddlers are exported for @code{gas};
183
  @code{coff_swap_aux_out}, @code{coff_swap_sym_out},
184
  @code{coff_swap_lineno_out}, @code{coff_swap_reloc_out},
185
  @code{coff_swap_filehdr_out}, @code{coff_swap_aouthdr_out},
186
  @code{coff_swap_scnhdr_out}. @code{Gas} currently keeps track
187
  of all the symbol table and reloc drudgery itself, thereby
188
  saving the internal BFD overhead, but uses BFD to swap things
189
  on the way out, making cross ports much safer.  Doing so also
190
  allows BFD (and thus the linker) to use the same header files
191
  as @code{gas}, which makes one avenue to disaster disappear.
192
193
SUBSUBSECTION
194
  Symbol reading
195
196
  The simple canonical form for symbols used by BFD is not rich
197
  enough to keep all the information available in a coff symbol
198
  table. The back end gets around this problem by keeping the original
199
  symbol table around, "behind the scenes".
200
201
  When a symbol table is requested (through a call to
202
  @code{bfd_canonicalize_symtab}), a request gets through to
203
  @code{coff_get_normalized_symtab}. This reads the symbol table from
204
  the coff file and swaps all the structures inside into the
205
  internal form. It also fixes up all the pointers in the table
206
  (represented in the file by offsets from the first symbol in
207
  the table) into physical pointers to elements in the new
208
  internal table. This involves some work since the meanings of
209
  fields change depending upon context: a field that is a
210
  pointer to another structure in the symbol table at one moment
211
  may be the size in bytes of a structure at the next.  Another
212
  pass is made over the table. All symbols which mark file names
213
  (<<C_FILE>> symbols) are modified so that the internal
214
  string points to the value in the auxent (the real filename)
215
  rather than the normal text associated with the symbol
216
  (@code{".file"}).
217
218
  At this time the symbol names are moved around. Coff stores
219
  all symbols less than nine characters long physically
220
  within the symbol table; longer strings are kept at the end of
221
  the file in the string table. This pass moves all strings
222
  into memory and replaces them with pointers to the strings.
223
224
  The symbol table is massaged once again, this time to create
225
  the canonical table used by the BFD application. Each symbol
226
  is inspected in turn, and a decision made (using the
227
  @code{sclass} field) about the various flags to set in the
228
  @code{asymbol}.  @xref{Symbols}. The generated canonical table
229
  shares strings with the hidden internal symbol table.
230
231
  Any linenumbers are read from the coff file too, and attached
232
  to the symbols which own the functions the linenumbers belong to.
233
234
SUBSUBSECTION
235
  Symbol writing
236
237
  Writing a symbol to a coff file which didn't come from a coff
238
  file will lose any debugging information. The @code{asymbol}
239
  structure remembers the BFD from which the symbol was taken, and on
240
  output the back end makes sure that the same destination target as
241
  source target is present.
242
243
  When the symbols have come from a coff file then all the
244
  debugging information is preserved.
245
246
  Symbol tables are provided for writing to the back end in a
247
  vector of pointers to pointers. This allows applications like
248
  the linker to accumulate and output large symbol tables
249
  without having to do too much byte copying.
250
251
  This function runs through the provided symbol table and
252
  patches each symbol marked as a file place holder
253
  (@code{C_FILE}) to point to the next file place holder in the
254
  list. It also marks each @code{offset} field in the list with
255
  the offset from the first symbol of the current symbol.
256
257
  Another function of this procedure is to turn the canonical
258
  value form of BFD into the form used by coff. Internally, BFD
259
  expects symbol values to be offsets from a section base; so a
260
  symbol physically at 0x120, but in a section starting at
261
  0x100, would have the value 0x20. Coff expects symbols to
262
  contain their final value, so symbols have their values
263
  changed at this point to reflect their sum with their owning
264
  section.  This transformation uses the
265
  <<output_section>> field of the @code{asymbol}'s
266
  @code{asection} @xref{Sections}.
267
268
  o <<coff_mangle_symbols>>
269
270
  This routine runs though the provided symbol table and uses
271
  the offsets generated by the previous pass and the pointers
272
  generated when the symbol table was read in to create the
273
  structured hierarchy required by coff. It changes each pointer
274
  to a symbol into the index into the symbol table of the asymbol.
275
276
  o <<coff_write_symbols>>
277
278
  This routine runs through the symbol table and patches up the
279
  symbols from their internal form into the coff way, calls the
280
  bit twiddlers, and writes out the table to the file.
281
282
*/
283
284
/*
285
INTERNAL_DEFINITION
286
  coff_symbol_type
287
288
DESCRIPTION
289
  The hidden information for an <<asymbol>> is described in a
290
  <<combined_entry_type>>:
291
292
CODE_FRAGMENT
293
.typedef struct coff_ptr_struct
294
.{
295
.  {* Remembers the offset from the first symbol in the file for
296
.     this symbol.  Generated by coff_renumber_symbols.  *}
297
.  unsigned int offset;
298
.
299
.  {* Selects between the elements of the union below.  *}
300
.  unsigned int is_sym : 1;
301
.
302
.  {* Selects between the elements of the x_sym.x_tagndx union.  If set,
303
.     p is valid and the field will be renumbered.  *}
304
.  unsigned int fix_tag : 1;
305
.
306
.  {* Selects between the elements of the x_sym.x_fcnary.x_fcn.x_endndx
307
.     union.  If set, p is valid and the field will be renumbered.  *}
308
.  unsigned int fix_end : 1;
309
.
310
.  {* Selects between the elements of the x_csect.x_scnlen union.  If set,
311
.     p is valid and the field will be renumbered.  *}
312
.  unsigned int fix_scnlen : 1;
313
.
314
.  {* If set, u.syment.n_value contains a pointer to a symbol.  The final
315
.     value will be the offset field.  Used for XCOFF C_BSTAT symbols.  *}
316
.  unsigned int fix_value : 1;
317
.
318
.  {* If set, u.syment.n_value is an index into the line number entries.
319
.     Used for XCOFF C_BINCL/C_EINCL symbols.  *}
320
.  unsigned int fix_line : 1;
321
.
322
.  {* The container for the symbol structure as read and translated
323
.     from the file.  *}
324
.  union
325
.  {
326
.    union internal_auxent auxent;
327
.    struct internal_syment syment;
328
.  } u;
329
.
330
. {* An extra pointer which can used by format based on COFF (like XCOFF)
331
.    to provide extra information to their backend.  *}
332
. void *extrap;
333
.} combined_entry_type;
334
.
335
.{* Each canonical asymbol really looks like this: *}
336
.
337
.typedef struct coff_symbol_struct
338
.{
339
.  {* The actual symbol which the rest of BFD works with *}
340
.  asymbol symbol;
341
.
342
.  {* A pointer to the hidden information for this symbol *}
343
.  combined_entry_type *native;
344
.
345
.  {* A pointer to the linenumber information for this symbol *}
346
.  struct lineno_cache_entry *lineno;
347
.
348
.  {* Have the line numbers been relocated yet ? *}
349
.  bool done_lineno;
350
.} coff_symbol_type;
351
.
352
*/
353
354
#include "libiberty.h"
355
356
#ifdef COFF_WITH_PE
357
#include "peicode.h"
358
#else
359
#include "coffswap.h"
360
#endif
361
362
0
#define STRING_SIZE_SIZE 4
363
364
170k
#define DOT_DEBUG ".debug"
365
168k
#define DOT_ZDEBUG  ".zdebug"
366
127k
#define GNU_LINKONCE_WI ".gnu.linkonce.wi."
367
127k
#define GNU_LINKONCE_WT ".gnu.linkonce.wt."
368
0
#define DOT_RELOC ".reloc"
369
370
#if defined(COFF_WITH_PE) || defined(COFF_GO32_EXE) || defined(COFF_GO32)
371
# define COFF_WITH_EXTENDED_RELOC_COUNTER
372
#endif
373
374
#if defined (COFF_LONG_SECTION_NAMES)
375
/* Needed to expand the inputs to BLANKOR1TOODD.  */
376
#define COFFLONGSECTIONCATHELPER(x,y)    x ## y
377
/* If the input macro Y is blank or '1', return an odd number; if it is
378
   '0', return an even number.  Result undefined in all other cases.  */
379
#define BLANKOR1TOODD(y)     COFFLONGSECTIONCATHELPER(1,y)
380
/* Defined to numerical 0 or 1 according to whether generation of long
381
   section names is disabled or enabled by default.  */
382
#define COFF_ENABLE_LONG_SECTION_NAMES   (BLANKOR1TOODD(COFF_LONG_SECTION_NAMES) & 1)
383
/* Where long section names are supported, we allow them to be enabled
384
   and disabled at runtime, so select an appropriate hook function for
385
   _bfd_coff_set_long_section_names.  */
386
#define COFF_LONG_SECTION_NAMES_SETTER   bfd_coff_set_long_section_names_allowed
387
#else /* !defined (COFF_LONG_SECTION_NAMES) */
388
/* If long section names are not supported, this stub disallows any
389
   attempt to enable them at run-time.  */
390
#define COFF_LONG_SECTION_NAMES_SETTER   bfd_coff_set_long_section_names_disallowed
391
#endif /* defined (COFF_LONG_SECTION_NAMES) */
392
393
/* Define a macro that can be used to initialise both the fields relating
394
   to long section names in the backend data struct simultaneously.  */
395
#if COFF_ENABLE_LONG_SECTION_NAMES
396
#define COFF_DEFAULT_LONG_SECTION_NAMES  (true), COFF_LONG_SECTION_NAMES_SETTER
397
#else /* !COFF_ENABLE_LONG_SECTION_NAMES */
398
#define COFF_DEFAULT_LONG_SECTION_NAMES  (false), COFF_LONG_SECTION_NAMES_SETTER
399
#endif /* COFF_ENABLE_LONG_SECTION_NAMES */
400
401
static enum coff_symbol_classification coff_classify_symbol
402
  (bfd *, struct internal_syment *);
403

404
/* void warning(); */
405
406
#if defined (COFF_LONG_SECTION_NAMES)
407
static bool
408
bfd_coff_set_long_section_names_allowed (bfd *abfd, int enable)
409
185k
{
410
185k
  bfd_coff_long_section_names (abfd) = enable;
411
185k
  return true;
412
185k
}
pei-i386.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
10.8k
{
410
10.8k
  bfd_coff_long_section_names (abfd) = enable;
411
10.8k
  return true;
412
10.8k
}
Unexecuted instantiation: pe-x86_64.c:bfd_coff_set_long_section_names_allowed
pei-x86_64.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
7.28k
{
410
7.28k
  bfd_coff_long_section_names (abfd) = enable;
411
7.28k
  return true;
412
7.28k
}
pei-aarch64.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
7.65k
{
410
7.65k
  bfd_coff_long_section_names (abfd) = enable;
411
7.65k
  return true;
412
7.65k
}
Unexecuted instantiation: pe-aarch64.c:bfd_coff_set_long_section_names_allowed
pei-ia64.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
8.57k
{
410
8.57k
  bfd_coff_long_section_names (abfd) = enable;
411
8.57k
  return true;
412
8.57k
}
pei-loongarch64.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
8.46k
{
410
8.46k
  bfd_coff_long_section_names (abfd) = enable;
411
8.46k
  return true;
412
8.46k
}
Unexecuted instantiation: coff-go32.c:bfd_coff_set_long_section_names_allowed
coff-stgo32.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
91.3k
{
410
91.3k
  bfd_coff_long_section_names (abfd) = enable;
411
91.3k
  return true;
412
91.3k
}
Unexecuted instantiation: pe-arm-wince.c:bfd_coff_set_long_section_names_allowed
Unexecuted instantiation: pe-arm.c:bfd_coff_set_long_section_names_allowed
pe-i386.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
15.6k
{
410
15.6k
  bfd_coff_long_section_names (abfd) = enable;
411
15.6k
  return true;
412
15.6k
}
Unexecuted instantiation: pe-mcore.c:bfd_coff_set_long_section_names_allowed
Unexecuted instantiation: pe-sh.c:bfd_coff_set_long_section_names_allowed
pei-arm-wince.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
10.5k
{
410
10.5k
  bfd_coff_long_section_names (abfd) = enable;
411
10.5k
  return true;
412
10.5k
}
pei-arm.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
12.0k
{
410
12.0k
  bfd_coff_long_section_names (abfd) = enable;
411
12.0k
  return true;
412
12.0k
}
pei-mcore.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
6.40k
{
410
6.40k
  bfd_coff_long_section_names (abfd) = enable;
411
6.40k
  return true;
412
6.40k
}
pei-sh.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
7.03k
{
410
7.03k
  bfd_coff_long_section_names (abfd) = enable;
411
7.03k
  return true;
412
7.03k
}
413
#else /* !defined (COFF_LONG_SECTION_NAMES) */
414
static bool
415
bfd_coff_set_long_section_names_disallowed (bfd *abfd ATTRIBUTE_UNUSED,
416
              int enable ATTRIBUTE_UNUSED)
417
89.3k
{
418
89.3k
  return false;
419
89.3k
}
Unexecuted instantiation: coff-x86_64.c:bfd_coff_set_long_section_names_disallowed
Unexecuted instantiation: coff64-rs6000.c:bfd_coff_set_long_section_names_disallowed
cf-i386lynx.c:bfd_coff_set_long_section_names_disallowed
Line
Count
Source
417
89.3k
{
418
89.3k
  return false;
419
89.3k
}
Unexecuted instantiation: coff-i386.c:bfd_coff_set_long_section_names_disallowed
Unexecuted instantiation: coff-rs6000.c:bfd_coff_set_long_section_names_disallowed
Unexecuted instantiation: coff-sh.c:bfd_coff_set_long_section_names_disallowed
Unexecuted instantiation: coff-tic30.c:bfd_coff_set_long_section_names_disallowed
Unexecuted instantiation: coff-tic4x.c:bfd_coff_set_long_section_names_disallowed
Unexecuted instantiation: coff-tic54x.c:bfd_coff_set_long_section_names_disallowed
Unexecuted instantiation: coff-z80.c:bfd_coff_set_long_section_names_disallowed
Unexecuted instantiation: coff-z8k.c:bfd_coff_set_long_section_names_disallowed
420
#endif /* defined (COFF_LONG_SECTION_NAMES) */
421
422
/* Return a word with STYP_* (scnhdr.s_flags) flags set to represent
423
   the incoming SEC_* flags.  The inverse of this function is
424
   styp_to_sec_flags().  NOTE: If you add to/change this routine, you
425
   should probably mirror the changes in styp_to_sec_flags().  */
426
427
#ifndef COFF_WITH_PE
428
429
/* Macros for setting debugging flags.  */
430
431
#ifdef STYP_DEBUG
432
0
#define STYP_XCOFF_DEBUG STYP_DEBUG
433
#else
434
0
#define STYP_XCOFF_DEBUG STYP_INFO
435
#endif
436
437
#ifdef COFF_ALIGN_IN_S_FLAGS
438
0
#define STYP_DEBUG_INFO STYP_DSECT
439
#else
440
0
#define STYP_DEBUG_INFO STYP_INFO
441
#endif
442
443
static long
444
sec_to_styp_flags (const char *sec_name, flagword sec_flags)
445
0
{
446
0
  long styp_flags = 0;
447
448
0
  if (!strcmp (sec_name, _TEXT))
449
0
    {
450
0
      styp_flags = STYP_TEXT;
451
0
    }
452
0
  else if (!strcmp (sec_name, _DATA))
453
0
    {
454
0
      styp_flags = STYP_DATA;
455
0
    }
456
0
  else if (!strcmp (sec_name, _BSS))
457
0
    {
458
0
      styp_flags = STYP_BSS;
459
#ifdef _COMMENT
460
    }
461
0
  else if (!strcmp (sec_name, _COMMENT))
462
0
    {
463
0
      styp_flags = STYP_INFO;
464
#endif /* _COMMENT */
465
#ifdef _LIB
466
    }
467
0
  else if (!strcmp (sec_name, _LIB))
468
0
    {
469
0
      styp_flags = STYP_LIB;
470
#endif /* _LIB */
471
#ifdef _LIT
472
    }
473
  else if (!strcmp (sec_name, _LIT))
474
    {
475
      styp_flags = STYP_LIT;
476
#endif /* _LIT */
477
0
    }
478
0
  else if (startswith (sec_name, DOT_DEBUG)
479
0
     || startswith (sec_name, DOT_ZDEBUG))
480
0
    {
481
      /* Handle the XCOFF debug section and DWARF2 debug sections.  */
482
0
      if (!sec_name[6])
483
0
  styp_flags = STYP_XCOFF_DEBUG;
484
0
      else
485
0
  styp_flags = STYP_DEBUG_INFO;
486
0
    }
487
0
  else if (startswith (sec_name, ".stab"))
488
0
    {
489
0
      styp_flags = STYP_DEBUG_INFO;
490
0
    }
491
#ifdef COFF_LONG_SECTION_NAMES
492
0
  else if (startswith (sec_name, GNU_LINKONCE_WI)
493
0
     || startswith (sec_name, GNU_LINKONCE_WT))
494
0
    {
495
0
      styp_flags = STYP_DEBUG_INFO;
496
0
    }
497
0
#endif
498
#ifdef RS6000COFF_C
499
0
  else if (!strcmp (sec_name, _TDATA))
500
0
    {
501
0
      styp_flags = STYP_TDATA;
502
0
    }
503
0
  else if (!strcmp (sec_name, _TBSS))
504
0
    {
505
0
      styp_flags = STYP_TBSS;
506
0
    }
507
0
  else if (!strcmp (sec_name, _PAD))
508
0
    {
509
0
      styp_flags = STYP_PAD;
510
0
    }
511
0
  else if (!strcmp (sec_name, _LOADER))
512
0
    {
513
0
      styp_flags = STYP_LOADER;
514
0
    }
515
0
  else if (!strcmp (sec_name, _EXCEPT))
516
0
    {
517
0
      styp_flags = STYP_EXCEPT;
518
0
    }
519
0
  else if (!strcmp (sec_name, _TYPCHK))
520
0
    {
521
0
      styp_flags = STYP_TYPCHK;
522
0
    }
523
0
  else if (sec_flags & SEC_DEBUGGING)
524
0
    {
525
0
      int i;
526
527
0
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
528
0
  if (!strcmp (sec_name, xcoff_dwsect_names[i].xcoff_name))
529
0
    {
530
0
      styp_flags = STYP_DWARF | xcoff_dwsect_names[i].flag;
531
0
      break;
532
0
    }
533
0
    }
534
0
#endif
535
  /* Try and figure out what it should be */
536
0
  else if (sec_flags & SEC_CODE)
537
0
    {
538
0
      styp_flags = STYP_TEXT;
539
0
    }
540
0
  else if (sec_flags & SEC_DATA)
541
0
    {
542
0
      styp_flags = STYP_DATA;
543
0
    }
544
0
  else if (sec_flags & SEC_READONLY)
545
0
    {
546
0
#ifdef STYP_LIT     /* 29k readonly text/data section */
547
0
      styp_flags = STYP_LIT;
548
#else
549
      styp_flags = STYP_TEXT;
550
#endif /* STYP_LIT */
551
0
    }
552
0
  else if (sec_flags & SEC_LOAD)
553
0
    {
554
0
      styp_flags = STYP_TEXT;
555
0
    }
556
0
  else if (sec_flags & SEC_ALLOC)
557
0
    {
558
0
      styp_flags = STYP_BSS;
559
0
    }
560
561
#ifdef STYP_CLINK
562
0
  if (sec_flags & SEC_TIC54X_CLINK)
563
0
    styp_flags |= STYP_CLINK;
564
#endif
565
566
#ifdef STYP_BLOCK
567
0
  if (sec_flags & SEC_TIC54X_BLOCK)
568
0
    styp_flags |= STYP_BLOCK;
569
#endif
570
571
0
#ifdef STYP_NOLOAD
572
0
  if ((sec_flags & (SEC_NEVER_LOAD | SEC_COFF_SHARED_LIBRARY)) != 0)
573
0
    styp_flags |= STYP_NOLOAD;
574
0
#endif
575
576
0
  return styp_flags;
577
0
}
Unexecuted instantiation: coff-x86_64.c:sec_to_styp_flags
Unexecuted instantiation: coff64-rs6000.c:sec_to_styp_flags
Unexecuted instantiation: cf-i386lynx.c:sec_to_styp_flags
Unexecuted instantiation: coff-go32.c:sec_to_styp_flags
Unexecuted instantiation: coff-i386.c:sec_to_styp_flags
Unexecuted instantiation: coff-rs6000.c:sec_to_styp_flags
Unexecuted instantiation: coff-sh.c:sec_to_styp_flags
Unexecuted instantiation: coff-stgo32.c:sec_to_styp_flags
Unexecuted instantiation: coff-tic30.c:sec_to_styp_flags
Unexecuted instantiation: coff-tic4x.c:sec_to_styp_flags
Unexecuted instantiation: coff-tic54x.c:sec_to_styp_flags
Unexecuted instantiation: coff-z80.c:sec_to_styp_flags
Unexecuted instantiation: coff-z8k.c:sec_to_styp_flags
578
579
#else /* COFF_WITH_PE */
580
581
/* The PE version; see above for the general comments.  The non-PE
582
   case seems to be more guessing, and breaks PE format; specifically,
583
   .rdata is readonly, but it sure ain't text.  Really, all this
584
   should be set up properly in gas (or whatever assembler is in use),
585
   and honor whatever objcopy/strip, etc. sent us as input.  */
586
587
static long
588
sec_to_styp_flags (const char *sec_name, flagword sec_flags)
589
0
{
590
0
  long styp_flags = 0;
591
0
  bool is_dbg = false;
592
593
0
  if (startswith (sec_name, DOT_DEBUG)
594
0
      || startswith (sec_name, DOT_ZDEBUG)
595
0
#ifdef COFF_LONG_SECTION_NAMES
596
0
      || startswith (sec_name, GNU_LINKONCE_WI)
597
0
      || startswith (sec_name, GNU_LINKONCE_WT)
598
0
#endif
599
0
      || startswith (sec_name, ".stab"))
600
0
    is_dbg = true;
601
602
  /* caution: there are at least three groups of symbols that have
603
     very similar bits and meanings: IMAGE_SCN*, SEC_*, and STYP_*.
604
     SEC_* are the BFD internal flags, used for generic BFD
605
     information.  STYP_* are the COFF section flags which appear in
606
     COFF files.  IMAGE_SCN_* are the PE section flags which appear in
607
     PE files.  The STYP_* flags and the IMAGE_SCN_* flags overlap,
608
     but there are more IMAGE_SCN_* flags.  */
609
610
  /* FIXME: There is no gas syntax to specify the debug section flag.  */
611
0
  if (is_dbg)
612
0
    {
613
0
      sec_flags &= (SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD
614
0
        | SEC_LINK_DUPLICATES_SAME_CONTENTS
615
0
        | SEC_LINK_DUPLICATES_SAME_SIZE);
616
0
      sec_flags |= SEC_DEBUGGING | SEC_READONLY;
617
0
    }
618
619
  /* skip LOAD */
620
  /* READONLY later */
621
  /* skip RELOC */
622
0
  if ((sec_flags & SEC_CODE) != 0)
623
0
    styp_flags |= IMAGE_SCN_CNT_CODE;
624
0
  if ((sec_flags & (SEC_DATA | SEC_DEBUGGING)) != 0)
625
0
    styp_flags |= IMAGE_SCN_CNT_INITIALIZED_DATA;
626
0
  if ((sec_flags & SEC_ALLOC) != 0 && (sec_flags & SEC_LOAD) == 0)
627
0
    styp_flags |= IMAGE_SCN_CNT_UNINITIALIZED_DATA;  /* ==STYP_BSS */
628
  /* skip ROM */
629
  /* skip constRUCTOR */
630
  /* skip CONTENTS */
631
#ifndef COFF_IMAGE_WITH_PE
632
  /* I don't think any of the IMAGE_SCN_LNK_* flags set below should be set
633
     when the output is PE. Only object files should have them, for the linker
634
     to consume.  */
635
0
  if ((sec_flags & SEC_IS_COMMON) != 0)
636
0
    styp_flags |= IMAGE_SCN_LNK_COMDAT;
637
#endif
638
0
  if ((sec_flags & SEC_DEBUGGING) != 0)
639
0
    styp_flags |= IMAGE_SCN_MEM_DISCARDABLE;
640
0
  if ((sec_flags & (SEC_EXCLUDE | SEC_NEVER_LOAD)) != 0 && !is_dbg)
641
#ifdef COFF_IMAGE_WITH_PE
642
0
    styp_flags |= IMAGE_SCN_MEM_DISCARDABLE;
643
#else
644
0
    styp_flags |= IMAGE_SCN_LNK_REMOVE;
645
#endif
646
  /* skip IN_MEMORY */
647
  /* skip SORT */
648
#ifndef COFF_IMAGE_WITH_PE
649
0
  if (sec_flags & SEC_LINK_ONCE)
650
0
    styp_flags |= IMAGE_SCN_LNK_COMDAT;
651
0
  if ((sec_flags
652
0
       & (SEC_LINK_DUPLICATES_DISCARD | SEC_LINK_DUPLICATES_SAME_CONTENTS
653
0
    | SEC_LINK_DUPLICATES_SAME_SIZE)) != 0)
654
0
    styp_flags |= IMAGE_SCN_LNK_COMDAT;
655
#endif
656
657
  /* skip LINKER_CREATED */
658
659
0
  if ((sec_flags & SEC_COFF_NOREAD) == 0)
660
0
    styp_flags |= IMAGE_SCN_MEM_READ;     /* Invert NOREAD for read.  */
661
0
  if ((sec_flags & SEC_READONLY) == 0)
662
0
    styp_flags |= IMAGE_SCN_MEM_WRITE;    /* Invert READONLY for write.  */
663
0
  if (sec_flags & SEC_CODE)
664
0
    styp_flags |= IMAGE_SCN_MEM_EXECUTE;  /* CODE->EXECUTE.  */
665
0
  if (sec_flags & SEC_COFF_SHARED)
666
0
    styp_flags |= IMAGE_SCN_MEM_SHARED;   /* Shared remains meaningful.  */
667
668
0
  return styp_flags;
669
0
}
Unexecuted instantiation: pei-i386.c:sec_to_styp_flags
Unexecuted instantiation: pe-x86_64.c:sec_to_styp_flags
Unexecuted instantiation: pei-x86_64.c:sec_to_styp_flags
Unexecuted instantiation: pei-aarch64.c:sec_to_styp_flags
Unexecuted instantiation: pe-aarch64.c:sec_to_styp_flags
Unexecuted instantiation: pei-ia64.c:sec_to_styp_flags
Unexecuted instantiation: pei-loongarch64.c:sec_to_styp_flags
Unexecuted instantiation: pe-arm-wince.c:sec_to_styp_flags
Unexecuted instantiation: pe-arm.c:sec_to_styp_flags
Unexecuted instantiation: pe-i386.c:sec_to_styp_flags
Unexecuted instantiation: pe-mcore.c:sec_to_styp_flags
Unexecuted instantiation: pe-sh.c:sec_to_styp_flags
Unexecuted instantiation: pei-arm-wince.c:sec_to_styp_flags
Unexecuted instantiation: pei-arm.c:sec_to_styp_flags
Unexecuted instantiation: pei-mcore.c:sec_to_styp_flags
Unexecuted instantiation: pei-sh.c:sec_to_styp_flags
670
671
#endif /* COFF_WITH_PE */
672
673
/* Return a word with SEC_* flags set to represent the incoming STYP_*
674
   flags (from scnhdr.s_flags).  The inverse of this function is
675
   sec_to_styp_flags().  NOTE: If you add to/change this routine, you
676
   should probably mirror the changes in sec_to_styp_flags().  */
677
678
#ifndef COFF_WITH_PE
679
680
static bool
681
styp_to_sec_flags (bfd *abfd,
682
       void * hdr,
683
       const char *name,
684
       asection *section ATTRIBUTE_UNUSED,
685
       flagword *flags_ptr)
686
179k
{
687
179k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
179k
  unsigned long styp_flags = internal_s->s_flags;
689
179k
  flagword sec_flags = 0;
690
691
#ifdef STYP_BLOCK
692
0
  if (styp_flags & STYP_BLOCK)
693
0
    sec_flags |= SEC_TIC54X_BLOCK;
694
#endif
695
696
#ifdef STYP_CLINK
697
0
  if (styp_flags & STYP_CLINK)
698
0
    sec_flags |= SEC_TIC54X_CLINK;
699
#endif
700
701
179k
#ifdef STYP_NOLOAD
702
179k
  if (styp_flags & STYP_NOLOAD)
703
52.9k
    sec_flags |= SEC_NEVER_LOAD;
704
179k
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
179k
  if (styp_flags & STYP_TEXT)
709
58.8k
    {
710
58.8k
      if (sec_flags & SEC_NEVER_LOAD)
711
31.3k
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
27.4k
      else
713
27.4k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
58.8k
    }
715
120k
  else if (styp_flags & STYP_DATA)
716
16.5k
    {
717
16.5k
      if (sec_flags & SEC_NEVER_LOAD)
718
8.21k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
8.34k
      else
720
8.34k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
16.5k
    }
722
104k
  else if (styp_flags & STYP_BSS)
723
7.81k
    {
724
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
7.81k
      if (sec_flags & SEC_NEVER_LOAD)
726
2.80k
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
5.00k
      else
728
5.00k
#endif
729
5.00k
  sec_flags |= SEC_ALLOC;
730
7.81k
    }
731
96.5k
  else if (styp_flags & STYP_INFO)
732
13.6k
    {
733
      /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
734
   defined.  coff_compute_section_file_positions uses
735
   COFF_PAGE_SIZE to ensure that the low order bits of the
736
   section VMA and the file offset match.  If we don't know
737
   COFF_PAGE_SIZE, we can't ensure the correct correspondence,
738
   and demand page loading of the file will fail.  */
739
#if defined (COFF_PAGE_SIZE) && !defined (COFF_ALIGN_IN_S_FLAGS)
740
13.6k
      sec_flags |= SEC_DEBUGGING;
741
#endif
742
13.6k
    }
743
82.8k
  else if (styp_flags & STYP_PAD)
744
4.08k
    sec_flags = 0;
745
#ifdef RS6000COFF_C
746
0
  else if (styp_flags & STYP_TDATA)
747
0
    {
748
0
      if (sec_flags & SEC_NEVER_LOAD)
749
0
  sec_flags |= SEC_DATA | SEC_THREAD_LOCAL | SEC_COFF_SHARED_LIBRARY;
750
0
      else
751
0
  sec_flags |= SEC_DATA | SEC_THREAD_LOCAL | SEC_LOAD | SEC_ALLOC;
752
0
    }
753
0
  else if (styp_flags & STYP_TBSS)
754
0
    {
755
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
756
      if (sec_flags & SEC_NEVER_LOAD)
757
  sec_flags |= SEC_ALLOC | SEC_THREAD_LOCAL | SEC_COFF_SHARED_LIBRARY;
758
      else
759
#endif
760
0
  sec_flags |= SEC_ALLOC | SEC_THREAD_LOCAL;
761
0
    }
762
0
  else if (styp_flags & STYP_EXCEPT)
763
0
    sec_flags |= SEC_LOAD;
764
0
  else if (styp_flags & STYP_LOADER)
765
0
    sec_flags |= SEC_LOAD;
766
0
  else if (styp_flags & STYP_TYPCHK)
767
0
    sec_flags |= SEC_LOAD;
768
0
  else if (styp_flags & STYP_DWARF)
769
0
    sec_flags |= SEC_DEBUGGING;
770
0
#endif
771
78.7k
  else if (strcmp (name, _TEXT) == 0)
772
240
    {
773
240
      if (sec_flags & SEC_NEVER_LOAD)
774
50
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
190
      else
776
190
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
240
    }
778
78.5k
  else if (strcmp (name, _DATA) == 0)
779
50
    {
780
50
      if (sec_flags & SEC_NEVER_LOAD)
781
24
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
26
      else
783
26
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
50
    }
785
78.4k
  else if (strcmp (name, _BSS) == 0)
786
42
    {
787
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
42
      if (sec_flags & SEC_NEVER_LOAD)
789
20
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
22
      else
791
22
#endif
792
22
  sec_flags |= SEC_ALLOC;
793
42
    }
794
78.4k
  else if (startswith (name, DOT_DEBUG)
795
78.4k
     || startswith (name, DOT_ZDEBUG)
796
#ifdef _COMMENT
797
77.0k
     || strcmp (name, _COMMENT) == 0
798
#endif
799
#ifdef COFF_LONG_SECTION_NAMES
800
37.5k
     || startswith (name, GNU_LINKONCE_WI)
801
37.5k
     || startswith (name, GNU_LINKONCE_WT)
802
#endif
803
78.4k
     || startswith (name, ".stab"))
804
4.77k
    {
805
#ifdef COFF_PAGE_SIZE
806
4.77k
      sec_flags |= SEC_DEBUGGING;
807
#endif
808
4.77k
    }
809
#ifdef _LIB
810
73.6k
  else if (strcmp (name, _LIB) == 0)
811
28
    ;
812
73.6k
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
73.6k
  else
818
73.6k
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
179k
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
179k
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
28.2k
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
179k
#endif /* STYP_LIT */
824
825
#ifdef STYP_OTHER_LOAD    /* Other loaded sections.  */
826
  if (styp_flags & STYP_OTHER_LOAD)
827
    sec_flags = (SEC_LOAD | SEC_ALLOC);
828
#endif /* STYP_SDATA */
829
830
179k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
179k
      && (startswith (name, ".sbss")
832
0
    || startswith (name, ".sdata")))
833
0
    sec_flags |= SEC_SMALL_DATA;
834
835
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
836
  /* As a GNU extension, if the name begins with .gnu.linkonce, we
837
     only link a single copy of the section.  This is used to support
838
     g++.  g++ will emit each template expansion in its own section.
839
     The symbols will be defined as weak, so that multiple definitions
840
     are permitted.  The GNU linker extension is to actually discard
841
     all but one of the sections.  */
842
90.3k
  if (startswith (name, ".gnu.linkonce"))
843
87
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
844
#endif
845
846
179k
  if (flags_ptr == NULL)
847
0
    return false;
848
849
179k
  * flags_ptr = sec_flags;
850
179k
  return true;
851
179k
}
Unexecuted instantiation: coff-x86_64.c:styp_to_sec_flags
Unexecuted instantiation: coff64-rs6000.c:styp_to_sec_flags
cf-i386lynx.c:styp_to_sec_flags
Line
Count
Source
686
89.3k
{
687
89.3k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
89.3k
  unsigned long styp_flags = internal_s->s_flags;
689
89.3k
  flagword sec_flags = 0;
690
691
#ifdef STYP_BLOCK
692
  if (styp_flags & STYP_BLOCK)
693
    sec_flags |= SEC_TIC54X_BLOCK;
694
#endif
695
696
#ifdef STYP_CLINK
697
  if (styp_flags & STYP_CLINK)
698
    sec_flags |= SEC_TIC54X_CLINK;
699
#endif
700
701
89.3k
#ifdef STYP_NOLOAD
702
89.3k
  if (styp_flags & STYP_NOLOAD)
703
26.3k
    sec_flags |= SEC_NEVER_LOAD;
704
89.3k
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
89.3k
  if (styp_flags & STYP_TEXT)
709
29.2k
    {
710
29.2k
      if (sec_flags & SEC_NEVER_LOAD)
711
15.6k
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
13.6k
      else
713
13.6k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
29.2k
    }
715
60.0k
  else if (styp_flags & STYP_DATA)
716
8.24k
    {
717
8.24k
      if (sec_flags & SEC_NEVER_LOAD)
718
4.08k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
4.16k
      else
720
4.16k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
8.24k
    }
722
51.7k
  else if (styp_flags & STYP_BSS)
723
3.90k
    {
724
3.90k
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
3.90k
      if (sec_flags & SEC_NEVER_LOAD)
726
1.40k
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
2.49k
      else
728
2.49k
#endif
729
2.49k
  sec_flags |= SEC_ALLOC;
730
3.90k
    }
731
47.8k
  else if (styp_flags & STYP_INFO)
732
6.79k
    {
733
      /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
734
   defined.  coff_compute_section_file_positions uses
735
   COFF_PAGE_SIZE to ensure that the low order bits of the
736
   section VMA and the file offset match.  If we don't know
737
   COFF_PAGE_SIZE, we can't ensure the correct correspondence,
738
   and demand page loading of the file will fail.  */
739
6.79k
#if defined (COFF_PAGE_SIZE) && !defined (COFF_ALIGN_IN_S_FLAGS)
740
6.79k
      sec_flags |= SEC_DEBUGGING;
741
6.79k
#endif
742
6.79k
    }
743
41.1k
  else if (styp_flags & STYP_PAD)
744
2.03k
    sec_flags = 0;
745
#ifdef RS6000COFF_C
746
  else if (styp_flags & STYP_TDATA)
747
    {
748
      if (sec_flags & SEC_NEVER_LOAD)
749
  sec_flags |= SEC_DATA | SEC_THREAD_LOCAL | SEC_COFF_SHARED_LIBRARY;
750
      else
751
  sec_flags |= SEC_DATA | SEC_THREAD_LOCAL | SEC_LOAD | SEC_ALLOC;
752
    }
753
  else if (styp_flags & STYP_TBSS)
754
    {
755
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
756
      if (sec_flags & SEC_NEVER_LOAD)
757
  sec_flags |= SEC_ALLOC | SEC_THREAD_LOCAL | SEC_COFF_SHARED_LIBRARY;
758
      else
759
#endif
760
  sec_flags |= SEC_ALLOC | SEC_THREAD_LOCAL;
761
    }
762
  else if (styp_flags & STYP_EXCEPT)
763
    sec_flags |= SEC_LOAD;
764
  else if (styp_flags & STYP_LOADER)
765
    sec_flags |= SEC_LOAD;
766
  else if (styp_flags & STYP_TYPCHK)
767
    sec_flags |= SEC_LOAD;
768
  else if (styp_flags & STYP_DWARF)
769
    sec_flags |= SEC_DEBUGGING;
770
#endif
771
39.0k
  else if (strcmp (name, _TEXT) == 0)
772
120
    {
773
120
      if (sec_flags & SEC_NEVER_LOAD)
774
25
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
95
      else
776
95
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
120
    }
778
38.9k
  else if (strcmp (name, _DATA) == 0)
779
25
    {
780
25
      if (sec_flags & SEC_NEVER_LOAD)
781
12
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
13
      else
783
13
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
25
    }
785
38.9k
  else if (strcmp (name, _BSS) == 0)
786
21
    {
787
21
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
21
      if (sec_flags & SEC_NEVER_LOAD)
789
10
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
11
      else
791
11
#endif
792
11
  sec_flags |= SEC_ALLOC;
793
21
    }
794
38.8k
  else if (startswith (name, DOT_DEBUG)
795
38.8k
     || startswith (name, DOT_ZDEBUG)
796
38.8k
#ifdef _COMMENT
797
38.8k
     || strcmp (name, _COMMENT) == 0
798
38.8k
#endif
799
#ifdef COFF_LONG_SECTION_NAMES
800
     || startswith (name, GNU_LINKONCE_WI)
801
     || startswith (name, GNU_LINKONCE_WT)
802
#endif
803
38.8k
     || startswith (name, ".stab"))
804
2.36k
    {
805
2.36k
#ifdef COFF_PAGE_SIZE
806
2.36k
      sec_flags |= SEC_DEBUGGING;
807
2.36k
#endif
808
2.36k
    }
809
36.5k
#ifdef _LIB
810
36.5k
  else if (strcmp (name, _LIB) == 0)
811
14
    ;
812
36.5k
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
36.5k
  else
818
36.5k
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
89.3k
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
89.3k
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
14.0k
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
89.3k
#endif /* STYP_LIT */
824
825
#ifdef STYP_OTHER_LOAD    /* Other loaded sections.  */
826
  if (styp_flags & STYP_OTHER_LOAD)
827
    sec_flags = (SEC_LOAD | SEC_ALLOC);
828
#endif /* STYP_SDATA */
829
830
89.3k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
89.3k
      && (startswith (name, ".sbss")
832
0
    || startswith (name, ".sdata")))
833
0
    sec_flags |= SEC_SMALL_DATA;
834
835
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
836
  /* As a GNU extension, if the name begins with .gnu.linkonce, we
837
     only link a single copy of the section.  This is used to support
838
     g++.  g++ will emit each template expansion in its own section.
839
     The symbols will be defined as weak, so that multiple definitions
840
     are permitted.  The GNU linker extension is to actually discard
841
     all but one of the sections.  */
842
  if (startswith (name, ".gnu.linkonce"))
843
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
844
#endif
845
846
89.3k
  if (flags_ptr == NULL)
847
0
    return false;
848
849
89.3k
  * flags_ptr = sec_flags;
850
89.3k
  return true;
851
89.3k
}
Unexecuted instantiation: coff-go32.c:styp_to_sec_flags
Unexecuted instantiation: coff-i386.c:styp_to_sec_flags
Unexecuted instantiation: coff-rs6000.c:styp_to_sec_flags
Unexecuted instantiation: coff-sh.c:styp_to_sec_flags
coff-stgo32.c:styp_to_sec_flags
Line
Count
Source
686
90.3k
{
687
90.3k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
90.3k
  unsigned long styp_flags = internal_s->s_flags;
689
90.3k
  flagword sec_flags = 0;
690
691
#ifdef STYP_BLOCK
692
  if (styp_flags & STYP_BLOCK)
693
    sec_flags |= SEC_TIC54X_BLOCK;
694
#endif
695
696
#ifdef STYP_CLINK
697
  if (styp_flags & STYP_CLINK)
698
    sec_flags |= SEC_TIC54X_CLINK;
699
#endif
700
701
90.3k
#ifdef STYP_NOLOAD
702
90.3k
  if (styp_flags & STYP_NOLOAD)
703
26.6k
    sec_flags |= SEC_NEVER_LOAD;
704
90.3k
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
90.3k
  if (styp_flags & STYP_TEXT)
709
29.5k
    {
710
29.5k
      if (sec_flags & SEC_NEVER_LOAD)
711
15.7k
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
13.7k
      else
713
13.7k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
29.5k
    }
715
60.8k
  else if (styp_flags & STYP_DATA)
716
8.32k
    {
717
8.32k
      if (sec_flags & SEC_NEVER_LOAD)
718
4.13k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
4.18k
      else
720
4.18k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
8.32k
    }
722
52.5k
  else if (styp_flags & STYP_BSS)
723
3.90k
    {
724
3.90k
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
3.90k
      if (sec_flags & SEC_NEVER_LOAD)
726
1.40k
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
2.50k
      else
728
2.50k
#endif
729
2.50k
  sec_flags |= SEC_ALLOC;
730
3.90k
    }
731
48.6k
  else if (styp_flags & STYP_INFO)
732
6.87k
    {
733
      /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
734
   defined.  coff_compute_section_file_positions uses
735
   COFF_PAGE_SIZE to ensure that the low order bits of the
736
   section VMA and the file offset match.  If we don't know
737
   COFF_PAGE_SIZE, we can't ensure the correct correspondence,
738
   and demand page loading of the file will fail.  */
739
6.87k
#if defined (COFF_PAGE_SIZE) && !defined (COFF_ALIGN_IN_S_FLAGS)
740
6.87k
      sec_flags |= SEC_DEBUGGING;
741
6.87k
#endif
742
6.87k
    }
743
41.7k
  else if (styp_flags & STYP_PAD)
744
2.04k
    sec_flags = 0;
745
#ifdef RS6000COFF_C
746
  else if (styp_flags & STYP_TDATA)
747
    {
748
      if (sec_flags & SEC_NEVER_LOAD)
749
  sec_flags |= SEC_DATA | SEC_THREAD_LOCAL | SEC_COFF_SHARED_LIBRARY;
750
      else
751
  sec_flags |= SEC_DATA | SEC_THREAD_LOCAL | SEC_LOAD | SEC_ALLOC;
752
    }
753
  else if (styp_flags & STYP_TBSS)
754
    {
755
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
756
      if (sec_flags & SEC_NEVER_LOAD)
757
  sec_flags |= SEC_ALLOC | SEC_THREAD_LOCAL | SEC_COFF_SHARED_LIBRARY;
758
      else
759
#endif
760
  sec_flags |= SEC_ALLOC | SEC_THREAD_LOCAL;
761
    }
762
  else if (styp_flags & STYP_EXCEPT)
763
    sec_flags |= SEC_LOAD;
764
  else if (styp_flags & STYP_LOADER)
765
    sec_flags |= SEC_LOAD;
766
  else if (styp_flags & STYP_TYPCHK)
767
    sec_flags |= SEC_LOAD;
768
  else if (styp_flags & STYP_DWARF)
769
    sec_flags |= SEC_DEBUGGING;
770
#endif
771
39.6k
  else if (strcmp (name, _TEXT) == 0)
772
120
    {
773
120
      if (sec_flags & SEC_NEVER_LOAD)
774
25
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
95
      else
776
95
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
120
    }
778
39.5k
  else if (strcmp (name, _DATA) == 0)
779
25
    {
780
25
      if (sec_flags & SEC_NEVER_LOAD)
781
12
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
13
      else
783
13
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
25
    }
785
39.5k
  else if (strcmp (name, _BSS) == 0)
786
21
    {
787
21
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
21
      if (sec_flags & SEC_NEVER_LOAD)
789
10
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
11
      else
791
11
#endif
792
11
  sec_flags |= SEC_ALLOC;
793
21
    }
794
39.5k
  else if (startswith (name, DOT_DEBUG)
795
39.5k
     || startswith (name, DOT_ZDEBUG)
796
39.5k
#ifdef _COMMENT
797
39.5k
     || strcmp (name, _COMMENT) == 0
798
39.5k
#endif
799
39.5k
#ifdef COFF_LONG_SECTION_NAMES
800
39.5k
     || startswith (name, GNU_LINKONCE_WI)
801
39.5k
     || startswith (name, GNU_LINKONCE_WT)
802
39.5k
#endif
803
39.5k
     || startswith (name, ".stab"))
804
2.41k
    {
805
2.41k
#ifdef COFF_PAGE_SIZE
806
2.41k
      sec_flags |= SEC_DEBUGGING;
807
2.41k
#endif
808
2.41k
    }
809
37.1k
#ifdef _LIB
810
37.1k
  else if (strcmp (name, _LIB) == 0)
811
14
    ;
812
37.1k
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
37.1k
  else
818
37.1k
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
90.3k
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
90.3k
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
14.1k
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
90.3k
#endif /* STYP_LIT */
824
825
#ifdef STYP_OTHER_LOAD    /* Other loaded sections.  */
826
  if (styp_flags & STYP_OTHER_LOAD)
827
    sec_flags = (SEC_LOAD | SEC_ALLOC);
828
#endif /* STYP_SDATA */
829
830
90.3k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
90.3k
      && (startswith (name, ".sbss")
832
0
    || startswith (name, ".sdata")))
833
0
    sec_flags |= SEC_SMALL_DATA;
834
835
90.3k
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
836
  /* As a GNU extension, if the name begins with .gnu.linkonce, we
837
     only link a single copy of the section.  This is used to support
838
     g++.  g++ will emit each template expansion in its own section.
839
     The symbols will be defined as weak, so that multiple definitions
840
     are permitted.  The GNU linker extension is to actually discard
841
     all but one of the sections.  */
842
90.3k
  if (startswith (name, ".gnu.linkonce"))
843
87
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
844
90.3k
#endif
845
846
90.3k
  if (flags_ptr == NULL)
847
0
    return false;
848
849
90.3k
  * flags_ptr = sec_flags;
850
90.3k
  return true;
851
90.3k
}
Unexecuted instantiation: coff-tic30.c:styp_to_sec_flags
Unexecuted instantiation: coff-tic4x.c:styp_to_sec_flags
Unexecuted instantiation: coff-tic54x.c:styp_to_sec_flags
Unexecuted instantiation: coff-z80.c:styp_to_sec_flags
Unexecuted instantiation: coff-z8k.c:styp_to_sec_flags
852
853
#else /* COFF_WITH_PE */
854
855
static bool
856
handle_COMDAT (bfd * abfd,
857
         flagword *sec_flags,
858
         void * hdr,
859
         const char *name,
860
         asection *section)
861
25.8k
{
862
25.8k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
25.8k
  bfd_byte *esymstart, *esym, *esymend;
864
25.8k
  int seen_state = 0;
865
25.8k
  char *target_name = NULL;
866
867
25.8k
  *sec_flags |= SEC_LINK_ONCE;
868
869
  /* Unfortunately, the PE format stores essential information in
870
     the symbol table, of all places.  We need to extract that
871
     information now, so that objdump and the linker will know how
872
     to handle the section without worrying about the symbols.  We
873
     can't call slurp_symtab, because the linker doesn't want the
874
     swapped symbols.  */
875
876
  /* COMDAT sections are special.  The first symbol is the section
877
     symbol, which tells what kind of COMDAT section it is.  The
878
     second symbol is the "comdat symbol" - the one with the
879
     unique name.  GNU uses the section symbol for the unique
880
     name; MS uses ".text" for every comdat section.  Sigh.  - DJ */
881
882
  /* This is not mirrored in sec_to_styp_flags(), but there
883
     doesn't seem to be a need to, either, and it would at best be
884
     rather messy.  */
885
886
25.8k
  if (! _bfd_coff_get_external_symbols (abfd))
887
12.5k
    return true;
888
889
13.3k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
13.3k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
13.3k
  for (struct internal_syment isym;
893
321k
       esym < esymend;
894
308k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
309k
    {
896
309k
      char buf[SYMNMLEN + 1];
897
309k
      const char *symname;
898
899
309k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
309k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
309k
      if (isym.n_scnum == section->target_index)
904
6.02k
  {
905
    /* According to the MSVC documentation, the first
906
       TWO entries with the section # are both of
907
       interest to us.  The first one is the "section
908
       symbol" (section name).  The second is the comdat
909
       symbol name.  Here, we've found the first
910
       qualifying entry; we distinguish it from the
911
       second with a state flag.
912
913
       In the case of gas-generated (at least until that
914
       is fixed) .o files, it isn't necessarily the
915
       second one.  It may be some other later symbol.
916
917
       Since gas also doesn't follow MS conventions and
918
       emits the section similar to .text$<name>, where
919
       <something> is the name we're looking for, we
920
       distinguish the two as follows:
921
922
       If the section name is simply a section name (no
923
       $) we presume it's MS-generated, and look at
924
       precisely the second symbol for the comdat name.
925
       If the section name has a $, we assume it's
926
       gas-generated, and look for <something> (whatever
927
       follows the $) as the comdat symbol.  */
928
929
    /* All 3 branches use this.  */
930
6.02k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
6.02k
    if (symname == NULL)
934
112
      {
935
112
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
112
          abfd);
937
112
        return false;
938
112
      }
939
940
5.90k
    switch (seen_state)
941
5.90k
      {
942
3.06k
      case 0:
943
3.06k
        {
944
    /* The first time we've seen the symbol.  */
945
3.06k
    union internal_auxent aux;
946
947
    /* If it isn't the stuff we're expecting, die;
948
       The MS documentation is vague, but it
949
       appears that the second entry serves BOTH
950
       as the comdat symbol and the defining
951
       symbol record (either C_STAT or C_EXT,
952
       possibly with an aux entry with debug
953
       information if it's a function.)  It
954
       appears the only way to find the second one
955
       is to count.  (On Intel, they appear to be
956
       adjacent, but on Alpha, they have been
957
       found separated.)
958
959
       Here, we think we've found the first one,
960
       but there's some checking we can do to be
961
       sure.  */
962
963
3.06k
    if (! ((isym.n_sclass == C_STAT
964
3.06k
      || isym.n_sclass == C_EXT)
965
3.06k
           && BTYPE (isym.n_type) == T_NULL
966
3.06k
           && isym.n_value == 0))
967
261
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
261
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
261
          abfd, symname);
972
261
        return false;
973
261
      }
974
975
    /* FIXME LATER: MSVC generates section names
976
       like .text for comdats.  Gas generates
977
       names like .text$foo__Fv (in the case of a
978
       function).  See comment above for more.  */
979
980
2.80k
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
2.42k
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
2.42k
          " does not match section name '%s'"),
984
2.42k
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
2.80k
    seen_state = 1;
988
2.80k
    target_name = strchr (name, '$');
989
2.80k
    if (target_name != NULL)
990
248
      {
991
        /* Gas mode.  */
992
248
        seen_state = 2;
993
        /* Skip the `$'.  */
994
248
        target_name += 1;
995
248
      }
996
997
2.80k
    if (isym.n_numaux == 0)
998
902
      aux.x_scn.x_comdat = 0;
999
1.89k
    else
1000
1.89k
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
1.89k
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
50
          {
1004
      /* xgettext:c-format */
1005
50
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
50
                " section '%s' found"),
1007
50
              abfd, symname);
1008
50
      break;
1009
50
          }
1010
1.84k
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
1.84k
            isym.n_type, isym.n_sclass,
1012
1.84k
            0, isym.n_numaux, &aux);
1013
1.84k
      }
1014
1015
    /* FIXME: Microsoft uses NODUPLICATES and
1016
       ASSOCIATIVE, but gnu uses ANY and
1017
       SAME_SIZE.  Unfortunately, gnu doesn't do
1018
       the comdat symbols right.  So, until we can
1019
       fix it to do the right thing, we are
1020
       temporarily disabling comdats for the MS
1021
       types (they're used in DLLs and C++, but we
1022
       don't support *their* C++ libraries anyway
1023
       - DJ.  */
1024
1025
    /* Cygwin does not follow the MS style, and
1026
       uses ANY and SAME_SIZE where NODUPLICATES
1027
       and ASSOCIATIVE should be used.  For
1028
       Interix, we just do the right thing up
1029
       front.  */
1030
1031
2.75k
    switch (aux.x_scn.x_comdat)
1032
2.75k
      {
1033
332
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
332
        *sec_flags &= ~SEC_LINK_ONCE;
1038
332
#endif
1039
332
        break;
1040
1041
5
      case IMAGE_COMDAT_SELECT_ANY:
1042
5
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
5
        break;
1044
1045
140
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
140
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
140
        break;
1048
1049
178
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
178
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
178
        break;
1053
1054
        /* debug$S gets this case; other
1055
           implications ??? */
1056
1057
        /* There may be no symbol... we'll search
1058
           the whole table... Is this the right
1059
           place to play this game? Or should we do
1060
           it when reading it in.  */
1061
156
      case IMAGE_COMDAT_SELECT_ASSOCIATIVE:
1062
#ifdef STRICT_PE_FORMAT
1063
        /* FIXME: This is not currently implemented.  */
1064
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1065
#else
1066
156
        *sec_flags &= ~SEC_LINK_ONCE;
1067
156
#endif
1068
156
        break;
1069
1070
1.94k
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
1.94k
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
1.94k
        break;
1075
2.75k
      }
1076
2.75k
        }
1077
2.75k
        break;
1078
1079
2.75k
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
#ifndef TARGET_UNDERSCORE
1083
732
#define TARGET_UNDERSCORE 0
1084
#endif
1085
        /* Is this the name we're looking for ?  */
1086
2.19k
        if (strcmp (target_name,
1087
2.19k
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
2.16k
    {
1089
      /* Not the name we're looking for */
1090
2.16k
      continue;
1091
2.16k
    }
1092
        /* Fall through.  */
1093
682
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
682
        {
1097
    /* This must the second symbol with the
1098
       section #.  It is the actual symbol name.
1099
       Intel puts the two adjacent, but Alpha (at
1100
       least) spreads them out.  */
1101
1102
682
    struct coff_comdat_info *comdat;
1103
682
    size_t len = strlen (symname) + 1;
1104
1105
682
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
682
    if (comdat == NULL)
1107
0
      return false;
1108
1109
682
    coff_section_data (abfd, section)->comdat = comdat;
1110
682
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
682
    char *newname = (char *) (comdat + 1);
1112
682
    comdat->name = newname;
1113
682
    memcpy (newname, symname, len);
1114
682
    return true;
1115
682
        }
1116
5.90k
      }
1117
5.90k
  }
1118
309k
    }
1119
1120
12.2k
  return true;
1121
13.3k
}
pei-i386.c:handle_COMDAT
Line
Count
Source
861
3.06k
{
862
3.06k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
3.06k
  bfd_byte *esymstart, *esym, *esymend;
864
3.06k
  int seen_state = 0;
865
3.06k
  char *target_name = NULL;
866
867
3.06k
  *sec_flags |= SEC_LINK_ONCE;
868
869
  /* Unfortunately, the PE format stores essential information in
870
     the symbol table, of all places.  We need to extract that
871
     information now, so that objdump and the linker will know how
872
     to handle the section without worrying about the symbols.  We
873
     can't call slurp_symtab, because the linker doesn't want the
874
     swapped symbols.  */
875
876
  /* COMDAT sections are special.  The first symbol is the section
877
     symbol, which tells what kind of COMDAT section it is.  The
878
     second symbol is the "comdat symbol" - the one with the
879
     unique name.  GNU uses the section symbol for the unique
880
     name; MS uses ".text" for every comdat section.  Sigh.  - DJ */
881
882
  /* This is not mirrored in sec_to_styp_flags(), but there
883
     doesn't seem to be a need to, either, and it would at best be
884
     rather messy.  */
885
886
3.06k
  if (! _bfd_coff_get_external_symbols (abfd))
887
1.37k
    return true;
888
889
1.69k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
1.69k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
1.69k
  for (struct internal_syment isym;
893
46.2k
       esym < esymend;
894
44.5k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
44.6k
    {
896
44.6k
      char buf[SYMNMLEN + 1];
897
44.6k
      const char *symname;
898
899
44.6k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
44.6k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
44.6k
      if (isym.n_scnum == section->target_index)
904
729
  {
905
    /* According to the MSVC documentation, the first
906
       TWO entries with the section # are both of
907
       interest to us.  The first one is the "section
908
       symbol" (section name).  The second is the comdat
909
       symbol name.  Here, we've found the first
910
       qualifying entry; we distinguish it from the
911
       second with a state flag.
912
913
       In the case of gas-generated (at least until that
914
       is fixed) .o files, it isn't necessarily the
915
       second one.  It may be some other later symbol.
916
917
       Since gas also doesn't follow MS conventions and
918
       emits the section similar to .text$<name>, where
919
       <something> is the name we're looking for, we
920
       distinguish the two as follows:
921
922
       If the section name is simply a section name (no
923
       $) we presume it's MS-generated, and look at
924
       precisely the second symbol for the comdat name.
925
       If the section name has a $, we assume it's
926
       gas-generated, and look for <something> (whatever
927
       follows the $) as the comdat symbol.  */
928
929
    /* All 3 branches use this.  */
930
729
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
729
    if (symname == NULL)
934
11
      {
935
11
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
11
          abfd);
937
11
        return false;
938
11
      }
939
940
718
    switch (seen_state)
941
718
      {
942
356
      case 0:
943
356
        {
944
    /* The first time we've seen the symbol.  */
945
356
    union internal_auxent aux;
946
947
    /* If it isn't the stuff we're expecting, die;
948
       The MS documentation is vague, but it
949
       appears that the second entry serves BOTH
950
       as the comdat symbol and the defining
951
       symbol record (either C_STAT or C_EXT,
952
       possibly with an aux entry with debug
953
       information if it's a function.)  It
954
       appears the only way to find the second one
955
       is to count.  (On Intel, they appear to be
956
       adjacent, but on Alpha, they have been
957
       found separated.)
958
959
       Here, we think we've found the first one,
960
       but there's some checking we can do to be
961
       sure.  */
962
963
356
    if (! ((isym.n_sclass == C_STAT
964
356
      || isym.n_sclass == C_EXT)
965
356
           && BTYPE (isym.n_type) == T_NULL
966
356
           && isym.n_value == 0))
967
15
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
15
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
15
          abfd, symname);
972
15
        return false;
973
15
      }
974
975
    /* FIXME LATER: MSVC generates section names
976
       like .text for comdats.  Gas generates
977
       names like .text$foo__Fv (in the case of a
978
       function).  See comment above for more.  */
979
980
341
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
271
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
271
          " does not match section name '%s'"),
984
271
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
341
    seen_state = 1;
988
341
    target_name = strchr (name, '$');
989
341
    if (target_name != NULL)
990
38
      {
991
        /* Gas mode.  */
992
38
        seen_state = 2;
993
        /* Skip the `$'.  */
994
38
        target_name += 1;
995
38
      }
996
997
341
    if (isym.n_numaux == 0)
998
61
      aux.x_scn.x_comdat = 0;
999
280
    else
1000
280
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
280
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
6
          {
1004
      /* xgettext:c-format */
1005
6
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
6
                " section '%s' found"),
1007
6
              abfd, symname);
1008
6
      break;
1009
6
          }
1010
274
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
274
            isym.n_type, isym.n_sclass,
1012
274
            0, isym.n_numaux, &aux);
1013
274
      }
1014
1015
    /* FIXME: Microsoft uses NODUPLICATES and
1016
       ASSOCIATIVE, but gnu uses ANY and
1017
       SAME_SIZE.  Unfortunately, gnu doesn't do
1018
       the comdat symbols right.  So, until we can
1019
       fix it to do the right thing, we are
1020
       temporarily disabling comdats for the MS
1021
       types (they're used in DLLs and C++, but we
1022
       don't support *their* C++ libraries anyway
1023
       - DJ.  */
1024
1025
    /* Cygwin does not follow the MS style, and
1026
       uses ANY and SAME_SIZE where NODUPLICATES
1027
       and ASSOCIATIVE should be used.  For
1028
       Interix, we just do the right thing up
1029
       front.  */
1030
1031
335
    switch (aux.x_scn.x_comdat)
1032
335
      {
1033
50
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
50
        *sec_flags &= ~SEC_LINK_ONCE;
1038
50
#endif
1039
50
        break;
1040
1041
2
      case IMAGE_COMDAT_SELECT_ANY:
1042
2
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
2
        break;
1044
1045
24
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
24
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
24
        break;
1048
1049
22
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
22
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
22
        break;
1053
1054
        /* debug$S gets this case; other
1055
           implications ??? */
1056
1057
        /* There may be no symbol... we'll search
1058
           the whole table... Is this the right
1059
           place to play this game? Or should we do
1060
           it when reading it in.  */
1061
26
      case IMAGE_COMDAT_SELECT_ASSOCIATIVE:
1062
#ifdef STRICT_PE_FORMAT
1063
        /* FIXME: This is not currently implemented.  */
1064
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1065
#else
1066
26
        *sec_flags &= ~SEC_LINK_ONCE;
1067
26
#endif
1068
26
        break;
1069
1070
211
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
211
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
211
        break;
1075
335
      }
1076
335
        }
1077
335
        break;
1078
1079
335
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
#ifndef TARGET_UNDERSCORE
1083
#define TARGET_UNDERSCORE 0
1084
#endif
1085
        /* Is this the name we're looking for ?  */
1086
279
        if (strcmp (target_name,
1087
279
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
276
    {
1089
      /* Not the name we're looking for */
1090
276
      continue;
1091
276
    }
1092
        /* Fall through.  */
1093
86
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
86
        {
1097
    /* This must the second symbol with the
1098
       section #.  It is the actual symbol name.
1099
       Intel puts the two adjacent, but Alpha (at
1100
       least) spreads them out.  */
1101
1102
86
    struct coff_comdat_info *comdat;
1103
86
    size_t len = strlen (symname) + 1;
1104
1105
86
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
86
    if (comdat == NULL)
1107
0
      return false;
1108
1109
86
    coff_section_data (abfd, section)->comdat = comdat;
1110
86
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
86
    char *newname = (char *) (comdat + 1);
1112
86
    comdat->name = newname;
1113
86
    memcpy (newname, symname, len);
1114
86
    return true;
1115
86
        }
1116
718
      }
1117
718
  }
1118
44.6k
    }
1119
1120
1.57k
  return true;
1121
1.69k
}
Unexecuted instantiation: pe-x86_64.c:handle_COMDAT
pei-x86_64.c:handle_COMDAT
Line
Count
Source
861
2.08k
{
862
2.08k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
2.08k
  bfd_byte *esymstart, *esym, *esymend;
864
2.08k
  int seen_state = 0;
865
2.08k
  char *target_name = NULL;
866
867
2.08k
  *sec_flags |= SEC_LINK_ONCE;
868
869
  /* Unfortunately, the PE format stores essential information in
870
     the symbol table, of all places.  We need to extract that
871
     information now, so that objdump and the linker will know how
872
     to handle the section without worrying about the symbols.  We
873
     can't call slurp_symtab, because the linker doesn't want the
874
     swapped symbols.  */
875
876
  /* COMDAT sections are special.  The first symbol is the section
877
     symbol, which tells what kind of COMDAT section it is.  The
878
     second symbol is the "comdat symbol" - the one with the
879
     unique name.  GNU uses the section symbol for the unique
880
     name; MS uses ".text" for every comdat section.  Sigh.  - DJ */
881
882
  /* This is not mirrored in sec_to_styp_flags(), but there
883
     doesn't seem to be a need to, either, and it would at best be
884
     rather messy.  */
885
886
2.08k
  if (! _bfd_coff_get_external_symbols (abfd))
887
794
    return true;
888
889
1.29k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
1.29k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
1.29k
  for (struct internal_syment isym;
893
22.3k
       esym < esymend;
894
21.0k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
21.1k
    {
896
21.1k
      char buf[SYMNMLEN + 1];
897
21.1k
      const char *symname;
898
899
21.1k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
21.1k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
21.1k
      if (isym.n_scnum == section->target_index)
904
486
  {
905
    /* According to the MSVC documentation, the first
906
       TWO entries with the section # are both of
907
       interest to us.  The first one is the "section
908
       symbol" (section name).  The second is the comdat
909
       symbol name.  Here, we've found the first
910
       qualifying entry; we distinguish it from the
911
       second with a state flag.
912
913
       In the case of gas-generated (at least until that
914
       is fixed) .o files, it isn't necessarily the
915
       second one.  It may be some other later symbol.
916
917
       Since gas also doesn't follow MS conventions and
918
       emits the section similar to .text$<name>, where
919
       <something> is the name we're looking for, we
920
       distinguish the two as follows:
921
922
       If the section name is simply a section name (no
923
       $) we presume it's MS-generated, and look at
924
       precisely the second symbol for the comdat name.
925
       If the section name has a $, we assume it's
926
       gas-generated, and look for <something> (whatever
927
       follows the $) as the comdat symbol.  */
928
929
    /* All 3 branches use this.  */
930
486
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
486
    if (symname == NULL)
934
4
      {
935
4
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
4
          abfd);
937
4
        return false;
938
4
      }
939
940
482
    switch (seen_state)
941
482
      {
942
371
      case 0:
943
371
        {
944
    /* The first time we've seen the symbol.  */
945
371
    union internal_auxent aux;
946
947
    /* If it isn't the stuff we're expecting, die;
948
       The MS documentation is vague, but it
949
       appears that the second entry serves BOTH
950
       as the comdat symbol and the defining
951
       symbol record (either C_STAT or C_EXT,
952
       possibly with an aux entry with debug
953
       information if it's a function.)  It
954
       appears the only way to find the second one
955
       is to count.  (On Intel, they appear to be
956
       adjacent, but on Alpha, they have been
957
       found separated.)
958
959
       Here, we think we've found the first one,
960
       but there's some checking we can do to be
961
       sure.  */
962
963
371
    if (! ((isym.n_sclass == C_STAT
964
371
      || isym.n_sclass == C_EXT)
965
371
           && BTYPE (isym.n_type) == T_NULL
966
371
           && isym.n_value == 0))
967
12
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
12
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
12
          abfd, symname);
972
12
        return false;
973
12
      }
974
975
    /* FIXME LATER: MSVC generates section names
976
       like .text for comdats.  Gas generates
977
       names like .text$foo__Fv (in the case of a
978
       function).  See comment above for more.  */
979
980
359
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
320
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
320
          " does not match section name '%s'"),
984
320
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
359
    seen_state = 1;
988
359
    target_name = strchr (name, '$');
989
359
    if (target_name != NULL)
990
25
      {
991
        /* Gas mode.  */
992
25
        seen_state = 2;
993
        /* Skip the `$'.  */
994
25
        target_name += 1;
995
25
      }
996
997
359
    if (isym.n_numaux == 0)
998
110
      aux.x_scn.x_comdat = 0;
999
249
    else
1000
249
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
249
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
7
          {
1004
      /* xgettext:c-format */
1005
7
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
7
                " section '%s' found"),
1007
7
              abfd, symname);
1008
7
      break;
1009
7
          }
1010
242
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
242
            isym.n_type, isym.n_sclass,
1012
242
            0, isym.n_numaux, &aux);
1013
242
      }
1014
1015
    /* FIXME: Microsoft uses NODUPLICATES and
1016
       ASSOCIATIVE, but gnu uses ANY and
1017
       SAME_SIZE.  Unfortunately, gnu doesn't do
1018
       the comdat symbols right.  So, until we can
1019
       fix it to do the right thing, we are
1020
       temporarily disabling comdats for the MS
1021
       types (they're used in DLLs and C++, but we
1022
       don't support *their* C++ libraries anyway
1023
       - DJ.  */
1024
1025
    /* Cygwin does not follow the MS style, and
1026
       uses ANY and SAME_SIZE where NODUPLICATES
1027
       and ASSOCIATIVE should be used.  For
1028
       Interix, we just do the right thing up
1029
       front.  */
1030
1031
352
    switch (aux.x_scn.x_comdat)
1032
352
      {
1033
25
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
25
        *sec_flags &= ~SEC_LINK_ONCE;
1038
25
#endif
1039
25
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
22
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
22
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
22
        break;
1048
1049
23
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
23
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
23
        break;
1053
1054
        /* debug$S gets this case; other
1055
           implications ??? */
1056
1057
        /* There may be no symbol... we'll search
1058
           the whole table... Is this the right
1059
           place to play this game? Or should we do
1060
           it when reading it in.  */
1061
27
      case IMAGE_COMDAT_SELECT_ASSOCIATIVE:
1062
#ifdef STRICT_PE_FORMAT
1063
        /* FIXME: This is not currently implemented.  */
1064
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1065
#else
1066
27
        *sec_flags &= ~SEC_LINK_ONCE;
1067
27
#endif
1068
27
        break;
1069
1070
255
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
255
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
255
        break;
1075
352
      }
1076
352
        }
1077
352
        break;
1078
1079
352
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
#ifndef TARGET_UNDERSCORE
1083
#define TARGET_UNDERSCORE 0
1084
#endif
1085
        /* Is this the name we're looking for ?  */
1086
16
        if (strcmp (target_name,
1087
16
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
13
    {
1089
      /* Not the name we're looking for */
1090
13
      continue;
1091
13
    }
1092
        /* Fall through.  */
1093
98
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
98
        {
1097
    /* This must the second symbol with the
1098
       section #.  It is the actual symbol name.
1099
       Intel puts the two adjacent, but Alpha (at
1100
       least) spreads them out.  */
1101
1102
98
    struct coff_comdat_info *comdat;
1103
98
    size_t len = strlen (symname) + 1;
1104
1105
98
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
98
    if (comdat == NULL)
1107
0
      return false;
1108
1109
98
    coff_section_data (abfd, section)->comdat = comdat;
1110
98
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
98
    char *newname = (char *) (comdat + 1);
1112
98
    comdat->name = newname;
1113
98
    memcpy (newname, symname, len);
1114
98
    return true;
1115
98
        }
1116
482
      }
1117
482
  }
1118
21.1k
    }
1119
1120
1.17k
  return true;
1121
1.29k
}
pei-aarch64.c:handle_COMDAT
Line
Count
Source
861
2.41k
{
862
2.41k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
2.41k
  bfd_byte *esymstart, *esym, *esymend;
864
2.41k
  int seen_state = 0;
865
2.41k
  char *target_name = NULL;
866
867
2.41k
  *sec_flags |= SEC_LINK_ONCE;
868
869
  /* Unfortunately, the PE format stores essential information in
870
     the symbol table, of all places.  We need to extract that
871
     information now, so that objdump and the linker will know how
872
     to handle the section without worrying about the symbols.  We
873
     can't call slurp_symtab, because the linker doesn't want the
874
     swapped symbols.  */
875
876
  /* COMDAT sections are special.  The first symbol is the section
877
     symbol, which tells what kind of COMDAT section it is.  The
878
     second symbol is the "comdat symbol" - the one with the
879
     unique name.  GNU uses the section symbol for the unique
880
     name; MS uses ".text" for every comdat section.  Sigh.  - DJ */
881
882
  /* This is not mirrored in sec_to_styp_flags(), but there
883
     doesn't seem to be a need to, either, and it would at best be
884
     rather messy.  */
885
886
2.41k
  if (! _bfd_coff_get_external_symbols (abfd))
887
734
    return true;
888
889
1.67k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
1.67k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
1.67k
  for (struct internal_syment isym;
893
40.1k
       esym < esymend;
894
38.4k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
38.6k
    {
896
38.6k
      char buf[SYMNMLEN + 1];
897
38.6k
      const char *symname;
898
899
38.6k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
38.6k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
38.6k
      if (isym.n_scnum == section->target_index)
904
695
  {
905
    /* According to the MSVC documentation, the first
906
       TWO entries with the section # are both of
907
       interest to us.  The first one is the "section
908
       symbol" (section name).  The second is the comdat
909
       symbol name.  Here, we've found the first
910
       qualifying entry; we distinguish it from the
911
       second with a state flag.
912
913
       In the case of gas-generated (at least until that
914
       is fixed) .o files, it isn't necessarily the
915
       second one.  It may be some other later symbol.
916
917
       Since gas also doesn't follow MS conventions and
918
       emits the section similar to .text$<name>, where
919
       <something> is the name we're looking for, we
920
       distinguish the two as follows:
921
922
       If the section name is simply a section name (no
923
       $) we presume it's MS-generated, and look at
924
       precisely the second symbol for the comdat name.
925
       If the section name has a $, we assume it's
926
       gas-generated, and look for <something> (whatever
927
       follows the $) as the comdat symbol.  */
928
929
    /* All 3 branches use this.  */
930
695
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
695
    if (symname == NULL)
934
8
      {
935
8
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
8
          abfd);
937
8
        return false;
938
8
      }
939
940
687
    switch (seen_state)
941
687
      {
942
362
      case 0:
943
362
        {
944
    /* The first time we've seen the symbol.  */
945
362
    union internal_auxent aux;
946
947
    /* If it isn't the stuff we're expecting, die;
948
       The MS documentation is vague, but it
949
       appears that the second entry serves BOTH
950
       as the comdat symbol and the defining
951
       symbol record (either C_STAT or C_EXT,
952
       possibly with an aux entry with debug
953
       information if it's a function.)  It
954
       appears the only way to find the second one
955
       is to count.  (On Intel, they appear to be
956
       adjacent, but on Alpha, they have been
957
       found separated.)
958
959
       Here, we think we've found the first one,
960
       but there's some checking we can do to be
961
       sure.  */
962
963
362
    if (! ((isym.n_sclass == C_STAT
964
362
      || isym.n_sclass == C_EXT)
965
362
           && BTYPE (isym.n_type) == T_NULL
966
362
           && isym.n_value == 0))
967
31
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
31
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
31
          abfd, symname);
972
31
        return false;
973
31
      }
974
975
    /* FIXME LATER: MSVC generates section names
976
       like .text for comdats.  Gas generates
977
       names like .text$foo__Fv (in the case of a
978
       function).  See comment above for more.  */
979
980
331
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
275
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
275
          " does not match section name '%s'"),
984
275
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
331
    seen_state = 1;
988
331
    target_name = strchr (name, '$');
989
331
    if (target_name != NULL)
990
25
      {
991
        /* Gas mode.  */
992
25
        seen_state = 2;
993
        /* Skip the `$'.  */
994
25
        target_name += 1;
995
25
      }
996
997
331
    if (isym.n_numaux == 0)
998
126
      aux.x_scn.x_comdat = 0;
999
205
    else
1000
205
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
205
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
3
          {
1004
      /* xgettext:c-format */
1005
3
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
3
                " section '%s' found"),
1007
3
              abfd, symname);
1008
3
      break;
1009
3
          }
1010
202
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
202
            isym.n_type, isym.n_sclass,
1012
202
            0, isym.n_numaux, &aux);
1013
202
      }
1014
1015
    /* FIXME: Microsoft uses NODUPLICATES and
1016
       ASSOCIATIVE, but gnu uses ANY and
1017
       SAME_SIZE.  Unfortunately, gnu doesn't do
1018
       the comdat symbols right.  So, until we can
1019
       fix it to do the right thing, we are
1020
       temporarily disabling comdats for the MS
1021
       types (they're used in DLLs and C++, but we
1022
       don't support *their* C++ libraries anyway
1023
       - DJ.  */
1024
1025
    /* Cygwin does not follow the MS style, and
1026
       uses ANY and SAME_SIZE where NODUPLICATES
1027
       and ASSOCIATIVE should be used.  For
1028
       Interix, we just do the right thing up
1029
       front.  */
1030
1031
328
    switch (aux.x_scn.x_comdat)
1032
328
      {
1033
35
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
35
        *sec_flags &= ~SEC_LINK_ONCE;
1038
35
#endif
1039
35
        break;
1040
1041
1
      case IMAGE_COMDAT_SELECT_ANY:
1042
1
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
1
        break;
1044
1045
15
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
15
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
15
        break;
1048
1049
16
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
16
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
16
        break;
1053
1054
        /* debug$S gets this case; other
1055
           implications ??? */
1056
1057
        /* There may be no symbol... we'll search
1058
           the whole table... Is this the right
1059
           place to play this game? Or should we do
1060
           it when reading it in.  */
1061
14
      case IMAGE_COMDAT_SELECT_ASSOCIATIVE:
1062
#ifdef STRICT_PE_FORMAT
1063
        /* FIXME: This is not currently implemented.  */
1064
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1065
#else
1066
14
        *sec_flags &= ~SEC_LINK_ONCE;
1067
14
#endif
1068
14
        break;
1069
1070
247
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
247
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
247
        break;
1075
328
      }
1076
328
        }
1077
328
        break;
1078
1079
328
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
246
#ifndef TARGET_UNDERSCORE
1083
246
#define TARGET_UNDERSCORE 0
1084
246
#endif
1085
        /* Is this the name we're looking for ?  */
1086
246
        if (strcmp (target_name,
1087
246
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
243
    {
1089
      /* Not the name we're looking for */
1090
243
      continue;
1091
243
    }
1092
        /* Fall through.  */
1093
82
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
82
        {
1097
    /* This must the second symbol with the
1098
       section #.  It is the actual symbol name.
1099
       Intel puts the two adjacent, but Alpha (at
1100
       least) spreads them out.  */
1101
1102
82
    struct coff_comdat_info *comdat;
1103
82
    size_t len = strlen (symname) + 1;
1104
1105
82
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
82
    if (comdat == NULL)
1107
0
      return false;
1108
1109
82
    coff_section_data (abfd, section)->comdat = comdat;
1110
82
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
82
    char *newname = (char *) (comdat + 1);
1112
82
    comdat->name = newname;
1113
82
    memcpy (newname, symname, len);
1114
82
    return true;
1115
82
        }
1116
687
      }
1117
687
  }
1118
38.6k
    }
1119
1120
1.55k
  return true;
1121
1.67k
}
Unexecuted instantiation: pe-aarch64.c:handle_COMDAT
pei-ia64.c:handle_COMDAT
Line
Count
Source
861
1.97k
{
862
1.97k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
1.97k
  bfd_byte *esymstart, *esym, *esymend;
864
1.97k
  int seen_state = 0;
865
1.97k
  char *target_name = NULL;
866
867
1.97k
  *sec_flags |= SEC_LINK_ONCE;
868
869
  /* Unfortunately, the PE format stores essential information in
870
     the symbol table, of all places.  We need to extract that
871
     information now, so that objdump and the linker will know how
872
     to handle the section without worrying about the symbols.  We
873
     can't call slurp_symtab, because the linker doesn't want the
874
     swapped symbols.  */
875
876
  /* COMDAT sections are special.  The first symbol is the section
877
     symbol, which tells what kind of COMDAT section it is.  The
878
     second symbol is the "comdat symbol" - the one with the
879
     unique name.  GNU uses the section symbol for the unique
880
     name; MS uses ".text" for every comdat section.  Sigh.  - DJ */
881
882
  /* This is not mirrored in sec_to_styp_flags(), but there
883
     doesn't seem to be a need to, either, and it would at best be
884
     rather messy.  */
885
886
1.97k
  if (! _bfd_coff_get_external_symbols (abfd))
887
749
    return true;
888
889
1.22k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
1.22k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
1.22k
  for (struct internal_syment isym;
893
28.0k
       esym < esymend;
894
26.8k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
26.9k
    {
896
26.9k
      char buf[SYMNMLEN + 1];
897
26.9k
      const char *symname;
898
899
26.9k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
26.9k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
26.9k
      if (isym.n_scnum == section->target_index)
904
663
  {
905
    /* According to the MSVC documentation, the first
906
       TWO entries with the section # are both of
907
       interest to us.  The first one is the "section
908
       symbol" (section name).  The second is the comdat
909
       symbol name.  Here, we've found the first
910
       qualifying entry; we distinguish it from the
911
       second with a state flag.
912
913
       In the case of gas-generated (at least until that
914
       is fixed) .o files, it isn't necessarily the
915
       second one.  It may be some other later symbol.
916
917
       Since gas also doesn't follow MS conventions and
918
       emits the section similar to .text$<name>, where
919
       <something> is the name we're looking for, we
920
       distinguish the two as follows:
921
922
       If the section name is simply a section name (no
923
       $) we presume it's MS-generated, and look at
924
       precisely the second symbol for the comdat name.
925
       If the section name has a $, we assume it's
926
       gas-generated, and look for <something> (whatever
927
       follows the $) as the comdat symbol.  */
928
929
    /* All 3 branches use this.  */
930
663
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
663
    if (symname == NULL)
934
5
      {
935
5
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
5
          abfd);
937
5
        return false;
938
5
      }
939
940
658
    switch (seen_state)
941
658
      {
942
328
      case 0:
943
328
        {
944
    /* The first time we've seen the symbol.  */
945
328
    union internal_auxent aux;
946
947
    /* If it isn't the stuff we're expecting, die;
948
       The MS documentation is vague, but it
949
       appears that the second entry serves BOTH
950
       as the comdat symbol and the defining
951
       symbol record (either C_STAT or C_EXT,
952
       possibly with an aux entry with debug
953
       information if it's a function.)  It
954
       appears the only way to find the second one
955
       is to count.  (On Intel, they appear to be
956
       adjacent, but on Alpha, they have been
957
       found separated.)
958
959
       Here, we think we've found the first one,
960
       but there's some checking we can do to be
961
       sure.  */
962
963
328
    if (! ((isym.n_sclass == C_STAT
964
328
      || isym.n_sclass == C_EXT)
965
328
           && BTYPE (isym.n_type) == T_NULL
966
328
           && isym.n_value == 0))
967
23
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
23
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
23
          abfd, symname);
972
23
        return false;
973
23
      }
974
975
    /* FIXME LATER: MSVC generates section names
976
       like .text for comdats.  Gas generates
977
       names like .text$foo__Fv (in the case of a
978
       function).  See comment above for more.  */
979
980
305
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
284
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
284
          " does not match section name '%s'"),
984
284
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
305
    seen_state = 1;
988
305
    target_name = strchr (name, '$');
989
305
    if (target_name != NULL)
990
32
      {
991
        /* Gas mode.  */
992
32
        seen_state = 2;
993
        /* Skip the `$'.  */
994
32
        target_name += 1;
995
32
      }
996
997
305
    if (isym.n_numaux == 0)
998
105
      aux.x_scn.x_comdat = 0;
999
200
    else
1000
200
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
200
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
1
          {
1004
      /* xgettext:c-format */
1005
1
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
1
                " section '%s' found"),
1007
1
              abfd, symname);
1008
1
      break;
1009
1
          }
1010
199
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
199
            isym.n_type, isym.n_sclass,
1012
199
            0, isym.n_numaux, &aux);
1013
199
      }
1014
1015
    /* FIXME: Microsoft uses NODUPLICATES and
1016
       ASSOCIATIVE, but gnu uses ANY and
1017
       SAME_SIZE.  Unfortunately, gnu doesn't do
1018
       the comdat symbols right.  So, until we can
1019
       fix it to do the right thing, we are
1020
       temporarily disabling comdats for the MS
1021
       types (they're used in DLLs and C++, but we
1022
       don't support *their* C++ libraries anyway
1023
       - DJ.  */
1024
1025
    /* Cygwin does not follow the MS style, and
1026
       uses ANY and SAME_SIZE where NODUPLICATES
1027
       and ASSOCIATIVE should be used.  For
1028
       Interix, we just do the right thing up
1029
       front.  */
1030
1031
304
    switch (aux.x_scn.x_comdat)
1032
304
      {
1033
40
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
40
        *sec_flags &= ~SEC_LINK_ONCE;
1038
40
#endif
1039
40
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
11
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
11
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
11
        break;
1048
1049
26
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
26
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
26
        break;
1053
1054
        /* debug$S gets this case; other
1055
           implications ??? */
1056
1057
        /* There may be no symbol... we'll search
1058
           the whole table... Is this the right
1059
           place to play this game? Or should we do
1060
           it when reading it in.  */
1061
15
      case IMAGE_COMDAT_SELECT_ASSOCIATIVE:
1062
#ifdef STRICT_PE_FORMAT
1063
        /* FIXME: This is not currently implemented.  */
1064
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1065
#else
1066
15
        *sec_flags &= ~SEC_LINK_ONCE;
1067
15
#endif
1068
15
        break;
1069
1070
212
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
212
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
212
        break;
1075
304
      }
1076
304
        }
1077
304
        break;
1078
1079
304
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
#ifndef TARGET_UNDERSCORE
1083
#define TARGET_UNDERSCORE 0
1084
#endif
1085
        /* Is this the name we're looking for ?  */
1086
256
        if (strcmp (target_name,
1087
256
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
252
    {
1089
      /* Not the name we're looking for */
1090
252
      continue;
1091
252
    }
1092
        /* Fall through.  */
1093
78
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
78
        {
1097
    /* This must the second symbol with the
1098
       section #.  It is the actual symbol name.
1099
       Intel puts the two adjacent, but Alpha (at
1100
       least) spreads them out.  */
1101
1102
78
    struct coff_comdat_info *comdat;
1103
78
    size_t len = strlen (symname) + 1;
1104
1105
78
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
78
    if (comdat == NULL)
1107
0
      return false;
1108
1109
78
    coff_section_data (abfd, section)->comdat = comdat;
1110
78
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
78
    char *newname = (char *) (comdat + 1);
1112
78
    comdat->name = newname;
1113
78
    memcpy (newname, symname, len);
1114
78
    return true;
1115
78
        }
1116
658
      }
1117
658
  }
1118
26.9k
    }
1119
1120
1.12k
  return true;
1121
1.22k
}
pei-loongarch64.c:handle_COMDAT
Line
Count
Source
861
2.45k
{
862
2.45k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
2.45k
  bfd_byte *esymstart, *esym, *esymend;
864
2.45k
  int seen_state = 0;
865
2.45k
  char *target_name = NULL;
866
867
2.45k
  *sec_flags |= SEC_LINK_ONCE;
868
869
  /* Unfortunately, the PE format stores essential information in
870
     the symbol table, of all places.  We need to extract that
871
     information now, so that objdump and the linker will know how
872
     to handle the section without worrying about the symbols.  We
873
     can't call slurp_symtab, because the linker doesn't want the
874
     swapped symbols.  */
875
876
  /* COMDAT sections are special.  The first symbol is the section
877
     symbol, which tells what kind of COMDAT section it is.  The
878
     second symbol is the "comdat symbol" - the one with the
879
     unique name.  GNU uses the section symbol for the unique
880
     name; MS uses ".text" for every comdat section.  Sigh.  - DJ */
881
882
  /* This is not mirrored in sec_to_styp_flags(), but there
883
     doesn't seem to be a need to, either, and it would at best be
884
     rather messy.  */
885
886
2.45k
  if (! _bfd_coff_get_external_symbols (abfd))
887
859
    return true;
888
889
1.59k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
1.59k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
1.59k
  for (struct internal_syment isym;
893
38.3k
       esym < esymend;
894
36.7k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
36.8k
    {
896
36.8k
      char buf[SYMNMLEN + 1];
897
36.8k
      const char *symname;
898
899
36.8k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
36.8k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
36.8k
      if (isym.n_scnum == section->target_index)
904
596
  {
905
    /* According to the MSVC documentation, the first
906
       TWO entries with the section # are both of
907
       interest to us.  The first one is the "section
908
       symbol" (section name).  The second is the comdat
909
       symbol name.  Here, we've found the first
910
       qualifying entry; we distinguish it from the
911
       second with a state flag.
912
913
       In the case of gas-generated (at least until that
914
       is fixed) .o files, it isn't necessarily the
915
       second one.  It may be some other later symbol.
916
917
       Since gas also doesn't follow MS conventions and
918
       emits the section similar to .text$<name>, where
919
       <something> is the name we're looking for, we
920
       distinguish the two as follows:
921
922
       If the section name is simply a section name (no
923
       $) we presume it's MS-generated, and look at
924
       precisely the second symbol for the comdat name.
925
       If the section name has a $, we assume it's
926
       gas-generated, and look for <something> (whatever
927
       follows the $) as the comdat symbol.  */
928
929
    /* All 3 branches use this.  */
930
596
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
596
    if (symname == NULL)
934
13
      {
935
13
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
13
          abfd);
937
13
        return false;
938
13
      }
939
940
583
    switch (seen_state)
941
583
      {
942
286
      case 0:
943
286
        {
944
    /* The first time we've seen the symbol.  */
945
286
    union internal_auxent aux;
946
947
    /* If it isn't the stuff we're expecting, die;
948
       The MS documentation is vague, but it
949
       appears that the second entry serves BOTH
950
       as the comdat symbol and the defining
951
       symbol record (either C_STAT or C_EXT,
952
       possibly with an aux entry with debug
953
       information if it's a function.)  It
954
       appears the only way to find the second one
955
       is to count.  (On Intel, they appear to be
956
       adjacent, but on Alpha, they have been
957
       found separated.)
958
959
       Here, we think we've found the first one,
960
       but there's some checking we can do to be
961
       sure.  */
962
963
286
    if (! ((isym.n_sclass == C_STAT
964
286
      || isym.n_sclass == C_EXT)
965
286
           && BTYPE (isym.n_type) == T_NULL
966
286
           && isym.n_value == 0))
967
21
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
21
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
21
          abfd, symname);
972
21
        return false;
973
21
      }
974
975
    /* FIXME LATER: MSVC generates section names
976
       like .text for comdats.  Gas generates
977
       names like .text$foo__Fv (in the case of a
978
       function).  See comment above for more.  */
979
980
265
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
223
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
223
          " does not match section name '%s'"),
984
223
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
265
    seen_state = 1;
988
265
    target_name = strchr (name, '$');
989
265
    if (target_name != NULL)
990
20
      {
991
        /* Gas mode.  */
992
20
        seen_state = 2;
993
        /* Skip the `$'.  */
994
20
        target_name += 1;
995
20
      }
996
997
265
    if (isym.n_numaux == 0)
998
113
      aux.x_scn.x_comdat = 0;
999
152
    else
1000
152
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
152
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
1
          {
1004
      /* xgettext:c-format */
1005
1
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
1
                " section '%s' found"),
1007
1
              abfd, symname);
1008
1
      break;
1009
1
          }
1010
151
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
151
            isym.n_type, isym.n_sclass,
1012
151
            0, isym.n_numaux, &aux);
1013
151
      }
1014
1015
    /* FIXME: Microsoft uses NODUPLICATES and
1016
       ASSOCIATIVE, but gnu uses ANY and
1017
       SAME_SIZE.  Unfortunately, gnu doesn't do
1018
       the comdat symbols right.  So, until we can
1019
       fix it to do the right thing, we are
1020
       temporarily disabling comdats for the MS
1021
       types (they're used in DLLs and C++, but we
1022
       don't support *their* C++ libraries anyway
1023
       - DJ.  */
1024
1025
    /* Cygwin does not follow the MS style, and
1026
       uses ANY and SAME_SIZE where NODUPLICATES
1027
       and ASSOCIATIVE should be used.  For
1028
       Interix, we just do the right thing up
1029
       front.  */
1030
1031
264
    switch (aux.x_scn.x_comdat)
1032
264
      {
1033
24
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
24
        *sec_flags &= ~SEC_LINK_ONCE;
1038
24
#endif
1039
24
        break;
1040
1041
1
      case IMAGE_COMDAT_SELECT_ANY:
1042
1
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
1
        break;
1044
1045
11
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
11
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
11
        break;
1048
1049
13
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
13
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
13
        break;
1053
1054
        /* debug$S gets this case; other
1055
           implications ??? */
1056
1057
        /* There may be no symbol... we'll search
1058
           the whole table... Is this the right
1059
           place to play this game? Or should we do
1060
           it when reading it in.  */
1061
13
      case IMAGE_COMDAT_SELECT_ASSOCIATIVE:
1062
#ifdef STRICT_PE_FORMAT
1063
        /* FIXME: This is not currently implemented.  */
1064
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1065
#else
1066
13
        *sec_flags &= ~SEC_LINK_ONCE;
1067
13
#endif
1068
13
        break;
1069
1070
202
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
202
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
202
        break;
1075
264
      }
1076
264
        }
1077
264
        break;
1078
1079
264
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
239
#ifndef TARGET_UNDERSCORE
1083
239
#define TARGET_UNDERSCORE 0
1084
239
#endif
1085
        /* Is this the name we're looking for ?  */
1086
239
        if (strcmp (target_name,
1087
239
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
238
    {
1089
      /* Not the name we're looking for */
1090
238
      continue;
1091
238
    }
1092
        /* Fall through.  */
1093
59
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
59
        {
1097
    /* This must the second symbol with the
1098
       section #.  It is the actual symbol name.
1099
       Intel puts the two adjacent, but Alpha (at
1100
       least) spreads them out.  */
1101
1102
59
    struct coff_comdat_info *comdat;
1103
59
    size_t len = strlen (symname) + 1;
1104
1105
59
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
59
    if (comdat == NULL)
1107
0
      return false;
1108
1109
59
    coff_section_data (abfd, section)->comdat = comdat;
1110
59
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
59
    char *newname = (char *) (comdat + 1);
1112
59
    comdat->name = newname;
1113
59
    memcpy (newname, symname, len);
1114
59
    return true;
1115
59
        }
1116
583
      }
1117
583
  }
1118
36.8k
    }
1119
1120
1.50k
  return true;
1121
1.59k
}
Unexecuted instantiation: pe-arm-wince.c:handle_COMDAT
Unexecuted instantiation: pe-arm.c:handle_COMDAT
pe-i386.c:handle_COMDAT
Line
Count
Source
861
4.16k
{
862
4.16k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
4.16k
  bfd_byte *esymstart, *esym, *esymend;
864
4.16k
  int seen_state = 0;
865
4.16k
  char *target_name = NULL;
866
867
4.16k
  *sec_flags |= SEC_LINK_ONCE;
868
869
  /* Unfortunately, the PE format stores essential information in
870
     the symbol table, of all places.  We need to extract that
871
     information now, so that objdump and the linker will know how
872
     to handle the section without worrying about the symbols.  We
873
     can't call slurp_symtab, because the linker doesn't want the
874
     swapped symbols.  */
875
876
  /* COMDAT sections are special.  The first symbol is the section
877
     symbol, which tells what kind of COMDAT section it is.  The
878
     second symbol is the "comdat symbol" - the one with the
879
     unique name.  GNU uses the section symbol for the unique
880
     name; MS uses ".text" for every comdat section.  Sigh.  - DJ */
881
882
  /* This is not mirrored in sec_to_styp_flags(), but there
883
     doesn't seem to be a need to, either, and it would at best be
884
     rather messy.  */
885
886
4.16k
  if (! _bfd_coff_get_external_symbols (abfd))
887
3.01k
    return true;
888
889
1.15k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
1.15k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
1.15k
  for (struct internal_syment isym;
893
20.4k
       esym < esymend;
894
19.3k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
19.4k
    {
896
19.4k
      char buf[SYMNMLEN + 1];
897
19.4k
      const char *symname;
898
899
19.4k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
19.4k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
19.4k
      if (isym.n_scnum == section->target_index)
904
279
  {
905
    /* According to the MSVC documentation, the first
906
       TWO entries with the section # are both of
907
       interest to us.  The first one is the "section
908
       symbol" (section name).  The second is the comdat
909
       symbol name.  Here, we've found the first
910
       qualifying entry; we distinguish it from the
911
       second with a state flag.
912
913
       In the case of gas-generated (at least until that
914
       is fixed) .o files, it isn't necessarily the
915
       second one.  It may be some other later symbol.
916
917
       Since gas also doesn't follow MS conventions and
918
       emits the section similar to .text$<name>, where
919
       <something> is the name we're looking for, we
920
       distinguish the two as follows:
921
922
       If the section name is simply a section name (no
923
       $) we presume it's MS-generated, and look at
924
       precisely the second symbol for the comdat name.
925
       If the section name has a $, we assume it's
926
       gas-generated, and look for <something> (whatever
927
       follows the $) as the comdat symbol.  */
928
929
    /* All 3 branches use this.  */
930
279
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
279
    if (symname == NULL)
934
22
      {
935
22
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
22
          abfd);
937
22
        return false;
938
22
      }
939
940
257
    switch (seen_state)
941
257
      {
942
199
      case 0:
943
199
        {
944
    /* The first time we've seen the symbol.  */
945
199
    union internal_auxent aux;
946
947
    /* If it isn't the stuff we're expecting, die;
948
       The MS documentation is vague, but it
949
       appears that the second entry serves BOTH
950
       as the comdat symbol and the defining
951
       symbol record (either C_STAT or C_EXT,
952
       possibly with an aux entry with debug
953
       information if it's a function.)  It
954
       appears the only way to find the second one
955
       is to count.  (On Intel, they appear to be
956
       adjacent, but on Alpha, they have been
957
       found separated.)
958
959
       Here, we think we've found the first one,
960
       but there's some checking we can do to be
961
       sure.  */
962
963
199
    if (! ((isym.n_sclass == C_STAT
964
199
      || isym.n_sclass == C_EXT)
965
199
           && BTYPE (isym.n_type) == T_NULL
966
199
           && isym.n_value == 0))
967
42
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
42
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
42
          abfd, symname);
972
42
        return false;
973
42
      }
974
975
    /* FIXME LATER: MSVC generates section names
976
       like .text for comdats.  Gas generates
977
       names like .text$foo__Fv (in the case of a
978
       function).  See comment above for more.  */
979
980
157
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
135
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
135
          " does not match section name '%s'"),
984
135
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
157
    seen_state = 1;
988
157
    target_name = strchr (name, '$');
989
157
    if (target_name != NULL)
990
12
      {
991
        /* Gas mode.  */
992
12
        seen_state = 2;
993
        /* Skip the `$'.  */
994
12
        target_name += 1;
995
12
      }
996
997
157
    if (isym.n_numaux == 0)
998
30
      aux.x_scn.x_comdat = 0;
999
127
    else
1000
127
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
127
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
2
          {
1004
      /* xgettext:c-format */
1005
2
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
2
                " section '%s' found"),
1007
2
              abfd, symname);
1008
2
      break;
1009
2
          }
1010
125
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
125
            isym.n_type, isym.n_sclass,
1012
125
            0, isym.n_numaux, &aux);
1013
125
      }
1014
1015
    /* FIXME: Microsoft uses NODUPLICATES and
1016
       ASSOCIATIVE, but gnu uses ANY and
1017
       SAME_SIZE.  Unfortunately, gnu doesn't do
1018
       the comdat symbols right.  So, until we can
1019
       fix it to do the right thing, we are
1020
       temporarily disabling comdats for the MS
1021
       types (they're used in DLLs and C++, but we
1022
       don't support *their* C++ libraries anyway
1023
       - DJ.  */
1024
1025
    /* Cygwin does not follow the MS style, and
1026
       uses ANY and SAME_SIZE where NODUPLICATES
1027
       and ASSOCIATIVE should be used.  For
1028
       Interix, we just do the right thing up
1029
       front.  */
1030
1031
155
    switch (aux.x_scn.x_comdat)
1032
155
      {
1033
21
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
21
        *sec_flags &= ~SEC_LINK_ONCE;
1038
21
#endif
1039
21
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
11
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
11
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
11
        break;
1048
1049
12
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
12
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
12
        break;
1053
1054
        /* debug$S gets this case; other
1055
           implications ??? */
1056
1057
        /* There may be no symbol... we'll search
1058
           the whole table... Is this the right
1059
           place to play this game? Or should we do
1060
           it when reading it in.  */
1061
19
      case IMAGE_COMDAT_SELECT_ASSOCIATIVE:
1062
#ifdef STRICT_PE_FORMAT
1063
        /* FIXME: This is not currently implemented.  */
1064
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1065
#else
1066
19
        *sec_flags &= ~SEC_LINK_ONCE;
1067
19
#endif
1068
19
        break;
1069
1070
92
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
92
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
92
        break;
1075
155
      }
1076
155
        }
1077
155
        break;
1078
1079
155
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
#ifndef TARGET_UNDERSCORE
1083
#define TARGET_UNDERSCORE 0
1084
#endif
1085
        /* Is this the name we're looking for ?  */
1086
16
        if (strcmp (target_name,
1087
16
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
15
    {
1089
      /* Not the name we're looking for */
1090
15
      continue;
1091
15
    }
1092
        /* Fall through.  */
1093
43
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
43
        {
1097
    /* This must the second symbol with the
1098
       section #.  It is the actual symbol name.
1099
       Intel puts the two adjacent, but Alpha (at
1100
       least) spreads them out.  */
1101
1102
43
    struct coff_comdat_info *comdat;
1103
43
    size_t len = strlen (symname) + 1;
1104
1105
43
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
43
    if (comdat == NULL)
1107
0
      return false;
1108
1109
43
    coff_section_data (abfd, section)->comdat = comdat;
1110
43
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
43
    char *newname = (char *) (comdat + 1);
1112
43
    comdat->name = newname;
1113
43
    memcpy (newname, symname, len);
1114
43
    return true;
1115
43
        }
1116
257
      }
1117
257
  }
1118
19.4k
    }
1119
1120
1.04k
  return true;
1121
1.15k
}
Unexecuted instantiation: pe-mcore.c:handle_COMDAT
Unexecuted instantiation: pe-sh.c:handle_COMDAT
pei-arm-wince.c:handle_COMDAT
Line
Count
Source
861
2.91k
{
862
2.91k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
2.91k
  bfd_byte *esymstart, *esym, *esymend;
864
2.91k
  int seen_state = 0;
865
2.91k
  char *target_name = NULL;
866
867
2.91k
  *sec_flags |= SEC_LINK_ONCE;
868
869
  /* Unfortunately, the PE format stores essential information in
870
     the symbol table, of all places.  We need to extract that
871
     information now, so that objdump and the linker will know how
872
     to handle the section without worrying about the symbols.  We
873
     can't call slurp_symtab, because the linker doesn't want the
874
     swapped symbols.  */
875
876
  /* COMDAT sections are special.  The first symbol is the section
877
     symbol, which tells what kind of COMDAT section it is.  The
878
     second symbol is the "comdat symbol" - the one with the
879
     unique name.  GNU uses the section symbol for the unique
880
     name; MS uses ".text" for every comdat section.  Sigh.  - DJ */
881
882
  /* This is not mirrored in sec_to_styp_flags(), but there
883
     doesn't seem to be a need to, either, and it would at best be
884
     rather messy.  */
885
886
2.91k
  if (! _bfd_coff_get_external_symbols (abfd))
887
1.73k
    return true;
888
889
1.18k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
1.18k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
1.18k
  for (struct internal_syment isym;
893
26.5k
       esym < esymend;
894
25.3k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
25.4k
    {
896
25.4k
      char buf[SYMNMLEN + 1];
897
25.4k
      const char *symname;
898
899
25.4k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
25.4k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
25.4k
      if (isym.n_scnum == section->target_index)
904
600
  {
905
    /* According to the MSVC documentation, the first
906
       TWO entries with the section # are both of
907
       interest to us.  The first one is the "section
908
       symbol" (section name).  The second is the comdat
909
       symbol name.  Here, we've found the first
910
       qualifying entry; we distinguish it from the
911
       second with a state flag.
912
913
       In the case of gas-generated (at least until that
914
       is fixed) .o files, it isn't necessarily the
915
       second one.  It may be some other later symbol.
916
917
       Since gas also doesn't follow MS conventions and
918
       emits the section similar to .text$<name>, where
919
       <something> is the name we're looking for, we
920
       distinguish the two as follows:
921
922
       If the section name is simply a section name (no
923
       $) we presume it's MS-generated, and look at
924
       precisely the second symbol for the comdat name.
925
       If the section name has a $, we assume it's
926
       gas-generated, and look for <something> (whatever
927
       follows the $) as the comdat symbol.  */
928
929
    /* All 3 branches use this.  */
930
600
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
600
    if (symname == NULL)
934
8
      {
935
8
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
8
          abfd);
937
8
        return false;
938
8
      }
939
940
592
    switch (seen_state)
941
592
      {
942
300
      case 0:
943
300
        {
944
    /* The first time we've seen the symbol.  */
945
300
    union internal_auxent aux;
946
947
    /* If it isn't the stuff we're expecting, die;
948
       The MS documentation is vague, but it
949
       appears that the second entry serves BOTH
950
       as the comdat symbol and the defining
951
       symbol record (either C_STAT or C_EXT,
952
       possibly with an aux entry with debug
953
       information if it's a function.)  It
954
       appears the only way to find the second one
955
       is to count.  (On Intel, they appear to be
956
       adjacent, but on Alpha, they have been
957
       found separated.)
958
959
       Here, we think we've found the first one,
960
       but there's some checking we can do to be
961
       sure.  */
962
963
300
    if (! ((isym.n_sclass == C_STAT
964
300
      || isym.n_sclass == C_EXT)
965
300
           && BTYPE (isym.n_type) == T_NULL
966
300
           && isym.n_value == 0))
967
28
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
28
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
28
          abfd, symname);
972
28
        return false;
973
28
      }
974
975
    /* FIXME LATER: MSVC generates section names
976
       like .text for comdats.  Gas generates
977
       names like .text$foo__Fv (in the case of a
978
       function).  See comment above for more.  */
979
980
272
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
234
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
234
          " does not match section name '%s'"),
984
234
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
272
    seen_state = 1;
988
272
    target_name = strchr (name, '$');
989
272
    if (target_name != NULL)
990
20
      {
991
        /* Gas mode.  */
992
20
        seen_state = 2;
993
        /* Skip the `$'.  */
994
20
        target_name += 1;
995
20
      }
996
997
272
    if (isym.n_numaux == 0)
998
97
      aux.x_scn.x_comdat = 0;
999
175
    else
1000
175
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
175
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
12
          {
1004
      /* xgettext:c-format */
1005
12
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
12
                " section '%s' found"),
1007
12
              abfd, symname);
1008
12
      break;
1009
12
          }
1010
163
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
163
            isym.n_type, isym.n_sclass,
1012
163
            0, isym.n_numaux, &aux);
1013
163
      }
1014
1015
    /* FIXME: Microsoft uses NODUPLICATES and
1016
       ASSOCIATIVE, but gnu uses ANY and
1017
       SAME_SIZE.  Unfortunately, gnu doesn't do
1018
       the comdat symbols right.  So, until we can
1019
       fix it to do the right thing, we are
1020
       temporarily disabling comdats for the MS
1021
       types (they're used in DLLs and C++, but we
1022
       don't support *their* C++ libraries anyway
1023
       - DJ.  */
1024
1025
    /* Cygwin does not follow the MS style, and
1026
       uses ANY and SAME_SIZE where NODUPLICATES
1027
       and ASSOCIATIVE should be used.  For
1028
       Interix, we just do the right thing up
1029
       front.  */
1030
1031
260
    switch (aux.x_scn.x_comdat)
1032
260
      {
1033
43
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
43
        *sec_flags &= ~SEC_LINK_ONCE;
1038
43
#endif
1039
43
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
10
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
10
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
10
        break;
1048
1049
18
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
18
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
18
        break;
1053
1054
        /* debug$S gets this case; other
1055
           implications ??? */
1056
1057
        /* There may be no symbol... we'll search
1058
           the whole table... Is this the right
1059
           place to play this game? Or should we do
1060
           it when reading it in.  */
1061
11
      case IMAGE_COMDAT_SELECT_ASSOCIATIVE:
1062
#ifdef STRICT_PE_FORMAT
1063
        /* FIXME: This is not currently implemented.  */
1064
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1065
#else
1066
11
        *sec_flags &= ~SEC_LINK_ONCE;
1067
11
#endif
1068
11
        break;
1069
1070
178
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
178
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
178
        break;
1075
260
      }
1076
260
        }
1077
260
        break;
1078
1079
260
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
#ifndef TARGET_UNDERSCORE
1083
#define TARGET_UNDERSCORE 0
1084
#endif
1085
        /* Is this the name we're looking for ?  */
1086
233
        if (strcmp (target_name,
1087
233
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
232
    {
1089
      /* Not the name we're looking for */
1090
232
      continue;
1091
232
    }
1092
        /* Fall through.  */
1093
60
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
60
        {
1097
    /* This must the second symbol with the
1098
       section #.  It is the actual symbol name.
1099
       Intel puts the two adjacent, but Alpha (at
1100
       least) spreads them out.  */
1101
1102
60
    struct coff_comdat_info *comdat;
1103
60
    size_t len = strlen (symname) + 1;
1104
1105
60
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
60
    if (comdat == NULL)
1107
0
      return false;
1108
1109
60
    coff_section_data (abfd, section)->comdat = comdat;
1110
60
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
60
    char *newname = (char *) (comdat + 1);
1112
60
    comdat->name = newname;
1113
60
    memcpy (newname, symname, len);
1114
60
    return true;
1115
60
        }
1116
592
      }
1117
592
  }
1118
25.4k
    }
1119
1120
1.08k
  return true;
1121
1.18k
}
pei-arm.c:handle_COMDAT
Line
Count
Source
861
3.62k
{
862
3.62k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
3.62k
  bfd_byte *esymstart, *esym, *esymend;
864
3.62k
  int seen_state = 0;
865
3.62k
  char *target_name = NULL;
866
867
3.62k
  *sec_flags |= SEC_LINK_ONCE;
868
869
  /* Unfortunately, the PE format stores essential information in
870
     the symbol table, of all places.  We need to extract that
871
     information now, so that objdump and the linker will know how
872
     to handle the section without worrying about the symbols.  We
873
     can't call slurp_symtab, because the linker doesn't want the
874
     swapped symbols.  */
875
876
  /* COMDAT sections are special.  The first symbol is the section
877
     symbol, which tells what kind of COMDAT section it is.  The
878
     second symbol is the "comdat symbol" - the one with the
879
     unique name.  GNU uses the section symbol for the unique
880
     name; MS uses ".text" for every comdat section.  Sigh.  - DJ */
881
882
  /* This is not mirrored in sec_to_styp_flags(), but there
883
     doesn't seem to be a need to, either, and it would at best be
884
     rather messy.  */
885
886
3.62k
  if (! _bfd_coff_get_external_symbols (abfd))
887
1.91k
    return true;
888
889
1.70k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
1.70k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
1.70k
  for (struct internal_syment isym;
893
30.6k
       esym < esymend;
894
28.9k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
29.0k
    {
896
29.0k
      char buf[SYMNMLEN + 1];
897
29.0k
      const char *symname;
898
899
29.0k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
29.0k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
29.0k
      if (isym.n_scnum == section->target_index)
904
698
  {
905
    /* According to the MSVC documentation, the first
906
       TWO entries with the section # are both of
907
       interest to us.  The first one is the "section
908
       symbol" (section name).  The second is the comdat
909
       symbol name.  Here, we've found the first
910
       qualifying entry; we distinguish it from the
911
       second with a state flag.
912
913
       In the case of gas-generated (at least until that
914
       is fixed) .o files, it isn't necessarily the
915
       second one.  It may be some other later symbol.
916
917
       Since gas also doesn't follow MS conventions and
918
       emits the section similar to .text$<name>, where
919
       <something> is the name we're looking for, we
920
       distinguish the two as follows:
921
922
       If the section name is simply a section name (no
923
       $) we presume it's MS-generated, and look at
924
       precisely the second symbol for the comdat name.
925
       If the section name has a $, we assume it's
926
       gas-generated, and look for <something> (whatever
927
       follows the $) as the comdat symbol.  */
928
929
    /* All 3 branches use this.  */
930
698
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
698
    if (symname == NULL)
934
14
      {
935
14
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
14
          abfd);
937
14
        return false;
938
14
      }
939
940
684
    switch (seen_state)
941
684
      {
942
377
      case 0:
943
377
        {
944
    /* The first time we've seen the symbol.  */
945
377
    union internal_auxent aux;
946
947
    /* If it isn't the stuff we're expecting, die;
948
       The MS documentation is vague, but it
949
       appears that the second entry serves BOTH
950
       as the comdat symbol and the defining
951
       symbol record (either C_STAT or C_EXT,
952
       possibly with an aux entry with debug
953
       information if it's a function.)  It
954
       appears the only way to find the second one
955
       is to count.  (On Intel, they appear to be
956
       adjacent, but on Alpha, they have been
957
       found separated.)
958
959
       Here, we think we've found the first one,
960
       but there's some checking we can do to be
961
       sure.  */
962
963
377
    if (! ((isym.n_sclass == C_STAT
964
377
      || isym.n_sclass == C_EXT)
965
377
           && BTYPE (isym.n_type) == T_NULL
966
377
           && isym.n_value == 0))
967
30
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
30
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
30
          abfd, symname);
972
30
        return false;
973
30
      }
974
975
    /* FIXME LATER: MSVC generates section names
976
       like .text for comdats.  Gas generates
977
       names like .text$foo__Fv (in the case of a
978
       function).  See comment above for more.  */
979
980
347
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
302
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
302
          " does not match section name '%s'"),
984
302
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
347
    seen_state = 1;
988
347
    target_name = strchr (name, '$');
989
347
    if (target_name != NULL)
990
23
      {
991
        /* Gas mode.  */
992
23
        seen_state = 2;
993
        /* Skip the `$'.  */
994
23
        target_name += 1;
995
23
      }
996
997
347
    if (isym.n_numaux == 0)
998
141
      aux.x_scn.x_comdat = 0;
999
206
    else
1000
206
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
206
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
12
          {
1004
      /* xgettext:c-format */
1005
12
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
12
                " section '%s' found"),
1007
12
              abfd, symname);
1008
12
      break;
1009
12
          }
1010
194
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
194
            isym.n_type, isym.n_sclass,
1012
194
            0, isym.n_numaux, &aux);
1013
194
      }
1014
1015
    /* FIXME: Microsoft uses NODUPLICATES and
1016
       ASSOCIATIVE, but gnu uses ANY and
1017
       SAME_SIZE.  Unfortunately, gnu doesn't do
1018
       the comdat symbols right.  So, until we can
1019
       fix it to do the right thing, we are
1020
       temporarily disabling comdats for the MS
1021
       types (they're used in DLLs and C++, but we
1022
       don't support *their* C++ libraries anyway
1023
       - DJ.  */
1024
1025
    /* Cygwin does not follow the MS style, and
1026
       uses ANY and SAME_SIZE where NODUPLICATES
1027
       and ASSOCIATIVE should be used.  For
1028
       Interix, we just do the right thing up
1029
       front.  */
1030
1031
335
    switch (aux.x_scn.x_comdat)
1032
335
      {
1033
48
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
48
        *sec_flags &= ~SEC_LINK_ONCE;
1038
48
#endif
1039
48
        break;
1040
1041
1
      case IMAGE_COMDAT_SELECT_ANY:
1042
1
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
1
        break;
1044
1045
10
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
10
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
10
        break;
1048
1049
18
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
18
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
18
        break;
1053
1054
        /* debug$S gets this case; other
1055
           implications ??? */
1056
1057
        /* There may be no symbol... we'll search
1058
           the whole table... Is this the right
1059
           place to play this game? Or should we do
1060
           it when reading it in.  */
1061
11
      case IMAGE_COMDAT_SELECT_ASSOCIATIVE:
1062
#ifdef STRICT_PE_FORMAT
1063
        /* FIXME: This is not currently implemented.  */
1064
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1065
#else
1066
11
        *sec_flags &= ~SEC_LINK_ONCE;
1067
11
#endif
1068
11
        break;
1069
1070
247
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
247
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
247
        break;
1075
335
      }
1076
335
        }
1077
335
        break;
1078
1079
335
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
#ifndef TARGET_UNDERSCORE
1083
#define TARGET_UNDERSCORE 0
1084
#endif
1085
        /* Is this the name we're looking for ?  */
1086
236
        if (strcmp (target_name,
1087
236
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
232
    {
1089
      /* Not the name we're looking for */
1090
232
      continue;
1091
232
    }
1092
        /* Fall through.  */
1093
75
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
75
        {
1097
    /* This must the second symbol with the
1098
       section #.  It is the actual symbol name.
1099
       Intel puts the two adjacent, but Alpha (at
1100
       least) spreads them out.  */
1101
1102
75
    struct coff_comdat_info *comdat;
1103
75
    size_t len = strlen (symname) + 1;
1104
1105
75
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
75
    if (comdat == NULL)
1107
0
      return false;
1108
1109
75
    coff_section_data (abfd, section)->comdat = comdat;
1110
75
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
75
    char *newname = (char *) (comdat + 1);
1112
75
    comdat->name = newname;
1113
75
    memcpy (newname, symname, len);
1114
75
    return true;
1115
75
        }
1116
684
      }
1117
684
  }
1118
29.0k
    }
1119
1120
1.58k
  return true;
1121
1.70k
}
pei-mcore.c:handle_COMDAT
Line
Count
Source
861
1.36k
{
862
1.36k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
1.36k
  bfd_byte *esymstart, *esym, *esymend;
864
1.36k
  int seen_state = 0;
865
1.36k
  char *target_name = NULL;
866
867
1.36k
  *sec_flags |= SEC_LINK_ONCE;
868
869
  /* Unfortunately, the PE format stores essential information in
870
     the symbol table, of all places.  We need to extract that
871
     information now, so that objdump and the linker will know how
872
     to handle the section without worrying about the symbols.  We
873
     can't call slurp_symtab, because the linker doesn't want the
874
     swapped symbols.  */
875
876
  /* COMDAT sections are special.  The first symbol is the section
877
     symbol, which tells what kind of COMDAT section it is.  The
878
     second symbol is the "comdat symbol" - the one with the
879
     unique name.  GNU uses the section symbol for the unique
880
     name; MS uses ".text" for every comdat section.  Sigh.  - DJ */
881
882
  /* This is not mirrored in sec_to_styp_flags(), but there
883
     doesn't seem to be a need to, either, and it would at best be
884
     rather messy.  */
885
886
1.36k
  if (! _bfd_coff_get_external_symbols (abfd))
887
647
    return true;
888
889
718
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
718
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
718
  for (struct internal_syment isym;
893
28.1k
       esym < esymend;
894
27.3k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
27.4k
    {
896
27.4k
      char buf[SYMNMLEN + 1];
897
27.4k
      const char *symname;
898
899
27.4k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
27.4k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
27.4k
      if (isym.n_scnum == section->target_index)
904
542
  {
905
    /* According to the MSVC documentation, the first
906
       TWO entries with the section # are both of
907
       interest to us.  The first one is the "section
908
       symbol" (section name).  The second is the comdat
909
       symbol name.  Here, we've found the first
910
       qualifying entry; we distinguish it from the
911
       second with a state flag.
912
913
       In the case of gas-generated (at least until that
914
       is fixed) .o files, it isn't necessarily the
915
       second one.  It may be some other later symbol.
916
917
       Since gas also doesn't follow MS conventions and
918
       emits the section similar to .text$<name>, where
919
       <something> is the name we're looking for, we
920
       distinguish the two as follows:
921
922
       If the section name is simply a section name (no
923
       $) we presume it's MS-generated, and look at
924
       precisely the second symbol for the comdat name.
925
       If the section name has a $, we assume it's
926
       gas-generated, and look for <something> (whatever
927
       follows the $) as the comdat symbol.  */
928
929
    /* All 3 branches use this.  */
930
542
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
542
    if (symname == NULL)
934
13
      {
935
13
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
13
          abfd);
937
13
        return false;
938
13
      }
939
940
529
    switch (seen_state)
941
529
      {
942
237
      case 0:
943
237
        {
944
    /* The first time we've seen the symbol.  */
945
237
    union internal_auxent aux;
946
947
    /* If it isn't the stuff we're expecting, die;
948
       The MS documentation is vague, but it
949
       appears that the second entry serves BOTH
950
       as the comdat symbol and the defining
951
       symbol record (either C_STAT or C_EXT,
952
       possibly with an aux entry with debug
953
       information if it's a function.)  It
954
       appears the only way to find the second one
955
       is to count.  (On Intel, they appear to be
956
       adjacent, but on Alpha, they have been
957
       found separated.)
958
959
       Here, we think we've found the first one,
960
       but there's some checking we can do to be
961
       sure.  */
962
963
237
    if (! ((isym.n_sclass == C_STAT
964
237
      || isym.n_sclass == C_EXT)
965
237
           && BTYPE (isym.n_type) == T_NULL
966
237
           && isym.n_value == 0))
967
24
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
24
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
24
          abfd, symname);
972
24
        return false;
973
24
      }
974
975
    /* FIXME LATER: MSVC generates section names
976
       like .text for comdats.  Gas generates
977
       names like .text$foo__Fv (in the case of a
978
       function).  See comment above for more.  */
979
980
213
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
187
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
187
          " does not match section name '%s'"),
984
187
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
213
    seen_state = 1;
988
213
    target_name = strchr (name, '$');
989
213
    if (target_name != NULL)
990
28
      {
991
        /* Gas mode.  */
992
28
        seen_state = 2;
993
        /* Skip the `$'.  */
994
28
        target_name += 1;
995
28
      }
996
997
213
    if (isym.n_numaux == 0)
998
53
      aux.x_scn.x_comdat = 0;
999
160
    else
1000
160
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
160
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
1
          {
1004
      /* xgettext:c-format */
1005
1
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
1
                " section '%s' found"),
1007
1
              abfd, symname);
1008
1
      break;
1009
1
          }
1010
159
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
159
            isym.n_type, isym.n_sclass,
1012
159
            0, isym.n_numaux, &aux);
1013
159
      }
1014
1015
    /* FIXME: Microsoft uses NODUPLICATES and
1016
       ASSOCIATIVE, but gnu uses ANY and
1017
       SAME_SIZE.  Unfortunately, gnu doesn't do
1018
       the comdat symbols right.  So, until we can
1019
       fix it to do the right thing, we are
1020
       temporarily disabling comdats for the MS
1021
       types (they're used in DLLs and C++, but we
1022
       don't support *their* C++ libraries anyway
1023
       - DJ.  */
1024
1025
    /* Cygwin does not follow the MS style, and
1026
       uses ANY and SAME_SIZE where NODUPLICATES
1027
       and ASSOCIATIVE should be used.  For
1028
       Interix, we just do the right thing up
1029
       front.  */
1030
1031
212
    switch (aux.x_scn.x_comdat)
1032
212
      {
1033
25
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
25
        *sec_flags &= ~SEC_LINK_ONCE;
1038
25
#endif
1039
25
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
14
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
14
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
14
        break;
1048
1049
17
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
17
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
17
        break;
1053
1054
        /* debug$S gets this case; other
1055
           implications ??? */
1056
1057
        /* There may be no symbol... we'll search
1058
           the whole table... Is this the right
1059
           place to play this game? Or should we do
1060
           it when reading it in.  */
1061
10
      case IMAGE_COMDAT_SELECT_ASSOCIATIVE:
1062
#ifdef STRICT_PE_FORMAT
1063
        /* FIXME: This is not currently implemented.  */
1064
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1065
#else
1066
10
        *sec_flags &= ~SEC_LINK_ONCE;
1067
10
#endif
1068
10
        break;
1069
1070
146
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
146
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
146
        break;
1075
212
      }
1076
212
        }
1077
212
        break;
1078
1079
247
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
247
#ifndef TARGET_UNDERSCORE
1083
247
#define TARGET_UNDERSCORE 0
1084
247
#endif
1085
        /* Is this the name we're looking for ?  */
1086
247
        if (strcmp (target_name,
1087
247
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
242
    {
1089
      /* Not the name we're looking for */
1090
242
      continue;
1091
242
    }
1092
        /* Fall through.  */
1093
50
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
50
        {
1097
    /* This must the second symbol with the
1098
       section #.  It is the actual symbol name.
1099
       Intel puts the two adjacent, but Alpha (at
1100
       least) spreads them out.  */
1101
1102
50
    struct coff_comdat_info *comdat;
1103
50
    size_t len = strlen (symname) + 1;
1104
1105
50
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
50
    if (comdat == NULL)
1107
0
      return false;
1108
1109
50
    coff_section_data (abfd, section)->comdat = comdat;
1110
50
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
50
    char *newname = (char *) (comdat + 1);
1112
50
    comdat->name = newname;
1113
50
    memcpy (newname, symname, len);
1114
50
    return true;
1115
50
        }
1116
529
      }
1117
529
  }
1118
27.4k
    }
1119
1120
631
  return true;
1121
718
}
pei-sh.c:handle_COMDAT
Line
Count
Source
861
1.78k
{
862
1.78k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
1.78k
  bfd_byte *esymstart, *esym, *esymend;
864
1.78k
  int seen_state = 0;
865
1.78k
  char *target_name = NULL;
866
867
1.78k
  *sec_flags |= SEC_LINK_ONCE;
868
869
  /* Unfortunately, the PE format stores essential information in
870
     the symbol table, of all places.  We need to extract that
871
     information now, so that objdump and the linker will know how
872
     to handle the section without worrying about the symbols.  We
873
     can't call slurp_symtab, because the linker doesn't want the
874
     swapped symbols.  */
875
876
  /* COMDAT sections are special.  The first symbol is the section
877
     symbol, which tells what kind of COMDAT section it is.  The
878
     second symbol is the "comdat symbol" - the one with the
879
     unique name.  GNU uses the section symbol for the unique
880
     name; MS uses ".text" for every comdat section.  Sigh.  - DJ */
881
882
  /* This is not mirrored in sec_to_styp_flags(), but there
883
     doesn't seem to be a need to, either, and it would at best be
884
     rather messy.  */
885
886
1.78k
  if (! _bfd_coff_get_external_symbols (abfd))
887
704
    return true;
888
889
1.08k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
1.08k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
1.08k
  for (struct internal_syment isym;
893
40.5k
       esym < esymend;
894
39.4k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
39.5k
    {
896
39.5k
      char buf[SYMNMLEN + 1];
897
39.5k
      const char *symname;
898
899
39.5k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
39.5k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
39.5k
      if (isym.n_scnum == section->target_index)
904
732
  {
905
    /* According to the MSVC documentation, the first
906
       TWO entries with the section # are both of
907
       interest to us.  The first one is the "section
908
       symbol" (section name).  The second is the comdat
909
       symbol name.  Here, we've found the first
910
       qualifying entry; we distinguish it from the
911
       second with a state flag.
912
913
       In the case of gas-generated (at least until that
914
       is fixed) .o files, it isn't necessarily the
915
       second one.  It may be some other later symbol.
916
917
       Since gas also doesn't follow MS conventions and
918
       emits the section similar to .text$<name>, where
919
       <something> is the name we're looking for, we
920
       distinguish the two as follows:
921
922
       If the section name is simply a section name (no
923
       $) we presume it's MS-generated, and look at
924
       precisely the second symbol for the comdat name.
925
       If the section name has a $, we assume it's
926
       gas-generated, and look for <something> (whatever
927
       follows the $) as the comdat symbol.  */
928
929
    /* All 3 branches use this.  */
930
732
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
732
    if (symname == NULL)
934
14
      {
935
14
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
14
          abfd);
937
14
        return false;
938
14
      }
939
940
718
    switch (seen_state)
941
718
      {
942
246
      case 0:
943
246
        {
944
    /* The first time we've seen the symbol.  */
945
246
    union internal_auxent aux;
946
947
    /* If it isn't the stuff we're expecting, die;
948
       The MS documentation is vague, but it
949
       appears that the second entry serves BOTH
950
       as the comdat symbol and the defining
951
       symbol record (either C_STAT or C_EXT,
952
       possibly with an aux entry with debug
953
       information if it's a function.)  It
954
       appears the only way to find the second one
955
       is to count.  (On Intel, they appear to be
956
       adjacent, but on Alpha, they have been
957
       found separated.)
958
959
       Here, we think we've found the first one,
960
       but there's some checking we can do to be
961
       sure.  */
962
963
246
    if (! ((isym.n_sclass == C_STAT
964
246
      || isym.n_sclass == C_EXT)
965
246
           && BTYPE (isym.n_type) == T_NULL
966
246
           && isym.n_value == 0))
967
35
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
35
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
35
          abfd, symname);
972
35
        return false;
973
35
      }
974
975
    /* FIXME LATER: MSVC generates section names
976
       like .text for comdats.  Gas generates
977
       names like .text$foo__Fv (in the case of a
978
       function).  See comment above for more.  */
979
980
211
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
190
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
190
          " does not match section name '%s'"),
984
190
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
211
    seen_state = 1;
988
211
    target_name = strchr (name, '$');
989
211
    if (target_name != NULL)
990
25
      {
991
        /* Gas mode.  */
992
25
        seen_state = 2;
993
        /* Skip the `$'.  */
994
25
        target_name += 1;
995
25
      }
996
997
211
    if (isym.n_numaux == 0)
998
66
      aux.x_scn.x_comdat = 0;
999
145
    else
1000
145
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
145
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
5
          {
1004
      /* xgettext:c-format */
1005
5
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
5
                " section '%s' found"),
1007
5
              abfd, symname);
1008
5
      break;
1009
5
          }
1010
140
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
140
            isym.n_type, isym.n_sclass,
1012
140
            0, isym.n_numaux, &aux);
1013
140
      }
1014
1015
    /* FIXME: Microsoft uses NODUPLICATES and
1016
       ASSOCIATIVE, but gnu uses ANY and
1017
       SAME_SIZE.  Unfortunately, gnu doesn't do
1018
       the comdat symbols right.  So, until we can
1019
       fix it to do the right thing, we are
1020
       temporarily disabling comdats for the MS
1021
       types (they're used in DLLs and C++, but we
1022
       don't support *their* C++ libraries anyway
1023
       - DJ.  */
1024
1025
    /* Cygwin does not follow the MS style, and
1026
       uses ANY and SAME_SIZE where NODUPLICATES
1027
       and ASSOCIATIVE should be used.  For
1028
       Interix, we just do the right thing up
1029
       front.  */
1030
1031
206
    switch (aux.x_scn.x_comdat)
1032
206
      {
1033
21
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
21
        *sec_flags &= ~SEC_LINK_ONCE;
1038
21
#endif
1039
21
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
12
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
12
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
12
        break;
1048
1049
13
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
13
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
13
        break;
1053
1054
        /* debug$S gets this case; other
1055
           implications ??? */
1056
1057
        /* There may be no symbol... we'll search
1058
           the whole table... Is this the right
1059
           place to play this game? Or should we do
1060
           it when reading it in.  */
1061
10
      case IMAGE_COMDAT_SELECT_ASSOCIATIVE:
1062
#ifdef STRICT_PE_FORMAT
1063
        /* FIXME: This is not currently implemented.  */
1064
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1065
#else
1066
10
        *sec_flags &= ~SEC_LINK_ONCE;
1067
10
#endif
1068
10
        break;
1069
1070
150
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
150
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
150
        break;
1075
206
      }
1076
206
        }
1077
206
        break;
1078
1079
424
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
#ifndef TARGET_UNDERSCORE
1083
#define TARGET_UNDERSCORE 0
1084
#endif
1085
        /* Is this the name we're looking for ?  */
1086
424
        if (strcmp (target_name,
1087
424
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
421
    {
1089
      /* Not the name we're looking for */
1090
421
      continue;
1091
421
    }
1092
        /* Fall through.  */
1093
51
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
51
        {
1097
    /* This must the second symbol with the
1098
       section #.  It is the actual symbol name.
1099
       Intel puts the two adjacent, but Alpha (at
1100
       least) spreads them out.  */
1101
1102
51
    struct coff_comdat_info *comdat;
1103
51
    size_t len = strlen (symname) + 1;
1104
1105
51
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
51
    if (comdat == NULL)
1107
0
      return false;
1108
1109
51
    coff_section_data (abfd, section)->comdat = comdat;
1110
51
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
51
    char *newname = (char *) (comdat + 1);
1112
51
    comdat->name = newname;
1113
51
    memcpy (newname, symname, len);
1114
51
    return true;
1115
51
        }
1116
718
      }
1117
718
  }
1118
39.5k
    }
1119
1120
980
  return true;
1121
1.08k
}
1122
1123
1124
/* The PE version; see above for the general comments.
1125
1126
   Since to set the SEC_LINK_ONCE and associated flags, we have to
1127
   look at the symbol table anyway, we return the symbol table index
1128
   of the symbol being used as the COMDAT symbol.  This is admittedly
1129
   ugly, but there's really nowhere else that we have access to the
1130
   required information.  FIXME: Is the COMDAT symbol index used for
1131
   any purpose other than objdump?  */
1132
1133
static bool
1134
styp_to_sec_flags (bfd *abfd,
1135
       void * hdr,
1136
       const char *name,
1137
       asection *section,
1138
       flagword *flags_ptr)
1139
92.0k
{
1140
92.0k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
92.0k
  unsigned long styp_flags = internal_s->s_flags;
1142
92.0k
  flagword sec_flags;
1143
92.0k
  bool result = true;
1144
92.0k
  bool is_dbg = false;
1145
1146
92.0k
  if (startswith (name, DOT_DEBUG)
1147
92.0k
      || startswith (name, DOT_ZDEBUG)
1148
92.0k
#ifdef COFF_LONG_SECTION_NAMES
1149
92.0k
      || startswith (name, GNU_LINKONCE_WI)
1150
92.0k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
92.0k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
92.0k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
92.0k
      || startswith (name, GNU_DEBUGLINK)
1155
92.0k
      || startswith (name, GNU_DEBUGALTLINK)
1156
92.0k
#endif
1157
92.0k
      || startswith (name, ".stab"))
1158
8.18k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
92.0k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
92.0k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
59.8k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
776k
  while (styp_flags)
1168
684k
    {
1169
684k
      unsigned long flag = styp_flags & - styp_flags;
1170
684k
      char * unhandled = NULL;
1171
1172
684k
      styp_flags &= ~ flag;
1173
1174
      /* We infer from the distinct read/write/execute bits the settings
1175
   of some of the bfd flags; the actual values, should we need them,
1176
   are also in pei_section_data (abfd, section)->pe_flags.  */
1177
1178
684k
      switch (flag)
1179
684k
  {
1180
2.75k
  case STYP_DSECT:
1181
2.75k
    unhandled = "STYP_DSECT";
1182
2.75k
    break;
1183
2.59k
  case STYP_GROUP:
1184
2.59k
    unhandled = "STYP_GROUP";
1185
2.59k
    break;
1186
2.60k
  case STYP_COPY:
1187
2.60k
    unhandled = "STYP_COPY";
1188
2.60k
    break;
1189
2.91k
  case STYP_OVER:
1190
2.91k
    unhandled = "STYP_OVER";
1191
2.91k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
26.3k
  case STYP_NOLOAD:
1194
26.3k
    sec_flags |= SEC_NEVER_LOAD;
1195
26.3k
    break;
1196
0
#endif
1197
32.1k
  case IMAGE_SCN_MEM_READ:
1198
32.1k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
32.1k
    break;
1200
20.9k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
20.9k
    break;
1203
2.94k
  case IMAGE_SCN_LNK_OTHER:
1204
2.94k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
2.94k
    break;
1206
2.70k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
2.70k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
2.70k
    break;
1209
21.8k
  case IMAGE_SCN_MEM_NOT_PAGED:
1210
    /* Generate a warning message rather using the 'unhandled'
1211
       variable as this will allow some .sys files generate by
1212
       other toolchains to be processed.  See bugzilla issue 196.  */
1213
    /* xgettext:c-format */
1214
21.8k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
21.8k
        " %s in section %s"),
1216
21.8k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
21.8k
    break;
1218
27.9k
  case IMAGE_SCN_MEM_EXECUTE:
1219
27.9k
    sec_flags |= SEC_CODE;
1220
27.9k
    break;
1221
39.1k
  case IMAGE_SCN_MEM_WRITE:
1222
39.1k
    sec_flags &= ~ SEC_READONLY;
1223
39.1k
    break;
1224
35.8k
  case IMAGE_SCN_MEM_DISCARDABLE:
1225
    /* The MS PE spec says that debug sections are DISCARDABLE,
1226
       but the presence of a DISCARDABLE flag does not necessarily
1227
       mean that a given section contains debug information.  Thus
1228
       we only set the SEC_DEBUGGING flag on sections that we
1229
       recognise as containing debug information.  */
1230
35.8k
       if (is_dbg
1231
35.8k
#ifdef _COMMENT
1232
35.8k
        || strcmp (name, _COMMENT) == 0
1233
35.8k
#endif
1234
35.8k
        )
1235
10.6k
      {
1236
10.6k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
10.6k
      }
1238
35.8k
    break;
1239
10.5k
  case IMAGE_SCN_MEM_SHARED:
1240
10.5k
    sec_flags |= SEC_COFF_SHARED;
1241
10.5k
    break;
1242
34.9k
  case IMAGE_SCN_LNK_REMOVE:
1243
34.9k
    if (!is_dbg)
1244
31.4k
      sec_flags |= SEC_EXCLUDE;
1245
34.9k
    break;
1246
20.8k
  case IMAGE_SCN_CNT_CODE:
1247
20.8k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
20.8k
    break;
1249
17.6k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
17.6k
    if (is_dbg)
1251
3.72k
      sec_flags |= SEC_DEBUGGING;
1252
13.9k
    else
1253
13.9k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
17.6k
    break;
1255
22.8k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
22.8k
    sec_flags |= SEC_ALLOC;
1257
22.8k
    break;
1258
22.2k
  case IMAGE_SCN_LNK_INFO:
1259
    /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
1260
       defined.  coff_compute_section_file_positions uses
1261
       COFF_PAGE_SIZE to ensure that the low order bits of the
1262
       section VMA and the file offset match.  If we don't know
1263
       COFF_PAGE_SIZE, we can't ensure the correct correspondence,
1264
       and demand page loading of the file will fail.  */
1265
#ifdef COFF_PAGE_SIZE
1266
22.2k
    sec_flags |= SEC_DEBUGGING;
1267
#endif
1268
22.2k
    break;
1269
25.8k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
25.8k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
373
      result = false;
1273
25.8k
    break;
1274
309k
  default:
1275
    /* Silently ignore for now.  */
1276
309k
    break;
1277
684k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
684k
      if (unhandled != NULL)
1281
16.5k
  {
1282
16.5k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
16.5k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
16.5k
       abfd, name, unhandled, flag);
1286
16.5k
    result = false;
1287
16.5k
  }
1288
684k
    }
1289
1290
92.0k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
92.0k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
1296
  /* As a GNU extension, if the name begins with .gnu.linkonce, we
1297
     only link a single copy of the section.  This is used to support
1298
     g++.  g++ will emit each template expansion in its own section.
1299
     The symbols will be defined as weak, so that multiple definitions
1300
     are permitted.  The GNU linker extension is to actually discard
1301
     all but one of the sections.  */
1302
32.9k
  if (startswith (name, ".gnu.linkonce"))
1303
183
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
#endif
1305
1306
92.0k
  if (flags_ptr)
1307
92.0k
    * flags_ptr = sec_flags;
1308
1309
92.0k
  return result;
1310
92.0k
}
pei-i386.c:styp_to_sec_flags
Line
Count
Source
1139
10.6k
{
1140
10.6k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
10.6k
  unsigned long styp_flags = internal_s->s_flags;
1142
10.6k
  flagword sec_flags;
1143
10.6k
  bool result = true;
1144
10.6k
  bool is_dbg = false;
1145
1146
10.6k
  if (startswith (name, DOT_DEBUG)
1147
10.6k
      || startswith (name, DOT_ZDEBUG)
1148
10.6k
#ifdef COFF_LONG_SECTION_NAMES
1149
10.6k
      || startswith (name, GNU_LINKONCE_WI)
1150
10.6k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
10.6k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
10.6k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
10.6k
      || startswith (name, GNU_DEBUGLINK)
1155
10.6k
      || startswith (name, GNU_DEBUGALTLINK)
1156
10.6k
#endif
1157
10.6k
      || startswith (name, ".stab"))
1158
566
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
10.6k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
10.6k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
7.42k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
78.5k
  while (styp_flags)
1168
67.9k
    {
1169
67.9k
      unsigned long flag = styp_flags & - styp_flags;
1170
67.9k
      char * unhandled = NULL;
1171
1172
67.9k
      styp_flags &= ~ flag;
1173
1174
      /* We infer from the distinct read/write/execute bits the settings
1175
   of some of the bfd flags; the actual values, should we need them,
1176
   are also in pei_section_data (abfd, section)->pe_flags.  */
1177
1178
67.9k
      switch (flag)
1179
67.9k
  {
1180
134
  case STYP_DSECT:
1181
134
    unhandled = "STYP_DSECT";
1182
134
    break;
1183
129
  case STYP_GROUP:
1184
129
    unhandled = "STYP_GROUP";
1185
129
    break;
1186
123
  case STYP_COPY:
1187
123
    unhandled = "STYP_COPY";
1188
123
    break;
1189
146
  case STYP_OVER:
1190
146
    unhandled = "STYP_OVER";
1191
146
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
3.29k
  case STYP_NOLOAD:
1194
3.29k
    sec_flags |= SEC_NEVER_LOAD;
1195
3.29k
    break;
1196
0
#endif
1197
3.17k
  case IMAGE_SCN_MEM_READ:
1198
3.17k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
3.17k
    break;
1200
2.21k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
2.21k
    break;
1203
127
  case IMAGE_SCN_LNK_OTHER:
1204
127
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
127
    break;
1206
127
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
127
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
127
    break;
1209
2.31k
  case IMAGE_SCN_MEM_NOT_PAGED:
1210
    /* Generate a warning message rather using the 'unhandled'
1211
       variable as this will allow some .sys files generate by
1212
       other toolchains to be processed.  See bugzilla issue 196.  */
1213
    /* xgettext:c-format */
1214
2.31k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
2.31k
        " %s in section %s"),
1216
2.31k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
2.31k
    break;
1218
2.68k
  case IMAGE_SCN_MEM_EXECUTE:
1219
2.68k
    sec_flags |= SEC_CODE;
1220
2.68k
    break;
1221
3.85k
  case IMAGE_SCN_MEM_WRITE:
1222
3.85k
    sec_flags &= ~ SEC_READONLY;
1223
3.85k
    break;
1224
3.27k
  case IMAGE_SCN_MEM_DISCARDABLE:
1225
    /* The MS PE spec says that debug sections are DISCARDABLE,
1226
       but the presence of a DISCARDABLE flag does not necessarily
1227
       mean that a given section contains debug information.  Thus
1228
       we only set the SEC_DEBUGGING flag on sections that we
1229
       recognise as containing debug information.  */
1230
3.27k
       if (is_dbg
1231
3.27k
#ifdef _COMMENT
1232
3.27k
        || strcmp (name, _COMMENT) == 0
1233
3.27k
#endif
1234
3.27k
        )
1235
869
      {
1236
869
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
869
      }
1238
3.27k
    break;
1239
1.18k
  case IMAGE_SCN_MEM_SHARED:
1240
1.18k
    sec_flags |= SEC_COFF_SHARED;
1241
1.18k
    break;
1242
3.23k
  case IMAGE_SCN_LNK_REMOVE:
1243
3.23k
    if (!is_dbg)
1244
2.98k
      sec_flags |= SEC_EXCLUDE;
1245
3.23k
    break;
1246
2.30k
  case IMAGE_SCN_CNT_CODE:
1247
2.30k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
2.30k
    break;
1249
1.55k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
1.55k
    if (is_dbg)
1251
246
      sec_flags |= SEC_DEBUGGING;
1252
1.30k
    else
1253
1.30k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
1.55k
    break;
1255
2.42k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
2.42k
    sec_flags |= SEC_ALLOC;
1257
2.42k
    break;
1258
2.22k
  case IMAGE_SCN_LNK_INFO:
1259
    /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
1260
       defined.  coff_compute_section_file_positions uses
1261
       COFF_PAGE_SIZE to ensure that the low order bits of the
1262
       section VMA and the file offset match.  If we don't know
1263
       COFF_PAGE_SIZE, we can't ensure the correct correspondence,
1264
       and demand page loading of the file will fail.  */
1265
2.22k
#ifdef COFF_PAGE_SIZE
1266
2.22k
    sec_flags |= SEC_DEBUGGING;
1267
2.22k
#endif
1268
2.22k
    break;
1269
3.06k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
3.06k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
26
      result = false;
1273
3.06k
    break;
1274
30.3k
  default:
1275
    /* Silently ignore for now.  */
1276
30.3k
    break;
1277
67.9k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
67.9k
      if (unhandled != NULL)
1281
786
  {
1282
786
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
786
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
786
       abfd, name, unhandled, flag);
1286
786
    result = false;
1287
786
  }
1288
67.9k
    }
1289
1290
10.6k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
10.6k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
10.6k
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
1296
  /* As a GNU extension, if the name begins with .gnu.linkonce, we
1297
     only link a single copy of the section.  This is used to support
1298
     g++.  g++ will emit each template expansion in its own section.
1299
     The symbols will be defined as weak, so that multiple definitions
1300
     are permitted.  The GNU linker extension is to actually discard
1301
     all but one of the sections.  */
1302
10.6k
  if (startswith (name, ".gnu.linkonce"))
1303
55
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
10.6k
#endif
1305
1306
10.6k
  if (flags_ptr)
1307
10.6k
    * flags_ptr = sec_flags;
1308
1309
10.6k
  return result;
1310
10.6k
}
Unexecuted instantiation: pe-x86_64.c:styp_to_sec_flags
pei-x86_64.c:styp_to_sec_flags
Line
Count
Source
1139
7.07k
{
1140
7.07k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
7.07k
  unsigned long styp_flags = internal_s->s_flags;
1142
7.07k
  flagword sec_flags;
1143
7.07k
  bool result = true;
1144
7.07k
  bool is_dbg = false;
1145
1146
7.07k
  if (startswith (name, DOT_DEBUG)
1147
7.07k
      || startswith (name, DOT_ZDEBUG)
1148
7.07k
#ifdef COFF_LONG_SECTION_NAMES
1149
7.07k
      || startswith (name, GNU_LINKONCE_WI)
1150
7.07k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
7.07k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
7.07k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
7.07k
      || startswith (name, GNU_DEBUGLINK)
1155
7.07k
      || startswith (name, GNU_DEBUGALTLINK)
1156
7.07k
#endif
1157
7.07k
      || startswith (name, ".stab"))
1158
496
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
7.07k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
7.07k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
5.08k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
52.2k
  while (styp_flags)
1168
45.1k
    {
1169
45.1k
      unsigned long flag = styp_flags & - styp_flags;
1170
45.1k
      char * unhandled = NULL;
1171
1172
45.1k
      styp_flags &= ~ flag;
1173
1174
      /* We infer from the distinct read/write/execute bits the settings
1175
   of some of the bfd flags; the actual values, should we need them,
1176
   are also in pei_section_data (abfd, section)->pe_flags.  */
1177
1178
45.1k
      switch (flag)
1179
45.1k
  {
1180
145
  case STYP_DSECT:
1181
145
    unhandled = "STYP_DSECT";
1182
145
    break;
1183
128
  case STYP_GROUP:
1184
128
    unhandled = "STYP_GROUP";
1185
128
    break;
1186
131
  case STYP_COPY:
1187
131
    unhandled = "STYP_COPY";
1188
131
    break;
1189
158
  case STYP_OVER:
1190
158
    unhandled = "STYP_OVER";
1191
158
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
2.00k
  case STYP_NOLOAD:
1194
2.00k
    sec_flags |= SEC_NEVER_LOAD;
1195
2.00k
    break;
1196
0
#endif
1197
1.99k
  case IMAGE_SCN_MEM_READ:
1198
1.99k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
1.99k
    break;
1200
1.45k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
1.45k
    break;
1203
159
  case IMAGE_SCN_LNK_OTHER:
1204
159
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
159
    break;
1206
136
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
136
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
136
    break;
1209
1.58k
  case IMAGE_SCN_MEM_NOT_PAGED:
1210
    /* Generate a warning message rather using the 'unhandled'
1211
       variable as this will allow some .sys files generate by
1212
       other toolchains to be processed.  See bugzilla issue 196.  */
1213
    /* xgettext:c-format */
1214
1.58k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
1.58k
        " %s in section %s"),
1216
1.58k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
1.58k
    break;
1218
1.42k
  case IMAGE_SCN_MEM_EXECUTE:
1219
1.42k
    sec_flags |= SEC_CODE;
1220
1.42k
    break;
1221
2.15k
  case IMAGE_SCN_MEM_WRITE:
1222
2.15k
    sec_flags &= ~ SEC_READONLY;
1223
2.15k
    break;
1224
2.25k
  case IMAGE_SCN_MEM_DISCARDABLE:
1225
    /* The MS PE spec says that debug sections are DISCARDABLE,
1226
       but the presence of a DISCARDABLE flag does not necessarily
1227
       mean that a given section contains debug information.  Thus
1228
       we only set the SEC_DEBUGGING flag on sections that we
1229
       recognise as containing debug information.  */
1230
2.25k
       if (is_dbg
1231
2.25k
#ifdef _COMMENT
1232
2.25k
        || strcmp (name, _COMMENT) == 0
1233
2.25k
#endif
1234
2.25k
        )
1235
551
      {
1236
551
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
551
      }
1238
2.25k
    break;
1239
862
  case IMAGE_SCN_MEM_SHARED:
1240
862
    sec_flags |= SEC_COFF_SHARED;
1241
862
    break;
1242
2.46k
  case IMAGE_SCN_LNK_REMOVE:
1243
2.46k
    if (!is_dbg)
1244
2.28k
      sec_flags |= SEC_EXCLUDE;
1245
2.46k
    break;
1246
1.10k
  case IMAGE_SCN_CNT_CODE:
1247
1.10k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
1.10k
    break;
1249
1.15k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
1.15k
    if (is_dbg)
1251
202
      sec_flags |= SEC_DEBUGGING;
1252
956
    else
1253
956
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
1.15k
    break;
1255
1.48k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
1.48k
    sec_flags |= SEC_ALLOC;
1257
1.48k
    break;
1258
1.51k
  case IMAGE_SCN_LNK_INFO:
1259
    /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
1260
       defined.  coff_compute_section_file_positions uses
1261
       COFF_PAGE_SIZE to ensure that the low order bits of the
1262
       section VMA and the file offset match.  If we don't know
1263
       COFF_PAGE_SIZE, we can't ensure the correct correspondence,
1264
       and demand page loading of the file will fail.  */
1265
1.51k
#ifdef COFF_PAGE_SIZE
1266
1.51k
    sec_flags |= SEC_DEBUGGING;
1267
1.51k
#endif
1268
1.51k
    break;
1269
2.08k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
2.08k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
16
      result = false;
1273
2.08k
    break;
1274
20.7k
  default:
1275
    /* Silently ignore for now.  */
1276
20.7k
    break;
1277
45.1k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
45.1k
      if (unhandled != NULL)
1281
857
  {
1282
857
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
857
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
857
       abfd, name, unhandled, flag);
1286
857
    result = false;
1287
857
  }
1288
45.1k
    }
1289
1290
7.07k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
7.07k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
7.07k
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
1296
  /* As a GNU extension, if the name begins with .gnu.linkonce, we
1297
     only link a single copy of the section.  This is used to support
1298
     g++.  g++ will emit each template expansion in its own section.
1299
     The symbols will be defined as weak, so that multiple definitions
1300
     are permitted.  The GNU linker extension is to actually discard
1301
     all but one of the sections.  */
1302
7.07k
  if (startswith (name, ".gnu.linkonce"))
1303
55
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
7.07k
#endif
1305
1306
7.07k
  if (flags_ptr)
1307
7.07k
    * flags_ptr = sec_flags;
1308
1309
7.07k
  return result;
1310
7.07k
}
pei-aarch64.c:styp_to_sec_flags
Line
Count
Source
1139
7.52k
{
1140
7.52k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
7.52k
  unsigned long styp_flags = internal_s->s_flags;
1142
7.52k
  flagword sec_flags;
1143
7.52k
  bool result = true;
1144
7.52k
  bool is_dbg = false;
1145
1146
7.52k
  if (startswith (name, DOT_DEBUG)
1147
7.52k
      || startswith (name, DOT_ZDEBUG)
1148
7.52k
#ifdef COFF_LONG_SECTION_NAMES
1149
7.52k
      || startswith (name, GNU_LINKONCE_WI)
1150
7.52k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
7.52k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
7.52k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
7.52k
      || startswith (name, GNU_DEBUGLINK)
1155
7.52k
      || startswith (name, GNU_DEBUGALTLINK)
1156
7.52k
#endif
1157
7.52k
      || startswith (name, ".stab"))
1158
716
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
7.52k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
7.52k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
4.59k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
65.7k
  while (styp_flags)
1168
58.2k
    {
1169
58.2k
      unsigned long flag = styp_flags & - styp_flags;
1170
58.2k
      char * unhandled = NULL;
1171
1172
58.2k
      styp_flags &= ~ flag;
1173
1174
      /* We infer from the distinct read/write/execute bits the settings
1175
   of some of the bfd flags; the actual values, should we need them,
1176
   are also in pei_section_data (abfd, section)->pe_flags.  */
1177
1178
58.2k
      switch (flag)
1179
58.2k
  {
1180
251
  case STYP_DSECT:
1181
251
    unhandled = "STYP_DSECT";
1182
251
    break;
1183
241
  case STYP_GROUP:
1184
241
    unhandled = "STYP_GROUP";
1185
241
    break;
1186
245
  case STYP_COPY:
1187
245
    unhandled = "STYP_COPY";
1188
245
    break;
1189
265
  case STYP_OVER:
1190
265
    unhandled = "STYP_OVER";
1191
265
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
2.00k
  case STYP_NOLOAD:
1194
2.00k
    sec_flags |= SEC_NEVER_LOAD;
1195
2.00k
    break;
1196
0
#endif
1197
2.92k
  case IMAGE_SCN_MEM_READ:
1198
2.92k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
2.92k
    break;
1200
1.72k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
1.72k
    break;
1203
279
  case IMAGE_SCN_LNK_OTHER:
1204
279
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
279
    break;
1206
234
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
234
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
234
    break;
1209
1.78k
  case IMAGE_SCN_MEM_NOT_PAGED:
1210
    /* Generate a warning message rather using the 'unhandled'
1211
       variable as this will allow some .sys files generate by
1212
       other toolchains to be processed.  See bugzilla issue 196.  */
1213
    /* xgettext:c-format */
1214
1.78k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
1.78k
        " %s in section %s"),
1216
1.78k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
1.78k
    break;
1218
2.28k
  case IMAGE_SCN_MEM_EXECUTE:
1219
2.28k
    sec_flags |= SEC_CODE;
1220
2.28k
    break;
1221
3.60k
  case IMAGE_SCN_MEM_WRITE:
1222
3.60k
    sec_flags &= ~ SEC_READONLY;
1223
3.60k
    break;
1224
3.07k
  case IMAGE_SCN_MEM_DISCARDABLE:
1225
    /* The MS PE spec says that debug sections are DISCARDABLE,
1226
       but the presence of a DISCARDABLE flag does not necessarily
1227
       mean that a given section contains debug information.  Thus
1228
       we only set the SEC_DEBUGGING flag on sections that we
1229
       recognise as containing debug information.  */
1230
3.07k
       if (is_dbg
1231
3.07k
#ifdef _COMMENT
1232
3.07k
        || strcmp (name, _COMMENT) == 0
1233
3.07k
#endif
1234
3.07k
        )
1235
1.09k
      {
1236
1.09k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
1.09k
      }
1238
3.07k
    break;
1239
981
  case IMAGE_SCN_MEM_SHARED:
1240
981
    sec_flags |= SEC_COFF_SHARED;
1241
981
    break;
1242
3.03k
  case IMAGE_SCN_LNK_REMOVE:
1243
3.03k
    if (!is_dbg)
1244
2.72k
      sec_flags |= SEC_EXCLUDE;
1245
3.03k
    break;
1246
1.60k
  case IMAGE_SCN_CNT_CODE:
1247
1.60k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
1.60k
    break;
1249
1.62k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
1.62k
    if (is_dbg)
1251
346
      sec_flags |= SEC_DEBUGGING;
1252
1.28k
    else
1253
1.28k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
1.62k
    break;
1255
1.80k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
1.80k
    sec_flags |= SEC_ALLOC;
1257
1.80k
    break;
1258
1.84k
  case IMAGE_SCN_LNK_INFO:
1259
    /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
1260
       defined.  coff_compute_section_file_positions uses
1261
       COFF_PAGE_SIZE to ensure that the low order bits of the
1262
       section VMA and the file offset match.  If we don't know
1263
       COFF_PAGE_SIZE, we can't ensure the correct correspondence,
1264
       and demand page loading of the file will fail.  */
1265
1.84k
#ifdef COFF_PAGE_SIZE
1266
1.84k
    sec_flags |= SEC_DEBUGGING;
1267
1.84k
#endif
1268
1.84k
    break;
1269
2.41k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
2.41k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
39
      result = false;
1273
2.41k
    break;
1274
25.9k
  default:
1275
    /* Silently ignore for now.  */
1276
25.9k
    break;
1277
58.2k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
58.2k
      if (unhandled != NULL)
1281
1.51k
  {
1282
1.51k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
1.51k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
1.51k
       abfd, name, unhandled, flag);
1286
1.51k
    result = false;
1287
1.51k
  }
1288
58.2k
    }
1289
1290
7.52k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
7.52k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
1296
  /* As a GNU extension, if the name begins with .gnu.linkonce, we
1297
     only link a single copy of the section.  This is used to support
1298
     g++.  g++ will emit each template expansion in its own section.
1299
     The symbols will be defined as weak, so that multiple definitions
1300
     are permitted.  The GNU linker extension is to actually discard
1301
     all but one of the sections.  */
1302
  if (startswith (name, ".gnu.linkonce"))
1303
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
#endif
1305
1306
7.52k
  if (flags_ptr)
1307
7.52k
    * flags_ptr = sec_flags;
1308
1309
7.52k
  return result;
1310
7.52k
}
Unexecuted instantiation: pe-aarch64.c:styp_to_sec_flags
pei-ia64.c:styp_to_sec_flags
Line
Count
Source
1139
8.36k
{
1140
8.36k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
8.36k
  unsigned long styp_flags = internal_s->s_flags;
1142
8.36k
  flagword sec_flags;
1143
8.36k
  bool result = true;
1144
8.36k
  bool is_dbg = false;
1145
1146
8.36k
  if (startswith (name, DOT_DEBUG)
1147
8.36k
      || startswith (name, DOT_ZDEBUG)
1148
8.36k
#ifdef COFF_LONG_SECTION_NAMES
1149
8.36k
      || startswith (name, GNU_LINKONCE_WI)
1150
8.36k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
8.36k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
8.36k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
8.36k
      || startswith (name, GNU_DEBUGLINK)
1155
8.36k
      || startswith (name, GNU_DEBUGALTLINK)
1156
8.36k
#endif
1157
8.36k
      || startswith (name, ".stab"))
1158
882
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
8.36k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
8.36k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
5.84k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
65.7k
  while (styp_flags)
1168
57.4k
    {
1169
57.4k
      unsigned long flag = styp_flags & - styp_flags;
1170
57.4k
      char * unhandled = NULL;
1171
1172
57.4k
      styp_flags &= ~ flag;
1173
1174
      /* We infer from the distinct read/write/execute bits the settings
1175
   of some of the bfd flags; the actual values, should we need them,
1176
   are also in pei_section_data (abfd, section)->pe_flags.  */
1177
1178
57.4k
      switch (flag)
1179
57.4k
  {
1180
297
  case STYP_DSECT:
1181
297
    unhandled = "STYP_DSECT";
1182
297
    break;
1183
258
  case STYP_GROUP:
1184
258
    unhandled = "STYP_GROUP";
1185
258
    break;
1186
273
  case STYP_COPY:
1187
273
    unhandled = "STYP_COPY";
1188
273
    break;
1189
278
  case STYP_OVER:
1190
278
    unhandled = "STYP_OVER";
1191
278
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
2.44k
  case STYP_NOLOAD:
1194
2.44k
    sec_flags |= SEC_NEVER_LOAD;
1195
2.44k
    break;
1196
0
#endif
1197
2.52k
  case IMAGE_SCN_MEM_READ:
1198
2.52k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
2.52k
    break;
1200
1.82k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
1.82k
    break;
1203
311
  case IMAGE_SCN_LNK_OTHER:
1204
311
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
311
    break;
1206
254
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
254
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
254
    break;
1209
1.56k
  case IMAGE_SCN_MEM_NOT_PAGED:
1210
    /* Generate a warning message rather using the 'unhandled'
1211
       variable as this will allow some .sys files generate by
1212
       other toolchains to be processed.  See bugzilla issue 196.  */
1213
    /* xgettext:c-format */
1214
1.56k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
1.56k
        " %s in section %s"),
1216
1.56k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
1.56k
    break;
1218
2.32k
  case IMAGE_SCN_MEM_EXECUTE:
1219
2.32k
    sec_flags |= SEC_CODE;
1220
2.32k
    break;
1221
3.01k
  case IMAGE_SCN_MEM_WRITE:
1222
3.01k
    sec_flags &= ~ SEC_READONLY;
1223
3.01k
    break;
1224
2.78k
  case IMAGE_SCN_MEM_DISCARDABLE:
1225
    /* The MS PE spec says that debug sections are DISCARDABLE,
1226
       but the presence of a DISCARDABLE flag does not necessarily
1227
       mean that a given section contains debug information.  Thus
1228
       we only set the SEC_DEBUGGING flag on sections that we
1229
       recognise as containing debug information.  */
1230
2.78k
       if (is_dbg
1231
2.78k
#ifdef _COMMENT
1232
2.78k
        || strcmp (name, _COMMENT) == 0
1233
2.78k
#endif
1234
2.78k
        )
1235
842
      {
1236
842
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
842
      }
1238
2.78k
    break;
1239
928
  case IMAGE_SCN_MEM_SHARED:
1240
928
    sec_flags |= SEC_COFF_SHARED;
1241
928
    break;
1242
2.87k
  case IMAGE_SCN_LNK_REMOVE:
1243
2.87k
    if (!is_dbg)
1244
2.47k
      sec_flags |= SEC_EXCLUDE;
1245
2.87k
    break;
1246
1.83k
  case IMAGE_SCN_CNT_CODE:
1247
1.83k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
1.83k
    break;
1249
1.81k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
1.81k
    if (is_dbg)
1251
457
      sec_flags |= SEC_DEBUGGING;
1252
1.35k
    else
1253
1.35k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
1.81k
    break;
1255
1.94k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
1.94k
    sec_flags |= SEC_ALLOC;
1257
1.94k
    break;
1258
1.87k
  case IMAGE_SCN_LNK_INFO:
1259
    /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
1260
       defined.  coff_compute_section_file_positions uses
1261
       COFF_PAGE_SIZE to ensure that the low order bits of the
1262
       section VMA and the file offset match.  If we don't know
1263
       COFF_PAGE_SIZE, we can't ensure the correct correspondence,
1264
       and demand page loading of the file will fail.  */
1265
1.87k
#ifdef COFF_PAGE_SIZE
1266
1.87k
    sec_flags |= SEC_DEBUGGING;
1267
1.87k
#endif
1268
1.87k
    break;
1269
1.97k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
1.97k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
28
      result = false;
1273
1.97k
    break;
1274
26.0k
  default:
1275
    /* Silently ignore for now.  */
1276
26.0k
    break;
1277
57.4k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
57.4k
      if (unhandled != NULL)
1281
1.67k
  {
1282
1.67k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
1.67k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
1.67k
       abfd, name, unhandled, flag);
1286
1.67k
    result = false;
1287
1.67k
  }
1288
57.4k
    }
1289
1290
8.36k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
8.36k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
1296
  /* As a GNU extension, if the name begins with .gnu.linkonce, we
1297
     only link a single copy of the section.  This is used to support
1298
     g++.  g++ will emit each template expansion in its own section.
1299
     The symbols will be defined as weak, so that multiple definitions
1300
     are permitted.  The GNU linker extension is to actually discard
1301
     all but one of the sections.  */
1302
  if (startswith (name, ".gnu.linkonce"))
1303
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
#endif
1305
1306
8.36k
  if (flags_ptr)
1307
8.36k
    * flags_ptr = sec_flags;
1308
1309
8.36k
  return result;
1310
8.36k
}
pei-loongarch64.c:styp_to_sec_flags
Line
Count
Source
1139
8.24k
{
1140
8.24k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
8.24k
  unsigned long styp_flags = internal_s->s_flags;
1142
8.24k
  flagword sec_flags;
1143
8.24k
  bool result = true;
1144
8.24k
  bool is_dbg = false;
1145
1146
8.24k
  if (startswith (name, DOT_DEBUG)
1147
8.24k
      || startswith (name, DOT_ZDEBUG)
1148
8.24k
#ifdef COFF_LONG_SECTION_NAMES
1149
8.24k
      || startswith (name, GNU_LINKONCE_WI)
1150
8.24k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
8.24k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
8.24k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
8.24k
      || startswith (name, GNU_DEBUGLINK)
1155
8.24k
      || startswith (name, GNU_DEBUGALTLINK)
1156
8.24k
#endif
1157
8.24k
      || startswith (name, ".stab"))
1158
812
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
8.24k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
8.24k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
5.14k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
67.2k
  while (styp_flags)
1168
59.0k
    {
1169
59.0k
      unsigned long flag = styp_flags & - styp_flags;
1170
59.0k
      char * unhandled = NULL;
1171
1172
59.0k
      styp_flags &= ~ flag;
1173
1174
      /* We infer from the distinct read/write/execute bits the settings
1175
   of some of the bfd flags; the actual values, should we need them,
1176
   are also in pei_section_data (abfd, section)->pe_flags.  */
1177
1178
59.0k
      switch (flag)
1179
59.0k
  {
1180
228
  case STYP_DSECT:
1181
228
    unhandled = "STYP_DSECT";
1182
228
    break;
1183
240
  case STYP_GROUP:
1184
240
    unhandled = "STYP_GROUP";
1185
240
    break;
1186
227
  case STYP_COPY:
1187
227
    unhandled = "STYP_COPY";
1188
227
    break;
1189
262
  case STYP_OVER:
1190
262
    unhandled = "STYP_OVER";
1191
262
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
2.35k
  case STYP_NOLOAD:
1194
2.35k
    sec_flags |= SEC_NEVER_LOAD;
1195
2.35k
    break;
1196
0
#endif
1197
3.09k
  case IMAGE_SCN_MEM_READ:
1198
3.09k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
3.09k
    break;
1200
1.58k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
1.58k
    break;
1203
257
  case IMAGE_SCN_LNK_OTHER:
1204
257
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
257
    break;
1206
236
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
236
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
236
    break;
1209
2.08k
  case IMAGE_SCN_MEM_NOT_PAGED:
1210
    /* Generate a warning message rather using the 'unhandled'
1211
       variable as this will allow some .sys files generate by
1212
       other toolchains to be processed.  See bugzilla issue 196.  */
1213
    /* xgettext:c-format */
1214
2.08k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
2.08k
        " %s in section %s"),
1216
2.08k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
2.08k
    break;
1218
2.22k
  case IMAGE_SCN_MEM_EXECUTE:
1219
2.22k
    sec_flags |= SEC_CODE;
1220
2.22k
    break;
1221
3.39k
  case IMAGE_SCN_MEM_WRITE:
1222
3.39k
    sec_flags &= ~ SEC_READONLY;
1223
3.39k
    break;
1224
3.07k
  case IMAGE_SCN_MEM_DISCARDABLE:
1225
    /* The MS PE spec says that debug sections are DISCARDABLE,
1226
       but the presence of a DISCARDABLE flag does not necessarily
1227
       mean that a given section contains debug information.  Thus
1228
       we only set the SEC_DEBUGGING flag on sections that we
1229
       recognise as containing debug information.  */
1230
3.07k
       if (is_dbg
1231
3.07k
#ifdef _COMMENT
1232
3.07k
        || strcmp (name, _COMMENT) == 0
1233
3.07k
#endif
1234
3.07k
        )
1235
832
      {
1236
832
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
832
      }
1238
3.07k
    break;
1239
966
  case IMAGE_SCN_MEM_SHARED:
1240
966
    sec_flags |= SEC_COFF_SHARED;
1241
966
    break;
1242
2.66k
  case IMAGE_SCN_LNK_REMOVE:
1243
2.66k
    if (!is_dbg)
1244
2.38k
      sec_flags |= SEC_EXCLUDE;
1245
2.66k
    break;
1246
1.43k
  case IMAGE_SCN_CNT_CODE:
1247
1.43k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
1.43k
    break;
1249
1.87k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
1.87k
    if (is_dbg)
1251
289
      sec_flags |= SEC_DEBUGGING;
1252
1.58k
    else
1253
1.58k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
1.87k
    break;
1255
1.91k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
1.91k
    sec_flags |= SEC_ALLOC;
1257
1.91k
    break;
1258
1.90k
  case IMAGE_SCN_LNK_INFO:
1259
    /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
1260
       defined.  coff_compute_section_file_positions uses
1261
       COFF_PAGE_SIZE to ensure that the low order bits of the
1262
       section VMA and the file offset match.  If we don't know
1263
       COFF_PAGE_SIZE, we can't ensure the correct correspondence,
1264
       and demand page loading of the file will fail.  */
1265
1.90k
#ifdef COFF_PAGE_SIZE
1266
1.90k
    sec_flags |= SEC_DEBUGGING;
1267
1.90k
#endif
1268
1.90k
    break;
1269
2.45k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
2.45k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
34
      result = false;
1273
2.45k
    break;
1274
26.5k
  default:
1275
    /* Silently ignore for now.  */
1276
26.5k
    break;
1277
59.0k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
59.0k
      if (unhandled != NULL)
1281
1.45k
  {
1282
1.45k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
1.45k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
1.45k
       abfd, name, unhandled, flag);
1286
1.45k
    result = false;
1287
1.45k
  }
1288
59.0k
    }
1289
1290
8.24k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
8.24k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
1296
  /* As a GNU extension, if the name begins with .gnu.linkonce, we
1297
     only link a single copy of the section.  This is used to support
1298
     g++.  g++ will emit each template expansion in its own section.
1299
     The symbols will be defined as weak, so that multiple definitions
1300
     are permitted.  The GNU linker extension is to actually discard
1301
     all but one of the sections.  */
1302
  if (startswith (name, ".gnu.linkonce"))
1303
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
#endif
1305
1306
8.24k
  if (flags_ptr)
1307
8.24k
    * flags_ptr = sec_flags;
1308
1309
8.24k
  return result;
1310
8.24k
}
Unexecuted instantiation: pe-arm-wince.c:styp_to_sec_flags
Unexecuted instantiation: pe-arm.c:styp_to_sec_flags
pe-i386.c:styp_to_sec_flags
Line
Count
Source
1139
15.2k
{
1140
15.2k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
15.2k
  unsigned long styp_flags = internal_s->s_flags;
1142
15.2k
  flagword sec_flags;
1143
15.2k
  bool result = true;
1144
15.2k
  bool is_dbg = false;
1145
1146
15.2k
  if (startswith (name, DOT_DEBUG)
1147
15.2k
      || startswith (name, DOT_ZDEBUG)
1148
15.2k
#ifdef COFF_LONG_SECTION_NAMES
1149
15.2k
      || startswith (name, GNU_LINKONCE_WI)
1150
15.2k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
15.2k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
15.2k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
15.2k
      || startswith (name, GNU_DEBUGLINK)
1155
15.2k
      || startswith (name, GNU_DEBUGALTLINK)
1156
15.2k
#endif
1157
15.2k
      || startswith (name, ".stab"))
1158
1.99k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
15.2k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
15.2k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
9.38k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
139k
  while (styp_flags)
1168
124k
    {
1169
124k
      unsigned long flag = styp_flags & - styp_flags;
1170
124k
      char * unhandled = NULL;
1171
1172
124k
      styp_flags &= ~ flag;
1173
1174
      /* We infer from the distinct read/write/execute bits the settings
1175
   of some of the bfd flags; the actual values, should we need them,
1176
   are also in pei_section_data (abfd, section)->pe_flags.  */
1177
1178
124k
      switch (flag)
1179
124k
  {
1180
526
  case STYP_DSECT:
1181
526
    unhandled = "STYP_DSECT";
1182
526
    break;
1183
484
  case STYP_GROUP:
1184
484
    unhandled = "STYP_GROUP";
1185
484
    break;
1186
478
  case STYP_COPY:
1187
478
    unhandled = "STYP_COPY";
1188
478
    break;
1189
525
  case STYP_OVER:
1190
525
    unhandled = "STYP_OVER";
1191
525
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
4.04k
  case STYP_NOLOAD:
1194
4.04k
    sec_flags |= SEC_NEVER_LOAD;
1195
4.04k
    break;
1196
0
#endif
1197
5.85k
  case IMAGE_SCN_MEM_READ:
1198
5.85k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
5.85k
    break;
1200
3.58k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
3.58k
    break;
1203
567
  case IMAGE_SCN_LNK_OTHER:
1204
567
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
567
    break;
1206
594
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
594
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
594
    break;
1209
3.35k
  case IMAGE_SCN_MEM_NOT_PAGED:
1210
    /* Generate a warning message rather using the 'unhandled'
1211
       variable as this will allow some .sys files generate by
1212
       other toolchains to be processed.  See bugzilla issue 196.  */
1213
    /* xgettext:c-format */
1214
3.35k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
3.35k
        " %s in section %s"),
1216
3.35k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
3.35k
    break;
1218
5.21k
  case IMAGE_SCN_MEM_EXECUTE:
1219
5.21k
    sec_flags |= SEC_CODE;
1220
5.21k
    break;
1221
7.81k
  case IMAGE_SCN_MEM_WRITE:
1222
7.81k
    sec_flags &= ~ SEC_READONLY;
1223
7.81k
    break;
1224
7.04k
  case IMAGE_SCN_MEM_DISCARDABLE:
1225
    /* The MS PE spec says that debug sections are DISCARDABLE,
1226
       but the presence of a DISCARDABLE flag does not necessarily
1227
       mean that a given section contains debug information.  Thus
1228
       we only set the SEC_DEBUGGING flag on sections that we
1229
       recognise as containing debug information.  */
1230
7.04k
       if (is_dbg
1231
7.04k
#ifdef _COMMENT
1232
7.04k
        || strcmp (name, _COMMENT) == 0
1233
7.04k
#endif
1234
7.04k
        )
1235
2.70k
      {
1236
2.70k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
2.70k
      }
1238
7.04k
    break;
1239
1.61k
  case IMAGE_SCN_MEM_SHARED:
1240
1.61k
    sec_flags |= SEC_COFF_SHARED;
1241
1.61k
    break;
1242
6.59k
  case IMAGE_SCN_LNK_REMOVE:
1243
6.59k
    if (!is_dbg)
1244
5.63k
      sec_flags |= SEC_EXCLUDE;
1245
6.59k
    break;
1246
3.71k
  case IMAGE_SCN_CNT_CODE:
1247
3.71k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
3.71k
    break;
1249
3.02k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
3.02k
    if (is_dbg)
1251
1.04k
      sec_flags |= SEC_DEBUGGING;
1252
1.97k
    else
1253
1.97k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
3.02k
    break;
1255
3.96k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
3.96k
    sec_flags |= SEC_ALLOC;
1257
3.96k
    break;
1258
4.02k
  case IMAGE_SCN_LNK_INFO:
1259
    /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
1260
       defined.  coff_compute_section_file_positions uses
1261
       COFF_PAGE_SIZE to ensure that the low order bits of the
1262
       section VMA and the file offset match.  If we don't know
1263
       COFF_PAGE_SIZE, we can't ensure the correct correspondence,
1264
       and demand page loading of the file will fail.  */
1265
4.02k
#ifdef COFF_PAGE_SIZE
1266
4.02k
    sec_flags |= SEC_DEBUGGING;
1267
4.02k
#endif
1268
4.02k
    break;
1269
4.16k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
4.16k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
64
      result = false;
1273
4.16k
    break;
1274
57.2k
  default:
1275
    /* Silently ignore for now.  */
1276
57.2k
    break;
1277
124k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
124k
      if (unhandled != NULL)
1281
3.17k
  {
1282
3.17k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
3.17k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
3.17k
       abfd, name, unhandled, flag);
1286
3.17k
    result = false;
1287
3.17k
  }
1288
124k
    }
1289
1290
15.2k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
15.2k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
15.2k
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
1296
  /* As a GNU extension, if the name begins with .gnu.linkonce, we
1297
     only link a single copy of the section.  This is used to support
1298
     g++.  g++ will emit each template expansion in its own section.
1299
     The symbols will be defined as weak, so that multiple definitions
1300
     are permitted.  The GNU linker extension is to actually discard
1301
     all but one of the sections.  */
1302
15.2k
  if (startswith (name, ".gnu.linkonce"))
1303
73
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
15.2k
#endif
1305
1306
15.2k
  if (flags_ptr)
1307
15.2k
    * flags_ptr = sec_flags;
1308
1309
15.2k
  return result;
1310
15.2k
}
Unexecuted instantiation: pe-mcore.c:styp_to_sec_flags
Unexecuted instantiation: pe-sh.c:styp_to_sec_flags
pei-arm-wince.c:styp_to_sec_flags
Line
Count
Source
1139
10.1k
{
1140
10.1k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
10.1k
  unsigned long styp_flags = internal_s->s_flags;
1142
10.1k
  flagword sec_flags;
1143
10.1k
  bool result = true;
1144
10.1k
  bool is_dbg = false;
1145
1146
10.1k
  if (startswith (name, DOT_DEBUG)
1147
10.1k
      || startswith (name, DOT_ZDEBUG)
1148
10.1k
#ifdef COFF_LONG_SECTION_NAMES
1149
10.1k
      || startswith (name, GNU_LINKONCE_WI)
1150
10.1k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
10.1k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
10.1k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
10.1k
      || startswith (name, GNU_DEBUGLINK)
1155
10.1k
      || startswith (name, GNU_DEBUGALTLINK)
1156
10.1k
#endif
1157
10.1k
      || startswith (name, ".stab"))
1158
821
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
10.1k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
10.1k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
6.49k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
92.4k
  while (styp_flags)
1168
82.3k
    {
1169
82.3k
      unsigned long flag = styp_flags & - styp_flags;
1170
82.3k
      char * unhandled = NULL;
1171
1172
82.3k
      styp_flags &= ~ flag;
1173
1174
      /* We infer from the distinct read/write/execute bits the settings
1175
   of some of the bfd flags; the actual values, should we need them,
1176
   are also in pei_section_data (abfd, section)->pe_flags.  */
1177
1178
82.3k
      switch (flag)
1179
82.3k
  {
1180
350
  case STYP_DSECT:
1181
350
    unhandled = "STYP_DSECT";
1182
350
    break;
1183
330
  case STYP_GROUP:
1184
330
    unhandled = "STYP_GROUP";
1185
330
    break;
1186
320
  case STYP_COPY:
1187
320
    unhandled = "STYP_COPY";
1188
320
    break;
1189
385
  case STYP_OVER:
1190
385
    unhandled = "STYP_OVER";
1191
385
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
2.90k
  case STYP_NOLOAD:
1194
2.90k
    sec_flags |= SEC_NEVER_LOAD;
1195
2.90k
    break;
1196
0
#endif
1197
3.64k
  case IMAGE_SCN_MEM_READ:
1198
3.64k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
3.64k
    break;
1200
2.59k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
2.59k
    break;
1203
365
  case IMAGE_SCN_LNK_OTHER:
1204
365
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
365
    break;
1206
336
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
336
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
336
    break;
1209
2.58k
  case IMAGE_SCN_MEM_NOT_PAGED:
1210
    /* Generate a warning message rather using the 'unhandled'
1211
       variable as this will allow some .sys files generate by
1212
       other toolchains to be processed.  See bugzilla issue 196.  */
1213
    /* xgettext:c-format */
1214
2.58k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
2.58k
        " %s in section %s"),
1216
2.58k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
2.58k
    break;
1218
3.46k
  case IMAGE_SCN_MEM_EXECUTE:
1219
3.46k
    sec_flags |= SEC_CODE;
1220
3.46k
    break;
1221
4.66k
  case IMAGE_SCN_MEM_WRITE:
1222
4.66k
    sec_flags &= ~ SEC_READONLY;
1223
4.66k
    break;
1224
4.34k
  case IMAGE_SCN_MEM_DISCARDABLE:
1225
    /* The MS PE spec says that debug sections are DISCARDABLE,
1226
       but the presence of a DISCARDABLE flag does not necessarily
1227
       mean that a given section contains debug information.  Thus
1228
       we only set the SEC_DEBUGGING flag on sections that we
1229
       recognise as containing debug information.  */
1230
4.34k
       if (is_dbg
1231
4.34k
#ifdef _COMMENT
1232
4.34k
        || strcmp (name, _COMMENT) == 0
1233
4.34k
#endif
1234
4.34k
        )
1235
1.24k
      {
1236
1.24k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
1.24k
      }
1238
4.34k
    break;
1239
1.05k
  case IMAGE_SCN_MEM_SHARED:
1240
1.05k
    sec_flags |= SEC_COFF_SHARED;
1241
1.05k
    break;
1242
4.60k
  case IMAGE_SCN_LNK_REMOVE:
1243
4.60k
    if (!is_dbg)
1244
4.26k
      sec_flags |= SEC_EXCLUDE;
1245
4.60k
    break;
1246
2.76k
  case IMAGE_SCN_CNT_CODE:
1247
2.76k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
2.76k
    break;
1249
1.82k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
1.82k
    if (is_dbg)
1251
330
      sec_flags |= SEC_DEBUGGING;
1252
1.49k
    else
1253
1.49k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
1.82k
    break;
1255
2.71k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
2.71k
    sec_flags |= SEC_ALLOC;
1257
2.71k
    break;
1258
2.66k
  case IMAGE_SCN_LNK_INFO:
1259
    /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
1260
       defined.  coff_compute_section_file_positions uses
1261
       COFF_PAGE_SIZE to ensure that the low order bits of the
1262
       section VMA and the file offset match.  If we don't know
1263
       COFF_PAGE_SIZE, we can't ensure the correct correspondence,
1264
       and demand page loading of the file will fail.  */
1265
2.66k
#ifdef COFF_PAGE_SIZE
1266
2.66k
    sec_flags |= SEC_DEBUGGING;
1267
2.66k
#endif
1268
2.66k
    break;
1269
2.91k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
2.91k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
36
      result = false;
1273
2.91k
    break;
1274
37.4k
  default:
1275
    /* Silently ignore for now.  */
1276
37.4k
    break;
1277
82.3k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
82.3k
      if (unhandled != NULL)
1281
2.08k
  {
1282
2.08k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
2.08k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
2.08k
       abfd, name, unhandled, flag);
1286
2.08k
    result = false;
1287
2.08k
  }
1288
82.3k
    }
1289
1290
10.1k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
10.1k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
1296
  /* As a GNU extension, if the name begins with .gnu.linkonce, we
1297
     only link a single copy of the section.  This is used to support
1298
     g++.  g++ will emit each template expansion in its own section.
1299
     The symbols will be defined as weak, so that multiple definitions
1300
     are permitted.  The GNU linker extension is to actually discard
1301
     all but one of the sections.  */
1302
  if (startswith (name, ".gnu.linkonce"))
1303
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
#endif
1305
1306
10.1k
  if (flags_ptr)
1307
10.1k
    * flags_ptr = sec_flags;
1308
1309
10.1k
  return result;
1310
10.1k
}
pei-arm.c:styp_to_sec_flags
Line
Count
Source
1139
11.6k
{
1140
11.6k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
11.6k
  unsigned long styp_flags = internal_s->s_flags;
1142
11.6k
  flagword sec_flags;
1143
11.6k
  bool result = true;
1144
11.6k
  bool is_dbg = false;
1145
1146
11.6k
  if (startswith (name, DOT_DEBUG)
1147
11.6k
      || startswith (name, DOT_ZDEBUG)
1148
11.6k
#ifdef COFF_LONG_SECTION_NAMES
1149
11.6k
      || startswith (name, GNU_LINKONCE_WI)
1150
11.6k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
11.6k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
11.6k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
11.6k
      || startswith (name, GNU_DEBUGLINK)
1155
11.6k
      || startswith (name, GNU_DEBUGALTLINK)
1156
11.6k
#endif
1157
11.6k
      || startswith (name, ".stab"))
1158
881
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
11.6k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
11.6k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
7.32k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
105k
  while (styp_flags)
1168
94.0k
    {
1169
94.0k
      unsigned long flag = styp_flags & - styp_flags;
1170
94.0k
      char * unhandled = NULL;
1171
1172
94.0k
      styp_flags &= ~ flag;
1173
1174
      /* We infer from the distinct read/write/execute bits the settings
1175
   of some of the bfd flags; the actual values, should we need them,
1176
   are also in pei_section_data (abfd, section)->pe_flags.  */
1177
1178
94.0k
      switch (flag)
1179
94.0k
  {
1180
410
  case STYP_DSECT:
1181
410
    unhandled = "STYP_DSECT";
1182
410
    break;
1183
380
  case STYP_GROUP:
1184
380
    unhandled = "STYP_GROUP";
1185
380
    break;
1186
375
  case STYP_COPY:
1187
375
    unhandled = "STYP_COPY";
1188
375
    break;
1189
441
  case STYP_OVER:
1190
441
    unhandled = "STYP_OVER";
1191
441
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
3.26k
  case STYP_NOLOAD:
1194
3.26k
    sec_flags |= SEC_NEVER_LOAD;
1195
3.26k
    break;
1196
0
#endif
1197
4.37k
  case IMAGE_SCN_MEM_READ:
1198
4.37k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
4.37k
    break;
1200
2.78k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
2.78k
    break;
1203
419
  case IMAGE_SCN_LNK_OTHER:
1204
419
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
419
    break;
1206
380
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
380
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
380
    break;
1209
2.74k
  case IMAGE_SCN_MEM_NOT_PAGED:
1210
    /* Generate a warning message rather using the 'unhandled'
1211
       variable as this will allow some .sys files generate by
1212
       other toolchains to be processed.  See bugzilla issue 196.  */
1213
    /* xgettext:c-format */
1214
2.74k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
2.74k
        " %s in section %s"),
1216
2.74k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
2.74k
    break;
1218
3.97k
  case IMAGE_SCN_MEM_EXECUTE:
1219
3.97k
    sec_flags |= SEC_CODE;
1220
3.97k
    break;
1221
5.34k
  case IMAGE_SCN_MEM_WRITE:
1222
5.34k
    sec_flags &= ~ SEC_READONLY;
1223
5.34k
    break;
1224
4.84k
  case IMAGE_SCN_MEM_DISCARDABLE:
1225
    /* The MS PE spec says that debug sections are DISCARDABLE,
1226
       but the presence of a DISCARDABLE flag does not necessarily
1227
       mean that a given section contains debug information.  Thus
1228
       we only set the SEC_DEBUGGING flag on sections that we
1229
       recognise as containing debug information.  */
1230
4.84k
       if (is_dbg
1231
4.84k
#ifdef _COMMENT
1232
4.84k
        || strcmp (name, _COMMENT) == 0
1233
4.84k
#endif
1234
4.84k
        )
1235
1.38k
      {
1236
1.38k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
1.38k
      }
1238
4.84k
    break;
1239
1.18k
  case IMAGE_SCN_MEM_SHARED:
1240
1.18k
    sec_flags |= SEC_COFF_SHARED;
1241
1.18k
    break;
1242
5.13k
  case IMAGE_SCN_LNK_REMOVE:
1243
5.13k
    if (!is_dbg)
1244
4.74k
      sec_flags |= SEC_EXCLUDE;
1245
5.13k
    break;
1246
3.13k
  case IMAGE_SCN_CNT_CODE:
1247
3.13k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
3.13k
    break;
1249
2.20k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
2.20k
    if (is_dbg)
1251
348
      sec_flags |= SEC_DEBUGGING;
1252
1.85k
    else
1253
1.85k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
2.20k
    break;
1255
3.08k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
3.08k
    sec_flags |= SEC_ALLOC;
1257
3.08k
    break;
1258
2.84k
  case IMAGE_SCN_LNK_INFO:
1259
    /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
1260
       defined.  coff_compute_section_file_positions uses
1261
       COFF_PAGE_SIZE to ensure that the low order bits of the
1262
       section VMA and the file offset match.  If we don't know
1263
       COFF_PAGE_SIZE, we can't ensure the correct correspondence,
1264
       and demand page loading of the file will fail.  */
1265
2.84k
#ifdef COFF_PAGE_SIZE
1266
2.84k
    sec_flags |= SEC_DEBUGGING;
1267
2.84k
#endif
1268
2.84k
    break;
1269
3.62k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
3.62k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
44
      result = false;
1273
3.62k
    break;
1274
43.1k
  default:
1275
    /* Silently ignore for now.  */
1276
43.1k
    break;
1277
94.0k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
94.0k
      if (unhandled != NULL)
1281
2.40k
  {
1282
2.40k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
2.40k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
2.40k
       abfd, name, unhandled, flag);
1286
2.40k
    result = false;
1287
2.40k
  }
1288
94.0k
    }
1289
1290
11.6k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
11.6k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
1296
  /* As a GNU extension, if the name begins with .gnu.linkonce, we
1297
     only link a single copy of the section.  This is used to support
1298
     g++.  g++ will emit each template expansion in its own section.
1299
     The symbols will be defined as weak, so that multiple definitions
1300
     are permitted.  The GNU linker extension is to actually discard
1301
     all but one of the sections.  */
1302
  if (startswith (name, ".gnu.linkonce"))
1303
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
#endif
1305
1306
11.6k
  if (flags_ptr)
1307
11.6k
    * flags_ptr = sec_flags;
1308
1309
11.6k
  return result;
1310
11.6k
}
pei-mcore.c:styp_to_sec_flags
Line
Count
Source
1139
6.26k
{
1140
6.26k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
6.26k
  unsigned long styp_flags = internal_s->s_flags;
1142
6.26k
  flagword sec_flags;
1143
6.26k
  bool result = true;
1144
6.26k
  bool is_dbg = false;
1145
1146
6.26k
  if (startswith (name, DOT_DEBUG)
1147
6.26k
      || startswith (name, DOT_ZDEBUG)
1148
6.26k
#ifdef COFF_LONG_SECTION_NAMES
1149
6.26k
      || startswith (name, GNU_LINKONCE_WI)
1150
6.26k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
6.26k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
6.26k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
6.26k
      || startswith (name, GNU_DEBUGLINK)
1155
6.26k
      || startswith (name, GNU_DEBUGALTLINK)
1156
6.26k
#endif
1157
6.26k
      || startswith (name, ".stab"))
1158
500
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
6.26k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
6.26k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
4.11k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
56.1k
  while (styp_flags)
1168
49.9k
    {
1169
49.9k
      unsigned long flag = styp_flags & - styp_flags;
1170
49.9k
      char * unhandled = NULL;
1171
1172
49.9k
      styp_flags &= ~ flag;
1173
1174
      /* We infer from the distinct read/write/execute bits the settings
1175
   of some of the bfd flags; the actual values, should we need them,
1176
   are also in pei_section_data (abfd, section)->pe_flags.  */
1177
1178
49.9k
      switch (flag)
1179
49.9k
  {
1180
201
  case STYP_DSECT:
1181
201
    unhandled = "STYP_DSECT";
1182
201
    break;
1183
173
  case STYP_GROUP:
1184
173
    unhandled = "STYP_GROUP";
1185
173
    break;
1186
223
  case STYP_COPY:
1187
223
    unhandled = "STYP_COPY";
1188
223
    break;
1189
218
  case STYP_OVER:
1190
218
    unhandled = "STYP_OVER";
1191
218
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
2.38k
  case STYP_NOLOAD:
1194
2.38k
    sec_flags |= SEC_NEVER_LOAD;
1195
2.38k
    break;
1196
0
#endif
1197
2.14k
  case IMAGE_SCN_MEM_READ:
1198
2.14k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
2.14k
    break;
1200
2.03k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
2.03k
    break;
1203
218
  case IMAGE_SCN_LNK_OTHER:
1204
218
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
218
    break;
1206
191
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
191
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
191
    break;
1209
2.13k
  case IMAGE_SCN_MEM_NOT_PAGED:
1210
    /* Generate a warning message rather using the 'unhandled'
1211
       variable as this will allow some .sys files generate by
1212
       other toolchains to be processed.  See bugzilla issue 196.  */
1213
    /* xgettext:c-format */
1214
2.13k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
2.13k
        " %s in section %s"),
1216
2.13k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
2.13k
    break;
1218
2.33k
  case IMAGE_SCN_MEM_EXECUTE:
1219
2.33k
    sec_flags |= SEC_CODE;
1220
2.33k
    break;
1221
2.61k
  case IMAGE_SCN_MEM_WRITE:
1222
2.61k
    sec_flags &= ~ SEC_READONLY;
1223
2.61k
    break;
1224
2.63k
  case IMAGE_SCN_MEM_DISCARDABLE:
1225
    /* The MS PE spec says that debug sections are DISCARDABLE,
1226
       but the presence of a DISCARDABLE flag does not necessarily
1227
       mean that a given section contains debug information.  Thus
1228
       we only set the SEC_DEBUGGING flag on sections that we
1229
       recognise as containing debug information.  */
1230
2.63k
       if (is_dbg
1231
2.63k
#ifdef _COMMENT
1232
2.63k
        || strcmp (name, _COMMENT) == 0
1233
2.63k
#endif
1234
2.63k
        )
1235
492
      {
1236
492
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
492
      }
1238
2.63k
    break;
1239
725
  case IMAGE_SCN_MEM_SHARED:
1240
725
    sec_flags |= SEC_COFF_SHARED;
1241
725
    break;
1242
2.41k
  case IMAGE_SCN_LNK_REMOVE:
1243
2.41k
    if (!is_dbg)
1244
2.16k
      sec_flags |= SEC_EXCLUDE;
1245
2.41k
    break;
1246
1.76k
  case IMAGE_SCN_CNT_CODE:
1247
1.76k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
1.76k
    break;
1249
1.36k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
1.36k
    if (is_dbg)
1251
259
      sec_flags |= SEC_DEBUGGING;
1252
1.10k
    else
1253
1.10k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
1.36k
    break;
1255
2.03k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
2.03k
    sec_flags |= SEC_ALLOC;
1257
2.03k
    break;
1258
2.02k
  case IMAGE_SCN_LNK_INFO:
1259
    /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
1260
       defined.  coff_compute_section_file_positions uses
1261
       COFF_PAGE_SIZE to ensure that the low order bits of the
1262
       section VMA and the file offset match.  If we don't know
1263
       COFF_PAGE_SIZE, we can't ensure the correct correspondence,
1264
       and demand page loading of the file will fail.  */
1265
2.02k
#ifdef COFF_PAGE_SIZE
1266
2.02k
    sec_flags |= SEC_DEBUGGING;
1267
2.02k
#endif
1268
2.02k
    break;
1269
1.36k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
1.36k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
37
      result = false;
1273
1.36k
    break;
1274
20.7k
  default:
1275
    /* Silently ignore for now.  */
1276
20.7k
    break;
1277
49.9k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
49.9k
      if (unhandled != NULL)
1281
1.22k
  {
1282
1.22k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
1.22k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
1.22k
       abfd, name, unhandled, flag);
1286
1.22k
    result = false;
1287
1.22k
  }
1288
49.9k
    }
1289
1290
6.26k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
6.26k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
1296
  /* As a GNU extension, if the name begins with .gnu.linkonce, we
1297
     only link a single copy of the section.  This is used to support
1298
     g++.  g++ will emit each template expansion in its own section.
1299
     The symbols will be defined as weak, so that multiple definitions
1300
     are permitted.  The GNU linker extension is to actually discard
1301
     all but one of the sections.  */
1302
  if (startswith (name, ".gnu.linkonce"))
1303
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
#endif
1305
1306
6.26k
  if (flags_ptr)
1307
6.26k
    * flags_ptr = sec_flags;
1308
1309
6.26k
  return result;
1310
6.26k
}
pei-sh.c:styp_to_sec_flags
Line
Count
Source
1139
6.85k
{
1140
6.85k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
6.85k
  unsigned long styp_flags = internal_s->s_flags;
1142
6.85k
  flagword sec_flags;
1143
6.85k
  bool result = true;
1144
6.85k
  bool is_dbg = false;
1145
1146
6.85k
  if (startswith (name, DOT_DEBUG)
1147
6.85k
      || startswith (name, DOT_ZDEBUG)
1148
6.85k
#ifdef COFF_LONG_SECTION_NAMES
1149
6.85k
      || startswith (name, GNU_LINKONCE_WI)
1150
6.85k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
6.85k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
6.85k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
6.85k
      || startswith (name, GNU_DEBUGLINK)
1155
6.85k
      || startswith (name, GNU_DEBUGALTLINK)
1156
6.85k
#endif
1157
6.85k
      || startswith (name, ".stab"))
1158
519
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
6.85k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
6.85k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
4.41k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
53.2k
  while (styp_flags)
1168
46.3k
    {
1169
46.3k
      unsigned long flag = styp_flags & - styp_flags;
1170
46.3k
      char * unhandled = NULL;
1171
1172
46.3k
      styp_flags &= ~ flag;
1173
1174
      /* We infer from the distinct read/write/execute bits the settings
1175
   of some of the bfd flags; the actual values, should we need them,
1176
   are also in pei_section_data (abfd, section)->pe_flags.  */
1177
1178
46.3k
      switch (flag)
1179
46.3k
  {
1180
216
  case STYP_DSECT:
1181
216
    unhandled = "STYP_DSECT";
1182
216
    break;
1183
229
  case STYP_GROUP:
1184
229
    unhandled = "STYP_GROUP";
1185
229
    break;
1186
212
  case STYP_COPY:
1187
212
    unhandled = "STYP_COPY";
1188
212
    break;
1189
234
  case STYP_OVER:
1190
234
    unhandled = "STYP_OVER";
1191
234
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
1.68k
  case STYP_NOLOAD:
1194
1.68k
    sec_flags |= SEC_NEVER_LOAD;
1195
1.68k
    break;
1196
0
#endif
1197
2.43k
  case IMAGE_SCN_MEM_READ:
1198
2.43k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
2.43k
    break;
1200
1.18k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
1.18k
    break;
1203
241
  case IMAGE_SCN_LNK_OTHER:
1204
241
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
241
    break;
1206
217
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
217
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
217
    break;
1209
1.69k
  case IMAGE_SCN_MEM_NOT_PAGED:
1210
    /* Generate a warning message rather using the 'unhandled'
1211
       variable as this will allow some .sys files generate by
1212
       other toolchains to be processed.  See bugzilla issue 196.  */
1213
    /* xgettext:c-format */
1214
1.69k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
1.69k
        " %s in section %s"),
1216
1.69k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
1.69k
    break;
1218
2.04k
  case IMAGE_SCN_MEM_EXECUTE:
1219
2.04k
    sec_flags |= SEC_CODE;
1220
2.04k
    break;
1221
2.66k
  case IMAGE_SCN_MEM_WRITE:
1222
2.66k
    sec_flags &= ~ SEC_READONLY;
1223
2.66k
    break;
1224
2.46k
  case IMAGE_SCN_MEM_DISCARDABLE:
1225
    /* The MS PE spec says that debug sections are DISCARDABLE,
1226
       but the presence of a DISCARDABLE flag does not necessarily
1227
       mean that a given section contains debug information.  Thus
1228
       we only set the SEC_DEBUGGING flag on sections that we
1229
       recognise as containing debug information.  */
1230
2.46k
       if (is_dbg
1231
2.46k
#ifdef _COMMENT
1232
2.46k
        || strcmp (name, _COMMENT) == 0
1233
2.46k
#endif
1234
2.46k
        )
1235
654
      {
1236
654
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
654
      }
1238
2.46k
    break;
1239
1.04k
  case IMAGE_SCN_MEM_SHARED:
1240
1.04k
    sec_flags |= SEC_COFF_SHARED;
1241
1.04k
    break;
1242
1.95k
  case IMAGE_SCN_LNK_REMOVE:
1243
1.95k
    if (!is_dbg)
1244
1.76k
      sec_flags |= SEC_EXCLUDE;
1245
1.95k
    break;
1246
1.20k
  case IMAGE_SCN_CNT_CODE:
1247
1.20k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
1.20k
    break;
1249
1.20k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
1.20k
    if (is_dbg)
1251
204
      sec_flags |= SEC_DEBUGGING;
1252
999
    else
1253
999
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
1.20k
    break;
1255
1.46k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
1.46k
    sec_flags |= SEC_ALLOC;
1257
1.46k
    break;
1258
1.34k
  case IMAGE_SCN_LNK_INFO:
1259
    /* We mark these as SEC_DEBUGGING, but only if COFF_PAGE_SIZE is
1260
       defined.  coff_compute_section_file_positions uses
1261
       COFF_PAGE_SIZE to ensure that the low order bits of the
1262
       section VMA and the file offset match.  If we don't know
1263
       COFF_PAGE_SIZE, we can't ensure the correct correspondence,
1264
       and demand page loading of the file will fail.  */
1265
1.34k
#ifdef COFF_PAGE_SIZE
1266
1.34k
    sec_flags |= SEC_DEBUGGING;
1267
1.34k
#endif
1268
1.34k
    break;
1269
1.78k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
1.78k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
49
      result = false;
1273
1.78k
    break;
1274
20.8k
  default:
1275
    /* Silently ignore for now.  */
1276
20.8k
    break;
1277
46.3k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
46.3k
      if (unhandled != NULL)
1281
1.34k
  {
1282
1.34k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
1.34k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
1.34k
       abfd, name, unhandled, flag);
1286
1.34k
    result = false;
1287
1.34k
  }
1288
46.3k
    }
1289
1290
6.85k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
6.85k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
#if defined (COFF_LONG_SECTION_NAMES) && defined (COFF_SUPPORT_GNU_LINKONCE)
1296
  /* As a GNU extension, if the name begins with .gnu.linkonce, we
1297
     only link a single copy of the section.  This is used to support
1298
     g++.  g++ will emit each template expansion in its own section.
1299
     The symbols will be defined as weak, so that multiple definitions
1300
     are permitted.  The GNU linker extension is to actually discard
1301
     all but one of the sections.  */
1302
  if (startswith (name, ".gnu.linkonce"))
1303
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
#endif
1305
1306
6.85k
  if (flags_ptr)
1307
6.85k
    * flags_ptr = sec_flags;
1308
1309
6.85k
  return result;
1310
6.85k
}
1311
1312
#endif /* COFF_WITH_PE */
1313
1314
0
#define get_index(symbol) ((symbol)->udata.i)
1315
1316
/*
1317
INTERNAL_DEFINITION
1318
  bfd_coff_backend_data
1319
1320
INTERNAL
1321
.{* COFF symbol classifications.  *}
1322
.
1323
.enum coff_symbol_classification
1324
.{
1325
.  {* Global symbol.  *}
1326
.  COFF_SYMBOL_GLOBAL,
1327
.  {* Common symbol.  *}
1328
.  COFF_SYMBOL_COMMON,
1329
.  {* Undefined symbol.  *}
1330
.  COFF_SYMBOL_UNDEFINED,
1331
.  {* Local symbol.  *}
1332
.  COFF_SYMBOL_LOCAL,
1333
.  {* PE section symbol.  *}
1334
.  COFF_SYMBOL_PE_SECTION
1335
.};
1336
.
1337
.typedef asection * (*coff_gc_mark_hook_fn)
1338
.  (asection *, struct bfd_link_info *, struct internal_reloc *,
1339
.   struct coff_link_hash_entry *, struct internal_syment *);
1340
.
1341
1342
Special entry points for gdb to swap in coff symbol table parts:
1343
1344
CODE_FRAGMENT
1345
.typedef struct
1346
.{
1347
.  void (*_bfd_coff_swap_aux_in)
1348
.    (bfd *, void *, int, int, int, int, void *);
1349
.
1350
.  void (*_bfd_coff_swap_sym_in)
1351
.    (bfd *, void *, void *);
1352
.
1353
.  void (*_bfd_coff_swap_lineno_in)
1354
.    (bfd *, void *, void *);
1355
.
1356
.  unsigned int (*_bfd_coff_swap_aux_out)
1357
.    (bfd *, void *, int, int, int, int, void *);
1358
.
1359
.  unsigned int (*_bfd_coff_swap_sym_out)
1360
.    (bfd *, void *, void *);
1361
.
1362
.  unsigned int (*_bfd_coff_swap_lineno_out)
1363
.    (bfd *, void *, void *);
1364
.
1365
.  unsigned int (*_bfd_coff_swap_reloc_out)
1366
.    (bfd *, void *, void *);
1367
.
1368
.  unsigned int (*_bfd_coff_swap_filehdr_out)
1369
.    (bfd *, void *, void *);
1370
.
1371
.  unsigned int (*_bfd_coff_swap_aouthdr_out)
1372
.    (bfd *, void *, void *);
1373
.
1374
.  unsigned int (*_bfd_coff_swap_scnhdr_out)
1375
.    (bfd *, void *, void *);
1376
.
1377
.  unsigned int _bfd_filhsz;
1378
.  unsigned int _bfd_aoutsz;
1379
.  unsigned int _bfd_scnhsz;
1380
.  unsigned int _bfd_symesz;
1381
.  unsigned int _bfd_auxesz;
1382
.  unsigned int _bfd_relsz;
1383
.  unsigned int _bfd_linesz;
1384
.  unsigned int _bfd_filnmlen;
1385
.  bool _bfd_coff_long_filenames;
1386
.
1387
.  bool _bfd_coff_long_section_names;
1388
.  bool (*_bfd_coff_set_long_section_names)
1389
.    (bfd *, int);
1390
.
1391
.  unsigned int _bfd_coff_default_section_alignment_power;
1392
.  bool _bfd_coff_force_symnames_in_strings;
1393
.  unsigned int _bfd_coff_debug_string_prefix_length;
1394
.  unsigned int _bfd_coff_max_nscns;
1395
.
1396
.  void (*_bfd_coff_swap_filehdr_in)
1397
.    (bfd *, void *, void *);
1398
.
1399
.  void (*_bfd_coff_swap_aouthdr_in)
1400
.    (bfd *, void *, void *);
1401
.
1402
.  void (*_bfd_coff_swap_scnhdr_in)
1403
.    (bfd *, void *, void *);
1404
.
1405
.  void (*_bfd_coff_swap_reloc_in)
1406
.    (bfd *abfd, void *, void *);
1407
.
1408
.  bool (*_bfd_coff_bad_format_hook)
1409
.    (bfd *, void *);
1410
.
1411
.  bool (*_bfd_coff_set_arch_mach_hook)
1412
.    (bfd *, void *);
1413
.
1414
.  void * (*_bfd_coff_mkobject_hook)
1415
.    (bfd *, void *, void *);
1416
.
1417
.  bool (*_bfd_styp_to_sec_flags_hook)
1418
.    (bfd *, void *, const char *, asection *, flagword *);
1419
.
1420
.  void (*_bfd_set_alignment_hook)
1421
.    (bfd *, asection *, void *);
1422
.
1423
.  bool (*_bfd_coff_slurp_symbol_table)
1424
.    (bfd *);
1425
.
1426
.  bool (*_bfd_coff_symname_in_debug)
1427
.    (bfd *, struct internal_syment *);
1428
.
1429
.  bool (*_bfd_coff_pointerize_aux_hook)
1430
.    (bfd *, combined_entry_type *, combined_entry_type *,
1431
.     unsigned int, combined_entry_type *);
1432
.
1433
.  bool (*_bfd_coff_print_aux)
1434
.    (bfd *, FILE *, combined_entry_type *, combined_entry_type *,
1435
.     combined_entry_type *, unsigned int);
1436
.
1437
.  bool (*_bfd_coff_reloc16_extra_cases)
1438
.    (bfd *, struct bfd_link_info *, struct bfd_link_order *, arelent *,
1439
.     bfd_byte *, size_t *, size_t *);
1440
.
1441
.  int (*_bfd_coff_reloc16_estimate)
1442
.    (bfd *, asection *, arelent *, unsigned int,
1443
.     struct bfd_link_info *);
1444
.
1445
.  enum coff_symbol_classification (*_bfd_coff_classify_symbol)
1446
.    (bfd *, struct internal_syment *);
1447
.
1448
.  bool (*_bfd_coff_compute_section_file_positions)
1449
.    (bfd *);
1450
.
1451
.  bool (*_bfd_coff_start_final_link)
1452
.    (bfd *, struct bfd_link_info *);
1453
.
1454
.  bool (*_bfd_coff_relocate_section)
1455
.    (bfd *, struct bfd_link_info *, bfd *, asection *, bfd_byte *,
1456
.     struct internal_reloc *, struct internal_syment *, asection **);
1457
.
1458
.  reloc_howto_type *(*_bfd_coff_rtype_to_howto)
1459
.    (bfd *, asection *, struct internal_reloc *,
1460
.     struct coff_link_hash_entry *, struct internal_syment *, bfd_vma *);
1461
.
1462
.  bool (*_bfd_coff_adjust_symndx)
1463
.    (bfd *, struct bfd_link_info *, bfd *, asection *,
1464
.     struct internal_reloc *, bool *);
1465
.
1466
.  bool (*_bfd_coff_link_add_one_symbol)
1467
.    (struct bfd_link_info *, bfd *, const char *, flagword,
1468
.     asection *, bfd_vma, const char *, bool, bool,
1469
.     struct bfd_link_hash_entry **);
1470
.
1471
.  bool (*_bfd_coff_link_output_has_begun)
1472
.    (bfd *, struct coff_final_link_info *);
1473
.
1474
.  bool (*_bfd_coff_final_link_postscript)
1475
.    (bfd *, struct coff_final_link_info *);
1476
.
1477
.  bool (*_bfd_coff_print_pdata)
1478
.    (bfd *, void *);
1479
.
1480
.} bfd_coff_backend_data;
1481
.
1482
1483
INTERNAL
1484
.#define coff_backend_info(abfd) \
1485
.  ((const bfd_coff_backend_data *) (abfd)->xvec->backend_data)
1486
.
1487
.#define bfd_coff_swap_aux_in(a,e,t,c,ind,num,i) \
1488
.  ((coff_backend_info (a)->_bfd_coff_swap_aux_in) (a,e,t,c,ind,num,i))
1489
.
1490
.#define bfd_coff_swap_sym_in(a,e,i) \
1491
.  ((coff_backend_info (a)->_bfd_coff_swap_sym_in) (a,e,i))
1492
.
1493
.#define bfd_coff_swap_lineno_in(a,e,i) \
1494
.  ((coff_backend_info ( a)->_bfd_coff_swap_lineno_in) (a,e,i))
1495
.
1496
.#define bfd_coff_swap_reloc_out(abfd, i, o) \
1497
.  ((coff_backend_info (abfd)->_bfd_coff_swap_reloc_out) (abfd, i, o))
1498
.
1499
.#define bfd_coff_swap_lineno_out(abfd, i, o) \
1500
.  ((coff_backend_info (abfd)->_bfd_coff_swap_lineno_out) (abfd, i, o))
1501
.
1502
.#define bfd_coff_swap_aux_out(a,i,t,c,ind,num,o) \
1503
.  ((coff_backend_info (a)->_bfd_coff_swap_aux_out) (a,i,t,c,ind,num,o))
1504
.
1505
.#define bfd_coff_swap_sym_out(abfd, i,o) \
1506
.  ((coff_backend_info (abfd)->_bfd_coff_swap_sym_out) (abfd, i, o))
1507
.
1508
.#define bfd_coff_swap_scnhdr_out(abfd, i,o) \
1509
.  ((coff_backend_info (abfd)->_bfd_coff_swap_scnhdr_out) (abfd, i, o))
1510
.
1511
.#define bfd_coff_swap_filehdr_out(abfd, i,o) \
1512
.  ((coff_backend_info (abfd)->_bfd_coff_swap_filehdr_out) (abfd, i, o))
1513
.
1514
.#define bfd_coff_swap_aouthdr_out(abfd, i,o) \
1515
.  ((coff_backend_info (abfd)->_bfd_coff_swap_aouthdr_out) (abfd, i, o))
1516
.
1517
.#define bfd_coff_filhsz(abfd) (coff_backend_info (abfd)->_bfd_filhsz)
1518
.#define bfd_coff_aoutsz(abfd) (coff_backend_info (abfd)->_bfd_aoutsz)
1519
.#define bfd_coff_scnhsz(abfd) (coff_backend_info (abfd)->_bfd_scnhsz)
1520
.#define bfd_coff_symesz(abfd) (coff_backend_info (abfd)->_bfd_symesz)
1521
.#define bfd_coff_auxesz(abfd) (coff_backend_info (abfd)->_bfd_auxesz)
1522
.#define bfd_coff_relsz(abfd)  (coff_backend_info (abfd)->_bfd_relsz)
1523
.#define bfd_coff_linesz(abfd) (coff_backend_info (abfd)->_bfd_linesz)
1524
.#define bfd_coff_filnmlen(abfd) (coff_backend_info (abfd)->_bfd_filnmlen)
1525
.#define bfd_coff_long_filenames(abfd) \
1526
.  (coff_backend_info (abfd)->_bfd_coff_long_filenames)
1527
.#define bfd_coff_long_section_names(abfd) \
1528
.  (coff_data (abfd)->long_section_names)
1529
.#define bfd_coff_set_long_section_names(abfd, enable) \
1530
.  ((coff_backend_info (abfd)->_bfd_coff_set_long_section_names) (abfd, enable))
1531
.#define bfd_coff_default_section_alignment_power(abfd) \
1532
.  (coff_backend_info (abfd)->_bfd_coff_default_section_alignment_power)
1533
.#define bfd_coff_max_nscns(abfd) \
1534
.  (coff_backend_info (abfd)->_bfd_coff_max_nscns)
1535
.
1536
.#define bfd_coff_swap_filehdr_in(abfd, i,o) \
1537
.  ((coff_backend_info (abfd)->_bfd_coff_swap_filehdr_in) (abfd, i, o))
1538
.
1539
.#define bfd_coff_swap_aouthdr_in(abfd, i,o) \
1540
.  ((coff_backend_info (abfd)->_bfd_coff_swap_aouthdr_in) (abfd, i, o))
1541
.
1542
.#define bfd_coff_swap_scnhdr_in(abfd, i,o) \
1543
.  ((coff_backend_info (abfd)->_bfd_coff_swap_scnhdr_in) (abfd, i, o))
1544
.
1545
.#define bfd_coff_swap_reloc_in(abfd, i, o) \
1546
.  ((coff_backend_info (abfd)->_bfd_coff_swap_reloc_in) (abfd, i, o))
1547
.
1548
.#define bfd_coff_bad_format_hook(abfd, filehdr) \
1549
.  ((coff_backend_info (abfd)->_bfd_coff_bad_format_hook) (abfd, filehdr))
1550
.
1551
.#define bfd_coff_set_arch_mach_hook(abfd, filehdr)\
1552
.  ((coff_backend_info (abfd)->_bfd_coff_set_arch_mach_hook) (abfd, filehdr))
1553
.#define bfd_coff_mkobject_hook(abfd, filehdr, aouthdr)\
1554
.  ((coff_backend_info (abfd)->_bfd_coff_mkobject_hook)\
1555
.   (abfd, filehdr, aouthdr))
1556
.
1557
.#define bfd_coff_styp_to_sec_flags_hook(abfd, scnhdr, name, section, flags_ptr)\
1558
.  ((coff_backend_info (abfd)->_bfd_styp_to_sec_flags_hook)\
1559
.   (abfd, scnhdr, name, section, flags_ptr))
1560
.
1561
.#define bfd_coff_set_alignment_hook(abfd, sec, scnhdr)\
1562
.  ((coff_backend_info (abfd)->_bfd_set_alignment_hook) (abfd, sec, scnhdr))
1563
.
1564
.#define bfd_coff_slurp_symbol_table(abfd)\
1565
.  ((coff_backend_info (abfd)->_bfd_coff_slurp_symbol_table) (abfd))
1566
.
1567
.#define bfd_coff_symname_in_debug(abfd, sym)\
1568
.  ((coff_backend_info (abfd)->_bfd_coff_symname_in_debug) (abfd, sym))
1569
.
1570
.#define bfd_coff_force_symnames_in_strings(abfd)\
1571
.  (coff_backend_info (abfd)->_bfd_coff_force_symnames_in_strings)
1572
.
1573
.#define bfd_coff_debug_string_prefix_length(abfd)\
1574
.  (coff_backend_info (abfd)->_bfd_coff_debug_string_prefix_length)
1575
.
1576
.#define bfd_coff_print_aux(abfd, file, base, symbol, aux, indaux)\
1577
.  ((coff_backend_info (abfd)->_bfd_coff_print_aux)\
1578
.   (abfd, file, base, symbol, aux, indaux))
1579
.
1580
.#define bfd_coff_reloc16_extra_cases(abfd, link_info, link_order,\
1581
.             reloc, data, src_ptr, dst_ptr)\
1582
.  ((coff_backend_info (abfd)->_bfd_coff_reloc16_extra_cases)\
1583
.   (abfd, link_info, link_order, reloc, data, src_ptr, dst_ptr))
1584
.
1585
.#define bfd_coff_reloc16_estimate(abfd, section, reloc, shrink, link_info)\
1586
.  ((coff_backend_info (abfd)->_bfd_coff_reloc16_estimate)\
1587
.   (abfd, section, reloc, shrink, link_info))
1588
.
1589
.#define bfd_coff_classify_symbol(abfd, sym)\
1590
.  ((coff_backend_info (abfd)->_bfd_coff_classify_symbol)\
1591
.   (abfd, sym))
1592
.
1593
.#define bfd_coff_compute_section_file_positions(abfd)\
1594
.  ((coff_backend_info (abfd)->_bfd_coff_compute_section_file_positions)\
1595
.   (abfd))
1596
.
1597
.#define bfd_coff_start_final_link(obfd, info)\
1598
.  ((coff_backend_info (obfd)->_bfd_coff_start_final_link)\
1599
.   (obfd, info))
1600
.#define bfd_coff_relocate_section(obfd,info,ibfd,o,con,rel,isyms,secs)\
1601
.  ((coff_backend_info (ibfd)->_bfd_coff_relocate_section)\
1602
.   (obfd, info, ibfd, o, con, rel, isyms, secs))
1603
.#define bfd_coff_rtype_to_howto(abfd, sec, rel, h, sym, addendp)\
1604
.  ((coff_backend_info (abfd)->_bfd_coff_rtype_to_howto)\
1605
.   (abfd, sec, rel, h, sym, addendp))
1606
.#define bfd_coff_adjust_symndx(obfd, info, ibfd, sec, rel, adjustedp)\
1607
.  ((coff_backend_info (abfd)->_bfd_coff_adjust_symndx)\
1608
.   (obfd, info, ibfd, sec, rel, adjustedp))
1609
.#define bfd_coff_link_add_one_symbol(info, abfd, name, flags, section,\
1610
.             value, string, cp, coll, hashp)\
1611
.  ((coff_backend_info (abfd)->_bfd_coff_link_add_one_symbol)\
1612
.   (info, abfd, name, flags, section, value, string, cp, coll, hashp))
1613
.
1614
.#define bfd_coff_link_output_has_begun(a,p) \
1615
.  ((coff_backend_info (a)->_bfd_coff_link_output_has_begun) (a, p))
1616
.#define bfd_coff_final_link_postscript(a,p) \
1617
.  ((coff_backend_info (a)->_bfd_coff_final_link_postscript) (a, p))
1618
.
1619
.#define bfd_coff_have_print_pdata(a) \
1620
.  (coff_backend_info (a)->_bfd_coff_print_pdata)
1621
.#define bfd_coff_print_pdata(a,p) \
1622
.  ((coff_backend_info (a)->_bfd_coff_print_pdata) (a, p))
1623
.
1624
.{* Macro: Returns true if the bfd is a PE executable as opposed to a
1625
.   PE object file.  *}
1626
.#define bfd_pei_p(abfd) \
1627
.  (startswith ((abfd)->xvec->name, "pei-"))
1628
*/
1629
1630
/* See whether the magic number matches.  */
1631
1632
static bool
1633
coff_bad_format_hook (bfd * abfd ATTRIBUTE_UNUSED, void * filehdr)
1634
326k
{
1635
326k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
326k
  if (BADMAG (*internal_f))
1638
311k
    return false;
1639
1640
15.2k
  return true;
1641
326k
}
pei-i386.c:coff_bad_format_hook
Line
Count
Source
1634
8.19k
{
1635
8.19k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
8.19k
  if (BADMAG (*internal_f))
1638
7.01k
    return false;
1639
1640
1.18k
  return true;
1641
8.19k
}
pe-x86_64.c:coff_bad_format_hook
Line
Count
Source
1634
21.2k
{
1635
21.2k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
21.2k
  if (BADMAG (*internal_f))
1638
20.8k
    return false;
1639
1640
433
  return true;
1641
21.2k
}
pei-x86_64.c:coff_bad_format_hook
Line
Count
Source
1634
8.21k
{
1635
8.21k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
8.21k
  if (BADMAG (*internal_f))
1638
6.89k
    return false;
1639
1640
1.31k
  return true;
1641
8.21k
}
coff-x86_64.c:coff_bad_format_hook
Line
Count
Source
1634
10.8k
{
1635
10.8k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
10.8k
  if (BADMAG (*internal_f))
1638
10.8k
    return false;
1639
1640
0
  return true;
1641
10.8k
}
Unexecuted instantiation: coff64-rs6000.c:coff_bad_format_hook
pei-aarch64.c:coff_bad_format_hook
Line
Count
Source
1634
7.94k
{
1635
7.94k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
7.94k
  if (BADMAG (*internal_f))
1638
6.97k
    return false;
1639
1640
974
  return true;
1641
7.94k
}
pe-aarch64.c:coff_bad_format_hook
Line
Count
Source
1634
10.8k
{
1635
10.8k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
10.8k
  if (BADMAG (*internal_f))
1638
10.8k
    return false;
1639
1640
0
  return true;
1641
10.8k
}
pei-ia64.c:coff_bad_format_hook
Line
Count
Source
1634
1.96k
{
1635
1.96k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
1.96k
  if (BADMAG (*internal_f))
1638
1.01k
    return false;
1639
1640
951
  return true;
1641
1.96k
}
pei-loongarch64.c:coff_bad_format_hook
Line
Count
Source
1634
7.81k
{
1635
7.81k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
7.81k
  if (BADMAG (*internal_f))
1638
6.89k
    return false;
1639
1640
916
  return true;
1641
7.81k
}
cf-i386lynx.c:coff_bad_format_hook
Line
Count
Source
1634
10.8k
{
1635
10.8k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
10.8k
  if (BADMAG (*internal_f))
1638
9.44k
    return false;
1639
1640
1.40k
  return true;
1641
10.8k
}
coff-go32.c:coff_bad_format_hook
Line
Count
Source
1634
10.8k
{
1635
10.8k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
10.8k
  if (BADMAG (*internal_f))
1638
10.8k
    return false;
1639
1640
0
  return true;
1641
10.8k
}
coff-i386.c:coff_bad_format_hook
Line
Count
Source
1634
10.8k
{
1635
10.8k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
10.8k
  if (BADMAG (*internal_f))
1638
10.8k
    return false;
1639
1640
0
  return true;
1641
10.8k
}
coff-rs6000.c:coff_bad_format_hook
Line
Count
Source
1634
10.8k
{
1635
10.8k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
10.8k
  if (BADMAG (*internal_f))
1638
10.8k
    return false;
1639
1640
0
  return true;
1641
10.8k
}
coff-sh.c:coff_bad_format_hook
Line
Count
Source
1634
21.7k
{
1635
21.7k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
21.7k
  if (BADMAG (*internal_f))
1638
21.7k
    return false;
1639
1640
0
  return true;
1641
21.7k
}
coff-stgo32.c:coff_bad_format_hook
Line
Count
Source
1634
1.61k
{
1635
1.61k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
1.61k
  if (BADMAG (*internal_f))
1638
74
    return false;
1639
1640
1.53k
  return true;
1641
1.61k
}
coff-tic30.c:coff_bad_format_hook
Line
Count
Source
1634
10.8k
{
1635
10.8k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
10.8k
  if (BADMAG (*internal_f))
1638
10.8k
    return false;
1639
1640
0
  return true;
1641
10.8k
}
Unexecuted instantiation: coff-tic4x.c:coff_bad_format_hook
coff-tic54x.c:coff_bad_format_hook
Line
Count
Source
1634
21.5k
{
1635
21.5k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
21.5k
  if (BADMAG (*internal_f))
1638
21.5k
    return false;
1639
1640
0
  return true;
1641
21.5k
}
coff-z80.c:coff_bad_format_hook
Line
Count
Source
1634
10.8k
{
1635
10.8k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
10.8k
  if (BADMAG (*internal_f))
1638
10.8k
    return false;
1639
1640
0
  return true;
1641
10.8k
}
coff-z8k.c:coff_bad_format_hook
Line
Count
Source
1634
10.8k
{
1635
10.8k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
10.8k
  if (BADMAG (*internal_f))
1638
10.8k
    return false;
1639
1640
0
  return true;
1641
10.8k
}
pe-arm-wince.c:coff_bad_format_hook
Line
Count
Source
1634
21.7k
{
1635
21.7k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
21.7k
  if (BADMAG (*internal_f))
1638
21.7k
    return false;
1639
1640
0
  return true;
1641
21.7k
}
pe-arm.c:coff_bad_format_hook
Line
Count
Source
1634
21.7k
{
1635
21.7k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
21.7k
  if (BADMAG (*internal_f))
1638
21.7k
    return false;
1639
1640
0
  return true;
1641
21.7k
}
pe-i386.c:coff_bad_format_hook
Line
Count
Source
1634
21.2k
{
1635
21.2k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
21.2k
  if (BADMAG (*internal_f))
1638
19.5k
    return false;
1639
1640
1.72k
  return true;
1641
21.2k
}
pe-mcore.c:coff_bad_format_hook
Line
Count
Source
1634
21.7k
{
1635
21.7k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
21.7k
  if (BADMAG (*internal_f))
1638
21.7k
    return false;
1639
1640
0
  return true;
1641
21.7k
}
pe-sh.c:coff_bad_format_hook
Line
Count
Source
1634
10.8k
{
1635
10.8k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
10.8k
  if (BADMAG (*internal_f))
1638
10.8k
    return false;
1639
1640
0
  return true;
1641
10.8k
}
pei-arm-wince.c:coff_bad_format_hook
Line
Count
Source
1634
7.94k
{
1635
7.94k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
7.94k
  if (BADMAG (*internal_f))
1638
6.39k
    return false;
1639
1640
1.55k
  return true;
1641
7.94k
}
pei-arm.c:coff_bad_format_hook
Line
Count
Source
1634
7.94k
{
1635
7.94k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
7.94k
  if (BADMAG (*internal_f))
1638
6.39k
    return false;
1639
1640
1.55k
  return true;
1641
7.94k
}
pei-mcore.c:coff_bad_format_hook
Line
Count
Source
1634
7.81k
{
1635
7.81k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
7.81k
  if (BADMAG (*internal_f))
1638
6.94k
    return false;
1639
1640
865
  return true;
1641
7.81k
}
pei-sh.c:coff_bad_format_hook
Line
Count
Source
1634
7.81k
{
1635
7.81k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
7.81k
  if (BADMAG (*internal_f))
1638
6.96k
    return false;
1639
1640
846
  return true;
1641
7.81k
}
1642
1643
#ifdef TICOFF
1644
static bool
1645
ticoff0_bad_format_hook (bfd *abfd ATTRIBUTE_UNUSED, void * filehdr)
1646
21.7k
{
1647
21.7k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1648
1649
21.7k
  if (COFF0_BADMAG (*internal_f))
1650
21.7k
    return false;
1651
1652
0
  return true;
1653
21.7k
}
Unexecuted instantiation: coff-tic4x.c:ticoff0_bad_format_hook
coff-tic54x.c:ticoff0_bad_format_hook
Line
Count
Source
1646
21.7k
{
1647
21.7k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1648
1649
21.7k
  if (COFF0_BADMAG (*internal_f))
1650
21.7k
    return false;
1651
1652
0
  return true;
1653
21.7k
}
1654
#endif
1655
1656
#ifdef TICOFF
1657
static bool
1658
ticoff1_bad_format_hook (bfd *abfd ATTRIBUTE_UNUSED, void * filehdr)
1659
21.5k
{
1660
21.5k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1661
1662
21.5k
  if (COFF1_BADMAG (*internal_f))
1663
21.5k
    return false;
1664
1665
0
  return true;
1666
21.5k
}
Unexecuted instantiation: coff-tic4x.c:ticoff1_bad_format_hook
coff-tic54x.c:ticoff1_bad_format_hook
Line
Count
Source
1659
21.5k
{
1660
21.5k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1661
1662
21.5k
  if (COFF1_BADMAG (*internal_f))
1663
21.5k
    return false;
1664
1665
0
  return true;
1666
21.5k
}
1667
#endif
1668
1669
/* Check whether this section uses an alignment other than the
1670
   default.  */
1671
1672
static void
1673
coff_set_custom_section_alignment (bfd *abfd ATTRIBUTE_UNUSED,
1674
           asection *section,
1675
           const struct coff_section_alignment_entry *alignment_table,
1676
           const unsigned int table_size)
1677
274k
{
1678
274k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
274k
  unsigned int i;
1680
1681
2.17M
  for (i = 0; i < table_size; ++i)
1682
1.91M
    {
1683
1.91M
      const char *secname = bfd_section_name (section);
1684
1685
1.91M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
1.91M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
1.91M
    : strncmp (alignment_table[i].name, secname,
1688
972k
         alignment_table[i].comparison_length) == 0)
1689
12.9k
  break;
1690
1.91M
    }
1691
274k
  if (i >= table_size)
1692
261k
    return;
1693
1694
12.9k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
12.9k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
4.26k
    return;
1697
1698
8.69k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
0
      && default_alignment > alignment_table[i].default_alignment_max
1701
#endif
1702
8.69k
      )
1703
0
    return;
1704
1705
8.69k
  section->alignment_power = alignment_table[i].alignment_power;
1706
8.69k
}
pei-i386.c:coff_set_custom_section_alignment
Line
Count
Source
1677
10.9k
{
1678
10.9k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
10.9k
  unsigned int i;
1680
1681
96.1k
  for (i = 0; i < table_size; ++i)
1682
85.7k
    {
1683
85.7k
      const char *secname = bfd_section_name (section);
1684
1685
85.7k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
85.7k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
85.7k
    : strncmp (alignment_table[i].name, secname,
1688
53.9k
         alignment_table[i].comparison_length) == 0)
1689
484
  break;
1690
85.7k
    }
1691
10.9k
  if (i >= table_size)
1692
10.4k
    return;
1693
1694
484
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
484
      && default_alignment < alignment_table[i].default_alignment_min)
1696
148
    return;
1697
1698
336
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
336
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
336
      && default_alignment > alignment_table[i].default_alignment_max
1701
336
#endif
1702
336
      )
1703
0
    return;
1704
1705
336
  section->alignment_power = alignment_table[i].alignment_power;
1706
336
}
Unexecuted instantiation: pe-x86_64.c:coff_set_custom_section_alignment
pei-x86_64.c:coff_set_custom_section_alignment
Line
Count
Source
1677
7.50k
{
1678
7.50k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
7.50k
  unsigned int i;
1680
1681
95.4k
  for (i = 0; i < table_size; ++i)
1682
88.4k
    {
1683
88.4k
      const char *secname = bfd_section_name (section);
1684
1685
88.4k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
88.4k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
88.4k
    : strncmp (alignment_table[i].name, secname,
1688
59.3k
         alignment_table[i].comparison_length) == 0)
1689
475
  break;
1690
88.4k
    }
1691
7.50k
  if (i >= table_size)
1692
7.03k
    return;
1693
1694
475
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
475
      && default_alignment < alignment_table[i].default_alignment_min)
1696
171
    return;
1697
1698
304
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
304
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
304
      && default_alignment > alignment_table[i].default_alignment_max
1701
304
#endif
1702
304
      )
1703
0
    return;
1704
1705
304
  section->alignment_power = alignment_table[i].alignment_power;
1706
304
}
Unexecuted instantiation: coff-x86_64.c:coff_set_custom_section_alignment
Unexecuted instantiation: coff64-rs6000.c:coff_set_custom_section_alignment
pei-aarch64.c:coff_set_custom_section_alignment
Line
Count
Source
1677
7.89k
{
1678
7.89k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
7.89k
  unsigned int i;
1680
1681
99.6k
  for (i = 0; i < table_size; ++i)
1682
92.4k
    {
1683
92.4k
      const char *secname = bfd_section_name (section);
1684
1685
92.4k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
92.4k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
92.4k
    : strncmp (alignment_table[i].name, secname,
1688
38.6k
         alignment_table[i].comparison_length) == 0)
1689
733
  break;
1690
92.4k
    }
1691
7.89k
  if (i >= table_size)
1692
7.15k
    return;
1693
1694
733
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
733
      && default_alignment < alignment_table[i].default_alignment_min)
1696
257
    return;
1697
1698
476
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
476
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
476
      && default_alignment > alignment_table[i].default_alignment_max
1701
476
#endif
1702
476
      )
1703
0
    return;
1704
1705
476
  section->alignment_power = alignment_table[i].alignment_power;
1706
476
}
Unexecuted instantiation: pe-aarch64.c:coff_set_custom_section_alignment
pei-ia64.c:coff_set_custom_section_alignment
Line
Count
Source
1677
8.69k
{
1678
8.69k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
8.69k
  unsigned int i;
1680
1681
40.8k
  for (i = 0; i < table_size; ++i)
1682
32.8k
    {
1683
32.8k
      const char *secname = bfd_section_name (section);
1684
1685
32.8k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
32.8k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
32.8k
    : strncmp (alignment_table[i].name, secname,
1688
16.9k
         alignment_table[i].comparison_length) == 0)
1689
767
  break;
1690
32.8k
    }
1691
8.69k
  if (i >= table_size)
1692
7.93k
    return;
1693
1694
767
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
767
      && default_alignment < alignment_table[i].default_alignment_min)
1696
316
    return;
1697
1698
451
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
451
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
451
      && default_alignment > alignment_table[i].default_alignment_max
1701
451
#endif
1702
451
      )
1703
0
    return;
1704
1705
451
  section->alignment_power = alignment_table[i].alignment_power;
1706
451
}
pei-loongarch64.c:coff_set_custom_section_alignment
Line
Count
Source
1677
8.57k
{
1678
8.57k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
8.57k
  unsigned int i;
1680
1681
109k
  for (i = 0; i < table_size; ++i)
1682
101k
    {
1683
101k
      const char *secname = bfd_section_name (section);
1684
1685
101k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
101k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
101k
    : strncmp (alignment_table[i].name, secname,
1688
42.2k
         alignment_table[i].comparison_length) == 0)
1689
672
  break;
1690
101k
    }
1691
8.57k
  if (i >= table_size)
1692
7.90k
    return;
1693
1694
672
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
672
      && default_alignment < alignment_table[i].default_alignment_min)
1696
279
    return;
1697
1698
393
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
393
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
393
      && default_alignment > alignment_table[i].default_alignment_max
1701
393
#endif
1702
393
      )
1703
0
    return;
1704
1705
393
  section->alignment_power = alignment_table[i].alignment_power;
1706
393
}
cf-i386lynx.c:coff_set_custom_section_alignment
Line
Count
Source
1677
89.3k
{
1678
89.3k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
89.3k
  unsigned int i;
1680
1681
438k
  for (i = 0; i < table_size; ++i)
1682
351k
    {
1683
351k
      const char *secname = bfd_section_name (section);
1684
1685
351k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
351k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
351k
    : strncmp (alignment_table[i].name, secname,
1688
177k
         alignment_table[i].comparison_length) == 0)
1689
2.26k
  break;
1690
351k
    }
1691
89.3k
  if (i >= table_size)
1692
87.0k
    return;
1693
1694
2.26k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
2.26k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
814
    return;
1697
1698
1.45k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
1.45k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
1.45k
      && default_alignment > alignment_table[i].default_alignment_max
1701
1.45k
#endif
1702
1.45k
      )
1703
0
    return;
1704
1705
1.45k
  section->alignment_power = alignment_table[i].alignment_power;
1706
1.45k
}
Unexecuted instantiation: coff-go32.c:coff_set_custom_section_alignment
Unexecuted instantiation: coff-i386.c:coff_set_custom_section_alignment
Unexecuted instantiation: coff-rs6000.c:coff_set_custom_section_alignment
Unexecuted instantiation: coff-sh.c:coff_set_custom_section_alignment
coff-stgo32.c:coff_set_custom_section_alignment
Line
Count
Source
1677
90.3k
{
1678
90.3k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
90.3k
  unsigned int i;
1680
1681
799k
  for (i = 0; i < table_size; ++i)
1682
712k
    {
1683
712k
      const char *secname = bfd_section_name (section);
1684
1685
712k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
712k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
712k
    : strncmp (alignment_table[i].name, secname,
1688
357k
         alignment_table[i].comparison_length) == 0)
1689
3.22k
  break;
1690
712k
    }
1691
90.3k
  if (i >= table_size)
1692
87.1k
    return;
1693
1694
3.22k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
3.22k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
832
    return;
1697
1698
2.39k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
2.39k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
2.39k
      && default_alignment > alignment_table[i].default_alignment_max
1701
2.39k
#endif
1702
2.39k
      )
1703
0
    return;
1704
1705
2.39k
  section->alignment_power = alignment_table[i].alignment_power;
1706
2.39k
}
Unexecuted instantiation: coff-tic30.c:coff_set_custom_section_alignment
Unexecuted instantiation: coff-tic4x.c:coff_set_custom_section_alignment
Unexecuted instantiation: coff-tic54x.c:coff_set_custom_section_alignment
Unexecuted instantiation: coff-z80.c:coff_set_custom_section_alignment
Unexecuted instantiation: coff-z8k.c:coff_set_custom_section_alignment
Unexecuted instantiation: pe-arm-wince.c:coff_set_custom_section_alignment
Unexecuted instantiation: pe-arm.c:coff_set_custom_section_alignment
pe-i386.c:coff_set_custom_section_alignment
Line
Count
Source
1677
15.3k
{
1678
15.3k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
15.3k
  unsigned int i;
1680
1681
144k
  for (i = 0; i < table_size; ++i)
1682
131k
    {
1683
131k
      const char *secname = bfd_section_name (section);
1684
1685
131k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
131k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
131k
    : strncmp (alignment_table[i].name, secname,
1688
89.3k
         alignment_table[i].comparison_length) == 0)
1689
2.00k
  break;
1690
131k
    }
1691
15.3k
  if (i >= table_size)
1692
13.3k
    return;
1693
1694
2.00k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
2.00k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
535
    return;
1697
1698
1.46k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
1.46k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
1.46k
      && default_alignment > alignment_table[i].default_alignment_max
1701
1.46k
#endif
1702
1.46k
      )
1703
0
    return;
1704
1705
1.46k
  section->alignment_power = alignment_table[i].alignment_power;
1706
1.46k
}
Unexecuted instantiation: pe-mcore.c:coff_set_custom_section_alignment
Unexecuted instantiation: pe-sh.c:coff_set_custom_section_alignment
pei-arm-wince.c:coff_set_custom_section_alignment
Line
Count
Source
1677
10.4k
{
1678
10.4k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
10.4k
  unsigned int i;
1680
1681
132k
  for (i = 0; i < table_size; ++i)
1682
123k
    {
1683
123k
      const char *secname = bfd_section_name (section);
1684
1685
123k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
123k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
123k
    : strncmp (alignment_table[i].name, secname,
1688
51.4k
         alignment_table[i].comparison_length) == 0)
1689
711
  break;
1690
123k
    }
1691
10.4k
  if (i >= table_size)
1692
9.75k
    return;
1693
1694
711
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
711
      && default_alignment < alignment_table[i].default_alignment_min)
1696
221
    return;
1697
1698
490
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
490
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
490
      && default_alignment > alignment_table[i].default_alignment_max
1701
490
#endif
1702
490
      )
1703
0
    return;
1704
1705
490
  section->alignment_power = alignment_table[i].alignment_power;
1706
490
}
pei-arm.c:coff_set_custom_section_alignment
Line
Count
Source
1677
12.0k
{
1678
12.0k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
12.0k
  unsigned int i;
1680
1681
153k
  for (i = 0; i < table_size; ++i)
1682
142k
    {
1683
142k
      const char *secname = bfd_section_name (section);
1684
1685
142k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
142k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
142k
    : strncmp (alignment_table[i].name, secname,
1688
59.3k
         alignment_table[i].comparison_length) == 0)
1689
793
  break;
1690
142k
    }
1691
12.0k
  if (i >= table_size)
1692
11.2k
    return;
1693
1694
793
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
793
      && default_alignment < alignment_table[i].default_alignment_min)
1696
257
    return;
1697
1698
536
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
536
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
536
      && default_alignment > alignment_table[i].default_alignment_max
1701
536
#endif
1702
536
      )
1703
0
    return;
1704
1705
536
  section->alignment_power = alignment_table[i].alignment_power;
1706
536
}
pei-mcore.c:coff_set_custom_section_alignment
Line
Count
Source
1677
6.46k
{
1678
6.46k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
6.46k
  unsigned int i;
1680
1681
30.9k
  for (i = 0; i < table_size; ++i)
1682
24.9k
    {
1683
24.9k
      const char *secname = bfd_section_name (section);
1684
1685
24.9k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
24.9k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
24.9k
    : strncmp (alignment_table[i].name, secname,
1688
12.7k
         alignment_table[i].comparison_length) == 0)
1689
395
  break;
1690
24.9k
    }
1691
6.46k
  if (i >= table_size)
1692
6.07k
    return;
1693
1694
395
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
395
      && default_alignment < alignment_table[i].default_alignment_min)
1696
189
    return;
1697
1698
206
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
206
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
206
      && default_alignment > alignment_table[i].default_alignment_max
1701
206
#endif
1702
206
      )
1703
0
    return;
1704
1705
206
  section->alignment_power = alignment_table[i].alignment_power;
1706
206
}
pei-sh.c:coff_set_custom_section_alignment
Line
Count
Source
1677
7.05k
{
1678
7.05k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
7.05k
  unsigned int i;
1680
1681
33.9k
  for (i = 0; i < table_size; ++i)
1682
27.2k
    {
1683
27.2k
      const char *secname = bfd_section_name (section);
1684
1685
27.2k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
27.2k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
27.2k
    : strncmp (alignment_table[i].name, secname,
1688
13.9k
         alignment_table[i].comparison_length) == 0)
1689
436
  break;
1690
27.2k
    }
1691
7.05k
  if (i >= table_size)
1692
6.62k
    return;
1693
1694
436
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
436
      && default_alignment < alignment_table[i].default_alignment_min)
1696
246
    return;
1697
1698
190
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
190
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
190
      && default_alignment > alignment_table[i].default_alignment_max
1701
190
#endif
1702
190
      )
1703
0
    return;
1704
1705
190
  section->alignment_power = alignment_table[i].alignment_power;
1706
190
}
1707
1708
/* Custom section alignment records.  */
1709
1710
static const struct coff_section_alignment_entry
1711
coff_section_alignment_table[] =
1712
{
1713
#ifdef COFF_SECTION_ALIGNMENT_ENTRIES
1714
  COFF_SECTION_ALIGNMENT_ENTRIES,
1715
#endif
1716
  /* There must not be any gaps between .stabstr sections.  */
1717
  { COFF_SECTION_NAME_PARTIAL_MATCH (".stabstr"),
1718
    1, COFF_ALIGNMENT_FIELD_EMPTY, 0 },
1719
  /* The .stab section must be aligned to 2**2 at most, to avoid gaps.  */
1720
  { COFF_SECTION_NAME_PARTIAL_MATCH (".stab"),
1721
    3, COFF_ALIGNMENT_FIELD_EMPTY, 2 },
1722
  /* Similarly for the .ctors and .dtors sections.  */
1723
  { COFF_SECTION_NAME_EXACT_MATCH (".ctors"),
1724
    3, COFF_ALIGNMENT_FIELD_EMPTY, 2 },
1725
  { COFF_SECTION_NAME_EXACT_MATCH (".dtors"),
1726
    3, COFF_ALIGNMENT_FIELD_EMPTY, 2 }
1727
};
1728
1729
static const unsigned int coff_section_alignment_table_size =
1730
  sizeof coff_section_alignment_table / sizeof coff_section_alignment_table[0];
1731
1732
/* Initialize a section structure with information peculiar to this
1733
   particular implementation of COFF.  */
1734
1735
static bool
1736
coff_new_section_hook (bfd * abfd, asection * section)
1737
274k
{
1738
274k
  combined_entry_type *native;
1739
274k
  size_t amt;
1740
274k
  unsigned char sclass = C_STAT;
1741
1742
274k
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
#ifdef RS6000COFF_C
1745
0
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
0
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
0
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
0
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
0
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
0
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
0
  else
1752
0
    {
1753
0
      int i;
1754
1755
0
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
0
  if (strcmp (bfd_section_name (section),
1757
0
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
0
    {
1759
0
      section->alignment_power = 0;
1760
0
      sclass = C_DWARF;
1761
0
      break;
1762
0
    }
1763
0
    }
1764
#endif
1765
1766
  /* Set up the section symbol.  */
1767
274k
  if (!_bfd_generic_new_section_hook (abfd, section))
1768
0
    return false;
1769
1770
  /* Allocate aux records for section symbols, to store size and
1771
     related info.
1772
1773
     @@ The 10 is a guess at a plausible maximum number of aux entries
1774
     (but shouldn't be a constant).  */
1775
274k
  amt = sizeof (combined_entry_type) * 10;
1776
274k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
274k
  if (native == NULL)
1778
0
    return false;
1779
1780
  /* We don't need to set up n_name, n_value, or n_scnum in the native
1781
     symbol information, since they'll be overridden by the BFD symbol
1782
     anyhow.  However, we do need to set the type and storage class,
1783
     in case this symbol winds up getting written out.  The value 0
1784
     for n_numaux is already correct.  */
1785
1786
274k
  native->is_sym = true;
1787
274k
  native->u.syment.n_type = T_NULL;
1788
274k
  native->u.syment.n_sclass = sclass;
1789
1790
274k
  coffsymbol (section->symbol)->native = native;
1791
1792
274k
  coff_set_custom_section_alignment (abfd, section,
1793
274k
             coff_section_alignment_table,
1794
274k
             coff_section_alignment_table_size);
1795
1796
274k
  return true;
1797
274k
}
pei-i386.c:coff_new_section_hook
Line
Count
Source
1737
10.9k
{
1738
10.9k
  combined_entry_type *native;
1739
10.9k
  size_t amt;
1740
10.9k
  unsigned char sclass = C_STAT;
1741
1742
10.9k
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
#ifdef RS6000COFF_C
1745
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
  else
1752
    {
1753
      int i;
1754
1755
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
  if (strcmp (bfd_section_name (section),
1757
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
    {
1759
      section->alignment_power = 0;
1760
      sclass = C_DWARF;
1761
      break;
1762
    }
1763
    }
1764
#endif
1765
1766
  /* Set up the section symbol.  */
1767
10.9k
  if (!_bfd_generic_new_section_hook (abfd, section))
1768
0
    return false;
1769
1770
  /* Allocate aux records for section symbols, to store size and
1771
     related info.
1772
1773
     @@ The 10 is a guess at a plausible maximum number of aux entries
1774
     (but shouldn't be a constant).  */
1775
10.9k
  amt = sizeof (combined_entry_type) * 10;
1776
10.9k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
10.9k
  if (native == NULL)
1778
0
    return false;
1779
1780
  /* We don't need to set up n_name, n_value, or n_scnum in the native
1781
     symbol information, since they'll be overridden by the BFD symbol
1782
     anyhow.  However, we do need to set the type and storage class,
1783
     in case this symbol winds up getting written out.  The value 0
1784
     for n_numaux is already correct.  */
1785
1786
10.9k
  native->is_sym = true;
1787
10.9k
  native->u.syment.n_type = T_NULL;
1788
10.9k
  native->u.syment.n_sclass = sclass;
1789
1790
10.9k
  coffsymbol (section->symbol)->native = native;
1791
1792
10.9k
  coff_set_custom_section_alignment (abfd, section,
1793
10.9k
             coff_section_alignment_table,
1794
10.9k
             coff_section_alignment_table_size);
1795
1796
10.9k
  return true;
1797
10.9k
}
Unexecuted instantiation: pe-x86_64.c:coff_new_section_hook
pei-x86_64.c:coff_new_section_hook
Line
Count
Source
1737
7.50k
{
1738
7.50k
  combined_entry_type *native;
1739
7.50k
  size_t amt;
1740
7.50k
  unsigned char sclass = C_STAT;
1741
1742
7.50k
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
#ifdef RS6000COFF_C
1745
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
  else
1752
    {
1753
      int i;
1754
1755
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
  if (strcmp (bfd_section_name (section),
1757
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
    {
1759
      section->alignment_power = 0;
1760
      sclass = C_DWARF;
1761
      break;
1762
    }
1763
    }
1764
#endif
1765
1766
  /* Set up the section symbol.  */
1767
7.50k
  if (!_bfd_generic_new_section_hook (abfd, section))
1768
0
    return false;
1769
1770
  /* Allocate aux records for section symbols, to store size and
1771
     related info.
1772
1773
     @@ The 10 is a guess at a plausible maximum number of aux entries
1774
     (but shouldn't be a constant).  */
1775
7.50k
  amt = sizeof (combined_entry_type) * 10;
1776
7.50k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
7.50k
  if (native == NULL)
1778
0
    return false;
1779
1780
  /* We don't need to set up n_name, n_value, or n_scnum in the native
1781
     symbol information, since they'll be overridden by the BFD symbol
1782
     anyhow.  However, we do need to set the type and storage class,
1783
     in case this symbol winds up getting written out.  The value 0
1784
     for n_numaux is already correct.  */
1785
1786
7.50k
  native->is_sym = true;
1787
7.50k
  native->u.syment.n_type = T_NULL;
1788
7.50k
  native->u.syment.n_sclass = sclass;
1789
1790
7.50k
  coffsymbol (section->symbol)->native = native;
1791
1792
7.50k
  coff_set_custom_section_alignment (abfd, section,
1793
7.50k
             coff_section_alignment_table,
1794
7.50k
             coff_section_alignment_table_size);
1795
1796
7.50k
  return true;
1797
7.50k
}
Unexecuted instantiation: coff-x86_64.c:coff_new_section_hook
Unexecuted instantiation: coff64-rs6000.c:coff_new_section_hook
pei-aarch64.c:coff_new_section_hook
Line
Count
Source
1737
7.89k
{
1738
7.89k
  combined_entry_type *native;
1739
7.89k
  size_t amt;
1740
7.89k
  unsigned char sclass = C_STAT;
1741
1742
7.89k
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
#ifdef RS6000COFF_C
1745
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
  else
1752
    {
1753
      int i;
1754
1755
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
  if (strcmp (bfd_section_name (section),
1757
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
    {
1759
      section->alignment_power = 0;
1760
      sclass = C_DWARF;
1761
      break;
1762
    }
1763
    }
1764
#endif
1765
1766
  /* Set up the section symbol.  */
1767
7.89k
  if (!_bfd_generic_new_section_hook (abfd, section))
1768
0
    return false;
1769
1770
  /* Allocate aux records for section symbols, to store size and
1771
     related info.
1772
1773
     @@ The 10 is a guess at a plausible maximum number of aux entries
1774
     (but shouldn't be a constant).  */
1775
7.89k
  amt = sizeof (combined_entry_type) * 10;
1776
7.89k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
7.89k
  if (native == NULL)
1778
0
    return false;
1779
1780
  /* We don't need to set up n_name, n_value, or n_scnum in the native
1781
     symbol information, since they'll be overridden by the BFD symbol
1782
     anyhow.  However, we do need to set the type and storage class,
1783
     in case this symbol winds up getting written out.  The value 0
1784
     for n_numaux is already correct.  */
1785
1786
7.89k
  native->is_sym = true;
1787
7.89k
  native->u.syment.n_type = T_NULL;
1788
7.89k
  native->u.syment.n_sclass = sclass;
1789
1790
7.89k
  coffsymbol (section->symbol)->native = native;
1791
1792
7.89k
  coff_set_custom_section_alignment (abfd, section,
1793
7.89k
             coff_section_alignment_table,
1794
7.89k
             coff_section_alignment_table_size);
1795
1796
7.89k
  return true;
1797
7.89k
}
Unexecuted instantiation: pe-aarch64.c:coff_new_section_hook
pei-ia64.c:coff_new_section_hook
Line
Count
Source
1737
8.69k
{
1738
8.69k
  combined_entry_type *native;
1739
8.69k
  size_t amt;
1740
8.69k
  unsigned char sclass = C_STAT;
1741
1742
8.69k
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
#ifdef RS6000COFF_C
1745
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
  else
1752
    {
1753
      int i;
1754
1755
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
  if (strcmp (bfd_section_name (section),
1757
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
    {
1759
      section->alignment_power = 0;
1760
      sclass = C_DWARF;
1761
      break;
1762
    }
1763
    }
1764
#endif
1765
1766
  /* Set up the section symbol.  */
1767
8.69k
  if (!_bfd_generic_new_section_hook (abfd, section))
1768
0
    return false;
1769
1770
  /* Allocate aux records for section symbols, to store size and
1771
     related info.
1772
1773
     @@ The 10 is a guess at a plausible maximum number of aux entries
1774
     (but shouldn't be a constant).  */
1775
8.69k
  amt = sizeof (combined_entry_type) * 10;
1776
8.69k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
8.69k
  if (native == NULL)
1778
0
    return false;
1779
1780
  /* We don't need to set up n_name, n_value, or n_scnum in the native
1781
     symbol information, since they'll be overridden by the BFD symbol
1782
     anyhow.  However, we do need to set the type and storage class,
1783
     in case this symbol winds up getting written out.  The value 0
1784
     for n_numaux is already correct.  */
1785
1786
8.69k
  native->is_sym = true;
1787
8.69k
  native->u.syment.n_type = T_NULL;
1788
8.69k
  native->u.syment.n_sclass = sclass;
1789
1790
8.69k
  coffsymbol (section->symbol)->native = native;
1791
1792
8.69k
  coff_set_custom_section_alignment (abfd, section,
1793
8.69k
             coff_section_alignment_table,
1794
8.69k
             coff_section_alignment_table_size);
1795
1796
8.69k
  return true;
1797
8.69k
}
pei-loongarch64.c:coff_new_section_hook
Line
Count
Source
1737
8.57k
{
1738
8.57k
  combined_entry_type *native;
1739
8.57k
  size_t amt;
1740
8.57k
  unsigned char sclass = C_STAT;
1741
1742
8.57k
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
#ifdef RS6000COFF_C
1745
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
  else
1752
    {
1753
      int i;
1754
1755
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
  if (strcmp (bfd_section_name (section),
1757
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
    {
1759
      section->alignment_power = 0;
1760
      sclass = C_DWARF;
1761
      break;
1762
    }
1763
    }
1764
#endif
1765
1766
  /* Set up the section symbol.  */
1767
8.57k
  if (!_bfd_generic_new_section_hook (abfd, section))
1768
0
    return false;
1769
1770
  /* Allocate aux records for section symbols, to store size and
1771
     related info.
1772
1773
     @@ The 10 is a guess at a plausible maximum number of aux entries
1774
     (but shouldn't be a constant).  */
1775
8.57k
  amt = sizeof (combined_entry_type) * 10;
1776
8.57k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
8.57k
  if (native == NULL)
1778
0
    return false;
1779
1780
  /* We don't need to set up n_name, n_value, or n_scnum in the native
1781
     symbol information, since they'll be overridden by the BFD symbol
1782
     anyhow.  However, we do need to set the type and storage class,
1783
     in case this symbol winds up getting written out.  The value 0
1784
     for n_numaux is already correct.  */
1785
1786
8.57k
  native->is_sym = true;
1787
8.57k
  native->u.syment.n_type = T_NULL;
1788
8.57k
  native->u.syment.n_sclass = sclass;
1789
1790
8.57k
  coffsymbol (section->symbol)->native = native;
1791
1792
8.57k
  coff_set_custom_section_alignment (abfd, section,
1793
8.57k
             coff_section_alignment_table,
1794
8.57k
             coff_section_alignment_table_size);
1795
1796
8.57k
  return true;
1797
8.57k
}
cf-i386lynx.c:coff_new_section_hook
Line
Count
Source
1737
89.3k
{
1738
89.3k
  combined_entry_type *native;
1739
89.3k
  size_t amt;
1740
89.3k
  unsigned char sclass = C_STAT;
1741
1742
89.3k
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
#ifdef RS6000COFF_C
1745
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
  else
1752
    {
1753
      int i;
1754
1755
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
  if (strcmp (bfd_section_name (section),
1757
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
    {
1759
      section->alignment_power = 0;
1760
      sclass = C_DWARF;
1761
      break;
1762
    }
1763
    }
1764
#endif
1765
1766
  /* Set up the section symbol.  */
1767
89.3k
  if (!_bfd_generic_new_section_hook (abfd, section))
1768
0
    return false;
1769
1770
  /* Allocate aux records for section symbols, to store size and
1771
     related info.
1772
1773
     @@ The 10 is a guess at a plausible maximum number of aux entries
1774
     (but shouldn't be a constant).  */
1775
89.3k
  amt = sizeof (combined_entry_type) * 10;
1776
89.3k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
89.3k
  if (native == NULL)
1778
0
    return false;
1779
1780
  /* We don't need to set up n_name, n_value, or n_scnum in the native
1781
     symbol information, since they'll be overridden by the BFD symbol
1782
     anyhow.  However, we do need to set the type and storage class,
1783
     in case this symbol winds up getting written out.  The value 0
1784
     for n_numaux is already correct.  */
1785
1786
89.3k
  native->is_sym = true;
1787
89.3k
  native->u.syment.n_type = T_NULL;
1788
89.3k
  native->u.syment.n_sclass = sclass;
1789
1790
89.3k
  coffsymbol (section->symbol)->native = native;
1791
1792
89.3k
  coff_set_custom_section_alignment (abfd, section,
1793
89.3k
             coff_section_alignment_table,
1794
89.3k
             coff_section_alignment_table_size);
1795
1796
89.3k
  return true;
1797
89.3k
}
Unexecuted instantiation: coff-go32.c:coff_new_section_hook
Unexecuted instantiation: coff-i386.c:coff_new_section_hook
Unexecuted instantiation: coff-rs6000.c:coff_new_section_hook
Unexecuted instantiation: coff-sh.c:coff_new_section_hook
coff-stgo32.c:coff_new_section_hook
Line
Count
Source
1737
90.3k
{
1738
90.3k
  combined_entry_type *native;
1739
90.3k
  size_t amt;
1740
90.3k
  unsigned char sclass = C_STAT;
1741
1742
90.3k
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
#ifdef RS6000COFF_C
1745
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
  else
1752
    {
1753
      int i;
1754
1755
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
  if (strcmp (bfd_section_name (section),
1757
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
    {
1759
      section->alignment_power = 0;
1760
      sclass = C_DWARF;
1761
      break;
1762
    }
1763
    }
1764
#endif
1765
1766
  /* Set up the section symbol.  */
1767
90.3k
  if (!_bfd_generic_new_section_hook (abfd, section))
1768
0
    return false;
1769
1770
  /* Allocate aux records for section symbols, to store size and
1771
     related info.
1772
1773
     @@ The 10 is a guess at a plausible maximum number of aux entries
1774
     (but shouldn't be a constant).  */
1775
90.3k
  amt = sizeof (combined_entry_type) * 10;
1776
90.3k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
90.3k
  if (native == NULL)
1778
0
    return false;
1779
1780
  /* We don't need to set up n_name, n_value, or n_scnum in the native
1781
     symbol information, since they'll be overridden by the BFD symbol
1782
     anyhow.  However, we do need to set the type and storage class,
1783
     in case this symbol winds up getting written out.  The value 0
1784
     for n_numaux is already correct.  */
1785
1786
90.3k
  native->is_sym = true;
1787
90.3k
  native->u.syment.n_type = T_NULL;
1788
90.3k
  native->u.syment.n_sclass = sclass;
1789
1790
90.3k
  coffsymbol (section->symbol)->native = native;
1791
1792
90.3k
  coff_set_custom_section_alignment (abfd, section,
1793
90.3k
             coff_section_alignment_table,
1794
90.3k
             coff_section_alignment_table_size);
1795
1796
90.3k
  return true;
1797
90.3k
}
Unexecuted instantiation: coff-tic30.c:coff_new_section_hook
Unexecuted instantiation: coff-tic4x.c:coff_new_section_hook
Unexecuted instantiation: coff-tic54x.c:coff_new_section_hook
Unexecuted instantiation: coff-z80.c:coff_new_section_hook
Unexecuted instantiation: coff-z8k.c:coff_new_section_hook
Unexecuted instantiation: pe-arm-wince.c:coff_new_section_hook
Unexecuted instantiation: pe-arm.c:coff_new_section_hook
pe-i386.c:coff_new_section_hook
Line
Count
Source
1737
15.3k
{
1738
15.3k
  combined_entry_type *native;
1739
15.3k
  size_t amt;
1740
15.3k
  unsigned char sclass = C_STAT;
1741
1742
15.3k
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
#ifdef RS6000COFF_C
1745
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
  else
1752
    {
1753
      int i;
1754
1755
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
  if (strcmp (bfd_section_name (section),
1757
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
    {
1759
      section->alignment_power = 0;
1760
      sclass = C_DWARF;
1761
      break;
1762
    }
1763
    }
1764
#endif
1765
1766
  /* Set up the section symbol.  */
1767
15.3k
  if (!_bfd_generic_new_section_hook (abfd, section))
1768
0
    return false;
1769
1770
  /* Allocate aux records for section symbols, to store size and
1771
     related info.
1772
1773
     @@ The 10 is a guess at a plausible maximum number of aux entries
1774
     (but shouldn't be a constant).  */
1775
15.3k
  amt = sizeof (combined_entry_type) * 10;
1776
15.3k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
15.3k
  if (native == NULL)
1778
0
    return false;
1779
1780
  /* We don't need to set up n_name, n_value, or n_scnum in the native
1781
     symbol information, since they'll be overridden by the BFD symbol
1782
     anyhow.  However, we do need to set the type and storage class,
1783
     in case this symbol winds up getting written out.  The value 0
1784
     for n_numaux is already correct.  */
1785
1786
15.3k
  native->is_sym = true;
1787
15.3k
  native->u.syment.n_type = T_NULL;
1788
15.3k
  native->u.syment.n_sclass = sclass;
1789
1790
15.3k
  coffsymbol (section->symbol)->native = native;
1791
1792
15.3k
  coff_set_custom_section_alignment (abfd, section,
1793
15.3k
             coff_section_alignment_table,
1794
15.3k
             coff_section_alignment_table_size);
1795
1796
15.3k
  return true;
1797
15.3k
}
Unexecuted instantiation: pe-mcore.c:coff_new_section_hook
Unexecuted instantiation: pe-sh.c:coff_new_section_hook
pei-arm-wince.c:coff_new_section_hook
Line
Count
Source
1737
10.4k
{
1738
10.4k
  combined_entry_type *native;
1739
10.4k
  size_t amt;
1740
10.4k
  unsigned char sclass = C_STAT;
1741
1742
10.4k
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
#ifdef RS6000COFF_C
1745
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
  else
1752
    {
1753
      int i;
1754
1755
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
  if (strcmp (bfd_section_name (section),
1757
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
    {
1759
      section->alignment_power = 0;
1760
      sclass = C_DWARF;
1761
      break;
1762
    }
1763
    }
1764
#endif
1765
1766
  /* Set up the section symbol.  */
1767
10.4k
  if (!_bfd_generic_new_section_hook (abfd, section))
1768
0
    return false;
1769
1770
  /* Allocate aux records for section symbols, to store size and
1771
     related info.
1772
1773
     @@ The 10 is a guess at a plausible maximum number of aux entries
1774
     (but shouldn't be a constant).  */
1775
10.4k
  amt = sizeof (combined_entry_type) * 10;
1776
10.4k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
10.4k
  if (native == NULL)
1778
0
    return false;
1779
1780
  /* We don't need to set up n_name, n_value, or n_scnum in the native
1781
     symbol information, since they'll be overridden by the BFD symbol
1782
     anyhow.  However, we do need to set the type and storage class,
1783
     in case this symbol winds up getting written out.  The value 0
1784
     for n_numaux is already correct.  */
1785
1786
10.4k
  native->is_sym = true;
1787
10.4k
  native->u.syment.n_type = T_NULL;
1788
10.4k
  native->u.syment.n_sclass = sclass;
1789
1790
10.4k
  coffsymbol (section->symbol)->native = native;
1791
1792
10.4k
  coff_set_custom_section_alignment (abfd, section,
1793
10.4k
             coff_section_alignment_table,
1794
10.4k
             coff_section_alignment_table_size);
1795
1796
10.4k
  return true;
1797
10.4k
}
pei-arm.c:coff_new_section_hook
Line
Count
Source
1737
12.0k
{
1738
12.0k
  combined_entry_type *native;
1739
12.0k
  size_t amt;
1740
12.0k
  unsigned char sclass = C_STAT;
1741
1742
12.0k
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
#ifdef RS6000COFF_C
1745
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
  else
1752
    {
1753
      int i;
1754
1755
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
  if (strcmp (bfd_section_name (section),
1757
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
    {
1759
      section->alignment_power = 0;
1760
      sclass = C_DWARF;
1761
      break;
1762
    }
1763
    }
1764
#endif
1765
1766
  /* Set up the section symbol.  */
1767
12.0k
  if (!_bfd_generic_new_section_hook (abfd, section))
1768
0
    return false;
1769
1770
  /* Allocate aux records for section symbols, to store size and
1771
     related info.
1772
1773
     @@ The 10 is a guess at a plausible maximum number of aux entries
1774
     (but shouldn't be a constant).  */
1775
12.0k
  amt = sizeof (combined_entry_type) * 10;
1776
12.0k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
12.0k
  if (native == NULL)
1778
0
    return false;
1779
1780
  /* We don't need to set up n_name, n_value, or n_scnum in the native
1781
     symbol information, since they'll be overridden by the BFD symbol
1782
     anyhow.  However, we do need to set the type and storage class,
1783
     in case this symbol winds up getting written out.  The value 0
1784
     for n_numaux is already correct.  */
1785
1786
12.0k
  native->is_sym = true;
1787
12.0k
  native->u.syment.n_type = T_NULL;
1788
12.0k
  native->u.syment.n_sclass = sclass;
1789
1790
12.0k
  coffsymbol (section->symbol)->native = native;
1791
1792
12.0k
  coff_set_custom_section_alignment (abfd, section,
1793
12.0k
             coff_section_alignment_table,
1794
12.0k
             coff_section_alignment_table_size);
1795
1796
12.0k
  return true;
1797
12.0k
}
pei-mcore.c:coff_new_section_hook
Line
Count
Source
1737
6.46k
{
1738
6.46k
  combined_entry_type *native;
1739
6.46k
  size_t amt;
1740
6.46k
  unsigned char sclass = C_STAT;
1741
1742
6.46k
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
#ifdef RS6000COFF_C
1745
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
  else
1752
    {
1753
      int i;
1754
1755
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
  if (strcmp (bfd_section_name (section),
1757
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
    {
1759
      section->alignment_power = 0;
1760
      sclass = C_DWARF;
1761
      break;
1762
    }
1763
    }
1764
#endif
1765
1766
  /* Set up the section symbol.  */
1767
6.46k
  if (!_bfd_generic_new_section_hook (abfd, section))
1768
0
    return false;
1769
1770
  /* Allocate aux records for section symbols, to store size and
1771
     related info.
1772
1773
     @@ The 10 is a guess at a plausible maximum number of aux entries
1774
     (but shouldn't be a constant).  */
1775
6.46k
  amt = sizeof (combined_entry_type) * 10;
1776
6.46k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
6.46k
  if (native == NULL)
1778
0
    return false;
1779
1780
  /* We don't need to set up n_name, n_value, or n_scnum in the native
1781
     symbol information, since they'll be overridden by the BFD symbol
1782
     anyhow.  However, we do need to set the type and storage class,
1783
     in case this symbol winds up getting written out.  The value 0
1784
     for n_numaux is already correct.  */
1785
1786
6.46k
  native->is_sym = true;
1787
6.46k
  native->u.syment.n_type = T_NULL;
1788
6.46k
  native->u.syment.n_sclass = sclass;
1789
1790
6.46k
  coffsymbol (section->symbol)->native = native;
1791
1792
6.46k
  coff_set_custom_section_alignment (abfd, section,
1793
6.46k
             coff_section_alignment_table,
1794
6.46k
             coff_section_alignment_table_size);
1795
1796
6.46k
  return true;
1797
6.46k
}
pei-sh.c:coff_new_section_hook
Line
Count
Source
1737
7.05k
{
1738
7.05k
  combined_entry_type *native;
1739
7.05k
  size_t amt;
1740
7.05k
  unsigned char sclass = C_STAT;
1741
1742
7.05k
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
#ifdef RS6000COFF_C
1745
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
  else
1752
    {
1753
      int i;
1754
1755
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
  if (strcmp (bfd_section_name (section),
1757
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
    {
1759
      section->alignment_power = 0;
1760
      sclass = C_DWARF;
1761
      break;
1762
    }
1763
    }
1764
#endif
1765
1766
  /* Set up the section symbol.  */
1767
7.05k
  if (!_bfd_generic_new_section_hook (abfd, section))
1768
0
    return false;
1769
1770
  /* Allocate aux records for section symbols, to store size and
1771
     related info.
1772
1773
     @@ The 10 is a guess at a plausible maximum number of aux entries
1774
     (but shouldn't be a constant).  */
1775
7.05k
  amt = sizeof (combined_entry_type) * 10;
1776
7.05k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
7.05k
  if (native == NULL)
1778
0
    return false;
1779
1780
  /* We don't need to set up n_name, n_value, or n_scnum in the native
1781
     symbol information, since they'll be overridden by the BFD symbol
1782
     anyhow.  However, we do need to set the type and storage class,
1783
     in case this symbol winds up getting written out.  The value 0
1784
     for n_numaux is already correct.  */
1785
1786
7.05k
  native->is_sym = true;
1787
7.05k
  native->u.syment.n_type = T_NULL;
1788
7.05k
  native->u.syment.n_sclass = sclass;
1789
1790
7.05k
  coffsymbol (section->symbol)->native = native;
1791
1792
7.05k
  coff_set_custom_section_alignment (abfd, section,
1793
7.05k
             coff_section_alignment_table,
1794
7.05k
             coff_section_alignment_table_size);
1795
1796
7.05k
  return true;
1797
7.05k
}
1798
1799
#ifdef COFF_ALIGN_IN_SECTION_HEADER
1800
1801
/* Set the alignment of a BFD section.  */
1802
1803
static void
1804
coff_set_alignment_hook (bfd * abfd ATTRIBUTE_UNUSED,
1805
       asection * section,
1806
       void * scnhdr)
1807
0
{
1808
0
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1809
0
  unsigned int i;
1810
1811
0
#ifdef COFF_DECODE_ALIGNMENT
1812
0
  i = COFF_DECODE_ALIGNMENT(hdr->s_flags);
1813
0
#endif
1814
0
  section->alignment_power = i;
1815
1816
#ifdef coff_set_section_load_page
1817
0
  coff_set_section_load_page (section, hdr->s_page);
1818
#endif
1819
0
}
Unexecuted instantiation: coff-tic4x.c:coff_set_alignment_hook
Unexecuted instantiation: coff-tic54x.c:coff_set_alignment_hook
Unexecuted instantiation: coff-z80.c:coff_set_alignment_hook
1820
1821
#else /* ! COFF_ALIGN_IN_SECTION_HEADER */
1822
#ifdef COFF_WITH_PE
1823
1824
static void
1825
coff_set_alignment_hook (bfd * abfd ATTRIBUTE_UNUSED,
1826
       asection * section,
1827
       void * scnhdr)
1828
92.0k
{
1829
92.0k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
92.0k
  size_t amt;
1831
92.0k
  unsigned int alignment_power_const
1832
92.0k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
92.0k
  switch (alignment_power_const)
1835
92.0k
    {
1836
9.88k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
10.1k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
13.0k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
13.6k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
20.7k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
21.7k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
22.4k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
22.8k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
27.4k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
27.7k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
28.7k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
29.2k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
30.6k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
32.5k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
32.5k
      section->alignment_power
1851
32.5k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
32.5k
      break;
1853
59.4k
    default:
1854
59.4k
      break;
1855
92.0k
    }
1856
1857
  /* In a PE image file, the s_paddr field holds the virtual size of a
1858
     section, while the s_size field holds the raw size.  We also keep
1859
     the original section flag value, since not every bit can be
1860
     mapped onto a generic BFD section bit.  */
1861
92.0k
  if (coff_section_data (abfd, section) == NULL)
1862
92.0k
    {
1863
92.0k
      amt = sizeof (struct coff_section_tdata);
1864
92.0k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
92.0k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
92.0k
    }
1869
1870
92.0k
  if (pei_section_data (abfd, section) == NULL)
1871
92.0k
    {
1872
92.0k
      amt = sizeof (struct pei_section_tdata);
1873
92.0k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
92.0k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
92.0k
    }
1878
92.0k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
92.0k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
92.0k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
92.0k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
23.5k
    {
1886
23.5k
      struct external_reloc dst;
1887
23.5k
      struct internal_reloc n;
1888
23.5k
      file_ptr oldpos = bfd_tell (abfd);
1889
23.5k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
23.5k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
23.5k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
8.49k
  return;
1895
1896
15.0k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
15.0k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
15.0k
      if (n.r_vaddr < 0x10000)
1900
5.17k
  {
1901
5.17k
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
5.17k
    bfd_set_error (bfd_error_bad_value);
1903
5.17k
    return;
1904
5.17k
  }
1905
9.86k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
9.86k
      section->rel_filepos += relsz;
1907
9.86k
    }
1908
68.4k
  else if (hdr->s_nreloc == 0xffff)
1909
1.03k
    _bfd_error_handler
1910
1.03k
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
1.03k
       abfd);
1912
92.0k
}
pei-i386.c:coff_set_alignment_hook
Line
Count
Source
1828
10.6k
{
1829
10.6k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
10.6k
  size_t amt;
1831
10.6k
  unsigned int alignment_power_const
1832
10.6k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
10.6k
  switch (alignment_power_const)
1835
10.6k
    {
1836
918
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
940
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
1.21k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
1.28k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
2.09k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
2.17k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
2.22k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
2.25k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
2.48k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
2.53k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
2.64k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
2.65k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
2.83k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
3.21k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
3.21k
      section->alignment_power
1851
3.21k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
3.21k
      break;
1853
7.39k
    default:
1854
7.39k
      break;
1855
10.6k
    }
1856
1857
  /* In a PE image file, the s_paddr field holds the virtual size of a
1858
     section, while the s_size field holds the raw size.  We also keep
1859
     the original section flag value, since not every bit can be
1860
     mapped onto a generic BFD section bit.  */
1861
10.6k
  if (coff_section_data (abfd, section) == NULL)
1862
10.6k
    {
1863
10.6k
      amt = sizeof (struct coff_section_tdata);
1864
10.6k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
10.6k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
10.6k
    }
1869
1870
10.6k
  if (pei_section_data (abfd, section) == NULL)
1871
10.6k
    {
1872
10.6k
      amt = sizeof (struct pei_section_tdata);
1873
10.6k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
10.6k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
10.6k
    }
1878
10.6k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
10.6k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
10.6k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
10.6k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
2.17k
    {
1886
2.17k
      struct external_reloc dst;
1887
2.17k
      struct internal_reloc n;
1888
2.17k
      file_ptr oldpos = bfd_tell (abfd);
1889
2.17k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
2.17k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
2.17k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
951
  return;
1895
1896
1.22k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
1.22k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
1.22k
      if (n.r_vaddr < 0x10000)
1900
577
  {
1901
577
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
577
    bfd_set_error (bfd_error_bad_value);
1903
577
    return;
1904
577
  }
1905
643
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
643
      section->rel_filepos += relsz;
1907
643
    }
1908
8.43k
  else if (hdr->s_nreloc == 0xffff)
1909
0
    _bfd_error_handler
1910
0
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
0
       abfd);
1912
10.6k
}
Unexecuted instantiation: pe-x86_64.c:coff_set_alignment_hook
pei-x86_64.c:coff_set_alignment_hook
Line
Count
Source
1828
7.07k
{
1829
7.07k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
7.07k
  size_t amt;
1831
7.07k
  unsigned int alignment_power_const
1832
7.07k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
7.07k
  switch (alignment_power_const)
1835
7.07k
    {
1836
385
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
399
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
788
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
836
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
1.11k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
1.19k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
1.27k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
1.32k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
1.73k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
1.75k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
1.82k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
1.89k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
2.00k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
2.15k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
2.15k
      section->alignment_power
1851
2.15k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
2.15k
      break;
1853
4.92k
    default:
1854
4.92k
      break;
1855
7.07k
    }
1856
1857
  /* In a PE image file, the s_paddr field holds the virtual size of a
1858
     section, while the s_size field holds the raw size.  We also keep
1859
     the original section flag value, since not every bit can be
1860
     mapped onto a generic BFD section bit.  */
1861
7.07k
  if (coff_section_data (abfd, section) == NULL)
1862
7.07k
    {
1863
7.07k
      amt = sizeof (struct coff_section_tdata);
1864
7.07k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
7.07k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
7.07k
    }
1869
1870
7.07k
  if (pei_section_data (abfd, section) == NULL)
1871
7.07k
    {
1872
7.07k
      amt = sizeof (struct pei_section_tdata);
1873
7.07k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
7.07k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
7.07k
    }
1878
7.07k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
7.07k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
7.07k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
7.07k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
1.48k
    {
1886
1.48k
      struct external_reloc dst;
1887
1.48k
      struct internal_reloc n;
1888
1.48k
      file_ptr oldpos = bfd_tell (abfd);
1889
1.48k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
1.48k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
1.48k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
716
  return;
1895
1896
771
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
771
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
771
      if (n.r_vaddr < 0x10000)
1900
204
  {
1901
204
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
204
    bfd_set_error (bfd_error_bad_value);
1903
204
    return;
1904
204
  }
1905
567
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
567
      section->rel_filepos += relsz;
1907
567
    }
1908
5.59k
  else if (hdr->s_nreloc == 0xffff)
1909
0
    _bfd_error_handler
1910
0
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
0
       abfd);
1912
7.07k
}
pei-aarch64.c:coff_set_alignment_hook
Line
Count
Source
1828
7.52k
{
1829
7.52k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
7.52k
  size_t amt;
1831
7.52k
  unsigned int alignment_power_const
1832
7.52k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
7.52k
  switch (alignment_power_const)
1835
7.52k
    {
1836
824
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
846
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
1.13k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
1.19k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
1.68k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
1.73k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
1.80k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
1.83k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
2.08k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
2.11k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
2.19k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
2.25k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
2.35k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
2.53k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
2.53k
      section->alignment_power
1851
2.53k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
2.53k
      break;
1853
4.99k
    default:
1854
4.99k
      break;
1855
7.52k
    }
1856
1857
  /* In a PE image file, the s_paddr field holds the virtual size of a
1858
     section, while the s_size field holds the raw size.  We also keep
1859
     the original section flag value, since not every bit can be
1860
     mapped onto a generic BFD section bit.  */
1861
7.52k
  if (coff_section_data (abfd, section) == NULL)
1862
7.52k
    {
1863
7.52k
      amt = sizeof (struct coff_section_tdata);
1864
7.52k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
7.52k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
7.52k
    }
1869
1870
7.52k
  if (pei_section_data (abfd, section) == NULL)
1871
7.52k
    {
1872
7.52k
      amt = sizeof (struct pei_section_tdata);
1873
7.52k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
7.52k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
7.52k
    }
1878
7.52k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
7.52k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
7.52k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
7.52k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
1.93k
    {
1886
1.93k
      struct external_reloc dst;
1887
1.93k
      struct internal_reloc n;
1888
1.93k
      file_ptr oldpos = bfd_tell (abfd);
1889
1.93k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
1.93k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
1.93k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
594
  return;
1895
1896
1.34k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
1.34k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
1.34k
      if (n.r_vaddr < 0x10000)
1900
205
  {
1901
205
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
205
    bfd_set_error (bfd_error_bad_value);
1903
205
    return;
1904
205
  }
1905
1.13k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
1.13k
      section->rel_filepos += relsz;
1907
1.13k
    }
1908
5.58k
  else if (hdr->s_nreloc == 0xffff)
1909
0
    _bfd_error_handler
1910
0
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
0
       abfd);
1912
7.52k
}
Unexecuted instantiation: pe-aarch64.c:coff_set_alignment_hook
pei-ia64.c:coff_set_alignment_hook
Line
Count
Source
1828
8.36k
{
1829
8.36k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
8.36k
  size_t amt;
1831
8.36k
  unsigned int alignment_power_const
1832
8.36k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
8.36k
  switch (alignment_power_const)
1835
8.36k
    {
1836
1.04k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
1.06k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
1.35k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
1.42k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
1.73k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
1.81k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
1.86k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
1.91k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
2.61k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
2.62k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
2.66k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
2.69k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
2.82k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
3.01k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
3.01k
      section->alignment_power
1851
3.01k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
3.01k
      break;
1853
5.35k
    default:
1854
5.35k
      break;
1855
8.36k
    }
1856
1857
  /* In a PE image file, the s_paddr field holds the virtual size of a
1858
     section, while the s_size field holds the raw size.  We also keep
1859
     the original section flag value, since not every bit can be
1860
     mapped onto a generic BFD section bit.  */
1861
8.36k
  if (coff_section_data (abfd, section) == NULL)
1862
8.36k
    {
1863
8.36k
      amt = sizeof (struct coff_section_tdata);
1864
8.36k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
8.36k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
8.36k
    }
1869
1870
8.36k
  if (pei_section_data (abfd, section) == NULL)
1871
8.36k
    {
1872
8.36k
      amt = sizeof (struct pei_section_tdata);
1873
8.36k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
8.36k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
8.36k
    }
1878
8.36k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
8.36k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
8.36k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
8.36k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
1.98k
    {
1886
1.98k
      struct external_reloc dst;
1887
1.98k
      struct internal_reloc n;
1888
1.98k
      file_ptr oldpos = bfd_tell (abfd);
1889
1.98k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
1.98k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
1.98k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
878
  return;
1895
1896
1.10k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
1.10k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
1.10k
      if (n.r_vaddr < 0x10000)
1900
367
  {
1901
367
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
367
    bfd_set_error (bfd_error_bad_value);
1903
367
    return;
1904
367
  }
1905
738
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
738
      section->rel_filepos += relsz;
1907
738
    }
1908
6.38k
  else if (hdr->s_nreloc == 0xffff)
1909
0
    _bfd_error_handler
1910
0
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
0
       abfd);
1912
8.36k
}
pei-loongarch64.c:coff_set_alignment_hook
Line
Count
Source
1828
8.24k
{
1829
8.24k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
8.24k
  size_t amt;
1831
8.24k
  unsigned int alignment_power_const
1832
8.24k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
8.24k
  switch (alignment_power_const)
1835
8.24k
    {
1836
904
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
916
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
1.43k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
1.52k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
1.80k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
1.94k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
2.01k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
2.05k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
2.25k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
2.29k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
2.39k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
2.52k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
2.64k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
2.83k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
2.83k
      section->alignment_power
1851
2.83k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
2.83k
      break;
1853
5.41k
    default:
1854
5.41k
      break;
1855
8.24k
    }
1856
1857
  /* In a PE image file, the s_paddr field holds the virtual size of a
1858
     section, while the s_size field holds the raw size.  We also keep
1859
     the original section flag value, since not every bit can be
1860
     mapped onto a generic BFD section bit.  */
1861
8.24k
  if (coff_section_data (abfd, section) == NULL)
1862
8.24k
    {
1863
8.24k
      amt = sizeof (struct coff_section_tdata);
1864
8.24k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
8.24k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
8.24k
    }
1869
1870
8.24k
  if (pei_section_data (abfd, section) == NULL)
1871
8.24k
    {
1872
8.24k
      amt = sizeof (struct pei_section_tdata);
1873
8.24k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
8.24k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
8.24k
    }
1878
8.24k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
8.24k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
8.24k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
8.24k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
2.03k
    {
1886
2.03k
      struct external_reloc dst;
1887
2.03k
      struct internal_reloc n;
1888
2.03k
      file_ptr oldpos = bfd_tell (abfd);
1889
2.03k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
2.03k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
2.03k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
749
  return;
1895
1896
1.28k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
1.28k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
1.28k
      if (n.r_vaddr < 0x10000)
1900
418
  {
1901
418
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
418
    bfd_set_error (bfd_error_bad_value);
1903
418
    return;
1904
418
  }
1905
864
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
864
      section->rel_filepos += relsz;
1907
864
    }
1908
6.21k
  else if (hdr->s_nreloc == 0xffff)
1909
0
    _bfd_error_handler
1910
0
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
0
       abfd);
1912
8.24k
}
Unexecuted instantiation: pe-arm-wince.c:coff_set_alignment_hook
Unexecuted instantiation: pe-arm.c:coff_set_alignment_hook
pe-i386.c:coff_set_alignment_hook
Line
Count
Source
1828
15.2k
{
1829
15.2k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
15.2k
  size_t amt;
1831
15.2k
  unsigned int alignment_power_const
1832
15.2k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
15.2k
  switch (alignment_power_const)
1835
15.2k
    {
1836
2.19k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
2.24k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
2.50k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
2.52k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
4.07k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
4.10k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
4.22k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
4.27k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
4.91k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
4.95k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
5.06k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
5.12k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
5.26k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
5.53k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
5.53k
      section->alignment_power
1851
5.53k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
5.53k
      break;
1853
9.70k
    default:
1854
9.70k
      break;
1855
15.2k
    }
1856
1857
  /* In a PE image file, the s_paddr field holds the virtual size of a
1858
     section, while the s_size field holds the raw size.  We also keep
1859
     the original section flag value, since not every bit can be
1860
     mapped onto a generic BFD section bit.  */
1861
15.2k
  if (coff_section_data (abfd, section) == NULL)
1862
15.2k
    {
1863
15.2k
      amt = sizeof (struct coff_section_tdata);
1864
15.2k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
15.2k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
15.2k
    }
1869
1870
15.2k
  if (pei_section_data (abfd, section) == NULL)
1871
15.2k
    {
1872
15.2k
      amt = sizeof (struct pei_section_tdata);
1873
15.2k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
15.2k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
15.2k
    }
1878
15.2k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
15.2k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
15.2k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
15.2k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
4.54k
    {
1886
4.54k
      struct external_reloc dst;
1887
4.54k
      struct internal_reloc n;
1888
4.54k
      file_ptr oldpos = bfd_tell (abfd);
1889
4.54k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
4.54k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
4.54k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
1.30k
  return;
1895
1896
3.23k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
3.23k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
3.23k
      if (n.r_vaddr < 0x10000)
1900
742
  {
1901
742
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
742
    bfd_set_error (bfd_error_bad_value);
1903
742
    return;
1904
742
  }
1905
2.49k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
2.49k
      section->rel_filepos += relsz;
1907
2.49k
    }
1908
10.6k
  else if (hdr->s_nreloc == 0xffff)
1909
1.03k
    _bfd_error_handler
1910
1.03k
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
1.03k
       abfd);
1912
15.2k
}
Unexecuted instantiation: pe-mcore.c:coff_set_alignment_hook
Unexecuted instantiation: pe-sh.c:coff_set_alignment_hook
pei-arm-wince.c:coff_set_alignment_hook
Line
Count
Source
1828
10.1k
{
1829
10.1k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
10.1k
  size_t amt;
1831
10.1k
  unsigned int alignment_power_const
1832
10.1k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
10.1k
  switch (alignment_power_const)
1835
10.1k
    {
1836
1.04k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
1.07k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
1.24k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
1.27k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
2.46k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
2.62k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
2.68k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
2.74k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
3.50k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
3.55k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
3.67k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
3.69k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
3.86k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
3.98k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
3.98k
      section->alignment_power
1851
3.98k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
3.98k
      break;
1853
6.15k
    default:
1854
6.15k
      break;
1855
10.1k
    }
1856
1857
  /* In a PE image file, the s_paddr field holds the virtual size of a
1858
     section, while the s_size field holds the raw size.  We also keep
1859
     the original section flag value, since not every bit can be
1860
     mapped onto a generic BFD section bit.  */
1861
10.1k
  if (coff_section_data (abfd, section) == NULL)
1862
10.1k
    {
1863
10.1k
      amt = sizeof (struct coff_section_tdata);
1864
10.1k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
10.1k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
10.1k
    }
1869
1870
10.1k
  if (pei_section_data (abfd, section) == NULL)
1871
10.1k
    {
1872
10.1k
      amt = sizeof (struct pei_section_tdata);
1873
10.1k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
10.1k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
10.1k
    }
1878
10.1k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
10.1k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
10.1k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
10.1k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
3.07k
    {
1886
3.07k
      struct external_reloc dst;
1887
3.07k
      struct internal_reloc n;
1888
3.07k
      file_ptr oldpos = bfd_tell (abfd);
1889
3.07k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
3.07k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
3.07k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
1.05k
  return;
1895
1896
2.01k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
2.01k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
2.01k
      if (n.r_vaddr < 0x10000)
1900
909
  {
1901
909
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
909
    bfd_set_error (bfd_error_bad_value);
1903
909
    return;
1904
909
  }
1905
1.10k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
1.10k
      section->rel_filepos += relsz;
1907
1.10k
    }
1908
7.06k
  else if (hdr->s_nreloc == 0xffff)
1909
0
    _bfd_error_handler
1910
0
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
0
       abfd);
1912
10.1k
}
pei-arm.c:coff_set_alignment_hook
Line
Count
Source
1828
11.6k
{
1829
11.6k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
11.6k
  size_t amt;
1831
11.6k
  unsigned int alignment_power_const
1832
11.6k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
11.6k
  switch (alignment_power_const)
1835
11.6k
    {
1836
1.32k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
1.35k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
1.55k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
1.63k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
2.83k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
2.99k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
3.06k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
3.12k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
4.01k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
4.07k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
4.21k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
4.24k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
4.44k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
4.62k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
4.62k
      section->alignment_power
1851
4.62k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
4.62k
      break;
1853
7.07k
    default:
1854
7.07k
      break;
1855
11.6k
    }
1856
1857
  /* In a PE image file, the s_paddr field holds the virtual size of a
1858
     section, while the s_size field holds the raw size.  We also keep
1859
     the original section flag value, since not every bit can be
1860
     mapped onto a generic BFD section bit.  */
1861
11.6k
  if (coff_section_data (abfd, section) == NULL)
1862
11.6k
    {
1863
11.6k
      amt = sizeof (struct coff_section_tdata);
1864
11.6k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
11.6k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
11.6k
    }
1869
1870
11.6k
  if (pei_section_data (abfd, section) == NULL)
1871
11.6k
    {
1872
11.6k
      amt = sizeof (struct pei_section_tdata);
1873
11.6k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
11.6k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
11.6k
    }
1878
11.6k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
11.6k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
11.6k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
11.6k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
3.45k
    {
1886
3.45k
      struct external_reloc dst;
1887
3.45k
      struct internal_reloc n;
1888
3.45k
      file_ptr oldpos = bfd_tell (abfd);
1889
3.45k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
3.45k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
3.45k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
1.17k
  return;
1895
1896
2.28k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
2.28k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
2.28k
      if (n.r_vaddr < 0x10000)
1900
1.02k
  {
1901
1.02k
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
1.02k
    bfd_set_error (bfd_error_bad_value);
1903
1.02k
    return;
1904
1.02k
  }
1905
1.25k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
1.25k
      section->rel_filepos += relsz;
1907
1.25k
    }
1908
8.24k
  else if (hdr->s_nreloc == 0xffff)
1909
0
    _bfd_error_handler
1910
0
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
0
       abfd);
1912
11.6k
}
pei-mcore.c:coff_set_alignment_hook
Line
Count
Source
1828
6.26k
{
1829
6.26k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
6.26k
  size_t amt;
1831
6.26k
  unsigned int alignment_power_const
1832
6.26k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
6.26k
  switch (alignment_power_const)
1835
6.26k
    {
1836
567
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
579
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
955
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
985
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
1.72k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
1.80k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
1.84k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
1.88k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
2.17k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
2.20k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
2.29k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
2.34k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
2.48k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
2.59k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
2.59k
      section->alignment_power
1851
2.59k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
2.59k
      break;
1853
3.66k
    default:
1854
3.66k
      break;
1855
6.26k
    }
1856
1857
  /* In a PE image file, the s_paddr field holds the virtual size of a
1858
     section, while the s_size field holds the raw size.  We also keep
1859
     the original section flag value, since not every bit can be
1860
     mapped onto a generic BFD section bit.  */
1861
6.26k
  if (coff_section_data (abfd, section) == NULL)
1862
6.26k
    {
1863
6.26k
      amt = sizeof (struct coff_section_tdata);
1864
6.26k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
6.26k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
6.26k
    }
1869
1870
6.26k
  if (pei_section_data (abfd, section) == NULL)
1871
6.26k
    {
1872
6.26k
      amt = sizeof (struct pei_section_tdata);
1873
6.26k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
6.26k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
6.26k
    }
1878
6.26k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
6.26k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
6.26k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
6.26k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
1.21k
    {
1886
1.21k
      struct external_reloc dst;
1887
1.21k
      struct internal_reloc n;
1888
1.21k
      file_ptr oldpos = bfd_tell (abfd);
1889
1.21k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
1.21k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
1.21k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
578
  return;
1895
1896
634
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
634
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
634
      if (n.r_vaddr < 0x10000)
1900
171
  {
1901
171
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
171
    bfd_set_error (bfd_error_bad_value);
1903
171
    return;
1904
171
  }
1905
463
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
463
      section->rel_filepos += relsz;
1907
463
    }
1908
5.04k
  else if (hdr->s_nreloc == 0xffff)
1909
0
    _bfd_error_handler
1910
0
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
0
       abfd);
1912
6.26k
}
pei-sh.c:coff_set_alignment_hook
Line
Count
Source
1828
6.85k
{
1829
6.85k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
6.85k
  size_t amt;
1831
6.85k
  unsigned int alignment_power_const
1832
6.85k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
6.85k
  switch (alignment_power_const)
1835
6.85k
    {
1836
677
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
695
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
897
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
938
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
1.23k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
1.32k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
1.40k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
1.45k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
1.64k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
1.66k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
1.75k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
1.80k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
1.89k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
2.08k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
2.08k
      section->alignment_power
1851
2.08k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
2.08k
      break;
1853
4.76k
    default:
1854
4.76k
      break;
1855
6.85k
    }
1856
1857
  /* In a PE image file, the s_paddr field holds the virtual size of a
1858
     section, while the s_size field holds the raw size.  We also keep
1859
     the original section flag value, since not every bit can be
1860
     mapped onto a generic BFD section bit.  */
1861
6.85k
  if (coff_section_data (abfd, section) == NULL)
1862
6.85k
    {
1863
6.85k
      amt = sizeof (struct coff_section_tdata);
1864
6.85k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
6.85k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
6.85k
    }
1869
1870
6.85k
  if (pei_section_data (abfd, section) == NULL)
1871
6.85k
    {
1872
6.85k
      amt = sizeof (struct pei_section_tdata);
1873
6.85k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
6.85k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
6.85k
    }
1878
6.85k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
6.85k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
6.85k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
6.85k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
1.65k
    {
1886
1.65k
      struct external_reloc dst;
1887
1.65k
      struct internal_reloc n;
1888
1.65k
      file_ptr oldpos = bfd_tell (abfd);
1889
1.65k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
1.65k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
1.65k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
496
  return;
1895
1896
1.15k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
1.15k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
1.15k
      if (n.r_vaddr < 0x10000)
1900
560
  {
1901
560
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
560
    bfd_set_error (bfd_error_bad_value);
1903
560
    return;
1904
560
  }
1905
598
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
598
      section->rel_filepos += relsz;
1907
598
    }
1908
5.20k
  else if (hdr->s_nreloc == 0xffff)
1909
0
    _bfd_error_handler
1910
0
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
0
       abfd);
1912
6.85k
}
1913
#undef ALIGN_SET
1914
#undef ELIFALIGN_SET
1915
1916
#else /* ! COFF_WITH_PE */
1917
#ifdef RS6000COFF_C
1918
1919
/* We grossly abuse this function to handle XCOFF overflow headers.
1920
   When we see one, we correct the reloc and line number counts in the
1921
   real header, and remove the section we just created.  */
1922
1923
static void
1924
coff_set_alignment_hook (bfd *abfd, asection *section, void * scnhdr)
1925
0
{
1926
0
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1927
0
  asection *real_sec;
1928
1929
0
  if ((hdr->s_flags & STYP_OVRFLO) == 0)
1930
0
    return;
1931
1932
0
  real_sec = coff_section_from_bfd_index (abfd, (int) hdr->s_nreloc);
1933
0
  if (real_sec == NULL)
1934
0
    return;
1935
1936
0
  real_sec->reloc_count = hdr->s_paddr;
1937
0
  real_sec->lineno_count = hdr->s_vaddr;
1938
1939
0
  if (!bfd_section_removed_from_list (abfd, section))
1940
0
    {
1941
0
      bfd_section_list_remove (abfd, section);
1942
0
      --abfd->section_count;
1943
0
    }
1944
0
}
Unexecuted instantiation: coff64-rs6000.c:coff_set_alignment_hook
Unexecuted instantiation: coff-rs6000.c:coff_set_alignment_hook
1945
1946
#else /* ! RS6000COFF_C */
1947
#if defined (COFF_GO32_EXE) || defined (COFF_GO32)
1948
1949
static void
1950
coff_set_alignment_hook (bfd * abfd, asection * section, void * scnhdr)
1951
90.3k
{
1952
90.3k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1953
1954
  /* Check for extended relocs.  */
1955
90.3k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1956
25.7k
    {
1957
25.7k
      struct external_reloc dst;
1958
25.7k
      struct internal_reloc n;
1959
25.7k
      const file_ptr oldpos = bfd_tell (abfd);
1960
25.7k
      const bfd_size_type relsz = bfd_coff_relsz (abfd);
1961
1962
25.7k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1963
0
  return;
1964
25.7k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1965
18.6k
  return;
1966
1967
7.03k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1968
7.03k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1969
0
  return;
1970
7.03k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1971
7.03k
      section->rel_filepos += relsz;
1972
7.03k
    }
1973
64.6k
  else if (hdr->s_nreloc == 0xffff)
1974
2.36k
    _bfd_error_handler
1975
2.36k
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1976
2.36k
       abfd);
1977
90.3k
}
Unexecuted instantiation: coff-go32.c:coff_set_alignment_hook
coff-stgo32.c:coff_set_alignment_hook
Line
Count
Source
1951
90.3k
{
1952
90.3k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1953
1954
  /* Check for extended relocs.  */
1955
90.3k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1956
25.7k
    {
1957
25.7k
      struct external_reloc dst;
1958
25.7k
      struct internal_reloc n;
1959
25.7k
      const file_ptr oldpos = bfd_tell (abfd);
1960
25.7k
      const bfd_size_type relsz = bfd_coff_relsz (abfd);
1961
1962
25.7k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1963
0
  return;
1964
25.7k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1965
18.6k
  return;
1966
1967
7.03k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1968
7.03k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1969
0
  return;
1970
7.03k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1971
7.03k
      section->rel_filepos += relsz;
1972
7.03k
    }
1973
64.6k
  else if (hdr->s_nreloc == 0xffff)
1974
2.36k
    _bfd_error_handler
1975
2.36k
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1976
2.36k
       abfd);
1977
90.3k
}
1978
1979
#else /* ! COFF_GO32_EXE && ! COFF_GO32 */
1980
1981
static void
1982
coff_set_alignment_hook (bfd *abfd ATTRIBUTE_UNUSED,
1983
       asection *section ATTRIBUTE_UNUSED,
1984
       void *scnhdr ATTRIBUTE_UNUSED)
1985
89.3k
{
1986
89.3k
}
Unexecuted instantiation: coff-x86_64.c:coff_set_alignment_hook
cf-i386lynx.c:coff_set_alignment_hook
Line
Count
Source
1985
89.3k
{
1986
89.3k
}
Unexecuted instantiation: coff-i386.c:coff_set_alignment_hook
Unexecuted instantiation: coff-sh.c:coff_set_alignment_hook
Unexecuted instantiation: coff-tic30.c:coff_set_alignment_hook
Unexecuted instantiation: coff-z8k.c:coff_set_alignment_hook
1987
1988
#endif /* ! COFF_GO32_EXE && ! COFF_GO32 */
1989
#endif /* ! RS6000COFF_C */
1990
#endif /* ! COFF_WITH_PE */
1991
#endif /* ! COFF_ALIGN_IN_SECTION_HEADER */
1992
1993
#ifndef coff_mkobject
1994
1995
static bool
1996
coff_mkobject (bfd * abfd)
1997
1.40k
{
1998
1.40k
  coff_data_type *coff;
1999
1.40k
  size_t amt = sizeof (coff_data_type);
2000
2001
1.40k
  abfd->tdata.coff_obj_data = bfd_zalloc (abfd, amt);
2002
1.40k
  if (abfd->tdata.coff_obj_data == NULL)
2003
0
    return false;
2004
2005
1.40k
  coff = coff_data (abfd);
2006
1.40k
  coff->symbols = NULL;
2007
1.40k
  coff->conversion_table = NULL;
2008
1.40k
  coff->raw_syments = NULL;
2009
1.40k
  coff->relocbase = 0;
2010
1.40k
  coff->local_toc_sym_map = 0;
2011
2012
1.40k
  bfd_coff_long_section_names (abfd)
2013
1.40k
    = coff_backend_info (abfd)->_bfd_coff_long_section_names;
2014
2015
/*  make_abs_section(abfd);*/
2016
2017
1.40k
  return true;
2018
1.40k
}
Unexecuted instantiation: coff-x86_64.c:coff_mkobject
cf-i386lynx.c:coff_mkobject
Line
Count
Source
1997
1.40k
{
1998
1.40k
  coff_data_type *coff;
1999
1.40k
  size_t amt = sizeof (coff_data_type);
2000
2001
1.40k
  abfd->tdata.coff_obj_data = bfd_zalloc (abfd, amt);
2002
1.40k
  if (abfd->tdata.coff_obj_data == NULL)
2003
0
    return false;
2004
2005
1.40k
  coff = coff_data (abfd);
2006
1.40k
  coff->symbols = NULL;
2007
1.40k
  coff->conversion_table = NULL;
2008
1.40k
  coff->raw_syments = NULL;
2009
1.40k
  coff->relocbase = 0;
2010
1.40k
  coff->local_toc_sym_map = 0;
2011
2012
1.40k
  bfd_coff_long_section_names (abfd)
2013
1.40k
    = coff_backend_info (abfd)->_bfd_coff_long_section_names;
2014
2015
/*  make_abs_section(abfd);*/
2016
2017
1.40k
  return true;
2018
1.40k
}
Unexecuted instantiation: coff-i386.c:coff_mkobject
Unexecuted instantiation: coff-sh.c:coff_mkobject
Unexecuted instantiation: coff-tic30.c:coff_mkobject
Unexecuted instantiation: coff-tic4x.c:coff_mkobject
Unexecuted instantiation: coff-tic54x.c:coff_mkobject
Unexecuted instantiation: coff-z80.c:coff_mkobject
Unexecuted instantiation: coff-z8k.c:coff_mkobject
2019
#endif
2020
2021
/* Create the COFF backend specific information.  */
2022
2023
#ifndef coff_mkobject_hook
2024
static void *
2025
coff_mkobject_hook (bfd * abfd,
2026
        void * filehdr,
2027
        void * aouthdr ATTRIBUTE_UNUSED)
2028
2.93k
{
2029
2.93k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
2.93k
  coff_data_type *coff;
2031
2032
2.93k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
2.93k
  coff = coff_data (abfd);
2036
2037
2.93k
  coff->sym_filepos = internal_f->f_symptr;
2038
2039
  /* These members communicate important constants about the symbol
2040
     table to GDB's symbol-reading code.  These `constants'
2041
     unfortunately vary among coff implementations...  */
2042
2.93k
  coff->local_n_btmask = N_BTMASK;
2043
2.93k
  coff->local_n_btshft = N_BTSHFT;
2044
2.93k
  coff->local_n_tmask = N_TMASK;
2045
2.93k
  coff->local_n_tshift = N_TSHIFT;
2046
2.93k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
2.93k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
2.93k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
2.93k
  coff->timestamp = internal_f->f_timdat;
2051
2052
2.93k
  obj_raw_syment_count (abfd) =
2053
2.93k
    obj_conv_table_size (abfd) =
2054
2.93k
      internal_f->f_nsyms;
2055
2056
#ifdef RS6000COFF_C
2057
0
  if ((internal_f->f_flags & F_SHROBJ) != 0)
2058
0
    abfd->flags |= DYNAMIC;
2059
0
  if (aouthdr != NULL && internal_f->f_opthdr >= bfd_coff_aoutsz (abfd))
2060
0
    {
2061
0
      struct internal_aouthdr *internal_a =
2062
0
  (struct internal_aouthdr *) aouthdr;
2063
0
      struct xcoff_tdata *xcoff;
2064
2065
0
      xcoff = xcoff_data (abfd);
2066
# ifdef U803XTOCMAGIC
2067
0
      xcoff->xcoff64 = internal_f->f_magic == U803XTOCMAGIC;
2068
# else
2069
      xcoff->xcoff64 = 0;
2070
# endif
2071
0
      xcoff->full_aouthdr = true;
2072
0
      xcoff->toc = internal_a->o_toc;
2073
0
      xcoff->sntoc = internal_a->o_sntoc;
2074
0
      xcoff->snentry = internal_a->o_snentry;
2075
0
      bfd_xcoff_text_align_power (abfd) = internal_a->o_algntext;
2076
0
      bfd_xcoff_data_align_power (abfd) = internal_a->o_algndata;
2077
0
      xcoff->modtype = internal_a->o_modtype;
2078
0
      xcoff->cputype = internal_a->o_cputype;
2079
0
      xcoff->maxdata = internal_a->o_maxdata;
2080
0
      xcoff->maxstack = internal_a->o_maxstack;
2081
0
    }
2082
#endif
2083
2084
#ifdef ARM
2085
  /* Set the flags field from the COFF header read in.  */
2086
  if (! _bfd_coff_arm_set_private_flags (abfd, internal_f->f_flags))
2087
    coff->flags = 0;
2088
#endif
2089
2090
#ifdef COFF_WITH_PE
2091
  /* FIXME: I'm not sure this is ever executed, since peicode.h
2092
     defines coff_mkobject_hook.  */
2093
  if ((internal_f->f_flags & IMAGE_FILE_DEBUG_STRIPPED) == 0)
2094
    abfd->flags |= HAS_DEBUG;
2095
#endif
2096
2097
2.93k
  return coff;
2098
2.93k
}
Unexecuted instantiation: coff-x86_64.c:coff_mkobject_hook
Unexecuted instantiation: coff64-rs6000.c:coff_mkobject_hook
cf-i386lynx.c:coff_mkobject_hook
Line
Count
Source
2028
1.40k
{
2029
1.40k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
1.40k
  coff_data_type *coff;
2031
2032
1.40k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
1.40k
  coff = coff_data (abfd);
2036
2037
1.40k
  coff->sym_filepos = internal_f->f_symptr;
2038
2039
  /* These members communicate important constants about the symbol
2040
     table to GDB's symbol-reading code.  These `constants'
2041
     unfortunately vary among coff implementations...  */
2042
1.40k
  coff->local_n_btmask = N_BTMASK;
2043
1.40k
  coff->local_n_btshft = N_BTSHFT;
2044
1.40k
  coff->local_n_tmask = N_TMASK;
2045
1.40k
  coff->local_n_tshift = N_TSHIFT;
2046
1.40k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
1.40k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
1.40k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
1.40k
  coff->timestamp = internal_f->f_timdat;
2051
2052
1.40k
  obj_raw_syment_count (abfd) =
2053
1.40k
    obj_conv_table_size (abfd) =
2054
1.40k
      internal_f->f_nsyms;
2055
2056
#ifdef RS6000COFF_C
2057
  if ((internal_f->f_flags & F_SHROBJ) != 0)
2058
    abfd->flags |= DYNAMIC;
2059
  if (aouthdr != NULL && internal_f->f_opthdr >= bfd_coff_aoutsz (abfd))
2060
    {
2061
      struct internal_aouthdr *internal_a =
2062
  (struct internal_aouthdr *) aouthdr;
2063
      struct xcoff_tdata *xcoff;
2064
2065
      xcoff = xcoff_data (abfd);
2066
# ifdef U803XTOCMAGIC
2067
      xcoff->xcoff64 = internal_f->f_magic == U803XTOCMAGIC;
2068
# else
2069
      xcoff->xcoff64 = 0;
2070
# endif
2071
      xcoff->full_aouthdr = true;
2072
      xcoff->toc = internal_a->o_toc;
2073
      xcoff->sntoc = internal_a->o_sntoc;
2074
      xcoff->snentry = internal_a->o_snentry;
2075
      bfd_xcoff_text_align_power (abfd) = internal_a->o_algntext;
2076
      bfd_xcoff_data_align_power (abfd) = internal_a->o_algndata;
2077
      xcoff->modtype = internal_a->o_modtype;
2078
      xcoff->cputype = internal_a->o_cputype;
2079
      xcoff->maxdata = internal_a->o_maxdata;
2080
      xcoff->maxstack = internal_a->o_maxstack;
2081
    }
2082
#endif
2083
2084
#ifdef ARM
2085
  /* Set the flags field from the COFF header read in.  */
2086
  if (! _bfd_coff_arm_set_private_flags (abfd, internal_f->f_flags))
2087
    coff->flags = 0;
2088
#endif
2089
2090
#ifdef COFF_WITH_PE
2091
  /* FIXME: I'm not sure this is ever executed, since peicode.h
2092
     defines coff_mkobject_hook.  */
2093
  if ((internal_f->f_flags & IMAGE_FILE_DEBUG_STRIPPED) == 0)
2094
    abfd->flags |= HAS_DEBUG;
2095
#endif
2096
2097
1.40k
  return coff;
2098
1.40k
}
Unexecuted instantiation: coff-go32.c:coff_mkobject_hook
Unexecuted instantiation: coff-i386.c:coff_mkobject_hook
Unexecuted instantiation: coff-rs6000.c:coff_mkobject_hook
Unexecuted instantiation: coff-sh.c:coff_mkobject_hook
coff-stgo32.c:coff_mkobject_hook
Line
Count
Source
2028
1.53k
{
2029
1.53k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
1.53k
  coff_data_type *coff;
2031
2032
1.53k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
1.53k
  coff = coff_data (abfd);
2036
2037
1.53k
  coff->sym_filepos = internal_f->f_symptr;
2038
2039
  /* These members communicate important constants about the symbol
2040
     table to GDB's symbol-reading code.  These `constants'
2041
     unfortunately vary among coff implementations...  */
2042
1.53k
  coff->local_n_btmask = N_BTMASK;
2043
1.53k
  coff->local_n_btshft = N_BTSHFT;
2044
1.53k
  coff->local_n_tmask = N_TMASK;
2045
1.53k
  coff->local_n_tshift = N_TSHIFT;
2046
1.53k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
1.53k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
1.53k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
1.53k
  coff->timestamp = internal_f->f_timdat;
2051
2052
1.53k
  obj_raw_syment_count (abfd) =
2053
1.53k
    obj_conv_table_size (abfd) =
2054
1.53k
      internal_f->f_nsyms;
2055
2056
#ifdef RS6000COFF_C
2057
  if ((internal_f->f_flags & F_SHROBJ) != 0)
2058
    abfd->flags |= DYNAMIC;
2059
  if (aouthdr != NULL && internal_f->f_opthdr >= bfd_coff_aoutsz (abfd))
2060
    {
2061
      struct internal_aouthdr *internal_a =
2062
  (struct internal_aouthdr *) aouthdr;
2063
      struct xcoff_tdata *xcoff;
2064
2065
      xcoff = xcoff_data (abfd);
2066
# ifdef U803XTOCMAGIC
2067
      xcoff->xcoff64 = internal_f->f_magic == U803XTOCMAGIC;
2068
# else
2069
      xcoff->xcoff64 = 0;
2070
# endif
2071
      xcoff->full_aouthdr = true;
2072
      xcoff->toc = internal_a->o_toc;
2073
      xcoff->sntoc = internal_a->o_sntoc;
2074
      xcoff->snentry = internal_a->o_snentry;
2075
      bfd_xcoff_text_align_power (abfd) = internal_a->o_algntext;
2076
      bfd_xcoff_data_align_power (abfd) = internal_a->o_algndata;
2077
      xcoff->modtype = internal_a->o_modtype;
2078
      xcoff->cputype = internal_a->o_cputype;
2079
      xcoff->maxdata = internal_a->o_maxdata;
2080
      xcoff->maxstack = internal_a->o_maxstack;
2081
    }
2082
#endif
2083
2084
#ifdef ARM
2085
  /* Set the flags field from the COFF header read in.  */
2086
  if (! _bfd_coff_arm_set_private_flags (abfd, internal_f->f_flags))
2087
    coff->flags = 0;
2088
#endif
2089
2090
#ifdef COFF_WITH_PE
2091
  /* FIXME: I'm not sure this is ever executed, since peicode.h
2092
     defines coff_mkobject_hook.  */
2093
  if ((internal_f->f_flags & IMAGE_FILE_DEBUG_STRIPPED) == 0)
2094
    abfd->flags |= HAS_DEBUG;
2095
#endif
2096
2097
1.53k
  return coff;
2098
1.53k
}
Unexecuted instantiation: coff-tic30.c:coff_mkobject_hook
Unexecuted instantiation: coff-tic4x.c:coff_mkobject_hook
Unexecuted instantiation: coff-tic54x.c:coff_mkobject_hook
Unexecuted instantiation: coff-z80.c:coff_mkobject_hook
Unexecuted instantiation: coff-z8k.c:coff_mkobject_hook
2099
#endif
2100
2101
/* Determine the machine architecture and type.  FIXME: This is target
2102
   dependent because the magic numbers are defined in the target
2103
   dependent header files.  But there is no particular need for this.
2104
   If the magic numbers were moved to a separate file, this function
2105
   would be target independent and would also be much more successful
2106
   at linking together COFF files for different architectures.  */
2107
2108
static bool
2109
coff_set_arch_mach_hook (bfd *abfd, void * filehdr)
2110
13.0k
{
2111
13.0k
  unsigned long machine;
2112
13.0k
  enum bfd_architecture arch;
2113
13.0k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
13.0k
  machine = 0;
2117
13.0k
  switch (internal_f->f_magic)
2118
13.0k
    {
2119
#ifdef I386MAGIC
2120
2.43k
    case I386MAGIC:
2121
3.59k
    case I386PTXMAGIC:
2122
4.07k
    case I386AIXMAGIC:   /* Danbury PS/2 AIX C Compiler.  */
2123
4.27k
    case LYNXCOFFMAGIC:
2124
4.28k
    case I386_APPLE_MAGIC:
2125
4.30k
    case I386_FREEBSD_MAGIC:
2126
4.31k
    case I386_LINUX_MAGIC:
2127
5.42k
    case I386_NETBSD_MAGIC:
2128
5.42k
      arch = bfd_arch_i386;
2129
5.42k
      break;
2130
0
#endif
2131
#ifdef AMD64MAGIC
2132
1.20k
    case AMD64MAGIC:
2133
1.21k
    case AMD64_APPLE_MAGIC:
2134
1.21k
    case AMD64_FREEBSD_MAGIC:
2135
1.21k
    case AMD64_LINUX_MAGIC:
2136
1.23k
    case AMD64_NETBSD_MAGIC:
2137
1.23k
      arch = bfd_arch_i386;
2138
1.23k
      machine = bfd_mach_x86_64;
2139
1.23k
      break;
2140
0
#endif
2141
#ifdef IA64MAGIC
2142
842
    case IA64MAGIC:
2143
842
      arch = bfd_arch_ia64;
2144
842
      break;
2145
0
#endif
2146
#ifdef ARMMAGIC
2147
1.75k
    case ARMMAGIC:
2148
1.92k
    case ARMPEMAGIC:
2149
2.01k
    case THUMBPEMAGIC:
2150
2.01k
      arch = bfd_arch_arm;
2151
2.01k
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
2.01k
      if (machine == bfd_mach_arm_unknown)
2153
2.01k
  {
2154
2.01k
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
2.01k
      {
2156
105
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
140
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
112
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
856
      default:
2160
1.17k
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
206
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
133
      case F_ARM_4T: machine = bfd_mach_arm_4T; break;
2163
        /* The COFF header does not have enough bits available
2164
     to cover all the different ARM architectures.  So
2165
     we interpret F_ARM_5, the highest flag value to mean
2166
     "the highest ARM architecture known to BFD" which is
2167
     currently the XScale.  */
2168
149
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
2.01k
      }
2170
2.01k
  }
2171
2.01k
      break;
2172
2.01k
#endif
2173
#ifdef AARCH64MAGIC
2174
874
    case AARCH64MAGIC:
2175
874
      arch = bfd_arch_aarch64;
2176
874
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
874
      break;
2178
0
#endif
2179
#ifdef LOONGARCH64MAGIC
2180
824
    case LOONGARCH64MAGIC:
2181
824
      arch = bfd_arch_loongarch;
2182
824
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
824
      break;
2184
0
#endif
2185
#ifdef Z80MAGIC
2186
0
    case Z80MAGIC:
2187
0
      arch = bfd_arch_z80;
2188
0
      switch (internal_f->f_flags & F_MACHMASK)
2189
0
  {
2190
0
  case bfd_mach_z80strict << 12:
2191
0
  case bfd_mach_z80 << 12:
2192
0
  case bfd_mach_z80n << 12:
2193
0
  case bfd_mach_z80full << 12:
2194
0
  case bfd_mach_r800 << 12:
2195
0
  case bfd_mach_gbz80 << 12:
2196
0
  case bfd_mach_z180 << 12:
2197
0
  case bfd_mach_ez80_z80 << 12:
2198
0
  case bfd_mach_ez80_adl << 12:
2199
0
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
0
    break;
2201
0
  default:
2202
0
    return false;
2203
0
  }
2204
0
      break;
2205
0
#endif
2206
#ifdef Z8KMAGIC
2207
0
    case Z8KMAGIC:
2208
0
      arch = bfd_arch_z8k;
2209
0
      switch (internal_f->f_flags & F_MACHMASK)
2210
0
  {
2211
0
  case F_Z8001:
2212
0
    machine = bfd_mach_z8001;
2213
0
    break;
2214
0
  case F_Z8002:
2215
0
    machine = bfd_mach_z8002;
2216
0
    break;
2217
0
  default:
2218
0
    return false;
2219
0
  }
2220
0
      break;
2221
0
#endif
2222
2223
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
0
    case U64_TOCMAGIC:
2226
0
    case U803XTOCMAGIC:
2227
#else
2228
0
    case U802ROMAGIC:
2229
0
    case U802WRMAGIC:
2230
0
    case U802TOCMAGIC:
2231
#endif
2232
0
      {
2233
0
  int cputype;
2234
2235
0
  if (xcoff_data (abfd)->cputype != -1)
2236
0
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
0
  else
2238
0
    {
2239
      /* We did not get a value from the a.out header.  If the
2240
         file has not been stripped, we may be able to get the
2241
         architecture information from the first symbol, if it
2242
         is a .file symbol.  */
2243
0
      if (obj_raw_syment_count (abfd) == 0)
2244
0
        cputype = 0;
2245
0
      else
2246
0
        {
2247
0
    bfd_byte *buf;
2248
0
    struct internal_syment sym;
2249
0
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
0
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
0
      return false;
2253
0
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
0
    if (buf == NULL)
2255
0
      return false;
2256
0
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
0
    if (sym.n_sclass == C_FILE)
2258
0
      cputype = sym.n_type & 0xff;
2259
0
    else
2260
0
      cputype = 0;
2261
0
    free (buf);
2262
0
        }
2263
0
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
0
  switch (cputype)
2267
0
    {
2268
0
    default:
2269
0
    case 0:
2270
0
      arch = bfd_xcoff_architecture (abfd);
2271
0
      machine = bfd_xcoff_machine (abfd);
2272
0
      break;
2273
2274
0
    case 1:
2275
0
      arch = bfd_arch_powerpc;
2276
0
      machine = bfd_mach_ppc_601;
2277
0
      break;
2278
0
    case 2: /* 64 bit PowerPC */
2279
0
      arch = bfd_arch_powerpc;
2280
0
      machine = bfd_mach_ppc_620;
2281
0
      break;
2282
0
    case 3:
2283
0
      arch = bfd_arch_powerpc;
2284
0
      machine = bfd_mach_ppc;
2285
0
      break;
2286
0
    case 4:
2287
0
      arch = bfd_arch_rs6000;
2288
0
      machine = bfd_mach_rs6k;
2289
0
      break;
2290
0
    }
2291
0
      }
2292
0
      break;
2293
0
#endif
2294
2295
#ifdef SH_ARCH_MAGIC_BIG
2296
647
    case SH_ARCH_MAGIC_BIG:
2297
650
    case SH_ARCH_MAGIC_LITTLE:
2298
#ifdef COFF_WITH_PE
2299
774
    case SH_ARCH_MAGIC_WINCE:
2300
#endif
2301
774
      arch = bfd_arch_sh;
2302
774
      break;
2303
0
#endif
2304
2305
#ifdef MIPS_ARCH_MAGIC_WINCE
2306
    case MIPS_ARCH_MAGIC_WINCE:
2307
      arch = bfd_arch_mips;
2308
      break;
2309
#endif
2310
2311
#ifdef SPARCMAGIC
2312
    case SPARCMAGIC:
2313
#ifdef LYNXCOFFMAGIC
2314
    case LYNXCOFFMAGIC:
2315
#endif
2316
      arch = bfd_arch_sparc;
2317
      break;
2318
#endif
2319
2320
#ifdef TIC30MAGIC
2321
0
    case TIC30MAGIC:
2322
0
      arch = bfd_arch_tic30;
2323
0
      break;
2324
0
#endif
2325
2326
#ifdef TICOFF0MAGIC
2327
#ifdef TICOFF_TARGET_ARCH
2328
      /* This TI COFF section should be used by all new TI COFF v0 targets.  */
2329
0
    case TICOFF0MAGIC:
2330
0
      arch = TICOFF_TARGET_ARCH;
2331
0
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
0
      break;
2333
0
#endif
2334
0
#endif
2335
2336
#ifdef TICOFF1MAGIC
2337
      /* This TI COFF section should be used by all new TI COFF v1/2 targets.  */
2338
      /* TI COFF1 and COFF2 use the target_id field to specify which arch.  */
2339
0
    case TICOFF1MAGIC:
2340
0
    case TICOFF2MAGIC:
2341
0
      switch (internal_f->f_target_id)
2342
0
  {
2343
0
#ifdef TI_TARGET_ID
2344
0
  case TI_TARGET_ID:
2345
0
    arch = TICOFF_TARGET_ARCH;
2346
0
    machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2347
0
    break;
2348
0
#endif
2349
0
  default:
2350
0
    arch = bfd_arch_obscure;
2351
0
    _bfd_error_handler
2352
0
      (_("unrecognized TI COFF target id '0x%x'"),
2353
0
       internal_f->f_target_id);
2354
0
    break;
2355
0
  }
2356
0
      break;
2357
0
#endif
2358
2359
#ifdef MCOREMAGIC
2360
792
    case MCOREMAGIC:
2361
792
      arch = bfd_arch_mcore;
2362
792
      break;
2363
0
#endif
2364
2365
222
    default:      /* Unreadable input file type.  */
2366
222
      arch = bfd_arch_obscure;
2367
222
      break;
2368
13.0k
    }
2369
2370
13.0k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
13.0k
  return true;
2372
13.0k
}
pei-i386.c:coff_set_arch_mach_hook
Line
Count
Source
2110
1.11k
{
2111
1.11k
  unsigned long machine;
2112
1.11k
  enum bfd_architecture arch;
2113
1.11k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
1.11k
  machine = 0;
2117
1.11k
  switch (internal_f->f_magic)
2118
1.11k
    {
2119
0
#ifdef I386MAGIC
2120
79
    case I386MAGIC:
2121
676
    case I386PTXMAGIC:
2122
725
    case I386AIXMAGIC:   /* Danbury PS/2 AIX C Compiler.  */
2123
890
    case LYNXCOFFMAGIC:
2124
893
    case I386_APPLE_MAGIC:
2125
896
    case I386_FREEBSD_MAGIC:
2126
899
    case I386_LINUX_MAGIC:
2127
1.11k
    case I386_NETBSD_MAGIC:
2128
1.11k
      arch = bfd_arch_i386;
2129
1.11k
      break;
2130
0
#endif
2131
#ifdef AMD64MAGIC
2132
    case AMD64MAGIC:
2133
    case AMD64_APPLE_MAGIC:
2134
    case AMD64_FREEBSD_MAGIC:
2135
    case AMD64_LINUX_MAGIC:
2136
    case AMD64_NETBSD_MAGIC:
2137
      arch = bfd_arch_i386;
2138
      machine = bfd_mach_x86_64;
2139
      break;
2140
#endif
2141
#ifdef IA64MAGIC
2142
    case IA64MAGIC:
2143
      arch = bfd_arch_ia64;
2144
      break;
2145
#endif
2146
#ifdef ARMMAGIC
2147
    case ARMMAGIC:
2148
    case ARMPEMAGIC:
2149
    case THUMBPEMAGIC:
2150
      arch = bfd_arch_arm;
2151
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
      if (machine == bfd_mach_arm_unknown)
2153
  {
2154
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
      {
2156
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
      default:
2160
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
      case F_ARM_4T: machine = bfd_mach_arm_4T; break;
2163
        /* The COFF header does not have enough bits available
2164
     to cover all the different ARM architectures.  So
2165
     we interpret F_ARM_5, the highest flag value to mean
2166
     "the highest ARM architecture known to BFD" which is
2167
     currently the XScale.  */
2168
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
      }
2170
  }
2171
      break;
2172
#endif
2173
#ifdef AARCH64MAGIC
2174
    case AARCH64MAGIC:
2175
      arch = bfd_arch_aarch64;
2176
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
      break;
2178
#endif
2179
#ifdef LOONGARCH64MAGIC
2180
    case LOONGARCH64MAGIC:
2181
      arch = bfd_arch_loongarch;
2182
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
      break;
2184
#endif
2185
#ifdef Z80MAGIC
2186
    case Z80MAGIC:
2187
      arch = bfd_arch_z80;
2188
      switch (internal_f->f_flags & F_MACHMASK)
2189
  {
2190
  case bfd_mach_z80strict << 12:
2191
  case bfd_mach_z80 << 12:
2192
  case bfd_mach_z80n << 12:
2193
  case bfd_mach_z80full << 12:
2194
  case bfd_mach_r800 << 12:
2195
  case bfd_mach_gbz80 << 12:
2196
  case bfd_mach_z180 << 12:
2197
  case bfd_mach_ez80_z80 << 12:
2198
  case bfd_mach_ez80_adl << 12:
2199
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
    break;
2201
  default:
2202
    return false;
2203
  }
2204
      break;
2205
#endif
2206
#ifdef Z8KMAGIC
2207
    case Z8KMAGIC:
2208
      arch = bfd_arch_z8k;
2209
      switch (internal_f->f_flags & F_MACHMASK)
2210
  {
2211
  case F_Z8001:
2212
    machine = bfd_mach_z8001;
2213
    break;
2214
  case F_Z8002:
2215
    machine = bfd_mach_z8002;
2216
    break;
2217
  default:
2218
    return false;
2219
  }
2220
      break;
2221
#endif
2222
2223
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
    case U64_TOCMAGIC:
2226
    case U803XTOCMAGIC:
2227
#else
2228
    case U802ROMAGIC:
2229
    case U802WRMAGIC:
2230
    case U802TOCMAGIC:
2231
#endif
2232
      {
2233
  int cputype;
2234
2235
  if (xcoff_data (abfd)->cputype != -1)
2236
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
  else
2238
    {
2239
      /* We did not get a value from the a.out header.  If the
2240
         file has not been stripped, we may be able to get the
2241
         architecture information from the first symbol, if it
2242
         is a .file symbol.  */
2243
      if (obj_raw_syment_count (abfd) == 0)
2244
        cputype = 0;
2245
      else
2246
        {
2247
    bfd_byte *buf;
2248
    struct internal_syment sym;
2249
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
      return false;
2253
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
    if (buf == NULL)
2255
      return false;
2256
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
    if (sym.n_sclass == C_FILE)
2258
      cputype = sym.n_type & 0xff;
2259
    else
2260
      cputype = 0;
2261
    free (buf);
2262
        }
2263
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
  switch (cputype)
2267
    {
2268
    default:
2269
    case 0:
2270
      arch = bfd_xcoff_architecture (abfd);
2271
      machine = bfd_xcoff_machine (abfd);
2272
      break;
2273
2274
    case 1:
2275
      arch = bfd_arch_powerpc;
2276
      machine = bfd_mach_ppc_601;
2277
      break;
2278
    case 2: /* 64 bit PowerPC */
2279
      arch = bfd_arch_powerpc;
2280
      machine = bfd_mach_ppc_620;
2281
      break;
2282
    case 3:
2283
      arch = bfd_arch_powerpc;
2284
      machine = bfd_mach_ppc;
2285
      break;
2286
    case 4:
2287
      arch = bfd_arch_rs6000;
2288
      machine = bfd_mach_rs6k;
2289
      break;
2290
    }
2291
      }
2292
      break;
2293
#endif
2294
2295
#ifdef SH_ARCH_MAGIC_BIG
2296
    case SH_ARCH_MAGIC_BIG:
2297
    case SH_ARCH_MAGIC_LITTLE:
2298
#ifdef COFF_WITH_PE
2299
    case SH_ARCH_MAGIC_WINCE:
2300
#endif
2301
      arch = bfd_arch_sh;
2302
      break;
2303
#endif
2304
2305
#ifdef MIPS_ARCH_MAGIC_WINCE
2306
    case MIPS_ARCH_MAGIC_WINCE:
2307
      arch = bfd_arch_mips;
2308
      break;
2309
#endif
2310
2311
#ifdef SPARCMAGIC
2312
    case SPARCMAGIC:
2313
#ifdef LYNXCOFFMAGIC
2314
    case LYNXCOFFMAGIC:
2315
#endif
2316
      arch = bfd_arch_sparc;
2317
      break;
2318
#endif
2319
2320
#ifdef TIC30MAGIC
2321
    case TIC30MAGIC:
2322
      arch = bfd_arch_tic30;
2323
      break;
2324
#endif
2325
2326
#ifdef TICOFF0MAGIC
2327
#ifdef TICOFF_TARGET_ARCH
2328
      /* This TI COFF section should be used by all new TI COFF v0 targets.  */
2329
    case TICOFF0MAGIC:
2330
      arch = TICOFF_TARGET_ARCH;
2331
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
      break;
2333
#endif
2334
#endif
2335
2336
#ifdef TICOFF1MAGIC
2337
      /* This TI COFF section should be used by all new TI COFF v1/2 targets.  */
2338
      /* TI COFF1 and COFF2 use the target_id field to specify which arch.  */
2339
    case TICOFF1MAGIC:
2340
    case TICOFF2MAGIC:
2341
      switch (internal_f->f_target_id)
2342
  {
2343
#ifdef TI_TARGET_ID
2344
  case TI_TARGET_ID:
2345
    arch = TICOFF_TARGET_ARCH;
2346
    machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2347
    break;
2348
#endif
2349
  default:
2350
    arch = bfd_arch_obscure;
2351
    _bfd_error_handler
2352
      (_("unrecognized TI COFF target id '0x%x'"),
2353
       internal_f->f_target_id);
2354
    break;
2355
  }
2356
      break;
2357
#endif
2358
2359
#ifdef MCOREMAGIC
2360
    case MCOREMAGIC:
2361
      arch = bfd_arch_mcore;
2362
      break;
2363
#endif
2364
2365
0
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
1.11k
    }
2369
2370
1.11k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
1.11k
  return true;
2372
1.11k
}
Unexecuted instantiation: pe-x86_64.c:coff_set_arch_mach_hook
pei-x86_64.c:coff_set_arch_mach_hook
Line
Count
Source
2110
1.23k
{
2111
1.23k
  unsigned long machine;
2112
1.23k
  enum bfd_architecture arch;
2113
1.23k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
1.23k
  machine = 0;
2117
1.23k
  switch (internal_f->f_magic)
2118
1.23k
    {
2119
#ifdef I386MAGIC
2120
    case I386MAGIC:
2121
    case I386PTXMAGIC:
2122
    case I386AIXMAGIC:    /* Danbury PS/2 AIX C Compiler.  */
2123
    case LYNXCOFFMAGIC:
2124
    case I386_APPLE_MAGIC:
2125
    case I386_FREEBSD_MAGIC:
2126
    case I386_LINUX_MAGIC:
2127
    case I386_NETBSD_MAGIC:
2128
      arch = bfd_arch_i386;
2129
      break;
2130
#endif
2131
0
#ifdef AMD64MAGIC
2132
1.20k
    case AMD64MAGIC:
2133
1.21k
    case AMD64_APPLE_MAGIC:
2134
1.21k
    case AMD64_FREEBSD_MAGIC:
2135
1.21k
    case AMD64_LINUX_MAGIC:
2136
1.23k
    case AMD64_NETBSD_MAGIC:
2137
1.23k
      arch = bfd_arch_i386;
2138
1.23k
      machine = bfd_mach_x86_64;
2139
1.23k
      break;
2140
0
#endif
2141
#ifdef IA64MAGIC
2142
    case IA64MAGIC:
2143
      arch = bfd_arch_ia64;
2144
      break;
2145
#endif
2146
#ifdef ARMMAGIC
2147
    case ARMMAGIC:
2148
    case ARMPEMAGIC:
2149
    case THUMBPEMAGIC:
2150
      arch = bfd_arch_arm;
2151
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
      if (machine == bfd_mach_arm_unknown)
2153
  {
2154
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
      {
2156
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
      default:
2160
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
      case F_ARM_4T: machine = bfd_mach_arm_4T; break;
2163
        /* The COFF header does not have enough bits available
2164
     to cover all the different ARM architectures.  So
2165
     we interpret F_ARM_5, the highest flag value to mean
2166
     "the highest ARM architecture known to BFD" which is
2167
     currently the XScale.  */
2168
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
      }
2170
  }
2171
      break;
2172
#endif
2173
#ifdef AARCH64MAGIC
2174
    case AARCH64MAGIC:
2175
      arch = bfd_arch_aarch64;
2176
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
      break;
2178
#endif
2179
#ifdef LOONGARCH64MAGIC
2180
    case LOONGARCH64MAGIC:
2181
      arch = bfd_arch_loongarch;
2182
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
      break;
2184
#endif
2185
#ifdef Z80MAGIC
2186
    case Z80MAGIC:
2187
      arch = bfd_arch_z80;
2188
      switch (internal_f->f_flags & F_MACHMASK)
2189
  {
2190
  case bfd_mach_z80strict << 12:
2191
  case bfd_mach_z80 << 12:
2192
  case bfd_mach_z80n << 12:
2193
  case bfd_mach_z80full << 12:
2194
  case bfd_mach_r800 << 12:
2195
  case bfd_mach_gbz80 << 12:
2196
  case bfd_mach_z180 << 12:
2197
  case bfd_mach_ez80_z80 << 12:
2198
  case bfd_mach_ez80_adl << 12:
2199
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
    break;
2201
  default:
2202
    return false;
2203
  }
2204
      break;
2205
#endif
2206
#ifdef Z8KMAGIC
2207
    case Z8KMAGIC:
2208
      arch = bfd_arch_z8k;
2209
      switch (internal_f->f_flags & F_MACHMASK)
2210
  {
2211
  case F_Z8001:
2212
    machine = bfd_mach_z8001;
2213
    break;
2214
  case F_Z8002:
2215
    machine = bfd_mach_z8002;
2216
    break;
2217
  default:
2218
    return false;
2219
  }
2220
      break;
2221
#endif
2222
2223
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
    case U64_TOCMAGIC:
2226
    case U803XTOCMAGIC:
2227
#else
2228
    case U802ROMAGIC:
2229
    case U802WRMAGIC:
2230
    case U802TOCMAGIC:
2231
#endif
2232
      {
2233
  int cputype;
2234
2235
  if (xcoff_data (abfd)->cputype != -1)
2236
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
  else
2238
    {
2239
      /* We did not get a value from the a.out header.  If the
2240
         file has not been stripped, we may be able to get the
2241
         architecture information from the first symbol, if it
2242
         is a .file symbol.  */
2243
      if (obj_raw_syment_count (abfd) == 0)
2244
        cputype = 0;
2245
      else
2246
        {
2247
    bfd_byte *buf;
2248
    struct internal_syment sym;
2249
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
      return false;
2253
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
    if (buf == NULL)
2255
      return false;
2256
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
    if (sym.n_sclass == C_FILE)
2258
      cputype = sym.n_type & 0xff;
2259
    else
2260
      cputype = 0;
2261
    free (buf);
2262
        }
2263
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
  switch (cputype)
2267
    {
2268
    default:
2269
    case 0:
2270
      arch = bfd_xcoff_architecture (abfd);
2271
      machine = bfd_xcoff_machine (abfd);
2272
      break;
2273
2274
    case 1:
2275
      arch = bfd_arch_powerpc;
2276
      machine = bfd_mach_ppc_601;
2277
      break;
2278
    case 2: /* 64 bit PowerPC */
2279
      arch = bfd_arch_powerpc;
2280
      machine = bfd_mach_ppc_620;
2281
      break;
2282
    case 3:
2283
      arch = bfd_arch_powerpc;
2284
      machine = bfd_mach_ppc;
2285
      break;
2286
    case 4:
2287
      arch = bfd_arch_rs6000;
2288
      machine = bfd_mach_rs6k;
2289
      break;
2290
    }
2291
      }
2292
      break;
2293
#endif
2294
2295
#ifdef SH_ARCH_MAGIC_BIG
2296
    case SH_ARCH_MAGIC_BIG:
2297
    case SH_ARCH_MAGIC_LITTLE:
2298
#ifdef COFF_WITH_PE
2299
    case SH_ARCH_MAGIC_WINCE:
2300
#endif
2301
      arch = bfd_arch_sh;
2302
      break;
2303
#endif
2304
2305
#ifdef MIPS_ARCH_MAGIC_WINCE
2306
    case MIPS_ARCH_MAGIC_WINCE:
2307
      arch = bfd_arch_mips;
2308
      break;
2309
#endif
2310
2311
#ifdef SPARCMAGIC
2312
    case SPARCMAGIC:
2313
#ifdef LYNXCOFFMAGIC
2314
    case LYNXCOFFMAGIC:
2315
#endif
2316
      arch = bfd_arch_sparc;
2317
      break;
2318
#endif
2319
2320
#ifdef TIC30MAGIC
2321
    case TIC30MAGIC:
2322
      arch = bfd_arch_tic30;
2323
      break;
2324
#endif
2325
2326
#ifdef TICOFF0MAGIC
2327
#ifdef TICOFF_TARGET_ARCH
2328
      /* This TI COFF section should be used by all new TI COFF v0 targets.  */
2329
    case TICOFF0MAGIC:
2330
      arch = TICOFF_TARGET_ARCH;
2331
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
      break;
2333
#endif
2334
#endif
2335
2336
#ifdef TICOFF1MAGIC
2337
      /* This TI COFF section should be used by all new TI COFF v1/2 targets.  */
2338
      /* TI COFF1 and COFF2 use the target_id field to specify which arch.  */
2339
    case TICOFF1MAGIC:
2340
    case TICOFF2MAGIC:
2341
      switch (internal_f->f_target_id)
2342
  {
2343
#ifdef TI_TARGET_ID
2344
  case TI_TARGET_ID:
2345
    arch = TICOFF_TARGET_ARCH;
2346
    machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2347
    break;
2348
#endif
2349
  default:
2350
    arch = bfd_arch_obscure;
2351
    _bfd_error_handler
2352
      (_("unrecognized TI COFF target id '0x%x'"),
2353
       internal_f->f_target_id);
2354
    break;
2355
  }
2356
      break;
2357
#endif
2358
2359
#ifdef MCOREMAGIC
2360
    case MCOREMAGIC:
2361
      arch = bfd_arch_mcore;
2362
      break;
2363
#endif
2364
2365
0
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
1.23k
    }
2369
2370
1.23k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
1.23k
  return true;
2372
1.23k
}
Unexecuted instantiation: coff-x86_64.c:coff_set_arch_mach_hook
Unexecuted instantiation: coff64-rs6000.c:coff_set_arch_mach_hook
pei-aarch64.c:coff_set_arch_mach_hook
Line
Count
Source
2110
874
{
2111
874
  unsigned long machine;
2112
874
  enum bfd_architecture arch;
2113
874
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
874
  machine = 0;
2117
874
  switch (internal_f->f_magic)
2118
874
    {
2119
#ifdef I386MAGIC
2120
    case I386MAGIC:
2121
    case I386PTXMAGIC:
2122
    case I386AIXMAGIC:    /* Danbury PS/2 AIX C Compiler.  */
2123
    case LYNXCOFFMAGIC:
2124
    case I386_APPLE_MAGIC:
2125
    case I386_FREEBSD_MAGIC:
2126
    case I386_LINUX_MAGIC:
2127
    case I386_NETBSD_MAGIC:
2128
      arch = bfd_arch_i386;
2129
      break;
2130
#endif
2131
#ifdef AMD64MAGIC
2132
    case AMD64MAGIC:
2133
    case AMD64_APPLE_MAGIC:
2134
    case AMD64_FREEBSD_MAGIC:
2135
    case AMD64_LINUX_MAGIC:
2136
    case AMD64_NETBSD_MAGIC:
2137
      arch = bfd_arch_i386;
2138
      machine = bfd_mach_x86_64;
2139
      break;
2140
#endif
2141
#ifdef IA64MAGIC
2142
    case IA64MAGIC:
2143
      arch = bfd_arch_ia64;
2144
      break;
2145
#endif
2146
#ifdef ARMMAGIC
2147
    case ARMMAGIC:
2148
    case ARMPEMAGIC:
2149
    case THUMBPEMAGIC:
2150
      arch = bfd_arch_arm;
2151
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
      if (machine == bfd_mach_arm_unknown)
2153
  {
2154
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
      {
2156
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
      default:
2160
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
      case F_ARM_4T: machine = bfd_mach_arm_4T; break;
2163
        /* The COFF header does not have enough bits available
2164
     to cover all the different ARM architectures.  So
2165
     we interpret F_ARM_5, the highest flag value to mean
2166
     "the highest ARM architecture known to BFD" which is
2167
     currently the XScale.  */
2168
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
      }
2170
  }
2171
      break;
2172
#endif
2173
0
#ifdef AARCH64MAGIC
2174
874
    case AARCH64MAGIC:
2175
874
      arch = bfd_arch_aarch64;
2176
874
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
874
      break;
2178
0
#endif
2179
#ifdef LOONGARCH64MAGIC
2180
    case LOONGARCH64MAGIC:
2181
      arch = bfd_arch_loongarch;
2182
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
      break;
2184
#endif
2185
#ifdef Z80MAGIC
2186
    case Z80MAGIC:
2187
      arch = bfd_arch_z80;
2188
      switch (internal_f->f_flags & F_MACHMASK)
2189
  {
2190
  case bfd_mach_z80strict << 12:
2191
  case bfd_mach_z80 << 12:
2192
  case bfd_mach_z80n << 12:
2193
  case bfd_mach_z80full << 12:
2194
  case bfd_mach_r800 << 12:
2195
  case bfd_mach_gbz80 << 12:
2196
  case bfd_mach_z180 << 12:
2197
  case bfd_mach_ez80_z80 << 12:
2198
  case bfd_mach_ez80_adl << 12:
2199
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
    break;
2201
  default:
2202
    return false;
2203
  }
2204
      break;
2205
#endif
2206
#ifdef Z8KMAGIC
2207
    case Z8KMAGIC:
2208
      arch = bfd_arch_z8k;
2209
      switch (internal_f->f_flags & F_MACHMASK)
2210
  {
2211
  case F_Z8001:
2212
    machine = bfd_mach_z8001;
2213
    break;
2214
  case F_Z8002:
2215
    machine = bfd_mach_z8002;
2216
    break;
2217
  default:
2218
    return false;
2219
  }
2220
      break;
2221
#endif
2222
2223
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
    case U64_TOCMAGIC:
2226
    case U803XTOCMAGIC:
2227
#else
2228
    case U802ROMAGIC:
2229
    case U802WRMAGIC:
2230
    case U802TOCMAGIC:
2231
#endif
2232
      {
2233
  int cputype;
2234
2235
  if (xcoff_data (abfd)->cputype != -1)
2236
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
  else
2238
    {
2239
      /* We did not get a value from the a.out header.  If the
2240
         file has not been stripped, we may be able to get the
2241
         architecture information from the first symbol, if it
2242
         is a .file symbol.  */
2243
      if (obj_raw_syment_count (abfd) == 0)
2244
        cputype = 0;
2245
      else
2246
        {
2247
    bfd_byte *buf;
2248
    struct internal_syment sym;
2249
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
      return false;
2253
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
    if (buf == NULL)
2255
      return false;
2256
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
    if (sym.n_sclass == C_FILE)
2258
      cputype = sym.n_type & 0xff;
2259
    else
2260
      cputype = 0;
2261
    free (buf);
2262
        }
2263
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
  switch (cputype)
2267
    {
2268
    default:
2269
    case 0:
2270
      arch = bfd_xcoff_architecture (abfd);
2271
      machine = bfd_xcoff_machine (abfd);
2272
      break;
2273
2274
    case 1:
2275
      arch = bfd_arch_powerpc;
2276
      machine = bfd_mach_ppc_601;
2277
      break;
2278
    case 2: /* 64 bit PowerPC */
2279
      arch = bfd_arch_powerpc;
2280
      machine = bfd_mach_ppc_620;
2281
      break;
2282
    case 3:
2283
      arch = bfd_arch_powerpc;
2284
      machine = bfd_mach_ppc;
2285
      break;
2286
    case 4:
2287
      arch = bfd_arch_rs6000;
2288
      machine = bfd_mach_rs6k;
2289
      break;
2290
    }
2291
      }
2292
      break;
2293
#endif
2294
2295
#ifdef SH_ARCH_MAGIC_BIG
2296
    case SH_ARCH_MAGIC_BIG:
2297
    case SH_ARCH_MAGIC_LITTLE:
2298
#ifdef COFF_WITH_PE
2299
    case SH_ARCH_MAGIC_WINCE:
2300
#endif
2301
      arch = bfd_arch_sh;
2302
      break;
2303
#endif
2304
2305
#ifdef MIPS_ARCH_MAGIC_WINCE
2306
    case MIPS_ARCH_MAGIC_WINCE:
2307
      arch = bfd_arch_mips;
2308
      break;
2309
#endif
2310
2311
#ifdef SPARCMAGIC
2312
    case SPARCMAGIC:
2313
#ifdef LYNXCOFFMAGIC
2314
    case LYNXCOFFMAGIC:
2315
#endif
2316
      arch = bfd_arch_sparc;
2317
      break;
2318
#endif
2319
2320
#ifdef TIC30MAGIC
2321
    case TIC30MAGIC:
2322
      arch = bfd_arch_tic30;
2323
      break;
2324
#endif
2325
2326
#ifdef TICOFF0MAGIC
2327
#ifdef TICOFF_TARGET_ARCH
2328
      /* This TI COFF section should be used by all new TI COFF v0 targets.  */
2329
    case TICOFF0MAGIC:
2330
      arch = TICOFF_TARGET_ARCH;
2331
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
      break;
2333
#endif
2334
#endif
2335
2336
#ifdef TICOFF1MAGIC
2337
      /* This TI COFF section should be used by all new TI COFF v1/2 targets.  */
2338
      /* TI COFF1 and COFF2 use the target_id field to specify which arch.  */
2339
    case TICOFF1MAGIC:
2340
    case TICOFF2MAGIC:
2341
      switch (internal_f->f_target_id)
2342
  {
2343
#ifdef TI_TARGET_ID
2344
  case TI_TARGET_ID:
2345
    arch = TICOFF_TARGET_ARCH;
2346
    machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2347
    break;
2348
#endif
2349
  default:
2350
    arch = bfd_arch_obscure;
2351
    _bfd_error_handler
2352
      (_("unrecognized TI COFF target id '0x%x'"),
2353
       internal_f->f_target_id);
2354
    break;
2355
  }
2356
      break;
2357
#endif
2358
2359
#ifdef MCOREMAGIC
2360
    case MCOREMAGIC:
2361
      arch = bfd_arch_mcore;
2362
      break;
2363
#endif
2364
2365
0
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
874
    }
2369
2370
874
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
874
  return true;
2372
874
}
Unexecuted instantiation: pe-aarch64.c:coff_set_arch_mach_hook
pei-ia64.c:coff_set_arch_mach_hook
Line
Count
Source
2110
842
{
2111
842
  unsigned long machine;
2112
842
  enum bfd_architecture arch;
2113
842
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
842
  machine = 0;
2117
842
  switch (internal_f->f_magic)
2118
842
    {
2119
#ifdef I386MAGIC
2120
    case I386MAGIC:
2121
    case I386PTXMAGIC:
2122
    case I386AIXMAGIC:    /* Danbury PS/2 AIX C Compiler.  */
2123
    case LYNXCOFFMAGIC:
2124
    case I386_APPLE_MAGIC:
2125
    case I386_FREEBSD_MAGIC:
2126
    case I386_LINUX_MAGIC:
2127
    case I386_NETBSD_MAGIC:
2128
      arch = bfd_arch_i386;
2129
      break;
2130
#endif
2131
#ifdef AMD64MAGIC
2132
    case AMD64MAGIC:
2133
    case AMD64_APPLE_MAGIC:
2134
    case AMD64_FREEBSD_MAGIC:
2135
    case AMD64_LINUX_MAGIC:
2136
    case AMD64_NETBSD_MAGIC:
2137
      arch = bfd_arch_i386;
2138
      machine = bfd_mach_x86_64;
2139
      break;
2140
#endif
2141
0
#ifdef IA64MAGIC
2142
842
    case IA64MAGIC:
2143
842
      arch = bfd_arch_ia64;
2144
842
      break;
2145
0
#endif
2146
#ifdef ARMMAGIC
2147
    case ARMMAGIC:
2148
    case ARMPEMAGIC:
2149
    case THUMBPEMAGIC:
2150
      arch = bfd_arch_arm;
2151
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
      if (machine == bfd_mach_arm_unknown)
2153
  {
2154
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
      {
2156
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
      default:
2160
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
      case F_ARM_4T: machine = bfd_mach_arm_4T; break;
2163
        /* The COFF header does not have enough bits available
2164
     to cover all the different ARM architectures.  So
2165
     we interpret F_ARM_5, the highest flag value to mean
2166
     "the highest ARM architecture known to BFD" which is
2167
     currently the XScale.  */
2168
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
      }
2170
  }
2171
      break;
2172
#endif
2173
#ifdef AARCH64MAGIC
2174
    case AARCH64MAGIC:
2175
      arch = bfd_arch_aarch64;
2176
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
      break;
2178
#endif
2179
#ifdef LOONGARCH64MAGIC
2180
    case LOONGARCH64MAGIC:
2181
      arch = bfd_arch_loongarch;
2182
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
      break;
2184
#endif
2185
#ifdef Z80MAGIC
2186
    case Z80MAGIC:
2187
      arch = bfd_arch_z80;
2188
      switch (internal_f->f_flags & F_MACHMASK)
2189
  {
2190
  case bfd_mach_z80strict << 12:
2191
  case bfd_mach_z80 << 12:
2192
  case bfd_mach_z80n << 12:
2193
  case bfd_mach_z80full << 12:
2194
  case bfd_mach_r800 << 12:
2195
  case bfd_mach_gbz80 << 12:
2196
  case bfd_mach_z180 << 12:
2197
  case bfd_mach_ez80_z80 << 12:
2198
  case bfd_mach_ez80_adl << 12:
2199
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
    break;
2201
  default:
2202
    return false;
2203
  }
2204
      break;
2205
#endif
2206
#ifdef Z8KMAGIC
2207
    case Z8KMAGIC:
2208
      arch = bfd_arch_z8k;
2209
      switch (internal_f->f_flags & F_MACHMASK)
2210
  {
2211
  case F_Z8001:
2212
    machine = bfd_mach_z8001;
2213
    break;
2214
  case F_Z8002:
2215
    machine = bfd_mach_z8002;
2216
    break;
2217
  default:
2218
    return false;
2219
  }
2220
      break;
2221
#endif
2222
2223
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
    case U64_TOCMAGIC:
2226
    case U803XTOCMAGIC:
2227
#else
2228
    case U802ROMAGIC:
2229
    case U802WRMAGIC:
2230
    case U802TOCMAGIC:
2231
#endif
2232
      {
2233
  int cputype;
2234
2235
  if (xcoff_data (abfd)->cputype != -1)
2236
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
  else
2238
    {
2239
      /* We did not get a value from the a.out header.  If the
2240
         file has not been stripped, we may be able to get the
2241
         architecture information from the first symbol, if it
2242
         is a .file symbol.  */
2243
      if (obj_raw_syment_count (abfd) == 0)
2244
        cputype = 0;
2245
      else
2246
        {
2247
    bfd_byte *buf;
2248
    struct internal_syment sym;
2249
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
      return false;
2253
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
    if (buf == NULL)
2255
      return false;
2256
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
    if (sym.n_sclass == C_FILE)
2258
      cputype = sym.n_type & 0xff;
2259
    else
2260
      cputype = 0;
2261
    free (buf);
2262
        }
2263
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
  switch (cputype)
2267
    {
2268
    default:
2269
    case 0:
2270
      arch = bfd_xcoff_architecture (abfd);
2271
      machine = bfd_xcoff_machine (abfd);
2272
      break;
2273
2274
    case 1:
2275
      arch = bfd_arch_powerpc;
2276
      machine = bfd_mach_ppc_601;
2277
      break;
2278
    case 2: /* 64 bit PowerPC */
2279
      arch = bfd_arch_powerpc;
2280
      machine = bfd_mach_ppc_620;
2281
      break;
2282
    case 3:
2283
      arch = bfd_arch_powerpc;
2284
      machine = bfd_mach_ppc;
2285
      break;
2286
    case 4:
2287
      arch = bfd_arch_rs6000;
2288
      machine = bfd_mach_rs6k;
2289
      break;
2290
    }
2291
      }
2292
      break;
2293
#endif
2294
2295
#ifdef SH_ARCH_MAGIC_BIG
2296
    case SH_ARCH_MAGIC_BIG:
2297
    case SH_ARCH_MAGIC_LITTLE:
2298
#ifdef COFF_WITH_PE
2299
    case SH_ARCH_MAGIC_WINCE:
2300
#endif
2301
      arch = bfd_arch_sh;
2302
      break;
2303
#endif
2304
2305
#ifdef MIPS_ARCH_MAGIC_WINCE
2306
    case MIPS_ARCH_MAGIC_WINCE:
2307
      arch = bfd_arch_mips;
2308
      break;
2309
#endif
2310
2311
#ifdef SPARCMAGIC
2312
    case SPARCMAGIC:
2313
#ifdef LYNXCOFFMAGIC
2314
    case LYNXCOFFMAGIC:
2315
#endif
2316
      arch = bfd_arch_sparc;
2317
      break;
2318
#endif
2319
2320
#ifdef TIC30MAGIC
2321
    case TIC30MAGIC:
2322
      arch = bfd_arch_tic30;
2323
      break;
2324
#endif
2325
2326
#ifdef TICOFF0MAGIC
2327
#ifdef TICOFF_TARGET_ARCH
2328
      /* This TI COFF section should be used by all new TI COFF v0 targets.  */
2329
    case TICOFF0MAGIC:
2330
      arch = TICOFF_TARGET_ARCH;
2331
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
      break;
2333
#endif
2334
#endif
2335
2336
#ifdef TICOFF1MAGIC
2337
      /* This TI COFF section should be used by all new TI COFF v1/2 targets.  */
2338
      /* TI COFF1 and COFF2 use the target_id field to specify which arch.  */
2339
    case TICOFF1MAGIC:
2340
    case TICOFF2MAGIC:
2341
      switch (internal_f->f_target_id)
2342
  {
2343
#ifdef TI_TARGET_ID
2344
  case TI_TARGET_ID:
2345
    arch = TICOFF_TARGET_ARCH;
2346
    machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2347
    break;
2348
#endif
2349
  default:
2350
    arch = bfd_arch_obscure;
2351
    _bfd_error_handler
2352
      (_("unrecognized TI COFF target id '0x%x'"),
2353
       internal_f->f_target_id);
2354
    break;
2355
  }
2356
      break;
2357
#endif
2358
2359
#ifdef MCOREMAGIC
2360
    case MCOREMAGIC:
2361
      arch = bfd_arch_mcore;
2362
      break;
2363
#endif
2364
2365
0
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
842
    }
2369
2370
842
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
842
  return true;
2372
842
}
pei-loongarch64.c:coff_set_arch_mach_hook
Line
Count
Source
2110
824
{
2111
824
  unsigned long machine;
2112
824
  enum bfd_architecture arch;
2113
824
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
824
  machine = 0;
2117
824
  switch (internal_f->f_magic)
2118
824
    {
2119
#ifdef I386MAGIC
2120
    case I386MAGIC:
2121
    case I386PTXMAGIC:
2122
    case I386AIXMAGIC:    /* Danbury PS/2 AIX C Compiler.  */
2123
    case LYNXCOFFMAGIC:
2124
    case I386_APPLE_MAGIC:
2125
    case I386_FREEBSD_MAGIC:
2126
    case I386_LINUX_MAGIC:
2127
    case I386_NETBSD_MAGIC:
2128
      arch = bfd_arch_i386;
2129
      break;
2130
#endif
2131
#ifdef AMD64MAGIC
2132
    case AMD64MAGIC:
2133
    case AMD64_APPLE_MAGIC:
2134
    case AMD64_FREEBSD_MAGIC:
2135
    case AMD64_LINUX_MAGIC:
2136
    case AMD64_NETBSD_MAGIC:
2137
      arch = bfd_arch_i386;
2138
      machine = bfd_mach_x86_64;
2139
      break;
2140
#endif
2141
#ifdef IA64MAGIC
2142
    case IA64MAGIC:
2143
      arch = bfd_arch_ia64;
2144
      break;
2145
#endif
2146
#ifdef ARMMAGIC
2147
    case ARMMAGIC:
2148
    case ARMPEMAGIC:
2149
    case THUMBPEMAGIC:
2150
      arch = bfd_arch_arm;
2151
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
      if (machine == bfd_mach_arm_unknown)
2153
  {
2154
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
      {
2156
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
      default:
2160
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
      case F_ARM_4T: machine = bfd_mach_arm_4T; break;
2163
        /* The COFF header does not have enough bits available
2164
     to cover all the different ARM architectures.  So
2165
     we interpret F_ARM_5, the highest flag value to mean
2166
     "the highest ARM architecture known to BFD" which is
2167
     currently the XScale.  */
2168
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
      }
2170
  }
2171
      break;
2172
#endif
2173
#ifdef AARCH64MAGIC
2174
    case AARCH64MAGIC:
2175
      arch = bfd_arch_aarch64;
2176
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
      break;
2178
#endif
2179
0
#ifdef LOONGARCH64MAGIC
2180
824
    case LOONGARCH64MAGIC:
2181
824
      arch = bfd_arch_loongarch;
2182
824
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
824
      break;
2184
0
#endif
2185
#ifdef Z80MAGIC
2186
    case Z80MAGIC:
2187
      arch = bfd_arch_z80;
2188
      switch (internal_f->f_flags & F_MACHMASK)
2189
  {
2190
  case bfd_mach_z80strict << 12:
2191
  case bfd_mach_z80 << 12:
2192
  case bfd_mach_z80n << 12:
2193
  case bfd_mach_z80full << 12:
2194
  case bfd_mach_r800 << 12:
2195
  case bfd_mach_gbz80 << 12:
2196
  case bfd_mach_z180 << 12:
2197
  case bfd_mach_ez80_z80 << 12:
2198
  case bfd_mach_ez80_adl << 12:
2199
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
    break;
2201
  default:
2202
    return false;
2203
  }
2204
      break;
2205
#endif
2206
#ifdef Z8KMAGIC
2207
    case Z8KMAGIC:
2208
      arch = bfd_arch_z8k;
2209
      switch (internal_f->f_flags & F_MACHMASK)
2210
  {
2211
  case F_Z8001:
2212
    machine = bfd_mach_z8001;
2213
    break;
2214
  case F_Z8002:
2215
    machine = bfd_mach_z8002;
2216
    break;
2217
  default:
2218
    return false;
2219
  }
2220
      break;
2221
#endif
2222
2223
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
    case U64_TOCMAGIC:
2226
    case U803XTOCMAGIC:
2227
#else
2228
    case U802ROMAGIC:
2229
    case U802WRMAGIC:
2230
    case U802TOCMAGIC:
2231
#endif
2232
      {
2233
  int cputype;
2234
2235
  if (xcoff_data (abfd)->cputype != -1)
2236
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
  else
2238
    {
2239
      /* We did not get a value from the a.out header.  If the
2240
         file has not been stripped, we may be able to get the
2241
         architecture information from the first symbol, if it
2242
         is a .file symbol.  */
2243
      if (obj_raw_syment_count (abfd) == 0)
2244
        cputype = 0;
2245
      else
2246
        {
2247
    bfd_byte *buf;
2248
    struct internal_syment sym;
2249
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
      return false;
2253
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
    if (buf == NULL)
2255
      return false;
2256
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
    if (sym.n_sclass == C_FILE)
2258
      cputype = sym.n_type & 0xff;
2259
    else
2260
      cputype = 0;
2261
    free (buf);
2262
        }
2263
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
  switch (cputype)
2267
    {
2268
    default:
2269
    case 0:
2270
      arch = bfd_xcoff_architecture (abfd);
2271
      machine = bfd_xcoff_machine (abfd);
2272
      break;
2273
2274
    case 1:
2275
      arch = bfd_arch_powerpc;
2276
      machine = bfd_mach_ppc_601;
2277
      break;
2278
    case 2: /* 64 bit PowerPC */
2279
      arch = bfd_arch_powerpc;
2280
      machine = bfd_mach_ppc_620;
2281
      break;
2282
    case 3:
2283
      arch = bfd_arch_powerpc;
2284
      machine = bfd_mach_ppc;
2285
      break;
2286
    case 4:
2287
      arch = bfd_arch_rs6000;
2288
      machine = bfd_mach_rs6k;
2289
      break;
2290
    }
2291
      }
2292
      break;
2293
#endif
2294
2295
#ifdef SH_ARCH_MAGIC_BIG
2296
    case SH_ARCH_MAGIC_BIG:
2297
    case SH_ARCH_MAGIC_LITTLE:
2298
#ifdef COFF_WITH_PE
2299
    case SH_ARCH_MAGIC_WINCE:
2300
#endif
2301
      arch = bfd_arch_sh;
2302
      break;
2303
#endif
2304
2305
#ifdef MIPS_ARCH_MAGIC_WINCE
2306
    case MIPS_ARCH_MAGIC_WINCE:
2307
      arch = bfd_arch_mips;
2308
      break;
2309
#endif
2310
2311
#ifdef SPARCMAGIC
2312
    case SPARCMAGIC:
2313
#ifdef LYNXCOFFMAGIC
2314
    case LYNXCOFFMAGIC:
2315
#endif
2316
      arch = bfd_arch_sparc;
2317
      break;
2318
#endif
2319
2320
#ifdef TIC30MAGIC
2321
    case TIC30MAGIC:
2322
      arch = bfd_arch_tic30;
2323
      break;
2324
#endif
2325
2326
#ifdef TICOFF0MAGIC
2327
#ifdef TICOFF_TARGET_ARCH
2328
      /* This TI COFF section should be used by all new TI COFF v0 targets.  */
2329
    case TICOFF0MAGIC:
2330
      arch = TICOFF_TARGET_ARCH;
2331
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
      break;
2333
#endif
2334
#endif
2335
2336
#ifdef TICOFF1MAGIC
2337
      /* This TI COFF section should be used by all new TI COFF v1/2 targets.  */
2338
      /* TI COFF1 and COFF2 use the target_id field to specify which arch.  */
2339
    case TICOFF1MAGIC:
2340
    case TICOFF2MAGIC:
2341
      switch (internal_f->f_target_id)
2342
  {
2343
#ifdef TI_TARGET_ID
2344
  case TI_TARGET_ID:
2345
    arch = TICOFF_TARGET_ARCH;
2346
    machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2347
    break;
2348
#endif
2349
  default:
2350
    arch = bfd_arch_obscure;
2351
    _bfd_error_handler
2352
      (_("unrecognized TI COFF target id '0x%x'"),
2353
       internal_f->f_target_id);
2354
    break;
2355
  }
2356
      break;
2357
#endif
2358
2359
#ifdef MCOREMAGIC
2360
    case MCOREMAGIC:
2361
      arch = bfd_arch_mcore;
2362
      break;
2363
#endif
2364
2365
0
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
824
    }
2369
2370
824
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
824
  return true;
2372
824
}
cf-i386lynx.c:coff_set_arch_mach_hook
Line
Count
Source
2110
1.40k
{
2111
1.40k
  unsigned long machine;
2112
1.40k
  enum bfd_architecture arch;
2113
1.40k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
1.40k
  machine = 0;
2117
1.40k
  switch (internal_f->f_magic)
2118
1.40k
    {
2119
0
#ifdef I386MAGIC
2120
771
    case I386MAGIC:
2121
952
    case I386PTXMAGIC:
2122
1.09k
    case I386AIXMAGIC:   /* Danbury PS/2 AIX C Compiler.  */
2123
1.10k
    case LYNXCOFFMAGIC:
2124
1.10k
    case I386_APPLE_MAGIC:
2125
1.11k
    case I386_FREEBSD_MAGIC:
2126
1.11k
    case I386_LINUX_MAGIC:
2127
1.40k
    case I386_NETBSD_MAGIC:
2128
1.40k
      arch = bfd_arch_i386;
2129
1.40k
      break;
2130
0
#endif
2131
#ifdef AMD64MAGIC
2132
    case AMD64MAGIC:
2133
    case AMD64_APPLE_MAGIC:
2134
    case AMD64_FREEBSD_MAGIC:
2135
    case AMD64_LINUX_MAGIC:
2136
    case AMD64_NETBSD_MAGIC:
2137
      arch = bfd_arch_i386;
2138
      machine = bfd_mach_x86_64;
2139
      break;
2140
#endif
2141
#ifdef IA64MAGIC
2142
    case IA64MAGIC:
2143
      arch = bfd_arch_ia64;
2144
      break;
2145
#endif
2146
#ifdef ARMMAGIC
2147
    case ARMMAGIC:
2148
    case ARMPEMAGIC:
2149
    case THUMBPEMAGIC:
2150
      arch = bfd_arch_arm;
2151
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
      if (machine == bfd_mach_arm_unknown)
2153
  {
2154
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
      {
2156
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
      default:
2160
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
      case F_ARM_4T: machine = bfd_mach_arm_4T; break;
2163
        /* The COFF header does not have enough bits available
2164
     to cover all the different ARM architectures.  So
2165
     we interpret F_ARM_5, the highest flag value to mean
2166
     "the highest ARM architecture known to BFD" which is
2167
     currently the XScale.  */
2168
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
      }
2170
  }
2171
      break;
2172
#endif
2173
#ifdef AARCH64MAGIC
2174
    case AARCH64MAGIC:
2175
      arch = bfd_arch_aarch64;
2176
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
      break;
2178
#endif
2179
#ifdef LOONGARCH64MAGIC
2180
    case LOONGARCH64MAGIC:
2181
      arch = bfd_arch_loongarch;
2182
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
      break;
2184
#endif
2185
#ifdef Z80MAGIC
2186
    case Z80MAGIC:
2187
      arch = bfd_arch_z80;
2188
      switch (internal_f->f_flags & F_MACHMASK)
2189
  {
2190
  case bfd_mach_z80strict << 12:
2191
  case bfd_mach_z80 << 12:
2192
  case bfd_mach_z80n << 12:
2193
  case bfd_mach_z80full << 12:
2194
  case bfd_mach_r800 << 12:
2195
  case bfd_mach_gbz80 << 12:
2196
  case bfd_mach_z180 << 12:
2197
  case bfd_mach_ez80_z80 << 12:
2198
  case bfd_mach_ez80_adl << 12:
2199
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
    break;
2201
  default:
2202
    return false;
2203
  }
2204
      break;
2205
#endif
2206
#ifdef Z8KMAGIC
2207
    case Z8KMAGIC:
2208
      arch = bfd_arch_z8k;
2209
      switch (internal_f->f_flags & F_MACHMASK)
2210
  {
2211
  case F_Z8001:
2212
    machine = bfd_mach_z8001;
2213
    break;
2214
  case F_Z8002:
2215
    machine = bfd_mach_z8002;
2216
    break;
2217
  default:
2218
    return false;
2219
  }
2220
      break;
2221
#endif
2222
2223
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
    case U64_TOCMAGIC:
2226
    case U803XTOCMAGIC:
2227
#else
2228
    case U802ROMAGIC:
2229
    case U802WRMAGIC:
2230
    case U802TOCMAGIC:
2231
#endif
2232
      {
2233
  int cputype;
2234
2235
  if (xcoff_data (abfd)->cputype != -1)
2236
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
  else
2238
    {
2239
      /* We did not get a value from the a.out header.  If the
2240
         file has not been stripped, we may be able to get the
2241
         architecture information from the first symbol, if it
2242
         is a .file symbol.  */
2243
      if (obj_raw_syment_count (abfd) == 0)
2244
        cputype = 0;
2245
      else
2246
        {
2247
    bfd_byte *buf;
2248
    struct internal_syment sym;
2249
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
      return false;
2253
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
    if (buf == NULL)
2255
      return false;
2256
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
    if (sym.n_sclass == C_FILE)
2258
      cputype = sym.n_type & 0xff;
2259
    else
2260
      cputype = 0;
2261
    free (buf);
2262
        }
2263
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
  switch (cputype)
2267
    {
2268
    default:
2269
    case 0:
2270
      arch = bfd_xcoff_architecture (abfd);
2271
      machine = bfd_xcoff_machine (abfd);
2272
      break;
2273
2274
    case 1:
2275
      arch = bfd_arch_powerpc;
2276
      machine = bfd_mach_ppc_601;
2277
      break;
2278
    case 2: /* 64 bit PowerPC */
2279
      arch = bfd_arch_powerpc;
2280
      machine = bfd_mach_ppc_620;
2281
      break;
2282
    case 3:
2283
      arch = bfd_arch_powerpc;
2284
      machine = bfd_mach_ppc;
2285
      break;
2286
    case 4:
2287
      arch = bfd_arch_rs6000;
2288
      machine = bfd_mach_rs6k;
2289
      break;
2290
    }
2291
      }
2292
      break;
2293
#endif
2294
2295
#ifdef SH_ARCH_MAGIC_BIG
2296
    case SH_ARCH_MAGIC_BIG:
2297
    case SH_ARCH_MAGIC_LITTLE:
2298
#ifdef COFF_WITH_PE
2299
    case SH_ARCH_MAGIC_WINCE:
2300
#endif
2301
      arch = bfd_arch_sh;
2302
      break;
2303
#endif
2304
2305
#ifdef MIPS_ARCH_MAGIC_WINCE
2306
    case MIPS_ARCH_MAGIC_WINCE:
2307
      arch = bfd_arch_mips;
2308
      break;
2309
#endif
2310
2311
#ifdef SPARCMAGIC
2312
    case SPARCMAGIC:
2313
#ifdef LYNXCOFFMAGIC
2314
    case LYNXCOFFMAGIC:
2315
#endif
2316
      arch = bfd_arch_sparc;
2317
      break;
2318
#endif
2319
2320
#ifdef TIC30MAGIC
2321
    case TIC30MAGIC:
2322
      arch = bfd_arch_tic30;
2323
      break;
2324
#endif
2325
2326
#ifdef TICOFF0MAGIC
2327
#ifdef TICOFF_TARGET_ARCH
2328
      /* This TI COFF section should be used by all new TI COFF v0 targets.  */
2329
    case TICOFF0MAGIC:
2330
      arch = TICOFF_TARGET_ARCH;
2331
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
      break;
2333
#endif
2334
#endif
2335
2336
#ifdef TICOFF1MAGIC
2337
      /* This TI COFF section should be used by all new TI COFF v1/2 targets.  */
2338
      /* TI COFF1 and COFF2 use the target_id field to specify which arch.  */
2339
    case TICOFF1MAGIC:
2340
    case TICOFF2MAGIC:
2341
      switch (internal_f->f_target_id)
2342
  {
2343
#ifdef TI_TARGET_ID
2344
  case TI_TARGET_ID:
2345
    arch = TICOFF_TARGET_ARCH;
2346
    machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2347
    break;
2348
#endif
2349
  default:
2350
    arch = bfd_arch_obscure;
2351
    _bfd_error_handler
2352
      (_("unrecognized TI COFF target id '0x%x'"),
2353
       internal_f->f_target_id);
2354
    break;
2355
  }
2356
      break;
2357
#endif
2358
2359
#ifdef MCOREMAGIC
2360
    case MCOREMAGIC:
2361
      arch = bfd_arch_mcore;
2362
      break;
2363
#endif
2364
2365
0
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
1.40k
    }
2369
2370
1.40k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
1.40k
  return true;
2372
1.40k
}
Unexecuted instantiation: coff-go32.c:coff_set_arch_mach_hook
Unexecuted instantiation: coff-i386.c:coff_set_arch_mach_hook
Unexecuted instantiation: coff-rs6000.c:coff_set_arch_mach_hook
Unexecuted instantiation: coff-sh.c:coff_set_arch_mach_hook
coff-stgo32.c:coff_set_arch_mach_hook
Line
Count
Source
2110
1.50k
{
2111
1.50k
  unsigned long machine;
2112
1.50k
  enum bfd_architecture arch;
2113
1.50k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
1.50k
  machine = 0;
2117
1.50k
  switch (internal_f->f_magic)
2118
1.50k
    {
2119
0
#ifdef I386MAGIC
2120
817
    case I386MAGIC:
2121
1.01k
    case I386PTXMAGIC:
2122
1.16k
    case I386AIXMAGIC:   /* Danbury PS/2 AIX C Compiler.  */
2123
1.17k
    case LYNXCOFFMAGIC:
2124
1.17k
    case I386_APPLE_MAGIC:
2125
1.18k
    case I386_FREEBSD_MAGIC:
2126
1.18k
    case I386_LINUX_MAGIC:
2127
1.50k
    case I386_NETBSD_MAGIC:
2128
1.50k
      arch = bfd_arch_i386;
2129
1.50k
      break;
2130
0
#endif
2131
#ifdef AMD64MAGIC
2132
    case AMD64MAGIC:
2133
    case AMD64_APPLE_MAGIC:
2134
    case AMD64_FREEBSD_MAGIC:
2135
    case AMD64_LINUX_MAGIC:
2136
    case AMD64_NETBSD_MAGIC:
2137
      arch = bfd_arch_i386;
2138
      machine = bfd_mach_x86_64;
2139
      break;
2140
#endif
2141
#ifdef IA64MAGIC
2142
    case IA64MAGIC:
2143
      arch = bfd_arch_ia64;
2144
      break;
2145
#endif
2146
#ifdef ARMMAGIC
2147
    case ARMMAGIC:
2148
    case ARMPEMAGIC:
2149
    case THUMBPEMAGIC:
2150
      arch = bfd_arch_arm;
2151
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
      if (machine == bfd_mach_arm_unknown)
2153
  {
2154
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
      {
2156
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
      default:
2160
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
      case F_ARM_4T: machine = bfd_mach_arm_4T; break;
2163
        /* The COFF header does not have enough bits available
2164
     to cover all the different ARM architectures.  So
2165
     we interpret F_ARM_5, the highest flag value to mean
2166
     "the highest ARM architecture known to BFD" which is
2167
     currently the XScale.  */
2168
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
      }
2170
  }
2171
      break;
2172
#endif
2173
#ifdef AARCH64MAGIC
2174
    case AARCH64MAGIC:
2175
      arch = bfd_arch_aarch64;
2176
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
      break;
2178
#endif
2179
#ifdef LOONGARCH64MAGIC
2180
    case LOONGARCH64MAGIC:
2181
      arch = bfd_arch_loongarch;
2182
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
      break;
2184
#endif
2185
#ifdef Z80MAGIC
2186
    case Z80MAGIC:
2187
      arch = bfd_arch_z80;
2188
      switch (internal_f->f_flags & F_MACHMASK)
2189
  {
2190
  case bfd_mach_z80strict << 12:
2191
  case bfd_mach_z80 << 12:
2192
  case bfd_mach_z80n << 12:
2193
  case bfd_mach_z80full << 12:
2194
  case bfd_mach_r800 << 12:
2195
  case bfd_mach_gbz80 << 12:
2196
  case bfd_mach_z180 << 12:
2197
  case bfd_mach_ez80_z80 << 12:
2198
  case bfd_mach_ez80_adl << 12:
2199
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
    break;
2201
  default:
2202
    return false;
2203
  }
2204
      break;
2205
#endif
2206
#ifdef Z8KMAGIC
2207
    case Z8KMAGIC:
2208
      arch = bfd_arch_z8k;
2209
      switch (internal_f->f_flags & F_MACHMASK)
2210
  {
2211
  case F_Z8001:
2212
    machine = bfd_mach_z8001;
2213
    break;
2214
  case F_Z8002:
2215
    machine = bfd_mach_z8002;
2216
    break;
2217
  default:
2218
    return false;
2219
  }
2220
      break;
2221
#endif
2222
2223
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
    case U64_TOCMAGIC:
2226
    case U803XTOCMAGIC:
2227
#else
2228
    case U802ROMAGIC:
2229
    case U802WRMAGIC:
2230
    case U802TOCMAGIC:
2231
#endif
2232
      {
2233
  int cputype;
2234
2235
  if (xcoff_data (abfd)->cputype != -1)
2236
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
  else
2238
    {
2239
      /* We did not get a value from the a.out header.  If the
2240
         file has not been stripped, we may be able to get the
2241
         architecture information from the first symbol, if it
2242
         is a .file symbol.  */
2243
      if (obj_raw_syment_count (abfd) == 0)
2244
        cputype = 0;
2245
      else
2246
        {
2247
    bfd_byte *buf;
2248
    struct internal_syment sym;
2249
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
      return false;
2253
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
    if (buf == NULL)
2255
      return false;
2256
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
    if (sym.n_sclass == C_FILE)
2258
      cputype = sym.n_type & 0xff;
2259
    else
2260
      cputype = 0;
2261
    free (buf);
2262
        }
2263
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
  switch (cputype)
2267
    {
2268
    default:
2269
    case 0:
2270
      arch = bfd_xcoff_architecture (abfd);
2271
      machine = bfd_xcoff_machine (abfd);
2272
      break;
2273
2274
    case 1:
2275
      arch = bfd_arch_powerpc;
2276
      machine = bfd_mach_ppc_601;
2277
      break;
2278
    case 2: /* 64 bit PowerPC */
2279
      arch = bfd_arch_powerpc;
2280
      machine = bfd_mach_ppc_620;
2281
      break;
2282
    case 3:
2283
      arch = bfd_arch_powerpc;
2284
      machine = bfd_mach_ppc;
2285
      break;
2286
    case 4:
2287
      arch = bfd_arch_rs6000;
2288
      machine = bfd_mach_rs6k;
2289
      break;
2290
    }
2291
      }
2292
      break;
2293
#endif
2294
2295
#ifdef SH_ARCH_MAGIC_BIG
2296
    case SH_ARCH_MAGIC_BIG:
2297
    case SH_ARCH_MAGIC_LITTLE:
2298
#ifdef COFF_WITH_PE
2299
    case SH_ARCH_MAGIC_WINCE:
2300
#endif
2301
      arch = bfd_arch_sh;
2302
      break;
2303
#endif
2304
2305
#ifdef MIPS_ARCH_MAGIC_WINCE
2306
    case MIPS_ARCH_MAGIC_WINCE:
2307
      arch = bfd_arch_mips;
2308
      break;
2309
#endif
2310
2311
#ifdef SPARCMAGIC
2312
    case SPARCMAGIC:
2313
#ifdef LYNXCOFFMAGIC
2314
    case LYNXCOFFMAGIC:
2315
#endif
2316
      arch = bfd_arch_sparc;
2317
      break;
2318
#endif
2319
2320
#ifdef TIC30MAGIC
2321
    case TIC30MAGIC:
2322
      arch = bfd_arch_tic30;
2323
      break;
2324
#endif
2325
2326
#ifdef TICOFF0MAGIC
2327
#ifdef TICOFF_TARGET_ARCH
2328
      /* This TI COFF section should be used by all new TI COFF v0 targets.  */
2329
    case TICOFF0MAGIC:
2330
      arch = TICOFF_TARGET_ARCH;
2331
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
      break;
2333
#endif
2334
#endif
2335
2336
#ifdef TICOFF1MAGIC
2337
      /* This TI COFF section should be used by all new TI COFF v1/2 targets.  */
2338
      /* TI COFF1 and COFF2 use the target_id field to specify which arch.  */
2339
    case TICOFF1MAGIC:
2340
    case TICOFF2MAGIC:
2341
      switch (internal_f->f_target_id)
2342
  {
2343
#ifdef TI_TARGET_ID
2344
  case TI_TARGET_ID:
2345
    arch = TICOFF_TARGET_ARCH;
2346
    machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2347
    break;
2348
#endif
2349
  default:
2350
    arch = bfd_arch_obscure;
2351
    _bfd_error_handler
2352
      (_("unrecognized TI COFF target id '0x%x'"),
2353
       internal_f->f_target_id);
2354
    break;
2355
  }
2356
      break;
2357
#endif
2358
2359
#ifdef MCOREMAGIC
2360
    case MCOREMAGIC:
2361
      arch = bfd_arch_mcore;
2362
      break;
2363
#endif
2364
2365
0
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
1.50k
    }
2369
2370
1.50k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
1.50k
  return true;
2372
1.50k
}
Unexecuted instantiation: coff-tic30.c:coff_set_arch_mach_hook
Unexecuted instantiation: coff-tic4x.c:coff_set_arch_mach_hook
Unexecuted instantiation: coff-tic54x.c:coff_set_arch_mach_hook
Unexecuted instantiation: coff-z80.c:coff_set_arch_mach_hook
Unexecuted instantiation: coff-z8k.c:coff_set_arch_mach_hook
Unexecuted instantiation: pe-arm-wince.c:coff_set_arch_mach_hook
Unexecuted instantiation: pe-arm.c:coff_set_arch_mach_hook
pe-i386.c:coff_set_arch_mach_hook
Line
Count
Source
2110
1.40k
{
2111
1.40k
  unsigned long machine;
2112
1.40k
  enum bfd_architecture arch;
2113
1.40k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
1.40k
  machine = 0;
2117
1.40k
  switch (internal_f->f_magic)
2118
1.40k
    {
2119
0
#ifdef I386MAGIC
2120
771
    case I386MAGIC:
2121
952
    case I386PTXMAGIC:
2122
1.09k
    case I386AIXMAGIC:   /* Danbury PS/2 AIX C Compiler.  */
2123
1.10k
    case LYNXCOFFMAGIC:
2124
1.10k
    case I386_APPLE_MAGIC:
2125
1.11k
    case I386_FREEBSD_MAGIC:
2126
1.11k
    case I386_LINUX_MAGIC:
2127
1.40k
    case I386_NETBSD_MAGIC:
2128
1.40k
      arch = bfd_arch_i386;
2129
1.40k
      break;
2130
0
#endif
2131
#ifdef AMD64MAGIC
2132
    case AMD64MAGIC:
2133
    case AMD64_APPLE_MAGIC:
2134
    case AMD64_FREEBSD_MAGIC:
2135
    case AMD64_LINUX_MAGIC:
2136
    case AMD64_NETBSD_MAGIC:
2137
      arch = bfd_arch_i386;
2138
      machine = bfd_mach_x86_64;
2139
      break;
2140
#endif
2141
#ifdef IA64MAGIC
2142
    case IA64MAGIC:
2143
      arch = bfd_arch_ia64;
2144
      break;
2145
#endif
2146
#ifdef ARMMAGIC
2147
    case ARMMAGIC:
2148
    case ARMPEMAGIC:
2149
    case THUMBPEMAGIC:
2150
      arch = bfd_arch_arm;
2151
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
      if (machine == bfd_mach_arm_unknown)
2153
  {
2154
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
      {
2156
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
      default:
2160
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
      case F_ARM_4T: machine = bfd_mach_arm_4T; break;
2163
        /* The COFF header does not have enough bits available
2164
     to cover all the different ARM architectures.  So
2165
     we interpret F_ARM_5, the highest flag value to mean
2166
     "the highest ARM architecture known to BFD" which is
2167
     currently the XScale.  */
2168
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
      }
2170
  }
2171
      break;
2172
#endif
2173
#ifdef AARCH64MAGIC
2174
    case AARCH64MAGIC:
2175
      arch = bfd_arch_aarch64;
2176
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
      break;
2178
#endif
2179
#ifdef LOONGARCH64MAGIC
2180
    case LOONGARCH64MAGIC:
2181
      arch = bfd_arch_loongarch;
2182
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
      break;
2184
#endif
2185
#ifdef Z80MAGIC
2186
    case Z80MAGIC:
2187
      arch = bfd_arch_z80;
2188
      switch (internal_f->f_flags & F_MACHMASK)
2189
  {
2190
  case bfd_mach_z80strict << 12:
2191
  case bfd_mach_z80 << 12:
2192
  case bfd_mach_z80n << 12:
2193
  case bfd_mach_z80full << 12:
2194
  case bfd_mach_r800 << 12:
2195
  case bfd_mach_gbz80 << 12:
2196
  case bfd_mach_z180 << 12:
2197
  case bfd_mach_ez80_z80 << 12:
2198
  case bfd_mach_ez80_adl << 12:
2199
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
    break;
2201
  default:
2202
    return false;
2203
  }
2204
      break;
2205
#endif
2206
#ifdef Z8KMAGIC
2207
    case Z8KMAGIC:
2208
      arch = bfd_arch_z8k;
2209
      switch (internal_f->f_flags & F_MACHMASK)
2210
  {
2211
  case F_Z8001:
2212
    machine = bfd_mach_z8001;
2213
    break;
2214
  case F_Z8002:
2215
    machine = bfd_mach_z8002;
2216
    break;
2217
  default:
2218
    return false;
2219
  }
2220
      break;
2221
#endif
2222
2223
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
    case U64_TOCMAGIC:
2226
    case U803XTOCMAGIC:
2227
#else
2228
    case U802ROMAGIC:
2229
    case U802WRMAGIC:
2230
    case U802TOCMAGIC:
2231
#endif
2232
      {
2233
  int cputype;
2234
2235
  if (xcoff_data (abfd)->cputype != -1)
2236
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
  else
2238
    {
2239
      /* We did not get a value from the a.out header.  If the
2240
         file has not been stripped, we may be able to get the
2241
         architecture information from the first symbol, if it
2242
         is a .file symbol.  */
2243
      if (obj_raw_syment_count (abfd) == 0)
2244
        cputype = 0;
2245
      else
2246
        {
2247
    bfd_byte *buf;
2248
    struct internal_syment sym;
2249
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
      return false;
2253
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
    if (buf == NULL)
2255
      return false;
2256
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
    if (sym.n_sclass == C_FILE)
2258
      cputype = sym.n_type & 0xff;
2259
    else
2260
      cputype = 0;
2261
    free (buf);
2262
        }
2263
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
  switch (cputype)
2267
    {
2268
    default:
2269
    case 0:
2270
      arch = bfd_xcoff_architecture (abfd);
2271
      machine = bfd_xcoff_machine (abfd);
2272
      break;
2273
2274
    case 1:
2275
      arch = bfd_arch_powerpc;
2276
      machine = bfd_mach_ppc_601;
2277
      break;
2278
    case 2: /* 64 bit PowerPC */
2279
      arch = bfd_arch_powerpc;
2280
      machine = bfd_mach_ppc_620;
2281
      break;
2282
    case 3:
2283
      arch = bfd_arch_powerpc;
2284
      machine = bfd_mach_ppc;
2285
      break;
2286
    case 4:
2287
      arch = bfd_arch_rs6000;
2288
      machine = bfd_mach_rs6k;
2289
      break;
2290
    }
2291
      }
2292
      break;
2293
#endif
2294
2295
#ifdef SH_ARCH_MAGIC_BIG
2296
    case SH_ARCH_MAGIC_BIG:
2297
    case SH_ARCH_MAGIC_LITTLE:
2298
#ifdef COFF_WITH_PE
2299
    case SH_ARCH_MAGIC_WINCE:
2300
#endif
2301
      arch = bfd_arch_sh;
2302
      break;
2303
#endif
2304
2305
#ifdef MIPS_ARCH_MAGIC_WINCE
2306
    case MIPS_ARCH_MAGIC_WINCE:
2307
      arch = bfd_arch_mips;
2308
      break;
2309
#endif
2310
2311
#ifdef SPARCMAGIC
2312
    case SPARCMAGIC:
2313
#ifdef LYNXCOFFMAGIC
2314
    case LYNXCOFFMAGIC:
2315
#endif
2316
      arch = bfd_arch_sparc;
2317
      break;
2318
#endif
2319
2320
#ifdef TIC30MAGIC
2321
    case TIC30MAGIC:
2322
      arch = bfd_arch_tic30;
2323
      break;
2324
#endif
2325
2326
#ifdef TICOFF0MAGIC
2327
#ifdef TICOFF_TARGET_ARCH
2328
      /* This TI COFF section should be used by all new TI COFF v0 targets.  */
2329
    case TICOFF0MAGIC:
2330
      arch = TICOFF_TARGET_ARCH;
2331
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
      break;
2333
#endif
2334
#endif
2335
2336
#ifdef TICOFF1MAGIC
2337
      /* This TI COFF section should be used by all new TI COFF v1/2 targets.  */
2338
      /* TI COFF1 and COFF2 use the target_id field to specify which arch.  */
2339
    case TICOFF1MAGIC:
2340
    case TICOFF2MAGIC:
2341
      switch (internal_f->f_target_id)
2342
  {
2343
#ifdef TI_TARGET_ID
2344
  case TI_TARGET_ID:
2345
    arch = TICOFF_TARGET_ARCH;
2346
    machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2347
    break;
2348
#endif
2349
  default:
2350
    arch = bfd_arch_obscure;
2351
    _bfd_error_handler
2352
      (_("unrecognized TI COFF target id '0x%x'"),
2353
       internal_f->f_target_id);
2354
    break;
2355
  }
2356
      break;
2357
#endif
2358
2359
#ifdef MCOREMAGIC
2360
    case MCOREMAGIC:
2361
      arch = bfd_arch_mcore;
2362
      break;
2363
#endif
2364
2365
0
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
1.40k
    }
2369
2370
1.40k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
1.40k
  return true;
2372
1.40k
}
Unexecuted instantiation: pe-mcore.c:coff_set_arch_mach_hook
Unexecuted instantiation: pe-sh.c:coff_set_arch_mach_hook
pei-arm-wince.c:coff_set_arch_mach_hook
Line
Count
Source
2110
1.05k
{
2111
1.05k
  unsigned long machine;
2112
1.05k
  enum bfd_architecture arch;
2113
1.05k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
1.05k
  machine = 0;
2117
1.05k
  switch (internal_f->f_magic)
2118
1.05k
    {
2119
#ifdef I386MAGIC
2120
    case I386MAGIC:
2121
    case I386PTXMAGIC:
2122
    case I386AIXMAGIC:    /* Danbury PS/2 AIX C Compiler.  */
2123
    case LYNXCOFFMAGIC:
2124
    case I386_APPLE_MAGIC:
2125
    case I386_FREEBSD_MAGIC:
2126
    case I386_LINUX_MAGIC:
2127
    case I386_NETBSD_MAGIC:
2128
      arch = bfd_arch_i386;
2129
      break;
2130
#endif
2131
#ifdef AMD64MAGIC
2132
    case AMD64MAGIC:
2133
    case AMD64_APPLE_MAGIC:
2134
    case AMD64_FREEBSD_MAGIC:
2135
    case AMD64_LINUX_MAGIC:
2136
    case AMD64_NETBSD_MAGIC:
2137
      arch = bfd_arch_i386;
2138
      machine = bfd_mach_x86_64;
2139
      break;
2140
#endif
2141
#ifdef IA64MAGIC
2142
    case IA64MAGIC:
2143
      arch = bfd_arch_ia64;
2144
      break;
2145
#endif
2146
0
#ifdef ARMMAGIC
2147
824
    case ARMMAGIC:
2148
905
    case ARMPEMAGIC:
2149
951
    case THUMBPEMAGIC:
2150
951
      arch = bfd_arch_arm;
2151
951
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
951
      if (machine == bfd_mach_arm_unknown)
2153
951
  {
2154
951
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
951
      {
2156
45
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
60
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
51
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
404
      default:
2160
561
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
102
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
67
      case F_ARM_4T: machine = bfd_mach_arm_4T; break;
2163
        /* The COFF header does not have enough bits available
2164
     to cover all the different ARM architectures.  So
2165
     we interpret F_ARM_5, the highest flag value to mean
2166
     "the highest ARM architecture known to BFD" which is
2167
     currently the XScale.  */
2168
65
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
951
      }
2170
951
  }
2171
951
      break;
2172
951
#endif
2173
#ifdef AARCH64MAGIC
2174
    case AARCH64MAGIC:
2175
      arch = bfd_arch_aarch64;
2176
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
      break;
2178
#endif
2179
#ifdef LOONGARCH64MAGIC
2180
    case LOONGARCH64MAGIC:
2181
      arch = bfd_arch_loongarch;
2182
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
      break;
2184
#endif
2185
#ifdef Z80MAGIC
2186
    case Z80MAGIC:
2187
      arch = bfd_arch_z80;
2188
      switch (internal_f->f_flags & F_MACHMASK)
2189
  {
2190
  case bfd_mach_z80strict << 12:
2191
  case bfd_mach_z80 << 12:
2192
  case bfd_mach_z80n << 12:
2193
  case bfd_mach_z80full << 12:
2194
  case bfd_mach_r800 << 12:
2195
  case bfd_mach_gbz80 << 12:
2196
  case bfd_mach_z180 << 12:
2197
  case bfd_mach_ez80_z80 << 12:
2198
  case bfd_mach_ez80_adl << 12:
2199
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
    break;
2201
  default:
2202
    return false;
2203
  }
2204
      break;
2205
#endif
2206
#ifdef Z8KMAGIC
2207
    case Z8KMAGIC:
2208
      arch = bfd_arch_z8k;
2209
      switch (internal_f->f_flags & F_MACHMASK)
2210
  {
2211
  case F_Z8001:
2212
    machine = bfd_mach_z8001;
2213
    break;
2214
  case F_Z8002:
2215
    machine = bfd_mach_z8002;
2216
    break;
2217
  default:
2218
    return false;
2219
  }
2220
      break;
2221
#endif
2222
2223
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
    case U64_TOCMAGIC:
2226
    case U803XTOCMAGIC:
2227
#else
2228
    case U802ROMAGIC:
2229
    case U802WRMAGIC:
2230
    case U802TOCMAGIC:
2231
#endif
2232
      {
2233
  int cputype;
2234
2235
  if (xcoff_data (abfd)->cputype != -1)
2236
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
  else
2238
    {
2239
      /* We did not get a value from the a.out header.  If the
2240
         file has not been stripped, we may be able to get the
2241
         architecture information from the first symbol, if it
2242
         is a .file symbol.  */
2243
      if (obj_raw_syment_count (abfd) == 0)
2244
        cputype = 0;
2245
      else
2246
        {
2247
    bfd_byte *buf;
2248
    struct internal_syment sym;
2249
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
      return false;
2253
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
    if (buf == NULL)
2255
      return false;
2256
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
    if (sym.n_sclass == C_FILE)
2258
      cputype = sym.n_type & 0xff;
2259
    else
2260
      cputype = 0;
2261
    free (buf);
2262
        }
2263
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
  switch (cputype)
2267
    {
2268
    default:
2269
    case 0:
2270
      arch = bfd_xcoff_architecture (abfd);
2271
      machine = bfd_xcoff_machine (abfd);
2272
      break;
2273
2274
    case 1:
2275
      arch = bfd_arch_powerpc;
2276
      machine = bfd_mach_ppc_601;
2277
      break;
2278
    case 2: /* 64 bit PowerPC */
2279
      arch = bfd_arch_powerpc;
2280
      machine = bfd_mach_ppc_620;
2281
      break;
2282
    case 3:
2283
      arch = bfd_arch_powerpc;
2284
      machine = bfd_mach_ppc;
2285
      break;
2286
    case 4:
2287
      arch = bfd_arch_rs6000;
2288
      machine = bfd_mach_rs6k;
2289
      break;
2290
    }
2291
      }
2292
      break;
2293
#endif
2294
2295
#ifdef SH_ARCH_MAGIC_BIG
2296
    case SH_ARCH_MAGIC_BIG:
2297
    case SH_ARCH_MAGIC_LITTLE:
2298
#ifdef COFF_WITH_PE
2299
    case SH_ARCH_MAGIC_WINCE:
2300
#endif
2301
      arch = bfd_arch_sh;
2302
      break;
2303
#endif
2304
2305
#ifdef MIPS_ARCH_MAGIC_WINCE
2306
    case MIPS_ARCH_MAGIC_WINCE:
2307
      arch = bfd_arch_mips;
2308
      break;
2309
#endif
2310
2311
#ifdef SPARCMAGIC
2312
    case SPARCMAGIC:
2313
#ifdef LYNXCOFFMAGIC
2314
    case LYNXCOFFMAGIC:
2315
#endif
2316
      arch = bfd_arch_sparc;
2317
      break;
2318
#endif
2319
2320
#ifdef TIC30MAGIC
2321
    case TIC30MAGIC:
2322
      arch = bfd_arch_tic30;
2323
      break;
2324
#endif
2325
2326
#ifdef TICOFF0MAGIC
2327
#ifdef TICOFF_TARGET_ARCH
2328
      /* This TI COFF section should be used by all new TI COFF v0 targets.  */
2329
    case TICOFF0MAGIC:
2330
      arch = TICOFF_TARGET_ARCH;
2331
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
      break;
2333
#endif
2334
#endif
2335
2336
#ifdef TICOFF1MAGIC
2337
      /* This TI COFF section should be used by all new TI COFF v1/2 targets.  */
2338
      /* TI COFF1 and COFF2 use the target_id field to specify which arch.  */
2339
    case TICOFF1MAGIC:
2340
    case TICOFF2MAGIC:
2341
      switch (internal_f->f_target_id)
2342
  {
2343
#ifdef TI_TARGET_ID
2344
  case TI_TARGET_ID:
2345
    arch = TICOFF_TARGET_ARCH;
2346
    machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2347
    break;
2348
#endif
2349
  default:
2350
    arch = bfd_arch_obscure;
2351
    _bfd_error_handler
2352
      (_("unrecognized TI COFF target id '0x%x'"),
2353
       internal_f->f_target_id);
2354
    break;
2355
  }
2356
      break;
2357
#endif
2358
2359
#ifdef MCOREMAGIC
2360
    case MCOREMAGIC:
2361
      arch = bfd_arch_mcore;
2362
      break;
2363
#endif
2364
2365
951
    default:      /* Unreadable input file type.  */
2366
108
      arch = bfd_arch_obscure;
2367
108
      break;
2368
1.05k
    }
2369
2370
1.05k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
1.05k
  return true;
2372
1.05k
}
pei-arm.c:coff_set_arch_mach_hook
Line
Count
Source
2110
1.18k
{
2111
1.18k
  unsigned long machine;
2112
1.18k
  enum bfd_architecture arch;
2113
1.18k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
1.18k
  machine = 0;
2117
1.18k
  switch (internal_f->f_magic)
2118
1.18k
    {
2119
#ifdef I386MAGIC
2120
    case I386MAGIC:
2121
    case I386PTXMAGIC:
2122
    case I386AIXMAGIC:    /* Danbury PS/2 AIX C Compiler.  */
2123
    case LYNXCOFFMAGIC:
2124
    case I386_APPLE_MAGIC:
2125
    case I386_FREEBSD_MAGIC:
2126
    case I386_LINUX_MAGIC:
2127
    case I386_NETBSD_MAGIC:
2128
      arch = bfd_arch_i386;
2129
      break;
2130
#endif
2131
#ifdef AMD64MAGIC
2132
    case AMD64MAGIC:
2133
    case AMD64_APPLE_MAGIC:
2134
    case AMD64_FREEBSD_MAGIC:
2135
    case AMD64_LINUX_MAGIC:
2136
    case AMD64_NETBSD_MAGIC:
2137
      arch = bfd_arch_i386;
2138
      machine = bfd_mach_x86_64;
2139
      break;
2140
#endif
2141
#ifdef IA64MAGIC
2142
    case IA64MAGIC:
2143
      arch = bfd_arch_ia64;
2144
      break;
2145
#endif
2146
0
#ifdef ARMMAGIC
2147
929
    case ARMMAGIC:
2148
1.01k
    case ARMPEMAGIC:
2149
1.06k
    case THUMBPEMAGIC:
2150
1.06k
      arch = bfd_arch_arm;
2151
1.06k
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
1.06k
      if (machine == bfd_mach_arm_unknown)
2153
1.06k
  {
2154
1.06k
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
1.06k
      {
2156
60
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
80
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
61
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
452
      default:
2160
611
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
104
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
66
      case F_ARM_4T: machine = bfd_mach_arm_4T; break;
2163
        /* The COFF header does not have enough bits available
2164
     to cover all the different ARM architectures.  So
2165
     we interpret F_ARM_5, the highest flag value to mean
2166
     "the highest ARM architecture known to BFD" which is
2167
     currently the XScale.  */
2168
84
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
1.06k
      }
2170
1.06k
  }
2171
1.06k
      break;
2172
1.06k
#endif
2173
#ifdef AARCH64MAGIC
2174
    case AARCH64MAGIC:
2175
      arch = bfd_arch_aarch64;
2176
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
      break;
2178
#endif
2179
#ifdef LOONGARCH64MAGIC
2180
    case LOONGARCH64MAGIC:
2181
      arch = bfd_arch_loongarch;
2182
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
      break;
2184
#endif
2185
#ifdef Z80MAGIC
2186
    case Z80MAGIC:
2187
      arch = bfd_arch_z80;
2188
      switch (internal_f->f_flags & F_MACHMASK)
2189
  {
2190
  case bfd_mach_z80strict << 12:
2191
  case bfd_mach_z80 << 12:
2192
  case bfd_mach_z80n << 12:
2193
  case bfd_mach_z80full << 12:
2194
  case bfd_mach_r800 << 12:
2195
  case bfd_mach_gbz80 << 12:
2196
  case bfd_mach_z180 << 12:
2197
  case bfd_mach_ez80_z80 << 12:
2198
  case bfd_mach_ez80_adl << 12:
2199
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
    break;
2201
  default:
2202
    return false;
2203
  }
2204
      break;
2205
#endif
2206
#ifdef Z8KMAGIC
2207
    case Z8KMAGIC:
2208
      arch = bfd_arch_z8k;
2209
      switch (internal_f->f_flags & F_MACHMASK)
2210
  {
2211
  case F_Z8001:
2212
    machine = bfd_mach_z8001;
2213
    break;
2214
  case F_Z8002:
2215
    machine = bfd_mach_z8002;
2216
    break;
2217
  default:
2218
    return false;
2219
  }
2220
      break;
2221
#endif
2222
2223
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
    case U64_TOCMAGIC:
2226
    case U803XTOCMAGIC:
2227
#else
2228
    case U802ROMAGIC:
2229
    case U802WRMAGIC:
2230
    case U802TOCMAGIC:
2231
#endif
2232
      {
2233
  int cputype;
2234
2235
  if (xcoff_data (abfd)->cputype != -1)
2236
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
  else
2238
    {
2239
      /* We did not get a value from the a.out header.  If the
2240
         file has not been stripped, we may be able to get the
2241
         architecture information from the first symbol, if it
2242
         is a .file symbol.  */
2243
      if (obj_raw_syment_count (abfd) == 0)
2244
        cputype = 0;
2245
      else
2246
        {
2247
    bfd_byte *buf;
2248
    struct internal_syment sym;
2249
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
      return false;
2253
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
    if (buf == NULL)
2255
      return false;
2256
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
    if (sym.n_sclass == C_FILE)
2258
      cputype = sym.n_type & 0xff;
2259
    else
2260
      cputype = 0;
2261
    free (buf);
2262
        }
2263
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
  switch (cputype)
2267
    {
2268
    default:
2269
    case 0:
2270
      arch = bfd_xcoff_architecture (abfd);
2271
      machine = bfd_xcoff_machine (abfd);
2272
      break;
2273
2274
    case 1:
2275
      arch = bfd_arch_powerpc;
2276
      machine = bfd_mach_ppc_601;
2277
      break;
2278
    case 2: /* 64 bit PowerPC */
2279
      arch = bfd_arch_powerpc;
2280
      machine = bfd_mach_ppc_620;
2281
      break;
2282
    case 3:
2283
      arch = bfd_arch_powerpc;
2284
      machine = bfd_mach_ppc;
2285
      break;
2286
    case 4:
2287
      arch = bfd_arch_rs6000;
2288
      machine = bfd_mach_rs6k;
2289
      break;
2290
    }
2291
      }
2292
      break;
2293
#endif
2294
2295
#ifdef SH_ARCH_MAGIC_BIG
2296
    case SH_ARCH_MAGIC_BIG:
2297
    case SH_ARCH_MAGIC_LITTLE:
2298
#ifdef COFF_WITH_PE
2299
    case SH_ARCH_MAGIC_WINCE:
2300
#endif
2301
      arch = bfd_arch_sh;
2302
      break;
2303
#endif
2304
2305
#ifdef MIPS_ARCH_MAGIC_WINCE
2306
    case MIPS_ARCH_MAGIC_WINCE:
2307
      arch = bfd_arch_mips;
2308
      break;
2309
#endif
2310
2311
#ifdef SPARCMAGIC
2312
    case SPARCMAGIC:
2313
#ifdef LYNXCOFFMAGIC
2314
    case LYNXCOFFMAGIC:
2315
#endif
2316
      arch = bfd_arch_sparc;
2317
      break;
2318
#endif
2319
2320
#ifdef TIC30MAGIC
2321
    case TIC30MAGIC:
2322
      arch = bfd_arch_tic30;
2323
      break;
2324
#endif
2325
2326
#ifdef TICOFF0MAGIC
2327
#ifdef TICOFF_TARGET_ARCH
2328
      /* This TI COFF section should be used by all new TI COFF v0 targets.  */
2329
    case TICOFF0MAGIC:
2330
      arch = TICOFF_TARGET_ARCH;
2331
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
      break;
2333
#endif
2334
#endif
2335
2336
#ifdef TICOFF1MAGIC
2337
      /* This TI COFF section should be used by all new TI COFF v1/2 targets.  */
2338
      /* TI COFF1 and COFF2 use the target_id field to specify which arch.  */
2339
    case TICOFF1MAGIC:
2340
    case TICOFF2MAGIC:
2341
      switch (internal_f->f_target_id)
2342
  {
2343
#ifdef TI_TARGET_ID
2344
  case TI_TARGET_ID:
2345
    arch = TICOFF_TARGET_ARCH;
2346
    machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2347
    break;
2348
#endif
2349
  default:
2350
    arch = bfd_arch_obscure;
2351
    _bfd_error_handler
2352
      (_("unrecognized TI COFF target id '0x%x'"),
2353
       internal_f->f_target_id);
2354
    break;
2355
  }
2356
      break;
2357
#endif
2358
2359
#ifdef MCOREMAGIC
2360
    case MCOREMAGIC:
2361
      arch = bfd_arch_mcore;
2362
      break;
2363
#endif
2364
2365
1.06k
    default:      /* Unreadable input file type.  */
2366
114
      arch = bfd_arch_obscure;
2367
114
      break;
2368
1.18k
    }
2369
2370
1.18k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
1.18k
  return true;
2372
1.18k
}
pei-mcore.c:coff_set_arch_mach_hook
Line
Count
Source
2110
792
{
2111
792
  unsigned long machine;
2112
792
  enum bfd_architecture arch;
2113
792
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
792
  machine = 0;
2117
792
  switch (internal_f->f_magic)
2118
792
    {
2119
#ifdef I386MAGIC
2120
    case I386MAGIC:
2121
    case I386PTXMAGIC:
2122
    case I386AIXMAGIC:    /* Danbury PS/2 AIX C Compiler.  */
2123
    case LYNXCOFFMAGIC:
2124
    case I386_APPLE_MAGIC:
2125
    case I386_FREEBSD_MAGIC:
2126
    case I386_LINUX_MAGIC:
2127
    case I386_NETBSD_MAGIC:
2128
      arch = bfd_arch_i386;
2129
      break;
2130
#endif
2131
#ifdef AMD64MAGIC
2132
    case AMD64MAGIC:
2133
    case AMD64_APPLE_MAGIC:
2134
    case AMD64_FREEBSD_MAGIC:
2135
    case AMD64_LINUX_MAGIC:
2136
    case AMD64_NETBSD_MAGIC:
2137
      arch = bfd_arch_i386;
2138
      machine = bfd_mach_x86_64;
2139
      break;
2140
#endif
2141
#ifdef IA64MAGIC
2142
    case IA64MAGIC:
2143
      arch = bfd_arch_ia64;
2144
      break;
2145
#endif
2146
#ifdef ARMMAGIC
2147
    case ARMMAGIC:
2148
    case ARMPEMAGIC:
2149
    case THUMBPEMAGIC:
2150
      arch = bfd_arch_arm;
2151
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
      if (machine == bfd_mach_arm_unknown)
2153
  {
2154
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
      {
2156
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
      default:
2160
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
      case F_ARM_4T: machine = bfd_mach_arm_4T; break;
2163
        /* The COFF header does not have enough bits available
2164
     to cover all the different ARM architectures.  So
2165
     we interpret F_ARM_5, the highest flag value to mean
2166
     "the highest ARM architecture known to BFD" which is
2167
     currently the XScale.  */
2168
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
      }
2170
  }
2171
      break;
2172
#endif
2173
#ifdef AARCH64MAGIC
2174
    case AARCH64MAGIC:
2175
      arch = bfd_arch_aarch64;
2176
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
      break;
2178
#endif
2179
#ifdef LOONGARCH64MAGIC
2180
    case LOONGARCH64MAGIC:
2181
      arch = bfd_arch_loongarch;
2182
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
      break;
2184
#endif
2185
#ifdef Z80MAGIC
2186
    case Z80MAGIC:
2187
      arch = bfd_arch_z80;
2188
      switch (internal_f->f_flags & F_MACHMASK)
2189
  {
2190
  case bfd_mach_z80strict << 12:
2191
  case bfd_mach_z80 << 12:
2192
  case bfd_mach_z80n << 12:
2193
  case bfd_mach_z80full << 12:
2194
  case bfd_mach_r800 << 12:
2195
  case bfd_mach_gbz80 << 12:
2196
  case bfd_mach_z180 << 12:
2197
  case bfd_mach_ez80_z80 << 12:
2198
  case bfd_mach_ez80_adl << 12:
2199
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
    break;
2201
  default:
2202
    return false;
2203
  }
2204
      break;
2205
#endif
2206
#ifdef Z8KMAGIC
2207
    case Z8KMAGIC:
2208
      arch = bfd_arch_z8k;
2209
      switch (internal_f->f_flags & F_MACHMASK)
2210
  {
2211
  case F_Z8001:
2212
    machine = bfd_mach_z8001;
2213
    break;
2214
  case F_Z8002:
2215
    machine = bfd_mach_z8002;
2216
    break;
2217
  default:
2218
    return false;
2219
  }
2220
      break;
2221
#endif
2222
2223
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
    case U64_TOCMAGIC:
2226
    case U803XTOCMAGIC:
2227
#else
2228
    case U802ROMAGIC:
2229
    case U802WRMAGIC:
2230
    case U802TOCMAGIC:
2231
#endif
2232
      {
2233
  int cputype;
2234
2235
  if (xcoff_data (abfd)->cputype != -1)
2236
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
  else
2238
    {
2239
      /* We did not get a value from the a.out header.  If the
2240
         file has not been stripped, we may be able to get the
2241
         architecture information from the first symbol, if it
2242
         is a .file symbol.  */
2243
      if (obj_raw_syment_count (abfd) == 0)
2244
        cputype = 0;
2245
      else
2246
        {
2247
    bfd_byte *buf;
2248
    struct internal_syment sym;
2249
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
      return false;
2253
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
    if (buf == NULL)
2255
      return false;
2256
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
    if (sym.n_sclass == C_FILE)
2258
      cputype = sym.n_type & 0xff;
2259
    else
2260
      cputype = 0;
2261
    free (buf);
2262
        }
2263
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
  switch (cputype)
2267
    {
2268
    default:
2269
    case 0:
2270
      arch = bfd_xcoff_architecture (abfd);
2271
      machine = bfd_xcoff_machine (abfd);
2272
      break;
2273
2274
    case 1:
2275
      arch = bfd_arch_powerpc;
2276
      machine = bfd_mach_ppc_601;
2277
      break;
2278
    case 2: /* 64 bit PowerPC */
2279
      arch = bfd_arch_powerpc;
2280
      machine = bfd_mach_ppc_620;
2281
      break;
2282
    case 3:
2283
      arch = bfd_arch_powerpc;
2284
      machine = bfd_mach_ppc;
2285
      break;
2286
    case 4:
2287
      arch = bfd_arch_rs6000;
2288
      machine = bfd_mach_rs6k;
2289
      break;
2290
    }
2291
      }
2292
      break;
2293
#endif
2294
2295
#ifdef SH_ARCH_MAGIC_BIG
2296
    case SH_ARCH_MAGIC_BIG:
2297
    case SH_ARCH_MAGIC_LITTLE:
2298
#ifdef COFF_WITH_PE
2299
    case SH_ARCH_MAGIC_WINCE:
2300
#endif
2301
      arch = bfd_arch_sh;
2302
      break;
2303
#endif
2304
2305
#ifdef MIPS_ARCH_MAGIC_WINCE
2306
    case MIPS_ARCH_MAGIC_WINCE:
2307
      arch = bfd_arch_mips;
2308
      break;
2309
#endif
2310
2311
#ifdef SPARCMAGIC
2312
    case SPARCMAGIC:
2313
#ifdef LYNXCOFFMAGIC
2314
    case LYNXCOFFMAGIC:
2315
#endif
2316
      arch = bfd_arch_sparc;
2317
      break;
2318
#endif
2319
2320
#ifdef TIC30MAGIC
2321
    case TIC30MAGIC:
2322
      arch = bfd_arch_tic30;
2323
      break;
2324
#endif
2325
2326
#ifdef TICOFF0MAGIC
2327
#ifdef TICOFF_TARGET_ARCH
2328
      /* This TI COFF section should be used by all new TI COFF v0 targets.  */
2329
    case TICOFF0MAGIC:
2330
      arch = TICOFF_TARGET_ARCH;
2331
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
      break;
2333
#endif
2334
#endif
2335
2336
#ifdef TICOFF1MAGIC
2337
      /* This TI COFF section should be used by all new TI COFF v1/2 targets.  */
2338
      /* TI COFF1 and COFF2 use the target_id field to specify which arch.  */
2339
    case TICOFF1MAGIC:
2340
    case TICOFF2MAGIC:
2341
      switch (internal_f->f_target_id)
2342
  {
2343
#ifdef TI_TARGET_ID
2344
  case TI_TARGET_ID:
2345
    arch = TICOFF_TARGET_ARCH;
2346
    machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2347
    break;
2348
#endif
2349
  default:
2350
    arch = bfd_arch_obscure;
2351
    _bfd_error_handler
2352
      (_("unrecognized TI COFF target id '0x%x'"),
2353
       internal_f->f_target_id);
2354
    break;
2355
  }
2356
      break;
2357
#endif
2358
2359
0
#ifdef MCOREMAGIC
2360
792
    case MCOREMAGIC:
2361
792
      arch = bfd_arch_mcore;
2362
792
      break;
2363
0
#endif
2364
2365
0
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
792
    }
2369
2370
792
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
792
  return true;
2372
792
}
pei-sh.c:coff_set_arch_mach_hook
Line
Count
Source
2110
774
{
2111
774
  unsigned long machine;
2112
774
  enum bfd_architecture arch;
2113
774
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
774
  machine = 0;
2117
774
  switch (internal_f->f_magic)
2118
774
    {
2119
#ifdef I386MAGIC
2120
    case I386MAGIC:
2121
    case I386PTXMAGIC:
2122
    case I386AIXMAGIC:    /* Danbury PS/2 AIX C Compiler.  */
2123
    case LYNXCOFFMAGIC:
2124
    case I386_APPLE_MAGIC:
2125
    case I386_FREEBSD_MAGIC:
2126
    case I386_LINUX_MAGIC:
2127
    case I386_NETBSD_MAGIC:
2128
      arch = bfd_arch_i386;
2129
      break;
2130
#endif
2131
#ifdef AMD64MAGIC
2132
    case AMD64MAGIC:
2133
    case AMD64_APPLE_MAGIC:
2134
    case AMD64_FREEBSD_MAGIC:
2135
    case AMD64_LINUX_MAGIC:
2136
    case AMD64_NETBSD_MAGIC:
2137
      arch = bfd_arch_i386;
2138
      machine = bfd_mach_x86_64;
2139
      break;
2140
#endif
2141
#ifdef IA64MAGIC
2142
    case IA64MAGIC:
2143
      arch = bfd_arch_ia64;
2144
      break;
2145
#endif
2146
#ifdef ARMMAGIC
2147
    case ARMMAGIC:
2148
    case ARMPEMAGIC:
2149
    case THUMBPEMAGIC:
2150
      arch = bfd_arch_arm;
2151
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
      if (machine == bfd_mach_arm_unknown)
2153
  {
2154
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
      {
2156
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
      default:
2160
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
      case F_ARM_4T: machine = bfd_mach_arm_4T; break;
2163
        /* The COFF header does not have enough bits available
2164
     to cover all the different ARM architectures.  So
2165
     we interpret F_ARM_5, the highest flag value to mean
2166
     "the highest ARM architecture known to BFD" which is
2167
     currently the XScale.  */
2168
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
      }
2170
  }
2171
      break;
2172
#endif
2173
#ifdef AARCH64MAGIC
2174
    case AARCH64MAGIC:
2175
      arch = bfd_arch_aarch64;
2176
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
      break;
2178
#endif
2179
#ifdef LOONGARCH64MAGIC
2180
    case LOONGARCH64MAGIC:
2181
      arch = bfd_arch_loongarch;
2182
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
      break;
2184
#endif
2185
#ifdef Z80MAGIC
2186
    case Z80MAGIC:
2187
      arch = bfd_arch_z80;
2188
      switch (internal_f->f_flags & F_MACHMASK)
2189
  {
2190
  case bfd_mach_z80strict << 12:
2191
  case bfd_mach_z80 << 12:
2192
  case bfd_mach_z80n << 12:
2193
  case bfd_mach_z80full << 12:
2194
  case bfd_mach_r800 << 12:
2195
  case bfd_mach_gbz80 << 12:
2196
  case bfd_mach_z180 << 12:
2197
  case bfd_mach_ez80_z80 << 12:
2198
  case bfd_mach_ez80_adl << 12:
2199
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
    break;
2201
  default:
2202
    return false;
2203
  }
2204
      break;
2205
#endif
2206
#ifdef Z8KMAGIC
2207
    case Z8KMAGIC:
2208
      arch = bfd_arch_z8k;
2209
      switch (internal_f->f_flags & F_MACHMASK)
2210
  {
2211
  case F_Z8001:
2212
    machine = bfd_mach_z8001;
2213
    break;
2214
  case F_Z8002:
2215
    machine = bfd_mach_z8002;
2216
    break;
2217
  default:
2218
    return false;
2219
  }
2220
      break;
2221
#endif
2222
2223
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
    case U64_TOCMAGIC:
2226
    case U803XTOCMAGIC:
2227
#else
2228
    case U802ROMAGIC:
2229
    case U802WRMAGIC:
2230
    case U802TOCMAGIC:
2231
#endif
2232
      {
2233
  int cputype;
2234
2235
  if (xcoff_data (abfd)->cputype != -1)
2236
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
  else
2238
    {
2239
      /* We did not get a value from the a.out header.  If the
2240
         file has not been stripped, we may be able to get the
2241
         architecture information from the first symbol, if it
2242
         is a .file symbol.  */
2243
      if (obj_raw_syment_count (abfd) == 0)
2244
        cputype = 0;
2245
      else
2246
        {
2247
    bfd_byte *buf;
2248
    struct internal_syment sym;
2249
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
      return false;
2253
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
    if (buf == NULL)
2255
      return false;
2256
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
    if (sym.n_sclass == C_FILE)
2258
      cputype = sym.n_type & 0xff;
2259
    else
2260
      cputype = 0;
2261
    free (buf);
2262
        }
2263
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
  switch (cputype)
2267
    {
2268
    default:
2269
    case 0:
2270
      arch = bfd_xcoff_architecture (abfd);
2271
      machine = bfd_xcoff_machine (abfd);
2272
      break;
2273
2274
    case 1:
2275
      arch = bfd_arch_powerpc;
2276
      machine = bfd_mach_ppc_601;
2277
      break;
2278
    case 2: /* 64 bit PowerPC */
2279
      arch = bfd_arch_powerpc;
2280
      machine = bfd_mach_ppc_620;
2281
      break;
2282
    case 3:
2283
      arch = bfd_arch_powerpc;
2284
      machine = bfd_mach_ppc;
2285
      break;
2286
    case 4:
2287
      arch = bfd_arch_rs6000;
2288
      machine = bfd_mach_rs6k;
2289
      break;
2290
    }
2291
      }
2292
      break;
2293
#endif
2294
2295
0
#ifdef SH_ARCH_MAGIC_BIG
2296
647
    case SH_ARCH_MAGIC_BIG:
2297
650
    case SH_ARCH_MAGIC_LITTLE:
2298
650
#ifdef COFF_WITH_PE
2299
774
    case SH_ARCH_MAGIC_WINCE:
2300
774
#endif
2301
774
      arch = bfd_arch_sh;
2302
774
      break;
2303
0
#endif
2304
2305
#ifdef MIPS_ARCH_MAGIC_WINCE
2306
    case MIPS_ARCH_MAGIC_WINCE:
2307
      arch = bfd_arch_mips;
2308
      break;
2309
#endif
2310
2311
#ifdef SPARCMAGIC
2312
    case SPARCMAGIC:
2313
#ifdef LYNXCOFFMAGIC
2314
    case LYNXCOFFMAGIC:
2315
#endif
2316
      arch = bfd_arch_sparc;
2317
      break;
2318
#endif
2319
2320
#ifdef TIC30MAGIC
2321
    case TIC30MAGIC:
2322
      arch = bfd_arch_tic30;
2323
      break;
2324
#endif
2325
2326
#ifdef TICOFF0MAGIC
2327
#ifdef TICOFF_TARGET_ARCH
2328
      /* This TI COFF section should be used by all new TI COFF v0 targets.  */
2329
    case TICOFF0MAGIC:
2330
      arch = TICOFF_TARGET_ARCH;
2331
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
      break;
2333
#endif
2334
#endif
2335
2336
#ifdef TICOFF1MAGIC
2337
      /* This TI COFF section should be used by all new TI COFF v1/2 targets.  */
2338
      /* TI COFF1 and COFF2 use the target_id field to specify which arch.  */
2339
    case TICOFF1MAGIC:
2340
    case TICOFF2MAGIC:
2341
      switch (internal_f->f_target_id)
2342
  {
2343
#ifdef TI_TARGET_ID
2344
  case TI_TARGET_ID:
2345
    arch = TICOFF_TARGET_ARCH;
2346
    machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2347
    break;
2348
#endif
2349
  default:
2350
    arch = bfd_arch_obscure;
2351
    _bfd_error_handler
2352
      (_("unrecognized TI COFF target id '0x%x'"),
2353
       internal_f->f_target_id);
2354
    break;
2355
  }
2356
      break;
2357
#endif
2358
2359
#ifdef MCOREMAGIC
2360
    case MCOREMAGIC:
2361
      arch = bfd_arch_mcore;
2362
      break;
2363
#endif
2364
2365
0
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
774
    }
2369
2370
774
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
774
  return true;
2372
774
}
2373
2374
static bool
2375
symname_in_debug_hook (bfd *abfd ATTRIBUTE_UNUSED,
2376
           struct internal_syment *sym ATTRIBUTE_UNUSED)
2377
0
{
2378
#ifdef SYMNAME_IN_DEBUG
2379
0
  return SYMNAME_IN_DEBUG (sym) != 0;
2380
#else
2381
  return false;
2382
#endif
2383
0
}
Unexecuted instantiation: pei-i386.c:symname_in_debug_hook
Unexecuted instantiation: pe-x86_64.c:symname_in_debug_hook
Unexecuted instantiation: pei-x86_64.c:symname_in_debug_hook
Unexecuted instantiation: coff-x86_64.c:symname_in_debug_hook
Unexecuted instantiation: coff64-rs6000.c:symname_in_debug_hook
Unexecuted instantiation: pei-aarch64.c:symname_in_debug_hook
Unexecuted instantiation: pe-aarch64.c:symname_in_debug_hook
Unexecuted instantiation: pei-ia64.c:symname_in_debug_hook
Unexecuted instantiation: pei-loongarch64.c:symname_in_debug_hook
Unexecuted instantiation: cf-i386lynx.c:symname_in_debug_hook
Unexecuted instantiation: coff-go32.c:symname_in_debug_hook
Unexecuted instantiation: coff-i386.c:symname_in_debug_hook
Unexecuted instantiation: coff-rs6000.c:symname_in_debug_hook
Unexecuted instantiation: coff-sh.c:symname_in_debug_hook
Unexecuted instantiation: coff-stgo32.c:symname_in_debug_hook
Unexecuted instantiation: coff-tic30.c:symname_in_debug_hook
Unexecuted instantiation: coff-tic4x.c:symname_in_debug_hook
Unexecuted instantiation: coff-tic54x.c:symname_in_debug_hook
Unexecuted instantiation: coff-z80.c:symname_in_debug_hook
Unexecuted instantiation: coff-z8k.c:symname_in_debug_hook
Unexecuted instantiation: pe-arm-wince.c:symname_in_debug_hook
Unexecuted instantiation: pe-arm.c:symname_in_debug_hook
Unexecuted instantiation: pe-i386.c:symname_in_debug_hook
Unexecuted instantiation: pe-mcore.c:symname_in_debug_hook
Unexecuted instantiation: pe-sh.c:symname_in_debug_hook
Unexecuted instantiation: pei-arm-wince.c:symname_in_debug_hook
Unexecuted instantiation: pei-arm.c:symname_in_debug_hook
Unexecuted instantiation: pei-mcore.c:symname_in_debug_hook
Unexecuted instantiation: pei-sh.c:symname_in_debug_hook
2384
2385
#ifdef RS6000COFF_C
2386
2387
#ifdef XCOFF64
2388
#define FORCE_SYMNAMES_IN_STRINGS
2389
#endif
2390
2391
/* Handle the csect auxent of a C_EXT, C_AIX_WEAKEXT or C_HIDEXT symbol.  */
2392
2393
static bool
2394
coff_pointerize_aux_hook (bfd *abfd ATTRIBUTE_UNUSED,
2395
        combined_entry_type *table_base,
2396
        combined_entry_type *symbol,
2397
        unsigned int indaux,
2398
        combined_entry_type *aux)
2399
0
{
2400
0
  BFD_ASSERT (symbol->is_sym);
2401
0
  int n_sclass = symbol->u.syment.n_sclass;
2402
2403
0
  if (CSECT_SYM_P (n_sclass)
2404
0
      && indaux + 1 == symbol->u.syment.n_numaux)
2405
0
    {
2406
0
      BFD_ASSERT (! aux->is_sym);
2407
0
      if (SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp) == XTY_LD
2408
0
    && aux->u.auxent.x_csect.x_scnlen.u64 < obj_raw_syment_count (abfd))
2409
0
  {
2410
0
    aux->u.auxent.x_csect.x_scnlen.p =
2411
0
      table_base + aux->u.auxent.x_csect.x_scnlen.u64;
2412
0
    aux->fix_scnlen = 1;
2413
0
  }
2414
2415
      /* Return TRUE to indicate that the caller should not do any
2416
   further work on this auxent.  */
2417
0
      return true;
2418
0
    }
2419
2420
  /* Return FALSE to indicate that this auxent should be handled by
2421
     the caller.  */
2422
0
  return false;
2423
0
}
Unexecuted instantiation: coff64-rs6000.c:coff_pointerize_aux_hook
Unexecuted instantiation: coff-rs6000.c:coff_pointerize_aux_hook
2424
2425
#else
2426
#define coff_pointerize_aux_hook 0
2427
#endif /* ! RS6000COFF_C */
2428
2429
/* Print an aux entry.  This returns TRUE if it has printed it.  */
2430
2431
static bool
2432
coff_print_aux (bfd *abfd ATTRIBUTE_UNUSED,
2433
    FILE *file ATTRIBUTE_UNUSED,
2434
    combined_entry_type *table_base ATTRIBUTE_UNUSED,
2435
    combined_entry_type *symbol ATTRIBUTE_UNUSED,
2436
    combined_entry_type *aux ATTRIBUTE_UNUSED,
2437
    unsigned int indaux ATTRIBUTE_UNUSED)
2438
0
{
2439
0
  BFD_ASSERT (symbol->is_sym);
2440
0
  BFD_ASSERT (! aux->is_sym);
2441
#ifdef RS6000COFF_C
2442
0
  if (CSECT_SYM_P (symbol->u.syment.n_sclass)
2443
0
      && indaux + 1 == symbol->u.syment.n_numaux)
2444
0
    {
2445
      /* This is a csect entry.  */
2446
0
      fprintf (file, "AUX ");
2447
0
      if (SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp) != XTY_LD)
2448
0
  {
2449
0
    BFD_ASSERT (! aux->fix_scnlen);
2450
0
    fprintf (file, "val %5" PRIu64,
2451
0
       aux->u.auxent.x_csect.x_scnlen.u64);
2452
0
  }
2453
0
      else
2454
0
  {
2455
0
    fprintf (file, "indx ");
2456
0
    if (! aux->fix_scnlen)
2457
0
      fprintf (file, "%4" PRIu64,
2458
0
         aux->u.auxent.x_csect.x_scnlen.u64);
2459
0
    else
2460
0
      fprintf (file, "%4ld",
2461
0
         (long) (aux->u.auxent.x_csect.x_scnlen.p - table_base));
2462
0
  }
2463
0
      fprintf (file,
2464
0
         " prmhsh %u snhsh %u typ %d algn %d clss %u stb %u snstb %u",
2465
0
         aux->u.auxent.x_csect.x_parmhash,
2466
0
         (unsigned int) aux->u.auxent.x_csect.x_snhash,
2467
0
         SMTYP_SMTYP (aux->u.auxent.x_csect.x_smtyp),
2468
0
         SMTYP_ALIGN (aux->u.auxent.x_csect.x_smtyp),
2469
0
         (unsigned int) aux->u.auxent.x_csect.x_smclas,
2470
0
         aux->u.auxent.x_csect.x_stab,
2471
0
         (unsigned int) aux->u.auxent.x_csect.x_snstab);
2472
0
      return true;
2473
0
    }
2474
0
#endif
2475
2476
  /* Return FALSE to indicate that no special action was taken.  */
2477
0
  return false;
2478
0
}
Unexecuted instantiation: pei-i386.c:coff_print_aux
Unexecuted instantiation: pe-x86_64.c:coff_print_aux
Unexecuted instantiation: pei-x86_64.c:coff_print_aux
Unexecuted instantiation: coff-x86_64.c:coff_print_aux
Unexecuted instantiation: coff64-rs6000.c:coff_print_aux
Unexecuted instantiation: pei-aarch64.c:coff_print_aux
Unexecuted instantiation: pe-aarch64.c:coff_print_aux
Unexecuted instantiation: pei-ia64.c:coff_print_aux
Unexecuted instantiation: pei-loongarch64.c:coff_print_aux
Unexecuted instantiation: cf-i386lynx.c:coff_print_aux
Unexecuted instantiation: coff-go32.c:coff_print_aux
Unexecuted instantiation: coff-i386.c:coff_print_aux
Unexecuted instantiation: coff-rs6000.c:coff_print_aux
Unexecuted instantiation: coff-sh.c:coff_print_aux
Unexecuted instantiation: coff-stgo32.c:coff_print_aux
Unexecuted instantiation: coff-tic30.c:coff_print_aux
Unexecuted instantiation: coff-tic4x.c:coff_print_aux
Unexecuted instantiation: coff-tic54x.c:coff_print_aux
Unexecuted instantiation: coff-z80.c:coff_print_aux
Unexecuted instantiation: coff-z8k.c:coff_print_aux
Unexecuted instantiation: pe-arm-wince.c:coff_print_aux
Unexecuted instantiation: pe-arm.c:coff_print_aux
Unexecuted instantiation: pe-i386.c:coff_print_aux
Unexecuted instantiation: pe-mcore.c:coff_print_aux
Unexecuted instantiation: pe-sh.c:coff_print_aux
Unexecuted instantiation: pei-arm-wince.c:coff_print_aux
Unexecuted instantiation: pei-arm.c:coff_print_aux
Unexecuted instantiation: pei-mcore.c:coff_print_aux
Unexecuted instantiation: pei-sh.c:coff_print_aux
2479
2480
/*
2481
SUBSUBSECTION
2482
  Writing relocations
2483
2484
  To write relocations, the back end steps though the
2485
  canonical relocation table and create an
2486
  @code{internal_reloc}. The symbol index to use is removed from
2487
  the @code{offset} field in the symbol table supplied.  The
2488
  address comes directly from the sum of the section base
2489
  address and the relocation offset; the type is dug directly
2490
  from the howto field.  Then the @code{internal_reloc} is
2491
  swapped into the shape of an @code{external_reloc} and written
2492
  out to disk.
2493
2494
*/
2495
2496
#ifdef TARG_AUX
2497
2498
2499
/* AUX's ld wants relocations to be sorted.  */
2500
static int
2501
compare_arelent_ptr (const void * x, const void * y)
2502
{
2503
  const arelent **a = (const arelent **) x;
2504
  const arelent **b = (const arelent **) y;
2505
  bfd_size_type aadr = (*a)->address;
2506
  bfd_size_type badr = (*b)->address;
2507
2508
  return (aadr < badr ? -1 : badr < aadr ? 1 : 0);
2509
}
2510
2511
#endif /* TARG_AUX */
2512
2513
static bool
2514
coff_write_relocs (bfd * abfd, int first_undef)
2515
0
{
2516
0
  asection *s;
2517
2518
0
  for (s = abfd->sections; s != NULL; s = s->next)
2519
0
    {
2520
0
      unsigned int i;
2521
0
      struct external_reloc dst;
2522
0
      arelent **p;
2523
2524
0
#ifndef TARG_AUX
2525
0
      p = s->orelocation;
2526
#else
2527
      {
2528
  /* Sort relocations before we write them out.  */
2529
  bfd_size_type amt;
2530
2531
  amt = s->reloc_count;
2532
  amt *= sizeof (arelent *);
2533
  p = bfd_malloc (amt);
2534
  if (p == NULL)
2535
    {
2536
      if (s->reloc_count > 0)
2537
        return false;
2538
    }
2539
  else
2540
    {
2541
      memcpy (p, s->orelocation, (size_t) amt);
2542
      qsort (p, s->reloc_count, sizeof (arelent *), compare_arelent_ptr);
2543
    }
2544
      }
2545
#endif
2546
2547
0
      if (bfd_seek (abfd, s->rel_filepos, SEEK_SET) != 0)
2548
0
  return false;
2549
2550
#ifdef COFF_WITH_EXTENDED_RELOC_COUNTER
2551
0
      if ((obj_pe (abfd) || obj_go32 (abfd)) && s->reloc_count >= 0xffff)
2552
0
  {
2553
    /* Encode real count here as first reloc.  */
2554
0
    struct internal_reloc n;
2555
2556
0
    memset (& n, 0, sizeof (n));
2557
    /* Add one to count *this* reloc (grr).  */
2558
0
    n.r_vaddr = s->reloc_count + 1;
2559
0
    coff_swap_reloc_out (abfd, &n, &dst);
2560
0
    if (bfd_bwrite (& dst, (bfd_size_type) bfd_coff_relsz (abfd),
2561
0
        abfd) != bfd_coff_relsz (abfd))
2562
0
      return false;
2563
0
  }
2564
0
#endif
2565
2566
0
      for (i = 0; i < s->reloc_count; i++)
2567
0
  {
2568
0
    struct internal_reloc n;
2569
0
    arelent *q = p[i];
2570
2571
0
    memset (& n, 0, sizeof (n));
2572
2573
    /* Now we've renumbered the symbols we know where the
2574
       undefined symbols live in the table.  Check the reloc
2575
       entries for symbols who's output bfd isn't the right one.
2576
       This is because the symbol was undefined (which means
2577
       that all the pointers are never made to point to the same
2578
       place). This is a bad thing,'cause the symbols attached
2579
       to the output bfd are indexed, so that the relocation
2580
       entries know which symbol index they point to.  So we
2581
       have to look up the output symbol here.  */
2582
2583
0
    if (q->sym_ptr_ptr[0] != NULL && q->sym_ptr_ptr[0]->the_bfd != abfd)
2584
0
      {
2585
0
        int j;
2586
0
        const char *sname = q->sym_ptr_ptr[0]->name;
2587
0
        asymbol **outsyms = abfd->outsymbols;
2588
2589
0
        for (j = first_undef; outsyms[j]; j++)
2590
0
    {
2591
0
      const char *intable = outsyms[j]->name;
2592
2593
0
      if (strcmp (intable, sname) == 0)
2594
0
        {
2595
          /* Got a hit, so repoint the reloc.  */
2596
0
          q->sym_ptr_ptr = outsyms + j;
2597
0
          break;
2598
0
        }
2599
0
    }
2600
0
      }
2601
2602
0
    n.r_vaddr = q->address + s->vma;
2603
2604
#ifdef R_IHCONST
2605
    /* The 29k const/consth reloc pair is a real kludge.  The consth
2606
       part doesn't have a symbol; it has an offset.  So rebuilt
2607
       that here.  */
2608
    if (q->howto->type == R_IHCONST)
2609
      n.r_symndx = q->addend;
2610
    else
2611
#endif
2612
0
      if (q->sym_ptr_ptr && q->sym_ptr_ptr[0] != NULL)
2613
0
        {
2614
#ifdef SECTION_RELATIVE_ABSOLUTE_SYMBOL_P
2615
0
    if (SECTION_RELATIVE_ABSOLUTE_SYMBOL_P (q, s))
2616
#else
2617
0
    if ((*q->sym_ptr_ptr)->section == bfd_abs_section_ptr
2618
0
        && ((*q->sym_ptr_ptr)->flags & BSF_SECTION_SYM) != 0)
2619
0
#endif
2620
      /* This is a relocation relative to the absolute symbol.  */
2621
0
      n.r_symndx = -1;
2622
0
    else
2623
0
      {
2624
0
        n.r_symndx = get_index ((*(q->sym_ptr_ptr)));
2625
        /* Check to see if the symbol reloc points to a symbol
2626
           we don't have in our symbol table.  */
2627
0
        if (n.r_symndx > obj_conv_table_size (abfd))
2628
0
          {
2629
0
      bfd_set_error (bfd_error_bad_value);
2630
      /* xgettext:c-format */
2631
0
      _bfd_error_handler (_("%pB: reloc against a non-existent"
2632
0
                " symbol index: %ld"),
2633
0
              abfd, n.r_symndx);
2634
0
      return false;
2635
0
          }
2636
0
      }
2637
0
        }
2638
2639
#ifdef SWAP_OUT_RELOC_OFFSET
2640
0
    n.r_offset = q->addend;
2641
0
#endif
2642
2643
#ifdef SELECT_RELOC
2644
    /* Work out reloc type from what is required.  */
2645
0
    if (q->howto)
2646
0
      SELECT_RELOC (n, q->howto);
2647
#else
2648
0
    if (q->howto)
2649
0
      n.r_type = q->howto->type;
2650
#endif
2651
0
    coff_swap_reloc_out (abfd, &n, &dst);
2652
2653
0
    if (bfd_bwrite (& dst, (bfd_size_type) bfd_coff_relsz (abfd),
2654
0
       abfd) != bfd_coff_relsz (abfd))
2655
0
      return false;
2656
0
  }
2657
2658
#ifdef TARG_AUX
2659
      free (p);
2660
#endif
2661
0
    }
2662
2663
0
  return true;
2664
0
}
Unexecuted instantiation: pei-i386.c:coff_write_relocs
Unexecuted instantiation: pe-x86_64.c:coff_write_relocs
Unexecuted instantiation: pei-x86_64.c:coff_write_relocs
Unexecuted instantiation: coff-x86_64.c:coff_write_relocs
Unexecuted instantiation: coff64-rs6000.c:coff_write_relocs
Unexecuted instantiation: pei-aarch64.c:coff_write_relocs
Unexecuted instantiation: pe-aarch64.c:coff_write_relocs
Unexecuted instantiation: pei-ia64.c:coff_write_relocs
Unexecuted instantiation: pei-loongarch64.c:coff_write_relocs
Unexecuted instantiation: cf-i386lynx.c:coff_write_relocs
Unexecuted instantiation: coff-go32.c:coff_write_relocs
Unexecuted instantiation: coff-i386.c:coff_write_relocs
Unexecuted instantiation: coff-rs6000.c:coff_write_relocs
Unexecuted instantiation: coff-sh.c:coff_write_relocs
Unexecuted instantiation: coff-stgo32.c:coff_write_relocs
Unexecuted instantiation: coff-tic30.c:coff_write_relocs
Unexecuted instantiation: coff-tic4x.c:coff_write_relocs
Unexecuted instantiation: coff-tic54x.c:coff_write_relocs
Unexecuted instantiation: coff-z80.c:coff_write_relocs
Unexecuted instantiation: coff-z8k.c:coff_write_relocs
Unexecuted instantiation: pe-arm-wince.c:coff_write_relocs
Unexecuted instantiation: pe-arm.c:coff_write_relocs
Unexecuted instantiation: pe-i386.c:coff_write_relocs
Unexecuted instantiation: pe-mcore.c:coff_write_relocs
Unexecuted instantiation: pe-sh.c:coff_write_relocs
Unexecuted instantiation: pei-arm-wince.c:coff_write_relocs
Unexecuted instantiation: pei-arm.c:coff_write_relocs
Unexecuted instantiation: pei-mcore.c:coff_write_relocs
Unexecuted instantiation: pei-sh.c:coff_write_relocs
2665
2666
/* Set flags and magic number of a coff file from architecture and machine
2667
   type.  Result is TRUE if we can represent the arch&type, FALSE if not.  */
2668
2669
static bool
2670
coff_set_flags (bfd * abfd,
2671
    unsigned int *magicp ATTRIBUTE_UNUSED,
2672
    unsigned short *flagsp ATTRIBUTE_UNUSED)
2673
0
{
2674
0
  switch (bfd_get_arch (abfd))
2675
0
    {
2676
#ifdef Z80MAGIC
2677
0
    case bfd_arch_z80:
2678
0
      *magicp = Z80MAGIC;
2679
0
      switch (bfd_get_mach (abfd))
2680
0
  {
2681
0
  case bfd_mach_z80strict:
2682
0
  case bfd_mach_z80:
2683
0
  case bfd_mach_z80n:
2684
0
  case bfd_mach_z80full:
2685
0
  case bfd_mach_r800:
2686
0
  case bfd_mach_gbz80:
2687
0
  case bfd_mach_z180:
2688
0
  case bfd_mach_ez80_z80:
2689
0
  case bfd_mach_ez80_adl:
2690
0
    *flagsp = bfd_get_mach (abfd) << 12;
2691
0
    break;
2692
0
  default:
2693
0
    return false;
2694
0
  }
2695
0
      return true;
2696
0
#endif
2697
2698
#ifdef Z8KMAGIC
2699
0
    case bfd_arch_z8k:
2700
0
      *magicp = Z8KMAGIC;
2701
2702
0
      switch (bfd_get_mach (abfd))
2703
0
  {
2704
0
  case bfd_mach_z8001: *flagsp = F_Z8001; break;
2705
0
  case bfd_mach_z8002: *flagsp = F_Z8002; break;
2706
0
  default:       return false;
2707
0
  }
2708
0
      return true;
2709
0
#endif
2710
2711
#ifdef TIC30MAGIC
2712
0
    case bfd_arch_tic30:
2713
0
      *magicp = TIC30MAGIC;
2714
0
      return true;
2715
0
#endif
2716
2717
#ifdef TICOFF_DEFAULT_MAGIC
2718
0
    case TICOFF_TARGET_ARCH:
2719
      /* If there's no indication of which version we want, use the default.  */
2720
0
      if (!abfd->xvec )
2721
0
  *magicp = TICOFF_DEFAULT_MAGIC;
2722
0
      else
2723
0
  {
2724
    /* We may want to output in a different COFF version.  */
2725
0
    switch (abfd->xvec->name[4])
2726
0
      {
2727
0
      case '0':
2728
0
        *magicp = TICOFF0MAGIC;
2729
0
        break;
2730
0
      case '1':
2731
0
        *magicp = TICOFF1MAGIC;
2732
0
        break;
2733
0
      case '2':
2734
0
        *magicp = TICOFF2MAGIC;
2735
0
        break;
2736
0
      default:
2737
0
        return false;
2738
0
      }
2739
0
  }
2740
0
      TICOFF_TARGET_MACHINE_SET (flagsp, bfd_get_mach (abfd));
2741
0
      return true;
2742
0
#endif
2743
2744
#ifdef AARCH64MAGIC
2745
0
    case bfd_arch_aarch64:
2746
0
      * magicp = AARCH64MAGIC;
2747
0
      return true;
2748
0
#endif
2749
2750
#ifdef LOONGARCH64MAGIC
2751
0
    case bfd_arch_loongarch:
2752
0
      * magicp = LOONGARCH64MAGIC;
2753
0
      return true;
2754
0
#endif
2755
2756
#ifdef ARMMAGIC
2757
0
    case bfd_arch_arm:
2758
#ifdef ARM_WINCE
2759
      * magicp = ARMPEMAGIC;
2760
#else
2761
0
      * magicp = ARMMAGIC;
2762
0
#endif
2763
0
      * flagsp = 0;
2764
0
      if (APCS_SET (abfd))
2765
0
  {
2766
0
    if (APCS_26_FLAG (abfd))
2767
0
      * flagsp |= F_APCS26;
2768
2769
0
    if (APCS_FLOAT_FLAG (abfd))
2770
0
      * flagsp |= F_APCS_FLOAT;
2771
2772
0
    if (PIC_FLAG (abfd))
2773
0
      * flagsp |= F_PIC;
2774
0
  }
2775
0
      if (INTERWORK_SET (abfd) && INTERWORK_FLAG (abfd))
2776
0
  * flagsp |= F_INTERWORK;
2777
0
      switch (bfd_get_mach (abfd))
2778
0
  {
2779
0
  case bfd_mach_arm_2:  * flagsp |= F_ARM_2;  break;
2780
0
  case bfd_mach_arm_2a: * flagsp |= F_ARM_2a; break;
2781
0
  case bfd_mach_arm_3:  * flagsp |= F_ARM_3;  break;
2782
0
  case bfd_mach_arm_3M: * flagsp |= F_ARM_3M; break;
2783
0
  case bfd_mach_arm_4:  * flagsp |= F_ARM_4;  break;
2784
0
  case bfd_mach_arm_4T: * flagsp |= F_ARM_4T; break;
2785
0
  case bfd_mach_arm_5:  * flagsp |= F_ARM_5;  break;
2786
    /* FIXME: we do not have F_ARM vaues greater than F_ARM_5.
2787
       See also the comment in coff_set_arch_mach_hook().  */
2788
0
  case bfd_mach_arm_5T: * flagsp |= F_ARM_5;  break;
2789
0
  case bfd_mach_arm_5TE: * flagsp |= F_ARM_5; break;
2790
0
  case bfd_mach_arm_XScale: * flagsp |= F_ARM_5; break;
2791
0
  }
2792
0
      return true;
2793
0
#endif
2794
2795
#if defined(I386MAGIC) || defined(AMD64MAGIC)
2796
0
    case bfd_arch_i386:
2797
#if defined(I386MAGIC)
2798
0
      *magicp = I386MAGIC;
2799
#endif
2800
#if defined LYNXOS
2801
      /* Just overwrite the usual value if we're doing Lynx.  */
2802
0
      *magicp = LYNXCOFFMAGIC;
2803
#endif
2804
#if defined AMD64MAGIC
2805
0
      *magicp = AMD64MAGIC;
2806
#endif
2807
0
      return true;
2808
0
#endif
2809
2810
#ifdef IA64MAGIC
2811
0
    case bfd_arch_ia64:
2812
0
      *magicp = IA64MAGIC;
2813
0
      return true;
2814
0
#endif
2815
2816
#ifdef SH_ARCH_MAGIC_BIG
2817
0
    case bfd_arch_sh:
2818
#ifdef COFF_IMAGE_WITH_PE
2819
0
      *magicp = SH_ARCH_MAGIC_WINCE;
2820
#else
2821
0
      if (bfd_big_endian (abfd))
2822
0
  *magicp = SH_ARCH_MAGIC_BIG;
2823
0
      else
2824
0
  *magicp = SH_ARCH_MAGIC_LITTLE;
2825
#endif
2826
0
      return true;
2827
0
#endif
2828
2829
#ifdef MIPS_ARCH_MAGIC_WINCE
2830
    case bfd_arch_mips:
2831
      *magicp = MIPS_ARCH_MAGIC_WINCE;
2832
      return true;
2833
#endif
2834
2835
#ifdef SPARCMAGIC
2836
    case bfd_arch_sparc:
2837
      *magicp = SPARCMAGIC;
2838
#ifdef LYNXOS
2839
      /* Just overwrite the usual value if we're doing Lynx.  */
2840
      *magicp = LYNXCOFFMAGIC;
2841
#endif
2842
      return true;
2843
#endif
2844
2845
#ifdef RS6000COFF_C
2846
0
    case bfd_arch_rs6000:
2847
0
    case bfd_arch_powerpc:
2848
0
      BFD_ASSERT (bfd_get_flavour (abfd) == bfd_target_xcoff_flavour);
2849
0
      *magicp = bfd_xcoff_magic_number (abfd);
2850
0
      return true;
2851
0
#endif
2852
2853
#ifdef MCOREMAGIC
2854
0
    case bfd_arch_mcore:
2855
0
      * magicp = MCOREMAGIC;
2856
0
      return true;
2857
0
#endif
2858
2859
0
    default:      /* Unknown architecture.  */
2860
0
      break;
2861
0
    }
2862
2863
0
  return false;
2864
0
}
Unexecuted instantiation: pei-i386.c:coff_set_flags
Unexecuted instantiation: pe-x86_64.c:coff_set_flags
Unexecuted instantiation: pei-x86_64.c:coff_set_flags
Unexecuted instantiation: coff-x86_64.c:coff_set_flags
Unexecuted instantiation: coff64-rs6000.c:coff_set_flags
Unexecuted instantiation: pei-aarch64.c:coff_set_flags
Unexecuted instantiation: pe-aarch64.c:coff_set_flags
Unexecuted instantiation: pei-ia64.c:coff_set_flags
Unexecuted instantiation: pei-loongarch64.c:coff_set_flags
Unexecuted instantiation: cf-i386lynx.c:coff_set_flags
Unexecuted instantiation: coff-go32.c:coff_set_flags
Unexecuted instantiation: coff-i386.c:coff_set_flags
Unexecuted instantiation: coff-rs6000.c:coff_set_flags
Unexecuted instantiation: coff-sh.c:coff_set_flags
Unexecuted instantiation: coff-stgo32.c:coff_set_flags
Unexecuted instantiation: coff-tic30.c:coff_set_flags
Unexecuted instantiation: coff-tic4x.c:coff_set_flags
Unexecuted instantiation: coff-tic54x.c:coff_set_flags
Unexecuted instantiation: coff-z80.c:coff_set_flags
Unexecuted instantiation: coff-z8k.c:coff_set_flags
Unexecuted instantiation: pe-arm-wince.c:coff_set_flags
Unexecuted instantiation: pe-arm.c:coff_set_flags
Unexecuted instantiation: pe-i386.c:coff_set_flags
Unexecuted instantiation: pe-mcore.c:coff_set_flags
Unexecuted instantiation: pe-sh.c:coff_set_flags
Unexecuted instantiation: pei-arm-wince.c:coff_set_flags
Unexecuted instantiation: pei-arm.c:coff_set_flags
Unexecuted instantiation: pei-mcore.c:coff_set_flags
Unexecuted instantiation: pei-sh.c:coff_set_flags
2865
2866
static bool
2867
coff_set_arch_mach (bfd * abfd,
2868
        enum bfd_architecture arch,
2869
        unsigned long machine)
2870
0
{
2871
0
  unsigned dummy1;
2872
0
  unsigned short dummy2;
2873
2874
0
  if (! bfd_default_set_arch_mach (abfd, arch, machine))
2875
0
    return false;
2876
2877
0
  if (arch != bfd_arch_unknown
2878
0
      && ! coff_set_flags (abfd, &dummy1, &dummy2))
2879
0
    return false;   /* We can't represent this type.  */
2880
2881
0
  return true;     /* We're easy...  */
2882
0
}
Unexecuted instantiation: pei-i386.c:coff_set_arch_mach
Unexecuted instantiation: pe-x86_64.c:coff_set_arch_mach
Unexecuted instantiation: pei-x86_64.c:coff_set_arch_mach
Unexecuted instantiation: coff-x86_64.c:coff_set_arch_mach
Unexecuted instantiation: coff64-rs6000.c:coff_set_arch_mach
Unexecuted instantiation: pei-aarch64.c:coff_set_arch_mach
Unexecuted instantiation: pe-aarch64.c:coff_set_arch_mach
Unexecuted instantiation: pei-ia64.c:coff_set_arch_mach
Unexecuted instantiation: pei-loongarch64.c:coff_set_arch_mach
Unexecuted instantiation: cf-i386lynx.c:coff_set_arch_mach
Unexecuted instantiation: coff-go32.c:coff_set_arch_mach
Unexecuted instantiation: coff-i386.c:coff_set_arch_mach
Unexecuted instantiation: coff-rs6000.c:coff_set_arch_mach
Unexecuted instantiation: coff-sh.c:coff_set_arch_mach
Unexecuted instantiation: coff-stgo32.c:coff_set_arch_mach
Unexecuted instantiation: coff-tic30.c:coff_set_arch_mach
Unexecuted instantiation: coff-tic4x.c:coff_set_arch_mach
Unexecuted instantiation: coff-tic54x.c:coff_set_arch_mach
Unexecuted instantiation: coff-z80.c:coff_set_arch_mach
Unexecuted instantiation: coff-z8k.c:coff_set_arch_mach
Unexecuted instantiation: pe-arm-wince.c:coff_set_arch_mach
Unexecuted instantiation: pe-arm.c:coff_set_arch_mach
Unexecuted instantiation: pe-i386.c:coff_set_arch_mach
Unexecuted instantiation: pe-mcore.c:coff_set_arch_mach
Unexecuted instantiation: pe-sh.c:coff_set_arch_mach
Unexecuted instantiation: pei-arm-wince.c:coff_set_arch_mach
Unexecuted instantiation: pei-arm.c:coff_set_arch_mach
Unexecuted instantiation: pei-mcore.c:coff_set_arch_mach
Unexecuted instantiation: pei-sh.c:coff_set_arch_mach
2883
2884
#ifdef COFF_IMAGE_WITH_PE
2885
2886
/* This is used to sort sections by VMA, as required by PE image
2887
   files.  */
2888
2889
static int
2890
sort_by_secaddr (const void * arg1, const void * arg2)
2891
0
{
2892
0
  const asection *a = *(const asection **) arg1;
2893
0
  const asection *b = *(const asection **) arg2;
2894
2895
0
  if (a->vma < b->vma)
2896
0
    return -1;
2897
0
  else if (a->vma > b->vma)
2898
0
    return 1;
2899
2900
0
  return 0;
2901
0
}
Unexecuted instantiation: pei-i386.c:sort_by_secaddr
Unexecuted instantiation: pei-x86_64.c:sort_by_secaddr
Unexecuted instantiation: pei-aarch64.c:sort_by_secaddr
Unexecuted instantiation: pei-ia64.c:sort_by_secaddr
Unexecuted instantiation: pei-loongarch64.c:sort_by_secaddr
Unexecuted instantiation: pei-arm-wince.c:sort_by_secaddr
Unexecuted instantiation: pei-arm.c:sort_by_secaddr
Unexecuted instantiation: pei-mcore.c:sort_by_secaddr
Unexecuted instantiation: pei-sh.c:sort_by_secaddr
2902
2903
#endif /* COFF_IMAGE_WITH_PE */
2904
2905
/* Calculate the file position for each section.  */
2906
2907
#define ALIGN_SECTIONS_IN_FILE
2908
#ifdef TICOFF
2909
#undef ALIGN_SECTIONS_IN_FILE
2910
#endif
2911
2912
static bool
2913
coff_compute_section_file_positions (bfd * abfd)
2914
0
{
2915
0
  asection *current;
2916
0
  file_ptr sofar = bfd_coff_filhsz (abfd);
2917
0
  bool align_adjust;
2918
0
  unsigned int target_index;
2919
#ifdef ALIGN_SECTIONS_IN_FILE
2920
  asection *previous = NULL;
2921
  file_ptr old_sofar;
2922
#endif
2923
2924
#ifdef COFF_IMAGE_WITH_PE
2925
  unsigned int page_size;
2926
2927
0
  if (coff_data (abfd)->link_info
2928
0
      || (pe_data (abfd) && pe_data (abfd)->pe_opthdr.FileAlignment))
2929
0
    {
2930
0
      page_size = pe_data (abfd)->pe_opthdr.FileAlignment;
2931
2932
      /* If no file alignment has been set, default to one.
2933
   This repairs 'ld -r' for arm-wince-pe target.  */
2934
0
      if (page_size == 0)
2935
0
  page_size = 1;
2936
0
    }
2937
0
  else
2938
0
    page_size = PE_DEF_FILE_ALIGNMENT;
2939
#else
2940
#ifdef COFF_PAGE_SIZE
2941
0
  unsigned int page_size = COFF_PAGE_SIZE;
2942
#endif
2943
#endif
2944
2945
#ifdef RS6000COFF_C
2946
  /* On XCOFF, if we have symbols, set up the .debug section.  */
2947
0
  if (bfd_get_symcount (abfd) > 0)
2948
0
    {
2949
0
      bfd_size_type sz;
2950
0
      bfd_size_type i, symcount;
2951
0
      asymbol **symp;
2952
2953
      sz = 0;
2954
      symcount = bfd_get_symcount (abfd);
2955
0
      for (symp = abfd->outsymbols, i = 0; i < symcount; symp++, i++)
2956
0
  {
2957
0
    coff_symbol_type *cf;
2958
2959
0
    cf = coff_symbol_from (*symp);
2960
0
    if (cf != NULL
2961
0
        && cf->native != NULL
2962
0
        && cf->native->is_sym
2963
0
        && SYMNAME_IN_DEBUG (&cf->native->u.syment))
2964
0
      {
2965
0
        size_t len;
2966
2967
0
        len = strlen (bfd_asymbol_name (*symp));
2968
0
        if (len > SYMNMLEN || bfd_coff_force_symnames_in_strings (abfd))
2969
0
    sz += len + 1 + bfd_coff_debug_string_prefix_length (abfd);
2970
0
      }
2971
0
  }
2972
0
      if (sz > 0)
2973
0
  {
2974
0
    asection *dsec;
2975
2976
0
    dsec = bfd_make_section_old_way (abfd, DOT_DEBUG);
2977
0
    if (dsec == NULL)
2978
0
      abort ();
2979
0
    dsec->size = sz;
2980
0
    dsec->flags |= SEC_HAS_CONTENTS;
2981
0
  }
2982
0
    }
2983
0
#endif
2984
2985
0
  if (bfd_get_start_address (abfd))
2986
    /*  A start address may have been added to the original file. In this
2987
  case it will need an optional header to record it.  */
2988
0
    abfd->flags |= EXEC_P;
2989
2990
0
  if (abfd->flags & EXEC_P)
2991
0
    sofar += bfd_coff_aoutsz (abfd);
2992
#ifdef RS6000COFF_C
2993
0
  else if (xcoff_data (abfd)->full_aouthdr)
2994
0
    sofar += bfd_coff_aoutsz (abfd);
2995
0
  else
2996
0
    sofar += SMALL_AOUTSZ;
2997
#endif
2998
2999
0
  sofar += abfd->section_count * bfd_coff_scnhsz (abfd);
3000
3001
#ifdef RS6000COFF_C
3002
  /* XCOFF handles overflows in the reloc and line number count fields
3003
     by allocating a new section header to hold the correct counts.  */
3004
0
  for (current = abfd->sections; current != NULL; current = current->next)
3005
0
    if (current->reloc_count >= 0xffff || current->lineno_count >= 0xffff)
3006
0
      sofar += bfd_coff_scnhsz (abfd);
3007
#endif
3008
3009
0
  if (coff_data (abfd)->section_by_target_index)
3010
0
    htab_empty (coff_data (abfd)->section_by_target_index);
3011
3012
#ifdef COFF_IMAGE_WITH_PE
3013
  {
3014
    /* PE requires the sections to be in memory order when listed in
3015
       the section headers.  It also does not like empty loadable
3016
       sections.  The sections apparently do not have to be in the
3017
       right order in the image file itself, but we do need to get the
3018
       target_index values right.  */
3019
3020
    unsigned int count;
3021
    asection **section_list;
3022
    unsigned int i;
3023
    bfd_size_type amt;
3024
3025
#ifdef COFF_PAGE_SIZE
3026
    /* Clear D_PAGED if section / file alignment aren't suitable for
3027
       paging at COFF_PAGE_SIZE granularity.  */
3028
0
   if (pe_data (abfd)->pe_opthdr.SectionAlignment < COFF_PAGE_SIZE
3029
0
       || page_size < COFF_PAGE_SIZE)
3030
0
     abfd->flags &= ~D_PAGED;
3031
#endif
3032
3033
    count = 0;
3034
0
    for (current = abfd->sections; current != NULL; current = current->next)
3035
0
      ++count;
3036
3037
    /* We allocate an extra cell to simplify the final loop.  */
3038
    amt = sizeof (struct asection *) * (count + 1);
3039
    section_list = (asection **) bfd_malloc (amt);
3040
0
    if (section_list == NULL)
3041
0
      return false;
3042
3043
0
    i = 0;
3044
0
    for (current = abfd->sections; current != NULL; current = current->next)
3045
0
      {
3046
0
  section_list[i] = current;
3047
0
  ++i;
3048
0
      }
3049
0
    section_list[i] = NULL;
3050
3051
0
    qsort (section_list, count, sizeof (asection *), sort_by_secaddr);
3052
3053
    /* Rethread the linked list into sorted order; at the same time,
3054
       assign target_index values.  */
3055
0
    target_index = 1;
3056
0
    abfd->sections = NULL;
3057
0
    abfd->section_last = NULL;
3058
0
    for (i = 0; i < count; i++)
3059
0
      {
3060
0
  current = section_list[i];
3061
0
  bfd_section_list_append (abfd, current);
3062
3063
  /* Later, if the section has zero size, we'll be throwing it
3064
     away, so we don't want to number it now.  Note that having
3065
     a zero size and having real contents are different
3066
     concepts: .bss has no contents, but (usually) non-zero
3067
     size.  */
3068
0
  if (current->size == 0)
3069
0
    {
3070
      /* Discard.  However, it still might have (valid) symbols
3071
         in it, so arbitrarily set it to section 1 (indexing is
3072
         1-based here; usually .text).  __end__ and other
3073
         contents of .endsection really have this happen.
3074
         FIXME: This seems somewhat dubious.  */
3075
0
      current->target_index = 1;
3076
0
    }
3077
0
  else
3078
0
    current->target_index = target_index++;
3079
0
      }
3080
3081
0
    free (section_list);
3082
0
  }
3083
#else /* ! COFF_IMAGE_WITH_PE */
3084
  {
3085
    /* Set the target_index field.  */
3086
    target_index = 1;
3087
0
    for (current = abfd->sections; current != NULL; current = current->next)
3088
0
      current->target_index = target_index++;
3089
  }
3090
#endif /* ! COFF_IMAGE_WITH_PE */
3091
3092
0
  if (target_index >= bfd_coff_max_nscns (abfd))
3093
0
    {
3094
0
      bfd_set_error (bfd_error_file_too_big);
3095
0
      _bfd_error_handler
3096
  /* xgettext:c-format */
3097
0
  (_("%pB: too many sections (%d)"), abfd, target_index);
3098
0
      return false;
3099
0
    }
3100
3101
0
  align_adjust = false;
3102
0
  for (current = abfd->sections;
3103
0
       current != NULL;
3104
0
       current = current->next)
3105
0
    {
3106
#ifdef COFF_IMAGE_WITH_PE
3107
      /* With PE we have to pad each section to be a multiple of its
3108
   page size too, and remember both sizes.  */
3109
0
      if (coff_section_data (abfd, current) == NULL)
3110
0
  {
3111
0
    size_t amt = sizeof (struct coff_section_tdata);
3112
3113
    current->used_by_bfd = bfd_zalloc (abfd, amt);
3114
0
    if (current->used_by_bfd == NULL)
3115
0
      return false;
3116
0
  }
3117
0
      if (pei_section_data (abfd, current) == NULL)
3118
0
  {
3119
0
    size_t amt = sizeof (struct pei_section_tdata);
3120
3121
0
    coff_section_data (abfd, current)->tdata = bfd_zalloc (abfd, amt);
3122
0
    if (coff_section_data (abfd, current)->tdata == NULL)
3123
0
      return false;
3124
0
  }
3125
0
      if (pei_section_data (abfd, current)->virt_size == 0)
3126
0
  pei_section_data (abfd, current)->virt_size = current->size;
3127
0
#endif
3128
3129
      /* Only deal with sections which have contents.  */
3130
0
      if (!(current->flags & SEC_HAS_CONTENTS))
3131
0
  continue;
3132
3133
0
      current->rawsize = current->size;
3134
3135
#ifdef COFF_IMAGE_WITH_PE
3136
      /* Make sure we skip empty sections in a PE image.  */
3137
0
      if (current->size == 0)
3138
0
  continue;
3139
0
#endif
3140
3141
      /* Align the sections in the file to the same boundary on
3142
   which they are aligned in virtual memory.  */
3143
#ifdef ALIGN_SECTIONS_IN_FILE
3144
0
      if ((abfd->flags & EXEC_P) != 0)
3145
0
  {
3146
    /* Make sure this section is aligned on the right boundary - by
3147
       padding the previous section up if necessary.  */
3148
0
    old_sofar = sofar;
3149
3150
#ifdef COFF_IMAGE_WITH_PE
3151
0
    sofar = BFD_ALIGN (sofar, page_size);
3152
#else
3153
0
    sofar = BFD_ALIGN (sofar, (bfd_vma) 1 << current->alignment_power);
3154
#endif
3155
3156
#ifdef RS6000COFF_C
3157
    /* Make sure the file offset and the vma of .text/.data are at the
3158
       same page offset, so that the file can be mmap'ed without being
3159
       relocated.  Failing that, AIX is able to load and execute the
3160
       program, but it will be silently relocated (possible as
3161
       executables are PIE).  But the relocation is slightly costly and
3162
       complexify the use of addr2line or gdb.  So better to avoid it,
3163
       like does the native linker.  Usually gnu ld makes sure that
3164
       the vma of .text is the file offset so this issue shouldn't
3165
       appear unless you are stripping such an executable.
3166
3167
       AIX loader checks the text section alignment of (vma - filepos),
3168
       and the native linker doesn't try to align the text sections.
3169
       For example:
3170
3171
       0 .text       000054cc  10000128  10000128  00000128  2**5
3172
           CONTENTS, ALLOC, LOAD, CODE
3173
3174
       Don't perform the above tweak if the previous one is .tdata,
3175
       as it will increase the memory allocated for every threads
3176
       created and not just improve performances with gdb.
3177
    */
3178
3179
0
    if ((!strcmp (current->name, _TEXT)
3180
0
         || !strcmp (current->name, _DATA))
3181
0
        && (previous == NULL || strcmp(previous->name, _TDATA)))
3182
0
      {
3183
0
        bfd_vma align = 4096;
3184
0
        bfd_vma sofar_off = sofar % align;
3185
0
        bfd_vma vma_off = current->vma % align;
3186
3187
0
        if (vma_off > sofar_off)
3188
0
    sofar += vma_off - sofar_off;
3189
0
        else if (vma_off < sofar_off)
3190
0
    sofar += align + vma_off - sofar_off;
3191
0
      }
3192
#endif
3193
0
    if (previous != NULL)
3194
0
      previous->size += sofar - old_sofar;
3195
0
  }
3196
3197
0
#endif
3198
3199
      /* In demand paged files the low order bits of the file offset
3200
   must match the low order bits of the virtual address.  */
3201
#ifdef COFF_PAGE_SIZE
3202
0
      if ((abfd->flags & D_PAGED) != 0
3203
0
    && (current->flags & SEC_ALLOC) != 0)
3204
0
  sofar += (current->vma - (bfd_vma) sofar) % page_size;
3205
#endif
3206
0
      current->filepos = sofar;
3207
3208
#ifdef COFF_IMAGE_WITH_PE
3209
      /* Set the padded size.  */
3210
      current->size = (current->size + page_size - 1) & -page_size;
3211
#endif
3212
3213
0
      sofar += current->size;
3214
3215
#ifdef ALIGN_SECTIONS_IN_FILE
3216
      /* Make sure that this section is of the right size too.  */
3217
0
      if ((abfd->flags & EXEC_P) == 0)
3218
0
  {
3219
0
    bfd_size_type old_size;
3220
3221
0
    old_size = current->size;
3222
0
    current->size = BFD_ALIGN (current->size,
3223
0
             (bfd_vma) 1 << current->alignment_power);
3224
0
    align_adjust = current->size != old_size;
3225
0
    sofar += current->size - old_size;
3226
0
  }
3227
0
      else
3228
0
  {
3229
0
    old_sofar = sofar;
3230
#ifdef COFF_IMAGE_WITH_PE
3231
0
    sofar = BFD_ALIGN (sofar, page_size);
3232
#else
3233
0
    sofar = BFD_ALIGN (sofar, (bfd_vma) 1 << current->alignment_power);
3234
#endif
3235
0
    align_adjust = sofar != old_sofar;
3236
0
    current->size += sofar - old_sofar;
3237
0
  }
3238
#endif
3239
3240
#ifdef COFF_IMAGE_WITH_PE
3241
      /* For PE we need to make sure we pad out to the aligned
3242
   size, in case the caller only writes out data to the
3243
   unaligned size.  */
3244
0
      if (pei_section_data (abfd, current)->virt_size < current->size)
3245
0
  align_adjust = true;
3246
#endif
3247
3248
#ifdef _LIB
3249
      /* Force .lib sections to start at zero.  The vma is then
3250
   incremented in coff_set_section_contents.  This is right for
3251
   SVR3.2.  */
3252
0
      if (strcmp (current->name, _LIB) == 0)
3253
0
  bfd_set_section_vma (current, 0);
3254
#endif
3255
3256
#ifdef ALIGN_SECTIONS_IN_FILE
3257
      previous = current;
3258
#endif
3259
0
    }
3260
3261
  /* It is now safe to write to the output file.  If we needed an
3262
     alignment adjustment for the last section, then make sure that
3263
     there is a byte at offset sofar.  If there are no symbols and no
3264
     relocs, then nothing follows the last section.  If we don't force
3265
     the last byte out, then the file may appear to be truncated.  */
3266
0
  if (align_adjust)
3267
0
    {
3268
0
      bfd_byte b;
3269
3270
0
      b = 0;
3271
0
      if (bfd_seek (abfd, sofar - 1, SEEK_SET) != 0
3272
0
    || bfd_bwrite (&b, (bfd_size_type) 1, abfd) != 1)
3273
0
  return false;
3274
0
    }
3275
3276
  /* Make sure the relocations are aligned.  We don't need to make
3277
     sure that this byte exists, because it will only matter if there
3278
     really are relocs.  */
3279
0
  sofar = BFD_ALIGN (sofar,
3280
0
         (bfd_vma) 1 << COFF_DEFAULT_SECTION_ALIGNMENT_POWER);
3281
3282
0
  obj_relocbase (abfd) = sofar;
3283
0
  abfd->output_has_begun = true;
3284
3285
0
  return true;
3286
0
}
Unexecuted instantiation: pei-i386.c:coff_compute_section_file_positions
Unexecuted instantiation: pe-x86_64.c:coff_compute_section_file_positions
Unexecuted instantiation: pei-x86_64.c:coff_compute_section_file_positions
Unexecuted instantiation: coff-x86_64.c:coff_compute_section_file_positions
Unexecuted instantiation: coff64-rs6000.c:coff_compute_section_file_positions
Unexecuted instantiation: pei-aarch64.c:coff_compute_section_file_positions
Unexecuted instantiation: pe-aarch64.c:coff_compute_section_file_positions
Unexecuted instantiation: pei-ia64.c:coff_compute_section_file_positions
Unexecuted instantiation: pei-loongarch64.c:coff_compute_section_file_positions
Unexecuted instantiation: cf-i386lynx.c:coff_compute_section_file_positions
Unexecuted instantiation: coff-go32.c:coff_compute_section_file_positions
Unexecuted instantiation: coff-i386.c:coff_compute_section_file_positions
Unexecuted instantiation: coff-rs6000.c:coff_compute_section_file_positions
Unexecuted instantiation: coff-sh.c:coff_compute_section_file_positions
Unexecuted instantiation: coff-stgo32.c:coff_compute_section_file_positions
Unexecuted instantiation: coff-tic30.c:coff_compute_section_file_positions
Unexecuted instantiation: coff-tic4x.c:coff_compute_section_file_positions
Unexecuted instantiation: coff-tic54x.c:coff_compute_section_file_positions
Unexecuted instantiation: coff-z80.c:coff_compute_section_file_positions
Unexecuted instantiation: coff-z8k.c:coff_compute_section_file_positions
Unexecuted instantiation: pe-arm-wince.c:coff_compute_section_file_positions
Unexecuted instantiation: pe-arm.c:coff_compute_section_file_positions
Unexecuted instantiation: pe-i386.c:coff_compute_section_file_positions
Unexecuted instantiation: pe-mcore.c:coff_compute_section_file_positions
Unexecuted instantiation: pe-sh.c:coff_compute_section_file_positions
Unexecuted instantiation: pei-arm-wince.c:coff_compute_section_file_positions
Unexecuted instantiation: pei-arm.c:coff_compute_section_file_positions
Unexecuted instantiation: pei-mcore.c:coff_compute_section_file_positions
Unexecuted instantiation: pei-sh.c:coff_compute_section_file_positions
3287
3288
#ifdef COFF_IMAGE_WITH_PE
3289
3290
static bool
3291
coff_read_word (bfd *abfd, unsigned int *value, unsigned int *pelength)
3292
0
{
3293
0
  unsigned char b[2];
3294
0
  int status;
3295
3296
0
  status = bfd_bread (b, (bfd_size_type) 2, abfd);
3297
0
  if (status < 1)
3298
0
    {
3299
0
      *value = 0;
3300
0
      return false;
3301
0
    }
3302
3303
0
  if (status == 1)
3304
0
    *value = (unsigned int) b[0];
3305
0
  else
3306
0
    *value = (unsigned int) (b[0] + (b[1] << 8));
3307
3308
0
  *pelength += status;
3309
3310
0
  return true;
3311
0
}
Unexecuted instantiation: pei-i386.c:coff_read_word
Unexecuted instantiation: pei-x86_64.c:coff_read_word
Unexecuted instantiation: pei-aarch64.c:coff_read_word
Unexecuted instantiation: pei-ia64.c:coff_read_word
Unexecuted instantiation: pei-loongarch64.c:coff_read_word
Unexecuted instantiation: pei-arm-wince.c:coff_read_word
Unexecuted instantiation: pei-arm.c:coff_read_word
Unexecuted instantiation: pei-mcore.c:coff_read_word
Unexecuted instantiation: pei-sh.c:coff_read_word
3312
3313
/* Read a two byte number from buffer B returning the result in VALUE.
3314
   No more than BUF_SIZE bytes will be read.
3315
   Returns true upobn success, false otherwise.
3316
   If successful, increases the value stored in PELENGTH by the number
3317
   of bytes read.  */
3318
3319
static bool
3320
coff_read_word_from_buffer (unsigned char *  b,
3321
          int              buf_size,
3322
                            unsigned int *   value,
3323
          unsigned int *   pelength)
3324
0
{
3325
0
  if (buf_size < 1)
3326
0
    {
3327
0
      *value = 0;
3328
0
      return false;
3329
0
    }
3330
3331
0
  if (buf_size == 1)
3332
0
    {
3333
0
      *value = (unsigned int)b[0];
3334
0
      *pelength += 1;
3335
0
    }
3336
0
  else
3337
0
    {
3338
0
      *value = (unsigned int)(b[0] + (b[1] << 8));
3339
0
      *pelength += 2;
3340
0
    }
3341
3342
0
  return true;
3343
0
}
Unexecuted instantiation: pei-i386.c:coff_read_word_from_buffer
Unexecuted instantiation: pei-x86_64.c:coff_read_word_from_buffer
Unexecuted instantiation: pei-aarch64.c:coff_read_word_from_buffer
Unexecuted instantiation: pei-ia64.c:coff_read_word_from_buffer
Unexecuted instantiation: pei-loongarch64.c:coff_read_word_from_buffer
Unexecuted instantiation: pei-arm-wince.c:coff_read_word_from_buffer
Unexecuted instantiation: pei-arm.c:coff_read_word_from_buffer
Unexecuted instantiation: pei-mcore.c:coff_read_word_from_buffer
Unexecuted instantiation: pei-sh.c:coff_read_word_from_buffer
3344
3345
0
#define COFF_CHECKSUM_BUFFER_SIZE 0x800000
3346
3347
static unsigned int
3348
coff_compute_checksum (bfd *abfd, unsigned int *pelength)
3349
0
{
3350
0
  file_ptr filepos;
3351
0
  unsigned int value;
3352
0
  unsigned int total;
3353
0
  unsigned char *buf;
3354
0
  int buf_size;
3355
3356
0
  total = 0;
3357
0
  *pelength = 0;
3358
0
  filepos = (file_ptr) 0;
3359
0
  buf = (unsigned char *) bfd_malloc (COFF_CHECKSUM_BUFFER_SIZE);
3360
0
  if (buf == NULL)
3361
0
    return 0;
3362
0
  buf_size = 0;
3363
3364
0
  do
3365
0
    {
3366
0
      unsigned char *cur_buf;
3367
0
      int cur_buf_size;
3368
3369
0
      if (bfd_seek (abfd, filepos, SEEK_SET) != 0)
3370
0
  return 0;
3371
3372
0
      buf_size = bfd_bread (buf, COFF_CHECKSUM_BUFFER_SIZE, abfd);
3373
0
      cur_buf_size = buf_size;
3374
0
      cur_buf = buf;
3375
3376
0
      while (cur_buf_size > 0)
3377
0
        {
3378
0
          coff_read_word_from_buffer (cur_buf, cur_buf_size, &value, pelength);
3379
0
          cur_buf += 2;
3380
0
          cur_buf_size -= 2;
3381
0
          total += value;
3382
0
          total = 0xffff & (total + (total >> 0x10));
3383
0
        }
3384
3385
0
      filepos += buf_size;
3386
0
    }
3387
0
  while (buf_size > 0);
3388
3389
0
  free (buf);
3390
3391
0
  return (0xffff & (total + (total >> 0x10)));
3392
0
}
Unexecuted instantiation: pei-i386.c:coff_compute_checksum
Unexecuted instantiation: pei-x86_64.c:coff_compute_checksum
Unexecuted instantiation: pei-aarch64.c:coff_compute_checksum
Unexecuted instantiation: pei-ia64.c:coff_compute_checksum
Unexecuted instantiation: pei-loongarch64.c:coff_compute_checksum
Unexecuted instantiation: pei-arm-wince.c:coff_compute_checksum
Unexecuted instantiation: pei-arm.c:coff_compute_checksum
Unexecuted instantiation: pei-mcore.c:coff_compute_checksum
Unexecuted instantiation: pei-sh.c:coff_compute_checksum
3393
3394
static bool
3395
coff_apply_checksum (bfd *abfd)
3396
0
{
3397
0
  unsigned int computed;
3398
0
  unsigned int checksum = 0;
3399
0
  unsigned int peheader;
3400
0
  unsigned int pelength;
3401
3402
0
  if (bfd_seek (abfd, 0x3c, SEEK_SET) != 0)
3403
0
    return false;
3404
3405
0
  if (!coff_read_word (abfd, &peheader, &pelength))
3406
0
    return false;
3407
3408
0
  if (bfd_seek (abfd, peheader + 0x58, SEEK_SET) != 0)
3409
0
    return false;
3410
3411
0
  checksum = 0;
3412
0
  bfd_bwrite (&checksum, (bfd_size_type) 4, abfd);
3413
3414
0
  if (bfd_seek (abfd, peheader, SEEK_SET) != 0)
3415
0
    return false;
3416
3417
0
  computed = coff_compute_checksum (abfd, &pelength);
3418
3419
0
  checksum = computed + pelength;
3420
3421
0
  if (bfd_seek (abfd, peheader + 0x58, SEEK_SET) != 0)
3422
0
    return false;
3423
3424
0
  bfd_bwrite (&checksum, (bfd_size_type) 4, abfd);
3425
3426
0
  return true;
3427
0
}
Unexecuted instantiation: pei-i386.c:coff_apply_checksum
Unexecuted instantiation: pei-x86_64.c:coff_apply_checksum
Unexecuted instantiation: pei-aarch64.c:coff_apply_checksum
Unexecuted instantiation: pei-ia64.c:coff_apply_checksum
Unexecuted instantiation: pei-loongarch64.c:coff_apply_checksum
Unexecuted instantiation: pei-arm-wince.c:coff_apply_checksum
Unexecuted instantiation: pei-arm.c:coff_apply_checksum
Unexecuted instantiation: pei-mcore.c:coff_apply_checksum
Unexecuted instantiation: pei-sh.c:coff_apply_checksum
3428
3429
#endif /* COFF_IMAGE_WITH_PE */
3430
3431
static bool
3432
coff_write_object_contents (bfd * abfd)
3433
0
{
3434
0
  asection *current;
3435
0
  bool hasrelocs = false;
3436
0
  bool haslinno = false;
3437
#ifdef COFF_IMAGE_WITH_PE
3438
  bool hasdebug = false;
3439
#endif
3440
0
  file_ptr scn_base;
3441
0
  file_ptr reloc_base;
3442
0
  file_ptr lineno_base;
3443
0
  file_ptr sym_base;
3444
0
  unsigned long reloc_size = 0, reloc_count = 0;
3445
0
  unsigned long lnno_size = 0;
3446
0
  bool long_section_names;
3447
0
  asection *text_sec = NULL;
3448
0
  asection *data_sec = NULL;
3449
0
  asection *bss_sec = NULL;
3450
#ifdef RS6000COFF_C
3451
  asection *tdata_sec = NULL;
3452
  asection *tbss_sec = NULL;
3453
#endif
3454
0
  struct internal_filehdr internal_f;
3455
0
  struct internal_aouthdr internal_a;
3456
#ifdef COFF_LONG_SECTION_NAMES
3457
0
  size_t string_size = STRING_SIZE_SIZE;
3458
#endif
3459
3460
0
  bfd_set_error (bfd_error_system_call);
3461
3462
  /* Make a pass through the symbol table to count line number entries and
3463
     put them into the correct asections.  */
3464
0
  lnno_size = coff_count_linenumbers (abfd) * bfd_coff_linesz (abfd);
3465
3466
0
  if (! abfd->output_has_begun)
3467
0
    {
3468
0
      if (! coff_compute_section_file_positions (abfd))
3469
0
  return false;
3470
0
    }
3471
3472
0
  reloc_base = obj_relocbase (abfd);
3473
3474
  /* Work out the size of the reloc and linno areas.  */
3475
3476
0
  for (current = abfd->sections; current != NULL; current =
3477
0
       current->next)
3478
0
    {
3479
#ifdef COFF_WITH_EXTENDED_RELOC_COUNTER
3480
      /* We store the actual reloc count in the first reloc's addr.  */
3481
0
      if ((obj_pe (abfd) || obj_go32 (abfd)) && current->reloc_count >= 0xffff)
3482
0
  reloc_count ++;
3483
#endif
3484
0
      reloc_count += current->reloc_count;
3485
0
    }
3486
3487
0
  reloc_size = reloc_count * bfd_coff_relsz (abfd);
3488
3489
0
  lineno_base = reloc_base + reloc_size;
3490
0
  sym_base = lineno_base + lnno_size;
3491
3492
  /* Indicate in each section->line_filepos its actual file address.  */
3493
0
  for (current = abfd->sections; current != NULL; current =
3494
0
       current->next)
3495
0
    {
3496
0
      if (current->lineno_count)
3497
0
  {
3498
0
    current->line_filepos = lineno_base;
3499
0
    current->moving_line_filepos = lineno_base;
3500
0
    lineno_base += current->lineno_count * bfd_coff_linesz (abfd);
3501
0
  }
3502
0
      else
3503
0
  current->line_filepos = 0;
3504
3505
0
      if (current->reloc_count)
3506
0
  {
3507
0
    current->rel_filepos = reloc_base;
3508
0
    reloc_base += current->reloc_count * bfd_coff_relsz (abfd);
3509
#ifdef COFF_WITH_EXTENDED_RELOC_COUNTER
3510
    /* Extra reloc to hold real count.  */
3511
0
    if ((obj_pe (abfd) || obj_go32 (abfd)) && current->reloc_count >= 0xffff)
3512
0
      reloc_base += bfd_coff_relsz (abfd);
3513
#endif
3514
0
  }
3515
0
      else
3516
0
  current->rel_filepos = 0;
3517
0
    }
3518
3519
  /* Write section headers to the file.  */
3520
0
  internal_f.f_nscns = 0;
3521
3522
0
  if ((abfd->flags & EXEC_P) != 0)
3523
0
    scn_base = bfd_coff_filhsz (abfd) + bfd_coff_aoutsz (abfd);
3524
0
  else
3525
0
    {
3526
0
      scn_base = bfd_coff_filhsz (abfd);
3527
#ifdef RS6000COFF_C
3528
#ifndef XCOFF64
3529
0
      if (xcoff_data (abfd)->full_aouthdr)
3530
0
  scn_base += bfd_coff_aoutsz (abfd);
3531
0
      else
3532
0
  scn_base += SMALL_AOUTSZ;
3533
#endif
3534
#endif
3535
0
    }
3536
3537
0
  if (bfd_seek (abfd, scn_base, SEEK_SET) != 0)
3538
0
    return false;
3539
3540
0
  long_section_names = false;
3541
0
  for (current = abfd->sections;
3542
0
       current != NULL;
3543
0
       current = current->next)
3544
0
    {
3545
0
      struct internal_scnhdr section;
3546
#ifdef COFF_IMAGE_WITH_PE
3547
      bool is_reloc_section = false;
3548
3549
0
      if (strcmp (current->name, DOT_RELOC) == 0)
3550
0
  {
3551
0
    is_reloc_section = true;
3552
0
    hasrelocs = true;
3553
0
    pe_data (abfd)->has_reloc_section = 1;
3554
0
  }
3555
#endif
3556
3557
0
      internal_f.f_nscns++;
3558
3559
0
      strncpy (section.s_name, current->name, SCNNMLEN);
3560
3561
#ifdef COFF_LONG_SECTION_NAMES
3562
      /* Handle long section names as in PE.  This must be compatible
3563
   with the code in coff_write_symbols and _bfd_coff_final_link.  */
3564
0
      if (bfd_coff_long_section_names (abfd))
3565
0
  {
3566
0
    size_t len;
3567
3568
    len = strlen (current->name);
3569
0
    if (len > SCNNMLEN)
3570
0
      {
3571
3572
        /* An inherent limitation of the /nnnnnnn notation used to indicate
3573
     the offset of the long name in the string table is that we
3574
     cannot address entries beyone the ten million byte boundary.  */
3575
0
        if (string_size < 10000000)
3576
0
    {
3577
      /* The s_name field is defined to be NUL-padded but need not
3578
         be NUL-terminated.  We use a temporary buffer so that we
3579
         can still sprintf all eight chars without splatting a
3580
         terminating NUL over the first byte of the following
3581
         member (s_paddr).  */
3582
      /* PR 21096: The +20 is to stop a bogus warning from gcc7
3583
         about a possible buffer overflow.  */
3584
      char s_name_buf[SCNNMLEN + 1 + 20];
3585
3586
      /* We do not need to use snprintf here as we have already
3587
         verified that string_size is not too big, plus we have
3588
         an overlarge buffer, just in case.  */
3589
0
      sprintf (s_name_buf, "/%lu", (unsigned long) string_size);
3590
      /* Then strncpy takes care of any padding for us.  */
3591
0
      strncpy (section.s_name, s_name_buf, SCNNMLEN);
3592
0
    }
3593
0
        else
3594
#ifdef COFF_WITH_PE
3595
0
    {
3596
      /* PE use a base 64 encoding for long section names whose
3597
         index is very large.  But contrary to RFC 4648, there is
3598
         no padding: 6 characters must be generated.  */
3599
0
      static const char base64[] =
3600
0
        "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
3601
0
        "abcdefghijklmnopqrstuvwxyz"
3602
0
        "0123456789+/";
3603
0
      unsigned long off = string_size;
3604
0
      unsigned i;
3605
3606
0
      section.s_name[0] = '/';
3607
0
      section.s_name[1] = '/';
3608
0
      for (i = SCNNMLEN - 1; i >= 2; i--)
3609
0
        {
3610
0
          section.s_name[i] = base64[off & 0x3f];
3611
0
          off >>= 6;
3612
0
        }
3613
0
    }
3614
#endif
3615
0
        if (string_size > 0xffffffffUL - (len + 1)
3616
#ifndef COFF_WITH_PE
3617
0
      || string_size >= 10000000
3618
#endif
3619
0
      )
3620
0
    {
3621
0
      bfd_set_error (bfd_error_file_too_big);
3622
0
      _bfd_error_handler
3623
        /* xgettext:c-format */
3624
0
        (_("%pB: section %pA: string table overflow at offset %ld"),
3625
0
        abfd, current, (unsigned long) string_size);
3626
0
      return false;
3627
0
    }
3628
3629
0
        string_size += len + 1;
3630
0
        long_section_names = true;
3631
0
      }
3632
0
  }
3633
0
#endif
3634
3635
#ifdef _LIB
3636
      /* Always set s_vaddr of .lib to 0.  This is right for SVR3.2
3637
   Ian Taylor <ian@cygnus.com>.  */
3638
0
      if (strcmp (current->name, _LIB) == 0)
3639
0
  section.s_vaddr = 0;
3640
0
      else
3641
0
#endif
3642
0
      section.s_vaddr = current->vma;
3643
0
      section.s_paddr = current->lma;
3644
0
      section.s_size =  current->size;
3645
#ifdef coff_get_section_load_page
3646
0
      section.s_page = coff_get_section_load_page (current);
3647
#else
3648
      section.s_page = 0;
3649
#endif
3650
3651
#ifdef COFF_WITH_PE
3652
      section.s_paddr = 0;
3653
#endif
3654
#ifdef COFF_IMAGE_WITH_PE
3655
      /* Reminder: s_paddr holds the virtual size of the section.  */
3656
0
      if (coff_section_data (abfd, current) != NULL
3657
0
    && pei_section_data (abfd, current) != NULL)
3658
0
  section.s_paddr = pei_section_data (abfd, current)->virt_size;
3659
0
      else
3660
0
  section.s_paddr = 0;
3661
#endif
3662
3663
      /* If this section has no size or is unloadable then the scnptr
3664
   will be 0 too.  */
3665
0
      if (current->size == 0
3666
0
    || (current->flags & (SEC_LOAD | SEC_HAS_CONTENTS)) == 0)
3667
0
  section.s_scnptr = 0;
3668
0
      else
3669
0
  section.s_scnptr = current->filepos;
3670
3671
0
      section.s_relptr = current->rel_filepos;
3672
0
      section.s_lnnoptr = current->line_filepos;
3673
0
      section.s_nreloc = current->reloc_count;
3674
0
      section.s_nlnno = current->lineno_count;
3675
#ifndef COFF_IMAGE_WITH_PE
3676
      /* In PEI, relocs come in the .reloc section.  */
3677
0
      if (current->reloc_count != 0)
3678
0
  hasrelocs = true;
3679
#endif
3680
0
      if (current->lineno_count != 0)
3681
0
  haslinno = true;
3682
#ifdef COFF_IMAGE_WITH_PE
3683
0
      if ((current->flags & SEC_DEBUGGING) != 0
3684
0
    && ! is_reloc_section)
3685
0
  hasdebug = true;
3686
#endif
3687
3688
#ifdef RS6000COFF_C
3689
#ifndef XCOFF64
3690
      /* Indicate the use of an XCOFF overflow section header.  */
3691
0
      if (current->reloc_count >= 0xffff || current->lineno_count >= 0xffff)
3692
0
  {
3693
0
    section.s_nreloc = 0xffff;
3694
0
    section.s_nlnno = 0xffff;
3695
0
  }
3696
#endif
3697
#endif
3698
3699
0
      section.s_flags = sec_to_styp_flags (current->name, current->flags);
3700
3701
0
      if (!strcmp (current->name, _TEXT))
3702
0
  text_sec = current;
3703
0
      else if (!strcmp (current->name, _DATA))
3704
0
  data_sec = current;
3705
0
      else if (!strcmp (current->name, _BSS))
3706
0
  bss_sec = current;
3707
#ifdef RS6000COFF_C
3708
0
      else if (!strcmp (current->name, _TDATA))
3709
0
  tdata_sec = current;
3710
0
      else if (!strcmp (current->name, _TBSS))
3711
0
  tbss_sec = current;
3712
#endif
3713
3714
3715
#ifdef COFF_ENCODE_ALIGNMENT
3716
0
      if (COFF_ENCODE_ALIGNMENT (abfd, section, current->alignment_power)
3717
0
    && (COFF_DECODE_ALIGNMENT (section.s_flags)
3718
0
        != current->alignment_power))
3719
0
  {
3720
0
    bool warn = (coff_data (abfd)->link_info
3721
0
           && !bfd_link_relocatable (coff_data (abfd)->link_info));
3722
3723
0
    _bfd_error_handler
3724
      /* xgettext:c-format */
3725
0
      (_("%pB:%s section %s: alignment 2**%u not representable"),
3726
0
       abfd, warn ? " warning:" : "", current->name,
3727
0
       current->alignment_power);
3728
0
    if (!warn)
3729
0
      {
3730
0
        bfd_set_error (bfd_error_nonrepresentable_section);
3731
0
        return false;
3732
0
      }
3733
0
  }
3734
0
#endif
3735
3736
#ifdef COFF_IMAGE_WITH_PE
3737
      /* Suppress output of the sections if they are null.  ld
3738
   includes the bss and data sections even if there is no size
3739
   assigned to them.  NT loader doesn't like it if these section
3740
   headers are included if the sections themselves are not
3741
   needed.  See also coff_compute_section_file_positions.  */
3742
0
      if (section.s_size == 0)
3743
0
  internal_f.f_nscns--;
3744
0
      else
3745
0
#endif
3746
0
  {
3747
0
    SCNHDR buff;
3748
0
    bfd_size_type amt = bfd_coff_scnhsz (abfd);
3749
3750
0
    if (bfd_coff_swap_scnhdr_out (abfd, &section, &buff) == 0
3751
0
        || bfd_bwrite (& buff, amt, abfd) != amt)
3752
0
      return false;
3753
0
  }
3754
3755
#ifdef COFF_WITH_PE
3756
      /* PE stores COMDAT section information in the symbol table.  If
3757
   this section is supposed to have some COMDAT info, track down
3758
   the symbol in the symbol table and modify it.  */
3759
0
      if ((current->flags & SEC_LINK_ONCE) != 0)
3760
0
  {
3761
0
    unsigned int i, count;
3762
0
    asymbol **psym;
3763
0
    coff_symbol_type *csym = NULL;
3764
0
    asymbol **psymsec;
3765
3766
    psymsec = NULL;
3767
    count = bfd_get_symcount (abfd);
3768
0
    for (i = 0, psym = abfd->outsymbols; i < count; i++, psym++)
3769
0
      {
3770
0
        if ((*psym)->section != current)
3771
0
    continue;
3772
3773
        /* Remember the location of the first symbol in this
3774
     section.  */
3775
0
        if (psymsec == NULL)
3776
0
    psymsec = psym;
3777
3778
        /* See if this is the section symbol.  */
3779
0
        if (strcmp ((*psym)->name, current->name) == 0)
3780
0
    {
3781
0
      csym = coff_symbol_from (*psym);
3782
0
      if (csym == NULL
3783
0
          || csym->native == NULL
3784
0
          || ! csym->native->is_sym
3785
0
          || csym->native->u.syment.n_numaux < 1
3786
0
          || csym->native->u.syment.n_sclass != C_STAT
3787
0
          || csym->native->u.syment.n_type != T_NULL)
3788
0
        continue;
3789
3790
      /* Here *PSYM is the section symbol for CURRENT.  */
3791
3792
0
      break;
3793
0
    }
3794
0
      }
3795
3796
    /* Did we find it?
3797
       Note that we might not if we're converting the file from
3798
       some other object file format.  */
3799
0
    if (i < count)
3800
0
      {
3801
0
        combined_entry_type *aux;
3802
3803
        /* We don't touch the x_checksum field.  The
3804
     x_associated field is not currently supported.  */
3805
3806
0
        aux = csym->native + 1;
3807
0
        BFD_ASSERT (! aux->is_sym);
3808
0
        switch (current->flags & SEC_LINK_DUPLICATES)
3809
0
    {
3810
0
    case SEC_LINK_DUPLICATES_DISCARD:
3811
0
      aux->u.auxent.x_scn.x_comdat = IMAGE_COMDAT_SELECT_ANY;
3812
0
      break;
3813
3814
0
    case SEC_LINK_DUPLICATES_ONE_ONLY:
3815
0
      aux->u.auxent.x_scn.x_comdat =
3816
0
        IMAGE_COMDAT_SELECT_NODUPLICATES;
3817
0
      break;
3818
3819
0
    case SEC_LINK_DUPLICATES_SAME_SIZE:
3820
0
      aux->u.auxent.x_scn.x_comdat =
3821
0
        IMAGE_COMDAT_SELECT_SAME_SIZE;
3822
0
      break;
3823
3824
0
    case SEC_LINK_DUPLICATES_SAME_CONTENTS:
3825
0
      aux->u.auxent.x_scn.x_comdat =
3826
0
        IMAGE_COMDAT_SELECT_EXACT_MATCH;
3827
0
      break;
3828
0
    }
3829
3830
        /* The COMDAT symbol must be the first symbol from this
3831
     section in the symbol table.  In order to make this
3832
     work, we move the COMDAT symbol before the first
3833
     symbol we found in the search above.  It's OK to
3834
     rearrange the symbol table at this point, because
3835
     coff_renumber_symbols is going to rearrange it
3836
     further and fix up all the aux entries.  */
3837
0
        if (psym != psymsec)
3838
0
    {
3839
0
      asymbol *hold;
3840
0
      asymbol **pcopy;
3841
3842
0
      hold = *psym;
3843
0
      for (pcopy = psym; pcopy > psymsec; pcopy--)
3844
0
        pcopy[0] = pcopy[-1];
3845
0
      *psymsec = hold;
3846
0
    }
3847
0
      }
3848
0
  }
3849
#endif /* COFF_WITH_PE */
3850
0
    }
3851
3852
#ifdef RS6000COFF_C
3853
#ifndef XCOFF64
3854
  /* XCOFF handles overflows in the reloc and line number count fields
3855
     by creating a new section header to hold the correct values.  */
3856
0
  for (current = abfd->sections; current != NULL; current = current->next)
3857
0
    {
3858
0
      if (current->reloc_count >= 0xffff || current->lineno_count >= 0xffff)
3859
0
  {
3860
0
    struct internal_scnhdr scnhdr;
3861
0
    SCNHDR buff;
3862
0
    bfd_size_type amt;
3863
3864
0
    internal_f.f_nscns++;
3865
0
    memcpy (scnhdr.s_name, ".ovrflo", 8);
3866
0
    scnhdr.s_paddr = current->reloc_count;
3867
0
    scnhdr.s_vaddr = current->lineno_count;
3868
0
    scnhdr.s_size = 0;
3869
0
    scnhdr.s_scnptr = 0;
3870
0
    scnhdr.s_relptr = current->rel_filepos;
3871
0
    scnhdr.s_lnnoptr = current->line_filepos;
3872
0
    scnhdr.s_nreloc = current->target_index;
3873
0
    scnhdr.s_nlnno = current->target_index;
3874
0
    scnhdr.s_flags = STYP_OVRFLO;
3875
0
    amt = bfd_coff_scnhsz (abfd);
3876
0
    if (bfd_coff_swap_scnhdr_out (abfd, &scnhdr, &buff) == 0
3877
0
        || bfd_bwrite (& buff, amt, abfd) != amt)
3878
0
      return false;
3879
0
  }
3880
0
    }
3881
0
#endif
3882
#endif
3883
3884
#if defined (COFF_GO32_EXE) || defined (COFF_GO32)
3885
  /* Pad section headers.  */
3886
0
  if ((abfd->flags & EXEC_P) && abfd->sections != NULL)
3887
0
    {
3888
0
      file_ptr cur_ptr = scn_base
3889
0
       + abfd->section_count * bfd_coff_scnhsz (abfd);
3890
0
      long fill_size = (abfd->sections->filepos - cur_ptr);
3891
0
      bfd_byte *b = bfd_zmalloc (fill_size);
3892
0
      if (b)
3893
0
  {
3894
0
    bfd_bwrite (b, fill_size, abfd);
3895
0
    free (b);
3896
0
  }
3897
0
    }
3898
0
#endif
3899
3900
  /* OK, now set up the filehdr...  */
3901
3902
  /* Don't include the internal abs section in the section count */
3903
3904
  /* We will NOT put a fucking timestamp in the header here. Every time you
3905
     put it back, I will come in and take it out again.  I'm sorry.  This
3906
     field does not belong here.  We fill it with a 0 so it compares the
3907
     same but is not a reasonable time. -- gnu@cygnus.com  */
3908
0
  internal_f.f_timdat = 0;
3909
0
  internal_f.f_flags = 0;
3910
3911
0
  if (abfd->flags & EXEC_P)
3912
0
    internal_f.f_opthdr = bfd_coff_aoutsz (abfd);
3913
0
  else
3914
0
    {
3915
0
      internal_f.f_opthdr = 0;
3916
#ifdef RS6000COFF_C
3917
#ifndef XCOFF64
3918
0
      if (xcoff_data (abfd)->full_aouthdr)
3919
0
  internal_f.f_opthdr = bfd_coff_aoutsz (abfd);
3920
0
      else
3921
0
  internal_f.f_opthdr = SMALL_AOUTSZ;
3922
#endif
3923
#endif
3924
0
    }
3925
3926
0
  if (!hasrelocs)
3927
0
    internal_f.f_flags |= F_RELFLG;
3928
0
  if (!haslinno)
3929
0
    internal_f.f_flags |= F_LNNO;
3930
0
  if (abfd->flags & EXEC_P)
3931
0
    internal_f.f_flags |= F_EXEC;
3932
#ifdef COFF_IMAGE_WITH_PE
3933
0
  if (! hasdebug)
3934
0
    internal_f.f_flags |= IMAGE_FILE_DEBUG_STRIPPED;
3935
0
  if (pe_data (abfd)->real_flags & IMAGE_FILE_LARGE_ADDRESS_AWARE)
3936
0
    internal_f.f_flags |= IMAGE_FILE_LARGE_ADDRESS_AWARE;
3937
#endif
3938
3939
#if !defined(COFF_WITH_pex64) && !defined(COFF_WITH_peAArch64) && !defined(COFF_WITH_peLoongArch64)
3940
#ifdef COFF_WITH_PE
3941
0
  internal_f.f_flags |= IMAGE_FILE_32BIT_MACHINE;
3942
#else
3943
0
  if (bfd_little_endian (abfd))
3944
0
    internal_f.f_flags |= F_AR32WR;
3945
0
  else
3946
0
    internal_f.f_flags |= F_AR32W;
3947
#endif
3948
#endif
3949
3950
#ifdef TI_TARGET_ID
3951
  /* Target id is used in TI COFF v1 and later; COFF0 won't use this field,
3952
     but it doesn't hurt to set it internally.  */
3953
0
  internal_f.f_target_id = TI_TARGET_ID;
3954
#endif
3955
3956
  /* FIXME, should do something about the other byte orders and
3957
     architectures.  */
3958
3959
#ifdef RS6000COFF_C
3960
0
  if ((abfd->flags & DYNAMIC) != 0)
3961
0
    internal_f.f_flags |= F_SHROBJ;
3962
0
  if (bfd_get_section_by_name (abfd, _LOADER) != NULL)
3963
0
    internal_f.f_flags |= F_DYNLOAD;
3964
#endif
3965
3966
0
  memset (&internal_a, 0, sizeof internal_a);
3967
3968
  /* Set up architecture-dependent stuff.  */
3969
0
  {
3970
0
    unsigned int magic = 0;
3971
0
    unsigned short flags = 0;
3972
3973
0
    coff_set_flags (abfd, &magic, &flags);
3974
0
    internal_f.f_magic = magic;
3975
0
    internal_f.f_flags |= flags;
3976
    /* ...and the "opt"hdr...  */
3977
3978
#ifdef TICOFF_AOUT_MAGIC
3979
0
    internal_a.magic = TICOFF_AOUT_MAGIC;
3980
#define __A_MAGIC_SET__
3981
#endif
3982
3983
#if defined(ARM)
3984
#define __A_MAGIC_SET__
3985
0
    internal_a.magic = ZMAGIC;
3986
#endif
3987
3988
#if defined(AARCH64)
3989
#define __A_MAGIC_SET__
3990
0
    internal_a.magic = ZMAGIC;
3991
#endif
3992
3993
#if defined(LOONGARCH64)
3994
#define __A_MAGIC_SET__
3995
0
    internal_a.magic = ZMAGIC;
3996
#endif
3997
3998
#if defined MCORE_PE
3999
#define __A_MAGIC_SET__
4000
0
    internal_a.magic = IMAGE_NT_OPTIONAL_HDR_MAGIC;
4001
#endif
4002
4003
#if defined(I386)
4004
#define __A_MAGIC_SET__
4005
#if defined LYNXOS
4006
0
    internal_a.magic = LYNXCOFFMAGIC;
4007
#elif defined AMD64
4008
0
    internal_a.magic = IMAGE_NT_OPTIONAL_HDR64_MAGIC;
4009
#else
4010
0
    internal_a.magic = ZMAGIC;
4011
#endif
4012
#endif /* I386 */
4013
4014
#if defined(IA64)
4015
#define __A_MAGIC_SET__
4016
0
    internal_a.magic = PE32PMAGIC;
4017
#endif /* IA64 */
4018
4019
#if defined(SPARC)
4020
#define __A_MAGIC_SET__
4021
#if defined(LYNXOS)
4022
    internal_a.magic = LYNXCOFFMAGIC;
4023
#endif /* LYNXOS */
4024
#endif /* SPARC */
4025
4026
#ifdef RS6000COFF_C
4027
#define __A_MAGIC_SET__
4028
0
    internal_a.magic = (abfd->flags & D_PAGED) ? RS6K_AOUTHDR_ZMAGIC :
4029
0
    (abfd->flags & WP_TEXT) ? RS6K_AOUTHDR_NMAGIC :
4030
0
    RS6K_AOUTHDR_OMAGIC;
4031
#endif
4032
4033
#if defined(SH) && defined(COFF_WITH_PE)
4034
#define __A_MAGIC_SET__
4035
0
    internal_a.magic = SH_PE_MAGIC;
4036
#endif
4037
4038
#if defined(MIPS) && defined(COFF_WITH_PE)
4039
#define __A_MAGIC_SET__
4040
    internal_a.magic = MIPS_PE_MAGIC;
4041
#endif
4042
4043
#ifndef __A_MAGIC_SET__
4044
#include "Your aouthdr magic number is not being set!"
4045
#else
4046
0
#undef __A_MAGIC_SET__
4047
0
#endif
4048
0
  }
4049
4050
#ifdef RS6000COFF_C
4051
  /* XCOFF 32bit needs this to have new behaviour for n_type field.  */
4052
  internal_a.vstamp = 2;
4053
#else
4054
  /* FIXME: Does anybody ever set this to another value?  */
4055
  internal_a.vstamp = 0;
4056
#endif
4057
4058
  /* Now should write relocs, strings, syms.  */
4059
0
  obj_sym_filepos (abfd) = sym_base;
4060
4061
0
  if (bfd_get_symcount (abfd) != 0)
4062
0
    {
4063
0
      int firstundef;
4064
4065
0
      if (!coff_renumber_symbols (abfd, &firstundef))
4066
0
  return false;
4067
0
      coff_mangle_symbols (abfd);
4068
0
      if (! coff_write_symbols (abfd))
4069
0
  return false;
4070
0
      if (! coff_write_linenumbers (abfd))
4071
0
  return false;
4072
0
      if (! coff_write_relocs (abfd, firstundef))
4073
0
  return false;
4074
0
    }
4075
#ifdef COFF_LONG_SECTION_NAMES
4076
0
  else if (long_section_names && ! obj_coff_strings_written (abfd))
4077
0
    {
4078
      /* If we have long section names we have to write out the string
4079
   table even if there are no symbols.  */
4080
0
      if (! coff_write_symbols (abfd))
4081
0
  return false;
4082
0
    }
4083
0
#endif
4084
  /* If bfd_get_symcount (abfd) != 0, then we are not using the COFF
4085
     backend linker, and obj_raw_syment_count is not valid until after
4086
     coff_write_symbols is called.  */
4087
0
  if (obj_raw_syment_count (abfd) != 0)
4088
0
    {
4089
0
      internal_f.f_symptr = sym_base;
4090
#ifdef RS6000COFF_C
4091
      /* AIX appears to require that F_RELFLG not be set if there are
4092
   local symbols but no relocations.  */
4093
0
      internal_f.f_flags &=~ F_RELFLG;
4094
#endif
4095
0
    }
4096
0
  else
4097
0
    {
4098
0
      if (long_section_names)
4099
0
  internal_f.f_symptr = sym_base;
4100
0
      else
4101
0
  internal_f.f_symptr = 0;
4102
0
      internal_f.f_flags |= F_LSYMS;
4103
0
    }
4104
4105
0
  if (text_sec)
4106
0
    {
4107
0
      internal_a.tsize = text_sec->size;
4108
0
      internal_a.text_start = internal_a.tsize ? text_sec->vma : 0;
4109
0
    }
4110
0
  if (data_sec)
4111
0
    {
4112
0
      internal_a.dsize = data_sec->size;
4113
0
      internal_a.data_start = internal_a.dsize ? data_sec->vma : 0;
4114
0
    }
4115
0
  if (bss_sec)
4116
0
    {
4117
0
      internal_a.bsize = bss_sec->size;
4118
0
      if (internal_a.bsize && bss_sec->vma < internal_a.data_start)
4119
0
  internal_a.data_start = bss_sec->vma;
4120
0
    }
4121
4122
0
  internal_a.entry = bfd_get_start_address (abfd);
4123
0
  internal_f.f_nsyms = obj_raw_syment_count (abfd);
4124
4125
#ifdef RS6000COFF_C
4126
0
  if (xcoff_data (abfd)->full_aouthdr)
4127
0
    {
4128
0
      bfd_vma toc;
4129
0
      asection *loader_sec;
4130
4131
      internal_a.vstamp = 2;
4132
4133
0
      internal_a.o_snentry = xcoff_data (abfd)->snentry;
4134
0
      if (internal_a.o_snentry == 0)
4135
0
  internal_a.entry = (bfd_vma) -1;
4136
4137
0
      if (text_sec != NULL)
4138
0
  {
4139
0
    internal_a.o_sntext = text_sec->target_index;
4140
0
    internal_a.o_algntext = bfd_section_alignment (text_sec);
4141
0
  }
4142
0
      else
4143
0
  {
4144
0
    internal_a.o_sntext = 0;
4145
0
    internal_a.o_algntext = 0;
4146
0
  }
4147
0
      if (data_sec != NULL)
4148
0
  {
4149
0
    internal_a.o_sndata = data_sec->target_index;
4150
0
    internal_a.o_algndata = bfd_section_alignment (data_sec);
4151
0
  }
4152
0
      else
4153
0
  {
4154
0
    internal_a.o_sndata = 0;
4155
0
    internal_a.o_algndata = 0;
4156
0
  }
4157
      loader_sec = bfd_get_section_by_name (abfd, ".loader");
4158
0
      if (loader_sec != NULL)
4159
0
  internal_a.o_snloader = loader_sec->target_index;
4160
0
      else
4161
0
  internal_a.o_snloader = 0;
4162
0
      if (bss_sec != NULL)
4163
0
  internal_a.o_snbss = bss_sec->target_index;
4164
0
      else
4165
0
  internal_a.o_snbss = 0;
4166
4167
0
      if (tdata_sec != NULL)
4168
0
  {
4169
0
    internal_a.o_sntdata = tdata_sec->target_index;
4170
    /* TODO: o_flags should be set to RS6K_AOUTHDR_TLS_LE
4171
       if there is at least one R_TLS_LE relocations.  */
4172
0
    internal_a.o_flags = 0;
4173
#ifdef XCOFF64
4174
    internal_a.o_x64flags = 0;
4175
#endif
4176
0
  }
4177
0
      else
4178
0
  {
4179
0
    internal_a.o_sntdata = 0;
4180
0
    internal_a.o_flags = 0;
4181
#ifdef XCOFF64
4182
    internal_a.o_x64flags = 0;
4183
#endif
4184
0
  }
4185
0
      if (tbss_sec != NULL)
4186
0
    internal_a.o_sntbss = tbss_sec->target_index;
4187
0
      else
4188
0
    internal_a.o_sntbss = 0;
4189
4190
0
      toc = xcoff_data (abfd)->toc;
4191
      internal_a.o_toc = toc;
4192
0
      internal_a.o_sntoc = xcoff_data (abfd)->sntoc;
4193
4194
0
      internal_a.o_modtype = xcoff_data (abfd)->modtype;
4195
0
      if (xcoff_data (abfd)->cputype != -1)
4196
0
  internal_a.o_cputype = xcoff_data (abfd)->cputype;
4197
0
      else
4198
0
  {
4199
0
    switch (bfd_get_arch (abfd))
4200
0
      {
4201
0
      case bfd_arch_rs6000:
4202
0
        internal_a.o_cputype = 4;
4203
0
        break;
4204
0
      case bfd_arch_powerpc:
4205
0
        if (bfd_get_mach (abfd) == bfd_mach_ppc)
4206
0
    internal_a.o_cputype = 3;
4207
0
        else if (bfd_get_mach (abfd) == bfd_mach_ppc_620)
4208
0
    internal_a.o_cputype = 2;
4209
0
        else
4210
0
    internal_a.o_cputype = 1;
4211
0
        break;
4212
0
      default:
4213
0
        abort ();
4214
0
      }
4215
0
  }
4216
0
      internal_a.o_maxstack = xcoff_data (abfd)->maxstack;
4217
0
      internal_a.o_maxdata = xcoff_data (abfd)->maxdata;
4218
0
    }
4219
0
#endif
4220
4221
#ifdef COFF_WITH_PE
4222
  {
4223
    /* After object contents are finalized so we can compute a reasonable hash,
4224
       but before header is written so we can update it to point to debug directory.  */
4225
0
    struct pe_tdata *pe = pe_data (abfd);
4226
4227
0
    if (pe->build_id.after_write_object_contents != NULL)
4228
0
      (*pe->build_id.after_write_object_contents) (abfd);
4229
  }
4230
#endif
4231
4232
  /* Now write header.  */
4233
0
  if (bfd_seek (abfd, (file_ptr) 0, SEEK_SET) != 0)
4234
0
    return false;
4235
4236
0
  {
4237
0
    char * buff;
4238
0
    bfd_size_type amount = bfd_coff_filhsz (abfd);
4239
4240
0
    buff = (char *) bfd_malloc (amount);
4241
0
    if (buff == NULL)
4242
0
      return false;
4243
4244
0
    bfd_coff_swap_filehdr_out (abfd, & internal_f, buff);
4245
0
    amount = bfd_bwrite (buff, amount, abfd);
4246
4247
0
    free (buff);
4248
4249
0
    if (amount != bfd_coff_filhsz (abfd))
4250
0
      return false;
4251
0
  }
4252
4253
0
  if (abfd->flags & EXEC_P)
4254
0
    {
4255
      /* Note that peicode.h fills in a PEAOUTHDR, not an AOUTHDR.
4256
   include/coff/pe.h sets AOUTSZ == sizeof (PEAOUTHDR)).  */
4257
0
      char * buff;
4258
0
      bfd_size_type amount = bfd_coff_aoutsz (abfd);
4259
4260
0
      buff = (char *) bfd_malloc (amount);
4261
0
      if (buff == NULL)
4262
0
  return false;
4263
4264
0
      coff_swap_aouthdr_out (abfd, & internal_a, buff);
4265
0
      amount = bfd_bwrite (buff, amount, abfd);
4266
4267
0
      free (buff);
4268
4269
0
      if (amount != bfd_coff_aoutsz (abfd))
4270
0
  return false;
4271
4272
#ifdef COFF_IMAGE_WITH_PE
4273
0
      if (! coff_apply_checksum (abfd))
4274
0
  return false;
4275
#endif
4276
0
    }
4277
#ifdef RS6000COFF_C
4278
#ifndef XCOFF64
4279
  else
4280
0
    {
4281
0
      AOUTHDR buff;
4282
0
      size_t size;
4283
4284
      /* XCOFF32 seems to always write at least a small a.out header.  */
4285
0
      coff_swap_aouthdr_out (abfd, & internal_a, & buff);
4286
0
      if (xcoff_data (abfd)->full_aouthdr)
4287
0
  size = bfd_coff_aoutsz (abfd);
4288
0
      else
4289
0
  size = SMALL_AOUTSZ;
4290
0
      if (bfd_bwrite (& buff, (bfd_size_type) size, abfd) != size)
4291
0
  return false;
4292
0
    }
4293
0
#endif
4294
#endif
4295
4296
0
  return true;
4297
0
}
Unexecuted instantiation: pei-i386.c:coff_write_object_contents
Unexecuted instantiation: pe-x86_64.c:coff_write_object_contents
Unexecuted instantiation: pei-x86_64.c:coff_write_object_contents
Unexecuted instantiation: coff-x86_64.c:coff_write_object_contents
Unexecuted instantiation: coff64-rs6000.c:coff_write_object_contents
Unexecuted instantiation: pei-aarch64.c:coff_write_object_contents
Unexecuted instantiation: pe-aarch64.c:coff_write_object_contents
Unexecuted instantiation: pei-ia64.c:coff_write_object_contents
Unexecuted instantiation: pei-loongarch64.c:coff_write_object_contents
Unexecuted instantiation: cf-i386lynx.c:coff_write_object_contents
Unexecuted instantiation: coff-go32.c:coff_write_object_contents
Unexecuted instantiation: coff-i386.c:coff_write_object_contents
Unexecuted instantiation: coff-rs6000.c:coff_write_object_contents
Unexecuted instantiation: coff-sh.c:coff_write_object_contents
Unexecuted instantiation: coff-stgo32.c:coff_write_object_contents
Unexecuted instantiation: coff-tic30.c:coff_write_object_contents
Unexecuted instantiation: coff-tic4x.c:coff_write_object_contents
Unexecuted instantiation: coff-tic54x.c:coff_write_object_contents
Unexecuted instantiation: coff-z80.c:coff_write_object_contents
Unexecuted instantiation: coff-z8k.c:coff_write_object_contents
Unexecuted instantiation: pe-arm-wince.c:coff_write_object_contents
Unexecuted instantiation: pe-arm.c:coff_write_object_contents
Unexecuted instantiation: pe-i386.c:coff_write_object_contents
Unexecuted instantiation: pe-mcore.c:coff_write_object_contents
Unexecuted instantiation: pe-sh.c:coff_write_object_contents
Unexecuted instantiation: pei-arm-wince.c:coff_write_object_contents
Unexecuted instantiation: pei-arm.c:coff_write_object_contents
Unexecuted instantiation: pei-mcore.c:coff_write_object_contents
Unexecuted instantiation: pei-sh.c:coff_write_object_contents
4298
4299
static bool
4300
coff_set_section_contents (bfd * abfd,
4301
         sec_ptr section,
4302
         const void * location,
4303
         file_ptr offset,
4304
         bfd_size_type count)
4305
0
{
4306
0
  if (! abfd->output_has_begun) /* Set by bfd.c handler.  */
4307
0
    {
4308
0
      if (! coff_compute_section_file_positions (abfd))
4309
0
  return false;
4310
0
    }
4311
4312
#if defined(_LIB) && !defined(TARG_AUX)
4313
   /* The physical address field of a .lib section is used to hold the
4314
      number of shared libraries in the section.  This code counts the
4315
      number of sections being written, and increments the lma field
4316
      with the number.
4317
4318
      I have found no documentation on the contents of this section.
4319
      Experimentation indicates that the section contains zero or more
4320
      records, each of which has the following structure:
4321
4322
      - a (four byte) word holding the length of this record, in words,
4323
      - a word that always seems to be set to "2",
4324
      - the path to a shared library, null-terminated and then padded
4325
  to a whole word boundary.
4326
4327
      bfd_assert calls have been added to alert if an attempt is made
4328
      to write a section which doesn't follow these assumptions.  The
4329
      code has been tested on ISC 4.1 by me, and on SCO by Robert Lipe
4330
      <robertl@arnet.com> (Thanks!).
4331
4332
      Gvran Uddeborg <gvran@uddeborg.pp.se>.  */
4333
0
    if (strcmp (section->name, _LIB) == 0)
4334
0
      {
4335
0
  bfd_byte *rec, *recend;
4336
4337
  rec = (bfd_byte *) location;
4338
  recend = rec + count;
4339
0
  while (recend - rec >= 4)
4340
0
    {
4341
0
      size_t len = bfd_get_32 (abfd, rec);
4342
0
      if (len == 0 || len > (size_t) (recend - rec) / 4)
4343
0
        break;
4344
0
      rec += len * 4;
4345
0
      ++section->lma;
4346
0
    }
4347
4348
0
  BFD_ASSERT (rec == recend);
4349
0
      }
4350
0
#endif
4351
4352
  /* Don't write out bss sections - one way to do this is to
4353
       see if the filepos has not been set.  */
4354
0
  if (section->filepos == 0)
4355
0
    return true;
4356
4357
0
  if (bfd_seek (abfd, section->filepos + offset, SEEK_SET) != 0)
4358
0
    return false;
4359
4360
0
  if (count == 0)
4361
0
    return true;
4362
4363
0
  return bfd_bwrite (location, count, abfd) == count;
4364
0
}
Unexecuted instantiation: pei-i386.c:coff_set_section_contents
Unexecuted instantiation: pe-x86_64.c:coff_set_section_contents
Unexecuted instantiation: pei-x86_64.c:coff_set_section_contents
Unexecuted instantiation: coff-x86_64.c:coff_set_section_contents
Unexecuted instantiation: coff64-rs6000.c:coff_set_section_contents
Unexecuted instantiation: pei-aarch64.c:coff_set_section_contents
Unexecuted instantiation: pe-aarch64.c:coff_set_section_contents
Unexecuted instantiation: pei-ia64.c:coff_set_section_contents
Unexecuted instantiation: pei-loongarch64.c:coff_set_section_contents
Unexecuted instantiation: cf-i386lynx.c:coff_set_section_contents
Unexecuted instantiation: coff-go32.c:coff_set_section_contents
Unexecuted instantiation: coff-i386.c:coff_set_section_contents
Unexecuted instantiation: coff-rs6000.c:coff_set_section_contents
Unexecuted instantiation: coff-sh.c:coff_set_section_contents
Unexecuted instantiation: coff-stgo32.c:coff_set_section_contents
Unexecuted instantiation: coff-tic30.c:coff_set_section_contents
Unexecuted instantiation: coff-tic4x.c:coff_set_section_contents
Unexecuted instantiation: coff-tic54x.c:coff_set_section_contents
Unexecuted instantiation: coff-z80.c:coff_set_section_contents
Unexecuted instantiation: coff-z8k.c:coff_set_section_contents
Unexecuted instantiation: pe-arm-wince.c:coff_set_section_contents
Unexecuted instantiation: pe-arm.c:coff_set_section_contents
Unexecuted instantiation: pe-i386.c:coff_set_section_contents
Unexecuted instantiation: pe-mcore.c:coff_set_section_contents
Unexecuted instantiation: pe-sh.c:coff_set_section_contents
Unexecuted instantiation: pei-arm-wince.c:coff_set_section_contents
Unexecuted instantiation: pei-arm.c:coff_set_section_contents
Unexecuted instantiation: pei-mcore.c:coff_set_section_contents
Unexecuted instantiation: pei-sh.c:coff_set_section_contents
4365
4366
static void *
4367
buy_and_read (bfd *abfd, file_ptr where,
4368
        bfd_size_type nmemb, bfd_size_type size)
4369
0
{
4370
0
  size_t amt;
4371
4372
0
  if (_bfd_mul_overflow (nmemb, size, &amt))
4373
0
    {
4374
0
      bfd_set_error (bfd_error_file_too_big);
4375
0
      return NULL;
4376
0
    }
4377
0
  if (bfd_seek (abfd, where, SEEK_SET) != 0)
4378
0
    return NULL;
4379
0
  return _bfd_malloc_and_read (abfd, amt, amt);
4380
0
}
Unexecuted instantiation: pei-i386.c:buy_and_read
Unexecuted instantiation: pe-x86_64.c:buy_and_read
Unexecuted instantiation: pei-x86_64.c:buy_and_read
Unexecuted instantiation: coff-x86_64.c:buy_and_read
Unexecuted instantiation: coff64-rs6000.c:buy_and_read
Unexecuted instantiation: pei-aarch64.c:buy_and_read
Unexecuted instantiation: pe-aarch64.c:buy_and_read
Unexecuted instantiation: pei-ia64.c:buy_and_read
Unexecuted instantiation: pei-loongarch64.c:buy_and_read
Unexecuted instantiation: cf-i386lynx.c:buy_and_read
Unexecuted instantiation: coff-go32.c:buy_and_read
Unexecuted instantiation: coff-i386.c:buy_and_read
Unexecuted instantiation: coff-rs6000.c:buy_and_read
Unexecuted instantiation: coff-sh.c:buy_and_read
Unexecuted instantiation: coff-stgo32.c:buy_and_read
Unexecuted instantiation: coff-tic30.c:buy_and_read
Unexecuted instantiation: coff-tic4x.c:buy_and_read
Unexecuted instantiation: coff-tic54x.c:buy_and_read
Unexecuted instantiation: coff-z80.c:buy_and_read
Unexecuted instantiation: coff-z8k.c:buy_and_read
Unexecuted instantiation: pe-arm-wince.c:buy_and_read
Unexecuted instantiation: pe-arm.c:buy_and_read
Unexecuted instantiation: pe-i386.c:buy_and_read
Unexecuted instantiation: pe-mcore.c:buy_and_read
Unexecuted instantiation: pe-sh.c:buy_and_read
Unexecuted instantiation: pei-arm-wince.c:buy_and_read
Unexecuted instantiation: pei-arm.c:buy_and_read
Unexecuted instantiation: pei-mcore.c:buy_and_read
Unexecuted instantiation: pei-sh.c:buy_and_read
4381
4382
/*
4383
SUBSUBSECTION
4384
  Reading linenumbers
4385
4386
  Creating the linenumber table is done by reading in the entire
4387
  coff linenumber table, and creating another table for internal use.
4388
4389
  A coff linenumber table is structured so that each function
4390
  is marked as having a line number of 0. Each line within the
4391
  function is an offset from the first line in the function. The
4392
  base of the line number information for the table is stored in
4393
  the symbol associated with the function.
4394
4395
  Note: The PE format uses line number 0 for a flag indicating a
4396
  new source file.
4397
4398
  The information is copied from the external to the internal
4399
  table, and each symbol which marks a function is marked by
4400
  pointing its...
4401
4402
  How does this work ?
4403
*/
4404
4405
static int
4406
coff_sort_func_alent (const void * arg1, const void * arg2)
4407
0
{
4408
0
  const alent *al1 = *(const alent **) arg1;
4409
0
  const alent *al2 = *(const alent **) arg2;
4410
0
  const coff_symbol_type *s1 = (const coff_symbol_type *) (al1->u.sym);
4411
0
  const coff_symbol_type *s2 = (const coff_symbol_type *) (al2->u.sym);
4412
4413
0
  if (s1 == NULL || s2 == NULL)
4414
0
    return 0;
4415
0
  if (s1->symbol.value < s2->symbol.value)
4416
0
    return -1;
4417
0
  else if (s1->symbol.value > s2->symbol.value)
4418
0
    return 1;
4419
4420
0
  return 0;
4421
0
}
Unexecuted instantiation: pei-i386.c:coff_sort_func_alent
Unexecuted instantiation: pe-x86_64.c:coff_sort_func_alent
Unexecuted instantiation: pei-x86_64.c:coff_sort_func_alent
Unexecuted instantiation: coff-x86_64.c:coff_sort_func_alent
Unexecuted instantiation: coff64-rs6000.c:coff_sort_func_alent
Unexecuted instantiation: pei-aarch64.c:coff_sort_func_alent
Unexecuted instantiation: pe-aarch64.c:coff_sort_func_alent
Unexecuted instantiation: pei-ia64.c:coff_sort_func_alent
Unexecuted instantiation: pei-loongarch64.c:coff_sort_func_alent
Unexecuted instantiation: cf-i386lynx.c:coff_sort_func_alent
Unexecuted instantiation: coff-go32.c:coff_sort_func_alent
Unexecuted instantiation: coff-i386.c:coff_sort_func_alent
Unexecuted instantiation: coff-rs6000.c:coff_sort_func_alent
Unexecuted instantiation: coff-sh.c:coff_sort_func_alent
Unexecuted instantiation: coff-stgo32.c:coff_sort_func_alent
Unexecuted instantiation: coff-tic30.c:coff_sort_func_alent
Unexecuted instantiation: coff-tic4x.c:coff_sort_func_alent
Unexecuted instantiation: coff-tic54x.c:coff_sort_func_alent
Unexecuted instantiation: coff-z80.c:coff_sort_func_alent
Unexecuted instantiation: coff-z8k.c:coff_sort_func_alent
Unexecuted instantiation: pe-arm-wince.c:coff_sort_func_alent
Unexecuted instantiation: pe-arm.c:coff_sort_func_alent
Unexecuted instantiation: pe-i386.c:coff_sort_func_alent
Unexecuted instantiation: pe-mcore.c:coff_sort_func_alent
Unexecuted instantiation: pe-sh.c:coff_sort_func_alent
Unexecuted instantiation: pei-arm-wince.c:coff_sort_func_alent
Unexecuted instantiation: pei-arm.c:coff_sort_func_alent
Unexecuted instantiation: pei-mcore.c:coff_sort_func_alent
Unexecuted instantiation: pei-sh.c:coff_sort_func_alent
4422
4423
static bool
4424
coff_slurp_line_table (bfd *abfd, asection *asect)
4425
0
{
4426
0
  LINENO *native_lineno;
4427
0
  alent *lineno_cache;
4428
0
  unsigned int counter;
4429
0
  alent *cache_ptr;
4430
0
  bfd_vma prev_offset = 0;
4431
0
  bool ordered = true;
4432
0
  unsigned int nbr_func;
4433
0
  LINENO *src;
4434
0
  bool have_func;
4435
0
  bool ret = true;
4436
0
  size_t amt;
4437
4438
0
  if (asect->lineno_count == 0)
4439
0
    return true;
4440
4441
0
  BFD_ASSERT (asect->lineno == NULL);
4442
4443
0
  native_lineno = (LINENO *) buy_and_read (abfd, asect->line_filepos,
4444
0
             asect->lineno_count,
4445
0
             bfd_coff_linesz (abfd));
4446
0
  if (native_lineno == NULL)
4447
0
    {
4448
0
      _bfd_error_handler
4449
0
  (_("%pB: warning: line number table read failed"), abfd);
4450
0
      return false;
4451
0
    }
4452
4453
0
  if (_bfd_mul_overflow (asect->lineno_count + 1, sizeof (alent), &amt))
4454
0
    {
4455
0
      bfd_set_error (bfd_error_file_too_big);
4456
0
      free (native_lineno);
4457
0
      return false;
4458
0
    }
4459
0
  lineno_cache = (alent *) bfd_alloc (abfd, amt);
4460
0
  if (lineno_cache == NULL)
4461
0
    {
4462
0
      free (native_lineno);
4463
0
      return false;
4464
0
    }
4465
4466
0
  cache_ptr = lineno_cache;
4467
0
  asect->lineno = lineno_cache;
4468
0
  src = native_lineno;
4469
0
  nbr_func = 0;
4470
0
  have_func = false;
4471
4472
0
  for (counter = 0; counter < asect->lineno_count; counter++, src++)
4473
0
    {
4474
0
      struct internal_lineno dst;
4475
4476
0
      bfd_coff_swap_lineno_in (abfd, src, &dst);
4477
0
      cache_ptr->line_number = dst.l_lnno;
4478
      /* Appease memory checkers that get all excited about
4479
   uninitialised memory when copying alents if u.offset is
4480
   larger than u.sym.  (64-bit BFD on 32-bit host.)  */
4481
0
      memset (&cache_ptr->u, 0, sizeof (cache_ptr->u));
4482
4483
0
      if (cache_ptr->line_number == 0)
4484
0
  {
4485
0
    combined_entry_type * ent;
4486
0
    unsigned long symndx;
4487
0
    coff_symbol_type *sym;
4488
4489
0
    have_func = false;
4490
0
    symndx = dst.l_addr.l_symndx;
4491
0
    if (symndx >= obj_raw_syment_count (abfd))
4492
0
      {
4493
0
        _bfd_error_handler
4494
    /* xgettext:c-format */
4495
0
    (_("%pB: warning: illegal symbol index 0x%lx in line number entry %d"),
4496
0
     abfd, symndx, counter);
4497
0
        cache_ptr->line_number = -1;
4498
0
        ret = false;
4499
0
        continue;
4500
0
      }
4501
4502
0
    ent = obj_raw_syments (abfd) + symndx;
4503
    /* FIXME: We should not be casting between ints and
4504
       pointers like this.  */
4505
0
    if (! ent->is_sym)
4506
0
      {
4507
0
        _bfd_error_handler
4508
    /* xgettext:c-format */
4509
0
    (_("%pB: warning: illegal symbol index 0x%lx in line number entry %d"),
4510
0
     abfd, symndx, counter);
4511
0
        cache_ptr->line_number = -1;
4512
0
        ret = false;
4513
0
        continue;
4514
0
      }
4515
0
    sym = (coff_symbol_type *) (ent->u.syment._n._n_n._n_zeroes);
4516
4517
    /* PR 17512 file: 078-10659-0.004  */
4518
0
    if (sym < obj_symbols (abfd)
4519
0
        || sym >= obj_symbols (abfd) + bfd_get_symcount (abfd))
4520
0
      {
4521
0
        _bfd_error_handler
4522
    /* xgettext:c-format */
4523
0
    (_("%pB: warning: illegal symbol in line number entry %d"),
4524
0
     abfd, counter);
4525
0
        cache_ptr->line_number = -1;
4526
0
        ret = false;
4527
0
        continue;
4528
0
      }
4529
4530
0
    have_func = true;
4531
0
    nbr_func++;
4532
0
    cache_ptr->u.sym = (asymbol *) sym;
4533
0
    if (sym->lineno != NULL)
4534
0
      _bfd_error_handler
4535
        /* xgettext:c-format */
4536
0
        (_("%pB: warning: duplicate line number information for `%s'"),
4537
0
         abfd, bfd_asymbol_name (&sym->symbol));
4538
4539
0
    sym->lineno = cache_ptr;
4540
0
    if (sym->symbol.value < prev_offset)
4541
0
      ordered = false;
4542
0
    prev_offset = sym->symbol.value;
4543
0
  }
4544
0
      else if (!have_func)
4545
  /* Drop line information that has no associated function.
4546
     PR 17521: file: 078-10659-0.004.  */
4547
0
  continue;
4548
0
      else
4549
0
  cache_ptr->u.offset = dst.l_addr.l_paddr - bfd_section_vma (asect);
4550
0
      cache_ptr++;
4551
0
    }
4552
4553
0
  asect->lineno_count = cache_ptr - lineno_cache;
4554
0
  memset (cache_ptr, 0, sizeof (*cache_ptr));
4555
0
  free (native_lineno);
4556
4557
  /* On some systems (eg AIX5.3) the lineno table may not be sorted.  */
4558
0
  if (!ordered)
4559
0
    {
4560
      /* Sort the table.  */
4561
0
      alent **func_table;
4562
0
      alent *n_lineno_cache;
4563
4564
      /* Create a table of functions.  */
4565
0
      if (_bfd_mul_overflow (nbr_func, sizeof (alent *), &amt))
4566
0
  {
4567
0
    bfd_set_error (bfd_error_file_too_big);
4568
0
    ret = false;
4569
0
  }
4570
0
      else if ((func_table = (alent **) bfd_alloc (abfd, amt)) != NULL)
4571
0
  {
4572
0
    alent **p = func_table;
4573
0
    unsigned int i;
4574
4575
0
    for (i = 0; i < asect->lineno_count; i++)
4576
0
      if (lineno_cache[i].line_number == 0)
4577
0
        *p++ = &lineno_cache[i];
4578
4579
0
    BFD_ASSERT ((unsigned int) (p - func_table) == nbr_func);
4580
4581
    /* Sort by functions.  */
4582
0
    qsort (func_table, nbr_func, sizeof (alent *), coff_sort_func_alent);
4583
4584
    /* Create the new sorted table.  */
4585
0
    if (_bfd_mul_overflow (asect->lineno_count, sizeof (alent), &amt))
4586
0
      {
4587
0
        bfd_set_error (bfd_error_file_too_big);
4588
0
        ret = false;
4589
0
      }
4590
0
    else if ((n_lineno_cache = (alent *) bfd_alloc (abfd, amt)) != NULL)
4591
0
      {
4592
0
        alent *n_cache_ptr = n_lineno_cache;
4593
4594
0
        for (i = 0; i < nbr_func; i++)
4595
0
    {
4596
0
      coff_symbol_type *sym;
4597
0
      alent *old_ptr = func_table[i];
4598
4599
      /* Update the function entry.  */
4600
0
      sym = (coff_symbol_type *) old_ptr->u.sym;
4601
      /* PR binutils/17512: Point the lineno to where
4602
         this entry will be after the memcpy below.  */
4603
0
      sym->lineno = lineno_cache + (n_cache_ptr - n_lineno_cache);
4604
      /* Copy the function and line number entries.  */
4605
0
      do
4606
0
        *n_cache_ptr++ = *old_ptr++;
4607
0
      while (old_ptr->line_number != 0);
4608
0
    }
4609
4610
0
        memcpy (lineno_cache, n_lineno_cache,
4611
0
          asect->lineno_count * sizeof (alent));
4612
0
      }
4613
0
    else
4614
0
      ret = false;
4615
0
    bfd_release (abfd, func_table);
4616
0
  }
4617
0
      else
4618
0
  ret = false;
4619
0
    }
4620
4621
0
  return ret;
4622
0
}
Unexecuted instantiation: pei-i386.c:coff_slurp_line_table
Unexecuted instantiation: pe-x86_64.c:coff_slurp_line_table
Unexecuted instantiation: pei-x86_64.c:coff_slurp_line_table
Unexecuted instantiation: coff-x86_64.c:coff_slurp_line_table
Unexecuted instantiation: coff64-rs6000.c:coff_slurp_line_table
Unexecuted instantiation: pei-aarch64.c:coff_slurp_line_table
Unexecuted instantiation: pe-aarch64.c:coff_slurp_line_table
Unexecuted instantiation: pei-ia64.c:coff_slurp_line_table
Unexecuted instantiation: pei-loongarch64.c:coff_slurp_line_table
Unexecuted instantiation: cf-i386lynx.c:coff_slurp_line_table
Unexecuted instantiation: coff-go32.c:coff_slurp_line_table
Unexecuted instantiation: coff-i386.c:coff_slurp_line_table
Unexecuted instantiation: coff-rs6000.c:coff_slurp_line_table
Unexecuted instantiation: coff-sh.c:coff_slurp_line_table
Unexecuted instantiation: coff-stgo32.c:coff_slurp_line_table
Unexecuted instantiation: coff-tic30.c:coff_slurp_line_table
Unexecuted instantiation: coff-tic4x.c:coff_slurp_line_table
Unexecuted instantiation: coff-tic54x.c:coff_slurp_line_table
Unexecuted instantiation: coff-z80.c:coff_slurp_line_table
Unexecuted instantiation: coff-z8k.c:coff_slurp_line_table
Unexecuted instantiation: pe-arm-wince.c:coff_slurp_line_table
Unexecuted instantiation: pe-arm.c:coff_slurp_line_table
Unexecuted instantiation: pe-i386.c:coff_slurp_line_table
Unexecuted instantiation: pe-mcore.c:coff_slurp_line_table
Unexecuted instantiation: pe-sh.c:coff_slurp_line_table
Unexecuted instantiation: pei-arm-wince.c:coff_slurp_line_table
Unexecuted instantiation: pei-arm.c:coff_slurp_line_table
Unexecuted instantiation: pei-mcore.c:coff_slurp_line_table
Unexecuted instantiation: pei-sh.c:coff_slurp_line_table
4623
4624
/* Slurp in the symbol table, converting it to generic form.  Note
4625
   that if coff_relocate_section is defined, the linker will read
4626
   symbols via coff_link_add_symbols, rather than via this routine.  */
4627
4628
static bool
4629
coff_slurp_symbol_table (bfd * abfd)
4630
0
{
4631
0
  combined_entry_type *native_symbols;
4632
0
  coff_symbol_type *cached_area;
4633
0
  unsigned int *table_ptr;
4634
0
  unsigned int number_of_symbols = 0;
4635
0
  bool ret = true;
4636
0
  size_t amt;
4637
4638
0
  if (obj_symbols (abfd))
4639
0
    return true;
4640
4641
  /* Read in the symbol table.  */
4642
0
  if ((native_symbols = coff_get_normalized_symtab (abfd)) == NULL)
4643
0
    return false;
4644
4645
  /* Allocate enough room for all the symbols in cached form.  */
4646
0
  if (_bfd_mul_overflow (obj_raw_syment_count (abfd),
4647
0
       sizeof (*cached_area), &amt))
4648
0
    {
4649
0
      bfd_set_error (bfd_error_file_too_big);
4650
0
      return false;
4651
0
    }
4652
0
  cached_area = (coff_symbol_type *) bfd_alloc (abfd, amt);
4653
0
  if (cached_area == NULL)
4654
0
    return false;
4655
4656
0
  if (_bfd_mul_overflow (obj_raw_syment_count (abfd),
4657
0
       sizeof (*table_ptr), &amt))
4658
0
    {
4659
0
      bfd_set_error (bfd_error_file_too_big);
4660
0
      return false;
4661
0
    }
4662
0
  table_ptr = (unsigned int *) bfd_zalloc (abfd, amt);
4663
0
  if (table_ptr == NULL)
4664
0
    return false;
4665
0
  else
4666
0
    {
4667
0
      coff_symbol_type *dst = cached_area;
4668
0
      unsigned int last_native_index = obj_raw_syment_count (abfd);
4669
0
      unsigned int this_index = 0;
4670
4671
0
      while (this_index < last_native_index)
4672
0
  {
4673
0
    combined_entry_type *src = native_symbols + this_index;
4674
0
    table_ptr[this_index] = number_of_symbols;
4675
4676
0
    dst->symbol.the_bfd = abfd;
4677
0
    BFD_ASSERT (src->is_sym);
4678
0
    dst->symbol.name = (char *) (src->u.syment._n._n_n._n_offset);
4679
    /* We use the native name field to point to the cached field.  */
4680
0
    src->u.syment._n._n_n._n_zeroes = (uintptr_t) dst;
4681
0
    dst->symbol.section = coff_section_from_bfd_index (abfd,
4682
0
                 src->u.syment.n_scnum);
4683
0
    dst->symbol.flags = 0;
4684
    /* PR 17512: file: 079-7098-0.001:0.1.  */
4685
0
    dst->symbol.value = 0;
4686
0
    dst->done_lineno = false;
4687
4688
0
    switch (src->u.syment.n_sclass)
4689
0
      {
4690
0
      case C_EXT:
4691
0
      case C_WEAKEXT:
4692
#if defined ARM
4693
0
      case C_THUMBEXT:
4694
0
      case C_THUMBEXTFUNC:
4695
#endif
4696
#ifdef RS6000COFF_C
4697
0
      case C_HIDEXT:
4698
0
#if ! defined _AIX52 && ! defined AIX_WEAK_SUPPORT
4699
0
      case C_AIX_WEAKEXT:
4700
#endif
4701
#endif
4702
0
#ifdef C_SYSTEM
4703
0
      case C_SYSTEM: /* System Wide variable.  */
4704
0
#endif
4705
#ifdef COFF_WITH_PE
4706
      /* In PE, 0x68 (104) denotes a section symbol.  */
4707
0
      case C_SECTION:
4708
      /* In PE, 0x69 (105) denotes a weak external symbol.  */
4709
0
      case C_NT_WEAK:
4710
#endif
4711
0
        switch (coff_classify_symbol (abfd, &src->u.syment))
4712
0
    {
4713
0
    case COFF_SYMBOL_GLOBAL:
4714
0
      dst->symbol.flags = BSF_EXPORT | BSF_GLOBAL;
4715
#if defined COFF_WITH_PE
4716
      /* PE sets the symbol to a value relative to the
4717
         start of the section.  */
4718
      dst->symbol.value = src->u.syment.n_value;
4719
#else
4720
      dst->symbol.value = (src->u.syment.n_value
4721
               - dst->symbol.section->vma);
4722
#endif
4723
0
      if (ISFCN ((src->u.syment.n_type)))
4724
        /* A function ext does not go at the end of a
4725
           file.  */
4726
0
        dst->symbol.flags |= BSF_NOT_AT_END | BSF_FUNCTION;
4727
0
      break;
4728
4729
0
    case COFF_SYMBOL_COMMON:
4730
0
      dst->symbol.section = bfd_com_section_ptr;
4731
0
      dst->symbol.value = src->u.syment.n_value;
4732
0
      break;
4733
4734
0
    case COFF_SYMBOL_UNDEFINED:
4735
0
      dst->symbol.section = bfd_und_section_ptr;
4736
0
      dst->symbol.value = 0;
4737
0
      break;
4738
4739
0
    case COFF_SYMBOL_PE_SECTION:
4740
0
      dst->symbol.flags |= BSF_EXPORT | BSF_SECTION_SYM;
4741
0
      dst->symbol.value = 0;
4742
0
      break;
4743
4744
0
    case COFF_SYMBOL_LOCAL:
4745
0
      dst->symbol.flags = BSF_LOCAL;
4746
#if defined COFF_WITH_PE
4747
      /* PE sets the symbol to a value relative to the
4748
         start of the section.  */
4749
      dst->symbol.value = src->u.syment.n_value;
4750
#else
4751
      dst->symbol.value = (src->u.syment.n_value
4752
               - dst->symbol.section->vma);
4753
#endif
4754
0
      if (ISFCN ((src->u.syment.n_type)))
4755
0
        dst->symbol.flags |= BSF_NOT_AT_END | BSF_FUNCTION;
4756
0
      break;
4757
0
    }
4758
4759
#ifdef RS6000COFF_C
4760
        /* A symbol with a csect entry should not go at the end.  */
4761
0
        if (src->u.syment.n_numaux > 0)
4762
0
    dst->symbol.flags |= BSF_NOT_AT_END;
4763
#endif
4764
4765
#ifdef COFF_WITH_PE
4766
0
        if (src->u.syment.n_sclass == C_NT_WEAK)
4767
0
    dst->symbol.flags |= BSF_WEAK;
4768
4769
0
        if (src->u.syment.n_sclass == C_SECTION
4770
0
      && src->u.syment.n_scnum > 0)
4771
0
    dst->symbol.flags = BSF_LOCAL;
4772
#endif
4773
0
        if (src->u.syment.n_sclass == C_WEAKEXT
4774
#ifdef RS6000COFF_C
4775
0
      || src->u.syment.n_sclass == C_AIX_WEAKEXT
4776
#endif
4777
0
      )
4778
0
    dst->symbol.flags |= BSF_WEAK;
4779
4780
0
        break;
4781
4782
0
      case C_STAT:  /* Static.  */
4783
#if defined ARM
4784
0
      case C_THUMBSTAT:    /* Thumb static.  */
4785
0
      case C_THUMBLABEL:   /* Thumb label.  */
4786
0
      case C_THUMBSTATFUNC:/* Thumb static function.  */
4787
#endif
4788
#ifdef RS6000COFF_C
4789
0
      case C_DWARF:  /* A label in a dwarf section.  */
4790
0
      case C_INFO:  /* A label in a comment section.  */
4791
#endif
4792
0
      case C_LABEL:  /* Label.  */
4793
0
        if (src->u.syment.n_scnum == N_DEBUG)
4794
0
    dst->symbol.flags = BSF_DEBUGGING;
4795
0
        else
4796
0
    dst->symbol.flags = BSF_LOCAL;
4797
4798
        /* Base the value as an index from the base of the
4799
     section, if there is one.  */
4800
0
        if (dst->symbol.section)
4801
0
    {
4802
#if defined COFF_WITH_PE
4803
      /* PE sets the symbol to a value relative to the
4804
         start of the section.  */
4805
      dst->symbol.value = src->u.syment.n_value;
4806
#else
4807
      dst->symbol.value = (src->u.syment.n_value
4808
               - dst->symbol.section->vma);
4809
#endif
4810
0
    }
4811
0
        else
4812
0
    dst->symbol.value = src->u.syment.n_value;
4813
0
        break;
4814
4815
0
      case C_FILE: /* File name.  */
4816
0
        dst->symbol.flags = BSF_FILE;
4817
        /* Fall through.  */
4818
0
      case C_MOS:   /* Member of structure.  */
4819
0
      case C_EOS:   /* End of structure.  */
4820
0
      case C_REGPARM: /* Register parameter.  */
4821
0
      case C_REG:   /* register variable.  */
4822
        /* C_AUTOARG conflicts with TI COFF C_UEXT.  */
4823
0
      case C_TPDEF: /* Type definition.  */
4824
0
      case C_ARG:
4825
0
      case C_AUTO: /* Automatic variable.  */
4826
0
      case C_FIELD: /* Bit field.  */
4827
0
      case C_ENTAG: /* Enumeration tag.  */
4828
0
      case C_MOE:   /* Member of enumeration.  */
4829
0
      case C_MOU:   /* Member of union.  */
4830
0
      case C_UNTAG: /* Union tag.  */
4831
0
      case C_STRTAG: /* Structure tag.  */
4832
#ifdef RS6000COFF_C
4833
0
      case C_GSYM:
4834
0
      case C_LSYM:
4835
0
      case C_PSYM:
4836
0
      case C_RSYM:
4837
0
      case C_RPSYM:
4838
0
      case C_STSYM:
4839
0
      case C_TCSYM:
4840
0
      case C_BCOMM:
4841
0
      case C_ECOML:
4842
0
      case C_ECOMM:
4843
0
      case C_DECL:
4844
0
      case C_ENTRY:
4845
0
      case C_FUN:
4846
0
      case C_ESTAT:
4847
#endif
4848
0
        dst->symbol.flags |= BSF_DEBUGGING;
4849
0
        dst->symbol.value = (src->u.syment.n_value);
4850
0
        break;
4851
4852
#ifdef RS6000COFF_C
4853
0
      case C_BINCL: /* Beginning of include file.  */
4854
0
      case C_EINCL: /* Ending of include file.  */
4855
        /* The value is actually a pointer into the line numbers
4856
     of the file.  We locate the line number entry, and
4857
     set the section to the section which contains it, and
4858
     the value to the index in that section.  */
4859
0
        {
4860
0
    asection *sec;
4861
4862
0
    dst->symbol.flags = BSF_DEBUGGING;
4863
0
    for (sec = abfd->sections; sec != NULL; sec = sec->next)
4864
0
      if (sec->line_filepos <= (file_ptr) src->u.syment.n_value
4865
0
          && ((file_ptr) (sec->line_filepos
4866
0
              + sec->lineno_count * bfd_coff_linesz (abfd))
4867
0
        > (file_ptr) src->u.syment.n_value))
4868
0
        break;
4869
0
    if (sec == NULL)
4870
0
      dst->symbol.value = 0;
4871
0
    else
4872
0
      {
4873
0
        dst->symbol.section = sec;
4874
0
        dst->symbol.value = ((src->u.syment.n_value
4875
0
            - sec->line_filepos)
4876
0
           / bfd_coff_linesz (abfd));
4877
0
        src->fix_line = 1;
4878
0
      }
4879
0
        }
4880
0
        break;
4881
4882
0
      case C_BSTAT:
4883
0
        dst->symbol.flags = BSF_DEBUGGING;
4884
4885
0
        if (src->u.syment.n_value >= obj_raw_syment_count (abfd))
4886
0
    dst->symbol.value = 0;
4887
0
        else
4888
0
    {
4889
      /* The value is actually a symbol index.  Save a pointer
4890
         to the symbol instead of the index.  FIXME: This
4891
         should use a union.  */
4892
0
      src->u.syment.n_value
4893
0
        = (uintptr_t) (native_symbols + src->u.syment.n_value);
4894
0
      dst->symbol.value = src->u.syment.n_value;
4895
0
      src->fix_value = 1;
4896
0
    }
4897
0
        break;
4898
0
#endif
4899
4900
0
      case C_BLOCK: /* ".bb" or ".eb".  */
4901
0
      case C_FCN:   /* ".bf" or ".ef" (or PE ".lf").  */
4902
0
      case C_EFCN: /* Physical end of function.  */
4903
#if defined COFF_WITH_PE
4904
        /* PE sets the symbol to a value relative to the start
4905
     of the section.  */
4906
        dst->symbol.value = src->u.syment.n_value;
4907
0
        if (strcmp (dst->symbol.name, ".bf") != 0)
4908
0
    {
4909
      /* PE uses funny values for .ef and .lf; don't
4910
         relocate them.  */
4911
0
      dst->symbol.flags = BSF_DEBUGGING;
4912
0
    }
4913
0
        else
4914
0
    dst->symbol.flags = BSF_DEBUGGING | BSF_DEBUGGING_RELOC;
4915
#else
4916
        /* Base the value as an index from the base of the
4917
     section.  */
4918
0
        dst->symbol.flags = BSF_LOCAL;
4919
        dst->symbol.value = (src->u.syment.n_value
4920
           - dst->symbol.section->vma);
4921
#endif
4922
0
        break;
4923
4924
0
      case C_STATLAB: /* Static load time label.  */
4925
0
        dst->symbol.value = src->u.syment.n_value;
4926
0
        dst->symbol.flags = BSF_GLOBAL;
4927
0
        break;
4928
4929
0
      case C_NULL:
4930
        /* PE DLLs sometimes have zeroed out symbols for some
4931
     reason.  Just ignore them without a warning.  */
4932
0
        if (src->u.syment.n_type == 0
4933
0
      && src->u.syment.n_value == 0
4934
0
      && src->u.syment.n_scnum == 0)
4935
0
    break;
4936
#ifdef RS6000COFF_C
4937
        /* XCOFF specific: deleted entry.  */
4938
0
        if (src->u.syment.n_value == C_NULL_VALUE)
4939
0
    break;
4940
0
#endif
4941
        /* Fall through.  */
4942
0
      case C_EXTDEF: /* External definition.  */
4943
0
      case C_ULABEL: /* Undefined label.  */
4944
0
      case C_USTATIC: /* Undefined static.  */
4945
#ifndef COFF_WITH_PE
4946
      /* C_LINE in regular coff is 0x68.  NT has taken over this storage
4947
         class to represent a section symbol.  */
4948
0
      case C_LINE: /* line # reformatted as symbol table entry.  */
4949
        /* NT uses 0x67 for a weak symbol, not C_ALIAS.  */
4950
0
      case C_ALIAS: /* Duplicate tag.  */
4951
0
#endif
4952
        /* New storage classes for TI COFF.  */
4953
#ifdef TICOFF
4954
0
      case C_UEXT: /* Tentative external definition.  */
4955
#endif
4956
0
      case C_EXTLAB: /* External load time label.  */
4957
0
      default:
4958
0
        _bfd_error_handler
4959
    /* xgettext:c-format */
4960
0
    (_("%pB: unrecognized storage class %d for %s symbol `%s'"),
4961
0
     abfd, src->u.syment.n_sclass,
4962
0
     dst->symbol.section->name, dst->symbol.name);
4963
0
        ret = false;
4964
        /* Fall through.  */
4965
0
      case C_HIDDEN: /* Ext symbol in dmert public lib.  */
4966
        /* PR 20722: These symbols can also be generated by
4967
     building DLLs with --gc-sections enabled.  */
4968
0
        dst->symbol.flags = BSF_DEBUGGING;
4969
0
        dst->symbol.value = (src->u.syment.n_value);
4970
0
        break;
4971
0
      }
4972
4973
0
    dst->native = src;
4974
0
    dst->symbol.udata.i = 0;
4975
0
    dst->lineno = NULL;
4976
4977
0
    this_index += (src->u.syment.n_numaux) + 1;
4978
0
    dst++;
4979
0
    number_of_symbols++;
4980
0
  }
4981
0
    }
4982
4983
0
  obj_symbols (abfd) = cached_area;
4984
0
  obj_raw_syments (abfd) = native_symbols;
4985
4986
0
  abfd->symcount = number_of_symbols;
4987
0
  obj_convert (abfd) = table_ptr;
4988
  /* Slurp the line tables for each section too.  */
4989
0
  {
4990
0
    asection *p;
4991
4992
0
    p = abfd->sections;
4993
0
    while (p)
4994
0
      {
4995
0
  if (! coff_slurp_line_table (abfd, p))
4996
0
    return false;
4997
0
  p = p->next;
4998
0
      }
4999
0
  }
5000
5001
0
  return ret;
5002
0
}
Unexecuted instantiation: pei-i386.c:coff_slurp_symbol_table
Unexecuted instantiation: pe-x86_64.c:coff_slurp_symbol_table
Unexecuted instantiation: pei-x86_64.c:coff_slurp_symbol_table
Unexecuted instantiation: coff-x86_64.c:coff_slurp_symbol_table
Unexecuted instantiation: coff64-rs6000.c:coff_slurp_symbol_table
Unexecuted instantiation: pei-aarch64.c:coff_slurp_symbol_table
Unexecuted instantiation: pe-aarch64.c:coff_slurp_symbol_table
Unexecuted instantiation: pei-ia64.c:coff_slurp_symbol_table
Unexecuted instantiation: pei-loongarch64.c:coff_slurp_symbol_table
Unexecuted instantiation: cf-i386lynx.c:coff_slurp_symbol_table
Unexecuted instantiation: coff-go32.c:coff_slurp_symbol_table
Unexecuted instantiation: coff-i386.c:coff_slurp_symbol_table
Unexecuted instantiation: coff-rs6000.c:coff_slurp_symbol_table
Unexecuted instantiation: coff-sh.c:coff_slurp_symbol_table
Unexecuted instantiation: coff-stgo32.c:coff_slurp_symbol_table
Unexecuted instantiation: coff-tic30.c:coff_slurp_symbol_table
Unexecuted instantiation: coff-tic4x.c:coff_slurp_symbol_table
Unexecuted instantiation: coff-tic54x.c:coff_slurp_symbol_table
Unexecuted instantiation: coff-z80.c:coff_slurp_symbol_table
Unexecuted instantiation: coff-z8k.c:coff_slurp_symbol_table
Unexecuted instantiation: pe-arm-wince.c:coff_slurp_symbol_table
Unexecuted instantiation: pe-arm.c:coff_slurp_symbol_table
Unexecuted instantiation: pe-i386.c:coff_slurp_symbol_table
Unexecuted instantiation: pe-mcore.c:coff_slurp_symbol_table
Unexecuted instantiation: pe-sh.c:coff_slurp_symbol_table
Unexecuted instantiation: pei-arm-wince.c:coff_slurp_symbol_table
Unexecuted instantiation: pei-arm.c:coff_slurp_symbol_table
Unexecuted instantiation: pei-mcore.c:coff_slurp_symbol_table
Unexecuted instantiation: pei-sh.c:coff_slurp_symbol_table
5003
5004
/* Classify a COFF symbol.  A couple of targets have globally visible
5005
   symbols which are not class C_EXT, and this handles those.  It also
5006
   recognizes some special PE cases.  */
5007
5008
static enum coff_symbol_classification
5009
coff_classify_symbol (bfd *abfd,
5010
          struct internal_syment *syment)
5011
0
{
5012
  /* FIXME: This partially duplicates the switch in
5013
     coff_slurp_symbol_table.  */
5014
0
  switch (syment->n_sclass)
5015
0
    {
5016
0
    case C_EXT:
5017
0
    case C_WEAKEXT:
5018
#ifdef ARM
5019
0
    case C_THUMBEXT:
5020
0
    case C_THUMBEXTFUNC:
5021
#endif
5022
#ifdef RS6000COFF_C
5023
0
    case C_HIDEXT:
5024
0
#if ! defined _AIX52 && ! defined AIX_WEAK_SUPPORT
5025
0
    case C_AIX_WEAKEXT:
5026
#endif
5027
#endif
5028
0
#ifdef C_SYSTEM
5029
0
    case C_SYSTEM:
5030
0
#endif
5031
#ifdef COFF_WITH_PE
5032
0
    case C_NT_WEAK:
5033
#endif
5034
0
      if (syment->n_scnum == 0)
5035
0
  {
5036
0
    if (syment->n_value == 0)
5037
0
      return COFF_SYMBOL_UNDEFINED;
5038
0
    else
5039
0
      return COFF_SYMBOL_COMMON;
5040
0
  }
5041
#ifdef RS6000COFF_C
5042
0
      if (syment->n_sclass == C_HIDEXT)
5043
0
  return COFF_SYMBOL_LOCAL;
5044
0
#endif
5045
0
      return COFF_SYMBOL_GLOBAL;
5046
5047
0
    default:
5048
0
      break;
5049
0
    }
5050
5051
#ifdef COFF_WITH_PE
5052
0
  if (syment->n_sclass == C_STAT)
5053
0
    {
5054
0
      if (syment->n_scnum == 0)
5055
  /* The Microsoft compiler sometimes generates these if a
5056
     small static function is inlined every time it is used.
5057
     The function is discarded, but the symbol table entry
5058
     remains.  */
5059
0
  return COFF_SYMBOL_LOCAL;
5060
5061
#ifdef STRICT_PE_FORMAT
5062
      /* This is correct for Microsoft generated objects, but it
5063
   breaks gas generated objects.  */
5064
      if (syment->n_value == 0)
5065
  {
5066
    const asection *sec;
5067
    const char *name;
5068
    char buf[SYMNMLEN + 1];
5069
5070
    name = _bfd_coff_internal_syment_name (abfd, syment, buf);
5071
    sec = coff_section_from_bfd_index (abfd, syment->n_scnum);
5072
    if (sec != NULL && name != NULL
5073
        && (strcmp (bfd_section_name (sec), name) == 0))
5074
      return COFF_SYMBOL_PE_SECTION;
5075
  }
5076
#endif
5077
5078
0
      return COFF_SYMBOL_LOCAL;
5079
0
    }
5080
5081
0
  if (syment->n_sclass == C_SECTION)
5082
0
    {
5083
      /* In some cases in a DLL generated by the Microsoft linker, the
5084
   n_value field will contain garbage.  FIXME: This should
5085
   probably be handled by the swapping function instead.  */
5086
0
      syment->n_value = 0;
5087
0
      if (syment->n_scnum == 0)
5088
0
  return COFF_SYMBOL_UNDEFINED;
5089
0
      return COFF_SYMBOL_PE_SECTION;
5090
0
    }
5091
0
#endif /* COFF_WITH_PE */
5092
5093
  /* If it is not a global symbol, we presume it is a local symbol.  */
5094
0
  if (syment->n_scnum == 0)
5095
0
    {
5096
0
      char buf[SYMNMLEN + 1];
5097
5098
0
      _bfd_error_handler
5099
  /* xgettext:c-format */
5100
0
  (_("warning: %pB: local symbol `%s' has no section"),
5101
0
   abfd, _bfd_coff_internal_syment_name (abfd, syment, buf));
5102
0
    }
5103
5104
0
  return COFF_SYMBOL_LOCAL;
5105
0
}
Unexecuted instantiation: pei-i386.c:coff_classify_symbol
Unexecuted instantiation: pe-x86_64.c:coff_classify_symbol
Unexecuted instantiation: pei-x86_64.c:coff_classify_symbol
Unexecuted instantiation: coff-x86_64.c:coff_classify_symbol
Unexecuted instantiation: coff64-rs6000.c:coff_classify_symbol
Unexecuted instantiation: pei-aarch64.c:coff_classify_symbol
Unexecuted instantiation: pe-aarch64.c:coff_classify_symbol
Unexecuted instantiation: pei-ia64.c:coff_classify_symbol
Unexecuted instantiation: pei-loongarch64.c:coff_classify_symbol
Unexecuted instantiation: cf-i386lynx.c:coff_classify_symbol
Unexecuted instantiation: coff-go32.c:coff_classify_symbol
Unexecuted instantiation: coff-i386.c:coff_classify_symbol
Unexecuted instantiation: coff-rs6000.c:coff_classify_symbol
Unexecuted instantiation: coff-sh.c:coff_classify_symbol
Unexecuted instantiation: coff-stgo32.c:coff_classify_symbol
Unexecuted instantiation: coff-tic30.c:coff_classify_symbol
Unexecuted instantiation: coff-tic4x.c:coff_classify_symbol
Unexecuted instantiation: coff-tic54x.c:coff_classify_symbol
Unexecuted instantiation: coff-z80.c:coff_classify_symbol
Unexecuted instantiation: coff-z8k.c:coff_classify_symbol
Unexecuted instantiation: pe-arm-wince.c:coff_classify_symbol
Unexecuted instantiation: pe-arm.c:coff_classify_symbol
Unexecuted instantiation: pe-i386.c:coff_classify_symbol
Unexecuted instantiation: pe-mcore.c:coff_classify_symbol
Unexecuted instantiation: pe-sh.c:coff_classify_symbol
Unexecuted instantiation: pei-arm-wince.c:coff_classify_symbol
Unexecuted instantiation: pei-arm.c:coff_classify_symbol
Unexecuted instantiation: pei-mcore.c:coff_classify_symbol
Unexecuted instantiation: pei-sh.c:coff_classify_symbol
5106
5107
/*
5108
SUBSUBSECTION
5109
  Reading relocations
5110
5111
  Coff relocations are easily transformed into the internal BFD form
5112
  (@code{arelent}).
5113
5114
  Reading a coff relocation table is done in the following stages:
5115
5116
  o Read the entire coff relocation table into memory.
5117
5118
  o Process each relocation in turn; first swap it from the
5119
  external to the internal form.
5120
5121
  o Turn the symbol referenced in the relocation's symbol index
5122
  into a pointer into the canonical symbol table.
5123
  This table is the same as the one returned by a call to
5124
  @code{bfd_canonicalize_symtab}. The back end will call that
5125
  routine and save the result if a canonicalization hasn't been done.
5126
5127
  o The reloc index is turned into a pointer to a howto
5128
  structure, in a back end specific way. For instance, the 386
5129
  uses the @code{r_type} to directly produce an index
5130
  into a howto table vector.
5131
5132
  o Note that @code{arelent.addend} for COFF is often not what
5133
  most people understand as a relocation addend, but rather an
5134
  adjustment to the relocation addend stored in section contents
5135
  of relocatable object files.  The value found in section
5136
  contents may also be confusing, depending on both symbol value
5137
  and addend somewhat similar to the field value for a
5138
  final-linked object.  See @code{CALC_ADDEND}.
5139
*/
5140
5141
#ifndef CALC_ADDEND
5142
#define CALC_ADDEND(abfd, ptr, reloc, cache_ptr)    \
5143
0
  {               \
5144
0
    coff_symbol_type *coffsym = NULL;       \
5145
0
                \
5146
0
    if (ptr && bfd_asymbol_bfd (ptr) != abfd)     \
5147
0
      coffsym = (obj_symbols (abfd)       \
5148
0
     + (cache_ptr->sym_ptr_ptr - symbols));   \
5149
0
    else if (ptr)           \
5150
0
      coffsym = coff_symbol_from (ptr);       \
5151
0
    if (coffsym != NULL            \
5152
0
  && coffsym->native->is_sym        \
5153
0
  && coffsym->native->u.syment.n_scnum == 0)   \
5154
0
      cache_ptr->addend = 0;         \
5155
0
    else if (ptr && bfd_asymbol_bfd (ptr) == abfd    \
5156
0
       && ptr->section != NULL)       \
5157
0
      cache_ptr->addend = - (ptr->section->vma + ptr->value); \
5158
0
    else              \
5159
0
      cache_ptr->addend = 0;         \
5160
0
  }
5161
#endif
5162
5163
static bool
5164
coff_slurp_reloc_table (bfd * abfd, sec_ptr asect, asymbol ** symbols)
5165
0
{
5166
0
  bfd_byte *native_relocs;
5167
0
  arelent *reloc_cache;
5168
0
  arelent *cache_ptr;
5169
0
  unsigned int idx;
5170
0
  size_t amt;
5171
5172
0
  if (asect->relocation)
5173
0
    return true;
5174
0
  if (asect->reloc_count == 0)
5175
0
    return true;
5176
0
  if (asect->flags & SEC_CONSTRUCTOR)
5177
0
    return true;
5178
0
  if (!coff_slurp_symbol_table (abfd))
5179
0
    return false;
5180
5181
0
  native_relocs = (bfd_byte *) buy_and_read (abfd, asect->rel_filepos,
5182
0
               asect->reloc_count,
5183
0
               bfd_coff_relsz (abfd));
5184
0
  if (native_relocs == NULL)
5185
0
    return false;
5186
5187
0
  if (_bfd_mul_overflow (asect->reloc_count, sizeof (arelent), &amt))
5188
0
    {
5189
0
      bfd_set_error (bfd_error_file_too_big);
5190
0
      return false;
5191
0
    }
5192
0
  reloc_cache = (arelent *) bfd_alloc (abfd, amt);
5193
0
  if (reloc_cache == NULL)
5194
0
    {
5195
0
      free (native_relocs);
5196
0
      return false;
5197
0
    }
5198
5199
0
  for (idx = 0; idx < asect->reloc_count; idx++)
5200
0
    {
5201
0
      struct internal_reloc dst;
5202
0
      void *src;
5203
#ifndef RELOC_PROCESSING
5204
      asymbol *ptr;
5205
#endif
5206
5207
0
      cache_ptr = reloc_cache + idx;
5208
0
      src = native_relocs + idx * (size_t) bfd_coff_relsz (abfd);
5209
5210
0
      dst.r_offset = 0;
5211
0
      bfd_coff_swap_reloc_in (abfd, src, &dst);
5212
5213
#ifdef RELOC_PROCESSING
5214
0
      RELOC_PROCESSING (cache_ptr, &dst, symbols, abfd, asect);
5215
#else
5216
      cache_ptr->address = dst.r_vaddr;
5217
5218
0
      if (dst.r_symndx != -1 && symbols != NULL)
5219
0
  {
5220
0
    if (dst.r_symndx < 0 || dst.r_symndx >= obj_conv_table_size (abfd))
5221
0
      {
5222
0
        _bfd_error_handler
5223
    /* xgettext:c-format */
5224
0
    (_("%pB: warning: illegal symbol index %ld in relocs"),
5225
0
     abfd, dst.r_symndx);
5226
0
        cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
5227
0
        ptr = NULL;
5228
0
      }
5229
0
    else
5230
0
      {
5231
0
        cache_ptr->sym_ptr_ptr = (symbols
5232
0
          + obj_convert (abfd)[dst.r_symndx]);
5233
0
        ptr = *(cache_ptr->sym_ptr_ptr);
5234
0
      }
5235
0
  }
5236
0
      else
5237
0
  {
5238
0
    cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
5239
0
    ptr = NULL;
5240
0
  }
5241
5242
      /* The symbols definitions that we have read in have been
5243
   relocated as if their sections started at 0. But the offsets
5244
   refering to the symbols in the raw data have not been
5245
   modified, so we have to have a negative addend to compensate.
5246
5247
   Note that symbols which used to be common must be left alone.  */
5248
5249
      /* Calculate any reloc addend by looking at the symbol.  */
5250
0
      CALC_ADDEND (abfd, ptr, dst, cache_ptr);
5251
      (void) ptr;
5252
5253
      cache_ptr->address -= asect->vma;
5254
      /* !! cache_ptr->section = NULL;*/
5255
5256
      /* Fill in the cache_ptr->howto field from dst.r_type.  */
5257
0
      RTYPE2HOWTO (cache_ptr, &dst);
5258
#endif  /* RELOC_PROCESSING */
5259
5260
0
      if (cache_ptr->howto == NULL)
5261
0
  {
5262
0
    _bfd_error_handler
5263
      /* xgettext:c-format */
5264
0
      (_("%pB: illegal relocation type %d at address %#" PRIx64),
5265
0
       abfd, dst.r_type, (uint64_t) dst.r_vaddr);
5266
0
    bfd_set_error (bfd_error_bad_value);
5267
0
    free (native_relocs);
5268
0
    return false;
5269
0
  }
5270
0
    }
5271
5272
0
  free (native_relocs);
5273
0
  asect->relocation = reloc_cache;
5274
0
  return true;
5275
0
}
Unexecuted instantiation: pei-i386.c:coff_slurp_reloc_table
Unexecuted instantiation: pe-x86_64.c:coff_slurp_reloc_table
Unexecuted instantiation: pei-x86_64.c:coff_slurp_reloc_table
Unexecuted instantiation: coff-x86_64.c:coff_slurp_reloc_table
Unexecuted instantiation: coff64-rs6000.c:coff_slurp_reloc_table
Unexecuted instantiation: pei-aarch64.c:coff_slurp_reloc_table
Unexecuted instantiation: pe-aarch64.c:coff_slurp_reloc_table
Unexecuted instantiation: pei-ia64.c:coff_slurp_reloc_table
Unexecuted instantiation: pei-loongarch64.c:coff_slurp_reloc_table
Unexecuted instantiation: cf-i386lynx.c:coff_slurp_reloc_table
Unexecuted instantiation: coff-go32.c:coff_slurp_reloc_table
Unexecuted instantiation: coff-i386.c:coff_slurp_reloc_table
Unexecuted instantiation: coff-rs6000.c:coff_slurp_reloc_table
Unexecuted instantiation: coff-sh.c:coff_slurp_reloc_table
Unexecuted instantiation: coff-stgo32.c:coff_slurp_reloc_table
Unexecuted instantiation: coff-tic30.c:coff_slurp_reloc_table
Unexecuted instantiation: coff-tic4x.c:coff_slurp_reloc_table
Unexecuted instantiation: coff-tic54x.c:coff_slurp_reloc_table
Unexecuted instantiation: coff-z80.c:coff_slurp_reloc_table
Unexecuted instantiation: coff-z8k.c:coff_slurp_reloc_table
Unexecuted instantiation: pe-arm-wince.c:coff_slurp_reloc_table
Unexecuted instantiation: pe-arm.c:coff_slurp_reloc_table
Unexecuted instantiation: pe-i386.c:coff_slurp_reloc_table
Unexecuted instantiation: pe-mcore.c:coff_slurp_reloc_table
Unexecuted instantiation: pe-sh.c:coff_slurp_reloc_table
Unexecuted instantiation: pei-arm-wince.c:coff_slurp_reloc_table
Unexecuted instantiation: pei-arm.c:coff_slurp_reloc_table
Unexecuted instantiation: pei-mcore.c:coff_slurp_reloc_table
Unexecuted instantiation: pei-sh.c:coff_slurp_reloc_table
5276
5277
#ifndef coff_rtype_to_howto
5278
#ifdef RTYPE2HOWTO
5279
5280
/* Get the howto structure for a reloc.  This is only used if the file
5281
   including this one defines coff_relocate_section to be
5282
   _bfd_coff_generic_relocate_section, so it is OK if it does not
5283
   always work.  It is the responsibility of the including file to
5284
   make sure it is reasonable if it is needed.  */
5285
5286
static reloc_howto_type *
5287
coff_rtype_to_howto (bfd *abfd ATTRIBUTE_UNUSED,
5288
         asection *sec ATTRIBUTE_UNUSED,
5289
         struct internal_reloc *rel ATTRIBUTE_UNUSED,
5290
         struct coff_link_hash_entry *h ATTRIBUTE_UNUSED,
5291
         struct internal_syment *sym ATTRIBUTE_UNUSED,
5292
         bfd_vma *addendp ATTRIBUTE_UNUSED)
5293
0
{
5294
0
  arelent genrel;
5295
5296
0
  genrel.howto = NULL;
5297
0
  RTYPE2HOWTO (&genrel, rel);
5298
0
  return genrel.howto;
5299
0
}
Unexecuted instantiation: coff64-rs6000.c:coff_rtype_to_howto
Unexecuted instantiation: pei-ia64.c:coff_rtype_to_howto
Unexecuted instantiation: pei-loongarch64.c:coff_rtype_to_howto
Unexecuted instantiation: coff-rs6000.c:coff_rtype_to_howto
Unexecuted instantiation: coff-sh.c:coff_rtype_to_howto
Unexecuted instantiation: coff-tic30.c:coff_rtype_to_howto
Unexecuted instantiation: coff-z80.c:coff_rtype_to_howto
Unexecuted instantiation: coff-z8k.c:coff_rtype_to_howto
5300
5301
#else /* ! defined (RTYPE2HOWTO) */
5302
5303
#define coff_rtype_to_howto NULL
5304
5305
#endif /* ! defined (RTYPE2HOWTO) */
5306
#endif /* ! defined (coff_rtype_to_howto) */
5307
5308
/* This is stupid.  This function should be a boolean predicate.  */
5309
5310
static long
5311
coff_canonicalize_reloc (bfd * abfd,
5312
       sec_ptr section,
5313
       arelent ** relptr,
5314
       asymbol ** symbols)
5315
0
{
5316
0
  arelent *tblptr = section->relocation;
5317
0
  unsigned int count = 0;
5318
5319
0
  if (section->flags & SEC_CONSTRUCTOR)
5320
0
    {
5321
      /* This section has relocs made up by us, they are not in the
5322
   file, so take them out of their chain and place them into
5323
   the data area provided.  */
5324
0
      arelent_chain *chain = section->constructor_chain;
5325
5326
0
      for (count = 0; count < section->reloc_count; count++)
5327
0
  {
5328
0
    *relptr++ = &chain->relent;
5329
0
    chain = chain->next;
5330
0
  }
5331
0
    }
5332
0
  else
5333
0
    {
5334
0
      if (! coff_slurp_reloc_table (abfd, section, symbols))
5335
0
  return -1;
5336
5337
0
      tblptr = section->relocation;
5338
5339
0
      for (; count++ < section->reloc_count;)
5340
0
  *relptr++ = tblptr++;
5341
0
    }
5342
0
  *relptr = 0;
5343
0
  return section->reloc_count;
5344
0
}
Unexecuted instantiation: pei-i386.c:coff_canonicalize_reloc
Unexecuted instantiation: pe-x86_64.c:coff_canonicalize_reloc
Unexecuted instantiation: pei-x86_64.c:coff_canonicalize_reloc
Unexecuted instantiation: coff-x86_64.c:coff_canonicalize_reloc
Unexecuted instantiation: coff64-rs6000.c:coff_canonicalize_reloc
Unexecuted instantiation: pei-aarch64.c:coff_canonicalize_reloc
Unexecuted instantiation: pe-aarch64.c:coff_canonicalize_reloc
Unexecuted instantiation: pei-ia64.c:coff_canonicalize_reloc
Unexecuted instantiation: pei-loongarch64.c:coff_canonicalize_reloc
Unexecuted instantiation: cf-i386lynx.c:coff_canonicalize_reloc
Unexecuted instantiation: coff-go32.c:coff_canonicalize_reloc
Unexecuted instantiation: coff-i386.c:coff_canonicalize_reloc
Unexecuted instantiation: coff-rs6000.c:coff_canonicalize_reloc
Unexecuted instantiation: coff-sh.c:coff_canonicalize_reloc
Unexecuted instantiation: coff-stgo32.c:coff_canonicalize_reloc
Unexecuted instantiation: coff-tic30.c:coff_canonicalize_reloc
Unexecuted instantiation: coff-tic4x.c:coff_canonicalize_reloc
Unexecuted instantiation: coff-tic54x.c:coff_canonicalize_reloc
Unexecuted instantiation: coff-z80.c:coff_canonicalize_reloc
Unexecuted instantiation: coff-z8k.c:coff_canonicalize_reloc
Unexecuted instantiation: pe-arm-wince.c:coff_canonicalize_reloc
Unexecuted instantiation: pe-arm.c:coff_canonicalize_reloc
Unexecuted instantiation: pe-i386.c:coff_canonicalize_reloc
Unexecuted instantiation: pe-mcore.c:coff_canonicalize_reloc
Unexecuted instantiation: pe-sh.c:coff_canonicalize_reloc
Unexecuted instantiation: pei-arm-wince.c:coff_canonicalize_reloc
Unexecuted instantiation: pei-arm.c:coff_canonicalize_reloc
Unexecuted instantiation: pei-mcore.c:coff_canonicalize_reloc
Unexecuted instantiation: pei-sh.c:coff_canonicalize_reloc
5345
5346
#ifndef coff_set_reloc
5347
#define coff_set_reloc _bfd_generic_set_reloc
5348
#endif
5349
5350
#ifndef coff_reloc16_estimate
5351
#define coff_reloc16_estimate dummy_reloc16_estimate
5352
5353
static int
5354
dummy_reloc16_estimate (bfd *abfd ATTRIBUTE_UNUSED,
5355
      asection *input_section ATTRIBUTE_UNUSED,
5356
      arelent *reloc ATTRIBUTE_UNUSED,
5357
      unsigned int shrink ATTRIBUTE_UNUSED,
5358
      struct bfd_link_info *link_info ATTRIBUTE_UNUSED)
5359
0
{
5360
0
  abort ();
5361
0
  return 0;
5362
0
}
Unexecuted instantiation: pei-i386.c:dummy_reloc16_estimate
Unexecuted instantiation: pe-x86_64.c:dummy_reloc16_estimate
Unexecuted instantiation: pei-x86_64.c:dummy_reloc16_estimate
Unexecuted instantiation: coff-x86_64.c:dummy_reloc16_estimate
Unexecuted instantiation: coff64-rs6000.c:dummy_reloc16_estimate
Unexecuted instantiation: pei-aarch64.c:dummy_reloc16_estimate
Unexecuted instantiation: pe-aarch64.c:dummy_reloc16_estimate
Unexecuted instantiation: pei-ia64.c:dummy_reloc16_estimate
Unexecuted instantiation: pei-loongarch64.c:dummy_reloc16_estimate
Unexecuted instantiation: cf-i386lynx.c:dummy_reloc16_estimate
Unexecuted instantiation: coff-go32.c:dummy_reloc16_estimate
Unexecuted instantiation: coff-i386.c:dummy_reloc16_estimate
Unexecuted instantiation: coff-rs6000.c:dummy_reloc16_estimate
Unexecuted instantiation: coff-sh.c:dummy_reloc16_estimate
Unexecuted instantiation: coff-stgo32.c:dummy_reloc16_estimate
Unexecuted instantiation: coff-tic30.c:dummy_reloc16_estimate
Unexecuted instantiation: coff-tic4x.c:dummy_reloc16_estimate
Unexecuted instantiation: coff-tic54x.c:dummy_reloc16_estimate
Unexecuted instantiation: coff-z80.c:dummy_reloc16_estimate
Unexecuted instantiation: coff-z8k.c:dummy_reloc16_estimate
Unexecuted instantiation: pe-arm-wince.c:dummy_reloc16_estimate
Unexecuted instantiation: pe-arm.c:dummy_reloc16_estimate
Unexecuted instantiation: pe-i386.c:dummy_reloc16_estimate
Unexecuted instantiation: pe-mcore.c:dummy_reloc16_estimate
Unexecuted instantiation: pe-sh.c:dummy_reloc16_estimate
Unexecuted instantiation: pei-arm-wince.c:dummy_reloc16_estimate
Unexecuted instantiation: pei-arm.c:dummy_reloc16_estimate
Unexecuted instantiation: pei-mcore.c:dummy_reloc16_estimate
Unexecuted instantiation: pei-sh.c:dummy_reloc16_estimate
5363
5364
#endif
5365
5366
#ifndef coff_reloc16_extra_cases
5367
5368
#define coff_reloc16_extra_cases dummy_reloc16_extra_cases
5369
5370
static bool
5371
dummy_reloc16_extra_cases (bfd *abfd ATTRIBUTE_UNUSED,
5372
         struct bfd_link_info *link_info ATTRIBUTE_UNUSED,
5373
         struct bfd_link_order *link_order ATTRIBUTE_UNUSED,
5374
         arelent *reloc ATTRIBUTE_UNUSED,
5375
         bfd_byte *data ATTRIBUTE_UNUSED,
5376
         size_t *src_ptr ATTRIBUTE_UNUSED,
5377
         size_t *dst_ptr ATTRIBUTE_UNUSED)
5378
0
{
5379
0
  return false;
5380
0
}
Unexecuted instantiation: pei-i386.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pe-x86_64.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pei-x86_64.c:dummy_reloc16_extra_cases
Unexecuted instantiation: coff-x86_64.c:dummy_reloc16_extra_cases
Unexecuted instantiation: coff64-rs6000.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pei-aarch64.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pe-aarch64.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pei-ia64.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pei-loongarch64.c:dummy_reloc16_extra_cases
Unexecuted instantiation: cf-i386lynx.c:dummy_reloc16_extra_cases
Unexecuted instantiation: coff-go32.c:dummy_reloc16_extra_cases
Unexecuted instantiation: coff-i386.c:dummy_reloc16_extra_cases
Unexecuted instantiation: coff-rs6000.c:dummy_reloc16_extra_cases
Unexecuted instantiation: coff-sh.c:dummy_reloc16_extra_cases
Unexecuted instantiation: coff-stgo32.c:dummy_reloc16_extra_cases
Unexecuted instantiation: coff-tic30.c:dummy_reloc16_extra_cases
Unexecuted instantiation: coff-tic4x.c:dummy_reloc16_extra_cases
Unexecuted instantiation: coff-tic54x.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pe-arm-wince.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pe-arm.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pe-i386.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pe-mcore.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pe-sh.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pei-arm-wince.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pei-arm.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pei-mcore.c:dummy_reloc16_extra_cases
Unexecuted instantiation: pei-sh.c:dummy_reloc16_extra_cases
5381
#endif
5382
5383
/* If coff_relocate_section is defined, we can use the optimized COFF
5384
   backend linker.  Otherwise we must continue to use the old linker.  */
5385
5386
#ifdef coff_relocate_section
5387
5388
#ifndef coff_bfd_link_hash_table_create
5389
#define coff_bfd_link_hash_table_create _bfd_coff_link_hash_table_create
5390
#endif
5391
#ifndef coff_bfd_link_add_symbols
5392
#define coff_bfd_link_add_symbols _bfd_coff_link_add_symbols
5393
#endif
5394
#ifndef coff_bfd_final_link
5395
#define coff_bfd_final_link _bfd_coff_final_link
5396
#endif
5397
5398
#else /* ! defined (coff_relocate_section) */
5399
5400
#define coff_relocate_section NULL
5401
#ifndef coff_bfd_link_hash_table_create
5402
#define coff_bfd_link_hash_table_create _bfd_generic_link_hash_table_create
5403
#endif
5404
#ifndef coff_bfd_link_add_symbols
5405
#define coff_bfd_link_add_symbols _bfd_generic_link_add_symbols
5406
#endif
5407
#define coff_bfd_final_link _bfd_generic_final_link
5408
5409
#endif /* ! defined (coff_relocate_section) */
5410
5411
#define coff_bfd_link_just_syms      _bfd_generic_link_just_syms
5412
#define coff_bfd_copy_link_hash_symbol_type \
5413
  _bfd_generic_copy_link_hash_symbol_type
5414
#define coff_bfd_link_split_section  _bfd_generic_link_split_section
5415
5416
#define coff_bfd_link_check_relocs   _bfd_generic_link_check_relocs
5417
5418
#ifndef coff_start_final_link
5419
#define coff_start_final_link NULL
5420
#endif
5421
5422
#ifndef coff_adjust_symndx
5423
#define coff_adjust_symndx NULL
5424
#endif
5425
5426
#ifndef coff_link_add_one_symbol
5427
#define coff_link_add_one_symbol _bfd_generic_link_add_one_symbol
5428
#endif
5429
5430
#ifndef coff_link_output_has_begun
5431
5432
static bool
5433
coff_link_output_has_begun (bfd * abfd,
5434
          struct coff_final_link_info * info ATTRIBUTE_UNUSED)
5435
0
{
5436
0
  return abfd->output_has_begun;
5437
0
}
Unexecuted instantiation: pei-i386.c:coff_link_output_has_begun
Unexecuted instantiation: pe-x86_64.c:coff_link_output_has_begun
Unexecuted instantiation: pei-x86_64.c:coff_link_output_has_begun
Unexecuted instantiation: coff-x86_64.c:coff_link_output_has_begun
Unexecuted instantiation: coff64-rs6000.c:coff_link_output_has_begun
Unexecuted instantiation: pei-aarch64.c:coff_link_output_has_begun
Unexecuted instantiation: pe-aarch64.c:coff_link_output_has_begun
Unexecuted instantiation: pei-ia64.c:coff_link_output_has_begun
Unexecuted instantiation: pei-loongarch64.c:coff_link_output_has_begun
Unexecuted instantiation: cf-i386lynx.c:coff_link_output_has_begun
Unexecuted instantiation: coff-go32.c:coff_link_output_has_begun
Unexecuted instantiation: coff-i386.c:coff_link_output_has_begun
Unexecuted instantiation: coff-rs6000.c:coff_link_output_has_begun
Unexecuted instantiation: coff-sh.c:coff_link_output_has_begun
Unexecuted instantiation: coff-stgo32.c:coff_link_output_has_begun
Unexecuted instantiation: coff-tic30.c:coff_link_output_has_begun
Unexecuted instantiation: coff-tic4x.c:coff_link_output_has_begun
Unexecuted instantiation: coff-tic54x.c:coff_link_output_has_begun
Unexecuted instantiation: coff-z80.c:coff_link_output_has_begun
Unexecuted instantiation: coff-z8k.c:coff_link_output_has_begun
Unexecuted instantiation: pe-i386.c:coff_link_output_has_begun
Unexecuted instantiation: pe-mcore.c:coff_link_output_has_begun
Unexecuted instantiation: pe-sh.c:coff_link_output_has_begun
Unexecuted instantiation: pei-mcore.c:coff_link_output_has_begun
Unexecuted instantiation: pei-sh.c:coff_link_output_has_begun
5438
#endif
5439
5440
#ifndef coff_final_link_postscript
5441
5442
static bool
5443
coff_final_link_postscript (bfd * abfd ATTRIBUTE_UNUSED,
5444
          struct coff_final_link_info * pfinfo ATTRIBUTE_UNUSED)
5445
0
{
5446
0
  return true;
5447
0
}
Unexecuted instantiation: coff-x86_64.c:coff_final_link_postscript
Unexecuted instantiation: coff64-rs6000.c:coff_final_link_postscript
Unexecuted instantiation: cf-i386lynx.c:coff_final_link_postscript
Unexecuted instantiation: coff-go32.c:coff_final_link_postscript
Unexecuted instantiation: coff-i386.c:coff_final_link_postscript
Unexecuted instantiation: coff-rs6000.c:coff_final_link_postscript
Unexecuted instantiation: coff-sh.c:coff_final_link_postscript
Unexecuted instantiation: coff-stgo32.c:coff_final_link_postscript
Unexecuted instantiation: coff-tic30.c:coff_final_link_postscript
Unexecuted instantiation: coff-tic4x.c:coff_final_link_postscript
Unexecuted instantiation: coff-tic54x.c:coff_final_link_postscript
Unexecuted instantiation: coff-z80.c:coff_final_link_postscript
Unexecuted instantiation: coff-z8k.c:coff_final_link_postscript
5448
#endif
5449
5450
#ifndef coff_SWAP_aux_in
5451
#define coff_SWAP_aux_in coff_swap_aux_in
5452
#endif
5453
#ifndef coff_SWAP_sym_in
5454
#define coff_SWAP_sym_in coff_swap_sym_in
5455
#endif
5456
#ifndef coff_SWAP_lineno_in
5457
#define coff_SWAP_lineno_in coff_swap_lineno_in
5458
#endif
5459
#ifndef coff_SWAP_aux_out
5460
#define coff_SWAP_aux_out coff_swap_aux_out
5461
#endif
5462
#ifndef coff_SWAP_sym_out
5463
#define coff_SWAP_sym_out coff_swap_sym_out
5464
#endif
5465
#ifndef coff_SWAP_lineno_out
5466
#define coff_SWAP_lineno_out coff_swap_lineno_out
5467
#endif
5468
#ifndef coff_SWAP_reloc_out
5469
#define coff_SWAP_reloc_out coff_swap_reloc_out
5470
#endif
5471
#ifndef coff_SWAP_filehdr_out
5472
#define coff_SWAP_filehdr_out coff_swap_filehdr_out
5473
#endif
5474
#ifndef coff_SWAP_aouthdr_out
5475
#define coff_SWAP_aouthdr_out coff_swap_aouthdr_out
5476
#endif
5477
#ifndef coff_SWAP_scnhdr_out
5478
#define coff_SWAP_scnhdr_out coff_swap_scnhdr_out
5479
#endif
5480
#ifndef coff_SWAP_reloc_in
5481
#define coff_SWAP_reloc_in coff_swap_reloc_in
5482
#endif
5483
#ifndef coff_SWAP_filehdr_in
5484
#define coff_SWAP_filehdr_in coff_swap_filehdr_in
5485
#endif
5486
#ifndef coff_SWAP_aouthdr_in
5487
#define coff_SWAP_aouthdr_in coff_swap_aouthdr_in
5488
#endif
5489
#ifndef coff_SWAP_scnhdr_in
5490
#define coff_SWAP_scnhdr_in coff_swap_scnhdr_in
5491
#endif
5492
5493
#define COFF_SWAP_TABLE (void *) &bfd_coff_std_swap_table
5494
5495
static const bfd_coff_backend_data bfd_coff_std_swap_table ATTRIBUTE_UNUSED =
5496
{
5497
  coff_SWAP_aux_in, coff_SWAP_sym_in, coff_SWAP_lineno_in,
5498
  coff_SWAP_aux_out, coff_SWAP_sym_out,
5499
  coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5500
  coff_SWAP_filehdr_out, coff_SWAP_aouthdr_out,
5501
  coff_SWAP_scnhdr_out,
5502
  FILHSZ, AOUTSZ, SCNHSZ, SYMESZ, AUXESZ, RELSZ, LINESZ, FILNMLEN,
5503
#ifdef COFF_LONG_FILENAMES
5504
  true,
5505
#else
5506
  false,
5507
#endif
5508
  COFF_DEFAULT_LONG_SECTION_NAMES,
5509
  COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5510
#ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
5511
  true,
5512
#else
5513
  false,
5514
#endif
5515
#ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5516
  4,
5517
#else
5518
  2,
5519
#endif
5520
  32768,
5521
  coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5522
  coff_SWAP_reloc_in, coff_bad_format_hook, coff_set_arch_mach_hook,
5523
  coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5524
  coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5525
  coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5526
  coff_classify_symbol, coff_compute_section_file_positions,
5527
  coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5528
  coff_adjust_symndx, coff_link_add_one_symbol,
5529
  coff_link_output_has_begun, coff_final_link_postscript,
5530
  bfd_pe_print_pdata
5531
};
5532
5533
#ifdef TICOFF
5534
/* COFF0 differs in file/section header size and relocation entry size.  */
5535
5536
static const bfd_coff_backend_data ticoff0_swap_table =
5537
{
5538
  coff_SWAP_aux_in, coff_SWAP_sym_in, coff_SWAP_lineno_in,
5539
  coff_SWAP_aux_out, coff_SWAP_sym_out,
5540
  coff_SWAP_lineno_out, coff_swap_reloc_v0_out,
5541
  coff_SWAP_filehdr_out, coff_SWAP_aouthdr_out,
5542
  coff_SWAP_scnhdr_out,
5543
  FILHSZ_V0, AOUTSZ, SCNHSZ_V01, SYMESZ, AUXESZ, RELSZ_V0, LINESZ, FILNMLEN,
5544
#ifdef COFF_LONG_FILENAMES
5545
  true,
5546
#else
5547
  false,
5548
#endif
5549
  COFF_DEFAULT_LONG_SECTION_NAMES,
5550
  COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5551
#ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
5552
  true,
5553
#else
5554
  false,
5555
#endif
5556
#ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5557
  4,
5558
#else
5559
  2,
5560
#endif
5561
  32768,
5562
  coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5563
  coff_swap_reloc_v0_in, ticoff0_bad_format_hook, coff_set_arch_mach_hook,
5564
  coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5565
  coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5566
  coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5567
  coff_classify_symbol, coff_compute_section_file_positions,
5568
  coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5569
  coff_adjust_symndx, coff_link_add_one_symbol,
5570
  coff_link_output_has_begun, coff_final_link_postscript,
5571
  bfd_pe_print_pdata
5572
};
5573
#endif
5574
5575
#ifdef TICOFF
5576
/* COFF1 differs in section header size.  */
5577
5578
static const bfd_coff_backend_data ticoff1_swap_table =
5579
{
5580
  coff_SWAP_aux_in, coff_SWAP_sym_in, coff_SWAP_lineno_in,
5581
  coff_SWAP_aux_out, coff_SWAP_sym_out,
5582
  coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5583
  coff_SWAP_filehdr_out, coff_SWAP_aouthdr_out,
5584
  coff_SWAP_scnhdr_out,
5585
  FILHSZ, AOUTSZ, SCNHSZ_V01, SYMESZ, AUXESZ, RELSZ, LINESZ, FILNMLEN,
5586
#ifdef COFF_LONG_FILENAMES
5587
  true,
5588
#else
5589
  false,
5590
#endif
5591
  COFF_DEFAULT_LONG_SECTION_NAMES,
5592
  COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5593
#ifdef COFF_FORCE_SYMBOLS_IN_STRINGS
5594
  true,
5595
#else
5596
  false,
5597
#endif
5598
#ifdef COFF_DEBUG_STRING_WIDE_PREFIX
5599
  4,
5600
#else
5601
  2,
5602
#endif
5603
  32768,
5604
  coff_SWAP_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5605
  coff_SWAP_reloc_in, ticoff1_bad_format_hook, coff_set_arch_mach_hook,
5606
  coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5607
  coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5608
  coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5609
  coff_classify_symbol, coff_compute_section_file_positions,
5610
  coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5611
  coff_adjust_symndx, coff_link_add_one_symbol,
5612
  coff_link_output_has_begun, coff_final_link_postscript,
5613
  bfd_pe_print_pdata  /* huh */
5614
};
5615
#endif
5616
5617
#ifdef COFF_WITH_PE_BIGOBJ
5618
/* The UID for bigobj files.  */
5619
5620
static const char header_bigobj_classid[16] =
5621
{
5622
  0xC7, 0xA1, 0xBA, 0xD1,
5623
  0xEE, 0xBA,
5624
  0xa9, 0x4b,
5625
  0xAF, 0x20,
5626
  0xFA, 0xF6, 0x6A, 0xA4, 0xDC, 0xB8
5627
};
5628
5629
/* Swap routines.  */
5630
5631
static void
5632
coff_bigobj_swap_filehdr_in (bfd * abfd, void * src, void * dst)
5633
20.8k
{
5634
20.8k
  struct external_ANON_OBJECT_HEADER_BIGOBJ *filehdr_src =
5635
20.8k
    (struct external_ANON_OBJECT_HEADER_BIGOBJ *) src;
5636
20.8k
  struct internal_filehdr *filehdr_dst = (struct internal_filehdr *) dst;
5637
5638
20.8k
  filehdr_dst->f_magic  = H_GET_16 (abfd, filehdr_src->Machine);
5639
20.8k
  filehdr_dst->f_nscns  = H_GET_32 (abfd, filehdr_src->NumberOfSections);
5640
20.8k
  filehdr_dst->f_timdat = H_GET_32 (abfd, filehdr_src->TimeDateStamp);
5641
20.8k
  filehdr_dst->f_symptr =
5642
20.8k
    GET_FILEHDR_SYMPTR (abfd, filehdr_src->PointerToSymbolTable);
5643
20.8k
  filehdr_dst->f_nsyms  = H_GET_32 (abfd, filehdr_src->NumberOfSymbols);
5644
20.8k
  filehdr_dst->f_opthdr = 0;
5645
20.8k
  filehdr_dst->f_flags  = 0;
5646
5647
  /* Check other magic numbers.  */
5648
20.8k
  if (H_GET_16 (abfd, filehdr_src->Sig1) != IMAGE_FILE_MACHINE_UNKNOWN
5649
20.8k
      || H_GET_16 (abfd, filehdr_src->Sig2) != 0xffff
5650
20.8k
      || H_GET_16 (abfd, filehdr_src->Version) != 2
5651
20.8k
      || memcmp (filehdr_src->ClassID, header_bigobj_classid, 16) != 0)
5652
20.8k
    filehdr_dst->f_opthdr = 0xffff;
5653
5654
  /* Note that CLR metadata are ignored.  */
5655
20.8k
}
pe-x86_64.c:coff_bigobj_swap_filehdr_in
Line
Count
Source
5633
10.4k
{
5634
10.4k
  struct external_ANON_OBJECT_HEADER_BIGOBJ *filehdr_src =
5635
10.4k
    (struct external_ANON_OBJECT_HEADER_BIGOBJ *) src;
5636
10.4k
  struct internal_filehdr *filehdr_dst = (struct internal_filehdr *) dst;
5637
5638
10.4k
  filehdr_dst->f_magic  = H_GET_16 (abfd, filehdr_src->Machine);
5639
10.4k
  filehdr_dst->f_nscns  = H_GET_32 (abfd, filehdr_src->NumberOfSections);
5640
10.4k
  filehdr_dst->f_timdat = H_GET_32 (abfd, filehdr_src->TimeDateStamp);
5641
10.4k
  filehdr_dst->f_symptr =
5642
10.4k
    GET_FILEHDR_SYMPTR (abfd, filehdr_src->PointerToSymbolTable);
5643
10.4k
  filehdr_dst->f_nsyms  = H_GET_32 (abfd, filehdr_src->NumberOfSymbols);
5644
10.4k
  filehdr_dst->f_opthdr = 0;
5645
10.4k
  filehdr_dst->f_flags  = 0;
5646
5647
  /* Check other magic numbers.  */
5648
10.4k
  if (H_GET_16 (abfd, filehdr_src->Sig1) != IMAGE_FILE_MACHINE_UNKNOWN
5649
10.4k
      || H_GET_16 (abfd, filehdr_src->Sig2) != 0xffff
5650
10.4k
      || H_GET_16 (abfd, filehdr_src->Version) != 2
5651
10.4k
      || memcmp (filehdr_src->ClassID, header_bigobj_classid, 16) != 0)
5652
10.4k
    filehdr_dst->f_opthdr = 0xffff;
5653
5654
  /* Note that CLR metadata are ignored.  */
5655
10.4k
}
pe-i386.c:coff_bigobj_swap_filehdr_in
Line
Count
Source
5633
10.4k
{
5634
10.4k
  struct external_ANON_OBJECT_HEADER_BIGOBJ *filehdr_src =
5635
10.4k
    (struct external_ANON_OBJECT_HEADER_BIGOBJ *) src;
5636
10.4k
  struct internal_filehdr *filehdr_dst = (struct internal_filehdr *) dst;
5637
5638
10.4k
  filehdr_dst->f_magic  = H_GET_16 (abfd, filehdr_src->Machine);
5639
10.4k
  filehdr_dst->f_nscns  = H_GET_32 (abfd, filehdr_src->NumberOfSections);
5640
10.4k
  filehdr_dst->f_timdat = H_GET_32 (abfd, filehdr_src->TimeDateStamp);
5641
10.4k
  filehdr_dst->f_symptr =
5642
10.4k
    GET_FILEHDR_SYMPTR (abfd, filehdr_src->PointerToSymbolTable);
5643
10.4k
  filehdr_dst->f_nsyms  = H_GET_32 (abfd, filehdr_src->NumberOfSymbols);
5644
10.4k
  filehdr_dst->f_opthdr = 0;
5645
10.4k
  filehdr_dst->f_flags  = 0;
5646
5647
  /* Check other magic numbers.  */
5648
10.4k
  if (H_GET_16 (abfd, filehdr_src->Sig1) != IMAGE_FILE_MACHINE_UNKNOWN
5649
10.4k
      || H_GET_16 (abfd, filehdr_src->Sig2) != 0xffff
5650
10.4k
      || H_GET_16 (abfd, filehdr_src->Version) != 2
5651
10.4k
      || memcmp (filehdr_src->ClassID, header_bigobj_classid, 16) != 0)
5652
10.4k
    filehdr_dst->f_opthdr = 0xffff;
5653
5654
  /* Note that CLR metadata are ignored.  */
5655
10.4k
}
5656
5657
static unsigned int
5658
coff_bigobj_swap_filehdr_out (bfd *abfd, void * in, void * out)
5659
0
{
5660
0
  struct internal_filehdr *filehdr_in = (struct internal_filehdr *) in;
5661
0
  struct external_ANON_OBJECT_HEADER_BIGOBJ *filehdr_out =
5662
0
    (struct external_ANON_OBJECT_HEADER_BIGOBJ *) out;
5663
5664
0
  memset (filehdr_out, 0, sizeof (*filehdr_out));
5665
5666
0
  H_PUT_16 (abfd, IMAGE_FILE_MACHINE_UNKNOWN, filehdr_out->Sig1);
5667
0
  H_PUT_16 (abfd, 0xffff, filehdr_out->Sig2);
5668
0
  H_PUT_16 (abfd, 2, filehdr_out->Version);
5669
0
  memcpy (filehdr_out->ClassID, header_bigobj_classid, 16);
5670
0
  H_PUT_16 (abfd, filehdr_in->f_magic, filehdr_out->Machine);
5671
0
  H_PUT_32 (abfd, filehdr_in->f_nscns, filehdr_out->NumberOfSections);
5672
0
  H_PUT_32 (abfd, filehdr_in->f_timdat, filehdr_out->TimeDateStamp);
5673
0
  PUT_FILEHDR_SYMPTR (abfd, filehdr_in->f_symptr,
5674
0
          filehdr_out->PointerToSymbolTable);
5675
0
  H_PUT_32 (abfd, filehdr_in->f_nsyms, filehdr_out->NumberOfSymbols);
5676
5677
0
  return bfd_coff_filhsz (abfd);
5678
0
}
Unexecuted instantiation: pe-x86_64.c:coff_bigobj_swap_filehdr_out
Unexecuted instantiation: pe-i386.c:coff_bigobj_swap_filehdr_out
5679
5680
static void
5681
coff_bigobj_swap_sym_in (bfd * abfd, void * ext1, void * in1)
5682
0
{
5683
0
  SYMENT_BIGOBJ *ext = (SYMENT_BIGOBJ *) ext1;
5684
0
  struct internal_syment *in = (struct internal_syment *) in1;
5685
5686
0
  if (ext->e.e_name[0] == 0)
5687
0
    {
5688
0
      in->_n._n_n._n_zeroes = 0;
5689
0
      in->_n._n_n._n_offset = H_GET_32 (abfd, ext->e.e.e_offset);
5690
0
    }
5691
0
  else
5692
0
    {
5693
#if SYMNMLEN != E_SYMNMLEN
5694
#error we need to cope with truncating or extending SYMNMLEN
5695
#else
5696
0
      memcpy (in->_n._n_name, ext->e.e_name, SYMNMLEN);
5697
0
#endif
5698
0
    }
5699
5700
0
  in->n_value = H_GET_32 (abfd, ext->e_value);
5701
0
  BFD_ASSERT (sizeof (in->n_scnum) >= 4);
5702
0
  in->n_scnum = H_GET_32 (abfd, ext->e_scnum);
5703
0
  in->n_type = H_GET_16 (abfd, ext->e_type);
5704
0
  in->n_sclass = H_GET_8 (abfd, ext->e_sclass);
5705
0
  in->n_numaux = H_GET_8 (abfd, ext->e_numaux);
5706
0
}
Unexecuted instantiation: pe-x86_64.c:coff_bigobj_swap_sym_in
Unexecuted instantiation: pe-i386.c:coff_bigobj_swap_sym_in
5707
5708
static unsigned int
5709
coff_bigobj_swap_sym_out (bfd * abfd, void * inp, void * extp)
5710
0
{
5711
0
  struct internal_syment *in = (struct internal_syment *) inp;
5712
0
  SYMENT_BIGOBJ *ext = (SYMENT_BIGOBJ *) extp;
5713
5714
0
  if (in->_n._n_name[0] == 0)
5715
0
    {
5716
0
      H_PUT_32 (abfd, 0, ext->e.e.e_zeroes);
5717
0
      H_PUT_32 (abfd, in->_n._n_n._n_offset, ext->e.e.e_offset);
5718
0
    }
5719
0
  else
5720
0
    {
5721
#if SYMNMLEN != E_SYMNMLEN
5722
#error we need to cope with truncating or extending SYMNMLEN
5723
#else
5724
0
      memcpy (ext->e.e_name, in->_n._n_name, SYMNMLEN);
5725
0
#endif
5726
0
    }
5727
5728
0
  H_PUT_32 (abfd, in->n_value, ext->e_value);
5729
0
  H_PUT_32 (abfd, in->n_scnum, ext->e_scnum);
5730
5731
0
  H_PUT_16 (abfd, in->n_type, ext->e_type);
5732
0
  H_PUT_8 (abfd, in->n_sclass, ext->e_sclass);
5733
0
  H_PUT_8 (abfd, in->n_numaux, ext->e_numaux);
5734
5735
0
  return SYMESZ_BIGOBJ;
5736
0
}
Unexecuted instantiation: pe-x86_64.c:coff_bigobj_swap_sym_out
Unexecuted instantiation: pe-i386.c:coff_bigobj_swap_sym_out
5737
5738
static void
5739
coff_bigobj_swap_aux_in (bfd *abfd,
5740
       void * ext1,
5741
       int type,
5742
       int in_class,
5743
       int indx,
5744
       int numaux,
5745
       void * in1)
5746
0
{
5747
0
  AUXENT_BIGOBJ *ext = (AUXENT_BIGOBJ *) ext1;
5748
0
  union internal_auxent *in = (union internal_auxent *) in1;
5749
5750
  /* Make sure that all fields in the aux structure are
5751
     initialised.  */
5752
0
  memset (in, 0, sizeof * in);
5753
0
  switch (in_class)
5754
0
    {
5755
0
    case C_FILE:
5756
0
      if (numaux > 1)
5757
0
  {
5758
0
    if (indx == 0)
5759
0
      memcpy (in->x_file.x_n.x_fname, ext->File.Name,
5760
0
        numaux * sizeof (AUXENT_BIGOBJ));
5761
0
  }
5762
0
      else
5763
0
  memcpy (in->x_file.x_n.x_fname, ext->File.Name, sizeof (ext->File.Name));
5764
0
      break;
5765
5766
0
    case C_STAT:
5767
0
    case C_LEAFSTAT:
5768
0
    case C_HIDDEN:
5769
0
      if (type == T_NULL)
5770
0
  {
5771
0
    in->x_scn.x_scnlen = H_GET_32 (abfd, ext->Section.Length);
5772
0
    in->x_scn.x_nreloc =
5773
0
      H_GET_16 (abfd, ext->Section.NumberOfRelocations);
5774
0
    in->x_scn.x_nlinno =
5775
0
      H_GET_16 (abfd, ext->Section.NumberOfLinenumbers);
5776
0
    in->x_scn.x_checksum = H_GET_32 (abfd, ext->Section.Checksum);
5777
0
    in->x_scn.x_associated = H_GET_16 (abfd, ext->Section.Number)
5778
0
      | (H_GET_16 (abfd, ext->Section.HighNumber) << 16);
5779
0
    in->x_scn.x_comdat = H_GET_8 (abfd, ext->Section.Selection);
5780
0
    return;
5781
0
  }
5782
0
      break;
5783
5784
0
    default:
5785
0
      in->x_sym.x_tagndx.u32 = H_GET_32 (abfd, ext->Sym.WeakDefaultSymIndex);
5786
      /* Characteristics is ignored.  */
5787
0
      break;
5788
0
    }
5789
0
}
Unexecuted instantiation: pe-x86_64.c:coff_bigobj_swap_aux_in
Unexecuted instantiation: pe-i386.c:coff_bigobj_swap_aux_in
5790
5791
static unsigned int
5792
coff_bigobj_swap_aux_out (bfd * abfd,
5793
        void * inp,
5794
        int type,
5795
        int in_class,
5796
        int indx ATTRIBUTE_UNUSED,
5797
        int numaux ATTRIBUTE_UNUSED,
5798
        void * extp)
5799
0
{
5800
0
  union internal_auxent * in = (union internal_auxent *) inp;
5801
0
  AUXENT_BIGOBJ *ext = (AUXENT_BIGOBJ *) extp;
5802
5803
0
  memset (ext, 0, AUXESZ);
5804
5805
0
  switch (in_class)
5806
0
    {
5807
0
    case C_FILE:
5808
0
      memcpy (ext->File.Name, in->x_file.x_n.x_fname, sizeof (ext->File.Name));
5809
5810
0
      return AUXESZ;
5811
5812
0
    case C_STAT:
5813
0
    case C_LEAFSTAT:
5814
0
    case C_HIDDEN:
5815
0
      if (type == T_NULL)
5816
0
  {
5817
0
    H_PUT_32 (abfd, in->x_scn.x_scnlen, ext->Section.Length);
5818
0
    H_PUT_16 (abfd, in->x_scn.x_nreloc,
5819
0
        ext->Section.NumberOfRelocations);
5820
0
    H_PUT_16 (abfd, in->x_scn.x_nlinno,
5821
0
        ext->Section.NumberOfLinenumbers);
5822
0
    H_PUT_32 (abfd, in->x_scn.x_checksum, ext->Section.Checksum);
5823
0
    H_PUT_16 (abfd, in->x_scn.x_associated & 0xffff,
5824
0
        ext->Section.Number);
5825
0
    H_PUT_16 (abfd, (in->x_scn.x_associated >> 16),
5826
0
        ext->Section.HighNumber);
5827
0
    H_PUT_8 (abfd, in->x_scn.x_comdat, ext->Section.Selection);
5828
0
    return AUXESZ;
5829
0
  }
5830
0
      break;
5831
0
    }
5832
5833
0
  H_PUT_32 (abfd, in->x_sym.x_tagndx.u32, ext->Sym.WeakDefaultSymIndex);
5834
0
  H_PUT_32 (abfd, 1, ext->Sym.WeakSearchType);
5835
5836
0
  return AUXESZ;
5837
0
}
Unexecuted instantiation: pe-x86_64.c:coff_bigobj_swap_aux_out
Unexecuted instantiation: pe-i386.c:coff_bigobj_swap_aux_out
5838
5839
static const bfd_coff_backend_data bigobj_swap_table =
5840
{
5841
  coff_bigobj_swap_aux_in, coff_bigobj_swap_sym_in, coff_SWAP_lineno_in,
5842
  coff_bigobj_swap_aux_out, coff_bigobj_swap_sym_out,
5843
  coff_SWAP_lineno_out, coff_SWAP_reloc_out,
5844
  coff_bigobj_swap_filehdr_out, coff_SWAP_aouthdr_out,
5845
  coff_SWAP_scnhdr_out,
5846
  FILHSZ_BIGOBJ, AOUTSZ, SCNHSZ, SYMESZ_BIGOBJ, AUXESZ_BIGOBJ,
5847
   RELSZ, LINESZ, FILNMLEN_BIGOBJ,
5848
  true,
5849
  COFF_DEFAULT_LONG_SECTION_NAMES,
5850
  COFF_DEFAULT_SECTION_ALIGNMENT_POWER,
5851
  false,
5852
  2,
5853
  1U << 31,
5854
  coff_bigobj_swap_filehdr_in, coff_SWAP_aouthdr_in, coff_SWAP_scnhdr_in,
5855
  coff_SWAP_reloc_in, coff_bad_format_hook, coff_set_arch_mach_hook,
5856
  coff_mkobject_hook, styp_to_sec_flags, coff_set_alignment_hook,
5857
  coff_slurp_symbol_table, symname_in_debug_hook, coff_pointerize_aux_hook,
5858
  coff_print_aux, coff_reloc16_extra_cases, coff_reloc16_estimate,
5859
  coff_classify_symbol, coff_compute_section_file_positions,
5860
  coff_start_final_link, coff_relocate_section, coff_rtype_to_howto,
5861
  coff_adjust_symndx, coff_link_add_one_symbol,
5862
  coff_link_output_has_begun, coff_final_link_postscript,
5863
  bfd_pe_print_pdata  /* huh */
5864
};
5865
5866
#endif /* COFF_WITH_PE_BIGOBJ */
5867
5868
#ifndef coff_close_and_cleanup
5869
#define coff_close_and_cleanup        _bfd_generic_close_and_cleanup
5870
#endif
5871
5872
#ifndef coff_bfd_free_cached_info
5873
#define coff_bfd_free_cached_info     _bfd_coff_free_cached_info
5874
#endif
5875
5876
#ifndef coff_get_section_contents
5877
#define coff_get_section_contents     _bfd_generic_get_section_contents
5878
#endif
5879
5880
#ifndef coff_bfd_copy_private_symbol_data
5881
#define coff_bfd_copy_private_symbol_data   _bfd_generic_bfd_copy_private_symbol_data
5882
#endif
5883
5884
#ifndef coff_bfd_copy_private_header_data
5885
#define coff_bfd_copy_private_header_data   _bfd_generic_bfd_copy_private_header_data
5886
#endif
5887
5888
#ifndef coff_bfd_copy_private_section_data
5889
#define coff_bfd_copy_private_section_data  _bfd_generic_bfd_copy_private_section_data
5890
#endif
5891
5892
#ifndef coff_bfd_copy_private_bfd_data
5893
#define coff_bfd_copy_private_bfd_data      _bfd_generic_bfd_copy_private_bfd_data
5894
#endif
5895
5896
#ifndef coff_bfd_merge_private_bfd_data
5897
#define coff_bfd_merge_private_bfd_data     _bfd_generic_bfd_merge_private_bfd_data
5898
#endif
5899
5900
#ifndef coff_bfd_set_private_flags
5901
#define coff_bfd_set_private_flags      _bfd_generic_bfd_set_private_flags
5902
#endif
5903
5904
#ifndef coff_bfd_print_private_bfd_data
5905
#define coff_bfd_print_private_bfd_data     _bfd_generic_bfd_print_private_bfd_data
5906
#endif
5907
5908
#ifndef coff_bfd_is_local_label_name
5909
#define coff_bfd_is_local_label_name      _bfd_coff_is_local_label_name
5910
#endif
5911
5912
#ifndef coff_bfd_is_target_special_symbol
5913
#define coff_bfd_is_target_special_symbol   _bfd_bool_bfd_asymbol_false
5914
#endif
5915
5916
#ifndef coff_read_minisymbols
5917
#define coff_read_minisymbols       _bfd_generic_read_minisymbols
5918
#endif
5919
5920
#ifndef coff_minisymbol_to_symbol
5921
#define coff_minisymbol_to_symbol     _bfd_generic_minisymbol_to_symbol
5922
#endif
5923
5924
/* The reloc lookup routine must be supplied by each individual COFF
5925
   backend.  */
5926
#ifndef coff_bfd_reloc_type_lookup
5927
#define coff_bfd_reloc_type_lookup      _bfd_norelocs_bfd_reloc_type_lookup
5928
#endif
5929
#ifndef coff_bfd_reloc_name_lookup
5930
#define coff_bfd_reloc_name_lookup    _bfd_norelocs_bfd_reloc_name_lookup
5931
#endif
5932
5933
#ifndef coff_bfd_get_relocated_section_contents
5934
#define coff_bfd_get_relocated_section_contents \
5935
  bfd_generic_get_relocated_section_contents
5936
#endif
5937
5938
#ifndef coff_bfd_relax_section
5939
#define coff_bfd_relax_section        bfd_generic_relax_section
5940
#endif
5941
5942
#ifndef coff_bfd_gc_sections
5943
#define coff_bfd_gc_sections        bfd_coff_gc_sections
5944
#endif
5945
5946
#ifndef coff_bfd_lookup_section_flags
5947
#define coff_bfd_lookup_section_flags     bfd_generic_lookup_section_flags
5948
#endif
5949
5950
#ifndef coff_bfd_merge_sections
5951
#define coff_bfd_merge_sections       bfd_generic_merge_sections
5952
#endif
5953
5954
#ifndef coff_bfd_is_group_section
5955
#define coff_bfd_is_group_section     bfd_generic_is_group_section
5956
#endif
5957
5958
#ifndef coff_bfd_group_name
5959
#define coff_bfd_group_name       bfd_coff_group_name
5960
#endif
5961
5962
#ifndef coff_bfd_discard_group
5963
#define coff_bfd_discard_group        bfd_generic_discard_group
5964
#endif
5965
5966
#ifndef coff_section_already_linked
5967
#define coff_section_already_linked \
5968
  _bfd_coff_section_already_linked
5969
#endif
5970
5971
#ifndef coff_bfd_define_common_symbol
5972
#define coff_bfd_define_common_symbol     bfd_generic_define_common_symbol
5973
#endif
5974
5975
#ifndef coff_bfd_link_hide_symbol
5976
#define coff_bfd_link_hide_symbol     _bfd_generic_link_hide_symbol
5977
#endif
5978
5979
#ifndef coff_bfd_define_start_stop
5980
#define coff_bfd_define_start_stop      bfd_generic_define_start_stop
5981
#endif
5982
5983
#define CREATE_BIG_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE) \
5984
const bfd_target VAR =              \
5985
{                 \
5986
  NAME ,                \
5987
  bfd_target_coff_flavour,            \
5988
  BFD_ENDIAN_BIG,   /* Data byte order is big.  */    \
5989
  BFD_ENDIAN_BIG,   /* Header byte order is big.  */  \
5990
  /* object flags */              \
5991
  (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG |      \
5992
   HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS),      \
5993
  /* section flags */             \
5994
  (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
5995
  UNDER,      /* Leading symbol underscore.  */ \
5996
  '/',        /* AR_pad_char.  */     \
5997
  15,       /* AR_max_namelen.  */      \
5998
  0,        /* match priority.  */      \
5999
  TARGET_KEEP_UNUSED_SECTION_SYMBOLS, /* keep unused section symbols.  */ \
6000
                  \
6001
  /* Data conversion functions.  */         \
6002
  bfd_getb64, bfd_getb_signed_64, bfd_putb64,       \
6003
  bfd_getb32, bfd_getb_signed_32, bfd_putb32,       \
6004
  bfd_getb16, bfd_getb_signed_16, bfd_putb16,       \
6005
                  \
6006
  /* Header conversion functions.  */         \
6007
  bfd_getb64, bfd_getb_signed_64, bfd_putb64,       \
6008
  bfd_getb32, bfd_getb_signed_32, bfd_putb32,       \
6009
  bfd_getb16, bfd_getb_signed_16, bfd_putb16,       \
6010
                  \
6011
  {       /* bfd_check_format.  */    \
6012
    _bfd_dummy_target,              \
6013
    coff_object_p,              \
6014
    bfd_generic_archive_p,            \
6015
    _bfd_dummy_target             \
6016
  },                  \
6017
  {       /* bfd_set_format.  */      \
6018
    _bfd_bool_bfd_false_error,            \
6019
    coff_mkobject,              \
6020
    _bfd_generic_mkarchive,           \
6021
    _bfd_bool_bfd_false_error           \
6022
  },                  \
6023
  {       /* bfd_write_contents.  */    \
6024
    _bfd_bool_bfd_false_error,            \
6025
    coff_write_object_contents,           \
6026
    _bfd_write_archive_contents,          \
6027
    _bfd_bool_bfd_false_error           \
6028
  },                  \
6029
                  \
6030
  BFD_JUMP_TABLE_GENERIC (coff),          \
6031
  BFD_JUMP_TABLE_COPY (coff),           \
6032
  BFD_JUMP_TABLE_CORE (_bfd_nocore),          \
6033
  BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff),       \
6034
  BFD_JUMP_TABLE_SYMBOLS (coff),          \
6035
  BFD_JUMP_TABLE_RELOCS (coff),           \
6036
  BFD_JUMP_TABLE_WRITE (coff),            \
6037
  BFD_JUMP_TABLE_LINK (coff),           \
6038
  BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic),        \
6039
                  \
6040
  ALTERNATIVE,                \
6041
                  \
6042
  SWAP_TABLE                \
6043
};
6044
6045
#define CREATE_BIGHDR_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE)  \
6046
const bfd_target VAR =              \
6047
{                 \
6048
  NAME ,                \
6049
  bfd_target_coff_flavour,            \
6050
  BFD_ENDIAN_LITTLE,    /* Data byte order is little.  */ \
6051
  BFD_ENDIAN_BIG,   /* Header byte order is big.  */  \
6052
  /* object flags */              \
6053
  (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG |      \
6054
   HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS),      \
6055
  /* section flags */             \
6056
  (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
6057
  UNDER,      /* Leading symbol underscore.  */ \
6058
  '/',        /* AR_pad_char.  */     \
6059
  15,       /* AR_max_namelen.  */      \
6060
  0,        /* match priority.  */      \
6061
  TARGET_KEEP_UNUSED_SECTION_SYMBOLS, /* keep unused section symbols.  */ \
6062
                  \
6063
  /* Data conversion functions.  */         \
6064
  bfd_getb64, bfd_getb_signed_64, bfd_putb64,       \
6065
  bfd_getb32, bfd_getb_signed_32, bfd_putb32,       \
6066
  bfd_getb16, bfd_getb_signed_16, bfd_putb16,       \
6067
                  \
6068
  /* Header conversion functions.  */         \
6069
  bfd_getb64, bfd_getb_signed_64, bfd_putb64,       \
6070
  bfd_getb32, bfd_getb_signed_32, bfd_putb32,       \
6071
  bfd_getb16, bfd_getb_signed_16, bfd_putb16,       \
6072
                  \
6073
  {       /* bfd_check_format.  */    \
6074
    _bfd_dummy_target,              \
6075
    coff_object_p,              \
6076
    bfd_generic_archive_p,            \
6077
    _bfd_dummy_target             \
6078
  },                  \
6079
  {       /* bfd_set_format.  */      \
6080
    _bfd_bool_bfd_false_error,            \
6081
    coff_mkobject,              \
6082
    _bfd_generic_mkarchive,           \
6083
    _bfd_bool_bfd_false_error           \
6084
  },                  \
6085
  {       /* bfd_write_contents.  */    \
6086
    _bfd_bool_bfd_false_error,            \
6087
    coff_write_object_contents,           \
6088
    _bfd_write_archive_contents,          \
6089
    _bfd_bool_bfd_false_error           \
6090
  },                  \
6091
                  \
6092
  BFD_JUMP_TABLE_GENERIC (coff),          \
6093
  BFD_JUMP_TABLE_COPY (coff),           \
6094
  BFD_JUMP_TABLE_CORE (_bfd_nocore),          \
6095
  BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff),       \
6096
  BFD_JUMP_TABLE_SYMBOLS (coff),          \
6097
  BFD_JUMP_TABLE_RELOCS (coff),           \
6098
  BFD_JUMP_TABLE_WRITE (coff),            \
6099
  BFD_JUMP_TABLE_LINK (coff),           \
6100
  BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic),        \
6101
                  \
6102
  ALTERNATIVE,                \
6103
                  \
6104
  SWAP_TABLE                \
6105
};
6106
6107
#define CREATE_LITTLE_COFF_TARGET_VEC(VAR, NAME, EXTRA_O_FLAGS, EXTRA_S_FLAGS, UNDER, ALTERNATIVE, SWAP_TABLE)  \
6108
const bfd_target VAR =              \
6109
{                 \
6110
  NAME ,                \
6111
  bfd_target_coff_flavour,            \
6112
  BFD_ENDIAN_LITTLE,    /* Data byte order is little.  */ \
6113
  BFD_ENDIAN_LITTLE,    /* Header byte order is little.  */ \
6114
  /* object flags */            \
6115
  (HAS_RELOC | EXEC_P | HAS_LINENO | HAS_DEBUG |      \
6116
   HAS_SYMS | HAS_LOCALS | WP_TEXT | EXTRA_O_FLAGS),      \
6117
  /* section flags */           \
6118
  (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | EXTRA_S_FLAGS),\
6119
  UNDER,      /* Leading symbol underscore.  */ \
6120
  '/',        /* AR_pad_char.  */     \
6121
  15,       /* AR_max_namelen.  */      \
6122
  0,        /* match priority.  */      \
6123
  TARGET_KEEP_UNUSED_SECTION_SYMBOLS, /* keep unused section symbols.  */ \
6124
                  \
6125
  /* Data conversion functions.  */         \
6126
  bfd_getl64, bfd_getl_signed_64, bfd_putl64,       \
6127
  bfd_getl32, bfd_getl_signed_32, bfd_putl32,       \
6128
  bfd_getl16, bfd_getl_signed_16, bfd_putl16,       \
6129
  /* Header conversion functions.  */         \
6130
  bfd_getl64, bfd_getl_signed_64, bfd_putl64,       \
6131
  bfd_getl32, bfd_getl_signed_32, bfd_putl32,       \
6132
  bfd_getl16, bfd_getl_signed_16, bfd_putl16,       \
6133
                  \
6134
  {       /* bfd_check_format.  */    \
6135
    _bfd_dummy_target,              \
6136
    coff_object_p,              \
6137
    bfd_generic_archive_p,            \
6138
    _bfd_dummy_target             \
6139
  },                  \
6140
  {       /* bfd_set_format.  */      \
6141
    _bfd_bool_bfd_false_error,            \
6142
    coff_mkobject,              \
6143
    _bfd_generic_mkarchive,           \
6144
    _bfd_bool_bfd_false_error           \
6145
  },                  \
6146
  {       /* bfd_write_contents.  */    \
6147
    _bfd_bool_bfd_false_error,            \
6148
    coff_write_object_contents,           \
6149
    _bfd_write_archive_contents,          \
6150
    _bfd_bool_bfd_false_error           \
6151
  },                  \
6152
                  \
6153
  BFD_JUMP_TABLE_GENERIC (coff),          \
6154
  BFD_JUMP_TABLE_COPY (coff),           \
6155
  BFD_JUMP_TABLE_CORE (_bfd_nocore),          \
6156
  BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff),       \
6157
  BFD_JUMP_TABLE_SYMBOLS (coff),          \
6158
  BFD_JUMP_TABLE_RELOCS (coff),           \
6159
  BFD_JUMP_TABLE_WRITE (coff),            \
6160
  BFD_JUMP_TABLE_LINK (coff),           \
6161
  BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic),        \
6162
                  \
6163
  ALTERNATIVE,                \
6164
                  \
6165
  SWAP_TABLE                \
6166
};