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