Coverage Report

Created: 2023-06-29 07:13

/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
31.8M
#define DOT_DEBUG ".debug"
365
31.8M
#define DOT_ZDEBUG  ".zdebug"
366
3.71M
#define GNU_LINKONCE_WI ".gnu.linkonce.wi."
367
3.71M
#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
8.31M
{
410
8.31M
  bfd_coff_long_section_names (abfd) = enable;
411
8.31M
  return true;
412
8.31M
}
pei-i386.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
38.2k
{
410
38.2k
  bfd_coff_long_section_names (abfd) = enable;
411
38.2k
  return true;
412
38.2k
}
pe-x86_64.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
62.8k
{
410
62.8k
  bfd_coff_long_section_names (abfd) = enable;
411
62.8k
  return true;
412
62.8k
}
pei-x86_64.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
87.9k
{
410
87.9k
  bfd_coff_long_section_names (abfd) = enable;
411
87.9k
  return true;
412
87.9k
}
pei-aarch64.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
32.6k
{
410
32.6k
  bfd_coff_long_section_names (abfd) = enable;
411
32.6k
  return true;
412
32.6k
}
pe-aarch64.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
14.3k
{
410
14.3k
  bfd_coff_long_section_names (abfd) = enable;
411
14.3k
  return true;
412
14.3k
}
pei-ia64.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
52.0k
{
410
52.0k
  bfd_coff_long_section_names (abfd) = enable;
411
52.0k
  return true;
412
52.0k
}
pei-loongarch64.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
105k
{
410
105k
  bfd_coff_long_section_names (abfd) = enable;
411
105k
  return true;
412
105k
}
coff-go32.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
7.16M
{
410
7.16M
  bfd_coff_long_section_names (abfd) = enable;
411
7.16M
  return true;
412
7.16M
}
Unexecuted instantiation: coff-stgo32.c:bfd_coff_set_long_section_names_allowed
pe-arm-wince.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
9.77k
{
410
9.77k
  bfd_coff_long_section_names (abfd) = enable;
411
9.77k
  return true;
412
9.77k
}
pe-arm.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
9.77k
{
410
9.77k
  bfd_coff_long_section_names (abfd) = enable;
411
9.77k
  return true;
412
9.77k
}
pe-i386.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
41.1k
{
410
41.1k
  bfd_coff_long_section_names (abfd) = enable;
411
41.1k
  return true;
412
41.1k
}
pe-mcore.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
492k
{
410
492k
  bfd_coff_long_section_names (abfd) = enable;
411
492k
  return true;
412
492k
}
pe-sh.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
30.0k
{
410
30.0k
  bfd_coff_long_section_names (abfd) = enable;
411
30.0k
  return true;
412
30.0k
}
pei-arm-wince.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
34.3k
{
410
34.3k
  bfd_coff_long_section_names (abfd) = enable;
411
34.3k
  return true;
412
34.3k
}
pei-arm.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
40.9k
{
410
40.9k
  bfd_coff_long_section_names (abfd) = enable;
411
40.9k
  return true;
412
40.9k
}
pei-mcore.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
47.8k
{
410
47.8k
  bfd_coff_long_section_names (abfd) = enable;
411
47.8k
  return true;
412
47.8k
}
pei-sh.c:bfd_coff_set_long_section_names_allowed
Line
Count
Source
409
51.1k
{
410
51.1k
  bfd_coff_long_section_names (abfd) = enable;
411
51.1k
  return true;
412
51.1k
}
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
79.8M
{
418
79.8M
  return false;
419
79.8M
}
coff-x86_64.c:bfd_coff_set_long_section_names_disallowed
Line
Count
Source
417
1.67M
{
418
1.67M
  return false;
419
1.67M
}
coff64-rs6000.c:bfd_coff_set_long_section_names_disallowed
Line
Count
Source
417
3.93M
{
418
3.93M
  return false;
419
3.93M
}
cf-i386lynx.c:bfd_coff_set_long_section_names_disallowed
Line
Count
Source
417
9.07M
{
418
9.07M
  return false;
419
9.07M
}
coff-i386.c:bfd_coff_set_long_section_names_disallowed
Line
Count
Source
417
9.07M
{
418
9.07M
  return false;
419
9.07M
}
coff-rs6000.c:bfd_coff_set_long_section_names_disallowed
Line
Count
Source
417
18.8M
{
418
18.8M
  return false;
419
18.8M
}
coff-sh.c:bfd_coff_set_long_section_names_disallowed
Line
Count
Source
417
6.69M
{
418
6.69M
  return false;
419
6.69M
}
coff-tic30.c:bfd_coff_set_long_section_names_disallowed
Line
Count
Source
417
17.9M
{
418
17.9M
  return false;
419
17.9M
}
Unexecuted instantiation: coff-tic4x.c:bfd_coff_set_long_section_names_disallowed
coff-tic54x.c:bfd_coff_set_long_section_names_disallowed
Line
Count
Source
417
5.33M
{
418
5.33M
  return false;
419
5.33M
}
coff-z80.c:bfd_coff_set_long_section_names_disallowed
Line
Count
Source
417
440k
{
418
440k
  return false;
419
440k
}
coff-z8k.c:bfd_coff_set_long_section_names_disallowed
Line
Count
Source
417
6.84M
{
418
6.84M
  return false;
419
6.84M
}
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
87.0M
{
687
87.0M
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
87.0M
  unsigned long styp_flags = internal_s->s_flags;
689
87.0M
  flagword sec_flags = 0;
690
691
#ifdef STYP_BLOCK
692
5.33M
  if (styp_flags & STYP_BLOCK)
693
1.88M
    sec_flags |= SEC_TIC54X_BLOCK;
694
#endif
695
696
#ifdef STYP_CLINK
697
5.33M
  if (styp_flags & STYP_CLINK)
698
1.88M
    sec_flags |= SEC_TIC54X_CLINK;
699
#endif
700
701
87.0M
#ifdef STYP_NOLOAD
702
87.0M
  if (styp_flags & STYP_NOLOAD)
703
30.4M
    sec_flags |= SEC_NEVER_LOAD;
704
87.0M
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
87.0M
  if (styp_flags & STYP_TEXT)
709
35.0M
    {
710
35.0M
      if (sec_flags & SEC_NEVER_LOAD)
711
20.2M
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
14.8M
      else
713
14.8M
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
35.0M
    }
715
51.9M
  else if (styp_flags & STYP_DATA)
716
9.48M
    {
717
9.48M
      if (sec_flags & SEC_NEVER_LOAD)
718
5.45M
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
4.03M
      else
720
4.03M
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
9.48M
    }
722
42.4M
  else if (styp_flags & STYP_BSS)
723
2.76M
    {
724
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
823k
      if (sec_flags & SEC_NEVER_LOAD)
726
374k
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
449k
      else
728
449k
#endif
729
2.38M
  sec_flags |= SEC_ALLOC;
730
2.76M
    }
731
39.6M
  else if (styp_flags & STYP_INFO)
732
5.61M
    {
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
1.63M
      sec_flags |= SEC_DEBUGGING;
741
#endif
742
5.61M
    }
743
34.0M
  else if (styp_flags & STYP_PAD)
744
1.92M
    sec_flags = 0;
745
#ifdef RS6000COFF_C
746
7.98M
  else if (styp_flags & STYP_TDATA)
747
556k
    {
748
556k
      if (sec_flags & SEC_NEVER_LOAD)
749
57.7k
  sec_flags |= SEC_DATA | SEC_THREAD_LOCAL | SEC_COFF_SHARED_LIBRARY;
750
499k
      else
751
499k
  sec_flags |= SEC_DATA | SEC_THREAD_LOCAL | SEC_LOAD | SEC_ALLOC;
752
556k
    }
753
7.42M
  else if (styp_flags & STYP_TBSS)
754
194k
    {
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
194k
  sec_flags |= SEC_ALLOC | SEC_THREAD_LOCAL;
761
194k
    }
762
7.22M
  else if (styp_flags & STYP_EXCEPT)
763
268k
    sec_flags |= SEC_LOAD;
764
6.96M
  else if (styp_flags & STYP_LOADER)
765
88.0k
    sec_flags |= SEC_LOAD;
766
6.87M
  else if (styp_flags & STYP_TYPCHK)
767
50.8k
    sec_flags |= SEC_LOAD;
768
6.82M
  else if (styp_flags & STYP_DWARF)
769
85.0k
    sec_flags |= SEC_DEBUGGING;
770
6.73M
#endif
771
30.8M
  else if (strcmp (name, _TEXT) == 0)
772
67.6k
    {
773
67.6k
      if (sec_flags & SEC_NEVER_LOAD)
774
22.7k
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
44.9k
      else
776
44.9k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
67.6k
    }
778
30.8M
  else if (strcmp (name, _DATA) == 0)
779
96.1k
    {
780
96.1k
      if (sec_flags & SEC_NEVER_LOAD)
781
7.71k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
88.4k
      else
783
88.4k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
96.1k
    }
785
30.7M
  else if (strcmp (name, _BSS) == 0)
786
30.8k
    {
787
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
8.11k
      if (sec_flags & SEC_NEVER_LOAD)
789
2.24k
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
5.86k
      else
791
5.86k
#endif
792
28.6k
  sec_flags |= SEC_ALLOC;
793
30.8k
    }
794
30.7M
  else if (startswith (name, DOT_DEBUG)
795
30.7M
     || startswith (name, DOT_ZDEBUG)
796
#ifdef _COMMENT
797
22.1M
     || strcmp (name, _COMMENT) == 0
798
#endif
799
#ifdef COFF_LONG_SECTION_NAMES
800
2.59M
     || startswith (name, GNU_LINKONCE_WI)
801
2.59M
     || startswith (name, GNU_LINKONCE_WT)
802
#endif
803
30.7M
     || startswith (name, ".stab"))
804
126k
    {
805
#ifdef COFF_PAGE_SIZE
806
42.8k
      sec_flags |= SEC_DEBUGGING;
807
#endif
808
126k
    }
809
#ifdef _LIB
810
22.1M
  else if (strcmp (name, _LIB) == 0)
811
10.3k
    ;
812
22.1M
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
22.1M
  else
818
30.5M
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
87.0M
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
87.0M
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
11.4M
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
87.0M
#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
87.0M
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
87.0M
      && (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
7.13M
  if (startswith (name, ".gnu.linkonce"))
843
0
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
844
#endif
845
846
87.0M
  if (flags_ptr == NULL)
847
0
    return false;
848
849
87.0M
  * flags_ptr = sec_flags;
850
87.0M
  return true;
851
87.0M
}
coff-x86_64.c:styp_to_sec_flags
Line
Count
Source
686
1.67M
{
687
1.67M
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
1.67M
  unsigned long styp_flags = internal_s->s_flags;
689
1.67M
  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
1.67M
#ifdef STYP_NOLOAD
702
1.67M
  if (styp_flags & STYP_NOLOAD)
703
544k
    sec_flags |= SEC_NEVER_LOAD;
704
1.67M
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
1.67M
  if (styp_flags & STYP_TEXT)
709
635k
    {
710
635k
      if (sec_flags & SEC_NEVER_LOAD)
711
375k
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
259k
      else
713
259k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
635k
    }
715
1.04M
  else if (styp_flags & STYP_DATA)
716
140k
    {
717
140k
      if (sec_flags & SEC_NEVER_LOAD)
718
81.5k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
59.0k
      else
720
59.0k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
140k
    }
722
903k
  else if (styp_flags & STYP_BSS)
723
34.8k
    {
724
34.8k
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
34.8k
      if (sec_flags & SEC_NEVER_LOAD)
726
14.0k
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
20.7k
      else
728
20.7k
#endif
729
20.7k
  sec_flags |= SEC_ALLOC;
730
34.8k
    }
731
868k
  else if (styp_flags & STYP_INFO)
732
120k
    {
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
120k
#if defined (COFF_PAGE_SIZE) && !defined (COFF_ALIGN_IN_S_FLAGS)
740
120k
      sec_flags |= SEC_DEBUGGING;
741
120k
#endif
742
120k
    }
743
748k
  else if (styp_flags & STYP_PAD)
744
36.2k
    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
711k
  else if (strcmp (name, _TEXT) == 0)
772
2.87k
    {
773
2.87k
      if (sec_flags & SEC_NEVER_LOAD)
774
1.00k
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
1.86k
      else
776
1.86k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
2.87k
    }
778
708k
  else if (strcmp (name, _DATA) == 0)
779
2.03k
    {
780
2.03k
      if (sec_flags & SEC_NEVER_LOAD)
781
500
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
1.53k
      else
783
1.53k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
2.03k
    }
785
706k
  else if (strcmp (name, _BSS) == 0)
786
1.24k
    {
787
1.24k
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
1.24k
      if (sec_flags & SEC_NEVER_LOAD)
789
510
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
732
      else
791
732
#endif
792
732
  sec_flags |= SEC_ALLOC;
793
1.24k
    }
794
705k
  else if (startswith (name, DOT_DEBUG)
795
705k
     || startswith (name, DOT_ZDEBUG)
796
705k
#ifdef _COMMENT
797
705k
     || strcmp (name, _COMMENT) == 0
798
705k
#endif
799
#ifdef COFF_LONG_SECTION_NAMES
800
     || startswith (name, GNU_LINKONCE_WI)
801
     || startswith (name, GNU_LINKONCE_WT)
802
#endif
803
705k
     || startswith (name, ".stab"))
804
7.30k
    {
805
7.30k
#ifdef COFF_PAGE_SIZE
806
7.30k
      sec_flags |= SEC_DEBUGGING;
807
7.30k
#endif
808
7.30k
    }
809
698k
#ifdef _LIB
810
698k
  else if (strcmp (name, _LIB) == 0)
811
515
    ;
812
697k
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
697k
  else
818
697k
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
1.67M
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
1.67M
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
198k
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
1.67M
#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
1.67M
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
1.67M
      && (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
1.67M
  if (flags_ptr == NULL)
847
0
    return false;
848
849
1.67M
  * flags_ptr = sec_flags;
850
1.67M
  return true;
851
1.67M
}
coff64-rs6000.c:styp_to_sec_flags
Line
Count
Source
686
3.93M
{
687
3.93M
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
3.93M
  unsigned long styp_flags = internal_s->s_flags;
689
3.93M
  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
3.93M
#ifdef STYP_NOLOAD
702
3.93M
  if (styp_flags & STYP_NOLOAD)
703
1.29M
    sec_flags |= SEC_NEVER_LOAD;
704
3.93M
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
3.93M
  if (styp_flags & STYP_TEXT)
709
1.74M
    {
710
1.74M
      if (sec_flags & SEC_NEVER_LOAD)
711
892k
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
856k
      else
713
856k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
1.74M
    }
715
2.18M
  else if (styp_flags & STYP_DATA)
716
365k
    {
717
365k
      if (sec_flags & SEC_NEVER_LOAD)
718
221k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
143k
      else
720
143k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
365k
    }
722
1.82M
  else if (styp_flags & STYP_BSS)
723
88.4k
    {
724
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
      if (sec_flags & SEC_NEVER_LOAD)
726
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
      else
728
#endif
729
88.4k
  sec_flags |= SEC_ALLOC;
730
88.4k
    }
731
1.73M
  else if (styp_flags & STYP_INFO)
732
253k
    {
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
      sec_flags |= SEC_DEBUGGING;
741
#endif
742
253k
    }
743
1.47M
  else if (styp_flags & STYP_PAD)
744
85.6k
    sec_flags = 0;
745
1.39M
#ifdef RS6000COFF_C
746
1.39M
  else if (styp_flags & STYP_TDATA)
747
90.5k
    {
748
90.5k
      if (sec_flags & SEC_NEVER_LOAD)
749
6.17k
  sec_flags |= SEC_DATA | SEC_THREAD_LOCAL | SEC_COFF_SHARED_LIBRARY;
750
84.3k
      else
751
84.3k
  sec_flags |= SEC_DATA | SEC_THREAD_LOCAL | SEC_LOAD | SEC_ALLOC;
752
90.5k
    }
753
1.30M
  else if (styp_flags & STYP_TBSS)
754
28.4k
    {
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
28.4k
  sec_flags |= SEC_ALLOC | SEC_THREAD_LOCAL;
761
28.4k
    }
762
1.27M
  else if (styp_flags & STYP_EXCEPT)
763
46.7k
    sec_flags |= SEC_LOAD;
764
1.22M
  else if (styp_flags & STYP_LOADER)
765
12.6k
    sec_flags |= SEC_LOAD;
766
1.21M
  else if (styp_flags & STYP_TYPCHK)
767
10.8k
    sec_flags |= SEC_LOAD;
768
1.20M
  else if (styp_flags & STYP_DWARF)
769
19.2k
    sec_flags |= SEC_DEBUGGING;
770
1.18M
#endif
771
1.18M
  else if (strcmp (name, _TEXT) == 0)
772
2.33k
    {
773
2.33k
      if (sec_flags & SEC_NEVER_LOAD)
774
500
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
1.83k
      else
776
1.83k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
2.33k
    }
778
1.18M
  else if (strcmp (name, _DATA) == 0)
779
3.20k
    {
780
3.20k
      if (sec_flags & SEC_NEVER_LOAD)
781
500
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
2.70k
      else
783
2.70k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
3.20k
    }
785
1.17M
  else if (strcmp (name, _BSS) == 0)
786
1.16k
    {
787
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
      if (sec_flags & SEC_NEVER_LOAD)
789
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
      else
791
#endif
792
1.16k
  sec_flags |= SEC_ALLOC;
793
1.16k
    }
794
1.17M
  else if (startswith (name, DOT_DEBUG)
795
1.17M
     || startswith (name, DOT_ZDEBUG)
796
#ifdef _COMMENT
797
     || strcmp (name, _COMMENT) == 0
798
#endif
799
#ifdef COFF_LONG_SECTION_NAMES
800
     || startswith (name, GNU_LINKONCE_WI)
801
     || startswith (name, GNU_LINKONCE_WT)
802
#endif
803
1.17M
     || startswith (name, ".stab"))
804
5.14k
    {
805
#ifdef COFF_PAGE_SIZE
806
      sec_flags |= SEC_DEBUGGING;
807
#endif
808
5.14k
    }
809
#ifdef _LIB
810
  else if (strcmp (name, _LIB) == 0)
811
    ;
812
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
1.17M
  else
818
1.17M
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
3.93M
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
3.93M
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
512k
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
3.93M
#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
3.93M
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
3.93M
      && (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
3.93M
  if (flags_ptr == NULL)
847
0
    return false;
848
849
3.93M
  * flags_ptr = sec_flags;
850
3.93M
  return true;
851
3.93M
}
cf-i386lynx.c:styp_to_sec_flags
Line
Count
Source
686
9.07M
{
687
9.07M
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
9.07M
  unsigned long styp_flags = internal_s->s_flags;
689
9.07M
  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
9.07M
#ifdef STYP_NOLOAD
702
9.07M
  if (styp_flags & STYP_NOLOAD)
703
3.20M
    sec_flags |= SEC_NEVER_LOAD;
704
9.07M
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
9.07M
  if (styp_flags & STYP_TEXT)
709
3.62M
    {
710
3.62M
      if (sec_flags & SEC_NEVER_LOAD)
711
2.09M
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
1.52M
      else
713
1.52M
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
3.62M
    }
715
5.44M
  else if (styp_flags & STYP_DATA)
716
1.09M
    {
717
1.09M
      if (sec_flags & SEC_NEVER_LOAD)
718
618k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
477k
      else
720
477k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
1.09M
    }
722
4.35M
  else if (styp_flags & STYP_BSS)
723
285k
    {
724
285k
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
285k
      if (sec_flags & SEC_NEVER_LOAD)
726
129k
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
155k
      else
728
155k
#endif
729
155k
  sec_flags |= SEC_ALLOC;
730
285k
    }
731
4.06M
  else if (styp_flags & STYP_INFO)
732
545k
    {
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
545k
#if defined (COFF_PAGE_SIZE) && !defined (COFF_ALIGN_IN_S_FLAGS)
740
545k
      sec_flags |= SEC_DEBUGGING;
741
545k
#endif
742
545k
    }
743
3.52M
  else if (styp_flags & STYP_PAD)
744
204k
    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
3.31M
  else if (strcmp (name, _TEXT) == 0)
772
5.94k
    {
773
5.94k
      if (sec_flags & SEC_NEVER_LOAD)
774
1.59k
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
4.35k
      else
776
4.35k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
5.94k
    }
778
3.31M
  else if (strcmp (name, _DATA) == 0)
779
5.33k
    {
780
5.33k
      if (sec_flags & SEC_NEVER_LOAD)
781
524
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
4.81k
      else
783
4.81k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
5.33k
    }
785
3.30M
  else if (strcmp (name, _BSS) == 0)
786
2.49k
    {
787
2.49k
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
2.49k
      if (sec_flags & SEC_NEVER_LOAD)
789
613
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
1.88k
      else
791
1.88k
#endif
792
1.88k
  sec_flags |= SEC_ALLOC;
793
2.49k
    }
794
3.30M
  else if (startswith (name, DOT_DEBUG)
795
3.30M
     || startswith (name, DOT_ZDEBUG)
796
3.30M
#ifdef _COMMENT
797
3.30M
     || strcmp (name, _COMMENT) == 0
798
3.30M
#endif
799
#ifdef COFF_LONG_SECTION_NAMES
800
     || startswith (name, GNU_LINKONCE_WI)
801
     || startswith (name, GNU_LINKONCE_WT)
802
#endif
803
3.30M
     || startswith (name, ".stab"))
804
12.2k
    {
805
12.2k
#ifdef COFF_PAGE_SIZE
806
12.2k
      sec_flags |= SEC_DEBUGGING;
807
12.2k
#endif
808
12.2k
    }
809
3.29M
#ifdef _LIB
810
3.29M
  else if (strcmp (name, _LIB) == 0)
811
1.12k
    ;
812
3.29M
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
3.29M
  else
818
3.29M
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
9.07M
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
9.07M
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
1.19M
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
9.07M
#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
9.07M
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
9.07M
      && (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
9.07M
  if (flags_ptr == NULL)
847
0
    return false;
848
849
9.07M
  * flags_ptr = sec_flags;
850
9.07M
  return true;
851
9.07M
}
coff-go32.c:styp_to_sec_flags
Line
Count
Source
686
7.13M
{
687
7.13M
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
7.13M
  unsigned long styp_flags = internal_s->s_flags;
689
7.13M
  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
7.13M
#ifdef STYP_NOLOAD
702
7.13M
  if (styp_flags & STYP_NOLOAD)
703
2.50M
    sec_flags |= SEC_NEVER_LOAD;
704
7.13M
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
7.13M
  if (styp_flags & STYP_TEXT)
709
2.86M
    {
710
2.86M
      if (sec_flags & SEC_NEVER_LOAD)
711
1.64M
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
1.21M
      else
713
1.21M
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
2.86M
    }
715
4.27M
  else if (styp_flags & STYP_DATA)
716
857k
    {
717
857k
      if (sec_flags & SEC_NEVER_LOAD)
718
479k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
377k
      else
720
377k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
857k
    }
722
3.41M
  else if (styp_flags & STYP_BSS)
723
218k
    {
724
218k
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
218k
      if (sec_flags & SEC_NEVER_LOAD)
726
100k
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
118k
      else
728
118k
#endif
729
118k
  sec_flags |= SEC_ALLOC;
730
218k
    }
731
3.19M
  else if (styp_flags & STYP_INFO)
732
426k
    {
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
426k
#if defined (COFF_PAGE_SIZE) && !defined (COFF_ALIGN_IN_S_FLAGS)
740
426k
      sec_flags |= SEC_DEBUGGING;
741
426k
#endif
742
426k
    }
743
2.77M
  else if (styp_flags & STYP_PAD)
744
160k
    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
2.61M
  else if (strcmp (name, _TEXT) == 0)
772
4.69k
    {
773
4.69k
      if (sec_flags & SEC_NEVER_LOAD)
774
1.18k
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
3.51k
      else
776
3.51k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
4.69k
    }
778
2.60M
  else if (strcmp (name, _DATA) == 0)
779
4.89k
    {
780
4.89k
      if (sec_flags & SEC_NEVER_LOAD)
781
524
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
4.37k
      else
783
4.37k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
4.89k
    }
785
2.60M
  else if (strcmp (name, _BSS) == 0)
786
1.88k
    {
787
1.88k
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
1.88k
      if (sec_flags & SEC_NEVER_LOAD)
789
512
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
1.37k
      else
791
1.37k
#endif
792
1.37k
  sec_flags |= SEC_ALLOC;
793
1.88k
    }
794
2.60M
  else if (startswith (name, DOT_DEBUG)
795
2.60M
     || startswith (name, DOT_ZDEBUG)
796
2.60M
#ifdef _COMMENT
797
2.60M
     || strcmp (name, _COMMENT) == 0
798
2.60M
#endif
799
2.60M
#ifdef COFF_LONG_SECTION_NAMES
800
2.60M
     || startswith (name, GNU_LINKONCE_WI)
801
2.60M
     || startswith (name, GNU_LINKONCE_WT)
802
2.60M
#endif
803
2.60M
     || startswith (name, ".stab"))
804
11.0k
    {
805
11.0k
#ifdef COFF_PAGE_SIZE
806
11.0k
      sec_flags |= SEC_DEBUGGING;
807
11.0k
#endif
808
11.0k
    }
809
2.58M
#ifdef _LIB
810
2.58M
  else if (strcmp (name, _LIB) == 0)
811
922
    ;
812
2.58M
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
2.58M
  else
818
2.58M
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
7.13M
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
7.13M
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
939k
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
7.13M
#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
7.13M
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
7.13M
      && (startswith (name, ".sbss")
832
0
    || startswith (name, ".sdata")))
833
0
    sec_flags |= SEC_SMALL_DATA;
834
835
7.13M
#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
7.13M
  if (startswith (name, ".gnu.linkonce"))
843
0
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
844
7.13M
#endif
845
846
7.13M
  if (flags_ptr == NULL)
847
0
    return false;
848
849
7.13M
  * flags_ptr = sec_flags;
850
7.13M
  return true;
851
7.13M
}
coff-i386.c:styp_to_sec_flags
Line
Count
Source
686
9.07M
{
687
9.07M
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
9.07M
  unsigned long styp_flags = internal_s->s_flags;
689
9.07M
  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
9.07M
#ifdef STYP_NOLOAD
702
9.07M
  if (styp_flags & STYP_NOLOAD)
703
3.20M
    sec_flags |= SEC_NEVER_LOAD;
704
9.07M
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
9.07M
  if (styp_flags & STYP_TEXT)
709
3.62M
    {
710
3.62M
      if (sec_flags & SEC_NEVER_LOAD)
711
2.09M
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
1.52M
      else
713
1.52M
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
3.62M
    }
715
5.44M
  else if (styp_flags & STYP_DATA)
716
1.09M
    {
717
1.09M
      if (sec_flags & SEC_NEVER_LOAD)
718
618k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
477k
      else
720
477k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
1.09M
    }
722
4.35M
  else if (styp_flags & STYP_BSS)
723
285k
    {
724
285k
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
285k
      if (sec_flags & SEC_NEVER_LOAD)
726
129k
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
155k
      else
728
155k
#endif
729
155k
  sec_flags |= SEC_ALLOC;
730
285k
    }
731
4.06M
  else if (styp_flags & STYP_INFO)
732
545k
    {
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
545k
#if defined (COFF_PAGE_SIZE) && !defined (COFF_ALIGN_IN_S_FLAGS)
740
545k
      sec_flags |= SEC_DEBUGGING;
741
545k
#endif
742
545k
    }
743
3.52M
  else if (styp_flags & STYP_PAD)
744
204k
    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
3.31M
  else if (strcmp (name, _TEXT) == 0)
772
5.94k
    {
773
5.94k
      if (sec_flags & SEC_NEVER_LOAD)
774
1.59k
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
4.35k
      else
776
4.35k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
5.94k
    }
778
3.31M
  else if (strcmp (name, _DATA) == 0)
779
5.33k
    {
780
5.33k
      if (sec_flags & SEC_NEVER_LOAD)
781
524
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
4.81k
      else
783
4.81k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
5.33k
    }
785
3.30M
  else if (strcmp (name, _BSS) == 0)
786
2.49k
    {
787
2.49k
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
2.49k
      if (sec_flags & SEC_NEVER_LOAD)
789
613
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
1.88k
      else
791
1.88k
#endif
792
1.88k
  sec_flags |= SEC_ALLOC;
793
2.49k
    }
794
3.30M
  else if (startswith (name, DOT_DEBUG)
795
3.30M
     || startswith (name, DOT_ZDEBUG)
796
3.30M
#ifdef _COMMENT
797
3.30M
     || strcmp (name, _COMMENT) == 0
798
3.30M
#endif
799
#ifdef COFF_LONG_SECTION_NAMES
800
     || startswith (name, GNU_LINKONCE_WI)
801
     || startswith (name, GNU_LINKONCE_WT)
802
#endif
803
3.30M
     || startswith (name, ".stab"))
804
12.2k
    {
805
12.2k
#ifdef COFF_PAGE_SIZE
806
12.2k
      sec_flags |= SEC_DEBUGGING;
807
12.2k
#endif
808
12.2k
    }
809
3.29M
#ifdef _LIB
810
3.29M
  else if (strcmp (name, _LIB) == 0)
811
1.12k
    ;
812
3.29M
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
3.29M
  else
818
3.29M
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
9.07M
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
9.07M
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
1.19M
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
9.07M
#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
9.07M
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
9.07M
      && (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
9.07M
  if (flags_ptr == NULL)
847
0
    return false;
848
849
9.07M
  * flags_ptr = sec_flags;
850
9.07M
  return true;
851
9.07M
}
coff-rs6000.c:styp_to_sec_flags
Line
Count
Source
686
18.8M
{
687
18.8M
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
18.8M
  unsigned long styp_flags = internal_s->s_flags;
689
18.8M
  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
18.8M
#ifdef STYP_NOLOAD
702
18.8M
  if (styp_flags & STYP_NOLOAD)
703
6.82M
    sec_flags |= SEC_NEVER_LOAD;
704
18.8M
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
18.8M
  if (styp_flags & STYP_TEXT)
709
7.77M
    {
710
7.77M
      if (sec_flags & SEC_NEVER_LOAD)
711
4.47M
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
3.30M
      else
713
3.30M
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
7.77M
    }
715
11.0M
  else if (styp_flags & STYP_DATA)
716
2.11M
    {
717
2.11M
      if (sec_flags & SEC_NEVER_LOAD)
718
1.20M
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
914k
      else
720
914k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
2.11M
    }
722
8.94M
  else if (styp_flags & STYP_BSS)
723
750k
    {
724
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
      if (sec_flags & SEC_NEVER_LOAD)
726
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
      else
728
#endif
729
750k
  sec_flags |= SEC_ALLOC;
730
750k
    }
731
8.19M
  else if (styp_flags & STYP_INFO)
732
1.21M
    {
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
      sec_flags |= SEC_DEBUGGING;
741
#endif
742
1.21M
    }
743
6.98M
  else if (styp_flags & STYP_PAD)
744
394k
    sec_flags = 0;
745
6.58M
#ifdef RS6000COFF_C
746
6.58M
  else if (styp_flags & STYP_TDATA)
747
466k
    {
748
466k
      if (sec_flags & SEC_NEVER_LOAD)
749
51.5k
  sec_flags |= SEC_DATA | SEC_THREAD_LOCAL | SEC_COFF_SHARED_LIBRARY;
750
414k
      else
751
414k
  sec_flags |= SEC_DATA | SEC_THREAD_LOCAL | SEC_LOAD | SEC_ALLOC;
752
466k
    }
753
6.12M
  else if (styp_flags & STYP_TBSS)
754
166k
    {
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
166k
  sec_flags |= SEC_ALLOC | SEC_THREAD_LOCAL;
761
166k
    }
762
5.95M
  else if (styp_flags & STYP_EXCEPT)
763
221k
    sec_flags |= SEC_LOAD;
764
5.73M
  else if (styp_flags & STYP_LOADER)
765
75.3k
    sec_flags |= SEC_LOAD;
766
5.65M
  else if (styp_flags & STYP_TYPCHK)
767
40.0k
    sec_flags |= SEC_LOAD;
768
5.61M
  else if (styp_flags & STYP_DWARF)
769
65.7k
    sec_flags |= SEC_DEBUGGING;
770
5.55M
#endif
771
5.55M
  else if (strcmp (name, _TEXT) == 0)
772
6.82k
    {
773
6.82k
      if (sec_flags & SEC_NEVER_LOAD)
774
935
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
5.88k
      else
776
5.88k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
6.82k
    }
778
5.54M
  else if (strcmp (name, _DATA) == 0)
779
26.3k
    {
780
26.3k
      if (sec_flags & SEC_NEVER_LOAD)
781
1.30k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
25.0k
      else
783
25.0k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
26.3k
    }
785
5.51M
  else if (strcmp (name, _BSS) == 0)
786
6.25k
    {
787
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
      if (sec_flags & SEC_NEVER_LOAD)
789
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
      else
791
#endif
792
6.25k
  sec_flags |= SEC_ALLOC;
793
6.25k
    }
794
5.51M
  else if (startswith (name, DOT_DEBUG)
795
5.51M
     || startswith (name, DOT_ZDEBUG)
796
#ifdef _COMMENT
797
     || strcmp (name, _COMMENT) == 0
798
#endif
799
#ifdef COFF_LONG_SECTION_NAMES
800
     || startswith (name, GNU_LINKONCE_WI)
801
     || startswith (name, GNU_LINKONCE_WT)
802
#endif
803
5.51M
     || startswith (name, ".stab"))
804
20.3k
    {
805
#ifdef COFF_PAGE_SIZE
806
      sec_flags |= SEC_DEBUGGING;
807
#endif
808
20.3k
    }
809
#ifdef _LIB
810
  else if (strcmp (name, _LIB) == 0)
811
    ;
812
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
5.49M
  else
818
5.49M
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
18.8M
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
18.8M
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
2.73M
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
18.8M
#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
18.8M
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
18.8M
      && (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
18.8M
  if (flags_ptr == NULL)
847
0
    return false;
848
849
18.8M
  * flags_ptr = sec_flags;
850
18.8M
  return true;
851
18.8M
}
coff-sh.c:styp_to_sec_flags
Line
Count
Source
686
6.69M
{
687
6.69M
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
6.69M
  unsigned long styp_flags = internal_s->s_flags;
689
6.69M
  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
6.69M
#ifdef STYP_NOLOAD
702
6.69M
  if (styp_flags & STYP_NOLOAD)
703
1.89M
    sec_flags |= SEC_NEVER_LOAD;
704
6.69M
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
6.69M
  if (styp_flags & STYP_TEXT)
709
2.10M
    {
710
2.10M
      if (sec_flags & SEC_NEVER_LOAD)
711
1.20M
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
900k
      else
713
900k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
2.10M
    }
715
4.59M
  else if (styp_flags & STYP_DATA)
716
659k
    {
717
659k
      if (sec_flags & SEC_NEVER_LOAD)
718
400k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
259k
      else
720
259k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
659k
    }
722
3.93M
  else if (styp_flags & STYP_BSS)
723
162k
    {
724
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
      if (sec_flags & SEC_NEVER_LOAD)
726
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
      else
728
#endif
729
162k
  sec_flags |= SEC_ALLOC;
730
162k
    }
731
3.76M
  else if (styp_flags & STYP_INFO)
732
354k
    {
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
      sec_flags |= SEC_DEBUGGING;
741
#endif
742
354k
    }
743
3.41M
  else if (styp_flags & STYP_PAD)
744
166k
    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
3.24M
  else if (strcmp (name, _TEXT) == 0)
772
5.90k
    {
773
5.90k
      if (sec_flags & SEC_NEVER_LOAD)
774
2.68k
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
3.22k
      else
776
3.22k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
5.90k
    }
778
3.24M
  else if (strcmp (name, _DATA) == 0)
779
5.57k
    {
780
5.57k
      if (sec_flags & SEC_NEVER_LOAD)
781
418
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
5.15k
      else
783
5.15k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
5.57k
    }
785
3.23M
  else if (strcmp (name, _BSS) == 0)
786
3.11k
    {
787
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
      if (sec_flags & SEC_NEVER_LOAD)
789
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
      else
791
#endif
792
3.11k
  sec_flags |= SEC_ALLOC;
793
3.11k
    }
794
3.23M
  else if (startswith (name, DOT_DEBUG)
795
3.23M
     || startswith (name, DOT_ZDEBUG)
796
3.23M
#ifdef _COMMENT
797
3.23M
     || strcmp (name, _COMMENT) == 0
798
3.23M
#endif
799
#ifdef COFF_LONG_SECTION_NAMES
800
     || startswith (name, GNU_LINKONCE_WI)
801
     || startswith (name, GNU_LINKONCE_WT)
802
#endif
803
3.23M
     || startswith (name, ".stab"))
804
10.7k
    {
805
#ifdef COFF_PAGE_SIZE
806
      sec_flags |= SEC_DEBUGGING;
807
#endif
808
10.7k
    }
809
3.22M
#ifdef _LIB
810
3.22M
  else if (strcmp (name, _LIB) == 0)
811
848
    ;
812
3.22M
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
3.22M
  else
818
3.22M
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
6.69M
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
6.69M
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
618k
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
6.69M
#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
6.69M
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
6.69M
      && (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
6.69M
  if (flags_ptr == NULL)
847
0
    return false;
848
849
6.69M
  * flags_ptr = sec_flags;
850
6.69M
  return true;
851
6.69M
}
Unexecuted instantiation: coff-stgo32.c:styp_to_sec_flags
coff-tic30.c:styp_to_sec_flags
Line
Count
Source
686
17.9M
{
687
17.9M
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
17.9M
  unsigned long styp_flags = internal_s->s_flags;
689
17.9M
  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
17.9M
#ifdef STYP_NOLOAD
702
17.9M
  if (styp_flags & STYP_NOLOAD)
703
6.37M
    sec_flags |= SEC_NEVER_LOAD;
704
17.9M
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
17.9M
  if (styp_flags & STYP_TEXT)
709
7.47M
    {
710
7.47M
      if (sec_flags & SEC_NEVER_LOAD)
711
4.40M
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
3.07M
      else
713
3.07M
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
7.47M
    }
715
10.4M
  else if (styp_flags & STYP_DATA)
716
1.87M
    {
717
1.87M
      if (sec_flags & SEC_NEVER_LOAD)
718
1.08M
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
781k
      else
720
781k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
1.87M
    }
722
8.62M
  else if (styp_flags & STYP_BSS)
723
540k
    {
724
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
      if (sec_flags & SEC_NEVER_LOAD)
726
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
      else
728
#endif
729
540k
  sec_flags |= SEC_ALLOC;
730
540k
    }
731
8.08M
  else if (styp_flags & STYP_INFO)
732
1.22M
    {
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
      sec_flags |= SEC_DEBUGGING;
741
#endif
742
1.22M
    }
743
6.85M
  else if (styp_flags & STYP_PAD)
744
339k
    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
6.51M
  else if (strcmp (name, _TEXT) == 0)
772
10.2k
    {
773
10.2k
      if (sec_flags & SEC_NEVER_LOAD)
774
2.39k
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
7.88k
      else
776
7.88k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
10.2k
    }
778
6.50M
  else if (strcmp (name, _DATA) == 0)
779
25.4k
    {
780
25.4k
      if (sec_flags & SEC_NEVER_LOAD)
781
2.26k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
23.1k
      else
783
23.1k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
25.4k
    }
785
6.47M
  else if (strcmp (name, _BSS) == 0)
786
7.76k
    {
787
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
      if (sec_flags & SEC_NEVER_LOAD)
789
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
      else
791
#endif
792
7.76k
  sec_flags |= SEC_ALLOC;
793
7.76k
    }
794
6.47M
  else if (startswith (name, DOT_DEBUG)
795
6.47M
     || startswith (name, DOT_ZDEBUG)
796
6.47M
#ifdef _COMMENT
797
6.47M
     || strcmp (name, _COMMENT) == 0
798
6.47M
#endif
799
#ifdef COFF_LONG_SECTION_NAMES
800
     || startswith (name, GNU_LINKONCE_WI)
801
     || startswith (name, GNU_LINKONCE_WT)
802
#endif
803
6.47M
     || startswith (name, ".stab"))
804
24.3k
    {
805
#ifdef COFF_PAGE_SIZE
806
      sec_flags |= SEC_DEBUGGING;
807
#endif
808
24.3k
    }
809
6.44M
#ifdef _LIB
810
6.44M
  else if (strcmp (name, _LIB) == 0)
811
4.40k
    ;
812
6.44M
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
6.44M
  else
818
6.44M
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
17.9M
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
17.9M
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
2.40M
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
17.9M
#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
17.9M
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
17.9M
      && (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
17.9M
  if (flags_ptr == NULL)
847
0
    return false;
848
849
17.9M
  * flags_ptr = sec_flags;
850
17.9M
  return true;
851
17.9M
}
Unexecuted instantiation: coff-tic4x.c:styp_to_sec_flags
coff-tic54x.c:styp_to_sec_flags
Line
Count
Source
686
5.33M
{
687
5.33M
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
5.33M
  unsigned long styp_flags = internal_s->s_flags;
689
5.33M
  flagword sec_flags = 0;
690
691
5.33M
#ifdef STYP_BLOCK
692
5.33M
  if (styp_flags & STYP_BLOCK)
693
1.88M
    sec_flags |= SEC_TIC54X_BLOCK;
694
5.33M
#endif
695
696
5.33M
#ifdef STYP_CLINK
697
5.33M
  if (styp_flags & STYP_CLINK)
698
1.88M
    sec_flags |= SEC_TIC54X_CLINK;
699
5.33M
#endif
700
701
5.33M
#ifdef STYP_NOLOAD
702
5.33M
  if (styp_flags & STYP_NOLOAD)
703
1.84M
    sec_flags |= SEC_NEVER_LOAD;
704
5.33M
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
5.33M
  if (styp_flags & STYP_TEXT)
709
2.26M
    {
710
2.26M
      if (sec_flags & SEC_NEVER_LOAD)
711
1.28M
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
978k
      else
713
978k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
2.26M
    }
715
3.07M
  else if (styp_flags & STYP_DATA)
716
529k
    {
717
529k
      if (sec_flags & SEC_NEVER_LOAD)
718
301k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
228k
      else
720
228k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
529k
    }
722
2.54M
  else if (styp_flags & STYP_BSS)
723
157k
    {
724
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
      if (sec_flags & SEC_NEVER_LOAD)
726
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
      else
728
#endif
729
157k
  sec_flags |= SEC_ALLOC;
730
157k
    }
731
2.38M
  else if (styp_flags & STYP_INFO)
732
421k
    {
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
      sec_flags |= SEC_DEBUGGING;
741
#endif
742
421k
    }
743
1.96M
  else if (styp_flags & STYP_PAD)
744
162k
    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
1.80M
  else if (strcmp (name, _TEXT) == 0)
772
18.1k
    {
773
18.1k
      if (sec_flags & SEC_NEVER_LOAD)
774
10.1k
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
7.99k
      else
776
7.99k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
18.1k
    }
778
1.78M
  else if (strcmp (name, _DATA) == 0)
779
10.7k
    {
780
10.7k
      if (sec_flags & SEC_NEVER_LOAD)
781
257
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
10.4k
      else
783
10.4k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
10.7k
    }
785
1.77M
  else if (strcmp (name, _BSS) == 0)
786
2.50k
    {
787
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
      if (sec_flags & SEC_NEVER_LOAD)
789
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
      else
791
#endif
792
2.50k
  sec_flags |= SEC_ALLOC;
793
2.50k
    }
794
1.77M
  else if (startswith (name, DOT_DEBUG)
795
1.77M
     || startswith (name, DOT_ZDEBUG)
796
#ifdef _COMMENT
797
     || strcmp (name, _COMMENT) == 0
798
#endif
799
#ifdef COFF_LONG_SECTION_NAMES
800
     || startswith (name, GNU_LINKONCE_WI)
801
     || startswith (name, GNU_LINKONCE_WT)
802
#endif
803
1.77M
     || startswith (name, ".stab"))
804
8.57k
    {
805
#ifdef COFF_PAGE_SIZE
806
      sec_flags |= SEC_DEBUGGING;
807
#endif
808
8.57k
    }
809
#ifdef _LIB
810
  else if (strcmp (name, _LIB) == 0)
811
    ;
812
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
1.76M
  else
818
1.76M
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
5.33M
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
5.33M
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
672k
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
5.33M
#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
5.33M
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
5.33M
      && (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
5.33M
  if (flags_ptr == NULL)
847
0
    return false;
848
849
5.33M
  * flags_ptr = sec_flags;
850
5.33M
  return true;
851
5.33M
}
coff-z80.c:styp_to_sec_flags
Line
Count
Source
686
440k
{
687
440k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
440k
  unsigned long styp_flags = internal_s->s_flags;
689
440k
  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
440k
#ifdef STYP_NOLOAD
702
440k
  if (styp_flags & STYP_NOLOAD)
703
165k
    sec_flags |= SEC_NEVER_LOAD;
704
440k
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
440k
  if (styp_flags & STYP_TEXT)
709
184k
    {
710
184k
      if (sec_flags & SEC_NEVER_LOAD)
711
105k
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
79.1k
      else
713
79.1k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
184k
    }
715
255k
  else if (styp_flags & STYP_DATA)
716
56.0k
    {
717
56.0k
      if (sec_flags & SEC_NEVER_LOAD)
718
31.0k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
25.0k
      else
720
25.0k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
56.0k
    }
722
199k
  else if (styp_flags & STYP_BSS)
723
18.5k
    {
724
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
      if (sec_flags & SEC_NEVER_LOAD)
726
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
      else
728
#endif
729
18.5k
  sec_flags |= SEC_ALLOC;
730
18.5k
    }
731
180k
  else if (styp_flags & STYP_INFO)
732
31.0k
    {
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
      sec_flags |= SEC_DEBUGGING;
741
#endif
742
31.0k
    }
743
149k
  else if (styp_flags & STYP_PAD)
744
9.20k
    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
140k
  else if (strcmp (name, _TEXT) == 0)
772
1.69k
    {
773
1.69k
      if (sec_flags & SEC_NEVER_LOAD)
774
133
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
1.55k
      else
776
1.55k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
1.69k
    }
778
139k
  else if (strcmp (name, _DATA) == 0)
779
1.77k
    {
780
1.77k
      if (sec_flags & SEC_NEVER_LOAD)
781
234
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
1.54k
      else
783
1.54k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
1.77k
    }
785
137k
  else if (strcmp (name, _BSS) == 0)
786
503
    {
787
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
      if (sec_flags & SEC_NEVER_LOAD)
789
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
      else
791
#endif
792
503
  sec_flags |= SEC_ALLOC;
793
503
    }
794
136k
  else if (startswith (name, DOT_DEBUG)
795
136k
     || startswith (name, DOT_ZDEBUG)
796
136k
#ifdef _COMMENT
797
136k
     || strcmp (name, _COMMENT) == 0
798
136k
#endif
799
#ifdef COFF_LONG_SECTION_NAMES
800
     || startswith (name, GNU_LINKONCE_WI)
801
     || startswith (name, GNU_LINKONCE_WT)
802
#endif
803
136k
     || startswith (name, ".stab"))
804
4.02k
    {
805
#ifdef COFF_PAGE_SIZE
806
      sec_flags |= SEC_DEBUGGING;
807
#endif
808
4.02k
    }
809
132k
#ifdef _LIB
810
132k
  else if (strcmp (name, _LIB) == 0)
811
397
    ;
812
132k
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
132k
  else
818
132k
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
440k
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
440k
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
59.2k
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
440k
#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
440k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
440k
      && (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
440k
  if (flags_ptr == NULL)
847
0
    return false;
848
849
440k
  * flags_ptr = sec_flags;
850
440k
  return true;
851
440k
}
coff-z8k.c:styp_to_sec_flags
Line
Count
Source
686
6.84M
{
687
6.84M
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
688
6.84M
  unsigned long styp_flags = internal_s->s_flags;
689
6.84M
  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
6.84M
#ifdef STYP_NOLOAD
702
6.84M
  if (styp_flags & STYP_NOLOAD)
703
2.53M
    sec_flags |= SEC_NEVER_LOAD;
704
6.84M
#endif /* STYP_NOLOAD */
705
706
  /* For 386 COFF, at least, an unloadable text or data section is
707
     actually a shared library section.  */
708
6.84M
  if (styp_flags & STYP_TEXT)
709
2.79M
    {
710
2.79M
      if (sec_flags & SEC_NEVER_LOAD)
711
1.67M
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
712
1.11M
      else
713
1.11M
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
714
2.79M
    }
715
4.05M
  else if (styp_flags & STYP_DATA)
716
697k
    {
717
697k
      if (sec_flags & SEC_NEVER_LOAD)
718
409k
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
719
288k
      else
720
288k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
721
697k
    }
722
3.35M
  else if (styp_flags & STYP_BSS)
723
221k
    {
724
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
725
      if (sec_flags & SEC_NEVER_LOAD)
726
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
727
      else
728
#endif
729
221k
  sec_flags |= SEC_ALLOC;
730
221k
    }
731
3.13M
  else if (styp_flags & STYP_INFO)
732
480k
    {
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
      sec_flags |= SEC_DEBUGGING;
741
#endif
742
480k
    }
743
2.65M
  else if (styp_flags & STYP_PAD)
744
158k
    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
2.49M
  else if (strcmp (name, _TEXT) == 0)
772
3.02k
    {
773
3.02k
      if (sec_flags & SEC_NEVER_LOAD)
774
542
  sec_flags |= SEC_CODE | SEC_COFF_SHARED_LIBRARY;
775
2.47k
      else
776
2.47k
  sec_flags |= SEC_CODE | SEC_LOAD | SEC_ALLOC;
777
3.02k
    }
778
2.48M
  else if (strcmp (name, _DATA) == 0)
779
5.48k
    {
780
5.48k
      if (sec_flags & SEC_NEVER_LOAD)
781
664
  sec_flags |= SEC_DATA | SEC_COFF_SHARED_LIBRARY;
782
4.82k
      else
783
4.82k
  sec_flags |= SEC_DATA | SEC_LOAD | SEC_ALLOC;
784
5.48k
    }
785
2.48M
  else if (strcmp (name, _BSS) == 0)
786
1.42k
    {
787
#ifdef BSS_NOLOAD_IS_SHARED_LIBRARY
788
      if (sec_flags & SEC_NEVER_LOAD)
789
  sec_flags |= SEC_ALLOC | SEC_COFF_SHARED_LIBRARY;
790
      else
791
#endif
792
1.42k
  sec_flags |= SEC_ALLOC;
793
1.42k
    }
794
2.48M
  else if (startswith (name, DOT_DEBUG)
795
2.48M
     || startswith (name, DOT_ZDEBUG)
796
2.48M
#ifdef _COMMENT
797
2.48M
     || strcmp (name, _COMMENT) == 0
798
2.48M
#endif
799
#ifdef COFF_LONG_SECTION_NAMES
800
     || startswith (name, GNU_LINKONCE_WI)
801
     || startswith (name, GNU_LINKONCE_WT)
802
#endif
803
2.48M
     || startswith (name, ".stab"))
804
10.5k
    {
805
#ifdef COFF_PAGE_SIZE
806
      sec_flags |= SEC_DEBUGGING;
807
#endif
808
10.5k
    }
809
2.47M
#ifdef _LIB
810
2.47M
  else if (strcmp (name, _LIB) == 0)
811
1.03k
    ;
812
2.47M
#endif
813
#ifdef _LIT
814
  else if (strcmp (name, _LIT) == 0)
815
    sec_flags = SEC_LOAD | SEC_ALLOC | SEC_READONLY;
816
#endif
817
2.47M
  else
818
2.47M
    sec_flags |= SEC_ALLOC | SEC_LOAD;
819
820
6.84M
#ifdef STYP_LIT     /* A29k readonly text/data section type.  */
821
6.84M
  if ((styp_flags & STYP_LIT) == STYP_LIT)
822
910k
    sec_flags = (SEC_LOAD | SEC_ALLOC | SEC_READONLY);
823
6.84M
#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
6.84M
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
831
6.84M
      && (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
6.84M
  if (flags_ptr == NULL)
847
0
    return false;
848
849
6.84M
  * flags_ptr = sec_flags;
850
6.84M
  return true;
851
6.84M
}
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
184k
{
862
184k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
184k
  bfd_byte *esymstart, *esym, *esymend;
864
184k
  int seen_state = 0;
865
184k
  char *target_name = NULL;
866
867
184k
  *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
184k
  if (! _bfd_coff_get_external_symbols (abfd))
887
60.6k
    return true;
888
889
123k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
123k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
123k
  for (struct internal_syment isym;
893
8.87M
       esym < esymend;
894
8.75M
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
8.77M
    {
896
8.77M
      char buf[SYMNMLEN + 1];
897
8.77M
      const char *symname;
898
899
8.77M
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
8.77M
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
8.77M
      if (isym.n_scnum == section->target_index)
904
53.7k
  {
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
53.7k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
53.7k
    if (symname == NULL)
934
4.47k
      {
935
4.47k
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
4.47k
          abfd);
937
4.47k
        return false;
938
4.47k
      }
939
940
49.2k
    switch (seen_state)
941
49.2k
      {
942
39.9k
      case 0:
943
39.9k
        {
944
    /* The first time we've seen the symbol.  */
945
39.9k
    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
39.9k
    if (! ((isym.n_sclass == C_STAT
964
39.9k
      || isym.n_sclass == C_EXT)
965
39.9k
           && BTYPE (isym.n_type) == T_NULL
966
39.9k
           && isym.n_value == 0))
967
10.0k
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
10.0k
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
10.0k
          abfd, symname);
972
10.0k
        return false;
973
10.0k
      }
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
29.8k
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
21.0k
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
21.0k
          " does not match section name '%s'"),
984
21.0k
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
29.8k
    seen_state = 1;
988
29.8k
    target_name = strchr (name, '$');
989
29.8k
    if (target_name != NULL)
990
6.43k
      {
991
        /* Gas mode.  */
992
6.43k
        seen_state = 2;
993
        /* Skip the `$'.  */
994
6.43k
        target_name += 1;
995
6.43k
      }
996
997
29.8k
    if (isym.n_numaux == 0)
998
5.74k
      aux.x_scn.x_comdat = 0;
999
24.1k
    else
1000
24.1k
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
24.1k
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
550
          {
1004
      /* xgettext:c-format */
1005
550
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
550
                " section '%s' found"),
1007
550
              abfd, symname);
1008
550
      break;
1009
550
          }
1010
23.5k
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
23.5k
            isym.n_type, isym.n_sclass,
1012
23.5k
            0, isym.n_numaux, &aux);
1013
23.5k
      }
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
29.3k
    switch (aux.x_scn.x_comdat)
1032
29.3k
      {
1033
3.11k
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
3.11k
        *sec_flags &= ~SEC_LINK_ONCE;
1038
3.11k
#endif
1039
3.11k
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
454
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
454
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
454
        break;
1048
1049
681
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
681
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
681
        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
863
      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
863
        *sec_flags &= ~SEC_LINK_ONCE;
1067
863
#endif
1068
863
        break;
1069
1070
24.2k
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
24.2k
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
24.2k
        break;
1075
29.3k
      }
1076
29.3k
        }
1077
29.3k
        break;
1078
1079
29.3k
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
#ifndef TARGET_UNDERSCORE
1083
250
#define TARGET_UNDERSCORE 0
1084
#endif
1085
        /* Is this the name we're looking for ?  */
1086
4.69k
        if (strcmp (target_name,
1087
4.69k
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
3.49k
    {
1089
      /* Not the name we're looking for */
1090
3.49k
      continue;
1091
3.49k
    }
1092
        /* Fall through.  */
1093
5.84k
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
5.84k
        {
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
5.84k
    struct coff_comdat_info *comdat;
1103
5.84k
    size_t len = strlen (symname) + 1;
1104
1105
5.84k
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
5.84k
    if (comdat == NULL)
1107
0
      return false;
1108
1109
5.84k
    coff_section_data (abfd, section)->comdat = comdat;
1110
5.84k
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
5.84k
    char *newname = (char *) (comdat + 1);
1112
5.84k
    comdat->name = newname;
1113
5.84k
    memcpy (newname, symname, len);
1114
5.84k
    return true;
1115
5.84k
        }
1116
49.2k
      }
1117
49.2k
  }
1118
8.77M
    }
1119
1120
103k
  return true;
1121
123k
}
pei-i386.c:handle_COMDAT
Line
Count
Source
861
9.42k
{
862
9.42k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
9.42k
  bfd_byte *esymstart, *esym, *esymend;
864
9.42k
  int seen_state = 0;
865
9.42k
  char *target_name = NULL;
866
867
9.42k
  *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
9.42k
  if (! _bfd_coff_get_external_symbols (abfd))
887
2.60k
    return true;
888
889
6.81k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
6.81k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
6.81k
  for (struct internal_syment isym;
893
44.1k
       esym < esymend;
894
37.3k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
39.2k
    {
896
39.2k
      char buf[SYMNMLEN + 1];
897
39.2k
      const char *symname;
898
899
39.2k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
39.2k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
39.2k
      if (isym.n_scnum == section->target_index)
904
4.69k
  {
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
4.69k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
4.69k
    if (symname == NULL)
934
236
      {
935
236
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
236
          abfd);
937
236
        return false;
938
236
      }
939
940
4.45k
    switch (seen_state)
941
4.45k
      {
942
3.48k
      case 0:
943
3.48k
        {
944
    /* The first time we've seen the symbol.  */
945
3.48k
    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.48k
    if (! ((isym.n_sclass == C_STAT
964
3.48k
      || isym.n_sclass == C_EXT)
965
3.48k
           && BTYPE (isym.n_type) == T_NULL
966
3.48k
           && isym.n_value == 0))
967
945
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
945
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
945
          abfd, symname);
972
945
        return false;
973
945
      }
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.53k
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
957
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
957
          " does not match section name '%s'"),
984
957
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
2.53k
    seen_state = 1;
988
2.53k
    target_name = strchr (name, '$');
989
2.53k
    if (target_name != NULL)
990
1.00k
      {
991
        /* Gas mode.  */
992
1.00k
        seen_state = 2;
993
        /* Skip the `$'.  */
994
1.00k
        target_name += 1;
995
1.00k
      }
996
997
2.53k
    if (isym.n_numaux == 0)
998
1.34k
      aux.x_scn.x_comdat = 0;
999
1.19k
    else
1000
1.19k
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
1.19k
        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
1.19k
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
1.19k
            isym.n_type, isym.n_sclass,
1012
1.19k
            0, isym.n_numaux, &aux);
1013
1.19k
      }
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.53k
    switch (aux.x_scn.x_comdat)
1032
2.53k
      {
1033
1
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
1
        *sec_flags &= ~SEC_LINK_ONCE;
1038
1
#endif
1039
1
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
1
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
1
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
1
        break;
1048
1049
3
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
3
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
3
        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
0
      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
0
        *sec_flags &= ~SEC_LINK_ONCE;
1067
0
#endif
1068
0
        break;
1069
1070
2.53k
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
2.53k
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
2.53k
        break;
1075
2.53k
      }
1076
2.53k
        }
1077
2.53k
        break;
1078
1079
2.53k
      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
470
        if (strcmp (target_name,
1087
470
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
236
    {
1089
      /* Not the name we're looking for */
1090
236
      continue;
1091
236
    }
1092
        /* Fall through.  */
1093
735
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
735
        {
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
735
    struct coff_comdat_info *comdat;
1103
735
    size_t len = strlen (symname) + 1;
1104
1105
735
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
735
    if (comdat == NULL)
1107
0
      return false;
1108
1109
735
    coff_section_data (abfd, section)->comdat = comdat;
1110
735
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
735
    char *newname = (char *) (comdat + 1);
1112
735
    comdat->name = newname;
1113
735
    memcpy (newname, symname, len);
1114
735
    return true;
1115
735
        }
1116
4.45k
      }
1117
4.45k
  }
1118
39.2k
    }
1119
1120
4.89k
  return true;
1121
6.81k
}
pe-x86_64.c:handle_COMDAT
Line
Count
Source
861
13.8k
{
862
13.8k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
13.8k
  bfd_byte *esymstart, *esym, *esymend;
864
13.8k
  int seen_state = 0;
865
13.8k
  char *target_name = NULL;
866
867
13.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
13.8k
  if (! _bfd_coff_get_external_symbols (abfd))
887
6.37k
    return true;
888
889
7.42k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
7.42k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
7.42k
  for (struct internal_syment isym;
893
92.4k
       esym < esymend;
894
84.9k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
85.6k
    {
896
85.6k
      char buf[SYMNMLEN + 1];
897
85.6k
      const char *symname;
898
899
85.6k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
85.6k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
85.6k
      if (isym.n_scnum == section->target_index)
904
1.92k
  {
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
1.92k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
1.92k
    if (symname == NULL)
934
238
      {
935
238
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
238
          abfd);
937
238
        return false;
938
238
      }
939
940
1.68k
    switch (seen_state)
941
1.68k
      {
942
1.26k
      case 0:
943
1.26k
        {
944
    /* The first time we've seen the symbol.  */
945
1.26k
    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
1.26k
    if (! ((isym.n_sclass == C_STAT
964
1.26k
      || isym.n_sclass == C_EXT)
965
1.26k
           && BTYPE (isym.n_type) == T_NULL
966
1.26k
           && isym.n_value == 0))
967
347
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
347
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
347
          abfd, symname);
972
347
        return false;
973
347
      }
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
920
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
477
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
477
          " does not match section name '%s'"),
984
477
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
920
    seen_state = 1;
988
920
    target_name = strchr (name, '$');
989
920
    if (target_name != NULL)
990
476
      {
991
        /* Gas mode.  */
992
476
        seen_state = 2;
993
        /* Skip the `$'.  */
994
476
        target_name += 1;
995
476
      }
996
997
920
    if (isym.n_numaux == 0)
998
102
      aux.x_scn.x_comdat = 0;
999
818
    else
1000
818
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
818
        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
816
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
816
            isym.n_type, isym.n_sclass,
1012
816
            0, isym.n_numaux, &aux);
1013
816
      }
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
918
    switch (aux.x_scn.x_comdat)
1032
918
      {
1033
132
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
132
        *sec_flags &= ~SEC_LINK_ONCE;
1038
132
#endif
1039
132
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
1
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
1
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
1
        break;
1048
1049
4
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
4
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
4
        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
0
      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
0
        *sec_flags &= ~SEC_LINK_ONCE;
1067
0
#endif
1068
0
        break;
1069
1070
781
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
781
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
781
        break;
1075
918
      }
1076
918
        }
1077
918
        break;
1078
1079
918
      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
315
        if (strcmp (target_name,
1087
315
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
315
    {
1089
      /* Not the name we're looking for */
1090
315
      continue;
1091
315
    }
1092
        /* Fall through.  */
1093
102
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
102
        {
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
102
    struct coff_comdat_info *comdat;
1103
102
    size_t len = strlen (symname) + 1;
1104
1105
102
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
102
    if (comdat == NULL)
1107
0
      return false;
1108
1109
102
    coff_section_data (abfd, section)->comdat = comdat;
1110
102
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
102
    char *newname = (char *) (comdat + 1);
1112
102
    comdat->name = newname;
1113
102
    memcpy (newname, symname, len);
1114
102
    return true;
1115
102
        }
1116
1.68k
      }
1117
1.68k
  }
1118
85.6k
    }
1119
1120
6.74k
  return true;
1121
7.42k
}
pei-x86_64.c:handle_COMDAT
Line
Count
Source
861
32.0k
{
862
32.0k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
32.0k
  bfd_byte *esymstart, *esym, *esymend;
864
32.0k
  int seen_state = 0;
865
32.0k
  char *target_name = NULL;
866
867
32.0k
  *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
32.0k
  if (! _bfd_coff_get_external_symbols (abfd))
887
10.9k
    return true;
888
889
21.0k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
21.0k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
21.0k
  for (struct internal_syment isym;
893
703k
       esym < esymend;
894
682k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
685k
    {
896
685k
      char buf[SYMNMLEN + 1];
897
685k
      const char *symname;
898
899
685k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
685k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
685k
      if (isym.n_scnum == section->target_index)
904
11.8k
  {
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
11.8k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
11.8k
    if (symname == NULL)
934
762
      {
935
762
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
762
          abfd);
937
762
        return false;
938
762
      }
939
940
11.0k
    switch (seen_state)
941
11.0k
      {
942
9.24k
      case 0:
943
9.24k
        {
944
    /* The first time we've seen the symbol.  */
945
9.24k
    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
9.24k
    if (! ((isym.n_sclass == C_STAT
964
9.24k
      || isym.n_sclass == C_EXT)
965
9.24k
           && BTYPE (isym.n_type) == T_NULL
966
9.24k
           && isym.n_value == 0))
967
1.23k
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
1.23k
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
1.23k
          abfd, symname);
972
1.23k
        return false;
973
1.23k
      }
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
8.00k
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
7.01k
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
7.01k
          " does not match section name '%s'"),
984
7.01k
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
8.00k
    seen_state = 1;
988
8.00k
    target_name = strchr (name, '$');
989
8.00k
    if (target_name != NULL)
990
849
      {
991
        /* Gas mode.  */
992
849
        seen_state = 2;
993
        /* Skip the `$'.  */
994
849
        target_name += 1;
995
849
      }
996
997
8.00k
    if (isym.n_numaux == 0)
998
497
      aux.x_scn.x_comdat = 0;
999
7.51k
    else
1000
7.51k
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
7.51k
        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
7.50k
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
7.50k
            isym.n_type, isym.n_sclass,
1012
7.50k
            0, isym.n_numaux, &aux);
1013
7.50k
      }
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
8.00k
    switch (aux.x_scn.x_comdat)
1032
8.00k
      {
1033
496
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
496
        *sec_flags &= ~SEC_LINK_ONCE;
1038
496
#endif
1039
496
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
1
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
1
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
1
        break;
1048
1049
0
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
0
        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
395
      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
395
        *sec_flags &= ~SEC_LINK_ONCE;
1067
395
#endif
1068
395
        break;
1069
1070
7.11k
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
7.11k
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
7.11k
        break;
1075
8.00k
      }
1076
8.00k
        }
1077
8.00k
        break;
1078
1079
8.00k
      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
645
        if (strcmp (target_name,
1087
645
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
543
    {
1089
      /* Not the name we're looking for */
1090
543
      continue;
1091
543
    }
1092
        /* Fall through.  */
1093
1.26k
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
1.26k
        {
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
1.26k
    struct coff_comdat_info *comdat;
1103
1.26k
    size_t len = strlen (symname) + 1;
1104
1105
1.26k
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
1.26k
    if (comdat == NULL)
1107
0
      return false;
1108
1109
1.26k
    coff_section_data (abfd, section)->comdat = comdat;
1110
1.26k
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
1.26k
    char *newname = (char *) (comdat + 1);
1112
1.26k
    comdat->name = newname;
1113
1.26k
    memcpy (newname, symname, len);
1114
1.26k
    return true;
1115
1.26k
        }
1116
11.0k
      }
1117
11.0k
  }
1118
685k
    }
1119
1120
17.8k
  return true;
1121
21.0k
}
pei-aarch64.c:handle_COMDAT
Line
Count
Source
861
5.19k
{
862
5.19k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
5.19k
  bfd_byte *esymstart, *esym, *esymend;
864
5.19k
  int seen_state = 0;
865
5.19k
  char *target_name = NULL;
866
867
5.19k
  *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
5.19k
  if (! _bfd_coff_get_external_symbols (abfd))
887
1.81k
    return true;
888
889
3.38k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
3.38k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
3.38k
  for (struct internal_syment isym;
893
14.6k
       esym < esymend;
894
11.2k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
11.7k
    {
896
11.7k
      char buf[SYMNMLEN + 1];
897
11.7k
      const char *symname;
898
899
11.7k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
11.7k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
11.7k
      if (isym.n_scnum == section->target_index)
904
982
  {
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
982
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
982
    if (symname == NULL)
934
104
      {
935
104
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
104
          abfd);
937
104
        return false;
938
104
      }
939
940
878
    switch (seen_state)
941
878
      {
942
872
      case 0:
943
872
        {
944
    /* The first time we've seen the symbol.  */
945
872
    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
872
    if (! ((isym.n_sclass == C_STAT
964
872
      || isym.n_sclass == C_EXT)
965
872
           && BTYPE (isym.n_type) == T_NULL
966
872
           && isym.n_value == 0))
967
311
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
311
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
311
          abfd, symname);
972
311
        return false;
973
311
      }
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
561
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
446
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
446
          " does not match section name '%s'"),
984
446
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
561
    seen_state = 1;
988
561
    target_name = strchr (name, '$');
989
561
    if (target_name != NULL)
990
0
      {
991
        /* Gas mode.  */
992
0
        seen_state = 2;
993
        /* Skip the `$'.  */
994
0
        target_name += 1;
995
0
      }
996
997
561
    if (isym.n_numaux == 0)
998
109
      aux.x_scn.x_comdat = 0;
999
452
    else
1000
452
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
452
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
0
          {
1004
      /* xgettext:c-format */
1005
0
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
0
                " section '%s' found"),
1007
0
              abfd, symname);
1008
0
      break;
1009
0
          }
1010
452
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
452
            isym.n_type, isym.n_sclass,
1012
452
            0, isym.n_numaux, &aux);
1013
452
      }
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
561
    switch (aux.x_scn.x_comdat)
1032
561
      {
1033
0
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
0
        *sec_flags &= ~SEC_LINK_ONCE;
1038
0
#endif
1039
0
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
0
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
0
        break;
1048
1049
0
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
0
        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
0
      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
0
        *sec_flags &= ~SEC_LINK_ONCE;
1067
0
#endif
1068
0
        break;
1069
1070
561
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
561
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
561
        break;
1075
561
      }
1076
561
        }
1077
561
        break;
1078
1079
561
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
0
#ifndef TARGET_UNDERSCORE
1083
0
#define TARGET_UNDERSCORE 0
1084
0
#endif
1085
        /* Is this the name we're looking for ?  */
1086
0
        if (strcmp (target_name,
1087
0
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
0
    {
1089
      /* Not the name we're looking for */
1090
0
      continue;
1091
0
    }
1092
        /* Fall through.  */
1093
6
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
6
        {
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
6
    struct coff_comdat_info *comdat;
1103
6
    size_t len = strlen (symname) + 1;
1104
1105
6
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
6
    if (comdat == NULL)
1107
0
      return false;
1108
1109
6
    coff_section_data (abfd, section)->comdat = comdat;
1110
6
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
6
    char *newname = (char *) (comdat + 1);
1112
6
    comdat->name = newname;
1113
6
    memcpy (newname, symname, len);
1114
6
    return true;
1115
6
        }
1116
878
      }
1117
878
  }
1118
11.7k
    }
1119
1120
2.96k
  return true;
1121
3.38k
}
pe-aarch64.c:handle_COMDAT
Line
Count
Source
861
3.42k
{
862
3.42k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
3.42k
  bfd_byte *esymstart, *esym, *esymend;
864
3.42k
  int seen_state = 0;
865
3.42k
  char *target_name = NULL;
866
867
3.42k
  *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.42k
  if (! _bfd_coff_get_external_symbols (abfd))
887
470
    return true;
888
889
2.95k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
2.95k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
2.95k
  for (struct internal_syment isym;
893
27.5k
       esym < esymend;
894
24.5k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
24.7k
    {
896
24.7k
      char buf[SYMNMLEN + 1];
897
24.7k
      const char *symname;
898
899
24.7k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
24.7k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
24.7k
      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
104
      {
935
104
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
104
          abfd);
937
104
        return false;
938
104
      }
939
940
594
    switch (seen_state)
941
594
      {
942
591
      case 0:
943
591
        {
944
    /* The first time we've seen the symbol.  */
945
591
    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
591
    if (! ((isym.n_sclass == C_STAT
964
591
      || isym.n_sclass == C_EXT)
965
591
           && BTYPE (isym.n_type) == T_NULL
966
591
           && isym.n_value == 0))
967
106
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
106
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
106
          abfd, symname);
972
106
        return false;
973
106
      }
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
485
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
5
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
5
          " does not match section name '%s'"),
984
5
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
485
    seen_state = 1;
988
485
    target_name = strchr (name, '$');
989
485
    if (target_name != NULL)
990
0
      {
991
        /* Gas mode.  */
992
0
        seen_state = 2;
993
        /* Skip the `$'.  */
994
0
        target_name += 1;
995
0
      }
996
997
485
    if (isym.n_numaux == 0)
998
3
      aux.x_scn.x_comdat = 0;
999
482
    else
1000
482
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
482
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
0
          {
1004
      /* xgettext:c-format */
1005
0
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
0
                " section '%s' found"),
1007
0
              abfd, symname);
1008
0
      break;
1009
0
          }
1010
482
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
482
            isym.n_type, isym.n_sclass,
1012
482
            0, isym.n_numaux, &aux);
1013
482
      }
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
485
    switch (aux.x_scn.x_comdat)
1032
485
      {
1033
2
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
2
        *sec_flags &= ~SEC_LINK_ONCE;
1038
2
#endif
1039
2
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
0
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
0
        break;
1048
1049
0
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
0
        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
0
      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
0
        *sec_flags &= ~SEC_LINK_ONCE;
1067
0
#endif
1068
0
        break;
1069
1070
483
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
483
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
483
        break;
1075
485
      }
1076
485
        }
1077
485
        break;
1078
1079
485
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
0
#ifndef TARGET_UNDERSCORE
1083
0
#define TARGET_UNDERSCORE 0
1084
0
#endif
1085
        /* Is this the name we're looking for ?  */
1086
0
        if (strcmp (target_name,
1087
0
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
0
    {
1089
      /* Not the name we're looking for */
1090
0
      continue;
1091
0
    }
1092
        /* Fall through.  */
1093
3
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
3
        {
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
3
    struct coff_comdat_info *comdat;
1103
3
    size_t len = strlen (symname) + 1;
1104
1105
3
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
3
    if (comdat == NULL)
1107
0
      return false;
1108
1109
3
    coff_section_data (abfd, section)->comdat = comdat;
1110
3
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
3
    char *newname = (char *) (comdat + 1);
1112
3
    comdat->name = newname;
1113
3
    memcpy (newname, symname, len);
1114
3
    return true;
1115
3
        }
1116
594
      }
1117
594
  }
1118
24.7k
    }
1119
1120
2.74k
  return true;
1121
2.95k
}
pei-ia64.c:handle_COMDAT
Line
Count
Source
861
20.9k
{
862
20.9k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
20.9k
  bfd_byte *esymstart, *esym, *esymend;
864
20.9k
  int seen_state = 0;
865
20.9k
  char *target_name = NULL;
866
867
20.9k
  *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
20.9k
  if (! _bfd_coff_get_external_symbols (abfd))
887
6.43k
    return true;
888
889
14.5k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
14.5k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
14.5k
  for (struct internal_syment isym;
893
895k
       esym < esymend;
894
880k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
883k
    {
896
883k
      char buf[SYMNMLEN + 1];
897
883k
      const char *symname;
898
899
883k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
883k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
883k
      if (isym.n_scnum == section->target_index)
904
6.35k
  {
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.35k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
6.35k
    if (symname == NULL)
934
471
      {
935
471
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
471
          abfd);
937
471
        return false;
938
471
      }
939
940
5.88k
    switch (seen_state)
941
5.88k
      {
942
5.14k
      case 0:
943
5.14k
        {
944
    /* The first time we've seen the symbol.  */
945
5.14k
    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
5.14k
    if (! ((isym.n_sclass == C_STAT
964
5.14k
      || isym.n_sclass == C_EXT)
965
5.14k
           && BTYPE (isym.n_type) == T_NULL
966
5.14k
           && isym.n_value == 0))
967
1.10k
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
1.10k
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
1.10k
          abfd, symname);
972
1.10k
        return false;
973
1.10k
      }
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
4.03k
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
3.46k
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
3.46k
          " does not match section name '%s'"),
984
3.46k
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
4.03k
    seen_state = 1;
988
4.03k
    target_name = strchr (name, '$');
989
4.03k
    if (target_name != NULL)
990
470
      {
991
        /* Gas mode.  */
992
470
        seen_state = 2;
993
        /* Skip the `$'.  */
994
470
        target_name += 1;
995
470
      }
996
997
4.03k
    if (isym.n_numaux == 0)
998
576
      aux.x_scn.x_comdat = 0;
999
3.46k
    else
1000
3.46k
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
3.46k
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
101
          {
1004
      /* xgettext:c-format */
1005
101
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
101
                " section '%s' found"),
1007
101
              abfd, symname);
1008
101
      break;
1009
101
          }
1010
3.36k
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
3.36k
            isym.n_type, isym.n_sclass,
1012
3.36k
            0, isym.n_numaux, &aux);
1013
3.36k
      }
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
3.93k
    switch (aux.x_scn.x_comdat)
1032
3.93k
      {
1033
2
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
2
        *sec_flags &= ~SEC_LINK_ONCE;
1038
2
#endif
1039
2
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
235
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
235
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
235
        break;
1048
1049
233
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
233
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
233
        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
234
      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
234
        *sec_flags &= ~SEC_LINK_ONCE;
1067
234
#endif
1068
234
        break;
1069
1070
3.23k
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
3.23k
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
3.23k
        break;
1075
3.93k
      }
1076
3.93k
        }
1077
3.93k
        break;
1078
1079
3.93k
      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
2
    {
1089
      /* Not the name we're looking for */
1090
2
      continue;
1091
2
    }
1092
        /* Fall through.  */
1093
736
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
736
        {
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
736
    struct coff_comdat_info *comdat;
1103
736
    size_t len = strlen (symname) + 1;
1104
1105
736
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
736
    if (comdat == NULL)
1107
0
      return false;
1108
1109
736
    coff_section_data (abfd, section)->comdat = comdat;
1110
736
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
736
    char *newname = (char *) (comdat + 1);
1112
736
    comdat->name = newname;
1113
736
    memcpy (newname, symname, len);
1114
736
    return true;
1115
736
        }
1116
5.88k
      }
1117
5.88k
  }
1118
883k
    }
1119
1120
12.1k
  return true;
1121
14.5k
}
pei-loongarch64.c:handle_COMDAT
Line
Count
Source
861
5.33k
{
862
5.33k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
5.33k
  bfd_byte *esymstart, *esym, *esymend;
864
5.33k
  int seen_state = 0;
865
5.33k
  char *target_name = NULL;
866
867
5.33k
  *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
5.33k
  if (! _bfd_coff_get_external_symbols (abfd))
887
2.88k
    return true;
888
889
2.45k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
2.45k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
2.45k
  for (struct internal_syment isym;
893
17.8k
       esym < esymend;
894
15.3k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
15.9k
    {
896
15.9k
      char buf[SYMNMLEN + 1];
897
15.9k
      const char *symname;
898
899
15.9k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
15.9k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
15.9k
      if (isym.n_scnum == section->target_index)
904
1.22k
  {
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
1.22k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
1.22k
    if (symname == NULL)
934
104
      {
935
104
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
104
          abfd);
937
104
        return false;
938
104
      }
939
940
1.12k
    switch (seen_state)
941
1.12k
      {
942
889
      case 0:
943
889
        {
944
    /* The first time we've seen the symbol.  */
945
889
    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
889
    if (! ((isym.n_sclass == C_STAT
964
889
      || isym.n_sclass == C_EXT)
965
889
           && BTYPE (isym.n_type) == T_NULL
966
889
           && isym.n_value == 0))
967
209
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
209
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
209
          abfd, symname);
972
209
        return false;
973
209
      }
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
680
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
5
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
5
          " does not match section name '%s'"),
984
5
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
680
    seen_state = 1;
988
680
    target_name = strchr (name, '$');
989
680
    if (target_name != NULL)
990
0
      {
991
        /* Gas mode.  */
992
0
        seen_state = 2;
993
        /* Skip the `$'.  */
994
0
        target_name += 1;
995
0
      }
996
997
680
    if (isym.n_numaux == 0)
998
1
      aux.x_scn.x_comdat = 0;
999
679
    else
1000
679
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
679
        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
678
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
678
            isym.n_type, isym.n_sclass,
1012
678
            0, isym.n_numaux, &aux);
1013
678
      }
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
679
    switch (aux.x_scn.x_comdat)
1032
679
      {
1033
1
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
1
        *sec_flags &= ~SEC_LINK_ONCE;
1038
1
#endif
1039
1
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
1
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
1
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
1
        break;
1048
1049
0
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
0
        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
234
      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
234
        *sec_flags &= ~SEC_LINK_ONCE;
1067
234
#endif
1068
234
        break;
1069
1070
443
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
443
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
443
        break;
1075
679
      }
1076
679
        }
1077
679
        break;
1078
1079
679
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
0
#ifndef TARGET_UNDERSCORE
1083
0
#define TARGET_UNDERSCORE 0
1084
0
#endif
1085
        /* Is this the name we're looking for ?  */
1086
0
        if (strcmp (target_name,
1087
0
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
0
    {
1089
      /* Not the name we're looking for */
1090
0
      continue;
1091
0
    }
1092
        /* Fall through.  */
1093
234
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
234
        {
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
234
    struct coff_comdat_info *comdat;
1103
234
    size_t len = strlen (symname) + 1;
1104
1105
234
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
234
    if (comdat == NULL)
1107
0
      return false;
1108
1109
234
    coff_section_data (abfd, section)->comdat = comdat;
1110
234
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
234
    char *newname = (char *) (comdat + 1);
1112
234
    comdat->name = newname;
1113
234
    memcpy (newname, symname, len);
1114
234
    return true;
1115
234
        }
1116
1.12k
      }
1117
1.12k
  }
1118
15.9k
    }
1119
1120
1.90k
  return true;
1121
2.45k
}
pe-arm-wince.c:handle_COMDAT
Line
Count
Source
861
4.41k
{
862
4.41k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
4.41k
  bfd_byte *esymstart, *esym, *esymend;
864
4.41k
  int seen_state = 0;
865
4.41k
  char *target_name = NULL;
866
867
4.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
4.41k
  if (! _bfd_coff_get_external_symbols (abfd))
887
741
    return true;
888
889
3.67k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
3.67k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
3.67k
  for (struct internal_syment isym;
893
622k
       esym < esymend;
894
618k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
620k
    {
896
620k
      char buf[SYMNMLEN + 1];
897
620k
      const char *symname;
898
899
620k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
620k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
620k
      if (isym.n_scnum == section->target_index)
904
2.79k
  {
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
2.79k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
2.79k
    if (symname == NULL)
934
107
      {
935
107
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
107
          abfd);
937
107
        return false;
938
107
      }
939
940
2.68k
    switch (seen_state)
941
2.68k
      {
942
1.65k
      case 0:
943
1.65k
        {
944
    /* The first time we've seen the symbol.  */
945
1.65k
    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
1.65k
    if (! ((isym.n_sclass == C_STAT
964
1.65k
      || isym.n_sclass == C_EXT)
965
1.65k
           && BTYPE (isym.n_type) == T_NULL
966
1.65k
           && isym.n_value == 0))
967
619
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
619
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
619
          abfd, symname);
972
619
        return false;
973
619
      }
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
1.03k
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
931
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
931
          " does not match section name '%s'"),
984
931
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
1.03k
    seen_state = 1;
988
1.03k
    target_name = strchr (name, '$');
989
1.03k
    if (target_name != NULL)
990
621
      {
991
        /* Gas mode.  */
992
621
        seen_state = 2;
993
        /* Skip the `$'.  */
994
621
        target_name += 1;
995
621
      }
996
997
1.03k
    if (isym.n_numaux == 0)
998
104
      aux.x_scn.x_comdat = 0;
999
930
    else
1000
930
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
930
        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
928
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
928
            isym.n_type, isym.n_sclass,
1012
928
            0, isym.n_numaux, &aux);
1013
928
      }
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
1.03k
    switch (aux.x_scn.x_comdat)
1032
1.03k
      {
1033
611
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
611
        *sec_flags &= ~SEC_LINK_ONCE;
1038
611
#endif
1039
611
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
0
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
0
        break;
1048
1049
0
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
0
        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
0
      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
0
        *sec_flags &= ~SEC_LINK_ONCE;
1067
0
#endif
1068
0
        break;
1069
1070
421
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
421
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
421
        break;
1075
1.03k
      }
1076
1.03k
        }
1077
1.03k
        break;
1078
1079
1.03k
      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
825
        if (strcmp (target_name,
1087
825
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
620
    {
1089
      /* Not the name we're looking for */
1090
620
      continue;
1091
620
    }
1092
        /* Fall through.  */
1093
410
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
410
        {
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
410
    struct coff_comdat_info *comdat;
1103
410
    size_t len = strlen (symname) + 1;
1104
1105
410
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
410
    if (comdat == NULL)
1107
0
      return false;
1108
1109
410
    coff_section_data (abfd, section)->comdat = comdat;
1110
410
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
410
    char *newname = (char *) (comdat + 1);
1112
410
    comdat->name = newname;
1113
410
    memcpy (newname, symname, len);
1114
410
    return true;
1115
410
        }
1116
2.68k
      }
1117
2.68k
  }
1118
620k
    }
1119
1120
2.53k
  return true;
1121
3.67k
}
pe-arm.c:handle_COMDAT
Line
Count
Source
861
4.41k
{
862
4.41k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
4.41k
  bfd_byte *esymstart, *esym, *esymend;
864
4.41k
  int seen_state = 0;
865
4.41k
  char *target_name = NULL;
866
867
4.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
4.41k
  if (! _bfd_coff_get_external_symbols (abfd))
887
741
    return true;
888
889
3.67k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
3.67k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
3.67k
  for (struct internal_syment isym;
893
617k
       esym < esymend;
894
613k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
615k
    {
896
615k
      char buf[SYMNMLEN + 1];
897
615k
      const char *symname;
898
899
615k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
615k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
615k
      if (isym.n_scnum == section->target_index)
904
2.89k
  {
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
2.89k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
2.89k
    if (symname == NULL)
934
107
      {
935
107
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
107
          abfd);
937
107
        return false;
938
107
      }
939
940
2.78k
    switch (seen_state)
941
2.78k
      {
942
1.75k
      case 0:
943
1.75k
        {
944
    /* The first time we've seen the symbol.  */
945
1.75k
    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
1.75k
    if (! ((isym.n_sclass == C_STAT
964
1.75k
      || isym.n_sclass == C_EXT)
965
1.75k
           && BTYPE (isym.n_type) == T_NULL
966
1.75k
           && isym.n_value == 0))
967
619
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
619
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
619
          abfd, symname);
972
619
        return false;
973
619
      }
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
1.13k
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
931
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
931
          " does not match section name '%s'"),
984
931
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
1.13k
    seen_state = 1;
988
1.13k
    target_name = strchr (name, '$');
989
1.13k
    if (target_name != NULL)
990
621
      {
991
        /* Gas mode.  */
992
621
        seen_state = 2;
993
        /* Skip the `$'.  */
994
621
        target_name += 1;
995
621
      }
996
997
1.13k
    if (isym.n_numaux == 0)
998
205
      aux.x_scn.x_comdat = 0;
999
930
    else
1000
930
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
930
        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
928
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
928
            isym.n_type, isym.n_sclass,
1012
928
            0, isym.n_numaux, &aux);
1013
928
      }
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
1.13k
    switch (aux.x_scn.x_comdat)
1032
1.13k
      {
1033
611
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
611
        *sec_flags &= ~SEC_LINK_ONCE;
1038
611
#endif
1039
611
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
0
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
0
        break;
1048
1049
0
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
0
        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
0
      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
0
        *sec_flags &= ~SEC_LINK_ONCE;
1067
0
#endif
1068
0
        break;
1069
1070
522
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
522
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
522
        break;
1075
1.13k
      }
1076
1.13k
        }
1077
1.13k
        break;
1078
1079
1.13k
      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
825
        if (strcmp (target_name,
1087
825
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
517
    {
1089
      /* Not the name we're looking for */
1090
517
      continue;
1091
517
    }
1092
        /* Fall through.  */
1093
513
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
513
        {
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
513
    struct coff_comdat_info *comdat;
1103
513
    size_t len = strlen (symname) + 1;
1104
1105
513
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
513
    if (comdat == NULL)
1107
0
      return false;
1108
1109
513
    coff_section_data (abfd, section)->comdat = comdat;
1110
513
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
513
    char *newname = (char *) (comdat + 1);
1112
513
    comdat->name = newname;
1113
513
    memcpy (newname, symname, len);
1114
513
    return true;
1115
513
        }
1116
2.78k
      }
1117
2.78k
  }
1118
615k
    }
1119
1120
2.43k
  return true;
1121
3.67k
}
pe-i386.c:handle_COMDAT
Line
Count
Source
861
19.2k
{
862
19.2k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
19.2k
  bfd_byte *esymstart, *esym, *esymend;
864
19.2k
  int seen_state = 0;
865
19.2k
  char *target_name = NULL;
866
867
19.2k
  *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
19.2k
  if (! _bfd_coff_get_external_symbols (abfd))
887
6.87k
    return true;
888
889
12.3k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
12.3k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
12.3k
  for (struct internal_syment isym;
893
273k
       esym < esymend;
894
260k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
262k
    {
896
262k
      char buf[SYMNMLEN + 1];
897
262k
      const char *symname;
898
899
262k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
262k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
262k
      if (isym.n_scnum == section->target_index)
904
4.94k
  {
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
4.94k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
4.94k
    if (symname == NULL)
934
618
      {
935
618
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
618
          abfd);
937
618
        return false;
938
618
      }
939
940
4.32k
    switch (seen_state)
941
4.32k
      {
942
3.40k
      case 0:
943
3.40k
        {
944
    /* The first time we've seen the symbol.  */
945
3.40k
    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.40k
    if (! ((isym.n_sclass == C_STAT
964
3.40k
      || isym.n_sclass == C_EXT)
965
3.40k
           && BTYPE (isym.n_type) == T_NULL
966
3.40k
           && isym.n_value == 0))
967
731
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
731
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
731
          abfd, symname);
972
731
        return false;
973
731
      }
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.67k
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
1.94k
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
1.94k
          " does not match section name '%s'"),
984
1.94k
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
2.67k
    seen_state = 1;
988
2.67k
    target_name = strchr (name, '$');
989
2.67k
    if (target_name != NULL)
990
723
      {
991
        /* Gas mode.  */
992
723
        seen_state = 2;
993
        /* Skip the `$'.  */
994
723
        target_name += 1;
995
723
      }
996
997
2.67k
    if (isym.n_numaux == 0)
998
207
      aux.x_scn.x_comdat = 0;
999
2.46k
    else
1000
2.46k
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
2.46k
        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
2.46k
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
2.46k
            isym.n_type, isym.n_sclass,
1012
2.46k
            0, isym.n_numaux, &aux);
1013
2.46k
      }
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.67k
    switch (aux.x_scn.x_comdat)
1032
2.67k
      {
1033
102
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
102
        *sec_flags &= ~SEC_LINK_ONCE;
1038
102
#endif
1039
102
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
107
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
107
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
107
        break;
1048
1049
104
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
104
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
104
        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
0
      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
0
        *sec_flags &= ~SEC_LINK_ONCE;
1067
0
#endif
1068
0
        break;
1069
1070
2.35k
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
2.35k
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
2.35k
        break;
1075
2.67k
      }
1076
2.67k
        }
1077
2.67k
        break;
1078
1079
2.67k
      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
411
        if (strcmp (target_name,
1087
411
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
306
    {
1089
      /* Not the name we're looking for */
1090
306
      continue;
1091
306
    }
1092
        /* Fall through.  */
1093
613
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
613
        {
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
613
    struct coff_comdat_info *comdat;
1103
613
    size_t len = strlen (symname) + 1;
1104
1105
613
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
613
    if (comdat == NULL)
1107
0
      return false;
1108
1109
613
    coff_section_data (abfd, section)->comdat = comdat;
1110
613
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
613
    char *newname = (char *) (comdat + 1);
1112
613
    comdat->name = newname;
1113
613
    memcpy (newname, symname, len);
1114
613
    return true;
1115
613
        }
1116
4.32k
      }
1117
4.32k
  }
1118
262k
    }
1119
1120
10.4k
  return true;
1121
12.3k
}
pe-mcore.c:handle_COMDAT
Line
Count
Source
861
8.04k
{
862
8.04k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
8.04k
  bfd_byte *esymstart, *esym, *esymend;
864
8.04k
  int seen_state = 0;
865
8.04k
  char *target_name = NULL;
866
867
8.04k
  *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
8.04k
  if (! _bfd_coff_get_external_symbols (abfd))
887
2.46k
    return true;
888
889
5.58k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
5.58k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
5.58k
  for (struct internal_syment isym;
893
3.01M
       esym < esymend;
894
3.01M
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
3.01M
    {
896
3.01M
      char buf[SYMNMLEN + 1];
897
3.01M
      const char *symname;
898
899
3.01M
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
3.01M
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
3.01M
      if (isym.n_scnum == section->target_index)
904
1.27k
  {
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
1.27k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
1.27k
    if (symname == NULL)
934
108
      {
935
108
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
108
          abfd);
937
108
        return false;
938
108
      }
939
940
1.16k
    switch (seen_state)
941
1.16k
      {
942
1.04k
      case 0:
943
1.04k
        {
944
    /* The first time we've seen the symbol.  */
945
1.04k
    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
1.04k
    if (! ((isym.n_sclass == C_STAT
964
1.04k
      || isym.n_sclass == C_EXT)
965
1.04k
           && BTYPE (isym.n_type) == T_NULL
966
1.04k
           && isym.n_value == 0))
967
111
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
111
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
111
          abfd, symname);
972
111
        return false;
973
111
      }
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
935
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
497
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
497
          " does not match section name '%s'"),
984
497
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
935
    seen_state = 1;
988
935
    target_name = strchr (name, '$');
989
935
    if (target_name != NULL)
990
485
      {
991
        /* Gas mode.  */
992
485
        seen_state = 2;
993
        /* Skip the `$'.  */
994
485
        target_name += 1;
995
485
      }
996
997
935
    if (isym.n_numaux == 0)
998
437
      aux.x_scn.x_comdat = 0;
999
498
    else
1000
498
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
498
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
234
          {
1004
      /* xgettext:c-format */
1005
234
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
234
                " section '%s' found"),
1007
234
              abfd, symname);
1008
234
      break;
1009
234
          }
1010
264
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
264
            isym.n_type, isym.n_sclass,
1012
264
            0, isym.n_numaux, &aux);
1013
264
      }
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
701
    switch (aux.x_scn.x_comdat)
1032
701
      {
1033
1
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
1
        *sec_flags &= ~SEC_LINK_ONCE;
1038
1
#endif
1039
1
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
2
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
2
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
2
        break;
1048
1049
1
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
1
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
1
        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
0
      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
0
        *sec_flags &= ~SEC_LINK_ONCE;
1067
0
#endif
1068
0
        break;
1069
1070
697
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
697
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
697
        break;
1075
701
      }
1076
701
        }
1077
701
        break;
1078
1079
701
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
16
#ifndef TARGET_UNDERSCORE
1083
16
#define TARGET_UNDERSCORE 0
1084
16
#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
11
    {
1089
      /* Not the name we're looking for */
1090
11
      continue;
1091
11
    }
1092
        /* Fall through.  */
1093
112
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
112
        {
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
112
    struct coff_comdat_info *comdat;
1103
112
    size_t len = strlen (symname) + 1;
1104
1105
112
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
112
    if (comdat == NULL)
1107
0
      return false;
1108
1109
112
    coff_section_data (abfd, section)->comdat = comdat;
1110
112
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
112
    char *newname = (char *) (comdat + 1);
1112
112
    comdat->name = newname;
1113
112
    memcpy (newname, symname, len);
1114
112
    return true;
1115
112
        }
1116
1.16k
      }
1117
1.16k
  }
1118
3.01M
    }
1119
1120
5.25k
  return true;
1121
5.58k
}
pe-sh.c:handle_COMDAT
Line
Count
Source
861
9.10k
{
862
9.10k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
9.10k
  bfd_byte *esymstart, *esym, *esymend;
864
9.10k
  int seen_state = 0;
865
9.10k
  char *target_name = NULL;
866
867
9.10k
  *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
9.10k
  if (! _bfd_coff_get_external_symbols (abfd))
887
1.90k
    return true;
888
889
7.20k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
7.20k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
7.20k
  for (struct internal_syment isym;
893
2.24M
       esym < esymend;
894
2.23M
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
2.23M
    {
896
2.23M
      char buf[SYMNMLEN + 1];
897
2.23M
      const char *symname;
898
899
2.23M
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
2.23M
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
2.23M
      if (isym.n_scnum == section->target_index)
904
2.20k
  {
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
2.20k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
2.20k
    if (symname == NULL)
934
409
      {
935
409
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
409
          abfd);
937
409
        return false;
938
409
      }
939
940
1.79k
    switch (seen_state)
941
1.79k
      {
942
1.67k
      case 0:
943
1.67k
        {
944
    /* The first time we've seen the symbol.  */
945
1.67k
    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
1.67k
    if (! ((isym.n_sclass == C_STAT
964
1.67k
      || isym.n_sclass == C_EXT)
965
1.67k
           && BTYPE (isym.n_type) == T_NULL
966
1.67k
           && isym.n_value == 0))
967
522
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
522
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
522
          abfd, symname);
972
522
        return false;
973
522
      }
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
1.15k
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
838
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
838
          " does not match section name '%s'"),
984
838
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
1.15k
    seen_state = 1;
988
1.15k
    target_name = strchr (name, '$');
989
1.15k
    if (target_name != NULL)
990
14
      {
991
        /* Gas mode.  */
992
14
        seen_state = 2;
993
        /* Skip the `$'.  */
994
14
        target_name += 1;
995
14
      }
996
997
1.15k
    if (isym.n_numaux == 0)
998
109
      aux.x_scn.x_comdat = 0;
999
1.04k
    else
1000
1.04k
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
1.04k
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
0
          {
1004
      /* xgettext:c-format */
1005
0
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
0
                " section '%s' found"),
1007
0
              abfd, symname);
1008
0
      break;
1009
0
          }
1010
1.04k
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
1.04k
            isym.n_type, isym.n_sclass,
1012
1.04k
            0, isym.n_numaux, &aux);
1013
1.04k
      }
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
1.15k
    switch (aux.x_scn.x_comdat)
1032
1.15k
      {
1033
103
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
103
        *sec_flags &= ~SEC_LINK_ONCE;
1038
103
#endif
1039
103
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
106
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
106
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
106
        break;
1048
1049
203
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
203
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
203
        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
0
      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
0
        *sec_flags &= ~SEC_LINK_ONCE;
1067
0
#endif
1068
0
        break;
1069
1070
738
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
738
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
738
        break;
1075
1.15k
      }
1076
1.15k
        }
1077
1.15k
        break;
1078
1079
1.15k
      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
13
        if (strcmp (target_name,
1087
13
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
7
    {
1089
      /* Not the name we're looking for */
1090
7
      continue;
1091
7
    }
1092
        /* Fall through.  */
1093
112
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
112
        {
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
112
    struct coff_comdat_info *comdat;
1103
112
    size_t len = strlen (symname) + 1;
1104
1105
112
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
112
    if (comdat == NULL)
1107
0
      return false;
1108
1109
112
    coff_section_data (abfd, section)->comdat = comdat;
1110
112
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
112
    char *newname = (char *) (comdat + 1);
1112
112
    comdat->name = newname;
1113
112
    memcpy (newname, symname, len);
1114
112
    return true;
1115
112
        }
1116
1.79k
      }
1117
1.79k
  }
1118
2.23M
    }
1119
1120
6.16k
  return true;
1121
7.20k
}
pei-arm-wince.c:handle_COMDAT
Line
Count
Source
861
13.6k
{
862
13.6k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
13.6k
  bfd_byte *esymstart, *esym, *esymend;
864
13.6k
  int seen_state = 0;
865
13.6k
  char *target_name = NULL;
866
867
13.6k
  *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
13.6k
  if (! _bfd_coff_get_external_symbols (abfd))
887
6.04k
    return true;
888
889
7.56k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
7.56k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
7.56k
  for (struct internal_syment isym;
893
22.2k
       esym < esymend;
894
14.7k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
15.8k
    {
896
15.8k
      char buf[SYMNMLEN + 1];
897
15.8k
      const char *symname;
898
899
15.8k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
15.8k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
15.8k
      if (isym.n_scnum == section->target_index)
904
2.13k
  {
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
2.13k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
2.13k
    if (symname == NULL)
934
236
      {
935
236
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
236
          abfd);
937
236
        return false;
938
236
      }
939
940
1.89k
    switch (seen_state)
941
1.89k
      {
942
1.42k
      case 0:
943
1.42k
        {
944
    /* The first time we've seen the symbol.  */
945
1.42k
    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
1.42k
    if (! ((isym.n_sclass == C_STAT
964
1.42k
      || isym.n_sclass == C_EXT)
965
1.42k
           && BTYPE (isym.n_type) == T_NULL
966
1.42k
           && isym.n_value == 0))
967
711
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
711
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
711
          abfd, symname);
972
711
        return false;
973
711
      }
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
716
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
477
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
477
          " does not match section name '%s'"),
984
477
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
716
    seen_state = 1;
988
716
    target_name = strchr (name, '$');
989
716
    if (target_name != NULL)
990
235
      {
991
        /* Gas mode.  */
992
235
        seen_state = 2;
993
        /* Skip the `$'.  */
994
235
        target_name += 1;
995
235
      }
996
997
716
    if (isym.n_numaux == 0)
998
475
      aux.x_scn.x_comdat = 0;
999
241
    else
1000
241
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
241
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
0
          {
1004
      /* xgettext:c-format */
1005
0
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
0
                " section '%s' found"),
1007
0
              abfd, symname);
1008
0
      break;
1009
0
          }
1010
241
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
241
            isym.n_type, isym.n_sclass,
1012
241
            0, isym.n_numaux, &aux);
1013
241
      }
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
716
    switch (aux.x_scn.x_comdat)
1032
716
      {
1033
0
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
0
        *sec_flags &= ~SEC_LINK_ONCE;
1038
0
#endif
1039
0
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
0
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
0
        break;
1048
1049
0
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
0
        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
0
      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
0
        *sec_flags &= ~SEC_LINK_ONCE;
1067
0
#endif
1068
0
        break;
1069
1070
716
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
716
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
716
        break;
1075
716
      }
1076
716
        }
1077
716
        break;
1078
1079
716
      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
235
        if (strcmp (target_name,
1087
235
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
235
    {
1089
      /* Not the name we're looking for */
1090
235
      continue;
1091
235
    }
1092
        /* Fall through.  */
1093
234
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
234
        {
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
234
    struct coff_comdat_info *comdat;
1103
234
    size_t len = strlen (symname) + 1;
1104
1105
234
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
234
    if (comdat == NULL)
1107
0
      return false;
1108
1109
234
    coff_section_data (abfd, section)->comdat = comdat;
1110
234
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
234
    char *newname = (char *) (comdat + 1);
1112
234
    comdat->name = newname;
1113
234
    memcpy (newname, symname, len);
1114
234
    return true;
1115
234
        }
1116
1.89k
      }
1117
1.89k
  }
1118
15.8k
    }
1119
1120
6.38k
  return true;
1121
7.56k
}
pei-arm.c:handle_COMDAT
Line
Count
Source
861
14.8k
{
862
14.8k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
14.8k
  bfd_byte *esymstart, *esym, *esymend;
864
14.8k
  int seen_state = 0;
865
14.8k
  char *target_name = NULL;
866
867
14.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
14.8k
  if (! _bfd_coff_get_external_symbols (abfd))
887
6.68k
    return true;
888
889
8.16k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
8.16k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
8.16k
  for (struct internal_syment isym;
893
23.8k
       esym < esymend;
894
15.7k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
17.2k
    {
896
17.2k
      char buf[SYMNMLEN + 1];
897
17.2k
      const char *symname;
898
899
17.2k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
17.2k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
17.2k
      if (isym.n_scnum == section->target_index)
904
2.60k
  {
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
2.60k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
2.60k
    if (symname == NULL)
934
369
      {
935
369
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
369
          abfd);
937
369
        return false;
938
369
      }
939
940
2.23k
    switch (seen_state)
941
2.23k
      {
942
1.76k
      case 0:
943
1.76k
        {
944
    /* The first time we've seen the symbol.  */
945
1.76k
    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
1.76k
    if (! ((isym.n_sclass == C_STAT
964
1.76k
      || isym.n_sclass == C_EXT)
965
1.76k
           && BTYPE (isym.n_type) == T_NULL
966
1.76k
           && isym.n_value == 0))
967
943
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
943
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
943
          abfd, symname);
972
943
        return false;
973
943
      }
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
819
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
580
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
580
          " does not match section name '%s'"),
984
580
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
819
    seen_state = 1;
988
819
    target_name = strchr (name, '$');
989
819
    if (target_name != NULL)
990
235
      {
991
        /* Gas mode.  */
992
235
        seen_state = 2;
993
        /* Skip the `$'.  */
994
235
        target_name += 1;
995
235
      }
996
997
819
    if (isym.n_numaux == 0)
998
477
      aux.x_scn.x_comdat = 0;
999
342
    else
1000
342
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
342
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
101
          {
1004
      /* xgettext:c-format */
1005
101
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
101
                " section '%s' found"),
1007
101
              abfd, symname);
1008
101
      break;
1009
101
          }
1010
241
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
241
            isym.n_type, isym.n_sclass,
1012
241
            0, isym.n_numaux, &aux);
1013
241
      }
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
718
    switch (aux.x_scn.x_comdat)
1032
718
      {
1033
0
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
0
        *sec_flags &= ~SEC_LINK_ONCE;
1038
0
#endif
1039
0
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
0
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
0
        break;
1048
1049
0
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
0
        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
0
      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
0
        *sec_flags &= ~SEC_LINK_ONCE;
1067
0
#endif
1068
0
        break;
1069
1070
718
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
718
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
718
        break;
1075
718
      }
1076
718
        }
1077
718
        break;
1078
1079
718
      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
235
        if (strcmp (target_name,
1087
235
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
234
    {
1089
      /* Not the name we're looking for */
1090
234
      continue;
1091
234
    }
1092
        /* Fall through.  */
1093
237
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
237
        {
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
237
    struct coff_comdat_info *comdat;
1103
237
    size_t len = strlen (symname) + 1;
1104
1105
237
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
237
    if (comdat == NULL)
1107
0
      return false;
1108
1109
237
    coff_section_data (abfd, section)->comdat = comdat;
1110
237
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
237
    char *newname = (char *) (comdat + 1);
1112
237
    comdat->name = newname;
1113
237
    memcpy (newname, symname, len);
1114
237
    return true;
1115
237
        }
1116
2.23k
      }
1117
2.23k
  }
1118
17.2k
    }
1119
1120
6.61k
  return true;
1121
8.16k
}
pei-mcore.c:handle_COMDAT
Line
Count
Source
861
9.37k
{
862
9.37k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
9.37k
  bfd_byte *esymstart, *esym, *esymend;
864
9.37k
  int seen_state = 0;
865
9.37k
  char *target_name = NULL;
866
867
9.37k
  *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
9.37k
  if (! _bfd_coff_get_external_symbols (abfd))
887
2.07k
    return true;
888
889
7.29k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
7.29k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
7.29k
  for (struct internal_syment isym;
893
23.3k
       esym < esymend;
894
16.0k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
16.9k
    {
896
16.9k
      char buf[SYMNMLEN + 1];
897
16.9k
      const char *symname;
898
899
16.9k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
16.9k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
16.9k
      if (isym.n_scnum == section->target_index)
904
3.11k
  {
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
3.11k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
3.11k
    if (symname == NULL)
934
0
      {
935
0
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
0
          abfd);
937
0
        return false;
938
0
      }
939
940
3.11k
    switch (seen_state)
941
3.11k
      {
942
2.74k
      case 0:
943
2.74k
        {
944
    /* The first time we've seen the symbol.  */
945
2.74k
    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
2.74k
    if (! ((isym.n_sclass == C_STAT
964
2.74k
      || isym.n_sclass == C_EXT)
965
2.74k
           && BTYPE (isym.n_type) == T_NULL
966
2.74k
           && isym.n_value == 0))
967
811
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
811
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
811
          abfd, symname);
972
811
        return false;
973
811
      }
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
1.93k
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
1.46k
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
1.46k
          " does not match section name '%s'"),
984
1.46k
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
1.93k
    seen_state = 1;
988
1.93k
    target_name = strchr (name, '$');
989
1.93k
    if (target_name != NULL)
990
235
      {
991
        /* Gas mode.  */
992
235
        seen_state = 2;
993
        /* Skip the `$'.  */
994
235
        target_name += 1;
995
235
      }
996
997
1.93k
    if (isym.n_numaux == 0)
998
238
      aux.x_scn.x_comdat = 0;
999
1.69k
    else
1000
1.69k
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
1.69k
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
0
          {
1004
      /* xgettext:c-format */
1005
0
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
0
                " section '%s' found"),
1007
0
              abfd, symname);
1008
0
      break;
1009
0
          }
1010
1.69k
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
1.69k
            isym.n_type, isym.n_sclass,
1012
1.69k
            0, isym.n_numaux, &aux);
1013
1.69k
      }
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
1.93k
    switch (aux.x_scn.x_comdat)
1032
1.93k
      {
1033
1.05k
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
1.05k
        *sec_flags &= ~SEC_LINK_ONCE;
1038
1.05k
#endif
1039
1.05k
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
0
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
0
        break;
1048
1049
0
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
0
        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
0
      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
0
        *sec_flags &= ~SEC_LINK_ONCE;
1067
0
#endif
1068
0
        break;
1069
1070
878
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
878
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
878
        break;
1075
1.93k
      }
1076
1.93k
        }
1077
1.93k
        break;
1078
1079
1.93k
      case 2:
1080
        /* Gas mode: the first matching on partial name.  */
1081
1082
234
#ifndef TARGET_UNDERSCORE
1083
234
#define TARGET_UNDERSCORE 0
1084
234
#endif
1085
        /* Is this the name we're looking for ?  */
1086
234
        if (strcmp (target_name,
1087
234
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
234
    {
1089
      /* Not the name we're looking for */
1090
234
      continue;
1091
234
    }
1092
        /* Fall through.  */
1093
135
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
135
        {
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
135
    struct coff_comdat_info *comdat;
1103
135
    size_t len = strlen (symname) + 1;
1104
1105
135
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
135
    if (comdat == NULL)
1107
0
      return false;
1108
1109
135
    coff_section_data (abfd, section)->comdat = comdat;
1110
135
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
135
    char *newname = (char *) (comdat + 1);
1112
135
    comdat->name = newname;
1113
135
    memcpy (newname, symname, len);
1114
135
    return true;
1115
135
        }
1116
3.11k
      }
1117
3.11k
  }
1118
16.9k
    }
1119
1120
6.35k
  return true;
1121
7.29k
}
pei-sh.c:handle_COMDAT
Line
Count
Source
861
11.3k
{
862
11.3k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
863
11.3k
  bfd_byte *esymstart, *esym, *esymend;
864
11.3k
  int seen_state = 0;
865
11.3k
  char *target_name = NULL;
866
867
11.3k
  *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
11.3k
  if (! _bfd_coff_get_external_symbols (abfd))
887
1.61k
    return true;
888
889
9.73k
  esymstart = esym = (bfd_byte *) obj_coff_external_syms (abfd);
890
9.73k
  esymend = esym + obj_raw_syment_count (abfd) * bfd_coff_symesz (abfd);
891
892
9.73k
  for (struct internal_syment isym;
893
232k
       esym < esymend;
894
222k
       esym += (isym.n_numaux + 1) * bfd_coff_symesz (abfd))
895
224k
    {
896
224k
      char buf[SYMNMLEN + 1];
897
224k
      const char *symname;
898
899
224k
      bfd_coff_swap_sym_in (abfd, esym, &isym);
900
901
224k
      BFD_ASSERT (sizeof (internal_s->s_name) <= SYMNMLEN);
902
903
224k
      if (isym.n_scnum == section->target_index)
904
4.11k
  {
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
4.11k
    symname = _bfd_coff_internal_syment_name (abfd, &isym, buf);
931
932
    /* PR 17512 file: 078-11867-0.004  */
933
4.11k
    if (symname == NULL)
934
502
      {
935
502
        _bfd_error_handler (_("%pB: unable to load COMDAT section name"),
936
502
          abfd);
937
502
        return false;
938
502
      }
939
940
3.60k
    switch (seen_state)
941
3.60k
      {
942
2.97k
      case 0:
943
2.97k
        {
944
    /* The first time we've seen the symbol.  */
945
2.97k
    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
2.97k
    if (! ((isym.n_sclass == C_STAT
964
2.97k
      || isym.n_sclass == C_EXT)
965
2.97k
           && BTYPE (isym.n_type) == T_NULL
966
2.97k
           && isym.n_value == 0))
967
708
      {
968
        /* Malformed input files can trigger this test.
969
           cf PR 21781.  */
970
708
        _bfd_error_handler (_("%pB: error: unexpected symbol '%s' in COMDAT section"),
971
708
          abfd, symname);
972
708
        return false;
973
708
      }
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.26k
    if (isym.n_sclass == C_STAT && strcmp (name, symname) != 0)
981
      /* xgettext:c-format */
982
1.03k
      _bfd_error_handler (_("%pB: warning: COMDAT symbol '%s'"
983
1.03k
          " does not match section name '%s'"),
984
1.03k
              abfd, symname, name);
985
986
    /* This is the section symbol.  */
987
2.26k
    seen_state = 1;
988
2.26k
    target_name = strchr (name, '$');
989
2.26k
    if (target_name != NULL)
990
469
      {
991
        /* Gas mode.  */
992
469
        seen_state = 2;
993
        /* Skip the `$'.  */
994
469
        target_name += 1;
995
469
      }
996
997
2.26k
    if (isym.n_numaux == 0)
998
865
      aux.x_scn.x_comdat = 0;
999
1.40k
    else
1000
1.40k
      {
1001
        /* PR 17512: file: e2cfe54f.  */
1002
1.40k
        if (esym + bfd_coff_symesz (abfd) >= esymend)
1003
101
          {
1004
      /* xgettext:c-format */
1005
101
      _bfd_error_handler (_("%pB: warning: no symbol for"
1006
101
                " section '%s' found"),
1007
101
              abfd, symname);
1008
101
      break;
1009
101
          }
1010
1.30k
        bfd_coff_swap_aux_in (abfd, esym + bfd_coff_symesz (abfd),
1011
1.30k
            isym.n_type, isym.n_sclass,
1012
1.30k
            0, isym.n_numaux, &aux);
1013
1.30k
      }
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.16k
    switch (aux.x_scn.x_comdat)
1032
2.16k
      {
1033
0
      case IMAGE_COMDAT_SELECT_NODUPLICATES:
1034
#ifdef STRICT_PE_FORMAT
1035
        *sec_flags |= SEC_LINK_DUPLICATES_ONE_ONLY;
1036
#else
1037
0
        *sec_flags &= ~SEC_LINK_ONCE;
1038
0
#endif
1039
0
        break;
1040
1041
0
      case IMAGE_COMDAT_SELECT_ANY:
1042
0
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1043
0
        break;
1044
1045
0
      case IMAGE_COMDAT_SELECT_SAME_SIZE:
1046
0
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_SIZE;
1047
0
        break;
1048
1049
133
      case IMAGE_COMDAT_SELECT_EXACT_MATCH:
1050
        /* Not yet fully implemented ??? */
1051
133
        *sec_flags |= SEC_LINK_DUPLICATES_SAME_CONTENTS;
1052
133
        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
0
      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
0
        *sec_flags &= ~SEC_LINK_ONCE;
1067
0
#endif
1068
0
        break;
1069
1070
2.03k
      default:  /* 0 means "no symbol" */
1071
        /* debug$F gets this case; other
1072
           implications ??? */
1073
2.03k
        *sec_flags |= SEC_LINK_DUPLICATES_DISCARD;
1074
2.03k
        break;
1075
2.16k
      }
1076
2.16k
        }
1077
2.16k
        break;
1078
1079
2.16k
      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
234
        if (strcmp (target_name,
1087
234
        symname + (TARGET_UNDERSCORE ? 1 : 0)) != 0)
1088
234
    {
1089
      /* Not the name we're looking for */
1090
234
      continue;
1091
234
    }
1092
        /* Fall through.  */
1093
399
      case 1:
1094
        /* MSVC mode: the lexically second symbol (or
1095
     drop through from the above).  */
1096
399
        {
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
399
    struct coff_comdat_info *comdat;
1103
399
    size_t len = strlen (symname) + 1;
1104
1105
399
    comdat = bfd_alloc (abfd, sizeof (*comdat) + len);
1106
399
    if (comdat == NULL)
1107
0
      return false;
1108
1109
399
    coff_section_data (abfd, section)->comdat = comdat;
1110
399
    comdat->symbol = (esym - esymstart) / bfd_coff_symesz (abfd);
1111
399
    char *newname = (char *) (comdat + 1);
1112
399
    comdat->name = newname;
1113
399
    memcpy (newname, symname, len);
1114
399
    return true;
1115
399
        }
1116
3.60k
      }
1117
3.60k
  }
1118
224k
    }
1119
1120
8.12k
  return true;
1121
9.73k
}
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
1.14M
{
1140
1.14M
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
1.14M
  unsigned long styp_flags = internal_s->s_flags;
1142
1.14M
  flagword sec_flags;
1143
1.14M
  bool result = true;
1144
1.14M
  bool is_dbg = false;
1145
1146
1.14M
  if (startswith (name, DOT_DEBUG)
1147
1.14M
      || startswith (name, DOT_ZDEBUG)
1148
1.14M
#ifdef COFF_LONG_SECTION_NAMES
1149
1.14M
      || startswith (name, GNU_LINKONCE_WI)
1150
1.14M
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
1.14M
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
1.14M
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
1.14M
      || startswith (name, GNU_DEBUGLINK)
1155
1.14M
      || startswith (name, GNU_DEBUGALTLINK)
1156
1.14M
#endif
1157
1.14M
      || startswith (name, ".stab"))
1158
57.8k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
1.14M
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
1.14M
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
951k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
5.74M
  while (styp_flags)
1168
4.60M
    {
1169
4.60M
      unsigned long flag = styp_flags & - styp_flags;
1170
4.60M
      char * unhandled = NULL;
1171
1172
4.60M
      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
4.60M
      switch (flag)
1179
4.60M
  {
1180
55.6k
  case STYP_DSECT:
1181
55.6k
    unhandled = "STYP_DSECT";
1182
55.6k
    break;
1183
63.6k
  case STYP_GROUP:
1184
63.6k
    unhandled = "STYP_GROUP";
1185
63.6k
    break;
1186
64.9k
  case STYP_COPY:
1187
64.9k
    unhandled = "STYP_COPY";
1188
64.9k
    break;
1189
66.4k
  case STYP_OVER:
1190
66.4k
    unhandled = "STYP_OVER";
1191
66.4k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
133k
  case STYP_NOLOAD:
1194
133k
    sec_flags |= SEC_NEVER_LOAD;
1195
133k
    break;
1196
0
#endif
1197
190k
  case IMAGE_SCN_MEM_READ:
1198
190k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
190k
    break;
1200
136k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
136k
    break;
1203
60.5k
  case IMAGE_SCN_LNK_OTHER:
1204
60.5k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
60.5k
    break;
1206
62.5k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
62.5k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
62.5k
    break;
1209
195k
  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
195k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
195k
        " %s in section %s"),
1216
195k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
195k
    break;
1218
192k
  case IMAGE_SCN_MEM_EXECUTE:
1219
192k
    sec_flags |= SEC_CODE;
1220
192k
    break;
1221
134k
  case IMAGE_SCN_MEM_WRITE:
1222
134k
    sec_flags &= ~ SEC_READONLY;
1223
134k
    break;
1224
213k
  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
213k
       if (is_dbg
1231
213k
#ifdef _COMMENT
1232
213k
        || strcmp (name, _COMMENT) == 0
1233
213k
#endif
1234
213k
        )
1235
32.4k
      {
1236
32.4k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
32.4k
      }
1238
213k
    break;
1239
131k
  case IMAGE_SCN_MEM_SHARED:
1240
131k
    sec_flags |= SEC_COFF_SHARED;
1241
131k
    break;
1242
205k
  case IMAGE_SCN_LNK_REMOVE:
1243
205k
    if (!is_dbg)
1244
176k
      sec_flags |= SEC_EXCLUDE;
1245
205k
    break;
1246
196k
  case IMAGE_SCN_CNT_CODE:
1247
196k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
196k
    break;
1249
125k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
125k
    if (is_dbg)
1251
14.1k
      sec_flags |= SEC_DEBUGGING;
1252
110k
    else
1253
110k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
125k
    break;
1255
127k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
127k
    sec_flags |= SEC_ALLOC;
1257
127k
    break;
1258
198k
  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
188k
    sec_flags |= SEC_DEBUGGING;
1267
#endif
1268
198k
    break;
1269
184k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
184k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
14.5k
      result = false;
1273
184k
    break;
1274
1.86M
  default:
1275
    /* Silently ignore for now.  */
1276
1.86M
    break;
1277
4.60M
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
4.60M
      if (unhandled != NULL)
1281
373k
  {
1282
373k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
373k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
373k
       abfd, name, unhandled, flag);
1286
373k
    result = false;
1287
373k
  }
1288
4.60M
    }
1289
1290
1.14M
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
1.14M
      && (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
227k
  if (startswith (name, ".gnu.linkonce"))
1303
0
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
#endif
1305
1306
1.14M
  if (flags_ptr)
1307
1.14M
    * flags_ptr = sec_flags;
1308
1309
1.14M
  return result;
1310
1.14M
}
pei-i386.c:styp_to_sec_flags
Line
Count
Source
1139
37.4k
{
1140
37.4k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
37.4k
  unsigned long styp_flags = internal_s->s_flags;
1142
37.4k
  flagword sec_flags;
1143
37.4k
  bool result = true;
1144
37.4k
  bool is_dbg = false;
1145
1146
37.4k
  if (startswith (name, DOT_DEBUG)
1147
37.4k
      || startswith (name, DOT_ZDEBUG)
1148
37.4k
#ifdef COFF_LONG_SECTION_NAMES
1149
37.4k
      || startswith (name, GNU_LINKONCE_WI)
1150
37.4k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
37.4k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
37.4k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
37.4k
      || startswith (name, GNU_DEBUGLINK)
1155
37.4k
      || startswith (name, GNU_DEBUGALTLINK)
1156
37.4k
#endif
1157
37.4k
      || startswith (name, ".stab"))
1158
2.03k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
37.4k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
37.4k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
25.7k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
352k
  while (styp_flags)
1168
314k
    {
1169
314k
      unsigned long flag = styp_flags & - styp_flags;
1170
314k
      char * unhandled = NULL;
1171
1172
314k
      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
314k
      switch (flag)
1179
314k
  {
1180
3.42k
  case STYP_DSECT:
1181
3.42k
    unhandled = "STYP_DSECT";
1182
3.42k
    break;
1183
3.55k
  case STYP_GROUP:
1184
3.55k
    unhandled = "STYP_GROUP";
1185
3.55k
    break;
1186
4.17k
  case STYP_COPY:
1187
4.17k
    unhandled = "STYP_COPY";
1188
4.17k
    break;
1189
3.84k
  case STYP_OVER:
1190
3.84k
    unhandled = "STYP_OVER";
1191
3.84k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
12.0k
  case STYP_NOLOAD:
1194
12.0k
    sec_flags |= SEC_NEVER_LOAD;
1195
12.0k
    break;
1196
0
#endif
1197
11.7k
  case IMAGE_SCN_MEM_READ:
1198
11.7k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
11.7k
    break;
1200
10.3k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
10.3k
    break;
1203
2.74k
  case IMAGE_SCN_LNK_OTHER:
1204
2.74k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
2.74k
    break;
1206
2.93k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
2.93k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
2.93k
    break;
1209
12.1k
  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
12.1k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
12.1k
        " %s in section %s"),
1216
12.1k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
12.1k
    break;
1218
18.0k
  case IMAGE_SCN_MEM_EXECUTE:
1219
18.0k
    sec_flags |= SEC_CODE;
1220
18.0k
    break;
1221
9.49k
  case IMAGE_SCN_MEM_WRITE:
1222
9.49k
    sec_flags &= ~ SEC_READONLY;
1223
9.49k
    break;
1224
13.0k
  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
13.0k
       if (is_dbg
1231
13.0k
#ifdef _COMMENT
1232
13.0k
        || strcmp (name, _COMMENT) == 0
1233
13.0k
#endif
1234
13.0k
        )
1235
1.26k
      {
1236
1.26k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
1.26k
      }
1238
13.0k
    break;
1239
4.89k
  case IMAGE_SCN_MEM_SHARED:
1240
4.89k
    sec_flags |= SEC_COFF_SHARED;
1241
4.89k
    break;
1242
12.0k
  case IMAGE_SCN_LNK_REMOVE:
1243
12.0k
    if (!is_dbg)
1244
11.6k
      sec_flags |= SEC_EXCLUDE;
1245
12.0k
    break;
1246
16.3k
  case IMAGE_SCN_CNT_CODE:
1247
16.3k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
16.3k
    break;
1249
10.1k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
10.1k
    if (is_dbg)
1251
705
      sec_flags |= SEC_DEBUGGING;
1252
9.44k
    else
1253
9.44k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
10.1k
    break;
1255
10.3k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
10.3k
    sec_flags |= SEC_ALLOC;
1257
10.3k
    break;
1258
13.0k
  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
13.0k
#ifdef COFF_PAGE_SIZE
1266
13.0k
    sec_flags |= SEC_DEBUGGING;
1267
13.0k
#endif
1268
13.0k
    break;
1269
9.42k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
9.42k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
1.18k
      result = false;
1273
9.42k
    break;
1274
130k
  default:
1275
    /* Silently ignore for now.  */
1276
130k
    break;
1277
314k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
314k
      if (unhandled != NULL)
1281
20.6k
  {
1282
20.6k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
20.6k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
20.6k
       abfd, name, unhandled, flag);
1286
20.6k
    result = false;
1287
20.6k
  }
1288
314k
    }
1289
1290
37.4k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
37.4k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
37.4k
#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
37.4k
  if (startswith (name, ".gnu.linkonce"))
1303
0
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
37.4k
#endif
1305
1306
37.4k
  if (flags_ptr)
1307
37.4k
    * flags_ptr = sec_flags;
1308
1309
37.4k
  return result;
1310
37.4k
}
pe-x86_64.c:styp_to_sec_flags
Line
Count
Source
1139
61.6k
{
1140
61.6k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
61.6k
  unsigned long styp_flags = internal_s->s_flags;
1142
61.6k
  flagword sec_flags;
1143
61.6k
  bool result = true;
1144
61.6k
  bool is_dbg = false;
1145
1146
61.6k
  if (startswith (name, DOT_DEBUG)
1147
61.6k
      || startswith (name, DOT_ZDEBUG)
1148
61.6k
#ifdef COFF_LONG_SECTION_NAMES
1149
61.6k
      || startswith (name, GNU_LINKONCE_WI)
1150
61.6k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
61.6k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
61.6k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
61.6k
      || startswith (name, GNU_DEBUGLINK)
1155
61.6k
      || startswith (name, GNU_DEBUGALTLINK)
1156
61.6k
#endif
1157
61.6k
      || startswith (name, ".stab"))
1158
6.85k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
61.6k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
61.6k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
42.4k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
532k
  while (styp_flags)
1168
470k
    {
1169
470k
      unsigned long flag = styp_flags & - styp_flags;
1170
470k
      char * unhandled = NULL;
1171
1172
470k
      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
470k
      switch (flag)
1179
470k
  {
1180
6.28k
  case STYP_DSECT:
1181
6.28k
    unhandled = "STYP_DSECT";
1182
6.28k
    break;
1183
9.67k
  case STYP_GROUP:
1184
9.67k
    unhandled = "STYP_GROUP";
1185
9.67k
    break;
1186
7.25k
  case STYP_COPY:
1187
7.25k
    unhandled = "STYP_COPY";
1188
7.25k
    break;
1189
7.83k
  case STYP_OVER:
1190
7.83k
    unhandled = "STYP_OVER";
1191
7.83k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
13.5k
  case STYP_NOLOAD:
1194
13.5k
    sec_flags |= SEC_NEVER_LOAD;
1195
13.5k
    break;
1196
0
#endif
1197
19.1k
  case IMAGE_SCN_MEM_READ:
1198
19.1k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
19.1k
    break;
1200
13.0k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
13.0k
    break;
1203
5.28k
  case IMAGE_SCN_LNK_OTHER:
1204
5.28k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
5.28k
    break;
1206
8.16k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
8.16k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
8.16k
    break;
1209
23.1k
  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
23.1k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
23.1k
        " %s in section %s"),
1216
23.1k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
23.1k
    break;
1218
21.3k
  case IMAGE_SCN_MEM_EXECUTE:
1219
21.3k
    sec_flags |= SEC_CODE;
1220
21.3k
    break;
1221
14.2k
  case IMAGE_SCN_MEM_WRITE:
1222
14.2k
    sec_flags &= ~ SEC_READONLY;
1223
14.2k
    break;
1224
20.1k
  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
20.1k
       if (is_dbg
1231
20.1k
#ifdef _COMMENT
1232
20.1k
        || strcmp (name, _COMMENT) == 0
1233
20.1k
#endif
1234
20.1k
        )
1235
3.02k
      {
1236
3.02k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
3.02k
      }
1238
20.1k
    break;
1239
13.1k
  case IMAGE_SCN_MEM_SHARED:
1240
13.1k
    sec_flags |= SEC_COFF_SHARED;
1241
13.1k
    break;
1242
17.5k
  case IMAGE_SCN_LNK_REMOVE:
1243
17.5k
    if (!is_dbg)
1244
15.4k
      sec_flags |= SEC_EXCLUDE;
1245
17.5k
    break;
1246
22.6k
  case IMAGE_SCN_CNT_CODE:
1247
22.6k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
22.6k
    break;
1249
12.9k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
12.9k
    if (is_dbg)
1251
1.91k
      sec_flags |= SEC_DEBUGGING;
1252
11.0k
    else
1253
11.0k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
12.9k
    break;
1255
11.0k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
11.0k
    sec_flags |= SEC_ALLOC;
1257
11.0k
    break;
1258
16.8k
  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
16.8k
#ifdef COFF_PAGE_SIZE
1266
16.8k
    sec_flags |= SEC_DEBUGGING;
1267
16.8k
#endif
1268
16.8k
    break;
1269
13.8k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
13.8k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
585
      result = false;
1273
13.8k
    break;
1274
193k
  default:
1275
    /* Silently ignore for now.  */
1276
193k
    break;
1277
470k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
470k
      if (unhandled != NULL)
1281
44.5k
  {
1282
44.5k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
44.5k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
44.5k
       abfd, name, unhandled, flag);
1286
44.5k
    result = false;
1287
44.5k
  }
1288
470k
    }
1289
1290
61.6k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
61.6k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
61.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
61.6k
  if (startswith (name, ".gnu.linkonce"))
1303
0
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
61.6k
#endif
1305
1306
61.6k
  if (flags_ptr)
1307
61.6k
    * flags_ptr = sec_flags;
1308
1309
61.6k
  return result;
1310
61.6k
}
pei-x86_64.c:styp_to_sec_flags
Line
Count
Source
1139
87.6k
{
1140
87.6k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
87.6k
  unsigned long styp_flags = internal_s->s_flags;
1142
87.6k
  flagword sec_flags;
1143
87.6k
  bool result = true;
1144
87.6k
  bool is_dbg = false;
1145
1146
87.6k
  if (startswith (name, DOT_DEBUG)
1147
87.6k
      || startswith (name, DOT_ZDEBUG)
1148
87.6k
#ifdef COFF_LONG_SECTION_NAMES
1149
87.6k
      || startswith (name, GNU_LINKONCE_WI)
1150
87.6k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
87.6k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
87.6k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
87.6k
      || startswith (name, GNU_DEBUGLINK)
1155
87.6k
      || startswith (name, GNU_DEBUGALTLINK)
1156
87.6k
#endif
1157
87.6k
      || startswith (name, ".stab"))
1158
17.5k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
87.6k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
87.6k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
62.5k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
611k
  while (styp_flags)
1168
524k
    {
1169
524k
      unsigned long flag = styp_flags & - styp_flags;
1170
524k
      char * unhandled = NULL;
1171
1172
524k
      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
524k
      switch (flag)
1179
524k
  {
1180
3.90k
  case STYP_DSECT:
1181
3.90k
    unhandled = "STYP_DSECT";
1182
3.90k
    break;
1183
4.51k
  case STYP_GROUP:
1184
4.51k
    unhandled = "STYP_GROUP";
1185
4.51k
    break;
1186
5.13k
  case STYP_COPY:
1187
5.13k
    unhandled = "STYP_COPY";
1188
5.13k
    break;
1189
5.18k
  case STYP_OVER:
1190
5.18k
    unhandled = "STYP_OVER";
1191
5.18k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
8.88k
  case STYP_NOLOAD:
1194
8.88k
    sec_flags |= SEC_NEVER_LOAD;
1195
8.88k
    break;
1196
0
#endif
1197
25.0k
  case IMAGE_SCN_MEM_READ:
1198
25.0k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
25.0k
    break;
1200
8.49k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
8.49k
    break;
1203
4.66k
  case IMAGE_SCN_LNK_OTHER:
1204
4.66k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
4.66k
    break;
1206
3.97k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
3.97k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
3.97k
    break;
1209
25.2k
  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
25.2k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
25.2k
        " %s in section %s"),
1216
25.2k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
25.2k
    break;
1218
12.9k
  case IMAGE_SCN_MEM_EXECUTE:
1219
12.9k
    sec_flags |= SEC_CODE;
1220
12.9k
    break;
1221
7.45k
  case IMAGE_SCN_MEM_WRITE:
1222
7.45k
    sec_flags &= ~ SEC_READONLY;
1223
7.45k
    break;
1224
26.9k
  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
26.9k
       if (is_dbg
1231
26.9k
#ifdef _COMMENT
1232
26.9k
        || strcmp (name, _COMMENT) == 0
1233
26.9k
#endif
1234
26.9k
        )
1235
9.81k
      {
1236
9.81k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
9.81k
      }
1238
26.9k
    break;
1239
24.5k
  case IMAGE_SCN_MEM_SHARED:
1240
24.5k
    sec_flags |= SEC_COFF_SHARED;
1241
24.5k
    break;
1242
31.0k
  case IMAGE_SCN_LNK_REMOVE:
1243
31.0k
    if (!is_dbg)
1244
15.8k
      sec_flags |= SEC_EXCLUDE;
1245
31.0k
    break;
1246
29.8k
  case IMAGE_SCN_CNT_CODE:
1247
29.8k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
29.8k
    break;
1249
6.96k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
6.96k
    if (is_dbg)
1251
1.42k
      sec_flags |= SEC_DEBUGGING;
1252
5.54k
    else
1253
5.54k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
6.96k
    break;
1255
9.29k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
9.29k
    sec_flags |= SEC_ALLOC;
1257
9.29k
    break;
1258
27.5k
  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
27.5k
#ifdef COFF_PAGE_SIZE
1266
27.5k
    sec_flags |= SEC_DEBUGGING;
1267
27.5k
#endif
1268
27.5k
    break;
1269
32.0k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
32.0k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
1.99k
      result = false;
1273
32.0k
    break;
1274
220k
  default:
1275
    /* Silently ignore for now.  */
1276
220k
    break;
1277
524k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
524k
      if (unhandled != NULL)
1281
27.3k
  {
1282
27.3k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
27.3k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
27.3k
       abfd, name, unhandled, flag);
1286
27.3k
    result = false;
1287
27.3k
  }
1288
524k
    }
1289
1290
87.6k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
87.6k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
87.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
87.6k
  if (startswith (name, ".gnu.linkonce"))
1303
0
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
87.6k
#endif
1305
1306
87.6k
  if (flags_ptr)
1307
87.6k
    * flags_ptr = sec_flags;
1308
1309
87.6k
  return result;
1310
87.6k
}
pei-aarch64.c:styp_to_sec_flags
Line
Count
Source
1139
32.3k
{
1140
32.3k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
32.3k
  unsigned long styp_flags = internal_s->s_flags;
1142
32.3k
  flagword sec_flags;
1143
32.3k
  bool result = true;
1144
32.3k
  bool is_dbg = false;
1145
1146
32.3k
  if (startswith (name, DOT_DEBUG)
1147
32.3k
      || startswith (name, DOT_ZDEBUG)
1148
32.3k
#ifdef COFF_LONG_SECTION_NAMES
1149
32.3k
      || startswith (name, GNU_LINKONCE_WI)
1150
32.3k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
32.3k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
32.3k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
32.3k
      || startswith (name, GNU_DEBUGLINK)
1155
32.3k
      || startswith (name, GNU_DEBUGALTLINK)
1156
32.3k
#endif
1157
32.3k
      || startswith (name, ".stab"))
1158
1.53k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
32.3k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
32.3k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
20.8k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
247k
  while (styp_flags)
1168
215k
    {
1169
215k
      unsigned long flag = styp_flags & - styp_flags;
1170
215k
      char * unhandled = NULL;
1171
1172
215k
      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
215k
      switch (flag)
1179
215k
  {
1180
1.69k
  case STYP_DSECT:
1181
1.69k
    unhandled = "STYP_DSECT";
1182
1.69k
    break;
1183
1.88k
  case STYP_GROUP:
1184
1.88k
    unhandled = "STYP_GROUP";
1185
1.88k
    break;
1186
2.21k
  case STYP_COPY:
1187
2.21k
    unhandled = "STYP_COPY";
1188
2.21k
    break;
1189
1.58k
  case STYP_OVER:
1190
1.58k
    unhandled = "STYP_OVER";
1191
1.58k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
7.25k
  case STYP_NOLOAD:
1194
7.25k
    sec_flags |= SEC_NEVER_LOAD;
1195
7.25k
    break;
1196
0
#endif
1197
11.4k
  case IMAGE_SCN_MEM_READ:
1198
11.4k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
11.4k
    break;
1200
8.89k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
8.89k
    break;
1203
1.78k
  case IMAGE_SCN_LNK_OTHER:
1204
1.78k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
1.78k
    break;
1206
1.53k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
1.53k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
1.53k
    break;
1209
9.93k
  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
9.93k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
9.93k
        " %s in section %s"),
1216
9.93k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
9.93k
    break;
1218
9.86k
  case IMAGE_SCN_MEM_EXECUTE:
1219
9.86k
    sec_flags |= SEC_CODE;
1220
9.86k
    break;
1221
8.84k
  case IMAGE_SCN_MEM_WRITE:
1222
8.84k
    sec_flags &= ~ SEC_READONLY;
1223
8.84k
    break;
1224
7.97k
  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.97k
       if (is_dbg
1231
7.97k
#ifdef _COMMENT
1232
7.97k
        || strcmp (name, _COMMENT) == 0
1233
7.97k
#endif
1234
7.97k
        )
1235
720
      {
1236
720
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
720
      }
1238
7.97k
    break;
1239
4.91k
  case IMAGE_SCN_MEM_SHARED:
1240
4.91k
    sec_flags |= SEC_COFF_SHARED;
1241
4.91k
    break;
1242
11.4k
  case IMAGE_SCN_LNK_REMOVE:
1243
11.4k
    if (!is_dbg)
1244
11.0k
      sec_flags |= SEC_EXCLUDE;
1245
11.4k
    break;
1246
7.81k
  case IMAGE_SCN_CNT_CODE:
1247
7.81k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
7.81k
    break;
1249
9.60k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
9.60k
    if (is_dbg)
1251
953
      sec_flags |= SEC_DEBUGGING;
1252
8.65k
    else
1253
8.65k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
9.60k
    break;
1255
8.78k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
8.78k
    sec_flags |= SEC_ALLOC;
1257
8.78k
    break;
1258
10.3k
  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
10.3k
#ifdef COFF_PAGE_SIZE
1266
10.3k
    sec_flags |= SEC_DEBUGGING;
1267
10.3k
#endif
1268
10.3k
    break;
1269
5.19k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
5.19k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
415
      result = false;
1273
5.19k
    break;
1274
82.0k
  default:
1275
    /* Silently ignore for now.  */
1276
82.0k
    break;
1277
215k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
215k
      if (unhandled != NULL)
1281
10.7k
  {
1282
10.7k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
10.7k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
10.7k
       abfd, name, unhandled, flag);
1286
10.7k
    result = false;
1287
10.7k
  }
1288
215k
    }
1289
1290
32.3k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
32.3k
      && (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
32.3k
  if (flags_ptr)
1307
32.3k
    * flags_ptr = sec_flags;
1308
1309
32.3k
  return result;
1310
32.3k
}
pe-aarch64.c:styp_to_sec_flags
Line
Count
Source
1139
14.3k
{
1140
14.3k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
14.3k
  unsigned long styp_flags = internal_s->s_flags;
1142
14.3k
  flagword sec_flags;
1143
14.3k
  bool result = true;
1144
14.3k
  bool is_dbg = false;
1145
1146
14.3k
  if (startswith (name, DOT_DEBUG)
1147
14.3k
      || startswith (name, DOT_ZDEBUG)
1148
14.3k
#ifdef COFF_LONG_SECTION_NAMES
1149
14.3k
      || startswith (name, GNU_LINKONCE_WI)
1150
14.3k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
14.3k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
14.3k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
14.3k
      || startswith (name, GNU_DEBUGLINK)
1155
14.3k
      || startswith (name, GNU_DEBUGALTLINK)
1156
14.3k
#endif
1157
14.3k
      || startswith (name, ".stab"))
1158
1.16k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
14.3k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
14.3k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
10.9k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
75.9k
  while (styp_flags)
1168
61.6k
    {
1169
61.6k
      unsigned long flag = styp_flags & - styp_flags;
1170
61.6k
      char * unhandled = NULL;
1171
1172
61.6k
      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
61.6k
      switch (flag)
1179
61.6k
  {
1180
466
  case STYP_DSECT:
1181
466
    unhandled = "STYP_DSECT";
1182
466
    break;
1183
362
  case STYP_GROUP:
1184
362
    unhandled = "STYP_GROUP";
1185
362
    break;
1186
968
  case STYP_COPY:
1187
968
    unhandled = "STYP_COPY";
1188
968
    break;
1189
468
  case STYP_OVER:
1190
468
    unhandled = "STYP_OVER";
1191
468
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
1.71k
  case STYP_NOLOAD:
1194
1.71k
    sec_flags |= SEC_NEVER_LOAD;
1195
1.71k
    break;
1196
0
#endif
1197
3.39k
  case IMAGE_SCN_MEM_READ:
1198
3.39k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
3.39k
    break;
1200
1.77k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
1.77k
    break;
1203
360
  case IMAGE_SCN_LNK_OTHER:
1204
360
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
360
    break;
1206
766
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
766
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
766
    break;
1209
3.39k
  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.39k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
3.39k
        " %s in section %s"),
1216
3.39k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
3.39k
    break;
1218
2.68k
  case IMAGE_SCN_MEM_EXECUTE:
1219
2.68k
    sec_flags |= SEC_CODE;
1220
2.68k
    break;
1221
1.69k
  case IMAGE_SCN_MEM_WRITE:
1222
1.69k
    sec_flags &= ~ SEC_READONLY;
1223
1.69k
    break;
1224
3.31k
  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.31k
       if (is_dbg
1231
3.31k
#ifdef _COMMENT
1232
3.31k
        || strcmp (name, _COMMENT) == 0
1233
3.31k
#endif
1234
3.31k
        )
1235
954
      {
1236
954
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
954
      }
1238
3.31k
    break;
1239
3.19k
  case IMAGE_SCN_MEM_SHARED:
1240
3.19k
    sec_flags |= SEC_COFF_SHARED;
1241
3.19k
    break;
1242
3.69k
  case IMAGE_SCN_LNK_REMOVE:
1243
3.69k
    if (!is_dbg)
1244
3.35k
      sec_flags |= SEC_EXCLUDE;
1245
3.69k
    break;
1246
1.37k
  case IMAGE_SCN_CNT_CODE:
1247
1.37k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
1.37k
    break;
1249
1.68k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
1.68k
    if (is_dbg)
1251
343
      sec_flags |= SEC_DEBUGGING;
1252
1.33k
    else
1253
1.33k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
1.68k
    break;
1255
881
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
881
    sec_flags |= SEC_ALLOC;
1257
881
    break;
1258
3.33k
  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
3.33k
#ifdef COFF_PAGE_SIZE
1266
3.33k
    sec_flags |= SEC_DEBUGGING;
1267
3.33k
#endif
1268
3.33k
    break;
1269
3.42k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
3.42k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
210
      result = false;
1273
3.42k
    break;
1274
22.6k
  default:
1275
    /* Silently ignore for now.  */
1276
22.6k
    break;
1277
61.6k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
61.6k
      if (unhandled != NULL)
1281
3.39k
  {
1282
3.39k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
3.39k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
3.39k
       abfd, name, unhandled, flag);
1286
3.39k
    result = false;
1287
3.39k
  }
1288
61.6k
    }
1289
1290
14.3k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
14.3k
      && (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
14.3k
  if (flags_ptr)
1307
14.3k
    * flags_ptr = sec_flags;
1308
1309
14.3k
  return result;
1310
14.3k
}
pei-ia64.c:styp_to_sec_flags
Line
Count
Source
1139
51.0k
{
1140
51.0k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
51.0k
  unsigned long styp_flags = internal_s->s_flags;
1142
51.0k
  flagword sec_flags;
1143
51.0k
  bool result = true;
1144
51.0k
  bool is_dbg = false;
1145
1146
51.0k
  if (startswith (name, DOT_DEBUG)
1147
51.0k
      || startswith (name, DOT_ZDEBUG)
1148
51.0k
#ifdef COFF_LONG_SECTION_NAMES
1149
51.0k
      || startswith (name, GNU_LINKONCE_WI)
1150
51.0k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
51.0k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
51.0k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
51.0k
      || startswith (name, GNU_DEBUGLINK)
1155
51.0k
      || startswith (name, GNU_DEBUGALTLINK)
1156
51.0k
#endif
1157
51.0k
      || startswith (name, ".stab"))
1158
4.11k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
51.0k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
51.0k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
38.0k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
394k
  while (styp_flags)
1168
343k
    {
1169
343k
      unsigned long flag = styp_flags & - styp_flags;
1170
343k
      char * unhandled = NULL;
1171
1172
343k
      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
343k
      switch (flag)
1179
343k
  {
1180
3.41k
  case STYP_DSECT:
1181
3.41k
    unhandled = "STYP_DSECT";
1182
3.41k
    break;
1183
6.04k
  case STYP_GROUP:
1184
6.04k
    unhandled = "STYP_GROUP";
1185
6.04k
    break;
1186
5.98k
  case STYP_COPY:
1187
5.98k
    unhandled = "STYP_COPY";
1188
5.98k
    break;
1189
6.20k
  case STYP_OVER:
1190
6.20k
    unhandled = "STYP_OVER";
1191
6.20k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
13.0k
  case STYP_NOLOAD:
1194
13.0k
    sec_flags |= SEC_NEVER_LOAD;
1195
13.0k
    break;
1196
0
#endif
1197
12.9k
  case IMAGE_SCN_MEM_READ:
1198
12.9k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
12.9k
    break;
1200
6.46k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
6.46k
    break;
1203
3.44k
  case IMAGE_SCN_LNK_OTHER:
1204
3.44k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
3.44k
    break;
1206
5.65k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
5.65k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
5.65k
    break;
1209
9.75k
  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
9.75k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
9.75k
        " %s in section %s"),
1216
9.75k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
9.75k
    break;
1218
14.9k
  case IMAGE_SCN_MEM_EXECUTE:
1219
14.9k
    sec_flags |= SEC_CODE;
1220
14.9k
    break;
1221
8.78k
  case IMAGE_SCN_MEM_WRITE:
1222
8.78k
    sec_flags &= ~ SEC_READONLY;
1223
8.78k
    break;
1224
16.9k
  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
16.9k
       if (is_dbg
1231
16.9k
#ifdef _COMMENT
1232
16.9k
        || strcmp (name, _COMMENT) == 0
1233
16.9k
#endif
1234
16.9k
        )
1235
2.90k
      {
1236
2.90k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
2.90k
      }
1238
16.9k
    break;
1239
8.74k
  case IMAGE_SCN_MEM_SHARED:
1240
8.74k
    sec_flags |= SEC_COFF_SHARED;
1241
8.74k
    break;
1242
13.4k
  case IMAGE_SCN_LNK_REMOVE:
1243
13.4k
    if (!is_dbg)
1244
12.9k
      sec_flags |= SEC_EXCLUDE;
1245
13.4k
    break;
1246
14.3k
  case IMAGE_SCN_CNT_CODE:
1247
14.3k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
14.3k
    break;
1249
11.4k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
11.4k
    if (is_dbg)
1251
680
      sec_flags |= SEC_DEBUGGING;
1252
10.7k
    else
1253
10.7k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
11.4k
    break;
1255
8.58k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
8.58k
    sec_flags |= SEC_ALLOC;
1257
8.58k
    break;
1258
16.0k
  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
16.0k
#ifdef COFF_PAGE_SIZE
1266
16.0k
    sec_flags |= SEC_DEBUGGING;
1267
16.0k
#endif
1268
16.0k
    break;
1269
20.9k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
20.9k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
1.57k
      result = false;
1273
20.9k
    break;
1274
136k
  default:
1275
    /* Silently ignore for now.  */
1276
136k
    break;
1277
343k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
343k
      if (unhandled != NULL)
1281
30.7k
  {
1282
30.7k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
30.7k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
30.7k
       abfd, name, unhandled, flag);
1286
30.7k
    result = false;
1287
30.7k
  }
1288
343k
    }
1289
1290
51.0k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
51.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
  if (startswith (name, ".gnu.linkonce"))
1303
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
#endif
1305
1306
51.0k
  if (flags_ptr)
1307
51.0k
    * flags_ptr = sec_flags;
1308
1309
51.0k
  return result;
1310
51.0k
}
pei-loongarch64.c:styp_to_sec_flags
Line
Count
Source
1139
104k
{
1140
104k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
104k
  unsigned long styp_flags = internal_s->s_flags;
1142
104k
  flagword sec_flags;
1143
104k
  bool result = true;
1144
104k
  bool is_dbg = false;
1145
1146
104k
  if (startswith (name, DOT_DEBUG)
1147
104k
      || startswith (name, DOT_ZDEBUG)
1148
104k
#ifdef COFF_LONG_SECTION_NAMES
1149
104k
      || startswith (name, GNU_LINKONCE_WI)
1150
104k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
104k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
104k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
104k
      || startswith (name, GNU_DEBUGLINK)
1155
104k
      || startswith (name, GNU_DEBUGALTLINK)
1156
104k
#endif
1157
104k
      || startswith (name, ".stab"))
1158
927
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
104k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
104k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
96.2k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
295k
  while (styp_flags)
1168
191k
    {
1169
191k
      unsigned long flag = styp_flags & - styp_flags;
1170
191k
      char * unhandled = NULL;
1171
1172
191k
      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
191k
      switch (flag)
1179
191k
  {
1180
624
  case STYP_DSECT:
1181
624
    unhandled = "STYP_DSECT";
1182
624
    break;
1183
504
  case STYP_GROUP:
1184
504
    unhandled = "STYP_GROUP";
1185
504
    break;
1186
612
  case STYP_COPY:
1187
612
    unhandled = "STYP_COPY";
1188
612
    break;
1189
506
  case STYP_OVER:
1190
506
    unhandled = "STYP_OVER";
1191
506
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
5.31k
  case STYP_NOLOAD:
1194
5.31k
    sec_flags |= SEC_NEVER_LOAD;
1195
5.31k
    break;
1196
0
#endif
1197
8.60k
  case IMAGE_SCN_MEM_READ:
1198
8.60k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
8.60k
    break;
1200
7.41k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
7.41k
    break;
1203
529
  case IMAGE_SCN_LNK_OTHER:
1204
529
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
529
    break;
1206
710
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
710
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
710
    break;
1209
9.26k
  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
9.26k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
9.26k
        " %s in section %s"),
1216
9.26k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
9.26k
    break;
1218
11.1k
  case IMAGE_SCN_MEM_EXECUTE:
1219
11.1k
    sec_flags |= SEC_CODE;
1220
11.1k
    break;
1221
7.04k
  case IMAGE_SCN_MEM_WRITE:
1222
7.04k
    sec_flags &= ~ SEC_READONLY;
1223
7.04k
    break;
1224
13.0k
  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
13.0k
       if (is_dbg
1231
13.0k
#ifdef _COMMENT
1232
13.0k
        || strcmp (name, _COMMENT) == 0
1233
13.0k
#endif
1234
13.0k
        )
1235
346
      {
1236
346
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
346
      }
1238
13.0k
    break;
1239
2.27k
  case IMAGE_SCN_MEM_SHARED:
1240
2.27k
    sec_flags |= SEC_COFF_SHARED;
1241
2.27k
    break;
1242
11.5k
  case IMAGE_SCN_LNK_REMOVE:
1243
11.5k
    if (!is_dbg)
1244
11.2k
      sec_flags |= SEC_EXCLUDE;
1245
11.5k
    break;
1246
6.64k
  case IMAGE_SCN_CNT_CODE:
1247
6.64k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
6.64k
    break;
1249
5.34k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
5.34k
    if (is_dbg)
1251
308
      sec_flags |= SEC_DEBUGGING;
1252
5.03k
    else
1253
5.03k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
5.34k
    break;
1255
6.14k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
6.14k
    sec_flags |= SEC_ALLOC;
1257
6.14k
    break;
1258
9.29k
  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
9.29k
#ifdef COFF_PAGE_SIZE
1266
9.29k
    sec_flags |= SEC_DEBUGGING;
1267
9.29k
#endif
1268
9.29k
    break;
1269
5.33k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
5.33k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
313
      result = false;
1273
5.33k
    break;
1274
79.0k
  default:
1275
    /* Silently ignore for now.  */
1276
79.0k
    break;
1277
191k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
191k
      if (unhandled != NULL)
1281
3.48k
  {
1282
3.48k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
3.48k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
3.48k
       abfd, name, unhandled, flag);
1286
3.48k
    result = false;
1287
3.48k
  }
1288
191k
    }
1289
1290
104k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
104k
      && (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
104k
  if (flags_ptr)
1307
104k
    * flags_ptr = sec_flags;
1308
1309
104k
  return result;
1310
104k
}
pe-arm-wince.c:styp_to_sec_flags
Line
Count
Source
1139
9.73k
{
1140
9.73k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
9.73k
  unsigned long styp_flags = internal_s->s_flags;
1142
9.73k
  flagword sec_flags;
1143
9.73k
  bool result = true;
1144
9.73k
  bool is_dbg = false;
1145
1146
9.73k
  if (startswith (name, DOT_DEBUG)
1147
9.73k
      || startswith (name, DOT_ZDEBUG)
1148
9.73k
#ifdef COFF_LONG_SECTION_NAMES
1149
9.73k
      || startswith (name, GNU_LINKONCE_WI)
1150
9.73k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
9.73k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
9.73k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
9.73k
      || startswith (name, GNU_DEBUGLINK)
1155
9.73k
      || startswith (name, GNU_DEBUGALTLINK)
1156
9.73k
#endif
1157
9.73k
      || startswith (name, ".stab"))
1158
1.51k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
9.73k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
9.73k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
3.85k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
118k
  while (styp_flags)
1168
108k
    {
1169
108k
      unsigned long flag = styp_flags & - styp_flags;
1170
108k
      char * unhandled = NULL;
1171
1172
108k
      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
108k
      switch (flag)
1179
108k
  {
1180
1.50k
  case STYP_DSECT:
1181
1.50k
    unhandled = "STYP_DSECT";
1182
1.50k
    break;
1183
1.64k
  case STYP_GROUP:
1184
1.64k
    unhandled = "STYP_GROUP";
1185
1.64k
    break;
1186
1.42k
  case STYP_COPY:
1187
1.42k
    unhandled = "STYP_COPY";
1188
1.42k
    break;
1189
1.45k
  case STYP_OVER:
1190
1.45k
    unhandled = "STYP_OVER";
1191
1.45k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
2.53k
  case STYP_NOLOAD:
1194
2.53k
    sec_flags |= SEC_NEVER_LOAD;
1195
2.53k
    break;
1196
0
#endif
1197
5.88k
  case IMAGE_SCN_MEM_READ:
1198
5.88k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
5.88k
    break;
1200
2.61k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
2.61k
    break;
1203
2.74k
  case IMAGE_SCN_LNK_OTHER:
1204
2.74k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
2.74k
    break;
1206
2.45k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
2.45k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
2.45k
    break;
1209
4.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
4.56k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
4.56k
        " %s in section %s"),
1216
4.56k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
4.56k
    break;
1218
3.97k
  case IMAGE_SCN_MEM_EXECUTE:
1219
3.97k
    sec_flags |= SEC_CODE;
1220
3.97k
    break;
1221
3.00k
  case IMAGE_SCN_MEM_WRITE:
1222
3.00k
    sec_flags &= ~ SEC_READONLY;
1223
3.00k
    break;
1224
5.90k
  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
5.90k
       if (is_dbg
1231
5.90k
#ifdef _COMMENT
1232
5.90k
        || strcmp (name, _COMMENT) == 0
1233
5.90k
#endif
1234
5.90k
        )
1235
1.39k
      {
1236
1.39k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
1.39k
      }
1238
5.90k
    break;
1239
3.92k
  case IMAGE_SCN_MEM_SHARED:
1240
3.92k
    sec_flags |= SEC_COFF_SHARED;
1241
3.92k
    break;
1242
5.67k
  case IMAGE_SCN_LNK_REMOVE:
1243
5.67k
    if (!is_dbg)
1244
4.38k
      sec_flags |= SEC_EXCLUDE;
1245
5.67k
    break;
1246
5.65k
  case IMAGE_SCN_CNT_CODE:
1247
5.65k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
5.65k
    break;
1249
2.73k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
2.73k
    if (is_dbg)
1251
326
      sec_flags |= SEC_DEBUGGING;
1252
2.40k
    else
1253
2.40k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
2.73k
    break;
1255
1.50k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
1.50k
    sec_flags |= SEC_ALLOC;
1257
1.50k
    break;
1258
4.88k
  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.88k
#ifdef COFF_PAGE_SIZE
1266
4.88k
    sec_flags |= SEC_DEBUGGING;
1267
4.88k
#endif
1268
4.88k
    break;
1269
4.41k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
4.41k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
726
      result = false;
1273
4.41k
    break;
1274
40.1k
  default:
1275
    /* Silently ignore for now.  */
1276
40.1k
    break;
1277
108k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
108k
      if (unhandled != NULL)
1281
11.2k
  {
1282
11.2k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
11.2k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
11.2k
       abfd, name, unhandled, flag);
1286
11.2k
    result = false;
1287
11.2k
  }
1288
108k
    }
1289
1290
9.73k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
9.73k
      && (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
9.73k
  if (flags_ptr)
1307
9.73k
    * flags_ptr = sec_flags;
1308
1309
9.73k
  return result;
1310
9.73k
}
pe-arm.c:styp_to_sec_flags
Line
Count
Source
1139
9.73k
{
1140
9.73k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
9.73k
  unsigned long styp_flags = internal_s->s_flags;
1142
9.73k
  flagword sec_flags;
1143
9.73k
  bool result = true;
1144
9.73k
  bool is_dbg = false;
1145
1146
9.73k
  if (startswith (name, DOT_DEBUG)
1147
9.73k
      || startswith (name, DOT_ZDEBUG)
1148
9.73k
#ifdef COFF_LONG_SECTION_NAMES
1149
9.73k
      || startswith (name, GNU_LINKONCE_WI)
1150
9.73k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
9.73k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
9.73k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
9.73k
      || startswith (name, GNU_DEBUGLINK)
1155
9.73k
      || startswith (name, GNU_DEBUGALTLINK)
1156
9.73k
#endif
1157
9.73k
      || startswith (name, ".stab"))
1158
1.51k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
9.73k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
9.73k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
3.85k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
118k
  while (styp_flags)
1168
108k
    {
1169
108k
      unsigned long flag = styp_flags & - styp_flags;
1170
108k
      char * unhandled = NULL;
1171
1172
108k
      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
108k
      switch (flag)
1179
108k
  {
1180
1.50k
  case STYP_DSECT:
1181
1.50k
    unhandled = "STYP_DSECT";
1182
1.50k
    break;
1183
1.64k
  case STYP_GROUP:
1184
1.64k
    unhandled = "STYP_GROUP";
1185
1.64k
    break;
1186
1.42k
  case STYP_COPY:
1187
1.42k
    unhandled = "STYP_COPY";
1188
1.42k
    break;
1189
1.45k
  case STYP_OVER:
1190
1.45k
    unhandled = "STYP_OVER";
1191
1.45k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
2.53k
  case STYP_NOLOAD:
1194
2.53k
    sec_flags |= SEC_NEVER_LOAD;
1195
2.53k
    break;
1196
0
#endif
1197
5.88k
  case IMAGE_SCN_MEM_READ:
1198
5.88k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
5.88k
    break;
1200
2.61k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
2.61k
    break;
1203
2.74k
  case IMAGE_SCN_LNK_OTHER:
1204
2.74k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
2.74k
    break;
1206
2.45k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
2.45k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
2.45k
    break;
1209
4.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
4.56k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
4.56k
        " %s in section %s"),
1216
4.56k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
4.56k
    break;
1218
3.97k
  case IMAGE_SCN_MEM_EXECUTE:
1219
3.97k
    sec_flags |= SEC_CODE;
1220
3.97k
    break;
1221
3.00k
  case IMAGE_SCN_MEM_WRITE:
1222
3.00k
    sec_flags &= ~ SEC_READONLY;
1223
3.00k
    break;
1224
5.90k
  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
5.90k
       if (is_dbg
1231
5.90k
#ifdef _COMMENT
1232
5.90k
        || strcmp (name, _COMMENT) == 0
1233
5.90k
#endif
1234
5.90k
        )
1235
1.39k
      {
1236
1.39k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
1.39k
      }
1238
5.90k
    break;
1239
3.92k
  case IMAGE_SCN_MEM_SHARED:
1240
3.92k
    sec_flags |= SEC_COFF_SHARED;
1241
3.92k
    break;
1242
5.67k
  case IMAGE_SCN_LNK_REMOVE:
1243
5.67k
    if (!is_dbg)
1244
4.38k
      sec_flags |= SEC_EXCLUDE;
1245
5.67k
    break;
1246
5.65k
  case IMAGE_SCN_CNT_CODE:
1247
5.65k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
5.65k
    break;
1249
2.73k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
2.73k
    if (is_dbg)
1251
326
      sec_flags |= SEC_DEBUGGING;
1252
2.40k
    else
1253
2.40k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
2.73k
    break;
1255
1.50k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
1.50k
    sec_flags |= SEC_ALLOC;
1257
1.50k
    break;
1258
4.88k
  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.88k
#ifdef COFF_PAGE_SIZE
1266
4.88k
    sec_flags |= SEC_DEBUGGING;
1267
4.88k
#endif
1268
4.88k
    break;
1269
4.41k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
4.41k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
726
      result = false;
1273
4.41k
    break;
1274
40.1k
  default:
1275
    /* Silently ignore for now.  */
1276
40.1k
    break;
1277
108k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
108k
      if (unhandled != NULL)
1281
11.2k
  {
1282
11.2k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
11.2k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
11.2k
       abfd, name, unhandled, flag);
1286
11.2k
    result = false;
1287
11.2k
  }
1288
108k
    }
1289
1290
9.73k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
9.73k
      && (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
9.73k
  if (flags_ptr)
1307
9.73k
    * flags_ptr = sec_flags;
1308
1309
9.73k
  return result;
1310
9.73k
}
pe-i386.c:styp_to_sec_flags
Line
Count
Source
1139
40.9k
{
1140
40.9k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
40.9k
  unsigned long styp_flags = internal_s->s_flags;
1142
40.9k
  flagword sec_flags;
1143
40.9k
  bool result = true;
1144
40.9k
  bool is_dbg = false;
1145
1146
40.9k
  if (startswith (name, DOT_DEBUG)
1147
40.9k
      || startswith (name, DOT_ZDEBUG)
1148
40.9k
#ifdef COFF_LONG_SECTION_NAMES
1149
40.9k
      || startswith (name, GNU_LINKONCE_WI)
1150
40.9k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
40.9k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
40.9k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
40.9k
      || startswith (name, GNU_DEBUGLINK)
1155
40.9k
      || startswith (name, GNU_DEBUGALTLINK)
1156
40.9k
#endif
1157
40.9k
      || startswith (name, ".stab"))
1158
5.56k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
40.9k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
40.9k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
23.9k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
484k
  while (styp_flags)
1168
443k
    {
1169
443k
      unsigned long flag = styp_flags & - styp_flags;
1170
443k
      char * unhandled = NULL;
1171
1172
443k
      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
443k
      switch (flag)
1179
443k
  {
1180
9.93k
  case STYP_DSECT:
1181
9.93k
    unhandled = "STYP_DSECT";
1182
9.93k
    break;
1183
10.8k
  case STYP_GROUP:
1184
10.8k
    unhandled = "STYP_GROUP";
1185
10.8k
    break;
1186
10.8k
  case STYP_COPY:
1187
10.8k
    unhandled = "STYP_COPY";
1188
10.8k
    break;
1189
10.9k
  case STYP_OVER:
1190
10.9k
    unhandled = "STYP_OVER";
1191
10.9k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
13.0k
  case STYP_NOLOAD:
1194
13.0k
    sec_flags |= SEC_NEVER_LOAD;
1195
13.0k
    break;
1196
0
#endif
1197
17.0k
  case IMAGE_SCN_MEM_READ:
1198
17.0k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
17.0k
    break;
1200
11.7k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
11.7k
    break;
1203
11.8k
  case IMAGE_SCN_LNK_OTHER:
1204
11.8k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
11.8k
    break;
1206
11.7k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
11.7k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
11.7k
    break;
1209
14.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
14.8k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
14.8k
        " %s in section %s"),
1216
14.8k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
14.8k
    break;
1218
13.1k
  case IMAGE_SCN_MEM_EXECUTE:
1219
13.1k
    sec_flags |= SEC_CODE;
1220
13.1k
    break;
1221
12.3k
  case IMAGE_SCN_MEM_WRITE:
1222
12.3k
    sec_flags &= ~ SEC_READONLY;
1223
12.3k
    break;
1224
17.5k
  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
17.5k
       if (is_dbg
1231
17.5k
#ifdef _COMMENT
1232
17.5k
        || strcmp (name, _COMMENT) == 0
1233
17.5k
#endif
1234
17.5k
        )
1235
1.27k
      {
1236
1.27k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
1.27k
      }
1238
17.5k
    break;
1239
14.4k
  case IMAGE_SCN_MEM_SHARED:
1240
14.4k
    sec_flags |= SEC_COFF_SHARED;
1241
14.4k
    break;
1242
12.1k
  case IMAGE_SCN_LNK_REMOVE:
1243
12.1k
    if (!is_dbg)
1244
10.7k
      sec_flags |= SEC_EXCLUDE;
1245
12.1k
    break;
1246
12.9k
  case IMAGE_SCN_CNT_CODE:
1247
12.9k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
12.9k
    break;
1249
15.1k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
15.1k
    if (is_dbg)
1251
946
      sec_flags |= SEC_DEBUGGING;
1252
14.1k
    else
1253
14.1k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
15.1k
    break;
1255
12.4k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
12.4k
    sec_flags |= SEC_ALLOC;
1257
12.4k
    break;
1258
19.5k
  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
19.5k
#ifdef COFF_PAGE_SIZE
1266
19.5k
    sec_flags |= SEC_DEBUGGING;
1267
19.5k
#endif
1268
19.5k
    break;
1269
19.2k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
19.2k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
1.34k
      result = false;
1273
19.2k
    break;
1274
171k
  default:
1275
    /* Silently ignore for now.  */
1276
171k
    break;
1277
443k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
443k
      if (unhandled != NULL)
1281
66.2k
  {
1282
66.2k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
66.2k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
66.2k
       abfd, name, unhandled, flag);
1286
66.2k
    result = false;
1287
66.2k
  }
1288
443k
    }
1289
1290
40.9k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
40.9k
      && (startswith (name, ".sbss")
1292
0
    || startswith (name, ".sdata")))
1293
0
    sec_flags |= SEC_SMALL_DATA;
1294
1295
40.9k
#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
40.9k
  if (startswith (name, ".gnu.linkonce"))
1303
0
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
40.9k
#endif
1305
1306
40.9k
  if (flags_ptr)
1307
40.9k
    * flags_ptr = sec_flags;
1308
1309
40.9k
  return result;
1310
40.9k
}
pe-mcore.c:styp_to_sec_flags
Line
Count
Source
1139
492k
{
1140
492k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
492k
  unsigned long styp_flags = internal_s->s_flags;
1142
492k
  flagword sec_flags;
1143
492k
  bool result = true;
1144
492k
  bool is_dbg = false;
1145
1146
492k
  if (startswith (name, DOT_DEBUG)
1147
492k
      || startswith (name, DOT_ZDEBUG)
1148
492k
#ifdef COFF_LONG_SECTION_NAMES
1149
492k
      || startswith (name, GNU_LINKONCE_WI)
1150
492k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
492k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
492k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
492k
      || startswith (name, GNU_DEBUGLINK)
1155
492k
      || startswith (name, GNU_DEBUGALTLINK)
1156
492k
#endif
1157
492k
      || startswith (name, ".stab"))
1158
3.87k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
492k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
492k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
479k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
712k
  while (styp_flags)
1168
220k
    {
1169
220k
      unsigned long flag = styp_flags & - styp_flags;
1170
220k
      char * unhandled = NULL;
1171
1172
220k
      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
220k
      switch (flag)
1179
220k
  {
1180
810
  case STYP_DSECT:
1181
810
    unhandled = "STYP_DSECT";
1182
810
    break;
1183
924
  case STYP_GROUP:
1184
924
    unhandled = "STYP_GROUP";
1185
924
    break;
1186
617
  case STYP_COPY:
1187
617
    unhandled = "STYP_COPY";
1188
617
    break;
1189
1.03k
  case STYP_OVER:
1190
1.03k
    unhandled = "STYP_OVER";
1191
1.03k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
7.03k
  case STYP_NOLOAD:
1194
7.03k
    sec_flags |= SEC_NEVER_LOAD;
1195
7.03k
    break;
1196
0
#endif
1197
13.0k
  case IMAGE_SCN_MEM_READ:
1198
13.0k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
13.0k
    break;
1200
5.31k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
5.31k
    break;
1203
1.14k
  case IMAGE_SCN_LNK_OTHER:
1204
1.14k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
1.14k
    break;
1206
1.15k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
1.15k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
1.15k
    break;
1209
7.37k
  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
7.37k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
7.37k
        " %s in section %s"),
1216
7.37k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
7.37k
    break;
1218
12.1k
  case IMAGE_SCN_MEM_EXECUTE:
1219
12.1k
    sec_flags |= SEC_CODE;
1220
12.1k
    break;
1221
6.04k
  case IMAGE_SCN_MEM_WRITE:
1222
6.04k
    sec_flags &= ~ SEC_READONLY;
1223
6.04k
    break;
1224
12.0k
  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
12.0k
       if (is_dbg
1231
12.0k
#ifdef _COMMENT
1232
12.0k
        || strcmp (name, _COMMENT) == 0
1233
12.0k
#endif
1234
12.0k
        )
1235
1.49k
      {
1236
1.49k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
1.49k
      }
1238
12.0k
    break;
1239
5.35k
  case IMAGE_SCN_MEM_SHARED:
1240
5.35k
    sec_flags |= SEC_COFF_SHARED;
1241
5.35k
    break;
1242
11.1k
  case IMAGE_SCN_LNK_REMOVE:
1243
11.1k
    if (!is_dbg)
1244
10.2k
      sec_flags |= SEC_EXCLUDE;
1245
11.1k
    break;
1246
8.67k
  case IMAGE_SCN_CNT_CODE:
1247
8.67k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
8.67k
    break;
1249
6.18k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
6.18k
    if (is_dbg)
1251
652
      sec_flags |= SEC_DEBUGGING;
1252
5.53k
    else
1253
5.53k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
6.18k
    break;
1255
8.76k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
8.76k
    sec_flags |= SEC_ALLOC;
1257
8.76k
    break;
1258
10.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
10.2k
#ifdef COFF_PAGE_SIZE
1266
10.2k
    sec_flags |= SEC_DEBUGGING;
1267
10.2k
#endif
1268
10.2k
    break;
1269
8.04k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
8.04k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
219
      result = false;
1273
8.04k
    break;
1274
93.7k
  default:
1275
    /* Silently ignore for now.  */
1276
93.7k
    break;
1277
220k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
220k
      if (unhandled != NULL)
1281
5.67k
  {
1282
5.67k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
5.67k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
5.67k
       abfd, name, unhandled, flag);
1286
5.67k
    result = false;
1287
5.67k
  }
1288
220k
    }
1289
1290
492k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
492k
      && (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
492k
  if (flags_ptr)
1307
492k
    * flags_ptr = sec_flags;
1308
1309
492k
  return result;
1310
492k
}
pe-sh.c:styp_to_sec_flags
Line
Count
Source
1139
30.0k
{
1140
30.0k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
30.0k
  unsigned long styp_flags = internal_s->s_flags;
1142
30.0k
  flagword sec_flags;
1143
30.0k
  bool result = true;
1144
30.0k
  bool is_dbg = false;
1145
1146
30.0k
  if (startswith (name, DOT_DEBUG)
1147
30.0k
      || startswith (name, DOT_ZDEBUG)
1148
30.0k
#ifdef COFF_LONG_SECTION_NAMES
1149
30.0k
      || startswith (name, GNU_LINKONCE_WI)
1150
30.0k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
30.0k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
30.0k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
30.0k
      || startswith (name, GNU_DEBUGLINK)
1155
30.0k
      || startswith (name, GNU_DEBUGALTLINK)
1156
30.0k
#endif
1157
30.0k
      || startswith (name, ".stab"))
1158
4.96k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
30.0k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
30.0k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
19.2k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
321k
  while (styp_flags)
1168
291k
    {
1169
291k
      unsigned long flag = styp_flags & - styp_flags;
1170
291k
      char * unhandled = NULL;
1171
1172
291k
      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
291k
      switch (flag)
1179
291k
  {
1180
4.13k
  case STYP_DSECT:
1181
4.13k
    unhandled = "STYP_DSECT";
1182
4.13k
    break;
1183
4.41k
  case STYP_GROUP:
1184
4.41k
    unhandled = "STYP_GROUP";
1185
4.41k
    break;
1186
4.61k
  case STYP_COPY:
1187
4.61k
    unhandled = "STYP_COPY";
1188
4.61k
    break;
1189
4.54k
  case STYP_OVER:
1190
4.54k
    unhandled = "STYP_OVER";
1191
4.54k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
7.47k
  case STYP_NOLOAD:
1194
7.47k
    sec_flags |= SEC_NEVER_LOAD;
1195
7.47k
    break;
1196
0
#endif
1197
10.7k
  case IMAGE_SCN_MEM_READ:
1198
10.7k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
10.7k
    break;
1200
8.32k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
8.32k
    break;
1203
4.94k
  case IMAGE_SCN_LNK_OTHER:
1204
4.94k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
4.94k
    break;
1206
5.24k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
5.24k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
5.24k
    break;
1209
12.2k
  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
12.2k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
12.2k
        " %s in section %s"),
1216
12.2k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
12.2k
    break;
1218
13.3k
  case IMAGE_SCN_MEM_EXECUTE:
1219
13.3k
    sec_flags |= SEC_CODE;
1220
13.3k
    break;
1221
10.4k
  case IMAGE_SCN_MEM_WRITE:
1222
10.4k
    sec_flags &= ~ SEC_READONLY;
1223
10.4k
    break;
1224
12.1k
  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
12.1k
       if (is_dbg
1231
12.1k
#ifdef _COMMENT
1232
12.1k
        || strcmp (name, _COMMENT) == 0
1233
12.1k
#endif
1234
12.1k
        )
1235
3.47k
      {
1236
3.47k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
3.47k
      }
1238
12.1k
    break;
1239
10.3k
  case IMAGE_SCN_MEM_SHARED:
1240
10.3k
    sec_flags |= SEC_COFF_SHARED;
1241
10.3k
    break;
1242
9.71k
  case IMAGE_SCN_LNK_REMOVE:
1243
9.71k
    if (!is_dbg)
1244
6.93k
      sec_flags |= SEC_EXCLUDE;
1245
9.71k
    break;
1246
14.5k
  case IMAGE_SCN_CNT_CODE:
1247
14.5k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
14.5k
    break;
1249
6.00k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
6.00k
    if (is_dbg)
1251
2.69k
      sec_flags |= SEC_DEBUGGING;
1252
3.31k
    else
1253
3.31k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
6.00k
    break;
1255
7.72k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
7.72k
    sec_flags |= SEC_ALLOC;
1257
7.72k
    break;
1258
9.81k
  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
    sec_flags |= SEC_DEBUGGING;
1267
#endif
1268
9.81k
    break;
1269
9.10k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
9.10k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
931
      result = false;
1273
9.10k
    break;
1274
121k
  default:
1275
    /* Silently ignore for now.  */
1276
121k
    break;
1277
291k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
291k
      if (unhandled != NULL)
1281
27.8k
  {
1282
27.8k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
27.8k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
27.8k
       abfd, name, unhandled, flag);
1286
27.8k
    result = false;
1287
27.8k
  }
1288
291k
    }
1289
1290
30.0k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
30.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
  if (startswith (name, ".gnu.linkonce"))
1303
    sec_flags |= SEC_LINK_ONCE | SEC_LINK_DUPLICATES_DISCARD;
1304
#endif
1305
1306
30.0k
  if (flags_ptr)
1307
30.0k
    * flags_ptr = sec_flags;
1308
1309
30.0k
  return result;
1310
30.0k
}
pei-arm-wince.c:styp_to_sec_flags
Line
Count
Source
1139
32.4k
{
1140
32.4k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
32.4k
  unsigned long styp_flags = internal_s->s_flags;
1142
32.4k
  flagword sec_flags;
1143
32.4k
  bool result = true;
1144
32.4k
  bool is_dbg = false;
1145
1146
32.4k
  if (startswith (name, DOT_DEBUG)
1147
32.4k
      || startswith (name, DOT_ZDEBUG)
1148
32.4k
#ifdef COFF_LONG_SECTION_NAMES
1149
32.4k
      || startswith (name, GNU_LINKONCE_WI)
1150
32.4k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
32.4k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
32.4k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
32.4k
      || startswith (name, GNU_DEBUGLINK)
1155
32.4k
      || startswith (name, GNU_DEBUGALTLINK)
1156
32.4k
#endif
1157
32.4k
      || startswith (name, ".stab"))
1158
1.21k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
32.4k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
32.4k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
21.2k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
364k
  while (styp_flags)
1168
332k
    {
1169
332k
      unsigned long flag = styp_flags & - styp_flags;
1170
332k
      char * unhandled = NULL;
1171
1172
332k
      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
332k
      switch (flag)
1179
332k
  {
1180
4.84k
  case STYP_DSECT:
1181
4.84k
    unhandled = "STYP_DSECT";
1182
4.84k
    break;
1183
4.85k
  case STYP_GROUP:
1184
4.85k
    unhandled = "STYP_GROUP";
1185
4.85k
    break;
1186
6.06k
  case STYP_COPY:
1187
6.06k
    unhandled = "STYP_COPY";
1188
6.06k
    break;
1189
6.43k
  case STYP_OVER:
1190
6.43k
    unhandled = "STYP_OVER";
1191
6.43k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
9.61k
  case STYP_NOLOAD:
1194
9.61k
    sec_flags |= SEC_NEVER_LOAD;
1195
9.61k
    break;
1196
0
#endif
1197
11.2k
  case IMAGE_SCN_MEM_READ:
1198
11.2k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
11.2k
    break;
1200
11.2k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
11.2k
    break;
1203
5.47k
  case IMAGE_SCN_LNK_OTHER:
1204
5.47k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
5.47k
    break;
1206
4.70k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
4.70k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
4.70k
    break;
1209
14.7k
  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
14.7k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
14.7k
        " %s in section %s"),
1216
14.7k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
14.7k
    break;
1218
13.5k
  case IMAGE_SCN_MEM_EXECUTE:
1219
13.5k
    sec_flags |= SEC_CODE;
1220
13.5k
    break;
1221
8.77k
  case IMAGE_SCN_MEM_WRITE:
1222
8.77k
    sec_flags &= ~ SEC_READONLY;
1223
8.77k
    break;
1224
13.1k
  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
13.1k
       if (is_dbg
1231
13.1k
#ifdef _COMMENT
1232
13.1k
        || strcmp (name, _COMMENT) == 0
1233
13.1k
#endif
1234
13.1k
        )
1235
813
      {
1236
813
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
813
      }
1238
13.1k
    break;
1239
8.72k
  case IMAGE_SCN_MEM_SHARED:
1240
8.72k
    sec_flags |= SEC_COFF_SHARED;
1241
8.72k
    break;
1242
14.4k
  case IMAGE_SCN_LNK_REMOVE:
1243
14.4k
    if (!is_dbg)
1244
14.2k
      sec_flags |= SEC_EXCLUDE;
1245
14.4k
    break;
1246
12.8k
  case IMAGE_SCN_CNT_CODE:
1247
12.8k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
12.8k
    break;
1249
8.14k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
8.14k
    if (is_dbg)
1251
674
      sec_flags |= SEC_DEBUGGING;
1252
7.47k
    else
1253
7.47k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
8.14k
    break;
1255
6.93k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
6.93k
    sec_flags |= SEC_ALLOC;
1257
6.93k
    break;
1258
13.4k
  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
13.4k
#ifdef COFF_PAGE_SIZE
1266
13.4k
    sec_flags |= SEC_DEBUGGING;
1267
13.4k
#endif
1268
13.4k
    break;
1269
13.6k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
13.6k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
947
      result = false;
1273
13.6k
    break;
1274
139k
  default:
1275
    /* Silently ignore for now.  */
1276
139k
    break;
1277
332k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
332k
      if (unhandled != NULL)
1281
32.3k
  {
1282
32.3k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
32.3k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
32.3k
       abfd, name, unhandled, flag);
1286
32.3k
    result = false;
1287
32.3k
  }
1288
332k
    }
1289
1290
32.4k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
32.4k
      && (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
32.4k
  if (flags_ptr)
1307
32.4k
    * flags_ptr = sec_flags;
1308
1309
32.4k
  return result;
1310
32.4k
}
pei-arm.c:styp_to_sec_flags
Line
Count
Source
1139
38.7k
{
1140
38.7k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
38.7k
  unsigned long styp_flags = internal_s->s_flags;
1142
38.7k
  flagword sec_flags;
1143
38.7k
  bool result = true;
1144
38.7k
  bool is_dbg = false;
1145
1146
38.7k
  if (startswith (name, DOT_DEBUG)
1147
38.7k
      || startswith (name, DOT_ZDEBUG)
1148
38.7k
#ifdef COFF_LONG_SECTION_NAMES
1149
38.7k
      || startswith (name, GNU_LINKONCE_WI)
1150
38.7k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
38.7k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
38.7k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
38.7k
      || startswith (name, GNU_DEBUGLINK)
1155
38.7k
      || startswith (name, GNU_DEBUGALTLINK)
1156
38.7k
#endif
1157
38.7k
      || startswith (name, ".stab"))
1158
1.66k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
38.7k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
38.7k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
25.3k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
411k
  while (styp_flags)
1168
373k
    {
1169
373k
      unsigned long flag = styp_flags & - styp_flags;
1170
373k
      char * unhandled = NULL;
1171
1172
373k
      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
373k
      switch (flag)
1179
373k
  {
1180
5.41k
  case STYP_DSECT:
1181
5.41k
    unhandled = "STYP_DSECT";
1182
5.41k
    break;
1183
5.32k
  case STYP_GROUP:
1184
5.32k
    unhandled = "STYP_GROUP";
1185
5.32k
    break;
1186
6.90k
  case STYP_COPY:
1187
6.90k
    unhandled = "STYP_COPY";
1188
6.90k
    break;
1189
6.87k
  case STYP_OVER:
1190
6.87k
    unhandled = "STYP_OVER";
1191
6.87k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
10.5k
  case STYP_NOLOAD:
1194
10.5k
    sec_flags |= SEC_NEVER_LOAD;
1195
10.5k
    break;
1196
0
#endif
1197
13.4k
  case IMAGE_SCN_MEM_READ:
1198
13.4k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
13.4k
    break;
1200
13.1k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
13.1k
    break;
1203
6.35k
  case IMAGE_SCN_LNK_OTHER:
1204
6.35k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
6.35k
    break;
1206
5.32k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
5.32k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
5.32k
    break;
1209
17.2k
  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
17.2k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
17.2k
        " %s in section %s"),
1216
17.2k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
17.2k
    break;
1218
14.4k
  case IMAGE_SCN_MEM_EXECUTE:
1219
14.4k
    sec_flags |= SEC_CODE;
1220
14.4k
    break;
1221
11.9k
  case IMAGE_SCN_MEM_WRITE:
1222
11.9k
    sec_flags &= ~ SEC_READONLY;
1223
11.9k
    break;
1224
14.6k
  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
14.6k
       if (is_dbg
1231
14.6k
#ifdef _COMMENT
1232
14.6k
        || strcmp (name, _COMMENT) == 0
1233
14.6k
#endif
1234
14.6k
        )
1235
1.15k
      {
1236
1.15k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
1.15k
      }
1238
14.6k
    break;
1239
10.2k
  case IMAGE_SCN_MEM_SHARED:
1240
10.2k
    sec_flags |= SEC_COFF_SHARED;
1241
10.2k
    break;
1242
16.1k
  case IMAGE_SCN_LNK_REMOVE:
1243
16.1k
    if (!is_dbg)
1244
15.6k
      sec_flags |= SEC_EXCLUDE;
1245
16.1k
    break;
1246
14.5k
  case IMAGE_SCN_CNT_CODE:
1247
14.5k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
14.5k
    break;
1249
9.36k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
9.36k
    if (is_dbg)
1251
879
      sec_flags |= SEC_DEBUGGING;
1252
8.49k
    else
1253
8.49k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
9.36k
    break;
1255
9.53k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
9.53k
    sec_flags |= SEC_ALLOC;
1257
9.53k
    break;
1258
14.9k
  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
14.9k
#ifdef COFF_PAGE_SIZE
1266
14.9k
    sec_flags |= SEC_DEBUGGING;
1267
14.9k
#endif
1268
14.9k
    break;
1269
14.8k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
14.8k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
1.31k
      result = false;
1273
14.8k
    break;
1274
151k
  default:
1275
    /* Silently ignore for now.  */
1276
151k
    break;
1277
373k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
373k
      if (unhandled != NULL)
1281
36.2k
  {
1282
36.2k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
36.2k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
36.2k
       abfd, name, unhandled, flag);
1286
36.2k
    result = false;
1287
36.2k
  }
1288
373k
    }
1289
1290
38.7k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
38.7k
      && (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
38.7k
  if (flags_ptr)
1307
38.7k
    * flags_ptr = sec_flags;
1308
1309
38.7k
  return result;
1310
38.7k
}
pei-mcore.c:styp_to_sec_flags
Line
Count
Source
1139
47.8k
{
1140
47.8k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
47.8k
  unsigned long styp_flags = internal_s->s_flags;
1142
47.8k
  flagword sec_flags;
1143
47.8k
  bool result = true;
1144
47.8k
  bool is_dbg = false;
1145
1146
47.8k
  if (startswith (name, DOT_DEBUG)
1147
47.8k
      || startswith (name, DOT_ZDEBUG)
1148
47.8k
#ifdef COFF_LONG_SECTION_NAMES
1149
47.8k
      || startswith (name, GNU_LINKONCE_WI)
1150
47.8k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
47.8k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
47.8k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
47.8k
      || startswith (name, GNU_DEBUGLINK)
1155
47.8k
      || startswith (name, GNU_DEBUGALTLINK)
1156
47.8k
#endif
1157
47.8k
      || startswith (name, ".stab"))
1158
1.18k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
47.8k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
47.8k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
37.1k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
365k
  while (styp_flags)
1168
317k
    {
1169
317k
      unsigned long flag = styp_flags & - styp_flags;
1170
317k
      char * unhandled = NULL;
1171
1172
317k
      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
317k
      switch (flag)
1179
317k
  {
1180
4.82k
  case STYP_DSECT:
1181
4.82k
    unhandled = "STYP_DSECT";
1182
4.82k
    break;
1183
4.68k
  case STYP_GROUP:
1184
4.68k
    unhandled = "STYP_GROUP";
1185
4.68k
    break;
1186
4.05k
  case STYP_COPY:
1187
4.05k
    unhandled = "STYP_COPY";
1188
4.05k
    break;
1189
4.74k
  case STYP_OVER:
1190
4.74k
    unhandled = "STYP_OVER";
1191
4.74k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
9.77k
  case STYP_NOLOAD:
1194
9.77k
    sec_flags |= SEC_NEVER_LOAD;
1195
9.77k
    break;
1196
0
#endif
1197
10.6k
  case IMAGE_SCN_MEM_READ:
1198
10.6k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
10.6k
    break;
1200
13.3k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
13.3k
    break;
1203
3.57k
  case IMAGE_SCN_LNK_OTHER:
1204
3.57k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
3.57k
    break;
1206
3.39k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
3.39k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
3.39k
    break;
1209
13.9k
  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
13.9k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
13.9k
        " %s in section %s"),
1216
13.9k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
13.9k
    break;
1218
13.8k
  case IMAGE_SCN_MEM_EXECUTE:
1219
13.8k
    sec_flags |= SEC_CODE;
1220
13.8k
    break;
1221
10.3k
  case IMAGE_SCN_MEM_WRITE:
1222
10.3k
    sec_flags &= ~ SEC_READONLY;
1223
10.3k
    break;
1224
12.7k
  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
12.7k
       if (is_dbg
1231
12.7k
#ifdef _COMMENT
1232
12.7k
        || strcmp (name, _COMMENT) == 0
1233
12.7k
#endif
1234
12.7k
        )
1235
620
      {
1236
620
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
620
      }
1238
12.7k
    break;
1239
7.02k
  case IMAGE_SCN_MEM_SHARED:
1240
7.02k
    sec_flags |= SEC_COFF_SHARED;
1241
7.02k
    break;
1242
14.4k
  case IMAGE_SCN_LNK_REMOVE:
1243
14.4k
    if (!is_dbg)
1244
14.1k
      sec_flags |= SEC_EXCLUDE;
1245
14.4k
    break;
1246
12.5k
  case IMAGE_SCN_CNT_CODE:
1247
12.5k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
12.5k
    break;
1249
10.5k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
10.5k
    if (is_dbg)
1251
517
      sec_flags |= SEC_DEBUGGING;
1252
9.99k
    else
1253
9.99k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
10.5k
    break;
1255
12.5k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
12.5k
    sec_flags |= SEC_ALLOC;
1257
12.5k
    break;
1258
11.8k
  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
11.8k
#ifdef COFF_PAGE_SIZE
1266
11.8k
    sec_flags |= SEC_DEBUGGING;
1267
11.8k
#endif
1268
11.8k
    break;
1269
9.37k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
9.37k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
811
      result = false;
1273
9.37k
    break;
1274
129k
  default:
1275
    /* Silently ignore for now.  */
1276
129k
    break;
1277
317k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
317k
      if (unhandled != NULL)
1281
25.2k
  {
1282
25.2k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
25.2k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
25.2k
       abfd, name, unhandled, flag);
1286
25.2k
    result = false;
1287
25.2k
  }
1288
317k
    }
1289
1290
47.8k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
47.8k
      && (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
47.8k
  if (flags_ptr)
1307
47.8k
    * flags_ptr = sec_flags;
1308
1309
47.8k
  return result;
1310
47.8k
}
pei-sh.c:styp_to_sec_flags
Line
Count
Source
1139
50.7k
{
1140
50.7k
  struct internal_scnhdr *internal_s = (struct internal_scnhdr *) hdr;
1141
50.7k
  unsigned long styp_flags = internal_s->s_flags;
1142
50.7k
  flagword sec_flags;
1143
50.7k
  bool result = true;
1144
50.7k
  bool is_dbg = false;
1145
1146
50.7k
  if (startswith (name, DOT_DEBUG)
1147
50.7k
      || startswith (name, DOT_ZDEBUG)
1148
50.7k
#ifdef COFF_LONG_SECTION_NAMES
1149
50.7k
      || startswith (name, GNU_LINKONCE_WI)
1150
50.7k
      || startswith (name, GNU_LINKONCE_WT)
1151
      /* FIXME: These definitions ought to be in a header file.  */
1152
50.7k
#define GNU_DEBUGLINK   ".gnu_debuglink"
1153
50.7k
#define GNU_DEBUGALTLINK  ".gnu_debugaltlink"
1154
50.7k
      || startswith (name, GNU_DEBUGLINK)
1155
50.7k
      || startswith (name, GNU_DEBUGALTLINK)
1156
50.7k
#endif
1157
50.7k
      || startswith (name, ".stab"))
1158
2.19k
    is_dbg = true;
1159
  /* Assume read only unless IMAGE_SCN_MEM_WRITE is specified.  */
1160
50.7k
  sec_flags = SEC_READONLY;
1161
1162
  /* If section disallows read, then set the NOREAD flag. */
1163
50.7k
  if ((styp_flags & IMAGE_SCN_MEM_READ) == 0)
1164
40.5k
    sec_flags |= SEC_COFF_NOREAD;
1165
1166
  /* Process each flag bit in styp_flags in turn.  */
1167
333k
  while (styp_flags)
1168
283k
    {
1169
283k
      unsigned long flag = styp_flags & - styp_flags;
1170
283k
      char * unhandled = NULL;
1171
1172
283k
      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
283k
      switch (flag)
1179
283k
  {
1180
2.82k
  case STYP_DSECT:
1181
2.82k
    unhandled = "STYP_DSECT";
1182
2.82k
    break;
1183
2.76k
  case STYP_GROUP:
1184
2.76k
    unhandled = "STYP_GROUP";
1185
2.76k
    break;
1186
2.63k
  case STYP_COPY:
1187
2.63k
    unhandled = "STYP_COPY";
1188
2.63k
    break;
1189
3.37k
  case STYP_OVER:
1190
3.37k
    unhandled = "STYP_OVER";
1191
3.37k
    break;
1192
0
#ifdef SEC_NEVER_LOAD
1193
9.02k
  case STYP_NOLOAD:
1194
9.02k
    sec_flags |= SEC_NEVER_LOAD;
1195
9.02k
    break;
1196
0
#endif
1197
10.1k
  case IMAGE_SCN_MEM_READ:
1198
10.1k
    sec_flags &= ~SEC_COFF_NOREAD;
1199
10.1k
    break;
1200
11.2k
  case IMAGE_SCN_TYPE_NO_PAD:
1201
    /* Skip.  */
1202
11.2k
    break;
1203
2.86k
  case IMAGE_SCN_LNK_OTHER:
1204
2.86k
    unhandled = "IMAGE_SCN_LNK_OTHER";
1205
2.86k
    break;
1206
2.25k
  case IMAGE_SCN_MEM_NOT_CACHED:
1207
2.25k
    unhandled = "IMAGE_SCN_MEM_NOT_CACHED";
1208
2.25k
    break;
1209
12.7k
  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
12.7k
    _bfd_error_handler (_("%pB: warning: ignoring section flag"
1215
12.7k
        " %s in section %s"),
1216
12.7k
            abfd, "IMAGE_SCN_MEM_NOT_PAGED", name);
1217
12.7k
    break;
1218
13.1k
  case IMAGE_SCN_MEM_EXECUTE:
1219
13.1k
    sec_flags |= SEC_CODE;
1220
13.1k
    break;
1221
10.6k
  case IMAGE_SCN_MEM_WRITE:
1222
10.6k
    sec_flags &= ~ SEC_READONLY;
1223
10.6k
    break;
1224
17.7k
  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
17.7k
       if (is_dbg
1231
17.7k
#ifdef _COMMENT
1232
17.7k
        || strcmp (name, _COMMENT) == 0
1233
17.7k
#endif
1234
17.7k
        )
1235
1.81k
      {
1236
1.81k
        sec_flags |= SEC_DEBUGGING | SEC_READONLY;
1237
1.81k
      }
1238
17.7k
    break;
1239
6.25k
  case IMAGE_SCN_MEM_SHARED:
1240
6.25k
    sec_flags |= SEC_COFF_SHARED;
1241
6.25k
    break;
1242
14.9k
  case IMAGE_SCN_LNK_REMOVE:
1243
14.9k
    if (!is_dbg)
1244
14.1k
      sec_flags |= SEC_EXCLUDE;
1245
14.9k
    break;
1246
10.0k
  case IMAGE_SCN_CNT_CODE:
1247
10.0k
    sec_flags |= SEC_CODE | SEC_ALLOC | SEC_LOAD;
1248
10.0k
    break;
1249
6.09k
  case IMAGE_SCN_CNT_INITIALIZED_DATA:
1250
6.09k
    if (is_dbg)
1251
807
      sec_flags |= SEC_DEBUGGING;
1252
5.28k
    else
1253
5.28k
      sec_flags |= SEC_DATA | SEC_ALLOC | SEC_LOAD;
1254
6.09k
    break;
1255
11.3k
  case IMAGE_SCN_CNT_UNINITIALIZED_DATA:
1256
11.3k
    sec_flags |= SEC_ALLOC;
1257
11.3k
    break;
1258
12.0k
  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
12.0k
#ifdef COFF_PAGE_SIZE
1266
12.0k
    sec_flags |= SEC_DEBUGGING;
1267
12.0k
#endif
1268
12.0k
    break;
1269
11.3k
  case IMAGE_SCN_LNK_COMDAT:
1270
    /* COMDAT gets very special treatment.  */
1271
11.3k
    if (!handle_COMDAT (abfd, &sec_flags, hdr, name, section))
1272
1.21k
      result = false;
1273
11.3k
    break;
1274
109k
  default:
1275
    /* Silently ignore for now.  */
1276
109k
    break;
1277
283k
  }
1278
1279
      /* If the section flag was not handled, report it here.  */
1280
283k
      if (unhandled != NULL)
1281
16.7k
  {
1282
16.7k
    _bfd_error_handler
1283
      /* xgettext:c-format */
1284
16.7k
      (_("%pB (%s): section flag %s (%#lx) ignored"),
1285
16.7k
       abfd, name, unhandled, flag);
1286
16.7k
    result = false;
1287
16.7k
  }
1288
283k
    }
1289
1290
50.7k
  if ((bfd_applicable_section_flags (abfd) & SEC_SMALL_DATA) != 0
1291
50.7k
      && (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
50.7k
  if (flags_ptr)
1307
50.7k
    * flags_ptr = sec_flags;
1308
1309
50.7k
  return result;
1310
50.7k
}
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
16.6M
{
1635
16.6M
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
16.6M
  if (BADMAG (*internal_f))
1638
16.2M
    return false;
1639
1640
451k
  return true;
1641
16.6M
}
pei-i386.c:coff_bad_format_hook
Line
Count
Source
1634
177k
{
1635
177k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
177k
  if (BADMAG (*internal_f))
1638
154k
    return false;
1639
1640
23.3k
  return true;
1641
177k
}
pe-x86_64.c:coff_bad_format_hook
Line
Count
Source
1634
1.11M
{
1635
1.11M
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
1.11M
  if (BADMAG (*internal_f))
1638
1.09M
    return false;
1639
1640
27.7k
  return true;
1641
1.11M
}
pei-x86_64.c:coff_bad_format_hook
Line
Count
Source
1634
183k
{
1635
183k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
183k
  if (BADMAG (*internal_f))
1638
147k
    return false;
1639
1640
35.6k
  return true;
1641
183k
}
coff-x86_64.c:coff_bad_format_hook
Line
Count
Source
1634
585k
{
1635
585k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
585k
  if (BADMAG (*internal_f))
1638
562k
    return false;
1639
1640
22.5k
  return true;
1641
585k
}
Unexecuted instantiation: coff64-rs6000.c:coff_bad_format_hook
pei-aarch64.c:coff_bad_format_hook
Line
Count
Source
1634
173k
{
1635
173k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
173k
  if (BADMAG (*internal_f))
1638
159k
    return false;
1639
1640
14.1k
  return true;
1641
173k
}
pe-aarch64.c:coff_bad_format_hook
Line
Count
Source
1634
585k
{
1635
585k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
585k
  if (BADMAG (*internal_f))
1638
579k
    return false;
1639
1640
5.96k
  return true;
1641
585k
}
pei-ia64.c:coff_bad_format_hook
Line
Count
Source
1634
173k
{
1635
173k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
173k
  if (BADMAG (*internal_f))
1638
147k
    return false;
1639
1640
26.4k
  return true;
1641
173k
}
pei-loongarch64.c:coff_bad_format_hook
Line
Count
Source
1634
173k
{
1635
173k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
173k
  if (BADMAG (*internal_f))
1638
152k
    return false;
1639
1640
20.9k
  return true;
1641
173k
}
cf-i386lynx.c:coff_bad_format_hook
Line
Count
Source
1634
584k
{
1635
584k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
584k
  if (BADMAG (*internal_f))
1638
567k
    return false;
1639
1640
17.9k
  return true;
1641
584k
}
coff-go32.c:coff_bad_format_hook
Line
Count
Source
1634
584k
{
1635
584k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
584k
  if (BADMAG (*internal_f))
1638
567k
    return false;
1639
1640
17.9k
  return true;
1641
584k
}
coff-i386.c:coff_bad_format_hook
Line
Count
Source
1634
584k
{
1635
584k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
584k
  if (BADMAG (*internal_f))
1638
567k
    return false;
1639
1640
17.9k
  return true;
1641
584k
}
coff-rs6000.c:coff_bad_format_hook
Line
Count
Source
1634
584k
{
1635
584k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
584k
  if (BADMAG (*internal_f))
1638
560k
    return false;
1639
1640
24.6k
  return true;
1641
584k
}
coff-sh.c:coff_bad_format_hook
Line
Count
Source
1634
2.33M
{
1635
2.33M
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
2.33M
  if (BADMAG (*internal_f))
1638
2.31M
    return false;
1639
1640
23.3k
  return true;
1641
2.33M
}
Unexecuted instantiation: coff-stgo32.c:coff_bad_format_hook
coff-tic30.c:coff_bad_format_hook
Line
Count
Source
1634
585k
{
1635
585k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
585k
  if (BADMAG (*internal_f))
1638
571k
    return false;
1639
1640
13.2k
  return true;
1641
585k
}
Unexecuted instantiation: coff-tic4x.c:coff_bad_format_hook
coff-tic54x.c:coff_bad_format_hook
Line
Count
Source
1634
1.16M
{
1635
1.16M
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
1.16M
  if (BADMAG (*internal_f))
1638
1.16M
    return false;
1639
1640
0
  return true;
1641
1.16M
}
coff-z80.c:coff_bad_format_hook
Line
Count
Source
1634
585k
{
1635
585k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
585k
  if (BADMAG (*internal_f))
1638
576k
    return false;
1639
1640
8.74k
  return true;
1641
585k
}
coff-z8k.c:coff_bad_format_hook
Line
Count
Source
1634
585k
{
1635
585k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
585k
  if (BADMAG (*internal_f))
1638
576k
    return false;
1639
1640
8.91k
  return true;
1641
585k
}
pe-arm-wince.c:coff_bad_format_hook
Line
Count
Source
1634
1.16M
{
1635
1.16M
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
1.16M
  if (BADMAG (*internal_f))
1638
1.16M
    return false;
1639
1640
5.26k
  return true;
1641
1.16M
}
pe-arm.c:coff_bad_format_hook
Line
Count
Source
1634
1.16M
{
1635
1.16M
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
1.16M
  if (BADMAG (*internal_f))
1638
1.16M
    return false;
1639
1640
5.26k
  return true;
1641
1.16M
}
pe-i386.c:coff_bad_format_hook
Line
Count
Source
1634
1.11M
{
1635
1.11M
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
1.11M
  if (BADMAG (*internal_f))
1638
1.09M
    return false;
1639
1640
18.2k
  return true;
1641
1.11M
}
pe-mcore.c:coff_bad_format_hook
Line
Count
Source
1634
1.17M
{
1635
1.17M
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
1.17M
  if (BADMAG (*internal_f))
1638
1.16M
    return false;
1639
1640
8.63k
  return true;
1641
1.17M
}
pe-sh.c:coff_bad_format_hook
Line
Count
Source
1634
585k
{
1635
585k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
585k
  if (BADMAG (*internal_f))
1638
573k
    return false;
1639
1640
11.6k
  return true;
1641
585k
}
pei-arm-wince.c:coff_bad_format_hook
Line
Count
Source
1634
173k
{
1635
173k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
173k
  if (BADMAG (*internal_f))
1638
146k
    return false;
1639
1640
26.8k
  return true;
1641
173k
}
pei-arm.c:coff_bad_format_hook
Line
Count
Source
1634
173k
{
1635
173k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
173k
  if (BADMAG (*internal_f))
1638
146k
    return false;
1639
1640
26.9k
  return true;
1641
173k
}
pei-mcore.c:coff_bad_format_hook
Line
Count
Source
1634
173k
{
1635
173k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
173k
  if (BADMAG (*internal_f))
1638
151k
    return false;
1639
1640
22.6k
  return true;
1641
173k
}
pei-sh.c:coff_bad_format_hook
Line
Count
Source
1634
173k
{
1635
173k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1636
1637
173k
  if (BADMAG (*internal_f))
1638
157k
    return false;
1639
1640
16.6k
  return true;
1641
173k
}
1642
1643
#ifdef TICOFF
1644
static bool
1645
ticoff0_bad_format_hook (bfd *abfd ATTRIBUTE_UNUSED, void * filehdr)
1646
1.17M
{
1647
1.17M
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1648
1649
1.17M
  if (COFF0_BADMAG (*internal_f))
1650
1.14M
    return false;
1651
1652
29.1k
  return true;
1653
1.17M
}
Unexecuted instantiation: coff-tic4x.c:ticoff0_bad_format_hook
coff-tic54x.c:ticoff0_bad_format_hook
Line
Count
Source
1646
1.17M
{
1647
1.17M
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1648
1649
1.17M
  if (COFF0_BADMAG (*internal_f))
1650
1.14M
    return false;
1651
1652
29.1k
  return true;
1653
1.17M
}
1654
#endif
1655
1656
#ifdef TICOFF
1657
static bool
1658
ticoff1_bad_format_hook (bfd *abfd ATTRIBUTE_UNUSED, void * filehdr)
1659
1.16M
{
1660
1.16M
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1661
1662
1.16M
  if (COFF1_BADMAG (*internal_f))
1663
1.16M
    return false;
1664
1665
0
  return true;
1666
1.16M
}
Unexecuted instantiation: coff-tic4x.c:ticoff1_bad_format_hook
coff-tic54x.c:ticoff1_bad_format_hook
Line
Count
Source
1659
1.16M
{
1660
1.16M
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
1661
1662
1.16M
  if (COFF1_BADMAG (*internal_f))
1663
1.16M
    return false;
1664
1665
0
  return true;
1666
1.16M
}
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
88.2M
{
1678
88.2M
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
88.2M
  unsigned int i;
1680
1681
522M
  for (i = 0; i < table_size; ++i)
1682
434M
    {
1683
434M
      const char *secname = bfd_section_name (section);
1684
1685
434M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
434M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
434M
    : strncmp (alignment_table[i].name, secname,
1688
256M
         alignment_table[i].comparison_length) == 0)
1689
289k
  break;
1690
434M
    }
1691
88.2M
  if (i >= table_size)
1692
87.9M
    return;
1693
1694
289k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
289k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
124k
    return;
1697
1698
164k
  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
164k
      )
1703
0
    return;
1704
1705
164k
  section->alignment_power = alignment_table[i].alignment_power;
1706
164k
}
pei-i386.c:coff_set_custom_section_alignment
Line
Count
Source
1677
42.3k
{
1678
42.3k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
42.3k
  unsigned int i;
1680
1681
340k
  for (i = 0; i < table_size; ++i)
1682
303k
    {
1683
303k
      const char *secname = bfd_section_name (section);
1684
1685
303k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
303k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
303k
    : strncmp (alignment_table[i].name, secname,
1688
192k
         alignment_table[i].comparison_length) == 0)
1689
5.93k
  break;
1690
303k
    }
1691
42.3k
  if (i >= table_size)
1692
36.3k
    return;
1693
1694
5.93k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
5.93k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
762
    return;
1697
1698
5.17k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
5.17k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
5.17k
      && default_alignment > alignment_table[i].default_alignment_max
1701
5.17k
#endif
1702
5.17k
      )
1703
0
    return;
1704
1705
5.17k
  section->alignment_power = alignment_table[i].alignment_power;
1706
5.17k
}
pe-x86_64.c:coff_set_custom_section_alignment
Line
Count
Source
1677
62.0k
{
1678
62.0k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
62.0k
  unsigned int i;
1680
1681
839k
  for (i = 0; i < table_size; ++i)
1682
784k
    {
1683
784k
      const char *secname = bfd_section_name (section);
1684
1685
784k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
784k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
784k
    : strncmp (alignment_table[i].name, secname,
1688
550k
         alignment_table[i].comparison_length) == 0)
1689
6.86k
  break;
1690
784k
    }
1691
62.0k
  if (i >= table_size)
1692
55.2k
    return;
1693
1694
6.86k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
6.86k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
3.58k
    return;
1697
1698
3.28k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
3.28k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
3.28k
      && default_alignment > alignment_table[i].default_alignment_max
1701
3.28k
#endif
1702
3.28k
      )
1703
0
    return;
1704
1705
3.28k
  section->alignment_power = alignment_table[i].alignment_power;
1706
3.28k
}
pei-x86_64.c:coff_set_custom_section_alignment
Line
Count
Source
1677
100k
{
1678
100k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
100k
  unsigned int i;
1680
1681
1.18M
  for (i = 0; i < table_size; ++i)
1682
1.11M
    {
1683
1.11M
      const char *secname = bfd_section_name (section);
1684
1685
1.11M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
1.11M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
1.11M
    : strncmp (alignment_table[i].name, secname,
1688
763k
         alignment_table[i].comparison_length) == 0)
1689
23.5k
  break;
1690
1.11M
    }
1691
100k
  if (i >= table_size)
1692
76.4k
    return;
1693
1694
23.5k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
23.5k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
8.88k
    return;
1697
1698
14.6k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
14.6k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
14.6k
      && default_alignment > alignment_table[i].default_alignment_max
1701
14.6k
#endif
1702
14.6k
      )
1703
0
    return;
1704
1705
14.6k
  section->alignment_power = alignment_table[i].alignment_power;
1706
14.6k
}
coff-x86_64.c:coff_set_custom_section_alignment
Line
Count
Source
1677
1.67M
{
1678
1.67M
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
1.67M
  unsigned int i;
1680
1681
8.37M
  for (i = 0; i < table_size; ++i)
1682
6.70M
    {
1683
6.70M
      const char *secname = bfd_section_name (section);
1684
1685
6.70M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
6.70M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
6.70M
    : strncmp (alignment_table[i].name, secname,
1688
3.35M
         alignment_table[i].comparison_length) == 0)
1689
9.97k
  break;
1690
6.70M
    }
1691
1.67M
  if (i >= table_size)
1692
1.66M
    return;
1693
1694
9.97k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
9.97k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
6.76k
    return;
1697
1698
3.21k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
3.21k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
3.21k
      && default_alignment > alignment_table[i].default_alignment_max
1701
3.21k
#endif
1702
3.21k
      )
1703
0
    return;
1704
1705
3.21k
  section->alignment_power = alignment_table[i].alignment_power;
1706
3.21k
}
coff64-rs6000.c:coff_set_custom_section_alignment
Line
Count
Source
1677
3.93M
{
1678
3.93M
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
3.93M
  unsigned int i;
1680
1681
19.6M
  for (i = 0; i < table_size; ++i)
1682
15.7M
    {
1683
15.7M
      const char *secname = bfd_section_name (section);
1684
1685
15.7M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
15.7M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
15.7M
    : strncmp (alignment_table[i].name, secname,
1688
7.86M
         alignment_table[i].comparison_length) == 0)
1689
14.3k
  break;
1690
15.7M
    }
1691
3.93M
  if (i >= table_size)
1692
3.92M
    return;
1693
1694
14.3k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
14.3k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
0
    return;
1697
1698
14.3k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
14.3k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
14.3k
      && default_alignment > alignment_table[i].default_alignment_max
1701
14.3k
#endif
1702
14.3k
      )
1703
0
    return;
1704
1705
14.3k
  section->alignment_power = alignment_table[i].alignment_power;
1706
14.3k
}
pei-aarch64.c:coff_set_custom_section_alignment
Line
Count
Source
1677
33.9k
{
1678
33.9k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
33.9k
  unsigned int i;
1680
1681
424k
  for (i = 0; i < table_size; ++i)
1682
393k
    {
1683
393k
      const char *secname = bfd_section_name (section);
1684
1685
393k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
393k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
393k
    : strncmp (alignment_table[i].name, secname,
1688
162k
         alignment_table[i].comparison_length) == 0)
1689
2.73k
  break;
1690
393k
    }
1691
33.9k
  if (i >= table_size)
1692
31.2k
    return;
1693
1694
2.73k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
2.73k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
585
    return;
1697
1698
2.15k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
2.15k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
2.15k
      && default_alignment > alignment_table[i].default_alignment_max
1701
2.15k
#endif
1702
2.15k
      )
1703
0
    return;
1704
1705
2.15k
  section->alignment_power = alignment_table[i].alignment_power;
1706
2.15k
}
pe-aarch64.c:coff_set_custom_section_alignment
Line
Count
Source
1677
14.3k
{
1678
14.3k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
14.3k
  unsigned int i;
1680
1681
181k
  for (i = 0; i < table_size; ++i)
1682
168k
    {
1683
168k
      const char *secname = bfd_section_name (section);
1684
1685
168k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
168k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
168k
    : strncmp (alignment_table[i].name, secname,
1688
69.9k
         alignment_table[i].comparison_length) == 0)
1689
1.02k
  break;
1690
168k
    }
1691
14.3k
  if (i >= table_size)
1692
13.3k
    return;
1693
1694
1.02k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
1.02k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
345
    return;
1697
1698
682
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
682
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
682
      && default_alignment > alignment_table[i].default_alignment_max
1701
682
#endif
1702
682
      )
1703
0
    return;
1704
1705
682
  section->alignment_power = alignment_table[i].alignment_power;
1706
682
}
pei-ia64.c:coff_set_custom_section_alignment
Line
Count
Source
1677
55.5k
{
1678
55.5k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
55.5k
  unsigned int i;
1680
1681
266k
  for (i = 0; i < table_size; ++i)
1682
214k
    {
1683
214k
      const char *secname = bfd_section_name (section);
1684
1685
214k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
214k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
214k
    : strncmp (alignment_table[i].name, secname,
1688
110k
         alignment_table[i].comparison_length) == 0)
1689
3.80k
  break;
1690
214k
    }
1691
55.5k
  if (i >= table_size)
1692
51.7k
    return;
1693
1694
3.80k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
3.80k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
3.56k
    return;
1697
1698
240
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
240
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
240
      && default_alignment > alignment_table[i].default_alignment_max
1701
240
#endif
1702
240
      )
1703
0
    return;
1704
1705
240
  section->alignment_power = alignment_table[i].alignment_power;
1706
240
}
pei-loongarch64.c:coff_set_custom_section_alignment
Line
Count
Source
1677
110k
{
1678
110k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
110k
  unsigned int i;
1680
1681
1.39M
  for (i = 0; i < table_size; ++i)
1682
1.28M
    {
1683
1.28M
      const char *secname = bfd_section_name (section);
1684
1685
1.28M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
1.28M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
1.28M
    : strncmp (alignment_table[i].name, secname,
1688
529k
         alignment_table[i].comparison_length) == 0)
1689
6.29k
  break;
1690
1.28M
    }
1691
110k
  if (i >= table_size)
1692
104k
    return;
1693
1694
6.29k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
6.29k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
446
    return;
1697
1698
5.84k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
5.84k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
5.84k
      && default_alignment > alignment_table[i].default_alignment_max
1701
5.84k
#endif
1702
5.84k
      )
1703
0
    return;
1704
1705
5.84k
  section->alignment_power = alignment_table[i].alignment_power;
1706
5.84k
}
cf-i386lynx.c:coff_set_custom_section_alignment
Line
Count
Source
1677
9.07M
{
1678
9.07M
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
9.07M
  unsigned int i;
1680
1681
45.3M
  for (i = 0; i < table_size; ++i)
1682
36.2M
    {
1683
36.2M
      const char *secname = bfd_section_name (section);
1684
1685
36.2M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
36.2M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
36.2M
    : strncmp (alignment_table[i].name, secname,
1688
18.1M
         alignment_table[i].comparison_length) == 0)
1689
19.4k
  break;
1690
36.2M
    }
1691
9.07M
  if (i >= table_size)
1692
9.05M
    return;
1693
1694
19.4k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
19.4k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
15.1k
    return;
1697
1698
4.29k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
4.29k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
4.29k
      && default_alignment > alignment_table[i].default_alignment_max
1701
4.29k
#endif
1702
4.29k
      )
1703
0
    return;
1704
1705
4.29k
  section->alignment_power = alignment_table[i].alignment_power;
1706
4.29k
}
coff-go32.c:coff_set_custom_section_alignment
Line
Count
Source
1677
7.13M
{
1678
7.13M
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
7.13M
  unsigned int i;
1680
1681
113M
  for (i = 0; i < table_size; ++i)
1682
106M
    {
1683
106M
      const char *secname = bfd_section_name (section);
1684
1685
106M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
106M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
106M
    : strncmp (alignment_table[i].name, secname,
1688
92.6M
         alignment_table[i].comparison_length) == 0)
1689
37.3k
  break;
1690
106M
    }
1691
7.13M
  if (i >= table_size)
1692
7.10M
    return;
1693
1694
37.3k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
37.3k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
12.5k
    return;
1697
1698
24.7k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
24.7k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
24.7k
      && default_alignment > alignment_table[i].default_alignment_max
1701
24.7k
#endif
1702
24.7k
      )
1703
0
    return;
1704
1705
24.7k
  section->alignment_power = alignment_table[i].alignment_power;
1706
24.7k
}
coff-i386.c:coff_set_custom_section_alignment
Line
Count
Source
1677
9.07M
{
1678
9.07M
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
9.07M
  unsigned int i;
1680
1681
45.3M
  for (i = 0; i < table_size; ++i)
1682
36.2M
    {
1683
36.2M
      const char *secname = bfd_section_name (section);
1684
1685
36.2M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
36.2M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
36.2M
    : strncmp (alignment_table[i].name, secname,
1688
18.1M
         alignment_table[i].comparison_length) == 0)
1689
19.4k
  break;
1690
36.2M
    }
1691
9.07M
  if (i >= table_size)
1692
9.05M
    return;
1693
1694
19.4k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
19.4k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
15.1k
    return;
1697
1698
4.29k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
4.29k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
4.29k
      && default_alignment > alignment_table[i].default_alignment_max
1701
4.29k
#endif
1702
4.29k
      )
1703
0
    return;
1704
1705
4.29k
  section->alignment_power = alignment_table[i].alignment_power;
1706
4.29k
}
coff-rs6000.c:coff_set_custom_section_alignment
Line
Count
Source
1677
18.8M
{
1678
18.8M
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
18.8M
  unsigned int i;
1680
1681
94.1M
  for (i = 0; i < table_size; ++i)
1682
75.3M
    {
1683
75.3M
      const char *secname = bfd_section_name (section);
1684
1685
75.3M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
75.3M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
75.3M
    : strncmp (alignment_table[i].name, secname,
1688
37.6M
         alignment_table[i].comparison_length) == 0)
1689
30.5k
  break;
1690
75.3M
    }
1691
18.8M
  if (i >= table_size)
1692
18.8M
    return;
1693
1694
30.5k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
30.5k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
0
    return;
1697
1698
30.5k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
30.5k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
30.5k
      && default_alignment > alignment_table[i].default_alignment_max
1701
30.5k
#endif
1702
30.5k
      )
1703
0
    return;
1704
1705
30.5k
  section->alignment_power = alignment_table[i].alignment_power;
1706
30.5k
}
coff-sh.c:coff_set_custom_section_alignment
Line
Count
Source
1677
6.69M
{
1678
6.69M
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
6.69M
  unsigned int i;
1680
1681
33.4M
  for (i = 0; i < table_size; ++i)
1682
26.7M
    {
1683
26.7M
      const char *secname = bfd_section_name (section);
1684
1685
26.7M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
26.7M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
26.7M
    : strncmp (alignment_table[i].name, secname,
1688
13.3M
         alignment_table[i].comparison_length) == 0)
1689
19.0k
  break;
1690
26.7M
    }
1691
6.69M
  if (i >= table_size)
1692
6.67M
    return;
1693
1694
19.0k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
19.0k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
0
    return;
1697
1698
19.0k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
19.0k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
19.0k
      && default_alignment > alignment_table[i].default_alignment_max
1701
19.0k
#endif
1702
19.0k
      )
1703
0
    return;
1704
1705
19.0k
  section->alignment_power = alignment_table[i].alignment_power;
1706
19.0k
}
Unexecuted instantiation: coff-stgo32.c:coff_set_custom_section_alignment
coff-tic30.c:coff_set_custom_section_alignment
Line
Count
Source
1677
17.9M
{
1678
17.9M
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
17.9M
  unsigned int i;
1680
1681
89.7M
  for (i = 0; i < table_size; ++i)
1682
71.8M
    {
1683
71.8M
      const char *secname = bfd_section_name (section);
1684
1685
71.8M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
71.8M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
71.8M
    : strncmp (alignment_table[i].name, secname,
1688
35.9M
         alignment_table[i].comparison_length) == 0)
1689
29.2k
  break;
1690
71.8M
    }
1691
17.9M
  if (i >= table_size)
1692
17.9M
    return;
1693
1694
29.2k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
29.2k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
21.7k
    return;
1697
1698
7.52k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
7.52k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
7.52k
      && default_alignment > alignment_table[i].default_alignment_max
1701
7.52k
#endif
1702
7.52k
      )
1703
0
    return;
1704
1705
7.52k
  section->alignment_power = alignment_table[i].alignment_power;
1706
7.52k
}
Unexecuted instantiation: coff-tic4x.c:coff_set_custom_section_alignment
coff-tic54x.c:coff_set_custom_section_alignment
Line
Count
Source
1677
5.33M
{
1678
5.33M
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
5.33M
  unsigned int i;
1680
1681
26.6M
  for (i = 0; i < table_size; ++i)
1682
21.3M
    {
1683
21.3M
      const char *secname = bfd_section_name (section);
1684
1685
21.3M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
21.3M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
21.3M
    : strncmp (alignment_table[i].name, secname,
1688
10.6M
         alignment_table[i].comparison_length) == 0)
1689
10.4k
  break;
1690
21.3M
    }
1691
5.33M
  if (i >= table_size)
1692
5.32M
    return;
1693
1694
10.4k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
10.4k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
10.4k
    return;
1697
1698
0
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
      && default_alignment > alignment_table[i].default_alignment_max
1701
#endif
1702
0
      )
1703
0
    return;
1704
1705
0
  section->alignment_power = alignment_table[i].alignment_power;
1706
0
}
coff-z80.c:coff_set_custom_section_alignment
Line
Count
Source
1677
440k
{
1678
440k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
440k
  unsigned int i;
1680
1681
2.19M
  for (i = 0; i < table_size; ++i)
1682
1.75M
    {
1683
1.75M
      const char *secname = bfd_section_name (section);
1684
1685
1.75M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
1.75M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
1.75M
    : strncmp (alignment_table[i].name, secname,
1688
879k
         alignment_table[i].comparison_length) == 0)
1689
2.61k
  break;
1690
1.75M
    }
1691
440k
  if (i >= table_size)
1692
437k
    return;
1693
1694
2.61k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
2.61k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
2.61k
    return;
1697
1698
0
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
      && default_alignment > alignment_table[i].default_alignment_max
1701
#endif
1702
0
      )
1703
0
    return;
1704
1705
0
  section->alignment_power = alignment_table[i].alignment_power;
1706
0
}
coff-z8k.c:coff_set_custom_section_alignment
Line
Count
Source
1677
6.84M
{
1678
6.84M
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
6.84M
  unsigned int i;
1680
1681
34.1M
  for (i = 0; i < table_size; ++i)
1682
27.3M
    {
1683
27.3M
      const char *secname = bfd_section_name (section);
1684
1685
27.3M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
27.3M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
27.3M
    : strncmp (alignment_table[i].name, secname,
1688
13.6M
         alignment_table[i].comparison_length) == 0)
1689
17.0k
  break;
1690
27.3M
    }
1691
6.84M
  if (i >= table_size)
1692
6.82M
    return;
1693
1694
17.0k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
17.0k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
12.0k
    return;
1697
1698
5.05k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
5.05k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
5.05k
      && default_alignment > alignment_table[i].default_alignment_max
1701
5.05k
#endif
1702
5.05k
      )
1703
0
    return;
1704
1705
5.05k
  section->alignment_power = alignment_table[i].alignment_power;
1706
5.05k
}
pe-arm-wince.c:coff_set_custom_section_alignment
Line
Count
Source
1677
10.2k
{
1678
10.2k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
10.2k
  unsigned int i;
1680
1681
133k
  for (i = 0; i < table_size; ++i)
1682
124k
    {
1683
124k
      const char *secname = bfd_section_name (section);
1684
1685
124k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
124k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
124k
    : strncmp (alignment_table[i].name, secname,
1688
56.2k
         alignment_table[i].comparison_length) == 0)
1689
1.63k
  break;
1690
124k
    }
1691
10.2k
  if (i >= table_size)
1692
8.61k
    return;
1693
1694
1.63k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
1.63k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
212
    return;
1697
1698
1.42k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
1.42k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
1.42k
      && default_alignment > alignment_table[i].default_alignment_max
1701
1.42k
#endif
1702
1.42k
      )
1703
0
    return;
1704
1705
1.42k
  section->alignment_power = alignment_table[i].alignment_power;
1706
1.42k
}
pe-arm.c:coff_set_custom_section_alignment
Line
Count
Source
1677
10.1k
{
1678
10.1k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
10.1k
  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
55.6k
         alignment_table[i].comparison_length) == 0)
1689
1.63k
  break;
1690
123k
    }
1691
10.1k
  if (i >= table_size)
1692
8.51k
    return;
1693
1694
1.63k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
1.63k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
212
    return;
1697
1698
1.42k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
1.42k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
1.42k
      && default_alignment > alignment_table[i].default_alignment_max
1701
1.42k
#endif
1702
1.42k
      )
1703
0
    return;
1704
1705
1.42k
  section->alignment_power = alignment_table[i].alignment_power;
1706
1.42k
}
pe-i386.c:coff_set_custom_section_alignment
Line
Count
Source
1677
43.3k
{
1678
43.3k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
43.3k
  unsigned int i;
1680
1681
400k
  for (i = 0; i < table_size; ++i)
1682
362k
    {
1683
362k
      const char *secname = bfd_section_name (section);
1684
1685
362k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
362k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
362k
    : strncmp (alignment_table[i].name, secname,
1688
243k
         alignment_table[i].comparison_length) == 0)
1689
5.56k
  break;
1690
362k
    }
1691
43.3k
  if (i >= table_size)
1692
37.7k
    return;
1693
1694
5.56k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
5.56k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
648
    return;
1697
1698
4.91k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
4.91k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
4.91k
      && default_alignment > alignment_table[i].default_alignment_max
1701
4.91k
#endif
1702
4.91k
      )
1703
0
    return;
1704
1705
4.91k
  section->alignment_power = alignment_table[i].alignment_power;
1706
4.91k
}
pe-mcore.c:coff_set_custom_section_alignment
Line
Count
Source
1677
492k
{
1678
492k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
492k
  unsigned int i;
1680
1681
2.45M
  for (i = 0; i < table_size; ++i)
1682
1.96M
    {
1683
1.96M
      const char *secname = bfd_section_name (section);
1684
1685
1.96M
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
1.96M
    ? strcmp (alignment_table[i].name, secname) == 0
1687
1.96M
    : strncmp (alignment_table[i].name, secname,
1688
985k
         alignment_table[i].comparison_length) == 0)
1689
4.61k
  break;
1690
1.96M
    }
1691
492k
  if (i >= table_size)
1692
488k
    return;
1693
1694
4.61k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
4.61k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
4.34k
    return;
1697
1698
271
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
271
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
271
      && default_alignment > alignment_table[i].default_alignment_max
1701
271
#endif
1702
271
      )
1703
0
    return;
1704
1705
271
  section->alignment_power = alignment_table[i].alignment_power;
1706
271
}
pe-sh.c:coff_set_custom_section_alignment
Line
Count
Source
1677
31.0k
{
1678
31.0k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
31.0k
  unsigned int i;
1680
1681
137k
  for (i = 0; i < table_size; ++i)
1682
111k
    {
1683
111k
      const char *secname = bfd_section_name (section);
1684
1685
111k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
111k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
111k
    : strncmp (alignment_table[i].name, secname,
1688
58.2k
         alignment_table[i].comparison_length) == 0)
1689
4.61k
  break;
1690
111k
    }
1691
31.0k
  if (i >= table_size)
1692
26.4k
    return;
1693
1694
4.61k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
4.61k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
693
    return;
1697
1698
3.92k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
3.92k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
3.92k
      && default_alignment > alignment_table[i].default_alignment_max
1701
3.92k
#endif
1702
3.92k
      )
1703
0
    return;
1704
1705
3.92k
  section->alignment_power = alignment_table[i].alignment_power;
1706
3.92k
}
pei-arm-wince.c:coff_set_custom_section_alignment
Line
Count
Source
1677
33.2k
{
1678
33.2k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
33.2k
  unsigned int i;
1680
1681
426k
  for (i = 0; i < table_size; ++i)
1682
394k
    {
1683
394k
      const char *secname = bfd_section_name (section);
1684
1685
394k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
394k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
394k
    : strncmp (alignment_table[i].name, secname,
1688
164k
         alignment_table[i].comparison_length) == 0)
1689
1.31k
  break;
1690
394k
    }
1691
33.2k
  if (i >= table_size)
1692
31.9k
    return;
1693
1694
1.31k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
1.31k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
550
    return;
1697
1698
767
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
767
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
767
      && default_alignment > alignment_table[i].default_alignment_max
1701
767
#endif
1702
767
      )
1703
0
    return;
1704
1705
767
  section->alignment_power = alignment_table[i].alignment_power;
1706
767
}
pei-arm.c:coff_set_custom_section_alignment
Line
Count
Source
1677
45.3k
{
1678
45.3k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
45.3k
  unsigned int i;
1680
1681
535k
  for (i = 0; i < table_size; ++i)
1682
497k
    {
1683
497k
      const char *secname = bfd_section_name (section);
1684
1685
497k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
497k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
497k
    : strncmp (alignment_table[i].name, secname,
1688
200k
         alignment_table[i].comparison_length) == 0)
1689
7.23k
  break;
1690
497k
    }
1691
45.3k
  if (i >= table_size)
1692
38.0k
    return;
1693
1694
7.23k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
7.23k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
752
    return;
1697
1698
6.48k
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
6.48k
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
6.48k
      && default_alignment > alignment_table[i].default_alignment_max
1701
6.48k
#endif
1702
6.48k
      )
1703
0
    return;
1704
1705
6.48k
  section->alignment_power = alignment_table[i].alignment_power;
1706
6.48k
}
pei-mcore.c:coff_set_custom_section_alignment
Line
Count
Source
1677
48.3k
{
1678
48.3k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
48.3k
  unsigned int i;
1680
1681
239k
  for (i = 0; i < table_size; ++i)
1682
191k
    {
1683
191k
      const char *secname = bfd_section_name (section);
1684
1685
191k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
191k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
191k
    : strncmp (alignment_table[i].name, secname,
1688
96.4k
         alignment_table[i].comparison_length) == 0)
1689
955
  break;
1690
191k
    }
1691
48.3k
  if (i >= table_size)
1692
47.3k
    return;
1693
1694
955
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
955
      && default_alignment < alignment_table[i].default_alignment_min)
1696
688
    return;
1697
1698
267
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
267
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
267
      && default_alignment > alignment_table[i].default_alignment_max
1701
267
#endif
1702
267
      )
1703
0
    return;
1704
1705
267
  section->alignment_power = alignment_table[i].alignment_power;
1706
267
}
pei-sh.c:coff_set_custom_section_alignment
Line
Count
Source
1677
55.1k
{
1678
55.1k
  const unsigned int default_alignment = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1679
55.1k
  unsigned int i;
1680
1681
270k
  for (i = 0; i < table_size; ++i)
1682
217k
    {
1683
217k
      const char *secname = bfd_section_name (section);
1684
1685
217k
      if (alignment_table[i].comparison_length == (unsigned int) -1
1686
217k
    ? strcmp (alignment_table[i].name, secname) == 0
1687
217k
    : strncmp (alignment_table[i].name, secname,
1688
110k
         alignment_table[i].comparison_length) == 0)
1689
1.95k
  break;
1690
217k
    }
1691
55.1k
  if (i >= table_size)
1692
53.2k
    return;
1693
1694
1.95k
  if (alignment_table[i].default_alignment_min != COFF_ALIGNMENT_FIELD_EMPTY
1695
1.95k
      && default_alignment < alignment_table[i].default_alignment_min)
1696
1.85k
    return;
1697
1698
106
  if (alignment_table[i].default_alignment_max != COFF_ALIGNMENT_FIELD_EMPTY
1699
106
#if COFF_DEFAULT_SECTION_ALIGNMENT_POWER != 0
1700
106
      && default_alignment > alignment_table[i].default_alignment_max
1701
106
#endif
1702
106
      )
1703
0
    return;
1704
1705
106
  section->alignment_power = alignment_table[i].alignment_power;
1706
106
}
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
88.2M
{
1738
88.2M
  combined_entry_type *native;
1739
88.2M
  size_t amt;
1740
88.2M
  unsigned char sclass = C_STAT;
1741
1742
88.2M
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
#ifdef RS6000COFF_C
1745
22.7M
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
22.7M
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
30.7k
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
22.7M
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
22.7M
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
10.6k
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
22.7M
  else
1752
22.7M
    {
1753
22.7M
      int i;
1754
1755
272M
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
250M
  if (strcmp (bfd_section_name (section),
1757
250M
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
3.55k
    {
1759
3.55k
      section->alignment_power = 0;
1760
3.55k
      sclass = C_DWARF;
1761
3.55k
      break;
1762
3.55k
    }
1763
22.7M
    }
1764
#endif
1765
1766
  /* Set up the section symbol.  */
1767
88.2M
  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
88.2M
  amt = sizeof (combined_entry_type) * 10;
1776
88.2M
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
88.2M
  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
88.2M
  native->is_sym = true;
1787
88.2M
  native->u.syment.n_type = T_NULL;
1788
88.2M
  native->u.syment.n_sclass = sclass;
1789
1790
88.2M
  coffsymbol (section->symbol)->native = native;
1791
1792
88.2M
  coff_set_custom_section_alignment (abfd, section,
1793
88.2M
             coff_section_alignment_table,
1794
88.2M
             coff_section_alignment_table_size);
1795
1796
88.2M
  return true;
1797
88.2M
}
pei-i386.c:coff_new_section_hook
Line
Count
Source
1737
42.3k
{
1738
42.3k
  combined_entry_type *native;
1739
42.3k
  size_t amt;
1740
42.3k
  unsigned char sclass = C_STAT;
1741
1742
42.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
42.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
42.3k
  amt = sizeof (combined_entry_type) * 10;
1776
42.3k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
42.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
42.3k
  native->is_sym = true;
1787
42.3k
  native->u.syment.n_type = T_NULL;
1788
42.3k
  native->u.syment.n_sclass = sclass;
1789
1790
42.3k
  coffsymbol (section->symbol)->native = native;
1791
1792
42.3k
  coff_set_custom_section_alignment (abfd, section,
1793
42.3k
             coff_section_alignment_table,
1794
42.3k
             coff_section_alignment_table_size);
1795
1796
42.3k
  return true;
1797
42.3k
}
pe-x86_64.c:coff_new_section_hook
Line
Count
Source
1737
62.0k
{
1738
62.0k
  combined_entry_type *native;
1739
62.0k
  size_t amt;
1740
62.0k
  unsigned char sclass = C_STAT;
1741
1742
62.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
62.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
62.0k
  amt = sizeof (combined_entry_type) * 10;
1776
62.0k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
62.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
62.0k
  native->is_sym = true;
1787
62.0k
  native->u.syment.n_type = T_NULL;
1788
62.0k
  native->u.syment.n_sclass = sclass;
1789
1790
62.0k
  coffsymbol (section->symbol)->native = native;
1791
1792
62.0k
  coff_set_custom_section_alignment (abfd, section,
1793
62.0k
             coff_section_alignment_table,
1794
62.0k
             coff_section_alignment_table_size);
1795
1796
62.0k
  return true;
1797
62.0k
}
pei-x86_64.c:coff_new_section_hook
Line
Count
Source
1737
100k
{
1738
100k
  combined_entry_type *native;
1739
100k
  size_t amt;
1740
100k
  unsigned char sclass = C_STAT;
1741
1742
100k
  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
100k
  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
100k
  amt = sizeof (combined_entry_type) * 10;
1776
100k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
100k
  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
100k
  native->is_sym = true;
1787
100k
  native->u.syment.n_type = T_NULL;
1788
100k
  native->u.syment.n_sclass = sclass;
1789
1790
100k
  coffsymbol (section->symbol)->native = native;
1791
1792
100k
  coff_set_custom_section_alignment (abfd, section,
1793
100k
             coff_section_alignment_table,
1794
100k
             coff_section_alignment_table_size);
1795
1796
100k
  return true;
1797
100k
}
coff-x86_64.c:coff_new_section_hook
Line
Count
Source
1737
1.67M
{
1738
1.67M
  combined_entry_type *native;
1739
1.67M
  size_t amt;
1740
1.67M
  unsigned char sclass = C_STAT;
1741
1742
1.67M
  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
1.67M
  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
1.67M
  amt = sizeof (combined_entry_type) * 10;
1776
1.67M
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
1.67M
  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
1.67M
  native->is_sym = true;
1787
1.67M
  native->u.syment.n_type = T_NULL;
1788
1.67M
  native->u.syment.n_sclass = sclass;
1789
1790
1.67M
  coffsymbol (section->symbol)->native = native;
1791
1792
1.67M
  coff_set_custom_section_alignment (abfd, section,
1793
1.67M
             coff_section_alignment_table,
1794
1.67M
             coff_section_alignment_table_size);
1795
1796
1.67M
  return true;
1797
1.67M
}
coff64-rs6000.c:coff_new_section_hook
Line
Count
Source
1737
3.93M
{
1738
3.93M
  combined_entry_type *native;
1739
3.93M
  size_t amt;
1740
3.93M
  unsigned char sclass = C_STAT;
1741
1742
3.93M
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
3.93M
#ifdef RS6000COFF_C
1745
3.93M
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
3.93M
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
7.09k
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
3.92M
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
3.92M
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
1.27k
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
3.92M
  else
1752
3.92M
    {
1753
3.92M
      int i;
1754
1755
47.1M
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
43.1M
  if (strcmp (bfd_section_name (section),
1757
43.1M
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
766
    {
1759
766
      section->alignment_power = 0;
1760
766
      sclass = C_DWARF;
1761
766
      break;
1762
766
    }
1763
3.92M
    }
1764
3.93M
#endif
1765
1766
  /* Set up the section symbol.  */
1767
3.93M
  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
3.93M
  amt = sizeof (combined_entry_type) * 10;
1776
3.93M
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
3.93M
  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
3.93M
  native->is_sym = true;
1787
3.93M
  native->u.syment.n_type = T_NULL;
1788
3.93M
  native->u.syment.n_sclass = sclass;
1789
1790
3.93M
  coffsymbol (section->symbol)->native = native;
1791
1792
3.93M
  coff_set_custom_section_alignment (abfd, section,
1793
3.93M
             coff_section_alignment_table,
1794
3.93M
             coff_section_alignment_table_size);
1795
1796
3.93M
  return true;
1797
3.93M
}
pei-aarch64.c:coff_new_section_hook
Line
Count
Source
1737
33.9k
{
1738
33.9k
  combined_entry_type *native;
1739
33.9k
  size_t amt;
1740
33.9k
  unsigned char sclass = C_STAT;
1741
1742
33.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
33.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
33.9k
  amt = sizeof (combined_entry_type) * 10;
1776
33.9k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
33.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
33.9k
  native->is_sym = true;
1787
33.9k
  native->u.syment.n_type = T_NULL;
1788
33.9k
  native->u.syment.n_sclass = sclass;
1789
1790
33.9k
  coffsymbol (section->symbol)->native = native;
1791
1792
33.9k
  coff_set_custom_section_alignment (abfd, section,
1793
33.9k
             coff_section_alignment_table,
1794
33.9k
             coff_section_alignment_table_size);
1795
1796
33.9k
  return true;
1797
33.9k
}
pe-aarch64.c:coff_new_section_hook
Line
Count
Source
1737
14.3k
{
1738
14.3k
  combined_entry_type *native;
1739
14.3k
  size_t amt;
1740
14.3k
  unsigned char sclass = C_STAT;
1741
1742
14.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
14.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
14.3k
  amt = sizeof (combined_entry_type) * 10;
1776
14.3k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
14.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
14.3k
  native->is_sym = true;
1787
14.3k
  native->u.syment.n_type = T_NULL;
1788
14.3k
  native->u.syment.n_sclass = sclass;
1789
1790
14.3k
  coffsymbol (section->symbol)->native = native;
1791
1792
14.3k
  coff_set_custom_section_alignment (abfd, section,
1793
14.3k
             coff_section_alignment_table,
1794
14.3k
             coff_section_alignment_table_size);
1795
1796
14.3k
  return true;
1797
14.3k
}
pei-ia64.c:coff_new_section_hook
Line
Count
Source
1737
55.5k
{
1738
55.5k
  combined_entry_type *native;
1739
55.5k
  size_t amt;
1740
55.5k
  unsigned char sclass = C_STAT;
1741
1742
55.5k
  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
55.5k
  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
55.5k
  amt = sizeof (combined_entry_type) * 10;
1776
55.5k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
55.5k
  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
55.5k
  native->is_sym = true;
1787
55.5k
  native->u.syment.n_type = T_NULL;
1788
55.5k
  native->u.syment.n_sclass = sclass;
1789
1790
55.5k
  coffsymbol (section->symbol)->native = native;
1791
1792
55.5k
  coff_set_custom_section_alignment (abfd, section,
1793
55.5k
             coff_section_alignment_table,
1794
55.5k
             coff_section_alignment_table_size);
1795
1796
55.5k
  return true;
1797
55.5k
}
pei-loongarch64.c:coff_new_section_hook
Line
Count
Source
1737
110k
{
1738
110k
  combined_entry_type *native;
1739
110k
  size_t amt;
1740
110k
  unsigned char sclass = C_STAT;
1741
1742
110k
  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
110k
  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
110k
  amt = sizeof (combined_entry_type) * 10;
1776
110k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
110k
  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
110k
  native->is_sym = true;
1787
110k
  native->u.syment.n_type = T_NULL;
1788
110k
  native->u.syment.n_sclass = sclass;
1789
1790
110k
  coffsymbol (section->symbol)->native = native;
1791
1792
110k
  coff_set_custom_section_alignment (abfd, section,
1793
110k
             coff_section_alignment_table,
1794
110k
             coff_section_alignment_table_size);
1795
1796
110k
  return true;
1797
110k
}
cf-i386lynx.c:coff_new_section_hook
Line
Count
Source
1737
9.07M
{
1738
9.07M
  combined_entry_type *native;
1739
9.07M
  size_t amt;
1740
9.07M
  unsigned char sclass = C_STAT;
1741
1742
9.07M
  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
9.07M
  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
9.07M
  amt = sizeof (combined_entry_type) * 10;
1776
9.07M
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
9.07M
  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
9.07M
  native->is_sym = true;
1787
9.07M
  native->u.syment.n_type = T_NULL;
1788
9.07M
  native->u.syment.n_sclass = sclass;
1789
1790
9.07M
  coffsymbol (section->symbol)->native = native;
1791
1792
9.07M
  coff_set_custom_section_alignment (abfd, section,
1793
9.07M
             coff_section_alignment_table,
1794
9.07M
             coff_section_alignment_table_size);
1795
1796
9.07M
  return true;
1797
9.07M
}
coff-go32.c:coff_new_section_hook
Line
Count
Source
1737
7.13M
{
1738
7.13M
  combined_entry_type *native;
1739
7.13M
  size_t amt;
1740
7.13M
  unsigned char sclass = C_STAT;
1741
1742
7.13M
  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.13M
  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.13M
  amt = sizeof (combined_entry_type) * 10;
1776
7.13M
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
7.13M
  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.13M
  native->is_sym = true;
1787
7.13M
  native->u.syment.n_type = T_NULL;
1788
7.13M
  native->u.syment.n_sclass = sclass;
1789
1790
7.13M
  coffsymbol (section->symbol)->native = native;
1791
1792
7.13M
  coff_set_custom_section_alignment (abfd, section,
1793
7.13M
             coff_section_alignment_table,
1794
7.13M
             coff_section_alignment_table_size);
1795
1796
7.13M
  return true;
1797
7.13M
}
coff-i386.c:coff_new_section_hook
Line
Count
Source
1737
9.07M
{
1738
9.07M
  combined_entry_type *native;
1739
9.07M
  size_t amt;
1740
9.07M
  unsigned char sclass = C_STAT;
1741
1742
9.07M
  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
9.07M
  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
9.07M
  amt = sizeof (combined_entry_type) * 10;
1776
9.07M
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
9.07M
  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
9.07M
  native->is_sym = true;
1787
9.07M
  native->u.syment.n_type = T_NULL;
1788
9.07M
  native->u.syment.n_sclass = sclass;
1789
1790
9.07M
  coffsymbol (section->symbol)->native = native;
1791
1792
9.07M
  coff_set_custom_section_alignment (abfd, section,
1793
9.07M
             coff_section_alignment_table,
1794
9.07M
             coff_section_alignment_table_size);
1795
1796
9.07M
  return true;
1797
9.07M
}
coff-rs6000.c:coff_new_section_hook
Line
Count
Source
1737
18.8M
{
1738
18.8M
  combined_entry_type *native;
1739
18.8M
  size_t amt;
1740
18.8M
  unsigned char sclass = C_STAT;
1741
1742
18.8M
  section->alignment_power = COFF_DEFAULT_SECTION_ALIGNMENT_POWER;
1743
1744
18.8M
#ifdef RS6000COFF_C
1745
18.8M
  if (bfd_xcoff_text_align_power (abfd) != 0
1746
18.8M
      && strcmp (bfd_section_name (section), ".text") == 0)
1747
23.6k
    section->alignment_power = bfd_xcoff_text_align_power (abfd);
1748
18.8M
  else if (bfd_xcoff_data_align_power (abfd) != 0
1749
18.8M
      && strcmp (bfd_section_name (section), ".data") == 0)
1750
9.40k
    section->alignment_power = bfd_xcoff_data_align_power (abfd);
1751
18.8M
  else
1752
18.8M
    {
1753
18.8M
      int i;
1754
1755
225M
      for (i = 0; i < XCOFF_DWSECT_NBR_NAMES; i++)
1756
206M
  if (strcmp (bfd_section_name (section),
1757
206M
        xcoff_dwsect_names[i].xcoff_name) == 0)
1758
2.78k
    {
1759
2.78k
      section->alignment_power = 0;
1760
2.78k
      sclass = C_DWARF;
1761
2.78k
      break;
1762
2.78k
    }
1763
18.8M
    }
1764
18.8M
#endif
1765
1766
  /* Set up the section symbol.  */
1767
18.8M
  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
18.8M
  amt = sizeof (combined_entry_type) * 10;
1776
18.8M
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
18.8M
  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
18.8M
  native->is_sym = true;
1787
18.8M
  native->u.syment.n_type = T_NULL;
1788
18.8M
  native->u.syment.n_sclass = sclass;
1789
1790
18.8M
  coffsymbol (section->symbol)->native = native;
1791
1792
18.8M
  coff_set_custom_section_alignment (abfd, section,
1793
18.8M
             coff_section_alignment_table,
1794
18.8M
             coff_section_alignment_table_size);
1795
1796
18.8M
  return true;
1797
18.8M
}
coff-sh.c:coff_new_section_hook
Line
Count
Source
1737
6.69M
{
1738
6.69M
  combined_entry_type *native;
1739
6.69M
  size_t amt;
1740
6.69M
  unsigned char sclass = C_STAT;
1741
1742
6.69M
  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.69M
  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.69M
  amt = sizeof (combined_entry_type) * 10;
1776
6.69M
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
6.69M
  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.69M
  native->is_sym = true;
1787
6.69M
  native->u.syment.n_type = T_NULL;
1788
6.69M
  native->u.syment.n_sclass = sclass;
1789
1790
6.69M
  coffsymbol (section->symbol)->native = native;
1791
1792
6.69M
  coff_set_custom_section_alignment (abfd, section,
1793
6.69M
             coff_section_alignment_table,
1794
6.69M
             coff_section_alignment_table_size);
1795
1796
6.69M
  return true;
1797
6.69M
}
Unexecuted instantiation: coff-stgo32.c:coff_new_section_hook
coff-tic30.c:coff_new_section_hook
Line
Count
Source
1737
17.9M
{
1738
17.9M
  combined_entry_type *native;
1739
17.9M
  size_t amt;
1740
17.9M
  unsigned char sclass = C_STAT;
1741
1742
17.9M
  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
17.9M
  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
17.9M
  amt = sizeof (combined_entry_type) * 10;
1776
17.9M
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
17.9M
  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
17.9M
  native->is_sym = true;
1787
17.9M
  native->u.syment.n_type = T_NULL;
1788
17.9M
  native->u.syment.n_sclass = sclass;
1789
1790
17.9M
  coffsymbol (section->symbol)->native = native;
1791
1792
17.9M
  coff_set_custom_section_alignment (abfd, section,
1793
17.9M
             coff_section_alignment_table,
1794
17.9M
             coff_section_alignment_table_size);
1795
1796
17.9M
  return true;
1797
17.9M
}
Unexecuted instantiation: coff-tic4x.c:coff_new_section_hook
coff-tic54x.c:coff_new_section_hook
Line
Count
Source
1737
5.33M
{
1738
5.33M
  combined_entry_type *native;
1739
5.33M
  size_t amt;
1740
5.33M
  unsigned char sclass = C_STAT;
1741
1742
5.33M
  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
5.33M
  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
5.33M
  amt = sizeof (combined_entry_type) * 10;
1776
5.33M
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
5.33M
  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
5.33M
  native->is_sym = true;
1787
5.33M
  native->u.syment.n_type = T_NULL;
1788
5.33M
  native->u.syment.n_sclass = sclass;
1789
1790
5.33M
  coffsymbol (section->symbol)->native = native;
1791
1792
5.33M
  coff_set_custom_section_alignment (abfd, section,
1793
5.33M
             coff_section_alignment_table,
1794
5.33M
             coff_section_alignment_table_size);
1795
1796
5.33M
  return true;
1797
5.33M
}
coff-z80.c:coff_new_section_hook
Line
Count
Source
1737
440k
{
1738
440k
  combined_entry_type *native;
1739
440k
  size_t amt;
1740
440k
  unsigned char sclass = C_STAT;
1741
1742
440k
  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
440k
  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
440k
  amt = sizeof (combined_entry_type) * 10;
1776
440k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
440k
  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
440k
  native->is_sym = true;
1787
440k
  native->u.syment.n_type = T_NULL;
1788
440k
  native->u.syment.n_sclass = sclass;
1789
1790
440k
  coffsymbol (section->symbol)->native = native;
1791
1792
440k
  coff_set_custom_section_alignment (abfd, section,
1793
440k
             coff_section_alignment_table,
1794
440k
             coff_section_alignment_table_size);
1795
1796
440k
  return true;
1797
440k
}
coff-z8k.c:coff_new_section_hook
Line
Count
Source
1737
6.84M
{
1738
6.84M
  combined_entry_type *native;
1739
6.84M
  size_t amt;
1740
6.84M
  unsigned char sclass = C_STAT;
1741
1742
6.84M
  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.84M
  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.84M
  amt = sizeof (combined_entry_type) * 10;
1776
6.84M
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
6.84M
  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.84M
  native->is_sym = true;
1787
6.84M
  native->u.syment.n_type = T_NULL;
1788
6.84M
  native->u.syment.n_sclass = sclass;
1789
1790
6.84M
  coffsymbol (section->symbol)->native = native;
1791
1792
6.84M
  coff_set_custom_section_alignment (abfd, section,
1793
6.84M
             coff_section_alignment_table,
1794
6.84M
             coff_section_alignment_table_size);
1795
1796
6.84M
  return true;
1797
6.84M
}
pe-arm-wince.c:coff_new_section_hook
Line
Count
Source
1737
10.2k
{
1738
10.2k
  combined_entry_type *native;
1739
10.2k
  size_t amt;
1740
10.2k
  unsigned char sclass = C_STAT;
1741
1742
10.2k
  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.2k
  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.2k
  amt = sizeof (combined_entry_type) * 10;
1776
10.2k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
10.2k
  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.2k
  native->is_sym = true;
1787
10.2k
  native->u.syment.n_type = T_NULL;
1788
10.2k
  native->u.syment.n_sclass = sclass;
1789
1790
10.2k
  coffsymbol (section->symbol)->native = native;
1791
1792
10.2k
  coff_set_custom_section_alignment (abfd, section,
1793
10.2k
             coff_section_alignment_table,
1794
10.2k
             coff_section_alignment_table_size);
1795
1796
10.2k
  return true;
1797
10.2k
}
pe-arm.c:coff_new_section_hook
Line
Count
Source
1737
10.1k
{
1738
10.1k
  combined_entry_type *native;
1739
10.1k
  size_t amt;
1740
10.1k
  unsigned char sclass = C_STAT;
1741
1742
10.1k
  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.1k
  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.1k
  amt = sizeof (combined_entry_type) * 10;
1776
10.1k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
10.1k
  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.1k
  native->is_sym = true;
1787
10.1k
  native->u.syment.n_type = T_NULL;
1788
10.1k
  native->u.syment.n_sclass = sclass;
1789
1790
10.1k
  coffsymbol (section->symbol)->native = native;
1791
1792
10.1k
  coff_set_custom_section_alignment (abfd, section,
1793
10.1k
             coff_section_alignment_table,
1794
10.1k
             coff_section_alignment_table_size);
1795
1796
10.1k
  return true;
1797
10.1k
}
pe-i386.c:coff_new_section_hook
Line
Count
Source
1737
43.3k
{
1738
43.3k
  combined_entry_type *native;
1739
43.3k
  size_t amt;
1740
43.3k
  unsigned char sclass = C_STAT;
1741
1742
43.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
43.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
43.3k
  amt = sizeof (combined_entry_type) * 10;
1776
43.3k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
43.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
43.3k
  native->is_sym = true;
1787
43.3k
  native->u.syment.n_type = T_NULL;
1788
43.3k
  native->u.syment.n_sclass = sclass;
1789
1790
43.3k
  coffsymbol (section->symbol)->native = native;
1791
1792
43.3k
  coff_set_custom_section_alignment (abfd, section,
1793
43.3k
             coff_section_alignment_table,
1794
43.3k
             coff_section_alignment_table_size);
1795
1796
43.3k
  return true;
1797
43.3k
}
pe-mcore.c:coff_new_section_hook
Line
Count
Source
1737
492k
{
1738
492k
  combined_entry_type *native;
1739
492k
  size_t amt;
1740
492k
  unsigned char sclass = C_STAT;
1741
1742
492k
  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
492k
  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
492k
  amt = sizeof (combined_entry_type) * 10;
1776
492k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
492k
  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
492k
  native->is_sym = true;
1787
492k
  native->u.syment.n_type = T_NULL;
1788
492k
  native->u.syment.n_sclass = sclass;
1789
1790
492k
  coffsymbol (section->symbol)->native = native;
1791
1792
492k
  coff_set_custom_section_alignment (abfd, section,
1793
492k
             coff_section_alignment_table,
1794
492k
             coff_section_alignment_table_size);
1795
1796
492k
  return true;
1797
492k
}
pe-sh.c:coff_new_section_hook
Line
Count
Source
1737
31.0k
{
1738
31.0k
  combined_entry_type *native;
1739
31.0k
  size_t amt;
1740
31.0k
  unsigned char sclass = C_STAT;
1741
1742
31.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
31.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
31.0k
  amt = sizeof (combined_entry_type) * 10;
1776
31.0k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
31.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
31.0k
  native->is_sym = true;
1787
31.0k
  native->u.syment.n_type = T_NULL;
1788
31.0k
  native->u.syment.n_sclass = sclass;
1789
1790
31.0k
  coffsymbol (section->symbol)->native = native;
1791
1792
31.0k
  coff_set_custom_section_alignment (abfd, section,
1793
31.0k
             coff_section_alignment_table,
1794
31.0k
             coff_section_alignment_table_size);
1795
1796
31.0k
  return true;
1797
31.0k
}
pei-arm-wince.c:coff_new_section_hook
Line
Count
Source
1737
33.2k
{
1738
33.2k
  combined_entry_type *native;
1739
33.2k
  size_t amt;
1740
33.2k
  unsigned char sclass = C_STAT;
1741
1742
33.2k
  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
33.2k
  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
33.2k
  amt = sizeof (combined_entry_type) * 10;
1776
33.2k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
33.2k
  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
33.2k
  native->is_sym = true;
1787
33.2k
  native->u.syment.n_type = T_NULL;
1788
33.2k
  native->u.syment.n_sclass = sclass;
1789
1790
33.2k
  coffsymbol (section->symbol)->native = native;
1791
1792
33.2k
  coff_set_custom_section_alignment (abfd, section,
1793
33.2k
             coff_section_alignment_table,
1794
33.2k
             coff_section_alignment_table_size);
1795
1796
33.2k
  return true;
1797
33.2k
}
pei-arm.c:coff_new_section_hook
Line
Count
Source
1737
45.3k
{
1738
45.3k
  combined_entry_type *native;
1739
45.3k
  size_t amt;
1740
45.3k
  unsigned char sclass = C_STAT;
1741
1742
45.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
45.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
45.3k
  amt = sizeof (combined_entry_type) * 10;
1776
45.3k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
45.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
45.3k
  native->is_sym = true;
1787
45.3k
  native->u.syment.n_type = T_NULL;
1788
45.3k
  native->u.syment.n_sclass = sclass;
1789
1790
45.3k
  coffsymbol (section->symbol)->native = native;
1791
1792
45.3k
  coff_set_custom_section_alignment (abfd, section,
1793
45.3k
             coff_section_alignment_table,
1794
45.3k
             coff_section_alignment_table_size);
1795
1796
45.3k
  return true;
1797
45.3k
}
pei-mcore.c:coff_new_section_hook
Line
Count
Source
1737
48.3k
{
1738
48.3k
  combined_entry_type *native;
1739
48.3k
  size_t amt;
1740
48.3k
  unsigned char sclass = C_STAT;
1741
1742
48.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
48.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
48.3k
  amt = sizeof (combined_entry_type) * 10;
1776
48.3k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
48.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
48.3k
  native->is_sym = true;
1787
48.3k
  native->u.syment.n_type = T_NULL;
1788
48.3k
  native->u.syment.n_sclass = sclass;
1789
1790
48.3k
  coffsymbol (section->symbol)->native = native;
1791
1792
48.3k
  coff_set_custom_section_alignment (abfd, section,
1793
48.3k
             coff_section_alignment_table,
1794
48.3k
             coff_section_alignment_table_size);
1795
1796
48.3k
  return true;
1797
48.3k
}
pei-sh.c:coff_new_section_hook
Line
Count
Source
1737
55.1k
{
1738
55.1k
  combined_entry_type *native;
1739
55.1k
  size_t amt;
1740
55.1k
  unsigned char sclass = C_STAT;
1741
1742
55.1k
  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
55.1k
  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
55.1k
  amt = sizeof (combined_entry_type) * 10;
1776
55.1k
  native = (combined_entry_type *) bfd_zalloc (abfd, amt);
1777
55.1k
  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
55.1k
  native->is_sym = true;
1787
55.1k
  native->u.syment.n_type = T_NULL;
1788
55.1k
  native->u.syment.n_sclass = sclass;
1789
1790
55.1k
  coffsymbol (section->symbol)->native = native;
1791
1792
55.1k
  coff_set_custom_section_alignment (abfd, section,
1793
55.1k
             coff_section_alignment_table,
1794
55.1k
             coff_section_alignment_table_size);
1795
1796
55.1k
  return true;
1797
55.1k
}
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
5.77M
{
1808
5.77M
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1809
5.77M
  unsigned int i;
1810
1811
5.77M
#ifdef COFF_DECODE_ALIGNMENT
1812
5.77M
  i = COFF_DECODE_ALIGNMENT(hdr->s_flags);
1813
5.77M
#endif
1814
5.77M
  section->alignment_power = i;
1815
1816
#ifdef coff_set_section_load_page
1817
5.33M
  coff_set_section_load_page (section, hdr->s_page);
1818
#endif
1819
5.77M
}
Unexecuted instantiation: coff-tic4x.c:coff_set_alignment_hook
coff-tic54x.c:coff_set_alignment_hook
Line
Count
Source
1807
5.33M
{
1808
5.33M
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1809
5.33M
  unsigned int i;
1810
1811
5.33M
#ifdef COFF_DECODE_ALIGNMENT
1812
5.33M
  i = COFF_DECODE_ALIGNMENT(hdr->s_flags);
1813
5.33M
#endif
1814
5.33M
  section->alignment_power = i;
1815
1816
5.33M
#ifdef coff_set_section_load_page
1817
5.33M
  coff_set_section_load_page (section, hdr->s_page);
1818
5.33M
#endif
1819
5.33M
}
coff-z80.c:coff_set_alignment_hook
Line
Count
Source
1807
440k
{
1808
440k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1809
440k
  unsigned int i;
1810
1811
440k
#ifdef COFF_DECODE_ALIGNMENT
1812
440k
  i = COFF_DECODE_ALIGNMENT(hdr->s_flags);
1813
440k
#endif
1814
440k
  section->alignment_power = i;
1815
1816
#ifdef coff_set_section_load_page
1817
  coff_set_section_load_page (section, hdr->s_page);
1818
#endif
1819
440k
}
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
1.14M
{
1829
1.14M
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
1.14M
  size_t amt;
1831
1.14M
  unsigned int alignment_power_const
1832
1.14M
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
1.14M
  switch (alignment_power_const)
1835
1.14M
    {
1836
26.6k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
32.4k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
53.3k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
56.2k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
73.8k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
79.4k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
96.9k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
104k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
123k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
161k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
175k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
195k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
246k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
266k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
266k
      section->alignment_power
1851
266k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
266k
      break;
1853
875k
    default:
1854
875k
      break;
1855
1.14M
    }
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
1.14M
  if (coff_section_data (abfd, section) == NULL)
1862
1.14M
    {
1863
1.14M
      amt = sizeof (struct coff_section_tdata);
1864
1.14M
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
1.14M
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
1.14M
    }
1869
1870
1.14M
  if (pei_section_data (abfd, section) == NULL)
1871
1.14M
    {
1872
1.14M
      amt = sizeof (struct pei_section_tdata);
1873
1.14M
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
1.14M
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
1.14M
    }
1878
1.14M
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
1.14M
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
1.14M
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
1.14M
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
110k
    {
1886
110k
      struct external_reloc dst;
1887
110k
      struct internal_reloc n;
1888
110k
      file_ptr oldpos = bfd_tell (abfd);
1889
110k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
110k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
110k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
76.3k
  return;
1895
1896
34.0k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
34.0k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
34.0k
      if (n.r_vaddr < 0x10000)
1900
7.70k
  {
1901
7.70k
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
7.70k
    bfd_set_error (bfd_error_bad_value);
1903
7.70k
    return;
1904
7.70k
  }
1905
26.3k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
26.3k
      section->rel_filepos += relsz;
1907
26.3k
    }
1908
1.03M
  else if (hdr->s_nreloc == 0xffff)
1909
6.28k
    _bfd_error_handler
1910
6.28k
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
6.28k
       abfd);
1912
1.14M
}
pei-i386.c:coff_set_alignment_hook
Line
Count
Source
1828
37.4k
{
1829
37.4k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
37.4k
  size_t amt;
1831
37.4k
  unsigned int alignment_power_const
1832
37.4k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
37.4k
  switch (alignment_power_const)
1835
37.4k
    {
1836
3.14k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
3.63k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
4.04k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
4.04k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
4.41k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
4.41k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
6.57k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
6.80k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
7.85k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
8.84k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
9.11k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
10.4k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
20.1k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
20.3k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
20.3k
      section->alignment_power
1851
20.3k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
20.3k
      break;
1853
17.1k
    default:
1854
17.1k
      break;
1855
37.4k
    }
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
37.4k
  if (coff_section_data (abfd, section) == NULL)
1862
37.4k
    {
1863
37.4k
      amt = sizeof (struct coff_section_tdata);
1864
37.4k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
37.4k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
37.4k
    }
1869
1870
37.4k
  if (pei_section_data (abfd, section) == NULL)
1871
37.4k
    {
1872
37.4k
      amt = sizeof (struct pei_section_tdata);
1873
37.4k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
37.4k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
37.4k
    }
1878
37.4k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
37.4k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
37.4k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
37.4k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
5.06k
    {
1886
5.06k
      struct external_reloc dst;
1887
5.06k
      struct internal_reloc n;
1888
5.06k
      file_ptr oldpos = bfd_tell (abfd);
1889
5.06k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
5.06k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
5.06k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
3.65k
  return;
1895
1896
1.40k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
1.40k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
1.40k
      if (n.r_vaddr < 0x10000)
1900
236
  {
1901
236
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
236
    bfd_set_error (bfd_error_bad_value);
1903
236
    return;
1904
236
  }
1905
1.17k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
1.17k
      section->rel_filepos += relsz;
1907
1.17k
    }
1908
32.4k
  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
37.4k
}
pe-x86_64.c:coff_set_alignment_hook
Line
Count
Source
1828
61.6k
{
1829
61.6k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
61.6k
  size_t amt;
1831
61.6k
  unsigned int alignment_power_const
1832
61.6k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
61.6k
  switch (alignment_power_const)
1835
61.6k
    {
1836
1.02k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
1.68k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
6.10k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
6.76k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
6.76k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
7.17k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
8.40k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
8.84k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
10.9k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
15.6k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
19.5k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
22.6k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
28.3k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
32.7k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
32.7k
      section->alignment_power
1851
32.7k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
32.7k
      break;
1853
28.8k
    default:
1854
28.8k
      break;
1855
61.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
61.6k
  if (coff_section_data (abfd, section) == NULL)
1862
61.6k
    {
1863
61.6k
      amt = sizeof (struct coff_section_tdata);
1864
61.6k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
61.6k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
61.6k
    }
1869
1870
61.6k
  if (pei_section_data (abfd, section) == NULL)
1871
61.6k
    {
1872
61.6k
      amt = sizeof (struct pei_section_tdata);
1873
61.6k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
61.6k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
61.6k
    }
1878
61.6k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
61.6k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
61.6k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
61.6k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
9.84k
    {
1886
9.84k
      struct external_reloc dst;
1887
9.84k
      struct internal_reloc n;
1888
9.84k
      file_ptr oldpos = bfd_tell (abfd);
1889
9.84k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
9.84k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
9.84k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
7.14k
  return;
1895
1896
2.69k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
2.69k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
2.69k
      if (n.r_vaddr < 0x10000)
1900
334
  {
1901
334
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
334
    bfd_set_error (bfd_error_bad_value);
1903
334
    return;
1904
334
  }
1905
2.36k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
2.36k
      section->rel_filepos += relsz;
1907
2.36k
    }
1908
51.7k
  else if (hdr->s_nreloc == 0xffff)
1909
2.94k
    _bfd_error_handler
1910
2.94k
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
2.94k
       abfd);
1912
61.6k
}
pei-x86_64.c:coff_set_alignment_hook
Line
Count
Source
1828
87.6k
{
1829
87.6k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
87.6k
  size_t amt;
1831
87.6k
  unsigned int alignment_power_const
1832
87.6k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
87.6k
  switch (alignment_power_const)
1835
87.6k
    {
1836
1.66k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
1.79k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
2.16k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
2.82k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
5.99k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
6.10k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
7.07k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
7.54k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
8.59k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
24.1k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
26.0k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
28.7k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
34.0k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
42.0k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
42.0k
      section->alignment_power
1851
42.0k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
42.0k
      break;
1853
45.5k
    default:
1854
45.5k
      break;
1855
87.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
87.6k
  if (coff_section_data (abfd, section) == NULL)
1862
87.6k
    {
1863
87.6k
      amt = sizeof (struct coff_section_tdata);
1864
87.6k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
87.6k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
87.6k
    }
1869
1870
87.6k
  if (pei_section_data (abfd, section) == NULL)
1871
87.6k
    {
1872
87.6k
      amt = sizeof (struct pei_section_tdata);
1873
87.6k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
87.6k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
87.6k
    }
1878
87.6k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
87.6k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
87.6k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
87.6k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
7.51k
    {
1886
7.51k
      struct external_reloc dst;
1887
7.51k
      struct internal_reloc n;
1888
7.51k
      file_ptr oldpos = bfd_tell (abfd);
1889
7.51k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
7.51k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
7.51k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
5.17k
  return;
1895
1896
2.33k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
2.33k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
2.33k
      if (n.r_vaddr < 0x10000)
1900
861
  {
1901
861
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
861
    bfd_set_error (bfd_error_bad_value);
1903
861
    return;
1904
861
  }
1905
1.47k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
1.47k
      section->rel_filepos += relsz;
1907
1.47k
    }
1908
80.1k
  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
87.6k
}
pei-aarch64.c:coff_set_alignment_hook
Line
Count
Source
1828
32.3k
{
1829
32.3k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
32.3k
  size_t amt;
1831
32.3k
  unsigned int alignment_power_const
1832
32.3k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
32.3k
  switch (alignment_power_const)
1835
32.3k
    {
1836
3.42k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
3.69k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
6.38k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
6.38k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
7.22k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
7.22k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
7.43k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
7.64k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
9.11k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
9.59k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
10.0k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
10.4k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
11.5k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
11.5k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
11.5k
      section->alignment_power
1851
11.5k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
11.5k
      break;
1853
20.8k
    default:
1854
20.8k
      break;
1855
32.3k
    }
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
32.3k
  if (coff_section_data (abfd, section) == NULL)
1862
32.3k
    {
1863
32.3k
      amt = sizeof (struct coff_section_tdata);
1864
32.3k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
32.3k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
32.3k
    }
1869
1870
32.3k
  if (pei_section_data (abfd, section) == NULL)
1871
32.3k
    {
1872
32.3k
      amt = sizeof (struct pei_section_tdata);
1873
32.3k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
32.3k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
32.3k
    }
1878
32.3k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
32.3k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
32.3k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
32.3k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
5.09k
    {
1886
5.09k
      struct external_reloc dst;
1887
5.09k
      struct internal_reloc n;
1888
5.09k
      file_ptr oldpos = bfd_tell (abfd);
1889
5.09k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
5.09k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
5.09k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
2.19k
  return;
1895
1896
2.89k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
2.89k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
2.89k
      if (n.r_vaddr < 0x10000)
1900
356
  {
1901
356
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
356
    bfd_set_error (bfd_error_bad_value);
1903
356
    return;
1904
356
  }
1905
2.53k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
2.53k
      section->rel_filepos += relsz;
1907
2.53k
    }
1908
27.2k
  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
32.3k
}
pe-aarch64.c:coff_set_alignment_hook
Line
Count
Source
1828
14.3k
{
1829
14.3k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
14.3k
  size_t amt;
1831
14.3k
  unsigned int alignment_power_const
1832
14.3k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
14.3k
  switch (alignment_power_const)
1835
14.3k
    {
1836
99
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
200
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
200
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
302
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
303
    case IMAGE_SCN_ALIGN_512BYTES:
1841
317
    case IMAGE_SCN_ALIGN_256BYTES:
1842
337
    case IMAGE_SCN_ALIGN_128BYTES:
1843
643
    case IMAGE_SCN_ALIGN_64BYTES:
1844
1.14k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
1.15k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
2.08k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
2.57k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
2.60k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
2.60k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
2.60k
      section->alignment_power
1851
2.60k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
2.60k
      break;
1853
11.7k
    default:
1854
11.7k
      break;
1855
14.3k
    }
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
14.3k
  if (coff_section_data (abfd, section) == NULL)
1862
14.3k
    {
1863
14.3k
      amt = sizeof (struct coff_section_tdata);
1864
14.3k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
14.3k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
14.3k
    }
1869
1870
14.3k
  if (pei_section_data (abfd, section) == NULL)
1871
14.3k
    {
1872
14.3k
      amt = sizeof (struct pei_section_tdata);
1873
14.3k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
14.3k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
14.3k
    }
1878
14.3k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
14.3k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
14.3k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
14.3k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
2.65k
    {
1886
2.65k
      struct external_reloc dst;
1887
2.65k
      struct internal_reloc n;
1888
2.65k
      file_ptr oldpos = bfd_tell (abfd);
1889
2.65k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
2.65k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
2.65k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
1.86k
  return;
1895
1896
795
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
795
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
795
      if (n.r_vaddr < 0x10000)
1900
240
  {
1901
240
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
240
    bfd_set_error (bfd_error_bad_value);
1903
240
    return;
1904
240
  }
1905
555
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
555
      section->rel_filepos += relsz;
1907
555
    }
1908
11.6k
  else if (hdr->s_nreloc == 0xffff)
1909
346
    _bfd_error_handler
1910
346
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
346
       abfd);
1912
14.3k
}
pei-ia64.c:coff_set_alignment_hook
Line
Count
Source
1828
51.0k
{
1829
51.0k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
51.0k
  size_t amt;
1831
51.0k
  unsigned int alignment_power_const
1832
51.0k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
51.0k
  switch (alignment_power_const)
1835
51.0k
    {
1836
3.56k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
4.45k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
5.51k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
5.61k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
6.09k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
6.36k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
7.14k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
7.37k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
10.2k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
11.9k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
12.4k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
15.9k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
18.4k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
19.9k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
19.9k
      section->alignment_power
1851
19.9k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
19.9k
      break;
1853
31.0k
    default:
1854
31.0k
      break;
1855
51.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
51.0k
  if (coff_section_data (abfd, section) == NULL)
1862
51.0k
    {
1863
51.0k
      amt = sizeof (struct coff_section_tdata);
1864
51.0k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
51.0k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
51.0k
    }
1869
1870
51.0k
  if (pei_section_data (abfd, section) == NULL)
1871
51.0k
    {
1872
51.0k
      amt = sizeof (struct pei_section_tdata);
1873
51.0k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
51.0k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
51.0k
    }
1878
51.0k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
51.0k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
51.0k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
51.0k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
6.03k
    {
1886
6.03k
      struct external_reloc dst;
1887
6.03k
      struct internal_reloc n;
1888
6.03k
      file_ptr oldpos = bfd_tell (abfd);
1889
6.03k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
6.03k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
6.03k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
4.45k
  return;
1895
1896
1.58k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
1.58k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
1.58k
      if (n.r_vaddr < 0x10000)
1900
342
  {
1901
342
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
342
    bfd_set_error (bfd_error_bad_value);
1903
342
    return;
1904
342
  }
1905
1.24k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
1.24k
      section->rel_filepos += relsz;
1907
1.24k
    }
1908
45.0k
  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
51.0k
}
pei-loongarch64.c:coff_set_alignment_hook
Line
Count
Source
1828
104k
{
1829
104k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
104k
  size_t amt;
1831
104k
  unsigned int alignment_power_const
1832
104k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
104k
  switch (alignment_power_const)
1835
104k
    {
1836
1.80k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
1.80k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
3.55k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
3.55k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
3.56k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
3.80k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
6.55k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
6.66k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
8.29k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
8.32k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
8.94k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
9.39k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
12.7k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
12.8k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
12.8k
      section->alignment_power
1851
12.8k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
12.8k
      break;
1853
91.9k
    default:
1854
91.9k
      break;
1855
104k
    }
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
104k
  if (coff_section_data (abfd, section) == NULL)
1862
104k
    {
1863
104k
      amt = sizeof (struct coff_section_tdata);
1864
104k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
104k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
104k
    }
1869
1870
104k
  if (pei_section_data (abfd, section) == NULL)
1871
104k
    {
1872
104k
      amt = sizeof (struct pei_section_tdata);
1873
104k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
104k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
104k
    }
1878
104k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
104k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
104k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
104k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
3.93k
    {
1886
3.93k
      struct external_reloc dst;
1887
3.93k
      struct internal_reloc n;
1888
3.93k
      file_ptr oldpos = bfd_tell (abfd);
1889
3.93k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
3.93k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
3.93k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
1.60k
  return;
1895
1896
2.32k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
2.32k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
2.32k
      if (n.r_vaddr < 0x10000)
1900
344
  {
1901
344
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
344
    bfd_set_error (bfd_error_bad_value);
1903
344
    return;
1904
344
  }
1905
1.98k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
1.98k
      section->rel_filepos += relsz;
1907
1.98k
    }
1908
100k
  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
104k
}
pe-arm-wince.c:coff_set_alignment_hook
Line
Count
Source
1828
9.73k
{
1829
9.73k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
9.73k
  size_t amt;
1831
9.73k
  unsigned int alignment_power_const
1832
9.73k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
9.73k
  switch (alignment_power_const)
1835
9.73k
    {
1836
525
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
629
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
659
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
973
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
1.09k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
1.19k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
1.21k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
1.42k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
1.48k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
3.32k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
3.76k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
4.09k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
4.51k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
5.54k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
5.54k
      section->alignment_power
1851
5.54k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
5.54k
      break;
1853
4.19k
    default:
1854
4.19k
      break;
1855
9.73k
    }
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
9.73k
  if (coff_section_data (abfd, section) == NULL)
1862
9.73k
    {
1863
9.73k
      amt = sizeof (struct coff_section_tdata);
1864
9.73k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
9.73k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
9.73k
    }
1869
1870
9.73k
  if (pei_section_data (abfd, section) == NULL)
1871
9.73k
    {
1872
9.73k
      amt = sizeof (struct pei_section_tdata);
1873
9.73k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
9.73k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
9.73k
    }
1878
9.73k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
9.73k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
9.73k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
9.73k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
2.64k
    {
1886
2.64k
      struct external_reloc dst;
1887
2.64k
      struct internal_reloc n;
1888
2.64k
      file_ptr oldpos = bfd_tell (abfd);
1889
2.64k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
2.64k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
2.64k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
1.71k
  return;
1895
1896
930
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
930
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
930
      if (n.r_vaddr < 0x10000)
1900
311
  {
1901
311
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
311
    bfd_set_error (bfd_error_bad_value);
1903
311
    return;
1904
311
  }
1905
619
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
619
      section->rel_filepos += relsz;
1907
619
    }
1908
7.08k
  else if (hdr->s_nreloc == 0xffff)
1909
629
    _bfd_error_handler
1910
629
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
629
       abfd);
1912
9.73k
}
pe-arm.c:coff_set_alignment_hook
Line
Count
Source
1828
9.73k
{
1829
9.73k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
9.73k
  size_t amt;
1831
9.73k
  unsigned int alignment_power_const
1832
9.73k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
9.73k
  switch (alignment_power_const)
1835
9.73k
    {
1836
525
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
629
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
659
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
973
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
1.09k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
1.19k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
1.21k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
1.42k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
1.48k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
3.32k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
3.76k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
4.09k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
4.51k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
5.54k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
5.54k
      section->alignment_power
1851
5.54k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
5.54k
      break;
1853
4.19k
    default:
1854
4.19k
      break;
1855
9.73k
    }
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
9.73k
  if (coff_section_data (abfd, section) == NULL)
1862
9.73k
    {
1863
9.73k
      amt = sizeof (struct coff_section_tdata);
1864
9.73k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
9.73k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
9.73k
    }
1869
1870
9.73k
  if (pei_section_data (abfd, section) == NULL)
1871
9.73k
    {
1872
9.73k
      amt = sizeof (struct pei_section_tdata);
1873
9.73k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
9.73k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
9.73k
    }
1878
9.73k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
9.73k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
9.73k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
9.73k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
2.64k
    {
1886
2.64k
      struct external_reloc dst;
1887
2.64k
      struct internal_reloc n;
1888
2.64k
      file_ptr oldpos = bfd_tell (abfd);
1889
2.64k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
2.64k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
2.64k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
1.71k
  return;
1895
1896
930
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
930
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
930
      if (n.r_vaddr < 0x10000)
1900
311
  {
1901
311
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
311
    bfd_set_error (bfd_error_bad_value);
1903
311
    return;
1904
311
  }
1905
619
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
619
      section->rel_filepos += relsz;
1907
619
    }
1908
7.08k
  else if (hdr->s_nreloc == 0xffff)
1909
629
    _bfd_error_handler
1910
629
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
629
       abfd);
1912
9.73k
}
pe-i386.c:coff_set_alignment_hook
Line
Count
Source
1828
40.9k
{
1829
40.9k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
40.9k
  size_t amt;
1831
40.9k
  unsigned int alignment_power_const
1832
40.9k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
40.9k
  switch (alignment_power_const)
1835
40.9k
    {
1836
978
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
989
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
2.84k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
3.16k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
3.63k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
7.70k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
7.94k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
8.61k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
9.37k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
10.5k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
11.0k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
12.8k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
13.9k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
14.3k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
14.3k
      section->alignment_power
1851
14.3k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
14.3k
      break;
1853
26.5k
    default:
1854
26.5k
      break;
1855
40.9k
    }
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
40.9k
  if (coff_section_data (abfd, section) == NULL)
1862
40.9k
    {
1863
40.9k
      amt = sizeof (struct coff_section_tdata);
1864
40.9k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
40.9k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
40.9k
    }
1869
1870
40.9k
  if (pei_section_data (abfd, section) == NULL)
1871
40.9k
    {
1872
40.9k
      amt = sizeof (struct pei_section_tdata);
1873
40.9k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
40.9k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
40.9k
    }
1878
40.9k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
40.9k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
40.9k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
40.9k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
11.7k
    {
1886
11.7k
      struct external_reloc dst;
1887
11.7k
      struct internal_reloc n;
1888
11.7k
      file_ptr oldpos = bfd_tell (abfd);
1889
11.7k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
11.7k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
11.7k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
9.60k
  return;
1895
1896
2.12k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
2.12k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
2.12k
      if (n.r_vaddr < 0x10000)
1900
308
  {
1901
308
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
308
    bfd_set_error (bfd_error_bad_value);
1903
308
    return;
1904
308
  }
1905
1.81k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
1.81k
      section->rel_filepos += relsz;
1907
1.81k
    }
1908
29.1k
  else if (hdr->s_nreloc == 0xffff)
1909
627
    _bfd_error_handler
1910
627
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
627
       abfd);
1912
40.9k
}
pe-mcore.c:coff_set_alignment_hook
Line
Count
Source
1828
492k
{
1829
492k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
492k
  size_t amt;
1831
492k
  unsigned int alignment_power_const
1832
492k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
492k
  switch (alignment_power_const)
1835
492k
    {
1836
3.07k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
3.07k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
4.78k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
4.99k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
5.74k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
5.75k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
6.39k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
6.89k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
7.64k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
8.14k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
8.95k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
9.20k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
13.2k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
13.3k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
13.3k
      section->alignment_power
1851
13.3k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
13.3k
      break;
1853
478k
    default:
1854
478k
      break;
1855
492k
    }
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
492k
  if (coff_section_data (abfd, section) == NULL)
1862
492k
    {
1863
492k
      amt = sizeof (struct coff_section_tdata);
1864
492k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
492k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
492k
    }
1869
1870
492k
  if (pei_section_data (abfd, section) == NULL)
1871
492k
    {
1872
492k
      amt = sizeof (struct pei_section_tdata);
1873
492k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
492k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
492k
    }
1878
492k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
492k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
492k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
492k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
8.42k
    {
1886
8.42k
      struct external_reloc dst;
1887
8.42k
      struct internal_reloc n;
1888
8.42k
      file_ptr oldpos = bfd_tell (abfd);
1889
8.42k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
8.42k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
8.42k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
5.40k
  return;
1895
1896
3.02k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
3.02k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
3.02k
      if (n.r_vaddr < 0x10000)
1900
637
  {
1901
637
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
637
    bfd_set_error (bfd_error_bad_value);
1903
637
    return;
1904
637
  }
1905
2.38k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
2.38k
      section->rel_filepos += relsz;
1907
2.38k
    }
1908
483k
  else if (hdr->s_nreloc == 0xffff)
1909
392
    _bfd_error_handler
1910
392
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
392
       abfd);
1912
492k
}
pe-sh.c:coff_set_alignment_hook
Line
Count
Source
1828
30.0k
{
1829
30.0k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
30.0k
  size_t amt;
1831
30.0k
  unsigned int alignment_power_const
1832
30.0k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
30.0k
  switch (alignment_power_const)
1835
30.0k
    {
1836
250
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
478
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
1.15k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
1.40k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
3.50k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
3.51k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
4.23k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
7.02k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
7.72k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
9.99k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
10.6k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
11.4k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
16.0k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
16.1k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
16.1k
      section->alignment_power
1851
16.1k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
16.1k
      break;
1853
13.8k
    default:
1854
13.8k
      break;
1855
30.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
30.0k
  if (coff_section_data (abfd, section) == NULL)
1862
30.0k
    {
1863
30.0k
      amt = sizeof (struct coff_section_tdata);
1864
30.0k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
30.0k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
30.0k
    }
1869
1870
30.0k
  if (pei_section_data (abfd, section) == NULL)
1871
30.0k
    {
1872
30.0k
      amt = sizeof (struct pei_section_tdata);
1873
30.0k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
30.0k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
30.0k
    }
1878
30.0k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
30.0k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
30.0k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
30.0k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
8.90k
    {
1886
8.90k
      struct external_reloc dst;
1887
8.90k
      struct internal_reloc n;
1888
8.90k
      file_ptr oldpos = bfd_tell (abfd);
1889
8.90k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
8.90k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
8.90k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
7.89k
  return;
1895
1896
1.00k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
1.00k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
1.00k
      if (n.r_vaddr < 0x10000)
1900
209
  {
1901
209
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
209
    bfd_set_error (bfd_error_bad_value);
1903
209
    return;
1904
209
  }
1905
800
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
800
      section->rel_filepos += relsz;
1907
800
    }
1908
21.1k
  else if (hdr->s_nreloc == 0xffff)
1909
715
    _bfd_error_handler
1910
715
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1911
715
       abfd);
1912
30.0k
}
pei-arm-wince.c:coff_set_alignment_hook
Line
Count
Source
1828
32.4k
{
1829
32.4k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
32.4k
  size_t amt;
1831
32.4k
  unsigned int alignment_power_const
1832
32.4k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
32.4k
  switch (alignment_power_const)
1835
32.4k
    {
1836
1.59k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
3.23k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
4.14k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
4.14k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
6.85k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
6.85k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
7.10k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
7.38k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
8.43k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
10.5k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
11.3k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
12.4k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
15.3k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
16.0k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
16.0k
      section->alignment_power
1851
16.0k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
16.0k
      break;
1853
16.3k
    default:
1854
16.3k
      break;
1855
32.4k
    }
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
32.4k
  if (coff_section_data (abfd, section) == NULL)
1862
32.4k
    {
1863
32.4k
      amt = sizeof (struct coff_section_tdata);
1864
32.4k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
32.4k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
32.4k
    }
1869
1870
32.4k
  if (pei_section_data (abfd, section) == NULL)
1871
32.4k
    {
1872
32.4k
      amt = sizeof (struct pei_section_tdata);
1873
32.4k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
32.4k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
32.4k
    }
1878
32.4k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
32.4k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
32.4k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
32.4k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
9.50k
    {
1886
9.50k
      struct external_reloc dst;
1887
9.50k
      struct internal_reloc n;
1888
9.50k
      file_ptr oldpos = bfd_tell (abfd);
1889
9.50k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
9.50k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
9.50k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
7.08k
  return;
1895
1896
2.42k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
2.42k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
2.42k
      if (n.r_vaddr < 0x10000)
1900
344
  {
1901
344
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
344
    bfd_set_error (bfd_error_bad_value);
1903
344
    return;
1904
344
  }
1905
2.08k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
2.08k
      section->rel_filepos += relsz;
1907
2.08k
    }
1908
22.9k
  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
32.4k
}
pei-arm.c:coff_set_alignment_hook
Line
Count
Source
1828
38.7k
{
1829
38.7k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
38.7k
  size_t amt;
1831
38.7k
  unsigned int alignment_power_const
1832
38.7k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
38.7k
  switch (alignment_power_const)
1835
38.7k
    {
1836
1.95k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
1.98k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
3.38k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
3.38k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
6.20k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
6.20k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
8.01k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
8.40k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
9.81k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
12.3k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
13.1k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
14.5k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
16.8k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
17.7k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
17.7k
      section->alignment_power
1851
17.7k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
17.7k
      break;
1853
21.0k
    default:
1854
21.0k
      break;
1855
38.7k
    }
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
38.7k
  if (coff_section_data (abfd, section) == NULL)
1862
38.7k
    {
1863
38.7k
      amt = sizeof (struct coff_section_tdata);
1864
38.7k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
38.7k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
38.7k
    }
1869
1870
38.7k
  if (pei_section_data (abfd, section) == NULL)
1871
38.7k
    {
1872
38.7k
      amt = sizeof (struct pei_section_tdata);
1873
38.7k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
38.7k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
38.7k
    }
1878
38.7k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
38.7k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
38.7k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
38.7k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
9.40k
    {
1886
9.40k
      struct external_reloc dst;
1887
9.40k
      struct internal_reloc n;
1888
9.40k
      file_ptr oldpos = bfd_tell (abfd);
1889
9.40k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
9.40k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
9.40k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
6.64k
  return;
1895
1896
2.76k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
2.76k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
2.76k
      if (n.r_vaddr < 0x10000)
1900
347
  {
1901
347
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
347
    bfd_set_error (bfd_error_bad_value);
1903
347
    return;
1904
347
  }
1905
2.41k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
2.41k
      section->rel_filepos += relsz;
1907
2.41k
    }
1908
29.3k
  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
38.7k
}
pei-mcore.c:coff_set_alignment_hook
Line
Count
Source
1828
47.8k
{
1829
47.8k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
47.8k
  size_t amt;
1831
47.8k
  unsigned int alignment_power_const
1832
47.8k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
47.8k
  switch (alignment_power_const)
1835
47.8k
    {
1836
1.15k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
2.36k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
5.11k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
5.11k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
6.15k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
6.15k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
10.5k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
11.0k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
13.4k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
13.7k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
14.7k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
15.4k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
19.5k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
20.2k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
20.2k
      section->alignment_power
1851
20.2k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
20.2k
      break;
1853
27.5k
    default:
1854
27.5k
      break;
1855
47.8k
    }
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
47.8k
  if (coff_section_data (abfd, section) == NULL)
1862
47.8k
    {
1863
47.8k
      amt = sizeof (struct coff_section_tdata);
1864
47.8k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
47.8k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
47.8k
    }
1869
1870
47.8k
  if (pei_section_data (abfd, section) == NULL)
1871
47.8k
    {
1872
47.8k
      amt = sizeof (struct pei_section_tdata);
1873
47.8k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
47.8k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
47.8k
    }
1878
47.8k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
47.8k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
47.8k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
47.8k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
8.20k
    {
1886
8.20k
      struct external_reloc dst;
1887
8.20k
      struct internal_reloc n;
1888
8.20k
      file_ptr oldpos = bfd_tell (abfd);
1889
8.20k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
8.20k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
8.20k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
6.18k
  return;
1895
1896
2.02k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
2.02k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
2.02k
      if (n.r_vaddr < 0x10000)
1900
249
  {
1901
249
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
249
    bfd_set_error (bfd_error_bad_value);
1903
249
    return;
1904
249
  }
1905
1.77k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
1.77k
      section->rel_filepos += relsz;
1907
1.77k
    }
1908
39.5k
  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
47.8k
}
pei-sh.c:coff_set_alignment_hook
Line
Count
Source
1828
50.7k
{
1829
50.7k
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1830
50.7k
  size_t amt;
1831
50.7k
  unsigned int alignment_power_const
1832
50.7k
    = hdr->s_flags & IMAGE_SCN_ALIGN_POWER_BIT_MASK;
1833
1834
50.7k
  switch (alignment_power_const)
1835
50.7k
    {
1836
1.83k
    case IMAGE_SCN_ALIGN_8192BYTES:
1837
1.83k
    case IMAGE_SCN_ALIGN_4096BYTES:
1838
2.62k
    case IMAGE_SCN_ALIGN_2048BYTES:
1839
2.62k
    case IMAGE_SCN_ALIGN_1024BYTES:
1840
5.23k
    case IMAGE_SCN_ALIGN_512BYTES:
1841
5.47k
    case IMAGE_SCN_ALIGN_256BYTES:
1842
6.81k
    case IMAGE_SCN_ALIGN_128BYTES:
1843
7.05k
    case IMAGE_SCN_ALIGN_64BYTES:
1844
8.09k
    case IMAGE_SCN_ALIGN_32BYTES:
1845
9.71k
    case IMAGE_SCN_ALIGN_16BYTES:
1846
10.1k
    case IMAGE_SCN_ALIGN_8BYTES:
1847
11.2k
    case IMAGE_SCN_ALIGN_4BYTES:
1848
15.0k
    case IMAGE_SCN_ALIGN_2BYTES:
1849
15.2k
    case IMAGE_SCN_ALIGN_1BYTES:
1850
15.2k
      section->alignment_power
1851
15.2k
  = IMAGE_SCN_ALIGN_POWER_NUM (alignment_power_const);
1852
15.2k
      break;
1853
35.5k
    default:
1854
35.5k
      break;
1855
50.7k
    }
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
50.7k
  if (coff_section_data (abfd, section) == NULL)
1862
50.7k
    {
1863
50.7k
      amt = sizeof (struct coff_section_tdata);
1864
50.7k
      section->used_by_bfd = bfd_zalloc (abfd, amt);
1865
50.7k
      if (section->used_by_bfd == NULL)
1866
  /* FIXME: Return error.  */
1867
0
  abort ();
1868
50.7k
    }
1869
1870
50.7k
  if (pei_section_data (abfd, section) == NULL)
1871
50.7k
    {
1872
50.7k
      amt = sizeof (struct pei_section_tdata);
1873
50.7k
      coff_section_data (abfd, section)->tdata = bfd_zalloc (abfd, amt);
1874
50.7k
      if (coff_section_data (abfd, section)->tdata == NULL)
1875
  /* FIXME: Return error.  */
1876
0
  abort ();
1877
50.7k
    }
1878
50.7k
  pei_section_data (abfd, section)->virt_size = hdr->s_paddr;
1879
50.7k
  pei_section_data (abfd, section)->pe_flags = hdr->s_flags;
1880
1881
50.7k
  section->lma = hdr->s_vaddr;
1882
1883
  /* Check for extended relocs.  */
1884
50.7k
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1885
8.84k
    {
1886
8.84k
      struct external_reloc dst;
1887
8.84k
      struct internal_reloc n;
1888
8.84k
      file_ptr oldpos = bfd_tell (abfd);
1889
8.84k
      bfd_size_type relsz = bfd_coff_relsz (abfd);
1890
1891
8.84k
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1892
0
  return;
1893
8.84k
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1894
4.01k
  return;
1895
1896
4.82k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1897
4.82k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1898
0
  return;
1899
4.82k
      if (n.r_vaddr < 0x10000)
1900
2.27k
  {
1901
2.27k
    _bfd_error_handler (_("%pB: overflow reloc count too small"), abfd);
1902
2.27k
    bfd_set_error (bfd_error_bad_value);
1903
2.27k
    return;
1904
2.27k
  }
1905
2.55k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1906
2.55k
      section->rel_filepos += relsz;
1907
2.55k
    }
1908
41.8k
  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
50.7k
}
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
22.7M
{
1926
22.7M
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1927
22.7M
  asection *real_sec;
1928
1929
22.7M
  if ((hdr->s_flags & STYP_OVRFLO) == 0)
1930
17.4M
    return;
1931
1932
5.27M
  real_sec = coff_section_from_bfd_index (abfd, (int) hdr->s_nreloc);
1933
5.27M
  if (real_sec == NULL)
1934
0
    return;
1935
1936
5.27M
  real_sec->reloc_count = hdr->s_paddr;
1937
5.27M
  real_sec->lineno_count = hdr->s_vaddr;
1938
1939
5.27M
  if (!bfd_section_removed_from_list (abfd, section))
1940
5.27M
    {
1941
5.27M
      bfd_section_list_remove (abfd, section);
1942
5.27M
      --abfd->section_count;
1943
5.27M
    }
1944
5.27M
}
coff64-rs6000.c:coff_set_alignment_hook
Line
Count
Source
1925
3.93M
{
1926
3.93M
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1927
3.93M
  asection *real_sec;
1928
1929
3.93M
  if ((hdr->s_flags & STYP_OVRFLO) == 0)
1930
3.16M
    return;
1931
1932
765k
  real_sec = coff_section_from_bfd_index (abfd, (int) hdr->s_nreloc);
1933
765k
  if (real_sec == NULL)
1934
0
    return;
1935
1936
765k
  real_sec->reloc_count = hdr->s_paddr;
1937
765k
  real_sec->lineno_count = hdr->s_vaddr;
1938
1939
765k
  if (!bfd_section_removed_from_list (abfd, section))
1940
765k
    {
1941
765k
      bfd_section_list_remove (abfd, section);
1942
765k
      --abfd->section_count;
1943
765k
    }
1944
765k
}
coff-rs6000.c:coff_set_alignment_hook
Line
Count
Source
1925
18.8M
{
1926
18.8M
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1927
18.8M
  asection *real_sec;
1928
1929
18.8M
  if ((hdr->s_flags & STYP_OVRFLO) == 0)
1930
14.3M
    return;
1931
1932
4.51M
  real_sec = coff_section_from_bfd_index (abfd, (int) hdr->s_nreloc);
1933
4.51M
  if (real_sec == NULL)
1934
0
    return;
1935
1936
4.51M
  real_sec->reloc_count = hdr->s_paddr;
1937
4.51M
  real_sec->lineno_count = hdr->s_vaddr;
1938
1939
4.51M
  if (!bfd_section_removed_from_list (abfd, section))
1940
4.51M
    {
1941
4.51M
      bfd_section_list_remove (abfd, section);
1942
4.51M
      --abfd->section_count;
1943
4.51M
    }
1944
4.51M
}
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
7.13M
{
1952
7.13M
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1953
1954
  /* Check for extended relocs.  */
1955
7.13M
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1956
2.07M
    {
1957
2.07M
      struct external_reloc dst;
1958
2.07M
      struct internal_reloc n;
1959
2.07M
      const file_ptr oldpos = bfd_tell (abfd);
1960
2.07M
      const bfd_size_type relsz = bfd_coff_relsz (abfd);
1961
1962
2.07M
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1963
0
  return;
1964
2.07M
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1965
1.74M
  return;
1966
1967
328k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1968
328k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1969
0
  return;
1970
328k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1971
328k
      section->rel_filepos += relsz;
1972
328k
    }
1973
5.06M
  else if (hdr->s_nreloc == 0xffff)
1974
102k
    _bfd_error_handler
1975
102k
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1976
102k
       abfd);
1977
7.13M
}
coff-go32.c:coff_set_alignment_hook
Line
Count
Source
1951
7.13M
{
1952
7.13M
  struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr;
1953
1954
  /* Check for extended relocs.  */
1955
7.13M
  if (hdr->s_flags & IMAGE_SCN_LNK_NRELOC_OVFL)
1956
2.07M
    {
1957
2.07M
      struct external_reloc dst;
1958
2.07M
      struct internal_reloc n;
1959
2.07M
      const file_ptr oldpos = bfd_tell (abfd);
1960
2.07M
      const bfd_size_type relsz = bfd_coff_relsz (abfd);
1961
1962
2.07M
      if (bfd_seek (abfd, (file_ptr) hdr->s_relptr, 0) != 0)
1963
0
  return;
1964
2.07M
      if (bfd_bread (& dst, relsz, abfd) != relsz)
1965
1.74M
  return;
1966
1967
328k
      bfd_coff_swap_reloc_in (abfd, &dst, &n);
1968
328k
      if (bfd_seek (abfd, oldpos, 0) != 0)
1969
0
  return;
1970
328k
      section->reloc_count = hdr->s_nreloc = n.r_vaddr - 1;
1971
328k
      section->rel_filepos += relsz;
1972
328k
    }
1973
5.06M
  else if (hdr->s_nreloc == 0xffff)
1974
102k
    _bfd_error_handler
1975
102k
      (_("%pB: warning: claims to have 0xffff relocs, without overflow"),
1976
102k
       abfd);
1977
7.13M
}
Unexecuted instantiation: coff-stgo32.c:coff_set_alignment_hook
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
51.3M
{
1986
51.3M
}
coff-x86_64.c:coff_set_alignment_hook
Line
Count
Source
1985
1.67M
{
1986
1.67M
}
cf-i386lynx.c:coff_set_alignment_hook
Line
Count
Source
1985
9.07M
{
1986
9.07M
}
coff-i386.c:coff_set_alignment_hook
Line
Count
Source
1985
9.07M
{
1986
9.07M
}
coff-sh.c:coff_set_alignment_hook
Line
Count
Source
1985
6.69M
{
1986
6.69M
}
coff-tic30.c:coff_set_alignment_hook
Line
Count
Source
1985
17.9M
{
1986
17.9M
}
coff-z8k.c:coff_set_alignment_hook
Line
Count
Source
1985
6.84M
{
1986
6.84M
}
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
129k
{
1998
129k
  coff_data_type *coff;
1999
129k
  size_t amt = sizeof (coff_data_type);
2000
2001
129k
  abfd->tdata.coff_obj_data = bfd_zalloc (abfd, amt);
2002
129k
  if (abfd->tdata.coff_obj_data == NULL)
2003
0
    return false;
2004
2005
129k
  coff = coff_data (abfd);
2006
129k
  coff->symbols = NULL;
2007
129k
  coff->conversion_table = NULL;
2008
129k
  coff->raw_syments = NULL;
2009
129k
  coff->relocbase = 0;
2010
129k
  coff->local_toc_sym_map = 0;
2011
2012
129k
  bfd_coff_long_section_names (abfd)
2013
129k
    = coff_backend_info (abfd)->_bfd_coff_long_section_names;
2014
2015
/*  make_abs_section(abfd);*/
2016
2017
129k
  return true;
2018
129k
}
coff-x86_64.c:coff_mkobject
Line
Count
Source
1997
20.7k
{
1998
20.7k
  coff_data_type *coff;
1999
20.7k
  size_t amt = sizeof (coff_data_type);
2000
2001
20.7k
  abfd->tdata.coff_obj_data = bfd_zalloc (abfd, amt);
2002
20.7k
  if (abfd->tdata.coff_obj_data == NULL)
2003
0
    return false;
2004
2005
20.7k
  coff = coff_data (abfd);
2006
20.7k
  coff->symbols = NULL;
2007
20.7k
  coff->conversion_table = NULL;
2008
20.7k
  coff->raw_syments = NULL;
2009
20.7k
  coff->relocbase = 0;
2010
20.7k
  coff->local_toc_sym_map = 0;
2011
2012
20.7k
  bfd_coff_long_section_names (abfd)
2013
20.7k
    = coff_backend_info (abfd)->_bfd_coff_long_section_names;
2014
2015
/*  make_abs_section(abfd);*/
2016
2017
20.7k
  return true;
2018
20.7k
}
cf-i386lynx.c:coff_mkobject
Line
Count
Source
1997
16.7k
{
1998
16.7k
  coff_data_type *coff;
1999
16.7k
  size_t amt = sizeof (coff_data_type);
2000
2001
16.7k
  abfd->tdata.coff_obj_data = bfd_zalloc (abfd, amt);
2002
16.7k
  if (abfd->tdata.coff_obj_data == NULL)
2003
0
    return false;
2004
2005
16.7k
  coff = coff_data (abfd);
2006
16.7k
  coff->symbols = NULL;
2007
16.7k
  coff->conversion_table = NULL;
2008
16.7k
  coff->raw_syments = NULL;
2009
16.7k
  coff->relocbase = 0;
2010
16.7k
  coff->local_toc_sym_map = 0;
2011
2012
16.7k
  bfd_coff_long_section_names (abfd)
2013
16.7k
    = coff_backend_info (abfd)->_bfd_coff_long_section_names;
2014
2015
/*  make_abs_section(abfd);*/
2016
2017
16.7k
  return true;
2018
16.7k
}
coff-i386.c:coff_mkobject
Line
Count
Source
1997
16.7k
{
1998
16.7k
  coff_data_type *coff;
1999
16.7k
  size_t amt = sizeof (coff_data_type);
2000
2001
16.7k
  abfd->tdata.coff_obj_data = bfd_zalloc (abfd, amt);
2002
16.7k
  if (abfd->tdata.coff_obj_data == NULL)
2003
0
    return false;
2004
2005
16.7k
  coff = coff_data (abfd);
2006
16.7k
  coff->symbols = NULL;
2007
16.7k
  coff->conversion_table = NULL;
2008
16.7k
  coff->raw_syments = NULL;
2009
16.7k
  coff->relocbase = 0;
2010
16.7k
  coff->local_toc_sym_map = 0;
2011
2012
16.7k
  bfd_coff_long_section_names (abfd)
2013
16.7k
    = coff_backend_info (abfd)->_bfd_coff_long_section_names;
2014
2015
/*  make_abs_section(abfd);*/
2016
2017
16.7k
  return true;
2018
16.7k
}
coff-sh.c:coff_mkobject
Line
Count
Source
1997
16.2k
{
1998
16.2k
  coff_data_type *coff;
1999
16.2k
  size_t amt = sizeof (coff_data_type);
2000
2001
16.2k
  abfd->tdata.coff_obj_data = bfd_zalloc (abfd, amt);
2002
16.2k
  if (abfd->tdata.coff_obj_data == NULL)
2003
0
    return false;
2004
2005
16.2k
  coff = coff_data (abfd);
2006
16.2k
  coff->symbols = NULL;
2007
16.2k
  coff->conversion_table = NULL;
2008
16.2k
  coff->raw_syments = NULL;
2009
16.2k
  coff->relocbase = 0;
2010
16.2k
  coff->local_toc_sym_map = 0;
2011
2012
16.2k
  bfd_coff_long_section_names (abfd)
2013
16.2k
    = coff_backend_info (abfd)->_bfd_coff_long_section_names;
2014
2015
/*  make_abs_section(abfd);*/
2016
2017
16.2k
  return true;
2018
16.2k
}
coff-tic30.c:coff_mkobject
Line
Count
Source
1997
13.2k
{
1998
13.2k
  coff_data_type *coff;
1999
13.2k
  size_t amt = sizeof (coff_data_type);
2000
2001
13.2k
  abfd->tdata.coff_obj_data = bfd_zalloc (abfd, amt);
2002
13.2k
  if (abfd->tdata.coff_obj_data == NULL)
2003
0
    return false;
2004
2005
13.2k
  coff = coff_data (abfd);
2006
13.2k
  coff->symbols = NULL;
2007
13.2k
  coff->conversion_table = NULL;
2008
13.2k
  coff->raw_syments = NULL;
2009
13.2k
  coff->relocbase = 0;
2010
13.2k
  coff->local_toc_sym_map = 0;
2011
2012
13.2k
  bfd_coff_long_section_names (abfd)
2013
13.2k
    = coff_backend_info (abfd)->_bfd_coff_long_section_names;
2014
2015
/*  make_abs_section(abfd);*/
2016
2017
13.2k
  return true;
2018
13.2k
}
Unexecuted instantiation: coff-tic4x.c:coff_mkobject
coff-tic54x.c:coff_mkobject
Line
Count
Source
1997
27.9k
{
1998
27.9k
  coff_data_type *coff;
1999
27.9k
  size_t amt = sizeof (coff_data_type);
2000
2001
27.9k
  abfd->tdata.coff_obj_data = bfd_zalloc (abfd, amt);
2002
27.9k
  if (abfd->tdata.coff_obj_data == NULL)
2003
0
    return false;
2004
2005
27.9k
  coff = coff_data (abfd);
2006
27.9k
  coff->symbols = NULL;
2007
27.9k
  coff->conversion_table = NULL;
2008
27.9k
  coff->raw_syments = NULL;
2009
27.9k
  coff->relocbase = 0;
2010
27.9k
  coff->local_toc_sym_map = 0;
2011
2012
27.9k
  bfd_coff_long_section_names (abfd)
2013
27.9k
    = coff_backend_info (abfd)->_bfd_coff_long_section_names;
2014
2015
/*  make_abs_section(abfd);*/
2016
2017
27.9k
  return true;
2018
27.9k
}
coff-z80.c:coff_mkobject
Line
Count
Source
1997
8.74k
{
1998
8.74k
  coff_data_type *coff;
1999
8.74k
  size_t amt = sizeof (coff_data_type);
2000
2001
8.74k
  abfd->tdata.coff_obj_data = bfd_zalloc (abfd, amt);
2002
8.74k
  if (abfd->tdata.coff_obj_data == NULL)
2003
0
    return false;
2004
2005
8.74k
  coff = coff_data (abfd);
2006
8.74k
  coff->symbols = NULL;
2007
8.74k
  coff->conversion_table = NULL;
2008
8.74k
  coff->raw_syments = NULL;
2009
8.74k
  coff->relocbase = 0;
2010
8.74k
  coff->local_toc_sym_map = 0;
2011
2012
8.74k
  bfd_coff_long_section_names (abfd)
2013
8.74k
    = coff_backend_info (abfd)->_bfd_coff_long_section_names;
2014
2015
/*  make_abs_section(abfd);*/
2016
2017
8.74k
  return true;
2018
8.74k
}
coff-z8k.c:coff_mkobject
Line
Count
Source
1997
8.91k
{
1998
8.91k
  coff_data_type *coff;
1999
8.91k
  size_t amt = sizeof (coff_data_type);
2000
2001
8.91k
  abfd->tdata.coff_obj_data = bfd_zalloc (abfd, amt);
2002
8.91k
  if (abfd->tdata.coff_obj_data == NULL)
2003
0
    return false;
2004
2005
8.91k
  coff = coff_data (abfd);
2006
8.91k
  coff->symbols = NULL;
2007
8.91k
  coff->conversion_table = NULL;
2008
8.91k
  coff->raw_syments = NULL;
2009
8.91k
  coff->relocbase = 0;
2010
8.91k
  coff->local_toc_sym_map = 0;
2011
2012
8.91k
  bfd_coff_long_section_names (abfd)
2013
8.91k
    = coff_backend_info (abfd)->_bfd_coff_long_section_names;
2014
2015
/*  make_abs_section(abfd);*/
2016
2017
8.91k
  return true;
2018
8.91k
}
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
190k
{
2029
190k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
190k
  coff_data_type *coff;
2031
2032
190k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
190k
  coff = coff_data (abfd);
2036
2037
190k
  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
190k
  coff->local_n_btmask = N_BTMASK;
2043
190k
  coff->local_n_btshft = N_BTSHFT;
2044
190k
  coff->local_n_tmask = N_TMASK;
2045
190k
  coff->local_n_tshift = N_TSHIFT;
2046
190k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
190k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
190k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
190k
  coff->timestamp = internal_f->f_timdat;
2051
2052
190k
  obj_raw_syment_count (abfd) =
2053
190k
    obj_conv_table_size (abfd) =
2054
190k
      internal_f->f_nsyms;
2055
2056
#ifdef RS6000COFF_C
2057
44.7k
  if ((internal_f->f_flags & F_SHROBJ) != 0)
2058
26.5k
    abfd->flags |= DYNAMIC;
2059
44.7k
  if (aouthdr != NULL && internal_f->f_opthdr >= bfd_coff_aoutsz (abfd))
2060
13.7k
    {
2061
13.7k
      struct internal_aouthdr *internal_a =
2062
13.7k
  (struct internal_aouthdr *) aouthdr;
2063
13.7k
      struct xcoff_tdata *xcoff;
2064
2065
13.7k
      xcoff = xcoff_data (abfd);
2066
# ifdef U803XTOCMAGIC
2067
6.25k
      xcoff->xcoff64 = internal_f->f_magic == U803XTOCMAGIC;
2068
# else
2069
      xcoff->xcoff64 = 0;
2070
# endif
2071
13.7k
      xcoff->full_aouthdr = true;
2072
13.7k
      xcoff->toc = internal_a->o_toc;
2073
13.7k
      xcoff->sntoc = internal_a->o_sntoc;
2074
13.7k
      xcoff->snentry = internal_a->o_snentry;
2075
13.7k
      bfd_xcoff_text_align_power (abfd) = internal_a->o_algntext;
2076
13.7k
      bfd_xcoff_data_align_power (abfd) = internal_a->o_algndata;
2077
13.7k
      xcoff->modtype = internal_a->o_modtype;
2078
13.7k
      xcoff->cputype = internal_a->o_cputype;
2079
13.7k
      xcoff->maxdata = internal_a->o_maxdata;
2080
13.7k
      xcoff->maxstack = internal_a->o_maxstack;
2081
13.7k
    }
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
190k
  return coff;
2098
190k
}
coff-x86_64.c:coff_mkobject_hook
Line
Count
Source
2028
20.7k
{
2029
20.7k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
20.7k
  coff_data_type *coff;
2031
2032
20.7k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
20.7k
  coff = coff_data (abfd);
2036
2037
20.7k
  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
20.7k
  coff->local_n_btmask = N_BTMASK;
2043
20.7k
  coff->local_n_btshft = N_BTSHFT;
2044
20.7k
  coff->local_n_tmask = N_TMASK;
2045
20.7k
  coff->local_n_tshift = N_TSHIFT;
2046
20.7k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
20.7k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
20.7k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
20.7k
  coff->timestamp = internal_f->f_timdat;
2051
2052
20.7k
  obj_raw_syment_count (abfd) =
2053
20.7k
    obj_conv_table_size (abfd) =
2054
20.7k
      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
20.7k
  return coff;
2098
20.7k
}
coff64-rs6000.c:coff_mkobject_hook
Line
Count
Source
2028
20.0k
{
2029
20.0k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
20.0k
  coff_data_type *coff;
2031
2032
20.0k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
20.0k
  coff = coff_data (abfd);
2036
2037
20.0k
  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
20.0k
  coff->local_n_btmask = N_BTMASK;
2043
20.0k
  coff->local_n_btshft = N_BTSHFT;
2044
20.0k
  coff->local_n_tmask = N_TMASK;
2045
20.0k
  coff->local_n_tshift = N_TSHIFT;
2046
20.0k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
20.0k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
20.0k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
20.0k
  coff->timestamp = internal_f->f_timdat;
2051
2052
20.0k
  obj_raw_syment_count (abfd) =
2053
20.0k
    obj_conv_table_size (abfd) =
2054
20.0k
      internal_f->f_nsyms;
2055
2056
20.0k
#ifdef RS6000COFF_C
2057
20.0k
  if ((internal_f->f_flags & F_SHROBJ) != 0)
2058
7.38k
    abfd->flags |= DYNAMIC;
2059
20.0k
  if (aouthdr != NULL && internal_f->f_opthdr >= bfd_coff_aoutsz (abfd))
2060
6.25k
    {
2061
6.25k
      struct internal_aouthdr *internal_a =
2062
6.25k
  (struct internal_aouthdr *) aouthdr;
2063
6.25k
      struct xcoff_tdata *xcoff;
2064
2065
6.25k
      xcoff = xcoff_data (abfd);
2066
6.25k
# ifdef U803XTOCMAGIC
2067
6.25k
      xcoff->xcoff64 = internal_f->f_magic == U803XTOCMAGIC;
2068
# else
2069
      xcoff->xcoff64 = 0;
2070
# endif
2071
6.25k
      xcoff->full_aouthdr = true;
2072
6.25k
      xcoff->toc = internal_a->o_toc;
2073
6.25k
      xcoff->sntoc = internal_a->o_sntoc;
2074
6.25k
      xcoff->snentry = internal_a->o_snentry;
2075
6.25k
      bfd_xcoff_text_align_power (abfd) = internal_a->o_algntext;
2076
6.25k
      bfd_xcoff_data_align_power (abfd) = internal_a->o_algndata;
2077
6.25k
      xcoff->modtype = internal_a->o_modtype;
2078
6.25k
      xcoff->cputype = internal_a->o_cputype;
2079
6.25k
      xcoff->maxdata = internal_a->o_maxdata;
2080
6.25k
      xcoff->maxstack = internal_a->o_maxstack;
2081
6.25k
    }
2082
20.0k
#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
20.0k
  return coff;
2098
20.0k
}
cf-i386lynx.c:coff_mkobject_hook
Line
Count
Source
2028
16.7k
{
2029
16.7k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
16.7k
  coff_data_type *coff;
2031
2032
16.7k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
16.7k
  coff = coff_data (abfd);
2036
2037
16.7k
  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
16.7k
  coff->local_n_btmask = N_BTMASK;
2043
16.7k
  coff->local_n_btshft = N_BTSHFT;
2044
16.7k
  coff->local_n_tmask = N_TMASK;
2045
16.7k
  coff->local_n_tshift = N_TSHIFT;
2046
16.7k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
16.7k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
16.7k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
16.7k
  coff->timestamp = internal_f->f_timdat;
2051
2052
16.7k
  obj_raw_syment_count (abfd) =
2053
16.7k
    obj_conv_table_size (abfd) =
2054
16.7k
      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
16.7k
  return coff;
2098
16.7k
}
coff-go32.c:coff_mkobject_hook
Line
Count
Source
2028
16.7k
{
2029
16.7k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
16.7k
  coff_data_type *coff;
2031
2032
16.7k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
16.7k
  coff = coff_data (abfd);
2036
2037
16.7k
  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
16.7k
  coff->local_n_btmask = N_BTMASK;
2043
16.7k
  coff->local_n_btshft = N_BTSHFT;
2044
16.7k
  coff->local_n_tmask = N_TMASK;
2045
16.7k
  coff->local_n_tshift = N_TSHIFT;
2046
16.7k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
16.7k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
16.7k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
16.7k
  coff->timestamp = internal_f->f_timdat;
2051
2052
16.7k
  obj_raw_syment_count (abfd) =
2053
16.7k
    obj_conv_table_size (abfd) =
2054
16.7k
      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
16.7k
  return coff;
2098
16.7k
}
coff-i386.c:coff_mkobject_hook
Line
Count
Source
2028
16.7k
{
2029
16.7k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
16.7k
  coff_data_type *coff;
2031
2032
16.7k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
16.7k
  coff = coff_data (abfd);
2036
2037
16.7k
  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
16.7k
  coff->local_n_btmask = N_BTMASK;
2043
16.7k
  coff->local_n_btshft = N_BTSHFT;
2044
16.7k
  coff->local_n_tmask = N_TMASK;
2045
16.7k
  coff->local_n_tshift = N_TSHIFT;
2046
16.7k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
16.7k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
16.7k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
16.7k
  coff->timestamp = internal_f->f_timdat;
2051
2052
16.7k
  obj_raw_syment_count (abfd) =
2053
16.7k
    obj_conv_table_size (abfd) =
2054
16.7k
      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
16.7k
  return coff;
2098
16.7k
}
coff-rs6000.c:coff_mkobject_hook
Line
Count
Source
2028
24.6k
{
2029
24.6k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
24.6k
  coff_data_type *coff;
2031
2032
24.6k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
24.6k
  coff = coff_data (abfd);
2036
2037
24.6k
  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
24.6k
  coff->local_n_btmask = N_BTMASK;
2043
24.6k
  coff->local_n_btshft = N_BTSHFT;
2044
24.6k
  coff->local_n_tmask = N_TMASK;
2045
24.6k
  coff->local_n_tshift = N_TSHIFT;
2046
24.6k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
24.6k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
24.6k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
24.6k
  coff->timestamp = internal_f->f_timdat;
2051
2052
24.6k
  obj_raw_syment_count (abfd) =
2053
24.6k
    obj_conv_table_size (abfd) =
2054
24.6k
      internal_f->f_nsyms;
2055
2056
24.6k
#ifdef RS6000COFF_C
2057
24.6k
  if ((internal_f->f_flags & F_SHROBJ) != 0)
2058
19.1k
    abfd->flags |= DYNAMIC;
2059
24.6k
  if (aouthdr != NULL && internal_f->f_opthdr >= bfd_coff_aoutsz (abfd))
2060
7.45k
    {
2061
7.45k
      struct internal_aouthdr *internal_a =
2062
7.45k
  (struct internal_aouthdr *) aouthdr;
2063
7.45k
      struct xcoff_tdata *xcoff;
2064
2065
7.45k
      xcoff = xcoff_data (abfd);
2066
# ifdef U803XTOCMAGIC
2067
      xcoff->xcoff64 = internal_f->f_magic == U803XTOCMAGIC;
2068
# else
2069
7.45k
      xcoff->xcoff64 = 0;
2070
7.45k
# endif
2071
7.45k
      xcoff->full_aouthdr = true;
2072
7.45k
      xcoff->toc = internal_a->o_toc;
2073
7.45k
      xcoff->sntoc = internal_a->o_sntoc;
2074
7.45k
      xcoff->snentry = internal_a->o_snentry;
2075
7.45k
      bfd_xcoff_text_align_power (abfd) = internal_a->o_algntext;
2076
7.45k
      bfd_xcoff_data_align_power (abfd) = internal_a->o_algndata;
2077
7.45k
      xcoff->modtype = internal_a->o_modtype;
2078
7.45k
      xcoff->cputype = internal_a->o_cputype;
2079
7.45k
      xcoff->maxdata = internal_a->o_maxdata;
2080
7.45k
      xcoff->maxstack = internal_a->o_maxstack;
2081
7.45k
    }
2082
24.6k
#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
24.6k
  return coff;
2098
24.6k
}
coff-sh.c:coff_mkobject_hook
Line
Count
Source
2028
16.2k
{
2029
16.2k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
16.2k
  coff_data_type *coff;
2031
2032
16.2k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
16.2k
  coff = coff_data (abfd);
2036
2037
16.2k
  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
16.2k
  coff->local_n_btmask = N_BTMASK;
2043
16.2k
  coff->local_n_btshft = N_BTSHFT;
2044
16.2k
  coff->local_n_tmask = N_TMASK;
2045
16.2k
  coff->local_n_tshift = N_TSHIFT;
2046
16.2k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
16.2k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
16.2k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
16.2k
  coff->timestamp = internal_f->f_timdat;
2051
2052
16.2k
  obj_raw_syment_count (abfd) =
2053
16.2k
    obj_conv_table_size (abfd) =
2054
16.2k
      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
16.2k
  return coff;
2098
16.2k
}
Unexecuted instantiation: coff-stgo32.c:coff_mkobject_hook
coff-tic30.c:coff_mkobject_hook
Line
Count
Source
2028
13.2k
{
2029
13.2k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
13.2k
  coff_data_type *coff;
2031
2032
13.2k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
13.2k
  coff = coff_data (abfd);
2036
2037
13.2k
  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
13.2k
  coff->local_n_btmask = N_BTMASK;
2043
13.2k
  coff->local_n_btshft = N_BTSHFT;
2044
13.2k
  coff->local_n_tmask = N_TMASK;
2045
13.2k
  coff->local_n_tshift = N_TSHIFT;
2046
13.2k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
13.2k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
13.2k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
13.2k
  coff->timestamp = internal_f->f_timdat;
2051
2052
13.2k
  obj_raw_syment_count (abfd) =
2053
13.2k
    obj_conv_table_size (abfd) =
2054
13.2k
      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
13.2k
  return coff;
2098
13.2k
}
Unexecuted instantiation: coff-tic4x.c:coff_mkobject_hook
coff-tic54x.c:coff_mkobject_hook
Line
Count
Source
2028
27.9k
{
2029
27.9k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
27.9k
  coff_data_type *coff;
2031
2032
27.9k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
27.9k
  coff = coff_data (abfd);
2036
2037
27.9k
  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
27.9k
  coff->local_n_btmask = N_BTMASK;
2043
27.9k
  coff->local_n_btshft = N_BTSHFT;
2044
27.9k
  coff->local_n_tmask = N_TMASK;
2045
27.9k
  coff->local_n_tshift = N_TSHIFT;
2046
27.9k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
27.9k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
27.9k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
27.9k
  coff->timestamp = internal_f->f_timdat;
2051
2052
27.9k
  obj_raw_syment_count (abfd) =
2053
27.9k
    obj_conv_table_size (abfd) =
2054
27.9k
      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
27.9k
  return coff;
2098
27.9k
}
coff-z80.c:coff_mkobject_hook
Line
Count
Source
2028
8.74k
{
2029
8.74k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
8.74k
  coff_data_type *coff;
2031
2032
8.74k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
8.74k
  coff = coff_data (abfd);
2036
2037
8.74k
  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
8.74k
  coff->local_n_btmask = N_BTMASK;
2043
8.74k
  coff->local_n_btshft = N_BTSHFT;
2044
8.74k
  coff->local_n_tmask = N_TMASK;
2045
8.74k
  coff->local_n_tshift = N_TSHIFT;
2046
8.74k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
8.74k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
8.74k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
8.74k
  coff->timestamp = internal_f->f_timdat;
2051
2052
8.74k
  obj_raw_syment_count (abfd) =
2053
8.74k
    obj_conv_table_size (abfd) =
2054
8.74k
      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
8.74k
  return coff;
2098
8.74k
}
coff-z8k.c:coff_mkobject_hook
Line
Count
Source
2028
8.91k
{
2029
8.91k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2030
8.91k
  coff_data_type *coff;
2031
2032
8.91k
  if (! coff_mkobject (abfd))
2033
0
    return NULL;
2034
2035
8.91k
  coff = coff_data (abfd);
2036
2037
8.91k
  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
8.91k
  coff->local_n_btmask = N_BTMASK;
2043
8.91k
  coff->local_n_btshft = N_BTSHFT;
2044
8.91k
  coff->local_n_tmask = N_TMASK;
2045
8.91k
  coff->local_n_tshift = N_TSHIFT;
2046
8.91k
  coff->local_symesz = bfd_coff_symesz (abfd);
2047
8.91k
  coff->local_auxesz = bfd_coff_auxesz (abfd);
2048
8.91k
  coff->local_linesz = bfd_coff_linesz (abfd);
2049
2050
8.91k
  coff->timestamp = internal_f->f_timdat;
2051
2052
8.91k
  obj_raw_syment_count (abfd) =
2053
8.91k
    obj_conv_table_size (abfd) =
2054
8.91k
      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
8.91k
  return coff;
2098
8.91k
}
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
454k
{
2111
454k
  unsigned long machine;
2112
454k
  enum bfd_architecture arch;
2113
454k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
454k
  machine = 0;
2117
454k
  switch (internal_f->f_magic)
2118
454k
    {
2119
#ifdef I386MAGIC
2120
2.42k
    case I386MAGIC:
2121
2.82k
    case I386PTXMAGIC:
2122
6.92k
    case I386AIXMAGIC:   /* Danbury PS/2 AIX C Compiler.  */
2123
88.9k
    case LYNXCOFFMAGIC:
2124
89.1k
    case I386_APPLE_MAGIC:
2125
89.1k
    case I386_FREEBSD_MAGIC:
2126
89.1k
    case I386_LINUX_MAGIC:
2127
89.1k
    case I386_NETBSD_MAGIC:
2128
89.1k
      arch = bfd_arch_i386;
2129
89.1k
      break;
2130
0
#endif
2131
#ifdef AMD64MAGIC
2132
1.70k
    case AMD64MAGIC:
2133
50.4k
    case AMD64_APPLE_MAGIC:
2134
50.4k
    case AMD64_FREEBSD_MAGIC:
2135
82.5k
    case AMD64_LINUX_MAGIC:
2136
82.5k
    case AMD64_NETBSD_MAGIC:
2137
82.5k
      arch = bfd_arch_i386;
2138
82.5k
      machine = bfd_mach_x86_64;
2139
82.5k
      break;
2140
0
#endif
2141
#ifdef IA64MAGIC
2142
22.6k
    case IA64MAGIC:
2143
22.6k
      arch = bfd_arch_ia64;
2144
22.6k
      break;
2145
0
#endif
2146
#ifdef ARMMAGIC
2147
31.1k
    case ARMMAGIC:
2148
32.9k
    case ARMPEMAGIC:
2149
39.1k
    case THUMBPEMAGIC:
2150
39.1k
      arch = bfd_arch_arm;
2151
39.1k
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
39.1k
      if (machine == bfd_mach_arm_unknown)
2153
39.1k
  {
2154
39.1k
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
39.1k
      {
2156
3.79k
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
2.25k
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
1.64k
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
18.0k
      default:
2160
19.0k
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
3.54k
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
6.51k
      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
2.41k
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
39.1k
      }
2170
39.1k
  }
2171
39.1k
      break;
2172
39.1k
#endif
2173
#ifdef AARCH64MAGIC
2174
18.8k
    case AARCH64MAGIC:
2175
18.8k
      arch = bfd_arch_aarch64;
2176
18.8k
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
18.8k
      break;
2178
0
#endif
2179
#ifdef LOONGARCH64MAGIC
2180
21.4k
    case LOONGARCH64MAGIC:
2181
21.4k
      arch = bfd_arch_loongarch;
2182
21.4k
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
21.4k
      break;
2184
0
#endif
2185
#ifdef Z80MAGIC
2186
8.63k
    case Z80MAGIC:
2187
8.63k
      arch = bfd_arch_z80;
2188
8.63k
      switch (internal_f->f_flags & F_MACHMASK)
2189
8.63k
  {
2190
102
  case bfd_mach_z80strict << 12:
2191
1.91k
  case bfd_mach_z80 << 12:
2192
4.05k
  case bfd_mach_z80n << 12:
2193
4.28k
  case bfd_mach_z80full << 12:
2194
5.86k
  case bfd_mach_r800 << 12:
2195
6.19k
  case bfd_mach_gbz80 << 12:
2196
7.22k
  case bfd_mach_z180 << 12:
2197
7.59k
  case bfd_mach_ez80_z80 << 12:
2198
8.53k
  case bfd_mach_ez80_adl << 12:
2199
8.53k
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
8.53k
    break;
2201
104
  default:
2202
104
    return false;
2203
8.63k
  }
2204
8.53k
      break;
2205
8.53k
#endif
2206
#ifdef Z8KMAGIC
2207
8.81k
    case Z8KMAGIC:
2208
8.81k
      arch = bfd_arch_z8k;
2209
8.81k
      switch (internal_f->f_flags & F_MACHMASK)
2210
8.81k
  {
2211
3.68k
  case F_Z8001:
2212
3.68k
    machine = bfd_mach_z8001;
2213
3.68k
    break;
2214
5.01k
  case F_Z8002:
2215
5.01k
    machine = bfd_mach_z8002;
2216
5.01k
    break;
2217
107
  default:
2218
107
    return false;
2219
8.81k
  }
2220
8.70k
      break;
2221
8.70k
#endif
2222
2223
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
19.7k
    case U64_TOCMAGIC:
2226
19.7k
    case U803XTOCMAGIC:
2227
#else
2228
16.8k
    case U802ROMAGIC:
2229
17.4k
    case U802WRMAGIC:
2230
24.3k
    case U802TOCMAGIC:
2231
#endif
2232
24.3k
      {
2233
24.3k
  int cputype;
2234
2235
44.1k
  if (xcoff_data (abfd)->cputype != -1)
2236
13.2k
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
30.9k
  else
2238
30.9k
    {
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
30.9k
      if (obj_raw_syment_count (abfd) == 0)
2244
12.1k
        cputype = 0;
2245
18.7k
      else
2246
18.7k
        {
2247
18.7k
    bfd_byte *buf;
2248
18.7k
    struct internal_syment sym;
2249
18.7k
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
18.7k
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
115
      return false;
2253
18.6k
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
18.6k
    if (buf == NULL)
2255
219
      return false;
2256
18.4k
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
18.4k
    if (sym.n_sclass == C_FILE)
2258
397
      cputype = sym.n_type & 0xff;
2259
18.0k
    else
2260
18.0k
      cputype = 0;
2261
18.4k
    free (buf);
2262
18.4k
        }
2263
30.9k
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
43.8k
  switch (cputype)
2267
43.8k
    {
2268
8.34k
    default:
2269
41.2k
    case 0:
2270
41.2k
      arch = bfd_xcoff_architecture (abfd);
2271
41.2k
      machine = bfd_xcoff_machine (abfd);
2272
41.2k
      break;
2273
2274
710
    case 1:
2275
710
      arch = bfd_arch_powerpc;
2276
710
      machine = bfd_mach_ppc_601;
2277
710
      break;
2278
885
    case 2: /* 64 bit PowerPC */
2279
885
      arch = bfd_arch_powerpc;
2280
885
      machine = bfd_mach_ppc_620;
2281
885
      break;
2282
539
    case 3:
2283
539
      arch = bfd_arch_powerpc;
2284
539
      machine = bfd_mach_ppc;
2285
539
      break;
2286
473
    case 4:
2287
473
      arch = bfd_arch_rs6000;
2288
473
      machine = bfd_mach_rs6k;
2289
473
      break;
2290
43.8k
    }
2291
43.8k
      }
2292
43.8k
      break;
2293
43.8k
#endif
2294
2295
#ifdef SH_ARCH_MAGIC_BIG
2296
37.2k
    case SH_ARCH_MAGIC_BIG:
2297
37.2k
    case SH_ARCH_MAGIC_LITTLE:
2298
#ifdef COFF_WITH_PE
2299
27.9k
    case SH_ARCH_MAGIC_WINCE:
2300
#endif
2301
27.9k
      arch = bfd_arch_sh;
2302
27.9k
      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
13.0k
    case TIC30MAGIC:
2322
13.0k
      arch = bfd_arch_tic30;
2323
13.0k
      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
24.8k
    case TICOFF0MAGIC:
2330
24.8k
      arch = TICOFF_TARGET_ARCH;
2331
24.8k
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
24.8k
      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
29.6k
    case MCOREMAGIC:
2361
29.6k
      arch = bfd_arch_mcore;
2362
29.6k
      break;
2363
0
#endif
2364
2365
10.2k
    default:      /* Unreadable input file type.  */
2366
10.2k
      arch = bfd_arch_obscure;
2367
10.2k
      break;
2368
454k
    }
2369
2370
453k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
453k
  return true;
2372
454k
}
pei-i386.c:coff_set_arch_mach_hook
Line
Count
Source
2110
23.2k
{
2111
23.2k
  unsigned long machine;
2112
23.2k
  enum bfd_architecture arch;
2113
23.2k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
23.2k
  machine = 0;
2117
23.2k
  switch (internal_f->f_magic)
2118
23.2k
    {
2119
0
#ifdef I386MAGIC
2120
1.99k
    case I386MAGIC:
2121
1.99k
    case I386PTXMAGIC:
2122
5.22k
    case I386AIXMAGIC:   /* Danbury PS/2 AIX C Compiler.  */
2123
23.1k
    case LYNXCOFFMAGIC:
2124
23.2k
    case I386_APPLE_MAGIC:
2125
23.2k
    case I386_FREEBSD_MAGIC:
2126
23.2k
    case I386_LINUX_MAGIC:
2127
23.2k
    case I386_NETBSD_MAGIC:
2128
23.2k
      arch = bfd_arch_i386;
2129
23.2k
      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
23.2k
    }
2369
2370
23.2k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
23.2k
  return true;
2372
23.2k
}
pe-x86_64.c:coff_set_arch_mach_hook
Line
Count
Source
2110
26.6k
{
2111
26.6k
  unsigned long machine;
2112
26.6k
  enum bfd_architecture arch;
2113
26.6k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
26.6k
  machine = 0;
2117
26.6k
  switch (internal_f->f_magic)
2118
26.6k
    {
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
0
    case AMD64MAGIC:
2133
26.6k
    case AMD64_APPLE_MAGIC:
2134
26.6k
    case AMD64_FREEBSD_MAGIC:
2135
26.6k
    case AMD64_LINUX_MAGIC:
2136
26.6k
    case AMD64_NETBSD_MAGIC:
2137
26.6k
      arch = bfd_arch_i386;
2138
26.6k
      machine = bfd_mach_x86_64;
2139
26.6k
      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
26.6k
    }
2369
2370
26.6k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
26.6k
  return true;
2372
26.6k
}
pei-x86_64.c:coff_set_arch_mach_hook
Line
Count
Source
2110
35.3k
{
2111
35.3k
  unsigned long machine;
2112
35.3k
  enum bfd_architecture arch;
2113
35.3k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
35.3k
  machine = 0;
2117
35.3k
  switch (internal_f->f_magic)
2118
35.3k
    {
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.70k
    case AMD64MAGIC:
2133
3.21k
    case AMD64_APPLE_MAGIC:
2134
3.21k
    case AMD64_FREEBSD_MAGIC:
2135
35.3k
    case AMD64_LINUX_MAGIC:
2136
35.3k
    case AMD64_NETBSD_MAGIC:
2137
35.3k
      arch = bfd_arch_i386;
2138
35.3k
      machine = bfd_mach_x86_64;
2139
35.3k
      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
35.3k
    }
2369
2370
35.3k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
35.3k
  return true;
2372
35.3k
}
coff-x86_64.c:coff_set_arch_mach_hook
Line
Count
Source
2110
20.6k
{
2111
20.6k
  unsigned long machine;
2112
20.6k
  enum bfd_architecture arch;
2113
20.6k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
20.6k
  machine = 0;
2117
20.6k
  switch (internal_f->f_magic)
2118
20.6k
    {
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
0
    case AMD64MAGIC:
2133
20.6k
    case AMD64_APPLE_MAGIC:
2134
20.6k
    case AMD64_FREEBSD_MAGIC:
2135
20.6k
    case AMD64_LINUX_MAGIC:
2136
20.6k
    case AMD64_NETBSD_MAGIC:
2137
20.6k
      arch = bfd_arch_i386;
2138
20.6k
      machine = bfd_mach_x86_64;
2139
20.6k
      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
20.6k
    }
2369
2370
20.6k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
20.6k
  return true;
2372
20.6k
}
coff64-rs6000.c:coff_set_arch_mach_hook
Line
Count
Source
2110
19.7k
{
2111
19.7k
  unsigned long machine;
2112
19.7k
  enum bfd_architecture arch;
2113
19.7k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
19.7k
  machine = 0;
2117
19.7k
  switch (internal_f->f_magic)
2118
19.7k
    {
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
0
#ifdef RS6000COFF_C
2224
0
#ifdef XCOFF64
2225
19.7k
    case U64_TOCMAGIC:
2226
19.7k
    case U803XTOCMAGIC:
2227
#else
2228
    case U802ROMAGIC:
2229
    case U802WRMAGIC:
2230
    case U802TOCMAGIC:
2231
#endif
2232
19.7k
      {
2233
19.7k
  int cputype;
2234
2235
19.7k
  if (xcoff_data (abfd)->cputype != -1)
2236
6.14k
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
13.6k
  else
2238
13.6k
    {
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
13.6k
      if (obj_raw_syment_count (abfd) == 0)
2244
5.99k
        cputype = 0;
2245
7.65k
      else
2246
7.65k
        {
2247
7.65k
    bfd_byte *buf;
2248
7.65k
    struct internal_syment sym;
2249
7.65k
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
7.65k
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
115
      return false;
2253
7.53k
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
7.53k
    if (buf == NULL)
2255
109
      return false;
2256
7.43k
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
7.43k
    if (sym.n_sclass == C_FILE)
2258
132
      cputype = sym.n_type & 0xff;
2259
7.29k
    else
2260
7.29k
      cputype = 0;
2261
7.43k
    free (buf);
2262
7.43k
        }
2263
13.6k
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
19.5k
  switch (cputype)
2267
19.5k
    {
2268
4.08k
    default:
2269
18.7k
    case 0:
2270
18.7k
      arch = bfd_xcoff_architecture (abfd);
2271
18.7k
      machine = bfd_xcoff_machine (abfd);
2272
18.7k
      break;
2273
2274
134
    case 1:
2275
134
      arch = bfd_arch_powerpc;
2276
134
      machine = bfd_mach_ppc_601;
2277
134
      break;
2278
342
    case 2: /* 64 bit PowerPC */
2279
342
      arch = bfd_arch_powerpc;
2280
342
      machine = bfd_mach_ppc_620;
2281
342
      break;
2282
102
    case 3:
2283
102
      arch = bfd_arch_powerpc;
2284
102
      machine = bfd_mach_ppc;
2285
102
      break;
2286
234
    case 4:
2287
234
      arch = bfd_arch_rs6000;
2288
234
      machine = bfd_mach_rs6k;
2289
234
      break;
2290
19.5k
    }
2291
19.5k
      }
2292
19.5k
      break;
2293
19.5k
#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
19.5k
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
19.7k
    }
2369
2370
19.5k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
19.5k
  return true;
2372
19.7k
}
pei-aarch64.c:coff_set_arch_mach_hook
Line
Count
Source
2110
13.1k
{
2111
13.1k
  unsigned long machine;
2112
13.1k
  enum bfd_architecture arch;
2113
13.1k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
13.1k
  machine = 0;
2117
13.1k
  switch (internal_f->f_magic)
2118
13.1k
    {
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
13.1k
    case AARCH64MAGIC:
2175
13.1k
      arch = bfd_arch_aarch64;
2176
13.1k
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
13.1k
      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
13.1k
    }
2369
2370
13.1k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
13.1k
  return true;
2372
13.1k
}
pe-aarch64.c:coff_set_arch_mach_hook
Line
Count
Source
2110
5.74k
{
2111
5.74k
  unsigned long machine;
2112
5.74k
  enum bfd_architecture arch;
2113
5.74k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
5.74k
  machine = 0;
2117
5.74k
  switch (internal_f->f_magic)
2118
5.74k
    {
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
5.74k
    case AARCH64MAGIC:
2175
5.74k
      arch = bfd_arch_aarch64;
2176
5.74k
      machine = internal_f->f_flags & F_AARCH64_ARCHITECTURE_MASK;
2177
5.74k
      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
5.74k
    }
2369
2370
5.74k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
5.74k
  return true;
2372
5.74k
}
pei-ia64.c:coff_set_arch_mach_hook
Line
Count
Source
2110
22.6k
{
2111
22.6k
  unsigned long machine;
2112
22.6k
  enum bfd_architecture arch;
2113
22.6k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
22.6k
  machine = 0;
2117
22.6k
  switch (internal_f->f_magic)
2118
22.6k
    {
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
22.6k
    case IA64MAGIC:
2143
22.6k
      arch = bfd_arch_ia64;
2144
22.6k
      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
22.6k
    }
2369
2370
22.6k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
22.6k
  return true;
2372
22.6k
}
pei-loongarch64.c:coff_set_arch_mach_hook
Line
Count
Source
2110
21.4k
{
2111
21.4k
  unsigned long machine;
2112
21.4k
  enum bfd_architecture arch;
2113
21.4k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
21.4k
  machine = 0;
2117
21.4k
  switch (internal_f->f_magic)
2118
21.4k
    {
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
21.4k
    case LOONGARCH64MAGIC:
2181
21.4k
      arch = bfd_arch_loongarch;
2182
21.4k
      machine = internal_f->f_flags & F_LOONGARCH64_ARCHITECTURE_MASK;
2183
21.4k
      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
21.4k
    }
2369
2370
21.4k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
21.4k
  return true;
2372
21.4k
}
cf-i386lynx.c:coff_set_arch_mach_hook
Line
Count
Source
2110
16.2k
{
2111
16.2k
  unsigned long machine;
2112
16.2k
  enum bfd_architecture arch;
2113
16.2k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
16.2k
  machine = 0;
2117
16.2k
  switch (internal_f->f_magic)
2118
16.2k
    {
2119
0
#ifdef I386MAGIC
2120
106
    case I386MAGIC:
2121
208
    case I386PTXMAGIC:
2122
425
    case I386AIXMAGIC:   /* Danbury PS/2 AIX C Compiler.  */
2123
16.2k
    case LYNXCOFFMAGIC:
2124
16.2k
    case I386_APPLE_MAGIC:
2125
16.2k
    case I386_FREEBSD_MAGIC:
2126
16.2k
    case I386_LINUX_MAGIC:
2127
16.2k
    case I386_NETBSD_MAGIC:
2128
16.2k
      arch = bfd_arch_i386;
2129
16.2k
      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
16.2k
    }
2369
2370
16.2k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
16.2k
  return true;
2372
16.2k
}
coff-go32.c:coff_set_arch_mach_hook
Line
Count
Source
2110
16.2k
{
2111
16.2k
  unsigned long machine;
2112
16.2k
  enum bfd_architecture arch;
2113
16.2k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
16.2k
  machine = 0;
2117
16.2k
  switch (internal_f->f_magic)
2118
16.2k
    {
2119
0
#ifdef I386MAGIC
2120
106
    case I386MAGIC:
2121
208
    case I386PTXMAGIC:
2122
425
    case I386AIXMAGIC:   /* Danbury PS/2 AIX C Compiler.  */
2123
16.2k
    case LYNXCOFFMAGIC:
2124
16.2k
    case I386_APPLE_MAGIC:
2125
16.2k
    case I386_FREEBSD_MAGIC:
2126
16.2k
    case I386_LINUX_MAGIC:
2127
16.2k
    case I386_NETBSD_MAGIC:
2128
16.2k
      arch = bfd_arch_i386;
2129
16.2k
      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
16.2k
    }
2369
2370
16.2k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
16.2k
  return true;
2372
16.2k
}
coff-i386.c:coff_set_arch_mach_hook
Line
Count
Source
2110
16.2k
{
2111
16.2k
  unsigned long machine;
2112
16.2k
  enum bfd_architecture arch;
2113
16.2k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
16.2k
  machine = 0;
2117
16.2k
  switch (internal_f->f_magic)
2118
16.2k
    {
2119
0
#ifdef I386MAGIC
2120
106
    case I386MAGIC:
2121
208
    case I386PTXMAGIC:
2122
425
    case I386AIXMAGIC:   /* Danbury PS/2 AIX C Compiler.  */
2123
16.2k
    case LYNXCOFFMAGIC:
2124
16.2k
    case I386_APPLE_MAGIC:
2125
16.2k
    case I386_FREEBSD_MAGIC:
2126
16.2k
    case I386_LINUX_MAGIC:
2127
16.2k
    case I386_NETBSD_MAGIC:
2128
16.2k
      arch = bfd_arch_i386;
2129
16.2k
      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
16.2k
    }
2369
2370
16.2k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
16.2k
  return true;
2372
16.2k
}
coff-rs6000.c:coff_set_arch_mach_hook
Line
Count
Source
2110
24.3k
{
2111
24.3k
  unsigned long machine;
2112
24.3k
  enum bfd_architecture arch;
2113
24.3k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
24.3k
  machine = 0;
2117
24.3k
  switch (internal_f->f_magic)
2118
24.3k
    {
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
0
#ifdef RS6000COFF_C
2224
#ifdef XCOFF64
2225
    case U64_TOCMAGIC:
2226
    case U803XTOCMAGIC:
2227
#else
2228
16.8k
    case U802ROMAGIC:
2229
17.4k
    case U802WRMAGIC:
2230
24.3k
    case U802TOCMAGIC:
2231
24.3k
#endif
2232
24.3k
      {
2233
24.3k
  int cputype;
2234
2235
24.3k
  if (xcoff_data (abfd)->cputype != -1)
2236
7.11k
    cputype = xcoff_data (abfd)->cputype & 0xff;
2237
17.2k
  else
2238
17.2k
    {
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
17.2k
      if (obj_raw_syment_count (abfd) == 0)
2244
6.12k
        cputype = 0;
2245
11.1k
      else
2246
11.1k
        {
2247
11.1k
    bfd_byte *buf;
2248
11.1k
    struct internal_syment sym;
2249
11.1k
    bfd_size_type amt = bfd_coff_symesz (abfd);
2250
2251
11.1k
    if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0)
2252
0
      return false;
2253
11.1k
    buf = _bfd_malloc_and_read (abfd, amt, amt);
2254
11.1k
    if (buf == NULL)
2255
110
      return false;
2256
11.0k
    bfd_coff_swap_sym_in (abfd, buf, & sym);
2257
11.0k
    if (sym.n_sclass == C_FILE)
2258
265
      cputype = sym.n_type & 0xff;
2259
10.7k
    else
2260
10.7k
      cputype = 0;
2261
11.0k
    free (buf);
2262
11.0k
        }
2263
17.2k
    }
2264
2265
  /* FIXME: We don't handle all cases here.  */
2266
24.2k
  switch (cputype)
2267
24.2k
    {
2268
4.26k
    default:
2269
22.4k
    case 0:
2270
22.4k
      arch = bfd_xcoff_architecture (abfd);
2271
22.4k
      machine = bfd_xcoff_machine (abfd);
2272
22.4k
      break;
2273
2274
576
    case 1:
2275
576
      arch = bfd_arch_powerpc;
2276
576
      machine = bfd_mach_ppc_601;
2277
576
      break;
2278
543
    case 2: /* 64 bit PowerPC */
2279
543
      arch = bfd_arch_powerpc;
2280
543
      machine = bfd_mach_ppc_620;
2281
543
      break;
2282
437
    case 3:
2283
437
      arch = bfd_arch_powerpc;
2284
437
      machine = bfd_mach_ppc;
2285
437
      break;
2286
239
    case 4:
2287
239
      arch = bfd_arch_rs6000;
2288
239
      machine = bfd_mach_rs6k;
2289
239
      break;
2290
24.2k
    }
2291
24.2k
      }
2292
24.2k
      break;
2293
24.2k
#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
24.2k
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
24.3k
    }
2369
2370
24.2k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
24.2k
  return true;
2372
24.3k
}
coff-sh.c:coff_set_arch_mach_hook
Line
Count
Source
2110
15.8k
{
2111
15.8k
  unsigned long machine;
2112
15.8k
  enum bfd_architecture arch;
2113
15.8k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
15.8k
  machine = 0;
2117
15.8k
  switch (internal_f->f_magic)
2118
15.8k
    {
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
13.1k
    case SH_ARCH_MAGIC_BIG:
2297
13.1k
    case SH_ARCH_MAGIC_LITTLE:
2298
#ifdef COFF_WITH_PE
2299
    case SH_ARCH_MAGIC_WINCE:
2300
#endif
2301
13.1k
      arch = bfd_arch_sh;
2302
13.1k
      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
2.73k
    default:      /* Unreadable input file type.  */
2366
2.73k
      arch = bfd_arch_obscure;
2367
2.73k
      break;
2368
15.8k
    }
2369
2370
15.8k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
15.8k
  return true;
2372
15.8k
}
Unexecuted instantiation: coff-stgo32.c:coff_set_arch_mach_hook
coff-tic30.c:coff_set_arch_mach_hook
Line
Count
Source
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
    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
0
#ifdef TIC30MAGIC
2321
13.0k
    case TIC30MAGIC:
2322
13.0k
      arch = bfd_arch_tic30;
2323
13.0k
      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
    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
13.0k
    }
2369
2370
13.0k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
13.0k
  return true;
2372
13.0k
}
Unexecuted instantiation: coff-tic4x.c:coff_set_arch_mach_hook
coff-tic54x.c:coff_set_arch_mach_hook
Line
Count
Source
2110
24.8k
{
2111
24.8k
  unsigned long machine;
2112
24.8k
  enum bfd_architecture arch;
2113
24.8k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
24.8k
  machine = 0;
2117
24.8k
  switch (internal_f->f_magic)
2118
24.8k
    {
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
0
#ifdef TICOFF0MAGIC
2327
0
#ifdef TICOFF_TARGET_ARCH
2328
      /* This TI COFF section should be used by all new TI COFF v0 targets.  */
2329
24.8k
    case TICOFF0MAGIC:
2330
24.8k
      arch = TICOFF_TARGET_ARCH;
2331
24.8k
      machine = TICOFF_TARGET_MACHINE_GET (internal_f->f_flags);
2332
24.8k
      break;
2333
0
#endif
2334
0
#endif
2335
2336
0
#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
    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
24.8k
    }
2369
2370
24.8k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
24.8k
  return true;
2372
24.8k
}
coff-z80.c:coff_set_arch_mach_hook
Line
Count
Source
2110
8.63k
{
2111
8.63k
  unsigned long machine;
2112
8.63k
  enum bfd_architecture arch;
2113
8.63k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
8.63k
  machine = 0;
2117
8.63k
  switch (internal_f->f_magic)
2118
8.63k
    {
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
0
#ifdef Z80MAGIC
2186
8.63k
    case Z80MAGIC:
2187
8.63k
      arch = bfd_arch_z80;
2188
8.63k
      switch (internal_f->f_flags & F_MACHMASK)
2189
8.63k
  {
2190
102
  case bfd_mach_z80strict << 12:
2191
1.91k
  case bfd_mach_z80 << 12:
2192
4.05k
  case bfd_mach_z80n << 12:
2193
4.28k
  case bfd_mach_z80full << 12:
2194
5.86k
  case bfd_mach_r800 << 12:
2195
6.19k
  case bfd_mach_gbz80 << 12:
2196
7.22k
  case bfd_mach_z180 << 12:
2197
7.59k
  case bfd_mach_ez80_z80 << 12:
2198
8.53k
  case bfd_mach_ez80_adl << 12:
2199
8.53k
    machine = ((unsigned)internal_f->f_flags & F_MACHMASK) >> 12;
2200
8.53k
    break;
2201
104
  default:
2202
104
    return false;
2203
8.63k
  }
2204
8.53k
      break;
2205
8.53k
#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
8.53k
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
8.63k
    }
2369
2370
8.53k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
8.53k
  return true;
2372
8.63k
}
coff-z8k.c:coff_set_arch_mach_hook
Line
Count
Source
2110
8.81k
{
2111
8.81k
  unsigned long machine;
2112
8.81k
  enum bfd_architecture arch;
2113
8.81k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
8.81k
  machine = 0;
2117
8.81k
  switch (internal_f->f_magic)
2118
8.81k
    {
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
0
#ifdef Z8KMAGIC
2207
8.81k
    case Z8KMAGIC:
2208
8.81k
      arch = bfd_arch_z8k;
2209
8.81k
      switch (internal_f->f_flags & F_MACHMASK)
2210
8.81k
  {
2211
3.68k
  case F_Z8001:
2212
3.68k
    machine = bfd_mach_z8001;
2213
3.68k
    break;
2214
5.01k
  case F_Z8002:
2215
5.01k
    machine = bfd_mach_z8002;
2216
5.01k
    break;
2217
107
  default:
2218
107
    return false;
2219
8.81k
  }
2220
8.70k
      break;
2221
8.70k
#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
8.70k
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
8.81k
    }
2369
2370
8.70k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
8.70k
  return true;
2372
8.81k
}
pe-arm-wince.c:coff_set_arch_mach_hook
Line
Count
Source
2110
4.63k
{
2111
4.63k
  unsigned long machine;
2112
4.63k
  enum bfd_architecture arch;
2113
4.63k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
4.63k
  machine = 0;
2117
4.63k
  switch (internal_f->f_magic)
2118
4.63k
    {
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
3.91k
    case ARMMAGIC:
2148
4.19k
    case ARMPEMAGIC:
2149
4.20k
    case THUMBPEMAGIC:
2150
4.20k
      arch = bfd_arch_arm;
2151
4.20k
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
4.20k
      if (machine == bfd_mach_arm_unknown)
2153
4.20k
  {
2154
4.20k
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
4.20k
      {
2156
820
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
414
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
330
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
1.47k
      default:
2160
1.47k
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
940
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
108
      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
110
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
4.20k
      }
2170
4.20k
  }
2171
4.20k
      break;
2172
4.20k
#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
4.20k
    default:      /* Unreadable input file type.  */
2366
436
      arch = bfd_arch_obscure;
2367
436
      break;
2368
4.63k
    }
2369
2370
4.63k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
4.63k
  return true;
2372
4.63k
}
pe-arm.c:coff_set_arch_mach_hook
Line
Count
Source
2110
4.63k
{
2111
4.63k
  unsigned long machine;
2112
4.63k
  enum bfd_architecture arch;
2113
4.63k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
4.63k
  machine = 0;
2117
4.63k
  switch (internal_f->f_magic)
2118
4.63k
    {
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
3.91k
    case ARMMAGIC:
2148
4.19k
    case ARMPEMAGIC:
2149
4.20k
    case THUMBPEMAGIC:
2150
4.20k
      arch = bfd_arch_arm;
2151
4.20k
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
4.20k
      if (machine == bfd_mach_arm_unknown)
2153
4.20k
  {
2154
4.20k
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
4.20k
      {
2156
820
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
414
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
330
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
1.47k
      default:
2160
1.47k
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
940
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
108
      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
110
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
4.20k
      }
2170
4.20k
  }
2171
4.20k
      break;
2172
4.20k
#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
4.20k
    default:      /* Unreadable input file type.  */
2366
436
      arch = bfd_arch_obscure;
2367
436
      break;
2368
4.63k
    }
2369
2370
4.63k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
4.63k
  return true;
2372
4.63k
}
pe-i386.c:coff_set_arch_mach_hook
Line
Count
Source
2110
17.1k
{
2111
17.1k
  unsigned long machine;
2112
17.1k
  enum bfd_architecture arch;
2113
17.1k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
17.1k
  machine = 0;
2117
17.1k
  switch (internal_f->f_magic)
2118
17.1k
    {
2119
0
#ifdef I386MAGIC
2120
106
    case I386MAGIC:
2121
208
    case I386PTXMAGIC:
2122
425
    case I386AIXMAGIC:   /* Danbury PS/2 AIX C Compiler.  */
2123
17.1k
    case LYNXCOFFMAGIC:
2124
17.1k
    case I386_APPLE_MAGIC:
2125
17.1k
    case I386_FREEBSD_MAGIC:
2126
17.1k
    case I386_LINUX_MAGIC:
2127
17.1k
    case I386_NETBSD_MAGIC:
2128
17.1k
      arch = bfd_arch_i386;
2129
17.1k
      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
17.1k
    }
2369
2370
17.1k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
17.1k
  return true;
2372
17.1k
}
pe-mcore.c:coff_set_arch_mach_hook
Line
Count
Source
2110
8.42k
{
2111
8.42k
  unsigned long machine;
2112
8.42k
  enum bfd_architecture arch;
2113
8.42k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
8.42k
  machine = 0;
2117
8.42k
  switch (internal_f->f_magic)
2118
8.42k
    {
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
8.42k
    case MCOREMAGIC:
2361
8.42k
      arch = bfd_arch_mcore;
2362
8.42k
      break;
2363
0
#endif
2364
2365
0
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
8.42k
    }
2369
2370
8.42k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
8.42k
  return true;
2372
8.42k
}
pe-sh.c:coff_set_arch_mach_hook
Line
Count
Source
2110
11.2k
{
2111
11.2k
  unsigned long machine;
2112
11.2k
  enum bfd_architecture arch;
2113
11.2k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
11.2k
  machine = 0;
2117
11.2k
  switch (internal_f->f_magic)
2118
11.2k
    {
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
9.89k
    case SH_ARCH_MAGIC_BIG:
2297
9.89k
    case SH_ARCH_MAGIC_LITTLE:
2298
9.89k
#ifdef COFF_WITH_PE
2299
11.2k
    case SH_ARCH_MAGIC_WINCE:
2300
11.2k
#endif
2301
11.2k
      arch = bfd_arch_sh;
2302
11.2k
      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
11.2k
    }
2369
2370
11.2k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
11.2k
  return true;
2372
11.2k
}
pei-arm-wince.c:coff_set_arch_mach_hook
Line
Count
Source
2110
16.1k
{
2111
16.1k
  unsigned long machine;
2112
16.1k
  enum bfd_architecture arch;
2113
16.1k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
16.1k
  machine = 0;
2117
16.1k
  switch (internal_f->f_magic)
2118
16.1k
    {
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
10.9k
    case ARMMAGIC:
2148
10.9k
    case ARMPEMAGIC:
2149
13.0k
    case THUMBPEMAGIC:
2150
13.0k
      arch = bfd_arch_arm;
2151
13.0k
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
13.0k
      if (machine == bfd_mach_arm_unknown)
2153
13.0k
  {
2154
13.0k
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
13.0k
      {
2156
1.07k
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
137
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
375
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
7.33k
      default:
2160
7.61k
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
780
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
2.73k
      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
345
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
13.0k
      }
2170
13.0k
  }
2171
13.0k
      break;
2172
13.0k
#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
13.0k
    default:      /* Unreadable input file type.  */
2366
3.05k
      arch = bfd_arch_obscure;
2367
3.05k
      break;
2368
16.1k
    }
2369
2370
16.1k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
16.1k
  return true;
2372
16.1k
}
pei-arm.c:coff_set_arch_mach_hook
Line
Count
Source
2110
21.2k
{
2111
21.2k
  unsigned long machine;
2112
21.2k
  enum bfd_architecture arch;
2113
21.2k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
21.2k
  machine = 0;
2117
21.2k
  switch (internal_f->f_magic)
2118
21.2k
    {
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
12.3k
    case ARMMAGIC:
2148
13.5k
    case ARMPEMAGIC:
2149
17.7k
    case THUMBPEMAGIC:
2150
17.7k
      arch = bfd_arch_arm;
2151
17.7k
      machine = bfd_arm_get_mach_from_notes (abfd, ARM_NOTE_SECTION);
2152
17.7k
      if (machine == bfd_mach_arm_unknown)
2153
17.7k
  {
2154
17.7k
    switch (internal_f->f_flags & F_ARM_ARCHITECTURE_MASK)
2155
17.7k
      {
2156
1.08k
      case F_ARM_2:  machine = bfd_mach_arm_2;  break;
2157
1.29k
      case F_ARM_2a: machine = bfd_mach_arm_2a; break;
2158
609
      case F_ARM_3:  machine = bfd_mach_arm_3;  break;
2159
7.77k
      default:
2160
8.44k
      case F_ARM_3M: machine = bfd_mach_arm_3M; break;
2161
880
      case F_ARM_4:  machine = bfd_mach_arm_4;  break;
2162
3.56k
      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
1.85k
      case F_ARM_5:  machine = bfd_mach_arm_XScale;  break;
2169
17.7k
      }
2170
17.7k
  }
2171
17.7k
      break;
2172
17.7k
#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
17.7k
    default:      /* Unreadable input file type.  */
2366
3.56k
      arch = bfd_arch_obscure;
2367
3.56k
      break;
2368
21.2k
    }
2369
2370
21.2k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
21.2k
  return true;
2372
21.2k
}
pei-mcore.c:coff_set_arch_mach_hook
Line
Count
Source
2110
21.2k
{
2111
21.2k
  unsigned long machine;
2112
21.2k
  enum bfd_architecture arch;
2113
21.2k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
21.2k
  machine = 0;
2117
21.2k
  switch (internal_f->f_magic)
2118
21.2k
    {
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
21.2k
    case MCOREMAGIC:
2361
21.2k
      arch = bfd_arch_mcore;
2362
21.2k
      break;
2363
0
#endif
2364
2365
0
    default:      /* Unreadable input file type.  */
2366
0
      arch = bfd_arch_obscure;
2367
0
      break;
2368
21.2k
    }
2369
2370
21.2k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
21.2k
  return true;
2372
21.2k
}
pei-sh.c:coff_set_arch_mach_hook
Line
Count
Source
2110
16.6k
{
2111
16.6k
  unsigned long machine;
2112
16.6k
  enum bfd_architecture arch;
2113
16.6k
  struct internal_filehdr *internal_f = (struct internal_filehdr *) filehdr;
2114
2115
  /* Zero selects the default machine for an arch.  */
2116
16.6k
  machine = 0;
2117
16.6k
  switch (internal_f->f_magic)
2118
16.6k
    {
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
14.2k
    case SH_ARCH_MAGIC_BIG:
2297
14.2k
    case SH_ARCH_MAGIC_LITTLE:
2298
14.2k
#ifdef COFF_WITH_PE
2299
16.6k
    case SH_ARCH_MAGIC_WINCE:
2300
16.6k
#endif
2301
16.6k
      arch = bfd_arch_sh;
2302
16.6k
      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
16.6k
    }
2369
2370
16.6k
  bfd_default_set_arch_mach (abfd, arch, machine);
2371
16.6k
  return true;
2372
16.6k
}
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
1.05M
{
5634
1.05M
  struct external_ANON_OBJECT_HEADER_BIGOBJ *filehdr_src =
5635
1.05M
    (struct external_ANON_OBJECT_HEADER_BIGOBJ *) src;
5636
1.05M
  struct internal_filehdr *filehdr_dst = (struct internal_filehdr *) dst;
5637
5638
1.05M
  filehdr_dst->f_magic  = H_GET_16 (abfd, filehdr_src->Machine);
5639
1.05M
  filehdr_dst->f_nscns  = H_GET_32 (abfd, filehdr_src->NumberOfSections);
5640
1.05M
  filehdr_dst->f_timdat = H_GET_32 (abfd, filehdr_src->TimeDateStamp);
5641
1.05M
  filehdr_dst->f_symptr =
5642
1.05M
    GET_FILEHDR_SYMPTR (abfd, filehdr_src->PointerToSymbolTable);
5643
1.05M
  filehdr_dst->f_nsyms  = H_GET_32 (abfd, filehdr_src->NumberOfSymbols);
5644
1.05M
  filehdr_dst->f_opthdr = 0;
5645
1.05M
  filehdr_dst->f_flags  = 0;
5646
5647
  /* Check other magic numbers.  */
5648
1.05M
  if (H_GET_16 (abfd, filehdr_src->Sig1) != IMAGE_FILE_MACHINE_UNKNOWN
5649
1.05M
      || H_GET_16 (abfd, filehdr_src->Sig2) != 0xffff
5650
1.05M
      || H_GET_16 (abfd, filehdr_src->Version) != 2
5651
1.05M
      || memcmp (filehdr_src->ClassID, header_bigobj_classid, 16) != 0)
5652
1.05M
    filehdr_dst->f_opthdr = 0xffff;
5653
5654
  /* Note that CLR metadata are ignored.  */
5655
1.05M
}
pe-x86_64.c:coff_bigobj_swap_filehdr_in
Line
Count
Source
5633
529k
{
5634
529k
  struct external_ANON_OBJECT_HEADER_BIGOBJ *filehdr_src =
5635
529k
    (struct external_ANON_OBJECT_HEADER_BIGOBJ *) src;
5636
529k
  struct internal_filehdr *filehdr_dst = (struct internal_filehdr *) dst;
5637
5638
529k
  filehdr_dst->f_magic  = H_GET_16 (abfd, filehdr_src->Machine);
5639
529k
  filehdr_dst->f_nscns  = H_GET_32 (abfd, filehdr_src->NumberOfSections);
5640
529k
  filehdr_dst->f_timdat = H_GET_32 (abfd, filehdr_src->TimeDateStamp);
5641
529k
  filehdr_dst->f_symptr =
5642
529k
    GET_FILEHDR_SYMPTR (abfd, filehdr_src->PointerToSymbolTable);
5643
529k
  filehdr_dst->f_nsyms  = H_GET_32 (abfd, filehdr_src->NumberOfSymbols);
5644
529k
  filehdr_dst->f_opthdr = 0;
5645
529k
  filehdr_dst->f_flags  = 0;
5646
5647
  /* Check other magic numbers.  */
5648
529k
  if (H_GET_16 (abfd, filehdr_src->Sig1) != IMAGE_FILE_MACHINE_UNKNOWN
5649
529k
      || H_GET_16 (abfd, filehdr_src->Sig2) != 0xffff
5650
529k
      || H_GET_16 (abfd, filehdr_src->Version) != 2
5651
529k
      || memcmp (filehdr_src->ClassID, header_bigobj_classid, 16) != 0)
5652
529k
    filehdr_dst->f_opthdr = 0xffff;
5653
5654
  /* Note that CLR metadata are ignored.  */
5655
529k
}
pe-i386.c:coff_bigobj_swap_filehdr_in
Line
Count
Source
5633
527k
{
5634
527k
  struct external_ANON_OBJECT_HEADER_BIGOBJ *filehdr_src =
5635
527k
    (struct external_ANON_OBJECT_HEADER_BIGOBJ *) src;
5636
527k
  struct internal_filehdr *filehdr_dst = (struct internal_filehdr *) dst;
5637
5638
527k
  filehdr_dst->f_magic  = H_GET_16 (abfd, filehdr_src->Machine);
5639
527k
  filehdr_dst->f_nscns  = H_GET_32 (abfd, filehdr_src->NumberOfSections);
5640
527k
  filehdr_dst->f_timdat = H_GET_32 (abfd, filehdr_src->TimeDateStamp);
5641
527k
  filehdr_dst->f_symptr =
5642
527k
    GET_FILEHDR_SYMPTR (abfd, filehdr_src->PointerToSymbolTable);
5643
527k
  filehdr_dst->f_nsyms  = H_GET_32 (abfd, filehdr_src->NumberOfSymbols);
5644
527k
  filehdr_dst->f_opthdr = 0;
5645
527k
  filehdr_dst->f_flags  = 0;
5646
5647
  /* Check other magic numbers.  */
5648
527k
  if (H_GET_16 (abfd, filehdr_src->Sig1) != IMAGE_FILE_MACHINE_UNKNOWN
5649
527k
      || H_GET_16 (abfd, filehdr_src->Sig2) != 0xffff
5650
527k
      || H_GET_16 (abfd, filehdr_src->Version) != 2
5651
527k
      || memcmp (filehdr_src->ClassID, header_bigobj_classid, 16) != 0)
5652
527k
    filehdr_dst->f_opthdr = 0xffff;
5653
5654
  /* Note that CLR metadata are ignored.  */
5655
527k
}
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
};