Merge branch 'vendor/NVI2'
[dragonfly.git] / contrib / binutils-2.25 / 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 static bfd_boolean
1145 is_nondebug_keep_contents_section (bfd *ibfd, asection *isection)
1146 {
1147   /* Always keep ELF note sections.  */
1148   if (ibfd->xvec->flavour == bfd_target_elf_flavour)
1149     return (elf_section_type (isection) == SHT_NOTE);
1150
1151   /* Always keep the .buildid section for PE/COFF.
1152
1153      Strictly, this should be written "always keep the section storing the debug
1154      directory", but that may be the .text section for objects produced by some
1155      tools, which it is not sensible to keep.  */
1156   if (ibfd->xvec->flavour == bfd_target_coff_flavour)
1157     return (strcmp (bfd_get_section_name (ibfd, isection), ".buildid") == 0);
1158
1159   return FALSE;
1160 }
1161
1162 /* Return true if SYM is a hidden symbol.  */
1163
1164 static bfd_boolean
1165 is_hidden_symbol (asymbol *sym)
1166 {
1167   elf_symbol_type *elf_sym;
1168
1169   elf_sym = elf_symbol_from (sym->the_bfd, sym);
1170   if (elf_sym != NULL)
1171     switch (ELF_ST_VISIBILITY (elf_sym->internal_elf_sym.st_other))
1172       {
1173       case STV_HIDDEN:
1174       case STV_INTERNAL:
1175         return TRUE;
1176       }
1177   return FALSE;
1178 }
1179
1180 /* Choose which symbol entries to copy; put the result in OSYMS.
1181    We don't copy in place, because that confuses the relocs.
1182    Return the number of symbols to print.  */
1183
1184 static unsigned int
1185 filter_symbols (bfd *abfd, bfd *obfd, asymbol **osyms,
1186                 asymbol **isyms, long symcount)
1187 {
1188   asymbol **from = isyms, **to = osyms;
1189   long src_count = 0, dst_count = 0;
1190   int relocatable = (abfd->flags & (EXEC_P | DYNAMIC)) == 0;
1191
1192   for (; src_count < symcount; src_count++)
1193     {
1194       asymbol *sym = from[src_count];
1195       flagword flags = sym->flags;
1196       char *name = (char *) bfd_asymbol_name (sym);
1197       bfd_boolean keep;
1198       bfd_boolean used_in_reloc = FALSE;
1199       bfd_boolean undefined;
1200       bfd_boolean rem_leading_char;
1201       bfd_boolean add_leading_char;
1202
1203       undefined = bfd_is_und_section (bfd_get_section (sym));
1204
1205       if (redefine_sym_list)
1206         {
1207           char *old_name, *new_name;
1208
1209           old_name = (char *) bfd_asymbol_name (sym);
1210           new_name = (char *) lookup_sym_redefinition (old_name);
1211           bfd_asymbol_name (sym) = new_name;
1212           name = new_name;
1213         }
1214
1215       /* Check if we will remove the current leading character.  */
1216       rem_leading_char =
1217         (name[0] == bfd_get_symbol_leading_char (abfd))
1218         && (change_leading_char
1219             || (remove_leading_char
1220                 && ((flags & (BSF_GLOBAL | BSF_WEAK)) != 0
1221                     || undefined
1222                     || bfd_is_com_section (bfd_get_section (sym)))));
1223
1224       /* Check if we will add a new leading character.  */
1225       add_leading_char =
1226         change_leading_char
1227         && (bfd_get_symbol_leading_char (obfd) != '\0')
1228         && (bfd_get_symbol_leading_char (abfd) == '\0'
1229             || (name[0] == bfd_get_symbol_leading_char (abfd)));
1230
1231       /* Short circuit for change_leading_char if we can do it in-place.  */
1232       if (rem_leading_char && add_leading_char && !prefix_symbols_string)
1233         {
1234           name[0] = bfd_get_symbol_leading_char (obfd);
1235           bfd_asymbol_name (sym) = name;
1236           rem_leading_char = FALSE;
1237           add_leading_char = FALSE;
1238         }
1239
1240       /* Remove leading char.  */
1241       if (rem_leading_char)
1242         bfd_asymbol_name (sym) = ++name;
1243
1244       /* Add new leading char and/or prefix.  */
1245       if (add_leading_char || prefix_symbols_string)
1246         {
1247           char *n, *ptr;
1248
1249           ptr = n = (char *) xmalloc (1 + strlen (prefix_symbols_string)
1250                                       + strlen (name) + 1);
1251           if (add_leading_char)
1252             *ptr++ = bfd_get_symbol_leading_char (obfd);
1253
1254           if (prefix_symbols_string)
1255             {
1256               strcpy (ptr, prefix_symbols_string);
1257               ptr += strlen (prefix_symbols_string);
1258            }
1259
1260           strcpy (ptr, name);
1261           bfd_asymbol_name (sym) = n;
1262           name = n;
1263         }
1264
1265       if (strip_symbols == STRIP_ALL)
1266         keep = FALSE;
1267       else if ((flags & BSF_KEEP) != 0          /* Used in relocation.  */
1268                || ((flags & BSF_SECTION_SYM) != 0
1269                    && ((*bfd_get_section (sym)->symbol_ptr_ptr)->flags
1270                        & BSF_KEEP) != 0))
1271         {
1272           keep = TRUE;
1273           used_in_reloc = TRUE;
1274         }
1275       else if (relocatable                      /* Relocatable file.  */
1276                && ((flags & (BSF_GLOBAL | BSF_WEAK)) != 0
1277                    || bfd_is_com_section (bfd_get_section (sym))))
1278         keep = TRUE;
1279       else if (bfd_decode_symclass (sym) == 'I')
1280         /* Global symbols in $idata sections need to be retained
1281            even if relocatable is FALSE.  External users of the
1282            library containing the $idata section may reference these
1283            symbols.  */
1284         keep = TRUE;
1285       else if ((flags & BSF_GLOBAL) != 0        /* Global symbol.  */
1286                || (flags & BSF_WEAK) != 0
1287                || undefined
1288                || bfd_is_com_section (bfd_get_section (sym)))
1289         keep = strip_symbols != STRIP_UNNEEDED;
1290       else if ((flags & BSF_DEBUGGING) != 0)    /* Debugging symbol.  */
1291         keep = (strip_symbols != STRIP_DEBUG
1292                 && strip_symbols != STRIP_UNNEEDED
1293                 && ! convert_debugging);
1294       else if (bfd_coff_get_comdat_section (abfd, bfd_get_section (sym)))
1295         /* COMDAT sections store special information in local
1296            symbols, so we cannot risk stripping any of them.  */
1297         keep = TRUE;
1298       else                      /* Local symbol.  */
1299         keep = (strip_symbols != STRIP_UNNEEDED
1300                 && (discard_locals != LOCALS_ALL
1301                     && (discard_locals != LOCALS_START_L
1302                         || ! bfd_is_local_label (abfd, sym))));
1303
1304       if (keep && is_specified_symbol (name, strip_specific_htab))
1305         {
1306           /* There are multiple ways to set 'keep' above, but if it
1307              was the relocatable symbol case, then that's an error.  */
1308           if (used_in_reloc)
1309             {
1310               non_fatal (_("not stripping symbol `%s' because it is named in a relocation"), name);
1311               status = 1;
1312             }
1313           else
1314             keep = FALSE;
1315         }
1316
1317       if (keep
1318           && !(flags & BSF_KEEP)
1319           && is_specified_symbol (name, strip_unneeded_htab))
1320         keep = FALSE;
1321
1322       if (!keep
1323           && ((keep_file_symbols && (flags & BSF_FILE))
1324               || is_specified_symbol (name, keep_specific_htab)))
1325         keep = TRUE;
1326
1327       if (keep && is_strip_section (abfd, bfd_get_section (sym)))
1328         keep = FALSE;
1329
1330       if (keep)
1331         {
1332           if ((flags & BSF_GLOBAL) != 0
1333               && (weaken || is_specified_symbol (name, weaken_specific_htab)))
1334             {
1335               sym->flags &= ~ BSF_GLOBAL;
1336               sym->flags |= BSF_WEAK;
1337             }
1338
1339           if (!undefined
1340               && (flags & (BSF_GLOBAL | BSF_WEAK))
1341               && (is_specified_symbol (name, localize_specific_htab)
1342                   || (htab_elements (keepglobal_specific_htab) != 0
1343                       && ! is_specified_symbol (name, keepglobal_specific_htab))
1344                   || (localize_hidden && is_hidden_symbol (sym))))
1345             {
1346               sym->flags &= ~ (BSF_GLOBAL | BSF_WEAK);
1347               sym->flags |= BSF_LOCAL;
1348             }
1349
1350           if (!undefined
1351               && (flags & BSF_LOCAL)
1352               && is_specified_symbol (name, globalize_specific_htab))
1353             {
1354               sym->flags &= ~ BSF_LOCAL;
1355               sym->flags |= BSF_GLOBAL;
1356             }
1357
1358           to[dst_count++] = sym;
1359         }
1360     }
1361
1362   to[dst_count] = NULL;
1363
1364   return dst_count;
1365 }
1366
1367 /* Find the redefined name of symbol SOURCE.  */
1368
1369 static const char *
1370 lookup_sym_redefinition (const char *source)
1371 {
1372   struct redefine_node *list;
1373
1374   for (list = redefine_sym_list; list != NULL; list = list->next)
1375     if (strcmp (source, list->source) == 0)
1376       return list->target;
1377
1378   return source;
1379 }
1380
1381 /* Add a node to a symbol redefine list.  */
1382
1383 static void
1384 redefine_list_append (const char *cause, const char *source, const char *target)
1385 {
1386   struct redefine_node **p;
1387   struct redefine_node *list;
1388   struct redefine_node *new_node;
1389
1390   for (p = &redefine_sym_list; (list = *p) != NULL; p = &list->next)
1391     {
1392       if (strcmp (source, list->source) == 0)
1393         fatal (_("%s: Multiple redefinition of symbol \"%s\""),
1394                cause, source);
1395
1396       if (strcmp (target, list->target) == 0)
1397         fatal (_("%s: Symbol \"%s\" is target of more than one redefinition"),
1398                cause, target);
1399     }
1400
1401   new_node = (struct redefine_node *) xmalloc (sizeof (struct redefine_node));
1402
1403   new_node->source = strdup (source);
1404   new_node->target = strdup (target);
1405   new_node->next = NULL;
1406
1407   *p = new_node;
1408 }
1409
1410 /* Handle the --redefine-syms option.  Read lines containing "old new"
1411    from the file, and add them to the symbol redefine list.  */
1412
1413 static void
1414 add_redefine_syms_file (const char *filename)
1415 {
1416   FILE *file;
1417   char *buf;
1418   size_t bufsize;
1419   size_t len;
1420   size_t outsym_off;
1421   int c, lineno;
1422
1423   file = fopen (filename, "r");
1424   if (file == NULL)
1425     fatal (_("couldn't open symbol redefinition file %s (error: %s)"),
1426            filename, strerror (errno));
1427
1428   bufsize = 100;
1429   buf = (char *) xmalloc (bufsize + 1 /* For the terminating NUL.  */);
1430
1431   lineno = 1;
1432   c = getc (file);
1433   len = 0;
1434   outsym_off = 0;
1435   while (c != EOF)
1436     {
1437       /* Collect the input symbol name.  */
1438       while (! IS_WHITESPACE (c) && ! IS_LINE_TERMINATOR (c) && c != EOF)
1439         {
1440           if (c == '#')
1441             goto comment;
1442           buf[len++] = c;
1443           if (len >= bufsize)
1444             {
1445               bufsize *= 2;
1446               buf = (char *) xrealloc (buf, bufsize + 1);
1447             }
1448           c = getc (file);
1449         }
1450       buf[len++] = '\0';
1451       if (c == EOF)
1452         break;
1453
1454       /* Eat white space between the symbol names.  */
1455       while (IS_WHITESPACE (c))
1456         c = getc (file);
1457       if (c == '#' || IS_LINE_TERMINATOR (c))
1458         goto comment;
1459       if (c == EOF)
1460         break;
1461
1462       /* Collect the output symbol name.  */
1463       outsym_off = len;
1464       while (! IS_WHITESPACE (c) && ! IS_LINE_TERMINATOR (c) && c != EOF)
1465         {
1466           if (c == '#')
1467             goto comment;
1468           buf[len++] = c;
1469           if (len >= bufsize)
1470             {
1471               bufsize *= 2;
1472               buf = (char *) xrealloc (buf, bufsize + 1);
1473             }
1474           c = getc (file);
1475         }
1476       buf[len++] = '\0';
1477       if (c == EOF)
1478         break;
1479
1480       /* Eat white space at end of line.  */
1481       while (! IS_LINE_TERMINATOR(c) && c != EOF && IS_WHITESPACE (c))
1482         c = getc (file);
1483       if (c == '#')
1484         goto comment;
1485       /* Handle \r\n.  */
1486       if ((c == '\r' && (c = getc (file)) == '\n')
1487           || c == '\n' || c == EOF)
1488         {
1489  end_of_line:
1490           /* Append the redefinition to the list.  */
1491           if (buf[0] != '\0')
1492             redefine_list_append (filename, &buf[0], &buf[outsym_off]);
1493
1494           lineno++;
1495           len = 0;
1496           outsym_off = 0;
1497           if (c == EOF)
1498             break;
1499           c = getc (file);
1500           continue;
1501         }
1502       else
1503         fatal (_("%s:%d: garbage found at end of line"), filename, lineno);
1504  comment:
1505       if (len != 0 && (outsym_off == 0 || outsym_off == len))
1506         fatal (_("%s:%d: missing new symbol name"), filename, lineno);
1507       buf[len++] = '\0';
1508
1509       /* Eat the rest of the line and finish it.  */
1510       while (c != '\n' && c != EOF)
1511         c = getc (file);
1512       goto end_of_line;
1513     }
1514
1515   if (len != 0)
1516     fatal (_("%s:%d: premature end of file"), filename, lineno);
1517
1518   free (buf);
1519 }
1520
1521 /* Copy unkown object file IBFD onto OBFD.
1522    Returns TRUE upon success, FALSE otherwise.  */
1523
1524 static bfd_boolean
1525 copy_unknown_object (bfd *ibfd, bfd *obfd)
1526 {
1527   char *cbuf;
1528   int tocopy;
1529   long ncopied;
1530   long size;
1531   struct stat buf;
1532
1533   if (bfd_stat_arch_elt (ibfd, &buf) != 0)
1534     {
1535       bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
1536       return FALSE;
1537     }
1538
1539   size = buf.st_size;
1540   if (size < 0)
1541     {
1542       non_fatal (_("stat returns negative size for `%s'"),
1543                  bfd_get_archive_filename (ibfd));
1544       return FALSE;
1545     }
1546
1547   if (bfd_seek (ibfd, (file_ptr) 0, SEEK_SET) != 0)
1548     {
1549       bfd_nonfatal (bfd_get_archive_filename (ibfd));
1550       return FALSE;
1551     }
1552
1553   if (verbose)
1554     printf (_("copy from `%s' [unknown] to `%s' [unknown]\n"),
1555             bfd_get_archive_filename (ibfd), bfd_get_filename (obfd));
1556
1557   cbuf = (char *) xmalloc (BUFSIZE);
1558   ncopied = 0;
1559   while (ncopied < size)
1560     {
1561       tocopy = size - ncopied;
1562       if (tocopy > BUFSIZE)
1563         tocopy = BUFSIZE;
1564
1565       if (bfd_bread (cbuf, (bfd_size_type) tocopy, ibfd)
1566           != (bfd_size_type) tocopy)
1567         {
1568           bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
1569           free (cbuf);
1570           return FALSE;
1571         }
1572
1573       if (bfd_bwrite (cbuf, (bfd_size_type) tocopy, obfd)
1574           != (bfd_size_type) tocopy)
1575         {
1576           bfd_nonfatal_message (NULL, obfd, NULL, NULL);
1577           free (cbuf);
1578           return FALSE;
1579         }
1580
1581       ncopied += tocopy;
1582     }
1583
1584   /* We should at least to be able to read it back when copying an
1585      unknown object in an archive.  */
1586   chmod (bfd_get_filename (obfd), buf.st_mode | S_IRUSR);
1587   free (cbuf);
1588   return TRUE;
1589 }
1590
1591 /* Copy object file IBFD onto OBFD.
1592    Returns TRUE upon success, FALSE otherwise.  */
1593
1594 static bfd_boolean
1595 copy_object (bfd *ibfd, bfd *obfd, const bfd_arch_info_type *input_arch)
1596 {
1597   bfd_vma start;
1598   long symcount;
1599   asection **osections = NULL;
1600   asection *gnu_debuglink_section = NULL;
1601   bfd_size_type *gaps = NULL;
1602   bfd_size_type max_gap = 0;
1603   long symsize;
1604   void *dhandle;
1605   enum bfd_architecture iarch;
1606   unsigned int imach;
1607
1608   if (ibfd->xvec->byteorder != obfd->xvec->byteorder
1609       && ibfd->xvec->byteorder != BFD_ENDIAN_UNKNOWN
1610       && obfd->xvec->byteorder != BFD_ENDIAN_UNKNOWN)
1611     fatal (_("Unable to change endianness of input file(s)"));
1612
1613   if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
1614     {
1615       bfd_nonfatal_message (NULL, obfd, NULL, NULL);
1616       return FALSE;
1617     }
1618
1619   if (ibfd->sections == NULL)
1620     {
1621       non_fatal (_("error: the input file '%s' has no sections"),
1622                  bfd_get_archive_filename (ibfd));
1623       return FALSE;
1624     }
1625
1626   if (verbose)
1627     printf (_("copy from `%s' [%s] to `%s' [%s]\n"),
1628             bfd_get_archive_filename (ibfd), bfd_get_target (ibfd),
1629             bfd_get_filename (obfd), bfd_get_target (obfd));
1630
1631   if (extract_symbol)
1632     start = 0;
1633   else
1634     {
1635       if (set_start_set)
1636         start = set_start;
1637       else
1638         start = bfd_get_start_address (ibfd);
1639       start += change_start;
1640     }
1641
1642   /* Neither the start address nor the flags
1643      need to be set for a core file.  */
1644   if (bfd_get_format (obfd) != bfd_core)
1645     {
1646       flagword flags;
1647
1648       flags = bfd_get_file_flags (ibfd);
1649       flags |= bfd_flags_to_set;
1650       flags &= ~bfd_flags_to_clear;
1651       flags &= bfd_applicable_file_flags (obfd);
1652
1653       if (strip_symbols == STRIP_ALL)
1654         flags &= ~HAS_RELOC;
1655
1656       if (!bfd_set_start_address (obfd, start)
1657           || !bfd_set_file_flags (obfd, flags))
1658         {
1659           bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
1660           return FALSE;
1661         }
1662     }
1663
1664   /* Copy architecture of input file to output file.  */
1665   iarch = bfd_get_arch (ibfd);
1666   imach = bfd_get_mach (ibfd);
1667   if (input_arch)
1668     {
1669       if (bfd_get_arch_info (ibfd) == NULL
1670           || bfd_get_arch_info (ibfd)->arch == bfd_arch_unknown)
1671         {
1672           iarch = input_arch->arch;
1673           imach = input_arch->mach;
1674         }
1675       else
1676         non_fatal (_("Input file `%s' ignores binary architecture parameter."),
1677                    bfd_get_archive_filename (ibfd));
1678     }
1679   if (!bfd_set_arch_mach (obfd, iarch, imach)
1680       && (ibfd->target_defaulted
1681           || bfd_get_arch (ibfd) != bfd_get_arch (obfd)))
1682     {
1683       if (bfd_get_arch (ibfd) == bfd_arch_unknown)
1684         non_fatal (_("Unable to recognise the format of the input file `%s'"),
1685                    bfd_get_archive_filename (ibfd));
1686       else
1687         non_fatal (_("Output file cannot represent architecture `%s'"),
1688                    bfd_printable_arch_mach (bfd_get_arch (ibfd),
1689                                             bfd_get_mach (ibfd)));
1690       return FALSE;
1691     }
1692
1693   if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
1694     {
1695       bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
1696       return FALSE;
1697     }
1698
1699   if (bfd_get_flavour (obfd) == bfd_target_coff_flavour
1700       && bfd_pei_p (obfd))
1701     {
1702       /* Set up PE parameters.  */
1703       pe_data_type *pe = pe_data (obfd);
1704
1705       /* Copy PE parameters before changing them.  */
1706       if (ibfd->xvec->flavour == bfd_target_coff_flavour
1707           && bfd_pei_p (ibfd))
1708         pe->pe_opthdr = pe_data (ibfd)->pe_opthdr;
1709
1710       if (pe_file_alignment != (bfd_vma) -1)
1711         pe->pe_opthdr.FileAlignment = pe_file_alignment;
1712       else
1713         pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
1714
1715       if (pe_heap_commit != (bfd_vma) -1)
1716         pe->pe_opthdr.SizeOfHeapCommit = pe_heap_commit;
1717
1718       if (pe_heap_reserve != (bfd_vma) -1)
1719         pe->pe_opthdr.SizeOfHeapCommit = pe_heap_reserve;
1720
1721       if (pe_image_base != (bfd_vma) -1)
1722         pe->pe_opthdr.ImageBase = pe_image_base;
1723
1724       if (pe_section_alignment != (bfd_vma) -1)
1725         pe->pe_opthdr.SectionAlignment = pe_section_alignment;
1726       else
1727         pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
1728
1729       if (pe_stack_commit != (bfd_vma) -1)
1730         pe->pe_opthdr.SizeOfStackCommit = pe_stack_commit;
1731
1732       if (pe_stack_reserve != (bfd_vma) -1)
1733         pe->pe_opthdr.SizeOfStackCommit = pe_stack_reserve;
1734
1735       if (pe_subsystem != -1)
1736         pe->pe_opthdr.Subsystem = pe_subsystem;
1737
1738       if (pe_major_subsystem_version != -1)
1739         pe->pe_opthdr.MajorSubsystemVersion = pe_major_subsystem_version;
1740
1741       if (pe_minor_subsystem_version != -1)
1742         pe->pe_opthdr.MinorSubsystemVersion = pe_minor_subsystem_version;
1743
1744       if (pe_file_alignment > pe_section_alignment)
1745         {
1746           char file_alignment[20], section_alignment[20];
1747
1748           sprintf_vma (file_alignment, pe_file_alignment);
1749           sprintf_vma (section_alignment, pe_section_alignment);
1750           non_fatal (_("warning: file alignment (0x%s) > section alignment (0x%s)"),
1751
1752                      file_alignment, section_alignment);
1753         }
1754     }
1755
1756   if (isympp)
1757     free (isympp);
1758
1759   if (osympp != isympp)
1760     free (osympp);
1761
1762   isympp = NULL;
1763   osympp = NULL;
1764
1765   symsize = bfd_get_symtab_upper_bound (ibfd);
1766   if (symsize < 0)
1767     {
1768       bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
1769       return FALSE;
1770     }
1771
1772   osympp = isympp = (asymbol **) xmalloc (symsize);
1773   symcount = bfd_canonicalize_symtab (ibfd, isympp);
1774   if (symcount < 0)
1775     {
1776       bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
1777       return FALSE;
1778     }
1779
1780   /* BFD mandates that all output sections be created and sizes set before
1781      any output is done.  Thus, we traverse all sections multiple times.  */
1782   bfd_map_over_sections (ibfd, setup_section, obfd);
1783
1784   if (!extract_symbol)
1785     setup_bfd_headers (ibfd, obfd);
1786
1787   if (add_sections != NULL)
1788     {
1789       struct section_add *padd;
1790       struct section_list *pset;
1791
1792       for (padd = add_sections; padd != NULL; padd = padd->next)
1793         {
1794           flagword flags;
1795
1796           pset = find_section_list (padd->name, FALSE,
1797                                     SECTION_CONTEXT_SET_FLAGS);
1798           if (pset != NULL)
1799             flags = pset->flags | SEC_HAS_CONTENTS;
1800           else
1801             flags = SEC_HAS_CONTENTS | SEC_READONLY | SEC_DATA;
1802
1803           /* bfd_make_section_with_flags() does not return very helpful
1804              error codes, so check for the most likely user error first.  */
1805           if (bfd_get_section_by_name (obfd, padd->name))
1806             {
1807               bfd_nonfatal_message (NULL, obfd, NULL,
1808                                  _("can't add section '%s'"), padd->name);
1809               return FALSE;
1810             }
1811           else
1812             {
1813               /* We use LINKER_CREATED here so that the backend hooks
1814                  will create any special section type information,
1815                  instead of presuming we know what we're doing merely
1816                  because we set the flags.  */
1817               padd->section = bfd_make_section_with_flags
1818                 (obfd, padd->name, flags | SEC_LINKER_CREATED);
1819               if (padd->section == NULL)
1820                 {
1821                   bfd_nonfatal_message (NULL, obfd, NULL,
1822                                         _("can't create section `%s'"),
1823                                         padd->name);
1824                   return FALSE;
1825                 }
1826             }
1827
1828           if (! bfd_set_section_size (obfd, padd->section, padd->size))
1829             {
1830               bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
1831               return FALSE;
1832             }
1833
1834           pset = find_section_list (padd->name, FALSE,
1835                                     SECTION_CONTEXT_SET_VMA | SECTION_CONTEXT_ALTER_VMA);
1836           if (pset != NULL
1837               && ! bfd_set_section_vma (obfd, padd->section, pset->vma_val))
1838             {
1839               bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
1840               return FALSE;
1841             }
1842
1843           pset = find_section_list (padd->name, FALSE,
1844                                     SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_ALTER_LMA);
1845           if (pset != NULL)
1846             {
1847               padd->section->lma = pset->lma_val;
1848
1849               if (! bfd_set_section_alignment
1850                   (obfd, padd->section,
1851                    bfd_section_alignment (obfd, padd->section)))
1852                 {
1853                   bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
1854                   return FALSE;
1855                 }
1856             }
1857         }
1858     }
1859
1860   if (dump_sections != NULL)
1861     {
1862       struct section_add * pdump;
1863
1864       for (pdump = dump_sections; pdump != NULL; pdump = pdump->next)
1865         {
1866           asection * sec;
1867
1868           sec = bfd_get_section_by_name (ibfd, pdump->name);
1869           if (sec == NULL)
1870             {
1871               bfd_nonfatal_message (NULL, ibfd, NULL,
1872                                     _("can't dump section '%s' - it does not exist"),
1873                                     pdump->name);
1874               continue;
1875             }
1876
1877           if ((bfd_get_section_flags (ibfd, sec) & SEC_HAS_CONTENTS) == 0)
1878             {
1879               bfd_nonfatal_message (NULL, ibfd, sec,
1880                                     _("can't dump section - it has no contents"));
1881               continue;
1882             }
1883           
1884           bfd_size_type size = bfd_get_section_size (sec);
1885           if (size == 0)
1886             {
1887               bfd_nonfatal_message (NULL, ibfd, sec,
1888                                     _("can't dump section - it is empty"));
1889               continue;
1890             }
1891
1892           FILE * f;
1893           f = fopen (pdump->filename, FOPEN_WB);
1894           if (f == NULL)
1895             {
1896               bfd_nonfatal_message (pdump->filename, NULL, NULL,
1897                                     _("could not open section dump file"));
1898               continue;
1899             }
1900
1901           bfd_byte * contents = xmalloc (size);
1902           if (bfd_get_section_contents (ibfd, sec, contents, 0, size))
1903             {
1904               if (fwrite (contents, 1, size, f) != size)
1905                 fatal (_("error writing section contents to %s (error: %s)"),
1906                        pdump->filename,
1907                        strerror (errno));
1908             }
1909           else
1910             bfd_nonfatal_message (NULL, ibfd, sec,
1911                                   _("could not retrieve section contents"));
1912
1913           fclose (f);
1914           free (contents);
1915         }
1916     }
1917   
1918   if (gnu_debuglink_filename != NULL)
1919     {
1920       /* PR 15125: Give a helpful warning message if
1921          the debuglink section already exists, and
1922          allow the rest of the copy to complete.  */
1923       if (bfd_get_section_by_name (obfd, ".gnu_debuglink"))
1924         {
1925           non_fatal (_("%s: debuglink section already exists"),
1926                      bfd_get_filename (obfd));
1927           gnu_debuglink_filename = NULL;
1928         }
1929       else
1930         {
1931           gnu_debuglink_section = bfd_create_gnu_debuglink_section
1932             (obfd, gnu_debuglink_filename);
1933
1934           if (gnu_debuglink_section == NULL)
1935             {
1936               bfd_nonfatal_message (NULL, obfd, NULL,
1937                                     _("cannot create debug link section `%s'"),
1938                                     gnu_debuglink_filename);
1939               return FALSE;
1940             }
1941
1942           /* Special processing for PE format files.  We
1943              have no way to distinguish PE from COFF here.  */
1944           if (bfd_get_flavour (obfd) == bfd_target_coff_flavour)
1945             {
1946               bfd_vma debuglink_vma;
1947               asection * highest_section;
1948               asection * sec;
1949
1950               /* The PE spec requires that all sections be adjacent and sorted
1951                  in ascending order of VMA.  It also specifies that debug
1952                  sections should be last.  This is despite the fact that debug
1953                  sections are not loaded into memory and so in theory have no
1954                  use for a VMA.
1955
1956                  This means that the debuglink section must be given a non-zero
1957                  VMA which makes it contiguous with other debug sections.  So
1958                  walk the current section list, find the section with the
1959                  highest VMA and start the debuglink section after that one.  */
1960               for (sec = obfd->sections, highest_section = NULL;
1961                    sec != NULL;
1962                    sec = sec->next)
1963                 if (sec->vma > 0
1964                     && (highest_section == NULL
1965                         || sec->vma > highest_section->vma))
1966                   highest_section = sec;
1967
1968               if (highest_section)
1969                 debuglink_vma = BFD_ALIGN (highest_section->vma
1970                                            + highest_section->size,
1971                                            /* FIXME: We ought to be using
1972                                               COFF_PAGE_SIZE here or maybe
1973                                               bfd_get_section_alignment() (if it
1974                                               was set) but since this is for PE
1975                                               and we know the required alignment
1976                                               it is easier just to hard code it.  */
1977                                            0x1000);
1978               else
1979                 /* Umm, not sure what to do in this case.  */
1980                 debuglink_vma = 0x1000;
1981
1982               bfd_set_section_vma (obfd, gnu_debuglink_section, debuglink_vma);
1983             }
1984         }
1985     }
1986
1987   if (bfd_count_sections (obfd) != 0
1988       && (gap_fill_set || pad_to_set))
1989     {
1990       asection **set;
1991       unsigned int c, i;
1992
1993       /* We must fill in gaps between the sections and/or we must pad
1994          the last section to a specified address.  We do this by
1995          grabbing a list of the sections, sorting them by VMA, and
1996          increasing the section sizes as required to fill the gaps.
1997          We write out the gap contents below.  */
1998
1999       c = bfd_count_sections (obfd);
2000       osections = (asection **) xmalloc (c * sizeof (asection *));
2001       set = osections;
2002       bfd_map_over_sections (obfd, get_sections, &set);
2003
2004       qsort (osections, c, sizeof (asection *), compare_section_lma);
2005
2006       gaps = (bfd_size_type *) xmalloc (c * sizeof (bfd_size_type));
2007       memset (gaps, 0, c * sizeof (bfd_size_type));
2008
2009       if (gap_fill_set)
2010         {
2011           for (i = 0; i < c - 1; i++)
2012             {
2013               flagword flags;
2014               bfd_size_type size;
2015               bfd_vma gap_start, gap_stop;
2016
2017               flags = bfd_get_section_flags (obfd, osections[i]);
2018               if ((flags & SEC_HAS_CONTENTS) == 0
2019                   || (flags & SEC_LOAD) == 0)
2020                 continue;
2021
2022               size = bfd_section_size (obfd, osections[i]);
2023               gap_start = bfd_section_lma (obfd, osections[i]) + size;
2024               gap_stop = bfd_section_lma (obfd, osections[i + 1]);
2025               if (gap_start < gap_stop)
2026                 {
2027                   if (! bfd_set_section_size (obfd, osections[i],
2028                                               size + (gap_stop - gap_start)))
2029                     {
2030                       bfd_nonfatal_message (NULL, obfd, osections[i],
2031                                             _("Can't fill gap after section"));
2032                       status = 1;
2033                       break;
2034                     }
2035                   gaps[i] = gap_stop - gap_start;
2036                   if (max_gap < gap_stop - gap_start)
2037                     max_gap = gap_stop - gap_start;
2038                 }
2039             }
2040         }
2041
2042       if (pad_to_set)
2043         {
2044           bfd_vma lma;
2045           bfd_size_type size;
2046
2047           lma = bfd_section_lma (obfd, osections[c - 1]);
2048           size = bfd_section_size (obfd, osections[c - 1]);
2049           if (lma + size < pad_to)
2050             {
2051               if (! bfd_set_section_size (obfd, osections[c - 1],
2052                                           pad_to - lma))
2053                 {
2054                   bfd_nonfatal_message (NULL, obfd, osections[c - 1],
2055                                         _("can't add padding"));
2056                   status = 1;
2057                 }
2058               else
2059                 {
2060                   gaps[c - 1] = pad_to - (lma + size);
2061                   if (max_gap < pad_to - (lma + size))
2062                     max_gap = pad_to - (lma + size);
2063                 }
2064             }
2065         }
2066     }
2067
2068   /* Symbol filtering must happen after the output sections
2069      have been created, but before their contents are set.  */
2070   dhandle = NULL;
2071   if (convert_debugging)
2072     dhandle = read_debugging_info (ibfd, isympp, symcount, FALSE);
2073
2074   if (strip_symbols == STRIP_DEBUG
2075       || strip_symbols == STRIP_ALL
2076       || strip_symbols == STRIP_UNNEEDED
2077       || strip_symbols == STRIP_NONDEBUG
2078       || strip_symbols == STRIP_DWO
2079       || strip_symbols == STRIP_NONDWO
2080       || discard_locals != LOCALS_UNDEF
2081       || localize_hidden
2082       || htab_elements (strip_specific_htab) != 0
2083       || htab_elements (keep_specific_htab) != 0
2084       || htab_elements (localize_specific_htab) != 0
2085       || htab_elements (globalize_specific_htab) != 0
2086       || htab_elements (keepglobal_specific_htab) != 0
2087       || htab_elements (weaken_specific_htab) != 0
2088       || prefix_symbols_string
2089       || sections_removed
2090       || sections_copied
2091       || convert_debugging
2092       || change_leading_char
2093       || remove_leading_char
2094       || redefine_sym_list
2095       || weaken)
2096     {
2097       /* Mark symbols used in output relocations so that they
2098          are kept, even if they are local labels or static symbols.
2099
2100          Note we iterate over the input sections examining their
2101          relocations since the relocations for the output sections
2102          haven't been set yet.  mark_symbols_used_in_relocations will
2103          ignore input sections which have no corresponding output
2104          section.  */
2105       if (strip_symbols != STRIP_ALL)
2106         bfd_map_over_sections (ibfd,
2107                                mark_symbols_used_in_relocations,
2108                                isympp);
2109       osympp = (asymbol **) xmalloc ((symcount + 1) * sizeof (asymbol *));
2110       symcount = filter_symbols (ibfd, obfd, osympp, isympp, symcount);
2111     }
2112
2113   if (convert_debugging && dhandle != NULL)
2114     {
2115       if (! write_debugging_info (obfd, dhandle, &symcount, &osympp))
2116         {
2117           status = 1;
2118           return FALSE;
2119         }
2120     }
2121
2122   bfd_set_symtab (obfd, osympp, symcount);
2123
2124   /* This has to happen before section positions are set.  */
2125   bfd_map_over_sections (ibfd, copy_relocations_in_section, obfd);
2126
2127   /* This has to happen after the symbol table has been set.  */
2128   bfd_map_over_sections (ibfd, copy_section, obfd);
2129
2130   if (add_sections != NULL)
2131     {
2132       struct section_add *padd;
2133
2134       for (padd = add_sections; padd != NULL; padd = padd->next)
2135         {
2136           if (! bfd_set_section_contents (obfd, padd->section, padd->contents,
2137                                           0, padd->size))
2138             {
2139               bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
2140               return FALSE;
2141             }
2142         }
2143     }
2144
2145   if (gnu_debuglink_filename != NULL)
2146     {
2147       if (! bfd_fill_in_gnu_debuglink_section
2148           (obfd, gnu_debuglink_section, gnu_debuglink_filename))
2149         {
2150           bfd_nonfatal_message (NULL, obfd, NULL,
2151                                 _("cannot fill debug link section `%s'"),
2152                                 gnu_debuglink_filename);
2153           return FALSE;
2154         }
2155     }
2156
2157   if (gap_fill_set || pad_to_set)
2158     {
2159       bfd_byte *buf;
2160       int c, i;
2161
2162       /* Fill in the gaps.  */
2163       if (max_gap > 8192)
2164         max_gap = 8192;
2165       buf = (bfd_byte *) xmalloc (max_gap);
2166       memset (buf, gap_fill, max_gap);
2167
2168       c = bfd_count_sections (obfd);
2169       for (i = 0; i < c; i++)
2170         {
2171           if (gaps[i] != 0)
2172             {
2173               bfd_size_type left;
2174               file_ptr off;
2175
2176               left = gaps[i];
2177               off = bfd_section_size (obfd, osections[i]) - left;
2178
2179               while (left > 0)
2180                 {
2181                   bfd_size_type now;
2182
2183                   if (left > 8192)
2184                     now = 8192;
2185                   else
2186                     now = left;
2187
2188                   if (! bfd_set_section_contents (obfd, osections[i], buf,
2189                                                   off, now))
2190                     {
2191                       bfd_nonfatal_message (NULL, obfd, osections[i], NULL);
2192                       return FALSE;
2193                     }
2194
2195                   left -= now;
2196                   off += now;
2197                 }
2198             }
2199         }
2200     }
2201
2202   /* Do not copy backend data if --extract-symbol is passed; anything
2203      that needs to look at the section contents will fail.  */
2204   if (extract_symbol)
2205     return TRUE;
2206
2207   /* Allow the BFD backend to copy any private data it understands
2208      from the input BFD to the output BFD.  This is done last to
2209      permit the routine to look at the filtered symbol table, which is
2210      important for the ECOFF code at least.  */
2211   if (! bfd_copy_private_bfd_data (ibfd, obfd))
2212     {
2213       bfd_nonfatal_message (NULL, obfd, NULL,
2214                             _("error copying private BFD data"));
2215       return FALSE;
2216     }
2217
2218   /* Switch to the alternate machine code.  We have to do this at the
2219      very end, because we only initialize the header when we create
2220      the first section.  */
2221   if (use_alt_mach_code != 0)
2222     {
2223       if (! bfd_alt_mach_code (obfd, use_alt_mach_code))
2224         {
2225           non_fatal (_("this target does not support %lu alternative machine codes"),
2226                      use_alt_mach_code);
2227           if (bfd_get_flavour (obfd) == bfd_target_elf_flavour)
2228             {
2229               non_fatal (_("treating that number as an absolute e_machine value instead"));
2230               elf_elfheader (obfd)->e_machine = use_alt_mach_code;
2231             }
2232           else
2233             non_fatal (_("ignoring the alternative value"));
2234         }
2235     }
2236
2237   return TRUE;
2238 }
2239
2240 /* Read each archive element in turn from IBFD, copy the
2241    contents to temp file, and keep the temp file handle.
2242    If 'force_output_target' is TRUE then make sure that
2243    all elements in the new archive are of the type
2244    'output_target'.  */
2245
2246 static void
2247 copy_archive (bfd *ibfd, bfd *obfd, const char *output_target,
2248               bfd_boolean force_output_target,
2249               const bfd_arch_info_type *input_arch)
2250 {
2251   struct name_list
2252     {
2253       struct name_list *next;
2254       const char *name;
2255       bfd *obfd;
2256     } *list, *l;
2257   bfd **ptr = &obfd->archive_head;
2258   bfd *this_element;
2259   char *dir;
2260   const char *filename;
2261
2262   /* Make a temp directory to hold the contents.  */
2263   dir = make_tempdir (bfd_get_filename (obfd));
2264   if (dir == NULL)
2265       fatal (_("cannot create tempdir for archive copying (error: %s)"),
2266            strerror (errno));
2267
2268   if (strip_symbols == STRIP_ALL)
2269     obfd->has_armap = FALSE;
2270   else
2271     obfd->has_armap = ibfd->has_armap;
2272   obfd->is_thin_archive = ibfd->is_thin_archive;
2273
2274   if (deterministic)
2275     obfd->flags |= BFD_DETERMINISTIC_OUTPUT;
2276
2277   list = NULL;
2278
2279   this_element = bfd_openr_next_archived_file (ibfd, NULL);
2280
2281   if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
2282     {
2283       status = 1;
2284       bfd_nonfatal_message (NULL, obfd, NULL, NULL);
2285       return;
2286     }
2287
2288   while (!status && this_element != NULL)
2289     {
2290       char *output_name;
2291       bfd *output_bfd;
2292       bfd *last_element;
2293       struct stat buf;
2294       int stat_status = 0;
2295       bfd_boolean del = TRUE;
2296       bfd_boolean ok_object;
2297
2298       /* PR binutils/17533: Do not allow directory traversal
2299          outside of the current directory tree by archive members.  */
2300       if (! is_valid_archive_path (bfd_get_filename (this_element)))
2301         {
2302           non_fatal (_("illegal pathname found in archive member: %s"),
2303                      bfd_get_filename (this_element));
2304           status = 1;
2305           goto cleanup_and_exit;
2306         }
2307
2308       /* Create an output file for this member.  */
2309       output_name = concat (dir, "/",
2310                             bfd_get_filename (this_element), (char *) 0);
2311
2312       /* If the file already exists, make another temp dir.  */
2313       if (stat (output_name, &buf) >= 0)
2314         {
2315           output_name = make_tempdir (output_name);
2316           if (output_name == NULL)
2317             {
2318               non_fatal (_("cannot create tempdir for archive copying (error: %s)"),
2319                          strerror (errno));
2320               status = 1;
2321               goto cleanup_and_exit;
2322             }
2323
2324           l = (struct name_list *) xmalloc (sizeof (struct name_list));
2325           l->name = output_name;
2326           l->next = list;
2327           l->obfd = NULL;
2328           list = l;
2329           output_name = concat (output_name, "/",
2330                                 bfd_get_filename (this_element), (char *) 0);
2331         }
2332
2333       if (preserve_dates)
2334         {
2335           stat_status = bfd_stat_arch_elt (this_element, &buf);
2336
2337           if (stat_status != 0)
2338             non_fatal (_("internal stat error on %s"),
2339                        bfd_get_filename (this_element));
2340         }
2341
2342       l = (struct name_list *) xmalloc (sizeof (struct name_list));
2343       l->name = output_name;
2344       l->next = list;
2345       l->obfd = NULL;
2346       list = l;
2347
2348       ok_object = bfd_check_format (this_element, bfd_object);
2349       if (!ok_object)
2350         bfd_nonfatal_message (NULL, this_element, NULL,
2351                               _("Unable to recognise the format of file"));
2352
2353       /* PR binutils/3110: Cope with archives
2354          containing multiple target types.  */
2355       if (force_output_target || !ok_object)
2356         output_bfd = bfd_openw (output_name, output_target);
2357       else
2358         output_bfd = bfd_openw (output_name, bfd_get_target (this_element));
2359
2360       if (output_bfd == NULL)
2361         {
2362           bfd_nonfatal_message (output_name, NULL, NULL, NULL);
2363           status = 1;
2364           goto cleanup_and_exit;
2365         }
2366
2367       if (ok_object)
2368         {
2369           del = !copy_object (this_element, output_bfd, input_arch);
2370
2371           if (del && bfd_get_arch (this_element) == bfd_arch_unknown)
2372             /* Try again as an unknown object file.  */
2373             ok_object = FALSE;
2374           else if (!bfd_close (output_bfd))
2375             {
2376               bfd_nonfatal_message (output_name, NULL, NULL, NULL);
2377               /* Error in new object file. Don't change archive.  */
2378               status = 1;
2379             }
2380         }
2381
2382       if (!ok_object)
2383         {
2384           del = !copy_unknown_object (this_element, output_bfd);
2385           if (!bfd_close_all_done (output_bfd))
2386             {
2387               bfd_nonfatal_message (output_name, NULL, NULL, NULL);
2388               /* Error in new object file. Don't change archive.  */
2389               status = 1;
2390             }
2391         }
2392
2393       if (del)
2394         {
2395           unlink (output_name);
2396           status = 1;
2397         }
2398       else
2399         {
2400           if (preserve_dates && stat_status == 0)
2401             set_times (output_name, &buf);
2402
2403           /* Open the newly output file and attach to our list.  */
2404           output_bfd = bfd_openr (output_name, output_target);
2405
2406           l->obfd = output_bfd;
2407
2408           *ptr = output_bfd;
2409           ptr = &output_bfd->archive_next;
2410
2411           last_element = this_element;
2412
2413           this_element = bfd_openr_next_archived_file (ibfd, last_element);
2414
2415           bfd_close (last_element);
2416         }
2417     }
2418   *ptr = NULL;
2419
2420   filename = bfd_get_filename (obfd);
2421   if (!bfd_close (obfd))
2422     {
2423       status = 1;
2424       bfd_nonfatal_message (filename, NULL, NULL, NULL);
2425     }
2426
2427   filename = bfd_get_filename (ibfd);
2428   if (!bfd_close (ibfd))
2429     {
2430       status = 1;
2431       bfd_nonfatal_message (filename, NULL, NULL, NULL);
2432     }
2433
2434  cleanup_and_exit:
2435   /* Delete all the files that we opened.  */
2436   for (l = list; l != NULL; l = l->next)
2437     {
2438       if (l->obfd == NULL)
2439         rmdir (l->name);
2440       else
2441         {
2442           bfd_close (l->obfd);
2443           unlink (l->name);
2444         }
2445     }
2446   rmdir (dir);
2447 }
2448
2449 static void
2450 set_long_section_mode (bfd *output_bfd, bfd *input_bfd, enum long_section_name_handling style)
2451 {
2452   /* This is only relevant to Coff targets.  */
2453   if (bfd_get_flavour (output_bfd) == bfd_target_coff_flavour)
2454     {
2455       if (style == KEEP
2456           && bfd_get_flavour (input_bfd) == bfd_target_coff_flavour)
2457         style = bfd_coff_long_section_names (input_bfd) ? ENABLE : DISABLE;
2458       bfd_coff_set_long_section_names (output_bfd, style != DISABLE);
2459     }
2460 }
2461
2462 /* The top-level control.  */
2463
2464 static void
2465 copy_file (const char *input_filename, const char *output_filename,
2466            const char *input_target,   const char *output_target,
2467            const bfd_arch_info_type *input_arch)
2468 {
2469   bfd *ibfd;
2470   char **obj_matching;
2471   char **core_matching;
2472   off_t size = get_file_size (input_filename);
2473
2474   if (size < 1)
2475     {
2476       if (size == 0)
2477         non_fatal (_("error: the input file '%s' is empty"),
2478                    input_filename);
2479       status = 1;
2480       return;
2481     }
2482
2483   /* To allow us to do "strip *" without dying on the first
2484      non-object file, failures are nonfatal.  */
2485   ibfd = bfd_openr (input_filename, input_target);
2486   if (ibfd == NULL)
2487     {
2488       bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
2489       status = 1;
2490       return;
2491     }
2492
2493   switch (do_debug_sections)
2494     {
2495     case compress:
2496       ibfd->flags |= BFD_COMPRESS;
2497       break;
2498     case decompress:
2499       ibfd->flags |= BFD_DECOMPRESS;
2500       break;
2501     default:
2502       break;
2503     }
2504
2505   if (bfd_check_format (ibfd, bfd_archive))
2506     {
2507       bfd_boolean force_output_target;
2508       bfd *obfd;
2509
2510       /* bfd_get_target does not return the correct value until
2511          bfd_check_format succeeds.  */
2512       if (output_target == NULL)
2513         {
2514           output_target = bfd_get_target (ibfd);
2515           force_output_target = FALSE;
2516         }
2517       else
2518         force_output_target = TRUE;
2519
2520       obfd = bfd_openw (output_filename, output_target);
2521       if (obfd == NULL)
2522         {
2523           bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
2524           status = 1;
2525           return;
2526         }
2527       /* This is a no-op on non-Coff targets.  */
2528       set_long_section_mode (obfd, ibfd, long_section_names);
2529
2530       copy_archive (ibfd, obfd, output_target, force_output_target, input_arch);
2531     }
2532   else if (bfd_check_format_matches (ibfd, bfd_object, &obj_matching))
2533     {
2534       bfd *obfd;
2535     do_copy:
2536
2537       /* bfd_get_target does not return the correct value until
2538          bfd_check_format succeeds.  */
2539       if (output_target == NULL)
2540         output_target = bfd_get_target (ibfd);
2541
2542       obfd = bfd_openw (output_filename, output_target);
2543       if (obfd == NULL)
2544         {
2545           bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
2546           status = 1;
2547           return;
2548         }
2549       /* This is a no-op on non-Coff targets.  */
2550       set_long_section_mode (obfd, ibfd, long_section_names);
2551
2552       if (! copy_object (ibfd, obfd, input_arch))
2553         status = 1;
2554
2555       if (!bfd_close (obfd))
2556         {
2557           status = 1;
2558           bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
2559           return;
2560         }
2561
2562       if (!bfd_close (ibfd))
2563         {
2564           status = 1;
2565           bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
2566           return;
2567         }
2568     }
2569   else
2570     {
2571       bfd_error_type obj_error = bfd_get_error ();
2572       bfd_error_type core_error;
2573
2574       if (bfd_check_format_matches (ibfd, bfd_core, &core_matching))
2575         {
2576           /* This probably can't happen..  */
2577           if (obj_error == bfd_error_file_ambiguously_recognized)
2578             free (obj_matching);
2579           goto do_copy;
2580         }
2581
2582       core_error = bfd_get_error ();
2583       /* Report the object error in preference to the core error.  */
2584       if (obj_error != core_error)
2585         bfd_set_error (obj_error);
2586
2587       bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
2588
2589       if (obj_error == bfd_error_file_ambiguously_recognized)
2590         {
2591           list_matching_formats (obj_matching);
2592           free (obj_matching);
2593         }
2594       if (core_error == bfd_error_file_ambiguously_recognized)
2595         {
2596           list_matching_formats (core_matching);
2597           free (core_matching);
2598         }
2599
2600       status = 1;
2601     }
2602 }
2603
2604 /* Add a name to the section renaming list.  */
2605
2606 static void
2607 add_section_rename (const char * old_name, const char * new_name,
2608                     flagword flags)
2609 {
2610   section_rename * srename;
2611
2612   /* Check for conflicts first.  */
2613   for (srename = section_rename_list; srename != NULL; srename = srename->next)
2614     if (strcmp (srename->old_name, old_name) == 0)
2615       {
2616         /* Silently ignore duplicate definitions.  */
2617         if (strcmp (srename->new_name, new_name) == 0
2618             && srename->flags == flags)
2619           return;
2620
2621         fatal (_("Multiple renames of section %s"), old_name);
2622       }
2623
2624   srename = (section_rename *) xmalloc (sizeof (* srename));
2625
2626   srename->old_name = old_name;
2627   srename->new_name = new_name;
2628   srename->flags    = flags;
2629   srename->next     = section_rename_list;
2630
2631   section_rename_list = srename;
2632 }
2633
2634 /* Check the section rename list for a new name of the input section
2635    ISECTION.  Return the new name if one is found.
2636    Also set RETURNED_FLAGS to the flags to be used for this section.  */
2637
2638 static const char *
2639 find_section_rename (bfd * ibfd ATTRIBUTE_UNUSED, sec_ptr isection,
2640                      flagword * returned_flags)
2641 {
2642   const char * old_name = bfd_section_name (ibfd, isection);
2643   section_rename * srename;
2644
2645   /* Default to using the flags of the input section.  */
2646   * returned_flags = bfd_get_section_flags (ibfd, isection);
2647
2648   for (srename = section_rename_list; srename != NULL; srename = srename->next)
2649     if (strcmp (srename->old_name, old_name) == 0)
2650       {
2651         if (srename->flags != (flagword) -1)
2652           * returned_flags = srename->flags;
2653
2654         return srename->new_name;
2655       }
2656
2657   return old_name;
2658 }
2659
2660 /* Once each of the sections is copied, we may still need to do some
2661    finalization work for private section headers.  Do that here.  */
2662
2663 static void
2664 setup_bfd_headers (bfd *ibfd, bfd *obfd)
2665 {
2666   /* Allow the BFD backend to copy any private data it understands
2667      from the input section to the output section.  */
2668   if (! bfd_copy_private_header_data (ibfd, obfd))
2669     {
2670       status = 1;
2671       bfd_nonfatal_message (NULL, ibfd, NULL,
2672                             _("error in private header data"));
2673       return;
2674     }
2675
2676   /* All went well.  */
2677   return;
2678 }
2679
2680 /* Create a section in OBFD with the same
2681    name and attributes as ISECTION in IBFD.  */
2682
2683 static void
2684 setup_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
2685 {
2686   bfd *obfd = (bfd *) obfdarg;
2687   struct section_list *p;
2688   sec_ptr osection;
2689   bfd_size_type size;
2690   bfd_vma vma;
2691   bfd_vma lma;
2692   flagword flags;
2693   const char *err;
2694   const char * name;
2695   char *prefix = NULL;
2696   bfd_boolean make_nobits;
2697
2698   if (is_strip_section (ibfd, isection))
2699     return;
2700
2701   /* Get the, possibly new, name of the output section.  */
2702   name = find_section_rename (ibfd, isection, & flags);
2703
2704   /* Prefix sections.  */
2705   if ((prefix_alloc_sections_string)
2706       && (bfd_get_section_flags (ibfd, isection) & SEC_ALLOC))
2707     prefix = prefix_alloc_sections_string;
2708   else if (prefix_sections_string)
2709     prefix = prefix_sections_string;
2710
2711   if (prefix)
2712     {
2713       char *n;
2714
2715       n = (char *) xmalloc (strlen (prefix) + strlen (name) + 1);
2716       strcpy (n, prefix);
2717       strcat (n, name);
2718       name = n;
2719     }
2720
2721   make_nobits = FALSE;
2722
2723   p = find_section_list (bfd_section_name (ibfd, isection), FALSE,
2724                          SECTION_CONTEXT_SET_FLAGS);
2725   if (p != NULL)
2726     flags = p->flags | (flags & (SEC_HAS_CONTENTS | SEC_RELOC));
2727   else if (strip_symbols == STRIP_NONDEBUG
2728            && (flags & (SEC_ALLOC | SEC_GROUP)) != 0
2729            && !is_nondebug_keep_contents_section (ibfd, isection))
2730     {
2731       flags &= ~(SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP);
2732       if (obfd->xvec->flavour == bfd_target_elf_flavour)
2733         {
2734           make_nobits = TRUE;
2735
2736           /* Twiddle the input section flags so that it seems to
2737              elf.c:copy_private_bfd_data that section flags have not
2738              changed between input and output sections.  This hack
2739              prevents wholesale rewriting of the program headers.  */
2740           isection->flags &= ~(SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP);
2741         }
2742     }
2743
2744   osection = bfd_make_section_anyway_with_flags (obfd, name, flags);
2745
2746   if (osection == NULL)
2747     {
2748       err = _("failed to create output section");
2749       goto loser;
2750     }
2751
2752   if (make_nobits)
2753     elf_section_type (osection) = SHT_NOBITS;
2754
2755   size = bfd_section_size (ibfd, isection);
2756   if (copy_byte >= 0)
2757     size = (size + interleave - 1) / interleave * copy_width;
2758   else if (extract_symbol)
2759     size = 0;
2760   if (! bfd_set_section_size (obfd, osection, size))
2761     {
2762       err = _("failed to set size");
2763       goto loser;
2764     }
2765
2766   vma = bfd_section_vma (ibfd, isection);
2767   p = find_section_list (bfd_section_name (ibfd, isection), FALSE,
2768                          SECTION_CONTEXT_ALTER_VMA | SECTION_CONTEXT_SET_VMA);
2769   if (p != NULL)
2770     {
2771       if (p->context & SECTION_CONTEXT_SET_VMA)
2772         vma = p->vma_val;
2773       else
2774         vma += p->vma_val;
2775     }
2776   else
2777     vma += change_section_address;
2778
2779   if (! bfd_set_section_vma (obfd, osection, vma))
2780     {
2781       err = _("failed to set vma");
2782       goto loser;
2783     }
2784
2785   lma = isection->lma;
2786   p = find_section_list (bfd_section_name (ibfd, isection), FALSE,
2787                          SECTION_CONTEXT_ALTER_LMA | SECTION_CONTEXT_SET_LMA);
2788   if (p != NULL)
2789     {
2790       if (p->context & SECTION_CONTEXT_ALTER_LMA)
2791         lma += p->lma_val;
2792       else
2793         lma = p->lma_val;
2794     }
2795   else
2796     lma += change_section_address;
2797
2798   osection->lma = lma;
2799
2800   /* FIXME: This is probably not enough.  If we change the LMA we
2801      may have to recompute the header for the file as well.  */
2802   if (!bfd_set_section_alignment (obfd,
2803                                   osection,
2804                                   bfd_section_alignment (ibfd, isection)))
2805     {
2806       err = _("failed to set alignment");
2807       goto loser;
2808     }
2809
2810   /* Copy merge entity size.  */
2811   osection->entsize = isection->entsize;
2812
2813   /* This used to be mangle_section; we do here to avoid using
2814      bfd_get_section_by_name since some formats allow multiple
2815      sections with the same name.  */
2816   isection->output_section = osection;
2817   isection->output_offset = 0;
2818
2819   /* Do not copy backend data if --extract-symbol is passed; anything
2820      that needs to look at the section contents will fail.  */
2821   if (extract_symbol)
2822     return;
2823
2824   if ((isection->flags & SEC_GROUP) != 0)
2825     {
2826       asymbol *gsym = group_signature (isection);
2827
2828       if (gsym != NULL)
2829         {
2830           gsym->flags |= BSF_KEEP;
2831           if (ibfd->xvec->flavour == bfd_target_elf_flavour)
2832             elf_group_id (isection) = gsym;
2833         }
2834     }
2835
2836   /* Allow the BFD backend to copy any private data it understands
2837      from the input section to the output section.  */
2838   if (!bfd_copy_private_section_data (ibfd, isection, obfd, osection))
2839     {
2840       err = _("failed to copy private data");
2841       goto loser;
2842     }
2843
2844   /* All went well.  */
2845   return;
2846
2847 loser:
2848   status = 1;
2849   bfd_nonfatal_message (NULL, obfd, osection, err);
2850 }
2851
2852 /* Return TRUE if input section ISECTION should be skipped.  */
2853
2854 static bfd_boolean
2855 skip_section (bfd *ibfd, sec_ptr isection)
2856 {
2857   sec_ptr osection;
2858   bfd_size_type size;
2859   flagword flags;
2860
2861   /* If we have already failed earlier on,
2862      do not keep on generating complaints now.  */
2863   if (status != 0)
2864     return TRUE;
2865
2866   if (extract_symbol)
2867     return TRUE;
2868
2869   if (is_strip_section (ibfd, isection))
2870     return TRUE;
2871
2872   flags = bfd_get_section_flags (ibfd, isection);
2873   if ((flags & SEC_GROUP) != 0)
2874     return TRUE;
2875
2876   osection = isection->output_section;
2877   size = bfd_get_section_size (isection);
2878
2879   if (size == 0 || osection == 0)
2880     return TRUE;
2881
2882   return FALSE;
2883 }
2884
2885 /* Copy relocations in input section ISECTION of IBFD to an output
2886    section with the same name in OBFDARG.  If stripping then don't
2887    copy any relocation info.  */
2888
2889 static void
2890 copy_relocations_in_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
2891 {
2892   bfd *obfd = (bfd *) obfdarg;
2893   long relsize;
2894   arelent **relpp;
2895   long relcount;
2896   sec_ptr osection;
2897
2898   if (skip_section (ibfd, isection))
2899     return;
2900
2901   osection = isection->output_section;
2902
2903   /* Core files and DWO files do not need to be relocated.  */
2904   if (bfd_get_format (obfd) == bfd_core || strip_symbols == STRIP_NONDWO)
2905     relsize = 0;
2906   else
2907     {
2908       relsize = bfd_get_reloc_upper_bound (ibfd, isection);
2909
2910       if (relsize < 0)
2911         {
2912           /* Do not complain if the target does not support relocations.  */
2913           if (relsize == -1 && bfd_get_error () == bfd_error_invalid_operation)
2914             relsize = 0;
2915           else
2916             {
2917               status = 1;
2918               bfd_nonfatal_message (NULL, ibfd, isection, NULL);
2919               return;
2920             }
2921         }
2922     }
2923
2924   if (relsize == 0)
2925     {
2926       bfd_set_reloc (obfd, osection, NULL, 0);
2927       osection->flags &= ~SEC_RELOC;
2928     }
2929   else
2930     {
2931       relpp = (arelent **) xmalloc (relsize);
2932       relcount = bfd_canonicalize_reloc (ibfd, isection, relpp, isympp);
2933       if (relcount < 0)
2934         {
2935           status = 1;
2936           bfd_nonfatal_message (NULL, ibfd, isection,
2937                                 _("relocation count is negative"));
2938           return;
2939         }
2940
2941       if (strip_symbols == STRIP_ALL)
2942         {
2943           /* Remove relocations which are not in
2944              keep_strip_specific_list.  */
2945           arelent **temp_relpp;
2946           long temp_relcount = 0;
2947           long i;
2948
2949           temp_relpp = (arelent **) xmalloc (relsize);
2950           for (i = 0; i < relcount; i++)
2951             if (is_specified_symbol (bfd_asymbol_name (*relpp[i]->sym_ptr_ptr),
2952                                      keep_specific_htab))
2953               temp_relpp [temp_relcount++] = relpp [i];
2954           relcount = temp_relcount;
2955           free (relpp);
2956           relpp = temp_relpp;
2957         }
2958
2959       bfd_set_reloc (obfd, osection, relcount == 0 ? NULL : relpp, relcount);
2960       if (relcount == 0)
2961         {
2962           osection->flags &= ~SEC_RELOC;
2963           free (relpp);
2964         }
2965     }
2966 }
2967
2968 /* Copy the data of input section ISECTION of IBFD
2969    to an output section with the same name in OBFD.  */
2970
2971 static void
2972 copy_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
2973 {
2974   bfd *obfd = (bfd *) obfdarg;
2975   struct section_list *p;
2976   sec_ptr osection;
2977   bfd_size_type size;
2978
2979   if (skip_section (ibfd, isection))
2980     return;
2981
2982   osection = isection->output_section;
2983   size = bfd_get_section_size (isection);
2984
2985   if (bfd_get_section_flags (ibfd, isection) & SEC_HAS_CONTENTS
2986       && bfd_get_section_flags (obfd, osection) & SEC_HAS_CONTENTS)
2987     {
2988       bfd_byte *memhunk = NULL;
2989
2990       if (!bfd_get_full_section_contents (ibfd, isection, &memhunk))
2991         {
2992           status = 1;
2993           bfd_nonfatal_message (NULL, ibfd, isection, NULL);
2994           return;
2995         }
2996
2997       if (reverse_bytes)
2998         {
2999           /* We don't handle leftover bytes (too many possible behaviors,
3000              and we don't know what the user wants).  The section length
3001              must be a multiple of the number of bytes to swap.  */
3002           if ((size % reverse_bytes) == 0)
3003             {
3004               unsigned long i, j;
3005               bfd_byte b;
3006
3007               for (i = 0; i < size; i += reverse_bytes)
3008                 for (j = 0; j < (unsigned long)(reverse_bytes / 2); j++)
3009                   {
3010                     bfd_byte *m = (bfd_byte *) memhunk;
3011
3012                     b = m[i + j];
3013                     m[i + j] = m[(i + reverse_bytes) - (j + 1)];
3014                     m[(i + reverse_bytes) - (j + 1)] = b;
3015                   }
3016             }
3017           else
3018             /* User must pad the section up in order to do this.  */
3019             fatal (_("cannot reverse bytes: length of section %s must be evenly divisible by %d"),
3020                    bfd_section_name (ibfd, isection), reverse_bytes);
3021         }
3022
3023       if (copy_byte >= 0)
3024         {
3025           /* Keep only every `copy_byte'th byte in MEMHUNK.  */
3026           char *from = (char *) memhunk + copy_byte;
3027           char *to = (char *) memhunk;
3028           char *end = (char *) memhunk + size;
3029           int i;
3030
3031           for (; from < end; from += interleave)
3032             for (i = 0; i < copy_width; i++)
3033               {
3034                 if (&from[i] >= end)
3035                   break;
3036                 *to++ = from[i];
3037               }
3038
3039           size = (size + interleave - 1 - copy_byte) / interleave * copy_width;
3040           osection->lma /= interleave;
3041         }
3042
3043       if (!bfd_set_section_contents (obfd, osection, memhunk, 0, size))
3044         {
3045           status = 1;
3046           bfd_nonfatal_message (NULL, obfd, osection, NULL);
3047           return;
3048         }
3049       free (memhunk);
3050     }
3051   else if ((p = find_section_list (bfd_get_section_name (ibfd, isection),
3052                                    FALSE, SECTION_CONTEXT_SET_FLAGS)) != NULL
3053            && (p->flags & SEC_HAS_CONTENTS) != 0)
3054     {
3055       void *memhunk = xmalloc (size);
3056
3057       /* We don't permit the user to turn off the SEC_HAS_CONTENTS
3058          flag--they can just remove the section entirely and add it
3059          back again.  However, we do permit them to turn on the
3060          SEC_HAS_CONTENTS flag, and take it to mean that the section
3061          contents should be zeroed out.  */
3062
3063       memset (memhunk, 0, size);
3064       if (! bfd_set_section_contents (obfd, osection, memhunk, 0, size))
3065         {
3066           status = 1;
3067           bfd_nonfatal_message (NULL, obfd, osection, NULL);
3068           return;
3069         }
3070       free (memhunk);
3071     }
3072 }
3073
3074 /* Get all the sections.  This is used when --gap-fill or --pad-to is
3075    used.  */
3076
3077 static void
3078 get_sections (bfd *obfd ATTRIBUTE_UNUSED, asection *osection, void *secppparg)
3079 {
3080   asection ***secppp = (asection ***) secppparg;
3081
3082   **secppp = osection;
3083   ++(*secppp);
3084 }
3085
3086 /* Sort sections by VMA.  This is called via qsort, and is used when
3087    --gap-fill or --pad-to is used.  We force non loadable or empty
3088    sections to the front, where they are easier to ignore.  */
3089
3090 static int
3091 compare_section_lma (const void *arg1, const void *arg2)
3092 {
3093   const asection *const *sec1 = (const asection * const *) arg1;
3094   const asection *const *sec2 = (const asection * const *) arg2;
3095   flagword flags1, flags2;
3096
3097   /* Sort non loadable sections to the front.  */
3098   flags1 = (*sec1)->flags;
3099   flags2 = (*sec2)->flags;
3100   if ((flags1 & SEC_HAS_CONTENTS) == 0
3101       || (flags1 & SEC_LOAD) == 0)
3102     {
3103       if ((flags2 & SEC_HAS_CONTENTS) != 0
3104           && (flags2 & SEC_LOAD) != 0)
3105         return -1;
3106     }
3107   else
3108     {
3109       if ((flags2 & SEC_HAS_CONTENTS) == 0
3110           || (flags2 & SEC_LOAD) == 0)
3111         return 1;
3112     }
3113
3114   /* Sort sections by LMA.  */
3115   if ((*sec1)->lma > (*sec2)->lma)
3116     return 1;
3117   else if ((*sec1)->lma < (*sec2)->lma)
3118     return -1;
3119
3120   /* Sort sections with the same LMA by size.  */
3121   if (bfd_get_section_size (*sec1) > bfd_get_section_size (*sec2))
3122     return 1;
3123   else if (bfd_get_section_size (*sec1) < bfd_get_section_size (*sec2))
3124     return -1;
3125
3126   return 0;
3127 }
3128
3129 /* Mark all the symbols which will be used in output relocations with
3130    the BSF_KEEP flag so that those symbols will not be stripped.
3131
3132    Ignore relocations which will not appear in the output file.  */
3133
3134 static void
3135 mark_symbols_used_in_relocations (bfd *ibfd, sec_ptr isection, void *symbolsarg)
3136 {
3137   asymbol **symbols = (asymbol **) symbolsarg;
3138   long relsize;
3139   arelent **relpp;
3140   long relcount, i;
3141
3142   /* Ignore an input section with no corresponding output section.  */
3143   if (isection->output_section == NULL)
3144     return;
3145
3146   relsize = bfd_get_reloc_upper_bound (ibfd, isection);
3147   if (relsize < 0)
3148     {
3149       /* Do not complain if the target does not support relocations.  */
3150       if (relsize == -1 && bfd_get_error () == bfd_error_invalid_operation)
3151         return;
3152       bfd_fatal (bfd_get_filename (ibfd));
3153     }
3154
3155   if (relsize == 0)
3156     return;
3157
3158   relpp = (arelent **) xmalloc (relsize);
3159   relcount = bfd_canonicalize_reloc (ibfd, isection, relpp, symbols);
3160   if (relcount < 0)
3161     bfd_fatal (bfd_get_filename (ibfd));
3162
3163   /* Examine each symbol used in a relocation.  If it's not one of the
3164      special bfd section symbols, then mark it with BSF_KEEP.  */
3165   for (i = 0; i < relcount; i++)
3166     {
3167       if (*relpp[i]->sym_ptr_ptr != bfd_com_section_ptr->symbol
3168           && *relpp[i]->sym_ptr_ptr != bfd_abs_section_ptr->symbol
3169           && *relpp[i]->sym_ptr_ptr != bfd_und_section_ptr->symbol)
3170         (*relpp[i]->sym_ptr_ptr)->flags |= BSF_KEEP;
3171     }
3172
3173   if (relpp != NULL)
3174     free (relpp);
3175 }
3176
3177 /* Write out debugging information.  */
3178
3179 static bfd_boolean
3180 write_debugging_info (bfd *obfd, void *dhandle,
3181                       long *symcountp ATTRIBUTE_UNUSED,
3182                       asymbol ***symppp ATTRIBUTE_UNUSED)
3183 {
3184   if (bfd_get_flavour (obfd) == bfd_target_ieee_flavour)
3185     return write_ieee_debugging_info (obfd, dhandle);
3186
3187   if (bfd_get_flavour (obfd) == bfd_target_coff_flavour
3188       || bfd_get_flavour (obfd) == bfd_target_elf_flavour)
3189     {
3190       bfd_byte *syms, *strings;
3191       bfd_size_type symsize, stringsize;
3192       asection *stabsec, *stabstrsec;
3193       flagword flags;
3194
3195       if (! write_stabs_in_sections_debugging_info (obfd, dhandle, &syms,
3196                                                     &symsize, &strings,
3197                                                     &stringsize))
3198         return FALSE;
3199
3200       flags = SEC_HAS_CONTENTS | SEC_READONLY | SEC_DEBUGGING;
3201       stabsec = bfd_make_section_with_flags (obfd, ".stab", flags);
3202       stabstrsec = bfd_make_section_with_flags (obfd, ".stabstr", flags);
3203       if (stabsec == NULL
3204           || stabstrsec == NULL
3205           || ! bfd_set_section_size (obfd, stabsec, symsize)
3206           || ! bfd_set_section_size (obfd, stabstrsec, stringsize)
3207           || ! bfd_set_section_alignment (obfd, stabsec, 2)
3208           || ! bfd_set_section_alignment (obfd, stabstrsec, 0))
3209         {
3210           bfd_nonfatal_message (NULL, obfd, NULL,
3211                                 _("can't create debugging section"));
3212           return FALSE;
3213         }
3214
3215       /* We can get away with setting the section contents now because
3216          the next thing the caller is going to do is copy over the
3217          real sections.  We may someday have to split the contents
3218          setting out of this function.  */
3219       if (! bfd_set_section_contents (obfd, stabsec, syms, 0, symsize)
3220           || ! bfd_set_section_contents (obfd, stabstrsec, strings, 0,
3221                                          stringsize))
3222         {
3223           bfd_nonfatal_message (NULL, obfd, NULL,
3224                                 _("can't set debugging section contents"));
3225           return FALSE;
3226         }
3227
3228       return TRUE;
3229     }
3230
3231   bfd_nonfatal_message (NULL, obfd, NULL,
3232                         _("don't know how to write debugging information for %s"),
3233              bfd_get_target (obfd));
3234   return FALSE;
3235 }
3236
3237 /* If neither -D nor -U was specified explicitly,
3238    then use the configured default.  */
3239 static void
3240 default_deterministic (void)
3241 {
3242   if (deterministic < 0)
3243     deterministic = DEFAULT_AR_DETERMINISTIC;
3244 }
3245
3246 static int
3247 strip_main (int argc, char *argv[])
3248 {
3249   char *input_target = NULL;
3250   char *output_target = NULL;
3251   bfd_boolean show_version = FALSE;
3252   bfd_boolean formats_info = FALSE;
3253   int c;
3254   int i;
3255   char *output_file = NULL;
3256
3257   while ((c = getopt_long (argc, argv, "I:O:F:K:N:R:o:sSpdgxXHhVvw",
3258                            strip_options, (int *) 0)) != EOF)
3259     {
3260       switch (c)
3261         {
3262         case 'I':
3263           input_target = optarg;
3264           break;
3265         case 'O':
3266           output_target = optarg;
3267           break;
3268         case 'F':
3269           input_target = output_target = optarg;
3270           break;
3271         case 'R':
3272           find_section_list (optarg, TRUE, SECTION_CONTEXT_REMOVE);
3273           sections_removed = TRUE;
3274           break;
3275         case 's':
3276           strip_symbols = STRIP_ALL;
3277           break;
3278         case 'S':
3279         case 'g':
3280         case 'd':       /* Historic BSD alias for -g.  Used by early NetBSD.  */
3281           strip_symbols = STRIP_DEBUG;
3282           break;
3283         case OPTION_STRIP_DWO:
3284           strip_symbols = STRIP_DWO;
3285           break;
3286         case OPTION_STRIP_UNNEEDED:
3287           strip_symbols = STRIP_UNNEEDED;
3288           break;
3289         case 'K':
3290           add_specific_symbol (optarg, keep_specific_htab);
3291           break;
3292         case 'N':
3293           add_specific_symbol (optarg, strip_specific_htab);
3294           break;
3295         case 'o':
3296           output_file = optarg;
3297           break;
3298         case 'p':
3299           preserve_dates = TRUE;
3300           break;
3301         case 'D':
3302           deterministic = TRUE;
3303           break;
3304         case 'U':
3305           deterministic = FALSE;
3306           break;
3307         case 'x':
3308           discard_locals = LOCALS_ALL;
3309           break;
3310         case 'X':
3311           discard_locals = LOCALS_START_L;
3312           break;
3313         case 'v':
3314           verbose = TRUE;
3315           break;
3316         case 'V':
3317           show_version = TRUE;
3318           break;
3319         case OPTION_FORMATS_INFO:
3320           formats_info = TRUE;
3321           break;
3322         case OPTION_ONLY_KEEP_DEBUG:
3323           strip_symbols = STRIP_NONDEBUG;
3324           break;
3325         case OPTION_KEEP_FILE_SYMBOLS:
3326           keep_file_symbols = 1;
3327           break;
3328         case 0:
3329           /* We've been given a long option.  */
3330           break;
3331         case 'w':
3332           wildcard = TRUE;
3333           break;
3334         case 'H':
3335         case 'h':
3336           strip_usage (stdout, 0);
3337         default:
3338           strip_usage (stderr, 1);
3339         }
3340     }
3341
3342   if (formats_info)
3343     {
3344       display_info ();
3345       return 0;
3346     }
3347
3348   if (show_version)
3349     print_version ("strip");
3350
3351   default_deterministic ();
3352
3353   /* Default is to strip all symbols.  */
3354   if (strip_symbols == STRIP_UNDEF
3355       && discard_locals == LOCALS_UNDEF
3356       && htab_elements (strip_specific_htab) == 0)
3357     strip_symbols = STRIP_ALL;
3358
3359   if (output_target == NULL)
3360     output_target = input_target;
3361
3362   i = optind;
3363   if (i == argc
3364       || (output_file != NULL && (i + 1) < argc))
3365     strip_usage (stderr, 1);
3366
3367   for (; i < argc; i++)
3368     {
3369       int hold_status = status;
3370       struct stat statbuf;
3371       char *tmpname;
3372
3373       if (get_file_size (argv[i]) < 1)
3374         {
3375           status = 1;
3376           continue;
3377         }
3378
3379       if (preserve_dates)
3380         /* No need to check the return value of stat().
3381            It has already been checked in get_file_size().  */
3382         stat (argv[i], &statbuf);
3383
3384       if (output_file == NULL
3385           || filename_cmp (argv[i], output_file) == 0)
3386         tmpname = make_tempname (argv[i]);
3387       else
3388         tmpname = output_file;
3389
3390       if (tmpname == NULL)
3391         {
3392           bfd_nonfatal_message (argv[i], NULL, NULL,
3393                                 _("could not create temporary file to hold stripped copy"));
3394           status = 1;
3395           continue;
3396         }
3397
3398       status = 0;
3399       copy_file (argv[i], tmpname, input_target, output_target, NULL);
3400       if (status == 0)
3401         {
3402           if (preserve_dates)
3403             set_times (tmpname, &statbuf);
3404           if (output_file != tmpname)
3405             status = (smart_rename (tmpname,
3406                                     output_file ? output_file : argv[i],
3407                                     preserve_dates) != 0);
3408           if (status == 0)
3409             status = hold_status;
3410         }
3411       else
3412         unlink_if_ordinary (tmpname);
3413       if (output_file != tmpname)
3414         free (tmpname);
3415     }
3416
3417   return status;
3418 }
3419
3420 /* Set up PE subsystem.  */
3421
3422 static void
3423 set_pe_subsystem (const char *s)
3424 {
3425   const char *version, *subsystem;
3426   size_t i;
3427   static const struct
3428     {
3429       const char *name;
3430       const char set_def;
3431       const short value;
3432     }
3433   v[] =
3434     {
3435       { "native", 0, IMAGE_SUBSYSTEM_NATIVE },
3436       { "windows", 0, IMAGE_SUBSYSTEM_WINDOWS_GUI },
3437       { "console", 0, IMAGE_SUBSYSTEM_WINDOWS_CUI },
3438       { "posix", 0, IMAGE_SUBSYSTEM_POSIX_CUI },
3439       { "wince", 0, IMAGE_SUBSYSTEM_WINDOWS_CE_GUI },
3440       { "efi-app", 1, IMAGE_SUBSYSTEM_EFI_APPLICATION },
3441       { "efi-bsd", 1, IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER },
3442       { "efi-rtd", 1, IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER },
3443       { "sal-rtd", 1, IMAGE_SUBSYSTEM_SAL_RUNTIME_DRIVER },
3444       { "xbox", 0, IMAGE_SUBSYSTEM_XBOX }
3445     };
3446   short value;
3447   char *copy;
3448   int set_def = -1;
3449
3450   /* Check for the presence of a version number.  */
3451   version = strchr (s, ':');
3452   if (version == NULL)
3453     subsystem = s;
3454   else
3455     {
3456       int len = version - s;
3457       copy = xstrdup (s);
3458       subsystem = copy;
3459       copy[len] = '\0';
3460       version = copy + 1 + len;
3461       pe_major_subsystem_version = strtoul (version, &copy, 0);
3462       if (*copy == '.')
3463         pe_minor_subsystem_version = strtoul (copy + 1, &copy, 0);
3464       if (*copy != '\0')
3465         non_fatal (_("%s: bad version in PE subsystem"), s);
3466     }
3467
3468   /* Check for numeric subsystem.  */
3469   value = (short) strtol (subsystem, &copy, 0);
3470   if (*copy == '\0')
3471     {
3472       for (i = 0; i < ARRAY_SIZE (v); i++)
3473         if (v[i].value == value)
3474           {
3475             pe_subsystem = value;
3476             set_def = v[i].set_def;
3477             break;
3478           }
3479     }
3480   else
3481     {
3482       /* Search for subsystem by name.  */
3483       for (i = 0; i < ARRAY_SIZE (v); i++)
3484         if (strcmp (subsystem, v[i].name) == 0)
3485           {
3486             pe_subsystem = v[i].value;
3487             set_def = v[i].set_def;
3488             break;
3489           }
3490     }
3491
3492   switch (set_def)
3493     {
3494     case -1:
3495       fatal (_("unknown PE subsystem: %s"), s);
3496       break;
3497     case 0:
3498       break;
3499     default:
3500       if (pe_file_alignment == (bfd_vma) -1)
3501         pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
3502       if (pe_section_alignment == (bfd_vma) -1)
3503         pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
3504       break;
3505     }
3506   if (s != subsystem)
3507     free ((char *) subsystem);
3508 }
3509
3510 /* Convert EFI target to PEI target.  */
3511
3512 static void
3513 convert_efi_target (char *efi)
3514 {
3515   efi[0] = 'p';
3516   efi[1] = 'e';
3517   efi[2] = 'i';
3518
3519   if (strcmp (efi + 4, "ia32") == 0)
3520     {
3521       /* Change ia32 to i386.  */
3522       efi[5]= '3';
3523       efi[6]= '8';
3524       efi[7]= '6';
3525     }
3526   else if (strcmp (efi + 4, "x86_64") == 0)
3527     {
3528       /* Change x86_64 to x86-64.  */
3529       efi[7] = '-';
3530     }
3531 }
3532
3533 static int
3534 copy_main (int argc, char *argv[])
3535 {
3536   char *input_filename = NULL;
3537   char *output_filename = NULL;
3538   char *tmpname;
3539   char *input_target = NULL;
3540   char *output_target = NULL;
3541   bfd_boolean show_version = FALSE;
3542   bfd_boolean change_warn = TRUE;
3543   bfd_boolean formats_info = FALSE;
3544   int c;
3545   struct stat statbuf;
3546   const bfd_arch_info_type *input_arch = NULL;
3547
3548   while ((c = getopt_long (argc, argv, "b:B:i:I:j:K:N:s:O:d:F:L:G:R:SpgxXHhVvW:w",
3549                            copy_options, (int *) 0)) != EOF)
3550     {
3551       switch (c)
3552         {
3553         case 'b':
3554           copy_byte = atoi (optarg);
3555           if (copy_byte < 0)
3556             fatal (_("byte number must be non-negative"));
3557           break;
3558
3559         case 'B':
3560           input_arch = bfd_scan_arch (optarg);
3561           if (input_arch == NULL)
3562             fatal (_("architecture %s unknown"), optarg);
3563           break;
3564
3565         case 'i':
3566           if (optarg)
3567             {
3568               interleave = atoi (optarg);
3569               if (interleave < 1)
3570                 fatal (_("interleave must be positive"));
3571             }
3572           else
3573             interleave = 4;
3574           break;
3575
3576         case OPTION_INTERLEAVE_WIDTH:
3577           copy_width = atoi (optarg);
3578           if (copy_width < 1)
3579             fatal(_("interleave width must be positive"));
3580           break;
3581
3582         case 'I':
3583         case 's':               /* "source" - 'I' is preferred */
3584           input_target = optarg;
3585           break;
3586
3587         case 'O':
3588         case 'd':               /* "destination" - 'O' is preferred */
3589           output_target = optarg;
3590           break;
3591
3592         case 'F':
3593           input_target = output_target = optarg;
3594           break;
3595
3596         case 'j':
3597           find_section_list (optarg, TRUE, SECTION_CONTEXT_COPY);
3598           sections_copied = TRUE;
3599           break;
3600
3601         case 'R':
3602           find_section_list (optarg, TRUE, SECTION_CONTEXT_REMOVE);
3603           sections_removed = TRUE;
3604           break;
3605
3606         case 'S':
3607           strip_symbols = STRIP_ALL;
3608           break;
3609
3610         case 'g':
3611           strip_symbols = STRIP_DEBUG;
3612           break;
3613
3614         case OPTION_STRIP_DWO:
3615           strip_symbols = STRIP_DWO;
3616           break;
3617
3618         case OPTION_STRIP_UNNEEDED:
3619           strip_symbols = STRIP_UNNEEDED;
3620           break;
3621
3622         case OPTION_ONLY_KEEP_DEBUG:
3623           strip_symbols = STRIP_NONDEBUG;
3624           break;
3625
3626         case OPTION_KEEP_FILE_SYMBOLS:
3627           keep_file_symbols = 1;
3628           break;
3629
3630         case OPTION_ADD_GNU_DEBUGLINK:
3631           long_section_names = ENABLE ;
3632           gnu_debuglink_filename = optarg;
3633           break;
3634
3635         case 'K':
3636           add_specific_symbol (optarg, keep_specific_htab);
3637           break;
3638
3639         case 'N':
3640           add_specific_symbol (optarg, strip_specific_htab);
3641           break;
3642
3643         case OPTION_STRIP_UNNEEDED_SYMBOL:
3644           add_specific_symbol (optarg, strip_unneeded_htab);
3645           break;
3646
3647         case 'L':
3648           add_specific_symbol (optarg, localize_specific_htab);
3649           break;
3650
3651         case OPTION_GLOBALIZE_SYMBOL:
3652           add_specific_symbol (optarg, globalize_specific_htab);
3653           break;
3654
3655         case 'G':
3656           add_specific_symbol (optarg, keepglobal_specific_htab);
3657           break;
3658
3659         case 'W':
3660           add_specific_symbol (optarg, weaken_specific_htab);
3661           break;
3662
3663         case 'p':
3664           preserve_dates = TRUE;
3665           break;
3666
3667         case 'D':
3668           deterministic = TRUE;
3669           break;
3670
3671         case 'U':
3672           deterministic = FALSE;
3673           break;
3674
3675         case 'w':
3676           wildcard = TRUE;
3677           break;
3678
3679         case 'x':
3680           discard_locals = LOCALS_ALL;
3681           break;
3682
3683         case 'X':
3684           discard_locals = LOCALS_START_L;
3685           break;
3686
3687         case 'v':
3688           verbose = TRUE;
3689           break;
3690
3691         case 'V':
3692           show_version = TRUE;
3693           break;
3694
3695         case OPTION_FORMATS_INFO:
3696           formats_info = TRUE;
3697           break;
3698
3699         case OPTION_WEAKEN:
3700           weaken = TRUE;
3701           break;
3702
3703         case OPTION_ADD_SECTION:
3704           {
3705             const char *s;
3706             size_t off, alloc;
3707             struct section_add *pa;
3708             FILE *f;
3709
3710             s = strchr (optarg, '=');
3711
3712             if (s == NULL)
3713               fatal (_("bad format for %s"), "--add-section");
3714
3715             pa = (struct section_add *) xmalloc (sizeof (struct section_add));
3716             pa->name = xstrndup (optarg, s - optarg);
3717             pa->filename = s + 1;
3718
3719             /* We don't use get_file_size so that we can do
3720                  --add-section .note.GNU_stack=/dev/null
3721                get_file_size doesn't work on /dev/null.  */
3722
3723             f = fopen (pa->filename, FOPEN_RB);
3724             if (f == NULL)
3725               fatal (_("cannot open: %s: %s"),
3726                      pa->filename, strerror (errno));
3727
3728             off = 0;
3729             alloc = 4096;
3730             pa->contents = (bfd_byte *) xmalloc (alloc);
3731             while (!feof (f))
3732               {
3733                 off_t got;
3734
3735                 if (off == alloc)
3736                   {
3737                     alloc <<= 1;
3738                     pa->contents = (bfd_byte *) xrealloc (pa->contents, alloc);
3739                   }
3740
3741                 got = fread (pa->contents + off, 1, alloc - off, f);
3742                 if (ferror (f))
3743                   fatal (_("%s: fread failed"), pa->filename);
3744
3745                 off += got;
3746               }
3747
3748             pa->size = off;
3749
3750             fclose (f);
3751
3752             pa->next = add_sections;
3753             add_sections = pa;
3754           }
3755           break;
3756
3757         case OPTION_DUMP_SECTION:
3758           {
3759             const char *s;
3760             struct section_add *pa;
3761
3762             s = strchr (optarg, '=');
3763
3764             if (s == NULL)
3765               fatal (_("bad format for %s"), "--dump-section");
3766
3767             pa = (struct section_add *) xmalloc (sizeof * pa);
3768             pa->name = xstrndup (optarg, s - optarg);
3769             pa->filename = s + 1;
3770             pa->next = dump_sections;
3771             pa->contents = NULL;
3772             dump_sections = pa;
3773           }
3774           break;
3775           
3776         case OPTION_CHANGE_START:
3777           change_start = parse_vma (optarg, "--change-start");
3778           break;
3779
3780         case OPTION_CHANGE_SECTION_ADDRESS:
3781         case OPTION_CHANGE_SECTION_LMA:
3782         case OPTION_CHANGE_SECTION_VMA:
3783           {
3784             struct section_list * p;
3785             unsigned int context = 0;
3786             const char *s;
3787             int len;
3788             char *name;
3789             char *option = NULL;
3790             bfd_vma val;
3791
3792             switch (c)
3793               {
3794               case OPTION_CHANGE_SECTION_ADDRESS:
3795                 option = "--change-section-address";
3796                 context = SECTION_CONTEXT_ALTER_LMA | SECTION_CONTEXT_ALTER_VMA;
3797                 break;
3798               case OPTION_CHANGE_SECTION_LMA:
3799                 option = "--change-section-lma";
3800                 context = SECTION_CONTEXT_ALTER_LMA;
3801                 break;
3802               case OPTION_CHANGE_SECTION_VMA:
3803                 option = "--change-section-vma";
3804                 context = SECTION_CONTEXT_ALTER_VMA;
3805                 break;
3806               }
3807
3808             s = strchr (optarg, '=');
3809             if (s == NULL)
3810               {
3811                 s = strchr (optarg, '+');
3812                 if (s == NULL)
3813                   {
3814                     s = strchr (optarg, '-');
3815                     if (s == NULL)
3816                       fatal (_("bad format for %s"), option);
3817                   }
3818               }
3819             else
3820               {
3821                 /* Correct the context.  */
3822                 switch (c)
3823                   {
3824                   case OPTION_CHANGE_SECTION_ADDRESS:
3825                     context = SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_SET_VMA;
3826                     break;
3827                   case OPTION_CHANGE_SECTION_LMA:
3828                     context = SECTION_CONTEXT_SET_LMA;
3829                     break;
3830                   case OPTION_CHANGE_SECTION_VMA:
3831                     context = SECTION_CONTEXT_SET_VMA;
3832                     break;
3833                   }
3834               }
3835
3836             len = s - optarg;
3837             name = (char *) xmalloc (len + 1);
3838             strncpy (name, optarg, len);
3839             name[len] = '\0';
3840
3841             p = find_section_list (name, TRUE, context);
3842
3843             val = parse_vma (s + 1, option);
3844             if (*s == '-')
3845               val = - val;
3846
3847             switch (c)
3848               {
3849               case OPTION_CHANGE_SECTION_ADDRESS:
3850                 p->vma_val = val;
3851                 /* Drop through.  */
3852
3853               case OPTION_CHANGE_SECTION_LMA:
3854                 p->lma_val = val;
3855                 break;
3856
3857               case OPTION_CHANGE_SECTION_VMA:
3858                 p->vma_val = val;
3859                 break;
3860               }
3861           }
3862           break;
3863
3864         case OPTION_CHANGE_ADDRESSES:
3865           change_section_address = parse_vma (optarg, "--change-addresses");
3866           change_start = change_section_address;
3867           break;
3868
3869         case OPTION_CHANGE_WARNINGS:
3870           change_warn = TRUE;
3871           break;
3872
3873         case OPTION_CHANGE_LEADING_CHAR:
3874           change_leading_char = TRUE;
3875           break;
3876
3877         case OPTION_COMPRESS_DEBUG_SECTIONS:
3878           do_debug_sections = compress;
3879           break;
3880
3881         case OPTION_DEBUGGING:
3882           convert_debugging = TRUE;
3883           break;
3884
3885         case OPTION_DECOMPRESS_DEBUG_SECTIONS:
3886           do_debug_sections = decompress;
3887           break;
3888
3889         case OPTION_GAP_FILL:
3890           {
3891             bfd_vma gap_fill_vma;
3892
3893             gap_fill_vma = parse_vma (optarg, "--gap-fill");
3894             gap_fill = (bfd_byte) gap_fill_vma;
3895             if ((bfd_vma) gap_fill != gap_fill_vma)
3896               {
3897                 char buff[20];
3898
3899                 sprintf_vma (buff, gap_fill_vma);
3900
3901                 non_fatal (_("Warning: truncating gap-fill from 0x%s to 0x%x"),
3902                            buff, gap_fill);
3903               }
3904             gap_fill_set = TRUE;
3905           }
3906           break;
3907
3908         case OPTION_NO_CHANGE_WARNINGS:
3909           change_warn = FALSE;
3910           break;
3911
3912         case OPTION_PAD_TO:
3913           pad_to = parse_vma (optarg, "--pad-to");
3914           pad_to_set = TRUE;
3915           break;
3916
3917         case OPTION_REMOVE_LEADING_CHAR:
3918           remove_leading_char = TRUE;
3919           break;
3920
3921         case OPTION_REDEFINE_SYM:
3922           {
3923             /* Push this redefinition onto redefine_symbol_list.  */
3924
3925             int len;
3926             const char *s;
3927             const char *nextarg;
3928             char *source, *target;
3929
3930             s = strchr (optarg, '=');
3931             if (s == NULL)
3932               fatal (_("bad format for %s"), "--redefine-sym");
3933
3934             len = s - optarg;
3935             source = (char *) xmalloc (len + 1);
3936             strncpy (source, optarg, len);
3937             source[len] = '\0';
3938
3939             nextarg = s + 1;
3940             len = strlen (nextarg);
3941             target = (char *) xmalloc (len + 1);
3942             strcpy (target, nextarg);
3943
3944             redefine_list_append ("--redefine-sym", source, target);
3945
3946             free (source);
3947             free (target);
3948           }
3949           break;
3950
3951         case OPTION_REDEFINE_SYMS:
3952           add_redefine_syms_file (optarg);
3953           break;
3954
3955         case OPTION_SET_SECTION_FLAGS:
3956           {
3957             struct section_list *p;
3958             const char *s;
3959             int len;
3960             char *name;
3961
3962             s = strchr (optarg, '=');
3963             if (s == NULL)
3964               fatal (_("bad format for %s"), "--set-section-flags");
3965
3966             len = s - optarg;
3967             name = (char *) xmalloc (len + 1);
3968             strncpy (name, optarg, len);
3969             name[len] = '\0';
3970
3971             p = find_section_list (name, TRUE, SECTION_CONTEXT_SET_FLAGS);
3972
3973             p->flags = parse_flags (s + 1);
3974           }
3975           break;
3976
3977         case OPTION_RENAME_SECTION:
3978           {
3979             flagword flags;
3980             const char *eq, *fl;
3981             char *old_name;
3982             char *new_name;
3983             unsigned int len;
3984
3985             eq = strchr (optarg, '=');
3986             if (eq == NULL)
3987               fatal (_("bad format for %s"), "--rename-section");
3988
3989             len = eq - optarg;
3990             if (len == 0)
3991               fatal (_("bad format for %s"), "--rename-section");
3992
3993             old_name = (char *) xmalloc (len + 1);
3994             strncpy (old_name, optarg, len);
3995             old_name[len] = 0;
3996
3997             eq++;
3998             fl = strchr (eq, ',');
3999             if (fl)
4000               {
4001                 flags = parse_flags (fl + 1);
4002                 len = fl - eq;
4003               }
4004             else
4005               {
4006                 flags = -1;
4007                 len = strlen (eq);
4008               }
4009
4010             if (len == 0)
4011               fatal (_("bad format for %s"), "--rename-section");
4012
4013             new_name = (char *) xmalloc (len + 1);
4014             strncpy (new_name, eq, len);
4015             new_name[len] = 0;
4016
4017             add_section_rename (old_name, new_name, flags);
4018           }
4019           break;
4020
4021         case OPTION_SET_START:
4022           set_start = parse_vma (optarg, "--set-start");
4023           set_start_set = TRUE;
4024           break;
4025
4026         case OPTION_SREC_LEN:
4027           Chunk = parse_vma (optarg, "--srec-len");
4028           break;
4029
4030         case OPTION_SREC_FORCES3:
4031           S3Forced = TRUE;
4032           break;
4033
4034         case OPTION_STRIP_SYMBOLS:
4035           add_specific_symbols (optarg, strip_specific_htab);
4036           break;
4037
4038         case OPTION_STRIP_UNNEEDED_SYMBOLS:
4039           add_specific_symbols (optarg, strip_unneeded_htab);
4040           break;
4041
4042         case OPTION_KEEP_SYMBOLS:
4043           add_specific_symbols (optarg, keep_specific_htab);
4044           break;
4045
4046         case OPTION_LOCALIZE_HIDDEN:
4047           localize_hidden = TRUE;
4048           break;
4049
4050         case OPTION_LOCALIZE_SYMBOLS:
4051           add_specific_symbols (optarg, localize_specific_htab);
4052           break;
4053
4054         case OPTION_LONG_SECTION_NAMES:
4055           if (!strcmp ("enable", optarg))
4056             long_section_names = ENABLE;
4057           else if (!strcmp ("disable", optarg))
4058             long_section_names = DISABLE;
4059           else if (!strcmp ("keep", optarg))
4060             long_section_names = KEEP;
4061           else
4062             fatal (_("unknown long section names option '%s'"), optarg);
4063           break;
4064
4065         case OPTION_GLOBALIZE_SYMBOLS:
4066           add_specific_symbols (optarg, globalize_specific_htab);
4067           break;
4068
4069         case OPTION_KEEPGLOBAL_SYMBOLS:
4070           add_specific_symbols (optarg, keepglobal_specific_htab);
4071           break;
4072
4073         case OPTION_WEAKEN_SYMBOLS:
4074           add_specific_symbols (optarg, weaken_specific_htab);
4075           break;
4076
4077         case OPTION_ALT_MACH_CODE:
4078           use_alt_mach_code = strtoul (optarg, NULL, 0);
4079           if (use_alt_mach_code == 0)
4080             fatal (_("unable to parse alternative machine code"));
4081           break;
4082
4083         case OPTION_PREFIX_SYMBOLS:
4084           prefix_symbols_string = optarg;
4085           break;
4086
4087         case OPTION_PREFIX_SECTIONS:
4088           prefix_sections_string = optarg;
4089           break;
4090
4091         case OPTION_PREFIX_ALLOC_SECTIONS:
4092           prefix_alloc_sections_string = optarg;
4093           break;
4094
4095         case OPTION_READONLY_TEXT:
4096           bfd_flags_to_set |= WP_TEXT;
4097           bfd_flags_to_clear &= ~WP_TEXT;
4098           break;
4099
4100         case OPTION_WRITABLE_TEXT:
4101           bfd_flags_to_clear |= WP_TEXT;
4102           bfd_flags_to_set &= ~WP_TEXT;
4103           break;
4104
4105         case OPTION_PURE:
4106           bfd_flags_to_set |= D_PAGED;
4107           bfd_flags_to_clear &= ~D_PAGED;
4108           break;
4109
4110         case OPTION_IMPURE:
4111           bfd_flags_to_clear |= D_PAGED;
4112           bfd_flags_to_set &= ~D_PAGED;
4113           break;
4114
4115         case OPTION_EXTRACT_DWO:
4116           strip_symbols = STRIP_NONDWO;
4117           break;
4118
4119         case OPTION_EXTRACT_SYMBOL:
4120           extract_symbol = TRUE;
4121           break;
4122
4123         case OPTION_REVERSE_BYTES:
4124           {
4125             int prev = reverse_bytes;
4126
4127             reverse_bytes = atoi (optarg);
4128             if ((reverse_bytes <= 0) || ((reverse_bytes % 2) != 0))
4129               fatal (_("number of bytes to reverse must be positive and even"));
4130
4131             if (prev && prev != reverse_bytes)
4132               non_fatal (_("Warning: ignoring previous --reverse-bytes value of %d"),
4133                          prev);
4134             break;
4135           }
4136
4137         case OPTION_FILE_ALIGNMENT:
4138           pe_file_alignment = parse_vma (optarg, "--file-alignment");
4139           break;
4140
4141         case OPTION_HEAP:
4142             {
4143               char *end;
4144               pe_heap_reserve = strtoul (optarg, &end, 0);
4145               if (end == optarg
4146                   || (*end != '.' && *end != '\0'))
4147                 non_fatal (_("%s: invalid reserve value for --heap"),
4148                            optarg);
4149               else if (*end != '\0')
4150                 {
4151                   pe_heap_commit = strtoul (end + 1, &end, 0);
4152                   if (*end != '\0')
4153                     non_fatal (_("%s: invalid commit value for --heap"),
4154                                optarg);
4155                 }
4156             }
4157           break;
4158
4159         case OPTION_IMAGE_BASE:
4160           pe_image_base = parse_vma (optarg, "--image-base");
4161           break;
4162
4163         case OPTION_SECTION_ALIGNMENT:
4164           pe_section_alignment = parse_vma (optarg,
4165                                             "--section-alignment");
4166           break;
4167
4168         case OPTION_SUBSYSTEM:
4169           set_pe_subsystem (optarg);
4170           break;
4171
4172         case OPTION_STACK:
4173             {
4174               char *end;
4175               pe_stack_reserve = strtoul (optarg, &end, 0);
4176               if (end == optarg
4177                   || (*end != '.' && *end != '\0'))
4178                 non_fatal (_("%s: invalid reserve value for --stack"),
4179                            optarg);
4180               else if (*end != '\0')
4181                 {
4182                   pe_stack_commit = strtoul (end + 1, &end, 0);
4183                   if (*end != '\0')
4184                     non_fatal (_("%s: invalid commit value for --stack"),
4185                                optarg);
4186                 }
4187             }
4188           break;
4189
4190         case 0:
4191           /* We've been given a long option.  */
4192           break;
4193
4194         case 'H':
4195         case 'h':
4196           copy_usage (stdout, 0);
4197
4198         default:
4199           copy_usage (stderr, 1);
4200         }
4201     }
4202
4203   if (formats_info)
4204     {
4205       display_info ();
4206       return 0;
4207     }
4208
4209   if (show_version)
4210     print_version ("objcopy");
4211
4212   if (interleave && copy_byte == -1)
4213     fatal (_("interleave start byte must be set with --byte"));
4214
4215   if (copy_byte >= interleave)
4216     fatal (_("byte number must be less than interleave"));
4217
4218   if (copy_width > interleave - copy_byte)
4219     fatal (_("interleave width must be less than or equal to interleave - byte`"));
4220
4221   if (optind == argc || optind + 2 < argc)
4222     copy_usage (stderr, 1);
4223
4224   input_filename = argv[optind];
4225   if (optind + 1 < argc)
4226     output_filename = argv[optind + 1];
4227
4228   default_deterministic ();
4229
4230   /* Default is to strip no symbols.  */
4231   if (strip_symbols == STRIP_UNDEF && discard_locals == LOCALS_UNDEF)
4232     strip_symbols = STRIP_NONE;
4233
4234   if (output_target == NULL)
4235     output_target = input_target;
4236
4237   /* Convert input EFI target to PEI target.  */
4238   if (input_target != NULL
4239       && strncmp (input_target, "efi-", 4) == 0)
4240     {
4241       char *efi;
4242
4243       efi = xstrdup (output_target + 4);
4244       if (strncmp (efi, "bsdrv-", 6) == 0
4245           || strncmp (efi, "rtdrv-", 6) == 0)
4246         efi += 2;
4247       else if (strncmp (efi, "app-", 4) != 0)
4248         fatal (_("unknown input EFI target: %s"), input_target);
4249
4250       input_target = efi;
4251       convert_efi_target (efi);
4252     }
4253
4254   /* Convert output EFI target to PEI target.  */
4255   if (output_target != NULL
4256       && strncmp (output_target, "efi-", 4) == 0)
4257     {
4258       char *efi;
4259
4260       efi = xstrdup (output_target + 4);
4261       if (strncmp (efi, "app-", 4) == 0)
4262         {
4263           if (pe_subsystem == -1)
4264             pe_subsystem = IMAGE_SUBSYSTEM_EFI_APPLICATION;
4265         }
4266       else if (strncmp (efi, "bsdrv-", 6) == 0)
4267         {
4268           if (pe_subsystem == -1)
4269             pe_subsystem = IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER;
4270           efi += 2;
4271         }
4272       else if (strncmp (efi, "rtdrv-", 6) == 0)
4273         {
4274           if (pe_subsystem == -1)
4275             pe_subsystem = IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER;
4276           efi += 2;
4277         }
4278       else
4279         fatal (_("unknown output EFI target: %s"), output_target);
4280
4281       if (pe_file_alignment == (bfd_vma) -1)
4282         pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
4283       if (pe_section_alignment == (bfd_vma) -1)
4284         pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
4285
4286       output_target = efi;
4287       convert_efi_target (efi);
4288     }
4289
4290   if (preserve_dates)
4291     if (stat (input_filename, & statbuf) < 0)
4292       fatal (_("warning: could not locate '%s'.  System error message: %s"),
4293              input_filename, strerror (errno));
4294
4295   /* If there is no destination file, or the source and destination files
4296      are the same, then create a temp and rename the result into the input.  */
4297   if (output_filename == NULL
4298       || filename_cmp (input_filename, output_filename) == 0)
4299     tmpname = make_tempname (input_filename);
4300   else
4301     tmpname = output_filename;
4302
4303   if (tmpname == NULL)
4304     fatal (_("warning: could not create temporary file whilst copying '%s', (error: %s)"),
4305            input_filename, strerror (errno));
4306
4307   copy_file (input_filename, tmpname, input_target, output_target, input_arch);
4308   if (status == 0)
4309     {
4310       if (preserve_dates)
4311         set_times (tmpname, &statbuf);
4312       if (tmpname != output_filename)
4313         status = (smart_rename (tmpname, input_filename,
4314                                 preserve_dates) != 0);
4315     }
4316   else
4317     unlink_if_ordinary (tmpname);
4318
4319   if (change_warn)
4320     {
4321       struct section_list *p;
4322
4323       for (p = change_sections; p != NULL; p = p->next)
4324         {
4325           if (! p->used)
4326             {
4327               if (p->context & (SECTION_CONTEXT_SET_VMA | SECTION_CONTEXT_ALTER_VMA))
4328                 {
4329                   char buff [20];
4330
4331                   sprintf_vma (buff, p->vma_val);
4332
4333                   /* xgettext:c-format */
4334                   non_fatal (_("%s %s%c0x%s never used"),
4335                              "--change-section-vma",
4336                              p->pattern,
4337                              p->context & SECTION_CONTEXT_SET_VMA ? '=' : '+',
4338                              buff);
4339                 }
4340
4341               if (p->context & (SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_ALTER_LMA))
4342                 {
4343                   char buff [20];
4344
4345                   sprintf_vma (buff, p->lma_val);
4346
4347                   /* xgettext:c-format */
4348                   non_fatal (_("%s %s%c0x%s never used"),
4349                              "--change-section-lma",
4350                              p->pattern,
4351                              p->context & SECTION_CONTEXT_SET_LMA ? '=' : '+',
4352                              buff);
4353                 }
4354             }
4355         }
4356     }
4357
4358   return 0;
4359 }
4360
4361 int
4362 main (int argc, char *argv[])
4363 {
4364 #if defined (HAVE_SETLOCALE) && defined (HAVE_LC_MESSAGES)
4365   setlocale (LC_MESSAGES, "");
4366 #endif
4367 #if defined (HAVE_SETLOCALE)
4368   setlocale (LC_CTYPE, "");
4369 #endif
4370   bindtextdomain (PACKAGE, LOCALEDIR);
4371   textdomain (PACKAGE);
4372
4373   program_name = argv[0];
4374   xmalloc_set_program_name (program_name);
4375
4376   START_PROGRESS (program_name, 0);
4377
4378   expandargv (&argc, &argv);
4379
4380   strip_symbols = STRIP_UNDEF;
4381   discard_locals = LOCALS_UNDEF;
4382
4383   bfd_init ();
4384   set_default_bfd_target ();
4385
4386   if (is_strip < 0)
4387     {
4388       int i = strlen (program_name);
4389 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
4390       /* Drop the .exe suffix, if any.  */
4391       if (i > 4 && FILENAME_CMP (program_name + i - 4, ".exe") == 0)
4392         {
4393           i -= 4;
4394           program_name[i] = '\0';
4395         }
4396 #endif
4397       is_strip = (i >= 5 && FILENAME_CMP (program_name + i - 5, "strip") == 0);
4398     }
4399
4400   create_symbol_htabs ();
4401
4402   if (is_strip)
4403     strip_main (argc, argv);
4404   else
4405     copy_main (argc, argv);
4406
4407   END_PROGRESS (program_name);
4408
4409   return status;
4410 }