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