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