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