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