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