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