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