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