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