Automatic date update in version.in
[binutils-gdb.git] / binutils / objcopy.c
blobb907b02d5e7483dcf7915e02f930cfc468a47d9c
1 /* objcopy.c -- copy object file from input to output, optionally massaging it.
2 Copyright (C) 1991-2022 Free Software Foundation, Inc.
4 This file is part of GNU Binutils.
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
8 the Free Software Foundation; either version 3 of the License, or
9 (at your option) any later version.
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.
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
18 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA
19 02110-1301, USA. */
21 #include "sysdep.h"
22 #include "bfd.h"
23 #include "progress.h"
24 #include "getopt.h"
25 #include "libiberty.h"
26 #include "bucomm.h"
27 #include "budbg.h"
28 #include "filenames.h"
29 #include "fnmatch.h"
30 #include "elf-bfd.h"
31 #include "coff/internal.h"
32 #include "libcoff.h"
33 #include "safe-ctype.h"
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"
40 static bfd_vma pe_file_alignment = (bfd_vma) -1;
41 static bfd_vma pe_heap_commit = (bfd_vma) -1;
42 static bfd_vma pe_heap_reserve = (bfd_vma) -1;
43 static bfd_vma pe_image_base = (bfd_vma) -1;
44 static bfd_vma pe_section_alignment = (bfd_vma) -1;
45 static bfd_vma pe_stack_commit = (bfd_vma) -1;
46 static bfd_vma pe_stack_reserve = (bfd_vma) -1;
47 static short pe_subsystem = -1;
48 static short pe_major_subsystem_version = -1;
49 static short pe_minor_subsystem_version = -1;
51 struct is_specified_symbol_predicate_data
53 const char *name;
54 bool found;
57 /* A node includes symbol name mapping to support redefine_sym. */
58 struct redefine_node
60 char *source;
61 char *target;
64 struct addsym_node
66 struct addsym_node *next;
67 char * symdef;
68 long symval;
69 flagword flags;
70 char * section;
71 const char * othersym;
74 typedef struct section_rename
76 const char * old_name;
77 const char * new_name;
78 flagword flags;
79 struct section_rename * next;
81 section_rename;
83 /* List of sections to be renamed. */
84 static section_rename *section_rename_list;
86 static asymbol **isympp = NULL; /* Input symbols. */
87 static asymbol **osympp = NULL; /* Output symbols that survive stripping. */
89 /* If `copy_byte' >= 0, copy 'copy_width' byte(s) of every `interleave' bytes. */
90 static int copy_byte = -1;
91 static int interleave = 0; /* Initialised to 4 in copy_main(). */
92 static int copy_width = 1;
94 static bool keep_section_symbols = false ;/* True if section symbols should be retained. */
95 static bool verbose; /* Print file and target names. */
96 static bool preserve_dates; /* Preserve input file timestamp. */
97 static int deterministic = -1; /* Enable deterministic archives. */
98 static int status = 0; /* Exit status. */
100 static bool merge_notes = false; /* Merge note sections. */
102 typedef struct merged_note_section
104 asection * sec; /* The section that is being merged. */
105 bfd_byte * contents;/* New contents of the section. */
106 bfd_size_type size; /* New size of the section. */
107 struct merged_note_section * next; /* Link to next merged note section. */
108 } merged_note_section;
110 enum strip_action
112 STRIP_UNDEF,
113 STRIP_NONE, /* Don't strip. */
114 STRIP_DEBUG, /* Strip all debugger symbols. */
115 STRIP_UNNEEDED, /* Strip unnecessary symbols. */
116 STRIP_NONDEBUG, /* Strip everything but debug info. */
117 STRIP_DWO, /* Strip all DWO info. */
118 STRIP_NONDWO, /* Strip everything but DWO info. */
119 STRIP_ALL /* Strip all symbols. */
122 /* Which symbols to remove. */
123 static enum strip_action strip_symbols = STRIP_UNDEF;
125 enum locals_action
127 LOCALS_UNDEF,
128 LOCALS_START_L, /* Discard locals starting with L. */
129 LOCALS_ALL /* Discard all locals. */
132 /* Which local symbols to remove. Overrides STRIP_ALL. */
133 static enum locals_action discard_locals;
135 /* Structure used to hold lists of sections and actions to take. */
136 struct section_list
138 struct section_list *next; /* Next section to change. */
139 const char *pattern; /* Section name pattern. */
140 bool used; /* Whether this entry was used. */
142 unsigned int context; /* What to do with matching sections. */
143 /* Flag bits used in the context field.
144 COPY and REMOVE are mutually exlusive.
145 SET and ALTER are mutually exclusive. */
146 #define SECTION_CONTEXT_REMOVE (1 << 0) /* Remove this section. */
147 #define SECTION_CONTEXT_COPY (1 << 1) /* Copy this section, delete all non-copied section. */
148 #define SECTION_CONTEXT_KEEP (1 << 2) /* Keep this section. */
149 #define SECTION_CONTEXT_SET_VMA (1 << 3) /* Set the sections' VMA address. */
150 #define SECTION_CONTEXT_ALTER_VMA (1 << 4) /* Increment or decrement the section's VMA address. */
151 #define SECTION_CONTEXT_SET_LMA (1 << 5) /* Set the sections' LMA address. */
152 #define SECTION_CONTEXT_ALTER_LMA (1 << 6) /* Increment or decrement the section's LMA address. */
153 #define SECTION_CONTEXT_SET_FLAGS (1 << 7) /* Set the section's flags. */
154 #define SECTION_CONTEXT_REMOVE_RELOCS (1 << 8) /* Remove relocations for this section. */
155 #define SECTION_CONTEXT_SET_ALIGNMENT (1 << 9) /* Set alignment for section. */
157 bfd_vma vma_val; /* Amount to change by or set to. */
158 bfd_vma lma_val; /* Amount to change by or set to. */
159 flagword flags; /* What to set the section flags to. */
160 unsigned int alignment; /* Alignment of output section. */
163 static struct section_list *change_sections;
165 /* TRUE if some sections are to be removed. */
166 static bool sections_removed;
168 /* TRUE if only some sections are to be copied. */
169 static bool sections_copied;
171 /* Changes to the start address. */
172 static bfd_vma change_start = 0;
173 static bool set_start_set = false;
174 static bfd_vma set_start;
176 /* Changes to section addresses. */
177 static bfd_vma change_section_address = 0;
179 /* Filling gaps between sections. */
180 static bool gap_fill_set = false;
181 static bfd_byte gap_fill = 0;
183 /* Pad to a given address. */
184 static bool pad_to_set = false;
185 static bfd_vma pad_to;
187 /* Use alternative machine code? */
188 static unsigned long use_alt_mach_code = 0;
190 /* Output BFD flags user wants to set or clear */
191 static flagword bfd_flags_to_set;
192 static flagword bfd_flags_to_clear;
194 /* List of sections to add. */
195 struct section_add
197 /* Next section to add. */
198 struct section_add *next;
199 /* Name of section to add. */
200 const char *name;
201 /* Name of file holding section contents. */
202 const char *filename;
203 /* Size of file. */
204 size_t size;
205 /* Contents of file. */
206 bfd_byte *contents;
207 /* BFD section, after it has been added. */
208 asection *section;
211 /* List of sections to add to the output BFD. */
212 static struct section_add *add_sections;
214 /* List of sections to update in the output BFD. */
215 static struct section_add *update_sections;
217 /* List of sections to dump from the output BFD. */
218 static struct section_add *dump_sections;
220 /* If non-NULL the argument to --add-gnu-debuglink.
221 This should be the filename to store in the .gnu_debuglink section. */
222 static const char * gnu_debuglink_filename = NULL;
224 /* Whether to convert debugging information. */
225 static bool convert_debugging = false;
227 /* Whether to compress/decompress DWARF debug sections. */
228 static enum
230 nothing = 0,
231 compress = 1 << 0,
232 compress_zlib = compress | 1 << 1,
233 compress_gnu_zlib = compress | 1 << 2,
234 compress_gabi_zlib = compress | 1 << 3,
235 decompress = 1 << 4
236 } do_debug_sections = nothing;
238 /* Whether to generate ELF common symbols with the STT_COMMON type. */
239 static enum bfd_link_elf_stt_common do_elf_stt_common = unchanged;
241 /* Whether to change the leading character in symbol names. */
242 static bool change_leading_char = false;
244 /* Whether to remove the leading character from global symbol names. */
245 static bool remove_leading_char = false;
247 /* Whether to permit wildcard in symbol comparison. */
248 static bool wildcard = false;
250 /* True if --localize-hidden is in effect. */
251 static bool localize_hidden = false;
253 /* List of symbols to strip, keep, localize, keep-global, weaken,
254 or redefine. */
255 static htab_t strip_specific_htab = NULL;
256 static htab_t strip_unneeded_htab = NULL;
257 static htab_t keep_specific_htab = NULL;
258 static htab_t localize_specific_htab = NULL;
259 static htab_t globalize_specific_htab = NULL;
260 static htab_t keepglobal_specific_htab = NULL;
261 static htab_t weaken_specific_htab = NULL;
262 static htab_t redefine_specific_htab = NULL;
263 static htab_t redefine_specific_reverse_htab = NULL;
264 static struct addsym_node *add_sym_list = NULL, **add_sym_tail = &add_sym_list;
265 static int add_symbols = 0;
267 static char *strip_specific_buffer = NULL;
268 static char *strip_unneeded_buffer = NULL;
269 static char *keep_specific_buffer = NULL;
270 static char *localize_specific_buffer = NULL;
271 static char *globalize_specific_buffer = NULL;
272 static char *keepglobal_specific_buffer = NULL;
273 static char *weaken_specific_buffer = NULL;
275 /* If this is TRUE, we weaken global symbols (set BSF_WEAK). */
276 static bool weaken = false;
278 /* If this is TRUE, we retain BSF_FILE symbols. */
279 static bool keep_file_symbols = false;
281 /* Prefix symbols/sections. */
282 static char *prefix_symbols_string = 0;
283 static char *prefix_sections_string = 0;
284 static char *prefix_alloc_sections_string = 0;
286 /* True if --extract-symbol was passed on the command line. */
287 static bool extract_symbol = false;
289 /* If `reverse_bytes' is nonzero, then reverse the order of every chunk
290 of <reverse_bytes> bytes within each output section. */
291 static int reverse_bytes = 0;
293 /* For Coff objects, we may want to allow or disallow long section names,
294 or preserve them where found in the inputs. Debug info relies on them. */
295 enum long_section_name_handling
297 DISABLE,
298 ENABLE,
299 KEEP
302 /* The default long section handling mode is to preserve them.
303 This is also the only behaviour for 'strip'. */
304 static enum long_section_name_handling long_section_names = KEEP;
306 /* 150 isn't special; it's just an arbitrary non-ASCII char value. */
307 enum command_line_switch
309 OPTION_ADD_SECTION=150,
310 OPTION_ADD_GNU_DEBUGLINK,
311 OPTION_ADD_SYMBOL,
312 OPTION_ALT_MACH_CODE,
313 OPTION_CHANGE_ADDRESSES,
314 OPTION_CHANGE_LEADING_CHAR,
315 OPTION_CHANGE_SECTION_ADDRESS,
316 OPTION_CHANGE_SECTION_LMA,
317 OPTION_CHANGE_SECTION_VMA,
318 OPTION_CHANGE_START,
319 OPTION_CHANGE_WARNINGS,
320 OPTION_COMPRESS_DEBUG_SECTIONS,
321 OPTION_DEBUGGING,
322 OPTION_DECOMPRESS_DEBUG_SECTIONS,
323 OPTION_DUMP_SECTION,
324 OPTION_ELF_STT_COMMON,
325 OPTION_EXTRACT_DWO,
326 OPTION_EXTRACT_SYMBOL,
327 OPTION_FILE_ALIGNMENT,
328 OPTION_FORMATS_INFO,
329 OPTION_GAP_FILL,
330 OPTION_GLOBALIZE_SYMBOL,
331 OPTION_GLOBALIZE_SYMBOLS,
332 OPTION_HEAP,
333 OPTION_IMAGE_BASE,
334 OPTION_IMPURE,
335 OPTION_INTERLEAVE_WIDTH,
336 OPTION_KEEPGLOBAL_SYMBOLS,
337 OPTION_KEEP_FILE_SYMBOLS,
338 OPTION_KEEP_SECTION,
339 OPTION_KEEP_SYMBOLS,
340 OPTION_KEEP_SECTION_SYMBOLS,
341 OPTION_LOCALIZE_HIDDEN,
342 OPTION_LOCALIZE_SYMBOLS,
343 OPTION_LONG_SECTION_NAMES,
344 OPTION_MERGE_NOTES,
345 OPTION_NO_MERGE_NOTES,
346 OPTION_NO_CHANGE_WARNINGS,
347 OPTION_ONLY_KEEP_DEBUG,
348 OPTION_PAD_TO,
349 OPTION_PREFIX_ALLOC_SECTIONS,
350 OPTION_PREFIX_SECTIONS,
351 OPTION_PREFIX_SYMBOLS,
352 OPTION_PURE,
353 OPTION_READONLY_TEXT,
354 OPTION_REDEFINE_SYM,
355 OPTION_REDEFINE_SYMS,
356 OPTION_REMOVE_LEADING_CHAR,
357 OPTION_REMOVE_RELOCS,
358 OPTION_RENAME_SECTION,
359 OPTION_REVERSE_BYTES,
360 OPTION_PE_SECTION_ALIGNMENT,
361 OPTION_SET_SECTION_FLAGS,
362 OPTION_SET_SECTION_ALIGNMENT,
363 OPTION_SET_START,
364 OPTION_SREC_FORCES3,
365 OPTION_SREC_LEN,
366 OPTION_STACK,
367 OPTION_STRIP_DWO,
368 OPTION_STRIP_SYMBOLS,
369 OPTION_STRIP_UNNEEDED,
370 OPTION_STRIP_UNNEEDED_SYMBOL,
371 OPTION_STRIP_UNNEEDED_SYMBOLS,
372 OPTION_SUBSYSTEM,
373 OPTION_UPDATE_SECTION,
374 OPTION_VERILOG_DATA_WIDTH,
375 OPTION_WEAKEN,
376 OPTION_WEAKEN_SYMBOLS,
377 OPTION_WRITABLE_TEXT
380 /* Options to handle if running as "strip". */
382 static struct option strip_options[] =
384 {"disable-deterministic-archives", no_argument, 0, 'U'},
385 {"discard-all", no_argument, 0, 'x'},
386 {"discard-locals", no_argument, 0, 'X'},
387 {"enable-deterministic-archives", no_argument, 0, 'D'},
388 {"format", required_argument, 0, 'F'}, /* Obsolete */
389 {"help", no_argument, 0, 'h'},
390 {"info", no_argument, 0, OPTION_FORMATS_INFO},
391 {"input-format", required_argument, 0, 'I'}, /* Obsolete */
392 {"input-target", required_argument, 0, 'I'},
393 {"keep-section-symbols", no_argument, 0, OPTION_KEEP_SECTION_SYMBOLS},
394 {"keep-file-symbols", no_argument, 0, OPTION_KEEP_FILE_SYMBOLS},
395 {"keep-section", required_argument, 0, OPTION_KEEP_SECTION},
396 {"keep-symbol", required_argument, 0, 'K'},
397 {"merge-notes", no_argument, 0, 'M'},
398 {"no-merge-notes", no_argument, 0, OPTION_NO_MERGE_NOTES},
399 {"only-keep-debug", no_argument, 0, OPTION_ONLY_KEEP_DEBUG},
400 {"output-file", required_argument, 0, 'o'},
401 {"output-format", required_argument, 0, 'O'}, /* Obsolete */
402 {"output-target", required_argument, 0, 'O'},
403 {"preserve-dates", no_argument, 0, 'p'},
404 {"remove-section", required_argument, 0, 'R'},
405 {"remove-relocations", required_argument, 0, OPTION_REMOVE_RELOCS},
406 {"strip-all", no_argument, 0, 's'},
407 {"strip-debug", no_argument, 0, 'S'},
408 {"strip-dwo", no_argument, 0, OPTION_STRIP_DWO},
409 {"strip-symbol", required_argument, 0, 'N'},
410 {"strip-unneeded", no_argument, 0, OPTION_STRIP_UNNEEDED},
411 {"target", required_argument, 0, 'F'},
412 {"verbose", no_argument, 0, 'v'},
413 {"version", no_argument, 0, 'V'},
414 {"wildcard", no_argument, 0, 'w'},
415 {0, no_argument, 0, 0}
418 /* Options to handle if running as "objcopy". */
420 static struct option copy_options[] =
422 {"add-gnu-debuglink", required_argument, 0, OPTION_ADD_GNU_DEBUGLINK},
423 {"add-section", required_argument, 0, OPTION_ADD_SECTION},
424 {"add-symbol", required_argument, 0, OPTION_ADD_SYMBOL},
425 {"adjust-section-vma", required_argument, 0, OPTION_CHANGE_SECTION_ADDRESS},
426 {"adjust-start", required_argument, 0, OPTION_CHANGE_START},
427 {"adjust-vma", required_argument, 0, OPTION_CHANGE_ADDRESSES},
428 {"adjust-warnings", no_argument, 0, OPTION_CHANGE_WARNINGS},
429 {"alt-machine-code", required_argument, 0, OPTION_ALT_MACH_CODE},
430 {"binary-architecture", required_argument, 0, 'B'},
431 {"byte", required_argument, 0, 'b'},
432 {"change-addresses", required_argument, 0, OPTION_CHANGE_ADDRESSES},
433 {"change-leading-char", no_argument, 0, OPTION_CHANGE_LEADING_CHAR},
434 {"change-section-address", required_argument, 0, OPTION_CHANGE_SECTION_ADDRESS},
435 {"change-section-lma", required_argument, 0, OPTION_CHANGE_SECTION_LMA},
436 {"change-section-vma", required_argument, 0, OPTION_CHANGE_SECTION_VMA},
437 {"change-start", required_argument, 0, OPTION_CHANGE_START},
438 {"change-warnings", no_argument, 0, OPTION_CHANGE_WARNINGS},
439 {"compress-debug-sections", optional_argument, 0, OPTION_COMPRESS_DEBUG_SECTIONS},
440 {"debugging", no_argument, 0, OPTION_DEBUGGING},
441 {"decompress-debug-sections", no_argument, 0, OPTION_DECOMPRESS_DEBUG_SECTIONS},
442 {"disable-deterministic-archives", no_argument, 0, 'U'},
443 {"discard-all", no_argument, 0, 'x'},
444 {"discard-locals", no_argument, 0, 'X'},
445 {"dump-section", required_argument, 0, OPTION_DUMP_SECTION},
446 {"elf-stt-common", required_argument, 0, OPTION_ELF_STT_COMMON},
447 {"enable-deterministic-archives", no_argument, 0, 'D'},
448 {"extract-dwo", no_argument, 0, OPTION_EXTRACT_DWO},
449 {"extract-symbol", no_argument, 0, OPTION_EXTRACT_SYMBOL},
450 {"file-alignment", required_argument, 0, OPTION_FILE_ALIGNMENT},
451 {"format", required_argument, 0, 'F'}, /* Obsolete */
452 {"gap-fill", required_argument, 0, OPTION_GAP_FILL},
453 {"globalize-symbol", required_argument, 0, OPTION_GLOBALIZE_SYMBOL},
454 {"globalize-symbols", required_argument, 0, OPTION_GLOBALIZE_SYMBOLS},
455 {"heap", required_argument, 0, OPTION_HEAP},
456 {"help", no_argument, 0, 'h'},
457 {"image-base", required_argument, 0 , OPTION_IMAGE_BASE},
458 {"impure", no_argument, 0, OPTION_IMPURE},
459 {"info", no_argument, 0, OPTION_FORMATS_INFO},
460 {"input-format", required_argument, 0, 'I'}, /* Obsolete */
461 {"input-target", required_argument, 0, 'I'},
462 {"interleave", optional_argument, 0, 'i'},
463 {"interleave-width", required_argument, 0, OPTION_INTERLEAVE_WIDTH},
464 {"keep-file-symbols", no_argument, 0, OPTION_KEEP_FILE_SYMBOLS},
465 {"keep-global-symbol", required_argument, 0, 'G'},
466 {"keep-global-symbols", required_argument, 0, OPTION_KEEPGLOBAL_SYMBOLS},
467 {"keep-section", required_argument, 0, OPTION_KEEP_SECTION},
468 {"keep-symbol", required_argument, 0, 'K'},
469 {"keep-symbols", required_argument, 0, OPTION_KEEP_SYMBOLS},
470 {"keep-section-symbols", required_argument, 0, OPTION_KEEP_SECTION_SYMBOLS},
471 {"localize-hidden", no_argument, 0, OPTION_LOCALIZE_HIDDEN},
472 {"localize-symbol", required_argument, 0, 'L'},
473 {"localize-symbols", required_argument, 0, OPTION_LOCALIZE_SYMBOLS},
474 {"long-section-names", required_argument, 0, OPTION_LONG_SECTION_NAMES},
475 {"merge-notes", no_argument, 0, 'M'},
476 {"no-merge-notes", no_argument, 0, OPTION_NO_MERGE_NOTES},
477 {"no-adjust-warnings", no_argument, 0, OPTION_NO_CHANGE_WARNINGS},
478 {"no-change-warnings", no_argument, 0, OPTION_NO_CHANGE_WARNINGS},
479 {"only-keep-debug", no_argument, 0, OPTION_ONLY_KEEP_DEBUG},
480 {"only-section", required_argument, 0, 'j'},
481 {"output-format", required_argument, 0, 'O'}, /* Obsolete */
482 {"output-target", required_argument, 0, 'O'},
483 {"pad-to", required_argument, 0, OPTION_PAD_TO},
484 {"prefix-alloc-sections", required_argument, 0, OPTION_PREFIX_ALLOC_SECTIONS},
485 {"prefix-sections", required_argument, 0, OPTION_PREFIX_SECTIONS},
486 {"prefix-symbols", required_argument, 0, OPTION_PREFIX_SYMBOLS},
487 {"preserve-dates", no_argument, 0, 'p'},
488 {"pure", no_argument, 0, OPTION_PURE},
489 {"readonly-text", no_argument, 0, OPTION_READONLY_TEXT},
490 {"redefine-sym", required_argument, 0, OPTION_REDEFINE_SYM},
491 {"redefine-syms", required_argument, 0, OPTION_REDEFINE_SYMS},
492 {"remove-leading-char", no_argument, 0, OPTION_REMOVE_LEADING_CHAR},
493 {"remove-section", required_argument, 0, 'R'},
494 {"remove-relocations", required_argument, 0, OPTION_REMOVE_RELOCS},
495 {"rename-section", required_argument, 0, OPTION_RENAME_SECTION},
496 {"reverse-bytes", required_argument, 0, OPTION_REVERSE_BYTES},
497 {"section-alignment", required_argument, 0, OPTION_PE_SECTION_ALIGNMENT},
498 {"set-section-flags", required_argument, 0, OPTION_SET_SECTION_FLAGS},
499 {"set-section-alignment", required_argument, 0, OPTION_SET_SECTION_ALIGNMENT},
500 {"set-start", required_argument, 0, OPTION_SET_START},
501 {"srec-forceS3", no_argument, 0, OPTION_SREC_FORCES3},
502 {"srec-len", required_argument, 0, OPTION_SREC_LEN},
503 {"stack", required_argument, 0, OPTION_STACK},
504 {"strip-all", no_argument, 0, 'S'},
505 {"strip-debug", no_argument, 0, 'g'},
506 {"strip-dwo", no_argument, 0, OPTION_STRIP_DWO},
507 {"strip-symbol", required_argument, 0, 'N'},
508 {"strip-symbols", required_argument, 0, OPTION_STRIP_SYMBOLS},
509 {"strip-unneeded", no_argument, 0, OPTION_STRIP_UNNEEDED},
510 {"strip-unneeded-symbol", required_argument, 0, OPTION_STRIP_UNNEEDED_SYMBOL},
511 {"strip-unneeded-symbols", required_argument, 0, OPTION_STRIP_UNNEEDED_SYMBOLS},
512 {"subsystem", required_argument, 0, OPTION_SUBSYSTEM},
513 {"target", required_argument, 0, 'F'},
514 {"update-section", required_argument, 0, OPTION_UPDATE_SECTION},
515 {"verbose", no_argument, 0, 'v'},
516 {"verilog-data-width", required_argument, 0, OPTION_VERILOG_DATA_WIDTH},
517 {"version", no_argument, 0, 'V'},
518 {"weaken", no_argument, 0, OPTION_WEAKEN},
519 {"weaken-symbol", required_argument, 0, 'W'},
520 {"weaken-symbols", required_argument, 0, OPTION_WEAKEN_SYMBOLS},
521 {"wildcard", no_argument, 0, 'w'},
522 {"writable-text", no_argument, 0, OPTION_WRITABLE_TEXT},
523 {0, no_argument, 0, 0}
526 /* IMPORTS */
527 extern char *program_name;
529 /* This flag distinguishes between strip and objcopy:
530 1 means this is 'strip'; 0 means this is 'objcopy'.
531 -1 means if we should use argv[0] to decide. */
532 extern int is_strip;
534 /* The maximum length of an S record. This variable is defined in srec.c
535 and can be modified by the --srec-len parameter. */
536 extern unsigned int _bfd_srec_len;
538 /* Restrict the generation of Srecords to type S3 only.
539 This variable is defined in bfd/srec.c and can be toggled
540 on by the --srec-forceS3 command line switch. */
541 extern bool _bfd_srec_forceS3;
543 /* Width of data in bytes for verilog output.
544 This variable is declared in bfd/verilog.c and can be modified by
545 the --verilog-data-width parameter. */
546 extern unsigned int VerilogDataWidth;
548 /* Forward declarations. */
549 static void setup_section (bfd *, asection *, void *);
550 static void setup_bfd_headers (bfd *, bfd *);
551 static void copy_relocations_in_section (bfd *, asection *, void *);
552 static void copy_section (bfd *, asection *, void *);
553 static void get_sections (bfd *, asection *, void *);
554 static int compare_section_lma (const void *, const void *);
555 static void mark_symbols_used_in_relocations (bfd *, asection *, void *);
556 static bool write_debugging_info (bfd *, void *, long *, asymbol ***);
557 static const char *lookup_sym_redefinition (const char *);
558 static const char *find_section_rename (const char *, flagword *);
560 ATTRIBUTE_NORETURN static void
561 copy_usage (FILE *stream, int exit_status)
563 fprintf (stream, _("Usage: %s [option(s)] in-file [out-file]\n"), program_name);
564 fprintf (stream, _(" Copies a binary file, possibly transforming it in the process\n"));
565 fprintf (stream, _(" The options are:\n"));
566 fprintf (stream, _("\
567 -I --input-target <bfdname> Assume input file is in format <bfdname>\n\
568 -O --output-target <bfdname> Create an output file in format <bfdname>\n\
569 -B --binary-architecture <arch> Set output arch, when input is arch-less\n\
570 -F --target <bfdname> Set both input and output format to <bfdname>\n\
571 --debugging Convert debugging information, if possible\n\
572 -p --preserve-dates Copy modified/access timestamps to the output\n"));
573 if (DEFAULT_AR_DETERMINISTIC)
574 fprintf (stream, _("\
575 -D --enable-deterministic-archives\n\
576 Produce deterministic output when stripping archives (default)\n\
577 -U --disable-deterministic-archives\n\
578 Disable -D behavior\n"));
579 else
580 fprintf (stream, _("\
581 -D --enable-deterministic-archives\n\
582 Produce deterministic output when stripping archives\n\
583 -U --disable-deterministic-archives\n\
584 Disable -D behavior (default)\n"));
585 fprintf (stream, _("\
586 -j --only-section <name> Only copy section <name> into the output\n\
587 --add-gnu-debuglink=<file> Add section .gnu_debuglink linking to <file>\n\
588 -R --remove-section <name> Remove section <name> from the output\n\
589 --remove-relocations <name> Remove relocations from section <name>\n\
590 -S --strip-all Remove all symbol and relocation information\n\
591 -g --strip-debug Remove all debugging symbols & sections\n\
592 --strip-dwo Remove all DWO sections\n\
593 --strip-unneeded Remove all symbols not needed by relocations\n\
594 -N --strip-symbol <name> Do not copy symbol <name>\n\
595 --strip-unneeded-symbol <name>\n\
596 Do not copy symbol <name> unless needed by\n\
597 relocations\n\
598 --only-keep-debug Strip everything but the debug information\n\
599 --extract-dwo Copy only DWO sections\n\
600 --extract-symbol Remove section contents but keep symbols\n\
601 --keep-section <name> Do not strip section <name>\n\
602 -K --keep-symbol <name> Do not strip symbol <name>\n\
603 --keep-section-symbols Do not strip section symbols\n\
604 --keep-file-symbols Do not strip file symbol(s)\n\
605 --localize-hidden Turn all ELF hidden symbols into locals\n\
606 -L --localize-symbol <name> Force symbol <name> to be marked as a local\n\
607 --globalize-symbol <name> Force symbol <name> to be marked as a global\n\
608 -G --keep-global-symbol <name> Localize all symbols except <name>\n\
609 -W --weaken-symbol <name> Force symbol <name> to be marked as a weak\n\
610 --weaken Force all global symbols to be marked as weak\n\
611 -w --wildcard Permit wildcard in symbol comparison\n\
612 -x --discard-all Remove all non-global symbols\n\
613 -X --discard-locals Remove any compiler-generated symbols\n\
614 -i --interleave[=<number>] Only copy N out of every <number> bytes\n\
615 --interleave-width <number> Set N for --interleave\n\
616 -b --byte <num> Select byte <num> in every interleaved block\n\
617 --gap-fill <val> Fill gaps between sections with <val>\n\
618 --pad-to <addr> Pad the last section up to address <addr>\n\
619 --set-start <addr> Set the start address to <addr>\n\
620 {--change-start|--adjust-start} <incr>\n\
621 Add <incr> to the start address\n\
622 {--change-addresses|--adjust-vma} <incr>\n\
623 Add <incr> to LMA, VMA and start addresses\n\
624 {--change-section-address|--adjust-section-vma} <name>{=|+|-}<val>\n\
625 Change LMA and VMA of section <name> by <val>\n\
626 --change-section-lma <name>{=|+|-}<val>\n\
627 Change the LMA of section <name> by <val>\n\
628 --change-section-vma <name>{=|+|-}<val>\n\
629 Change the VMA of section <name> by <val>\n\
630 {--[no-]change-warnings|--[no-]adjust-warnings}\n\
631 Warn if a named section does not exist\n\
632 --set-section-flags <name>=<flags>\n\
633 Set section <name>'s properties to <flags>\n\
634 --set-section-alignment <name>=<align>\n\
635 Set section <name>'s alignment to <align> bytes\n\
636 --add-section <name>=<file> Add section <name> found in <file> to output\n\
637 --update-section <name>=<file>\n\
638 Update contents of section <name> with\n\
639 contents found in <file>\n\
640 --dump-section <name>=<file> Dump the contents of section <name> into <file>\n\
641 --rename-section <old>=<new>[,<flags>] Rename section <old> to <new>\n\
642 --long-section-names {enable|disable|keep}\n\
643 Handle long section names in Coff objects.\n\
644 --change-leading-char Force output format's leading character style\n\
645 --remove-leading-char Remove leading character from global symbols\n\
646 --reverse-bytes=<num> Reverse <num> bytes at a time, in output sections with content\n\
647 --redefine-sym <old>=<new> Redefine symbol name <old> to <new>\n\
648 --redefine-syms <file> --redefine-sym for all symbol pairs \n\
649 listed in <file>\n\
650 --srec-len <number> Restrict the length of generated Srecords\n\
651 --srec-forceS3 Restrict the type of generated Srecords to S3\n\
652 --strip-symbols <file> -N for all symbols listed in <file>\n\
653 --strip-unneeded-symbols <file>\n\
654 --strip-unneeded-symbol for all symbols listed\n\
655 in <file>\n\
656 --keep-symbols <file> -K for all symbols listed in <file>\n\
657 --localize-symbols <file> -L for all symbols listed in <file>\n\
658 --globalize-symbols <file> --globalize-symbol for all in <file>\n\
659 --keep-global-symbols <file> -G for all symbols listed in <file>\n\
660 --weaken-symbols <file> -W for all symbols listed in <file>\n\
661 --add-symbol <name>=[<section>:]<value>[,<flags>] Add a symbol\n\
662 --alt-machine-code <index> Use the target's <index>'th alternative machine\n\
663 --writable-text Mark the output text as writable\n\
664 --readonly-text Make the output text write protected\n\
665 --pure Mark the output file as demand paged\n\
666 --impure Mark the output file as impure\n\
667 --prefix-symbols <prefix> Add <prefix> to start of every symbol name\n\
668 --prefix-sections <prefix> Add <prefix> to start of every section name\n\
669 --prefix-alloc-sections <prefix>\n\
670 Add <prefix> to start of every allocatable\n\
671 section name\n\
672 --file-alignment <num> Set PE file alignment to <num>\n\
673 --heap <reserve>[,<commit>] Set PE reserve/commit heap to <reserve>/\n\
674 <commit>\n\
675 --image-base <address> Set PE image base to <address>\n\
676 --section-alignment <num> Set PE section alignment to <num>\n\
677 --stack <reserve>[,<commit>] Set PE reserve/commit stack to <reserve>/\n\
678 <commit>\n\
679 --subsystem <name>[:<version>]\n\
680 Set PE subsystem to <name> [& <version>]\n\
681 --compress-debug-sections[={none|zlib|zlib-gnu|zlib-gabi}]\n\
682 Compress DWARF debug sections using zlib\n\
683 --decompress-debug-sections Decompress DWARF debug sections using zlib\n\
684 --elf-stt-common=[yes|no] Generate ELF common symbols with STT_COMMON\n\
685 type\n\
686 --verilog-data-width <number> Specifies data width, in bytes, for verilog output\n\
687 -M --merge-notes Remove redundant entries in note sections\n\
688 --no-merge-notes Do not attempt to remove redundant notes (default)\n\
689 -v --verbose List all object files modified\n\
690 @<file> Read options from <file>\n\
691 -V --version Display this program's version number\n\
692 -h --help Display this output\n\
693 --info List object formats & architectures supported\n\
694 "));
695 list_supported_targets (program_name, stream);
696 if (REPORT_BUGS_TO[0] && exit_status == 0)
697 fprintf (stream, _("Report bugs to %s\n"), REPORT_BUGS_TO);
698 exit (exit_status);
701 ATTRIBUTE_NORETURN static void
702 strip_usage (FILE *stream, int exit_status)
704 fprintf (stream, _("Usage: %s <option(s)> in-file(s)\n"), program_name);
705 fprintf (stream, _(" Removes symbols and sections from files\n"));
706 fprintf (stream, _(" The options are:\n"));
707 fprintf (stream, _("\
708 -I --input-target=<bfdname> Assume input file is in format <bfdname>\n\
709 -O --output-target=<bfdname> Create an output file in format <bfdname>\n\
710 -F --target=<bfdname> Set both input and output format to <bfdname>\n\
711 -p --preserve-dates Copy modified/access timestamps to the output\n\
712 "));
713 if (DEFAULT_AR_DETERMINISTIC)
714 fprintf (stream, _("\
715 -D --enable-deterministic-archives\n\
716 Produce deterministic output when stripping archives (default)\n\
717 -U --disable-deterministic-archives\n\
718 Disable -D behavior\n"));
719 else
720 fprintf (stream, _("\
721 -D --enable-deterministic-archives\n\
722 Produce deterministic output when stripping archives\n\
723 -U --disable-deterministic-archives\n\
724 Disable -D behavior (default)\n"));
725 fprintf (stream, _("\
726 -R --remove-section=<name> Also remove section <name> from the output\n\
727 --remove-relocations <name> Remove relocations from section <name>\n\
728 -s --strip-all Remove all symbol and relocation information\n\
729 -g -S -d --strip-debug Remove all debugging symbols & sections\n\
730 --strip-dwo Remove all DWO sections\n\
731 --strip-unneeded Remove all symbols not needed by relocations\n\
732 --only-keep-debug Strip everything but the debug information\n\
733 -M --merge-notes Remove redundant entries in note sections (default)\n\
734 --no-merge-notes Do not attempt to remove redundant notes\n\
735 -N --strip-symbol=<name> Do not copy symbol <name>\n\
736 --keep-section=<name> Do not strip section <name>\n\
737 -K --keep-symbol=<name> Do not strip symbol <name>\n\
738 --keep-section-symbols Do not strip section symbols\n\
739 --keep-file-symbols Do not strip file symbol(s)\n\
740 -w --wildcard Permit wildcard in symbol comparison\n\
741 -x --discard-all Remove all non-global symbols\n\
742 -X --discard-locals Remove any compiler-generated symbols\n\
743 -v --verbose List all object files modified\n\
744 -V --version Display this program's version number\n\
745 -h --help Display this output\n\
746 --info List object formats & architectures supported\n\
747 -o <file> Place stripped output into <file>\n\
748 "));
750 list_supported_targets (program_name, stream);
751 if (REPORT_BUGS_TO[0] && exit_status == 0)
752 fprintf (stream, _("Report bugs to %s\n"), REPORT_BUGS_TO);
753 exit (exit_status);
756 /* Parse section flags into a flagword, with a fatal error if the
757 string can't be parsed. */
759 static flagword
760 parse_flags (const char *s)
762 flagword ret;
763 const char *snext;
764 int len;
766 ret = SEC_NO_FLAGS;
770 snext = strchr (s, ',');
771 if (snext == NULL)
772 len = strlen (s);
773 else
775 len = snext - s;
776 ++snext;
779 if (0) ;
780 #define PARSE_FLAG(fname,fval) \
781 else if (strncasecmp (fname, s, len) == 0) ret |= fval
782 PARSE_FLAG ("alloc", SEC_ALLOC);
783 PARSE_FLAG ("load", SEC_LOAD);
784 PARSE_FLAG ("noload", SEC_NEVER_LOAD);
785 PARSE_FLAG ("readonly", SEC_READONLY);
786 PARSE_FLAG ("debug", SEC_DEBUGGING);
787 PARSE_FLAG ("code", SEC_CODE);
788 PARSE_FLAG ("data", SEC_DATA);
789 PARSE_FLAG ("rom", SEC_ROM);
790 PARSE_FLAG ("exclude", SEC_EXCLUDE);
791 PARSE_FLAG ("share", SEC_COFF_SHARED);
792 PARSE_FLAG ("contents", SEC_HAS_CONTENTS);
793 PARSE_FLAG ("merge", SEC_MERGE);
794 PARSE_FLAG ("strings", SEC_STRINGS);
795 #undef PARSE_FLAG
796 else
798 char *copy;
800 copy = (char *) xmalloc (len + 1);
801 strncpy (copy, s, len);
802 copy[len] = '\0';
803 non_fatal (_("unrecognized section flag `%s'"), copy);
804 fatal (_("supported flags: %s"),
805 "alloc, load, noload, readonly, debug, code, data, rom, exclude, share, contents, merge, strings");
808 s = snext;
810 while (s != NULL);
812 return ret;
815 /* Parse symbol flags into a flagword, with a fatal error if the
816 string can't be parsed. */
818 static flagword
819 parse_symflags (const char *s, const char **other)
821 flagword ret;
822 const char *snext;
823 size_t len;
825 ret = BSF_NO_FLAGS;
829 snext = strchr (s, ',');
830 if (snext == NULL)
831 len = strlen (s);
832 else
834 len = snext - s;
835 ++snext;
838 #define PARSE_FLAG(fname, fval) \
839 else if (len == sizeof fname - 1 \
840 && strncasecmp (fname, s, len) == 0) \
841 ret |= fval
843 #define PARSE_OTHER(fname, fval) \
844 else if (len >= sizeof fname \
845 && strncasecmp (fname, s, sizeof fname - 1) == 0) \
846 fval = xstrndup (s + sizeof fname - 1, len - sizeof fname + 1)
848 if (0) ;
849 PARSE_FLAG ("local", BSF_LOCAL);
850 PARSE_FLAG ("global", BSF_GLOBAL);
851 PARSE_FLAG ("export", BSF_EXPORT);
852 PARSE_FLAG ("debug", BSF_DEBUGGING);
853 PARSE_FLAG ("function", BSF_FUNCTION);
854 PARSE_FLAG ("weak", BSF_WEAK);
855 PARSE_FLAG ("section", BSF_SECTION_SYM);
856 PARSE_FLAG ("constructor", BSF_CONSTRUCTOR);
857 PARSE_FLAG ("warning", BSF_WARNING);
858 PARSE_FLAG ("indirect", BSF_INDIRECT);
859 PARSE_FLAG ("file", BSF_FILE);
860 PARSE_FLAG ("object", BSF_OBJECT);
861 PARSE_FLAG ("synthetic", BSF_SYNTHETIC);
862 PARSE_FLAG ("indirect-function", BSF_GNU_INDIRECT_FUNCTION | BSF_FUNCTION);
863 PARSE_FLAG ("unique-object", BSF_GNU_UNIQUE | BSF_OBJECT);
864 PARSE_OTHER ("before=", *other);
866 #undef PARSE_FLAG
867 #undef PARSE_OTHER
868 else
870 char *copy;
872 copy = (char *) xmalloc (len + 1);
873 strncpy (copy, s, len);
874 copy[len] = '\0';
875 non_fatal (_("unrecognized symbol flag `%s'"), copy);
876 fatal (_("supported flags: %s"),
877 "local, global, export, debug, function, weak, section, "
878 "constructor, warning, indirect, file, object, synthetic, "
879 "indirect-function, unique-object, before=<othersym>");
882 s = snext;
884 while (s != NULL);
886 return ret;
889 /* Find and optionally add an entry in the change_sections list.
891 We need to be careful in how we match section names because of the support
892 for wildcard characters. For example suppose that the user has invoked
893 objcopy like this:
895 --set-section-flags .debug_*=debug
896 --set-section-flags .debug_str=readonly,debug
897 --change-section-address .debug_*ranges=0x1000
899 With the idea that all debug sections will receive the DEBUG flag, the
900 .debug_str section will also receive the READONLY flag and the
901 .debug_ranges and .debug_aranges sections will have their address set to
902 0x1000. (This may not make much sense, but it is just an example).
904 When adding the section name patterns to the section list we need to make
905 sure that previous entries do not match with the new entry, unless the
906 match is exact. (In which case we assume that the user is overriding
907 the previous entry with the new context).
909 When matching real section names to the section list we make use of the
910 wildcard characters, but we must do so in context. Eg if we are setting
911 section addresses then we match for .debug_ranges but not for .debug_info.
913 Finally, if ADD is false and we do find a match, we mark the section list
914 entry as used. */
916 static struct section_list *
917 find_section_list (const char *name, bool add, unsigned int context)
919 struct section_list *p, *match = NULL;
921 /* assert ((context & ((1 << 7) - 1)) != 0); */
923 for (p = change_sections; p != NULL; p = p->next)
925 if (add)
927 if (strcmp (p->pattern, name) == 0)
929 /* Check for context conflicts. */
930 if (((p->context & SECTION_CONTEXT_REMOVE)
931 && (context & SECTION_CONTEXT_COPY))
932 || ((context & SECTION_CONTEXT_REMOVE)
933 && (p->context & SECTION_CONTEXT_COPY)))
934 fatal (_("error: %s both copied and removed"), name);
936 if (((p->context & SECTION_CONTEXT_SET_VMA)
937 && (context & SECTION_CONTEXT_ALTER_VMA))
938 || ((context & SECTION_CONTEXT_SET_VMA)
939 && (context & SECTION_CONTEXT_ALTER_VMA)))
940 fatal (_("error: %s both sets and alters VMA"), name);
942 if (((p->context & SECTION_CONTEXT_SET_LMA)
943 && (context & SECTION_CONTEXT_ALTER_LMA))
944 || ((context & SECTION_CONTEXT_SET_LMA)
945 && (context & SECTION_CONTEXT_ALTER_LMA)))
946 fatal (_("error: %s both sets and alters LMA"), name);
948 /* Extend the context. */
949 p->context |= context;
950 return p;
953 /* If we are not adding a new name/pattern then
954 only check for a match if the context applies. */
955 else if (p->context & context)
957 /* We could check for the presence of wildchar characters
958 first and choose between calling strcmp and fnmatch,
959 but is that really worth it ? */
960 if (p->pattern [0] == '!')
962 if (fnmatch (p->pattern + 1, name, 0) == 0)
964 p->used = true;
965 return NULL;
968 else
970 if (fnmatch (p->pattern, name, 0) == 0)
972 if (match == NULL)
973 match = p;
979 if (! add)
981 if (match != NULL)
982 match->used = true;
983 return match;
986 p = (struct section_list *) xmalloc (sizeof (struct section_list));
987 p->pattern = name;
988 p->used = false;
989 p->context = context;
990 p->vma_val = 0;
991 p->lma_val = 0;
992 p->flags = 0;
993 p->alignment = 0;
994 p->next = change_sections;
995 change_sections = p;
997 return p;
1000 /* S1 is the entry node already in the table, S2 is the key node. */
1002 static int
1003 eq_string_redefnode (const void *s1, const void *s2)
1005 struct redefine_node *node1 = (struct redefine_node *) s1;
1006 struct redefine_node *node2 = (struct redefine_node *) s2;
1007 return !strcmp ((const char *) node1->source, (const char *) node2->source);
1010 /* P is redefine node. Hash value is generated from its "source" filed. */
1012 static hashval_t
1013 htab_hash_redefnode (const void *p)
1015 struct redefine_node *redefnode = (struct redefine_node *) p;
1016 return htab_hash_string (redefnode->source);
1019 /* Create hashtab used for redefine node. */
1021 static htab_t
1022 create_symbol2redef_htab (void)
1024 return htab_create_alloc (16, htab_hash_redefnode, eq_string_redefnode, NULL,
1025 xcalloc, free);
1028 static htab_t
1029 create_symbol_htab (void)
1031 return htab_create_alloc (16, htab_hash_string, htab_eq_string, NULL,
1032 xcalloc, free);
1035 static void
1036 create_symbol_htabs (void)
1038 strip_specific_htab = create_symbol_htab ();
1039 strip_unneeded_htab = create_symbol_htab ();
1040 keep_specific_htab = create_symbol_htab ();
1041 localize_specific_htab = create_symbol_htab ();
1042 globalize_specific_htab = create_symbol_htab ();
1043 keepglobal_specific_htab = create_symbol_htab ();
1044 weaken_specific_htab = create_symbol_htab ();
1045 redefine_specific_htab = create_symbol2redef_htab ();
1046 /* As there is no bidirectional hash table in libiberty, need a reverse table
1047 to check duplicated target string. */
1048 redefine_specific_reverse_htab = create_symbol_htab ();
1051 /* Add a symbol to strip_specific_list. */
1053 static void
1054 add_specific_symbol (const char *name, htab_t htab)
1056 *htab_find_slot (htab, name, INSERT) = (char *) name;
1059 /* Like add_specific_symbol, but the element type is void *. */
1061 static void
1062 add_specific_symbol_node (const void *node, htab_t htab)
1064 *htab_find_slot (htab, node, INSERT) = (void *) node;
1067 /* Add symbols listed in `filename' to strip_specific_list. */
1069 #define IS_WHITESPACE(c) ((c) == ' ' || (c) == '\t')
1070 #define IS_LINE_TERMINATOR(c) ((c) == '\n' || (c) == '\r' || (c) == '\0')
1072 static void
1073 add_specific_symbols (const char *filename, htab_t htab, char **buffer_p)
1075 off_t size;
1076 FILE * f;
1077 char * line;
1078 char * buffer;
1079 unsigned int line_count;
1081 size = get_file_size (filename);
1082 if (size == 0)
1084 status = 1;
1085 return;
1088 buffer = (char *) xmalloc (size + 2);
1089 f = fopen (filename, FOPEN_RT);
1090 if (f == NULL)
1091 fatal (_("cannot open '%s': %s"), filename, strerror (errno));
1093 if (fread (buffer, 1, size, f) == 0 || ferror (f))
1094 fatal (_("%s: fread failed"), filename);
1096 fclose (f);
1097 buffer [size] = '\n';
1098 buffer [size + 1] = '\0';
1100 line_count = 1;
1102 for (line = buffer; * line != '\0'; line ++)
1104 char * eol;
1105 char * name;
1106 char * name_end;
1107 int finished = false;
1109 for (eol = line;; eol ++)
1111 switch (* eol)
1113 case '\n':
1114 * eol = '\0';
1115 /* Cope with \n\r. */
1116 if (eol[1] == '\r')
1117 ++ eol;
1118 finished = true;
1119 break;
1121 case '\r':
1122 * eol = '\0';
1123 /* Cope with \r\n. */
1124 if (eol[1] == '\n')
1125 ++ eol;
1126 finished = true;
1127 break;
1129 case 0:
1130 finished = true;
1131 break;
1133 case '#':
1134 /* Line comment, Terminate the line here, in case a
1135 name is present and then allow the rest of the
1136 loop to find the real end of the line. */
1137 * eol = '\0';
1138 break;
1140 default:
1141 break;
1144 if (finished)
1145 break;
1148 /* A name may now exist somewhere between 'line' and 'eol'.
1149 Strip off leading whitespace and trailing whitespace,
1150 then add it to the list. */
1151 for (name = line; IS_WHITESPACE (* name); name ++)
1153 for (name_end = name;
1154 (! IS_WHITESPACE (* name_end))
1155 && (! IS_LINE_TERMINATOR (* name_end));
1156 name_end ++)
1159 if (! IS_LINE_TERMINATOR (* name_end))
1161 char * extra;
1163 for (extra = name_end + 1; IS_WHITESPACE (* extra); extra ++)
1166 if (! IS_LINE_TERMINATOR (* extra))
1167 non_fatal (_("%s:%d: Ignoring rubbish found on this line"),
1168 filename, line_count);
1171 * name_end = '\0';
1173 if (name_end > name)
1174 add_specific_symbol (name, htab);
1176 /* Advance line pointer to end of line. The 'eol ++' in the for
1177 loop above will then advance us to the start of the next line. */
1178 line = eol;
1179 line_count ++;
1182 /* Do not free the buffer. Parts of it will have been referenced
1183 in the calls to add_specific_symbol. */
1184 *buffer_p = buffer;
1187 /* See whether a symbol should be stripped or kept
1188 based on strip_specific_list and keep_symbols. */
1190 static int
1191 is_specified_symbol_predicate (void **slot, void *data)
1193 struct is_specified_symbol_predicate_data *d =
1194 (struct is_specified_symbol_predicate_data *) data;
1195 const char *slot_name = (char *) *slot;
1197 if (*slot_name != '!')
1199 if (! fnmatch (slot_name, d->name, 0))
1201 d->found = true;
1202 /* Continue traversal, there might be a non-match rule. */
1203 return 1;
1206 else
1208 if (! fnmatch (slot_name + 1, d->name, 0))
1210 d->found = false;
1211 /* Stop traversal. */
1212 return 0;
1216 /* Continue traversal. */
1217 return 1;
1220 static bool
1221 is_specified_symbol (const char *name, htab_t htab)
1223 if (wildcard)
1225 struct is_specified_symbol_predicate_data data;
1227 data.name = name;
1228 data.found = false;
1230 htab_traverse (htab, is_specified_symbol_predicate, &data);
1232 return data.found;
1235 return htab_find (htab, name) != NULL;
1238 /* Return a pointer to the symbol used as a signature for GROUP. */
1240 static asymbol *
1241 group_signature (asection *group)
1243 bfd *abfd = group->owner;
1244 Elf_Internal_Shdr *ghdr;
1246 /* PR 20089: An earlier error may have prevented us from loading the symbol table. */
1247 if (isympp == NULL)
1248 return NULL;
1250 if (bfd_get_flavour (abfd) != bfd_target_elf_flavour)
1251 return NULL;
1253 ghdr = &elf_section_data (group)->this_hdr;
1254 if (ghdr->sh_link == elf_onesymtab (abfd))
1256 const struct elf_backend_data *bed = get_elf_backend_data (abfd);
1257 Elf_Internal_Shdr *symhdr = &elf_symtab_hdr (abfd);
1259 if (ghdr->sh_info > 0
1260 && ghdr->sh_info < symhdr->sh_size / bed->s->sizeof_sym)
1261 return isympp[ghdr->sh_info - 1];
1263 return NULL;
1266 /* Return TRUE if the section is a DWO section. */
1268 static bool
1269 is_dwo_section (bfd *abfd ATTRIBUTE_UNUSED, asection *sec)
1271 const char *name;
1272 int len;
1274 if (sec == NULL || (name = bfd_section_name (sec)) == NULL)
1275 return false;
1277 len = strlen (name);
1278 if (len < 5)
1279 return false;
1281 return startswith (name + len - 4, ".dwo");
1284 /* Return TRUE if section SEC is in the update list. */
1286 static bool
1287 is_update_section (bfd *abfd ATTRIBUTE_UNUSED, asection *sec)
1289 if (update_sections != NULL)
1291 struct section_add *pupdate;
1293 for (pupdate = update_sections;
1294 pupdate != NULL;
1295 pupdate = pupdate->next)
1297 if (strcmp (sec->name, pupdate->name) == 0)
1298 return true;
1302 return false;
1305 static bool
1306 is_mergeable_note_section (bfd * abfd, asection * sec)
1308 if (merge_notes
1309 && bfd_get_flavour (abfd) == bfd_target_elf_flavour
1310 && elf_section_data (sec)->this_hdr.sh_type == SHT_NOTE
1311 /* FIXME: We currently only support merging GNU_BUILD_NOTEs.
1312 We should add support for more note types. */
1313 && (startswith (sec->name, GNU_BUILD_ATTRS_SECTION_NAME)))
1314 return true;
1316 return false;
1319 /* See if a non-group section is being removed. */
1321 static bool
1322 is_strip_section_1 (bfd *abfd ATTRIBUTE_UNUSED, asection *sec)
1324 if (find_section_list (bfd_section_name (sec), false, SECTION_CONTEXT_KEEP)
1325 != NULL)
1326 return false;
1328 if (sections_removed || sections_copied)
1330 struct section_list *p;
1331 struct section_list *q;
1333 p = find_section_list (bfd_section_name (sec), false,
1334 SECTION_CONTEXT_REMOVE);
1335 q = find_section_list (bfd_section_name (sec), false,
1336 SECTION_CONTEXT_COPY);
1338 if (p && q)
1339 fatal (_("error: section %s matches both remove and copy options"),
1340 bfd_section_name (sec));
1341 if (p && is_update_section (abfd, sec))
1342 fatal (_("error: section %s matches both update and remove options"),
1343 bfd_section_name (sec));
1345 if (p != NULL)
1346 return true;
1347 if (sections_copied && q == NULL)
1348 return true;
1351 if ((bfd_section_flags (sec) & SEC_DEBUGGING) != 0)
1353 if (strip_symbols == STRIP_DEBUG
1354 || strip_symbols == STRIP_UNNEEDED
1355 || strip_symbols == STRIP_ALL
1356 || discard_locals == LOCALS_ALL
1357 || convert_debugging)
1359 /* By default we don't want to strip .reloc section.
1360 This section has for pe-coff special meaning. See
1361 pe-dll.c file in ld, and peXXigen.c in bfd for details.
1362 Similarly we do not want to strip debuglink sections. */
1363 const char * kept_sections[] =
1365 ".reloc",
1366 ".gnu_debuglink",
1367 ".gnu_debugaltlink"
1369 int i;
1371 for (i = ARRAY_SIZE (kept_sections);i--;)
1372 if (strcmp (bfd_section_name (sec), kept_sections[i]) == 0)
1373 break;
1374 if (i == -1)
1375 return true;
1378 if (strip_symbols == STRIP_DWO)
1379 return is_dwo_section (abfd, sec);
1381 if (strip_symbols == STRIP_NONDEBUG)
1382 return false;
1385 if (strip_symbols == STRIP_NONDWO)
1386 return !is_dwo_section (abfd, sec);
1388 return false;
1391 /* See if a section is being removed. */
1393 static bool
1394 is_strip_section (bfd *abfd ATTRIBUTE_UNUSED, asection *sec)
1396 if (is_strip_section_1 (abfd, sec))
1397 return true;
1399 if ((bfd_section_flags (sec) & SEC_GROUP) != 0)
1401 asymbol *gsym;
1402 const char *gname;
1403 asection *elt, *first;
1405 gsym = group_signature (sec);
1406 /* Strip groups without a valid signature. */
1407 if (gsym == NULL)
1408 return true;
1410 /* PR binutils/3181
1411 If we are going to strip the group signature symbol, then
1412 strip the group section too. */
1413 gname = gsym->name;
1414 if ((strip_symbols == STRIP_ALL
1415 && !is_specified_symbol (gname, keep_specific_htab))
1416 || is_specified_symbol (gname, strip_specific_htab))
1417 return true;
1419 /* Remove the group section if all members are removed. */
1420 first = elt = elf_next_in_group (sec);
1421 while (elt != NULL)
1423 if (!is_strip_section_1 (abfd, elt))
1424 return false;
1425 elt = elf_next_in_group (elt);
1426 if (elt == first)
1427 break;
1430 return true;
1433 return false;
1436 static bool
1437 is_nondebug_keep_contents_section (bfd *ibfd, asection *isection)
1439 /* Always keep ELF note sections. */
1440 if (bfd_get_flavour (ibfd) == bfd_target_elf_flavour)
1441 return elf_section_type (isection) == SHT_NOTE;
1443 /* Always keep the .buildid section for PE/COFF.
1445 Strictly, this should be written "always keep the section storing the debug
1446 directory", but that may be the .text section for objects produced by some
1447 tools, which it is not sensible to keep. */
1448 if (bfd_get_flavour (ibfd) == bfd_target_coff_flavour)
1449 return strcmp (bfd_section_name (isection), ".buildid") == 0;
1451 return false;
1454 /* Return true if SYM is a hidden symbol. */
1456 static bool
1457 is_hidden_symbol (asymbol *sym)
1459 elf_symbol_type *elf_sym;
1461 elf_sym = elf_symbol_from (sym);
1462 if (elf_sym != NULL)
1463 switch (ELF_ST_VISIBILITY (elf_sym->internal_elf_sym.st_other))
1465 case STV_HIDDEN:
1466 case STV_INTERNAL:
1467 return true;
1469 return false;
1472 /* Empty name is hopefully never a valid symbol name. */
1473 static const char * empty_name = "";
1475 static bool
1476 need_sym_before (struct addsym_node **node, const char *sym)
1478 int count;
1479 struct addsym_node *ptr = add_sym_list;
1481 /* 'othersym' symbols are at the front of the list. */
1482 for (count = 0; count < add_symbols; count++)
1484 if (!ptr->othersym)
1485 break;
1486 if (ptr->othersym == empty_name)
1487 continue;
1488 else if (strcmp (ptr->othersym, sym) == 0)
1490 free ((char *) ptr->othersym);
1491 ptr->othersym = empty_name;
1492 *node = ptr;
1493 return true;
1495 ptr = ptr->next;
1497 return false;
1500 static asymbol *
1501 create_new_symbol (struct addsym_node *ptr, bfd *obfd)
1503 asymbol *sym = bfd_make_empty_symbol (obfd);
1505 bfd_set_asymbol_name (sym, ptr->symdef);
1506 sym->value = ptr->symval;
1507 sym->flags = ptr->flags;
1508 if (ptr->section)
1510 asection *sec = bfd_get_section_by_name (obfd, ptr->section);
1511 if (!sec)
1512 fatal (_("Section %s not found"), ptr->section);
1513 sym->section = sec;
1515 else
1516 sym->section = bfd_abs_section_ptr;
1517 return sym;
1520 /* Choose which symbol entries to copy; put the result in OSYMS.
1521 We don't copy in place, because that confuses the relocs.
1522 Return the number of symbols to print. */
1524 static unsigned int
1525 filter_symbols (bfd *abfd, bfd *obfd, asymbol **osyms,
1526 asymbol **isyms, long symcount)
1528 asymbol **from = isyms, **to = osyms;
1529 long src_count = 0, dst_count = 0;
1530 int relocatable = (abfd->flags & (EXEC_P | DYNAMIC)) == 0;
1532 for (; src_count < symcount; src_count++)
1534 asymbol *sym = from[src_count];
1535 flagword flags = sym->flags;
1536 char *name = (char *) bfd_asymbol_name (sym);
1537 bool keep;
1538 bool used_in_reloc = false;
1539 bool undefined;
1540 bool rem_leading_char;
1541 bool add_leading_char;
1543 undefined = bfd_is_und_section (bfd_asymbol_section (sym));
1545 if (add_sym_list)
1547 struct addsym_node *ptr;
1549 if (need_sym_before (&ptr, name))
1550 to[dst_count++] = create_new_symbol (ptr, obfd);
1553 if (htab_elements (redefine_specific_htab) || section_rename_list)
1555 char *new_name;
1557 if (name != NULL
1558 && name[0] == '_'
1559 && name[1] == '_'
1560 && strcmp (name + (name[2] == '_'), "__gnu_lto_slim") == 0)
1562 fatal (_("redefining symbols does not work on LTO-compiled object files"));
1565 new_name = (char *) lookup_sym_redefinition (name);
1566 if (new_name == name
1567 && (flags & BSF_SECTION_SYM) != 0)
1568 new_name = (char *) find_section_rename (name, NULL);
1569 bfd_set_asymbol_name (sym, new_name);
1570 name = new_name;
1573 /* Check if we will remove the current leading character. */
1574 rem_leading_char =
1575 (name[0] != '\0'
1576 && name[0] == bfd_get_symbol_leading_char (abfd)
1577 && (change_leading_char
1578 || (remove_leading_char
1579 && ((flags & (BSF_GLOBAL | BSF_WEAK)) != 0
1580 || undefined
1581 || bfd_is_com_section (bfd_asymbol_section (sym))))));
1583 /* Check if we will add a new leading character. */
1584 add_leading_char =
1585 change_leading_char
1586 && (bfd_get_symbol_leading_char (obfd) != '\0')
1587 && (bfd_get_symbol_leading_char (abfd) == '\0'
1588 || (name[0] == bfd_get_symbol_leading_char (abfd)));
1590 /* Short circuit for change_leading_char if we can do it in-place. */
1591 if (rem_leading_char && add_leading_char && !prefix_symbols_string)
1593 name[0] = bfd_get_symbol_leading_char (obfd);
1594 bfd_set_asymbol_name (sym, name);
1595 rem_leading_char = false;
1596 add_leading_char = false;
1599 /* Remove leading char. */
1600 if (rem_leading_char)
1601 bfd_set_asymbol_name (sym, ++name);
1603 /* Add new leading char and/or prefix. */
1604 if (add_leading_char || prefix_symbols_string)
1606 char *n, *ptr;
1607 size_t len = strlen (name) + 1;
1609 if (add_leading_char)
1610 len++;
1611 if (prefix_symbols_string)
1612 len += strlen (prefix_symbols_string);
1614 ptr = n = (char *) xmalloc (len);
1615 if (add_leading_char)
1616 *ptr++ = bfd_get_symbol_leading_char (obfd);
1618 if (prefix_symbols_string)
1620 strcpy (ptr, prefix_symbols_string);
1621 ptr += strlen (prefix_symbols_string);
1624 strcpy (ptr, name);
1625 bfd_set_asymbol_name (sym, n);
1626 name = n;
1629 if (strip_symbols == STRIP_ALL)
1630 keep = false;
1631 else if ((flags & BSF_KEEP) != 0 /* Used in relocation. */
1632 || ((flags & BSF_SECTION_SYM) != 0
1633 && ((*bfd_asymbol_section (sym)->symbol_ptr_ptr)->flags
1634 & BSF_KEEP) != 0))
1636 keep = true;
1637 used_in_reloc = true;
1639 else if (relocatable /* Relocatable file. */
1640 && ((flags & (BSF_GLOBAL | BSF_WEAK)) != 0
1641 || bfd_is_com_section (bfd_asymbol_section (sym))))
1642 keep = true;
1643 else if (bfd_decode_symclass (sym) == 'I')
1644 /* Global symbols in $idata sections need to be retained
1645 even if relocatable is FALSE. External users of the
1646 library containing the $idata section may reference these
1647 symbols. */
1648 keep = true;
1649 else if ((flags & BSF_GLOBAL) != 0 /* Global symbol. */
1650 || (flags & BSF_WEAK) != 0
1651 || undefined
1652 || bfd_is_com_section (bfd_asymbol_section (sym)))
1653 keep = strip_symbols != STRIP_UNNEEDED;
1654 else if ((flags & BSF_DEBUGGING) != 0) /* Debugging symbol. */
1655 keep = (strip_symbols != STRIP_DEBUG
1656 && strip_symbols != STRIP_UNNEEDED
1657 && ! convert_debugging);
1658 else if (bfd_coff_get_comdat_section (abfd, bfd_asymbol_section (sym)))
1659 /* COMDAT sections store special information in local
1660 symbols, so we cannot risk stripping any of them. */
1661 keep = true;
1662 else /* Local symbol. */
1663 keep = (strip_symbols != STRIP_UNNEEDED
1664 && (discard_locals != LOCALS_ALL
1665 && (discard_locals != LOCALS_START_L
1666 || ! bfd_is_local_label (abfd, sym))));
1668 if (keep && is_specified_symbol (name, strip_specific_htab))
1670 /* There are multiple ways to set 'keep' above, but if it
1671 was the relocatable symbol case, then that's an error. */
1672 if (used_in_reloc)
1674 non_fatal (_("not stripping symbol `%s' because it is named in a relocation"), name);
1675 status = 1;
1677 else
1678 keep = false;
1681 if (keep
1682 && !(flags & BSF_KEEP)
1683 && is_specified_symbol (name, strip_unneeded_htab))
1684 keep = false;
1686 if (!keep
1687 && ((keep_file_symbols && (flags & BSF_FILE))
1688 || is_specified_symbol (name, keep_specific_htab)))
1689 keep = true;
1691 if (keep && is_strip_section (abfd, bfd_asymbol_section (sym)))
1692 keep = false;
1694 if (keep)
1696 if (((flags & (BSF_GLOBAL | BSF_GNU_UNIQUE))
1697 || undefined)
1698 && (weaken || is_specified_symbol (name, weaken_specific_htab)))
1700 sym->flags &= ~ (BSF_GLOBAL | BSF_GNU_UNIQUE);
1701 sym->flags |= BSF_WEAK;
1704 if (!undefined
1705 && (flags & (BSF_GLOBAL | BSF_WEAK))
1706 && (is_specified_symbol (name, localize_specific_htab)
1707 || (htab_elements (keepglobal_specific_htab) != 0
1708 && ! is_specified_symbol (name, keepglobal_specific_htab))
1709 || (localize_hidden && is_hidden_symbol (sym))))
1711 sym->flags &= ~ (BSF_GLOBAL | BSF_WEAK);
1712 sym->flags |= BSF_LOCAL;
1715 if (!undefined
1716 && (flags & BSF_LOCAL)
1717 && is_specified_symbol (name, globalize_specific_htab))
1719 sym->flags &= ~ BSF_LOCAL;
1720 sym->flags |= BSF_GLOBAL;
1723 to[dst_count++] = sym;
1726 if (add_sym_list)
1728 struct addsym_node *ptr = add_sym_list;
1730 for (src_count = 0; src_count < add_symbols; src_count++)
1732 if (ptr->othersym)
1734 if (ptr->othersym != empty_name)
1735 fatal (_("'before=%s' not found"), ptr->othersym);
1737 else
1738 to[dst_count++] = create_new_symbol (ptr, obfd);
1740 ptr = ptr->next;
1744 to[dst_count] = NULL;
1746 return dst_count;
1749 /* Find the redefined name of symbol SOURCE. */
1751 static const char *
1752 lookup_sym_redefinition (const char *source)
1754 struct redefine_node key_node = {(char *) source, NULL};
1755 struct redefine_node *redef_node
1756 = (struct redefine_node *) htab_find (redefine_specific_htab, &key_node);
1758 return redef_node == NULL ? source : redef_node->target;
1761 /* Insert a node into symbol redefine hash tabel. */
1763 static void
1764 add_redefine_and_check (const char *cause, const char *source,
1765 const char *target)
1767 struct redefine_node *new_node
1768 = (struct redefine_node *) xmalloc (sizeof (struct redefine_node));
1770 new_node->source = strdup (source);
1771 new_node->target = strdup (target);
1773 if (htab_find (redefine_specific_htab, new_node) != HTAB_EMPTY_ENTRY)
1774 fatal (_("%s: Multiple redefinition of symbol \"%s\""),
1775 cause, source);
1777 if (htab_find (redefine_specific_reverse_htab, target) != HTAB_EMPTY_ENTRY)
1778 fatal (_("%s: Symbol \"%s\" is target of more than one redefinition"),
1779 cause, target);
1781 /* Insert the NEW_NODE into hash table for quick search. */
1782 add_specific_symbol_node (new_node, redefine_specific_htab);
1784 /* Insert the target string into the reverse hash table, this is needed for
1785 duplicated target string check. */
1786 add_specific_symbol (new_node->target, redefine_specific_reverse_htab);
1790 /* Handle the --redefine-syms option. Read lines containing "old new"
1791 from the file, and add them to the symbol redefine list. */
1793 static void
1794 add_redefine_syms_file (const char *filename)
1796 FILE *file;
1797 char *buf;
1798 size_t bufsize;
1799 size_t len;
1800 size_t outsym_off;
1801 int c, lineno;
1803 file = fopen (filename, "r");
1804 if (file == NULL)
1805 fatal (_("couldn't open symbol redefinition file %s (error: %s)"),
1806 filename, strerror (errno));
1808 bufsize = 100;
1809 buf = (char *) xmalloc (bufsize + 1 /* For the terminating NUL. */);
1811 lineno = 1;
1812 c = getc (file);
1813 len = 0;
1814 outsym_off = 0;
1815 while (c != EOF)
1817 /* Collect the input symbol name. */
1818 while (! IS_WHITESPACE (c) && ! IS_LINE_TERMINATOR (c) && c != EOF)
1820 if (c == '#')
1821 goto comment;
1822 buf[len++] = c;
1823 if (len >= bufsize)
1825 bufsize *= 2;
1826 buf = (char *) xrealloc (buf, bufsize + 1);
1828 c = getc (file);
1830 buf[len++] = '\0';
1831 if (c == EOF)
1832 break;
1834 /* Eat white space between the symbol names. */
1835 while (IS_WHITESPACE (c))
1836 c = getc (file);
1837 if (c == '#' || IS_LINE_TERMINATOR (c))
1838 goto comment;
1839 if (c == EOF)
1840 break;
1842 /* Collect the output symbol name. */
1843 outsym_off = len;
1844 while (! IS_WHITESPACE (c) && ! IS_LINE_TERMINATOR (c) && c != EOF)
1846 if (c == '#')
1847 goto comment;
1848 buf[len++] = c;
1849 if (len >= bufsize)
1851 bufsize *= 2;
1852 buf = (char *) xrealloc (buf, bufsize + 1);
1854 c = getc (file);
1856 buf[len++] = '\0';
1857 if (c == EOF)
1858 break;
1860 /* Eat white space at end of line. */
1861 while (! IS_LINE_TERMINATOR(c) && c != EOF && IS_WHITESPACE (c))
1862 c = getc (file);
1863 if (c == '#')
1864 goto comment;
1865 /* Handle \r\n. */
1866 if ((c == '\r' && (c = getc (file)) == '\n')
1867 || c == '\n' || c == EOF)
1869 end_of_line:
1870 /* Append the redefinition to the list. */
1871 if (buf[0] != '\0')
1872 add_redefine_and_check (filename, &buf[0], &buf[outsym_off]);
1874 lineno++;
1875 len = 0;
1876 outsym_off = 0;
1877 if (c == EOF)
1878 break;
1879 c = getc (file);
1880 continue;
1882 else
1883 fatal (_("%s:%d: garbage found at end of line"), filename, lineno);
1884 comment:
1885 if (len != 0 && (outsym_off == 0 || outsym_off == len))
1886 fatal (_("%s:%d: missing new symbol name"), filename, lineno);
1887 buf[len++] = '\0';
1889 /* Eat the rest of the line and finish it. */
1890 while (c != '\n' && c != EOF)
1891 c = getc (file);
1892 goto end_of_line;
1895 if (len != 0)
1896 fatal (_("%s:%d: premature end of file"), filename, lineno);
1898 free (buf);
1899 fclose (file);
1902 /* Copy unknown object file IBFD onto OBFD.
1903 Returns TRUE upon success, FALSE otherwise. */
1905 static bool
1906 copy_unknown_object (bfd *ibfd, bfd *obfd)
1908 char *cbuf;
1909 bfd_size_type tocopy;
1910 off_t size;
1911 struct stat buf;
1913 if (bfd_stat_arch_elt (ibfd, &buf) != 0)
1915 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
1916 return false;
1919 size = buf.st_size;
1920 if (size < 0)
1922 non_fatal (_("stat returns negative size for `%s'"),
1923 bfd_get_archive_filename (ibfd));
1924 return false;
1927 if (bfd_seek (ibfd, (file_ptr) 0, SEEK_SET) != 0)
1929 bfd_nonfatal (bfd_get_archive_filename (ibfd));
1930 return false;
1933 if (verbose)
1934 printf (_("copy from `%s' [unknown] to `%s' [unknown]\n"),
1935 bfd_get_archive_filename (ibfd), bfd_get_filename (obfd));
1937 cbuf = (char *) xmalloc (BUFSIZE);
1938 while (size != 0)
1940 if (size > BUFSIZE)
1941 tocopy = BUFSIZE;
1942 else
1943 tocopy = size;
1945 if (bfd_bread (cbuf, tocopy, ibfd) != tocopy)
1947 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
1948 free (cbuf);
1949 return false;
1952 if (bfd_bwrite (cbuf, tocopy, obfd) != tocopy)
1954 bfd_nonfatal_message (NULL, obfd, NULL, NULL);
1955 free (cbuf);
1956 return false;
1959 size -= tocopy;
1962 /* We should at least to be able to read it back when copying an
1963 unknown object in an archive. */
1964 chmod (bfd_get_filename (obfd), buf.st_mode | S_IRUSR);
1965 free (cbuf);
1966 return true;
1969 typedef struct objcopy_internal_note
1971 Elf_Internal_Note note;
1972 unsigned long padded_namesz;
1973 bfd_vma start;
1974 bfd_vma end;
1975 } objcopy_internal_note;
1977 #define DEBUG_MERGE 0
1979 #if DEBUG_MERGE
1980 #define merge_debug(format, ...) fprintf (stderr, format, ## __VA_ARGS__)
1981 #else
1982 #define merge_debug(format, ...)
1983 #endif
1985 /* Returns TRUE iff PNOTE1 overlaps or adjoins PNOTE2. */
1987 static bool
1988 overlaps_or_adjoins (objcopy_internal_note * pnote1,
1989 objcopy_internal_note * pnote2)
1991 if (pnote1->end < pnote2->start)
1992 /* FIXME: Alignment of 16 bytes taken from x86_64 binaries.
1993 Really we should extract the alignment of the section
1994 covered by the notes. */
1995 return BFD_ALIGN (pnote1->end, 16) < pnote2->start;
1997 if (pnote2->end < pnote2->start)
1998 return BFD_ALIGN (pnote2->end, 16) < pnote1->start;
2000 if (pnote1->end < pnote2->end)
2001 return true;
2003 if (pnote2->end < pnote1->end)
2004 return true;
2006 return false;
2009 /* Returns TRUE iff NEEDLE is fully contained by HAYSTACK. */
2011 static bool
2012 contained_by (objcopy_internal_note * needle,
2013 objcopy_internal_note * haystack)
2015 return needle->start >= haystack->start && needle->end <= haystack->end;
2018 static bool
2019 is_open_note (objcopy_internal_note * pnote)
2021 return pnote->note.type == NT_GNU_BUILD_ATTRIBUTE_OPEN;
2024 static bool
2025 is_func_note (objcopy_internal_note * pnote)
2027 return pnote->note.type == NT_GNU_BUILD_ATTRIBUTE_FUNC;
2030 static bool
2031 is_deleted_note (objcopy_internal_note * pnote)
2033 return pnote->note.type == 0;
2036 static bool
2037 is_version_note (objcopy_internal_note * pnote)
2039 return (pnote->note.namesz > 4
2040 && pnote->note.namedata[0] == 'G'
2041 && pnote->note.namedata[1] == 'A'
2042 && pnote->note.namedata[2] == '$'
2043 && pnote->note.namedata[3] == GNU_BUILD_ATTRIBUTE_VERSION);
2046 static bool
2047 is_64bit (bfd * abfd)
2049 /* Should never happen, but let's be paranoid. */
2050 if (bfd_get_flavour (abfd) != bfd_target_elf_flavour)
2051 return false;
2053 return elf_elfheader (abfd)->e_ident[EI_CLASS] == ELFCLASS64;
2056 /* This sorting function is used to get the notes into an order
2057 that makes merging easy. */
2059 static int
2060 compare_gnu_build_notes (const void * data1, const void * data2)
2062 objcopy_internal_note * pnote1 = (objcopy_internal_note *) data1;
2063 objcopy_internal_note * pnote2 = (objcopy_internal_note *) data2;
2065 /* Sort notes based upon the attribute they record. */
2066 int cmp = memcmp (pnote1->note.namedata + 3,
2067 pnote2->note.namedata + 3,
2068 pnote1->note.namesz < pnote2->note.namesz ?
2069 pnote1->note.namesz - 3 : pnote2->note.namesz - 3);
2070 if (cmp)
2071 return cmp;
2073 if (pnote1->end < pnote2->start)
2074 return -1;
2075 if (pnote1->start > pnote2->end)
2076 return 1;
2078 /* Overlaps - we should merge the two ranges. */
2079 if (pnote1->start < pnote2->start)
2080 return -1;
2081 if (pnote1->end > pnote2->end)
2082 return 1;
2083 if (pnote1->end < pnote2->end)
2084 return -1;
2086 /* Put OPEN notes before function notes. */
2087 if (is_open_note (pnote1) && ! is_open_note (pnote2))
2088 return -1;
2089 if (! is_open_note (pnote1) && is_open_note (pnote2))
2090 return 1;
2092 return 0;
2095 /* This sorting function is used to get the notes into an order
2096 that makes eliminating address ranges easier. */
2098 static int
2099 sort_gnu_build_notes (const void * data1, const void * data2)
2101 objcopy_internal_note * pnote1 = (objcopy_internal_note *) data1;
2102 objcopy_internal_note * pnote2 = (objcopy_internal_note *) data2;
2104 if (pnote1->note.type != pnote2->note.type)
2106 /* Move deleted notes to the end. */
2107 if (is_deleted_note (pnote1)) /* 1: OFD 2: OFD */
2108 return 1;
2110 /* Move OPEN notes to the start. */
2111 if (is_open_note (pnote1)) /* 1: OF 2: OFD */
2112 return -1;
2114 if (is_deleted_note (pnote2)) /* 1: F 2: O D */
2115 return -1;
2117 return 1; /* 1: F 2: O */
2120 /* Sort by starting address. */
2121 if (pnote1->start < pnote2->start)
2122 return -1;
2123 if (pnote1->start > pnote2->start)
2124 return 1;
2126 /* Then by end address (bigger range first). */
2127 if (pnote1->end > pnote2->end)
2128 return -1;
2129 if (pnote1->end < pnote2->end)
2130 return 1;
2132 /* Then by attribute type. */
2133 if (pnote1->note.namesz > 4
2134 && pnote2->note.namesz > 4
2135 && pnote1->note.namedata[3] != pnote2->note.namedata[3])
2136 return pnote1->note.namedata[3] - pnote2->note.namedata[3];
2138 return 0;
2141 /* Merge the notes on SEC, removing redundant entries.
2142 Returns the new, smaller size of the section upon success. */
2144 static bfd_size_type
2145 merge_gnu_build_notes (bfd * abfd,
2146 asection * sec,
2147 bfd_size_type size,
2148 bfd_byte * contents)
2150 objcopy_internal_note * pnotes_end;
2151 objcopy_internal_note * pnotes = NULL;
2152 objcopy_internal_note * pnote;
2153 bfd_size_type remain = size;
2154 unsigned version_1_seen = 0;
2155 unsigned version_2_seen = 0;
2156 unsigned version_3_seen = 0;
2157 const char * err = NULL;
2158 bfd_byte * in = contents;
2159 unsigned long previous_func_start = 0;
2160 unsigned long previous_open_start = 0;
2161 unsigned long previous_func_end = 0;
2162 unsigned long previous_open_end = 0;
2163 long relsize;
2165 relsize = bfd_get_reloc_upper_bound (abfd, sec);
2166 if (relsize > 0)
2168 arelent ** relpp;
2169 long relcount;
2171 /* If there are relocs associated with this section then we
2172 cannot safely merge it. */
2173 relpp = (arelent **) xmalloc (relsize);
2174 relcount = bfd_canonicalize_reloc (abfd, sec, relpp, isympp);
2175 free (relpp);
2176 if (relcount != 0)
2178 if (! is_strip)
2179 non_fatal (_("%s[%s]: Cannot merge - there are relocations against this section"),
2180 bfd_get_filename (abfd), bfd_section_name (sec));
2181 goto done;
2185 /* Make a copy of the notes and convert to our internal format.
2186 Minimum size of a note is 12 bytes. Also locate the version
2187 notes and check them. */
2188 pnote = pnotes = (objcopy_internal_note *)
2189 xcalloc ((size / 12), sizeof (* pnote));
2190 while (remain >= 12)
2192 bfd_vma start, end;
2194 pnote->note.namesz = bfd_get_32 (abfd, in);
2195 pnote->note.descsz = bfd_get_32 (abfd, in + 4);
2196 pnote->note.type = bfd_get_32 (abfd, in + 8);
2197 pnote->padded_namesz = (pnote->note.namesz + 3) & ~3;
2199 if (((pnote->note.descsz + 3) & ~3) != pnote->note.descsz)
2201 err = _("corrupt GNU build attribute note: description size not a factor of 4");
2202 goto done;
2205 if (pnote->note.type != NT_GNU_BUILD_ATTRIBUTE_OPEN
2206 && pnote->note.type != NT_GNU_BUILD_ATTRIBUTE_FUNC)
2208 err = _("corrupt GNU build attribute note: wrong note type");
2209 goto done;
2212 if (pnote->padded_namesz + pnote->note.descsz + 12 > remain)
2214 err = _("corrupt GNU build attribute note: note too big");
2215 goto done;
2218 if (pnote->note.namesz < 2)
2220 err = _("corrupt GNU build attribute note: name too small");
2221 goto done;
2224 pnote->note.namedata = (char *)(in + 12);
2225 pnote->note.descdata = (char *)(in + 12 + pnote->padded_namesz);
2227 remain -= 12 + pnote->padded_namesz + pnote->note.descsz;
2228 in += 12 + pnote->padded_namesz + pnote->note.descsz;
2230 if (pnote->note.namesz > 2
2231 && pnote->note.namedata[0] == '$'
2232 && pnote->note.namedata[1] == GNU_BUILD_ATTRIBUTE_VERSION
2233 && pnote->note.namedata[2] == '1')
2234 ++ version_1_seen;
2235 else if (is_version_note (pnote))
2237 if (pnote->note.namedata[4] == '2')
2238 ++ version_2_seen;
2239 else if (pnote->note.namedata[4] == '3')
2240 ++ version_3_seen;
2241 else
2243 err = _("corrupt GNU build attribute note: unsupported version");
2244 goto done;
2248 switch (pnote->note.descsz)
2250 case 0:
2251 start = end = 0;
2252 break;
2254 case 4:
2255 start = bfd_get_32 (abfd, pnote->note.descdata);
2256 /* FIXME: For version 1 and 2 notes we should try to
2257 calculate the end address by finding a symbol whose
2258 value is START, and then adding in its size.
2260 For now though, since v1 and v2 was not intended to
2261 handle gaps, we chose an artificially large end
2262 address. */
2263 end = (bfd_vma) -1;
2264 break;
2266 case 8:
2267 start = bfd_get_32 (abfd, pnote->note.descdata);
2268 end = bfd_get_32 (abfd, pnote->note.descdata + 4);
2269 break;
2271 case 16:
2272 start = bfd_get_64 (abfd, pnote->note.descdata);
2273 end = bfd_get_64 (abfd, pnote->note.descdata + 8);
2274 break;
2276 default:
2277 err = _("corrupt GNU build attribute note: bad description size");
2278 goto done;
2281 if (start > end)
2282 /* This can happen with PPC64LE binaries where empty notes are
2283 encoded as start = end + 4. */
2284 start = end;
2286 if (is_open_note (pnote))
2288 if (start)
2289 previous_open_start = start;
2291 pnote->start = previous_open_start;
2293 if (end)
2294 previous_open_end = end;
2296 pnote->end = previous_open_end;
2298 else
2300 if (start)
2301 previous_func_start = start;
2303 pnote->start = previous_func_start;
2305 if (end)
2306 previous_func_end = end;
2308 pnote->end = previous_func_end;
2311 if (pnote->note.namedata[pnote->note.namesz - 1] != 0)
2313 err = _("corrupt GNU build attribute note: name not NUL terminated");
2314 goto done;
2317 pnote ++;
2320 pnotes_end = pnote;
2322 /* Check that the notes are valid. */
2323 if (remain != 0)
2325 err = _("corrupt GNU build attribute notes: excess data at end");
2326 goto done;
2329 if (version_1_seen == 0 && version_2_seen == 0 && version_3_seen == 0)
2331 #if 0
2332 err = _("bad GNU build attribute notes: no known versions detected");
2333 goto done;
2334 #else
2335 /* This happens with glibc. No idea why. */
2336 non_fatal (_("%s[%s]: Warning: version note missing - assuming version 3"),
2337 bfd_get_filename (abfd), bfd_section_name (sec));
2338 version_3_seen = 2;
2339 #endif
2342 if ( (version_1_seen > 0 && version_2_seen > 0)
2343 || (version_1_seen > 0 && version_3_seen > 0)
2344 || (version_2_seen > 0 && version_3_seen > 0))
2346 err = _("bad GNU build attribute notes: multiple different versions");
2347 goto done;
2350 /* We are now only supporting the merging v3+ notes
2351 - it makes things much simpler. */
2352 if (version_3_seen == 0)
2354 merge_debug ("%s: skipping merge - not using v3 notes", bfd_section_name (sec));
2355 goto done;
2358 merge_debug ("Merging section %s which contains %ld notes\n",
2359 sec->name, pnotes_end - pnotes);
2361 /* Sort the notes. */
2362 qsort (pnotes, pnotes_end - pnotes, sizeof (* pnotes),
2363 compare_gnu_build_notes);
2365 #if DEBUG_MERGE
2366 merge_debug ("Results of initial sort:\n");
2367 for (pnote = pnotes; pnote < pnotes_end; pnote ++)
2368 merge_debug ("offset %#08lx range %#08lx..%#08lx type %ld attribute %d namesz %ld\n",
2369 (pnote->note.namedata - (char *) contents) - 12,
2370 pnote->start, pnote->end,
2371 pnote->note.type,
2372 pnote->note.namedata[3],
2373 pnote->note.namesz
2375 #endif
2377 /* Now merge the notes. The rules are:
2378 1. If a note has a zero range, it can be eliminated.
2379 2. If two notes have the same namedata then:
2380 2a. If one note's range is fully covered by the other note
2381 then it can be deleted.
2382 2b. If one note's range partially overlaps or adjoins the
2383 other note then if they are both of the same type (open
2384 or func) then they can be merged and one deleted. If
2385 they are of different types then they cannot be merged. */
2386 for (pnote = pnotes; pnote < pnotes_end; pnote ++)
2388 /* Skip already deleted notes.
2389 FIXME: Can this happen ? We are scanning forwards and
2390 deleting backwards after all. */
2391 if (is_deleted_note (pnote))
2392 continue;
2394 /* Rule 1 - delete 0-range notes. */
2395 if (pnote->start == pnote->end)
2397 merge_debug ("Delete note at offset %#08lx - empty range\n",
2398 (pnote->note.namedata - (char *) contents) - 12);
2399 pnote->note.type = 0;
2400 continue;
2403 int iter;
2404 objcopy_internal_note * back;
2406 /* Rule 2: Check to see if there is an identical previous note. */
2407 for (iter = 0, back = pnote - 1; back >= pnotes; back --)
2409 if (is_deleted_note (back))
2410 continue;
2412 /* Our sorting function should have placed all identically
2413 attributed notes together, so if we see a note of a different
2414 attribute type stop searching. */
2415 if (back->note.namesz != pnote->note.namesz
2416 || memcmp (back->note.namedata,
2417 pnote->note.namedata, pnote->note.namesz) != 0)
2418 break;
2420 if (back->start == pnote->start
2421 && back->end == pnote->end)
2423 merge_debug ("Delete note at offset %#08lx - duplicate of note at offset %#08lx\n",
2424 (pnote->note.namedata - (char *) contents) - 12,
2425 (back->note.namedata - (char *) contents) - 12);
2426 pnote->note.type = 0;
2427 break;
2430 /* Rule 2a. */
2431 if (contained_by (pnote, back))
2433 merge_debug ("Delete note at offset %#08lx - fully contained by note at %#08lx\n",
2434 (pnote->note.namedata - (char *) contents) - 12,
2435 (back->note.namedata - (char *) contents) - 12);
2436 pnote->note.type = 0;
2437 break;
2440 #if DEBUG_MERGE
2441 /* This should not happen as we have sorted the
2442 notes with earlier starting addresses first. */
2443 if (contained_by (back, pnote))
2444 merge_debug ("ERROR: UNEXPECTED CONTAINMENT\n");
2445 #endif
2447 /* Rule 2b. */
2448 if (overlaps_or_adjoins (back, pnote)
2449 && is_func_note (back) == is_func_note (pnote))
2451 merge_debug ("Delete note at offset %#08lx - merge into note at %#08lx\n",
2452 (pnote->note.namedata - (char *) contents) - 12,
2453 (back->note.namedata - (char *) contents) - 12);
2455 back->end = back->end > pnote->end ? back->end : pnote->end;
2456 back->start = back->start < pnote->start ? back->start : pnote->start;
2457 pnote->note.type = 0;
2458 break;
2461 /* Don't scan too far back however. */
2462 if (iter ++ > 16)
2464 /* FIXME: Not sure if this can ever be triggered. */
2465 merge_debug ("ITERATION LIMIT REACHED\n");
2466 break;
2469 #if DEBUG_MERGE
2470 if (! is_deleted_note (pnote))
2471 merge_debug ("Unable to do anything with note at %#08lx\n",
2472 (pnote->note.namedata - (char *) contents) - 12);
2473 #endif
2476 /* Resort the notes. */
2477 merge_debug ("Final sorting of notes\n");
2478 qsort (pnotes, pnotes_end - pnotes, sizeof (* pnotes), sort_gnu_build_notes);
2480 /* Reconstruct the ELF notes. */
2481 bfd_byte * new_contents;
2482 bfd_byte * old;
2483 bfd_byte * new;
2484 bfd_size_type new_size;
2485 bfd_vma prev_start = 0;
2486 bfd_vma prev_end = 0;
2488 /* Not sure how, but the notes might grow in size.
2489 (eg see PR 1774507). Allow for this here. */
2490 new = new_contents = xmalloc (size * 2);
2491 for (pnote = pnotes, old = contents;
2492 pnote < pnotes_end;
2493 pnote ++)
2495 bfd_size_type note_size = 12 + pnote->padded_namesz + pnote->note.descsz;
2497 if (! is_deleted_note (pnote))
2499 /* Create the note, potentially using the
2500 address range of the previous note. */
2501 if (pnote->start == prev_start && pnote->end == prev_end)
2503 bfd_put_32 (abfd, pnote->note.namesz, new);
2504 bfd_put_32 (abfd, 0, new + 4);
2505 bfd_put_32 (abfd, pnote->note.type, new + 8);
2506 new += 12;
2507 memcpy (new, pnote->note.namedata, pnote->note.namesz);
2508 if (pnote->note.namesz < pnote->padded_namesz)
2509 memset (new + pnote->note.namesz, 0, pnote->padded_namesz - pnote->note.namesz);
2510 new += pnote->padded_namesz;
2512 else
2514 bfd_put_32 (abfd, pnote->note.namesz, new);
2515 bfd_put_32 (abfd, is_64bit (abfd) ? 16 : 8, new + 4);
2516 bfd_put_32 (abfd, pnote->note.type, new + 8);
2517 new += 12;
2518 memcpy (new, pnote->note.namedata, pnote->note.namesz);
2519 if (pnote->note.namesz < pnote->padded_namesz)
2520 memset (new + pnote->note.namesz, 0, pnote->padded_namesz - pnote->note.namesz);
2521 new += pnote->padded_namesz;
2522 if (is_64bit (abfd))
2524 bfd_put_64 (abfd, pnote->start, new);
2525 bfd_put_64 (abfd, pnote->end, new + 8);
2526 new += 16;
2528 else
2530 bfd_put_32 (abfd, pnote->start, new);
2531 bfd_put_32 (abfd, pnote->end, new + 4);
2532 new += 8;
2535 prev_start = pnote->start;
2536 prev_end = pnote->end;
2540 old += note_size;
2543 #if DEBUG_MERGE
2544 merge_debug ("Results of merge:\n");
2545 for (pnote = pnotes; pnote < pnotes_end; pnote ++)
2546 if (! is_deleted_note (pnote))
2547 merge_debug ("offset %#08lx range %#08lx..%#08lx type %ld attribute %d namesz %ld\n",
2548 (pnote->note.namedata - (char *) contents) - 12,
2549 pnote->start, pnote->end,
2550 pnote->note.type,
2551 pnote->note.namedata[3],
2552 pnote->note.namesz
2554 #endif
2556 new_size = new - new_contents;
2557 if (new_size < size)
2559 memcpy (contents, new_contents, new_size);
2560 size = new_size;
2562 free (new_contents);
2564 done:
2565 if (err)
2567 bfd_set_error (bfd_error_bad_value);
2568 bfd_nonfatal_message (NULL, abfd, sec, err);
2569 status = 1;
2572 free (pnotes);
2573 return size;
2576 static flagword
2577 check_new_section_flags (flagword flags, bfd * abfd, const char * secname)
2579 /* Only set the SEC_COFF_SHARED flag on COFF files.
2580 The same bit value is used by ELF targets to indicate
2581 compressed sections, and setting that flag here breaks
2582 things. */
2583 if ((flags & SEC_COFF_SHARED)
2584 && bfd_get_flavour (abfd) != bfd_target_coff_flavour)
2586 non_fatal (_("%s[%s]: Note - dropping 'share' flag as output format is not COFF"),
2587 bfd_get_filename (abfd), secname);
2588 flags &= ~ SEC_COFF_SHARED;
2590 return flags;
2593 /* Copy object file IBFD onto OBFD.
2594 Returns TRUE upon success, FALSE otherwise. */
2596 static bool
2597 copy_object (bfd *ibfd, bfd *obfd, const bfd_arch_info_type *input_arch)
2599 bfd_vma start;
2600 long symcount;
2601 asection **osections = NULL;
2602 asection *osec;
2603 asection *gnu_debuglink_section = NULL;
2604 bfd_size_type *gaps = NULL;
2605 bfd_size_type max_gap = 0;
2606 long symsize;
2607 void *dhandle;
2608 enum bfd_architecture iarch;
2609 unsigned int imach;
2610 unsigned int num_sec, i;
2612 if (ibfd->xvec->byteorder != obfd->xvec->byteorder
2613 && ibfd->xvec->byteorder != BFD_ENDIAN_UNKNOWN
2614 && obfd->xvec->byteorder != BFD_ENDIAN_UNKNOWN)
2616 /* PR 17636: Call non-fatal so that we return to our parent who
2617 may need to tidy temporary files. */
2618 non_fatal (_("unable to change endianness of '%s'"),
2619 bfd_get_archive_filename (ibfd));
2620 return false;
2623 if (ibfd->read_only)
2625 non_fatal (_("unable to modify '%s' due to errors"),
2626 bfd_get_archive_filename (ibfd));
2627 return false;
2630 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
2632 bfd_nonfatal_message (NULL, obfd, NULL, NULL);
2633 return false;
2636 if (ibfd->sections == NULL)
2638 non_fatal (_("error: the input file '%s' has no sections"),
2639 bfd_get_archive_filename (ibfd));
2640 return false;
2643 if (bfd_get_flavour (ibfd) != bfd_target_elf_flavour)
2645 if ((do_debug_sections & compress) != 0
2646 && do_debug_sections != compress)
2648 non_fatal (_("--compress-debug-sections=[zlib|zlib-gnu|zlib-gabi] is unsupported on `%s'"),
2649 bfd_get_archive_filename (ibfd));
2650 return false;
2653 if (do_elf_stt_common)
2655 non_fatal (_("--elf-stt-common=[yes|no] is unsupported on `%s'"),
2656 bfd_get_archive_filename (ibfd));
2657 return false;
2661 if (verbose)
2662 printf (_("copy from `%s' [%s] to `%s' [%s]\n"),
2663 bfd_get_archive_filename (ibfd), bfd_get_target (ibfd),
2664 bfd_get_filename (obfd), bfd_get_target (obfd));
2666 if (extract_symbol)
2667 start = 0;
2668 else
2670 if (set_start_set)
2671 start = set_start;
2672 else
2673 start = bfd_get_start_address (ibfd);
2674 start += change_start;
2677 /* Neither the start address nor the flags
2678 need to be set for a core file. */
2679 if (bfd_get_format (obfd) != bfd_core)
2681 flagword flags;
2683 flags = bfd_get_file_flags (ibfd);
2684 flags |= bfd_flags_to_set;
2685 flags &= ~bfd_flags_to_clear;
2686 flags &= bfd_applicable_file_flags (obfd);
2688 if (strip_symbols == STRIP_ALL)
2689 flags &= ~HAS_RELOC;
2691 if (!bfd_set_start_address (obfd, start)
2692 || !bfd_set_file_flags (obfd, flags))
2694 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
2695 return false;
2699 /* Copy architecture of input file to output file. */
2700 iarch = bfd_get_arch (ibfd);
2701 imach = bfd_get_mach (ibfd);
2702 if (input_arch)
2704 if (iarch == bfd_arch_unknown)
2706 iarch = input_arch->arch;
2707 imach = input_arch->mach;
2709 else
2710 non_fatal (_("Input file `%s' ignores binary architecture parameter."),
2711 bfd_get_archive_filename (ibfd));
2713 if (iarch == bfd_arch_unknown
2714 && bfd_get_flavour (ibfd) != bfd_target_elf_flavour
2715 && bfd_get_flavour (obfd) == bfd_target_elf_flavour)
2717 const struct elf_backend_data *bed = get_elf_backend_data (obfd);
2718 iarch = bed->arch;
2719 imach = 0;
2721 if (!bfd_set_arch_mach (obfd, iarch, imach)
2722 && (ibfd->target_defaulted
2723 || bfd_get_arch (ibfd) != bfd_get_arch (obfd)))
2725 if (bfd_get_arch (ibfd) == bfd_arch_unknown)
2726 non_fatal (_("Unable to recognise the format of the input file `%s'"),
2727 bfd_get_archive_filename (ibfd));
2728 else
2729 non_fatal (_("Output file cannot represent architecture `%s'"),
2730 bfd_printable_arch_mach (bfd_get_arch (ibfd),
2731 bfd_get_mach (ibfd)));
2732 return false;
2735 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
2737 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
2738 return false;
2741 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour
2742 && bfd_pei_p (obfd))
2744 /* Set up PE parameters. */
2745 pe_data_type *pe = pe_data (obfd);
2747 /* Copy PE parameters before changing them. */
2748 if (bfd_get_flavour (ibfd) == bfd_target_coff_flavour
2749 && bfd_pei_p (ibfd))
2751 pe->pe_opthdr = pe_data (ibfd)->pe_opthdr;
2753 if (preserve_dates)
2754 pe->timestamp = pe_data (ibfd)->coff.timestamp;
2755 else
2756 pe->timestamp = -1;
2759 if (pe_file_alignment != (bfd_vma) -1)
2760 pe->pe_opthdr.FileAlignment = pe_file_alignment;
2761 else
2762 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
2764 if (pe_heap_commit != (bfd_vma) -1)
2765 pe->pe_opthdr.SizeOfHeapCommit = pe_heap_commit;
2767 if (pe_heap_reserve != (bfd_vma) -1)
2768 pe->pe_opthdr.SizeOfHeapCommit = pe_heap_reserve;
2770 if (pe_image_base != (bfd_vma) -1)
2771 pe->pe_opthdr.ImageBase = pe_image_base;
2773 if (pe_section_alignment != (bfd_vma) -1)
2774 pe->pe_opthdr.SectionAlignment = pe_section_alignment;
2775 else
2776 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
2778 if (pe_stack_commit != (bfd_vma) -1)
2779 pe->pe_opthdr.SizeOfStackCommit = pe_stack_commit;
2781 if (pe_stack_reserve != (bfd_vma) -1)
2782 pe->pe_opthdr.SizeOfStackCommit = pe_stack_reserve;
2784 if (pe_subsystem != -1)
2785 pe->pe_opthdr.Subsystem = pe_subsystem;
2787 if (pe_major_subsystem_version != -1)
2788 pe->pe_opthdr.MajorSubsystemVersion = pe_major_subsystem_version;
2790 if (pe_minor_subsystem_version != -1)
2791 pe->pe_opthdr.MinorSubsystemVersion = pe_minor_subsystem_version;
2793 if (pe_file_alignment > pe_section_alignment)
2795 non_fatal (_("warning: file alignment (0x%" PRIx64
2796 ") > section alignment (0x%" PRIx64 ")"),
2797 (uint64_t) pe_file_alignment,
2798 (uint64_t) pe_section_alignment);
2802 free (isympp);
2804 if (osympp != isympp)
2805 free (osympp);
2807 isympp = NULL;
2808 osympp = NULL;
2810 symsize = bfd_get_symtab_upper_bound (ibfd);
2811 if (symsize < 0)
2813 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
2814 return false;
2817 osympp = isympp = (asymbol **) xmalloc (symsize);
2818 symcount = bfd_canonicalize_symtab (ibfd, isympp);
2819 if (symcount < 0)
2821 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
2822 return false;
2824 /* PR 17512: file: d6323821
2825 If the symbol table could not be loaded do not pretend that we have
2826 any symbols. This trips us up later on when we load the relocs. */
2827 if (symcount == 0)
2829 free (isympp);
2830 osympp = isympp = NULL;
2833 /* BFD mandates that all output sections be created and sizes set before
2834 any output is done. Thus, we traverse all sections multiple times. */
2835 bfd_map_over_sections (ibfd, setup_section, obfd);
2837 if (!extract_symbol)
2838 setup_bfd_headers (ibfd, obfd);
2840 if (add_sections != NULL)
2842 struct section_add *padd;
2843 struct section_list *pset;
2845 for (padd = add_sections; padd != NULL; padd = padd->next)
2847 flagword flags;
2849 pset = find_section_list (padd->name, false,
2850 SECTION_CONTEXT_SET_FLAGS);
2851 if (pset != NULL)
2853 flags = pset->flags | SEC_HAS_CONTENTS;
2854 flags = check_new_section_flags (flags, obfd, padd->name);
2856 else
2857 flags = SEC_HAS_CONTENTS | SEC_READONLY | SEC_DATA;
2859 /* bfd_make_section_with_flags() does not return very helpful
2860 error codes, so check for the most likely user error first. */
2861 if (bfd_get_section_by_name (obfd, padd->name))
2863 bfd_nonfatal_message (NULL, obfd, NULL,
2864 _("can't add section '%s'"), padd->name);
2865 return false;
2867 else
2869 /* We use LINKER_CREATED here so that the backend hooks
2870 will create any special section type information,
2871 instead of presuming we know what we're doing merely
2872 because we set the flags. */
2873 padd->section = bfd_make_section_with_flags
2874 (obfd, padd->name, flags | SEC_LINKER_CREATED);
2875 if (padd->section == NULL)
2877 bfd_nonfatal_message (NULL, obfd, NULL,
2878 _("can't create section `%s'"),
2879 padd->name);
2880 return false;
2884 if (!bfd_set_section_size (padd->section, padd->size))
2886 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
2887 return false;
2890 pset = find_section_list (padd->name, false,
2891 SECTION_CONTEXT_SET_VMA | SECTION_CONTEXT_ALTER_VMA);
2892 if (pset != NULL
2893 && !bfd_set_section_vma (padd->section, pset->vma_val))
2895 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
2896 return false;
2899 pset = find_section_list (padd->name, false,
2900 SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_ALTER_LMA);
2901 if (pset != NULL)
2903 padd->section->lma = pset->lma_val;
2905 if (!bfd_set_section_alignment
2906 (padd->section, bfd_section_alignment (padd->section)))
2908 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
2909 return false;
2915 if (update_sections != NULL)
2917 struct section_add *pupdate;
2919 for (pupdate = update_sections;
2920 pupdate != NULL;
2921 pupdate = pupdate->next)
2923 pupdate->section = bfd_get_section_by_name (ibfd, pupdate->name);
2924 if (pupdate->section == NULL)
2926 non_fatal (_("error: %s not found, can't be updated"), pupdate->name);
2927 return false;
2930 osec = pupdate->section->output_section;
2931 if (!bfd_set_section_size (osec, pupdate->size))
2933 bfd_nonfatal_message (NULL, obfd, osec, NULL);
2934 return false;
2939 merged_note_section * merged_note_sections = NULL;
2940 if (merge_notes)
2942 /* This palaver is necessary because we must set the output
2943 section size first, before its contents are ready. */
2944 for (osec = ibfd->sections; osec != NULL; osec = osec->next)
2946 if (! is_mergeable_note_section (ibfd, osec))
2947 continue;
2949 /* If the section is going to be completly deleted then
2950 do not bother to merge it. */
2951 if (osec->output_section == NULL)
2952 continue;
2954 bfd_size_type size = bfd_section_size (osec);
2956 if (size == 0)
2958 bfd_nonfatal_message (NULL, ibfd, osec,
2959 _("warning: note section is empty"));
2960 continue;
2963 merged_note_section * merged = xmalloc (sizeof * merged);
2964 merged->contents = NULL;
2965 if (! bfd_get_full_section_contents (ibfd, osec, & merged->contents))
2967 bfd_nonfatal_message (NULL, ibfd, osec,
2968 _("warning: could not load note section"));
2969 free (merged);
2970 continue;
2973 merged->size = merge_gnu_build_notes (ibfd, osec, size,
2974 merged->contents);
2976 /* FIXME: Once we have read the contents in, we must write
2977 them out again. So even if the mergeing has achieved
2978 nothing we still add this entry to the merge list. */
2980 if (size != merged->size
2981 && !bfd_set_section_size (osec->output_section, merged->size))
2983 bfd_nonfatal_message (NULL, obfd, osec,
2984 _("warning: failed to set merged notes size"));
2985 free (merged->contents);
2986 free (merged);
2987 continue;
2990 /* Add section to list of merged sections. */
2991 merged->sec = osec;
2992 merged->next = merged_note_sections;
2993 merged_note_sections = merged;
2997 if (dump_sections != NULL)
2999 struct section_add * pdump;
3001 for (pdump = dump_sections; pdump != NULL; pdump = pdump->next)
3003 FILE * f;
3004 bfd_byte *contents;
3006 osec = bfd_get_section_by_name (ibfd, pdump->name);
3007 if (osec == NULL)
3009 bfd_nonfatal_message (NULL, ibfd, NULL,
3010 _("can't dump section '%s' - it does not exist"),
3011 pdump->name);
3012 continue;
3015 if ((bfd_section_flags (osec) & SEC_HAS_CONTENTS) == 0)
3017 bfd_nonfatal_message (NULL, ibfd, osec,
3018 _("can't dump section - it has no contents"));
3019 continue;
3022 bfd_size_type size = bfd_section_size (osec);
3023 /* Note - we allow the dumping of zero-sized sections,
3024 creating an empty file. */
3026 f = fopen (pdump->filename, FOPEN_WB);
3027 if (f == NULL)
3029 bfd_nonfatal_message (pdump->filename, NULL, NULL,
3030 _("could not open section dump file"));
3031 continue;
3034 if (bfd_malloc_and_get_section (ibfd, osec, &contents))
3036 if (size != 0 && fwrite (contents, 1, size, f) != size)
3038 non_fatal (_("error writing section contents to %s (error: %s)"),
3039 pdump->filename,
3040 strerror (errno));
3041 free (contents);
3042 fclose (f);
3043 return false;
3046 else
3047 bfd_nonfatal_message (NULL, ibfd, osec,
3048 _("could not retrieve section contents"));
3050 fclose (f);
3051 free (contents);
3055 if (gnu_debuglink_filename != NULL)
3057 /* PR 15125: Give a helpful warning message if
3058 the debuglink section already exists, and
3059 allow the rest of the copy to complete. */
3060 if (bfd_get_section_by_name (obfd, ".gnu_debuglink"))
3062 non_fatal (_("%s: debuglink section already exists"),
3063 bfd_get_filename (obfd));
3064 gnu_debuglink_filename = NULL;
3066 else
3068 gnu_debuglink_section = bfd_create_gnu_debuglink_section
3069 (obfd, gnu_debuglink_filename);
3071 if (gnu_debuglink_section == NULL)
3073 bfd_nonfatal_message (NULL, obfd, NULL,
3074 _("cannot create debug link section `%s'"),
3075 gnu_debuglink_filename);
3076 return false;
3079 /* Special processing for PE format files. We
3080 have no way to distinguish PE from COFF here. */
3081 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour)
3083 bfd_vma debuglink_vma;
3084 asection * highest_section;
3086 /* The PE spec requires that all sections be adjacent and sorted
3087 in ascending order of VMA. It also specifies that debug
3088 sections should be last. This is despite the fact that debug
3089 sections are not loaded into memory and so in theory have no
3090 use for a VMA.
3092 This means that the debuglink section must be given a non-zero
3093 VMA which makes it contiguous with other debug sections. So
3094 walk the current section list, find the section with the
3095 highest VMA and start the debuglink section after that one. */
3096 for (osec = obfd->sections, highest_section = NULL;
3097 osec != NULL;
3098 osec = osec->next)
3099 if (osec->vma > 0
3100 && (highest_section == NULL
3101 || osec->vma > highest_section->vma))
3102 highest_section = osec;
3104 if (highest_section)
3105 debuglink_vma = BFD_ALIGN (highest_section->vma
3106 + highest_section->size,
3107 /* FIXME: We ought to be using
3108 COFF_PAGE_SIZE here or maybe
3109 bfd_section_alignment() (if it
3110 was set) but since this is for PE
3111 and we know the required alignment
3112 it is easier just to hard code it. */
3113 0x1000);
3114 else
3115 /* Umm, not sure what to do in this case. */
3116 debuglink_vma = 0x1000;
3118 bfd_set_section_vma (gnu_debuglink_section, debuglink_vma);
3123 num_sec = bfd_count_sections (obfd);
3124 if (num_sec != 0
3125 && (gap_fill_set || pad_to_set))
3127 asection **set;
3129 /* We must fill in gaps between the sections and/or we must pad
3130 the last section to a specified address. We do this by
3131 grabbing a list of the sections, sorting them by VMA, and
3132 increasing the section sizes as required to fill the gaps.
3133 We write out the gap contents below. */
3135 osections = xmalloc (num_sec * sizeof (*osections));
3136 set = osections;
3137 bfd_map_over_sections (obfd, get_sections, &set);
3139 qsort (osections, num_sec, sizeof (*osections), compare_section_lma);
3141 gaps = xmalloc (num_sec * sizeof (*gaps));
3142 memset (gaps, 0, num_sec * sizeof (*gaps));
3144 if (gap_fill_set)
3146 for (i = 0; i < num_sec - 1; i++)
3148 flagword flags;
3149 bfd_size_type size; /* Octets. */
3150 bfd_vma gap_start, gap_stop; /* Octets. */
3151 unsigned int opb1 = bfd_octets_per_byte (obfd, osections[i]);
3152 unsigned int opb2 = bfd_octets_per_byte (obfd, osections[i+1]);
3154 flags = bfd_section_flags (osections[i]);
3155 if ((flags & SEC_HAS_CONTENTS) == 0
3156 || (flags & SEC_LOAD) == 0)
3157 continue;
3159 size = bfd_section_size (osections[i]);
3160 gap_start = bfd_section_lma (osections[i]) * opb1 + size;
3161 gap_stop = bfd_section_lma (osections[i + 1]) * opb2;
3162 if (gap_start < gap_stop)
3164 if (!bfd_set_section_size (osections[i],
3165 size + (gap_stop - gap_start)))
3167 bfd_nonfatal_message (NULL, obfd, osections[i],
3168 _("Can't fill gap after section"));
3169 status = 1;
3170 break;
3172 gaps[i] = gap_stop - gap_start;
3173 if (max_gap < gap_stop - gap_start)
3174 max_gap = gap_stop - gap_start;
3179 if (pad_to_set)
3181 bfd_vma lma; /* Octets. */
3182 bfd_size_type size; /* Octets. */
3183 unsigned int opb = bfd_octets_per_byte (obfd, osections[num_sec - 1]);
3184 bfd_vma _pad_to = pad_to * opb;
3186 lma = bfd_section_lma (osections[num_sec - 1]) * opb;
3187 size = bfd_section_size (osections[num_sec - 1]);
3188 if (lma + size < _pad_to)
3190 if (!bfd_set_section_size (osections[num_sec - 1], _pad_to - lma))
3192 bfd_nonfatal_message (NULL, obfd, osections[num_sec - 1],
3193 _("can't add padding"));
3194 status = 1;
3196 else
3198 gaps[num_sec - 1] = _pad_to - (lma + size);
3199 if (max_gap < _pad_to - (lma + size))
3200 max_gap = _pad_to - (lma + size);
3206 /* Symbol filtering must happen after the output sections
3207 have been created, but before their contents are set. */
3208 dhandle = NULL;
3209 if (convert_debugging)
3210 dhandle = read_debugging_info (ibfd, isympp, symcount, false);
3212 if ((obfd->flags & (EXEC_P | DYNAMIC)) != 0
3213 && (obfd->flags & HAS_RELOC) == 0)
3215 if (bfd_keep_unused_section_symbols (obfd) || keep_section_symbols)
3217 /* Non-relocatable inputs may not have the unused section
3218 symbols. Mark all section symbols as used to generate
3219 section symbols. */
3220 asection *asect;
3221 for (asect = obfd->sections; asect != NULL; asect = asect->next)
3222 if (asect->symbol)
3223 asect->symbol->flags |= BSF_SECTION_SYM_USED;
3225 else
3227 /* Non-relocatable inputs may have the unused section symbols.
3228 Mark all section symbols as unused to excluded them. */
3229 long s;
3230 for (s = 0; s < symcount; s++)
3231 if ((isympp[s]->flags & BSF_SECTION_SYM_USED))
3232 isympp[s]->flags &= ~BSF_SECTION_SYM_USED;
3236 if (strip_symbols == STRIP_DEBUG
3237 || strip_symbols == STRIP_ALL
3238 || strip_symbols == STRIP_UNNEEDED
3239 || strip_symbols == STRIP_NONDEBUG
3240 || strip_symbols == STRIP_DWO
3241 || strip_symbols == STRIP_NONDWO
3242 || discard_locals != LOCALS_UNDEF
3243 || localize_hidden
3244 || htab_elements (strip_specific_htab) != 0
3245 || htab_elements (keep_specific_htab) != 0
3246 || htab_elements (localize_specific_htab) != 0
3247 || htab_elements (globalize_specific_htab) != 0
3248 || htab_elements (keepglobal_specific_htab) != 0
3249 || htab_elements (weaken_specific_htab) != 0
3250 || htab_elements (redefine_specific_htab) != 0
3251 || prefix_symbols_string
3252 || sections_removed
3253 || sections_copied
3254 || convert_debugging
3255 || change_leading_char
3256 || remove_leading_char
3257 || section_rename_list
3258 || weaken
3259 || add_symbols)
3261 /* Mark symbols used in output relocations so that they
3262 are kept, even if they are local labels or static symbols.
3264 Note we iterate over the input sections examining their
3265 relocations since the relocations for the output sections
3266 haven't been set yet. mark_symbols_used_in_relocations will
3267 ignore input sections which have no corresponding output
3268 section. */
3269 if (strip_symbols != STRIP_ALL)
3271 bfd_set_error (bfd_error_no_error);
3272 bfd_map_over_sections (ibfd,
3273 mark_symbols_used_in_relocations,
3274 isympp);
3275 if (bfd_get_error () != bfd_error_no_error)
3277 status = 1;
3278 return false;
3282 osympp = (asymbol **) xmalloc ((symcount + add_symbols + 1) * sizeof (asymbol *));
3283 symcount = filter_symbols (ibfd, obfd, osympp, isympp, symcount);
3286 if (convert_debugging && dhandle != NULL)
3288 bool res;
3290 res = write_debugging_info (obfd, dhandle, &symcount, &osympp);
3292 free (dhandle);
3293 dhandle = NULL; /* Paranoia... */
3295 if (! res)
3297 status = 1;
3298 return false;
3302 bfd_set_symtab (obfd, osympp, symcount);
3304 /* This has to happen before section positions are set. */
3305 bfd_map_over_sections (ibfd, copy_relocations_in_section, obfd);
3307 /* This has to happen after the symbol table has been set. */
3308 bfd_map_over_sections (ibfd, copy_section, obfd);
3310 if (add_sections != NULL)
3312 struct section_add *padd;
3314 for (padd = add_sections; padd != NULL; padd = padd->next)
3316 if (! bfd_set_section_contents (obfd, padd->section, padd->contents,
3317 0, padd->size))
3319 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
3320 return false;
3325 if (update_sections != NULL)
3327 struct section_add *pupdate;
3329 for (pupdate = update_sections;
3330 pupdate != NULL;
3331 pupdate = pupdate->next)
3333 osec = pupdate->section->output_section;
3334 if (! bfd_set_section_contents (obfd, osec, pupdate->contents,
3335 0, pupdate->size))
3337 bfd_nonfatal_message (NULL, obfd, osec, NULL);
3338 return false;
3343 if (merged_note_sections != NULL)
3345 merged_note_section * merged = NULL;
3347 for (osec = obfd->sections; osec != NULL; osec = osec->next)
3349 if (! is_mergeable_note_section (obfd, osec))
3350 continue;
3352 if (merged == NULL)
3353 merged = merged_note_sections;
3355 /* It is likely that output sections are in the same order
3356 as the input sections, but do not assume that this is
3357 the case. */
3358 if (merged->sec->output_section != osec)
3360 for (merged = merged_note_sections;
3361 merged != NULL;
3362 merged = merged->next)
3363 if (merged->sec->output_section == osec)
3364 break;
3366 if (merged == NULL)
3368 bfd_nonfatal_message
3369 (NULL, obfd, osec,
3370 _("error: failed to locate merged notes"));
3371 continue;
3375 if (merged->contents == NULL)
3377 bfd_nonfatal_message
3378 (NULL, obfd, osec,
3379 _("error: failed to merge notes"));
3380 continue;
3383 if (! bfd_set_section_contents (obfd, osec, merged->contents, 0,
3384 merged->size))
3386 bfd_nonfatal_message
3387 (NULL, obfd, osec,
3388 _("error: failed to copy merged notes into output"));
3389 return false;
3392 merged = merged->next;
3395 /* Free the memory. */
3396 merged_note_section * next;
3397 for (merged = merged_note_sections; merged != NULL; merged = next)
3399 next = merged->next;
3400 free (merged->contents);
3401 free (merged);
3404 else if (merge_notes && ! is_strip)
3405 non_fatal (_("%s: Could not find any mergeable note sections"),
3406 bfd_get_filename (ibfd));
3408 if (gnu_debuglink_filename != NULL)
3410 if (! bfd_fill_in_gnu_debuglink_section
3411 (obfd, gnu_debuglink_section, gnu_debuglink_filename))
3413 bfd_nonfatal_message (NULL, obfd, NULL,
3414 _("cannot fill debug link section `%s'"),
3415 gnu_debuglink_filename);
3416 return false;
3420 if (gaps != NULL)
3422 bfd_byte *buf;
3424 /* Fill in the gaps. */
3425 if (max_gap > 8192)
3426 max_gap = 8192;
3427 buf = (bfd_byte *) xmalloc (max_gap);
3428 memset (buf, gap_fill, max_gap);
3430 for (i = 0; i < num_sec; i++)
3432 if (gaps[i] != 0)
3434 bfd_size_type left;
3435 file_ptr off;
3437 left = gaps[i];
3438 off = bfd_section_size (osections[i]) - left;
3440 while (left > 0)
3442 bfd_size_type now;
3444 if (left > 8192)
3445 now = 8192;
3446 else
3447 now = left;
3449 if (! bfd_set_section_contents (obfd, osections[i], buf,
3450 off, now))
3452 bfd_nonfatal_message (NULL, obfd, osections[i], NULL);
3453 free (buf);
3454 return false;
3457 left -= now;
3458 off += now;
3463 free (buf);
3464 free (gaps);
3465 gaps = NULL;
3468 /* Allow the BFD backend to copy any private data it understands
3469 from the input BFD to the output BFD. This is done last to
3470 permit the routine to look at the filtered symbol table, which is
3471 important for the ECOFF code at least. */
3472 if (! bfd_copy_private_bfd_data (ibfd, obfd))
3474 bfd_nonfatal_message (NULL, obfd, NULL,
3475 _("error copying private BFD data"));
3476 return false;
3479 /* Switch to the alternate machine code. We have to do this at the
3480 very end, because we only initialize the header when we create
3481 the first section. */
3482 if (use_alt_mach_code != 0)
3484 if (! bfd_alt_mach_code (obfd, use_alt_mach_code))
3486 non_fatal (_("this target does not support %lu alternative machine codes"),
3487 use_alt_mach_code);
3488 if (bfd_get_flavour (obfd) == bfd_target_elf_flavour)
3490 non_fatal (_("treating that number as an absolute e_machine value instead"));
3491 elf_elfheader (obfd)->e_machine = use_alt_mach_code;
3493 else
3494 non_fatal (_("ignoring the alternative value"));
3498 return true;
3501 /* Read each archive element in turn from IBFD, copy the
3502 contents to temp file, and keep the temp file handle.
3503 If 'force_output_target' is TRUE then make sure that
3504 all elements in the new archive are of the type
3505 'output_target'. */
3507 static void
3508 copy_archive (bfd *ibfd, bfd *obfd, const char *output_target,
3509 bool force_output_target,
3510 const bfd_arch_info_type *input_arch)
3512 struct name_list
3514 struct name_list *next;
3515 const char *name;
3516 bfd *obfd;
3517 } *list, *l;
3518 bfd **ptr = &obfd->archive_head;
3519 bfd *this_element;
3520 char *dir;
3521 const char *filename;
3523 /* PR 24281: It is not clear what should happen when copying a thin archive.
3524 One part is straight forward - if the output archive is in a different
3525 directory from the input archive then any relative paths in the library
3526 should be adjusted to the new location. But if any transformation
3527 options are active (eg strip, rename, add, etc) then the implication is
3528 that these should be applied to the files pointed to by the archive.
3529 But since objcopy is not destructive, this means that new files must be
3530 created, and there is no guidance for the names of the new files. (Plus
3531 this conflicts with one of the goals of thin libraries - only taking up
3532 a minimal amount of space in the file system).
3534 So for now we fail if an attempt is made to copy such libraries. */
3535 if (ibfd->is_thin_archive)
3537 status = 1;
3538 bfd_set_error (bfd_error_invalid_operation);
3539 bfd_nonfatal_message (NULL, ibfd, NULL,
3540 _("sorry: copying thin archives is not currently supported"));
3541 return;
3544 /* Make a temp directory to hold the contents. */
3545 dir = make_tempdir (bfd_get_filename (obfd));
3546 if (dir == NULL)
3547 fatal (_("cannot create tempdir for archive copying (error: %s)"),
3548 strerror (errno));
3550 if (strip_symbols == STRIP_ALL)
3551 obfd->has_armap = false;
3552 else
3553 obfd->has_armap = ibfd->has_armap;
3554 obfd->is_thin_archive = ibfd->is_thin_archive;
3556 if (deterministic)
3557 obfd->flags |= BFD_DETERMINISTIC_OUTPUT;
3559 list = NULL;
3561 this_element = bfd_openr_next_archived_file (ibfd, NULL);
3563 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
3565 status = 1;
3566 bfd_nonfatal_message (NULL, obfd, NULL, NULL);
3567 goto cleanup_and_exit;
3570 while (!status && this_element != NULL)
3572 char *output_name;
3573 bfd *output_bfd;
3574 bfd *last_element;
3575 struct stat buf;
3576 int stat_status = 0;
3577 bool del = true;
3578 bool ok_object;
3580 /* PR binutils/17533: Do not allow directory traversal
3581 outside of the current directory tree by archive members. */
3582 if (! is_valid_archive_path (bfd_get_filename (this_element)))
3584 non_fatal (_("illegal pathname found in archive member: %s"),
3585 bfd_get_filename (this_element));
3586 status = 1;
3587 goto cleanup_and_exit;
3590 /* Create an output file for this member. */
3591 output_name = concat (dir, "/",
3592 bfd_get_filename (this_element), (char *) 0);
3594 /* If the file already exists, make another temp dir. */
3595 if (stat (output_name, &buf) >= 0)
3597 char * tmpdir = make_tempdir (output_name);
3599 free (output_name);
3600 if (tmpdir == NULL)
3602 non_fatal (_("cannot create tempdir for archive copying (error: %s)"),
3603 strerror (errno));
3604 status = 1;
3605 goto cleanup_and_exit;
3608 l = (struct name_list *) xmalloc (sizeof (struct name_list));
3609 l->name = tmpdir;
3610 l->next = list;
3611 l->obfd = NULL;
3612 list = l;
3613 output_name = concat (tmpdir, "/",
3614 bfd_get_filename (this_element), (char *) 0);
3617 if (preserve_dates)
3619 memset (&buf, 0, sizeof (buf));
3620 stat_status = bfd_stat_arch_elt (this_element, &buf);
3622 if (stat_status != 0)
3623 non_fatal (_("internal stat error on %s"),
3624 bfd_get_filename (this_element));
3627 l = (struct name_list *) xmalloc (sizeof (struct name_list));
3628 l->name = output_name;
3629 l->next = list;
3630 l->obfd = NULL;
3631 list = l;
3633 ok_object = bfd_check_format (this_element, bfd_object);
3634 if (!ok_object)
3635 bfd_nonfatal_message (NULL, this_element, NULL,
3636 _("Unable to recognise the format of file"));
3638 /* PR binutils/3110: Cope with archives
3639 containing multiple target types. */
3640 if (force_output_target || !ok_object)
3641 output_bfd = bfd_openw (output_name, output_target);
3642 else
3643 output_bfd = bfd_openw (output_name, bfd_get_target (this_element));
3645 if (output_bfd == NULL)
3647 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
3648 status = 1;
3649 goto cleanup_and_exit;
3652 if (ok_object)
3654 del = !copy_object (this_element, output_bfd, input_arch);
3656 if (del && bfd_get_arch (this_element) == bfd_arch_unknown)
3657 /* Try again as an unknown object file. */
3658 ok_object = false;
3659 else if (!bfd_close (output_bfd))
3661 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
3662 /* Error in new object file. Don't change archive. */
3663 status = 1;
3667 if (!ok_object)
3669 del = !copy_unknown_object (this_element, output_bfd);
3670 if (!bfd_close_all_done (output_bfd))
3672 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
3673 /* Error in new object file. Don't change archive. */
3674 status = 1;
3678 if (del)
3680 unlink (output_name);
3681 status = 1;
3683 else
3685 if (preserve_dates && stat_status == 0)
3686 set_times (output_name, &buf);
3688 /* Open the newly output file and attach to our list. */
3689 output_bfd = bfd_openr (output_name, output_target);
3691 l->obfd = output_bfd;
3693 *ptr = output_bfd;
3694 ptr = &output_bfd->archive_next;
3696 last_element = this_element;
3698 this_element = bfd_openr_next_archived_file (ibfd, last_element);
3700 bfd_close (last_element);
3703 *ptr = NULL;
3705 filename = bfd_get_filename (obfd);
3706 if (!bfd_close (obfd))
3708 status = 1;
3709 bfd_nonfatal_message (filename, NULL, NULL, NULL);
3712 filename = bfd_get_filename (ibfd);
3713 if (!bfd_close (ibfd))
3715 status = 1;
3716 bfd_nonfatal_message (filename, NULL, NULL, NULL);
3719 cleanup_and_exit:
3720 /* Delete all the files that we opened. */
3722 struct name_list * next;
3724 for (l = list; l != NULL; l = next)
3726 if (l->obfd == NULL)
3727 rmdir (l->name);
3728 else
3730 bfd_close (l->obfd);
3731 unlink (l->name);
3733 next = l->next;
3734 free (l);
3738 rmdir (dir);
3741 static void
3742 set_long_section_mode (bfd *output_bfd, bfd *input_bfd, enum long_section_name_handling style)
3744 /* This is only relevant to Coff targets. */
3745 if (bfd_get_flavour (output_bfd) == bfd_target_coff_flavour)
3747 if (style == KEEP
3748 && bfd_get_flavour (input_bfd) == bfd_target_coff_flavour)
3749 style = bfd_coff_long_section_names (input_bfd) ? ENABLE : DISABLE;
3750 bfd_coff_set_long_section_names (output_bfd, style != DISABLE);
3754 /* The top-level control. */
3756 static void
3757 copy_file (const char *input_filename, const char *output_filename, int ofd,
3758 struct stat *in_stat, const char *input_target,
3759 const char *output_target, const bfd_arch_info_type *input_arch)
3761 bfd *ibfd;
3762 char **obj_matching;
3763 char **core_matching;
3764 off_t size = get_file_size (input_filename);
3766 if (size < 1)
3768 if (size == 0)
3769 non_fatal (_("error: the input file '%s' is empty"),
3770 input_filename);
3771 status = 1;
3772 return;
3775 /* To allow us to do "strip *" without dying on the first
3776 non-object file, failures are nonfatal. */
3777 ibfd = bfd_openr (input_filename, input_target);
3778 if (ibfd == NULL || bfd_stat (ibfd, in_stat) != 0)
3780 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
3781 status = 1;
3782 return;
3785 switch (do_debug_sections)
3787 case compress:
3788 case compress_zlib:
3789 case compress_gnu_zlib:
3790 case compress_gabi_zlib:
3791 ibfd->flags |= BFD_COMPRESS;
3792 /* Don't check if input is ELF here since this information is
3793 only available after bfd_check_format_matches is called. */
3794 if (do_debug_sections != compress_gnu_zlib)
3795 ibfd->flags |= BFD_COMPRESS_GABI;
3796 break;
3797 case decompress:
3798 ibfd->flags |= BFD_DECOMPRESS;
3799 break;
3800 default:
3801 break;
3804 switch (do_elf_stt_common)
3806 case elf_stt_common:
3807 ibfd->flags |= BFD_CONVERT_ELF_COMMON | BFD_USE_ELF_STT_COMMON;
3808 break;
3809 break;
3810 case no_elf_stt_common:
3811 ibfd->flags |= BFD_CONVERT_ELF_COMMON;
3812 break;
3813 default:
3814 break;
3817 if (bfd_check_format (ibfd, bfd_archive))
3819 bool force_output_target;
3820 bfd *obfd;
3822 /* bfd_get_target does not return the correct value until
3823 bfd_check_format succeeds. */
3824 if (output_target == NULL)
3826 output_target = bfd_get_target (ibfd);
3827 force_output_target = false;
3829 else
3830 force_output_target = true;
3832 if (ofd >= 0)
3833 obfd = bfd_fdopenw (output_filename, output_target, ofd);
3834 else
3835 obfd = bfd_openw (output_filename, output_target);
3837 if (obfd == NULL)
3839 close (ofd);
3840 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
3841 status = 1;
3842 return;
3845 if (gnu_debuglink_filename != NULL)
3847 non_fatal (_("--add-gnu-debuglink ignored for archive %s"),
3848 bfd_get_filename (ibfd));
3849 gnu_debuglink_filename = NULL;
3852 /* This is a no-op on non-Coff targets. */
3853 set_long_section_mode (obfd, ibfd, long_section_names);
3855 copy_archive (ibfd, obfd, output_target, force_output_target, input_arch);
3857 else if (bfd_check_format_matches (ibfd, bfd_object, &obj_matching))
3859 bfd *obfd;
3860 do_copy:
3862 /* bfd_get_target does not return the correct value until
3863 bfd_check_format succeeds. */
3864 if (output_target == NULL)
3865 output_target = bfd_get_target (ibfd);
3867 if (ofd >= 0)
3868 obfd = bfd_fdopenw (output_filename, output_target, ofd);
3869 else
3870 obfd = bfd_openw (output_filename, output_target);
3872 if (obfd == NULL)
3874 close (ofd);
3875 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
3876 status = 1;
3877 return;
3880 /* This is a no-op on non-Coff targets. */
3881 set_long_section_mode (obfd, ibfd, long_section_names);
3883 if (! copy_object (ibfd, obfd, input_arch))
3884 status = 1;
3886 /* PR 17512: file: 0f15796a.
3887 If the file could not be copied it may not be in a writeable
3888 state. So use bfd_close_all_done to avoid the possibility of
3889 writing uninitialised data into the file. */
3890 if (! (status ? bfd_close_all_done (obfd) : bfd_close (obfd)))
3892 status = 1;
3893 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
3894 return;
3897 if (!bfd_close (ibfd))
3899 status = 1;
3900 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
3901 return;
3904 else
3906 bfd_error_type obj_error = bfd_get_error ();
3907 bfd_error_type core_error;
3909 if (bfd_check_format_matches (ibfd, bfd_core, &core_matching))
3911 /* This probably can't happen.. */
3912 if (obj_error == bfd_error_file_ambiguously_recognized)
3913 free (obj_matching);
3914 goto do_copy;
3917 core_error = bfd_get_error ();
3918 /* Report the object error in preference to the core error. */
3919 if (obj_error != core_error)
3920 bfd_set_error (obj_error);
3922 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
3924 if (obj_error == bfd_error_file_ambiguously_recognized)
3925 list_matching_formats (obj_matching);
3926 if (core_error == bfd_error_file_ambiguously_recognized)
3927 list_matching_formats (core_matching);
3929 status = 1;
3933 /* Add a name to the section renaming list. */
3935 static void
3936 add_section_rename (const char * old_name, const char * new_name,
3937 flagword flags)
3939 section_rename * srename;
3941 /* Check for conflicts first. */
3942 for (srename = section_rename_list; srename != NULL; srename = srename->next)
3943 if (strcmp (srename->old_name, old_name) == 0)
3945 /* Silently ignore duplicate definitions. */
3946 if (strcmp (srename->new_name, new_name) == 0
3947 && srename->flags == flags)
3948 return;
3950 fatal (_("Multiple renames of section %s"), old_name);
3953 srename = (section_rename *) xmalloc (sizeof (* srename));
3955 srename->old_name = old_name;
3956 srename->new_name = new_name;
3957 srename->flags = flags;
3958 srename->next = section_rename_list;
3960 section_rename_list = srename;
3963 /* Check the section rename list for a new name of the input section
3964 called OLD_NAME. Returns the new name if one is found and sets
3965 RETURNED_FLAGS if non-NULL to the flags to be used for this section. */
3967 static const char *
3968 find_section_rename (const char *old_name, flagword *returned_flags)
3970 const section_rename *srename;
3972 for (srename = section_rename_list; srename != NULL; srename = srename->next)
3973 if (strcmp (srename->old_name, old_name) == 0)
3975 if (returned_flags != NULL && srename->flags != (flagword) -1)
3976 *returned_flags = srename->flags;
3978 return srename->new_name;
3981 return old_name;
3984 /* Once each of the sections is copied, we may still need to do some
3985 finalization work for private section headers. Do that here. */
3987 static void
3988 setup_bfd_headers (bfd *ibfd, bfd *obfd)
3990 /* Allow the BFD backend to copy any private data it understands
3991 from the input section to the output section. */
3992 if (! bfd_copy_private_header_data (ibfd, obfd))
3994 status = 1;
3995 bfd_nonfatal_message (NULL, ibfd, NULL,
3996 _("error in private header data"));
3997 return;
4000 /* All went well. */
4001 return;
4004 /* Create a section in OBFD with the same
4005 name and attributes as ISECTION in IBFD. */
4007 static void
4008 setup_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
4010 bfd *obfd = (bfd *) obfdarg;
4011 struct section_list *p;
4012 sec_ptr osection;
4013 bfd_size_type size;
4014 bfd_vma vma;
4015 bfd_vma lma;
4016 flagword flags;
4017 const char *err = NULL;
4018 const char * name;
4019 const char * new_name;
4020 char *prefix = NULL;
4021 bool make_nobits;
4022 unsigned int alignment;
4024 if (is_strip_section (ibfd, isection))
4025 return;
4027 /* Get the, possibly new, name of the output section. */
4028 name = bfd_section_name (isection);
4029 flags = bfd_section_flags (isection);
4030 if (bfd_get_flavour (ibfd) != bfd_get_flavour (obfd))
4032 flags &= bfd_applicable_section_flags (ibfd);
4033 flags &= bfd_applicable_section_flags (obfd);
4035 new_name = find_section_rename (name, &flags);
4036 if (new_name != name)
4038 name = new_name;
4039 flags = check_new_section_flags (flags, obfd, name);
4042 /* Prefix sections. */
4043 if (prefix_alloc_sections_string
4044 && (bfd_section_flags (isection) & SEC_ALLOC) != 0)
4045 prefix = prefix_alloc_sections_string;
4046 else if (prefix_sections_string)
4047 prefix = prefix_sections_string;
4049 if (prefix)
4051 char *n;
4053 n = (char *) xmalloc (strlen (prefix) + strlen (name) + 1);
4054 strcpy (n, prefix);
4055 strcat (n, name);
4056 name = n;
4059 make_nobits = false;
4061 p = find_section_list (bfd_section_name (isection), false,
4062 SECTION_CONTEXT_SET_FLAGS);
4063 if (p != NULL)
4065 flags = p->flags | (flags & (SEC_HAS_CONTENTS | SEC_RELOC));
4066 flags = check_new_section_flags (flags, obfd, bfd_section_name (isection));
4068 else if (strip_symbols == STRIP_NONDEBUG
4069 && (flags & (SEC_ALLOC | SEC_GROUP)) != 0
4070 && !is_nondebug_keep_contents_section (ibfd, isection))
4072 flags &= ~(SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP);
4073 if (bfd_get_flavour (obfd) == bfd_target_elf_flavour)
4075 make_nobits = true;
4077 /* Twiddle the input section flags so that it seems to
4078 elf.c:copy_private_bfd_data that section flags have not
4079 changed between input and output sections. This hack
4080 prevents wholesale rewriting of the program headers. */
4081 isection->flags &= ~(SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP);
4085 osection = bfd_make_section_anyway_with_flags (obfd, name, flags);
4087 if (osection == NULL)
4089 err = _("failed to create output section");
4090 goto loser;
4093 size = bfd_section_size (isection);
4094 size = bfd_convert_section_size (ibfd, isection, obfd, size);
4095 if (copy_byte >= 0)
4096 size = (size + interleave - 1) / interleave * copy_width;
4097 else if (extract_symbol)
4098 size = 0;
4099 if (!bfd_set_section_size (osection, size))
4100 err = _("failed to set size");
4102 vma = bfd_section_vma (isection);
4103 p = find_section_list (bfd_section_name (isection), false,
4104 SECTION_CONTEXT_ALTER_VMA | SECTION_CONTEXT_SET_VMA);
4105 if (p != NULL)
4107 if (p->context & SECTION_CONTEXT_SET_VMA)
4108 vma = p->vma_val;
4109 else
4110 vma += p->vma_val;
4112 else
4113 vma += change_section_address;
4115 if (!bfd_set_section_vma (osection, vma))
4116 err = _("failed to set vma");
4118 lma = isection->lma;
4119 p = find_section_list (bfd_section_name (isection), false,
4120 SECTION_CONTEXT_ALTER_LMA | SECTION_CONTEXT_SET_LMA);
4121 if (p != NULL)
4123 if (p->context & SECTION_CONTEXT_ALTER_LMA)
4124 lma += p->lma_val;
4125 else
4126 lma = p->lma_val;
4128 else
4129 lma += change_section_address;
4131 osection->lma = lma;
4133 p = find_section_list (bfd_section_name (isection), false,
4134 SECTION_CONTEXT_SET_ALIGNMENT);
4135 if (p != NULL)
4136 alignment = p->alignment;
4137 else
4138 alignment = bfd_section_alignment (isection);
4140 /* FIXME: This is probably not enough. If we change the LMA we
4141 may have to recompute the header for the file as well. */
4142 if (!bfd_set_section_alignment (osection, alignment))
4143 err = _("failed to set alignment");
4145 /* Copy merge entity size. */
4146 osection->entsize = isection->entsize;
4148 /* Copy compress status. */
4149 osection->compress_status = isection->compress_status;
4151 /* This used to be mangle_section; we do here to avoid using
4152 bfd_get_section_by_name since some formats allow multiple
4153 sections with the same name. */
4154 isection->output_section = osection;
4155 isection->output_offset = 0;
4157 if ((isection->flags & SEC_GROUP) != 0)
4159 asymbol *gsym = group_signature (isection);
4161 if (gsym != NULL)
4163 gsym->flags |= BSF_KEEP;
4164 if (bfd_get_flavour (ibfd) == bfd_target_elf_flavour)
4165 elf_group_id (isection) = gsym;
4169 /* Allow the BFD backend to copy any private data it understands
4170 from the input section to the output section. */
4171 if (!bfd_copy_private_section_data (ibfd, isection, obfd, osection))
4172 err = _("failed to copy private data");
4174 if (make_nobits)
4175 elf_section_type (osection) = SHT_NOBITS;
4177 if (!err)
4178 return;
4180 loser:
4181 status = 1;
4182 bfd_nonfatal_message (NULL, obfd, osection, err);
4185 /* Return TRUE if input section ISECTION should be skipped. */
4187 static bool
4188 skip_section (bfd *ibfd, sec_ptr isection, bool skip_copy)
4190 sec_ptr osection;
4191 bfd_size_type size;
4192 flagword flags;
4194 /* If we have already failed earlier on,
4195 do not keep on generating complaints now. */
4196 if (status != 0)
4197 return true;
4199 if (extract_symbol)
4200 return true;
4202 if (is_strip_section (ibfd, isection))
4203 return true;
4205 if (is_update_section (ibfd, isection))
4206 return true;
4208 /* When merging a note section we skip the copying of the contents,
4209 but not the copying of the relocs associated with the contents. */
4210 if (skip_copy && is_mergeable_note_section (ibfd, isection))
4211 return true;
4213 flags = bfd_section_flags (isection);
4214 if ((flags & SEC_GROUP) != 0)
4215 return true;
4217 osection = isection->output_section;
4218 size = bfd_section_size (isection);
4220 if (size == 0 || osection == 0)
4221 return true;
4223 return false;
4226 /* Add section SECTION_PATTERN to the list of sections that will have their
4227 relocations removed. */
4229 static void
4230 handle_remove_relocations_option (const char *section_pattern)
4232 find_section_list (section_pattern, true, SECTION_CONTEXT_REMOVE_RELOCS);
4235 /* Return TRUE if ISECTION from IBFD should have its relocations removed,
4236 otherwise return FALSE. If the user has requested that relocations be
4237 removed from a section that does not have relocations then this
4238 function will still return TRUE. */
4240 static bool
4241 discard_relocations (bfd *ibfd ATTRIBUTE_UNUSED, asection *isection)
4243 return (find_section_list (bfd_section_name (isection), false,
4244 SECTION_CONTEXT_REMOVE_RELOCS) != NULL);
4247 /* Wrapper for dealing with --remove-section (-R) command line arguments.
4248 A special case is detected here, if the user asks to remove a relocation
4249 section (one starting with ".rela" or ".rel") then this removal must
4250 be done using a different technique in a relocatable object. */
4252 static void
4253 handle_remove_section_option (const char *section_pattern)
4255 find_section_list (section_pattern, true, SECTION_CONTEXT_REMOVE);
4256 if (startswith (section_pattern, ".rel"))
4258 section_pattern += 4;
4259 if (*section_pattern == 'a')
4260 section_pattern++;
4261 if (*section_pattern)
4262 handle_remove_relocations_option (section_pattern);
4264 sections_removed = true;
4267 /* Copy relocations in input section ISECTION of IBFD to an output
4268 section with the same name in OBFDARG. If stripping then don't
4269 copy any relocation info. */
4271 static void
4272 copy_relocations_in_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
4274 bfd *obfd = (bfd *) obfdarg;
4275 long relsize;
4276 arelent **relpp;
4277 long relcount;
4278 sec_ptr osection;
4280 if (skip_section (ibfd, isection, false))
4281 return;
4283 osection = isection->output_section;
4285 /* Core files and DWO files do not need to be relocated. */
4286 if (bfd_get_format (obfd) == bfd_core
4287 || strip_symbols == STRIP_NONDWO
4288 || discard_relocations (ibfd, isection))
4289 relsize = 0;
4290 else
4292 relsize = bfd_get_reloc_upper_bound (ibfd, isection);
4294 if (relsize < 0)
4296 /* Do not complain if the target does not support relocations. */
4297 if (relsize == -1 && bfd_get_error () == bfd_error_invalid_operation)
4298 relsize = 0;
4299 else
4301 status = 1;
4302 bfd_nonfatal_message (NULL, ibfd, isection, NULL);
4303 return;
4308 if (relsize == 0)
4310 bfd_set_reloc (obfd, osection, NULL, 0);
4311 osection->flags &= ~SEC_RELOC;
4313 else
4315 if (isection->orelocation != NULL)
4317 /* Some other function has already set up the output relocs
4318 for us, so scan those instead of the default relocs. */
4319 relcount = isection->reloc_count;
4320 relpp = isection->orelocation;
4322 else
4324 relpp = bfd_xalloc (obfd, relsize);
4325 relcount = bfd_canonicalize_reloc (ibfd, isection, relpp, isympp);
4326 if (relcount < 0)
4328 status = 1;
4329 bfd_nonfatal_message (NULL, ibfd, isection,
4330 _("relocation count is negative"));
4331 return;
4335 if (strip_symbols == STRIP_ALL)
4337 /* Remove relocations which are not in
4338 keep_strip_specific_list. */
4339 arelent **w_relpp;
4340 long i;
4342 for (w_relpp = relpp, i = 0; i < relcount; i++)
4343 /* PR 17512: file: 9e907e0c. */
4344 if (relpp[i]->sym_ptr_ptr
4345 /* PR 20096 */
4346 && *relpp[i]->sym_ptr_ptr
4347 && is_specified_symbol (bfd_asymbol_name (*relpp[i]->sym_ptr_ptr),
4348 keep_specific_htab))
4349 *w_relpp++ = relpp[i];
4350 relcount = w_relpp - relpp;
4351 *w_relpp = 0;
4354 bfd_set_reloc (obfd, osection, relcount == 0 ? NULL : relpp, relcount);
4355 if (relcount == 0)
4356 osection->flags &= ~SEC_RELOC;
4360 /* Copy the data of input section ISECTION of IBFD
4361 to an output section with the same name in OBFD. */
4363 static void
4364 copy_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
4366 bfd *obfd = (bfd *) obfdarg;
4367 struct section_list *p;
4368 sec_ptr osection;
4369 bfd_size_type size;
4371 if (skip_section (ibfd, isection, true))
4372 return;
4374 osection = isection->output_section;
4375 /* The output SHF_COMPRESSED section size is different from input if
4376 ELF classes of input and output aren't the same. We can't use
4377 the output section size since --interleave will shrink the output
4378 section. Size will be updated if the section is converted. */
4379 size = bfd_section_size (isection);
4381 if (bfd_section_flags (isection) & SEC_HAS_CONTENTS
4382 && bfd_section_flags (osection) & SEC_HAS_CONTENTS)
4384 bfd_byte *memhunk = NULL;
4386 if (!bfd_get_full_section_contents (ibfd, isection, &memhunk)
4387 || !bfd_convert_section_contents (ibfd, isection, obfd,
4388 &memhunk, &size))
4390 status = 1;
4391 bfd_nonfatal_message (NULL, ibfd, isection, NULL);
4392 free (memhunk);
4393 return;
4396 if (reverse_bytes)
4398 /* We don't handle leftover bytes (too many possible behaviors,
4399 and we don't know what the user wants). The section length
4400 must be a multiple of the number of bytes to swap. */
4401 if ((size % reverse_bytes) == 0)
4403 unsigned long i, j;
4404 bfd_byte b;
4406 for (i = 0; i < size; i += reverse_bytes)
4407 for (j = 0; j < (unsigned long)(reverse_bytes / 2); j++)
4409 bfd_byte *m = (bfd_byte *) memhunk;
4411 b = m[i + j];
4412 m[i + j] = m[(i + reverse_bytes) - (j + 1)];
4413 m[(i + reverse_bytes) - (j + 1)] = b;
4416 else
4417 /* User must pad the section up in order to do this. */
4418 fatal (_("cannot reverse bytes: length of section %s must be evenly divisible by %d"),
4419 bfd_section_name (isection), reverse_bytes);
4422 if (copy_byte >= 0)
4424 /* Keep only every `copy_byte'th byte in MEMHUNK. */
4425 char *from = (char *) memhunk + copy_byte;
4426 char *to = (char *) memhunk;
4427 char *end = (char *) memhunk + size;
4428 int i;
4430 /* If the section address is not exactly divisible by the interleave,
4431 then we must bias the from address. If the copy_byte is less than
4432 the bias, then we must skip forward one interleave, and increment
4433 the final lma. */
4434 int extra = isection->lma % interleave;
4435 from -= extra;
4436 if (copy_byte < extra)
4437 from += interleave;
4439 for (; from < end; from += interleave)
4440 for (i = 0; i < copy_width; i++)
4442 if (&from[i] >= end)
4443 break;
4444 *to++ = from[i];
4447 size = (size + interleave - 1 - copy_byte) / interleave * copy_width;
4448 osection->lma /= interleave;
4449 if (copy_byte < extra)
4450 osection->lma++;
4453 if (!bfd_set_section_contents (obfd, osection, memhunk, 0, size))
4455 status = 1;
4456 bfd_nonfatal_message (NULL, obfd, osection, NULL);
4457 free (memhunk);
4458 return;
4460 free (memhunk);
4462 else if ((p = find_section_list (bfd_section_name (isection),
4463 false, SECTION_CONTEXT_SET_FLAGS)) != NULL
4464 && (p->flags & SEC_HAS_CONTENTS) != 0)
4466 void *memhunk = xmalloc (size);
4468 /* We don't permit the user to turn off the SEC_HAS_CONTENTS
4469 flag--they can just remove the section entirely and add it
4470 back again. However, we do permit them to turn on the
4471 SEC_HAS_CONTENTS flag, and take it to mean that the section
4472 contents should be zeroed out. */
4474 memset (memhunk, 0, size);
4475 if (! bfd_set_section_contents (obfd, osection, memhunk, 0, size))
4477 status = 1;
4478 bfd_nonfatal_message (NULL, obfd, osection, NULL);
4479 free (memhunk);
4480 return;
4482 free (memhunk);
4486 /* Get all the sections. This is used when --gap-fill or --pad-to is
4487 used. */
4489 static void
4490 get_sections (bfd *obfd ATTRIBUTE_UNUSED, asection *osection, void *secppparg)
4492 asection ***secppp = (asection ***) secppparg;
4494 **secppp = osection;
4495 ++(*secppp);
4498 /* Sort sections by LMA. This is called via qsort, and is used when
4499 --gap-fill or --pad-to is used. We force non loadable or empty
4500 sections to the front, where they are easier to ignore. */
4502 static int
4503 compare_section_lma (const void *arg1, const void *arg2)
4505 const asection *sec1 = *(const asection **) arg1;
4506 const asection *sec2 = *(const asection **) arg2;
4507 flagword flags1, flags2;
4509 /* Sort non loadable sections to the front. */
4510 flags1 = sec1->flags;
4511 flags2 = sec2->flags;
4512 if ((flags1 & SEC_HAS_CONTENTS) == 0
4513 || (flags1 & SEC_LOAD) == 0)
4515 if ((flags2 & SEC_HAS_CONTENTS) != 0
4516 && (flags2 & SEC_LOAD) != 0)
4517 return -1;
4519 else
4521 if ((flags2 & SEC_HAS_CONTENTS) == 0
4522 || (flags2 & SEC_LOAD) == 0)
4523 return 1;
4526 /* Sort sections by LMA. */
4527 if (sec1->lma > sec2->lma)
4528 return 1;
4529 if (sec1->lma < sec2->lma)
4530 return -1;
4532 /* Sort sections with the same LMA by size. */
4533 if (bfd_section_size (sec1) > bfd_section_size (sec2))
4534 return 1;
4535 if (bfd_section_size (sec1) < bfd_section_size (sec2))
4536 return -1;
4538 if (sec1->id > sec2->id)
4539 return 1;
4540 if (sec1->id < sec2->id)
4541 return -1;
4542 return 0;
4545 /* Mark all the symbols which will be used in output relocations with
4546 the BSF_KEEP flag so that those symbols will not be stripped.
4548 Ignore relocations which will not appear in the output file. */
4550 static void
4551 mark_symbols_used_in_relocations (bfd *ibfd, sec_ptr isection, void *symbolsarg)
4553 asymbol **symbols = (asymbol **) symbolsarg;
4554 long relsize;
4555 arelent **relpp;
4556 long relcount, i;
4558 /* Ignore an input section with no corresponding output section. */
4559 if (isection->output_section == NULL)
4560 return;
4562 relsize = bfd_get_reloc_upper_bound (ibfd, isection);
4563 if (relsize < 0)
4565 /* Do not complain if the target does not support relocations. */
4566 if (relsize == -1 && bfd_get_error () == bfd_error_invalid_operation)
4567 return;
4568 bfd_fatal (bfd_get_filename (ibfd));
4571 if (relsize == 0)
4572 return;
4574 relpp = (arelent **) xmalloc (relsize);
4575 relcount = bfd_canonicalize_reloc (ibfd, isection, relpp, symbols);
4576 if (relcount < 0)
4577 bfd_fatal (bfd_get_filename (ibfd));
4579 /* Examine each symbol used in a relocation. If it's not one of the
4580 special bfd section symbols, then mark it with BSF_KEEP. */
4581 for (i = 0; i < relcount; i++)
4583 /* See PRs 20923 and 20930 for reproducers for the NULL tests. */
4584 if (relpp[i]->sym_ptr_ptr != NULL
4585 && * relpp[i]->sym_ptr_ptr != NULL
4586 && *relpp[i]->sym_ptr_ptr != bfd_com_section_ptr->symbol
4587 && *relpp[i]->sym_ptr_ptr != bfd_abs_section_ptr->symbol
4588 && *relpp[i]->sym_ptr_ptr != bfd_und_section_ptr->symbol)
4589 (*relpp[i]->sym_ptr_ptr)->flags |= BSF_KEEP;
4592 free (relpp);
4595 /* Write out debugging information. */
4597 static bool
4598 write_debugging_info (bfd *obfd, void *dhandle,
4599 long *symcountp ATTRIBUTE_UNUSED,
4600 asymbol ***symppp ATTRIBUTE_UNUSED)
4602 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour
4603 || bfd_get_flavour (obfd) == bfd_target_elf_flavour)
4605 bfd_byte *syms, *strings = NULL;
4606 bfd_size_type symsize, stringsize;
4607 asection *stabsec, *stabstrsec;
4608 flagword flags;
4610 if (! write_stabs_in_sections_debugging_info (obfd, dhandle, &syms,
4611 &symsize, &strings,
4612 &stringsize))
4613 return false;
4615 flags = SEC_HAS_CONTENTS | SEC_READONLY | SEC_DEBUGGING;
4616 stabsec = bfd_make_section_with_flags (obfd, ".stab", flags);
4617 stabstrsec = bfd_make_section_with_flags (obfd, ".stabstr", flags);
4618 if (stabsec == NULL
4619 || stabstrsec == NULL
4620 || !bfd_set_section_size (stabsec, symsize)
4621 || !bfd_set_section_size (stabstrsec, stringsize)
4622 || !bfd_set_section_alignment (stabsec, 2)
4623 || !bfd_set_section_alignment (stabstrsec, 0))
4625 bfd_nonfatal_message (NULL, obfd, NULL,
4626 _("can't create debugging section"));
4627 free (strings);
4628 return false;
4631 /* We can get away with setting the section contents now because
4632 the next thing the caller is going to do is copy over the
4633 real sections. We may someday have to split the contents
4634 setting out of this function. */
4635 if (! bfd_set_section_contents (obfd, stabsec, syms, 0, symsize)
4636 || ! bfd_set_section_contents (obfd, stabstrsec, strings, 0,
4637 stringsize))
4639 bfd_nonfatal_message (NULL, obfd, NULL,
4640 _("can't set debugging section contents"));
4641 free (strings);
4642 return false;
4645 return true;
4648 bfd_nonfatal_message (NULL, obfd, NULL,
4649 _("don't know how to write debugging information for %s"),
4650 bfd_get_target (obfd));
4651 return false;
4654 /* If neither -D nor -U was specified explicitly,
4655 then use the configured default. */
4656 static void
4657 default_deterministic (void)
4659 if (deterministic < 0)
4660 deterministic = DEFAULT_AR_DETERMINISTIC;
4663 static int
4664 strip_main (int argc, char *argv[])
4666 char *input_target = NULL;
4667 char *output_target = NULL;
4668 bool show_version = false;
4669 bool formats_info = false;
4670 int c;
4671 int i;
4672 char *output_file = NULL;
4673 bool merge_notes_set = false;
4675 while ((c = getopt_long (argc, argv, "I:O:F:K:MN:R:o:sSpdgxXHhVvwDU",
4676 strip_options, (int *) 0)) != EOF)
4678 switch (c)
4680 case 'I':
4681 input_target = optarg;
4682 break;
4683 case 'O':
4684 output_target = optarg;
4685 break;
4686 case 'F':
4687 input_target = output_target = optarg;
4688 break;
4689 case 'R':
4690 handle_remove_section_option (optarg);
4691 break;
4692 case OPTION_KEEP_SECTION:
4693 find_section_list (optarg, true, SECTION_CONTEXT_KEEP);
4694 break;
4695 case OPTION_REMOVE_RELOCS:
4696 handle_remove_relocations_option (optarg);
4697 break;
4698 case 's':
4699 strip_symbols = STRIP_ALL;
4700 break;
4701 case 'S':
4702 case 'g':
4703 case 'd': /* Historic BSD alias for -g. Used by early NetBSD. */
4704 strip_symbols = STRIP_DEBUG;
4705 break;
4706 case OPTION_STRIP_DWO:
4707 strip_symbols = STRIP_DWO;
4708 break;
4709 case OPTION_STRIP_UNNEEDED:
4710 strip_symbols = STRIP_UNNEEDED;
4711 break;
4712 case 'K':
4713 add_specific_symbol (optarg, keep_specific_htab);
4714 break;
4715 case 'M':
4716 merge_notes = true;
4717 merge_notes_set = true;
4718 break;
4719 case OPTION_NO_MERGE_NOTES:
4720 merge_notes = false;
4721 merge_notes_set = true;
4722 break;
4723 case 'N':
4724 add_specific_symbol (optarg, strip_specific_htab);
4725 break;
4726 case 'o':
4727 output_file = optarg;
4728 break;
4729 case 'p':
4730 preserve_dates = true;
4731 break;
4732 case 'D':
4733 deterministic = true;
4734 break;
4735 case 'U':
4736 deterministic = false;
4737 break;
4738 case 'x':
4739 discard_locals = LOCALS_ALL;
4740 break;
4741 case 'X':
4742 discard_locals = LOCALS_START_L;
4743 break;
4744 case 'v':
4745 verbose = true;
4746 break;
4747 case 'V':
4748 show_version = true;
4749 break;
4750 case OPTION_FORMATS_INFO:
4751 formats_info = true;
4752 break;
4753 case OPTION_ONLY_KEEP_DEBUG:
4754 strip_symbols = STRIP_NONDEBUG;
4755 break;
4756 case OPTION_KEEP_FILE_SYMBOLS:
4757 keep_file_symbols = 1;
4758 break;
4759 case OPTION_KEEP_SECTION_SYMBOLS:
4760 keep_section_symbols = true;
4761 break;
4762 case 0:
4763 /* We've been given a long option. */
4764 break;
4765 case 'w':
4766 wildcard = true;
4767 break;
4768 case 'H':
4769 case 'h':
4770 strip_usage (stdout, 0);
4771 default:
4772 strip_usage (stderr, 1);
4776 /* If the user has not expressly chosen to merge/not-merge ELF notes
4777 then enable the merging unless we are stripping debug or dwo info. */
4778 if (! merge_notes_set
4779 && (strip_symbols == STRIP_UNDEF
4780 || strip_symbols == STRIP_ALL
4781 || strip_symbols == STRIP_UNNEEDED
4782 || strip_symbols == STRIP_NONDEBUG
4783 || strip_symbols == STRIP_NONDWO))
4784 merge_notes = true;
4786 if (formats_info)
4788 display_info ();
4789 return 0;
4792 if (show_version)
4793 print_version ("strip");
4795 default_deterministic ();
4797 /* Default is to strip all symbols. */
4798 if (strip_symbols == STRIP_UNDEF
4799 && discard_locals == LOCALS_UNDEF
4800 && htab_elements (strip_specific_htab) == 0)
4801 strip_symbols = STRIP_ALL;
4803 if (output_target == NULL)
4804 output_target = input_target;
4806 i = optind;
4807 if (i == argc
4808 || (output_file != NULL && (i + 1) < argc))
4809 strip_usage (stderr, 1);
4811 for (; i < argc; i++)
4813 int hold_status = status;
4814 struct stat statbuf;
4815 char *tmpname;
4816 int tmpfd = -1;
4817 int copyfd = -1;
4819 if (get_file_size (argv[i]) < 1)
4821 status = 1;
4822 continue;
4825 if (output_file == NULL
4826 || filename_cmp (argv[i], output_file) == 0)
4828 tmpname = make_tempname (argv[i], &tmpfd);
4829 if (tmpfd >= 0)
4830 copyfd = dup (tmpfd);
4832 else
4833 tmpname = output_file;
4835 if (tmpname == NULL)
4837 bfd_nonfatal_message (argv[i], NULL, NULL,
4838 _("could not create temporary file to hold stripped copy"));
4839 status = 1;
4840 continue;
4843 status = 0;
4844 copy_file (argv[i], tmpname, tmpfd, &statbuf, input_target,
4845 output_target, NULL);
4846 if (status == 0)
4848 const char *oname = output_file ? output_file : argv[i];
4849 status = smart_rename (tmpname, oname, copyfd,
4850 &statbuf, preserve_dates) != 0;
4851 if (status == 0)
4852 status = hold_status;
4854 else
4856 if (copyfd >= 0)
4857 close (copyfd);
4858 unlink_if_ordinary (tmpname);
4860 if (output_file != tmpname)
4861 free (tmpname);
4864 return status;
4867 /* Set up PE subsystem. */
4869 static void
4870 set_pe_subsystem (const char *s)
4872 const char *version, *subsystem;
4873 size_t i;
4874 static const struct
4876 const char *name;
4877 const char set_def;
4878 const short value;
4880 v[] =
4882 { "native", 0, IMAGE_SUBSYSTEM_NATIVE },
4883 { "windows", 0, IMAGE_SUBSYSTEM_WINDOWS_GUI },
4884 { "console", 0, IMAGE_SUBSYSTEM_WINDOWS_CUI },
4885 { "posix", 0, IMAGE_SUBSYSTEM_POSIX_CUI },
4886 { "wince", 0, IMAGE_SUBSYSTEM_WINDOWS_CE_GUI },
4887 { "efi-app", 1, IMAGE_SUBSYSTEM_EFI_APPLICATION },
4888 { "efi-bsd", 1, IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER },
4889 { "efi-rtd", 1, IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER },
4890 { "sal-rtd", 1, IMAGE_SUBSYSTEM_SAL_RUNTIME_DRIVER },
4891 { "xbox", 0, IMAGE_SUBSYSTEM_XBOX }
4893 short value;
4894 char *copy;
4895 int set_def = -1;
4897 /* Check for the presence of a version number. */
4898 version = strchr (s, ':');
4899 if (version == NULL)
4900 subsystem = s;
4901 else
4903 int len = version - s;
4904 copy = xstrdup (s);
4905 subsystem = copy;
4906 copy[len] = '\0';
4907 version = copy + 1 + len;
4908 pe_major_subsystem_version = strtoul (version, &copy, 0);
4909 if (*copy == '.')
4910 pe_minor_subsystem_version = strtoul (copy + 1, &copy, 0);
4911 if (*copy != '\0')
4912 non_fatal (_("%s: bad version in PE subsystem"), s);
4915 /* Check for numeric subsystem. */
4916 value = (short) strtol (subsystem, &copy, 0);
4917 if (*copy == '\0')
4919 for (i = 0; i < ARRAY_SIZE (v); i++)
4920 if (v[i].value == value)
4922 pe_subsystem = value;
4923 set_def = v[i].set_def;
4924 break;
4927 else
4929 /* Search for subsystem by name. */
4930 for (i = 0; i < ARRAY_SIZE (v); i++)
4931 if (strcmp (subsystem, v[i].name) == 0)
4933 pe_subsystem = v[i].value;
4934 set_def = v[i].set_def;
4935 break;
4939 switch (set_def)
4941 case -1:
4942 fatal (_("unknown PE subsystem: %s"), s);
4943 break;
4944 case 0:
4945 break;
4946 default:
4947 if (pe_file_alignment == (bfd_vma) -1)
4948 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
4949 if (pe_section_alignment == (bfd_vma) -1)
4950 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
4951 break;
4953 if (s != subsystem)
4954 free ((char *) subsystem);
4957 /* Convert EFI target to PEI target. */
4959 static int
4960 convert_efi_target (char **targ)
4962 size_t len;
4963 char *pei;
4964 char *efi = *targ + 4;
4965 int subsys = -1;
4967 if (startswith (efi, "app-"))
4968 subsys = IMAGE_SUBSYSTEM_EFI_APPLICATION;
4969 else if (startswith (efi, "bsdrv-"))
4971 subsys = IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER;
4972 efi += 2;
4974 else if (startswith (efi, "rtdrv-"))
4976 subsys = IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER;
4977 efi += 2;
4979 else
4980 return subsys;
4982 len = strlen (efi);
4983 pei = xmalloc (len + sizeof ("-little"));
4984 memcpy (pei, efi, len + 1);
4985 pei[0] = 'p';
4986 pei[1] = 'e';
4987 pei[2] = 'i';
4989 if (strcmp (efi + 4, "ia32") == 0)
4991 /* Change ia32 to i386. */
4992 pei[5]= '3';
4993 pei[6]= '8';
4994 pei[7]= '6';
4996 else if (strcmp (efi + 4, "x86_64") == 0)
4998 /* Change x86_64 to x86-64. */
4999 pei[7] = '-';
5001 else if (strcmp (efi + 4, "aarch64") == 0)
5003 /* Change aarch64 to aarch64-little. */
5004 memcpy (pei + 4 + sizeof ("aarch64") - 1, "-little", sizeof ("-little"));
5006 *targ = pei;
5007 return subsys;
5010 /* Allocate and return a pointer to a struct section_add, initializing the
5011 structure using ARG, a string in the format "sectionname=filename".
5012 The returned structure will have its next pointer set to NEXT. The
5013 OPTION field is the name of the command line option currently being
5014 parsed, and is only used if an error needs to be reported. */
5016 static struct section_add *
5017 init_section_add (const char *arg,
5018 struct section_add *next,
5019 const char *option)
5021 struct section_add *pa;
5022 const char *s;
5024 s = strchr (arg, '=');
5025 if (s == NULL)
5026 fatal (_("bad format for %s"), option);
5028 pa = (struct section_add *) xmalloc (sizeof (struct section_add));
5029 pa->name = xstrndup (arg, s - arg);
5030 pa->filename = s + 1;
5031 pa->next = next;
5032 pa->contents = NULL;
5033 pa->size = 0;
5035 return pa;
5038 /* Load the file specified in PA, allocating memory to hold the file
5039 contents, and store a pointer to the allocated memory in the contents
5040 field of PA. The size field of PA is also updated. All errors call
5041 FATAL. */
5043 static void
5044 section_add_load_file (struct section_add *pa)
5046 size_t off, alloc;
5047 FILE *f;
5049 /* We don't use get_file_size so that we can do
5050 --add-section .note.GNU_stack=/dev/null
5051 get_file_size doesn't work on /dev/null. */
5053 f = fopen (pa->filename, FOPEN_RB);
5054 if (f == NULL)
5055 fatal (_("cannot open: %s: %s"),
5056 pa->filename, strerror (errno));
5058 off = 0;
5059 alloc = 4096;
5060 pa->contents = (bfd_byte *) xmalloc (alloc);
5061 while (!feof (f))
5063 off_t got;
5065 if (off == alloc)
5067 alloc <<= 1;
5068 pa->contents = (bfd_byte *) xrealloc (pa->contents, alloc);
5071 got = fread (pa->contents + off, 1, alloc - off, f);
5072 if (ferror (f))
5073 fatal (_("%s: fread failed"), pa->filename);
5075 off += got;
5078 pa->size = off;
5080 fclose (f);
5083 static int
5084 copy_main (int argc, char *argv[])
5086 char *input_filename = NULL;
5087 char *output_filename = NULL;
5088 char *tmpname;
5089 char *input_target = NULL;
5090 char *output_target = NULL;
5091 bool show_version = false;
5092 bool change_warn = true;
5093 bool formats_info = false;
5094 bool use_globalize = false;
5095 bool use_keep_global = false;
5096 int c;
5097 int tmpfd = -1;
5098 int copyfd;
5099 struct stat statbuf;
5100 const bfd_arch_info_type *input_arch = NULL;
5102 while ((c = getopt_long (argc, argv, "b:B:i:I:j:K:MN:s:O:d:F:L:G:R:SpgxXHhVvW:wDU",
5103 copy_options, (int *) 0)) != EOF)
5105 switch (c)
5107 case 'b':
5108 copy_byte = atoi (optarg);
5109 if (copy_byte < 0)
5110 fatal (_("byte number must be non-negative"));
5111 break;
5113 case 'B':
5114 input_arch = bfd_scan_arch (optarg);
5115 if (input_arch == NULL)
5116 fatal (_("architecture %s unknown"), optarg);
5117 break;
5119 case 'i':
5120 if (optarg)
5122 interleave = atoi (optarg);
5123 if (interleave < 1)
5124 fatal (_("interleave must be positive"));
5126 else
5127 interleave = 4;
5128 break;
5130 case OPTION_INTERLEAVE_WIDTH:
5131 copy_width = atoi (optarg);
5132 if (copy_width < 1)
5133 fatal(_("interleave width must be positive"));
5134 break;
5136 case 'I':
5137 case 's': /* "source" - 'I' is preferred */
5138 input_target = optarg;
5139 break;
5141 case 'O':
5142 case 'd': /* "destination" - 'O' is preferred */
5143 output_target = optarg;
5144 break;
5146 case 'F':
5147 input_target = output_target = optarg;
5148 break;
5150 case 'j':
5151 find_section_list (optarg, true, SECTION_CONTEXT_COPY);
5152 sections_copied = true;
5153 break;
5155 case 'R':
5156 handle_remove_section_option (optarg);
5157 break;
5159 case OPTION_KEEP_SECTION:
5160 find_section_list (optarg, true, SECTION_CONTEXT_KEEP);
5161 break;
5163 case OPTION_REMOVE_RELOCS:
5164 handle_remove_relocations_option (optarg);
5165 break;
5167 case 'S':
5168 strip_symbols = STRIP_ALL;
5169 break;
5171 case 'g':
5172 strip_symbols = STRIP_DEBUG;
5173 break;
5175 case OPTION_STRIP_DWO:
5176 strip_symbols = STRIP_DWO;
5177 break;
5179 case OPTION_STRIP_UNNEEDED:
5180 strip_symbols = STRIP_UNNEEDED;
5181 break;
5183 case OPTION_ONLY_KEEP_DEBUG:
5184 strip_symbols = STRIP_NONDEBUG;
5185 break;
5187 case OPTION_KEEP_FILE_SYMBOLS:
5188 keep_file_symbols = 1;
5189 break;
5191 case OPTION_ADD_GNU_DEBUGLINK:
5192 long_section_names = ENABLE ;
5193 gnu_debuglink_filename = optarg;
5194 break;
5196 case 'K':
5197 add_specific_symbol (optarg, keep_specific_htab);
5198 break;
5200 case 'M':
5201 merge_notes = true;
5202 break;
5203 case OPTION_NO_MERGE_NOTES:
5204 merge_notes = false;
5205 break;
5207 case 'N':
5208 add_specific_symbol (optarg, strip_specific_htab);
5209 break;
5211 case OPTION_STRIP_UNNEEDED_SYMBOL:
5212 add_specific_symbol (optarg, strip_unneeded_htab);
5213 break;
5215 case 'L':
5216 add_specific_symbol (optarg, localize_specific_htab);
5217 break;
5219 case OPTION_GLOBALIZE_SYMBOL:
5220 use_globalize = true;
5221 add_specific_symbol (optarg, globalize_specific_htab);
5222 break;
5224 case 'G':
5225 use_keep_global = true;
5226 add_specific_symbol (optarg, keepglobal_specific_htab);
5227 break;
5229 case 'W':
5230 add_specific_symbol (optarg, weaken_specific_htab);
5231 break;
5233 case 'p':
5234 preserve_dates = true;
5235 break;
5237 case 'D':
5238 deterministic = true;
5239 break;
5241 case 'U':
5242 deterministic = false;
5243 break;
5245 case 'w':
5246 wildcard = true;
5247 break;
5249 case 'x':
5250 discard_locals = LOCALS_ALL;
5251 break;
5253 case 'X':
5254 discard_locals = LOCALS_START_L;
5255 break;
5257 case 'v':
5258 verbose = true;
5259 break;
5261 case 'V':
5262 show_version = true;
5263 break;
5265 case OPTION_FORMATS_INFO:
5266 formats_info = true;
5267 break;
5269 case OPTION_WEAKEN:
5270 weaken = true;
5271 break;
5273 case OPTION_ADD_SECTION:
5274 add_sections = init_section_add (optarg, add_sections,
5275 "--add-section");
5276 section_add_load_file (add_sections);
5277 break;
5279 case OPTION_UPDATE_SECTION:
5280 update_sections = init_section_add (optarg, update_sections,
5281 "--update-section");
5282 section_add_load_file (update_sections);
5283 break;
5285 case OPTION_DUMP_SECTION:
5286 dump_sections = init_section_add (optarg, dump_sections,
5287 "--dump-section");
5288 break;
5290 case OPTION_ADD_SYMBOL:
5292 char *s, *t;
5293 struct addsym_node *newsym = xmalloc (sizeof *newsym);
5295 newsym->next = NULL;
5296 s = strchr (optarg, '=');
5297 if (s == NULL)
5298 fatal (_("bad format for %s"), "--add-symbol");
5299 t = strchr (s + 1, ':');
5301 newsym->symdef = xstrndup (optarg, s - optarg);
5302 if (t)
5304 newsym->section = xstrndup (s + 1, t - (s + 1));
5305 newsym->symval = strtol (t + 1, NULL, 0);
5307 else
5309 newsym->section = NULL;
5310 newsym->symval = strtol (s + 1, NULL, 0);
5311 t = s;
5314 t = strchr (t + 1, ',');
5315 newsym->othersym = NULL;
5316 if (t)
5317 newsym->flags = parse_symflags (t+1, &newsym->othersym);
5318 else
5319 newsym->flags = BSF_GLOBAL;
5321 /* Keep 'othersym' symbols at the front of the list. */
5322 if (newsym->othersym)
5324 newsym->next = add_sym_list;
5325 if (!add_sym_list)
5326 add_sym_tail = &newsym->next;
5327 add_sym_list = newsym;
5329 else
5331 *add_sym_tail = newsym;
5332 add_sym_tail = &newsym->next;
5334 add_symbols++;
5336 break;
5338 case OPTION_CHANGE_START:
5339 change_start = parse_vma (optarg, "--change-start");
5340 break;
5342 case OPTION_CHANGE_SECTION_ADDRESS:
5343 case OPTION_CHANGE_SECTION_LMA:
5344 case OPTION_CHANGE_SECTION_VMA:
5346 struct section_list * p;
5347 unsigned int context = 0;
5348 const char *s;
5349 int len;
5350 char *name;
5351 char *option = NULL;
5352 bfd_vma val;
5354 switch (c)
5356 case OPTION_CHANGE_SECTION_ADDRESS:
5357 option = "--change-section-address";
5358 context = SECTION_CONTEXT_ALTER_LMA | SECTION_CONTEXT_ALTER_VMA;
5359 break;
5360 case OPTION_CHANGE_SECTION_LMA:
5361 option = "--change-section-lma";
5362 context = SECTION_CONTEXT_ALTER_LMA;
5363 break;
5364 case OPTION_CHANGE_SECTION_VMA:
5365 option = "--change-section-vma";
5366 context = SECTION_CONTEXT_ALTER_VMA;
5367 break;
5370 s = strchr (optarg, '=');
5371 if (s == NULL)
5373 s = strchr (optarg, '+');
5374 if (s == NULL)
5376 s = strchr (optarg, '-');
5377 if (s == NULL)
5378 fatal (_("bad format for %s"), option);
5381 else
5383 /* Correct the context. */
5384 switch (c)
5386 case OPTION_CHANGE_SECTION_ADDRESS:
5387 context = SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_SET_VMA;
5388 break;
5389 case OPTION_CHANGE_SECTION_LMA:
5390 context = SECTION_CONTEXT_SET_LMA;
5391 break;
5392 case OPTION_CHANGE_SECTION_VMA:
5393 context = SECTION_CONTEXT_SET_VMA;
5394 break;
5398 len = s - optarg;
5399 name = (char *) xmalloc (len + 1);
5400 strncpy (name, optarg, len);
5401 name[len] = '\0';
5403 p = find_section_list (name, true, context);
5405 val = parse_vma (s + 1, option);
5406 if (*s == '-')
5407 val = - val;
5409 switch (c)
5411 case OPTION_CHANGE_SECTION_ADDRESS:
5412 p->vma_val = val;
5413 /* Fall through. */
5415 case OPTION_CHANGE_SECTION_LMA:
5416 p->lma_val = val;
5417 break;
5419 case OPTION_CHANGE_SECTION_VMA:
5420 p->vma_val = val;
5421 break;
5424 break;
5426 case OPTION_CHANGE_ADDRESSES:
5427 change_section_address = parse_vma (optarg, "--change-addresses");
5428 change_start = change_section_address;
5429 break;
5431 case OPTION_CHANGE_WARNINGS:
5432 change_warn = true;
5433 break;
5435 case OPTION_CHANGE_LEADING_CHAR:
5436 change_leading_char = true;
5437 break;
5439 case OPTION_COMPRESS_DEBUG_SECTIONS:
5440 if (optarg)
5442 if (strcasecmp (optarg, "none") == 0)
5443 do_debug_sections = decompress;
5444 else if (strcasecmp (optarg, "zlib") == 0)
5445 do_debug_sections = compress_zlib;
5446 else if (strcasecmp (optarg, "zlib-gnu") == 0)
5447 do_debug_sections = compress_gnu_zlib;
5448 else if (strcasecmp (optarg, "zlib-gabi") == 0)
5449 do_debug_sections = compress_gabi_zlib;
5450 else
5451 fatal (_("unrecognized --compress-debug-sections type `%s'"),
5452 optarg);
5454 else
5455 do_debug_sections = compress;
5456 break;
5458 case OPTION_DEBUGGING:
5459 convert_debugging = true;
5460 break;
5462 case OPTION_DECOMPRESS_DEBUG_SECTIONS:
5463 do_debug_sections = decompress;
5464 break;
5466 case OPTION_ELF_STT_COMMON:
5467 if (strcasecmp (optarg, "yes") == 0)
5468 do_elf_stt_common = elf_stt_common;
5469 else if (strcasecmp (optarg, "no") == 0)
5470 do_elf_stt_common = no_elf_stt_common;
5471 else
5472 fatal (_("unrecognized --elf-stt-common= option `%s'"),
5473 optarg);
5474 break;
5476 case OPTION_GAP_FILL:
5478 bfd_vma gap_fill_vma;
5480 gap_fill_vma = parse_vma (optarg, "--gap-fill");
5481 gap_fill = (bfd_byte) gap_fill_vma;
5482 if ((bfd_vma) gap_fill != gap_fill_vma)
5483 non_fatal (_("Warning: truncating gap-fill from 0x%" PRIx64
5484 " to 0x%x"),
5485 (uint64_t) gap_fill_vma, gap_fill);
5486 gap_fill_set = true;
5488 break;
5490 case OPTION_NO_CHANGE_WARNINGS:
5491 change_warn = false;
5492 break;
5494 case OPTION_PAD_TO:
5495 pad_to = parse_vma (optarg, "--pad-to");
5496 pad_to_set = true;
5497 break;
5499 case OPTION_REMOVE_LEADING_CHAR:
5500 remove_leading_char = true;
5501 break;
5503 case OPTION_REDEFINE_SYM:
5505 /* Insert this redefinition onto redefine_specific_htab. */
5507 int len;
5508 const char *s;
5509 const char *nextarg;
5510 char *source, *target;
5512 s = strchr (optarg, '=');
5513 if (s == NULL)
5514 fatal (_("bad format for %s"), "--redefine-sym");
5516 len = s - optarg;
5517 source = (char *) xmalloc (len + 1);
5518 strncpy (source, optarg, len);
5519 source[len] = '\0';
5521 nextarg = s + 1;
5522 len = strlen (nextarg);
5523 target = (char *) xmalloc (len + 1);
5524 strcpy (target, nextarg);
5526 add_redefine_and_check ("--redefine-sym", source, target);
5528 free (source);
5529 free (target);
5531 break;
5533 case OPTION_REDEFINE_SYMS:
5534 add_redefine_syms_file (optarg);
5535 break;
5537 case OPTION_SET_SECTION_FLAGS:
5539 struct section_list *p;
5540 const char *s;
5541 int len;
5542 char *name;
5544 s = strchr (optarg, '=');
5545 if (s == NULL)
5546 fatal (_("bad format for %s"), "--set-section-flags");
5548 len = s - optarg;
5549 name = (char *) xmalloc (len + 1);
5550 strncpy (name, optarg, len);
5551 name[len] = '\0';
5553 p = find_section_list (name, true, SECTION_CONTEXT_SET_FLAGS);
5555 p->flags = parse_flags (s + 1);
5557 break;
5559 case OPTION_SET_SECTION_ALIGNMENT:
5561 struct section_list *p;
5562 const char *s;
5563 int len;
5564 char *name;
5565 int palign, align;
5567 s = strchr (optarg, '=');
5568 if (s == NULL)
5569 fatal (_("bad format for --set-section-alignment: argument needed"));
5571 align = atoi (s + 1);
5572 if (align <= 0)
5573 fatal (_("bad format for --set-section-alignment: numeric argument needed"));
5575 /* Convert integer alignment into a power-of-two alignment. */
5576 palign = 0;
5577 while ((align & 1) == 0)
5579 align >>= 1;
5580 ++palign;
5583 if (align != 1)
5584 /* Number has more than on 1, i.e. wasn't a power of 2. */
5585 fatal (_("bad format for --set-section-alignment: alignment is not a power of two"));
5587 /* Add the alignment setting to the section list. */
5588 len = s - optarg;
5589 name = (char *) xmalloc (len + 1);
5590 strncpy (name, optarg, len);
5591 name[len] = '\0';
5593 p = find_section_list (name, true, SECTION_CONTEXT_SET_ALIGNMENT);
5594 if (p)
5595 p->alignment = palign;
5597 break;
5599 case OPTION_RENAME_SECTION:
5601 flagword flags;
5602 const char *eq, *fl;
5603 char *old_name;
5604 char *new_name;
5605 unsigned int len;
5607 eq = strchr (optarg, '=');
5608 if (eq == NULL)
5609 fatal (_("bad format for %s"), "--rename-section");
5611 len = eq - optarg;
5612 if (len == 0)
5613 fatal (_("bad format for %s"), "--rename-section");
5615 old_name = (char *) xmalloc (len + 1);
5616 strncpy (old_name, optarg, len);
5617 old_name[len] = 0;
5619 eq++;
5620 fl = strchr (eq, ',');
5621 if (fl)
5623 flags = parse_flags (fl + 1);
5624 len = fl - eq;
5626 else
5628 flags = -1;
5629 len = strlen (eq);
5632 if (len == 0)
5633 fatal (_("bad format for %s"), "--rename-section");
5635 new_name = (char *) xmalloc (len + 1);
5636 strncpy (new_name, eq, len);
5637 new_name[len] = 0;
5639 add_section_rename (old_name, new_name, flags);
5641 break;
5643 case OPTION_SET_START:
5644 set_start = parse_vma (optarg, "--set-start");
5645 set_start_set = true;
5646 break;
5648 case OPTION_SREC_LEN:
5649 _bfd_srec_len = parse_vma (optarg, "--srec-len");
5650 break;
5652 case OPTION_SREC_FORCES3:
5653 _bfd_srec_forceS3 = true;
5654 break;
5656 case OPTION_STRIP_SYMBOLS:
5657 add_specific_symbols (optarg, strip_specific_htab,
5658 &strip_specific_buffer);
5659 break;
5661 case OPTION_STRIP_UNNEEDED_SYMBOLS:
5662 add_specific_symbols (optarg, strip_unneeded_htab,
5663 &strip_unneeded_buffer);
5664 break;
5666 case OPTION_KEEP_SYMBOLS:
5667 add_specific_symbols (optarg, keep_specific_htab,
5668 &keep_specific_buffer);
5669 break;
5671 case OPTION_KEEP_SECTION_SYMBOLS:
5672 keep_section_symbols = true;
5673 break;
5675 case OPTION_LOCALIZE_HIDDEN:
5676 localize_hidden = true;
5677 break;
5679 case OPTION_LOCALIZE_SYMBOLS:
5680 add_specific_symbols (optarg, localize_specific_htab,
5681 &localize_specific_buffer);
5682 break;
5684 case OPTION_LONG_SECTION_NAMES:
5685 if (!strcmp ("enable", optarg))
5686 long_section_names = ENABLE;
5687 else if (!strcmp ("disable", optarg))
5688 long_section_names = DISABLE;
5689 else if (!strcmp ("keep", optarg))
5690 long_section_names = KEEP;
5691 else
5692 fatal (_("unknown long section names option '%s'"), optarg);
5693 break;
5695 case OPTION_GLOBALIZE_SYMBOLS:
5696 use_globalize = true;
5697 add_specific_symbols (optarg, globalize_specific_htab,
5698 &globalize_specific_buffer);
5699 break;
5701 case OPTION_KEEPGLOBAL_SYMBOLS:
5702 use_keep_global = true;
5703 add_specific_symbols (optarg, keepglobal_specific_htab,
5704 &keepglobal_specific_buffer);
5705 break;
5707 case OPTION_WEAKEN_SYMBOLS:
5708 add_specific_symbols (optarg, weaken_specific_htab,
5709 &weaken_specific_buffer);
5710 break;
5712 case OPTION_ALT_MACH_CODE:
5713 use_alt_mach_code = strtoul (optarg, NULL, 0);
5714 if (use_alt_mach_code == 0)
5715 fatal (_("unable to parse alternative machine code"));
5716 break;
5718 case OPTION_PREFIX_SYMBOLS:
5719 prefix_symbols_string = optarg;
5720 break;
5722 case OPTION_PREFIX_SECTIONS:
5723 prefix_sections_string = optarg;
5724 break;
5726 case OPTION_PREFIX_ALLOC_SECTIONS:
5727 prefix_alloc_sections_string = optarg;
5728 break;
5730 case OPTION_READONLY_TEXT:
5731 bfd_flags_to_set |= WP_TEXT;
5732 bfd_flags_to_clear &= ~WP_TEXT;
5733 break;
5735 case OPTION_WRITABLE_TEXT:
5736 bfd_flags_to_clear |= WP_TEXT;
5737 bfd_flags_to_set &= ~WP_TEXT;
5738 break;
5740 case OPTION_PURE:
5741 bfd_flags_to_set |= D_PAGED;
5742 bfd_flags_to_clear &= ~D_PAGED;
5743 break;
5745 case OPTION_IMPURE:
5746 bfd_flags_to_clear |= D_PAGED;
5747 bfd_flags_to_set &= ~D_PAGED;
5748 break;
5750 case OPTION_EXTRACT_DWO:
5751 strip_symbols = STRIP_NONDWO;
5752 break;
5754 case OPTION_EXTRACT_SYMBOL:
5755 extract_symbol = true;
5756 break;
5758 case OPTION_REVERSE_BYTES:
5760 int prev = reverse_bytes;
5762 reverse_bytes = atoi (optarg);
5763 if ((reverse_bytes <= 0) || ((reverse_bytes % 2) != 0))
5764 fatal (_("number of bytes to reverse must be positive and even"));
5766 if (prev && prev != reverse_bytes)
5767 non_fatal (_("Warning: ignoring previous --reverse-bytes value of %d"),
5768 prev);
5769 break;
5772 case OPTION_FILE_ALIGNMENT:
5773 pe_file_alignment = parse_vma (optarg, "--file-alignment");
5774 break;
5776 case OPTION_HEAP:
5778 char *end;
5779 pe_heap_reserve = strtoul (optarg, &end, 0);
5780 if (end == optarg
5781 || (*end != '.' && *end != '\0'))
5782 non_fatal (_("%s: invalid reserve value for --heap"),
5783 optarg);
5784 else if (*end != '\0')
5786 pe_heap_commit = strtoul (end + 1, &end, 0);
5787 if (*end != '\0')
5788 non_fatal (_("%s: invalid commit value for --heap"),
5789 optarg);
5792 break;
5794 case OPTION_IMAGE_BASE:
5795 pe_image_base = parse_vma (optarg, "--image-base");
5796 break;
5798 case OPTION_PE_SECTION_ALIGNMENT:
5799 pe_section_alignment = parse_vma (optarg,
5800 "--section-alignment");
5801 break;
5803 case OPTION_SUBSYSTEM:
5804 set_pe_subsystem (optarg);
5805 break;
5807 case OPTION_STACK:
5809 char *end;
5810 pe_stack_reserve = strtoul (optarg, &end, 0);
5811 if (end == optarg
5812 || (*end != '.' && *end != '\0'))
5813 non_fatal (_("%s: invalid reserve value for --stack"),
5814 optarg);
5815 else if (*end != '\0')
5817 pe_stack_commit = strtoul (end + 1, &end, 0);
5818 if (*end != '\0')
5819 non_fatal (_("%s: invalid commit value for --stack"),
5820 optarg);
5823 break;
5825 case OPTION_VERILOG_DATA_WIDTH:
5826 VerilogDataWidth = parse_vma (optarg, "--verilog-data-width");
5827 if (VerilogDataWidth < 1)
5828 fatal (_("verilog data width must be at least 1 byte"));
5829 break;
5831 case 0:
5832 /* We've been given a long option. */
5833 break;
5835 case 'H':
5836 case 'h':
5837 copy_usage (stdout, 0);
5839 default:
5840 copy_usage (stderr, 1);
5844 if (use_globalize && use_keep_global)
5845 fatal(_("--globalize-symbol(s) is incompatible with -G/--keep-global-symbol(s)"));
5847 if (formats_info)
5849 display_info ();
5850 return 0;
5853 if (show_version)
5854 print_version ("objcopy");
5856 if (interleave && copy_byte == -1)
5857 fatal (_("interleave start byte must be set with --byte"));
5859 if (copy_byte >= interleave)
5860 fatal (_("byte number must be less than interleave"));
5862 if (copy_width > interleave - copy_byte)
5863 fatal (_("interleave width must be less than or equal to interleave - byte`"));
5865 if (optind == argc || optind + 2 < argc)
5866 copy_usage (stderr, 1);
5868 input_filename = argv[optind];
5869 if (optind + 1 < argc)
5870 output_filename = argv[optind + 1];
5872 default_deterministic ();
5874 /* Default is to strip no symbols. */
5875 if (strip_symbols == STRIP_UNDEF && discard_locals == LOCALS_UNDEF)
5876 strip_symbols = STRIP_NONE;
5878 if (output_target == NULL)
5879 output_target = input_target;
5881 /* Convert input EFI target to PEI target. */
5882 if (input_target != NULL
5883 && startswith (input_target, "efi-"))
5885 if (convert_efi_target (&input_target) < 0)
5886 fatal (_("unknown input EFI target: %s"), input_target);
5889 /* Convert output EFI target to PEI target. */
5890 if (output_target != NULL
5891 && startswith (output_target, "efi-"))
5893 int subsys = convert_efi_target (&output_target);
5895 if (subsys < 0)
5896 fatal (_("unknown output EFI target: %s"), output_target);
5897 if (pe_subsystem == -1)
5898 pe_subsystem = subsys;
5899 if (pe_file_alignment == (bfd_vma) -1)
5900 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
5901 if (pe_section_alignment == (bfd_vma) -1)
5902 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
5905 /* If there is no destination file, or the source and destination files
5906 are the same, then create a temp and copy the result into the input. */
5907 copyfd = -1;
5908 if (output_filename == NULL
5909 || filename_cmp (input_filename, output_filename) == 0)
5911 tmpname = make_tempname (input_filename, &tmpfd);
5912 if (tmpfd >= 0)
5913 copyfd = dup (tmpfd);
5915 else
5916 tmpname = output_filename;
5918 if (tmpname == NULL)
5920 fatal (_("warning: could not create temporary file whilst copying '%s', (error: %s)"),
5921 input_filename, strerror (errno));
5924 copy_file (input_filename, tmpname, tmpfd, &statbuf, input_target,
5925 output_target, input_arch);
5926 if (status == 0)
5928 const char *oname = output_filename ? output_filename : input_filename;
5929 status = smart_rename (tmpname, oname, copyfd,
5930 &statbuf, preserve_dates) != 0;
5932 else
5934 if (copyfd >= 0)
5935 close (copyfd);
5936 unlink_if_ordinary (tmpname);
5939 if (tmpname != output_filename)
5940 free (tmpname);
5942 if (change_warn)
5944 struct section_list *p;
5946 for (p = change_sections; p != NULL; p = p->next)
5948 if (! p->used)
5950 if (p->context & (SECTION_CONTEXT_SET_VMA | SECTION_CONTEXT_ALTER_VMA))
5951 /* xgettext:c-format */
5952 non_fatal (_("%s %s%c0x%" PRIx64 " never used"),
5953 "--change-section-vma",
5954 p->pattern,
5955 p->context & SECTION_CONTEXT_SET_VMA ? '=' : '+',
5956 (uint64_t) p->vma_val);
5958 if (p->context & (SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_ALTER_LMA))
5959 /* xgettext:c-format */
5960 non_fatal (_("%s %s%c0x%" PRIx64 " never used"),
5961 "--change-section-lma",
5962 p->pattern,
5963 p->context & SECTION_CONTEXT_SET_LMA ? '=' : '+',
5964 (uint64_t) p->lma_val);
5969 free (strip_specific_buffer);
5970 free (strip_unneeded_buffer);
5971 free (keep_specific_buffer);
5972 free (localize_specific_buffer);
5973 free (globalize_specific_buffer);
5974 free (keepglobal_specific_buffer);
5975 free (weaken_specific_buffer);
5977 return 0;
5981 main (int argc, char *argv[])
5983 #ifdef HAVE_LC_MESSAGES
5984 setlocale (LC_MESSAGES, "");
5985 #endif
5986 setlocale (LC_CTYPE, "");
5987 bindtextdomain (PACKAGE, LOCALEDIR);
5988 textdomain (PACKAGE);
5990 program_name = argv[0];
5991 xmalloc_set_program_name (program_name);
5993 START_PROGRESS (program_name, 0);
5995 expandargv (&argc, &argv);
5997 strip_symbols = STRIP_UNDEF;
5998 discard_locals = LOCALS_UNDEF;
6000 if (bfd_init () != BFD_INIT_MAGIC)
6001 fatal (_("fatal error: libbfd ABI mismatch"));
6002 set_default_bfd_target ();
6004 if (is_strip < 0)
6006 int i = strlen (program_name);
6007 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
6008 /* Drop the .exe suffix, if any. */
6009 if (i > 4 && FILENAME_CMP (program_name + i - 4, ".exe") == 0)
6011 i -= 4;
6012 program_name[i] = '\0';
6014 #endif
6015 is_strip = (i >= 5 && FILENAME_CMP (program_name + i - 5, "strip") == 0);
6018 create_symbol_htabs ();
6020 if (argv != NULL)
6021 bfd_set_error_program_name (argv[0]);
6023 if (is_strip)
6024 strip_main (argc, argv);
6025 else
6026 copy_main (argc, argv);
6028 END_PROGRESS (program_name);
6030 return status;