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