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