9bad4b70f2c07f4fcaa8cfc8925ebd22cce88671
[deliverable/binutils-gdb.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;
2189
2190 for (rel = relpp; rel < relpp + relcount; rel ++)
2191 if ((* rel)->howto == NULL)
2192 {
2193 /* Delete eliminated relocs.
2194 FIXME: There are better ways to do this. */
2195 memmove (rel, rel + 1, ((relcount - (rel - relpp)) - 1) * sizeof (* rel));
2196 relcount --;
2197 }
2198 bfd_set_reloc (abfd, sec, relpp, relcount);
2199 }
2200 }
2201
2202 done:
2203 if (err)
2204 {
2205 bfd_set_error (bfd_error_bad_value);
2206 bfd_nonfatal_message (NULL, abfd, sec, err);
2207 status = 1;
2208 }
2209
2210 free (pnotes);
2211 return size;
2212 }
2213
2214 /* Copy object file IBFD onto OBFD.
2215 Returns TRUE upon success, FALSE otherwise. */
2216
2217 static bfd_boolean
2218 copy_object (bfd *ibfd, bfd *obfd, const bfd_arch_info_type *input_arch)
2219 {
2220 bfd_vma start;
2221 long symcount;
2222 asection **osections = NULL;
2223 asection *osec;
2224 asection *gnu_debuglink_section = NULL;
2225 bfd_size_type *gaps = NULL;
2226 bfd_size_type max_gap = 0;
2227 long symsize;
2228 void *dhandle;
2229 enum bfd_architecture iarch;
2230 unsigned int imach;
2231 unsigned int c, i;
2232
2233 if (ibfd->xvec->byteorder != obfd->xvec->byteorder
2234 && ibfd->xvec->byteorder != BFD_ENDIAN_UNKNOWN
2235 && obfd->xvec->byteorder != BFD_ENDIAN_UNKNOWN)
2236 {
2237 /* PR 17636: Call non-fatal so that we return to our parent who
2238 may need to tidy temporary files. */
2239 non_fatal (_("Unable to change endianness of input file(s)"));
2240 return FALSE;
2241 }
2242
2243 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
2244 {
2245 bfd_nonfatal_message (NULL, obfd, NULL, NULL);
2246 return FALSE;
2247 }
2248
2249 if (ibfd->sections == NULL)
2250 {
2251 non_fatal (_("error: the input file '%s' has no sections"),
2252 bfd_get_archive_filename (ibfd));
2253 return FALSE;
2254 }
2255
2256 if (ibfd->xvec->flavour != bfd_target_elf_flavour)
2257 {
2258 if ((do_debug_sections & compress) != 0
2259 && do_debug_sections != compress)
2260 {
2261 non_fatal (_("--compress-debug-sections=[zlib|zlib-gnu|zlib-gabi] is unsupported on `%s'"),
2262 bfd_get_archive_filename (ibfd));
2263 return FALSE;
2264 }
2265
2266 if (do_elf_stt_common)
2267 {
2268 non_fatal (_("--elf-stt-common=[yes|no] is unsupported on `%s'"),
2269 bfd_get_archive_filename (ibfd));
2270 return FALSE;
2271 }
2272 }
2273
2274 if (verbose)
2275 printf (_("copy from `%s' [%s] to `%s' [%s]\n"),
2276 bfd_get_archive_filename (ibfd), bfd_get_target (ibfd),
2277 bfd_get_filename (obfd), bfd_get_target (obfd));
2278
2279 if (extract_symbol)
2280 start = 0;
2281 else
2282 {
2283 if (set_start_set)
2284 start = set_start;
2285 else
2286 start = bfd_get_start_address (ibfd);
2287 start += change_start;
2288 }
2289
2290 /* Neither the start address nor the flags
2291 need to be set for a core file. */
2292 if (bfd_get_format (obfd) != bfd_core)
2293 {
2294 flagword flags;
2295
2296 flags = bfd_get_file_flags (ibfd);
2297 flags |= bfd_flags_to_set;
2298 flags &= ~bfd_flags_to_clear;
2299 flags &= bfd_applicable_file_flags (obfd);
2300
2301 if (strip_symbols == STRIP_ALL)
2302 flags &= ~HAS_RELOC;
2303
2304 if (!bfd_set_start_address (obfd, start)
2305 || !bfd_set_file_flags (obfd, flags))
2306 {
2307 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
2308 return FALSE;
2309 }
2310 }
2311
2312 /* Copy architecture of input file to output file. */
2313 iarch = bfd_get_arch (ibfd);
2314 imach = bfd_get_mach (ibfd);
2315 if (input_arch)
2316 {
2317 if (bfd_get_arch_info (ibfd) == NULL
2318 || bfd_get_arch_info (ibfd)->arch == bfd_arch_unknown)
2319 {
2320 iarch = input_arch->arch;
2321 imach = input_arch->mach;
2322 }
2323 else
2324 non_fatal (_("Input file `%s' ignores binary architecture parameter."),
2325 bfd_get_archive_filename (ibfd));
2326 }
2327 if (!bfd_set_arch_mach (obfd, iarch, imach)
2328 && (ibfd->target_defaulted
2329 || bfd_get_arch (ibfd) != bfd_get_arch (obfd)))
2330 {
2331 if (bfd_get_arch (ibfd) == bfd_arch_unknown)
2332 non_fatal (_("Unable to recognise the format of the input file `%s'"),
2333 bfd_get_archive_filename (ibfd));
2334 else
2335 non_fatal (_("Output file cannot represent architecture `%s'"),
2336 bfd_printable_arch_mach (bfd_get_arch (ibfd),
2337 bfd_get_mach (ibfd)));
2338 return FALSE;
2339 }
2340
2341 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
2342 {
2343 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
2344 return FALSE;
2345 }
2346
2347 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour
2348 && bfd_pei_p (obfd))
2349 {
2350 /* Set up PE parameters. */
2351 pe_data_type *pe = pe_data (obfd);
2352
2353 /* Copy PE parameters before changing them. */
2354 if (ibfd->xvec->flavour == bfd_target_coff_flavour
2355 && bfd_pei_p (ibfd))
2356 pe->pe_opthdr = pe_data (ibfd)->pe_opthdr;
2357
2358 if (pe_file_alignment != (bfd_vma) -1)
2359 pe->pe_opthdr.FileAlignment = pe_file_alignment;
2360 else
2361 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
2362
2363 if (pe_heap_commit != (bfd_vma) -1)
2364 pe->pe_opthdr.SizeOfHeapCommit = pe_heap_commit;
2365
2366 if (pe_heap_reserve != (bfd_vma) -1)
2367 pe->pe_opthdr.SizeOfHeapCommit = pe_heap_reserve;
2368
2369 if (pe_image_base != (bfd_vma) -1)
2370 pe->pe_opthdr.ImageBase = pe_image_base;
2371
2372 if (pe_section_alignment != (bfd_vma) -1)
2373 pe->pe_opthdr.SectionAlignment = pe_section_alignment;
2374 else
2375 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
2376
2377 if (pe_stack_commit != (bfd_vma) -1)
2378 pe->pe_opthdr.SizeOfStackCommit = pe_stack_commit;
2379
2380 if (pe_stack_reserve != (bfd_vma) -1)
2381 pe->pe_opthdr.SizeOfStackCommit = pe_stack_reserve;
2382
2383 if (pe_subsystem != -1)
2384 pe->pe_opthdr.Subsystem = pe_subsystem;
2385
2386 if (pe_major_subsystem_version != -1)
2387 pe->pe_opthdr.MajorSubsystemVersion = pe_major_subsystem_version;
2388
2389 if (pe_minor_subsystem_version != -1)
2390 pe->pe_opthdr.MinorSubsystemVersion = pe_minor_subsystem_version;
2391
2392 if (pe_file_alignment > pe_section_alignment)
2393 {
2394 char file_alignment[20], section_alignment[20];
2395
2396 sprintf_vma (file_alignment, pe_file_alignment);
2397 sprintf_vma (section_alignment, pe_section_alignment);
2398 non_fatal (_("warning: file alignment (0x%s) > section alignment (0x%s)"),
2399
2400 file_alignment, section_alignment);
2401 }
2402 }
2403
2404 if (isympp)
2405 free (isympp);
2406
2407 if (osympp != isympp)
2408 free (osympp);
2409
2410 isympp = NULL;
2411 osympp = NULL;
2412
2413 symsize = bfd_get_symtab_upper_bound (ibfd);
2414 if (symsize < 0)
2415 {
2416 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
2417 return FALSE;
2418 }
2419
2420 osympp = isympp = (asymbol **) xmalloc (symsize);
2421 symcount = bfd_canonicalize_symtab (ibfd, isympp);
2422 if (symcount < 0)
2423 {
2424 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
2425 return FALSE;
2426 }
2427 /* PR 17512: file: d6323821
2428 If the symbol table could not be loaded do not pretend that we have
2429 any symbols. This trips us up later on when we load the relocs. */
2430 if (symcount == 0)
2431 {
2432 free (isympp);
2433 osympp = isympp = NULL;
2434 }
2435
2436 /* BFD mandates that all output sections be created and sizes set before
2437 any output is done. Thus, we traverse all sections multiple times. */
2438 bfd_map_over_sections (ibfd, setup_section, obfd);
2439
2440 if (!extract_symbol)
2441 setup_bfd_headers (ibfd, obfd);
2442
2443 if (add_sections != NULL)
2444 {
2445 struct section_add *padd;
2446 struct section_list *pset;
2447
2448 for (padd = add_sections; padd != NULL; padd = padd->next)
2449 {
2450 flagword flags;
2451
2452 pset = find_section_list (padd->name, FALSE,
2453 SECTION_CONTEXT_SET_FLAGS);
2454 if (pset != NULL)
2455 flags = pset->flags | SEC_HAS_CONTENTS;
2456 else
2457 flags = SEC_HAS_CONTENTS | SEC_READONLY | SEC_DATA;
2458
2459 /* bfd_make_section_with_flags() does not return very helpful
2460 error codes, so check for the most likely user error first. */
2461 if (bfd_get_section_by_name (obfd, padd->name))
2462 {
2463 bfd_nonfatal_message (NULL, obfd, NULL,
2464 _("can't add section '%s'"), padd->name);
2465 return FALSE;
2466 }
2467 else
2468 {
2469 /* We use LINKER_CREATED here so that the backend hooks
2470 will create any special section type information,
2471 instead of presuming we know what we're doing merely
2472 because we set the flags. */
2473 padd->section = bfd_make_section_with_flags
2474 (obfd, padd->name, flags | SEC_LINKER_CREATED);
2475 if (padd->section == NULL)
2476 {
2477 bfd_nonfatal_message (NULL, obfd, NULL,
2478 _("can't create section `%s'"),
2479 padd->name);
2480 return FALSE;
2481 }
2482 }
2483
2484 if (! bfd_set_section_size (obfd, padd->section, padd->size))
2485 {
2486 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
2487 return FALSE;
2488 }
2489
2490 pset = find_section_list (padd->name, FALSE,
2491 SECTION_CONTEXT_SET_VMA | SECTION_CONTEXT_ALTER_VMA);
2492 if (pset != NULL
2493 && ! bfd_set_section_vma (obfd, padd->section, pset->vma_val))
2494 {
2495 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
2496 return FALSE;
2497 }
2498
2499 pset = find_section_list (padd->name, FALSE,
2500 SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_ALTER_LMA);
2501 if (pset != NULL)
2502 {
2503 padd->section->lma = pset->lma_val;
2504
2505 if (! bfd_set_section_alignment
2506 (obfd, padd->section,
2507 bfd_section_alignment (obfd, padd->section)))
2508 {
2509 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
2510 return FALSE;
2511 }
2512 }
2513 }
2514 }
2515
2516 if (update_sections != NULL)
2517 {
2518 struct section_add *pupdate;
2519
2520 for (pupdate = update_sections;
2521 pupdate != NULL;
2522 pupdate = pupdate->next)
2523 {
2524 pupdate->section = bfd_get_section_by_name (ibfd, pupdate->name);
2525 if (pupdate->section == NULL)
2526 {
2527 non_fatal (_("error: %s not found, can't be updated"), pupdate->name);
2528 return FALSE;
2529 }
2530
2531 osec = pupdate->section->output_section;
2532 if (! bfd_set_section_size (obfd, osec, pupdate->size))
2533 {
2534 bfd_nonfatal_message (NULL, obfd, osec, NULL);
2535 return FALSE;
2536 }
2537 }
2538 }
2539
2540 if (merge_notes)
2541 {
2542 /* This palaver is necessary because we must set the output
2543 section size first, before its contents are ready. */
2544 osec = bfd_get_section_by_name (ibfd, GNU_BUILD_ATTRS_SECTION_NAME);
2545 if (osec && is_merged_note_section (ibfd, osec))
2546 {
2547 bfd_size_type size;
2548
2549 size = bfd_get_section_size (osec);
2550 if (size == 0)
2551 {
2552 bfd_nonfatal_message (NULL, ibfd, osec, _("warning: note section is empty"));
2553 merge_notes = FALSE;
2554 }
2555 else if (! bfd_get_full_section_contents (ibfd, osec, & merged_notes))
2556 {
2557 bfd_nonfatal_message (NULL, ibfd, osec, _("warning: could not load note section"));
2558 free (merged_notes);
2559 merged_notes = NULL;
2560 merge_notes = FALSE;
2561 }
2562 else
2563 {
2564 merged_size = merge_gnu_build_notes (ibfd, osec, size, merged_notes);
2565 if (merged_size == size)
2566 {
2567 /* Merging achieves nothing. */
2568 free (merged_notes);
2569 merged_notes = NULL;
2570 merge_notes = FALSE;
2571 merged_size = 0;
2572 }
2573 else
2574 {
2575 if (osec->output_section == NULL
2576 || ! bfd_set_section_size (obfd, osec->output_section, merged_size))
2577 {
2578 bfd_nonfatal_message (NULL, obfd, osec, _("warning: failed to set merged notes size"));
2579 free (merged_notes);
2580 merged_notes = NULL;
2581 merge_notes = FALSE;
2582 merged_size = 0;
2583 }
2584 }
2585 }
2586 }
2587 }
2588
2589 if (dump_sections != NULL)
2590 {
2591 struct section_add * pdump;
2592
2593 for (pdump = dump_sections; pdump != NULL; pdump = pdump->next)
2594 {
2595 osec = bfd_get_section_by_name (ibfd, pdump->name);
2596 if (osec == NULL)
2597 {
2598 bfd_nonfatal_message (NULL, ibfd, NULL,
2599 _("can't dump section '%s' - it does not exist"),
2600 pdump->name);
2601 continue;
2602 }
2603
2604 if ((bfd_get_section_flags (ibfd, osec) & SEC_HAS_CONTENTS) == 0)
2605 {
2606 bfd_nonfatal_message (NULL, ibfd, osec,
2607 _("can't dump section - it has no contents"));
2608 continue;
2609 }
2610
2611 bfd_size_type size = bfd_get_section_size (osec);
2612 if (size == 0)
2613 {
2614 bfd_nonfatal_message (NULL, ibfd, osec,
2615 _("can't dump section - it is empty"));
2616 continue;
2617 }
2618
2619 FILE * f;
2620 f = fopen (pdump->filename, FOPEN_WB);
2621 if (f == NULL)
2622 {
2623 bfd_nonfatal_message (pdump->filename, NULL, NULL,
2624 _("could not open section dump file"));
2625 continue;
2626 }
2627
2628 bfd_byte * contents = xmalloc (size);
2629 if (bfd_get_section_contents (ibfd, osec, contents, 0, size))
2630 {
2631 if (fwrite (contents, 1, size, f) != size)
2632 {
2633 non_fatal (_("error writing section contents to %s (error: %s)"),
2634 pdump->filename,
2635 strerror (errno));
2636 return FALSE;
2637 }
2638 }
2639 else
2640 bfd_nonfatal_message (NULL, ibfd, osec,
2641 _("could not retrieve section contents"));
2642
2643 fclose (f);
2644 free (contents);
2645 }
2646 }
2647
2648 if (gnu_debuglink_filename != NULL)
2649 {
2650 /* PR 15125: Give a helpful warning message if
2651 the debuglink section already exists, and
2652 allow the rest of the copy to complete. */
2653 if (bfd_get_section_by_name (obfd, ".gnu_debuglink"))
2654 {
2655 non_fatal (_("%s: debuglink section already exists"),
2656 bfd_get_filename (obfd));
2657 gnu_debuglink_filename = NULL;
2658 }
2659 else
2660 {
2661 gnu_debuglink_section = bfd_create_gnu_debuglink_section
2662 (obfd, gnu_debuglink_filename);
2663
2664 if (gnu_debuglink_section == NULL)
2665 {
2666 bfd_nonfatal_message (NULL, obfd, NULL,
2667 _("cannot create debug link section `%s'"),
2668 gnu_debuglink_filename);
2669 return FALSE;
2670 }
2671
2672 /* Special processing for PE format files. We
2673 have no way to distinguish PE from COFF here. */
2674 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour)
2675 {
2676 bfd_vma debuglink_vma;
2677 asection * highest_section;
2678
2679 /* The PE spec requires that all sections be adjacent and sorted
2680 in ascending order of VMA. It also specifies that debug
2681 sections should be last. This is despite the fact that debug
2682 sections are not loaded into memory and so in theory have no
2683 use for a VMA.
2684
2685 This means that the debuglink section must be given a non-zero
2686 VMA which makes it contiguous with other debug sections. So
2687 walk the current section list, find the section with the
2688 highest VMA and start the debuglink section after that one. */
2689 for (osec = obfd->sections, highest_section = NULL;
2690 osec != NULL;
2691 osec = osec->next)
2692 if (osec->vma > 0
2693 && (highest_section == NULL
2694 || osec->vma > highest_section->vma))
2695 highest_section = osec;
2696
2697 if (highest_section)
2698 debuglink_vma = BFD_ALIGN (highest_section->vma
2699 + highest_section->size,
2700 /* FIXME: We ought to be using
2701 COFF_PAGE_SIZE here or maybe
2702 bfd_get_section_alignment() (if it
2703 was set) but since this is for PE
2704 and we know the required alignment
2705 it is easier just to hard code it. */
2706 0x1000);
2707 else
2708 /* Umm, not sure what to do in this case. */
2709 debuglink_vma = 0x1000;
2710
2711 bfd_set_section_vma (obfd, gnu_debuglink_section, debuglink_vma);
2712 }
2713 }
2714 }
2715
2716 c = bfd_count_sections (obfd);
2717 if (c != 0
2718 && (gap_fill_set || pad_to_set))
2719 {
2720 asection **set;
2721
2722 /* We must fill in gaps between the sections and/or we must pad
2723 the last section to a specified address. We do this by
2724 grabbing a list of the sections, sorting them by VMA, and
2725 increasing the section sizes as required to fill the gaps.
2726 We write out the gap contents below. */
2727
2728 osections = (asection **) xmalloc (c * sizeof (asection *));
2729 set = osections;
2730 bfd_map_over_sections (obfd, get_sections, &set);
2731
2732 qsort (osections, c, sizeof (asection *), compare_section_lma);
2733
2734 gaps = (bfd_size_type *) xmalloc (c * sizeof (bfd_size_type));
2735 memset (gaps, 0, c * sizeof (bfd_size_type));
2736
2737 if (gap_fill_set)
2738 {
2739 for (i = 0; i < c - 1; i++)
2740 {
2741 flagword flags;
2742 bfd_size_type size;
2743 bfd_vma gap_start, gap_stop;
2744
2745 flags = bfd_get_section_flags (obfd, osections[i]);
2746 if ((flags & SEC_HAS_CONTENTS) == 0
2747 || (flags & SEC_LOAD) == 0)
2748 continue;
2749
2750 size = bfd_section_size (obfd, osections[i]);
2751 gap_start = bfd_section_lma (obfd, osections[i]) + size;
2752 gap_stop = bfd_section_lma (obfd, osections[i + 1]);
2753 if (gap_start < gap_stop)
2754 {
2755 if (! bfd_set_section_size (obfd, osections[i],
2756 size + (gap_stop - gap_start)))
2757 {
2758 bfd_nonfatal_message (NULL, obfd, osections[i],
2759 _("Can't fill gap after section"));
2760 status = 1;
2761 break;
2762 }
2763 gaps[i] = gap_stop - gap_start;
2764 if (max_gap < gap_stop - gap_start)
2765 max_gap = gap_stop - gap_start;
2766 }
2767 }
2768 }
2769
2770 if (pad_to_set)
2771 {
2772 bfd_vma lma;
2773 bfd_size_type size;
2774
2775 lma = bfd_section_lma (obfd, osections[c - 1]);
2776 size = bfd_section_size (obfd, osections[c - 1]);
2777 if (lma + size < pad_to)
2778 {
2779 if (! bfd_set_section_size (obfd, osections[c - 1],
2780 pad_to - lma))
2781 {
2782 bfd_nonfatal_message (NULL, obfd, osections[c - 1],
2783 _("can't add padding"));
2784 status = 1;
2785 }
2786 else
2787 {
2788 gaps[c - 1] = pad_to - (lma + size);
2789 if (max_gap < pad_to - (lma + size))
2790 max_gap = pad_to - (lma + size);
2791 }
2792 }
2793 }
2794 }
2795
2796 /* Symbol filtering must happen after the output sections
2797 have been created, but before their contents are set. */
2798 dhandle = NULL;
2799 if (convert_debugging)
2800 dhandle = read_debugging_info (ibfd, isympp, symcount, FALSE);
2801
2802 if (strip_symbols == STRIP_DEBUG
2803 || strip_symbols == STRIP_ALL
2804 || strip_symbols == STRIP_UNNEEDED
2805 || strip_symbols == STRIP_NONDEBUG
2806 || strip_symbols == STRIP_DWO
2807 || strip_symbols == STRIP_NONDWO
2808 || discard_locals != LOCALS_UNDEF
2809 || localize_hidden
2810 || htab_elements (strip_specific_htab) != 0
2811 || htab_elements (keep_specific_htab) != 0
2812 || htab_elements (localize_specific_htab) != 0
2813 || htab_elements (globalize_specific_htab) != 0
2814 || htab_elements (keepglobal_specific_htab) != 0
2815 || htab_elements (weaken_specific_htab) != 0
2816 || htab_elements (redefine_specific_htab) != 0
2817 || prefix_symbols_string
2818 || sections_removed
2819 || sections_copied
2820 || convert_debugging
2821 || change_leading_char
2822 || remove_leading_char
2823 || section_rename_list
2824 || weaken
2825 || add_symbols)
2826 {
2827 /* Mark symbols used in output relocations so that they
2828 are kept, even if they are local labels or static symbols.
2829
2830 Note we iterate over the input sections examining their
2831 relocations since the relocations for the output sections
2832 haven't been set yet. mark_symbols_used_in_relocations will
2833 ignore input sections which have no corresponding output
2834 section. */
2835 if (strip_symbols != STRIP_ALL)
2836 bfd_map_over_sections (ibfd,
2837 mark_symbols_used_in_relocations,
2838 isympp);
2839 osympp = (asymbol **) xmalloc ((symcount + add_symbols + 1) * sizeof (asymbol *));
2840 symcount = filter_symbols (ibfd, obfd, osympp, isympp, symcount);
2841 }
2842
2843 if (convert_debugging && dhandle != NULL)
2844 {
2845 if (! write_debugging_info (obfd, dhandle, &symcount, &osympp))
2846 {
2847 status = 1;
2848 return FALSE;
2849 }
2850 }
2851
2852 bfd_set_symtab (obfd, osympp, symcount);
2853
2854 /* This has to happen before section positions are set. */
2855 bfd_map_over_sections (ibfd, copy_relocations_in_section, obfd);
2856
2857 /* This has to happen after the symbol table has been set. */
2858 bfd_map_over_sections (ibfd, copy_section, obfd);
2859
2860 if (add_sections != NULL)
2861 {
2862 struct section_add *padd;
2863
2864 for (padd = add_sections; padd != NULL; padd = padd->next)
2865 {
2866 if (! bfd_set_section_contents (obfd, padd->section, padd->contents,
2867 0, padd->size))
2868 {
2869 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
2870 return FALSE;
2871 }
2872 }
2873 }
2874
2875 if (update_sections != NULL)
2876 {
2877 struct section_add *pupdate;
2878
2879 for (pupdate = update_sections;
2880 pupdate != NULL;
2881 pupdate = pupdate->next)
2882 {
2883 osec = pupdate->section->output_section;
2884 if (! bfd_set_section_contents (obfd, osec, pupdate->contents,
2885 0, pupdate->size))
2886 {
2887 bfd_nonfatal_message (NULL, obfd, osec, NULL);
2888 return FALSE;
2889 }
2890 }
2891 }
2892
2893 if (merge_notes)
2894 {
2895 osec = bfd_get_section_by_name (obfd, GNU_BUILD_ATTRS_SECTION_NAME);
2896 if (osec && is_merged_note_section (obfd, osec))
2897 {
2898 if (! bfd_set_section_contents (obfd, osec, merged_notes, 0, merged_size))
2899 {
2900 bfd_nonfatal_message (NULL, obfd, osec, _("error: failed to copy merged notes into output"));
2901 return FALSE;
2902 }
2903 }
2904 else if (! is_strip)
2905 bfd_nonfatal_message (NULL, obfd, osec, _("could not find any mergeable note sections"));
2906 free (merged_notes);
2907 merged_notes = NULL;
2908 merge_notes = FALSE;
2909 }
2910
2911 if (gnu_debuglink_filename != NULL)
2912 {
2913 if (! bfd_fill_in_gnu_debuglink_section
2914 (obfd, gnu_debuglink_section, gnu_debuglink_filename))
2915 {
2916 bfd_nonfatal_message (NULL, obfd, NULL,
2917 _("cannot fill debug link section `%s'"),
2918 gnu_debuglink_filename);
2919 return FALSE;
2920 }
2921 }
2922
2923 if (gap_fill_set || pad_to_set)
2924 {
2925 bfd_byte *buf;
2926
2927 /* Fill in the gaps. */
2928 if (max_gap > 8192)
2929 max_gap = 8192;
2930 buf = (bfd_byte *) xmalloc (max_gap);
2931 memset (buf, gap_fill, max_gap);
2932
2933 c = bfd_count_sections (obfd);
2934 for (i = 0; i < c; i++)
2935 {
2936 if (gaps[i] != 0)
2937 {
2938 bfd_size_type left;
2939 file_ptr off;
2940
2941 left = gaps[i];
2942 off = bfd_section_size (obfd, osections[i]) - left;
2943
2944 while (left > 0)
2945 {
2946 bfd_size_type now;
2947
2948 if (left > 8192)
2949 now = 8192;
2950 else
2951 now = left;
2952
2953 if (! bfd_set_section_contents (obfd, osections[i], buf,
2954 off, now))
2955 {
2956 bfd_nonfatal_message (NULL, obfd, osections[i], NULL);
2957 return FALSE;
2958 }
2959
2960 left -= now;
2961 off += now;
2962 }
2963 }
2964 }
2965 }
2966
2967 /* Allow the BFD backend to copy any private data it understands
2968 from the input BFD to the output BFD. This is done last to
2969 permit the routine to look at the filtered symbol table, which is
2970 important for the ECOFF code at least. */
2971 if (! bfd_copy_private_bfd_data (ibfd, obfd))
2972 {
2973 bfd_nonfatal_message (NULL, obfd, NULL,
2974 _("error copying private BFD data"));
2975 return FALSE;
2976 }
2977
2978 /* Switch to the alternate machine code. We have to do this at the
2979 very end, because we only initialize the header when we create
2980 the first section. */
2981 if (use_alt_mach_code != 0)
2982 {
2983 if (! bfd_alt_mach_code (obfd, use_alt_mach_code))
2984 {
2985 non_fatal (_("this target does not support %lu alternative machine codes"),
2986 use_alt_mach_code);
2987 if (bfd_get_flavour (obfd) == bfd_target_elf_flavour)
2988 {
2989 non_fatal (_("treating that number as an absolute e_machine value instead"));
2990 elf_elfheader (obfd)->e_machine = use_alt_mach_code;
2991 }
2992 else
2993 non_fatal (_("ignoring the alternative value"));
2994 }
2995 }
2996
2997 return TRUE;
2998 }
2999
3000 /* Read each archive element in turn from IBFD, copy the
3001 contents to temp file, and keep the temp file handle.
3002 If 'force_output_target' is TRUE then make sure that
3003 all elements in the new archive are of the type
3004 'output_target'. */
3005
3006 static void
3007 copy_archive (bfd *ibfd, bfd *obfd, const char *output_target,
3008 bfd_boolean force_output_target,
3009 const bfd_arch_info_type *input_arch)
3010 {
3011 struct name_list
3012 {
3013 struct name_list *next;
3014 const char *name;
3015 bfd *obfd;
3016 } *list, *l;
3017 bfd **ptr = &obfd->archive_head;
3018 bfd *this_element;
3019 char *dir;
3020 const char *filename;
3021
3022 /* Make a temp directory to hold the contents. */
3023 dir = make_tempdir (bfd_get_filename (obfd));
3024 if (dir == NULL)
3025 fatal (_("cannot create tempdir for archive copying (error: %s)"),
3026 strerror (errno));
3027
3028 if (strip_symbols == STRIP_ALL)
3029 obfd->has_armap = FALSE;
3030 else
3031 obfd->has_armap = ibfd->has_armap;
3032 obfd->is_thin_archive = ibfd->is_thin_archive;
3033
3034 if (deterministic)
3035 obfd->flags |= BFD_DETERMINISTIC_OUTPUT;
3036
3037 list = NULL;
3038
3039 this_element = bfd_openr_next_archived_file (ibfd, NULL);
3040
3041 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
3042 {
3043 status = 1;
3044 bfd_nonfatal_message (NULL, obfd, NULL, NULL);
3045 goto cleanup_and_exit;
3046 }
3047
3048 while (!status && this_element != NULL)
3049 {
3050 char *output_name;
3051 bfd *output_bfd;
3052 bfd *last_element;
3053 struct stat buf;
3054 int stat_status = 0;
3055 bfd_boolean del = TRUE;
3056 bfd_boolean ok_object;
3057
3058 /* PR binutils/17533: Do not allow directory traversal
3059 outside of the current directory tree by archive members. */
3060 if (! is_valid_archive_path (bfd_get_filename (this_element)))
3061 {
3062 non_fatal (_("illegal pathname found in archive member: %s"),
3063 bfd_get_filename (this_element));
3064 status = 1;
3065 goto cleanup_and_exit;
3066 }
3067
3068 /* Create an output file for this member. */
3069 output_name = concat (dir, "/",
3070 bfd_get_filename (this_element), (char *) 0);
3071
3072 /* If the file already exists, make another temp dir. */
3073 if (stat (output_name, &buf) >= 0)
3074 {
3075 output_name = make_tempdir (output_name);
3076 if (output_name == NULL)
3077 {
3078 non_fatal (_("cannot create tempdir for archive copying (error: %s)"),
3079 strerror (errno));
3080 status = 1;
3081 goto cleanup_and_exit;
3082 }
3083
3084 l = (struct name_list *) xmalloc (sizeof (struct name_list));
3085 l->name = output_name;
3086 l->next = list;
3087 l->obfd = NULL;
3088 list = l;
3089 output_name = concat (output_name, "/",
3090 bfd_get_filename (this_element), (char *) 0);
3091 }
3092
3093 if (preserve_dates)
3094 {
3095 stat_status = bfd_stat_arch_elt (this_element, &buf);
3096
3097 if (stat_status != 0)
3098 non_fatal (_("internal stat error on %s"),
3099 bfd_get_filename (this_element));
3100 }
3101
3102 l = (struct name_list *) xmalloc (sizeof (struct name_list));
3103 l->name = output_name;
3104 l->next = list;
3105 l->obfd = NULL;
3106 list = l;
3107
3108 ok_object = bfd_check_format (this_element, bfd_object);
3109 if (!ok_object)
3110 bfd_nonfatal_message (NULL, this_element, NULL,
3111 _("Unable to recognise the format of file"));
3112
3113 /* PR binutils/3110: Cope with archives
3114 containing multiple target types. */
3115 if (force_output_target || !ok_object)
3116 output_bfd = bfd_openw (output_name, output_target);
3117 else
3118 output_bfd = bfd_openw (output_name, bfd_get_target (this_element));
3119
3120 if (output_bfd == NULL)
3121 {
3122 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
3123 status = 1;
3124 goto cleanup_and_exit;
3125 }
3126
3127 if (ok_object)
3128 {
3129 del = !copy_object (this_element, output_bfd, input_arch);
3130
3131 if (del && bfd_get_arch (this_element) == bfd_arch_unknown)
3132 /* Try again as an unknown object file. */
3133 ok_object = FALSE;
3134 else if (!bfd_close (output_bfd))
3135 {
3136 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
3137 /* Error in new object file. Don't change archive. */
3138 status = 1;
3139 }
3140 }
3141
3142 if (!ok_object)
3143 {
3144 del = !copy_unknown_object (this_element, output_bfd);
3145 if (!bfd_close_all_done (output_bfd))
3146 {
3147 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
3148 /* Error in new object file. Don't change archive. */
3149 status = 1;
3150 }
3151 }
3152
3153 if (del)
3154 {
3155 unlink (output_name);
3156 status = 1;
3157 }
3158 else
3159 {
3160 if (preserve_dates && stat_status == 0)
3161 set_times (output_name, &buf);
3162
3163 /* Open the newly output file and attach to our list. */
3164 output_bfd = bfd_openr (output_name, output_target);
3165
3166 l->obfd = output_bfd;
3167
3168 *ptr = output_bfd;
3169 ptr = &output_bfd->archive_next;
3170
3171 last_element = this_element;
3172
3173 this_element = bfd_openr_next_archived_file (ibfd, last_element);
3174
3175 bfd_close (last_element);
3176 }
3177 }
3178 *ptr = NULL;
3179
3180 filename = bfd_get_filename (obfd);
3181 if (!bfd_close (obfd))
3182 {
3183 status = 1;
3184 bfd_nonfatal_message (filename, NULL, NULL, NULL);
3185 }
3186
3187 filename = bfd_get_filename (ibfd);
3188 if (!bfd_close (ibfd))
3189 {
3190 status = 1;
3191 bfd_nonfatal_message (filename, NULL, NULL, NULL);
3192 }
3193
3194 cleanup_and_exit:
3195 /* Delete all the files that we opened. */
3196 for (l = list; l != NULL; l = l->next)
3197 {
3198 if (l->obfd == NULL)
3199 rmdir (l->name);
3200 else
3201 {
3202 bfd_close (l->obfd);
3203 unlink (l->name);
3204 }
3205 }
3206
3207 rmdir (dir);
3208 }
3209
3210 static void
3211 set_long_section_mode (bfd *output_bfd, bfd *input_bfd, enum long_section_name_handling style)
3212 {
3213 /* This is only relevant to Coff targets. */
3214 if (bfd_get_flavour (output_bfd) == bfd_target_coff_flavour)
3215 {
3216 if (style == KEEP
3217 && bfd_get_flavour (input_bfd) == bfd_target_coff_flavour)
3218 style = bfd_coff_long_section_names (input_bfd) ? ENABLE : DISABLE;
3219 bfd_coff_set_long_section_names (output_bfd, style != DISABLE);
3220 }
3221 }
3222
3223 /* The top-level control. */
3224
3225 static void
3226 copy_file (const char *input_filename, const char *output_filename,
3227 const char *input_target, const char *output_target,
3228 const bfd_arch_info_type *input_arch)
3229 {
3230 bfd *ibfd;
3231 char **obj_matching;
3232 char **core_matching;
3233 off_t size = get_file_size (input_filename);
3234
3235 if (size < 1)
3236 {
3237 if (size == 0)
3238 non_fatal (_("error: the input file '%s' is empty"),
3239 input_filename);
3240 status = 1;
3241 return;
3242 }
3243
3244 /* To allow us to do "strip *" without dying on the first
3245 non-object file, failures are nonfatal. */
3246 ibfd = bfd_openr (input_filename, input_target);
3247 if (ibfd == NULL)
3248 {
3249 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
3250 status = 1;
3251 return;
3252 }
3253
3254 switch (do_debug_sections)
3255 {
3256 case compress:
3257 case compress_zlib:
3258 case compress_gnu_zlib:
3259 case compress_gabi_zlib:
3260 ibfd->flags |= BFD_COMPRESS;
3261 /* Don't check if input is ELF here since this information is
3262 only available after bfd_check_format_matches is called. */
3263 if (do_debug_sections != compress_gnu_zlib)
3264 ibfd->flags |= BFD_COMPRESS_GABI;
3265 break;
3266 case decompress:
3267 ibfd->flags |= BFD_DECOMPRESS;
3268 break;
3269 default:
3270 break;
3271 }
3272
3273 switch (do_elf_stt_common)
3274 {
3275 case elf_stt_common:
3276 ibfd->flags |= BFD_CONVERT_ELF_COMMON | BFD_USE_ELF_STT_COMMON;
3277 break;
3278 break;
3279 case no_elf_stt_common:
3280 ibfd->flags |= BFD_CONVERT_ELF_COMMON;
3281 break;
3282 default:
3283 break;
3284 }
3285
3286 if (bfd_check_format (ibfd, bfd_archive))
3287 {
3288 bfd_boolean force_output_target;
3289 bfd *obfd;
3290
3291 /* bfd_get_target does not return the correct value until
3292 bfd_check_format succeeds. */
3293 if (output_target == NULL)
3294 {
3295 output_target = bfd_get_target (ibfd);
3296 force_output_target = FALSE;
3297 }
3298 else
3299 force_output_target = TRUE;
3300
3301 obfd = bfd_openw (output_filename, output_target);
3302 if (obfd == NULL)
3303 {
3304 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
3305 status = 1;
3306 return;
3307 }
3308 /* This is a no-op on non-Coff targets. */
3309 set_long_section_mode (obfd, ibfd, long_section_names);
3310
3311 copy_archive (ibfd, obfd, output_target, force_output_target, input_arch);
3312 }
3313 else if (bfd_check_format_matches (ibfd, bfd_object, &obj_matching))
3314 {
3315 bfd *obfd;
3316 do_copy:
3317
3318 /* bfd_get_target does not return the correct value until
3319 bfd_check_format succeeds. */
3320 if (output_target == NULL)
3321 output_target = bfd_get_target (ibfd);
3322
3323 obfd = bfd_openw (output_filename, output_target);
3324 if (obfd == NULL)
3325 {
3326 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
3327 status = 1;
3328 return;
3329 }
3330 /* This is a no-op on non-Coff targets. */
3331 set_long_section_mode (obfd, ibfd, long_section_names);
3332
3333 if (! copy_object (ibfd, obfd, input_arch))
3334 status = 1;
3335
3336 /* PR 17512: file: 0f15796a.
3337 If the file could not be copied it may not be in a writeable
3338 state. So use bfd_close_all_done to avoid the possibility of
3339 writing uninitialised data into the file. */
3340 if (! (status ? bfd_close_all_done (obfd) : bfd_close (obfd)))
3341 {
3342 status = 1;
3343 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
3344 return;
3345 }
3346
3347 if (!bfd_close (ibfd))
3348 {
3349 status = 1;
3350 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
3351 return;
3352 }
3353 }
3354 else
3355 {
3356 bfd_error_type obj_error = bfd_get_error ();
3357 bfd_error_type core_error;
3358
3359 if (bfd_check_format_matches (ibfd, bfd_core, &core_matching))
3360 {
3361 /* This probably can't happen.. */
3362 if (obj_error == bfd_error_file_ambiguously_recognized)
3363 free (obj_matching);
3364 goto do_copy;
3365 }
3366
3367 core_error = bfd_get_error ();
3368 /* Report the object error in preference to the core error. */
3369 if (obj_error != core_error)
3370 bfd_set_error (obj_error);
3371
3372 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
3373
3374 if (obj_error == bfd_error_file_ambiguously_recognized)
3375 {
3376 list_matching_formats (obj_matching);
3377 free (obj_matching);
3378 }
3379 if (core_error == bfd_error_file_ambiguously_recognized)
3380 {
3381 list_matching_formats (core_matching);
3382 free (core_matching);
3383 }
3384
3385 status = 1;
3386 }
3387 }
3388
3389 /* Add a name to the section renaming list. */
3390
3391 static void
3392 add_section_rename (const char * old_name, const char * new_name,
3393 flagword flags)
3394 {
3395 section_rename * srename;
3396
3397 /* Check for conflicts first. */
3398 for (srename = section_rename_list; srename != NULL; srename = srename->next)
3399 if (strcmp (srename->old_name, old_name) == 0)
3400 {
3401 /* Silently ignore duplicate definitions. */
3402 if (strcmp (srename->new_name, new_name) == 0
3403 && srename->flags == flags)
3404 return;
3405
3406 fatal (_("Multiple renames of section %s"), old_name);
3407 }
3408
3409 srename = (section_rename *) xmalloc (sizeof (* srename));
3410
3411 srename->old_name = old_name;
3412 srename->new_name = new_name;
3413 srename->flags = flags;
3414 srename->next = section_rename_list;
3415
3416 section_rename_list = srename;
3417 }
3418
3419 /* Check the section rename list for a new name of the input section
3420 called OLD_NAME. Returns the new name if one is found and sets
3421 RETURNED_FLAGS if non-NULL to the flags to be used for this section. */
3422
3423 static const char *
3424 find_section_rename (const char *old_name, flagword *returned_flags)
3425 {
3426 const section_rename *srename;
3427
3428 for (srename = section_rename_list; srename != NULL; srename = srename->next)
3429 if (strcmp (srename->old_name, old_name) == 0)
3430 {
3431 if (returned_flags != NULL && srename->flags != (flagword) -1)
3432 *returned_flags = srename->flags;
3433
3434 return srename->new_name;
3435 }
3436
3437 return old_name;
3438 }
3439
3440 /* Once each of the sections is copied, we may still need to do some
3441 finalization work for private section headers. Do that here. */
3442
3443 static void
3444 setup_bfd_headers (bfd *ibfd, bfd *obfd)
3445 {
3446 /* Allow the BFD backend to copy any private data it understands
3447 from the input section to the output section. */
3448 if (! bfd_copy_private_header_data (ibfd, obfd))
3449 {
3450 status = 1;
3451 bfd_nonfatal_message (NULL, ibfd, NULL,
3452 _("error in private header data"));
3453 return;
3454 }
3455
3456 /* All went well. */
3457 return;
3458 }
3459
3460 /* Create a section in OBFD with the same
3461 name and attributes as ISECTION in IBFD. */
3462
3463 static void
3464 setup_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
3465 {
3466 bfd *obfd = (bfd *) obfdarg;
3467 struct section_list *p;
3468 sec_ptr osection;
3469 bfd_size_type size;
3470 bfd_vma vma;
3471 bfd_vma lma;
3472 flagword flags;
3473 const char *err;
3474 const char * name;
3475 char *prefix = NULL;
3476 bfd_boolean make_nobits;
3477
3478 if (is_strip_section (ibfd, isection))
3479 return;
3480
3481 /* Get the, possibly new, name of the output section. */
3482 name = bfd_section_name (ibfd, isection);
3483 flags = bfd_get_section_flags (ibfd, isection);
3484 name = find_section_rename (name, &flags);
3485
3486 /* Prefix sections. */
3487 if ((prefix_alloc_sections_string)
3488 && (bfd_get_section_flags (ibfd, isection) & SEC_ALLOC))
3489 prefix = prefix_alloc_sections_string;
3490 else if (prefix_sections_string)
3491 prefix = prefix_sections_string;
3492
3493 if (prefix)
3494 {
3495 char *n;
3496
3497 n = (char *) xmalloc (strlen (prefix) + strlen (name) + 1);
3498 strcpy (n, prefix);
3499 strcat (n, name);
3500 name = n;
3501 }
3502
3503 make_nobits = FALSE;
3504
3505 p = find_section_list (bfd_section_name (ibfd, isection), FALSE,
3506 SECTION_CONTEXT_SET_FLAGS);
3507 if (p != NULL)
3508 flags = p->flags | (flags & (SEC_HAS_CONTENTS | SEC_RELOC));
3509 else if (strip_symbols == STRIP_NONDEBUG
3510 && (flags & (SEC_ALLOC | SEC_GROUP)) != 0
3511 && !is_nondebug_keep_contents_section (ibfd, isection))
3512 {
3513 flags &= ~(SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP);
3514 if (obfd->xvec->flavour == bfd_target_elf_flavour)
3515 {
3516 make_nobits = TRUE;
3517
3518 /* Twiddle the input section flags so that it seems to
3519 elf.c:copy_private_bfd_data that section flags have not
3520 changed between input and output sections. This hack
3521 prevents wholesale rewriting of the program headers. */
3522 isection->flags &= ~(SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP);
3523 }
3524 }
3525
3526 osection = bfd_make_section_anyway_with_flags (obfd, name, flags);
3527
3528 if (osection == NULL)
3529 {
3530 err = _("failed to create output section");
3531 goto loser;
3532 }
3533
3534 if (make_nobits)
3535 elf_section_type (osection) = SHT_NOBITS;
3536
3537 size = bfd_section_size (ibfd, isection);
3538 size = bfd_convert_section_size (ibfd, isection, obfd, size);
3539 if (copy_byte >= 0)
3540 size = (size + interleave - 1) / interleave * copy_width;
3541 else if (extract_symbol)
3542 size = 0;
3543 if (! bfd_set_section_size (obfd, osection, size))
3544 {
3545 err = _("failed to set size");
3546 goto loser;
3547 }
3548
3549 vma = bfd_section_vma (ibfd, isection);
3550 p = find_section_list (bfd_section_name (ibfd, isection), FALSE,
3551 SECTION_CONTEXT_ALTER_VMA | SECTION_CONTEXT_SET_VMA);
3552 if (p != NULL)
3553 {
3554 if (p->context & SECTION_CONTEXT_SET_VMA)
3555 vma = p->vma_val;
3556 else
3557 vma += p->vma_val;
3558 }
3559 else
3560 vma += change_section_address;
3561
3562 if (! bfd_set_section_vma (obfd, osection, vma))
3563 {
3564 err = _("failed to set vma");
3565 goto loser;
3566 }
3567
3568 lma = isection->lma;
3569 p = find_section_list (bfd_section_name (ibfd, isection), FALSE,
3570 SECTION_CONTEXT_ALTER_LMA | SECTION_CONTEXT_SET_LMA);
3571 if (p != NULL)
3572 {
3573 if (p->context & SECTION_CONTEXT_ALTER_LMA)
3574 lma += p->lma_val;
3575 else
3576 lma = p->lma_val;
3577 }
3578 else
3579 lma += change_section_address;
3580
3581 osection->lma = lma;
3582
3583 /* FIXME: This is probably not enough. If we change the LMA we
3584 may have to recompute the header for the file as well. */
3585 if (!bfd_set_section_alignment (obfd,
3586 osection,
3587 bfd_section_alignment (ibfd, isection)))
3588 {
3589 err = _("failed to set alignment");
3590 goto loser;
3591 }
3592
3593 /* Copy merge entity size. */
3594 osection->entsize = isection->entsize;
3595
3596 /* Copy compress status. */
3597 osection->compress_status = isection->compress_status;
3598
3599 /* This used to be mangle_section; we do here to avoid using
3600 bfd_get_section_by_name since some formats allow multiple
3601 sections with the same name. */
3602 isection->output_section = osection;
3603 isection->output_offset = 0;
3604
3605 if ((isection->flags & SEC_GROUP) != 0)
3606 {
3607 asymbol *gsym = group_signature (isection);
3608
3609 if (gsym != NULL)
3610 {
3611 gsym->flags |= BSF_KEEP;
3612 if (ibfd->xvec->flavour == bfd_target_elf_flavour)
3613 elf_group_id (isection) = gsym;
3614 }
3615 }
3616
3617 /* Allow the BFD backend to copy any private data it understands
3618 from the input section to the output section. */
3619 if (!bfd_copy_private_section_data (ibfd, isection, obfd, osection))
3620 {
3621 err = _("failed to copy private data");
3622 goto loser;
3623 }
3624
3625 /* All went well. */
3626 return;
3627
3628 loser:
3629 status = 1;
3630 bfd_nonfatal_message (NULL, obfd, osection, err);
3631 }
3632
3633 /* Return TRUE if input section ISECTION should be skipped. */
3634
3635 static bfd_boolean
3636 skip_section (bfd *ibfd, sec_ptr isection, bfd_boolean skip_copy)
3637 {
3638 sec_ptr osection;
3639 bfd_size_type size;
3640 flagword flags;
3641
3642 /* If we have already failed earlier on,
3643 do not keep on generating complaints now. */
3644 if (status != 0)
3645 return TRUE;
3646
3647 if (extract_symbol)
3648 return TRUE;
3649
3650 if (is_strip_section (ibfd, isection))
3651 return TRUE;
3652
3653 if (is_update_section (ibfd, isection))
3654 return TRUE;
3655
3656 /* When merging a note section we skip the copying of the contents,
3657 but not the copying of the relocs associated with the contents. */
3658 if (skip_copy && is_merged_note_section (ibfd, isection))
3659 return TRUE;
3660
3661 flags = bfd_get_section_flags (ibfd, isection);
3662 if ((flags & SEC_GROUP) != 0)
3663 return TRUE;
3664
3665 osection = isection->output_section;
3666 size = bfd_get_section_size (isection);
3667
3668 if (size == 0 || osection == 0)
3669 return TRUE;
3670
3671 return FALSE;
3672 }
3673
3674 /* Add section SECTION_PATTERN to the list of sections that will have their
3675 relocations removed. */
3676
3677 static void
3678 handle_remove_relocations_option (const char *section_pattern)
3679 {
3680 find_section_list (section_pattern, TRUE, SECTION_CONTEXT_REMOVE_RELOCS);
3681 }
3682
3683 /* Return TRUE if ISECTION from IBFD should have its relocations removed,
3684 otherwise return FALSE. If the user has requested that relocations be
3685 removed from a section that does not have relocations then this
3686 function will still return TRUE. */
3687
3688 static bfd_boolean
3689 discard_relocations (bfd *ibfd ATTRIBUTE_UNUSED, asection *isection)
3690 {
3691 return (find_section_list (bfd_section_name (ibfd, isection), FALSE,
3692 SECTION_CONTEXT_REMOVE_RELOCS) != NULL);
3693 }
3694
3695 /* Wrapper for dealing with --remove-section (-R) command line arguments.
3696 A special case is detected here, if the user asks to remove a relocation
3697 section (one starting with ".rela." or ".rel.") then this removal must
3698 be done using a different technique. */
3699
3700 static void
3701 handle_remove_section_option (const char *section_pattern)
3702 {
3703 if (strncmp (section_pattern, ".rela.", 6) == 0)
3704 handle_remove_relocations_option (section_pattern + 5);
3705 else if (strncmp (section_pattern, ".rel.", 5) == 0)
3706 handle_remove_relocations_option (section_pattern + 4);
3707 else
3708 {
3709 find_section_list (section_pattern, TRUE, SECTION_CONTEXT_REMOVE);
3710 sections_removed = TRUE;
3711 }
3712 }
3713
3714 /* Copy relocations in input section ISECTION of IBFD to an output
3715 section with the same name in OBFDARG. If stripping then don't
3716 copy any relocation info. */
3717
3718 static void
3719 copy_relocations_in_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
3720 {
3721 bfd *obfd = (bfd *) obfdarg;
3722 long relsize;
3723 arelent **relpp;
3724 long relcount;
3725 sec_ptr osection;
3726
3727 if (skip_section (ibfd, isection, FALSE))
3728 return;
3729
3730 osection = isection->output_section;
3731
3732 /* Core files and DWO files do not need to be relocated. */
3733 if (bfd_get_format (obfd) == bfd_core
3734 || strip_symbols == STRIP_NONDWO
3735 || discard_relocations (ibfd, isection))
3736 relsize = 0;
3737 else
3738 {
3739 relsize = bfd_get_reloc_upper_bound (ibfd, isection);
3740
3741 if (relsize < 0)
3742 {
3743 /* Do not complain if the target does not support relocations. */
3744 if (relsize == -1 && bfd_get_error () == bfd_error_invalid_operation)
3745 relsize = 0;
3746 else
3747 {
3748 status = 1;
3749 bfd_nonfatal_message (NULL, ibfd, isection, NULL);
3750 return;
3751 }
3752 }
3753 }
3754
3755 if (relsize == 0)
3756 {
3757 bfd_set_reloc (obfd, osection, NULL, 0);
3758 osection->flags &= ~SEC_RELOC;
3759 }
3760 else
3761 {
3762 relpp = (arelent **) xmalloc (relsize);
3763 relcount = bfd_canonicalize_reloc (ibfd, isection, relpp, isympp);
3764 if (relcount < 0)
3765 {
3766 status = 1;
3767 bfd_nonfatal_message (NULL, ibfd, isection,
3768 _("relocation count is negative"));
3769 return;
3770 }
3771
3772 if (strip_symbols == STRIP_ALL)
3773 {
3774 /* Remove relocations which are not in
3775 keep_strip_specific_list. */
3776 arelent **temp_relpp;
3777 long temp_relcount = 0;
3778 long i;
3779
3780 temp_relpp = (arelent **) xmalloc (relsize);
3781 for (i = 0; i < relcount; i++)
3782 {
3783 /* PR 17512: file: 9e907e0c. */
3784 if (relpp[i]->sym_ptr_ptr
3785 /* PR 20096 */
3786 && * relpp[i]->sym_ptr_ptr)
3787 if (is_specified_symbol (bfd_asymbol_name (*relpp[i]->sym_ptr_ptr),
3788 keep_specific_htab))
3789 temp_relpp [temp_relcount++] = relpp [i];
3790 }
3791 relcount = temp_relcount;
3792 free (relpp);
3793 relpp = temp_relpp;
3794 }
3795
3796 bfd_set_reloc (obfd, osection, relcount == 0 ? NULL : relpp, relcount);
3797 if (relcount == 0)
3798 {
3799 osection->flags &= ~SEC_RELOC;
3800 free (relpp);
3801 }
3802 }
3803 }
3804
3805 /* Copy the data of input section ISECTION of IBFD
3806 to an output section with the same name in OBFD. */
3807
3808 static void
3809 copy_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
3810 {
3811 bfd *obfd = (bfd *) obfdarg;
3812 struct section_list *p;
3813 sec_ptr osection;
3814 bfd_size_type size;
3815
3816 if (skip_section (ibfd, isection, TRUE))
3817 return;
3818
3819 osection = isection->output_section;
3820 /* The output SHF_COMPRESSED section size is different from input if
3821 ELF classes of input and output aren't the same. We can't use
3822 the output section size since --interleave will shrink the output
3823 section. Size will be updated if the section is converted. */
3824 size = bfd_get_section_size (isection);
3825
3826 if (bfd_get_section_flags (ibfd, isection) & SEC_HAS_CONTENTS
3827 && bfd_get_section_flags (obfd, osection) & SEC_HAS_CONTENTS)
3828 {
3829 bfd_byte *memhunk = NULL;
3830
3831 if (!bfd_get_full_section_contents (ibfd, isection, &memhunk)
3832 || !bfd_convert_section_contents (ibfd, isection, obfd,
3833 &memhunk, &size))
3834 {
3835 status = 1;
3836 bfd_nonfatal_message (NULL, ibfd, isection, NULL);
3837 free (memhunk);
3838 return;
3839 }
3840
3841 if (reverse_bytes)
3842 {
3843 /* We don't handle leftover bytes (too many possible behaviors,
3844 and we don't know what the user wants). The section length
3845 must be a multiple of the number of bytes to swap. */
3846 if ((size % reverse_bytes) == 0)
3847 {
3848 unsigned long i, j;
3849 bfd_byte b;
3850
3851 for (i = 0; i < size; i += reverse_bytes)
3852 for (j = 0; j < (unsigned long)(reverse_bytes / 2); j++)
3853 {
3854 bfd_byte *m = (bfd_byte *) memhunk;
3855
3856 b = m[i + j];
3857 m[i + j] = m[(i + reverse_bytes) - (j + 1)];
3858 m[(i + reverse_bytes) - (j + 1)] = b;
3859 }
3860 }
3861 else
3862 /* User must pad the section up in order to do this. */
3863 fatal (_("cannot reverse bytes: length of section %s must be evenly divisible by %d"),
3864 bfd_section_name (ibfd, isection), reverse_bytes);
3865 }
3866
3867 if (copy_byte >= 0)
3868 {
3869 /* Keep only every `copy_byte'th byte in MEMHUNK. */
3870 char *from = (char *) memhunk + copy_byte;
3871 char *to = (char *) memhunk;
3872 char *end = (char *) memhunk + size;
3873 int i;
3874
3875 for (; from < end; from += interleave)
3876 for (i = 0; i < copy_width; i++)
3877 {
3878 if (&from[i] >= end)
3879 break;
3880 *to++ = from[i];
3881 }
3882
3883 size = (size + interleave - 1 - copy_byte) / interleave * copy_width;
3884 osection->lma /= interleave;
3885 }
3886
3887 if (!bfd_set_section_contents (obfd, osection, memhunk, 0, size))
3888 {
3889 status = 1;
3890 bfd_nonfatal_message (NULL, obfd, osection, NULL);
3891 free (memhunk);
3892 return;
3893 }
3894 free (memhunk);
3895 }
3896 else if ((p = find_section_list (bfd_get_section_name (ibfd, isection),
3897 FALSE, SECTION_CONTEXT_SET_FLAGS)) != NULL
3898 && (p->flags & SEC_HAS_CONTENTS) != 0)
3899 {
3900 void *memhunk = xmalloc (size);
3901
3902 /* We don't permit the user to turn off the SEC_HAS_CONTENTS
3903 flag--they can just remove the section entirely and add it
3904 back again. However, we do permit them to turn on the
3905 SEC_HAS_CONTENTS flag, and take it to mean that the section
3906 contents should be zeroed out. */
3907
3908 memset (memhunk, 0, size);
3909 if (! bfd_set_section_contents (obfd, osection, memhunk, 0, size))
3910 {
3911 status = 1;
3912 bfd_nonfatal_message (NULL, obfd, osection, NULL);
3913 free (memhunk);
3914 return;
3915 }
3916 free (memhunk);
3917 }
3918 }
3919
3920 /* Get all the sections. This is used when --gap-fill or --pad-to is
3921 used. */
3922
3923 static void
3924 get_sections (bfd *obfd ATTRIBUTE_UNUSED, asection *osection, void *secppparg)
3925 {
3926 asection ***secppp = (asection ***) secppparg;
3927
3928 **secppp = osection;
3929 ++(*secppp);
3930 }
3931
3932 /* Sort sections by VMA. This is called via qsort, and is used when
3933 --gap-fill or --pad-to is used. We force non loadable or empty
3934 sections to the front, where they are easier to ignore. */
3935
3936 static int
3937 compare_section_lma (const void *arg1, const void *arg2)
3938 {
3939 const asection *const *sec1 = (const asection * const *) arg1;
3940 const asection *const *sec2 = (const asection * const *) arg2;
3941 flagword flags1, flags2;
3942
3943 /* Sort non loadable sections to the front. */
3944 flags1 = (*sec1)->flags;
3945 flags2 = (*sec2)->flags;
3946 if ((flags1 & SEC_HAS_CONTENTS) == 0
3947 || (flags1 & SEC_LOAD) == 0)
3948 {
3949 if ((flags2 & SEC_HAS_CONTENTS) != 0
3950 && (flags2 & SEC_LOAD) != 0)
3951 return -1;
3952 }
3953 else
3954 {
3955 if ((flags2 & SEC_HAS_CONTENTS) == 0
3956 || (flags2 & SEC_LOAD) == 0)
3957 return 1;
3958 }
3959
3960 /* Sort sections by LMA. */
3961 if ((*sec1)->lma > (*sec2)->lma)
3962 return 1;
3963 else if ((*sec1)->lma < (*sec2)->lma)
3964 return -1;
3965
3966 /* Sort sections with the same LMA by size. */
3967 if (bfd_get_section_size (*sec1) > bfd_get_section_size (*sec2))
3968 return 1;
3969 else if (bfd_get_section_size (*sec1) < bfd_get_section_size (*sec2))
3970 return -1;
3971
3972 return 0;
3973 }
3974
3975 /* Mark all the symbols which will be used in output relocations with
3976 the BSF_KEEP flag so that those symbols will not be stripped.
3977
3978 Ignore relocations which will not appear in the output file. */
3979
3980 static void
3981 mark_symbols_used_in_relocations (bfd *ibfd, sec_ptr isection, void *symbolsarg)
3982 {
3983 asymbol **symbols = (asymbol **) symbolsarg;
3984 long relsize;
3985 arelent **relpp;
3986 long relcount, i;
3987
3988 /* Ignore an input section with no corresponding output section. */
3989 if (isection->output_section == NULL)
3990 return;
3991
3992 relsize = bfd_get_reloc_upper_bound (ibfd, isection);
3993 if (relsize < 0)
3994 {
3995 /* Do not complain if the target does not support relocations. */
3996 if (relsize == -1 && bfd_get_error () == bfd_error_invalid_operation)
3997 return;
3998 bfd_fatal (bfd_get_filename (ibfd));
3999 }
4000
4001 if (relsize == 0)
4002 return;
4003
4004 relpp = (arelent **) xmalloc (relsize);
4005 relcount = bfd_canonicalize_reloc (ibfd, isection, relpp, symbols);
4006 if (relcount < 0)
4007 bfd_fatal (bfd_get_filename (ibfd));
4008
4009 /* Examine each symbol used in a relocation. If it's not one of the
4010 special bfd section symbols, then mark it with BSF_KEEP. */
4011 for (i = 0; i < relcount; i++)
4012 {
4013 /* See PRs 20923 and 20930 for reproducers for the NULL tests. */
4014 if (relpp[i]->sym_ptr_ptr != NULL
4015 && * relpp[i]->sym_ptr_ptr != NULL
4016 && *relpp[i]->sym_ptr_ptr != bfd_com_section_ptr->symbol
4017 && *relpp[i]->sym_ptr_ptr != bfd_abs_section_ptr->symbol
4018 && *relpp[i]->sym_ptr_ptr != bfd_und_section_ptr->symbol)
4019 (*relpp[i]->sym_ptr_ptr)->flags |= BSF_KEEP;
4020 }
4021
4022 if (relpp != NULL)
4023 free (relpp);
4024 }
4025
4026 /* Write out debugging information. */
4027
4028 static bfd_boolean
4029 write_debugging_info (bfd *obfd, void *dhandle,
4030 long *symcountp ATTRIBUTE_UNUSED,
4031 asymbol ***symppp ATTRIBUTE_UNUSED)
4032 {
4033 if (bfd_get_flavour (obfd) == bfd_target_ieee_flavour)
4034 return write_ieee_debugging_info (obfd, dhandle);
4035
4036 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour
4037 || bfd_get_flavour (obfd) == bfd_target_elf_flavour)
4038 {
4039 bfd_byte *syms, *strings;
4040 bfd_size_type symsize, stringsize;
4041 asection *stabsec, *stabstrsec;
4042 flagword flags;
4043
4044 if (! write_stabs_in_sections_debugging_info (obfd, dhandle, &syms,
4045 &symsize, &strings,
4046 &stringsize))
4047 return FALSE;
4048
4049 flags = SEC_HAS_CONTENTS | SEC_READONLY | SEC_DEBUGGING;
4050 stabsec = bfd_make_section_with_flags (obfd, ".stab", flags);
4051 stabstrsec = bfd_make_section_with_flags (obfd, ".stabstr", flags);
4052 if (stabsec == NULL
4053 || stabstrsec == NULL
4054 || ! bfd_set_section_size (obfd, stabsec, symsize)
4055 || ! bfd_set_section_size (obfd, stabstrsec, stringsize)
4056 || ! bfd_set_section_alignment (obfd, stabsec, 2)
4057 || ! bfd_set_section_alignment (obfd, stabstrsec, 0))
4058 {
4059 bfd_nonfatal_message (NULL, obfd, NULL,
4060 _("can't create debugging section"));
4061 return FALSE;
4062 }
4063
4064 /* We can get away with setting the section contents now because
4065 the next thing the caller is going to do is copy over the
4066 real sections. We may someday have to split the contents
4067 setting out of this function. */
4068 if (! bfd_set_section_contents (obfd, stabsec, syms, 0, symsize)
4069 || ! bfd_set_section_contents (obfd, stabstrsec, strings, 0,
4070 stringsize))
4071 {
4072 bfd_nonfatal_message (NULL, obfd, NULL,
4073 _("can't set debugging section contents"));
4074 return FALSE;
4075 }
4076
4077 return TRUE;
4078 }
4079
4080 bfd_nonfatal_message (NULL, obfd, NULL,
4081 _("don't know how to write debugging information for %s"),
4082 bfd_get_target (obfd));
4083 return FALSE;
4084 }
4085
4086 /* If neither -D nor -U was specified explicitly,
4087 then use the configured default. */
4088 static void
4089 default_deterministic (void)
4090 {
4091 if (deterministic < 0)
4092 deterministic = DEFAULT_AR_DETERMINISTIC;
4093 }
4094
4095 static int
4096 strip_main (int argc, char *argv[])
4097 {
4098 char *input_target = NULL;
4099 char *output_target = NULL;
4100 bfd_boolean show_version = FALSE;
4101 bfd_boolean formats_info = FALSE;
4102 int c;
4103 int i;
4104 char *output_file = NULL;
4105
4106 merge_notes = TRUE;
4107
4108 while ((c = getopt_long (argc, argv, "I:O:F:K:N:R:o:sSpdgxXHhVvwDU",
4109 strip_options, (int *) 0)) != EOF)
4110 {
4111 switch (c)
4112 {
4113 case 'I':
4114 input_target = optarg;
4115 break;
4116 case 'O':
4117 output_target = optarg;
4118 break;
4119 case 'F':
4120 input_target = output_target = optarg;
4121 break;
4122 case 'R':
4123 handle_remove_section_option (optarg);
4124 break;
4125 case OPTION_REMOVE_RELOCS:
4126 handle_remove_relocations_option (optarg);
4127 break;
4128 case 's':
4129 strip_symbols = STRIP_ALL;
4130 break;
4131 case 'S':
4132 case 'g':
4133 case 'd': /* Historic BSD alias for -g. Used by early NetBSD. */
4134 strip_symbols = STRIP_DEBUG;
4135 break;
4136 case OPTION_STRIP_DWO:
4137 strip_symbols = STRIP_DWO;
4138 break;
4139 case OPTION_STRIP_UNNEEDED:
4140 strip_symbols = STRIP_UNNEEDED;
4141 break;
4142 case 'K':
4143 add_specific_symbol (optarg, keep_specific_htab);
4144 break;
4145 case 'M':
4146 merge_notes = TRUE;
4147 break;
4148 case OPTION_NO_MERGE_NOTES:
4149 merge_notes = FALSE;
4150 break;
4151 case 'N':
4152 add_specific_symbol (optarg, strip_specific_htab);
4153 break;
4154 case 'o':
4155 output_file = optarg;
4156 break;
4157 case 'p':
4158 preserve_dates = TRUE;
4159 break;
4160 case 'D':
4161 deterministic = TRUE;
4162 break;
4163 case 'U':
4164 deterministic = FALSE;
4165 break;
4166 case 'x':
4167 discard_locals = LOCALS_ALL;
4168 break;
4169 case 'X':
4170 discard_locals = LOCALS_START_L;
4171 break;
4172 case 'v':
4173 verbose = TRUE;
4174 break;
4175 case 'V':
4176 show_version = TRUE;
4177 break;
4178 case OPTION_FORMATS_INFO:
4179 formats_info = TRUE;
4180 break;
4181 case OPTION_ONLY_KEEP_DEBUG:
4182 strip_symbols = STRIP_NONDEBUG;
4183 break;
4184 case OPTION_KEEP_FILE_SYMBOLS:
4185 keep_file_symbols = 1;
4186 break;
4187 case 0:
4188 /* We've been given a long option. */
4189 break;
4190 case 'w':
4191 wildcard = TRUE;
4192 break;
4193 case 'H':
4194 case 'h':
4195 strip_usage (stdout, 0);
4196 default:
4197 strip_usage (stderr, 1);
4198 }
4199 }
4200
4201 if (formats_info)
4202 {
4203 display_info ();
4204 return 0;
4205 }
4206
4207 if (show_version)
4208 print_version ("strip");
4209
4210 default_deterministic ();
4211
4212 /* Default is to strip all symbols. */
4213 if (strip_symbols == STRIP_UNDEF
4214 && discard_locals == LOCALS_UNDEF
4215 && htab_elements (strip_specific_htab) == 0)
4216 strip_symbols = STRIP_ALL;
4217
4218 if (output_target == NULL)
4219 output_target = input_target;
4220
4221 i = optind;
4222 if (i == argc
4223 || (output_file != NULL && (i + 1) < argc))
4224 strip_usage (stderr, 1);
4225
4226 for (; i < argc; i++)
4227 {
4228 int hold_status = status;
4229 struct stat statbuf;
4230 char *tmpname;
4231
4232 if (get_file_size (argv[i]) < 1)
4233 {
4234 status = 1;
4235 continue;
4236 }
4237
4238 if (preserve_dates)
4239 /* No need to check the return value of stat().
4240 It has already been checked in get_file_size(). */
4241 stat (argv[i], &statbuf);
4242
4243 if (output_file == NULL
4244 || filename_cmp (argv[i], output_file) == 0)
4245 tmpname = make_tempname (argv[i]);
4246 else
4247 tmpname = output_file;
4248
4249 if (tmpname == NULL)
4250 {
4251 bfd_nonfatal_message (argv[i], NULL, NULL,
4252 _("could not create temporary file to hold stripped copy"));
4253 status = 1;
4254 continue;
4255 }
4256
4257 status = 0;
4258 copy_file (argv[i], tmpname, input_target, output_target, NULL);
4259 if (status == 0)
4260 {
4261 if (preserve_dates)
4262 set_times (tmpname, &statbuf);
4263 if (output_file != tmpname)
4264 status = (smart_rename (tmpname,
4265 output_file ? output_file : argv[i],
4266 preserve_dates) != 0);
4267 if (status == 0)
4268 status = hold_status;
4269 }
4270 else
4271 unlink_if_ordinary (tmpname);
4272 if (output_file != tmpname)
4273 free (tmpname);
4274 }
4275
4276 return status;
4277 }
4278
4279 /* Set up PE subsystem. */
4280
4281 static void
4282 set_pe_subsystem (const char *s)
4283 {
4284 const char *version, *subsystem;
4285 size_t i;
4286 static const struct
4287 {
4288 const char *name;
4289 const char set_def;
4290 const short value;
4291 }
4292 v[] =
4293 {
4294 { "native", 0, IMAGE_SUBSYSTEM_NATIVE },
4295 { "windows", 0, IMAGE_SUBSYSTEM_WINDOWS_GUI },
4296 { "console", 0, IMAGE_SUBSYSTEM_WINDOWS_CUI },
4297 { "posix", 0, IMAGE_SUBSYSTEM_POSIX_CUI },
4298 { "wince", 0, IMAGE_SUBSYSTEM_WINDOWS_CE_GUI },
4299 { "efi-app", 1, IMAGE_SUBSYSTEM_EFI_APPLICATION },
4300 { "efi-bsd", 1, IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER },
4301 { "efi-rtd", 1, IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER },
4302 { "sal-rtd", 1, IMAGE_SUBSYSTEM_SAL_RUNTIME_DRIVER },
4303 { "xbox", 0, IMAGE_SUBSYSTEM_XBOX }
4304 };
4305 short value;
4306 char *copy;
4307 int set_def = -1;
4308
4309 /* Check for the presence of a version number. */
4310 version = strchr (s, ':');
4311 if (version == NULL)
4312 subsystem = s;
4313 else
4314 {
4315 int len = version - s;
4316 copy = xstrdup (s);
4317 subsystem = copy;
4318 copy[len] = '\0';
4319 version = copy + 1 + len;
4320 pe_major_subsystem_version = strtoul (version, &copy, 0);
4321 if (*copy == '.')
4322 pe_minor_subsystem_version = strtoul (copy + 1, &copy, 0);
4323 if (*copy != '\0')
4324 non_fatal (_("%s: bad version in PE subsystem"), s);
4325 }
4326
4327 /* Check for numeric subsystem. */
4328 value = (short) strtol (subsystem, &copy, 0);
4329 if (*copy == '\0')
4330 {
4331 for (i = 0; i < ARRAY_SIZE (v); i++)
4332 if (v[i].value == value)
4333 {
4334 pe_subsystem = value;
4335 set_def = v[i].set_def;
4336 break;
4337 }
4338 }
4339 else
4340 {
4341 /* Search for subsystem by name. */
4342 for (i = 0; i < ARRAY_SIZE (v); i++)
4343 if (strcmp (subsystem, v[i].name) == 0)
4344 {
4345 pe_subsystem = v[i].value;
4346 set_def = v[i].set_def;
4347 break;
4348 }
4349 }
4350
4351 switch (set_def)
4352 {
4353 case -1:
4354 fatal (_("unknown PE subsystem: %s"), s);
4355 break;
4356 case 0:
4357 break;
4358 default:
4359 if (pe_file_alignment == (bfd_vma) -1)
4360 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
4361 if (pe_section_alignment == (bfd_vma) -1)
4362 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
4363 break;
4364 }
4365 if (s != subsystem)
4366 free ((char *) subsystem);
4367 }
4368
4369 /* Convert EFI target to PEI target. */
4370
4371 static void
4372 convert_efi_target (char *efi)
4373 {
4374 efi[0] = 'p';
4375 efi[1] = 'e';
4376 efi[2] = 'i';
4377
4378 if (strcmp (efi + 4, "ia32") == 0)
4379 {
4380 /* Change ia32 to i386. */
4381 efi[5]= '3';
4382 efi[6]= '8';
4383 efi[7]= '6';
4384 }
4385 else if (strcmp (efi + 4, "x86_64") == 0)
4386 {
4387 /* Change x86_64 to x86-64. */
4388 efi[7] = '-';
4389 }
4390 }
4391
4392 /* Allocate and return a pointer to a struct section_add, initializing the
4393 structure using ARG, a string in the format "sectionname=filename".
4394 The returned structure will have its next pointer set to NEXT. The
4395 OPTION field is the name of the command line option currently being
4396 parsed, and is only used if an error needs to be reported. */
4397
4398 static struct section_add *
4399 init_section_add (const char *arg,
4400 struct section_add *next,
4401 const char *option)
4402 {
4403 struct section_add *pa;
4404 const char *s;
4405
4406 s = strchr (arg, '=');
4407 if (s == NULL)
4408 fatal (_("bad format for %s"), option);
4409
4410 pa = (struct section_add *) xmalloc (sizeof (struct section_add));
4411 pa->name = xstrndup (arg, s - arg);
4412 pa->filename = s + 1;
4413 pa->next = next;
4414 pa->contents = NULL;
4415 pa->size = 0;
4416
4417 return pa;
4418 }
4419
4420 /* Load the file specified in PA, allocating memory to hold the file
4421 contents, and store a pointer to the allocated memory in the contents
4422 field of PA. The size field of PA is also updated. All errors call
4423 FATAL. */
4424
4425 static void
4426 section_add_load_file (struct section_add *pa)
4427 {
4428 size_t off, alloc;
4429 FILE *f;
4430
4431 /* We don't use get_file_size so that we can do
4432 --add-section .note.GNU_stack=/dev/null
4433 get_file_size doesn't work on /dev/null. */
4434
4435 f = fopen (pa->filename, FOPEN_RB);
4436 if (f == NULL)
4437 fatal (_("cannot open: %s: %s"),
4438 pa->filename, strerror (errno));
4439
4440 off = 0;
4441 alloc = 4096;
4442 pa->contents = (bfd_byte *) xmalloc (alloc);
4443 while (!feof (f))
4444 {
4445 off_t got;
4446
4447 if (off == alloc)
4448 {
4449 alloc <<= 1;
4450 pa->contents = (bfd_byte *) xrealloc (pa->contents, alloc);
4451 }
4452
4453 got = fread (pa->contents + off, 1, alloc - off, f);
4454 if (ferror (f))
4455 fatal (_("%s: fread failed"), pa->filename);
4456
4457 off += got;
4458 }
4459
4460 pa->size = off;
4461
4462 fclose (f);
4463 }
4464
4465 static int
4466 copy_main (int argc, char *argv[])
4467 {
4468 char *input_filename = NULL;
4469 char *output_filename = NULL;
4470 char *tmpname;
4471 char *input_target = NULL;
4472 char *output_target = NULL;
4473 bfd_boolean show_version = FALSE;
4474 bfd_boolean change_warn = TRUE;
4475 bfd_boolean formats_info = FALSE;
4476 int c;
4477 struct stat statbuf;
4478 const bfd_arch_info_type *input_arch = NULL;
4479
4480 while ((c = getopt_long (argc, argv, "b:B:i:I:j:K:MN:s:O:d:F:L:G:R:SpgxXHhVvW:wDU",
4481 copy_options, (int *) 0)) != EOF)
4482 {
4483 switch (c)
4484 {
4485 case 'b':
4486 copy_byte = atoi (optarg);
4487 if (copy_byte < 0)
4488 fatal (_("byte number must be non-negative"));
4489 break;
4490
4491 case 'B':
4492 input_arch = bfd_scan_arch (optarg);
4493 if (input_arch == NULL)
4494 fatal (_("architecture %s unknown"), optarg);
4495 break;
4496
4497 case 'i':
4498 if (optarg)
4499 {
4500 interleave = atoi (optarg);
4501 if (interleave < 1)
4502 fatal (_("interleave must be positive"));
4503 }
4504 else
4505 interleave = 4;
4506 break;
4507
4508 case OPTION_INTERLEAVE_WIDTH:
4509 copy_width = atoi (optarg);
4510 if (copy_width < 1)
4511 fatal(_("interleave width must be positive"));
4512 break;
4513
4514 case 'I':
4515 case 's': /* "source" - 'I' is preferred */
4516 input_target = optarg;
4517 break;
4518
4519 case 'O':
4520 case 'd': /* "destination" - 'O' is preferred */
4521 output_target = optarg;
4522 break;
4523
4524 case 'F':
4525 input_target = output_target = optarg;
4526 break;
4527
4528 case 'j':
4529 find_section_list (optarg, TRUE, SECTION_CONTEXT_COPY);
4530 sections_copied = TRUE;
4531 break;
4532
4533 case 'R':
4534 handle_remove_section_option (optarg);
4535 break;
4536
4537 case OPTION_REMOVE_RELOCS:
4538 handle_remove_relocations_option (optarg);
4539 break;
4540
4541 case 'S':
4542 strip_symbols = STRIP_ALL;
4543 break;
4544
4545 case 'g':
4546 strip_symbols = STRIP_DEBUG;
4547 break;
4548
4549 case OPTION_STRIP_DWO:
4550 strip_symbols = STRIP_DWO;
4551 break;
4552
4553 case OPTION_STRIP_UNNEEDED:
4554 strip_symbols = STRIP_UNNEEDED;
4555 break;
4556
4557 case OPTION_ONLY_KEEP_DEBUG:
4558 strip_symbols = STRIP_NONDEBUG;
4559 break;
4560
4561 case OPTION_KEEP_FILE_SYMBOLS:
4562 keep_file_symbols = 1;
4563 break;
4564
4565 case OPTION_ADD_GNU_DEBUGLINK:
4566 long_section_names = ENABLE ;
4567 gnu_debuglink_filename = optarg;
4568 break;
4569
4570 case 'K':
4571 add_specific_symbol (optarg, keep_specific_htab);
4572 break;
4573
4574 case 'M':
4575 merge_notes = TRUE;
4576 break;
4577 case OPTION_NO_MERGE_NOTES:
4578 merge_notes = FALSE;
4579 break;
4580
4581 case 'N':
4582 add_specific_symbol (optarg, strip_specific_htab);
4583 break;
4584
4585 case OPTION_STRIP_UNNEEDED_SYMBOL:
4586 add_specific_symbol (optarg, strip_unneeded_htab);
4587 break;
4588
4589 case 'L':
4590 add_specific_symbol (optarg, localize_specific_htab);
4591 break;
4592
4593 case OPTION_GLOBALIZE_SYMBOL:
4594 add_specific_symbol (optarg, globalize_specific_htab);
4595 break;
4596
4597 case 'G':
4598 add_specific_symbol (optarg, keepglobal_specific_htab);
4599 break;
4600
4601 case 'W':
4602 add_specific_symbol (optarg, weaken_specific_htab);
4603 break;
4604
4605 case 'p':
4606 preserve_dates = TRUE;
4607 break;
4608
4609 case 'D':
4610 deterministic = TRUE;
4611 break;
4612
4613 case 'U':
4614 deterministic = FALSE;
4615 break;
4616
4617 case 'w':
4618 wildcard = TRUE;
4619 break;
4620
4621 case 'x':
4622 discard_locals = LOCALS_ALL;
4623 break;
4624
4625 case 'X':
4626 discard_locals = LOCALS_START_L;
4627 break;
4628
4629 case 'v':
4630 verbose = TRUE;
4631 break;
4632
4633 case 'V':
4634 show_version = TRUE;
4635 break;
4636
4637 case OPTION_FORMATS_INFO:
4638 formats_info = TRUE;
4639 break;
4640
4641 case OPTION_WEAKEN:
4642 weaken = TRUE;
4643 break;
4644
4645 case OPTION_ADD_SECTION:
4646 add_sections = init_section_add (optarg, add_sections,
4647 "--add-section");
4648 section_add_load_file (add_sections);
4649 break;
4650
4651 case OPTION_UPDATE_SECTION:
4652 update_sections = init_section_add (optarg, update_sections,
4653 "--update-section");
4654 section_add_load_file (update_sections);
4655 break;
4656
4657 case OPTION_DUMP_SECTION:
4658 dump_sections = init_section_add (optarg, dump_sections,
4659 "--dump-section");
4660 break;
4661
4662 case OPTION_ADD_SYMBOL:
4663 {
4664 char *s, *t;
4665 struct addsym_node *newsym = xmalloc (sizeof *newsym);
4666
4667 newsym->next = NULL;
4668 s = strchr (optarg, '=');
4669 if (s == NULL)
4670 fatal (_("bad format for %s"), "--add-symbol");
4671 t = strchr (s + 1, ':');
4672
4673 newsym->symdef = xstrndup (optarg, s - optarg);
4674 if (t)
4675 {
4676 newsym->section = xstrndup (s + 1, t - (s + 1));
4677 newsym->symval = strtol (t + 1, NULL, 0);
4678 }
4679 else
4680 {
4681 newsym->section = NULL;
4682 newsym->symval = strtol (s + 1, NULL, 0);
4683 t = s;
4684 }
4685
4686 t = strchr (t + 1, ',');
4687 newsym->othersym = NULL;
4688 if (t)
4689 newsym->flags = parse_symflags (t+1, &newsym->othersym);
4690 else
4691 newsym->flags = BSF_GLOBAL;
4692
4693 /* Keep 'othersym' symbols at the front of the list. */
4694 if (newsym->othersym)
4695 {
4696 newsym->next = add_sym_list;
4697 if (!add_sym_list)
4698 add_sym_tail = &newsym->next;
4699 add_sym_list = newsym;
4700 }
4701 else
4702 {
4703 *add_sym_tail = newsym;
4704 add_sym_tail = &newsym->next;
4705 }
4706 add_symbols++;
4707 }
4708 break;
4709
4710 case OPTION_CHANGE_START:
4711 change_start = parse_vma (optarg, "--change-start");
4712 break;
4713
4714 case OPTION_CHANGE_SECTION_ADDRESS:
4715 case OPTION_CHANGE_SECTION_LMA:
4716 case OPTION_CHANGE_SECTION_VMA:
4717 {
4718 struct section_list * p;
4719 unsigned int context = 0;
4720 const char *s;
4721 int len;
4722 char *name;
4723 char *option = NULL;
4724 bfd_vma val;
4725
4726 switch (c)
4727 {
4728 case OPTION_CHANGE_SECTION_ADDRESS:
4729 option = "--change-section-address";
4730 context = SECTION_CONTEXT_ALTER_LMA | SECTION_CONTEXT_ALTER_VMA;
4731 break;
4732 case OPTION_CHANGE_SECTION_LMA:
4733 option = "--change-section-lma";
4734 context = SECTION_CONTEXT_ALTER_LMA;
4735 break;
4736 case OPTION_CHANGE_SECTION_VMA:
4737 option = "--change-section-vma";
4738 context = SECTION_CONTEXT_ALTER_VMA;
4739 break;
4740 }
4741
4742 s = strchr (optarg, '=');
4743 if (s == NULL)
4744 {
4745 s = strchr (optarg, '+');
4746 if (s == NULL)
4747 {
4748 s = strchr (optarg, '-');
4749 if (s == NULL)
4750 fatal (_("bad format for %s"), option);
4751 }
4752 }
4753 else
4754 {
4755 /* Correct the context. */
4756 switch (c)
4757 {
4758 case OPTION_CHANGE_SECTION_ADDRESS:
4759 context = SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_SET_VMA;
4760 break;
4761 case OPTION_CHANGE_SECTION_LMA:
4762 context = SECTION_CONTEXT_SET_LMA;
4763 break;
4764 case OPTION_CHANGE_SECTION_VMA:
4765 context = SECTION_CONTEXT_SET_VMA;
4766 break;
4767 }
4768 }
4769
4770 len = s - optarg;
4771 name = (char *) xmalloc (len + 1);
4772 strncpy (name, optarg, len);
4773 name[len] = '\0';
4774
4775 p = find_section_list (name, TRUE, context);
4776
4777 val = parse_vma (s + 1, option);
4778 if (*s == '-')
4779 val = - val;
4780
4781 switch (c)
4782 {
4783 case OPTION_CHANGE_SECTION_ADDRESS:
4784 p->vma_val = val;
4785 /* Fall through. */
4786
4787 case OPTION_CHANGE_SECTION_LMA:
4788 p->lma_val = val;
4789 break;
4790
4791 case OPTION_CHANGE_SECTION_VMA:
4792 p->vma_val = val;
4793 break;
4794 }
4795 }
4796 break;
4797
4798 case OPTION_CHANGE_ADDRESSES:
4799 change_section_address = parse_vma (optarg, "--change-addresses");
4800 change_start = change_section_address;
4801 break;
4802
4803 case OPTION_CHANGE_WARNINGS:
4804 change_warn = TRUE;
4805 break;
4806
4807 case OPTION_CHANGE_LEADING_CHAR:
4808 change_leading_char = TRUE;
4809 break;
4810
4811 case OPTION_COMPRESS_DEBUG_SECTIONS:
4812 if (optarg)
4813 {
4814 if (strcasecmp (optarg, "none") == 0)
4815 do_debug_sections = decompress;
4816 else if (strcasecmp (optarg, "zlib") == 0)
4817 do_debug_sections = compress_zlib;
4818 else if (strcasecmp (optarg, "zlib-gnu") == 0)
4819 do_debug_sections = compress_gnu_zlib;
4820 else if (strcasecmp (optarg, "zlib-gabi") == 0)
4821 do_debug_sections = compress_gabi_zlib;
4822 else
4823 fatal (_("unrecognized --compress-debug-sections type `%s'"),
4824 optarg);
4825 }
4826 else
4827 do_debug_sections = compress;
4828 break;
4829
4830 case OPTION_DEBUGGING:
4831 convert_debugging = TRUE;
4832 break;
4833
4834 case OPTION_DECOMPRESS_DEBUG_SECTIONS:
4835 do_debug_sections = decompress;
4836 break;
4837
4838 case OPTION_ELF_STT_COMMON:
4839 if (strcasecmp (optarg, "yes") == 0)
4840 do_elf_stt_common = elf_stt_common;
4841 else if (strcasecmp (optarg, "no") == 0)
4842 do_elf_stt_common = no_elf_stt_common;
4843 else
4844 fatal (_("unrecognized --elf-stt-common= option `%s'"),
4845 optarg);
4846 break;
4847
4848 case OPTION_GAP_FILL:
4849 {
4850 bfd_vma gap_fill_vma;
4851
4852 gap_fill_vma = parse_vma (optarg, "--gap-fill");
4853 gap_fill = (bfd_byte) gap_fill_vma;
4854 if ((bfd_vma) gap_fill != gap_fill_vma)
4855 {
4856 char buff[20];
4857
4858 sprintf_vma (buff, gap_fill_vma);
4859
4860 non_fatal (_("Warning: truncating gap-fill from 0x%s to 0x%x"),
4861 buff, gap_fill);
4862 }
4863 gap_fill_set = TRUE;
4864 }
4865 break;
4866
4867 case OPTION_NO_CHANGE_WARNINGS:
4868 change_warn = FALSE;
4869 break;
4870
4871 case OPTION_PAD_TO:
4872 pad_to = parse_vma (optarg, "--pad-to");
4873 pad_to_set = TRUE;
4874 break;
4875
4876 case OPTION_REMOVE_LEADING_CHAR:
4877 remove_leading_char = TRUE;
4878 break;
4879
4880 case OPTION_REDEFINE_SYM:
4881 {
4882 /* Insert this redefinition onto redefine_specific_htab. */
4883
4884 int len;
4885 const char *s;
4886 const char *nextarg;
4887 char *source, *target;
4888
4889 s = strchr (optarg, '=');
4890 if (s == NULL)
4891 fatal (_("bad format for %s"), "--redefine-sym");
4892
4893 len = s - optarg;
4894 source = (char *) xmalloc (len + 1);
4895 strncpy (source, optarg, len);
4896 source[len] = '\0';
4897
4898 nextarg = s + 1;
4899 len = strlen (nextarg);
4900 target = (char *) xmalloc (len + 1);
4901 strcpy (target, nextarg);
4902
4903 add_redefine_and_check ("--redefine-sym", source, target);
4904
4905 free (source);
4906 free (target);
4907 }
4908 break;
4909
4910 case OPTION_REDEFINE_SYMS:
4911 add_redefine_syms_file (optarg);
4912 break;
4913
4914 case OPTION_SET_SECTION_FLAGS:
4915 {
4916 struct section_list *p;
4917 const char *s;
4918 int len;
4919 char *name;
4920
4921 s = strchr (optarg, '=');
4922 if (s == NULL)
4923 fatal (_("bad format for %s"), "--set-section-flags");
4924
4925 len = s - optarg;
4926 name = (char *) xmalloc (len + 1);
4927 strncpy (name, optarg, len);
4928 name[len] = '\0';
4929
4930 p = find_section_list (name, TRUE, SECTION_CONTEXT_SET_FLAGS);
4931
4932 p->flags = parse_flags (s + 1);
4933 }
4934 break;
4935
4936 case OPTION_RENAME_SECTION:
4937 {
4938 flagword flags;
4939 const char *eq, *fl;
4940 char *old_name;
4941 char *new_name;
4942 unsigned int len;
4943
4944 eq = strchr (optarg, '=');
4945 if (eq == NULL)
4946 fatal (_("bad format for %s"), "--rename-section");
4947
4948 len = eq - optarg;
4949 if (len == 0)
4950 fatal (_("bad format for %s"), "--rename-section");
4951
4952 old_name = (char *) xmalloc (len + 1);
4953 strncpy (old_name, optarg, len);
4954 old_name[len] = 0;
4955
4956 eq++;
4957 fl = strchr (eq, ',');
4958 if (fl)
4959 {
4960 flags = parse_flags (fl + 1);
4961 len = fl - eq;
4962 }
4963 else
4964 {
4965 flags = -1;
4966 len = strlen (eq);
4967 }
4968
4969 if (len == 0)
4970 fatal (_("bad format for %s"), "--rename-section");
4971
4972 new_name = (char *) xmalloc (len + 1);
4973 strncpy (new_name, eq, len);
4974 new_name[len] = 0;
4975
4976 add_section_rename (old_name, new_name, flags);
4977 }
4978 break;
4979
4980 case OPTION_SET_START:
4981 set_start = parse_vma (optarg, "--set-start");
4982 set_start_set = TRUE;
4983 break;
4984
4985 case OPTION_SREC_LEN:
4986 _bfd_srec_len = parse_vma (optarg, "--srec-len");
4987 break;
4988
4989 case OPTION_SREC_FORCES3:
4990 _bfd_srec_forceS3 = TRUE;
4991 break;
4992
4993 case OPTION_STRIP_SYMBOLS:
4994 add_specific_symbols (optarg, strip_specific_htab);
4995 break;
4996
4997 case OPTION_STRIP_UNNEEDED_SYMBOLS:
4998 add_specific_symbols (optarg, strip_unneeded_htab);
4999 break;
5000
5001 case OPTION_KEEP_SYMBOLS:
5002 add_specific_symbols (optarg, keep_specific_htab);
5003 break;
5004
5005 case OPTION_LOCALIZE_HIDDEN:
5006 localize_hidden = TRUE;
5007 break;
5008
5009 case OPTION_LOCALIZE_SYMBOLS:
5010 add_specific_symbols (optarg, localize_specific_htab);
5011 break;
5012
5013 case OPTION_LONG_SECTION_NAMES:
5014 if (!strcmp ("enable", optarg))
5015 long_section_names = ENABLE;
5016 else if (!strcmp ("disable", optarg))
5017 long_section_names = DISABLE;
5018 else if (!strcmp ("keep", optarg))
5019 long_section_names = KEEP;
5020 else
5021 fatal (_("unknown long section names option '%s'"), optarg);
5022 break;
5023
5024 case OPTION_GLOBALIZE_SYMBOLS:
5025 add_specific_symbols (optarg, globalize_specific_htab);
5026 break;
5027
5028 case OPTION_KEEPGLOBAL_SYMBOLS:
5029 add_specific_symbols (optarg, keepglobal_specific_htab);
5030 break;
5031
5032 case OPTION_WEAKEN_SYMBOLS:
5033 add_specific_symbols (optarg, weaken_specific_htab);
5034 break;
5035
5036 case OPTION_ALT_MACH_CODE:
5037 use_alt_mach_code = strtoul (optarg, NULL, 0);
5038 if (use_alt_mach_code == 0)
5039 fatal (_("unable to parse alternative machine code"));
5040 break;
5041
5042 case OPTION_PREFIX_SYMBOLS:
5043 prefix_symbols_string = optarg;
5044 break;
5045
5046 case OPTION_PREFIX_SECTIONS:
5047 prefix_sections_string = optarg;
5048 break;
5049
5050 case OPTION_PREFIX_ALLOC_SECTIONS:
5051 prefix_alloc_sections_string = optarg;
5052 break;
5053
5054 case OPTION_READONLY_TEXT:
5055 bfd_flags_to_set |= WP_TEXT;
5056 bfd_flags_to_clear &= ~WP_TEXT;
5057 break;
5058
5059 case OPTION_WRITABLE_TEXT:
5060 bfd_flags_to_clear |= WP_TEXT;
5061 bfd_flags_to_set &= ~WP_TEXT;
5062 break;
5063
5064 case OPTION_PURE:
5065 bfd_flags_to_set |= D_PAGED;
5066 bfd_flags_to_clear &= ~D_PAGED;
5067 break;
5068
5069 case OPTION_IMPURE:
5070 bfd_flags_to_clear |= D_PAGED;
5071 bfd_flags_to_set &= ~D_PAGED;
5072 break;
5073
5074 case OPTION_EXTRACT_DWO:
5075 strip_symbols = STRIP_NONDWO;
5076 break;
5077
5078 case OPTION_EXTRACT_SYMBOL:
5079 extract_symbol = TRUE;
5080 break;
5081
5082 case OPTION_REVERSE_BYTES:
5083 {
5084 int prev = reverse_bytes;
5085
5086 reverse_bytes = atoi (optarg);
5087 if ((reverse_bytes <= 0) || ((reverse_bytes % 2) != 0))
5088 fatal (_("number of bytes to reverse must be positive and even"));
5089
5090 if (prev && prev != reverse_bytes)
5091 non_fatal (_("Warning: ignoring previous --reverse-bytes value of %d"),
5092 prev);
5093 break;
5094 }
5095
5096 case OPTION_FILE_ALIGNMENT:
5097 pe_file_alignment = parse_vma (optarg, "--file-alignment");
5098 break;
5099
5100 case OPTION_HEAP:
5101 {
5102 char *end;
5103 pe_heap_reserve = strtoul (optarg, &end, 0);
5104 if (end == optarg
5105 || (*end != '.' && *end != '\0'))
5106 non_fatal (_("%s: invalid reserve value for --heap"),
5107 optarg);
5108 else if (*end != '\0')
5109 {
5110 pe_heap_commit = strtoul (end + 1, &end, 0);
5111 if (*end != '\0')
5112 non_fatal (_("%s: invalid commit value for --heap"),
5113 optarg);
5114 }
5115 }
5116 break;
5117
5118 case OPTION_IMAGE_BASE:
5119 pe_image_base = parse_vma (optarg, "--image-base");
5120 break;
5121
5122 case OPTION_SECTION_ALIGNMENT:
5123 pe_section_alignment = parse_vma (optarg,
5124 "--section-alignment");
5125 break;
5126
5127 case OPTION_SUBSYSTEM:
5128 set_pe_subsystem (optarg);
5129 break;
5130
5131 case OPTION_STACK:
5132 {
5133 char *end;
5134 pe_stack_reserve = strtoul (optarg, &end, 0);
5135 if (end == optarg
5136 || (*end != '.' && *end != '\0'))
5137 non_fatal (_("%s: invalid reserve value for --stack"),
5138 optarg);
5139 else if (*end != '\0')
5140 {
5141 pe_stack_commit = strtoul (end + 1, &end, 0);
5142 if (*end != '\0')
5143 non_fatal (_("%s: invalid commit value for --stack"),
5144 optarg);
5145 }
5146 }
5147 break;
5148
5149 case 0:
5150 /* We've been given a long option. */
5151 break;
5152
5153 case 'H':
5154 case 'h':
5155 copy_usage (stdout, 0);
5156
5157 default:
5158 copy_usage (stderr, 1);
5159 }
5160 }
5161
5162 if (formats_info)
5163 {
5164 display_info ();
5165 return 0;
5166 }
5167
5168 if (show_version)
5169 print_version ("objcopy");
5170
5171 if (interleave && copy_byte == -1)
5172 fatal (_("interleave start byte must be set with --byte"));
5173
5174 if (copy_byte >= interleave)
5175 fatal (_("byte number must be less than interleave"));
5176
5177 if (copy_width > interleave - copy_byte)
5178 fatal (_("interleave width must be less than or equal to interleave - byte`"));
5179
5180 if (optind == argc || optind + 2 < argc)
5181 copy_usage (stderr, 1);
5182
5183 input_filename = argv[optind];
5184 if (optind + 1 < argc)
5185 output_filename = argv[optind + 1];
5186
5187 default_deterministic ();
5188
5189 /* Default is to strip no symbols. */
5190 if (strip_symbols == STRIP_UNDEF && discard_locals == LOCALS_UNDEF)
5191 strip_symbols = STRIP_NONE;
5192
5193 if (output_target == NULL)
5194 output_target = input_target;
5195
5196 /* Convert input EFI target to PEI target. */
5197 if (input_target != NULL
5198 && strncmp (input_target, "efi-", 4) == 0)
5199 {
5200 char *efi;
5201
5202 efi = xstrdup (output_target + 4);
5203 if (strncmp (efi, "bsdrv-", 6) == 0
5204 || strncmp (efi, "rtdrv-", 6) == 0)
5205 efi += 2;
5206 else if (strncmp (efi, "app-", 4) != 0)
5207 fatal (_("unknown input EFI target: %s"), input_target);
5208
5209 input_target = efi;
5210 convert_efi_target (efi);
5211 }
5212
5213 /* Convert output EFI target to PEI target. */
5214 if (output_target != NULL
5215 && strncmp (output_target, "efi-", 4) == 0)
5216 {
5217 char *efi;
5218
5219 efi = xstrdup (output_target + 4);
5220 if (strncmp (efi, "app-", 4) == 0)
5221 {
5222 if (pe_subsystem == -1)
5223 pe_subsystem = IMAGE_SUBSYSTEM_EFI_APPLICATION;
5224 }
5225 else if (strncmp (efi, "bsdrv-", 6) == 0)
5226 {
5227 if (pe_subsystem == -1)
5228 pe_subsystem = IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER;
5229 efi += 2;
5230 }
5231 else if (strncmp (efi, "rtdrv-", 6) == 0)
5232 {
5233 if (pe_subsystem == -1)
5234 pe_subsystem = IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER;
5235 efi += 2;
5236 }
5237 else
5238 fatal (_("unknown output EFI target: %s"), output_target);
5239
5240 if (pe_file_alignment == (bfd_vma) -1)
5241 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
5242 if (pe_section_alignment == (bfd_vma) -1)
5243 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
5244
5245 output_target = efi;
5246 convert_efi_target (efi);
5247 }
5248
5249 if (preserve_dates)
5250 if (stat (input_filename, & statbuf) < 0)
5251 fatal (_("warning: could not locate '%s'. System error message: %s"),
5252 input_filename, strerror (errno));
5253
5254 /* If there is no destination file, or the source and destination files
5255 are the same, then create a temp and rename the result into the input. */
5256 if (output_filename == NULL
5257 || filename_cmp (input_filename, output_filename) == 0)
5258 tmpname = make_tempname (input_filename);
5259 else
5260 tmpname = output_filename;
5261
5262 if (tmpname == NULL)
5263 fatal (_("warning: could not create temporary file whilst copying '%s', (error: %s)"),
5264 input_filename, strerror (errno));
5265
5266 copy_file (input_filename, tmpname, input_target, output_target, input_arch);
5267 if (status == 0)
5268 {
5269 if (preserve_dates)
5270 set_times (tmpname, &statbuf);
5271 if (tmpname != output_filename)
5272 status = (smart_rename (tmpname, input_filename,
5273 preserve_dates) != 0);
5274 }
5275 else
5276 unlink_if_ordinary (tmpname);
5277
5278 if (change_warn)
5279 {
5280 struct section_list *p;
5281
5282 for (p = change_sections; p != NULL; p = p->next)
5283 {
5284 if (! p->used)
5285 {
5286 if (p->context & (SECTION_CONTEXT_SET_VMA | SECTION_CONTEXT_ALTER_VMA))
5287 {
5288 char buff [20];
5289
5290 sprintf_vma (buff, p->vma_val);
5291
5292 /* xgettext:c-format */
5293 non_fatal (_("%s %s%c0x%s never used"),
5294 "--change-section-vma",
5295 p->pattern,
5296 p->context & SECTION_CONTEXT_SET_VMA ? '=' : '+',
5297 buff);
5298 }
5299
5300 if (p->context & (SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_ALTER_LMA))
5301 {
5302 char buff [20];
5303
5304 sprintf_vma (buff, p->lma_val);
5305
5306 /* xgettext:c-format */
5307 non_fatal (_("%s %s%c0x%s never used"),
5308 "--change-section-lma",
5309 p->pattern,
5310 p->context & SECTION_CONTEXT_SET_LMA ? '=' : '+',
5311 buff);
5312 }
5313 }
5314 }
5315 }
5316
5317 return 0;
5318 }
5319
5320 int
5321 main (int argc, char *argv[])
5322 {
5323 #if defined (HAVE_SETLOCALE) && defined (HAVE_LC_MESSAGES)
5324 setlocale (LC_MESSAGES, "");
5325 #endif
5326 #if defined (HAVE_SETLOCALE)
5327 setlocale (LC_CTYPE, "");
5328 #endif
5329 bindtextdomain (PACKAGE, LOCALEDIR);
5330 textdomain (PACKAGE);
5331
5332 program_name = argv[0];
5333 xmalloc_set_program_name (program_name);
5334
5335 START_PROGRESS (program_name, 0);
5336
5337 expandargv (&argc, &argv);
5338
5339 strip_symbols = STRIP_UNDEF;
5340 discard_locals = LOCALS_UNDEF;
5341
5342 bfd_init ();
5343 set_default_bfd_target ();
5344
5345 if (is_strip < 0)
5346 {
5347 int i = strlen (program_name);
5348 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
5349 /* Drop the .exe suffix, if any. */
5350 if (i > 4 && FILENAME_CMP (program_name + i - 4, ".exe") == 0)
5351 {
5352 i -= 4;
5353 program_name[i] = '\0';
5354 }
5355 #endif
5356 is_strip = (i >= 5 && FILENAME_CMP (program_name + i - 5, "strip") == 0);
5357 }
5358
5359 create_symbol_htabs ();
5360
5361 if (argv != NULL)
5362 bfd_set_error_program_name (argv[0]);
5363
5364 if (is_strip)
5365 strip_main (argc, argv);
5366 else
5367 copy_main (argc, argv);
5368
5369 END_PROGRESS (program_name);
5370
5371 return status;
5372 }
This page took 0.140644 seconds and 4 git commands to generate.