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