binutils: Use file descriptors from make_tempname
[deliverable/binutils-gdb.git] / binutils / objcopy.c
CommitLineData
252b5132 1/* objcopy.c -- copy object file from input to output, optionally massaging it.
b3adc24a 2 Copyright (C) 1991-2020 Free Software Foundation, Inc.
252b5132
RH
3
4 This file is part of GNU Binutils.
5
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
32866df7 8 the Free Software Foundation; either version 3 of the License, or
252b5132
RH
9 (at your option) any later version.
10
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
b43b5d5f
NC
18 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA
19 02110-1301, USA. */
252b5132 20\f
3db64b00 21#include "sysdep.h"
252b5132 22#include "bfd.h"
365f5fb6 23#include "libbfd.h"
252b5132 24#include "progress.h"
252b5132
RH
25#include "getopt.h"
26#include "libiberty.h"
3db64b00 27#include "bucomm.h"
252b5132 28#include "budbg.h"
5af11cab 29#include "filenames.h"
5fe11841 30#include "fnmatch.h"
f0312d39 31#include "elf-bfd.h"
0408dee6
DK
32#include "coff/internal.h"
33#include "libcoff.h"
9ef920e9 34#include "safe-ctype.h"
252b5132 35
92dd4511
L
36/* FIXME: See bfd/peXXigen.c for why we include an architecture specific
37 header in generic PE code. */
38#include "coff/i386.h"
39#include "coff/pe.h"
40
41static bfd_vma pe_file_alignment = (bfd_vma) -1;
42static bfd_vma pe_heap_commit = (bfd_vma) -1;
43static bfd_vma pe_heap_reserve = (bfd_vma) -1;
44static bfd_vma pe_image_base = (bfd_vma) -1;
45static bfd_vma pe_section_alignment = (bfd_vma) -1;
46static bfd_vma pe_stack_commit = (bfd_vma) -1;
47static bfd_vma pe_stack_reserve = (bfd_vma) -1;
48static short pe_subsystem = -1;
49static short pe_major_subsystem_version = -1;
50static short pe_minor_subsystem_version = -1;
51
047c9024 52struct is_specified_symbol_predicate_data
252b5132 53{
2b35fb28 54 const char * name;
047c9024 55 bfd_boolean found;
252b5132
RH
56};
57
0f65a5d8 58/* A node includes symbol name mapping to support redefine_sym. */
57938635
AM
59struct redefine_node
60{
61 char *source;
62 char *target;
57938635
AM
63};
64
2b35fb28
RH
65struct addsym_node
66{
67 struct addsym_node *next;
68 char * symdef;
69 long symval;
70 flagword flags;
71 char * section;
ffebb0bb 72 const char * othersym;
2b35fb28
RH
73};
74
594ef5db
NC
75typedef struct section_rename
76{
77 const char * old_name;
78 const char * new_name;
79 flagword flags;
80 struct section_rename * next;
81}
82section_rename;
83
84/* List of sections to be renamed. */
84e2f313 85static section_rename *section_rename_list;
594ef5db 86
84e2f313
NC
87static asymbol **isympp = NULL; /* Input symbols. */
88static asymbol **osympp = NULL; /* Output symbols that survive stripping. */
252b5132 89
b7dd81f7 90/* If `copy_byte' >= 0, copy 'copy_width' byte(s) of every `interleave' bytes. */
252b5132 91static int copy_byte = -1;
b7dd81f7
NC
92static int interleave = 0; /* Initialised to 4 in copy_main(). */
93static int copy_width = 1;
252b5132 94
b34976b6
AM
95static bfd_boolean verbose; /* Print file and target names. */
96static bfd_boolean preserve_dates; /* Preserve input file timestamp. */
955d0b3b 97static int deterministic = -1; /* Enable deterministic archives. */
9ef920e9
NC
98static int status = 0; /* Exit status. */
99
100static bfd_boolean merge_notes = FALSE; /* Merge note sections. */
5c49f2cd
NC
101
102typedef struct merged_note_section
103{
104 asection * sec; /* The section that is being merged. */
105 bfd_byte * contents;/* New contents of the section. */
106 bfd_size_type size; /* New size of the section. */
107 struct merged_note_section * next; /* Link to next merged note section. */
108} merged_note_section;
252b5132
RH
109
110enum strip_action
2b35fb28
RH
111{
112 STRIP_UNDEF,
113 STRIP_NONE, /* Don't strip. */
114 STRIP_DEBUG, /* Strip all debugger symbols. */
115 STRIP_UNNEEDED, /* Strip unnecessary symbols. */
116 STRIP_NONDEBUG, /* Strip everything but debug info. */
117 STRIP_DWO, /* Strip all DWO info. */
118 STRIP_NONDWO, /* Strip everything but DWO info. */
119 STRIP_ALL /* Strip all symbols. */
120};
252b5132 121
0af11b59 122/* Which symbols to remove. */
4fc8b895 123static enum strip_action strip_symbols = STRIP_UNDEF;
252b5132
RH
124
125enum locals_action
2b35fb28
RH
126{
127 LOCALS_UNDEF,
128 LOCALS_START_L, /* Discard locals starting with L. */
129 LOCALS_ALL /* Discard all locals. */
130};
252b5132
RH
131
132/* Which local symbols to remove. Overrides STRIP_ALL. */
133static enum locals_action discard_locals;
134
252b5132
RH
135/* Structure used to hold lists of sections and actions to take. */
136struct section_list
137{
b34976b6 138 struct section_list * next; /* Next section to change. */
2e62b721 139 const char * pattern; /* Section name pattern. */
b34976b6 140 bfd_boolean used; /* Whether this entry was used. */
2e62b721
NC
141
142 unsigned int context; /* What to do with matching sections. */
143 /* Flag bits used in the context field.
144 COPY and REMOVE are mutually exlusive. SET and ALTER are mutually exclusive. */
145#define SECTION_CONTEXT_REMOVE (1 << 0) /* Remove this section. */
146#define SECTION_CONTEXT_COPY (1 << 1) /* Copy this section, delete all non-copied section. */
64f52b3e
FS
147#define SECTION_CONTEXT_KEEP (1 << 2) /* Keep this section. */
148#define SECTION_CONTEXT_SET_VMA (1 << 3) /* Set the sections' VMA address. */
149#define SECTION_CONTEXT_ALTER_VMA (1 << 4) /* Increment or decrement the section's VMA address. */
150#define SECTION_CONTEXT_SET_LMA (1 << 5) /* Set the sections' LMA address. */
151#define SECTION_CONTEXT_ALTER_LMA (1 << 6) /* Increment or decrement the section's LMA address. */
152#define SECTION_CONTEXT_SET_FLAGS (1 << 7) /* Set the section's flags. */
153#define SECTION_CONTEXT_REMOVE_RELOCS (1 << 8) /* Remove relocations for this section. */
154#define SECTION_CONTEXT_SET_ALIGNMENT (1 << 9) /* Set alignment for section. */
2e62b721 155
b34976b6 156 bfd_vma vma_val; /* Amount to change by or set to. */
b34976b6 157 bfd_vma lma_val; /* Amount to change by or set to. */
b34976b6 158 flagword flags; /* What to set the section flags to. */
fa463e9f 159 unsigned int alignment; /* Alignment of output section. */
252b5132
RH
160};
161
162static struct section_list *change_sections;
594ef5db 163
b34976b6
AM
164/* TRUE if some sections are to be removed. */
165static bfd_boolean sections_removed;
594ef5db 166
b34976b6
AM
167/* TRUE if only some sections are to be copied. */
168static bfd_boolean sections_copied;
252b5132
RH
169
170/* Changes to the start address. */
171static bfd_vma change_start = 0;
b34976b6 172static bfd_boolean set_start_set = FALSE;
252b5132
RH
173static bfd_vma set_start;
174
175/* Changes to section addresses. */
176static bfd_vma change_section_address = 0;
177
178/* Filling gaps between sections. */
b34976b6 179static bfd_boolean gap_fill_set = FALSE;
252b5132
RH
180static bfd_byte gap_fill = 0;
181
182/* Pad to a given address. */
b34976b6 183static bfd_boolean pad_to_set = FALSE;
252b5132
RH
184static bfd_vma pad_to;
185
f9d4ad2a
NC
186/* Use alternative machine code? */
187static unsigned long use_alt_mach_code = 0;
1ae8b3d2 188
4087920c
MR
189/* Output BFD flags user wants to set or clear */
190static flagword bfd_flags_to_set;
191static flagword bfd_flags_to_clear;
192
252b5132 193/* List of sections to add. */
252b5132
RH
194struct section_add
195{
196 /* Next section to add. */
197 struct section_add *next;
198 /* Name of section to add. */
199 const char *name;
200 /* Name of file holding section contents. */
201 const char *filename;
202 /* Size of file. */
203 size_t size;
204 /* Contents of file. */
205 bfd_byte *contents;
206 /* BFD section, after it has been added. */
207 asection *section;
208};
209
594ef5db 210/* List of sections to add to the output BFD. */
252b5132
RH
211static struct section_add *add_sections;
212
acf1419f
AB
213/* List of sections to update in the output BFD. */
214static struct section_add *update_sections;
215
bbad633b
NC
216/* List of sections to dump from the output BFD. */
217static struct section_add *dump_sections;
218
2593f09a
NC
219/* If non-NULL the argument to --add-gnu-debuglink.
220 This should be the filename to store in the .gnu_debuglink section. */
221static const char * gnu_debuglink_filename = NULL;
222
252b5132 223/* Whether to convert debugging information. */
b34976b6 224static bfd_boolean convert_debugging = FALSE;
252b5132 225
4a114e3e
L
226/* Whether to compress/decompress DWARF debug sections. */
227static enum
228{
cd6faa73
L
229 nothing = 0,
230 compress = 1 << 0,
231 compress_zlib = compress | 1 << 1,
232 compress_gnu_zlib = compress | 1 << 2,
233 compress_gabi_zlib = compress | 1 << 3,
234 decompress = 1 << 4
4a114e3e
L
235} do_debug_sections = nothing;
236
b8871f35 237/* Whether to generate ELF common symbols with the STT_COMMON type. */
eecc1a7f 238static enum bfd_link_elf_stt_common do_elf_stt_common = unchanged;
b8871f35 239
252b5132 240/* Whether to change the leading character in symbol names. */
b34976b6 241static bfd_boolean change_leading_char = FALSE;
252b5132
RH
242
243/* Whether to remove the leading character from global symbol names. */
b34976b6 244static bfd_boolean remove_leading_char = FALSE;
252b5132 245
aaad4cf3 246/* Whether to permit wildcard in symbol comparison. */
5fe11841
NC
247static bfd_boolean wildcard = FALSE;
248
d58c2e3a
RS
249/* True if --localize-hidden is in effect. */
250static bfd_boolean localize_hidden = FALSE;
251
16b2b71c
NC
252/* List of symbols to strip, keep, localize, keep-global, weaken,
253 or redefine. */
047c9024
NC
254static htab_t strip_specific_htab = NULL;
255static htab_t strip_unneeded_htab = NULL;
256static htab_t keep_specific_htab = NULL;
257static htab_t localize_specific_htab = NULL;
258static htab_t globalize_specific_htab = NULL;
259static htab_t keepglobal_specific_htab = NULL;
260static htab_t weaken_specific_htab = NULL;
0f65a5d8
JW
261static htab_t redefine_specific_htab = NULL;
262static htab_t redefine_specific_reverse_htab = NULL;
2b35fb28
RH
263static struct addsym_node *add_sym_list = NULL, **add_sym_tail = &add_sym_list;
264static int add_symbols = 0;
252b5132 265
d839b914
L
266static char *strip_specific_buffer = NULL;
267static char *strip_unneeded_buffer = NULL;
268static char *keep_specific_buffer = NULL;
269static char *localize_specific_buffer = NULL;
270static char *globalize_specific_buffer = NULL;
271static char *keepglobal_specific_buffer = NULL;
272static char *weaken_specific_buffer = NULL;
273
b34976b6
AM
274/* If this is TRUE, we weaken global symbols (set BSF_WEAK). */
275static bfd_boolean weaken = FALSE;
252b5132 276
1637cd90
JB
277/* If this is TRUE, we retain BSF_FILE symbols. */
278static bfd_boolean keep_file_symbols = FALSE;
279
d7fb0dd2
NC
280/* Prefix symbols/sections. */
281static char *prefix_symbols_string = 0;
282static char *prefix_sections_string = 0;
283static char *prefix_alloc_sections_string = 0;
284
d3e52d40
RS
285/* True if --extract-symbol was passed on the command line. */
286static bfd_boolean extract_symbol = FALSE;
287
9e48b4c6
NC
288/* If `reverse_bytes' is nonzero, then reverse the order of every chunk
289 of <reverse_bytes> bytes within each output section. */
290static int reverse_bytes = 0;
291
0408dee6
DK
292/* For Coff objects, we may want to allow or disallow long section names,
293 or preserve them where found in the inputs. Debug info relies on them. */
294enum long_section_name_handling
2b35fb28
RH
295{
296 DISABLE,
297 ENABLE,
298 KEEP
299};
0408dee6
DK
300
301/* The default long section handling mode is to preserve them.
302 This is also the only behaviour for 'strip'. */
303static enum long_section_name_handling long_section_names = KEEP;
9e48b4c6 304
252b5132 305/* 150 isn't special; it's just an arbitrary non-ASCII char value. */
84e2f313 306enum command_line_switch
2b35fb28
RH
307{
308 OPTION_ADD_SECTION=150,
309 OPTION_ADD_GNU_DEBUGLINK,
310 OPTION_ADD_SYMBOL,
311 OPTION_ALT_MACH_CODE,
312 OPTION_CHANGE_ADDRESSES,
313 OPTION_CHANGE_LEADING_CHAR,
314 OPTION_CHANGE_SECTION_ADDRESS,
315 OPTION_CHANGE_SECTION_LMA,
316 OPTION_CHANGE_SECTION_VMA,
317 OPTION_CHANGE_START,
318 OPTION_CHANGE_WARNINGS,
319 OPTION_COMPRESS_DEBUG_SECTIONS,
320 OPTION_DEBUGGING,
321 OPTION_DECOMPRESS_DEBUG_SECTIONS,
322 OPTION_DUMP_SECTION,
b8871f35 323 OPTION_ELF_STT_COMMON,
2b35fb28
RH
324 OPTION_EXTRACT_DWO,
325 OPTION_EXTRACT_SYMBOL,
326 OPTION_FILE_ALIGNMENT,
327 OPTION_FORMATS_INFO,
328 OPTION_GAP_FILL,
329 OPTION_GLOBALIZE_SYMBOL,
330 OPTION_GLOBALIZE_SYMBOLS,
331 OPTION_HEAP,
332 OPTION_IMAGE_BASE,
333 OPTION_IMPURE,
334 OPTION_INTERLEAVE_WIDTH,
335 OPTION_KEEPGLOBAL_SYMBOLS,
336 OPTION_KEEP_FILE_SYMBOLS,
64f52b3e 337 OPTION_KEEP_SECTION,
2b35fb28
RH
338 OPTION_KEEP_SYMBOLS,
339 OPTION_LOCALIZE_HIDDEN,
340 OPTION_LOCALIZE_SYMBOLS,
341 OPTION_LONG_SECTION_NAMES,
9ef920e9 342 OPTION_MERGE_NOTES,
1d15e434 343 OPTION_NO_MERGE_NOTES,
2b35fb28
RH
344 OPTION_NO_CHANGE_WARNINGS,
345 OPTION_ONLY_KEEP_DEBUG,
346 OPTION_PAD_TO,
347 OPTION_PREFIX_ALLOC_SECTIONS,
348 OPTION_PREFIX_SECTIONS,
349 OPTION_PREFIX_SYMBOLS,
350 OPTION_PURE,
351 OPTION_READONLY_TEXT,
352 OPTION_REDEFINE_SYM,
353 OPTION_REDEFINE_SYMS,
354 OPTION_REMOVE_LEADING_CHAR,
d3e5f6c8 355 OPTION_REMOVE_RELOCS,
2b35fb28
RH
356 OPTION_RENAME_SECTION,
357 OPTION_REVERSE_BYTES,
fa463e9f 358 OPTION_PE_SECTION_ALIGNMENT,
2b35fb28 359 OPTION_SET_SECTION_FLAGS,
fa463e9f 360 OPTION_SET_SECTION_ALIGNMENT,
2b35fb28
RH
361 OPTION_SET_START,
362 OPTION_SREC_FORCES3,
363 OPTION_SREC_LEN,
364 OPTION_STACK,
365 OPTION_STRIP_DWO,
366 OPTION_STRIP_SYMBOLS,
367 OPTION_STRIP_UNNEEDED,
368 OPTION_STRIP_UNNEEDED_SYMBOL,
369 OPTION_STRIP_UNNEEDED_SYMBOLS,
370 OPTION_SUBSYSTEM,
371 OPTION_UPDATE_SECTION,
37d0d091 372 OPTION_VERILOG_DATA_WIDTH,
2b35fb28
RH
373 OPTION_WEAKEN,
374 OPTION_WEAKEN_SYMBOLS,
375 OPTION_WRITABLE_TEXT
376};
252b5132
RH
377
378/* Options to handle if running as "strip". */
379
380static struct option strip_options[] =
381{
955d0b3b 382 {"disable-deterministic-archives", no_argument, 0, 'U'},
252b5132
RH
383 {"discard-all", no_argument, 0, 'x'},
384 {"discard-locals", no_argument, 0, 'X'},
2e30cb57 385 {"enable-deterministic-archives", no_argument, 0, 'D'},
252b5132
RH
386 {"format", required_argument, 0, 'F'}, /* Obsolete */
387 {"help", no_argument, 0, 'h'},
7c29036b 388 {"info", no_argument, 0, OPTION_FORMATS_INFO},
252b5132
RH
389 {"input-format", required_argument, 0, 'I'}, /* Obsolete */
390 {"input-target", required_argument, 0, 'I'},
1637cd90 391 {"keep-file-symbols", no_argument, 0, OPTION_KEEP_FILE_SYMBOLS},
64f52b3e 392 {"keep-section", required_argument, 0, OPTION_KEEP_SECTION},
252b5132 393 {"keep-symbol", required_argument, 0, 'K'},
1d15e434
NC
394 {"merge-notes", no_argument, 0, 'M'},
395 {"no-merge-notes", no_argument, 0, OPTION_NO_MERGE_NOTES},
ed1653a7 396 {"only-keep-debug", no_argument, 0, OPTION_ONLY_KEEP_DEBUG},
2b35fb28 397 {"output-file", required_argument, 0, 'o'},
252b5132
RH
398 {"output-format", required_argument, 0, 'O'}, /* Obsolete */
399 {"output-target", required_argument, 0, 'O'},
400 {"preserve-dates", no_argument, 0, 'p'},
401 {"remove-section", required_argument, 0, 'R'},
d3e5f6c8 402 {"remove-relocations", required_argument, 0, OPTION_REMOVE_RELOCS},
252b5132
RH
403 {"strip-all", no_argument, 0, 's'},
404 {"strip-debug", no_argument, 0, 'S'},
96109726 405 {"strip-dwo", no_argument, 0, OPTION_STRIP_DWO},
252b5132 406 {"strip-symbol", required_argument, 0, 'N'},
2b35fb28 407 {"strip-unneeded", no_argument, 0, OPTION_STRIP_UNNEEDED},
252b5132
RH
408 {"target", required_argument, 0, 'F'},
409 {"verbose", no_argument, 0, 'v'},
410 {"version", no_argument, 0, 'V'},
5fe11841 411 {"wildcard", no_argument, 0, 'w'},
252b5132
RH
412 {0, no_argument, 0, 0}
413};
414
415/* Options to handle if running as "objcopy". */
416
417static struct option copy_options[] =
418{
2593f09a 419 {"add-gnu-debuglink", required_argument, 0, OPTION_ADD_GNU_DEBUGLINK},
252b5132 420 {"add-section", required_argument, 0, OPTION_ADD_SECTION},
2b35fb28
RH
421 {"add-symbol", required_argument, 0, OPTION_ADD_SYMBOL},
422 {"adjust-section-vma", required_argument, 0, OPTION_CHANGE_SECTION_ADDRESS},
252b5132
RH
423 {"adjust-start", required_argument, 0, OPTION_CHANGE_START},
424 {"adjust-vma", required_argument, 0, OPTION_CHANGE_ADDRESSES},
252b5132 425 {"adjust-warnings", no_argument, 0, OPTION_CHANGE_WARNINGS},
d7fb0dd2 426 {"alt-machine-code", required_argument, 0, OPTION_ALT_MACH_CODE},
43a0748c 427 {"binary-architecture", required_argument, 0, 'B'},
252b5132
RH
428 {"byte", required_argument, 0, 'b'},
429 {"change-addresses", required_argument, 0, OPTION_CHANGE_ADDRESSES},
430 {"change-leading-char", no_argument, 0, OPTION_CHANGE_LEADING_CHAR},
431 {"change-section-address", required_argument, 0, OPTION_CHANGE_SECTION_ADDRESS},
432 {"change-section-lma", required_argument, 0, OPTION_CHANGE_SECTION_LMA},
433 {"change-section-vma", required_argument, 0, OPTION_CHANGE_SECTION_VMA},
434 {"change-start", required_argument, 0, OPTION_CHANGE_START},
435 {"change-warnings", no_argument, 0, OPTION_CHANGE_WARNINGS},
151411f8 436 {"compress-debug-sections", optional_argument, 0, OPTION_COMPRESS_DEBUG_SECTIONS},
252b5132 437 {"debugging", no_argument, 0, OPTION_DEBUGGING},
4a114e3e 438 {"decompress-debug-sections", no_argument, 0, OPTION_DECOMPRESS_DEBUG_SECTIONS},
955d0b3b 439 {"disable-deterministic-archives", no_argument, 0, 'U'},
252b5132
RH
440 {"discard-all", no_argument, 0, 'x'},
441 {"discard-locals", no_argument, 0, 'X'},
bbad633b 442 {"dump-section", required_argument, 0, OPTION_DUMP_SECTION},
b8871f35 443 {"elf-stt-common", required_argument, 0, OPTION_ELF_STT_COMMON},
2e30cb57 444 {"enable-deterministic-archives", no_argument, 0, 'D'},
96109726 445 {"extract-dwo", no_argument, 0, OPTION_EXTRACT_DWO},
d3e52d40 446 {"extract-symbol", no_argument, 0, OPTION_EXTRACT_SYMBOL},
2b35fb28 447 {"file-alignment", required_argument, 0, OPTION_FILE_ALIGNMENT},
252b5132
RH
448 {"format", required_argument, 0, 'F'}, /* Obsolete */
449 {"gap-fill", required_argument, 0, OPTION_GAP_FILL},
7b4a0685
NC
450 {"globalize-symbol", required_argument, 0, OPTION_GLOBALIZE_SYMBOL},
451 {"globalize-symbols", required_argument, 0, OPTION_GLOBALIZE_SYMBOLS},
2b35fb28 452 {"heap", required_argument, 0, OPTION_HEAP},
252b5132 453 {"help", no_argument, 0, 'h'},
2b35fb28 454 {"image-base", required_argument, 0 , OPTION_IMAGE_BASE},
4087920c 455 {"impure", no_argument, 0, OPTION_IMPURE},
7c29036b 456 {"info", no_argument, 0, OPTION_FORMATS_INFO},
252b5132
RH
457 {"input-format", required_argument, 0, 'I'}, /* Obsolete */
458 {"input-target", required_argument, 0, 'I'},
b7dd81f7
NC
459 {"interleave", optional_argument, 0, 'i'},
460 {"interleave-width", required_argument, 0, OPTION_INTERLEAVE_WIDTH},
1637cd90 461 {"keep-file-symbols", no_argument, 0, OPTION_KEEP_FILE_SYMBOLS},
d7fb0dd2
NC
462 {"keep-global-symbol", required_argument, 0, 'G'},
463 {"keep-global-symbols", required_argument, 0, OPTION_KEEPGLOBAL_SYMBOLS},
64f52b3e 464 {"keep-section", required_argument, 0, OPTION_KEEP_SECTION},
252b5132 465 {"keep-symbol", required_argument, 0, 'K'},
d7fb0dd2 466 {"keep-symbols", required_argument, 0, OPTION_KEEP_SYMBOLS},
d58c2e3a 467 {"localize-hidden", no_argument, 0, OPTION_LOCALIZE_HIDDEN},
d7fb0dd2
NC
468 {"localize-symbol", required_argument, 0, 'L'},
469 {"localize-symbols", required_argument, 0, OPTION_LOCALIZE_SYMBOLS},
0408dee6 470 {"long-section-names", required_argument, 0, OPTION_LONG_SECTION_NAMES},
9ef920e9 471 {"merge-notes", no_argument, 0, 'M'},
1d15e434 472 {"no-merge-notes", no_argument, 0, OPTION_NO_MERGE_NOTES},
252b5132
RH
473 {"no-adjust-warnings", no_argument, 0, OPTION_NO_CHANGE_WARNINGS},
474 {"no-change-warnings", no_argument, 0, OPTION_NO_CHANGE_WARNINGS},
ed1653a7 475 {"only-keep-debug", no_argument, 0, OPTION_ONLY_KEEP_DEBUG},
d7fb0dd2 476 {"only-section", required_argument, 0, 'j'},
252b5132
RH
477 {"output-format", required_argument, 0, 'O'}, /* Obsolete */
478 {"output-target", required_argument, 0, 'O'},
479 {"pad-to", required_argument, 0, OPTION_PAD_TO},
d7fb0dd2 480 {"prefix-alloc-sections", required_argument, 0, OPTION_PREFIX_ALLOC_SECTIONS},
2b35fb28
RH
481 {"prefix-sections", required_argument, 0, OPTION_PREFIX_SECTIONS},
482 {"prefix-symbols", required_argument, 0, OPTION_PREFIX_SYMBOLS},
252b5132 483 {"preserve-dates", no_argument, 0, 'p'},
4087920c
MR
484 {"pure", no_argument, 0, OPTION_PURE},
485 {"readonly-text", no_argument, 0, OPTION_READONLY_TEXT},
d7fb0dd2 486 {"redefine-sym", required_argument, 0, OPTION_REDEFINE_SYM},
92991082 487 {"redefine-syms", required_argument, 0, OPTION_REDEFINE_SYMS},
252b5132
RH
488 {"remove-leading-char", no_argument, 0, OPTION_REMOVE_LEADING_CHAR},
489 {"remove-section", required_argument, 0, 'R'},
d3e5f6c8 490 {"remove-relocations", required_argument, 0, OPTION_REMOVE_RELOCS},
594ef5db 491 {"rename-section", required_argument, 0, OPTION_RENAME_SECTION},
9e48b4c6 492 {"reverse-bytes", required_argument, 0, OPTION_REVERSE_BYTES},
fa463e9f 493 {"section-alignment", required_argument, 0, OPTION_PE_SECTION_ALIGNMENT},
252b5132 494 {"set-section-flags", required_argument, 0, OPTION_SET_SECTION_FLAGS},
fa463e9f 495 {"set-section-alignment", required_argument, 0, OPTION_SET_SECTION_ALIGNMENT},
252b5132 496 {"set-start", required_argument, 0, OPTION_SET_START},
d7fb0dd2 497 {"srec-forceS3", no_argument, 0, OPTION_SREC_FORCES3},
2b35fb28
RH
498 {"srec-len", required_argument, 0, OPTION_SREC_LEN},
499 {"stack", required_argument, 0, OPTION_STACK},
252b5132
RH
500 {"strip-all", no_argument, 0, 'S'},
501 {"strip-debug", no_argument, 0, 'g'},
96109726 502 {"strip-dwo", no_argument, 0, OPTION_STRIP_DWO},
2b35fb28
RH
503 {"strip-symbol", required_argument, 0, 'N'},
504 {"strip-symbols", required_argument, 0, OPTION_STRIP_SYMBOLS},
252b5132 505 {"strip-unneeded", no_argument, 0, OPTION_STRIP_UNNEEDED},
bcf32829
JB
506 {"strip-unneeded-symbol", required_argument, 0, OPTION_STRIP_UNNEEDED_SYMBOL},
507 {"strip-unneeded-symbols", required_argument, 0, OPTION_STRIP_UNNEEDED_SYMBOLS},
2b35fb28 508 {"subsystem", required_argument, 0, OPTION_SUBSYSTEM},
252b5132 509 {"target", required_argument, 0, 'F'},
2b35fb28 510 {"update-section", required_argument, 0, OPTION_UPDATE_SECTION},
252b5132 511 {"verbose", no_argument, 0, 'v'},
37d0d091 512 {"verilog-data-width", required_argument, 0, OPTION_VERILOG_DATA_WIDTH},
252b5132
RH
513 {"version", no_argument, 0, 'V'},
514 {"weaken", no_argument, 0, OPTION_WEAKEN},
515 {"weaken-symbol", required_argument, 0, 'W'},
16b2b71c 516 {"weaken-symbols", required_argument, 0, OPTION_WEAKEN_SYMBOLS},
5fe11841 517 {"wildcard", no_argument, 0, 'w'},
4087920c 518 {"writable-text", no_argument, 0, OPTION_WRITABLE_TEXT},
252b5132
RH
519 {0, no_argument, 0, 0}
520};
521
522/* IMPORTS */
523extern char *program_name;
524
525/* This flag distinguishes between strip and objcopy:
526 1 means this is 'strip'; 0 means this is 'objcopy'.
0af11b59 527 -1 means if we should use argv[0] to decide. */
252b5132
RH
528extern int is_strip;
529
4bc26c69 530/* The maximum length of an S record. This variable is defined in srec.c
420496c1 531 and can be modified by the --srec-len parameter. */
4bc26c69 532extern unsigned int _bfd_srec_len;
420496c1
NC
533
534/* Restrict the generation of Srecords to type S3 only.
4bc26c69 535 This variable is defined in bfd/srec.c and can be toggled
420496c1 536 on by the --srec-forceS3 command line switch. */
4bc26c69 537extern bfd_boolean _bfd_srec_forceS3;
252b5132 538
37d0d091
JH
539/* Width of data in bytes for verilog output.
540 This variable is declared in bfd/verilog.c and can be modified by
541 the --verilog-data-width parameter. */
542extern unsigned int VerilogDataWidth;
543
d3ba0551
AM
544/* Forward declarations. */
545static void setup_section (bfd *, asection *, void *);
80fccad2 546static void setup_bfd_headers (bfd *, bfd *);
c3989150 547static void copy_relocations_in_section (bfd *, asection *, void *);
d3ba0551
AM
548static void copy_section (bfd *, asection *, void *);
549static void get_sections (bfd *, asection *, void *);
550static int compare_section_lma (const void *, const void *);
551static void mark_symbols_used_in_relocations (bfd *, asection *, void *);
552static bfd_boolean write_debugging_info (bfd *, void *, long *, asymbol ***);
553static const char *lookup_sym_redefinition (const char *);
9cc0123f 554static const char *find_section_rename (const char *, flagword *);
594ef5db 555\f
1e0f0b4d 556ATTRIBUTE_NORETURN static void
84e2f313 557copy_usage (FILE *stream, int exit_status)
252b5132 558{
8b53311e
NC
559 fprintf (stream, _("Usage: %s [option(s)] in-file [out-file]\n"), program_name);
560 fprintf (stream, _(" Copies a binary file, possibly transforming it in the process\n"));
6364e0b4 561 fprintf (stream, _(" The options are:\n"));
252b5132 562 fprintf (stream, _("\
d5bcb29d
NC
563 -I --input-target <bfdname> Assume input file is in format <bfdname>\n\
564 -O --output-target <bfdname> Create an output file in format <bfdname>\n\
8b31b6c4 565 -B --binary-architecture <arch> Set output arch, when input is arch-less\n\
d5bcb29d
NC
566 -F --target <bfdname> Set both input and output format to <bfdname>\n\
567 --debugging Convert debugging information, if possible\n\
955d0b3b
RM
568 -p --preserve-dates Copy modified/access timestamps to the output\n"));
569 if (DEFAULT_AR_DETERMINISTIC)
570 fprintf (stream, _("\
571 -D --enable-deterministic-archives\n\
572 Produce deterministic output when stripping archives (default)\n\
573 -U --disable-deterministic-archives\n\
574 Disable -D behavior\n"));
575 else
576 fprintf (stream, _("\
2e30cb57
CC
577 -D --enable-deterministic-archives\n\
578 Produce deterministic output when stripping archives\n\
955d0b3b
RM
579 -U --disable-deterministic-archives\n\
580 Disable -D behavior (default)\n"));
581 fprintf (stream, _("\
d5bcb29d 582 -j --only-section <name> Only copy section <name> into the output\n\
2593f09a 583 --add-gnu-debuglink=<file> Add section .gnu_debuglink linking to <file>\n\
d5bcb29d 584 -R --remove-section <name> Remove section <name> from the output\n\
d3e5f6c8 585 --remove-relocations <name> Remove relocations from section <name>\n\
d5bcb29d 586 -S --strip-all Remove all symbol and relocation information\n\
2593f09a 587 -g --strip-debug Remove all debugging symbols & sections\n\
96109726 588 --strip-dwo Remove all DWO sections\n\
d5bcb29d
NC
589 --strip-unneeded Remove all symbols not needed by relocations\n\
590 -N --strip-symbol <name> Do not copy symbol <name>\n\
bcf32829
JB
591 --strip-unneeded-symbol <name>\n\
592 Do not copy symbol <name> unless needed by\n\
593 relocations\n\
6ea3dd37 594 --only-keep-debug Strip everything but the debug information\n\
96109726 595 --extract-dwo Copy only DWO sections\n\
d3e52d40 596 --extract-symbol Remove section contents but keep symbols\n\
64f52b3e 597 --keep-section <name> Do not strip section <name>\n\
e7f918ad 598 -K --keep-symbol <name> Do not strip symbol <name>\n\
1637cd90 599 --keep-file-symbols Do not strip file symbol(s)\n\
d58c2e3a 600 --localize-hidden Turn all ELF hidden symbols into locals\n\
d5bcb29d 601 -L --localize-symbol <name> Force symbol <name> to be marked as a local\n\
7b4a0685 602 --globalize-symbol <name> Force symbol <name> to be marked as a global\n\
16b2b71c 603 -G --keep-global-symbol <name> Localize all symbols except <name>\n\
d5bcb29d
NC
604 -W --weaken-symbol <name> Force symbol <name> to be marked as a weak\n\
605 --weaken Force all global symbols to be marked as weak\n\
a95b5cf9 606 -w --wildcard Permit wildcard in symbol comparison\n\
d5bcb29d
NC
607 -x --discard-all Remove all non-global symbols\n\
608 -X --discard-locals Remove any compiler-generated symbols\n\
bfcf0ccd 609 -i --interleave[=<number>] Only copy N out of every <number> bytes\n\
b7dd81f7 610 --interleave-width <number> Set N for --interleave\n\
d5bcb29d
NC
611 -b --byte <num> Select byte <num> in every interleaved block\n\
612 --gap-fill <val> Fill gaps between sections with <val>\n\
613 --pad-to <addr> Pad the last section up to address <addr>\n\
614 --set-start <addr> Set the start address to <addr>\n\
615 {--change-start|--adjust-start} <incr>\n\
616 Add <incr> to the start address\n\
617 {--change-addresses|--adjust-vma} <incr>\n\
618 Add <incr> to LMA, VMA and start addresses\n\
619 {--change-section-address|--adjust-section-vma} <name>{=|+|-}<val>\n\
620 Change LMA and VMA of section <name> by <val>\n\
621 --change-section-lma <name>{=|+|-}<val>\n\
622 Change the LMA of section <name> by <val>\n\
623 --change-section-vma <name>{=|+|-}<val>\n\
624 Change the VMA of section <name> by <val>\n\
625 {--[no-]change-warnings|--[no-]adjust-warnings}\n\
626 Warn if a named section does not exist\n\
627 --set-section-flags <name>=<flags>\n\
628 Set section <name>'s properties to <flags>\n\
fa463e9f 629 --set-section-alignment <name>=<align>\n\
de4859ea 630 Set section <name>'s alignment to <align> bytes\n\
d5bcb29d 631 --add-section <name>=<file> Add section <name> found in <file> to output\n\
acf1419f
AB
632 --update-section <name>=<file>\n\
633 Update contents of section <name> with\n\
634 contents found in <file>\n\
bbad633b 635 --dump-section <name>=<file> Dump the contents of section <name> into <file>\n\
594ef5db 636 --rename-section <old>=<new>[,<flags>] Rename section <old> to <new>\n\
0408dee6
DK
637 --long-section-names {enable|disable|keep}\n\
638 Handle long section names in Coff objects.\n\
d5bcb29d
NC
639 --change-leading-char Force output format's leading character style\n\
640 --remove-leading-char Remove leading character from global symbols\n\
9e48b4c6 641 --reverse-bytes=<num> Reverse <num> bytes at a time, in output sections with content\n\
57938635 642 --redefine-sym <old>=<new> Redefine symbol name <old> to <new>\n\
92991082
JT
643 --redefine-syms <file> --redefine-sym for all symbol pairs \n\
644 listed in <file>\n\
420496c1
NC
645 --srec-len <number> Restrict the length of generated Srecords\n\
646 --srec-forceS3 Restrict the type of generated Srecords to S3\n\
16b2b71c 647 --strip-symbols <file> -N for all symbols listed in <file>\n\
bcf32829
JB
648 --strip-unneeded-symbols <file>\n\
649 --strip-unneeded-symbol for all symbols listed\n\
650 in <file>\n\
16b2b71c
NC
651 --keep-symbols <file> -K for all symbols listed in <file>\n\
652 --localize-symbols <file> -L for all symbols listed in <file>\n\
7b4a0685 653 --globalize-symbols <file> --globalize-symbol for all in <file>\n\
16b2b71c
NC
654 --keep-global-symbols <file> -G for all symbols listed in <file>\n\
655 --weaken-symbols <file> -W for all symbols listed in <file>\n\
2b35fb28 656 --add-symbol <name>=[<section>:]<value>[,<flags>] Add a symbol\n\
f9d4ad2a 657 --alt-machine-code <index> Use the target's <index>'th alternative machine\n\
4087920c
MR
658 --writable-text Mark the output text as writable\n\
659 --readonly-text Make the output text write protected\n\
660 --pure Mark the output file as demand paged\n\
661 --impure Mark the output file as impure\n\
d7fb0dd2
NC
662 --prefix-symbols <prefix> Add <prefix> to start of every symbol name\n\
663 --prefix-sections <prefix> Add <prefix> to start of every section name\n\
664 --prefix-alloc-sections <prefix>\n\
665 Add <prefix> to start of every allocatable\n\
666 section name\n\
92dd4511
L
667 --file-alignment <num> Set PE file alignment to <num>\n\
668 --heap <reserve>[,<commit>] Set PE reserve/commit heap to <reserve>/\n\
669 <commit>\n\
670 --image-base <address> Set PE image base to <address>\n\
671 --section-alignment <num> Set PE section alignment to <num>\n\
672 --stack <reserve>[,<commit>] Set PE reserve/commit stack to <reserve>/\n\
673 <commit>\n\
674 --subsystem <name>[:<version>]\n\
447049af 675 Set PE subsystem to <name> [& <version>]\n\
151411f8
L
676 --compress-debug-sections[={none|zlib|zlib-gnu|zlib-gabi}]\n\
677 Compress DWARF debug sections using zlib\n\
4a114e3e 678 --decompress-debug-sections Decompress DWARF debug sections using zlib\n\
b8871f35
L
679 --elf-stt-common=[yes|no] Generate ELF common symbols with STT_COMMON\n\
680 type\n\
37d0d091 681 --verilog-data-width <number> Specifies data width, in bytes, for verilog output\n\
9ef920e9 682 -M --merge-notes Remove redundant entries in note sections\n\
1d15e434 683 --no-merge-notes Do not attempt to remove redundant notes (default)\n\
d5bcb29d 684 -v --verbose List all object files modified\n\
07012eee 685 @<file> Read options from <file>\n\
d5bcb29d
NC
686 -V --version Display this program's version number\n\
687 -h --help Display this output\n\
7c29036b 688 --info List object formats & architectures supported\n\
d5bcb29d 689"));
252b5132 690 list_supported_targets (program_name, stream);
92f01d61 691 if (REPORT_BUGS_TO[0] && exit_status == 0)
8ad3436c 692 fprintf (stream, _("Report bugs to %s\n"), REPORT_BUGS_TO);
252b5132
RH
693 exit (exit_status);
694}
695
1e0f0b4d 696ATTRIBUTE_NORETURN static void
84e2f313 697strip_usage (FILE *stream, int exit_status)
252b5132 698{
8b53311e
NC
699 fprintf (stream, _("Usage: %s <option(s)> in-file(s)\n"), program_name);
700 fprintf (stream, _(" Removes symbols and sections from files\n"));
6364e0b4 701 fprintf (stream, _(" The options are:\n"));
252b5132 702 fprintf (stream, _("\
8b53311e
NC
703 -I --input-target=<bfdname> Assume input file is in format <bfdname>\n\
704 -O --output-target=<bfdname> Create an output file in format <bfdname>\n\
705 -F --target=<bfdname> Set both input and output format to <bfdname>\n\
d5bcb29d 706 -p --preserve-dates Copy modified/access timestamps to the output\n\
955d0b3b
RM
707"));
708 if (DEFAULT_AR_DETERMINISTIC)
709 fprintf (stream, _("\
710 -D --enable-deterministic-archives\n\
711 Produce deterministic output when stripping archives (default)\n\
712 -U --disable-deterministic-archives\n\
713 Disable -D behavior\n"));
714 else
715 fprintf (stream, _("\
2e30cb57
CC
716 -D --enable-deterministic-archives\n\
717 Produce deterministic output when stripping archives\n\
955d0b3b
RM
718 -U --disable-deterministic-archives\n\
719 Disable -D behavior (default)\n"));
720 fprintf (stream, _("\
805b1c8b 721 -R --remove-section=<name> Also remove section <name> from the output\n\
d3e5f6c8 722 --remove-relocations <name> Remove relocations from section <name>\n\
d5bcb29d 723 -s --strip-all Remove all symbol and relocation information\n\
2593f09a 724 -g -S -d --strip-debug Remove all debugging symbols & sections\n\
96109726 725 --strip-dwo Remove all DWO sections\n\
d5bcb29d 726 --strip-unneeded Remove all symbols not needed by relocations\n\
6ea3dd37 727 --only-keep-debug Strip everything but the debug information\n\
1d15e434
NC
728 -M --merge-notes Remove redundant entries in note sections (default)\n\
729 --no-merge-notes Do not attempt to remove redundant notes\n\
8b53311e 730 -N --strip-symbol=<name> Do not copy symbol <name>\n\
64f52b3e 731 --keep-section=<name> Do not strip section <name>\n\
5219e4c0 732 -K --keep-symbol=<name> Do not strip symbol <name>\n\
1637cd90 733 --keep-file-symbols Do not strip file symbol(s)\n\
a95b5cf9 734 -w --wildcard Permit wildcard in symbol comparison\n\
d5bcb29d
NC
735 -x --discard-all Remove all non-global symbols\n\
736 -X --discard-locals Remove any compiler-generated symbols\n\
737 -v --verbose List all object files modified\n\
738 -V --version Display this program's version number\n\
739 -h --help Display this output\n\
7c29036b 740 --info List object formats & architectures supported\n\
d5bcb29d
NC
741 -o <file> Place stripped output into <file>\n\
742"));
743
252b5132 744 list_supported_targets (program_name, stream);
92f01d61 745 if (REPORT_BUGS_TO[0] && exit_status == 0)
8ad3436c 746 fprintf (stream, _("Report bugs to %s\n"), REPORT_BUGS_TO);
252b5132
RH
747 exit (exit_status);
748}
749
750/* Parse section flags into a flagword, with a fatal error if the
751 string can't be parsed. */
752
753static flagword
84e2f313 754parse_flags (const char *s)
252b5132
RH
755{
756 flagword ret;
757 const char *snext;
758 int len;
759
760 ret = SEC_NO_FLAGS;
761
762 do
763 {
764 snext = strchr (s, ',');
765 if (snext == NULL)
766 len = strlen (s);
767 else
768 {
769 len = snext - s;
770 ++snext;
771 }
772
773 if (0) ;
f7433f01
AM
774#define PARSE_FLAG(fname,fval) \
775 else if (strncasecmp (fname, s, len) == 0) ret |= fval
252b5132
RH
776 PARSE_FLAG ("alloc", SEC_ALLOC);
777 PARSE_FLAG ("load", SEC_LOAD);
3994e2c6 778 PARSE_FLAG ("noload", SEC_NEVER_LOAD);
252b5132 779 PARSE_FLAG ("readonly", SEC_READONLY);
3994e2c6 780 PARSE_FLAG ("debug", SEC_DEBUGGING);
252b5132
RH
781 PARSE_FLAG ("code", SEC_CODE);
782 PARSE_FLAG ("data", SEC_DATA);
783 PARSE_FLAG ("rom", SEC_ROM);
3a5d12fb 784 PARSE_FLAG ("exclude", SEC_EXCLUDE);
ebe372c1 785 PARSE_FLAG ("share", SEC_COFF_SHARED);
252b5132 786 PARSE_FLAG ("contents", SEC_HAS_CONTENTS);
5dddde8e
AM
787 PARSE_FLAG ("merge", SEC_MERGE);
788 PARSE_FLAG ("strings", SEC_STRINGS);
252b5132
RH
789#undef PARSE_FLAG
790 else
791 {
792 char *copy;
793
3f5e193b 794 copy = (char *) xmalloc (len + 1);
252b5132
RH
795 strncpy (copy, s, len);
796 copy[len] = '\0';
797 non_fatal (_("unrecognized section flag `%s'"), copy);
57938635 798 fatal (_("supported flags: %s"),
3a5d12fb 799 "alloc, load, noload, readonly, debug, code, data, rom, exclude, share, contents, merge, strings");
252b5132
RH
800 }
801
802 s = snext;
803 }
804 while (s != NULL);
805
806 return ret;
807}
808
2b35fb28
RH
809/* Parse symbol flags into a flagword, with a fatal error if the
810 string can't be parsed. */
811
812static flagword
ffebb0bb 813parse_symflags (const char *s, const char **other)
2b35fb28
RH
814{
815 flagword ret;
816 const char *snext;
f7433f01 817 size_t len;
2b35fb28
RH
818
819 ret = BSF_NO_FLAGS;
820
821 do
822 {
823 snext = strchr (s, ',');
824 if (snext == NULL)
f7433f01 825 len = strlen (s);
2b35fb28
RH
826 else
827 {
828 len = snext - s;
829 ++snext;
830 }
831
f7433f01
AM
832#define PARSE_FLAG(fname, fval) \
833 else if (len == sizeof fname - 1 \
834 && strncasecmp (fname, s, len) == 0) \
2b35fb28
RH
835 ret |= fval
836
f7433f01
AM
837#define PARSE_OTHER(fname, fval) \
838 else if (len >= sizeof fname \
839 && strncasecmp (fname, s, sizeof fname - 1) == 0) \
a4f8732b 840 fval = xstrndup (s + sizeof fname - 1, len - sizeof fname + 1)
f7433f01 841
2b35fb28
RH
842 if (0) ;
843 PARSE_FLAG ("local", BSF_LOCAL);
844 PARSE_FLAG ("global", BSF_GLOBAL);
845 PARSE_FLAG ("export", BSF_EXPORT);
846 PARSE_FLAG ("debug", BSF_DEBUGGING);
847 PARSE_FLAG ("function", BSF_FUNCTION);
848 PARSE_FLAG ("weak", BSF_WEAK);
849 PARSE_FLAG ("section", BSF_SECTION_SYM);
850 PARSE_FLAG ("constructor", BSF_CONSTRUCTOR);
851 PARSE_FLAG ("warning", BSF_WARNING);
852 PARSE_FLAG ("indirect", BSF_INDIRECT);
853 PARSE_FLAG ("file", BSF_FILE);
854 PARSE_FLAG ("object", BSF_OBJECT);
855 PARSE_FLAG ("synthetic", BSF_SYNTHETIC);
856 PARSE_FLAG ("indirect-function", BSF_GNU_INDIRECT_FUNCTION | BSF_FUNCTION);
857 PARSE_FLAG ("unique-object", BSF_GNU_UNIQUE | BSF_OBJECT);
858 PARSE_OTHER ("before=", *other);
859
860#undef PARSE_FLAG
861#undef PARSE_OTHER
862 else
863 {
864 char *copy;
865
866 copy = (char *) xmalloc (len + 1);
867 strncpy (copy, s, len);
868 copy[len] = '\0';
869 non_fatal (_("unrecognized symbol flag `%s'"), copy);
870 fatal (_("supported flags: %s"),
f7433f01
AM
871 "local, global, export, debug, function, weak, section, "
872 "constructor, warning, indirect, file, object, synthetic, "
873 "indirect-function, unique-object, before=<othersym>");
2b35fb28
RH
874 }
875
876 s = snext;
877 }
878 while (s != NULL);
879
880 return ret;
881}
882
2e62b721
NC
883/* Find and optionally add an entry in the change_sections list.
884
885 We need to be careful in how we match section names because of the support
886 for wildcard characters. For example suppose that the user has invoked
887 objcopy like this:
3aade688 888
2e62b721
NC
889 --set-section-flags .debug_*=debug
890 --set-section-flags .debug_str=readonly,debug
891 --change-section-address .debug_*ranges=0x1000
892
893 With the idea that all debug sections will receive the DEBUG flag, the
894 .debug_str section will also receive the READONLY flag and the
895 .debug_ranges and .debug_aranges sections will have their address set to
896 0x1000. (This may not make much sense, but it is just an example).
897
898 When adding the section name patterns to the section list we need to make
899 sure that previous entries do not match with the new entry, unless the
900 match is exact. (In which case we assume that the user is overriding
901 the previous entry with the new context).
902
903 When matching real section names to the section list we make use of the
904 wildcard characters, but we must do so in context. Eg if we are setting
905 section addresses then we match for .debug_ranges but not for .debug_info.
906
907 Finally, if ADD is false and we do find a match, we mark the section list
908 entry as used. */
252b5132
RH
909
910static struct section_list *
2e62b721 911find_section_list (const char *name, bfd_boolean add, unsigned int context)
252b5132 912{
e511c9b1 913 struct section_list *p, *match = NULL;
252b5132 914
2e62b721 915 /* assert ((context & ((1 << 7) - 1)) != 0); */
3aade688 916
252b5132 917 for (p = change_sections; p != NULL; p = p->next)
2e62b721
NC
918 {
919 if (add)
920 {
921 if (strcmp (p->pattern, name) == 0)
922 {
923 /* Check for context conflicts. */
924 if (((p->context & SECTION_CONTEXT_REMOVE)
925 && (context & SECTION_CONTEXT_COPY))
926 || ((context & SECTION_CONTEXT_REMOVE)
927 && (p->context & SECTION_CONTEXT_COPY)))
928 fatal (_("error: %s both copied and removed"), name);
929
930 if (((p->context & SECTION_CONTEXT_SET_VMA)
931 && (context & SECTION_CONTEXT_ALTER_VMA))
932 || ((context & SECTION_CONTEXT_SET_VMA)
933 && (context & SECTION_CONTEXT_ALTER_VMA)))
934 fatal (_("error: %s both sets and alters VMA"), name);
935
936 if (((p->context & SECTION_CONTEXT_SET_LMA)
937 && (context & SECTION_CONTEXT_ALTER_LMA))
938 || ((context & SECTION_CONTEXT_SET_LMA)
939 && (context & SECTION_CONTEXT_ALTER_LMA)))
940 fatal (_("error: %s both sets and alters LMA"), name);
941
942 /* Extend the context. */
943 p->context |= context;
944 return p;
945 }
946 }
947 /* If we are not adding a new name/pattern then
948 only check for a match if the context applies. */
e511c9b1
AB
949 else if (p->context & context)
950 {
951 /* We could check for the presence of wildchar characters
952 first and choose between calling strcmp and fnmatch,
953 but is that really worth it ? */
954 if (p->pattern [0] == '!')
955 {
956 if (fnmatch (p->pattern + 1, name, 0) == 0)
957 {
958 p->used = TRUE;
959 return NULL;
960 }
961 }
962 else
963 {
964 if (fnmatch (p->pattern, name, 0) == 0)
965 {
966 if (match == NULL)
967 match = p;
968 }
969 }
970 }
2e62b721 971 }
252b5132
RH
972
973 if (! add)
e511c9b1
AB
974 {
975 if (match != NULL)
976 match->used = TRUE;
977 return match;
978 }
252b5132 979
3f5e193b 980 p = (struct section_list *) xmalloc (sizeof (struct section_list));
2e62b721 981 p->pattern = name;
b34976b6 982 p->used = FALSE;
2e62b721 983 p->context = context;
252b5132
RH
984 p->vma_val = 0;
985 p->lma_val = 0;
252b5132 986 p->flags = 0;
fa463e9f 987 p->alignment = 0;
252b5132
RH
988 p->next = change_sections;
989 change_sections = p;
990
991 return p;
992}
993
0f65a5d8
JW
994/* S1 is the entry node already in the table, S2 is the key node. */
995
996static int
997eq_string_redefnode (const void *s1, const void *s2)
998{
999 struct redefine_node *node1 = (struct redefine_node *) s1;
1000 struct redefine_node *node2 = (struct redefine_node *) s2;
1001 return !strcmp ((const char *) node1->source, (const char *) node2->source);
1002}
1003
1004/* P is redefine node. Hash value is generated from its "source" filed. */
1005
1006static hashval_t
1007htab_hash_redefnode (const void *p)
1008{
1009 struct redefine_node *redefnode = (struct redefine_node *) p;
1010 return htab_hash_string (redefnode->source);
1011}
1012
1013/* Create hashtab used for redefine node. */
1014
1015static htab_t
1016create_symbol2redef_htab (void)
1017{
1018 return htab_create_alloc (16, htab_hash_redefnode, eq_string_redefnode, NULL,
1019 xcalloc, free);
1020}
1021
047c9024
NC
1022/* There is htab_hash_string but no htab_eq_string. Makes sense. */
1023
1024static int
1025eq_string (const void *s1, const void *s2)
1026{
3f5e193b 1027 return strcmp ((const char *) s1, (const char *) s2) == 0;
047c9024
NC
1028}
1029
1030static htab_t
1031create_symbol_htab (void)
1032{
1033 return htab_create_alloc (16, htab_hash_string, eq_string, NULL, xcalloc, free);
1034}
252b5132 1035
57938635 1036static void
047c9024 1037create_symbol_htabs (void)
252b5132 1038{
047c9024
NC
1039 strip_specific_htab = create_symbol_htab ();
1040 strip_unneeded_htab = create_symbol_htab ();
1041 keep_specific_htab = create_symbol_htab ();
1042 localize_specific_htab = create_symbol_htab ();
1043 globalize_specific_htab = create_symbol_htab ();
1044 keepglobal_specific_htab = create_symbol_htab ();
1045 weaken_specific_htab = create_symbol_htab ();
0f65a5d8
JW
1046 redefine_specific_htab = create_symbol2redef_htab ();
1047 /* As there is no bidirectional hash table in libiberty, need a reverse table
1048 to check duplicated target string. */
1049 redefine_specific_reverse_htab = create_symbol_htab ();
047c9024
NC
1050}
1051
1052/* Add a symbol to strip_specific_list. */
252b5132 1053
047c9024
NC
1054static void
1055add_specific_symbol (const char *name, htab_t htab)
1056{
1057 *htab_find_slot (htab, name, INSERT) = (char *) name;
252b5132
RH
1058}
1059
0f65a5d8
JW
1060/* Like add_specific_symbol, but the element type is void *. */
1061
1062static void
1063add_specific_symbol_node (const void *node, htab_t htab)
1064{
1065 *htab_find_slot (htab, node, INSERT) = (void *) node;
1066}
1067
0af11b59 1068/* Add symbols listed in `filename' to strip_specific_list. */
16b2b71c
NC
1069
1070#define IS_WHITESPACE(c) ((c) == ' ' || (c) == '\t')
1071#define IS_LINE_TERMINATOR(c) ((c) == '\n' || (c) == '\r' || (c) == '\0')
1072
1073static void
d839b914 1074add_specific_symbols (const char *filename, htab_t htab, char **buffer_p)
16b2b71c 1075{
f24ddbdd 1076 off_t size;
16b2b71c
NC
1077 FILE * f;
1078 char * line;
1079 char * buffer;
1080 unsigned int line_count;
0af11b59 1081
f24ddbdd
NC
1082 size = get_file_size (filename);
1083 if (size == 0)
d68c385b
NC
1084 {
1085 status = 1;
1086 return;
1087 }
16b2b71c 1088
3f5e193b 1089 buffer = (char *) xmalloc (size + 2);
16b2b71c
NC
1090 f = fopen (filename, FOPEN_RT);
1091 if (f == NULL)
f24ddbdd 1092 fatal (_("cannot open '%s': %s"), filename, strerror (errno));
16b2b71c 1093
f24ddbdd 1094 if (fread (buffer, 1, size, f) == 0 || ferror (f))
16b2b71c
NC
1095 fatal (_("%s: fread failed"), filename);
1096
1097 fclose (f);
f24ddbdd
NC
1098 buffer [size] = '\n';
1099 buffer [size + 1] = '\0';
16b2b71c
NC
1100
1101 line_count = 1;
0af11b59 1102
16b2b71c
NC
1103 for (line = buffer; * line != '\0'; line ++)
1104 {
1105 char * eol;
1106 char * name;
1107 char * name_end;
b34976b6 1108 int finished = FALSE;
16b2b71c
NC
1109
1110 for (eol = line;; eol ++)
1111 {
1112 switch (* eol)
1113 {
1114 case '\n':
1115 * eol = '\0';
1116 /* Cope with \n\r. */
1117 if (eol[1] == '\r')
1118 ++ eol;
b34976b6 1119 finished = TRUE;
16b2b71c 1120 break;
0af11b59 1121
16b2b71c
NC
1122 case '\r':
1123 * eol = '\0';
1124 /* Cope with \r\n. */
1125 if (eol[1] == '\n')
1126 ++ eol;
b34976b6 1127 finished = TRUE;
16b2b71c 1128 break;
0af11b59 1129
16b2b71c 1130 case 0:
b34976b6 1131 finished = TRUE;
16b2b71c 1132 break;
0af11b59 1133
16b2b71c
NC
1134 case '#':
1135 /* Line comment, Terminate the line here, in case a
1136 name is present and then allow the rest of the
1137 loop to find the real end of the line. */
1138 * eol = '\0';
1139 break;
0af11b59 1140
16b2b71c
NC
1141 default:
1142 break;
1143 }
1144
1145 if (finished)
1146 break;
1147 }
1148
1149 /* A name may now exist somewhere between 'line' and 'eol'.
1150 Strip off leading whitespace and trailing whitespace,
1151 then add it to the list. */
1152 for (name = line; IS_WHITESPACE (* name); name ++)
1153 ;
1154 for (name_end = name;
1155 (! IS_WHITESPACE (* name_end))
1156 && (! IS_LINE_TERMINATOR (* name_end));
0af11b59
KH
1157 name_end ++)
1158 ;
16b2b71c
NC
1159
1160 if (! IS_LINE_TERMINATOR (* name_end))
1161 {
1162 char * extra;
1163
1164 for (extra = name_end + 1; IS_WHITESPACE (* extra); extra ++)
1165 ;
1166
1167 if (! IS_LINE_TERMINATOR (* extra))
d412a550
NC
1168 non_fatal (_("%s:%d: Ignoring rubbish found on this line"),
1169 filename, line_count);
16b2b71c 1170 }
0af11b59 1171
16b2b71c
NC
1172 * name_end = '\0';
1173
1174 if (name_end > name)
047c9024 1175 add_specific_symbol (name, htab);
16b2b71c
NC
1176
1177 /* Advance line pointer to end of line. The 'eol ++' in the for
1178 loop above will then advance us to the start of the next line. */
1179 line = eol;
1180 line_count ++;
1181 }
3391569f 1182
508d0c9b
NC
1183 /* Do not free the buffer. Parts of it will have been referenced
1184 in the calls to add_specific_symbol. */
d839b914 1185 *buffer_p = buffer;
16b2b71c
NC
1186}
1187
047c9024
NC
1188/* See whether a symbol should be stripped or kept
1189 based on strip_specific_list and keep_symbols. */
252b5132 1190
047c9024
NC
1191static int
1192is_specified_symbol_predicate (void **slot, void *data)
252b5132 1193{
3f5e193b
NC
1194 struct is_specified_symbol_predicate_data *d =
1195 (struct is_specified_symbol_predicate_data *) data;
1196 const char *slot_name = (char *) *slot;
252b5132 1197
047c9024 1198 if (*slot_name != '!')
5fe11841 1199 {
047c9024
NC
1200 if (! fnmatch (slot_name, d->name, 0))
1201 {
1202 d->found = TRUE;
0b45135e
AB
1203 /* Continue traversal, there might be a non-match rule. */
1204 return 1;
047c9024 1205 }
5fe11841
NC
1206 }
1207 else
1208 {
0b45135e 1209 if (! fnmatch (slot_name + 1, d->name, 0))
047c9024 1210 {
0b45135e 1211 d->found = FALSE;
047c9024
NC
1212 /* Stop traversal. */
1213 return 0;
1214 }
5fe11841 1215 }
594ef5db 1216
047c9024
NC
1217 /* Continue traversal. */
1218 return 1;
1219}
1220
1221static bfd_boolean
1222is_specified_symbol (const char *name, htab_t htab)
1223{
1224 if (wildcard)
1225 {
1226 struct is_specified_symbol_predicate_data data;
1227
1228 data.name = name;
1229 data.found = FALSE;
1230
1231 htab_traverse (htab, is_specified_symbol_predicate, &data);
1232
1233 return data.found;
1234 }
1235
1236 return htab_find (htab, name) != NULL;
252b5132
RH
1237}
1238
30288845
AM
1239/* Return a pointer to the symbol used as a signature for GROUP. */
1240
1241static asymbol *
1242group_signature (asection *group)
1243{
1244 bfd *abfd = group->owner;
1245 Elf_Internal_Shdr *ghdr;
1246
bcc3a8bc
NC
1247 /* PR 20089: An earlier error may have prevented us from loading the symbol table. */
1248 if (isympp == NULL)
1249 return NULL;
1250
30288845
AM
1251 if (bfd_get_flavour (abfd) != bfd_target_elf_flavour)
1252 return NULL;
1253
1254 ghdr = &elf_section_data (group)->this_hdr;
ce4ec1a9 1255 if (ghdr->sh_link == elf_onesymtab (abfd))
30288845
AM
1256 {
1257 const struct elf_backend_data *bed = get_elf_backend_data (abfd);
ce4ec1a9 1258 Elf_Internal_Shdr *symhdr = &elf_symtab_hdr (abfd);
30288845 1259
ce4ec1a9
AM
1260 if (ghdr->sh_info > 0
1261 && ghdr->sh_info < symhdr->sh_size / bed->s->sizeof_sym)
748fc5e9 1262 return isympp[ghdr->sh_info - 1];
30288845
AM
1263 }
1264 return NULL;
1265}
1266
96109726
CC
1267/* Return TRUE if the section is a DWO section. */
1268
1269static bfd_boolean
1270is_dwo_section (bfd *abfd ATTRIBUTE_UNUSED, asection *sec)
1271{
00c19b8e
NC
1272 const char *name;
1273 int len;
1274
1275 if (sec == NULL || (name = bfd_section_name (sec)) == NULL)
1276 return FALSE;
1277
1278 len = strlen (name);
1279 if (len < 5)
1280 return FALSE;
96109726
CC
1281
1282 return strncmp (name + len - 4, ".dwo", 4) == 0;
1283}
1284
acf1419f
AB
1285/* Return TRUE if section SEC is in the update list. */
1286
1287static bfd_boolean
1288is_update_section (bfd *abfd ATTRIBUTE_UNUSED, asection *sec)
1289{
1290 if (update_sections != NULL)
1291 {
1292 struct section_add *pupdate;
1293
1294 for (pupdate = update_sections;
f7433f01
AM
1295 pupdate != NULL;
1296 pupdate = pupdate->next)
acf1419f 1297 {
f7433f01
AM
1298 if (strcmp (sec->name, pupdate->name) == 0)
1299 return TRUE;
1300 }
acf1419f
AB
1301 }
1302
1303 return FALSE;
1304}
1305
9ef920e9 1306static bfd_boolean
5c49f2cd 1307is_mergeable_note_section (bfd * abfd, asection * sec)
9ef920e9
NC
1308{
1309 if (merge_notes
1310 && bfd_get_flavour (abfd) == bfd_target_elf_flavour
1311 && elf_section_data (sec)->this_hdr.sh_type == SHT_NOTE
1312 /* FIXME: We currently only support merging GNU_BUILD_NOTEs.
1313 We should add support for more note types. */
05ed4310
NC
1314 && ((elf_section_data (sec)->this_hdr.sh_flags & SHF_GNU_BUILD_NOTE) != 0
1315 /* Old versions of GAS (prior to 2.27) could not set the section
5c49f2cd
NC
1316 flags to OS-specific values, so we also accept sections that
1317 start with the expected name. */
1318 || (CONST_STRNEQ (sec->name, GNU_BUILD_ATTRS_SECTION_NAME))))
9ef920e9
NC
1319 return TRUE;
1320
1321 return FALSE;
1322}
1323
4c8e8a7e 1324/* See if a non-group section is being removed. */
252b5132 1325
b34976b6 1326static bfd_boolean
4c8e8a7e 1327is_strip_section_1 (bfd *abfd ATTRIBUTE_UNUSED, asection *sec)
252b5132 1328{
64f52b3e
FS
1329 if (find_section_list (bfd_section_name (sec), FALSE, SECTION_CONTEXT_KEEP)
1330 != NULL)
1331 return FALSE;
1332
2593f09a
NC
1333 if (sections_removed || sections_copied)
1334 {
1335 struct section_list *p;
2e62b721 1336 struct section_list *q;
2593f09a 1337
fd361982 1338 p = find_section_list (bfd_section_name (sec), FALSE,
2e62b721 1339 SECTION_CONTEXT_REMOVE);
fd361982 1340 q = find_section_list (bfd_section_name (sec), FALSE,
2e62b721 1341 SECTION_CONTEXT_COPY);
2593f09a 1342
2e62b721
NC
1343 if (p && q)
1344 fatal (_("error: section %s matches both remove and copy options"),
fd361982 1345 bfd_section_name (sec));
acf1419f 1346 if (p && is_update_section (abfd, sec))
f7433f01 1347 fatal (_("error: section %s matches both update and remove options"),
fd361982 1348 bfd_section_name (sec));
2e62b721
NC
1349
1350 if (p != NULL)
2593f09a 1351 return TRUE;
2e62b721 1352 if (sections_copied && q == NULL)
2593f09a
NC
1353 return TRUE;
1354 }
252b5132 1355
fd361982 1356 if ((bfd_section_flags (sec) & SEC_DEBUGGING) != 0)
2593f09a
NC
1357 {
1358 if (strip_symbols == STRIP_DEBUG
252b5132
RH
1359 || strip_symbols == STRIP_UNNEEDED
1360 || strip_symbols == STRIP_ALL
1361 || discard_locals == LOCALS_ALL
2593f09a 1362 || convert_debugging)
4fc8b895
KT
1363 {
1364 /* By default we don't want to strip .reloc section.
1365 This section has for pe-coff special meaning. See
1366 pe-dll.c file in ld, and peXXigen.c in bfd for details. */
fd361982 1367 if (strcmp (bfd_section_name (sec), ".reloc") != 0)
4fc8b895
KT
1368 return TRUE;
1369 }
ed1653a7 1370
96109726
CC
1371 if (strip_symbols == STRIP_DWO)
1372 return is_dwo_section (abfd, sec);
1373
ed1653a7
NC
1374 if (strip_symbols == STRIP_NONDEBUG)
1375 return FALSE;
2593f09a 1376 }
f91ea849 1377
96109726
CC
1378 if (strip_symbols == STRIP_NONDWO)
1379 return !is_dwo_section (abfd, sec);
1380
4c8e8a7e
L
1381 return FALSE;
1382}
1383
1384/* See if a section is being removed. */
1385
1386static bfd_boolean
1387is_strip_section (bfd *abfd ATTRIBUTE_UNUSED, asection *sec)
1388{
1389 if (is_strip_section_1 (abfd, sec))
1390 return TRUE;
1391
fd361982 1392 if ((bfd_section_flags (sec) & SEC_GROUP) != 0)
30288845
AM
1393 {
1394 asymbol *gsym;
1395 const char *gname;
4c8e8a7e 1396 asection *elt, *first;
30288845 1397
886d5428
AM
1398 gsym = group_signature (sec);
1399 /* Strip groups without a valid signature. */
1400 if (gsym == NULL)
1401 return TRUE;
1402
30288845
AM
1403 /* PR binutils/3181
1404 If we are going to strip the group signature symbol, then
1405 strip the group section too. */
886d5428 1406 gname = gsym->name;
30288845 1407 if ((strip_symbols == STRIP_ALL
047c9024
NC
1408 && !is_specified_symbol (gname, keep_specific_htab))
1409 || is_specified_symbol (gname, strip_specific_htab))
30288845 1410 return TRUE;
4c8e8a7e
L
1411
1412 /* Remove the group section if all members are removed. */
1413 first = elt = elf_next_in_group (sec);
1414 while (elt != NULL)
1415 {
1416 if (!is_strip_section_1 (abfd, elt))
1417 return FALSE;
1418 elt = elf_next_in_group (elt);
1419 if (elt == first)
1420 break;
1421 }
1422
1423 return TRUE;
30288845 1424 }
91bb255c 1425
f0312d39 1426 return FALSE;
252b5132
RH
1427}
1428
6e6e7cfc
JT
1429static bfd_boolean
1430is_nondebug_keep_contents_section (bfd *ibfd, asection *isection)
1431{
1432 /* Always keep ELF note sections. */
dd68a12b
AM
1433 if (bfd_get_flavour (ibfd) == bfd_target_elf_flavour)
1434 return elf_section_type (isection) == SHT_NOTE;
6e6e7cfc 1435
74fffc39 1436 /* Always keep the .buildid section for PE/COFF.
6e6e7cfc
JT
1437
1438 Strictly, this should be written "always keep the section storing the debug
1439 directory", but that may be the .text section for objects produced by some
1440 tools, which it is not sensible to keep. */
dd68a12b
AM
1441 if (bfd_get_flavour (ibfd) == bfd_target_coff_flavour)
1442 return strcmp (bfd_section_name (isection), ".buildid") == 0;
6e6e7cfc
JT
1443
1444 return FALSE;
1445}
1446
d58c2e3a
RS
1447/* Return true if SYM is a hidden symbol. */
1448
1449static bfd_boolean
1450is_hidden_symbol (asymbol *sym)
1451{
1452 elf_symbol_type *elf_sym;
1453
c1229f84 1454 elf_sym = elf_symbol_from (sym);
d58c2e3a
RS
1455 if (elf_sym != NULL)
1456 switch (ELF_ST_VISIBILITY (elf_sym->internal_elf_sym.st_other))
1457 {
1458 case STV_HIDDEN:
1459 case STV_INTERNAL:
1460 return TRUE;
1461 }
1462 return FALSE;
1463}
1464
ffebb0bb
NC
1465/* Empty name is hopefully never a valid symbol name. */
1466static const char * empty_name = "";
1467
2b35fb28
RH
1468static bfd_boolean
1469need_sym_before (struct addsym_node **node, const char *sym)
1470{
1471 int count;
1472 struct addsym_node *ptr = add_sym_list;
1473
1474 /* 'othersym' symbols are at the front of the list. */
1475 for (count = 0; count < add_symbols; count++)
1476 {
1477 if (!ptr->othersym)
1478 break;
ffebb0bb
NC
1479 if (ptr->othersym == empty_name)
1480 continue;
2b35fb28
RH
1481 else if (strcmp (ptr->othersym, sym) == 0)
1482 {
ffebb0bb
NC
1483 free ((char *) ptr->othersym);
1484 ptr->othersym = empty_name;
2b35fb28
RH
1485 *node = ptr;
1486 return TRUE;
1487 }
1488 ptr = ptr->next;
1489 }
1490 return FALSE;
1491}
1492
1493static asymbol *
1494create_new_symbol (struct addsym_node *ptr, bfd *obfd)
1495{
f7433f01 1496 asymbol *sym = bfd_make_empty_symbol (obfd);
2b35fb28 1497
e6f7f6d1 1498 bfd_set_asymbol_name (sym, ptr->symdef);
2b35fb28
RH
1499 sym->value = ptr->symval;
1500 sym->flags = ptr->flags;
1501 if (ptr->section)
1502 {
1503 asection *sec = bfd_get_section_by_name (obfd, ptr->section);
1504 if (!sec)
1505 fatal (_("Section %s not found"), ptr->section);
1506 sym->section = sec;
1507 }
f7433f01
AM
1508 else
1509 sym->section = bfd_abs_section_ptr;
2b35fb28
RH
1510 return sym;
1511}
1512
252b5132
RH
1513/* Choose which symbol entries to copy; put the result in OSYMS.
1514 We don't copy in place, because that confuses the relocs.
1515 Return the number of symbols to print. */
1516
1517static unsigned int
84e2f313
NC
1518filter_symbols (bfd *abfd, bfd *obfd, asymbol **osyms,
1519 asymbol **isyms, long symcount)
252b5132 1520{
84e2f313 1521 asymbol **from = isyms, **to = osyms;
252b5132 1522 long src_count = 0, dst_count = 0;
e205a099 1523 int relocatable = (abfd->flags & (EXEC_P | DYNAMIC)) == 0;
252b5132
RH
1524
1525 for (; src_count < symcount; src_count++)
1526 {
1527 asymbol *sym = from[src_count];
1528 flagword flags = sym->flags;
d7fb0dd2 1529 char *name = (char *) bfd_asymbol_name (sym);
312aaa3c
NC
1530 bfd_boolean keep;
1531 bfd_boolean used_in_reloc = FALSE;
b34976b6 1532 bfd_boolean undefined;
d7fb0dd2
NC
1533 bfd_boolean rem_leading_char;
1534 bfd_boolean add_leading_char;
1535
e6f7f6d1 1536 undefined = bfd_is_und_section (bfd_asymbol_section (sym));
252b5132 1537
2b35fb28
RH
1538 if (add_sym_list)
1539 {
1540 struct addsym_node *ptr;
1541
1542 if (need_sym_before (&ptr, name))
1543 to[dst_count++] = create_new_symbol (ptr, obfd);
1544 }
1545
0f65a5d8 1546 if (htab_elements (redefine_specific_htab) || section_rename_list)
57938635 1547 {
9cc0123f 1548 char *new_name;
57938635 1549
9cc0123f
AM
1550 new_name = (char *) lookup_sym_redefinition (name);
1551 if (new_name == name
1552 && (flags & BSF_SECTION_SYM) != 0)
1553 new_name = (char *) find_section_rename (name, NULL);
e6f7f6d1 1554 bfd_set_asymbol_name (sym, new_name);
66491ebc 1555 name = new_name;
57938635
AM
1556 }
1557
d7fb0dd2
NC
1558 /* Check if we will remove the current leading character. */
1559 rem_leading_char =
a9b90127
AM
1560 (name[0] != '\0'
1561 && name[0] == bfd_get_symbol_leading_char (abfd)
1562 && (change_leading_char
1563 || (remove_leading_char
1564 && ((flags & (BSF_GLOBAL | BSF_WEAK)) != 0
1565 || undefined
1566 || bfd_is_com_section (bfd_asymbol_section (sym))))));
d7fb0dd2
NC
1567
1568 /* Check if we will add a new leading character. */
1569 add_leading_char =
1570 change_leading_char
1571 && (bfd_get_symbol_leading_char (obfd) != '\0')
1572 && (bfd_get_symbol_leading_char (abfd) == '\0'
1573 || (name[0] == bfd_get_symbol_leading_char (abfd)));
1574
1575 /* Short circuit for change_leading_char if we can do it in-place. */
1576 if (rem_leading_char && add_leading_char && !prefix_symbols_string)
f7433f01 1577 {
d7fb0dd2 1578 name[0] = bfd_get_symbol_leading_char (obfd);
e6f7f6d1 1579 bfd_set_asymbol_name (sym, name);
d7fb0dd2
NC
1580 rem_leading_char = FALSE;
1581 add_leading_char = FALSE;
f7433f01 1582 }
d7fb0dd2
NC
1583
1584 /* Remove leading char. */
1585 if (rem_leading_char)
e6f7f6d1 1586 bfd_set_asymbol_name (sym, ++name);
d7fb0dd2
NC
1587
1588 /* Add new leading char and/or prefix. */
1589 if (add_leading_char || prefix_symbols_string)
f7433f01
AM
1590 {
1591 char *n, *ptr;
d1faf7ca 1592 size_t len = strlen (name) + 1;
d7fb0dd2 1593
d1faf7ca
AM
1594 if (add_leading_char)
1595 len++;
1596 if (prefix_symbols_string)
1597 len += strlen (prefix_symbols_string);
1598
1599 ptr = n = (char *) xmalloc (len);
f7433f01 1600 if (add_leading_char)
d7fb0dd2
NC
1601 *ptr++ = bfd_get_symbol_leading_char (obfd);
1602
f7433f01
AM
1603 if (prefix_symbols_string)
1604 {
1605 strcpy (ptr, prefix_symbols_string);
1606 ptr += strlen (prefix_symbols_string);
1607 }
d7fb0dd2 1608
f7433f01 1609 strcpy (ptr, name);
e6f7f6d1 1610 bfd_set_asymbol_name (sym, n);
f7433f01 1611 name = n;
252b5132
RH
1612 }
1613
252b5132 1614 if (strip_symbols == STRIP_ALL)
312aaa3c 1615 keep = FALSE;
252b5132
RH
1616 else if ((flags & BSF_KEEP) != 0 /* Used in relocation. */
1617 || ((flags & BSF_SECTION_SYM) != 0
e6f7f6d1 1618 && ((*bfd_asymbol_section (sym)->symbol_ptr_ptr)->flags
252b5132 1619 & BSF_KEEP) != 0))
312aaa3c
NC
1620 {
1621 keep = TRUE;
1622 used_in_reloc = TRUE;
1623 }
0af11b59 1624 else if (relocatable /* Relocatable file. */
0691f7af 1625 && ((flags & (BSF_GLOBAL | BSF_WEAK)) != 0
e6f7f6d1 1626 || bfd_is_com_section (bfd_asymbol_section (sym))))
312aaa3c 1627 keep = TRUE;
16b2b71c
NC
1628 else if (bfd_decode_symclass (sym) == 'I')
1629 /* Global symbols in $idata sections need to be retained
b34976b6 1630 even if relocatable is FALSE. External users of the
16b2b71c
NC
1631 library containing the $idata section may reference these
1632 symbols. */
312aaa3c 1633 keep = TRUE;
252b5132
RH
1634 else if ((flags & BSF_GLOBAL) != 0 /* Global symbol. */
1635 || (flags & BSF_WEAK) != 0
24e01a36 1636 || undefined
e6f7f6d1 1637 || bfd_is_com_section (bfd_asymbol_section (sym)))
252b5132
RH
1638 keep = strip_symbols != STRIP_UNNEEDED;
1639 else if ((flags & BSF_DEBUGGING) != 0) /* Debugging symbol. */
1640 keep = (strip_symbols != STRIP_DEBUG
1641 && strip_symbols != STRIP_UNNEEDED
1642 && ! convert_debugging);
e6f7f6d1 1643 else if (bfd_coff_get_comdat_section (abfd, bfd_asymbol_section (sym)))
af3bdff7
NC
1644 /* COMDAT sections store special information in local
1645 symbols, so we cannot risk stripping any of them. */
312aaa3c 1646 keep = TRUE;
252b5132
RH
1647 else /* Local symbol. */
1648 keep = (strip_symbols != STRIP_UNNEEDED
1649 && (discard_locals != LOCALS_ALL
1650 && (discard_locals != LOCALS_START_L
1651 || ! bfd_is_local_label (abfd, sym))));
1652
047c9024 1653 if (keep && is_specified_symbol (name, strip_specific_htab))
312aaa3c
NC
1654 {
1655 /* There are multiple ways to set 'keep' above, but if it
1656 was the relocatable symbol case, then that's an error. */
1657 if (used_in_reloc)
1658 {
1659 non_fatal (_("not stripping symbol `%s' because it is named in a relocation"), name);
1660 status = 1;
1661 }
1662 else
1663 keep = FALSE;
1664 }
1665
bcf32829
JB
1666 if (keep
1667 && !(flags & BSF_KEEP)
047c9024 1668 && is_specified_symbol (name, strip_unneeded_htab))
312aaa3c
NC
1669 keep = FALSE;
1670
1637cd90
JB
1671 if (!keep
1672 && ((keep_file_symbols && (flags & BSF_FILE))
047c9024 1673 || is_specified_symbol (name, keep_specific_htab)))
312aaa3c
NC
1674 keep = TRUE;
1675
e6f7f6d1 1676 if (keep && is_strip_section (abfd, bfd_asymbol_section (sym)))
312aaa3c 1677 keep = FALSE;
e0c60db2 1678
7b4a0685 1679 if (keep)
252b5132 1680 {
7b4a0685 1681 if ((flags & BSF_GLOBAL) != 0
047c9024 1682 && (weaken || is_specified_symbol (name, weaken_specific_htab)))
7b4a0685
NC
1683 {
1684 sym->flags &= ~ BSF_GLOBAL;
1685 sym->flags |= BSF_WEAK;
1686 }
252b5132 1687
7b4a0685
NC
1688 if (!undefined
1689 && (flags & (BSF_GLOBAL | BSF_WEAK))
047c9024
NC
1690 && (is_specified_symbol (name, localize_specific_htab)
1691 || (htab_elements (keepglobal_specific_htab) != 0
1692 && ! is_specified_symbol (name, keepglobal_specific_htab))
d58c2e3a 1693 || (localize_hidden && is_hidden_symbol (sym))))
7b4a0685
NC
1694 {
1695 sym->flags &= ~ (BSF_GLOBAL | BSF_WEAK);
1696 sym->flags |= BSF_LOCAL;
1697 }
1698
1699 if (!undefined
c1c0eb9e 1700 && (flags & BSF_LOCAL)
047c9024 1701 && is_specified_symbol (name, globalize_specific_htab))
7b4a0685
NC
1702 {
1703 sym->flags &= ~ BSF_LOCAL;
1704 sym->flags |= BSF_GLOBAL;
1705 }
1706
1707 to[dst_count++] = sym;
1708 }
252b5132 1709 }
2b35fb28
RH
1710 if (add_sym_list)
1711 {
1712 struct addsym_node *ptr = add_sym_list;
1713
1714 for (src_count = 0; src_count < add_symbols; src_count++)
1715 {
1716 if (ptr->othersym)
1717 {
ffebb0bb 1718 if (ptr->othersym != empty_name)
2b35fb28
RH
1719 fatal (_("'before=%s' not found"), ptr->othersym);
1720 }
1721 else
1722 to[dst_count++] = create_new_symbol (ptr, obfd);
1723
1724 ptr = ptr->next;
1725 }
1726 }
252b5132
RH
1727
1728 to[dst_count] = NULL;
1729
1730 return dst_count;
1731}
1732
594ef5db
NC
1733/* Find the redefined name of symbol SOURCE. */
1734
57938635 1735static const char *
84e2f313 1736lookup_sym_redefinition (const char *source)
57938635 1737{
0f65a5d8
JW
1738 struct redefine_node key_node = {(char *) source, NULL};
1739 struct redefine_node *redef_node
1740 = (struct redefine_node *) htab_find (redefine_specific_htab, &key_node);
594ef5db 1741
0f65a5d8 1742 return redef_node == NULL ? source : redef_node->target;
57938635
AM
1743}
1744
0f65a5d8 1745/* Insert a node into symbol redefine hash tabel. */
57938635
AM
1746
1747static void
0f65a5d8
JW
1748add_redefine_and_check (const char *cause, const char *source,
1749 const char *target)
57938635 1750{
0f65a5d8
JW
1751 struct redefine_node *new_node
1752 = (struct redefine_node *) xmalloc (sizeof (struct redefine_node));
57938635 1753
0f65a5d8
JW
1754 new_node->source = strdup (source);
1755 new_node->target = strdup (target);
57938635 1756
0f65a5d8
JW
1757 if (htab_find (redefine_specific_htab, new_node) != HTAB_EMPTY_ENTRY)
1758 fatal (_("%s: Multiple redefinition of symbol \"%s\""),
1759 cause, source);
57938635 1760
0f65a5d8
JW
1761 if (htab_find (redefine_specific_reverse_htab, target) != HTAB_EMPTY_ENTRY)
1762 fatal (_("%s: Symbol \"%s\" is target of more than one redefinition"),
1763 cause, target);
57938635 1764
0f65a5d8
JW
1765 /* Insert the NEW_NODE into hash table for quick search. */
1766 add_specific_symbol_node (new_node, redefine_specific_htab);
1767
1768 /* Insert the target string into the reverse hash table, this is needed for
1769 duplicated target string check. */
1770 add_specific_symbol (new_node->target, redefine_specific_reverse_htab);
57938635 1771
57938635
AM
1772}
1773
92991082
JT
1774/* Handle the --redefine-syms option. Read lines containing "old new"
1775 from the file, and add them to the symbol redefine list. */
1776
2593f09a 1777static void
84e2f313 1778add_redefine_syms_file (const char *filename)
92991082
JT
1779{
1780 FILE *file;
1781 char *buf;
84e2f313
NC
1782 size_t bufsize;
1783 size_t len;
1784 size_t outsym_off;
92991082
JT
1785 int c, lineno;
1786
1787 file = fopen (filename, "r");
d3ba0551 1788 if (file == NULL)
92991082
JT
1789 fatal (_("couldn't open symbol redefinition file %s (error: %s)"),
1790 filename, strerror (errno));
1791
1792 bufsize = 100;
a6da20b5 1793 buf = (char *) xmalloc (bufsize + 1 /* For the terminating NUL. */);
92991082
JT
1794
1795 lineno = 1;
1796 c = getc (file);
1797 len = 0;
1798 outsym_off = 0;
1799 while (c != EOF)
1800 {
1801 /* Collect the input symbol name. */
1802 while (! IS_WHITESPACE (c) && ! IS_LINE_TERMINATOR (c) && c != EOF)
1803 {
1804 if (c == '#')
1805 goto comment;
1806 buf[len++] = c;
1807 if (len >= bufsize)
1808 {
1809 bufsize *= 2;
a6da20b5 1810 buf = (char *) xrealloc (buf, bufsize + 1);
92991082
JT
1811 }
1812 c = getc (file);
1813 }
1814 buf[len++] = '\0';
1815 if (c == EOF)
1816 break;
1817
1818 /* Eat white space between the symbol names. */
1819 while (IS_WHITESPACE (c))
1820 c = getc (file);
1821 if (c == '#' || IS_LINE_TERMINATOR (c))
1822 goto comment;
1823 if (c == EOF)
1824 break;
1825
1826 /* Collect the output symbol name. */
1827 outsym_off = len;
1828 while (! IS_WHITESPACE (c) && ! IS_LINE_TERMINATOR (c) && c != EOF)
1829 {
1830 if (c == '#')
1831 goto comment;
1832 buf[len++] = c;
1833 if (len >= bufsize)
1834 {
1835 bufsize *= 2;
a6da20b5 1836 buf = (char *) xrealloc (buf, bufsize + 1);
92991082
JT
1837 }
1838 c = getc (file);
1839 }
1840 buf[len++] = '\0';
1841 if (c == EOF)
1842 break;
1843
1844 /* Eat white space at end of line. */
1845 while (! IS_LINE_TERMINATOR(c) && c != EOF && IS_WHITESPACE (c))
1846 c = getc (file);
1847 if (c == '#')
1848 goto comment;
1849 /* Handle \r\n. */
1850 if ((c == '\r' && (c = getc (file)) == '\n')
1851 || c == '\n' || c == EOF)
1852 {
f7433f01 1853 end_of_line:
92991082
JT
1854 /* Append the redefinition to the list. */
1855 if (buf[0] != '\0')
0f65a5d8 1856 add_redefine_and_check (filename, &buf[0], &buf[outsym_off]);
92991082 1857
c1c0eb9e 1858 lineno++;
92991082
JT
1859 len = 0;
1860 outsym_off = 0;
1861 if (c == EOF)
1862 break;
1863 c = getc (file);
1864 continue;
1865 }
1866 else
d412a550 1867 fatal (_("%s:%d: garbage found at end of line"), filename, lineno);
f7433f01 1868 comment:
92991082 1869 if (len != 0 && (outsym_off == 0 || outsym_off == len))
d412a550 1870 fatal (_("%s:%d: missing new symbol name"), filename, lineno);
92991082
JT
1871 buf[len++] = '\0';
1872
1873 /* Eat the rest of the line and finish it. */
1874 while (c != '\n' && c != EOF)
1875 c = getc (file);
1876 goto end_of_line;
1877 }
1878
1879 if (len != 0)
d412a550 1880 fatal (_("%s:%d: premature end of file"), filename, lineno);
92991082
JT
1881
1882 free (buf);
3391569f 1883 fclose (file);
92991082
JT
1884}
1885
222c2bf0 1886/* Copy unknown object file IBFD onto OBFD.
77f762d6
L
1887 Returns TRUE upon success, FALSE otherwise. */
1888
1889static bfd_boolean
1890copy_unknown_object (bfd *ibfd, bfd *obfd)
1891{
1892 char *cbuf;
1893 int tocopy;
1894 long ncopied;
1895 long size;
1896 struct stat buf;
1897
1898 if (bfd_stat_arch_elt (ibfd, &buf) != 0)
1899 {
8d8e0703 1900 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
77f762d6
L
1901 return FALSE;
1902 }
1903
1904 size = buf.st_size;
1905 if (size < 0)
1906 {
1907 non_fatal (_("stat returns negative size for `%s'"),
1908 bfd_get_archive_filename (ibfd));
1909 return FALSE;
1910 }
1911
1912 if (bfd_seek (ibfd, (file_ptr) 0, SEEK_SET) != 0)
1913 {
1914 bfd_nonfatal (bfd_get_archive_filename (ibfd));
1915 return FALSE;
1916 }
1917
1918 if (verbose)
1919 printf (_("copy from `%s' [unknown] to `%s' [unknown]\n"),
1920 bfd_get_archive_filename (ibfd), bfd_get_filename (obfd));
1921
3f5e193b 1922 cbuf = (char *) xmalloc (BUFSIZE);
77f762d6
L
1923 ncopied = 0;
1924 while (ncopied < size)
1925 {
1926 tocopy = size - ncopied;
1927 if (tocopy > BUFSIZE)
1928 tocopy = BUFSIZE;
1929
1930 if (bfd_bread (cbuf, (bfd_size_type) tocopy, ibfd)
1931 != (bfd_size_type) tocopy)
1932 {
8d8e0703 1933 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
77f762d6
L
1934 free (cbuf);
1935 return FALSE;
1936 }
1937
1938 if (bfd_bwrite (cbuf, (bfd_size_type) tocopy, obfd)
1939 != (bfd_size_type) tocopy)
1940 {
2db6cde7 1941 bfd_nonfatal_message (NULL, obfd, NULL, NULL);
77f762d6
L
1942 free (cbuf);
1943 return FALSE;
1944 }
1945
1946 ncopied += tocopy;
1947 }
1948
1e99536a
L
1949 /* We should at least to be able to read it back when copying an
1950 unknown object in an archive. */
1951 chmod (bfd_get_filename (obfd), buf.st_mode | S_IRUSR);
77f762d6
L
1952 free (cbuf);
1953 return TRUE;
1954}
1955
6f156d7a
NC
1956typedef struct objcopy_internal_note
1957{
1958 Elf_Internal_Note note;
5c49f2cd 1959 unsigned long padded_namesz;
6f156d7a
NC
1960 bfd_vma start;
1961 bfd_vma end;
6f156d7a 1962} objcopy_internal_note;
82ef9cad 1963
5c49f2cd
NC
1964#define DEBUG_MERGE 0
1965
1966#if DEBUG_MERGE
1967#define merge_debug(format, ...) fprintf (stderr, format, ## __VA_ARGS__)
1968#else
1969#define merge_debug(format, ...)
1970#endif
1971
1972/* Returns TRUE iff PNOTE1 overlaps or adjoins PNOTE2. */
6f156d7a
NC
1973
1974static bfd_boolean
5c49f2cd
NC
1975overlaps_or_adjoins (objcopy_internal_note * pnote1,
1976 objcopy_internal_note * pnote2)
6f156d7a 1977{
5c49f2cd
NC
1978 if (pnote1->end < pnote2->start)
1979 /* FIXME: Alignment of 16 bytes taken from x86_64 binaries.
1980 Really we should extract the alignment of the section
1981 covered by the notes. */
1982 return BFD_ALIGN (pnote1->end, 16) < pnote2->start;
1983
1984 if (pnote2->end < pnote2->start)
1985 return BFD_ALIGN (pnote2->end, 16) < pnote1->start;
1986
1987 if (pnote1->end < pnote2->end)
6f156d7a
NC
1988 return TRUE;
1989
5c49f2cd
NC
1990 if (pnote2->end < pnote1->end)
1991 return TRUE;
1992
1993 return FALSE;
1994}
1995
1996/* Returns TRUE iff NEEDLE is fully contained by HAYSTACK. */
1997
1998static bfd_boolean
1999contained_by (objcopy_internal_note * needle,
2000 objcopy_internal_note * haystack)
2001{
2002 return needle->start >= haystack->start && needle->end <= haystack->end;
6f156d7a
NC
2003}
2004
2005static bfd_boolean
2006is_open_note (objcopy_internal_note * pnote)
2007{
5c49f2cd 2008 return pnote->note.type == NT_GNU_BUILD_ATTRIBUTE_OPEN;
6f156d7a
NC
2009}
2010
2011static bfd_boolean
2012is_func_note (objcopy_internal_note * pnote)
2013{
5c49f2cd
NC
2014 return pnote->note.type == NT_GNU_BUILD_ATTRIBUTE_FUNC;
2015}
2016
2017static bfd_boolean
2018is_deleted_note (objcopy_internal_note * pnote)
2019{
2020 return pnote->note.type == 0;
2021}
2022
2023static bfd_boolean
2024is_version_note (objcopy_internal_note * pnote)
2025{
2026 return (pnote->note.namesz > 4
2027 && pnote->note.namedata[0] == 'G'
2028 && pnote->note.namedata[1] == 'A'
2029 && pnote->note.namedata[2] == '$'
2030 && pnote->note.namedata[3] == GNU_BUILD_ATTRIBUTE_VERSION);
6f156d7a
NC
2031}
2032
2033static bfd_boolean
2034is_64bit (bfd * abfd)
2035{
2036 /* Should never happen, but let's be paranoid. */
2037 if (bfd_get_flavour (abfd) != bfd_target_elf_flavour)
2038 return FALSE;
2039
2040 return elf_elfheader (abfd)->e_ident[EI_CLASS] == ELFCLASS64;
2041}
2042
5c49f2cd
NC
2043/* This sorting function is used to get the notes into an order
2044 that makes merging easy. */
2045
2046static int
2047compare_gnu_build_notes (const void * data1, const void * data2)
2048{
2049 objcopy_internal_note * pnote1 = (objcopy_internal_note *) data1;
2050 objcopy_internal_note * pnote2 = (objcopy_internal_note *) data2;
2051
2052 /* Sort notes based upon the attribute they record. */
2053 int cmp = memcmp (pnote1->note.namedata + 3,
2054 pnote2->note.namedata + 3,
2055 pnote1->note.namesz < pnote2->note.namesz ?
2056 pnote1->note.namesz - 3 : pnote2->note.namesz - 3);
2057 if (cmp)
2058 return cmp;
82ef9cad 2059
5c49f2cd
NC
2060 if (pnote1->end < pnote2->start)
2061 return -1;
2062 if (pnote1->start > pnote2->end)
2063 return 1;
2064
2065 /* Overlaps - we should merge the two ranges. */
2066 if (pnote1->start < pnote2->start)
2067 return -1;
2068 if (pnote1->end > pnote2->end)
2069 return 1;
82ef9cad
RM
2070 if (pnote1->end < pnote2->end)
2071 return -1;
2072
5c49f2cd
NC
2073 /* Put OPEN notes before function notes. */
2074 if (is_open_note (pnote1) && ! is_open_note (pnote2))
2075 return -1;
2076 if (! is_open_note (pnote1) && is_open_note (pnote2))
2077 return 1;
82ef9cad 2078
5c49f2cd
NC
2079 return 0;
2080}
2081
2082/* This sorting function is used to get the notes into an order
2083 that makes eliminating address ranges easier. */
2084
2085static int
2086sort_gnu_build_notes (const void * data1, const void * data2)
2087{
2088 objcopy_internal_note * pnote1 = (objcopy_internal_note *) data1;
2089 objcopy_internal_note * pnote2 = (objcopy_internal_note *) data2;
2090
2091 if (pnote1->note.type != pnote2->note.type)
2092 {
2093 /* Move deleted notes to the end. */
2094 if (is_deleted_note (pnote1)) /* 1: OFD 2: OFD */
2095 return 1;
2096
2097 /* Move OPEN notes to the start. */
2098 if (is_open_note (pnote1)) /* 1: OF 2: OFD */
2099 return -1;
2100
2101 if (is_deleted_note (pnote2)) /* 1: F 2: O D */
1cc3da76 2102 return -1;
5c49f2cd
NC
2103
2104 return 1; /* 1: F 2: O */
2105 }
82ef9cad 2106
5c49f2cd
NC
2107 /* Sort by starting address. */
2108 if (pnote1->start < pnote2->start)
2109 return -1;
2110 if (pnote1->start > pnote2->start)
2111 return 1;
2112
2113 /* Then by end address (bigger range first). */
2114 if (pnote1->end > pnote2->end)
2115 return -1;
2116 if (pnote1->end < pnote2->end)
2117 return 1;
2118
2119 /* Then by attribute type. */
2120 if (pnote1->note.namesz > 4
2121 && pnote2->note.namesz > 4
2122 && pnote1->note.namedata[3] != pnote2->note.namedata[3])
2123 return pnote1->note.namedata[3] - pnote2->note.namedata[3];
82ef9cad 2124
5c49f2cd
NC
2125 return 0;
2126}
2127
9ef920e9
NC
2128/* Merge the notes on SEC, removing redundant entries.
2129 Returns the new, smaller size of the section upon success. */
2130
2131static bfd_size_type
5c49f2cd
NC
2132merge_gnu_build_notes (bfd * abfd,
2133 asection * sec,
2134 bfd_size_type size,
2135 bfd_byte * contents)
9ef920e9 2136{
6f156d7a
NC
2137 objcopy_internal_note * pnotes_end;
2138 objcopy_internal_note * pnotes = NULL;
2139 objcopy_internal_note * pnote;
9ef920e9 2140 bfd_size_type remain = size;
88305e1b
NC
2141 unsigned version_1_seen = 0;
2142 unsigned version_2_seen = 0;
6f156d7a 2143 unsigned version_3_seen = 0;
9ef920e9
NC
2144 const char * err = NULL;
2145 bfd_byte * in = contents;
6f156d7a
NC
2146 unsigned long previous_func_start = 0;
2147 unsigned long previous_open_start = 0;
2148 unsigned long previous_func_end = 0;
2149 unsigned long previous_open_end = 0;
2150 long relsize;
2151
6f156d7a
NC
2152 relsize = bfd_get_reloc_upper_bound (abfd, sec);
2153 if (relsize > 0)
2154 {
2155 arelent ** relpp;
2156 long relcount;
2157
2158 /* If there are relocs associated with this section then we
2159 cannot safely merge it. */
2160 relpp = (arelent **) xmalloc (relsize);
2161 relcount = bfd_canonicalize_reloc (abfd, sec, relpp, isympp);
2162 free (relpp);
2163 if (relcount != 0)
5c49f2cd
NC
2164 {
2165 if (! is_strip)
2166 non_fatal (_("%s[%s]: Cannot merge - there are relocations against this section"),
2167 bfd_get_filename (abfd), bfd_section_name (sec));
2168 goto done;
2169 }
6f156d7a 2170 }
82ef9cad 2171
6f156d7a 2172 /* Make a copy of the notes and convert to our internal format.
276cbbdf
NC
2173 Minimum size of a note is 12 bytes. Also locate the version
2174 notes and check them. */
5c49f2cd
NC
2175 pnote = pnotes = (objcopy_internal_note *)
2176 xcalloc ((size / 12), sizeof (* pnote));
9ef920e9
NC
2177 while (remain >= 12)
2178 {
6f156d7a
NC
2179 bfd_vma start, end;
2180
5c49f2cd
NC
2181 pnote->note.namesz = bfd_get_32 (abfd, in);
2182 pnote->note.descsz = bfd_get_32 (abfd, in + 4);
2183 pnote->note.type = bfd_get_32 (abfd, in + 8);
2184 pnote->padded_namesz = (pnote->note.namesz + 3) & ~3;
2185
2186 if (((pnote->note.descsz + 3) & ~3) != pnote->note.descsz)
2187 {
2188 err = _("corrupt GNU build attribute note: description size not a factor of 4");
2189 goto done;
2190 }
9ef920e9 2191
6f156d7a
NC
2192 if (pnote->note.type != NT_GNU_BUILD_ATTRIBUTE_OPEN
2193 && pnote->note.type != NT_GNU_BUILD_ATTRIBUTE_FUNC)
9ef920e9
NC
2194 {
2195 err = _("corrupt GNU build attribute note: wrong note type");
2196 goto done;
2197 }
2198
5c49f2cd 2199 if (pnote->padded_namesz + pnote->note.descsz + 12 > remain)
9ef920e9
NC
2200 {
2201 err = _("corrupt GNU build attribute note: note too big");
2202 goto done;
2203 }
2204
6f156d7a 2205 if (pnote->note.namesz < 2)
9ef920e9
NC
2206 {
2207 err = _("corrupt GNU build attribute note: name too small");
2208 goto done;
2209 }
2210
6f156d7a 2211 pnote->note.namedata = (char *)(in + 12);
5c49f2cd 2212 pnote->note.descdata = (char *)(in + 12 + pnote->padded_namesz);
6f156d7a 2213
5c49f2cd
NC
2214 remain -= 12 + pnote->padded_namesz + pnote->note.descsz;
2215 in += 12 + pnote->padded_namesz + pnote->note.descsz;
6f156d7a
NC
2216
2217 if (pnote->note.namesz > 2
2218 && pnote->note.namedata[0] == '$'
2219 && pnote->note.namedata[1] == GNU_BUILD_ATTRIBUTE_VERSION
2220 && pnote->note.namedata[2] == '1')
2221 ++ version_1_seen;
5c49f2cd 2222 else if (is_version_note (pnote))
6f156d7a
NC
2223 {
2224 if (pnote->note.namedata[4] == '2')
2225 ++ version_2_seen;
2226 else if (pnote->note.namedata[4] == '3')
2227 ++ version_3_seen;
2228 else
2229 {
2230 err = _("corrupt GNU build attribute note: unsupported version");
2231 goto done;
2232 }
2233 }
2234
2235 switch (pnote->note.descsz)
9ef920e9 2236 {
6f156d7a
NC
2237 case 0:
2238 start = end = 0;
2239 break;
2240
2241 case 4:
2242 start = bfd_get_32 (abfd, pnote->note.descdata);
2243 /* FIXME: For version 1 and 2 notes we should try to
2244 calculate the end address by finding a symbol whose
2245 value is START, and then adding in its size.
2246
2247 For now though, since v1 and v2 was not intended to
2248 handle gaps, we chose an artificially large end
2249 address. */
f49db8be 2250 end = (bfd_vma) -1;
6f156d7a 2251 break;
82ef9cad 2252
6f156d7a
NC
2253 case 8:
2254 if (! is_64bit (abfd))
2255 {
2256 start = bfd_get_32 (abfd, pnote->note.descdata);
2257 end = bfd_get_32 (abfd, pnote->note.descdata + 4);
2258 }
2259 else
2260 {
2261 start = bfd_get_64 (abfd, pnote->note.descdata);
2262 /* FIXME: For version 1 and 2 notes we should try to
2263 calculate the end address by finding a symbol whose
2264 value is START, and then adding in its size.
2265
2266 For now though, since v1 and v2 was not intended to
2267 handle gaps, we chose an artificially large end
2268 address. */
f49db8be 2269 end = (bfd_vma) -1;
6f156d7a
NC
2270 }
2271 break;
2272
2273 case 16:
2274 start = bfd_get_64 (abfd, pnote->note.descdata);
2275 end = bfd_get_64 (abfd, pnote->note.descdata + 8);
2276 break;
82ef9cad 2277
6f156d7a 2278 default:
9ef920e9
NC
2279 err = _("corrupt GNU build attribute note: bad description size");
2280 goto done;
2281 }
2282
6f156d7a
NC
2283 if (is_open_note (pnote))
2284 {
2285 if (start)
2286 previous_open_start = start;
2287
2288 pnote->start = previous_open_start;
2289
2290 if (end)
2291 previous_open_end = end;
2292
2293 pnote->end = previous_open_end;
2294 }
2295 else
2296 {
2297 if (start)
2298 previous_func_start = start;
2299
2300 pnote->start = previous_func_start;
9ef920e9 2301
6f156d7a
NC
2302 if (end)
2303 previous_func_end = end;
9ef920e9 2304
6f156d7a
NC
2305 pnote->end = previous_func_end;
2306 }
2307
2308 if (pnote->note.namedata[pnote->note.namesz - 1] != 0)
1d15e434
NC
2309 {
2310 err = _("corrupt GNU build attribute note: name not NUL terminated");
2311 goto done;
2312 }
6f156d7a 2313
9ef920e9
NC
2314 pnote ++;
2315 }
2316
2317 pnotes_end = pnote;
2318
2319 /* Check that the notes are valid. */
2320 if (remain != 0)
2321 {
88305e1b 2322 err = _("corrupt GNU build attribute notes: excess data at end");
9ef920e9
NC
2323 goto done;
2324 }
2325
6f156d7a 2326 if (version_1_seen == 0 && version_2_seen == 0 && version_3_seen == 0)
9ef920e9 2327 {
5c49f2cd 2328#if 0
88305e1b
NC
2329 err = _("bad GNU build attribute notes: no known versions detected");
2330 goto done;
5c49f2cd
NC
2331#else
2332 /* This happens with glibc. No idea why. */
2333 non_fatal (_("%s[%s]: Warning: version note missing - assuming version 3"),
2334 bfd_get_filename (abfd), bfd_section_name (sec));
2335 version_3_seen = 2;
2336#endif
88305e1b
NC
2337 }
2338
5c49f2cd 2339 if ( (version_1_seen > 0 && version_2_seen > 0)
6f156d7a
NC
2340 || (version_1_seen > 0 && version_3_seen > 0)
2341 || (version_2_seen > 0 && version_3_seen > 0))
88305e1b
NC
2342 {
2343 err = _("bad GNU build attribute notes: multiple different versions");
9ef920e9
NC
2344 goto done;
2345 }
2346
5c49f2cd
NC
2347 /* We are now only supporting the merging v3+ notes
2348 - it makes things much simpler. */
2349 if (version_3_seen == 0)
2350 {
2351 merge_debug ("%s: skipping merge - not using v3 notes", bfd_section_name (sec));
2352 goto done;
2353 }
9ef920e9 2354
5c49f2cd
NC
2355 merge_debug ("Merging section %s which contains %ld notes\n",
2356 sec->name, pnotes_end - pnotes);
88305e1b 2357
5c49f2cd
NC
2358 /* Sort the notes. */
2359 qsort (pnotes, pnotes_end - pnotes, sizeof (* pnotes),
2360 compare_gnu_build_notes);
2361
2362#if DEBUG_MERGE
2363 merge_debug ("Results of initial sort:\n");
2364 for (pnote = pnotes; pnote < pnotes_end; pnote ++)
2365 merge_debug ("offset %#08lx range %#08lx..%#08lx type %ld attribute %d namesz %ld\n",
2366 (pnote->note.namedata - (char *) contents) - 12,
2367 pnote->start, pnote->end,
2368 pnote->note.type,
2369 pnote->note.namedata[3],
2370 pnote->note.namesz
2371 );
2372#endif
9ef920e9 2373
9ef920e9 2374 /* Now merge the notes. The rules are:
5c49f2cd
NC
2375 1. If a note has a zero range, it can be eliminated.
2376 2. If two notes have the same namedata then:
2377 2a. If one note's range is fully covered by the other note
2378 then it can be deleted.
2379 2b. If one note's range partially overlaps or adjoins the
2380 other note then if they are both of the same type (open
2381 or func) then they can be merged and one deleted. If
2382 they are of different types then they cannot be merged. */
276cbbdf 2383 for (pnote = pnotes; pnote < pnotes_end; pnote ++)
9ef920e9 2384 {
5c49f2cd
NC
2385 /* Skip already deleted notes.
2386 FIXME: Can this happen ? We are scanning forwards and
2387 deleting backwards after all. */
2388 if (is_deleted_note (pnote))
2389 continue;
9ef920e9 2390
5c49f2cd 2391 /* Rule 1 - delete 0-range notes. */
4aae6e5a
NC
2392 if (pnote->start == pnote->end)
2393 {
5c49f2cd
NC
2394 merge_debug ("Delete note at offset %#08lx - empty range\n",
2395 (pnote->note.namedata - (char *) contents) - 12);
4aae6e5a
NC
2396 pnote->note.type = 0;
2397 continue;
2398 }
2399
5c49f2cd
NC
2400 int iter;
2401 objcopy_internal_note * back;
9ef920e9 2402
5c49f2cd
NC
2403 /* Rule 2: Check to see if there is an identical previous note. */
2404 for (iter = 0, back = pnote - 1; back >= pnotes; back --)
9ef920e9 2405 {
5c49f2cd 2406 if (is_deleted_note (back))
6f156d7a 2407 continue;
88305e1b 2408
5c49f2cd
NC
2409 /* Our sorting function should have placed all identically
2410 attributed notes together, so if we see a note of a different
2411 attribute type stop searching. */
2412 if (back->note.namesz != pnote->note.namesz
2413 || memcmp (back->note.namedata,
2414 pnote->note.namedata, pnote->note.namesz) != 0)
2415 break;
82ef9cad 2416
5c49f2cd
NC
2417 if (back->start == pnote->start
2418 && back->end == pnote->end)
6f156d7a 2419 {
5c49f2cd
NC
2420 merge_debug ("Delete note at offset %#08lx - duplicate of note at offset %#08lx\n",
2421 (pnote->note.namedata - (char *) contents) - 12,
2422 (back->note.namedata - (char *) contents) - 12);
6f156d7a
NC
2423 pnote->note.type = 0;
2424 break;
2425 }
2426
5c49f2cd
NC
2427 /* Rule 2a. */
2428 if (contained_by (pnote, back))
6f156d7a 2429 {
5c49f2cd
NC
2430 merge_debug ("Delete note at offset %#08lx - fully contained by note at %#08lx\n",
2431 (pnote->note.namedata - (char *) contents) - 12,
2432 (back->note.namedata - (char *) contents) - 12);
6f156d7a 2433 pnote->note.type = 0;
6f156d7a
NC
2434 break;
2435 }
2436
5c49f2cd
NC
2437#if DEBUG_MERGE
2438 /* This should not happen as we have sorted the
2439 notes with earlier starting addresses first. */
2440 if (contained_by (back, pnote))
2441 merge_debug ("ERROR: UNEXPECTED CONTAINMENT\n");
2442#endif
2443
2444 /* Rule 2b. */
2445 if (overlaps_or_adjoins (back, pnote)
2446 && is_func_note (back) == is_func_note (pnote))
6f156d7a 2447 {
5c49f2cd
NC
2448 merge_debug ("Delete note at offset %#08lx - merge into note at %#08lx\n",
2449 (pnote->note.namedata - (char *) contents) - 12,
2450 (back->note.namedata - (char *) contents) - 12);
2451
2452 back->end = back->end > pnote->end ? back->end : pnote->end;
2453 back->start = back->start < pnote->start ? back->start : pnote->start;
2454 pnote->note.type = 0;
2455 break;
6f156d7a 2456 }
5c49f2cd
NC
2457
2458 /* Don't scan too far back however. */
2459 if (iter ++ > 16)
6f156d7a 2460 {
5c49f2cd
NC
2461 /* FIXME: Not sure if this can ever be triggered. */
2462 merge_debug ("ITERATION LIMIT REACHED\n");
2463 break;
9ef920e9
NC
2464 }
2465 }
5c49f2cd
NC
2466#if DEBUG_MERGE
2467 if (! is_deleted_note (pnote))
2468 merge_debug ("Unable to do anything with note at %#08lx\n",
2469 (pnote->note.namedata - (char *) contents) - 12);
82ef9cad 2470#endif
9ef920e9
NC
2471 }
2472
5c49f2cd
NC
2473 /* Resort the notes. */
2474 merge_debug ("Final sorting of notes\n");
2475 qsort (pnotes, pnotes_end - pnotes, sizeof (* pnotes), sort_gnu_build_notes);
2476
2477 /* Reconstruct the ELF notes. */
2478 bfd_byte * new_contents;
2479 bfd_byte * old;
2480 bfd_byte * new;
2481 bfd_size_type new_size;
2482 bfd_vma prev_start = 0;
2483 bfd_vma prev_end = 0;
2484
f76d7958
NC
2485 /* Not sure how, but the notes might grow in size.
2486 (eg see PR 1774507). Allow for this here. */
2487 new = new_contents = xmalloc (size * 2);
5c49f2cd
NC
2488 for (pnote = pnotes, old = contents;
2489 pnote < pnotes_end;
2490 pnote ++)
9ef920e9 2491 {
5c49f2cd 2492 bfd_size_type note_size = 12 + pnote->padded_namesz + pnote->note.descsz;
9ef920e9 2493
5c49f2cd 2494 if (! is_deleted_note (pnote))
9ef920e9 2495 {
5c49f2cd
NC
2496 /* Create the note, potentially using the
2497 address range of the previous note. */
2498 if (pnote->start == prev_start && pnote->end == prev_end)
9ef920e9 2499 {
5c49f2cd
NC
2500 bfd_put_32 (abfd, pnote->note.namesz, new);
2501 bfd_put_32 (abfd, 0, new + 4);
2502 bfd_put_32 (abfd, pnote->note.type, new + 8);
2503 new += 12;
2504 memcpy (new, pnote->note.namedata, pnote->note.namesz);
2505 if (pnote->note.namesz < pnote->padded_namesz)
2506 memset (new + pnote->note.namesz, 0, pnote->padded_namesz - pnote->note.namesz);
2507 new += pnote->padded_namesz;
2508 }
2509 else
2510 {
2511 bfd_put_32 (abfd, pnote->note.namesz, new);
2512 bfd_put_32 (abfd, is_64bit (abfd) ? 16 : 8, new + 4);
2513 bfd_put_32 (abfd, pnote->note.type, new + 8);
2514 new += 12;
2515 memcpy (new, pnote->note.namedata, pnote->note.namesz);
2516 if (pnote->note.namesz < pnote->padded_namesz)
2517 memset (new + pnote->note.namesz, 0, pnote->padded_namesz - pnote->note.namesz);
2518 new += pnote->padded_namesz;
2519 if (is_64bit (abfd))
9ef920e9 2520 {
5c49f2cd
NC
2521 bfd_put_64 (abfd, pnote->start, new);
2522 bfd_put_64 (abfd, pnote->end, new + 8);
2523 new += 16;
9ef920e9 2524 }
6f156d7a
NC
2525 else
2526 {
5c49f2cd
NC
2527 bfd_put_32 (abfd, pnote->start, new);
2528 bfd_put_32 (abfd, pnote->end, new + 4);
2529 new += 8;
6f156d7a 2530 }
5c49f2cd 2531
6f156d7a
NC
2532 prev_start = pnote->start;
2533 prev_end = pnote->end;
9ef920e9 2534 }
9ef920e9
NC
2535 }
2536
5c49f2cd 2537 old += note_size;
9ef920e9
NC
2538 }
2539
5c49f2cd
NC
2540#if DEBUG_MERGE
2541 merge_debug ("Results of merge:\n");
2542 for (pnote = pnotes; pnote < pnotes_end; pnote ++)
2543 if (! is_deleted_note (pnote))
2544 merge_debug ("offset %#08lx range %#08lx..%#08lx type %ld attribute %d namesz %ld\n",
2545 (pnote->note.namedata - (char *) contents) - 12,
2546 pnote->start, pnote->end,
2547 pnote->note.type,
2548 pnote->note.namedata[3],
2549 pnote->note.namesz
2550 );
2551#endif
82ef9cad 2552
5c49f2cd 2553 new_size = new - new_contents;
f76d7958
NC
2554 if (new_size < size)
2555 {
2556 memcpy (contents, new_contents, new_size);
2557 size = new_size;
2558 }
5c49f2cd
NC
2559 free (new_contents);
2560
9ef920e9
NC
2561 done:
2562 if (err)
2563 {
2564 bfd_set_error (bfd_error_bad_value);
2565 bfd_nonfatal_message (NULL, abfd, sec, err);
2566 status = 1;
2567 }
2568
2569 free (pnotes);
2570 return size;
2571}
2572
a0dcf297
NC
2573static flagword
2574check_new_section_flags (flagword flags, bfd * abfd, const char * secname)
2575{
2576 /* Only set the SEC_COFF_SHARED flag on COFF files.
2577 The same bit value is used by ELF targets to indicate
2578 compressed sections, and setting that flag here breaks
2579 things. */
2580 if ((flags & SEC_COFF_SHARED)
2581 && bfd_get_flavour (abfd) != bfd_target_coff_flavour)
2582 {
2583 non_fatal (_("%s[%s]: Note - dropping 'share' flag as output format is not COFF"),
2584 bfd_get_filename (abfd), secname);
2585 flags &= ~ SEC_COFF_SHARED;
2586 }
2587 return flags;
2588}
2589
950d48e7 2590/* Copy object file IBFD onto OBFD.
5b8c74e6 2591 Returns TRUE upon success, FALSE otherwise. */
252b5132 2592
950d48e7 2593static bfd_boolean
8b31b6c4 2594copy_object (bfd *ibfd, bfd *obfd, const bfd_arch_info_type *input_arch)
252b5132
RH
2595{
2596 bfd_vma start;
2597 long symcount;
2598 asection **osections = NULL;
9ef920e9 2599 asection *osec;
84e2f313 2600 asection *gnu_debuglink_section = NULL;
252b5132
RH
2601 bfd_size_type *gaps = NULL;
2602 bfd_size_type max_gap = 0;
2603 long symsize;
84e2f313 2604 void *dhandle;
66491ebc
AM
2605 enum bfd_architecture iarch;
2606 unsigned int imach;
9cc89dc0 2607 unsigned int num_sec, i;
252b5132 2608
23719f39
NC
2609 if (ibfd->xvec->byteorder != obfd->xvec->byteorder
2610 && ibfd->xvec->byteorder != BFD_ENDIAN_UNKNOWN
2611 && obfd->xvec->byteorder != BFD_ENDIAN_UNKNOWN)
cfad8730
NC
2612 {
2613 /* PR 17636: Call non-fatal so that we return to our parent who
2614 may need to tidy temporary files. */
75e100a3
AM
2615 non_fatal (_("unable to change endianness of '%s'"),
2616 bfd_get_archive_filename (ibfd));
2617 return FALSE;
2618 }
2619
2620 if (ibfd->read_only)
2621 {
2622 non_fatal (_("unable to modify '%s' due to errors"),
2623 bfd_get_archive_filename (ibfd));
cfad8730
NC
2624 return FALSE;
2625 }
252b5132
RH
2626
2627 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
950d48e7 2628 {
2db6cde7 2629 bfd_nonfatal_message (NULL, obfd, NULL, NULL);
950d48e7
NC
2630 return FALSE;
2631 }
252b5132 2632
5063a421
AM
2633 if (ibfd->sections == NULL)
2634 {
2635 non_fatal (_("error: the input file '%s' has no sections"),
2636 bfd_get_archive_filename (ibfd));
2637 return FALSE;
2638 }
2639
dd68a12b 2640 if (bfd_get_flavour (ibfd) != bfd_target_elf_flavour)
cd6faa73 2641 {
b8871f35
L
2642 if ((do_debug_sections & compress) != 0
2643 && do_debug_sections != compress)
2644 {
2645 non_fatal (_("--compress-debug-sections=[zlib|zlib-gnu|zlib-gabi] is unsupported on `%s'"),
2646 bfd_get_archive_filename (ibfd));
2647 return FALSE;
2648 }
2649
2650 if (do_elf_stt_common)
2651 {
2652 non_fatal (_("--elf-stt-common=[yes|no] is unsupported on `%s'"),
2653 bfd_get_archive_filename (ibfd));
2654 return FALSE;
2655 }
cd6faa73
L
2656 }
2657
252b5132 2658 if (verbose)
77f762d6
L
2659 printf (_("copy from `%s' [%s] to `%s' [%s]\n"),
2660 bfd_get_archive_filename (ibfd), bfd_get_target (ibfd),
252b5132
RH
2661 bfd_get_filename (obfd), bfd_get_target (obfd));
2662
d3e52d40
RS
2663 if (extract_symbol)
2664 start = 0;
252b5132 2665 else
d3e52d40
RS
2666 {
2667 if (set_start_set)
2668 start = set_start;
2669 else
2670 start = bfd_get_start_address (ibfd);
2671 start += change_start;
2672 }
252b5132 2673
0af11b59
KH
2674 /* Neither the start address nor the flags
2675 need to be set for a core file. */
4dd67f29
MS
2676 if (bfd_get_format (obfd) != bfd_core)
2677 {
4087920c
MR
2678 flagword flags;
2679
2680 flags = bfd_get_file_flags (ibfd);
2681 flags |= bfd_flags_to_set;
2682 flags &= ~bfd_flags_to_clear;
2683 flags &= bfd_applicable_file_flags (obfd);
2684
3516e984
L
2685 if (strip_symbols == STRIP_ALL)
2686 flags &= ~HAS_RELOC;
2687
4dd67f29 2688 if (!bfd_set_start_address (obfd, start)
4087920c 2689 || !bfd_set_file_flags (obfd, flags))
950d48e7 2690 {
8d8e0703 2691 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
950d48e7
NC
2692 return FALSE;
2693 }
4dd67f29 2694 }
252b5132 2695
594ef5db 2696 /* Copy architecture of input file to output file. */
66491ebc
AM
2697 iarch = bfd_get_arch (ibfd);
2698 imach = bfd_get_mach (ibfd);
8b31b6c4
NC
2699 if (input_arch)
2700 {
6765ee18 2701 if (iarch == bfd_arch_unknown)
8b31b6c4
NC
2702 {
2703 iarch = input_arch->arch;
2704 imach = input_arch->mach;
2705 }
2706 else
2707 non_fatal (_("Input file `%s' ignores binary architecture parameter."),
2708 bfd_get_archive_filename (ibfd));
2709 }
6765ee18
AM
2710 if (iarch == bfd_arch_unknown
2711 && bfd_get_flavour (ibfd) != bfd_target_elf_flavour
2712 && bfd_get_flavour (obfd) == bfd_target_elf_flavour)
2713 {
2714 const struct elf_backend_data *bed = get_elf_backend_data (obfd);
2715 iarch = bed->arch;
2716 imach = 0;
2717 }
66491ebc 2718 if (!bfd_set_arch_mach (obfd, iarch, imach)
212a3c4d
L
2719 && (ibfd->target_defaulted
2720 || bfd_get_arch (ibfd) != bfd_get_arch (obfd)))
f57a841a
NC
2721 {
2722 if (bfd_get_arch (ibfd) == bfd_arch_unknown)
77f762d6
L
2723 non_fatal (_("Unable to recognise the format of the input file `%s'"),
2724 bfd_get_archive_filename (ibfd));
f57a841a 2725 else
c1e2cb9d 2726 non_fatal (_("Output file cannot represent architecture `%s'"),
77f762d6
L
2727 bfd_printable_arch_mach (bfd_get_arch (ibfd),
2728 bfd_get_mach (ibfd)));
2729 return FALSE;
f57a841a 2730 }
57938635 2731
252b5132 2732 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
950d48e7 2733 {
8d8e0703 2734 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
950d48e7
NC
2735 return FALSE;
2736 }
252b5132 2737
92dd4511
L
2738 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour
2739 && bfd_pei_p (obfd))
2740 {
2741 /* Set up PE parameters. */
2742 pe_data_type *pe = pe_data (obfd);
2743
325c681d 2744 /* Copy PE parameters before changing them. */
dd68a12b 2745 if (bfd_get_flavour (ibfd) == bfd_target_coff_flavour
325c681d
L
2746 && bfd_pei_p (ibfd))
2747 pe->pe_opthdr = pe_data (ibfd)->pe_opthdr;
2748
92dd4511
L
2749 if (pe_file_alignment != (bfd_vma) -1)
2750 pe->pe_opthdr.FileAlignment = pe_file_alignment;
2751 else
2752 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
2753
2754 if (pe_heap_commit != (bfd_vma) -1)
2755 pe->pe_opthdr.SizeOfHeapCommit = pe_heap_commit;
2756
2757 if (pe_heap_reserve != (bfd_vma) -1)
2758 pe->pe_opthdr.SizeOfHeapCommit = pe_heap_reserve;
2759
2760 if (pe_image_base != (bfd_vma) -1)
2761 pe->pe_opthdr.ImageBase = pe_image_base;
2762
2763 if (pe_section_alignment != (bfd_vma) -1)
2764 pe->pe_opthdr.SectionAlignment = pe_section_alignment;
2765 else
2766 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
2767
2768 if (pe_stack_commit != (bfd_vma) -1)
2769 pe->pe_opthdr.SizeOfStackCommit = pe_stack_commit;
2770
2771 if (pe_stack_reserve != (bfd_vma) -1)
2772 pe->pe_opthdr.SizeOfStackCommit = pe_stack_reserve;
2773
2774 if (pe_subsystem != -1)
2775 pe->pe_opthdr.Subsystem = pe_subsystem;
2776
2777 if (pe_major_subsystem_version != -1)
2778 pe->pe_opthdr.MajorSubsystemVersion = pe_major_subsystem_version;
2779
2780 if (pe_minor_subsystem_version != -1)
2781 pe->pe_opthdr.MinorSubsystemVersion = pe_minor_subsystem_version;
2782
2783 if (pe_file_alignment > pe_section_alignment)
2784 {
2785 char file_alignment[20], section_alignment[20];
2786
2787 sprintf_vma (file_alignment, pe_file_alignment);
2788 sprintf_vma (section_alignment, pe_section_alignment);
2789 non_fatal (_("warning: file alignment (0x%s) > section alignment (0x%s)"),
2790
2791 file_alignment, section_alignment);
2792 }
00386881
NC
2793
2794 if (preserve_dates
2795 && bfd_get_flavour (ibfd) == bfd_target_coff_flavour
2796 && bfd_pei_p (ibfd))
2797 pe->timestamp = pe_data (ibfd)->coff.timestamp;
92dd4511
L
2798 }
2799
252b5132 2800 if (isympp)
62d732f5 2801 free (isympp);
57938635 2802
252b5132 2803 if (osympp != isympp)
62d732f5
AM
2804 free (osympp);
2805
2806 isympp = NULL;
2807 osympp = NULL;
252b5132 2808
c39ada54
AM
2809 symsize = bfd_get_symtab_upper_bound (ibfd);
2810 if (symsize < 0)
2811 {
8d8e0703 2812 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
c39ada54
AM
2813 return FALSE;
2814 }
2815
3f5e193b 2816 osympp = isympp = (asymbol **) xmalloc (symsize);
c39ada54
AM
2817 symcount = bfd_canonicalize_symtab (ibfd, isympp);
2818 if (symcount < 0)
2819 {
2db6cde7 2820 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
c39ada54
AM
2821 return FALSE;
2822 }
063bb025
NC
2823 /* PR 17512: file: d6323821
2824 If the symbol table could not be loaded do not pretend that we have
2825 any symbols. This trips us up later on when we load the relocs. */
2826 if (symcount == 0)
2827 {
2828 free (isympp);
2829 osympp = isympp = NULL;
2830 }
c39ada54 2831
252b5132
RH
2832 /* BFD mandates that all output sections be created and sizes set before
2833 any output is done. Thus, we traverse all sections multiple times. */
d3ba0551 2834 bfd_map_over_sections (ibfd, setup_section, obfd);
252b5132 2835
237dcb53
AM
2836 if (!extract_symbol)
2837 setup_bfd_headers (ibfd, obfd);
80fccad2 2838
252b5132
RH
2839 if (add_sections != NULL)
2840 {
2841 struct section_add *padd;
2842 struct section_list *pset;
2843
2844 for (padd = add_sections; padd != NULL; padd = padd->next)
2845 {
2593f09a
NC
2846 flagword flags;
2847
2e62b721
NC
2848 pset = find_section_list (padd->name, FALSE,
2849 SECTION_CONTEXT_SET_FLAGS);
551b43fd 2850 if (pset != NULL)
a0dcf297
NC
2851 {
2852 flags = pset->flags | SEC_HAS_CONTENTS;
2853 flags = check_new_section_flags (flags, obfd, padd->name);
2854 }
2e62b721
NC
2855 else
2856 flags = SEC_HAS_CONTENTS | SEC_READONLY | SEC_DATA;
551b43fd 2857
c8782eee
NC
2858 /* bfd_make_section_with_flags() does not return very helpful
2859 error codes, so check for the most likely user error first. */
2860 if (bfd_get_section_by_name (obfd, padd->name))
252b5132 2861 {
2db6cde7 2862 bfd_nonfatal_message (NULL, obfd, NULL,
f7433f01 2863 _("can't add section '%s'"), padd->name);
950d48e7 2864 return FALSE;
252b5132 2865 }
c8782eee
NC
2866 else
2867 {
0930eddd 2868 /* We use LINKER_CREATED here so that the backend hooks
f7433f01
AM
2869 will create any special section type information,
2870 instead of presuming we know what we're doing merely
2871 because we set the flags. */
0930eddd
NS
2872 padd->section = bfd_make_section_with_flags
2873 (obfd, padd->name, flags | SEC_LINKER_CREATED);
c8782eee
NC
2874 if (padd->section == NULL)
2875 {
2db6cde7
NS
2876 bfd_nonfatal_message (NULL, obfd, NULL,
2877 _("can't create section `%s'"),
2878 padd->name);
c8782eee
NC
2879 return FALSE;
2880 }
2881 }
252b5132 2882
fd361982 2883 if (!bfd_set_section_size (padd->section, padd->size))
950d48e7 2884 {
2db6cde7 2885 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
950d48e7
NC
2886 return FALSE;
2887 }
252b5132 2888
2e62b721
NC
2889 pset = find_section_list (padd->name, FALSE,
2890 SECTION_CONTEXT_SET_VMA | SECTION_CONTEXT_ALTER_VMA);
2891 if (pset != NULL
fd361982 2892 && !bfd_set_section_vma (padd->section, pset->vma_val))
2e62b721
NC
2893 {
2894 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
2895 return FALSE;
2896 }
2897
2898 pset = find_section_list (padd->name, FALSE,
2899 SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_ALTER_LMA);
2593f09a
NC
2900 if (pset != NULL)
2901 {
2e62b721 2902 padd->section->lma = pset->lma_val;
57938635 2903
fd361982
AM
2904 if (!bfd_set_section_alignment
2905 (padd->section, bfd_section_alignment (padd->section)))
2593f09a 2906 {
2e62b721
NC
2907 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
2908 return FALSE;
252b5132
RH
2909 }
2910 }
2911 }
2912 }
2913
acf1419f
AB
2914 if (update_sections != NULL)
2915 {
2916 struct section_add *pupdate;
2917
2918 for (pupdate = update_sections;
2919 pupdate != NULL;
2920 pupdate = pupdate->next)
2921 {
acf1419f
AB
2922 pupdate->section = bfd_get_section_by_name (ibfd, pupdate->name);
2923 if (pupdate->section == NULL)
cfad8730
NC
2924 {
2925 non_fatal (_("error: %s not found, can't be updated"), pupdate->name);
2926 return FALSE;
2927 }
acf1419f
AB
2928
2929 osec = pupdate->section->output_section;
fd361982 2930 if (!bfd_set_section_size (osec, pupdate->size))
acf1419f
AB
2931 {
2932 bfd_nonfatal_message (NULL, obfd, osec, NULL);
2933 return FALSE;
2934 }
2935 }
2936 }
2937
5c49f2cd 2938 merged_note_section * merged_note_sections = NULL;
9ef920e9
NC
2939 if (merge_notes)
2940 {
2941 /* This palaver is necessary because we must set the output
2942 section size first, before its contents are ready. */
5c49f2cd 2943 for (osec = ibfd->sections; osec != NULL; osec = osec->next)
9ef920e9 2944 {
5c49f2cd
NC
2945 if (! is_mergeable_note_section (ibfd, osec))
2946 continue;
2947
ef07b808
NC
2948 /* If the section is going to be completly deleted then
2949 do not bother to merge it. */
2950 if (osec->output_section == NULL)
2951 continue;
2952
5c49f2cd
NC
2953 bfd_size_type size = bfd_section_size (osec);
2954
9ef920e9
NC
2955 if (size == 0)
2956 {
5c49f2cd
NC
2957 bfd_nonfatal_message (NULL, ibfd, osec,
2958 _("warning: note section is empty"));
2959 continue;
9ef920e9 2960 }
5c49f2cd
NC
2961
2962 merged_note_section * merged = xmalloc (sizeof * merged);
2963 merged->contents = NULL;
2964 if (! bfd_get_full_section_contents (ibfd, osec, & merged->contents))
9ef920e9 2965 {
5c49f2cd
NC
2966 bfd_nonfatal_message (NULL, ibfd, osec,
2967 _("warning: could not load note section"));
5c49f2cd
NC
2968 free (merged);
2969 continue;
9ef920e9 2970 }
5c49f2cd
NC
2971
2972 merged->size = merge_gnu_build_notes (ibfd, osec, size,
2973 merged->contents);
5c49f2cd 2974
ef07b808
NC
2975 /* FIXME: Once we have read the contents in, we must write
2976 them out again. So even if the mergeing has achieved
2977 nothing we still add this entry to the merge list. */
2978
2979 if (size != merged->size
2980 && !bfd_set_section_size (osec->output_section, merged->size))
5c49f2cd
NC
2981 {
2982 bfd_nonfatal_message (NULL, obfd, osec,
2983 _("warning: failed to set merged notes size"));
2984 free (merged->contents);
2985 free (merged);
2986 continue;
9ef920e9 2987 }
5c49f2cd
NC
2988
2989 /* Add section to list of merged sections. */
2990 merged->sec = osec;
2991 merged->next = merged_note_sections;
2992 merged_note_sections = merged;
9ef920e9
NC
2993 }
2994 }
2995
bbad633b
NC
2996 if (dump_sections != NULL)
2997 {
2998 struct section_add * pdump;
2999
3000 for (pdump = dump_sections; pdump != NULL; pdump = pdump->next)
3001 {
e052e2ba
FS
3002 FILE * f;
3003 bfd_byte *contents;
3004
9ef920e9
NC
3005 osec = bfd_get_section_by_name (ibfd, pdump->name);
3006 if (osec == NULL)
bbad633b
NC
3007 {
3008 bfd_nonfatal_message (NULL, ibfd, NULL,
3009 _("can't dump section '%s' - it does not exist"),
3010 pdump->name);
3011 continue;
3012 }
3013
fd361982 3014 if ((bfd_section_flags (osec) & SEC_HAS_CONTENTS) == 0)
bbad633b 3015 {
9ef920e9 3016 bfd_nonfatal_message (NULL, ibfd, osec,
bbad633b
NC
3017 _("can't dump section - it has no contents"));
3018 continue;
3019 }
3aade688 3020
fd361982 3021 bfd_size_type size = bfd_section_size (osec);
a68aba2d
AM
3022 /* Note - we allow the dumping of zero-sized sections,
3023 creating an empty file. */
bbad633b 3024
bbad633b
NC
3025 f = fopen (pdump->filename, FOPEN_WB);
3026 if (f == NULL)
3027 {
3028 bfd_nonfatal_message (pdump->filename, NULL, NULL,
3029 _("could not open section dump file"));
3030 continue;
3031 }
3032
bae7501e 3033 if (bfd_malloc_and_get_section (ibfd, osec, &contents))
182a105a 3034 {
a68aba2d 3035 if (size != 0 && fwrite (contents, 1, size, f) != size)
cfad8730
NC
3036 {
3037 non_fatal (_("error writing section contents to %s (error: %s)"),
3038 pdump->filename,
3039 strerror (errno));
bae7501e 3040 free (contents);
3391569f 3041 fclose (f);
cfad8730
NC
3042 return FALSE;
3043 }
182a105a 3044 }
bbad633b 3045 else
9ef920e9 3046 bfd_nonfatal_message (NULL, ibfd, osec,
bbad633b
NC
3047 _("could not retrieve section contents"));
3048
3049 fclose (f);
3050 free (contents);
3051 }
3052 }
3aade688 3053
2593f09a
NC
3054 if (gnu_debuglink_filename != NULL)
3055 {
d99b05a3
NC
3056 /* PR 15125: Give a helpful warning message if
3057 the debuglink section already exists, and
3058 allow the rest of the copy to complete. */
3059 if (bfd_get_section_by_name (obfd, ".gnu_debuglink"))
950d48e7 3060 {
d99b05a3
NC
3061 non_fatal (_("%s: debuglink section already exists"),
3062 bfd_get_filename (obfd));
3063 gnu_debuglink_filename = NULL;
950d48e7 3064 }
d99b05a3 3065 else
6e2c86ac 3066 {
d99b05a3
NC
3067 gnu_debuglink_section = bfd_create_gnu_debuglink_section
3068 (obfd, gnu_debuglink_filename);
3069
3070 if (gnu_debuglink_section == NULL)
3071 {
3072 bfd_nonfatal_message (NULL, obfd, NULL,
3073 _("cannot create debug link section `%s'"),
3074 gnu_debuglink_filename);
3075 return FALSE;
3076 }
6e2c86ac 3077
d99b05a3
NC
3078 /* Special processing for PE format files. We
3079 have no way to distinguish PE from COFF here. */
3080 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour)
3081 {
3082 bfd_vma debuglink_vma;
3083 asection * highest_section;
d99b05a3
NC
3084
3085 /* The PE spec requires that all sections be adjacent and sorted
3086 in ascending order of VMA. It also specifies that debug
3087 sections should be last. This is despite the fact that debug
3088 sections are not loaded into memory and so in theory have no
3089 use for a VMA.
3090
3091 This means that the debuglink section must be given a non-zero
3092 VMA which makes it contiguous with other debug sections. So
3093 walk the current section list, find the section with the
3094 highest VMA and start the debuglink section after that one. */
9ef920e9
NC
3095 for (osec = obfd->sections, highest_section = NULL;
3096 osec != NULL;
3097 osec = osec->next)
3098 if (osec->vma > 0
d99b05a3 3099 && (highest_section == NULL
9ef920e9
NC
3100 || osec->vma > highest_section->vma))
3101 highest_section = osec;
d99b05a3
NC
3102
3103 if (highest_section)
3104 debuglink_vma = BFD_ALIGN (highest_section->vma
3105 + highest_section->size,
3106 /* FIXME: We ought to be using
3107 COFF_PAGE_SIZE here or maybe
fd361982 3108 bfd_section_alignment() (if it
d99b05a3
NC
3109 was set) but since this is for PE
3110 and we know the required alignment
3111 it is easier just to hard code it. */
3112 0x1000);
3113 else
3114 /* Umm, not sure what to do in this case. */
3115 debuglink_vma = 0x1000;
3116
fd361982 3117 bfd_set_section_vma (gnu_debuglink_section, debuglink_vma);
d99b05a3 3118 }
6e2c86ac 3119 }
950d48e7
NC
3120 }
3121
9cc89dc0
AM
3122 num_sec = bfd_count_sections (obfd);
3123 if (num_sec != 0
1aa9ef63 3124 && (gap_fill_set || pad_to_set))
252b5132
RH
3125 {
3126 asection **set;
252b5132
RH
3127
3128 /* We must fill in gaps between the sections and/or we must pad
3129 the last section to a specified address. We do this by
3130 grabbing a list of the sections, sorting them by VMA, and
3131 increasing the section sizes as required to fill the gaps.
3132 We write out the gap contents below. */
3133
9cc89dc0 3134 osections = xmalloc (num_sec * sizeof (*osections));
252b5132 3135 set = osections;
d3ba0551 3136 bfd_map_over_sections (obfd, get_sections, &set);
252b5132 3137
9cc89dc0 3138 qsort (osections, num_sec, sizeof (*osections), compare_section_lma);
252b5132 3139
9cc89dc0
AM
3140 gaps = xmalloc (num_sec * sizeof (*gaps));
3141 memset (gaps, 0, num_sec * sizeof (*gaps));
252b5132
RH
3142
3143 if (gap_fill_set)
3144 {
9cc89dc0 3145 for (i = 0; i < num_sec - 1; i++)
252b5132
RH
3146 {
3147 flagword flags;
eef64366
CE
3148 bfd_size_type size; /* Octets. */
3149 bfd_vma gap_start, gap_stop; /* Octets. */
3150 unsigned int opb1 = bfd_octets_per_byte (obfd, osections[i]);
3151 unsigned int opb2 = bfd_octets_per_byte (obfd, osections[i+1]);
252b5132 3152
fd361982 3153 flags = bfd_section_flags (osections[i]);
252b5132
RH
3154 if ((flags & SEC_HAS_CONTENTS) == 0
3155 || (flags & SEC_LOAD) == 0)
3156 continue;
3157
fd361982 3158 size = bfd_section_size (osections[i]);
eef64366
CE
3159 gap_start = bfd_section_lma (osections[i]) * opb1 + size;
3160 gap_stop = bfd_section_lma (osections[i + 1]) * opb2;
252b5132
RH
3161 if (gap_start < gap_stop)
3162 {
fd361982
AM
3163 if (!bfd_set_section_size (osections[i],
3164 size + (gap_stop - gap_start)))
252b5132 3165 {
2db6cde7
NS
3166 bfd_nonfatal_message (NULL, obfd, osections[i],
3167 _("Can't fill gap after section"));
252b5132
RH
3168 status = 1;
3169 break;
3170 }
3171 gaps[i] = gap_stop - gap_start;
3172 if (max_gap < gap_stop - gap_start)
3173 max_gap = gap_stop - gap_start;
3174 }
3175 }
3176 }
3177
3178 if (pad_to_set)
3179 {
eef64366
CE
3180 bfd_vma lma; /* Octets. */
3181 bfd_size_type size; /* Octets. */
9cc89dc0 3182 unsigned int opb = bfd_octets_per_byte (obfd, osections[num_sec - 1]);
eef64366 3183 bfd_vma _pad_to = pad_to * opb;
252b5132 3184
9cc89dc0
AM
3185 lma = bfd_section_lma (osections[num_sec - 1]) * opb;
3186 size = bfd_section_size (osections[num_sec - 1]);
eef64366 3187 if (lma + size < _pad_to)
252b5132 3188 {
9cc89dc0 3189 if (!bfd_set_section_size (osections[num_sec - 1], _pad_to - lma))
252b5132 3190 {
9cc89dc0 3191 bfd_nonfatal_message (NULL, obfd, osections[num_sec - 1],
2db6cde7 3192 _("can't add padding"));
252b5132
RH
3193 status = 1;
3194 }
3195 else
3196 {
9cc89dc0 3197 gaps[num_sec - 1] = _pad_to - (lma + size);
eef64366
CE
3198 if (max_gap < _pad_to - (lma + size))
3199 max_gap = _pad_to - (lma + size);
252b5132
RH
3200 }
3201 }
3202 }
3203 }
3204
594ef5db
NC
3205 /* Symbol filtering must happen after the output sections
3206 have been created, but before their contents are set. */
252b5132 3207 dhandle = NULL;
252b5132 3208 if (convert_debugging)
b922d590 3209 dhandle = read_debugging_info (ibfd, isympp, symcount, FALSE);
57938635
AM
3210
3211 if (strip_symbols == STRIP_DEBUG
252b5132
RH
3212 || strip_symbols == STRIP_ALL
3213 || strip_symbols == STRIP_UNNEEDED
ed1653a7 3214 || strip_symbols == STRIP_NONDEBUG
96109726
CC
3215 || strip_symbols == STRIP_DWO
3216 || strip_symbols == STRIP_NONDWO
252b5132 3217 || discard_locals != LOCALS_UNDEF
d58c2e3a 3218 || localize_hidden
047c9024
NC
3219 || htab_elements (strip_specific_htab) != 0
3220 || htab_elements (keep_specific_htab) != 0
3221 || htab_elements (localize_specific_htab) != 0
3222 || htab_elements (globalize_specific_htab) != 0
3223 || htab_elements (keepglobal_specific_htab) != 0
3224 || htab_elements (weaken_specific_htab) != 0
0f65a5d8 3225 || htab_elements (redefine_specific_htab) != 0
d7fb0dd2 3226 || prefix_symbols_string
252b5132 3227 || sections_removed
f91ea849 3228 || sections_copied
252b5132
RH
3229 || convert_debugging
3230 || change_leading_char
3231 || remove_leading_char
9cc0123f 3232 || section_rename_list
2b35fb28
RH
3233 || weaken
3234 || add_symbols)
252b5132
RH
3235 {
3236 /* Mark symbols used in output relocations so that they
3237 are kept, even if they are local labels or static symbols.
57938635 3238
252b5132
RH
3239 Note we iterate over the input sections examining their
3240 relocations since the relocations for the output sections
3241 haven't been set yet. mark_symbols_used_in_relocations will
3242 ignore input sections which have no corresponding output
3243 section. */
3244 if (strip_symbols != STRIP_ALL)
f3185997
NC
3245 {
3246 bfd_set_error (bfd_error_no_error);
3247 bfd_map_over_sections (ibfd,
3248 mark_symbols_used_in_relocations,
3249 isympp);
3250 if (bfd_get_error () != bfd_error_no_error)
3251 {
3252 status = 1;
3253 return FALSE;
3254 }
3255 }
3256
2b35fb28 3257 osympp = (asymbol **) xmalloc ((symcount + add_symbols + 1) * sizeof (asymbol *));
252b5132
RH
3258 symcount = filter_symbols (ibfd, obfd, osympp, isympp, symcount);
3259 }
3260
3261 if (convert_debugging && dhandle != NULL)
3262 {
cf0ad5bb
NC
3263 bfd_boolean res;
3264
3265 res = write_debugging_info (obfd, dhandle, &symcount, &osympp);
3266
3267 free (dhandle);
3268 dhandle = NULL; /* Paranoia... */
3269
3270 if (! res)
252b5132
RH
3271 {
3272 status = 1;
950d48e7 3273 return FALSE;
252b5132
RH
3274 }
3275 }
3276
3277 bfd_set_symtab (obfd, osympp, symcount);
3278
c3989150
L
3279 /* This has to happen before section positions are set. */
3280 bfd_map_over_sections (ibfd, copy_relocations_in_section, obfd);
3281
252b5132 3282 /* This has to happen after the symbol table has been set. */
d3ba0551 3283 bfd_map_over_sections (ibfd, copy_section, obfd);
252b5132
RH
3284
3285 if (add_sections != NULL)
3286 {
3287 struct section_add *padd;
3288
3289 for (padd = add_sections; padd != NULL; padd = padd->next)
3290 {
d3ba0551
AM
3291 if (! bfd_set_section_contents (obfd, padd->section, padd->contents,
3292 0, padd->size))
950d48e7 3293 {
2db6cde7 3294 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
950d48e7
NC
3295 return FALSE;
3296 }
252b5132
RH
3297 }
3298 }
3299
acf1419f
AB
3300 if (update_sections != NULL)
3301 {
3302 struct section_add *pupdate;
3303
3304 for (pupdate = update_sections;
f7433f01
AM
3305 pupdate != NULL;
3306 pupdate = pupdate->next)
acf1419f 3307 {
acf1419f
AB
3308 osec = pupdate->section->output_section;
3309 if (! bfd_set_section_contents (obfd, osec, pupdate->contents,
f7433f01 3310 0, pupdate->size))
acf1419f
AB
3311 {
3312 bfd_nonfatal_message (NULL, obfd, osec, NULL);
3313 return FALSE;
3314 }
3315 }
3316 }
3317
5c49f2cd 3318 if (merged_note_sections != NULL)
9ef920e9 3319 {
5c49f2cd
NC
3320 merged_note_section * merged = NULL;
3321
3322 for (osec = obfd->sections; osec != NULL; osec = osec->next)
9ef920e9 3323 {
5c49f2cd
NC
3324 if (! is_mergeable_note_section (obfd, osec))
3325 continue;
3326
3327 if (merged == NULL)
3328 merged = merged_note_sections;
3329
3330 /* It is likely that output sections are in the same order
3331 as the input sections, but do not assume that this is
3332 the case. */
0ec992e6 3333 if (merged->sec->output_section != osec)
5c49f2cd
NC
3334 {
3335 for (merged = merged_note_sections;
3336 merged != NULL;
3337 merged = merged->next)
0ec992e6 3338 if (merged->sec->output_section == osec)
5c49f2cd
NC
3339 break;
3340
3341 if (merged == NULL)
3342 {
3343 bfd_nonfatal_message
3344 (NULL, obfd, osec,
ef07b808 3345 _("error: failed to locate merged notes"));
5c49f2cd
NC
3346 continue;
3347 }
3348 }
3349
ef07b808 3350 if (merged->contents == NULL)
5c49f2cd
NC
3351 {
3352 bfd_nonfatal_message
3353 (NULL, obfd, osec,
ef07b808 3354 _("error: failed to merge notes"));
5c49f2cd
NC
3355 continue;
3356 }
3357
3358 if (! bfd_set_section_contents (obfd, osec, merged->contents, 0,
3359 merged->size))
9ef920e9 3360 {
5c49f2cd
NC
3361 bfd_nonfatal_message
3362 (NULL, obfd, osec,
3363 _("error: failed to copy merged notes into output"));
9ef920e9
NC
3364 return FALSE;
3365 }
5c49f2cd
NC
3366
3367 merged = merged->next;
3368 }
3369
3370 /* Free the memory. */
3371 merged_note_section * next;
3372 for (merged = merged_note_sections; merged != NULL; merged = next)
3373 {
3374 next = merged->next;
3375 free (merged->contents);
3376 free (merged);
9ef920e9 3377 }
9ef920e9 3378 }
5c49f2cd
NC
3379 else if (merge_notes && ! is_strip)
3380 non_fatal (_("%s: Could not find any mergeable note sections"),
3381 bfd_get_filename (ibfd));
9ef920e9 3382
e7c81c25
NC
3383 if (gnu_debuglink_filename != NULL)
3384 {
3385 if (! bfd_fill_in_gnu_debuglink_section
3386 (obfd, gnu_debuglink_section, gnu_debuglink_filename))
950d48e7 3387 {
2db6cde7
NS
3388 bfd_nonfatal_message (NULL, obfd, NULL,
3389 _("cannot fill debug link section `%s'"),
3390 gnu_debuglink_filename);
950d48e7
NC
3391 return FALSE;
3392 }
e7c81c25
NC
3393 }
3394
9cc89dc0 3395 if (gaps != NULL)
252b5132
RH
3396 {
3397 bfd_byte *buf;
252b5132
RH
3398
3399 /* Fill in the gaps. */
252b5132
RH
3400 if (max_gap > 8192)
3401 max_gap = 8192;
3f5e193b 3402 buf = (bfd_byte *) xmalloc (max_gap);
d3ba0551 3403 memset (buf, gap_fill, max_gap);
252b5132 3404
9cc89dc0 3405 for (i = 0; i < num_sec; i++)
252b5132
RH
3406 {
3407 if (gaps[i] != 0)
3408 {
3409 bfd_size_type left;
3410 file_ptr off;
3411
3412 left = gaps[i];
fd361982 3413 off = bfd_section_size (osections[i]) - left;
594ef5db 3414
252b5132
RH
3415 while (left > 0)
3416 {
3417 bfd_size_type now;
3418
3419 if (left > 8192)
3420 now = 8192;
3421 else
3422 now = left;
3423
3424 if (! bfd_set_section_contents (obfd, osections[i], buf,
3425 off, now))
950d48e7 3426 {
2db6cde7 3427 bfd_nonfatal_message (NULL, obfd, osections[i], NULL);
3391569f 3428 free (buf);
950d48e7
NC
3429 return FALSE;
3430 }
252b5132
RH
3431
3432 left -= now;
3433 off += now;
3434 }
3435 }
3436 }
3391569f
NC
3437
3438 free (buf);
3439 free (gaps);
3440 gaps = NULL;
252b5132
RH
3441 }
3442
3443 /* Allow the BFD backend to copy any private data it understands
3444 from the input BFD to the output BFD. This is done last to
3445 permit the routine to look at the filtered symbol table, which is
3446 important for the ECOFF code at least. */
42bb2e33 3447 if (! bfd_copy_private_bfd_data (ibfd, obfd))
252b5132 3448 {
2db6cde7
NS
3449 bfd_nonfatal_message (NULL, obfd, NULL,
3450 _("error copying private BFD data"));
950d48e7 3451 return FALSE;
252b5132 3452 }
1ae8b3d2
AO
3453
3454 /* Switch to the alternate machine code. We have to do this at the
3455 very end, because we only initialize the header when we create
3456 the first section. */
f9d4ad2a
NC
3457 if (use_alt_mach_code != 0)
3458 {
3459 if (! bfd_alt_mach_code (obfd, use_alt_mach_code))
3460 {
3461 non_fatal (_("this target does not support %lu alternative machine codes"),
3462 use_alt_mach_code);
3463 if (bfd_get_flavour (obfd) == bfd_target_elf_flavour)
3464 {
3465 non_fatal (_("treating that number as an absolute e_machine value instead"));
3466 elf_elfheader (obfd)->e_machine = use_alt_mach_code;
3467 }
3468 else
3469 non_fatal (_("ignoring the alternative value"));
3470 }
3471 }
950d48e7
NC
3472
3473 return TRUE;
252b5132
RH
3474}
3475
3476/* Read each archive element in turn from IBFD, copy the
ee873e00
NC
3477 contents to temp file, and keep the temp file handle.
3478 If 'force_output_target' is TRUE then make sure that
3479 all elements in the new archive are of the type
3480 'output_target'. */
252b5132
RH
3481
3482static void
ee873e00 3483copy_archive (bfd *ibfd, bfd *obfd, const char *output_target,
8b31b6c4
NC
3484 bfd_boolean force_output_target,
3485 const bfd_arch_info_type *input_arch)
252b5132
RH
3486{
3487 struct name_list
3488 {
3489 struct name_list *next;
4c168fa3 3490 const char *name;
252b5132
RH
3491 bfd *obfd;
3492 } *list, *l;
3493 bfd **ptr = &obfd->archive_head;
3494 bfd *this_element;
8d8e0703
AM
3495 char *dir;
3496 const char *filename;
252b5132 3497
f5f20315
NC
3498 /* PR 24281: It is not clear what should happen when copying a thin archive.
3499 One part is straight forward - if the output archive is in a different
3500 directory from the input archive then any relative paths in the library
3501 should be adjusted to the new location. But if any transformation
3502 options are active (eg strip, rename, add, etc) then the implication is
3503 that these should be applied to the files pointed to by the archive.
3504 But since objcopy is not destructive, this means that new files must be
3505 created, and there is no guidance for the names of the new files. (Plus
3506 this conflicts with one of the goals of thin libraries - only taking up
3507 a minimal amount of space in the file system).
3508
3509 So for now we fail if an attempt is made to copy such libraries. */
3510 if (ibfd->is_thin_archive)
3511 {
3512 status = 1;
3513 bfd_set_error (bfd_error_invalid_operation);
3514 bfd_nonfatal_message (NULL, ibfd, NULL,
3515 _("sorry: copying thin archives is not currently supported"));
3516 return;
3517 }
3518
252b5132 3519 /* Make a temp directory to hold the contents. */
1ff5d5c4 3520 dir = make_tempdir (bfd_get_filename (obfd));
f9c026a8 3521 if (dir == NULL)
f7433f01 3522 fatal (_("cannot create tempdir for archive copying (error: %s)"),
f9c026a8 3523 strerror (errno));
84e2f313 3524
2e30cb57
CC
3525 if (strip_symbols == STRIP_ALL)
3526 obfd->has_armap = FALSE;
3527 else
3528 obfd->has_armap = ibfd->has_armap;
a8da6403 3529 obfd->is_thin_archive = ibfd->is_thin_archive;
252b5132 3530
2e30cb57
CC
3531 if (deterministic)
3532 obfd->flags |= BFD_DETERMINISTIC_OUTPUT;
3533
252b5132
RH
3534 list = NULL;
3535
3536 this_element = bfd_openr_next_archived_file (ibfd, NULL);
594ef5db 3537
b667df2e 3538 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
8d8e0703
AM
3539 {
3540 status = 1;
3541 bfd_nonfatal_message (NULL, obfd, NULL, NULL);
cfad8730 3542 goto cleanup_and_exit;
8d8e0703 3543 }
b667df2e 3544
d3ba0551 3545 while (!status && this_element != NULL)
252b5132 3546 {
4c168fa3
AM
3547 char *output_name;
3548 bfd *output_bfd;
252b5132 3549 bfd *last_element;
8066d1a2
AS
3550 struct stat buf;
3551 int stat_status = 0;
3f5e193b 3552 bfd_boolean del = TRUE;
19094d10 3553 bfd_boolean ok_object;
8066d1a2 3554
dd9b91de
NC
3555 /* PR binutils/17533: Do not allow directory traversal
3556 outside of the current directory tree by archive members. */
3557 if (! is_valid_archive_path (bfd_get_filename (this_element)))
5e186ece
NC
3558 {
3559 non_fatal (_("illegal pathname found in archive member: %s"),
3560 bfd_get_filename (this_element));
3561 status = 1;
3562 goto cleanup_and_exit;
3563 }
dd9b91de 3564
4c168fa3
AM
3565 /* Create an output file for this member. */
3566 output_name = concat (dir, "/",
3567 bfd_get_filename (this_element), (char *) 0);
3568
3569 /* If the file already exists, make another temp dir. */
3570 if (stat (output_name, &buf) >= 0)
3571 {
1d97232a
NC
3572 char * tmpdir = make_tempdir (output_name);
3573
3574 free (output_name);
3575 if (tmpdir == NULL)
5e186ece
NC
3576 {
3577 non_fatal (_("cannot create tempdir for archive copying (error: %s)"),
3578 strerror (errno));
3579 status = 1;
3580 goto cleanup_and_exit;
3581 }
84e2f313 3582
3f5e193b 3583 l = (struct name_list *) xmalloc (sizeof (struct name_list));
1d97232a 3584 l->name = tmpdir;
4c168fa3
AM
3585 l->next = list;
3586 l->obfd = NULL;
3587 list = l;
1d97232a 3588 output_name = concat (tmpdir, "/",
4c168fa3
AM
3589 bfd_get_filename (this_element), (char *) 0);
3590 }
3591
8066d1a2
AS
3592 if (preserve_dates)
3593 {
3594 stat_status = bfd_stat_arch_elt (this_element, &buf);
594ef5db 3595
8066d1a2
AS
3596 if (stat_status != 0)
3597 non_fatal (_("internal stat error on %s"),
3598 bfd_get_filename (this_element));
3599 }
252b5132 3600
3f5e193b 3601 l = (struct name_list *) xmalloc (sizeof (struct name_list));
252b5132
RH
3602 l->name = output_name;
3603 l->next = list;
bee59fd2 3604 l->obfd = NULL;
252b5132
RH
3605 list = l;
3606
19094d10
AM
3607 ok_object = bfd_check_format (this_element, bfd_object);
3608 if (!ok_object)
3609 bfd_nonfatal_message (NULL, this_element, NULL,
3610 _("Unable to recognise the format of file"));
3611
3612 /* PR binutils/3110: Cope with archives
3613 containing multiple target types. */
3614 if (force_output_target || !ok_object)
3615 output_bfd = bfd_openw (output_name, output_target);
3616 else
3617 output_bfd = bfd_openw (output_name, bfd_get_target (this_element));
3618
3619 if (output_bfd == NULL)
77f762d6 3620 {
19094d10
AM
3621 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
3622 status = 1;
5e186ece 3623 goto cleanup_and_exit;
19094d10
AM
3624 }
3625
3626 if (ok_object)
3627 {
3628 del = !copy_object (this_element, output_bfd, input_arch);
ee873e00 3629
19094d10
AM
3630 if (del && bfd_get_arch (this_element) == bfd_arch_unknown)
3631 /* Try again as an unknown object file. */
3632 ok_object = FALSE;
3633 else if (!bfd_close (output_bfd))
2db6cde7
NS
3634 {
3635 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
19094d10 3636 /* Error in new object file. Don't change archive. */
2db6cde7 3637 status = 1;
77f762d6 3638 }
77f762d6 3639 }
77f762d6 3640
19094d10
AM
3641 if (!ok_object)
3642 {
3f5e193b 3643 del = !copy_unknown_object (this_element, output_bfd);
77f762d6
L
3644 if (!bfd_close_all_done (output_bfd))
3645 {
8d8e0703 3646 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
77f762d6
L
3647 /* Error in new object file. Don't change archive. */
3648 status = 1;
3649 }
252b5132
RH
3650 }
3651
3f5e193b 3652 if (del)
950d48e7
NC
3653 {
3654 unlink (output_name);
3655 status = 1;
3656 }
3657 else
3658 {
3659 if (preserve_dates && stat_status == 0)
3660 set_times (output_name, &buf);
8066d1a2 3661
950d48e7
NC
3662 /* Open the newly output file and attach to our list. */
3663 output_bfd = bfd_openr (output_name, output_target);
252b5132 3664
950d48e7 3665 l->obfd = output_bfd;
252b5132 3666
950d48e7 3667 *ptr = output_bfd;
cc481421 3668 ptr = &output_bfd->archive_next;
252b5132 3669
950d48e7 3670 last_element = this_element;
252b5132 3671
950d48e7 3672 this_element = bfd_openr_next_archived_file (ibfd, last_element);
252b5132 3673
950d48e7
NC
3674 bfd_close (last_element);
3675 }
252b5132 3676 }
d3ba0551 3677 *ptr = NULL;
252b5132 3678
8d8e0703 3679 filename = bfd_get_filename (obfd);
252b5132 3680 if (!bfd_close (obfd))
8d8e0703
AM
3681 {
3682 status = 1;
3683 bfd_nonfatal_message (filename, NULL, NULL, NULL);
8d8e0703 3684 }
252b5132 3685
8d8e0703 3686 filename = bfd_get_filename (ibfd);
252b5132 3687 if (!bfd_close (ibfd))
8d8e0703
AM
3688 {
3689 status = 1;
3690 bfd_nonfatal_message (filename, NULL, NULL, NULL);
8d8e0703 3691 }
252b5132 3692
5e186ece 3693 cleanup_and_exit:
252b5132 3694 /* Delete all the files that we opened. */
1d97232a
NC
3695 {
3696 struct name_list * next;
3697
3698 for (l = list; l != NULL; l = next)
3699 {
3700 if (l->obfd == NULL)
3701 rmdir (l->name);
3702 else
3703 {
3704 bfd_close (l->obfd);
3705 unlink (l->name);
3706 }
3707 next = l->next;
3708 free (l);
3709 }
3710 }
cfad8730 3711
252b5132
RH
3712 rmdir (dir);
3713}
3714
0408dee6
DK
3715static void
3716set_long_section_mode (bfd *output_bfd, bfd *input_bfd, enum long_section_name_handling style)
3717{
3718 /* This is only relevant to Coff targets. */
3719 if (bfd_get_flavour (output_bfd) == bfd_target_coff_flavour)
3720 {
78e82dc3
AM
3721 if (style == KEEP
3722 && bfd_get_flavour (input_bfd) == bfd_target_coff_flavour)
0408dee6
DK
3723 style = bfd_coff_long_section_names (input_bfd) ? ENABLE : DISABLE;
3724 bfd_coff_set_long_section_names (output_bfd, style != DISABLE);
3725 }
3726}
3727
252b5132
RH
3728/* The top-level control. */
3729
3730static void
365f5fb6 3731copy_file (const char *input_filename, const char *output_filename, int ofd,
8b31b6c4
NC
3732 const char *input_target, const char *output_target,
3733 const bfd_arch_info_type *input_arch)
252b5132
RH
3734{
3735 bfd *ibfd;
49c12576
AM
3736 char **obj_matching;
3737 char **core_matching;
52a476ee 3738 off_t size = get_file_size (input_filename);
252b5132 3739
52a476ee 3740 if (size < 1)
f24ddbdd 3741 {
52a476ee
L
3742 if (size == 0)
3743 non_fatal (_("error: the input file '%s' is empty"),
3744 input_filename);
f24ddbdd
NC
3745 status = 1;
3746 return;
3747 }
3748
252b5132
RH
3749 /* To allow us to do "strip *" without dying on the first
3750 non-object file, failures are nonfatal. */
252b5132
RH
3751 ibfd = bfd_openr (input_filename, input_target);
3752 if (ibfd == NULL)
2db6cde7
NS
3753 {
3754 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
3755 status = 1;
3756 return;
3757 }
252b5132 3758
4a114e3e
L
3759 switch (do_debug_sections)
3760 {
3761 case compress:
151411f8
L
3762 case compress_zlib:
3763 case compress_gnu_zlib:
3764 case compress_gabi_zlib:
4a114e3e 3765 ibfd->flags |= BFD_COMPRESS;
cd6faa73
L
3766 /* Don't check if input is ELF here since this information is
3767 only available after bfd_check_format_matches is called. */
19a7fe52 3768 if (do_debug_sections != compress_gnu_zlib)
cd6faa73 3769 ibfd->flags |= BFD_COMPRESS_GABI;
4a114e3e
L
3770 break;
3771 case decompress:
3772 ibfd->flags |= BFD_DECOMPRESS;
3773 break;
3774 default:
3775 break;
3776 }
3777
b8871f35
L
3778 switch (do_elf_stt_common)
3779 {
3780 case elf_stt_common:
3781 ibfd->flags |= BFD_CONVERT_ELF_COMMON | BFD_USE_ELF_STT_COMMON;
3782 break;
3783 break;
3784 case no_elf_stt_common:
3785 ibfd->flags |= BFD_CONVERT_ELF_COMMON;
3786 break;
3787 default:
3788 break;
3789 }
3790
252b5132
RH
3791 if (bfd_check_format (ibfd, bfd_archive))
3792 {
ee873e00 3793 bfd_boolean force_output_target;
252b5132
RH
3794 bfd *obfd;
3795
3796 /* bfd_get_target does not return the correct value until
f7433f01 3797 bfd_check_format succeeds. */
252b5132 3798 if (output_target == NULL)
ee873e00
NC
3799 {
3800 output_target = bfd_get_target (ibfd);
3801 force_output_target = FALSE;
3802 }
3803 else
3804 force_output_target = TRUE;
252b5132 3805
365f5fb6
SP
3806 if (ofd >= 0)
3807 obfd = bfd_fdopenw (output_filename, output_target, ofd);
3808 else
3809 obfd = bfd_openw (output_filename, output_target);
3810
252b5132 3811 if (obfd == NULL)
2db6cde7 3812 {
365f5fb6 3813 close (ofd);
2db6cde7
NS
3814 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
3815 status = 1;
3816 return;
3817 }
f2032b67
AM
3818
3819 if (gnu_debuglink_filename != NULL)
3820 {
3821 non_fatal (_("--add-gnu-debuglink ignored for archive %s"),
3822 bfd_get_filename (ibfd));
3823 gnu_debuglink_filename = NULL;
3824 }
3825
0408dee6
DK
3826 /* This is a no-op on non-Coff targets. */
3827 set_long_section_mode (obfd, ibfd, long_section_names);
252b5132 3828
8b31b6c4 3829 copy_archive (ibfd, obfd, output_target, force_output_target, input_arch);
252b5132 3830 }
49c12576 3831 else if (bfd_check_format_matches (ibfd, bfd_object, &obj_matching))
252b5132
RH
3832 {
3833 bfd *obfd;
49c12576 3834 do_copy:
950d48e7 3835
252b5132 3836 /* bfd_get_target does not return the correct value until
f7433f01 3837 bfd_check_format succeeds. */
252b5132
RH
3838 if (output_target == NULL)
3839 output_target = bfd_get_target (ibfd);
3840
365f5fb6
SP
3841 if (ofd >= 0)
3842 obfd = bfd_fdopenw (output_filename, output_target, ofd);
3843 else
3844 obfd = bfd_openw (output_filename, output_target);
3845
252b5132 3846 if (obfd == NULL)
2db6cde7 3847 {
365f5fb6 3848 close (ofd);
2db6cde7
NS
3849 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
3850 status = 1;
3851 return;
3852 }
365f5fb6 3853
0408dee6
DK
3854 /* This is a no-op on non-Coff targets. */
3855 set_long_section_mode (obfd, ibfd, long_section_names);
252b5132 3856
8b31b6c4 3857 if (! copy_object (ibfd, obfd, input_arch))
a580b8e0 3858 status = 1;
252b5132 3859
063bb025
NC
3860 /* PR 17512: file: 0f15796a.
3861 If the file could not be copied it may not be in a writeable
3862 state. So use bfd_close_all_done to avoid the possibility of
3863 writing uninitialised data into the file. */
3864 if (! (status ? bfd_close_all_done (obfd) : bfd_close (obfd)))
8d8e0703
AM
3865 {
3866 status = 1;
3867 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
3868 return;
3869 }
252b5132
RH
3870
3871 if (!bfd_close (ibfd))
8d8e0703
AM
3872 {
3873 status = 1;
3874 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
3875 return;
3876 }
252b5132
RH
3877 }
3878 else
3879 {
49c12576
AM
3880 bfd_error_type obj_error = bfd_get_error ();
3881 bfd_error_type core_error;
b34976b6 3882
49c12576
AM
3883 if (bfd_check_format_matches (ibfd, bfd_core, &core_matching))
3884 {
3885 /* This probably can't happen.. */
3886 if (obj_error == bfd_error_file_ambiguously_recognized)
3887 free (obj_matching);
3888 goto do_copy;
3889 }
3890
3891 core_error = bfd_get_error ();
3892 /* Report the object error in preference to the core error. */
3893 if (obj_error != core_error)
3894 bfd_set_error (obj_error);
3895
2db6cde7 3896 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
57938635 3897
49c12576
AM
3898 if (obj_error == bfd_error_file_ambiguously_recognized)
3899 {
3900 list_matching_formats (obj_matching);
3901 free (obj_matching);
3902 }
3903 if (core_error == bfd_error_file_ambiguously_recognized)
252b5132 3904 {
49c12576
AM
3905 list_matching_formats (core_matching);
3906 free (core_matching);
252b5132 3907 }
57938635 3908
252b5132
RH
3909 status = 1;
3910 }
3911}
3912
594ef5db
NC
3913/* Add a name to the section renaming list. */
3914
3915static void
84e2f313
NC
3916add_section_rename (const char * old_name, const char * new_name,
3917 flagword flags)
594ef5db 3918{
91d6fa6a 3919 section_rename * srename;
594ef5db
NC
3920
3921 /* Check for conflicts first. */
91d6fa6a
NC
3922 for (srename = section_rename_list; srename != NULL; srename = srename->next)
3923 if (strcmp (srename->old_name, old_name) == 0)
594ef5db
NC
3924 {
3925 /* Silently ignore duplicate definitions. */
91d6fa6a
NC
3926 if (strcmp (srename->new_name, new_name) == 0
3927 && srename->flags == flags)
594ef5db 3928 return;
0af11b59 3929
594ef5db
NC
3930 fatal (_("Multiple renames of section %s"), old_name);
3931 }
3932
91d6fa6a 3933 srename = (section_rename *) xmalloc (sizeof (* srename));
594ef5db 3934
91d6fa6a
NC
3935 srename->old_name = old_name;
3936 srename->new_name = new_name;
3937 srename->flags = flags;
3938 srename->next = section_rename_list;
0af11b59 3939
91d6fa6a 3940 section_rename_list = srename;
594ef5db
NC
3941}
3942
3943/* Check the section rename list for a new name of the input section
9cc0123f
AM
3944 called OLD_NAME. Returns the new name if one is found and sets
3945 RETURNED_FLAGS if non-NULL to the flags to be used for this section. */
594ef5db
NC
3946
3947static const char *
9cc0123f 3948find_section_rename (const char *old_name, flagword *returned_flags)
594ef5db 3949{
9cc0123f 3950 const section_rename *srename;
594ef5db 3951
91d6fa6a
NC
3952 for (srename = section_rename_list; srename != NULL; srename = srename->next)
3953 if (strcmp (srename->old_name, old_name) == 0)
594ef5db 3954 {
9cc0123f
AM
3955 if (returned_flags != NULL && srename->flags != (flagword) -1)
3956 *returned_flags = srename->flags;
594ef5db 3957
91d6fa6a 3958 return srename->new_name;
594ef5db
NC
3959 }
3960
3961 return old_name;
3962}
3963
80fccad2
BW
3964/* Once each of the sections is copied, we may still need to do some
3965 finalization work for private section headers. Do that here. */
3966
3967static void
3968setup_bfd_headers (bfd *ibfd, bfd *obfd)
3969{
80fccad2
BW
3970 /* Allow the BFD backend to copy any private data it understands
3971 from the input section to the output section. */
3972 if (! bfd_copy_private_header_data (ibfd, obfd))
3973 {
2db6cde7
NS
3974 status = 1;
3975 bfd_nonfatal_message (NULL, ibfd, NULL,
8d8e0703 3976 _("error in private header data"));
2db6cde7 3977 return;
80fccad2
BW
3978 }
3979
3980 /* All went well. */
3981 return;
80fccad2
BW
3982}
3983
594ef5db
NC
3984/* Create a section in OBFD with the same
3985 name and attributes as ISECTION in IBFD. */
252b5132
RH
3986
3987static void
84e2f313 3988setup_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
252b5132 3989{
3f5e193b 3990 bfd *obfd = (bfd *) obfdarg;
252b5132
RH
3991 struct section_list *p;
3992 sec_ptr osection;
3993 bfd_size_type size;
3994 bfd_vma vma;
3995 bfd_vma lma;
3996 flagword flags;
1a89cc7d 3997 const char *err;
594ef5db 3998 const char * name;
a0dcf297 3999 const char * new_name;
d7fb0dd2 4000 char *prefix = NULL;
66125551 4001 bfd_boolean make_nobits;
fa463e9f 4002 unsigned int alignment;
0af11b59 4003
2593f09a 4004 if (is_strip_section (ibfd, isection))
252b5132
RH
4005 return;
4006
594ef5db 4007 /* Get the, possibly new, name of the output section. */
fd361982
AM
4008 name = bfd_section_name (isection);
4009 flags = bfd_section_flags (isection);
dd68a12b
AM
4010 if (bfd_get_flavour (ibfd) != bfd_get_flavour (obfd))
4011 {
4012 flags &= bfd_applicable_section_flags (ibfd);
4013 flags &= bfd_applicable_section_flags (obfd);
4014 }
a0dcf297
NC
4015 new_name = find_section_rename (name, &flags);
4016 if (new_name != name)
4017 {
4018 name = new_name;
4019 flags = check_new_section_flags (flags, obfd, name);
4020 }
0af11b59 4021
d7fb0dd2 4022 /* Prefix sections. */
dd68a12b
AM
4023 if (prefix_alloc_sections_string
4024 && (bfd_section_flags (isection) & SEC_ALLOC) != 0)
d7fb0dd2
NC
4025 prefix = prefix_alloc_sections_string;
4026 else if (prefix_sections_string)
4027 prefix = prefix_sections_string;
4028
4029 if (prefix)
4030 {
4031 char *n;
4032
3f5e193b 4033 n = (char *) xmalloc (strlen (prefix) + strlen (name) + 1);
d7fb0dd2
NC
4034 strcpy (n, prefix);
4035 strcat (n, name);
4036 name = n;
4037 }
66491ebc 4038
66125551 4039 make_nobits = FALSE;
2e62b721 4040
fd361982 4041 p = find_section_list (bfd_section_name (isection), FALSE,
2e62b721
NC
4042 SECTION_CONTEXT_SET_FLAGS);
4043 if (p != NULL)
a0dcf297
NC
4044 {
4045 flags = p->flags | (flags & (SEC_HAS_CONTENTS | SEC_RELOC));
4046 flags = check_new_section_flags (flags, obfd, bfd_section_name (isection));
4047 }
42bb2e33 4048 else if (strip_symbols == STRIP_NONDEBUG
6c67a030 4049 && (flags & (SEC_ALLOC | SEC_GROUP)) != 0
f7433f01 4050 && !is_nondebug_keep_contents_section (ibfd, isection))
66125551 4051 {
6c67a030 4052 flags &= ~(SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP);
dd68a12b 4053 if (bfd_get_flavour (obfd) == bfd_target_elf_flavour)
66125551
AM
4054 {
4055 make_nobits = TRUE;
4056
4057 /* Twiddle the input section flags so that it seems to
4058 elf.c:copy_private_bfd_data that section flags have not
4059 changed between input and output sections. This hack
4060 prevents wholesale rewriting of the program headers. */
6c67a030 4061 isection->flags &= ~(SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP);
66125551
AM
4062 }
4063 }
551b43fd
AM
4064
4065 osection = bfd_make_section_anyway_with_flags (obfd, name, flags);
57938635 4066
252b5132
RH
4067 if (osection == NULL)
4068 {
2db6cde7 4069 err = _("failed to create output section");
252b5132
RH
4070 goto loser;
4071 }
4072
66125551 4073 if (make_nobits)
551b43fd
AM
4074 elf_section_type (osection) = SHT_NOBITS;
4075
fd361982 4076 size = bfd_section_size (isection);
88988473 4077 size = bfd_convert_section_size (ibfd, isection, obfd, size);
252b5132 4078 if (copy_byte >= 0)
b7dd81f7 4079 size = (size + interleave - 1) / interleave * copy_width;
d3e52d40
RS
4080 else if (extract_symbol)
4081 size = 0;
fd361982 4082 if (!bfd_set_section_size (osection, size))
252b5132 4083 {
2db6cde7 4084 err = _("failed to set size");
252b5132
RH
4085 goto loser;
4086 }
57938635 4087
fd361982
AM
4088 vma = bfd_section_vma (isection);
4089 p = find_section_list (bfd_section_name (isection), FALSE,
2e62b721
NC
4090 SECTION_CONTEXT_ALTER_VMA | SECTION_CONTEXT_SET_VMA);
4091 if (p != NULL)
4092 {
4093 if (p->context & SECTION_CONTEXT_SET_VMA)
4094 vma = p->vma_val;
4095 else
4096 vma += p->vma_val;
4097 }
252b5132
RH
4098 else
4099 vma += change_section_address;
57938635 4100
fd361982 4101 if (!bfd_set_section_vma (osection, vma))
252b5132 4102 {
2db6cde7 4103 err = _("failed to set vma");
252b5132
RH
4104 goto loser;
4105 }
4106
4107 lma = isection->lma;
fd361982 4108 p = find_section_list (bfd_section_name (isection), FALSE,
2e62b721
NC
4109 SECTION_CONTEXT_ALTER_LMA | SECTION_CONTEXT_SET_LMA);
4110 if (p != NULL)
252b5132 4111 {
2e62b721 4112 if (p->context & SECTION_CONTEXT_ALTER_LMA)
252b5132 4113 lma += p->lma_val;
252b5132 4114 else
2e62b721 4115 lma = p->lma_val;
252b5132
RH
4116 }
4117 else
4118 lma += change_section_address;
57938635 4119
237dcb53 4120 osection->lma = lma;
252b5132 4121
fd361982 4122 p = find_section_list (bfd_section_name (isection), FALSE,
fa463e9f
N
4123 SECTION_CONTEXT_SET_ALIGNMENT);
4124 if (p != NULL)
4125 alignment = p->alignment;
4126 else
fd361982 4127 alignment = bfd_section_alignment (isection);
82ef9cad 4128
252b5132
RH
4129 /* FIXME: This is probably not enough. If we change the LMA we
4130 may have to recompute the header for the file as well. */
fd361982 4131 if (!bfd_set_section_alignment (osection, alignment))
252b5132 4132 {
2db6cde7 4133 err = _("failed to set alignment");
252b5132
RH
4134 goto loser;
4135 }
4136
bc408b8a
JJ
4137 /* Copy merge entity size. */
4138 osection->entsize = isection->entsize;
4139
f6fe1ccd
L
4140 /* Copy compress status. */
4141 osection->compress_status = isection->compress_status;
4142
252b5132
RH
4143 /* This used to be mangle_section; we do here to avoid using
4144 bfd_get_section_by_name since some formats allow multiple
4145 sections with the same name. */
4146 isection->output_section = osection;
237dcb53 4147 isection->output_offset = 0;
d3e52d40 4148
119f4245
AM
4149 if ((isection->flags & SEC_GROUP) != 0)
4150 {
4151 asymbol *gsym = group_signature (isection);
4152
4153 if (gsym != NULL)
4154 {
4155 gsym->flags |= BSF_KEEP;
dd68a12b 4156 if (bfd_get_flavour (ibfd) == bfd_target_elf_flavour)
119f4245
AM
4157 elf_group_id (isection) = gsym;
4158 }
4159 }
4160
252b5132
RH
4161 /* Allow the BFD backend to copy any private data it understands
4162 from the input section to the output section. */
42bb2e33 4163 if (!bfd_copy_private_section_data (ibfd, isection, obfd, osection))
252b5132 4164 {
2db6cde7 4165 err = _("failed to copy private data");
252b5132
RH
4166 goto loser;
4167 }
4168
594ef5db 4169 /* All went well. */
252b5132
RH
4170 return;
4171
f7433f01 4172 loser:
252b5132 4173 status = 1;
2db6cde7 4174 bfd_nonfatal_message (NULL, obfd, osection, err);
252b5132
RH
4175}
4176
c3989150 4177/* Return TRUE if input section ISECTION should be skipped. */
252b5132 4178
c3989150 4179static bfd_boolean
9ef920e9 4180skip_section (bfd *ibfd, sec_ptr isection, bfd_boolean skip_copy)
252b5132 4181{
252b5132
RH
4182 sec_ptr osection;
4183 bfd_size_type size;
dc156bc0 4184 flagword flags;
252b5132 4185
594ef5db
NC
4186 /* If we have already failed earlier on,
4187 do not keep on generating complaints now. */
252b5132 4188 if (status != 0)
c3989150
L
4189 return TRUE;
4190
4191 if (extract_symbol)
4192 return TRUE;
57938635 4193
2593f09a 4194 if (is_strip_section (ibfd, isection))
c3989150 4195 return TRUE;
252b5132 4196
acf1419f
AB
4197 if (is_update_section (ibfd, isection))
4198 return TRUE;
4199
9ef920e9
NC
4200 /* When merging a note section we skip the copying of the contents,
4201 but not the copying of the relocs associated with the contents. */
5c49f2cd 4202 if (skip_copy && is_mergeable_note_section (ibfd, isection))
9ef920e9
NC
4203 return TRUE;
4204
fd361982 4205 flags = bfd_section_flags (isection);
dc156bc0 4206 if ((flags & SEC_GROUP) != 0)
c3989150 4207 return TRUE;
dc156bc0 4208
252b5132 4209 osection = isection->output_section;
fd361982 4210 size = bfd_section_size (isection);
252b5132
RH
4211
4212 if (size == 0 || osection == 0)
c3989150 4213 return TRUE;
252b5132 4214
c3989150
L
4215 return FALSE;
4216}
4217
d3e5f6c8
AB
4218/* Add section SECTION_PATTERN to the list of sections that will have their
4219 relocations removed. */
4220
4221static void
4222handle_remove_relocations_option (const char *section_pattern)
4223{
4224 find_section_list (section_pattern, TRUE, SECTION_CONTEXT_REMOVE_RELOCS);
4225}
4226
4227/* Return TRUE if ISECTION from IBFD should have its relocations removed,
4228 otherwise return FALSE. If the user has requested that relocations be
4229 removed from a section that does not have relocations then this
4230 function will still return TRUE. */
4231
4232static bfd_boolean
4233discard_relocations (bfd *ibfd ATTRIBUTE_UNUSED, asection *isection)
4234{
fd361982 4235 return (find_section_list (bfd_section_name (isection), FALSE,
d3e5f6c8
AB
4236 SECTION_CONTEXT_REMOVE_RELOCS) != NULL);
4237}
4238
4239/* Wrapper for dealing with --remove-section (-R) command line arguments.
4240 A special case is detected here, if the user asks to remove a relocation
c12d9fa2 4241 section (one starting with ".rela" or ".rel") then this removal must
f9853190 4242 be done using a different technique in a relocatable object. */
d3e5f6c8
AB
4243
4244static void
4245handle_remove_section_option (const char *section_pattern)
4246{
f9853190 4247 find_section_list (section_pattern, TRUE, SECTION_CONTEXT_REMOVE);
c12d9fa2
AM
4248 if (strncmp (section_pattern, ".rel", 4) == 0)
4249 {
4250 section_pattern += 4;
4251 if (*section_pattern == 'a')
4252 section_pattern++;
4253 if (*section_pattern)
4254 handle_remove_relocations_option (section_pattern);
4255 }
f9853190 4256 sections_removed = TRUE;
d3e5f6c8
AB
4257}
4258
c3989150
L
4259/* Copy relocations in input section ISECTION of IBFD to an output
4260 section with the same name in OBFDARG. If stripping then don't
4261 copy any relocation info. */
4262
4263static void
4264copy_relocations_in_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
4265{
4266 bfd *obfd = (bfd *) obfdarg;
4267 long relsize;
4268 arelent **relpp;
4269 long relcount;
4270 sec_ptr osection;
4271
9ef920e9 4272 if (skip_section (ibfd, isection, FALSE))
237dcb53
AM
4273 return;
4274
c3989150 4275 osection = isection->output_section;
2593f09a 4276
96109726 4277 /* Core files and DWO files do not need to be relocated. */
d3e5f6c8
AB
4278 if (bfd_get_format (obfd) == bfd_core
4279 || strip_symbols == STRIP_NONDWO
4280 || discard_relocations (ibfd, isection))
4dd67f29
MS
4281 relsize = 0;
4282 else
ed570f48
NC
4283 {
4284 relsize = bfd_get_reloc_upper_bound (ibfd, isection);
4dd67f29 4285
ed570f48
NC
4286 if (relsize < 0)
4287 {
4288 /* Do not complain if the target does not support relocations. */
4289 if (relsize == -1 && bfd_get_error () == bfd_error_invalid_operation)
4290 relsize = 0;
4291 else
2db6cde7
NS
4292 {
4293 status = 1;
4294 bfd_nonfatal_message (NULL, ibfd, isection, NULL);
4295 return;
4296 }
ed570f48
NC
4297 }
4298 }
57938635 4299
252b5132 4300 if (relsize == 0)
96109726
CC
4301 {
4302 bfd_set_reloc (obfd, osection, NULL, 0);
4303 osection->flags &= ~SEC_RELOC;
4304 }
252b5132
RH
4305 else
4306 {
2d054e6b 4307 if (isection->orelocation != NULL)
2db6cde7 4308 {
2d054e6b
NC
4309 /* Some other function has already set up the output relocs
4310 for us, so scan those instead of the default relocs. */
4311 relcount = isection->reloc_count;
4312 relpp = isection->orelocation;
4313 }
4314 else
4315 {
4316 relpp = (arelent **) xmalloc (relsize);
4317 relcount = bfd_canonicalize_reloc (ibfd, isection, relpp, isympp);
4318 if (relcount < 0)
4319 {
4320 status = 1;
4321 bfd_nonfatal_message (NULL, ibfd, isection,
4322 _("relocation count is negative"));
4a322448 4323 free (relpp);
2d054e6b
NC
4324 return;
4325 }
2db6cde7 4326 }
57938635 4327
252b5132
RH
4328 if (strip_symbols == STRIP_ALL)
4329 {
4330 /* Remove relocations which are not in
0af11b59 4331 keep_strip_specific_list. */
252b5132
RH
4332 arelent **temp_relpp;
4333 long temp_relcount = 0;
4334 long i;
57938635 4335
3f5e193b 4336 temp_relpp = (arelent **) xmalloc (relsize);
252b5132 4337 for (i = 0; i < relcount; i++)
86eafac0
NC
4338 {
4339 /* PR 17512: file: 9e907e0c. */
f507bebf
NC
4340 if (relpp[i]->sym_ptr_ptr
4341 /* PR 20096 */
4342 && * relpp[i]->sym_ptr_ptr)
86eafac0
NC
4343 if (is_specified_symbol (bfd_asymbol_name (*relpp[i]->sym_ptr_ptr),
4344 keep_specific_htab))
4345 temp_relpp [temp_relcount++] = relpp [i];
4346 }
252b5132 4347 relcount = temp_relcount;
4a322448 4348 if (relpp != isection->orelocation)
2d054e6b 4349 free (relpp);
252b5132
RH
4350 relpp = temp_relpp;
4351 }
e0c60db2 4352
d3ba0551 4353 bfd_set_reloc (obfd, osection, relcount == 0 ? NULL : relpp, relcount);
f0312d39 4354 if (relcount == 0)
c3989150
L
4355 {
4356 osection->flags &= ~SEC_RELOC;
4a322448
AM
4357 if (relpp != isection->orelocation)
4358 free (relpp);
c3989150 4359 }
252b5132 4360 }
c3989150
L
4361}
4362
4363/* Copy the data of input section ISECTION of IBFD
4364 to an output section with the same name in OBFD. */
4365
4366static void
4367copy_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
4368{
4369 bfd *obfd = (bfd *) obfdarg;
4370 struct section_list *p;
4371 sec_ptr osection;
4372 bfd_size_type size;
4373
9ef920e9 4374 if (skip_section (ibfd, isection, TRUE))
c3989150
L
4375 return;
4376
4377 osection = isection->output_section;
88988473 4378 /* The output SHF_COMPRESSED section size is different from input if
cbd44e24
L
4379 ELF classes of input and output aren't the same. We can't use
4380 the output section size since --interleave will shrink the output
4381 section. Size will be updated if the section is converted. */
fd361982 4382 size = bfd_section_size (isection);
c3989150 4383
fd361982
AM
4384 if (bfd_section_flags (isection) & SEC_HAS_CONTENTS
4385 && bfd_section_flags (osection) & SEC_HAS_CONTENTS)
252b5132 4386 {
4a114e3e 4387 bfd_byte *memhunk = NULL;
252b5132 4388
88988473
L
4389 if (!bfd_get_full_section_contents (ibfd, isection, &memhunk)
4390 || !bfd_convert_section_contents (ibfd, isection, obfd,
cbd44e24 4391 &memhunk, &size))
2db6cde7
NS
4392 {
4393 status = 1;
4394 bfd_nonfatal_message (NULL, ibfd, isection, NULL);
848ac659 4395 free (memhunk);
2db6cde7
NS
4396 return;
4397 }
252b5132 4398
9e48b4c6
NC
4399 if (reverse_bytes)
4400 {
4401 /* We don't handle leftover bytes (too many possible behaviors,
4402 and we don't know what the user wants). The section length
4403 must be a multiple of the number of bytes to swap. */
4404 if ((size % reverse_bytes) == 0)
4405 {
4406 unsigned long i, j;
4407 bfd_byte b;
4408
4409 for (i = 0; i < size; i += reverse_bytes)
4410 for (j = 0; j < (unsigned long)(reverse_bytes / 2); j++)
4411 {
4412 bfd_byte *m = (bfd_byte *) memhunk;
4413
4414 b = m[i + j];
4415 m[i + j] = m[(i + reverse_bytes) - (j + 1)];
4416 m[(i + reverse_bytes) - (j + 1)] = b;
4417 }
4418 }
4419 else
4420 /* User must pad the section up in order to do this. */
4421 fatal (_("cannot reverse bytes: length of section %s must be evenly divisible by %d"),
fd361982 4422 bfd_section_name (isection), reverse_bytes);
9e48b4c6
NC
4423 }
4424
57938635 4425 if (copy_byte >= 0)
5e675b72
AM
4426 {
4427 /* Keep only every `copy_byte'th byte in MEMHUNK. */
2f01ffbf 4428 char *from = (char *) memhunk + copy_byte;
3f5e193b 4429 char *to = (char *) memhunk;
2f01ffbf 4430 char *end = (char *) memhunk + size;
b7dd81f7 4431 int i;
5e675b72 4432
1c9c7ce0
JW
4433 /* If the section address is not exactly divisible by the interleave,
4434 then we must bias the from address. If the copy_byte is less than
4435 the bias, then we must skip forward one interleave, and increment
4436 the final lma. */
4437 int extra = isection->lma % interleave;
4438 from -= extra;
4439 if (copy_byte < extra)
4440 from += interleave;
4441
5e675b72 4442 for (; from < end; from += interleave)
b7dd81f7 4443 for (i = 0; i < copy_width; i++)
ee7da987
L
4444 {
4445 if (&from[i] >= end)
4446 break;
4447 *to++ = from[i];
4448 }
5e675b72 4449
b7dd81f7 4450 size = (size + interleave - 1 - copy_byte) / interleave * copy_width;
5e675b72 4451 osection->lma /= interleave;
1c9c7ce0
JW
4452 if (copy_byte < extra)
4453 osection->lma++;
5e675b72 4454 }
252b5132 4455
d3ba0551 4456 if (!bfd_set_section_contents (obfd, osection, memhunk, 0, size))
2db6cde7
NS
4457 {
4458 status = 1;
4459 bfd_nonfatal_message (NULL, obfd, osection, NULL);
848ac659 4460 free (memhunk);
2db6cde7
NS
4461 return;
4462 }
252b5132
RH
4463 free (memhunk);
4464 }
fd361982 4465 else if ((p = find_section_list (bfd_section_name (isection),
2e62b721
NC
4466 FALSE, SECTION_CONTEXT_SET_FLAGS)) != NULL
4467 && (p->flags & SEC_HAS_CONTENTS) != 0)
252b5132 4468 {
d3ba0551 4469 void *memhunk = xmalloc (size);
252b5132
RH
4470
4471 /* We don't permit the user to turn off the SEC_HAS_CONTENTS
4472 flag--they can just remove the section entirely and add it
4473 back again. However, we do permit them to turn on the
4474 SEC_HAS_CONTENTS flag, and take it to mean that the section
4475 contents should be zeroed out. */
4476
4477 memset (memhunk, 0, size);
d3ba0551 4478 if (! bfd_set_section_contents (obfd, osection, memhunk, 0, size))
2db6cde7
NS
4479 {
4480 status = 1;
4481 bfd_nonfatal_message (NULL, obfd, osection, NULL);
848ac659 4482 free (memhunk);
2db6cde7
NS
4483 return;
4484 }
252b5132
RH
4485 free (memhunk);
4486 }
4487}
4488
4489/* Get all the sections. This is used when --gap-fill or --pad-to is
4490 used. */
4491
4492static void
84e2f313 4493get_sections (bfd *obfd ATTRIBUTE_UNUSED, asection *osection, void *secppparg)
252b5132 4494{
3f5e193b 4495 asection ***secppp = (asection ***) secppparg;
252b5132
RH
4496
4497 **secppp = osection;
4498 ++(*secppp);
4499}
4500
6ce9ba7a 4501/* Sort sections by LMA. This is called via qsort, and is used when
252b5132
RH
4502 --gap-fill or --pad-to is used. We force non loadable or empty
4503 sections to the front, where they are easier to ignore. */
4504
4505static int
84e2f313 4506compare_section_lma (const void *arg1, const void *arg2)
252b5132 4507{
6ce9ba7a
AM
4508 const asection *sec1 = *(const asection **) arg1;
4509 const asection *sec2 = *(const asection **) arg2;
252b5132
RH
4510 flagword flags1, flags2;
4511
4512 /* Sort non loadable sections to the front. */
6ce9ba7a
AM
4513 flags1 = sec1->flags;
4514 flags2 = sec2->flags;
252b5132
RH
4515 if ((flags1 & SEC_HAS_CONTENTS) == 0
4516 || (flags1 & SEC_LOAD) == 0)
4517 {
4518 if ((flags2 & SEC_HAS_CONTENTS) != 0
4519 && (flags2 & SEC_LOAD) != 0)
4520 return -1;
4521 }
4522 else
4523 {
4524 if ((flags2 & SEC_HAS_CONTENTS) == 0
4525 || (flags2 & SEC_LOAD) == 0)
4526 return 1;
4527 }
4528
4529 /* Sort sections by LMA. */
6ce9ba7a 4530 if (sec1->lma > sec2->lma)
252b5132 4531 return 1;
6ce9ba7a 4532 if (sec1->lma < sec2->lma)
252b5132
RH
4533 return -1;
4534
4535 /* Sort sections with the same LMA by size. */
6ce9ba7a 4536 if (bfd_section_size (sec1) > bfd_section_size (sec2))
252b5132 4537 return 1;
6ce9ba7a 4538 if (bfd_section_size (sec1) < bfd_section_size (sec2))
252b5132
RH
4539 return -1;
4540
6ce9ba7a
AM
4541 if (sec1->id > sec2->id)
4542 return 1;
4543 if (sec1->id < sec2->id)
4544 return -1;
252b5132
RH
4545 return 0;
4546}
4547
4548/* Mark all the symbols which will be used in output relocations with
4549 the BSF_KEEP flag so that those symbols will not be stripped.
4550
4551 Ignore relocations which will not appear in the output file. */
4552
4553static void
84e2f313 4554mark_symbols_used_in_relocations (bfd *ibfd, sec_ptr isection, void *symbolsarg)
252b5132 4555{
3f5e193b 4556 asymbol **symbols = (asymbol **) symbolsarg;
252b5132
RH
4557 long relsize;
4558 arelent **relpp;
4559 long relcount, i;
4560
4561 /* Ignore an input section with no corresponding output section. */
4562 if (isection->output_section == NULL)
4563 return;
4564
4565 relsize = bfd_get_reloc_upper_bound (ibfd, isection);
4566 if (relsize < 0)
ed570f48
NC
4567 {
4568 /* Do not complain if the target does not support relocations. */
4569 if (relsize == -1 && bfd_get_error () == bfd_error_invalid_operation)
4570 return;
4571 bfd_fatal (bfd_get_filename (ibfd));
4572 }
252b5132
RH
4573
4574 if (relsize == 0)
4575 return;
4576
3f5e193b 4577 relpp = (arelent **) xmalloc (relsize);
252b5132
RH
4578 relcount = bfd_canonicalize_reloc (ibfd, isection, relpp, symbols);
4579 if (relcount < 0)
4580 bfd_fatal (bfd_get_filename (ibfd));
4581
ec5d57d5
NC
4582 /* Examine each symbol used in a relocation. If it's not one of the
4583 special bfd section symbols, then mark it with BSF_KEEP. */
252b5132
RH
4584 for (i = 0; i < relcount; i++)
4585 {
8b929e42 4586 /* See PRs 20923 and 20930 for reproducers for the NULL tests. */
88add6d8 4587 if (relpp[i]->sym_ptr_ptr != NULL
8b929e42 4588 && * relpp[i]->sym_ptr_ptr != NULL
88add6d8 4589 && *relpp[i]->sym_ptr_ptr != bfd_com_section_ptr->symbol
ec5d57d5
NC
4590 && *relpp[i]->sym_ptr_ptr != bfd_abs_section_ptr->symbol
4591 && *relpp[i]->sym_ptr_ptr != bfd_und_section_ptr->symbol)
4592 (*relpp[i]->sym_ptr_ptr)->flags |= BSF_KEEP;
252b5132
RH
4593 }
4594
4595 if (relpp != NULL)
4596 free (relpp);
4597}
4598
4599/* Write out debugging information. */
4600
b34976b6 4601static bfd_boolean
84e2f313
NC
4602write_debugging_info (bfd *obfd, void *dhandle,
4603 long *symcountp ATTRIBUTE_UNUSED,
4604 asymbol ***symppp ATTRIBUTE_UNUSED)
252b5132 4605{
252b5132
RH
4606 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour
4607 || bfd_get_flavour (obfd) == bfd_target_elf_flavour)
4608 {
1d97232a 4609 bfd_byte *syms, *strings = NULL;
252b5132
RH
4610 bfd_size_type symsize, stringsize;
4611 asection *stabsec, *stabstrsec;
551b43fd 4612 flagword flags;
252b5132
RH
4613
4614 if (! write_stabs_in_sections_debugging_info (obfd, dhandle, &syms,
4615 &symsize, &strings,
4616 &stringsize))
b34976b6 4617 return FALSE;
252b5132 4618
551b43fd
AM
4619 flags = SEC_HAS_CONTENTS | SEC_READONLY | SEC_DEBUGGING;
4620 stabsec = bfd_make_section_with_flags (obfd, ".stab", flags);
4621 stabstrsec = bfd_make_section_with_flags (obfd, ".stabstr", flags);
252b5132
RH
4622 if (stabsec == NULL
4623 || stabstrsec == NULL
fd361982
AM
4624 || !bfd_set_section_size (stabsec, symsize)
4625 || !bfd_set_section_size (stabstrsec, stringsize)
4626 || !bfd_set_section_alignment (stabsec, 2)
4627 || !bfd_set_section_alignment (stabstrsec, 0))
252b5132 4628 {
2db6cde7
NS
4629 bfd_nonfatal_message (NULL, obfd, NULL,
4630 _("can't create debugging section"));
1d97232a 4631 free (strings);
b34976b6 4632 return FALSE;
252b5132
RH
4633 }
4634
4635 /* We can get away with setting the section contents now because
f7433f01
AM
4636 the next thing the caller is going to do is copy over the
4637 real sections. We may someday have to split the contents
4638 setting out of this function. */
d3ba0551
AM
4639 if (! bfd_set_section_contents (obfd, stabsec, syms, 0, symsize)
4640 || ! bfd_set_section_contents (obfd, stabstrsec, strings, 0,
4641 stringsize))
252b5132 4642 {
2db6cde7
NS
4643 bfd_nonfatal_message (NULL, obfd, NULL,
4644 _("can't set debugging section contents"));
1d97232a 4645 free (strings);
b34976b6 4646 return FALSE;
252b5132
RH
4647 }
4648
b34976b6 4649 return TRUE;
252b5132
RH
4650 }
4651
2db6cde7
NS
4652 bfd_nonfatal_message (NULL, obfd, NULL,
4653 _("don't know how to write debugging information for %s"),
f7433f01 4654 bfd_get_target (obfd));
b34976b6 4655 return FALSE;
252b5132
RH
4656}
4657
955d0b3b
RM
4658/* If neither -D nor -U was specified explicitly,
4659 then use the configured default. */
4660static void
4661default_deterministic (void)
4662{
4663 if (deterministic < 0)
4664 deterministic = DEFAULT_AR_DETERMINISTIC;
4665}
4666
252b5132 4667static int
84e2f313 4668strip_main (int argc, char *argv[])
252b5132 4669{
7c29036b
NC
4670 char *input_target = NULL;
4671 char *output_target = NULL;
b34976b6 4672 bfd_boolean show_version = FALSE;
7c29036b
NC
4673 bfd_boolean formats_info = FALSE;
4674 int c;
4675 int i;
252b5132 4676 char *output_file = NULL;
1b8dd643 4677 bfd_boolean merge_notes_set = FALSE;
1d15e434 4678
ea8fae9f 4679 while ((c = getopt_long (argc, argv, "I:O:F:K:MN:R:o:sSpdgxXHhVvwDU",
252b5132
RH
4680 strip_options, (int *) 0)) != EOF)
4681 {
4682 switch (c)
4683 {
4684 case 'I':
4685 input_target = optarg;
4686 break;
4687 case 'O':
4688 output_target = optarg;
4689 break;
4690 case 'F':
4691 input_target = output_target = optarg;
4692 break;
4693 case 'R':
d3e5f6c8
AB
4694 handle_remove_section_option (optarg);
4695 break;
64f52b3e
FS
4696 case OPTION_KEEP_SECTION:
4697 find_section_list (optarg, TRUE, SECTION_CONTEXT_KEEP);
4698 break;
d3e5f6c8
AB
4699 case OPTION_REMOVE_RELOCS:
4700 handle_remove_relocations_option (optarg);
252b5132
RH
4701 break;
4702 case 's':
4703 strip_symbols = STRIP_ALL;
4704 break;
4705 case 'S':
4706 case 'g':
db4f6831 4707 case 'd': /* Historic BSD alias for -g. Used by early NetBSD. */
252b5132
RH
4708 strip_symbols = STRIP_DEBUG;
4709 break;
96109726
CC
4710 case OPTION_STRIP_DWO:
4711 strip_symbols = STRIP_DWO;
4712 break;
252b5132
RH
4713 case OPTION_STRIP_UNNEEDED:
4714 strip_symbols = STRIP_UNNEEDED;
4715 break;
4716 case 'K':
047c9024 4717 add_specific_symbol (optarg, keep_specific_htab);
252b5132 4718 break;
1d15e434
NC
4719 case 'M':
4720 merge_notes = TRUE;
1b8dd643 4721 merge_notes_set = TRUE;
1d15e434
NC
4722 break;
4723 case OPTION_NO_MERGE_NOTES:
4724 merge_notes = FALSE;
1b8dd643 4725 merge_notes_set = TRUE;
1d15e434 4726 break;
252b5132 4727 case 'N':
047c9024 4728 add_specific_symbol (optarg, strip_specific_htab);
252b5132
RH
4729 break;
4730 case 'o':
4731 output_file = optarg;
4732 break;
4733 case 'p':
b34976b6 4734 preserve_dates = TRUE;
252b5132 4735 break;
2e30cb57
CC
4736 case 'D':
4737 deterministic = TRUE;
4738 break;
955d0b3b
RM
4739 case 'U':
4740 deterministic = FALSE;
4741 break;
252b5132
RH
4742 case 'x':
4743 discard_locals = LOCALS_ALL;
4744 break;
4745 case 'X':
4746 discard_locals = LOCALS_START_L;
4747 break;
4748 case 'v':
b34976b6 4749 verbose = TRUE;
252b5132
RH
4750 break;
4751 case 'V':
b34976b6 4752 show_version = TRUE;
252b5132 4753 break;
7c29036b
NC
4754 case OPTION_FORMATS_INFO:
4755 formats_info = TRUE;
4756 break;
ed1653a7
NC
4757 case OPTION_ONLY_KEEP_DEBUG:
4758 strip_symbols = STRIP_NONDEBUG;
4759 break;
1637cd90
JB
4760 case OPTION_KEEP_FILE_SYMBOLS:
4761 keep_file_symbols = 1;
4762 break;
252b5132 4763 case 0:
594ef5db
NC
4764 /* We've been given a long option. */
4765 break;
5fe11841
NC
4766 case 'w':
4767 wildcard = TRUE;
4768 break;
8b53311e 4769 case 'H':
252b5132
RH
4770 case 'h':
4771 strip_usage (stdout, 0);
4772 default:
4773 strip_usage (stderr, 1);
4774 }
4775 }
4776
1b8dd643
NC
4777 /* If the user has not expressly chosen to merge/not-merge ELF notes
4778 then enable the merging unless we are stripping debug or dwo info. */
4779 if (! merge_notes_set
4780 && (strip_symbols == STRIP_UNDEF
4781 || strip_symbols == STRIP_ALL
4782 || strip_symbols == STRIP_UNNEEDED
4783 || strip_symbols == STRIP_NONDEBUG
4784 || strip_symbols == STRIP_NONDWO))
4785 merge_notes = TRUE;
4786
84e2f313
NC
4787 if (formats_info)
4788 {
4789 display_info ();
4790 return 0;
4791 }
c1c0eb9e 4792
252b5132
RH
4793 if (show_version)
4794 print_version ("strip");
4795
955d0b3b
RM
4796 default_deterministic ();
4797
252b5132
RH
4798 /* Default is to strip all symbols. */
4799 if (strip_symbols == STRIP_UNDEF
4800 && discard_locals == LOCALS_UNDEF
047c9024 4801 && htab_elements (strip_specific_htab) == 0)
252b5132
RH
4802 strip_symbols = STRIP_ALL;
4803
d3ba0551 4804 if (output_target == NULL)
252b5132
RH
4805 output_target = input_target;
4806
4807 i = optind;
4808 if (i == argc
4809 || (output_file != NULL && (i + 1) < argc))
4810 strip_usage (stderr, 1);
4811
4812 for (; i < argc; i++)
4813 {
4814 int hold_status = status;
4815 struct stat statbuf;
4816 char *tmpname;
365f5fb6 4817 int tmpfd = -1;
252b5132 4818
f24ddbdd 4819 if (get_file_size (argv[i]) < 1)
d68c385b
NC
4820 {
4821 status = 1;
4822 continue;
4823 }
f24ddbdd 4824
252b5132 4825 if (preserve_dates)
f24ddbdd
NC
4826 /* No need to check the return value of stat().
4827 It has already been checked in get_file_size(). */
4828 stat (argv[i], &statbuf);
252b5132 4829
8b6efd89
KT
4830 if (output_file == NULL
4831 || filename_cmp (argv[i], output_file) == 0)
365f5fb6 4832 tmpname = make_tempname (argv[i], &tmpfd);
12f498a7
NS
4833 else
4834 tmpname = output_file;
252b5132 4835
f9c026a8
NC
4836 if (tmpname == NULL)
4837 {
2db6cde7
NS
4838 bfd_nonfatal_message (argv[i], NULL, NULL,
4839 _("could not create temporary file to hold stripped copy"));
f9c026a8
NC
4840 status = 1;
4841 continue;
4842 }
4843
d68c385b 4844 status = 0;
365f5fb6 4845 copy_file (argv[i], tmpname, tmpfd, input_target, output_target, NULL);
252b5132
RH
4846 if (status == 0)
4847 {
4848 if (preserve_dates)
4849 set_times (tmpname, &statbuf);
12f498a7 4850 if (output_file != tmpname)
92fac5ec
L
4851 status = (smart_rename (tmpname,
4852 output_file ? output_file : argv[i],
4853 preserve_dates) != 0);
4854 if (status == 0)
4855 status = hold_status;
252b5132
RH
4856 }
4857 else
bb14f524 4858 unlink_if_ordinary (tmpname);
12f498a7 4859 if (output_file != tmpname)
252b5132
RH
4860 free (tmpname);
4861 }
4862
d68c385b 4863 return status;
252b5132
RH
4864}
4865
92dd4511
L
4866/* Set up PE subsystem. */
4867
4868static void
4869set_pe_subsystem (const char *s)
4870{
4871 const char *version, *subsystem;
4872 size_t i;
4873 static const struct
4874 {
4875 const char *name;
4876 const char set_def;
4877 const short value;
4878 }
4879 v[] =
4880 {
955d0b3b 4881 { "native", 0, IMAGE_SUBSYSTEM_NATIVE },
92dd4511
L
4882 { "windows", 0, IMAGE_SUBSYSTEM_WINDOWS_GUI },
4883 { "console", 0, IMAGE_SUBSYSTEM_WINDOWS_CUI },
4884 { "posix", 0, IMAGE_SUBSYSTEM_POSIX_CUI },
4885 { "wince", 0, IMAGE_SUBSYSTEM_WINDOWS_CE_GUI },
4886 { "efi-app", 1, IMAGE_SUBSYSTEM_EFI_APPLICATION },
4887 { "efi-bsd", 1, IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER },
4888 { "efi-rtd", 1, IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER },
d9118602 4889 { "sal-rtd", 1, IMAGE_SUBSYSTEM_SAL_RUNTIME_DRIVER },
92dd4511
L
4890 { "xbox", 0, IMAGE_SUBSYSTEM_XBOX }
4891 };
4892 short value;
4893 char *copy;
4894 int set_def = -1;
4895
4896 /* Check for the presence of a version number. */
4897 version = strchr (s, ':');
4898 if (version == NULL)
4899 subsystem = s;
4900 else
4901 {
4902 int len = version - s;
4903 copy = xstrdup (s);
4904 subsystem = copy;
4905 copy[len] = '\0';
4906 version = copy + 1 + len;
4907 pe_major_subsystem_version = strtoul (version, &copy, 0);
4908 if (*copy == '.')
4909 pe_minor_subsystem_version = strtoul (copy + 1, &copy, 0);
4910 if (*copy != '\0')
4911 non_fatal (_("%s: bad version in PE subsystem"), s);
4912 }
4913
4914 /* Check for numeric subsystem. */
4915 value = (short) strtol (subsystem, &copy, 0);
4916 if (*copy == '\0')
4917 {
4918 for (i = 0; i < ARRAY_SIZE (v); i++)
4919 if (v[i].value == value)
4920 {
4921 pe_subsystem = value;
4922 set_def = v[i].set_def;
4923 break;
4924 }
4925 }
4926 else
4927 {
4928 /* Search for subsystem by name. */
4929 for (i = 0; i < ARRAY_SIZE (v); i++)
4930 if (strcmp (subsystem, v[i].name) == 0)
4931 {
4932 pe_subsystem = v[i].value;
4933 set_def = v[i].set_def;
4934 break;
4935 }
4936 }
4937
4938 switch (set_def)
4939 {
4940 case -1:
4941 fatal (_("unknown PE subsystem: %s"), s);
4942 break;
4943 case 0:
4944 break;
4945 default:
4946 if (pe_file_alignment == (bfd_vma) -1)
4947 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
4948 if (pe_section_alignment == (bfd_vma) -1)
4949 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
4950 break;
4951 }
0cbf3531
MS
4952 if (s != subsystem)
4953 free ((char *) subsystem);
92dd4511
L
4954}
4955
4956/* Convert EFI target to PEI target. */
4957
4958static void
4959convert_efi_target (char *efi)
4960{
4961 efi[0] = 'p';
4962 efi[1] = 'e';
4963 efi[2] = 'i';
4964
4965 if (strcmp (efi + 4, "ia32") == 0)
4966 {
4967 /* Change ia32 to i386. */
4968 efi[5]= '3';
4969 efi[6]= '8';
4970 efi[7]= '6';
4971 }
4972 else if (strcmp (efi + 4, "x86_64") == 0)
4973 {
4974 /* Change x86_64 to x86-64. */
4975 efi[7] = '-';
4976 }
4977}
4978
7173b38a 4979/* Allocate and return a pointer to a struct section_add, initializing the
06b73f41 4980 structure using ARG, a string in the format "sectionname=filename".
7173b38a
AB
4981 The returned structure will have its next pointer set to NEXT. The
4982 OPTION field is the name of the command line option currently being
4983 parsed, and is only used if an error needs to be reported. */
4984
4985static struct section_add *
06b73f41 4986init_section_add (const char *arg,
f7433f01
AM
4987 struct section_add *next,
4988 const char *option)
7173b38a
AB
4989{
4990 struct section_add *pa;
4991 const char *s;
4992
06b73f41 4993 s = strchr (arg, '=');
7173b38a
AB
4994 if (s == NULL)
4995 fatal (_("bad format for %s"), option);
4996
4997 pa = (struct section_add *) xmalloc (sizeof (struct section_add));
06b73f41 4998 pa->name = xstrndup (arg, s - arg);
7173b38a
AB
4999 pa->filename = s + 1;
5000 pa->next = next;
5001 pa->contents = NULL;
5002 pa->size = 0;
5003
5004 return pa;
5005}
5006
5007/* Load the file specified in PA, allocating memory to hold the file
5008 contents, and store a pointer to the allocated memory in the contents
5009 field of PA. The size field of PA is also updated. All errors call
5010 FATAL. */
5011
5012static void
5013section_add_load_file (struct section_add *pa)
5014{
5015 size_t off, alloc;
5016 FILE *f;
5017
5018 /* We don't use get_file_size so that we can do
5019 --add-section .note.GNU_stack=/dev/null
5020 get_file_size doesn't work on /dev/null. */
5021
5022 f = fopen (pa->filename, FOPEN_RB);
5023 if (f == NULL)
5024 fatal (_("cannot open: %s: %s"),
f7433f01 5025 pa->filename, strerror (errno));
7173b38a
AB
5026
5027 off = 0;
5028 alloc = 4096;
5029 pa->contents = (bfd_byte *) xmalloc (alloc);
5030 while (!feof (f))
5031 {
5032 off_t got;
5033
5034 if (off == alloc)
f7433f01
AM
5035 {
5036 alloc <<= 1;
5037 pa->contents = (bfd_byte *) xrealloc (pa->contents, alloc);
5038 }
7173b38a
AB
5039
5040 got = fread (pa->contents + off, 1, alloc - off, f);
5041 if (ferror (f))
f7433f01 5042 fatal (_("%s: fread failed"), pa->filename);
7173b38a
AB
5043
5044 off += got;
5045 }
5046
5047 pa->size = off;
5048
5049 fclose (f);
5050}
5051
252b5132 5052static int
84e2f313 5053copy_main (int argc, char *argv[])
252b5132 5054{
7c29036b
NC
5055 char *input_filename = NULL;
5056 char *output_filename = NULL;
c1c0eb9e 5057 char *tmpname;
7c29036b
NC
5058 char *input_target = NULL;
5059 char *output_target = NULL;
b34976b6
AM
5060 bfd_boolean show_version = FALSE;
5061 bfd_boolean change_warn = TRUE;
7c29036b 5062 bfd_boolean formats_info = FALSE;
de564eb5
NC
5063 bfd_boolean use_globalize = FALSE;
5064 bfd_boolean use_keep_global = FALSE;
365f5fb6 5065 int c, tmpfd = -1;
252b5132 5066 struct stat statbuf;
8b31b6c4 5067 const bfd_arch_info_type *input_arch = NULL;
252b5132 5068
9ef920e9 5069 while ((c = getopt_long (argc, argv, "b:B:i:I:j:K:MN:s:O:d:F:L:G:R:SpgxXHhVvW:wDU",
252b5132
RH
5070 copy_options, (int *) 0)) != EOF)
5071 {
5072 switch (c)
5073 {
5074 case 'b':
5075 copy_byte = atoi (optarg);
5076 if (copy_byte < 0)
5077 fatal (_("byte number must be non-negative"));
5078 break;
57938635 5079
0af11b59 5080 case 'B':
8b31b6c4
NC
5081 input_arch = bfd_scan_arch (optarg);
5082 if (input_arch == NULL)
5083 fatal (_("architecture %s unknown"), optarg);
0af11b59 5084 break;
43a0748c 5085
252b5132 5086 case 'i':
b7dd81f7
NC
5087 if (optarg)
5088 {
5089 interleave = atoi (optarg);
5090 if (interleave < 1)
5091 fatal (_("interleave must be positive"));
5092 }
5093 else
5094 interleave = 4;
5095 break;
5096
5097 case OPTION_INTERLEAVE_WIDTH:
5098 copy_width = atoi (optarg);
5099 if (copy_width < 1)
5100 fatal(_("interleave width must be positive"));
252b5132 5101 break;
57938635 5102
252b5132
RH
5103 case 'I':
5104 case 's': /* "source" - 'I' is preferred */
5105 input_target = optarg;
5106 break;
57938635 5107
252b5132
RH
5108 case 'O':
5109 case 'd': /* "destination" - 'O' is preferred */
5110 output_target = optarg;
5111 break;
57938635 5112
252b5132
RH
5113 case 'F':
5114 input_target = output_target = optarg;
5115 break;
57938635 5116
f91ea849 5117 case 'j':
2e62b721 5118 find_section_list (optarg, TRUE, SECTION_CONTEXT_COPY);
b34976b6 5119 sections_copied = TRUE;
f91ea849 5120 break;
57938635 5121
252b5132 5122 case 'R':
d3e5f6c8
AB
5123 handle_remove_section_option (optarg);
5124 break;
5125
64f52b3e
FS
5126 case OPTION_KEEP_SECTION:
5127 find_section_list (optarg, TRUE, SECTION_CONTEXT_KEEP);
5128 break;
5129
d3e5f6c8
AB
5130 case OPTION_REMOVE_RELOCS:
5131 handle_remove_relocations_option (optarg);
252b5132 5132 break;
57938635 5133
252b5132
RH
5134 case 'S':
5135 strip_symbols = STRIP_ALL;
5136 break;
57938635 5137
252b5132
RH
5138 case 'g':
5139 strip_symbols = STRIP_DEBUG;
5140 break;
57938635 5141
96109726
CC
5142 case OPTION_STRIP_DWO:
5143 strip_symbols = STRIP_DWO;
5144 break;
5145
252b5132
RH
5146 case OPTION_STRIP_UNNEEDED:
5147 strip_symbols = STRIP_UNNEEDED;
5148 break;
57938635 5149
ed1653a7
NC
5150 case OPTION_ONLY_KEEP_DEBUG:
5151 strip_symbols = STRIP_NONDEBUG;
5152 break;
5153
1637cd90
JB
5154 case OPTION_KEEP_FILE_SYMBOLS:
5155 keep_file_symbols = 1;
5156 break;
5157
2593f09a 5158 case OPTION_ADD_GNU_DEBUGLINK:
9b8bf321 5159 long_section_names = ENABLE ;
2593f09a
NC
5160 gnu_debuglink_filename = optarg;
5161 break;
5162
252b5132 5163 case 'K':
047c9024 5164 add_specific_symbol (optarg, keep_specific_htab);
252b5132 5165 break;
57938635 5166
9ef920e9
NC
5167 case 'M':
5168 merge_notes = TRUE;
5169 break;
1d15e434
NC
5170 case OPTION_NO_MERGE_NOTES:
5171 merge_notes = FALSE;
5172 break;
9ef920e9 5173
252b5132 5174 case 'N':
047c9024 5175 add_specific_symbol (optarg, strip_specific_htab);
252b5132 5176 break;
57938635 5177
bcf32829 5178 case OPTION_STRIP_UNNEEDED_SYMBOL:
047c9024 5179 add_specific_symbol (optarg, strip_unneeded_htab);
bcf32829
JB
5180 break;
5181
252b5132 5182 case 'L':
047c9024 5183 add_specific_symbol (optarg, localize_specific_htab);
252b5132 5184 break;
57938635 5185
7b4a0685 5186 case OPTION_GLOBALIZE_SYMBOL:
de564eb5 5187 use_globalize = TRUE;
047c9024 5188 add_specific_symbol (optarg, globalize_specific_htab);
7b4a0685
NC
5189 break;
5190
16b2b71c 5191 case 'G':
de564eb5 5192 use_keep_global = TRUE;
047c9024 5193 add_specific_symbol (optarg, keepglobal_specific_htab);
16b2b71c
NC
5194 break;
5195
252b5132 5196 case 'W':
047c9024 5197 add_specific_symbol (optarg, weaken_specific_htab);
252b5132 5198 break;
57938635 5199
252b5132 5200 case 'p':
b34976b6 5201 preserve_dates = TRUE;
252b5132 5202 break;
57938635 5203
2e30cb57
CC
5204 case 'D':
5205 deterministic = TRUE;
5206 break;
5207
955d0b3b
RM
5208 case 'U':
5209 deterministic = FALSE;
5210 break;
5211
5fe11841
NC
5212 case 'w':
5213 wildcard = TRUE;
5214 break;
5215
252b5132
RH
5216 case 'x':
5217 discard_locals = LOCALS_ALL;
5218 break;
57938635 5219
252b5132
RH
5220 case 'X':
5221 discard_locals = LOCALS_START_L;
5222 break;
57938635 5223
252b5132 5224 case 'v':
b34976b6 5225 verbose = TRUE;
252b5132 5226 break;
57938635 5227
252b5132 5228 case 'V':
b34976b6 5229 show_version = TRUE;
252b5132 5230 break;
57938635 5231
7c29036b
NC
5232 case OPTION_FORMATS_INFO:
5233 formats_info = TRUE;
5234 break;
5235
252b5132 5236 case OPTION_WEAKEN:
b34976b6 5237 weaken = TRUE;
252b5132 5238 break;
57938635 5239
252b5132 5240 case OPTION_ADD_SECTION:
f7433f01
AM
5241 add_sections = init_section_add (optarg, add_sections,
5242 "--add-section");
5243 section_add_load_file (add_sections);
252b5132 5244 break;
57938635 5245
acf1419f
AB
5246 case OPTION_UPDATE_SECTION:
5247 update_sections = init_section_add (optarg, update_sections,
f7433f01 5248 "--update-section");
acf1419f
AB
5249 section_add_load_file (update_sections);
5250 break;
5251
bbad633b 5252 case OPTION_DUMP_SECTION:
f7433f01
AM
5253 dump_sections = init_section_add (optarg, dump_sections,
5254 "--dump-section");
bbad633b 5255 break;
3aade688 5256
2b35fb28
RH
5257 case OPTION_ADD_SYMBOL:
5258 {
5259 char *s, *t;
5260 struct addsym_node *newsym = xmalloc (sizeof *newsym);
5261
5262 newsym->next = NULL;
5263 s = strchr (optarg, '=');
5264 if (s == NULL)
5265 fatal (_("bad format for %s"), "--add-symbol");
5266 t = strchr (s + 1, ':');
5267
a4f8732b 5268 newsym->symdef = xstrndup (optarg, s - optarg);
2b35fb28
RH
5269 if (t)
5270 {
a4f8732b 5271 newsym->section = xstrndup (s + 1, t - (s + 1));
2b35fb28
RH
5272 newsym->symval = strtol (t + 1, NULL, 0);
5273 }
5274 else
5275 {
5276 newsym->section = NULL;
5277 newsym->symval = strtol (s + 1, NULL, 0);
5278 t = s;
5279 }
5280
5281 t = strchr (t + 1, ',');
f7433f01 5282 newsym->othersym = NULL;
2b35fb28
RH
5283 if (t)
5284 newsym->flags = parse_symflags (t+1, &newsym->othersym);
5285 else
5286 newsym->flags = BSF_GLOBAL;
5287
5288 /* Keep 'othersym' symbols at the front of the list. */
5289 if (newsym->othersym)
5290 {
5291 newsym->next = add_sym_list;
5292 if (!add_sym_list)
5293 add_sym_tail = &newsym->next;
5294 add_sym_list = newsym;
5295 }
5296 else
5297 {
5298 *add_sym_tail = newsym;
5299 add_sym_tail = &newsym->next;
5300 }
5301 add_symbols++;
5302 }
5303 break;
5304
252b5132
RH
5305 case OPTION_CHANGE_START:
5306 change_start = parse_vma (optarg, "--change-start");
5307 break;
57938635 5308
252b5132
RH
5309 case OPTION_CHANGE_SECTION_ADDRESS:
5310 case OPTION_CHANGE_SECTION_LMA:
5311 case OPTION_CHANGE_SECTION_VMA:
5312 {
2e62b721 5313 struct section_list * p;
76d8cf45 5314 unsigned int context = 0;
252b5132
RH
5315 const char *s;
5316 int len;
5317 char *name;
b4c96d0d 5318 char *option = NULL;
252b5132 5319 bfd_vma val;
57938635 5320
252b5132
RH
5321 switch (c)
5322 {
b4c96d0d
ILT
5323 case OPTION_CHANGE_SECTION_ADDRESS:
5324 option = "--change-section-address";
2e62b721 5325 context = SECTION_CONTEXT_ALTER_LMA | SECTION_CONTEXT_ALTER_VMA;
b4c96d0d
ILT
5326 break;
5327 case OPTION_CHANGE_SECTION_LMA:
5328 option = "--change-section-lma";
2e62b721 5329 context = SECTION_CONTEXT_ALTER_LMA;
b4c96d0d
ILT
5330 break;
5331 case OPTION_CHANGE_SECTION_VMA:
5332 option = "--change-section-vma";
2e62b721 5333 context = SECTION_CONTEXT_ALTER_VMA;
b4c96d0d 5334 break;
252b5132 5335 }
57938635 5336
252b5132
RH
5337 s = strchr (optarg, '=');
5338 if (s == NULL)
5339 {
5340 s = strchr (optarg, '+');
5341 if (s == NULL)
5342 {
5343 s = strchr (optarg, '-');
5344 if (s == NULL)
5345 fatal (_("bad format for %s"), option);
5346 }
5347 }
2e62b721
NC
5348 else
5349 {
5350 /* Correct the context. */
5351 switch (c)
5352 {
5353 case OPTION_CHANGE_SECTION_ADDRESS:
5354 context = SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_SET_VMA;
5355 break;
5356 case OPTION_CHANGE_SECTION_LMA:
5357 context = SECTION_CONTEXT_SET_LMA;
5358 break;
5359 case OPTION_CHANGE_SECTION_VMA:
5360 context = SECTION_CONTEXT_SET_VMA;
5361 break;
5362 }
5363 }
252b5132
RH
5364
5365 len = s - optarg;
3f5e193b 5366 name = (char *) xmalloc (len + 1);
252b5132
RH
5367 strncpy (name, optarg, len);
5368 name[len] = '\0';
5369
2e62b721 5370 p = find_section_list (name, TRUE, context);
252b5132
RH
5371
5372 val = parse_vma (s + 1, option);
2e62b721
NC
5373 if (*s == '-')
5374 val = - val;
57938635 5375
252b5132
RH
5376 switch (c)
5377 {
5378 case OPTION_CHANGE_SECTION_ADDRESS:
2e62b721 5379 p->vma_val = val;
1a0670f3 5380 /* Fall through. */
57938635 5381
252b5132 5382 case OPTION_CHANGE_SECTION_LMA:
2e62b721 5383 p->lma_val = val;
252b5132 5384 break;
57938635 5385
252b5132 5386 case OPTION_CHANGE_SECTION_VMA:
2e62b721 5387 p->vma_val = val;
252b5132
RH
5388 break;
5389 }
5390 }
5391 break;
57938635 5392
252b5132
RH
5393 case OPTION_CHANGE_ADDRESSES:
5394 change_section_address = parse_vma (optarg, "--change-addresses");
5395 change_start = change_section_address;
5396 break;
57938635 5397
252b5132 5398 case OPTION_CHANGE_WARNINGS:
b34976b6 5399 change_warn = TRUE;
252b5132 5400 break;
57938635 5401
252b5132 5402 case OPTION_CHANGE_LEADING_CHAR:
b34976b6 5403 change_leading_char = TRUE;
252b5132 5404 break;
57938635 5405
4a114e3e 5406 case OPTION_COMPRESS_DEBUG_SECTIONS:
151411f8
L
5407 if (optarg)
5408 {
5409 if (strcasecmp (optarg, "none") == 0)
5410 do_debug_sections = decompress;
5411 else if (strcasecmp (optarg, "zlib") == 0)
5412 do_debug_sections = compress_zlib;
5413 else if (strcasecmp (optarg, "zlib-gnu") == 0)
5414 do_debug_sections = compress_gnu_zlib;
5415 else if (strcasecmp (optarg, "zlib-gabi") == 0)
5416 do_debug_sections = compress_gabi_zlib;
5417 else
5418 fatal (_("unrecognized --compress-debug-sections type `%s'"),
5419 optarg);
5420 }
5421 else
5422 do_debug_sections = compress;
4a114e3e
L
5423 break;
5424
252b5132 5425 case OPTION_DEBUGGING:
b34976b6 5426 convert_debugging = TRUE;
252b5132 5427 break;
57938635 5428
4a114e3e
L
5429 case OPTION_DECOMPRESS_DEBUG_SECTIONS:
5430 do_debug_sections = decompress;
5431 break;
5432
b8871f35
L
5433 case OPTION_ELF_STT_COMMON:
5434 if (strcasecmp (optarg, "yes") == 0)
5435 do_elf_stt_common = elf_stt_common;
5436 else if (strcasecmp (optarg, "no") == 0)
5437 do_elf_stt_common = no_elf_stt_common;
5438 else
5439 fatal (_("unrecognized --elf-stt-common= option `%s'"),
5440 optarg);
5441 break;
5442
252b5132
RH
5443 case OPTION_GAP_FILL:
5444 {
5445 bfd_vma gap_fill_vma;
5446
5447 gap_fill_vma = parse_vma (optarg, "--gap-fill");
5448 gap_fill = (bfd_byte) gap_fill_vma;
5449 if ((bfd_vma) gap_fill != gap_fill_vma)
5450 {
5451 char buff[20];
57938635 5452
252b5132 5453 sprintf_vma (buff, gap_fill_vma);
57938635 5454
252b5132
RH
5455 non_fatal (_("Warning: truncating gap-fill from 0x%s to 0x%x"),
5456 buff, gap_fill);
5457 }
b34976b6 5458 gap_fill_set = TRUE;
252b5132
RH
5459 }
5460 break;
57938635 5461
252b5132 5462 case OPTION_NO_CHANGE_WARNINGS:
b34976b6 5463 change_warn = FALSE;
252b5132 5464 break;
57938635 5465
252b5132
RH
5466 case OPTION_PAD_TO:
5467 pad_to = parse_vma (optarg, "--pad-to");
b34976b6 5468 pad_to_set = TRUE;
252b5132 5469 break;
57938635 5470
252b5132 5471 case OPTION_REMOVE_LEADING_CHAR:
b34976b6 5472 remove_leading_char = TRUE;
252b5132 5473 break;
57938635
AM
5474
5475 case OPTION_REDEFINE_SYM:
5476 {
0f65a5d8 5477 /* Insert this redefinition onto redefine_specific_htab. */
57938635
AM
5478
5479 int len;
5480 const char *s;
5481 const char *nextarg;
5482 char *source, *target;
5483
5484 s = strchr (optarg, '=');
5485 if (s == NULL)
594ef5db 5486 fatal (_("bad format for %s"), "--redefine-sym");
57938635
AM
5487
5488 len = s - optarg;
3f5e193b 5489 source = (char *) xmalloc (len + 1);
57938635
AM
5490 strncpy (source, optarg, len);
5491 source[len] = '\0';
5492
5493 nextarg = s + 1;
5494 len = strlen (nextarg);
3f5e193b 5495 target = (char *) xmalloc (len + 1);
57938635
AM
5496 strcpy (target, nextarg);
5497
0f65a5d8 5498 add_redefine_and_check ("--redefine-sym", source, target);
57938635
AM
5499
5500 free (source);
5501 free (target);
5502 }
5503 break;
5504
92991082
JT
5505 case OPTION_REDEFINE_SYMS:
5506 add_redefine_syms_file (optarg);
5507 break;
5508
252b5132
RH
5509 case OPTION_SET_SECTION_FLAGS:
5510 {
2e62b721 5511 struct section_list *p;
252b5132
RH
5512 const char *s;
5513 int len;
5514 char *name;
5515
5516 s = strchr (optarg, '=');
5517 if (s == NULL)
57938635 5518 fatal (_("bad format for %s"), "--set-section-flags");
252b5132
RH
5519
5520 len = s - optarg;
3f5e193b 5521 name = (char *) xmalloc (len + 1);
252b5132
RH
5522 strncpy (name, optarg, len);
5523 name[len] = '\0';
5524
2e62b721 5525 p = find_section_list (name, TRUE, SECTION_CONTEXT_SET_FLAGS);
252b5132 5526
252b5132
RH
5527 p->flags = parse_flags (s + 1);
5528 }
5529 break;
57938635 5530
fa463e9f
N
5531 case OPTION_SET_SECTION_ALIGNMENT:
5532 {
5533 struct section_list *p;
5534 const char *s;
5535 int len;
5536 char *name;
de4859ea 5537 int palign, align;
fa463e9f
N
5538
5539 s = strchr (optarg, '=');
5540 if (s == NULL)
de4859ea 5541 fatal (_("bad format for --set-section-alignment: argument needed"));
82ef9cad 5542
de4859ea
NC
5543 align = atoi (s + 1);
5544 if (align <= 0)
5545 fatal (_("bad format for --set-section-alignment: numeric argument needed"));
fa463e9f 5546
de4859ea
NC
5547 /* Convert integer alignment into a power-of-two alignment. */
5548 palign = 0;
5549 while ((align & 1) == 0)
5550 {
5551 align >>= 1;
5552 ++palign;
5553 }
82ef9cad 5554
de4859ea
NC
5555 if (align != 1)
5556 /* Number has more than on 1, i.e. wasn't a power of 2. */
5557 fatal (_("bad format for --set-section-alignment: alignment is not a power of two"));
5558
5559 /* Add the alignment setting to the section list. */
fa463e9f
N
5560 len = s - optarg;
5561 name = (char *) xmalloc (len + 1);
5562 strncpy (name, optarg, len);
5563 name[len] = '\0';
5564
5565 p = find_section_list (name, TRUE, SECTION_CONTEXT_SET_ALIGNMENT);
de4859ea
NC
5566 if (p)
5567 p->alignment = palign;
fa463e9f
N
5568 }
5569 break;
82ef9cad 5570
594ef5db
NC
5571 case OPTION_RENAME_SECTION:
5572 {
5573 flagword flags;
3bcfb3e4
AM
5574 const char *eq, *fl;
5575 char *old_name;
5576 char *new_name;
594ef5db
NC
5577 unsigned int len;
5578
3bcfb3e4
AM
5579 eq = strchr (optarg, '=');
5580 if (eq == NULL)
594ef5db
NC
5581 fatal (_("bad format for %s"), "--rename-section");
5582
3bcfb3e4 5583 len = eq - optarg;
594ef5db 5584 if (len == 0)
3bcfb3e4 5585 fatal (_("bad format for %s"), "--rename-section");
594ef5db 5586
3f5e193b 5587 old_name = (char *) xmalloc (len + 1);
594ef5db
NC
5588 strncpy (old_name, optarg, len);
5589 old_name[len] = 0;
5590
3bcfb3e4
AM
5591 eq++;
5592 fl = strchr (eq, ',');
5593 if (fl)
594ef5db 5594 {
3bcfb3e4
AM
5595 flags = parse_flags (fl + 1);
5596 len = fl - eq;
594ef5db
NC
5597 }
5598 else
5599 {
594ef5db 5600 flags = -1;
3bcfb3e4 5601 len = strlen (eq);
594ef5db
NC
5602 }
5603
3bcfb3e4
AM
5604 if (len == 0)
5605 fatal (_("bad format for %s"), "--rename-section");
5606
3f5e193b 5607 new_name = (char *) xmalloc (len + 1);
3bcfb3e4
AM
5608 strncpy (new_name, eq, len);
5609 new_name[len] = 0;
5610
594ef5db
NC
5611 add_section_rename (old_name, new_name, flags);
5612 }
5613 break;
5614
252b5132
RH
5615 case OPTION_SET_START:
5616 set_start = parse_vma (optarg, "--set-start");
b34976b6 5617 set_start_set = TRUE;
252b5132 5618 break;
57938635 5619
0af11b59 5620 case OPTION_SREC_LEN:
4bc26c69 5621 _bfd_srec_len = parse_vma (optarg, "--srec-len");
0af11b59 5622 break;
420496c1 5623
0af11b59 5624 case OPTION_SREC_FORCES3:
4bc26c69 5625 _bfd_srec_forceS3 = TRUE;
0af11b59 5626 break;
420496c1 5627
16b2b71c 5628 case OPTION_STRIP_SYMBOLS:
d839b914
L
5629 add_specific_symbols (optarg, strip_specific_htab,
5630 &strip_specific_buffer);
16b2b71c
NC
5631 break;
5632
bcf32829 5633 case OPTION_STRIP_UNNEEDED_SYMBOLS:
d839b914
L
5634 add_specific_symbols (optarg, strip_unneeded_htab,
5635 &strip_unneeded_buffer);
bcf32829
JB
5636 break;
5637
16b2b71c 5638 case OPTION_KEEP_SYMBOLS:
d839b914
L
5639 add_specific_symbols (optarg, keep_specific_htab,
5640 &keep_specific_buffer);
16b2b71c
NC
5641 break;
5642
d58c2e3a
RS
5643 case OPTION_LOCALIZE_HIDDEN:
5644 localize_hidden = TRUE;
5645 break;
5646
16b2b71c 5647 case OPTION_LOCALIZE_SYMBOLS:
d839b914
L
5648 add_specific_symbols (optarg, localize_specific_htab,
5649 &localize_specific_buffer);
16b2b71c
NC
5650 break;
5651
0408dee6
DK
5652 case OPTION_LONG_SECTION_NAMES:
5653 if (!strcmp ("enable", optarg))
5654 long_section_names = ENABLE;
5655 else if (!strcmp ("disable", optarg))
5656 long_section_names = DISABLE;
5657 else if (!strcmp ("keep", optarg))
5658 long_section_names = KEEP;
5659 else
5660 fatal (_("unknown long section names option '%s'"), optarg);
5661 break;
5662
7b4a0685 5663 case OPTION_GLOBALIZE_SYMBOLS:
de564eb5 5664 use_globalize = TRUE;
d839b914
L
5665 add_specific_symbols (optarg, globalize_specific_htab,
5666 &globalize_specific_buffer);
7b4a0685
NC
5667 break;
5668
16b2b71c 5669 case OPTION_KEEPGLOBAL_SYMBOLS:
de564eb5 5670 use_keep_global = TRUE;
d839b914
L
5671 add_specific_symbols (optarg, keepglobal_specific_htab,
5672 &keepglobal_specific_buffer);
16b2b71c
NC
5673 break;
5674
5675 case OPTION_WEAKEN_SYMBOLS:
d839b914
L
5676 add_specific_symbols (optarg, weaken_specific_htab,
5677 &weaken_specific_buffer);
16b2b71c
NC
5678 break;
5679
1ae8b3d2 5680 case OPTION_ALT_MACH_CODE:
f9d4ad2a
NC
5681 use_alt_mach_code = strtoul (optarg, NULL, 0);
5682 if (use_alt_mach_code == 0)
5683 fatal (_("unable to parse alternative machine code"));
1ae8b3d2
AO
5684 break;
5685
d7fb0dd2
NC
5686 case OPTION_PREFIX_SYMBOLS:
5687 prefix_symbols_string = optarg;
5688 break;
5689
5690 case OPTION_PREFIX_SECTIONS:
5691 prefix_sections_string = optarg;
5692 break;
5693
5694 case OPTION_PREFIX_ALLOC_SECTIONS:
5695 prefix_alloc_sections_string = optarg;
5696 break;
5697
4087920c
MR
5698 case OPTION_READONLY_TEXT:
5699 bfd_flags_to_set |= WP_TEXT;
5700 bfd_flags_to_clear &= ~WP_TEXT;
5701 break;
5702
5703 case OPTION_WRITABLE_TEXT:
5704 bfd_flags_to_clear |= WP_TEXT;
5705 bfd_flags_to_set &= ~WP_TEXT;
5706 break;
5707
5708 case OPTION_PURE:
5709 bfd_flags_to_set |= D_PAGED;
5710 bfd_flags_to_clear &= ~D_PAGED;
5711 break;
5712
5713 case OPTION_IMPURE:
5714 bfd_flags_to_clear |= D_PAGED;
5715 bfd_flags_to_set &= ~D_PAGED;
5716 break;
5717
96109726
CC
5718 case OPTION_EXTRACT_DWO:
5719 strip_symbols = STRIP_NONDWO;
5720 break;
5721
d3e52d40
RS
5722 case OPTION_EXTRACT_SYMBOL:
5723 extract_symbol = TRUE;
5724 break;
5725
9e48b4c6 5726 case OPTION_REVERSE_BYTES:
f7433f01
AM
5727 {
5728 int prev = reverse_bytes;
9e48b4c6 5729
f7433f01
AM
5730 reverse_bytes = atoi (optarg);
5731 if ((reverse_bytes <= 0) || ((reverse_bytes % 2) != 0))
5732 fatal (_("number of bytes to reverse must be positive and even"));
9e48b4c6 5733
f7433f01
AM
5734 if (prev && prev != reverse_bytes)
5735 non_fatal (_("Warning: ignoring previous --reverse-bytes value of %d"),
5736 prev);
5737 break;
5738 }
9e48b4c6 5739
92dd4511
L
5740 case OPTION_FILE_ALIGNMENT:
5741 pe_file_alignment = parse_vma (optarg, "--file-alignment");
5742 break;
955d0b3b 5743
92dd4511 5744 case OPTION_HEAP:
f7433f01
AM
5745 {
5746 char *end;
5747 pe_heap_reserve = strtoul (optarg, &end, 0);
5748 if (end == optarg
5749 || (*end != '.' && *end != '\0'))
5750 non_fatal (_("%s: invalid reserve value for --heap"),
5751 optarg);
5752 else if (*end != '\0')
5753 {
5754 pe_heap_commit = strtoul (end + 1, &end, 0);
5755 if (*end != '\0')
5756 non_fatal (_("%s: invalid commit value for --heap"),
5757 optarg);
5758 }
5759 }
92dd4511 5760 break;
955d0b3b 5761
92dd4511
L
5762 case OPTION_IMAGE_BASE:
5763 pe_image_base = parse_vma (optarg, "--image-base");
5764 break;
955d0b3b 5765
fa463e9f 5766 case OPTION_PE_SECTION_ALIGNMENT:
92dd4511
L
5767 pe_section_alignment = parse_vma (optarg,
5768 "--section-alignment");
5769 break;
955d0b3b 5770
92dd4511
L
5771 case OPTION_SUBSYSTEM:
5772 set_pe_subsystem (optarg);
5773 break;
955d0b3b 5774
92dd4511 5775 case OPTION_STACK:
f7433f01
AM
5776 {
5777 char *end;
5778 pe_stack_reserve = strtoul (optarg, &end, 0);
5779 if (end == optarg
5780 || (*end != '.' && *end != '\0'))
5781 non_fatal (_("%s: invalid reserve value for --stack"),
5782 optarg);
5783 else if (*end != '\0')
5784 {
5785 pe_stack_commit = strtoul (end + 1, &end, 0);
5786 if (*end != '\0')
5787 non_fatal (_("%s: invalid commit value for --stack"),
5788 optarg);
5789 }
5790 }
92dd4511 5791 break;
955d0b3b 5792
37d0d091
JH
5793 case OPTION_VERILOG_DATA_WIDTH:
5794 VerilogDataWidth = parse_vma (optarg, "--verilog-data-width");
5795 if (VerilogDataWidth < 1)
5796 fatal (_("verilog data width must be at least 1 byte"));
5797 break;
5798
252b5132 5799 case 0:
2593f09a
NC
5800 /* We've been given a long option. */
5801 break;
57938635 5802
8b53311e 5803 case 'H':
252b5132
RH
5804 case 'h':
5805 copy_usage (stdout, 0);
57938635 5806
252b5132
RH
5807 default:
5808 copy_usage (stderr, 1);
5809 }
5810 }
5811
de564eb5
NC
5812 if (use_globalize && use_keep_global)
5813 fatal(_("--globalize-symbol(s) is incompatible with -G/--keep-global-symbol(s)"));
5814
7c29036b
NC
5815 if (formats_info)
5816 {
5817 display_info ();
5818 return 0;
5819 }
c1c0eb9e 5820
252b5132
RH
5821 if (show_version)
5822 print_version ("objcopy");
5823
b7dd81f7
NC
5824 if (interleave && copy_byte == -1)
5825 fatal (_("interleave start byte must be set with --byte"));
5826
252b5132
RH
5827 if (copy_byte >= interleave)
5828 fatal (_("byte number must be less than interleave"));
5829
b7dd81f7
NC
5830 if (copy_width > interleave - copy_byte)
5831 fatal (_("interleave width must be less than or equal to interleave - byte`"));
5832
252b5132
RH
5833 if (optind == argc || optind + 2 < argc)
5834 copy_usage (stderr, 1);
5835
5836 input_filename = argv[optind];
5837 if (optind + 1 < argc)
5838 output_filename = argv[optind + 1];
5839
955d0b3b
RM
5840 default_deterministic ();
5841
252b5132
RH
5842 /* Default is to strip no symbols. */
5843 if (strip_symbols == STRIP_UNDEF && discard_locals == LOCALS_UNDEF)
5844 strip_symbols = STRIP_NONE;
5845
d3ba0551 5846 if (output_target == NULL)
252b5132
RH
5847 output_target = input_target;
5848
92dd4511
L
5849 /* Convert input EFI target to PEI target. */
5850 if (input_target != NULL
5851 && strncmp (input_target, "efi-", 4) == 0)
5852 {
5853 char *efi;
5854
5855 efi = xstrdup (output_target + 4);
5856 if (strncmp (efi, "bsdrv-", 6) == 0
5857 || strncmp (efi, "rtdrv-", 6) == 0)
5858 efi += 2;
5859 else if (strncmp (efi, "app-", 4) != 0)
5860 fatal (_("unknown input EFI target: %s"), input_target);
5861
5862 input_target = efi;
5863 convert_efi_target (efi);
5864 }
5865
5866 /* Convert output EFI target to PEI target. */
5867 if (output_target != NULL
5868 && strncmp (output_target, "efi-", 4) == 0)
5869 {
5870 char *efi;
5871
5872 efi = xstrdup (output_target + 4);
5873 if (strncmp (efi, "app-", 4) == 0)
5874 {
5875 if (pe_subsystem == -1)
5876 pe_subsystem = IMAGE_SUBSYSTEM_EFI_APPLICATION;
5877 }
5878 else if (strncmp (efi, "bsdrv-", 6) == 0)
5879 {
5880 if (pe_subsystem == -1)
5881 pe_subsystem = IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER;
5882 efi += 2;
5883 }
5884 else if (strncmp (efi, "rtdrv-", 6) == 0)
5885 {
5886 if (pe_subsystem == -1)
5887 pe_subsystem = IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER;
5888 efi += 2;
5889 }
5890 else
5891 fatal (_("unknown output EFI target: %s"), output_target);
5892
5893 if (pe_file_alignment == (bfd_vma) -1)
5894 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
5895 if (pe_section_alignment == (bfd_vma) -1)
5896 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
5897
5898 output_target = efi;
5899 convert_efi_target (efi);
5900 }
5901
43a0748c
NC
5902 if (preserve_dates)
5903 if (stat (input_filename, & statbuf) < 0)
f24ddbdd
NC
5904 fatal (_("warning: could not locate '%s'. System error message: %s"),
5905 input_filename, strerror (errno));
43a0748c 5906
0fcdcb91 5907 /* If there is no destination file, or the source and destination files
d3ba0551 5908 are the same, then create a temp and rename the result into the input. */
8b6efd89
KT
5909 if (output_filename == NULL
5910 || filename_cmp (input_filename, output_filename) == 0)
365f5fb6 5911 tmpname = make_tempname (input_filename, &tmpfd);
252b5132 5912 else
12f498a7 5913 tmpname = output_filename;
c1c0eb9e 5914
12f498a7
NS
5915 if (tmpname == NULL)
5916 fatal (_("warning: could not create temporary file whilst copying '%s', (error: %s)"),
5917 input_filename, strerror (errno));
594ef5db 5918
365f5fb6
SP
5919 copy_file (input_filename, tmpname, tmpfd, input_target, output_target,
5920 input_arch);
12f498a7
NS
5921 if (status == 0)
5922 {
5923 if (preserve_dates)
5924 set_times (tmpname, &statbuf);
5925 if (tmpname != output_filename)
92fac5ec
L
5926 status = (smart_rename (tmpname, input_filename,
5927 preserve_dates) != 0);
252b5132 5928 }
12f498a7
NS
5929 else
5930 unlink_if_ordinary (tmpname);
252b5132 5931
be74fad9
AM
5932 if (tmpname != output_filename)
5933 free (tmpname);
5934
252b5132
RH
5935 if (change_warn)
5936 {
2e62b721
NC
5937 struct section_list *p;
5938
252b5132
RH
5939 for (p = change_sections; p != NULL; p = p->next)
5940 {
5941 if (! p->used)
5942 {
2e62b721 5943 if (p->context & (SECTION_CONTEXT_SET_VMA | SECTION_CONTEXT_ALTER_VMA))
252b5132
RH
5944 {
5945 char buff [20];
5946
5947 sprintf_vma (buff, p->vma_val);
57938635 5948
252b5132 5949 /* xgettext:c-format */
57938635
AM
5950 non_fatal (_("%s %s%c0x%s never used"),
5951 "--change-section-vma",
2e62b721
NC
5952 p->pattern,
5953 p->context & SECTION_CONTEXT_SET_VMA ? '=' : '+',
252b5132
RH
5954 buff);
5955 }
57938635 5956
2e62b721 5957 if (p->context & (SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_ALTER_LMA))
252b5132
RH
5958 {
5959 char buff [20];
5960
5961 sprintf_vma (buff, p->lma_val);
57938635 5962
252b5132 5963 /* xgettext:c-format */
57938635
AM
5964 non_fatal (_("%s %s%c0x%s never used"),
5965 "--change-section-lma",
2e62b721
NC
5966 p->pattern,
5967 p->context & SECTION_CONTEXT_SET_LMA ? '=' : '+',
252b5132
RH
5968 buff);
5969 }
5970 }
5971 }
5972 }
5973
d839b914
L
5974 if (strip_specific_buffer)
5975 free (strip_specific_buffer);
5976
5977 if (strip_unneeded_buffer)
5978 free (strip_unneeded_buffer);
5979
5980 if (keep_specific_buffer)
5981 free (keep_specific_buffer);
5982
5983 if (localize_specific_buffer)
5984 free (globalize_specific_buffer);
5985
5986 if (globalize_specific_buffer)
5987 free (globalize_specific_buffer);
5988
5989 if (keepglobal_specific_buffer)
5990 free (keepglobal_specific_buffer);
5991
5992 if (weaken_specific_buffer)
5993 free (weaken_specific_buffer);
5994
252b5132
RH
5995 return 0;
5996}
5997
5998int
84e2f313 5999main (int argc, char *argv[])
252b5132
RH
6000{
6001#if defined (HAVE_SETLOCALE) && defined (HAVE_LC_MESSAGES)
6002 setlocale (LC_MESSAGES, "");
3882b010
L
6003#endif
6004#if defined (HAVE_SETLOCALE)
6005 setlocale (LC_CTYPE, "");
252b5132
RH
6006#endif
6007 bindtextdomain (PACKAGE, LOCALEDIR);
6008 textdomain (PACKAGE);
6009
6010 program_name = argv[0];
6011 xmalloc_set_program_name (program_name);
6012
6013 START_PROGRESS (program_name, 0);
6014
869b9d07
MM
6015 expandargv (&argc, &argv);
6016
252b5132
RH
6017 strip_symbols = STRIP_UNDEF;
6018 discard_locals = LOCALS_UNDEF;
6019
bf2dd8d7
AM
6020 if (bfd_init () != BFD_INIT_MAGIC)
6021 fatal (_("fatal error: libbfd ABI mismatch"));
252b5132
RH
6022 set_default_bfd_target ();
6023
6024 if (is_strip < 0)
6025 {
6026 int i = strlen (program_name);
5af11cab
AM
6027#ifdef HAVE_DOS_BASED_FILE_SYSTEM
6028 /* Drop the .exe suffix, if any. */
6029 if (i > 4 && FILENAME_CMP (program_name + i - 4, ".exe") == 0)
6030 {
6031 i -= 4;
6032 program_name[i] = '\0';
6033 }
6034#endif
6035 is_strip = (i >= 5 && FILENAME_CMP (program_name + i - 5, "strip") == 0);
252b5132
RH
6036 }
6037
047c9024
NC
6038 create_symbol_htabs ();
6039
86eafac0
NC
6040 if (argv != NULL)
6041 bfd_set_error_program_name (argv[0]);
6042
252b5132
RH
6043 if (is_strip)
6044 strip_main (argc, argv);
6045 else
6046 copy_main (argc, argv);
6047
6048 END_PROGRESS (program_name);
6049
6050 return status;
6051}
This page took 2.129449 seconds and 4 git commands to generate.