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