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