Rename windows-termcap.c -> stub-termcap.c
[deliverable/binutils-gdb.git] / binutils / objcopy.c
CommitLineData
252b5132 1/* objcopy.c -- copy object file from input to output, optionally massaging it.
b90efa5b 2 Copyright (C) 1991-2015 Free Software Foundation, Inc.
252b5132
RH
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
32866df7 8 the Free Software Foundation; either version 3 of the License, or
252b5132
RH
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
b43b5d5f
NC
18 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA
19 02110-1301, USA. */
252b5132 20\f
3db64b00 21#include "sysdep.h"
252b5132
RH
22#include "bfd.h"
23#include "progress.h"
252b5132
RH
24#include "getopt.h"
25#include "libiberty.h"
3db64b00 26#include "bucomm.h"
252b5132 27#include "budbg.h"
5af11cab 28#include "filenames.h"
5fe11841 29#include "fnmatch.h"
f0312d39 30#include "elf-bfd.h"
6e2c86ac 31#include "libbfd.h"
0408dee6
DK
32#include "coff/internal.h"
33#include "libcoff.h"
252b5132 34
92dd4511
L
35/* FIXME: See bfd/peXXigen.c for why we include an architecture specific
36 header in generic PE code. */
37#include "coff/i386.h"
38#include "coff/pe.h"
39
40static bfd_vma pe_file_alignment = (bfd_vma) -1;
41static bfd_vma pe_heap_commit = (bfd_vma) -1;
42static bfd_vma pe_heap_reserve = (bfd_vma) -1;
43static bfd_vma pe_image_base = (bfd_vma) -1;
44static bfd_vma pe_section_alignment = (bfd_vma) -1;
45static bfd_vma pe_stack_commit = (bfd_vma) -1;
46static bfd_vma pe_stack_reserve = (bfd_vma) -1;
47static short pe_subsystem = -1;
48static short pe_major_subsystem_version = -1;
49static short pe_minor_subsystem_version = -1;
50
047c9024 51struct is_specified_symbol_predicate_data
252b5132 52{
047c9024
NC
53 const char *name;
54 bfd_boolean found;
252b5132
RH
55};
56
57938635
AM
57/* A list to support redefine_sym. */
58struct redefine_node
59{
60 char *source;
61 char *target;
62 struct redefine_node *next;
63};
64
594ef5db
NC
65typedef struct section_rename
66{
67 const char * old_name;
68 const char * new_name;
69 flagword flags;
70 struct section_rename * next;
71}
72section_rename;
73
74/* List of sections to be renamed. */
84e2f313 75static section_rename *section_rename_list;
594ef5db 76
84e2f313
NC
77static asymbol **isympp = NULL; /* Input symbols. */
78static asymbol **osympp = NULL; /* Output symbols that survive stripping. */
252b5132 79
b7dd81f7 80/* If `copy_byte' >= 0, copy 'copy_width' byte(s) of every `interleave' bytes. */
252b5132 81static int copy_byte = -1;
b7dd81f7
NC
82static int interleave = 0; /* Initialised to 4 in copy_main(). */
83static int copy_width = 1;
252b5132 84
b34976b6
AM
85static bfd_boolean verbose; /* Print file and target names. */
86static bfd_boolean preserve_dates; /* Preserve input file timestamp. */
955d0b3b 87static int deterministic = -1; /* Enable deterministic archives. */
252b5132
RH
88static int status = 0; /* Exit status. */
89
90enum strip_action
91 {
92 STRIP_UNDEF,
84e2f313
NC
93 STRIP_NONE, /* Don't strip. */
94 STRIP_DEBUG, /* Strip all debugger symbols. */
95 STRIP_UNNEEDED, /* Strip unnecessary symbols. */
ed1653a7 96 STRIP_NONDEBUG, /* Strip everything but debug info. */
96109726
CC
97 STRIP_DWO, /* Strip all DWO info. */
98 STRIP_NONDWO, /* Strip everything but DWO info. */
84e2f313 99 STRIP_ALL /* Strip all symbols. */
252b5132
RH
100 };
101
0af11b59 102/* Which symbols to remove. */
4fc8b895 103static enum strip_action strip_symbols = STRIP_UNDEF;
252b5132
RH
104
105enum locals_action
106 {
107 LOCALS_UNDEF,
84e2f313
NC
108 LOCALS_START_L, /* Discard locals starting with L. */
109 LOCALS_ALL /* Discard all locals. */
252b5132
RH
110 };
111
112/* Which local symbols to remove. Overrides STRIP_ALL. */
113static enum locals_action discard_locals;
114
252b5132
RH
115/* Structure used to hold lists of sections and actions to take. */
116struct section_list
117{
b34976b6 118 struct section_list * next; /* Next section to change. */
2e62b721 119 const char * pattern; /* Section name pattern. */
b34976b6 120 bfd_boolean used; /* Whether this entry was used. */
2e62b721
NC
121
122 unsigned int context; /* What to do with matching sections. */
123 /* Flag bits used in the context field.
124 COPY and REMOVE are mutually exlusive. SET and ALTER are mutually exclusive. */
125#define SECTION_CONTEXT_REMOVE (1 << 0) /* Remove this section. */
126#define SECTION_CONTEXT_COPY (1 << 1) /* Copy this section, delete all non-copied section. */
127#define SECTION_CONTEXT_SET_VMA (1 << 2) /* Set the sections' VMA address. */
128#define SECTION_CONTEXT_ALTER_VMA (1 << 3) /* Increment or decrement the section's VMA address. */
129#define SECTION_CONTEXT_SET_LMA (1 << 4) /* Set the sections' LMA address. */
130#define SECTION_CONTEXT_ALTER_LMA (1 << 5) /* Increment or decrement the section's LMA address. */
131#define SECTION_CONTEXT_SET_FLAGS (1 << 6) /* Set the section's flags. */
132
b34976b6 133 bfd_vma vma_val; /* Amount to change by or set to. */
b34976b6 134 bfd_vma lma_val; /* Amount to change by or set to. */
b34976b6 135 flagword flags; /* What to set the section flags to. */
252b5132
RH
136};
137
138static struct section_list *change_sections;
594ef5db 139
b34976b6
AM
140/* TRUE if some sections are to be removed. */
141static bfd_boolean sections_removed;
594ef5db 142
b34976b6
AM
143/* TRUE if only some sections are to be copied. */
144static bfd_boolean sections_copied;
252b5132
RH
145
146/* Changes to the start address. */
147static bfd_vma change_start = 0;
b34976b6 148static bfd_boolean set_start_set = FALSE;
252b5132
RH
149static bfd_vma set_start;
150
151/* Changes to section addresses. */
152static bfd_vma change_section_address = 0;
153
154/* Filling gaps between sections. */
b34976b6 155static bfd_boolean gap_fill_set = FALSE;
252b5132
RH
156static bfd_byte gap_fill = 0;
157
158/* Pad to a given address. */
b34976b6 159static bfd_boolean pad_to_set = FALSE;
252b5132
RH
160static bfd_vma pad_to;
161
f9d4ad2a
NC
162/* Use alternative machine code? */
163static unsigned long use_alt_mach_code = 0;
1ae8b3d2 164
4087920c
MR
165/* Output BFD flags user wants to set or clear */
166static flagword bfd_flags_to_set;
167static flagword bfd_flags_to_clear;
168
252b5132 169/* List of sections to add. */
252b5132
RH
170struct section_add
171{
172 /* Next section to add. */
173 struct section_add *next;
174 /* Name of section to add. */
175 const char *name;
176 /* Name of file holding section contents. */
177 const char *filename;
178 /* Size of file. */
179 size_t size;
180 /* Contents of file. */
181 bfd_byte *contents;
182 /* BFD section, after it has been added. */
183 asection *section;
184};
185
594ef5db 186/* List of sections to add to the output BFD. */
252b5132
RH
187static struct section_add *add_sections;
188
bbad633b
NC
189/* List of sections to dump from the output BFD. */
190static struct section_add *dump_sections;
191
2593f09a
NC
192/* If non-NULL the argument to --add-gnu-debuglink.
193 This should be the filename to store in the .gnu_debuglink section. */
194static const char * gnu_debuglink_filename = NULL;
195
252b5132 196/* Whether to convert debugging information. */
b34976b6 197static bfd_boolean convert_debugging = FALSE;
252b5132 198
4a114e3e
L
199/* Whether to compress/decompress DWARF debug sections. */
200static enum
201{
202 nothing,
203 compress,
204 decompress
205} do_debug_sections = nothing;
206
252b5132 207/* Whether to change the leading character in symbol names. */
b34976b6 208static bfd_boolean change_leading_char = FALSE;
252b5132
RH
209
210/* Whether to remove the leading character from global symbol names. */
b34976b6 211static bfd_boolean remove_leading_char = FALSE;
252b5132 212
aaad4cf3 213/* Whether to permit wildcard in symbol comparison. */
5fe11841
NC
214static bfd_boolean wildcard = FALSE;
215
d58c2e3a
RS
216/* True if --localize-hidden is in effect. */
217static bfd_boolean localize_hidden = FALSE;
218
16b2b71c
NC
219/* List of symbols to strip, keep, localize, keep-global, weaken,
220 or redefine. */
047c9024
NC
221static htab_t strip_specific_htab = NULL;
222static htab_t strip_unneeded_htab = NULL;
223static htab_t keep_specific_htab = NULL;
224static htab_t localize_specific_htab = NULL;
225static htab_t globalize_specific_htab = NULL;
226static htab_t keepglobal_specific_htab = NULL;
227static htab_t weaken_specific_htab = NULL;
57938635 228static struct redefine_node *redefine_sym_list = NULL;
252b5132 229
b34976b6
AM
230/* If this is TRUE, we weaken global symbols (set BSF_WEAK). */
231static bfd_boolean weaken = FALSE;
252b5132 232
1637cd90
JB
233/* If this is TRUE, we retain BSF_FILE symbols. */
234static bfd_boolean keep_file_symbols = FALSE;
235
d7fb0dd2
NC
236/* Prefix symbols/sections. */
237static char *prefix_symbols_string = 0;
238static char *prefix_sections_string = 0;
239static char *prefix_alloc_sections_string = 0;
240
d3e52d40
RS
241/* True if --extract-symbol was passed on the command line. */
242static bfd_boolean extract_symbol = FALSE;
243
9e48b4c6
NC
244/* If `reverse_bytes' is nonzero, then reverse the order of every chunk
245 of <reverse_bytes> bytes within each output section. */
246static int reverse_bytes = 0;
247
0408dee6
DK
248/* For Coff objects, we may want to allow or disallow long section names,
249 or preserve them where found in the inputs. Debug info relies on them. */
250enum long_section_name_handling
251 {
252 DISABLE,
253 ENABLE,
254 KEEP
255 };
256
257/* The default long section handling mode is to preserve them.
258 This is also the only behaviour for 'strip'. */
259static enum long_section_name_handling long_section_names = KEEP;
9e48b4c6 260
252b5132 261/* 150 isn't special; it's just an arbitrary non-ASCII char value. */
84e2f313
NC
262enum command_line_switch
263 {
264 OPTION_ADD_SECTION=150,
bbad633b 265 OPTION_DUMP_SECTION,
84e2f313
NC
266 OPTION_CHANGE_ADDRESSES,
267 OPTION_CHANGE_LEADING_CHAR,
268 OPTION_CHANGE_START,
269 OPTION_CHANGE_SECTION_ADDRESS,
270 OPTION_CHANGE_SECTION_LMA,
271 OPTION_CHANGE_SECTION_VMA,
272 OPTION_CHANGE_WARNINGS,
4a114e3e 273 OPTION_COMPRESS_DEBUG_SECTIONS,
84e2f313 274 OPTION_DEBUGGING,
4a114e3e 275 OPTION_DECOMPRESS_DEBUG_SECTIONS,
84e2f313
NC
276 OPTION_GAP_FILL,
277 OPTION_NO_CHANGE_WARNINGS,
278 OPTION_PAD_TO,
279 OPTION_REMOVE_LEADING_CHAR,
280 OPTION_SET_SECTION_FLAGS,
281 OPTION_SET_START,
282 OPTION_STRIP_UNNEEDED,
283 OPTION_WEAKEN,
284 OPTION_REDEFINE_SYM,
285 OPTION_REDEFINE_SYMS,
286 OPTION_SREC_LEN,
287 OPTION_SREC_FORCES3,
288 OPTION_STRIP_SYMBOLS,
bcf32829
JB
289 OPTION_STRIP_UNNEEDED_SYMBOL,
290 OPTION_STRIP_UNNEEDED_SYMBOLS,
84e2f313 291 OPTION_KEEP_SYMBOLS,
d58c2e3a 292 OPTION_LOCALIZE_HIDDEN,
84e2f313 293 OPTION_LOCALIZE_SYMBOLS,
0408dee6 294 OPTION_LONG_SECTION_NAMES,
7b4a0685
NC
295 OPTION_GLOBALIZE_SYMBOL,
296 OPTION_GLOBALIZE_SYMBOLS,
84e2f313
NC
297 OPTION_KEEPGLOBAL_SYMBOLS,
298 OPTION_WEAKEN_SYMBOLS,
299 OPTION_RENAME_SECTION,
300 OPTION_ALT_MACH_CODE,
301 OPTION_PREFIX_SYMBOLS,
302 OPTION_PREFIX_SECTIONS,
303 OPTION_PREFIX_ALLOC_SECTIONS,
304 OPTION_FORMATS_INFO,
305 OPTION_ADD_GNU_DEBUGLINK,
4087920c 306 OPTION_ONLY_KEEP_DEBUG,
1637cd90 307 OPTION_KEEP_FILE_SYMBOLS,
4087920c
MR
308 OPTION_READONLY_TEXT,
309 OPTION_WRITABLE_TEXT,
310 OPTION_PURE,
d3e52d40 311 OPTION_IMPURE,
9e48b4c6 312 OPTION_EXTRACT_SYMBOL,
92dd4511
L
313 OPTION_REVERSE_BYTES,
314 OPTION_FILE_ALIGNMENT,
315 OPTION_HEAP,
316 OPTION_IMAGE_BASE,
317 OPTION_SECTION_ALIGNMENT,
318 OPTION_STACK,
b7dd81f7 319 OPTION_INTERLEAVE_WIDTH,
96109726
CC
320 OPTION_SUBSYSTEM,
321 OPTION_EXTRACT_DWO,
322 OPTION_STRIP_DWO
84e2f313 323 };
252b5132
RH
324
325/* Options to handle if running as "strip". */
326
327static struct option strip_options[] =
328{
955d0b3b 329 {"disable-deterministic-archives", no_argument, 0, 'U'},
252b5132
RH
330 {"discard-all", no_argument, 0, 'x'},
331 {"discard-locals", no_argument, 0, 'X'},
2e30cb57 332 {"enable-deterministic-archives", no_argument, 0, 'D'},
252b5132
RH
333 {"format", required_argument, 0, 'F'}, /* Obsolete */
334 {"help", no_argument, 0, 'h'},
7c29036b 335 {"info", no_argument, 0, OPTION_FORMATS_INFO},
252b5132
RH
336 {"input-format", required_argument, 0, 'I'}, /* Obsolete */
337 {"input-target", required_argument, 0, 'I'},
1637cd90 338 {"keep-file-symbols", no_argument, 0, OPTION_KEEP_FILE_SYMBOLS},
252b5132 339 {"keep-symbol", required_argument, 0, 'K'},
ed1653a7 340 {"only-keep-debug", no_argument, 0, OPTION_ONLY_KEEP_DEBUG},
252b5132
RH
341 {"output-format", required_argument, 0, 'O'}, /* Obsolete */
342 {"output-target", required_argument, 0, 'O'},
af3bdff7 343 {"output-file", required_argument, 0, 'o'},
252b5132
RH
344 {"preserve-dates", no_argument, 0, 'p'},
345 {"remove-section", required_argument, 0, 'R'},
346 {"strip-all", no_argument, 0, 's'},
347 {"strip-debug", no_argument, 0, 'S'},
96109726 348 {"strip-dwo", no_argument, 0, OPTION_STRIP_DWO},
252b5132
RH
349 {"strip-unneeded", no_argument, 0, OPTION_STRIP_UNNEEDED},
350 {"strip-symbol", required_argument, 0, 'N'},
351 {"target", required_argument, 0, 'F'},
352 {"verbose", no_argument, 0, 'v'},
353 {"version", no_argument, 0, 'V'},
5fe11841 354 {"wildcard", no_argument, 0, 'w'},
252b5132
RH
355 {0, no_argument, 0, 0}
356};
357
358/* Options to handle if running as "objcopy". */
359
360static struct option copy_options[] =
361{
2593f09a 362 {"add-gnu-debuglink", required_argument, 0, OPTION_ADD_GNU_DEBUGLINK},
252b5132
RH
363 {"add-section", required_argument, 0, OPTION_ADD_SECTION},
364 {"adjust-start", required_argument, 0, OPTION_CHANGE_START},
365 {"adjust-vma", required_argument, 0, OPTION_CHANGE_ADDRESSES},
366 {"adjust-section-vma", required_argument, 0, OPTION_CHANGE_SECTION_ADDRESS},
367 {"adjust-warnings", no_argument, 0, OPTION_CHANGE_WARNINGS},
d7fb0dd2 368 {"alt-machine-code", required_argument, 0, OPTION_ALT_MACH_CODE},
43a0748c 369 {"binary-architecture", required_argument, 0, 'B'},
252b5132
RH
370 {"byte", required_argument, 0, 'b'},
371 {"change-addresses", required_argument, 0, OPTION_CHANGE_ADDRESSES},
372 {"change-leading-char", no_argument, 0, OPTION_CHANGE_LEADING_CHAR},
373 {"change-section-address", required_argument, 0, OPTION_CHANGE_SECTION_ADDRESS},
374 {"change-section-lma", required_argument, 0, OPTION_CHANGE_SECTION_LMA},
375 {"change-section-vma", required_argument, 0, OPTION_CHANGE_SECTION_VMA},
376 {"change-start", required_argument, 0, OPTION_CHANGE_START},
377 {"change-warnings", no_argument, 0, OPTION_CHANGE_WARNINGS},
4a114e3e 378 {"compress-debug-sections", no_argument, 0, OPTION_COMPRESS_DEBUG_SECTIONS},
252b5132 379 {"debugging", no_argument, 0, OPTION_DEBUGGING},
4a114e3e 380 {"decompress-debug-sections", no_argument, 0, OPTION_DECOMPRESS_DEBUG_SECTIONS},
955d0b3b 381 {"disable-deterministic-archives", no_argument, 0, 'U'},
252b5132
RH
382 {"discard-all", no_argument, 0, 'x'},
383 {"discard-locals", no_argument, 0, 'X'},
bbad633b 384 {"dump-section", required_argument, 0, OPTION_DUMP_SECTION},
2e30cb57 385 {"enable-deterministic-archives", no_argument, 0, 'D'},
96109726 386 {"extract-dwo", no_argument, 0, OPTION_EXTRACT_DWO},
d3e52d40 387 {"extract-symbol", no_argument, 0, OPTION_EXTRACT_SYMBOL},
252b5132
RH
388 {"format", required_argument, 0, 'F'}, /* Obsolete */
389 {"gap-fill", required_argument, 0, OPTION_GAP_FILL},
7b4a0685
NC
390 {"globalize-symbol", required_argument, 0, OPTION_GLOBALIZE_SYMBOL},
391 {"globalize-symbols", required_argument, 0, OPTION_GLOBALIZE_SYMBOLS},
252b5132 392 {"help", no_argument, 0, 'h'},
4087920c 393 {"impure", no_argument, 0, OPTION_IMPURE},
7c29036b 394 {"info", no_argument, 0, OPTION_FORMATS_INFO},
252b5132
RH
395 {"input-format", required_argument, 0, 'I'}, /* Obsolete */
396 {"input-target", required_argument, 0, 'I'},
b7dd81f7
NC
397 {"interleave", optional_argument, 0, 'i'},
398 {"interleave-width", required_argument, 0, OPTION_INTERLEAVE_WIDTH},
1637cd90 399 {"keep-file-symbols", no_argument, 0, OPTION_KEEP_FILE_SYMBOLS},
d7fb0dd2
NC
400 {"keep-global-symbol", required_argument, 0, 'G'},
401 {"keep-global-symbols", required_argument, 0, OPTION_KEEPGLOBAL_SYMBOLS},
252b5132 402 {"keep-symbol", required_argument, 0, 'K'},
d7fb0dd2 403 {"keep-symbols", required_argument, 0, OPTION_KEEP_SYMBOLS},
d58c2e3a 404 {"localize-hidden", no_argument, 0, OPTION_LOCALIZE_HIDDEN},
d7fb0dd2
NC
405 {"localize-symbol", required_argument, 0, 'L'},
406 {"localize-symbols", required_argument, 0, OPTION_LOCALIZE_SYMBOLS},
0408dee6 407 {"long-section-names", required_argument, 0, OPTION_LONG_SECTION_NAMES},
252b5132
RH
408 {"no-adjust-warnings", no_argument, 0, OPTION_NO_CHANGE_WARNINGS},
409 {"no-change-warnings", no_argument, 0, OPTION_NO_CHANGE_WARNINGS},
ed1653a7 410 {"only-keep-debug", no_argument, 0, OPTION_ONLY_KEEP_DEBUG},
d7fb0dd2 411 {"only-section", required_argument, 0, 'j'},
252b5132
RH
412 {"output-format", required_argument, 0, 'O'}, /* Obsolete */
413 {"output-target", required_argument, 0, 'O'},
414 {"pad-to", required_argument, 0, OPTION_PAD_TO},
d7fb0dd2
NC
415 {"prefix-symbols", required_argument, 0, OPTION_PREFIX_SYMBOLS},
416 {"prefix-sections", required_argument, 0, OPTION_PREFIX_SECTIONS},
417 {"prefix-alloc-sections", required_argument, 0, OPTION_PREFIX_ALLOC_SECTIONS},
252b5132 418 {"preserve-dates", no_argument, 0, 'p'},
4087920c
MR
419 {"pure", no_argument, 0, OPTION_PURE},
420 {"readonly-text", no_argument, 0, OPTION_READONLY_TEXT},
d7fb0dd2 421 {"redefine-sym", required_argument, 0, OPTION_REDEFINE_SYM},
92991082 422 {"redefine-syms", required_argument, 0, OPTION_REDEFINE_SYMS},
252b5132
RH
423 {"remove-leading-char", no_argument, 0, OPTION_REMOVE_LEADING_CHAR},
424 {"remove-section", required_argument, 0, 'R'},
594ef5db 425 {"rename-section", required_argument, 0, OPTION_RENAME_SECTION},
9e48b4c6 426 {"reverse-bytes", required_argument, 0, OPTION_REVERSE_BYTES},
252b5132
RH
427 {"set-section-flags", required_argument, 0, OPTION_SET_SECTION_FLAGS},
428 {"set-start", required_argument, 0, OPTION_SET_START},
d7fb0dd2
NC
429 {"srec-len", required_argument, 0, OPTION_SREC_LEN},
430 {"srec-forceS3", no_argument, 0, OPTION_SREC_FORCES3},
252b5132
RH
431 {"strip-all", no_argument, 0, 'S'},
432 {"strip-debug", no_argument, 0, 'g'},
96109726 433 {"strip-dwo", no_argument, 0, OPTION_STRIP_DWO},
252b5132 434 {"strip-unneeded", no_argument, 0, OPTION_STRIP_UNNEEDED},
bcf32829
JB
435 {"strip-unneeded-symbol", required_argument, 0, OPTION_STRIP_UNNEEDED_SYMBOL},
436 {"strip-unneeded-symbols", required_argument, 0, OPTION_STRIP_UNNEEDED_SYMBOLS},
252b5132 437 {"strip-symbol", required_argument, 0, 'N'},
d7fb0dd2 438 {"strip-symbols", required_argument, 0, OPTION_STRIP_SYMBOLS},
252b5132
RH
439 {"target", required_argument, 0, 'F'},
440 {"verbose", no_argument, 0, 'v'},
441 {"version", no_argument, 0, 'V'},
442 {"weaken", no_argument, 0, OPTION_WEAKEN},
443 {"weaken-symbol", required_argument, 0, 'W'},
16b2b71c 444 {"weaken-symbols", required_argument, 0, OPTION_WEAKEN_SYMBOLS},
5fe11841 445 {"wildcard", no_argument, 0, 'w'},
4087920c 446 {"writable-text", no_argument, 0, OPTION_WRITABLE_TEXT},
92dd4511
L
447 {"file-alignment", required_argument, 0, OPTION_FILE_ALIGNMENT},
448 {"heap", required_argument, 0, OPTION_HEAP},
449 {"image-base", required_argument, 0 , OPTION_IMAGE_BASE},
450 {"section-alignment", required_argument, 0, OPTION_SECTION_ALIGNMENT},
451 {"stack", required_argument, 0, OPTION_STACK},
452 {"subsystem", required_argument, 0, OPTION_SUBSYSTEM},
252b5132
RH
453 {0, no_argument, 0, 0}
454};
455
456/* IMPORTS */
457extern char *program_name;
458
459/* This flag distinguishes between strip and objcopy:
460 1 means this is 'strip'; 0 means this is 'objcopy'.
0af11b59 461 -1 means if we should use argv[0] to decide. */
252b5132
RH
462extern int is_strip;
463
420496c1
NC
464/* The maximum length of an S record. This variable is declared in srec.c
465 and can be modified by the --srec-len parameter. */
466extern unsigned int Chunk;
467
468/* Restrict the generation of Srecords to type S3 only.
469 This variable is declare in bfd/srec.c and can be toggled
470 on by the --srec-forceS3 command line switch. */
b34976b6 471extern bfd_boolean S3Forced;
252b5132 472
d3ba0551
AM
473/* Forward declarations. */
474static void setup_section (bfd *, asection *, void *);
80fccad2 475static void setup_bfd_headers (bfd *, bfd *);
c3989150 476static void copy_relocations_in_section (bfd *, asection *, void *);
d3ba0551
AM
477static void copy_section (bfd *, asection *, void *);
478static void get_sections (bfd *, asection *, void *);
479static int compare_section_lma (const void *, const void *);
480static void mark_symbols_used_in_relocations (bfd *, asection *, void *);
481static bfd_boolean write_debugging_info (bfd *, void *, long *, asymbol ***);
482static const char *lookup_sym_redefinition (const char *);
594ef5db 483\f
252b5132 484static void
84e2f313 485copy_usage (FILE *stream, int exit_status)
252b5132 486{
8b53311e
NC
487 fprintf (stream, _("Usage: %s [option(s)] in-file [out-file]\n"), program_name);
488 fprintf (stream, _(" Copies a binary file, possibly transforming it in the process\n"));
6364e0b4 489 fprintf (stream, _(" The options are:\n"));
252b5132 490 fprintf (stream, _("\
d5bcb29d
NC
491 -I --input-target <bfdname> Assume input file is in format <bfdname>\n\
492 -O --output-target <bfdname> Create an output file in format <bfdname>\n\
8b31b6c4 493 -B --binary-architecture <arch> Set output arch, when input is arch-less\n\
d5bcb29d
NC
494 -F --target <bfdname> Set both input and output format to <bfdname>\n\
495 --debugging Convert debugging information, if possible\n\
955d0b3b
RM
496 -p --preserve-dates Copy modified/access timestamps to the output\n"));
497 if (DEFAULT_AR_DETERMINISTIC)
498 fprintf (stream, _("\
499 -D --enable-deterministic-archives\n\
500 Produce deterministic output when stripping archives (default)\n\
501 -U --disable-deterministic-archives\n\
502 Disable -D behavior\n"));
503 else
504 fprintf (stream, _("\
2e30cb57
CC
505 -D --enable-deterministic-archives\n\
506 Produce deterministic output when stripping archives\n\
955d0b3b
RM
507 -U --disable-deterministic-archives\n\
508 Disable -D behavior (default)\n"));
509 fprintf (stream, _("\
d5bcb29d 510 -j --only-section <name> Only copy section <name> into the output\n\
2593f09a 511 --add-gnu-debuglink=<file> Add section .gnu_debuglink linking to <file>\n\
d5bcb29d
NC
512 -R --remove-section <name> Remove section <name> from the output\n\
513 -S --strip-all Remove all symbol and relocation information\n\
2593f09a 514 -g --strip-debug Remove all debugging symbols & sections\n\
96109726 515 --strip-dwo Remove all DWO sections\n\
d5bcb29d
NC
516 --strip-unneeded Remove all symbols not needed by relocations\n\
517 -N --strip-symbol <name> Do not copy symbol <name>\n\
bcf32829
JB
518 --strip-unneeded-symbol <name>\n\
519 Do not copy symbol <name> unless needed by\n\
520 relocations\n\
6ea3dd37 521 --only-keep-debug Strip everything but the debug information\n\
96109726 522 --extract-dwo Copy only DWO sections\n\
d3e52d40 523 --extract-symbol Remove section contents but keep symbols\n\
e7f918ad 524 -K --keep-symbol <name> Do not strip symbol <name>\n\
1637cd90 525 --keep-file-symbols Do not strip file symbol(s)\n\
d58c2e3a 526 --localize-hidden Turn all ELF hidden symbols into locals\n\
d5bcb29d 527 -L --localize-symbol <name> Force symbol <name> to be marked as a local\n\
7b4a0685 528 --globalize-symbol <name> Force symbol <name> to be marked as a global\n\
16b2b71c 529 -G --keep-global-symbol <name> Localize all symbols except <name>\n\
d5bcb29d
NC
530 -W --weaken-symbol <name> Force symbol <name> to be marked as a weak\n\
531 --weaken Force all global symbols to be marked as weak\n\
a95b5cf9 532 -w --wildcard Permit wildcard in symbol comparison\n\
d5bcb29d
NC
533 -x --discard-all Remove all non-global symbols\n\
534 -X --discard-locals Remove any compiler-generated symbols\n\
b7dd81f7
NC
535 -i --interleave [<number>] Only copy N out of every <number> bytes\n\
536 --interleave-width <number> Set N for --interleave\n\
d5bcb29d
NC
537 -b --byte <num> Select byte <num> in every interleaved block\n\
538 --gap-fill <val> Fill gaps between sections with <val>\n\
539 --pad-to <addr> Pad the last section up to address <addr>\n\
540 --set-start <addr> Set the start address to <addr>\n\
541 {--change-start|--adjust-start} <incr>\n\
542 Add <incr> to the start address\n\
543 {--change-addresses|--adjust-vma} <incr>\n\
544 Add <incr> to LMA, VMA and start addresses\n\
545 {--change-section-address|--adjust-section-vma} <name>{=|+|-}<val>\n\
546 Change LMA and VMA of section <name> by <val>\n\
547 --change-section-lma <name>{=|+|-}<val>\n\
548 Change the LMA of section <name> by <val>\n\
549 --change-section-vma <name>{=|+|-}<val>\n\
550 Change the VMA of section <name> by <val>\n\
551 {--[no-]change-warnings|--[no-]adjust-warnings}\n\
552 Warn if a named section does not exist\n\
553 --set-section-flags <name>=<flags>\n\
554 Set section <name>'s properties to <flags>\n\
555 --add-section <name>=<file> Add section <name> found in <file> to output\n\
bbad633b 556 --dump-section <name>=<file> Dump the contents of section <name> into <file>\n\
594ef5db 557 --rename-section <old>=<new>[,<flags>] Rename section <old> to <new>\n\
0408dee6
DK
558 --long-section-names {enable|disable|keep}\n\
559 Handle long section names in Coff objects.\n\
d5bcb29d
NC
560 --change-leading-char Force output format's leading character style\n\
561 --remove-leading-char Remove leading character from global symbols\n\
9e48b4c6 562 --reverse-bytes=<num> Reverse <num> bytes at a time, in output sections with content\n\
57938635 563 --redefine-sym <old>=<new> Redefine symbol name <old> to <new>\n\
92991082
JT
564 --redefine-syms <file> --redefine-sym for all symbol pairs \n\
565 listed in <file>\n\
420496c1
NC
566 --srec-len <number> Restrict the length of generated Srecords\n\
567 --srec-forceS3 Restrict the type of generated Srecords to S3\n\
16b2b71c 568 --strip-symbols <file> -N for all symbols listed in <file>\n\
bcf32829
JB
569 --strip-unneeded-symbols <file>\n\
570 --strip-unneeded-symbol for all symbols listed\n\
571 in <file>\n\
16b2b71c
NC
572 --keep-symbols <file> -K for all symbols listed in <file>\n\
573 --localize-symbols <file> -L for all symbols listed in <file>\n\
7b4a0685 574 --globalize-symbols <file> --globalize-symbol for all in <file>\n\
16b2b71c
NC
575 --keep-global-symbols <file> -G for all symbols listed in <file>\n\
576 --weaken-symbols <file> -W for all symbols listed in <file>\n\
f9d4ad2a 577 --alt-machine-code <index> Use the target's <index>'th alternative machine\n\
4087920c
MR
578 --writable-text Mark the output text as writable\n\
579 --readonly-text Make the output text write protected\n\
580 --pure Mark the output file as demand paged\n\
581 --impure Mark the output file as impure\n\
d7fb0dd2
NC
582 --prefix-symbols <prefix> Add <prefix> to start of every symbol name\n\
583 --prefix-sections <prefix> Add <prefix> to start of every section name\n\
584 --prefix-alloc-sections <prefix>\n\
585 Add <prefix> to start of every allocatable\n\
586 section name\n\
92dd4511
L
587 --file-alignment <num> Set PE file alignment to <num>\n\
588 --heap <reserve>[,<commit>] Set PE reserve/commit heap to <reserve>/\n\
589 <commit>\n\
590 --image-base <address> Set PE image base to <address>\n\
591 --section-alignment <num> Set PE section alignment to <num>\n\
592 --stack <reserve>[,<commit>] Set PE reserve/commit stack to <reserve>/\n\
593 <commit>\n\
594 --subsystem <name>[:<version>]\n\
447049af 595 Set PE subsystem to <name> [& <version>]\n\
4a114e3e
L
596 --compress-debug-sections Compress DWARF debug sections using zlib\n\
597 --decompress-debug-sections Decompress DWARF debug sections using zlib\n\
d5bcb29d 598 -v --verbose List all object files modified\n\
07012eee 599 @<file> Read options from <file>\n\
d5bcb29d
NC
600 -V --version Display this program's version number\n\
601 -h --help Display this output\n\
7c29036b 602 --info List object formats & architectures supported\n\
d5bcb29d 603"));
252b5132 604 list_supported_targets (program_name, stream);
92f01d61 605 if (REPORT_BUGS_TO[0] && exit_status == 0)
8ad3436c 606 fprintf (stream, _("Report bugs to %s\n"), REPORT_BUGS_TO);
252b5132
RH
607 exit (exit_status);
608}
609
610static void
84e2f313 611strip_usage (FILE *stream, int exit_status)
252b5132 612{
8b53311e
NC
613 fprintf (stream, _("Usage: %s <option(s)> in-file(s)\n"), program_name);
614 fprintf (stream, _(" Removes symbols and sections from files\n"));
6364e0b4 615 fprintf (stream, _(" The options are:\n"));
252b5132 616 fprintf (stream, _("\
8b53311e
NC
617 -I --input-target=<bfdname> Assume input file is in format <bfdname>\n\
618 -O --output-target=<bfdname> Create an output file in format <bfdname>\n\
619 -F --target=<bfdname> Set both input and output format to <bfdname>\n\
d5bcb29d 620 -p --preserve-dates Copy modified/access timestamps to the output\n\
955d0b3b
RM
621"));
622 if (DEFAULT_AR_DETERMINISTIC)
623 fprintf (stream, _("\
624 -D --enable-deterministic-archives\n\
625 Produce deterministic output when stripping archives (default)\n\
626 -U --disable-deterministic-archives\n\
627 Disable -D behavior\n"));
628 else
629 fprintf (stream, _("\
2e30cb57
CC
630 -D --enable-deterministic-archives\n\
631 Produce deterministic output when stripping archives\n\
955d0b3b
RM
632 -U --disable-deterministic-archives\n\
633 Disable -D behavior (default)\n"));
634 fprintf (stream, _("\
805b1c8b 635 -R --remove-section=<name> Also remove section <name> from the output\n\
d5bcb29d 636 -s --strip-all Remove all symbol and relocation information\n\
2593f09a 637 -g -S -d --strip-debug Remove all debugging symbols & sections\n\
96109726 638 --strip-dwo Remove all DWO sections\n\
d5bcb29d 639 --strip-unneeded Remove all symbols not needed by relocations\n\
6ea3dd37 640 --only-keep-debug Strip everything but the debug information\n\
8b53311e 641 -N --strip-symbol=<name> Do not copy symbol <name>\n\
5219e4c0 642 -K --keep-symbol=<name> Do not strip symbol <name>\n\
1637cd90 643 --keep-file-symbols Do not strip file symbol(s)\n\
a95b5cf9 644 -w --wildcard Permit wildcard in symbol comparison\n\
d5bcb29d
NC
645 -x --discard-all Remove all non-global symbols\n\
646 -X --discard-locals Remove any compiler-generated symbols\n\
647 -v --verbose List all object files modified\n\
648 -V --version Display this program's version number\n\
649 -h --help Display this output\n\
7c29036b 650 --info List object formats & architectures supported\n\
d5bcb29d
NC
651 -o <file> Place stripped output into <file>\n\
652"));
653
252b5132 654 list_supported_targets (program_name, stream);
92f01d61 655 if (REPORT_BUGS_TO[0] && exit_status == 0)
8ad3436c 656 fprintf (stream, _("Report bugs to %s\n"), REPORT_BUGS_TO);
252b5132
RH
657 exit (exit_status);
658}
659
660/* Parse section flags into a flagword, with a fatal error if the
661 string can't be parsed. */
662
663static flagword
84e2f313 664parse_flags (const char *s)
252b5132
RH
665{
666 flagword ret;
667 const char *snext;
668 int len;
669
670 ret = SEC_NO_FLAGS;
671
672 do
673 {
674 snext = strchr (s, ',');
675 if (snext == NULL)
676 len = strlen (s);
677 else
678 {
679 len = snext - s;
680 ++snext;
681 }
682
683 if (0) ;
684#define PARSE_FLAG(fname,fval) \
685 else if (strncasecmp (fname, s, len) == 0) ret |= fval
686 PARSE_FLAG ("alloc", SEC_ALLOC);
687 PARSE_FLAG ("load", SEC_LOAD);
3994e2c6 688 PARSE_FLAG ("noload", SEC_NEVER_LOAD);
252b5132 689 PARSE_FLAG ("readonly", SEC_READONLY);
3994e2c6 690 PARSE_FLAG ("debug", SEC_DEBUGGING);
252b5132
RH
691 PARSE_FLAG ("code", SEC_CODE);
692 PARSE_FLAG ("data", SEC_DATA);
693 PARSE_FLAG ("rom", SEC_ROM);
ebe372c1 694 PARSE_FLAG ("share", SEC_COFF_SHARED);
252b5132 695 PARSE_FLAG ("contents", SEC_HAS_CONTENTS);
5dddde8e
AM
696 PARSE_FLAG ("merge", SEC_MERGE);
697 PARSE_FLAG ("strings", SEC_STRINGS);
252b5132
RH
698#undef PARSE_FLAG
699 else
700 {
701 char *copy;
702
3f5e193b 703 copy = (char *) xmalloc (len + 1);
252b5132
RH
704 strncpy (copy, s, len);
705 copy[len] = '\0';
706 non_fatal (_("unrecognized section flag `%s'"), copy);
57938635 707 fatal (_("supported flags: %s"),
5dddde8e 708 "alloc, load, noload, readonly, debug, code, data, rom, share, contents, merge, strings");
252b5132
RH
709 }
710
711 s = snext;
712 }
713 while (s != NULL);
714
715 return ret;
716}
717
2e62b721
NC
718/* Find and optionally add an entry in the change_sections list.
719
720 We need to be careful in how we match section names because of the support
721 for wildcard characters. For example suppose that the user has invoked
722 objcopy like this:
723
724 --set-section-flags .debug_*=debug
725 --set-section-flags .debug_str=readonly,debug
726 --change-section-address .debug_*ranges=0x1000
727
728 With the idea that all debug sections will receive the DEBUG flag, the
729 .debug_str section will also receive the READONLY flag and the
730 .debug_ranges and .debug_aranges sections will have their address set to
731 0x1000. (This may not make much sense, but it is just an example).
732
733 When adding the section name patterns to the section list we need to make
734 sure that previous entries do not match with the new entry, unless the
735 match is exact. (In which case we assume that the user is overriding
736 the previous entry with the new context).
737
738 When matching real section names to the section list we make use of the
739 wildcard characters, but we must do so in context. Eg if we are setting
740 section addresses then we match for .debug_ranges but not for .debug_info.
741
742 Finally, if ADD is false and we do find a match, we mark the section list
743 entry as used. */
252b5132
RH
744
745static struct section_list *
2e62b721 746find_section_list (const char *name, bfd_boolean add, unsigned int context)
252b5132 747{
84e2f313 748 struct section_list *p;
252b5132 749
2e62b721
NC
750 /* assert ((context & ((1 << 7) - 1)) != 0); */
751
252b5132 752 for (p = change_sections; p != NULL; p = p->next)
2e62b721
NC
753 {
754 if (add)
755 {
756 if (strcmp (p->pattern, name) == 0)
757 {
758 /* Check for context conflicts. */
759 if (((p->context & SECTION_CONTEXT_REMOVE)
760 && (context & SECTION_CONTEXT_COPY))
761 || ((context & SECTION_CONTEXT_REMOVE)
762 && (p->context & SECTION_CONTEXT_COPY)))
763 fatal (_("error: %s both copied and removed"), name);
764
765 if (((p->context & SECTION_CONTEXT_SET_VMA)
766 && (context & SECTION_CONTEXT_ALTER_VMA))
767 || ((context & SECTION_CONTEXT_SET_VMA)
768 && (context & SECTION_CONTEXT_ALTER_VMA)))
769 fatal (_("error: %s both sets and alters VMA"), name);
770
771 if (((p->context & SECTION_CONTEXT_SET_LMA)
772 && (context & SECTION_CONTEXT_ALTER_LMA))
773 || ((context & SECTION_CONTEXT_SET_LMA)
774 && (context & SECTION_CONTEXT_ALTER_LMA)))
775 fatal (_("error: %s both sets and alters LMA"), name);
776
777 /* Extend the context. */
778 p->context |= context;
779 return p;
780 }
781 }
782 /* If we are not adding a new name/pattern then
783 only check for a match if the context applies. */
784 else if ((p->context & context)
785 /* We could check for the presence of wildchar characters
786 first and choose between calling strcmp and fnmatch,
787 but is that really worth it ? */
788 && fnmatch (p->pattern, name, 0) == 0)
789 {
790 p->used = TRUE;
791 return p;
792 }
793 }
252b5132
RH
794
795 if (! add)
796 return NULL;
797
3f5e193b 798 p = (struct section_list *) xmalloc (sizeof (struct section_list));
2e62b721 799 p->pattern = name;
b34976b6 800 p->used = FALSE;
2e62b721 801 p->context = context;
252b5132
RH
802 p->vma_val = 0;
803 p->lma_val = 0;
252b5132 804 p->flags = 0;
252b5132
RH
805 p->next = change_sections;
806 change_sections = p;
807
808 return p;
809}
810
047c9024
NC
811/* There is htab_hash_string but no htab_eq_string. Makes sense. */
812
813static int
814eq_string (const void *s1, const void *s2)
815{
3f5e193b 816 return strcmp ((const char *) s1, (const char *) s2) == 0;
047c9024
NC
817}
818
819static htab_t
820create_symbol_htab (void)
821{
822 return htab_create_alloc (16, htab_hash_string, eq_string, NULL, xcalloc, free);
823}
252b5132 824
57938635 825static void
047c9024 826create_symbol_htabs (void)
252b5132 827{
047c9024
NC
828 strip_specific_htab = create_symbol_htab ();
829 strip_unneeded_htab = create_symbol_htab ();
830 keep_specific_htab = create_symbol_htab ();
831 localize_specific_htab = create_symbol_htab ();
832 globalize_specific_htab = create_symbol_htab ();
833 keepglobal_specific_htab = create_symbol_htab ();
834 weaken_specific_htab = create_symbol_htab ();
835}
836
837/* Add a symbol to strip_specific_list. */
252b5132 838
047c9024
NC
839static void
840add_specific_symbol (const char *name, htab_t htab)
841{
842 *htab_find_slot (htab, name, INSERT) = (char *) name;
252b5132
RH
843}
844
0af11b59 845/* Add symbols listed in `filename' to strip_specific_list. */
16b2b71c
NC
846
847#define IS_WHITESPACE(c) ((c) == ' ' || (c) == '\t')
848#define IS_LINE_TERMINATOR(c) ((c) == '\n' || (c) == '\r' || (c) == '\0')
849
850static void
047c9024 851add_specific_symbols (const char *filename, htab_t htab)
16b2b71c 852{
f24ddbdd 853 off_t size;
16b2b71c
NC
854 FILE * f;
855 char * line;
856 char * buffer;
857 unsigned int line_count;
0af11b59 858
f24ddbdd
NC
859 size = get_file_size (filename);
860 if (size == 0)
d68c385b
NC
861 {
862 status = 1;
863 return;
864 }
16b2b71c 865
3f5e193b 866 buffer = (char *) xmalloc (size + 2);
16b2b71c
NC
867 f = fopen (filename, FOPEN_RT);
868 if (f == NULL)
f24ddbdd 869 fatal (_("cannot open '%s': %s"), filename, strerror (errno));
16b2b71c 870
f24ddbdd 871 if (fread (buffer, 1, size, f) == 0 || ferror (f))
16b2b71c
NC
872 fatal (_("%s: fread failed"), filename);
873
874 fclose (f);
f24ddbdd
NC
875 buffer [size] = '\n';
876 buffer [size + 1] = '\0';
16b2b71c
NC
877
878 line_count = 1;
0af11b59 879
16b2b71c
NC
880 for (line = buffer; * line != '\0'; line ++)
881 {
882 char * eol;
883 char * name;
884 char * name_end;
b34976b6 885 int finished = FALSE;
16b2b71c
NC
886
887 for (eol = line;; eol ++)
888 {
889 switch (* eol)
890 {
891 case '\n':
892 * eol = '\0';
893 /* Cope with \n\r. */
894 if (eol[1] == '\r')
895 ++ eol;
b34976b6 896 finished = TRUE;
16b2b71c 897 break;
0af11b59 898
16b2b71c
NC
899 case '\r':
900 * eol = '\0';
901 /* Cope with \r\n. */
902 if (eol[1] == '\n')
903 ++ eol;
b34976b6 904 finished = TRUE;
16b2b71c 905 break;
0af11b59 906
16b2b71c 907 case 0:
b34976b6 908 finished = TRUE;
16b2b71c 909 break;
0af11b59 910
16b2b71c
NC
911 case '#':
912 /* Line comment, Terminate the line here, in case a
913 name is present and then allow the rest of the
914 loop to find the real end of the line. */
915 * eol = '\0';
916 break;
0af11b59 917
16b2b71c
NC
918 default:
919 break;
920 }
921
922 if (finished)
923 break;
924 }
925
926 /* A name may now exist somewhere between 'line' and 'eol'.
927 Strip off leading whitespace and trailing whitespace,
928 then add it to the list. */
929 for (name = line; IS_WHITESPACE (* name); name ++)
930 ;
931 for (name_end = name;
932 (! IS_WHITESPACE (* name_end))
933 && (! IS_LINE_TERMINATOR (* name_end));
0af11b59
KH
934 name_end ++)
935 ;
16b2b71c
NC
936
937 if (! IS_LINE_TERMINATOR (* name_end))
938 {
939 char * extra;
940
941 for (extra = name_end + 1; IS_WHITESPACE (* extra); extra ++)
942 ;
943
944 if (! IS_LINE_TERMINATOR (* extra))
d412a550
NC
945 non_fatal (_("%s:%d: Ignoring rubbish found on this line"),
946 filename, line_count);
16b2b71c 947 }
0af11b59 948
16b2b71c
NC
949 * name_end = '\0';
950
951 if (name_end > name)
047c9024 952 add_specific_symbol (name, htab);
16b2b71c
NC
953
954 /* Advance line pointer to end of line. The 'eol ++' in the for
955 loop above will then advance us to the start of the next line. */
956 line = eol;
957 line_count ++;
958 }
959}
960
047c9024
NC
961/* See whether a symbol should be stripped or kept
962 based on strip_specific_list and keep_symbols. */
252b5132 963
047c9024
NC
964static int
965is_specified_symbol_predicate (void **slot, void *data)
252b5132 966{
3f5e193b
NC
967 struct is_specified_symbol_predicate_data *d =
968 (struct is_specified_symbol_predicate_data *) data;
969 const char *slot_name = (char *) *slot;
252b5132 970
047c9024 971 if (*slot_name != '!')
5fe11841 972 {
047c9024
NC
973 if (! fnmatch (slot_name, d->name, 0))
974 {
975 d->found = TRUE;
976 /* Stop traversal. */
977 return 0;
978 }
5fe11841
NC
979 }
980 else
981 {
047c9024
NC
982 if (fnmatch (slot_name + 1, d->name, 0))
983 {
984 d->found = TRUE;
985 /* Stop traversal. */
986 return 0;
987 }
5fe11841 988 }
594ef5db 989
047c9024
NC
990 /* Continue traversal. */
991 return 1;
992}
993
994static bfd_boolean
995is_specified_symbol (const char *name, htab_t htab)
996{
997 if (wildcard)
998 {
999 struct is_specified_symbol_predicate_data data;
1000
1001 data.name = name;
1002 data.found = FALSE;
1003
1004 htab_traverse (htab, is_specified_symbol_predicate, &data);
1005
1006 return data.found;
1007 }
1008
1009 return htab_find (htab, name) != NULL;
252b5132
RH
1010}
1011
30288845
AM
1012/* Return a pointer to the symbol used as a signature for GROUP. */
1013
1014static asymbol *
1015group_signature (asection *group)
1016{
1017 bfd *abfd = group->owner;
1018 Elf_Internal_Shdr *ghdr;
1019
1020 if (bfd_get_flavour (abfd) != bfd_target_elf_flavour)
1021 return NULL;
1022
1023 ghdr = &elf_section_data (group)->this_hdr;
1024 if (ghdr->sh_link < elf_numsections (abfd))
1025 {
1026 const struct elf_backend_data *bed = get_elf_backend_data (abfd);
1027 Elf_Internal_Shdr *symhdr = elf_elfsections (abfd) [ghdr->sh_link];
1028
1029 if (symhdr->sh_type == SHT_SYMTAB
1030 && ghdr->sh_info < symhdr->sh_size / bed->s->sizeof_sym)
748fc5e9 1031 return isympp[ghdr->sh_info - 1];
30288845
AM
1032 }
1033 return NULL;
1034}
1035
96109726
CC
1036/* Return TRUE if the section is a DWO section. */
1037
1038static bfd_boolean
1039is_dwo_section (bfd *abfd ATTRIBUTE_UNUSED, asection *sec)
1040{
1041 const char *name = bfd_get_section_name (abfd, sec);
1042 int len = strlen (name);
1043
1044 return strncmp (name + len - 4, ".dwo", 4) == 0;
1045}
1046
4c8e8a7e 1047/* See if a non-group section is being removed. */
252b5132 1048
b34976b6 1049static bfd_boolean
4c8e8a7e 1050is_strip_section_1 (bfd *abfd ATTRIBUTE_UNUSED, asection *sec)
252b5132 1051{
2593f09a
NC
1052 if (sections_removed || sections_copied)
1053 {
1054 struct section_list *p;
2e62b721 1055 struct section_list *q;
2593f09a 1056
2e62b721
NC
1057 p = find_section_list (bfd_get_section_name (abfd, sec), FALSE,
1058 SECTION_CONTEXT_REMOVE);
1059 q = find_section_list (bfd_get_section_name (abfd, sec), FALSE,
1060 SECTION_CONTEXT_COPY);
2593f09a 1061
2e62b721
NC
1062 if (p && q)
1063 fatal (_("error: section %s matches both remove and copy options"),
1064 bfd_get_section_name (abfd, sec));
1065
1066 if (p != NULL)
2593f09a 1067 return TRUE;
2e62b721 1068 if (sections_copied && q == NULL)
2593f09a
NC
1069 return TRUE;
1070 }
252b5132 1071
2593f09a
NC
1072 if ((bfd_get_section_flags (abfd, sec) & SEC_DEBUGGING) != 0)
1073 {
1074 if (strip_symbols == STRIP_DEBUG
252b5132
RH
1075 || strip_symbols == STRIP_UNNEEDED
1076 || strip_symbols == STRIP_ALL
1077 || discard_locals == LOCALS_ALL
2593f09a 1078 || convert_debugging)
4fc8b895
KT
1079 {
1080 /* By default we don't want to strip .reloc section.
1081 This section has for pe-coff special meaning. See
1082 pe-dll.c file in ld, and peXXigen.c in bfd for details. */
1083 if (strcmp (bfd_get_section_name (abfd, sec), ".reloc") != 0)
1084 return TRUE;
1085 }
ed1653a7 1086
96109726
CC
1087 if (strip_symbols == STRIP_DWO)
1088 return is_dwo_section (abfd, sec);
1089
ed1653a7
NC
1090 if (strip_symbols == STRIP_NONDEBUG)
1091 return FALSE;
2593f09a 1092 }
f91ea849 1093
96109726
CC
1094 if (strip_symbols == STRIP_NONDWO)
1095 return !is_dwo_section (abfd, sec);
1096
4c8e8a7e
L
1097 return FALSE;
1098}
1099
1100/* See if a section is being removed. */
1101
1102static bfd_boolean
1103is_strip_section (bfd *abfd ATTRIBUTE_UNUSED, asection *sec)
1104{
1105 if (is_strip_section_1 (abfd, sec))
1106 return TRUE;
1107
30288845
AM
1108 if ((bfd_get_section_flags (abfd, sec) & SEC_GROUP) != 0)
1109 {
1110 asymbol *gsym;
1111 const char *gname;
4c8e8a7e 1112 asection *elt, *first;
30288845 1113
30288845
AM
1114 /* PR binutils/3181
1115 If we are going to strip the group signature symbol, then
1116 strip the group section too. */
1117 gsym = group_signature (sec);
1118 if (gsym != NULL)
1119 gname = gsym->name;
1120 else
1121 gname = sec->name;
1122 if ((strip_symbols == STRIP_ALL
047c9024
NC
1123 && !is_specified_symbol (gname, keep_specific_htab))
1124 || is_specified_symbol (gname, strip_specific_htab))
30288845 1125 return TRUE;
4c8e8a7e
L
1126
1127 /* Remove the group section if all members are removed. */
1128 first = elt = elf_next_in_group (sec);
1129 while (elt != NULL)
1130 {
1131 if (!is_strip_section_1 (abfd, elt))
1132 return FALSE;
1133 elt = elf_next_in_group (elt);
1134 if (elt == first)
1135 break;
1136 }
1137
1138 return TRUE;
30288845 1139 }
91bb255c 1140
f0312d39 1141 return FALSE;
252b5132
RH
1142}
1143
6e6e7cfc
JT
1144static bfd_boolean
1145is_nondebug_keep_contents_section (bfd *ibfd, asection *isection)
1146{
1147 /* Always keep ELF note sections. */
1148 if (ibfd->xvec->flavour == bfd_target_elf_flavour)
1149 return (elf_section_type (isection) == SHT_NOTE);
1150
74fffc39 1151 /* Always keep the .buildid section for PE/COFF.
6e6e7cfc
JT
1152
1153 Strictly, this should be written "always keep the section storing the debug
1154 directory", but that may be the .text section for objects produced by some
1155 tools, which it is not sensible to keep. */
1156 if (ibfd->xvec->flavour == bfd_target_coff_flavour)
74fffc39 1157 return (strcmp (bfd_get_section_name (ibfd, isection), ".buildid") == 0);
6e6e7cfc
JT
1158
1159 return FALSE;
1160}
1161
d58c2e3a
RS
1162/* Return true if SYM is a hidden symbol. */
1163
1164static bfd_boolean
1165is_hidden_symbol (asymbol *sym)
1166{
1167 elf_symbol_type *elf_sym;
1168
1169 elf_sym = elf_symbol_from (sym->the_bfd, sym);
1170 if (elf_sym != NULL)
1171 switch (ELF_ST_VISIBILITY (elf_sym->internal_elf_sym.st_other))
1172 {
1173 case STV_HIDDEN:
1174 case STV_INTERNAL:
1175 return TRUE;
1176 }
1177 return FALSE;
1178}
1179
252b5132
RH
1180/* Choose which symbol entries to copy; put the result in OSYMS.
1181 We don't copy in place, because that confuses the relocs.
1182 Return the number of symbols to print. */
1183
1184static unsigned int
84e2f313
NC
1185filter_symbols (bfd *abfd, bfd *obfd, asymbol **osyms,
1186 asymbol **isyms, long symcount)
252b5132 1187{
84e2f313 1188 asymbol **from = isyms, **to = osyms;
252b5132 1189 long src_count = 0, dst_count = 0;
e205a099 1190 int relocatable = (abfd->flags & (EXEC_P | DYNAMIC)) == 0;
252b5132
RH
1191
1192 for (; src_count < symcount; src_count++)
1193 {
1194 asymbol *sym = from[src_count];
1195 flagword flags = sym->flags;
d7fb0dd2 1196 char *name = (char *) bfd_asymbol_name (sym);
312aaa3c
NC
1197 bfd_boolean keep;
1198 bfd_boolean used_in_reloc = FALSE;
b34976b6 1199 bfd_boolean undefined;
d7fb0dd2
NC
1200 bfd_boolean rem_leading_char;
1201 bfd_boolean add_leading_char;
1202
1203 undefined = bfd_is_und_section (bfd_get_section (sym));
252b5132 1204
57938635
AM
1205 if (redefine_sym_list)
1206 {
d7fb0dd2 1207 char *old_name, *new_name;
57938635 1208
d7fb0dd2
NC
1209 old_name = (char *) bfd_asymbol_name (sym);
1210 new_name = (char *) lookup_sym_redefinition (old_name);
66491ebc
AM
1211 bfd_asymbol_name (sym) = new_name;
1212 name = new_name;
57938635
AM
1213 }
1214
d7fb0dd2
NC
1215 /* Check if we will remove the current leading character. */
1216 rem_leading_char =
1217 (name[0] == bfd_get_symbol_leading_char (abfd))
1218 && (change_leading_char
1219 || (remove_leading_char
1220 && ((flags & (BSF_GLOBAL | BSF_WEAK)) != 0
1221 || undefined
1222 || bfd_is_com_section (bfd_get_section (sym)))));
1223
1224 /* Check if we will add a new leading character. */
1225 add_leading_char =
1226 change_leading_char
1227 && (bfd_get_symbol_leading_char (obfd) != '\0')
1228 && (bfd_get_symbol_leading_char (abfd) == '\0'
1229 || (name[0] == bfd_get_symbol_leading_char (abfd)));
1230
1231 /* Short circuit for change_leading_char if we can do it in-place. */
1232 if (rem_leading_char && add_leading_char && !prefix_symbols_string)
1233 {
1234 name[0] = bfd_get_symbol_leading_char (obfd);
1235 bfd_asymbol_name (sym) = name;
1236 rem_leading_char = FALSE;
1237 add_leading_char = FALSE;
1238 }
1239
1240 /* Remove leading char. */
1241 if (rem_leading_char)
66491ebc 1242 bfd_asymbol_name (sym) = ++name;
d7fb0dd2
NC
1243
1244 /* Add new leading char and/or prefix. */
1245 if (add_leading_char || prefix_symbols_string)
1246 {
1247 char *n, *ptr;
1248
3f5e193b
NC
1249 ptr = n = (char *) xmalloc (1 + strlen (prefix_symbols_string)
1250 + strlen (name) + 1);
d7fb0dd2
NC
1251 if (add_leading_char)
1252 *ptr++ = bfd_get_symbol_leading_char (obfd);
1253
1254 if (prefix_symbols_string)
1255 {
1256 strcpy (ptr, prefix_symbols_string);
1257 ptr += strlen (prefix_symbols_string);
1258 }
1259
1260 strcpy (ptr, name);
66491ebc
AM
1261 bfd_asymbol_name (sym) = n;
1262 name = n;
252b5132
RH
1263 }
1264
252b5132 1265 if (strip_symbols == STRIP_ALL)
312aaa3c 1266 keep = FALSE;
252b5132
RH
1267 else if ((flags & BSF_KEEP) != 0 /* Used in relocation. */
1268 || ((flags & BSF_SECTION_SYM) != 0
1269 && ((*bfd_get_section (sym)->symbol_ptr_ptr)->flags
1270 & BSF_KEEP) != 0))
312aaa3c
NC
1271 {
1272 keep = TRUE;
1273 used_in_reloc = TRUE;
1274 }
0af11b59 1275 else if (relocatable /* Relocatable file. */
0691f7af
L
1276 && ((flags & (BSF_GLOBAL | BSF_WEAK)) != 0
1277 || bfd_is_com_section (bfd_get_section (sym))))
312aaa3c 1278 keep = TRUE;
16b2b71c
NC
1279 else if (bfd_decode_symclass (sym) == 'I')
1280 /* Global symbols in $idata sections need to be retained
b34976b6 1281 even if relocatable is FALSE. External users of the
16b2b71c
NC
1282 library containing the $idata section may reference these
1283 symbols. */
312aaa3c 1284 keep = TRUE;
252b5132
RH
1285 else if ((flags & BSF_GLOBAL) != 0 /* Global symbol. */
1286 || (flags & BSF_WEAK) != 0
24e01a36 1287 || undefined
252b5132
RH
1288 || bfd_is_com_section (bfd_get_section (sym)))
1289 keep = strip_symbols != STRIP_UNNEEDED;
1290 else if ((flags & BSF_DEBUGGING) != 0) /* Debugging symbol. */
1291 keep = (strip_symbols != STRIP_DEBUG
1292 && strip_symbols != STRIP_UNNEEDED
1293 && ! convert_debugging);
082b7297 1294 else if (bfd_coff_get_comdat_section (abfd, bfd_get_section (sym)))
af3bdff7
NC
1295 /* COMDAT sections store special information in local
1296 symbols, so we cannot risk stripping any of them. */
312aaa3c 1297 keep = TRUE;
252b5132
RH
1298 else /* Local symbol. */
1299 keep = (strip_symbols != STRIP_UNNEEDED
1300 && (discard_locals != LOCALS_ALL
1301 && (discard_locals != LOCALS_START_L
1302 || ! bfd_is_local_label (abfd, sym))));
1303
047c9024 1304 if (keep && is_specified_symbol (name, strip_specific_htab))
312aaa3c
NC
1305 {
1306 /* There are multiple ways to set 'keep' above, but if it
1307 was the relocatable symbol case, then that's an error. */
1308 if (used_in_reloc)
1309 {
1310 non_fatal (_("not stripping symbol `%s' because it is named in a relocation"), name);
1311 status = 1;
1312 }
1313 else
1314 keep = FALSE;
1315 }
1316
bcf32829
JB
1317 if (keep
1318 && !(flags & BSF_KEEP)
047c9024 1319 && is_specified_symbol (name, strip_unneeded_htab))
312aaa3c
NC
1320 keep = FALSE;
1321
1637cd90
JB
1322 if (!keep
1323 && ((keep_file_symbols && (flags & BSF_FILE))
047c9024 1324 || is_specified_symbol (name, keep_specific_htab)))
312aaa3c
NC
1325 keep = TRUE;
1326
252b5132 1327 if (keep && is_strip_section (abfd, bfd_get_section (sym)))
312aaa3c 1328 keep = FALSE;
e0c60db2 1329
7b4a0685 1330 if (keep)
252b5132 1331 {
7b4a0685 1332 if ((flags & BSF_GLOBAL) != 0
047c9024 1333 && (weaken || is_specified_symbol (name, weaken_specific_htab)))
7b4a0685
NC
1334 {
1335 sym->flags &= ~ BSF_GLOBAL;
1336 sym->flags |= BSF_WEAK;
1337 }
252b5132 1338
7b4a0685
NC
1339 if (!undefined
1340 && (flags & (BSF_GLOBAL | BSF_WEAK))
047c9024
NC
1341 && (is_specified_symbol (name, localize_specific_htab)
1342 || (htab_elements (keepglobal_specific_htab) != 0
1343 && ! is_specified_symbol (name, keepglobal_specific_htab))
d58c2e3a 1344 || (localize_hidden && is_hidden_symbol (sym))))
7b4a0685
NC
1345 {
1346 sym->flags &= ~ (BSF_GLOBAL | BSF_WEAK);
1347 sym->flags |= BSF_LOCAL;
1348 }
1349
1350 if (!undefined
c1c0eb9e 1351 && (flags & BSF_LOCAL)
047c9024 1352 && is_specified_symbol (name, globalize_specific_htab))
7b4a0685
NC
1353 {
1354 sym->flags &= ~ BSF_LOCAL;
1355 sym->flags |= BSF_GLOBAL;
1356 }
1357
1358 to[dst_count++] = sym;
1359 }
252b5132
RH
1360 }
1361
1362 to[dst_count] = NULL;
1363
1364 return dst_count;
1365}
1366
594ef5db
NC
1367/* Find the redefined name of symbol SOURCE. */
1368
57938635 1369static const char *
84e2f313 1370lookup_sym_redefinition (const char *source)
57938635 1371{
57938635
AM
1372 struct redefine_node *list;
1373
57938635 1374 for (list = redefine_sym_list; list != NULL; list = list->next)
594ef5db
NC
1375 if (strcmp (source, list->source) == 0)
1376 return list->target;
1377
1378 return source;
57938635
AM
1379}
1380
594ef5db 1381/* Add a node to a symbol redefine list. */
57938635
AM
1382
1383static void
84e2f313 1384redefine_list_append (const char *cause, const char *source, const char *target)
57938635
AM
1385{
1386 struct redefine_node **p;
1387 struct redefine_node *list;
1388 struct redefine_node *new_node;
1389
1390 for (p = &redefine_sym_list; (list = *p) != NULL; p = &list->next)
1391 {
1392 if (strcmp (source, list->source) == 0)
594ef5db 1393 fatal (_("%s: Multiple redefinition of symbol \"%s\""),
92991082 1394 cause, source);
57938635
AM
1395
1396 if (strcmp (target, list->target) == 0)
594ef5db 1397 fatal (_("%s: Symbol \"%s\" is target of more than one redefinition"),
92991082 1398 cause, target);
57938635
AM
1399 }
1400
3f5e193b 1401 new_node = (struct redefine_node *) xmalloc (sizeof (struct redefine_node));
57938635
AM
1402
1403 new_node->source = strdup (source);
1404 new_node->target = strdup (target);
1405 new_node->next = NULL;
1406
1407 *p = new_node;
1408}
1409
92991082
JT
1410/* Handle the --redefine-syms option. Read lines containing "old new"
1411 from the file, and add them to the symbol redefine list. */
1412
2593f09a 1413static void
84e2f313 1414add_redefine_syms_file (const char *filename)
92991082
JT
1415{
1416 FILE *file;
1417 char *buf;
84e2f313
NC
1418 size_t bufsize;
1419 size_t len;
1420 size_t outsym_off;
92991082
JT
1421 int c, lineno;
1422
1423 file = fopen (filename, "r");
d3ba0551 1424 if (file == NULL)
92991082
JT
1425 fatal (_("couldn't open symbol redefinition file %s (error: %s)"),
1426 filename, strerror (errno));
1427
1428 bufsize = 100;
a6da20b5 1429 buf = (char *) xmalloc (bufsize + 1 /* For the terminating NUL. */);
92991082
JT
1430
1431 lineno = 1;
1432 c = getc (file);
1433 len = 0;
1434 outsym_off = 0;
1435 while (c != EOF)
1436 {
1437 /* Collect the input symbol name. */
1438 while (! IS_WHITESPACE (c) && ! IS_LINE_TERMINATOR (c) && c != EOF)
1439 {
1440 if (c == '#')
1441 goto comment;
1442 buf[len++] = c;
1443 if (len >= bufsize)
1444 {
1445 bufsize *= 2;
a6da20b5 1446 buf = (char *) xrealloc (buf, bufsize + 1);
92991082
JT
1447 }
1448 c = getc (file);
1449 }
1450 buf[len++] = '\0';
1451 if (c == EOF)
1452 break;
1453
1454 /* Eat white space between the symbol names. */
1455 while (IS_WHITESPACE (c))
1456 c = getc (file);
1457 if (c == '#' || IS_LINE_TERMINATOR (c))
1458 goto comment;
1459 if (c == EOF)
1460 break;
1461
1462 /* Collect the output symbol name. */
1463 outsym_off = len;
1464 while (! IS_WHITESPACE (c) && ! IS_LINE_TERMINATOR (c) && c != EOF)
1465 {
1466 if (c == '#')
1467 goto comment;
1468 buf[len++] = c;
1469 if (len >= bufsize)
1470 {
1471 bufsize *= 2;
a6da20b5 1472 buf = (char *) xrealloc (buf, bufsize + 1);
92991082
JT
1473 }
1474 c = getc (file);
1475 }
1476 buf[len++] = '\0';
1477 if (c == EOF)
1478 break;
1479
1480 /* Eat white space at end of line. */
1481 while (! IS_LINE_TERMINATOR(c) && c != EOF && IS_WHITESPACE (c))
1482 c = getc (file);
1483 if (c == '#')
1484 goto comment;
1485 /* Handle \r\n. */
1486 if ((c == '\r' && (c = getc (file)) == '\n')
1487 || c == '\n' || c == EOF)
1488 {
1489 end_of_line:
1490 /* Append the redefinition to the list. */
1491 if (buf[0] != '\0')
1492 redefine_list_append (filename, &buf[0], &buf[outsym_off]);
1493
c1c0eb9e 1494 lineno++;
92991082
JT
1495 len = 0;
1496 outsym_off = 0;
1497 if (c == EOF)
1498 break;
1499 c = getc (file);
1500 continue;
1501 }
1502 else
d412a550 1503 fatal (_("%s:%d: garbage found at end of line"), filename, lineno);
92991082
JT
1504 comment:
1505 if (len != 0 && (outsym_off == 0 || outsym_off == len))
d412a550 1506 fatal (_("%s:%d: missing new symbol name"), filename, lineno);
92991082
JT
1507 buf[len++] = '\0';
1508
1509 /* Eat the rest of the line and finish it. */
1510 while (c != '\n' && c != EOF)
1511 c = getc (file);
1512 goto end_of_line;
1513 }
1514
1515 if (len != 0)
d412a550 1516 fatal (_("%s:%d: premature end of file"), filename, lineno);
92991082
JT
1517
1518 free (buf);
1519}
1520
77f762d6
L
1521/* Copy unkown object file IBFD onto OBFD.
1522 Returns TRUE upon success, FALSE otherwise. */
1523
1524static bfd_boolean
1525copy_unknown_object (bfd *ibfd, bfd *obfd)
1526{
1527 char *cbuf;
1528 int tocopy;
1529 long ncopied;
1530 long size;
1531 struct stat buf;
1532
1533 if (bfd_stat_arch_elt (ibfd, &buf) != 0)
1534 {
8d8e0703 1535 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
77f762d6
L
1536 return FALSE;
1537 }
1538
1539 size = buf.st_size;
1540 if (size < 0)
1541 {
1542 non_fatal (_("stat returns negative size for `%s'"),
1543 bfd_get_archive_filename (ibfd));
1544 return FALSE;
1545 }
1546
1547 if (bfd_seek (ibfd, (file_ptr) 0, SEEK_SET) != 0)
1548 {
1549 bfd_nonfatal (bfd_get_archive_filename (ibfd));
1550 return FALSE;
1551 }
1552
1553 if (verbose)
1554 printf (_("copy from `%s' [unknown] to `%s' [unknown]\n"),
1555 bfd_get_archive_filename (ibfd), bfd_get_filename (obfd));
1556
3f5e193b 1557 cbuf = (char *) xmalloc (BUFSIZE);
77f762d6
L
1558 ncopied = 0;
1559 while (ncopied < size)
1560 {
1561 tocopy = size - ncopied;
1562 if (tocopy > BUFSIZE)
1563 tocopy = BUFSIZE;
1564
1565 if (bfd_bread (cbuf, (bfd_size_type) tocopy, ibfd)
1566 != (bfd_size_type) tocopy)
1567 {
8d8e0703 1568 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
77f762d6
L
1569 free (cbuf);
1570 return FALSE;
1571 }
1572
1573 if (bfd_bwrite (cbuf, (bfd_size_type) tocopy, obfd)
1574 != (bfd_size_type) tocopy)
1575 {
2db6cde7 1576 bfd_nonfatal_message (NULL, obfd, NULL, NULL);
77f762d6
L
1577 free (cbuf);
1578 return FALSE;
1579 }
1580
1581 ncopied += tocopy;
1582 }
1583
1e99536a
L
1584 /* We should at least to be able to read it back when copying an
1585 unknown object in an archive. */
1586 chmod (bfd_get_filename (obfd), buf.st_mode | S_IRUSR);
77f762d6
L
1587 free (cbuf);
1588 return TRUE;
1589}
1590
950d48e7 1591/* Copy object file IBFD onto OBFD.
5b8c74e6 1592 Returns TRUE upon success, FALSE otherwise. */
252b5132 1593
950d48e7 1594static bfd_boolean
8b31b6c4 1595copy_object (bfd *ibfd, bfd *obfd, const bfd_arch_info_type *input_arch)
252b5132
RH
1596{
1597 bfd_vma start;
1598 long symcount;
1599 asection **osections = NULL;
84e2f313 1600 asection *gnu_debuglink_section = NULL;
252b5132
RH
1601 bfd_size_type *gaps = NULL;
1602 bfd_size_type max_gap = 0;
1603 long symsize;
84e2f313 1604 void *dhandle;
66491ebc
AM
1605 enum bfd_architecture iarch;
1606 unsigned int imach;
252b5132 1607
23719f39
NC
1608 if (ibfd->xvec->byteorder != obfd->xvec->byteorder
1609 && ibfd->xvec->byteorder != BFD_ENDIAN_UNKNOWN
1610 && obfd->xvec->byteorder != BFD_ENDIAN_UNKNOWN)
950d48e7 1611 fatal (_("Unable to change endianness of input file(s)"));
252b5132
RH
1612
1613 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
950d48e7 1614 {
2db6cde7 1615 bfd_nonfatal_message (NULL, obfd, NULL, NULL);
950d48e7
NC
1616 return FALSE;
1617 }
252b5132 1618
5063a421
AM
1619 if (ibfd->sections == NULL)
1620 {
1621 non_fatal (_("error: the input file '%s' has no sections"),
1622 bfd_get_archive_filename (ibfd));
1623 return FALSE;
1624 }
1625
252b5132 1626 if (verbose)
77f762d6
L
1627 printf (_("copy from `%s' [%s] to `%s' [%s]\n"),
1628 bfd_get_archive_filename (ibfd), bfd_get_target (ibfd),
252b5132
RH
1629 bfd_get_filename (obfd), bfd_get_target (obfd));
1630
d3e52d40
RS
1631 if (extract_symbol)
1632 start = 0;
252b5132 1633 else
d3e52d40
RS
1634 {
1635 if (set_start_set)
1636 start = set_start;
1637 else
1638 start = bfd_get_start_address (ibfd);
1639 start += change_start;
1640 }
252b5132 1641
0af11b59
KH
1642 /* Neither the start address nor the flags
1643 need to be set for a core file. */
4dd67f29
MS
1644 if (bfd_get_format (obfd) != bfd_core)
1645 {
4087920c
MR
1646 flagword flags;
1647
1648 flags = bfd_get_file_flags (ibfd);
1649 flags |= bfd_flags_to_set;
1650 flags &= ~bfd_flags_to_clear;
1651 flags &= bfd_applicable_file_flags (obfd);
1652
3516e984
L
1653 if (strip_symbols == STRIP_ALL)
1654 flags &= ~HAS_RELOC;
1655
4dd67f29 1656 if (!bfd_set_start_address (obfd, start)
4087920c 1657 || !bfd_set_file_flags (obfd, flags))
950d48e7 1658 {
8d8e0703 1659 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
950d48e7
NC
1660 return FALSE;
1661 }
4dd67f29 1662 }
252b5132 1663
594ef5db 1664 /* Copy architecture of input file to output file. */
66491ebc
AM
1665 iarch = bfd_get_arch (ibfd);
1666 imach = bfd_get_mach (ibfd);
8b31b6c4
NC
1667 if (input_arch)
1668 {
1669 if (bfd_get_arch_info (ibfd) == NULL
1670 || bfd_get_arch_info (ibfd)->arch == bfd_arch_unknown)
1671 {
1672 iarch = input_arch->arch;
1673 imach = input_arch->mach;
1674 }
1675 else
1676 non_fatal (_("Input file `%s' ignores binary architecture parameter."),
1677 bfd_get_archive_filename (ibfd));
1678 }
66491ebc 1679 if (!bfd_set_arch_mach (obfd, iarch, imach)
212a3c4d
L
1680 && (ibfd->target_defaulted
1681 || bfd_get_arch (ibfd) != bfd_get_arch (obfd)))
f57a841a
NC
1682 {
1683 if (bfd_get_arch (ibfd) == bfd_arch_unknown)
77f762d6
L
1684 non_fatal (_("Unable to recognise the format of the input file `%s'"),
1685 bfd_get_archive_filename (ibfd));
f57a841a 1686 else
c1e2cb9d 1687 non_fatal (_("Output file cannot represent architecture `%s'"),
77f762d6
L
1688 bfd_printable_arch_mach (bfd_get_arch (ibfd),
1689 bfd_get_mach (ibfd)));
1690 return FALSE;
f57a841a 1691 }
57938635 1692
252b5132 1693 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
950d48e7 1694 {
8d8e0703 1695 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
950d48e7
NC
1696 return FALSE;
1697 }
252b5132 1698
92dd4511
L
1699 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour
1700 && bfd_pei_p (obfd))
1701 {
1702 /* Set up PE parameters. */
1703 pe_data_type *pe = pe_data (obfd);
1704
325c681d
L
1705 /* Copy PE parameters before changing them. */
1706 if (ibfd->xvec->flavour == bfd_target_coff_flavour
1707 && bfd_pei_p (ibfd))
1708 pe->pe_opthdr = pe_data (ibfd)->pe_opthdr;
1709
92dd4511
L
1710 if (pe_file_alignment != (bfd_vma) -1)
1711 pe->pe_opthdr.FileAlignment = pe_file_alignment;
1712 else
1713 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
1714
1715 if (pe_heap_commit != (bfd_vma) -1)
1716 pe->pe_opthdr.SizeOfHeapCommit = pe_heap_commit;
1717
1718 if (pe_heap_reserve != (bfd_vma) -1)
1719 pe->pe_opthdr.SizeOfHeapCommit = pe_heap_reserve;
1720
1721 if (pe_image_base != (bfd_vma) -1)
1722 pe->pe_opthdr.ImageBase = pe_image_base;
1723
1724 if (pe_section_alignment != (bfd_vma) -1)
1725 pe->pe_opthdr.SectionAlignment = pe_section_alignment;
1726 else
1727 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
1728
1729 if (pe_stack_commit != (bfd_vma) -1)
1730 pe->pe_opthdr.SizeOfStackCommit = pe_stack_commit;
1731
1732 if (pe_stack_reserve != (bfd_vma) -1)
1733 pe->pe_opthdr.SizeOfStackCommit = pe_stack_reserve;
1734
1735 if (pe_subsystem != -1)
1736 pe->pe_opthdr.Subsystem = pe_subsystem;
1737
1738 if (pe_major_subsystem_version != -1)
1739 pe->pe_opthdr.MajorSubsystemVersion = pe_major_subsystem_version;
1740
1741 if (pe_minor_subsystem_version != -1)
1742 pe->pe_opthdr.MinorSubsystemVersion = pe_minor_subsystem_version;
1743
1744 if (pe_file_alignment > pe_section_alignment)
1745 {
1746 char file_alignment[20], section_alignment[20];
1747
1748 sprintf_vma (file_alignment, pe_file_alignment);
1749 sprintf_vma (section_alignment, pe_section_alignment);
1750 non_fatal (_("warning: file alignment (0x%s) > section alignment (0x%s)"),
1751
1752 file_alignment, section_alignment);
1753 }
1754 }
1755
252b5132 1756 if (isympp)
62d732f5 1757 free (isympp);
57938635 1758
252b5132 1759 if (osympp != isympp)
62d732f5
AM
1760 free (osympp);
1761
1762 isympp = NULL;
1763 osympp = NULL;
252b5132 1764
c39ada54
AM
1765 symsize = bfd_get_symtab_upper_bound (ibfd);
1766 if (symsize < 0)
1767 {
8d8e0703 1768 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
c39ada54
AM
1769 return FALSE;
1770 }
1771
3f5e193b 1772 osympp = isympp = (asymbol **) xmalloc (symsize);
c39ada54
AM
1773 symcount = bfd_canonicalize_symtab (ibfd, isympp);
1774 if (symcount < 0)
1775 {
2db6cde7 1776 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
c39ada54
AM
1777 return FALSE;
1778 }
063bb025
NC
1779 /* PR 17512: file: d6323821
1780 If the symbol table could not be loaded do not pretend that we have
1781 any symbols. This trips us up later on when we load the relocs. */
1782 if (symcount == 0)
1783 {
1784 free (isympp);
1785 osympp = isympp = NULL;
1786 }
c39ada54 1787
252b5132
RH
1788 /* BFD mandates that all output sections be created and sizes set before
1789 any output is done. Thus, we traverse all sections multiple times. */
d3ba0551 1790 bfd_map_over_sections (ibfd, setup_section, obfd);
252b5132 1791
237dcb53
AM
1792 if (!extract_symbol)
1793 setup_bfd_headers (ibfd, obfd);
80fccad2 1794
252b5132
RH
1795 if (add_sections != NULL)
1796 {
1797 struct section_add *padd;
1798 struct section_list *pset;
1799
1800 for (padd = add_sections; padd != NULL; padd = padd->next)
1801 {
2593f09a
NC
1802 flagword flags;
1803
2e62b721
NC
1804 pset = find_section_list (padd->name, FALSE,
1805 SECTION_CONTEXT_SET_FLAGS);
551b43fd 1806 if (pset != NULL)
551b43fd 1807 flags = pset->flags | SEC_HAS_CONTENTS;
2e62b721
NC
1808 else
1809 flags = SEC_HAS_CONTENTS | SEC_READONLY | SEC_DATA;
551b43fd 1810
c8782eee
NC
1811 /* bfd_make_section_with_flags() does not return very helpful
1812 error codes, so check for the most likely user error first. */
1813 if (bfd_get_section_by_name (obfd, padd->name))
252b5132 1814 {
2db6cde7
NS
1815 bfd_nonfatal_message (NULL, obfd, NULL,
1816 _("can't add section '%s'"), padd->name);
950d48e7 1817 return FALSE;
252b5132 1818 }
c8782eee
NC
1819 else
1820 {
0930eddd
NS
1821 /* We use LINKER_CREATED here so that the backend hooks
1822 will create any special section type information,
1823 instead of presuming we know what we're doing merely
1824 because we set the flags. */
1825 padd->section = bfd_make_section_with_flags
1826 (obfd, padd->name, flags | SEC_LINKER_CREATED);
c8782eee
NC
1827 if (padd->section == NULL)
1828 {
2db6cde7
NS
1829 bfd_nonfatal_message (NULL, obfd, NULL,
1830 _("can't create section `%s'"),
1831 padd->name);
c8782eee
NC
1832 return FALSE;
1833 }
1834 }
252b5132 1835
2593f09a 1836 if (! bfd_set_section_size (obfd, padd->section, padd->size))
950d48e7 1837 {
2db6cde7 1838 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
950d48e7
NC
1839 return FALSE;
1840 }
252b5132 1841
2e62b721
NC
1842 pset = find_section_list (padd->name, FALSE,
1843 SECTION_CONTEXT_SET_VMA | SECTION_CONTEXT_ALTER_VMA);
1844 if (pset != NULL
1845 && ! bfd_set_section_vma (obfd, padd->section, pset->vma_val))
1846 {
1847 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
1848 return FALSE;
1849 }
1850
1851 pset = find_section_list (padd->name, FALSE,
1852 SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_ALTER_LMA);
2593f09a
NC
1853 if (pset != NULL)
1854 {
2e62b721 1855 padd->section->lma = pset->lma_val;
57938635 1856
2e62b721
NC
1857 if (! bfd_set_section_alignment
1858 (obfd, padd->section,
1859 bfd_section_alignment (obfd, padd->section)))
2593f09a 1860 {
2e62b721
NC
1861 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
1862 return FALSE;
252b5132
RH
1863 }
1864 }
1865 }
1866 }
1867
bbad633b
NC
1868 if (dump_sections != NULL)
1869 {
1870 struct section_add * pdump;
1871
1872 for (pdump = dump_sections; pdump != NULL; pdump = pdump->next)
1873 {
1874 asection * sec;
1875
1876 sec = bfd_get_section_by_name (ibfd, pdump->name);
1877 if (sec == NULL)
1878 {
1879 bfd_nonfatal_message (NULL, ibfd, NULL,
1880 _("can't dump section '%s' - it does not exist"),
1881 pdump->name);
1882 continue;
1883 }
1884
1885 if ((bfd_get_section_flags (ibfd, sec) & SEC_HAS_CONTENTS) == 0)
1886 {
1887 bfd_nonfatal_message (NULL, ibfd, sec,
1888 _("can't dump section - it has no contents"));
1889 continue;
1890 }
1891
1892 bfd_size_type size = bfd_get_section_size (sec);
1893 if (size == 0)
1894 {
1895 bfd_nonfatal_message (NULL, ibfd, sec,
1896 _("can't dump section - it is empty"));
1897 continue;
1898 }
1899
1900 FILE * f;
1901 f = fopen (pdump->filename, FOPEN_WB);
1902 if (f == NULL)
1903 {
1904 bfd_nonfatal_message (pdump->filename, NULL, NULL,
1905 _("could not open section dump file"));
1906 continue;
1907 }
1908
1909 bfd_byte * contents = xmalloc (size);
1910 if (bfd_get_section_contents (ibfd, sec, contents, 0, size))
182a105a
AG
1911 {
1912 if (fwrite (contents, 1, size, f) != size)
1913 fatal (_("error writing section contents to %s (error: %s)"),
1914 pdump->filename,
1915 strerror (errno));
1916 }
bbad633b
NC
1917 else
1918 bfd_nonfatal_message (NULL, ibfd, sec,
1919 _("could not retrieve section contents"));
1920
1921 fclose (f);
1922 free (contents);
1923 }
1924 }
1925
2593f09a
NC
1926 if (gnu_debuglink_filename != NULL)
1927 {
d99b05a3
NC
1928 /* PR 15125: Give a helpful warning message if
1929 the debuglink section already exists, and
1930 allow the rest of the copy to complete. */
1931 if (bfd_get_section_by_name (obfd, ".gnu_debuglink"))
950d48e7 1932 {
d99b05a3
NC
1933 non_fatal (_("%s: debuglink section already exists"),
1934 bfd_get_filename (obfd));
1935 gnu_debuglink_filename = NULL;
950d48e7 1936 }
d99b05a3 1937 else
6e2c86ac 1938 {
d99b05a3
NC
1939 gnu_debuglink_section = bfd_create_gnu_debuglink_section
1940 (obfd, gnu_debuglink_filename);
1941
1942 if (gnu_debuglink_section == NULL)
1943 {
1944 bfd_nonfatal_message (NULL, obfd, NULL,
1945 _("cannot create debug link section `%s'"),
1946 gnu_debuglink_filename);
1947 return FALSE;
1948 }
6e2c86ac 1949
d99b05a3
NC
1950 /* Special processing for PE format files. We
1951 have no way to distinguish PE from COFF here. */
1952 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour)
1953 {
1954 bfd_vma debuglink_vma;
1955 asection * highest_section;
1956 asection * sec;
1957
1958 /* The PE spec requires that all sections be adjacent and sorted
1959 in ascending order of VMA. It also specifies that debug
1960 sections should be last. This is despite the fact that debug
1961 sections are not loaded into memory and so in theory have no
1962 use for a VMA.
1963
1964 This means that the debuglink section must be given a non-zero
1965 VMA which makes it contiguous with other debug sections. So
1966 walk the current section list, find the section with the
1967 highest VMA and start the debuglink section after that one. */
1968 for (sec = obfd->sections, highest_section = NULL;
1969 sec != NULL;
1970 sec = sec->next)
1971 if (sec->vma > 0
1972 && (highest_section == NULL
1973 || sec->vma > highest_section->vma))
1974 highest_section = sec;
1975
1976 if (highest_section)
1977 debuglink_vma = BFD_ALIGN (highest_section->vma
1978 + highest_section->size,
1979 /* FIXME: We ought to be using
1980 COFF_PAGE_SIZE here or maybe
1981 bfd_get_section_alignment() (if it
1982 was set) but since this is for PE
1983 and we know the required alignment
1984 it is easier just to hard code it. */
1985 0x1000);
1986 else
1987 /* Umm, not sure what to do in this case. */
1988 debuglink_vma = 0x1000;
1989
1990 bfd_set_section_vma (obfd, gnu_debuglink_section, debuglink_vma);
1991 }
6e2c86ac 1992 }
950d48e7
NC
1993 }
1994
1aa9ef63
L
1995 if (bfd_count_sections (obfd) != 0
1996 && (gap_fill_set || pad_to_set))
252b5132
RH
1997 {
1998 asection **set;
1999 unsigned int c, i;
2000
2001 /* We must fill in gaps between the sections and/or we must pad
2002 the last section to a specified address. We do this by
2003 grabbing a list of the sections, sorting them by VMA, and
2004 increasing the section sizes as required to fill the gaps.
2005 We write out the gap contents below. */
2006
2007 c = bfd_count_sections (obfd);
3f5e193b 2008 osections = (asection **) xmalloc (c * sizeof (asection *));
252b5132 2009 set = osections;
d3ba0551 2010 bfd_map_over_sections (obfd, get_sections, &set);
252b5132
RH
2011
2012 qsort (osections, c, sizeof (asection *), compare_section_lma);
2013
3f5e193b 2014 gaps = (bfd_size_type *) xmalloc (c * sizeof (bfd_size_type));
252b5132
RH
2015 memset (gaps, 0, c * sizeof (bfd_size_type));
2016
2017 if (gap_fill_set)
2018 {
2019 for (i = 0; i < c - 1; i++)
2020 {
2021 flagword flags;
2022 bfd_size_type size;
2023 bfd_vma gap_start, gap_stop;
2024
2025 flags = bfd_get_section_flags (obfd, osections[i]);
2026 if ((flags & SEC_HAS_CONTENTS) == 0
2027 || (flags & SEC_LOAD) == 0)
2028 continue;
2029
2030 size = bfd_section_size (obfd, osections[i]);
2031 gap_start = bfd_section_lma (obfd, osections[i]) + size;
2032 gap_stop = bfd_section_lma (obfd, osections[i + 1]);
2033 if (gap_start < gap_stop)
2034 {
2035 if (! bfd_set_section_size (obfd, osections[i],
2036 size + (gap_stop - gap_start)))
2037 {
2db6cde7
NS
2038 bfd_nonfatal_message (NULL, obfd, osections[i],
2039 _("Can't fill gap after section"));
252b5132
RH
2040 status = 1;
2041 break;
2042 }
2043 gaps[i] = gap_stop - gap_start;
2044 if (max_gap < gap_stop - gap_start)
2045 max_gap = gap_stop - gap_start;
2046 }
2047 }
2048 }
2049
2050 if (pad_to_set)
2051 {
2052 bfd_vma lma;
2053 bfd_size_type size;
2054
2055 lma = bfd_section_lma (obfd, osections[c - 1]);
2056 size = bfd_section_size (obfd, osections[c - 1]);
2057 if (lma + size < pad_to)
2058 {
2059 if (! bfd_set_section_size (obfd, osections[c - 1],
2060 pad_to - lma))
2061 {
2db6cde7
NS
2062 bfd_nonfatal_message (NULL, obfd, osections[c - 1],
2063 _("can't add padding"));
252b5132
RH
2064 status = 1;
2065 }
2066 else
2067 {
2068 gaps[c - 1] = pad_to - (lma + size);
2069 if (max_gap < pad_to - (lma + size))
2070 max_gap = pad_to - (lma + size);
2071 }
2072 }
2073 }
2074 }
2075
594ef5db
NC
2076 /* Symbol filtering must happen after the output sections
2077 have been created, but before their contents are set. */
252b5132 2078 dhandle = NULL;
252b5132 2079 if (convert_debugging)
b922d590 2080 dhandle = read_debugging_info (ibfd, isympp, symcount, FALSE);
57938635
AM
2081
2082 if (strip_symbols == STRIP_DEBUG
252b5132
RH
2083 || strip_symbols == STRIP_ALL
2084 || strip_symbols == STRIP_UNNEEDED
ed1653a7 2085 || strip_symbols == STRIP_NONDEBUG
96109726
CC
2086 || strip_symbols == STRIP_DWO
2087 || strip_symbols == STRIP_NONDWO
252b5132 2088 || discard_locals != LOCALS_UNDEF
d58c2e3a 2089 || localize_hidden
047c9024
NC
2090 || htab_elements (strip_specific_htab) != 0
2091 || htab_elements (keep_specific_htab) != 0
2092 || htab_elements (localize_specific_htab) != 0
2093 || htab_elements (globalize_specific_htab) != 0
2094 || htab_elements (keepglobal_specific_htab) != 0
2095 || htab_elements (weaken_specific_htab) != 0
d7fb0dd2 2096 || prefix_symbols_string
252b5132 2097 || sections_removed
f91ea849 2098 || sections_copied
252b5132
RH
2099 || convert_debugging
2100 || change_leading_char
2101 || remove_leading_char
57938635 2102 || redefine_sym_list
252b5132
RH
2103 || weaken)
2104 {
2105 /* Mark symbols used in output relocations so that they
2106 are kept, even if they are local labels or static symbols.
57938635 2107
252b5132
RH
2108 Note we iterate over the input sections examining their
2109 relocations since the relocations for the output sections
2110 haven't been set yet. mark_symbols_used_in_relocations will
2111 ignore input sections which have no corresponding output
2112 section. */
2113 if (strip_symbols != STRIP_ALL)
2114 bfd_map_over_sections (ibfd,
2115 mark_symbols_used_in_relocations,
d3ba0551 2116 isympp);
3f5e193b 2117 osympp = (asymbol **) xmalloc ((symcount + 1) * sizeof (asymbol *));
252b5132
RH
2118 symcount = filter_symbols (ibfd, obfd, osympp, isympp, symcount);
2119 }
2120
2121 if (convert_debugging && dhandle != NULL)
2122 {
2123 if (! write_debugging_info (obfd, dhandle, &symcount, &osympp))
2124 {
2125 status = 1;
950d48e7 2126 return FALSE;
252b5132
RH
2127 }
2128 }
2129
2130 bfd_set_symtab (obfd, osympp, symcount);
2131
c3989150
L
2132 /* This has to happen before section positions are set. */
2133 bfd_map_over_sections (ibfd, copy_relocations_in_section, obfd);
2134
252b5132 2135 /* This has to happen after the symbol table has been set. */
d3ba0551 2136 bfd_map_over_sections (ibfd, copy_section, obfd);
252b5132
RH
2137
2138 if (add_sections != NULL)
2139 {
2140 struct section_add *padd;
2141
2142 for (padd = add_sections; padd != NULL; padd = padd->next)
2143 {
d3ba0551
AM
2144 if (! bfd_set_section_contents (obfd, padd->section, padd->contents,
2145 0, padd->size))
950d48e7 2146 {
2db6cde7 2147 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
950d48e7
NC
2148 return FALSE;
2149 }
252b5132
RH
2150 }
2151 }
2152
e7c81c25
NC
2153 if (gnu_debuglink_filename != NULL)
2154 {
2155 if (! bfd_fill_in_gnu_debuglink_section
2156 (obfd, gnu_debuglink_section, gnu_debuglink_filename))
950d48e7 2157 {
2db6cde7
NS
2158 bfd_nonfatal_message (NULL, obfd, NULL,
2159 _("cannot fill debug link section `%s'"),
2160 gnu_debuglink_filename);
950d48e7
NC
2161 return FALSE;
2162 }
e7c81c25
NC
2163 }
2164
252b5132
RH
2165 if (gap_fill_set || pad_to_set)
2166 {
2167 bfd_byte *buf;
2168 int c, i;
2169
2170 /* Fill in the gaps. */
252b5132
RH
2171 if (max_gap > 8192)
2172 max_gap = 8192;
3f5e193b 2173 buf = (bfd_byte *) xmalloc (max_gap);
d3ba0551 2174 memset (buf, gap_fill, max_gap);
252b5132
RH
2175
2176 c = bfd_count_sections (obfd);
2177 for (i = 0; i < c; i++)
2178 {
2179 if (gaps[i] != 0)
2180 {
2181 bfd_size_type left;
2182 file_ptr off;
2183
2184 left = gaps[i];
2185 off = bfd_section_size (obfd, osections[i]) - left;
594ef5db 2186
252b5132
RH
2187 while (left > 0)
2188 {
2189 bfd_size_type now;
2190
2191 if (left > 8192)
2192 now = 8192;
2193 else
2194 now = left;
2195
2196 if (! bfd_set_section_contents (obfd, osections[i], buf,
2197 off, now))
950d48e7 2198 {
2db6cde7 2199 bfd_nonfatal_message (NULL, obfd, osections[i], NULL);
950d48e7
NC
2200 return FALSE;
2201 }
252b5132
RH
2202
2203 left -= now;
2204 off += now;
2205 }
2206 }
2207 }
2208 }
2209
d3e52d40
RS
2210 /* Do not copy backend data if --extract-symbol is passed; anything
2211 that needs to look at the section contents will fail. */
2212 if (extract_symbol)
2213 return TRUE;
2214
252b5132
RH
2215 /* Allow the BFD backend to copy any private data it understands
2216 from the input BFD to the output BFD. This is done last to
2217 permit the routine to look at the filtered symbol table, which is
2218 important for the ECOFF code at least. */
42bb2e33 2219 if (! bfd_copy_private_bfd_data (ibfd, obfd))
252b5132 2220 {
2db6cde7
NS
2221 bfd_nonfatal_message (NULL, obfd, NULL,
2222 _("error copying private BFD data"));
950d48e7 2223 return FALSE;
252b5132 2224 }
1ae8b3d2
AO
2225
2226 /* Switch to the alternate machine code. We have to do this at the
2227 very end, because we only initialize the header when we create
2228 the first section. */
f9d4ad2a
NC
2229 if (use_alt_mach_code != 0)
2230 {
2231 if (! bfd_alt_mach_code (obfd, use_alt_mach_code))
2232 {
2233 non_fatal (_("this target does not support %lu alternative machine codes"),
2234 use_alt_mach_code);
2235 if (bfd_get_flavour (obfd) == bfd_target_elf_flavour)
2236 {
2237 non_fatal (_("treating that number as an absolute e_machine value instead"));
2238 elf_elfheader (obfd)->e_machine = use_alt_mach_code;
2239 }
2240 else
2241 non_fatal (_("ignoring the alternative value"));
2242 }
2243 }
950d48e7
NC
2244
2245 return TRUE;
252b5132
RH
2246}
2247
2248/* Read each archive element in turn from IBFD, copy the
ee873e00
NC
2249 contents to temp file, and keep the temp file handle.
2250 If 'force_output_target' is TRUE then make sure that
2251 all elements in the new archive are of the type
2252 'output_target'. */
252b5132
RH
2253
2254static void
ee873e00 2255copy_archive (bfd *ibfd, bfd *obfd, const char *output_target,
8b31b6c4
NC
2256 bfd_boolean force_output_target,
2257 const bfd_arch_info_type *input_arch)
252b5132
RH
2258{
2259 struct name_list
2260 {
2261 struct name_list *next;
4c168fa3 2262 const char *name;
252b5132
RH
2263 bfd *obfd;
2264 } *list, *l;
2265 bfd **ptr = &obfd->archive_head;
2266 bfd *this_element;
8d8e0703
AM
2267 char *dir;
2268 const char *filename;
252b5132
RH
2269
2270 /* Make a temp directory to hold the contents. */
f9c026a8 2271 dir = make_tempdir (bfd_get_filename (obfd));
f9c026a8
NC
2272 if (dir == NULL)
2273 fatal (_("cannot create tempdir for archive copying (error: %s)"),
2274 strerror (errno));
84e2f313 2275
2e30cb57
CC
2276 if (strip_symbols == STRIP_ALL)
2277 obfd->has_armap = FALSE;
2278 else
2279 obfd->has_armap = ibfd->has_armap;
a8da6403 2280 obfd->is_thin_archive = ibfd->is_thin_archive;
252b5132 2281
2e30cb57
CC
2282 if (deterministic)
2283 obfd->flags |= BFD_DETERMINISTIC_OUTPUT;
2284
252b5132
RH
2285 list = NULL;
2286
2287 this_element = bfd_openr_next_archived_file (ibfd, NULL);
594ef5db 2288
b667df2e 2289 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
8d8e0703
AM
2290 {
2291 status = 1;
2292 bfd_nonfatal_message (NULL, obfd, NULL, NULL);
2293 return;
2294 }
b667df2e 2295
d3ba0551 2296 while (!status && this_element != NULL)
252b5132 2297 {
4c168fa3
AM
2298 char *output_name;
2299 bfd *output_bfd;
252b5132 2300 bfd *last_element;
8066d1a2
AS
2301 struct stat buf;
2302 int stat_status = 0;
3f5e193b 2303 bfd_boolean del = TRUE;
19094d10 2304 bfd_boolean ok_object;
8066d1a2 2305
dd9b91de
NC
2306 /* PR binutils/17533: Do not allow directory traversal
2307 outside of the current directory tree by archive members. */
2308 if (! is_valid_archive_path (bfd_get_filename (this_element)))
5e186ece
NC
2309 {
2310 non_fatal (_("illegal pathname found in archive member: %s"),
2311 bfd_get_filename (this_element));
2312 status = 1;
2313 goto cleanup_and_exit;
2314 }
dd9b91de 2315
4c168fa3
AM
2316 /* Create an output file for this member. */
2317 output_name = concat (dir, "/",
2318 bfd_get_filename (this_element), (char *) 0);
2319
2320 /* If the file already exists, make another temp dir. */
2321 if (stat (output_name, &buf) >= 0)
2322 {
f9c026a8
NC
2323 output_name = make_tempdir (output_name);
2324 if (output_name == NULL)
5e186ece
NC
2325 {
2326 non_fatal (_("cannot create tempdir for archive copying (error: %s)"),
2327 strerror (errno));
2328 status = 1;
2329 goto cleanup_and_exit;
2330 }
84e2f313 2331
3f5e193b 2332 l = (struct name_list *) xmalloc (sizeof (struct name_list));
4c168fa3
AM
2333 l->name = output_name;
2334 l->next = list;
2335 l->obfd = NULL;
2336 list = l;
2337 output_name = concat (output_name, "/",
2338 bfd_get_filename (this_element), (char *) 0);
2339 }
2340
8066d1a2
AS
2341 if (preserve_dates)
2342 {
2343 stat_status = bfd_stat_arch_elt (this_element, &buf);
594ef5db 2344
8066d1a2
AS
2345 if (stat_status != 0)
2346 non_fatal (_("internal stat error on %s"),
2347 bfd_get_filename (this_element));
2348 }
252b5132 2349
3f5e193b 2350 l = (struct name_list *) xmalloc (sizeof (struct name_list));
252b5132
RH
2351 l->name = output_name;
2352 l->next = list;
bee59fd2 2353 l->obfd = NULL;
252b5132
RH
2354 list = l;
2355
19094d10
AM
2356 ok_object = bfd_check_format (this_element, bfd_object);
2357 if (!ok_object)
2358 bfd_nonfatal_message (NULL, this_element, NULL,
2359 _("Unable to recognise the format of file"));
2360
2361 /* PR binutils/3110: Cope with archives
2362 containing multiple target types. */
2363 if (force_output_target || !ok_object)
2364 output_bfd = bfd_openw (output_name, output_target);
2365 else
2366 output_bfd = bfd_openw (output_name, bfd_get_target (this_element));
2367
2368 if (output_bfd == NULL)
77f762d6 2369 {
19094d10
AM
2370 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
2371 status = 1;
5e186ece 2372 goto cleanup_and_exit;
19094d10
AM
2373 }
2374
2375 if (ok_object)
2376 {
2377 del = !copy_object (this_element, output_bfd, input_arch);
ee873e00 2378
19094d10
AM
2379 if (del && bfd_get_arch (this_element) == bfd_arch_unknown)
2380 /* Try again as an unknown object file. */
2381 ok_object = FALSE;
2382 else if (!bfd_close (output_bfd))
2db6cde7
NS
2383 {
2384 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
19094d10 2385 /* Error in new object file. Don't change archive. */
2db6cde7 2386 status = 1;
77f762d6 2387 }
77f762d6 2388 }
77f762d6 2389
19094d10
AM
2390 if (!ok_object)
2391 {
3f5e193b 2392 del = !copy_unknown_object (this_element, output_bfd);
77f762d6
L
2393 if (!bfd_close_all_done (output_bfd))
2394 {
8d8e0703 2395 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
77f762d6
L
2396 /* Error in new object file. Don't change archive. */
2397 status = 1;
2398 }
252b5132
RH
2399 }
2400
3f5e193b 2401 if (del)
950d48e7
NC
2402 {
2403 unlink (output_name);
2404 status = 1;
2405 }
2406 else
2407 {
2408 if (preserve_dates && stat_status == 0)
2409 set_times (output_name, &buf);
8066d1a2 2410
950d48e7
NC
2411 /* Open the newly output file and attach to our list. */
2412 output_bfd = bfd_openr (output_name, output_target);
252b5132 2413
950d48e7 2414 l->obfd = output_bfd;
252b5132 2415
950d48e7 2416 *ptr = output_bfd;
cc481421 2417 ptr = &output_bfd->archive_next;
252b5132 2418
950d48e7 2419 last_element = this_element;
252b5132 2420
950d48e7 2421 this_element = bfd_openr_next_archived_file (ibfd, last_element);
252b5132 2422
950d48e7
NC
2423 bfd_close (last_element);
2424 }
252b5132 2425 }
d3ba0551 2426 *ptr = NULL;
252b5132 2427
8d8e0703 2428 filename = bfd_get_filename (obfd);
252b5132 2429 if (!bfd_close (obfd))
8d8e0703
AM
2430 {
2431 status = 1;
2432 bfd_nonfatal_message (filename, NULL, NULL, NULL);
8d8e0703 2433 }
252b5132 2434
8d8e0703 2435 filename = bfd_get_filename (ibfd);
252b5132 2436 if (!bfd_close (ibfd))
8d8e0703
AM
2437 {
2438 status = 1;
2439 bfd_nonfatal_message (filename, NULL, NULL, NULL);
8d8e0703 2440 }
252b5132 2441
5e186ece 2442 cleanup_and_exit:
252b5132
RH
2443 /* Delete all the files that we opened. */
2444 for (l = list; l != NULL; l = l->next)
2445 {
4c168fa3
AM
2446 if (l->obfd == NULL)
2447 rmdir (l->name);
2448 else
2449 {
2450 bfd_close (l->obfd);
2451 unlink (l->name);
2452 }
252b5132
RH
2453 }
2454 rmdir (dir);
2455}
2456
0408dee6
DK
2457static void
2458set_long_section_mode (bfd *output_bfd, bfd *input_bfd, enum long_section_name_handling style)
2459{
2460 /* This is only relevant to Coff targets. */
2461 if (bfd_get_flavour (output_bfd) == bfd_target_coff_flavour)
2462 {
78e82dc3
AM
2463 if (style == KEEP
2464 && bfd_get_flavour (input_bfd) == bfd_target_coff_flavour)
0408dee6
DK
2465 style = bfd_coff_long_section_names (input_bfd) ? ENABLE : DISABLE;
2466 bfd_coff_set_long_section_names (output_bfd, style != DISABLE);
2467 }
2468}
2469
252b5132
RH
2470/* The top-level control. */
2471
2472static void
84e2f313 2473copy_file (const char *input_filename, const char *output_filename,
8b31b6c4
NC
2474 const char *input_target, const char *output_target,
2475 const bfd_arch_info_type *input_arch)
252b5132
RH
2476{
2477 bfd *ibfd;
49c12576
AM
2478 char **obj_matching;
2479 char **core_matching;
52a476ee 2480 off_t size = get_file_size (input_filename);
252b5132 2481
52a476ee 2482 if (size < 1)
f24ddbdd 2483 {
52a476ee
L
2484 if (size == 0)
2485 non_fatal (_("error: the input file '%s' is empty"),
2486 input_filename);
f24ddbdd
NC
2487 status = 1;
2488 return;
2489 }
2490
252b5132
RH
2491 /* To allow us to do "strip *" without dying on the first
2492 non-object file, failures are nonfatal. */
252b5132
RH
2493 ibfd = bfd_openr (input_filename, input_target);
2494 if (ibfd == NULL)
2db6cde7
NS
2495 {
2496 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
2497 status = 1;
2498 return;
2499 }
252b5132 2500
4a114e3e
L
2501 switch (do_debug_sections)
2502 {
2503 case compress:
2504 ibfd->flags |= BFD_COMPRESS;
2505 break;
2506 case decompress:
2507 ibfd->flags |= BFD_DECOMPRESS;
2508 break;
2509 default:
2510 break;
2511 }
2512
252b5132
RH
2513 if (bfd_check_format (ibfd, bfd_archive))
2514 {
ee873e00 2515 bfd_boolean force_output_target;
252b5132
RH
2516 bfd *obfd;
2517
2518 /* bfd_get_target does not return the correct value until
2519 bfd_check_format succeeds. */
2520 if (output_target == NULL)
ee873e00
NC
2521 {
2522 output_target = bfd_get_target (ibfd);
2523 force_output_target = FALSE;
2524 }
2525 else
2526 force_output_target = TRUE;
252b5132
RH
2527
2528 obfd = bfd_openw (output_filename, output_target);
2529 if (obfd == NULL)
2db6cde7
NS
2530 {
2531 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
2532 status = 1;
2533 return;
2534 }
0408dee6
DK
2535 /* This is a no-op on non-Coff targets. */
2536 set_long_section_mode (obfd, ibfd, long_section_names);
252b5132 2537
8b31b6c4 2538 copy_archive (ibfd, obfd, output_target, force_output_target, input_arch);
252b5132 2539 }
49c12576 2540 else if (bfd_check_format_matches (ibfd, bfd_object, &obj_matching))
252b5132
RH
2541 {
2542 bfd *obfd;
49c12576 2543 do_copy:
950d48e7 2544
252b5132
RH
2545 /* bfd_get_target does not return the correct value until
2546 bfd_check_format succeeds. */
2547 if (output_target == NULL)
2548 output_target = bfd_get_target (ibfd);
2549
2550 obfd = bfd_openw (output_filename, output_target);
2551 if (obfd == NULL)
2db6cde7
NS
2552 {
2553 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
2554 status = 1;
2555 return;
2556 }
0408dee6
DK
2557 /* This is a no-op on non-Coff targets. */
2558 set_long_section_mode (obfd, ibfd, long_section_names);
252b5132 2559
8b31b6c4 2560 if (! copy_object (ibfd, obfd, input_arch))
a580b8e0 2561 status = 1;
252b5132 2562
063bb025
NC
2563 /* PR 17512: file: 0f15796a.
2564 If the file could not be copied it may not be in a writeable
2565 state. So use bfd_close_all_done to avoid the possibility of
2566 writing uninitialised data into the file. */
2567 if (! (status ? bfd_close_all_done (obfd) : bfd_close (obfd)))
8d8e0703
AM
2568 {
2569 status = 1;
2570 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
2571 return;
2572 }
252b5132
RH
2573
2574 if (!bfd_close (ibfd))
8d8e0703
AM
2575 {
2576 status = 1;
2577 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
2578 return;
2579 }
252b5132
RH
2580 }
2581 else
2582 {
49c12576
AM
2583 bfd_error_type obj_error = bfd_get_error ();
2584 bfd_error_type core_error;
b34976b6 2585
49c12576
AM
2586 if (bfd_check_format_matches (ibfd, bfd_core, &core_matching))
2587 {
2588 /* This probably can't happen.. */
2589 if (obj_error == bfd_error_file_ambiguously_recognized)
2590 free (obj_matching);
2591 goto do_copy;
2592 }
2593
2594 core_error = bfd_get_error ();
2595 /* Report the object error in preference to the core error. */
2596 if (obj_error != core_error)
2597 bfd_set_error (obj_error);
2598
2db6cde7 2599 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
57938635 2600
49c12576
AM
2601 if (obj_error == bfd_error_file_ambiguously_recognized)
2602 {
2603 list_matching_formats (obj_matching);
2604 free (obj_matching);
2605 }
2606 if (core_error == bfd_error_file_ambiguously_recognized)
252b5132 2607 {
49c12576
AM
2608 list_matching_formats (core_matching);
2609 free (core_matching);
252b5132 2610 }
57938635 2611
252b5132
RH
2612 status = 1;
2613 }
2614}
2615
594ef5db
NC
2616/* Add a name to the section renaming list. */
2617
2618static void
84e2f313
NC
2619add_section_rename (const char * old_name, const char * new_name,
2620 flagword flags)
594ef5db 2621{
91d6fa6a 2622 section_rename * srename;
594ef5db
NC
2623
2624 /* Check for conflicts first. */
91d6fa6a
NC
2625 for (srename = section_rename_list; srename != NULL; srename = srename->next)
2626 if (strcmp (srename->old_name, old_name) == 0)
594ef5db
NC
2627 {
2628 /* Silently ignore duplicate definitions. */
91d6fa6a
NC
2629 if (strcmp (srename->new_name, new_name) == 0
2630 && srename->flags == flags)
594ef5db 2631 return;
0af11b59 2632
594ef5db
NC
2633 fatal (_("Multiple renames of section %s"), old_name);
2634 }
2635
91d6fa6a 2636 srename = (section_rename *) xmalloc (sizeof (* srename));
594ef5db 2637
91d6fa6a
NC
2638 srename->old_name = old_name;
2639 srename->new_name = new_name;
2640 srename->flags = flags;
2641 srename->next = section_rename_list;
0af11b59 2642
91d6fa6a 2643 section_rename_list = srename;
594ef5db
NC
2644}
2645
2646/* Check the section rename list for a new name of the input section
2647 ISECTION. Return the new name if one is found.
2648 Also set RETURNED_FLAGS to the flags to be used for this section. */
2649
2650static const char *
84e2f313
NC
2651find_section_rename (bfd * ibfd ATTRIBUTE_UNUSED, sec_ptr isection,
2652 flagword * returned_flags)
594ef5db
NC
2653{
2654 const char * old_name = bfd_section_name (ibfd, isection);
91d6fa6a 2655 section_rename * srename;
594ef5db
NC
2656
2657 /* Default to using the flags of the input section. */
2658 * returned_flags = bfd_get_section_flags (ibfd, isection);
2659
91d6fa6a
NC
2660 for (srename = section_rename_list; srename != NULL; srename = srename->next)
2661 if (strcmp (srename->old_name, old_name) == 0)
594ef5db 2662 {
91d6fa6a
NC
2663 if (srename->flags != (flagword) -1)
2664 * returned_flags = srename->flags;
594ef5db 2665
91d6fa6a 2666 return srename->new_name;
594ef5db
NC
2667 }
2668
2669 return old_name;
2670}
2671
80fccad2
BW
2672/* Once each of the sections is copied, we may still need to do some
2673 finalization work for private section headers. Do that here. */
2674
2675static void
2676setup_bfd_headers (bfd *ibfd, bfd *obfd)
2677{
80fccad2
BW
2678 /* Allow the BFD backend to copy any private data it understands
2679 from the input section to the output section. */
2680 if (! bfd_copy_private_header_data (ibfd, obfd))
2681 {
2db6cde7
NS
2682 status = 1;
2683 bfd_nonfatal_message (NULL, ibfd, NULL,
8d8e0703 2684 _("error in private header data"));
2db6cde7 2685 return;
80fccad2
BW
2686 }
2687
2688 /* All went well. */
2689 return;
80fccad2
BW
2690}
2691
594ef5db
NC
2692/* Create a section in OBFD with the same
2693 name and attributes as ISECTION in IBFD. */
252b5132
RH
2694
2695static void
84e2f313 2696setup_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
252b5132 2697{
3f5e193b 2698 bfd *obfd = (bfd *) obfdarg;
252b5132
RH
2699 struct section_list *p;
2700 sec_ptr osection;
2701 bfd_size_type size;
2702 bfd_vma vma;
2703 bfd_vma lma;
2704 flagword flags;
1a89cc7d 2705 const char *err;
594ef5db 2706 const char * name;
d7fb0dd2 2707 char *prefix = NULL;
66125551 2708 bfd_boolean make_nobits;
0af11b59 2709
2593f09a 2710 if (is_strip_section (ibfd, isection))
252b5132
RH
2711 return;
2712
594ef5db
NC
2713 /* Get the, possibly new, name of the output section. */
2714 name = find_section_rename (ibfd, isection, & flags);
0af11b59 2715
d7fb0dd2 2716 /* Prefix sections. */
84e2f313
NC
2717 if ((prefix_alloc_sections_string)
2718 && (bfd_get_section_flags (ibfd, isection) & SEC_ALLOC))
d7fb0dd2
NC
2719 prefix = prefix_alloc_sections_string;
2720 else if (prefix_sections_string)
2721 prefix = prefix_sections_string;
2722
2723 if (prefix)
2724 {
2725 char *n;
2726
3f5e193b 2727 n = (char *) xmalloc (strlen (prefix) + strlen (name) + 1);
d7fb0dd2
NC
2728 strcpy (n, prefix);
2729 strcat (n, name);
2730 name = n;
2731 }
66491ebc 2732
66125551 2733 make_nobits = FALSE;
2e62b721
NC
2734
2735 p = find_section_list (bfd_section_name (ibfd, isection), FALSE,
2736 SECTION_CONTEXT_SET_FLAGS);
2737 if (p != NULL)
551b43fd 2738 flags = p->flags | (flags & (SEC_HAS_CONTENTS | SEC_RELOC));
42bb2e33 2739 else if (strip_symbols == STRIP_NONDEBUG
6c67a030 2740 && (flags & (SEC_ALLOC | SEC_GROUP)) != 0
6e6e7cfc 2741 && !is_nondebug_keep_contents_section (ibfd, isection))
66125551 2742 {
6c67a030 2743 flags &= ~(SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP);
66125551
AM
2744 if (obfd->xvec->flavour == bfd_target_elf_flavour)
2745 {
2746 make_nobits = TRUE;
2747
2748 /* Twiddle the input section flags so that it seems to
2749 elf.c:copy_private_bfd_data that section flags have not
2750 changed between input and output sections. This hack
2751 prevents wholesale rewriting of the program headers. */
6c67a030 2752 isection->flags &= ~(SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP);
66125551
AM
2753 }
2754 }
551b43fd
AM
2755
2756 osection = bfd_make_section_anyway_with_flags (obfd, name, flags);
57938635 2757
252b5132
RH
2758 if (osection == NULL)
2759 {
2db6cde7 2760 err = _("failed to create output section");
252b5132
RH
2761 goto loser;
2762 }
2763
66125551 2764 if (make_nobits)
551b43fd
AM
2765 elf_section_type (osection) = SHT_NOBITS;
2766
252b5132
RH
2767 size = bfd_section_size (ibfd, isection);
2768 if (copy_byte >= 0)
b7dd81f7 2769 size = (size + interleave - 1) / interleave * copy_width;
d3e52d40
RS
2770 else if (extract_symbol)
2771 size = 0;
252b5132
RH
2772 if (! bfd_set_section_size (obfd, osection, size))
2773 {
2db6cde7 2774 err = _("failed to set size");
252b5132
RH
2775 goto loser;
2776 }
57938635 2777
252b5132 2778 vma = bfd_section_vma (ibfd, isection);
2e62b721
NC
2779 p = find_section_list (bfd_section_name (ibfd, isection), FALSE,
2780 SECTION_CONTEXT_ALTER_VMA | SECTION_CONTEXT_SET_VMA);
2781 if (p != NULL)
2782 {
2783 if (p->context & SECTION_CONTEXT_SET_VMA)
2784 vma = p->vma_val;
2785 else
2786 vma += p->vma_val;
2787 }
252b5132
RH
2788 else
2789 vma += change_section_address;
57938635 2790
237dcb53 2791 if (! bfd_set_section_vma (obfd, osection, vma))
252b5132 2792 {
2db6cde7 2793 err = _("failed to set vma");
252b5132
RH
2794 goto loser;
2795 }
2796
2797 lma = isection->lma;
2e62b721
NC
2798 p = find_section_list (bfd_section_name (ibfd, isection), FALSE,
2799 SECTION_CONTEXT_ALTER_LMA | SECTION_CONTEXT_SET_LMA);
2800 if (p != NULL)
252b5132 2801 {
2e62b721 2802 if (p->context & SECTION_CONTEXT_ALTER_LMA)
252b5132 2803 lma += p->lma_val;
252b5132 2804 else
2e62b721 2805 lma = p->lma_val;
252b5132
RH
2806 }
2807 else
2808 lma += change_section_address;
57938635 2809
237dcb53 2810 osection->lma = lma;
252b5132
RH
2811
2812 /* FIXME: This is probably not enough. If we change the LMA we
2813 may have to recompute the header for the file as well. */
b34976b6
AM
2814 if (!bfd_set_section_alignment (obfd,
2815 osection,
2816 bfd_section_alignment (ibfd, isection)))
252b5132 2817 {
2db6cde7 2818 err = _("failed to set alignment");
252b5132
RH
2819 goto loser;
2820 }
2821
bc408b8a
JJ
2822 /* Copy merge entity size. */
2823 osection->entsize = isection->entsize;
2824
252b5132
RH
2825 /* This used to be mangle_section; we do here to avoid using
2826 bfd_get_section_by_name since some formats allow multiple
2827 sections with the same name. */
2828 isection->output_section = osection;
237dcb53 2829 isection->output_offset = 0;
d3e52d40
RS
2830
2831 /* Do not copy backend data if --extract-symbol is passed; anything
2832 that needs to look at the section contents will fail. */
2833 if (extract_symbol)
2834 return;
252b5132 2835
119f4245
AM
2836 if ((isection->flags & SEC_GROUP) != 0)
2837 {
2838 asymbol *gsym = group_signature (isection);
2839
2840 if (gsym != NULL)
2841 {
2842 gsym->flags |= BSF_KEEP;
2843 if (ibfd->xvec->flavour == bfd_target_elf_flavour)
2844 elf_group_id (isection) = gsym;
2845 }
2846 }
2847
252b5132
RH
2848 /* Allow the BFD backend to copy any private data it understands
2849 from the input section to the output section. */
42bb2e33 2850 if (!bfd_copy_private_section_data (ibfd, isection, obfd, osection))
252b5132 2851 {
2db6cde7 2852 err = _("failed to copy private data");
252b5132
RH
2853 goto loser;
2854 }
2855
594ef5db 2856 /* All went well. */
252b5132
RH
2857 return;
2858
2859loser:
252b5132 2860 status = 1;
2db6cde7 2861 bfd_nonfatal_message (NULL, obfd, osection, err);
252b5132
RH
2862}
2863
c3989150 2864/* Return TRUE if input section ISECTION should be skipped. */
252b5132 2865
c3989150
L
2866static bfd_boolean
2867skip_section (bfd *ibfd, sec_ptr isection)
252b5132 2868{
252b5132
RH
2869 sec_ptr osection;
2870 bfd_size_type size;
dc156bc0 2871 flagword flags;
252b5132 2872
594ef5db
NC
2873 /* If we have already failed earlier on,
2874 do not keep on generating complaints now. */
252b5132 2875 if (status != 0)
c3989150
L
2876 return TRUE;
2877
2878 if (extract_symbol)
2879 return TRUE;
57938635 2880
2593f09a 2881 if (is_strip_section (ibfd, isection))
c3989150 2882 return TRUE;
252b5132 2883
2593f09a 2884 flags = bfd_get_section_flags (ibfd, isection);
dc156bc0 2885 if ((flags & SEC_GROUP) != 0)
c3989150 2886 return TRUE;
dc156bc0 2887
252b5132 2888 osection = isection->output_section;
135dfb4a 2889 size = bfd_get_section_size (isection);
252b5132
RH
2890
2891 if (size == 0 || osection == 0)
c3989150 2892 return TRUE;
252b5132 2893
c3989150
L
2894 return FALSE;
2895}
2896
2897/* Copy relocations in input section ISECTION of IBFD to an output
2898 section with the same name in OBFDARG. If stripping then don't
2899 copy any relocation info. */
2900
2901static void
2902copy_relocations_in_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
2903{
2904 bfd *obfd = (bfd *) obfdarg;
2905 long relsize;
2906 arelent **relpp;
2907 long relcount;
2908 sec_ptr osection;
2909
2910 if (skip_section (ibfd, isection))
237dcb53
AM
2911 return;
2912
c3989150 2913 osection = isection->output_section;
2593f09a 2914
96109726
CC
2915 /* Core files and DWO files do not need to be relocated. */
2916 if (bfd_get_format (obfd) == bfd_core || strip_symbols == STRIP_NONDWO)
4dd67f29
MS
2917 relsize = 0;
2918 else
ed570f48
NC
2919 {
2920 relsize = bfd_get_reloc_upper_bound (ibfd, isection);
4dd67f29 2921
ed570f48
NC
2922 if (relsize < 0)
2923 {
2924 /* Do not complain if the target does not support relocations. */
2925 if (relsize == -1 && bfd_get_error () == bfd_error_invalid_operation)
2926 relsize = 0;
2927 else
2db6cde7
NS
2928 {
2929 status = 1;
2930 bfd_nonfatal_message (NULL, ibfd, isection, NULL);
2931 return;
2932 }
ed570f48
NC
2933 }
2934 }
57938635 2935
252b5132 2936 if (relsize == 0)
96109726
CC
2937 {
2938 bfd_set_reloc (obfd, osection, NULL, 0);
2939 osection->flags &= ~SEC_RELOC;
2940 }
252b5132
RH
2941 else
2942 {
3f5e193b 2943 relpp = (arelent **) xmalloc (relsize);
252b5132
RH
2944 relcount = bfd_canonicalize_reloc (ibfd, isection, relpp, isympp);
2945 if (relcount < 0)
2db6cde7
NS
2946 {
2947 status = 1;
2948 bfd_nonfatal_message (NULL, ibfd, isection,
2949 _("relocation count is negative"));
2950 return;
2951 }
57938635 2952
252b5132
RH
2953 if (strip_symbols == STRIP_ALL)
2954 {
2955 /* Remove relocations which are not in
0af11b59 2956 keep_strip_specific_list. */
252b5132
RH
2957 arelent **temp_relpp;
2958 long temp_relcount = 0;
2959 long i;
57938635 2960
3f5e193b 2961 temp_relpp = (arelent **) xmalloc (relsize);
252b5132 2962 for (i = 0; i < relcount; i++)
86eafac0
NC
2963 {
2964 /* PR 17512: file: 9e907e0c. */
2965 if (relpp[i]->sym_ptr_ptr)
2966 if (is_specified_symbol (bfd_asymbol_name (*relpp[i]->sym_ptr_ptr),
2967 keep_specific_htab))
2968 temp_relpp [temp_relcount++] = relpp [i];
2969 }
252b5132
RH
2970 relcount = temp_relcount;
2971 free (relpp);
2972 relpp = temp_relpp;
2973 }
e0c60db2 2974
d3ba0551 2975 bfd_set_reloc (obfd, osection, relcount == 0 ? NULL : relpp, relcount);
f0312d39 2976 if (relcount == 0)
c3989150
L
2977 {
2978 osection->flags &= ~SEC_RELOC;
2979 free (relpp);
2980 }
252b5132 2981 }
c3989150
L
2982}
2983
2984/* Copy the data of input section ISECTION of IBFD
2985 to an output section with the same name in OBFD. */
2986
2987static void
2988copy_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
2989{
2990 bfd *obfd = (bfd *) obfdarg;
2991 struct section_list *p;
2992 sec_ptr osection;
2993 bfd_size_type size;
2994
2995 if (skip_section (ibfd, isection))
2996 return;
2997
2998 osection = isection->output_section;
2999 size = bfd_get_section_size (isection);
3000
0af11b59 3001 if (bfd_get_section_flags (ibfd, isection) & SEC_HAS_CONTENTS
4dd67f29 3002 && bfd_get_section_flags (obfd, osection) & SEC_HAS_CONTENTS)
252b5132 3003 {
4a114e3e 3004 bfd_byte *memhunk = NULL;
252b5132 3005
4a114e3e 3006 if (!bfd_get_full_section_contents (ibfd, isection, &memhunk))
2db6cde7
NS
3007 {
3008 status = 1;
3009 bfd_nonfatal_message (NULL, ibfd, isection, NULL);
3010 return;
3011 }
252b5132 3012
9e48b4c6
NC
3013 if (reverse_bytes)
3014 {
3015 /* We don't handle leftover bytes (too many possible behaviors,
3016 and we don't know what the user wants). The section length
3017 must be a multiple of the number of bytes to swap. */
3018 if ((size % reverse_bytes) == 0)
3019 {
3020 unsigned long i, j;
3021 bfd_byte b;
3022
3023 for (i = 0; i < size; i += reverse_bytes)
3024 for (j = 0; j < (unsigned long)(reverse_bytes / 2); j++)
3025 {
3026 bfd_byte *m = (bfd_byte *) memhunk;
3027
3028 b = m[i + j];
3029 m[i + j] = m[(i + reverse_bytes) - (j + 1)];
3030 m[(i + reverse_bytes) - (j + 1)] = b;
3031 }
3032 }
3033 else
3034 /* User must pad the section up in order to do this. */
3035 fatal (_("cannot reverse bytes: length of section %s must be evenly divisible by %d"),
3036 bfd_section_name (ibfd, isection), reverse_bytes);
3037 }
3038
57938635 3039 if (copy_byte >= 0)
5e675b72
AM
3040 {
3041 /* Keep only every `copy_byte'th byte in MEMHUNK. */
2f01ffbf 3042 char *from = (char *) memhunk + copy_byte;
3f5e193b 3043 char *to = (char *) memhunk;
2f01ffbf 3044 char *end = (char *) memhunk + size;
b7dd81f7 3045 int i;
5e675b72
AM
3046
3047 for (; from < end; from += interleave)
b7dd81f7 3048 for (i = 0; i < copy_width; i++)
ee7da987
L
3049 {
3050 if (&from[i] >= end)
3051 break;
3052 *to++ = from[i];
3053 }
5e675b72 3054
b7dd81f7 3055 size = (size + interleave - 1 - copy_byte) / interleave * copy_width;
5e675b72
AM
3056 osection->lma /= interleave;
3057 }
252b5132 3058
d3ba0551 3059 if (!bfd_set_section_contents (obfd, osection, memhunk, 0, size))
2db6cde7
NS
3060 {
3061 status = 1;
3062 bfd_nonfatal_message (NULL, obfd, osection, NULL);
3063 return;
3064 }
252b5132
RH
3065 free (memhunk);
3066 }
2e62b721
NC
3067 else if ((p = find_section_list (bfd_get_section_name (ibfd, isection),
3068 FALSE, SECTION_CONTEXT_SET_FLAGS)) != NULL
3069 && (p->flags & SEC_HAS_CONTENTS) != 0)
252b5132 3070 {
d3ba0551 3071 void *memhunk = xmalloc (size);
252b5132
RH
3072
3073 /* We don't permit the user to turn off the SEC_HAS_CONTENTS
3074 flag--they can just remove the section entirely and add it
3075 back again. However, we do permit them to turn on the
3076 SEC_HAS_CONTENTS flag, and take it to mean that the section
3077 contents should be zeroed out. */
3078
3079 memset (memhunk, 0, size);
d3ba0551 3080 if (! bfd_set_section_contents (obfd, osection, memhunk, 0, size))
2db6cde7
NS
3081 {
3082 status = 1;
3083 bfd_nonfatal_message (NULL, obfd, osection, NULL);
3084 return;
3085 }
252b5132
RH
3086 free (memhunk);
3087 }
3088}
3089
3090/* Get all the sections. This is used when --gap-fill or --pad-to is
3091 used. */
3092
3093static void
84e2f313 3094get_sections (bfd *obfd ATTRIBUTE_UNUSED, asection *osection, void *secppparg)
252b5132 3095{
3f5e193b 3096 asection ***secppp = (asection ***) secppparg;
252b5132
RH
3097
3098 **secppp = osection;
3099 ++(*secppp);
3100}
3101
3102/* Sort sections by VMA. This is called via qsort, and is used when
3103 --gap-fill or --pad-to is used. We force non loadable or empty
3104 sections to the front, where they are easier to ignore. */
3105
3106static int
84e2f313 3107compare_section_lma (const void *arg1, const void *arg2)
252b5132 3108{
3f5e193b
NC
3109 const asection *const *sec1 = (const asection * const *) arg1;
3110 const asection *const *sec2 = (const asection * const *) arg2;
252b5132
RH
3111 flagword flags1, flags2;
3112
3113 /* Sort non loadable sections to the front. */
3114 flags1 = (*sec1)->flags;
3115 flags2 = (*sec2)->flags;
3116 if ((flags1 & SEC_HAS_CONTENTS) == 0
3117 || (flags1 & SEC_LOAD) == 0)
3118 {
3119 if ((flags2 & SEC_HAS_CONTENTS) != 0
3120 && (flags2 & SEC_LOAD) != 0)
3121 return -1;
3122 }
3123 else
3124 {
3125 if ((flags2 & SEC_HAS_CONTENTS) == 0
3126 || (flags2 & SEC_LOAD) == 0)
3127 return 1;
3128 }
3129
3130 /* Sort sections by LMA. */
3131 if ((*sec1)->lma > (*sec2)->lma)
3132 return 1;
3133 else if ((*sec1)->lma < (*sec2)->lma)
3134 return -1;
3135
3136 /* Sort sections with the same LMA by size. */
135dfb4a 3137 if (bfd_get_section_size (*sec1) > bfd_get_section_size (*sec2))
252b5132 3138 return 1;
135dfb4a 3139 else if (bfd_get_section_size (*sec1) < bfd_get_section_size (*sec2))
252b5132
RH
3140 return -1;
3141
3142 return 0;
3143}
3144
3145/* Mark all the symbols which will be used in output relocations with
3146 the BSF_KEEP flag so that those symbols will not be stripped.
3147
3148 Ignore relocations which will not appear in the output file. */
3149
3150static void
84e2f313 3151mark_symbols_used_in_relocations (bfd *ibfd, sec_ptr isection, void *symbolsarg)
252b5132 3152{
3f5e193b 3153 asymbol **symbols = (asymbol **) symbolsarg;
252b5132
RH
3154 long relsize;
3155 arelent **relpp;
3156 long relcount, i;
3157
3158 /* Ignore an input section with no corresponding output section. */
3159 if (isection->output_section == NULL)
3160 return;
3161
3162 relsize = bfd_get_reloc_upper_bound (ibfd, isection);
3163 if (relsize < 0)
ed570f48
NC
3164 {
3165 /* Do not complain if the target does not support relocations. */
3166 if (relsize == -1 && bfd_get_error () == bfd_error_invalid_operation)
3167 return;
3168 bfd_fatal (bfd_get_filename (ibfd));
3169 }
252b5132
RH
3170
3171 if (relsize == 0)
3172 return;
3173
3f5e193b 3174 relpp = (arelent **) xmalloc (relsize);
252b5132
RH
3175 relcount = bfd_canonicalize_reloc (ibfd, isection, relpp, symbols);
3176 if (relcount < 0)
3177 bfd_fatal (bfd_get_filename (ibfd));
3178
ec5d57d5
NC
3179 /* Examine each symbol used in a relocation. If it's not one of the
3180 special bfd section symbols, then mark it with BSF_KEEP. */
252b5132
RH
3181 for (i = 0; i < relcount; i++)
3182 {
ec5d57d5
NC
3183 if (*relpp[i]->sym_ptr_ptr != bfd_com_section_ptr->symbol
3184 && *relpp[i]->sym_ptr_ptr != bfd_abs_section_ptr->symbol
3185 && *relpp[i]->sym_ptr_ptr != bfd_und_section_ptr->symbol)
3186 (*relpp[i]->sym_ptr_ptr)->flags |= BSF_KEEP;
252b5132
RH
3187 }
3188
3189 if (relpp != NULL)
3190 free (relpp);
3191}
3192
3193/* Write out debugging information. */
3194
b34976b6 3195static bfd_boolean
84e2f313
NC
3196write_debugging_info (bfd *obfd, void *dhandle,
3197 long *symcountp ATTRIBUTE_UNUSED,
3198 asymbol ***symppp ATTRIBUTE_UNUSED)
252b5132
RH
3199{
3200 if (bfd_get_flavour (obfd) == bfd_target_ieee_flavour)
3201 return write_ieee_debugging_info (obfd, dhandle);
3202
3203 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour
3204 || bfd_get_flavour (obfd) == bfd_target_elf_flavour)
3205 {
3206 bfd_byte *syms, *strings;
3207 bfd_size_type symsize, stringsize;
3208 asection *stabsec, *stabstrsec;
551b43fd 3209 flagword flags;
252b5132
RH
3210
3211 if (! write_stabs_in_sections_debugging_info (obfd, dhandle, &syms,
3212 &symsize, &strings,
3213 &stringsize))
b34976b6 3214 return FALSE;
252b5132 3215
551b43fd
AM
3216 flags = SEC_HAS_CONTENTS | SEC_READONLY | SEC_DEBUGGING;
3217 stabsec = bfd_make_section_with_flags (obfd, ".stab", flags);
3218 stabstrsec = bfd_make_section_with_flags (obfd, ".stabstr", flags);
252b5132
RH
3219 if (stabsec == NULL
3220 || stabstrsec == NULL
3221 || ! bfd_set_section_size (obfd, stabsec, symsize)
3222 || ! bfd_set_section_size (obfd, stabstrsec, stringsize)
3223 || ! bfd_set_section_alignment (obfd, stabsec, 2)
551b43fd 3224 || ! bfd_set_section_alignment (obfd, stabstrsec, 0))
252b5132 3225 {
2db6cde7
NS
3226 bfd_nonfatal_message (NULL, obfd, NULL,
3227 _("can't create debugging section"));
b34976b6 3228 return FALSE;
252b5132
RH
3229 }
3230
3231 /* We can get away with setting the section contents now because
3232 the next thing the caller is going to do is copy over the
3233 real sections. We may someday have to split the contents
3234 setting out of this function. */
d3ba0551
AM
3235 if (! bfd_set_section_contents (obfd, stabsec, syms, 0, symsize)
3236 || ! bfd_set_section_contents (obfd, stabstrsec, strings, 0,
3237 stringsize))
252b5132 3238 {
2db6cde7
NS
3239 bfd_nonfatal_message (NULL, obfd, NULL,
3240 _("can't set debugging section contents"));
b34976b6 3241 return FALSE;
252b5132
RH
3242 }
3243
b34976b6 3244 return TRUE;
252b5132
RH
3245 }
3246
2db6cde7
NS
3247 bfd_nonfatal_message (NULL, obfd, NULL,
3248 _("don't know how to write debugging information for %s"),
3249 bfd_get_target (obfd));
b34976b6 3250 return FALSE;
252b5132
RH
3251}
3252
955d0b3b
RM
3253/* If neither -D nor -U was specified explicitly,
3254 then use the configured default. */
3255static void
3256default_deterministic (void)
3257{
3258 if (deterministic < 0)
3259 deterministic = DEFAULT_AR_DETERMINISTIC;
3260}
3261
252b5132 3262static int
84e2f313 3263strip_main (int argc, char *argv[])
252b5132 3264{
7c29036b
NC
3265 char *input_target = NULL;
3266 char *output_target = NULL;
b34976b6 3267 bfd_boolean show_version = FALSE;
7c29036b
NC
3268 bfd_boolean formats_info = FALSE;
3269 int c;
3270 int i;
252b5132
RH
3271 char *output_file = NULL;
3272
7a093a78 3273 while ((c = getopt_long (argc, argv, "I:O:F:K:N:R:o:sSpdgxXHhVvwDU",
252b5132
RH
3274 strip_options, (int *) 0)) != EOF)
3275 {
3276 switch (c)
3277 {
3278 case 'I':
3279 input_target = optarg;
3280 break;
3281 case 'O':
3282 output_target = optarg;
3283 break;
3284 case 'F':
3285 input_target = output_target = optarg;
3286 break;
3287 case 'R':
2e62b721 3288 find_section_list (optarg, TRUE, SECTION_CONTEXT_REMOVE);
b34976b6 3289 sections_removed = TRUE;
252b5132
RH
3290 break;
3291 case 's':
3292 strip_symbols = STRIP_ALL;
3293 break;
3294 case 'S':
3295 case 'g':
db4f6831 3296 case 'd': /* Historic BSD alias for -g. Used by early NetBSD. */
252b5132
RH
3297 strip_symbols = STRIP_DEBUG;
3298 break;
96109726
CC
3299 case OPTION_STRIP_DWO:
3300 strip_symbols = STRIP_DWO;
3301 break;
252b5132
RH
3302 case OPTION_STRIP_UNNEEDED:
3303 strip_symbols = STRIP_UNNEEDED;
3304 break;
3305 case 'K':
047c9024 3306 add_specific_symbol (optarg, keep_specific_htab);
252b5132
RH
3307 break;
3308 case 'N':
047c9024 3309 add_specific_symbol (optarg, strip_specific_htab);
252b5132
RH
3310 break;
3311 case 'o':
3312 output_file = optarg;
3313 break;
3314 case 'p':
b34976b6 3315 preserve_dates = TRUE;
252b5132 3316 break;
2e30cb57
CC
3317 case 'D':
3318 deterministic = TRUE;
3319 break;
955d0b3b
RM
3320 case 'U':
3321 deterministic = FALSE;
3322 break;
252b5132
RH
3323 case 'x':
3324 discard_locals = LOCALS_ALL;
3325 break;
3326 case 'X':
3327 discard_locals = LOCALS_START_L;
3328 break;
3329 case 'v':
b34976b6 3330 verbose = TRUE;
252b5132
RH
3331 break;
3332 case 'V':
b34976b6 3333 show_version = TRUE;
252b5132 3334 break;
7c29036b
NC
3335 case OPTION_FORMATS_INFO:
3336 formats_info = TRUE;
3337 break;
ed1653a7
NC
3338 case OPTION_ONLY_KEEP_DEBUG:
3339 strip_symbols = STRIP_NONDEBUG;
3340 break;
1637cd90
JB
3341 case OPTION_KEEP_FILE_SYMBOLS:
3342 keep_file_symbols = 1;
3343 break;
252b5132 3344 case 0:
594ef5db
NC
3345 /* We've been given a long option. */
3346 break;
5fe11841
NC
3347 case 'w':
3348 wildcard = TRUE;
3349 break;
8b53311e 3350 case 'H':
252b5132
RH
3351 case 'h':
3352 strip_usage (stdout, 0);
3353 default:
3354 strip_usage (stderr, 1);
3355 }
3356 }
3357
84e2f313
NC
3358 if (formats_info)
3359 {
3360 display_info ();
3361 return 0;
3362 }
c1c0eb9e 3363
252b5132
RH
3364 if (show_version)
3365 print_version ("strip");
3366
955d0b3b
RM
3367 default_deterministic ();
3368
252b5132
RH
3369 /* Default is to strip all symbols. */
3370 if (strip_symbols == STRIP_UNDEF
3371 && discard_locals == LOCALS_UNDEF
047c9024 3372 && htab_elements (strip_specific_htab) == 0)
252b5132
RH
3373 strip_symbols = STRIP_ALL;
3374
d3ba0551 3375 if (output_target == NULL)
252b5132
RH
3376 output_target = input_target;
3377
3378 i = optind;
3379 if (i == argc
3380 || (output_file != NULL && (i + 1) < argc))
3381 strip_usage (stderr, 1);
3382
3383 for (; i < argc; i++)
3384 {
3385 int hold_status = status;
3386 struct stat statbuf;
3387 char *tmpname;
3388
f24ddbdd 3389 if (get_file_size (argv[i]) < 1)
d68c385b
NC
3390 {
3391 status = 1;
3392 continue;
3393 }
f24ddbdd 3394
252b5132 3395 if (preserve_dates)
f24ddbdd
NC
3396 /* No need to check the return value of stat().
3397 It has already been checked in get_file_size(). */
3398 stat (argv[i], &statbuf);
252b5132 3399
8b6efd89
KT
3400 if (output_file == NULL
3401 || filename_cmp (argv[i], output_file) == 0)
252b5132 3402 tmpname = make_tempname (argv[i]);
12f498a7
NS
3403 else
3404 tmpname = output_file;
252b5132 3405
f9c026a8
NC
3406 if (tmpname == NULL)
3407 {
2db6cde7
NS
3408 bfd_nonfatal_message (argv[i], NULL, NULL,
3409 _("could not create temporary file to hold stripped copy"));
f9c026a8
NC
3410 status = 1;
3411 continue;
3412 }
3413
d68c385b 3414 status = 0;
8b31b6c4 3415 copy_file (argv[i], tmpname, input_target, output_target, NULL);
252b5132
RH
3416 if (status == 0)
3417 {
3418 if (preserve_dates)
3419 set_times (tmpname, &statbuf);
12f498a7 3420 if (output_file != tmpname)
92fac5ec
L
3421 status = (smart_rename (tmpname,
3422 output_file ? output_file : argv[i],
3423 preserve_dates) != 0);
3424 if (status == 0)
3425 status = hold_status;
252b5132
RH
3426 }
3427 else
bb14f524 3428 unlink_if_ordinary (tmpname);
12f498a7 3429 if (output_file != tmpname)
252b5132
RH
3430 free (tmpname);
3431 }
3432
d68c385b 3433 return status;
252b5132
RH
3434}
3435
92dd4511
L
3436/* Set up PE subsystem. */
3437
3438static void
3439set_pe_subsystem (const char *s)
3440{
3441 const char *version, *subsystem;
3442 size_t i;
3443 static const struct
3444 {
3445 const char *name;
3446 const char set_def;
3447 const short value;
3448 }
3449 v[] =
3450 {
955d0b3b 3451 { "native", 0, IMAGE_SUBSYSTEM_NATIVE },
92dd4511
L
3452 { "windows", 0, IMAGE_SUBSYSTEM_WINDOWS_GUI },
3453 { "console", 0, IMAGE_SUBSYSTEM_WINDOWS_CUI },
3454 { "posix", 0, IMAGE_SUBSYSTEM_POSIX_CUI },
3455 { "wince", 0, IMAGE_SUBSYSTEM_WINDOWS_CE_GUI },
3456 { "efi-app", 1, IMAGE_SUBSYSTEM_EFI_APPLICATION },
3457 { "efi-bsd", 1, IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER },
3458 { "efi-rtd", 1, IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER },
d9118602 3459 { "sal-rtd", 1, IMAGE_SUBSYSTEM_SAL_RUNTIME_DRIVER },
92dd4511
L
3460 { "xbox", 0, IMAGE_SUBSYSTEM_XBOX }
3461 };
3462 short value;
3463 char *copy;
3464 int set_def = -1;
3465
3466 /* Check for the presence of a version number. */
3467 version = strchr (s, ':');
3468 if (version == NULL)
3469 subsystem = s;
3470 else
3471 {
3472 int len = version - s;
3473 copy = xstrdup (s);
3474 subsystem = copy;
3475 copy[len] = '\0';
3476 version = copy + 1 + len;
3477 pe_major_subsystem_version = strtoul (version, &copy, 0);
3478 if (*copy == '.')
3479 pe_minor_subsystem_version = strtoul (copy + 1, &copy, 0);
3480 if (*copy != '\0')
3481 non_fatal (_("%s: bad version in PE subsystem"), s);
3482 }
3483
3484 /* Check for numeric subsystem. */
3485 value = (short) strtol (subsystem, &copy, 0);
3486 if (*copy == '\0')
3487 {
3488 for (i = 0; i < ARRAY_SIZE (v); i++)
3489 if (v[i].value == value)
3490 {
3491 pe_subsystem = value;
3492 set_def = v[i].set_def;
3493 break;
3494 }
3495 }
3496 else
3497 {
3498 /* Search for subsystem by name. */
3499 for (i = 0; i < ARRAY_SIZE (v); i++)
3500 if (strcmp (subsystem, v[i].name) == 0)
3501 {
3502 pe_subsystem = v[i].value;
3503 set_def = v[i].set_def;
3504 break;
3505 }
3506 }
3507
3508 switch (set_def)
3509 {
3510 case -1:
3511 fatal (_("unknown PE subsystem: %s"), s);
3512 break;
3513 case 0:
3514 break;
3515 default:
3516 if (pe_file_alignment == (bfd_vma) -1)
3517 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
3518 if (pe_section_alignment == (bfd_vma) -1)
3519 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
3520 break;
3521 }
0cbf3531
MS
3522 if (s != subsystem)
3523 free ((char *) subsystem);
92dd4511
L
3524}
3525
3526/* Convert EFI target to PEI target. */
3527
3528static void
3529convert_efi_target (char *efi)
3530{
3531 efi[0] = 'p';
3532 efi[1] = 'e';
3533 efi[2] = 'i';
3534
3535 if (strcmp (efi + 4, "ia32") == 0)
3536 {
3537 /* Change ia32 to i386. */
3538 efi[5]= '3';
3539 efi[6]= '8';
3540 efi[7]= '6';
3541 }
3542 else if (strcmp (efi + 4, "x86_64") == 0)
3543 {
3544 /* Change x86_64 to x86-64. */
3545 efi[7] = '-';
3546 }
3547}
3548
7173b38a
AB
3549/* Allocate and return a pointer to a struct section_add, initializing the
3550 structure using OPTARG, a string in the format "sectionname=filename".
3551 The returned structure will have its next pointer set to NEXT. The
3552 OPTION field is the name of the command line option currently being
3553 parsed, and is only used if an error needs to be reported. */
3554
3555static struct section_add *
3556init_section_add (const char *optarg,
3557 struct section_add *next,
3558 const char *option)
3559{
3560 struct section_add *pa;
3561 const char *s;
3562
3563 s = strchr (optarg, '=');
3564 if (s == NULL)
3565 fatal (_("bad format for %s"), option);
3566
3567 pa = (struct section_add *) xmalloc (sizeof (struct section_add));
3568 pa->name = xstrndup (optarg, s - optarg);
3569 pa->filename = s + 1;
3570 pa->next = next;
3571 pa->contents = NULL;
3572 pa->size = 0;
3573
3574 return pa;
3575}
3576
3577/* Load the file specified in PA, allocating memory to hold the file
3578 contents, and store a pointer to the allocated memory in the contents
3579 field of PA. The size field of PA is also updated. All errors call
3580 FATAL. */
3581
3582static void
3583section_add_load_file (struct section_add *pa)
3584{
3585 size_t off, alloc;
3586 FILE *f;
3587
3588 /* We don't use get_file_size so that we can do
3589 --add-section .note.GNU_stack=/dev/null
3590 get_file_size doesn't work on /dev/null. */
3591
3592 f = fopen (pa->filename, FOPEN_RB);
3593 if (f == NULL)
3594 fatal (_("cannot open: %s: %s"),
3595 pa->filename, strerror (errno));
3596
3597 off = 0;
3598 alloc = 4096;
3599 pa->contents = (bfd_byte *) xmalloc (alloc);
3600 while (!feof (f))
3601 {
3602 off_t got;
3603
3604 if (off == alloc)
3605 {
3606 alloc <<= 1;
3607 pa->contents = (bfd_byte *) xrealloc (pa->contents, alloc);
3608 }
3609
3610 got = fread (pa->contents + off, 1, alloc - off, f);
3611 if (ferror (f))
3612 fatal (_("%s: fread failed"), pa->filename);
3613
3614 off += got;
3615 }
3616
3617 pa->size = off;
3618
3619 fclose (f);
3620}
3621
252b5132 3622static int
84e2f313 3623copy_main (int argc, char *argv[])
252b5132 3624{
7c29036b
NC
3625 char *input_filename = NULL;
3626 char *output_filename = NULL;
c1c0eb9e 3627 char *tmpname;
7c29036b
NC
3628 char *input_target = NULL;
3629 char *output_target = NULL;
b34976b6
AM
3630 bfd_boolean show_version = FALSE;
3631 bfd_boolean change_warn = TRUE;
7c29036b 3632 bfd_boolean formats_info = FALSE;
252b5132 3633 int c;
252b5132 3634 struct stat statbuf;
8b31b6c4 3635 const bfd_arch_info_type *input_arch = NULL;
252b5132 3636
7a093a78 3637 while ((c = getopt_long (argc, argv, "b:B:i:I:j:K:N:s:O:d:F:L:G:R:SpgxXHhVvW:wDU",
252b5132
RH
3638 copy_options, (int *) 0)) != EOF)
3639 {
3640 switch (c)
3641 {
3642 case 'b':
3643 copy_byte = atoi (optarg);
3644 if (copy_byte < 0)
3645 fatal (_("byte number must be non-negative"));
3646 break;
57938635 3647
0af11b59 3648 case 'B':
8b31b6c4
NC
3649 input_arch = bfd_scan_arch (optarg);
3650 if (input_arch == NULL)
3651 fatal (_("architecture %s unknown"), optarg);
0af11b59 3652 break;
43a0748c 3653
252b5132 3654 case 'i':
b7dd81f7
NC
3655 if (optarg)
3656 {
3657 interleave = atoi (optarg);
3658 if (interleave < 1)
3659 fatal (_("interleave must be positive"));
3660 }
3661 else
3662 interleave = 4;
3663 break;
3664
3665 case OPTION_INTERLEAVE_WIDTH:
3666 copy_width = atoi (optarg);
3667 if (copy_width < 1)
3668 fatal(_("interleave width must be positive"));
252b5132 3669 break;
57938635 3670
252b5132
RH
3671 case 'I':
3672 case 's': /* "source" - 'I' is preferred */
3673 input_target = optarg;
3674 break;
57938635 3675
252b5132
RH
3676 case 'O':
3677 case 'd': /* "destination" - 'O' is preferred */
3678 output_target = optarg;
3679 break;
57938635 3680
252b5132
RH
3681 case 'F':
3682 input_target = output_target = optarg;
3683 break;
57938635 3684
f91ea849 3685 case 'j':
2e62b721 3686 find_section_list (optarg, TRUE, SECTION_CONTEXT_COPY);
b34976b6 3687 sections_copied = TRUE;
f91ea849 3688 break;
57938635 3689
252b5132 3690 case 'R':
2e62b721 3691 find_section_list (optarg, TRUE, SECTION_CONTEXT_REMOVE);
b34976b6 3692 sections_removed = TRUE;
252b5132 3693 break;
57938635 3694
252b5132
RH
3695 case 'S':
3696 strip_symbols = STRIP_ALL;
3697 break;
57938635 3698
252b5132
RH
3699 case 'g':
3700 strip_symbols = STRIP_DEBUG;
3701 break;
57938635 3702
96109726
CC
3703 case OPTION_STRIP_DWO:
3704 strip_symbols = STRIP_DWO;
3705 break;
3706
252b5132
RH
3707 case OPTION_STRIP_UNNEEDED:
3708 strip_symbols = STRIP_UNNEEDED;
3709 break;
57938635 3710
ed1653a7
NC
3711 case OPTION_ONLY_KEEP_DEBUG:
3712 strip_symbols = STRIP_NONDEBUG;
3713 break;
3714
1637cd90
JB
3715 case OPTION_KEEP_FILE_SYMBOLS:
3716 keep_file_symbols = 1;
3717 break;
3718
2593f09a 3719 case OPTION_ADD_GNU_DEBUGLINK:
9b8bf321 3720 long_section_names = ENABLE ;
2593f09a
NC
3721 gnu_debuglink_filename = optarg;
3722 break;
3723
252b5132 3724 case 'K':
047c9024 3725 add_specific_symbol (optarg, keep_specific_htab);
252b5132 3726 break;
57938635 3727
252b5132 3728 case 'N':
047c9024 3729 add_specific_symbol (optarg, strip_specific_htab);
252b5132 3730 break;
57938635 3731
bcf32829 3732 case OPTION_STRIP_UNNEEDED_SYMBOL:
047c9024 3733 add_specific_symbol (optarg, strip_unneeded_htab);
bcf32829
JB
3734 break;
3735
252b5132 3736 case 'L':
047c9024 3737 add_specific_symbol (optarg, localize_specific_htab);
252b5132 3738 break;
57938635 3739
7b4a0685 3740 case OPTION_GLOBALIZE_SYMBOL:
047c9024 3741 add_specific_symbol (optarg, globalize_specific_htab);
7b4a0685
NC
3742 break;
3743
16b2b71c 3744 case 'G':
047c9024 3745 add_specific_symbol (optarg, keepglobal_specific_htab);
16b2b71c
NC
3746 break;
3747
252b5132 3748 case 'W':
047c9024 3749 add_specific_symbol (optarg, weaken_specific_htab);
252b5132 3750 break;
57938635 3751
252b5132 3752 case 'p':
b34976b6 3753 preserve_dates = TRUE;
252b5132 3754 break;
57938635 3755
2e30cb57
CC
3756 case 'D':
3757 deterministic = TRUE;
3758 break;
3759
955d0b3b
RM
3760 case 'U':
3761 deterministic = FALSE;
3762 break;
3763
5fe11841
NC
3764 case 'w':
3765 wildcard = TRUE;
3766 break;
3767
252b5132
RH
3768 case 'x':
3769 discard_locals = LOCALS_ALL;
3770 break;
57938635 3771
252b5132
RH
3772 case 'X':
3773 discard_locals = LOCALS_START_L;
3774 break;
57938635 3775
252b5132 3776 case 'v':
b34976b6 3777 verbose = TRUE;
252b5132 3778 break;
57938635 3779
252b5132 3780 case 'V':
b34976b6 3781 show_version = TRUE;
252b5132 3782 break;
57938635 3783
7c29036b
NC
3784 case OPTION_FORMATS_INFO:
3785 formats_info = TRUE;
3786 break;
3787
252b5132 3788 case OPTION_WEAKEN:
b34976b6 3789 weaken = TRUE;
252b5132 3790 break;
57938635 3791
252b5132 3792 case OPTION_ADD_SECTION:
7173b38a
AB
3793 add_sections = init_section_add (optarg, add_sections,
3794 "--add-section");
3795 section_add_load_file (add_sections);
252b5132 3796 break;
57938635 3797
bbad633b 3798 case OPTION_DUMP_SECTION:
7173b38a
AB
3799 dump_sections = init_section_add (optarg, dump_sections,
3800 "--dump-section");
bbad633b
NC
3801 break;
3802
252b5132
RH
3803 case OPTION_CHANGE_START:
3804 change_start = parse_vma (optarg, "--change-start");
3805 break;
57938635 3806
252b5132
RH
3807 case OPTION_CHANGE_SECTION_ADDRESS:
3808 case OPTION_CHANGE_SECTION_LMA:
3809 case OPTION_CHANGE_SECTION_VMA:
3810 {
2e62b721 3811 struct section_list * p;
76d8cf45 3812 unsigned int context = 0;
252b5132
RH
3813 const char *s;
3814 int len;
3815 char *name;
b4c96d0d 3816 char *option = NULL;
252b5132 3817 bfd_vma val;
57938635 3818
252b5132
RH
3819 switch (c)
3820 {
b4c96d0d
ILT
3821 case OPTION_CHANGE_SECTION_ADDRESS:
3822 option = "--change-section-address";
2e62b721 3823 context = SECTION_CONTEXT_ALTER_LMA | SECTION_CONTEXT_ALTER_VMA;
b4c96d0d
ILT
3824 break;
3825 case OPTION_CHANGE_SECTION_LMA:
3826 option = "--change-section-lma";
2e62b721 3827 context = SECTION_CONTEXT_ALTER_LMA;
b4c96d0d
ILT
3828 break;
3829 case OPTION_CHANGE_SECTION_VMA:
3830 option = "--change-section-vma";
2e62b721 3831 context = SECTION_CONTEXT_ALTER_VMA;
b4c96d0d 3832 break;
252b5132 3833 }
57938635 3834
252b5132
RH
3835 s = strchr (optarg, '=');
3836 if (s == NULL)
3837 {
3838 s = strchr (optarg, '+');
3839 if (s == NULL)
3840 {
3841 s = strchr (optarg, '-');
3842 if (s == NULL)
3843 fatal (_("bad format for %s"), option);
3844 }
3845 }
2e62b721
NC
3846 else
3847 {
3848 /* Correct the context. */
3849 switch (c)
3850 {
3851 case OPTION_CHANGE_SECTION_ADDRESS:
3852 context = SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_SET_VMA;
3853 break;
3854 case OPTION_CHANGE_SECTION_LMA:
3855 context = SECTION_CONTEXT_SET_LMA;
3856 break;
3857 case OPTION_CHANGE_SECTION_VMA:
3858 context = SECTION_CONTEXT_SET_VMA;
3859 break;
3860 }
3861 }
252b5132
RH
3862
3863 len = s - optarg;
3f5e193b 3864 name = (char *) xmalloc (len + 1);
252b5132
RH
3865 strncpy (name, optarg, len);
3866 name[len] = '\0';
3867
2e62b721 3868 p = find_section_list (name, TRUE, context);
252b5132
RH
3869
3870 val = parse_vma (s + 1, option);
2e62b721
NC
3871 if (*s == '-')
3872 val = - val;
57938635 3873
252b5132
RH
3874 switch (c)
3875 {
3876 case OPTION_CHANGE_SECTION_ADDRESS:
2e62b721 3877 p->vma_val = val;
252b5132 3878 /* Drop through. */
57938635 3879
252b5132 3880 case OPTION_CHANGE_SECTION_LMA:
2e62b721 3881 p->lma_val = val;
252b5132 3882 break;
57938635 3883
252b5132 3884 case OPTION_CHANGE_SECTION_VMA:
2e62b721 3885 p->vma_val = val;
252b5132
RH
3886 break;
3887 }
3888 }
3889 break;
57938635 3890
252b5132
RH
3891 case OPTION_CHANGE_ADDRESSES:
3892 change_section_address = parse_vma (optarg, "--change-addresses");
3893 change_start = change_section_address;
3894 break;
57938635 3895
252b5132 3896 case OPTION_CHANGE_WARNINGS:
b34976b6 3897 change_warn = TRUE;
252b5132 3898 break;
57938635 3899
252b5132 3900 case OPTION_CHANGE_LEADING_CHAR:
b34976b6 3901 change_leading_char = TRUE;
252b5132 3902 break;
57938635 3903
4a114e3e
L
3904 case OPTION_COMPRESS_DEBUG_SECTIONS:
3905 do_debug_sections = compress;
3906 break;
3907
252b5132 3908 case OPTION_DEBUGGING:
b34976b6 3909 convert_debugging = TRUE;
252b5132 3910 break;
57938635 3911
4a114e3e
L
3912 case OPTION_DECOMPRESS_DEBUG_SECTIONS:
3913 do_debug_sections = decompress;
3914 break;
3915
252b5132
RH
3916 case OPTION_GAP_FILL:
3917 {
3918 bfd_vma gap_fill_vma;
3919
3920 gap_fill_vma = parse_vma (optarg, "--gap-fill");
3921 gap_fill = (bfd_byte) gap_fill_vma;
3922 if ((bfd_vma) gap_fill != gap_fill_vma)
3923 {
3924 char buff[20];
57938635 3925
252b5132 3926 sprintf_vma (buff, gap_fill_vma);
57938635 3927
252b5132
RH
3928 non_fatal (_("Warning: truncating gap-fill from 0x%s to 0x%x"),
3929 buff, gap_fill);
3930 }
b34976b6 3931 gap_fill_set = TRUE;
252b5132
RH
3932 }
3933 break;
57938635 3934
252b5132 3935 case OPTION_NO_CHANGE_WARNINGS:
b34976b6 3936 change_warn = FALSE;
252b5132 3937 break;
57938635 3938
252b5132
RH
3939 case OPTION_PAD_TO:
3940 pad_to = parse_vma (optarg, "--pad-to");
b34976b6 3941 pad_to_set = TRUE;
252b5132 3942 break;
57938635 3943
252b5132 3944 case OPTION_REMOVE_LEADING_CHAR:
b34976b6 3945 remove_leading_char = TRUE;
252b5132 3946 break;
57938635
AM
3947
3948 case OPTION_REDEFINE_SYM:
3949 {
3950 /* Push this redefinition onto redefine_symbol_list. */
3951
3952 int len;
3953 const char *s;
3954 const char *nextarg;
3955 char *source, *target;
3956
3957 s = strchr (optarg, '=');
3958 if (s == NULL)
594ef5db 3959 fatal (_("bad format for %s"), "--redefine-sym");
57938635
AM
3960
3961 len = s - optarg;
3f5e193b 3962 source = (char *) xmalloc (len + 1);
57938635
AM
3963 strncpy (source, optarg, len);
3964 source[len] = '\0';
3965
3966 nextarg = s + 1;
3967 len = strlen (nextarg);
3f5e193b 3968 target = (char *) xmalloc (len + 1);
57938635
AM
3969 strcpy (target, nextarg);
3970
92991082 3971 redefine_list_append ("--redefine-sym", source, target);
57938635
AM
3972
3973 free (source);
3974 free (target);
3975 }
3976 break;
3977
92991082
JT
3978 case OPTION_REDEFINE_SYMS:
3979 add_redefine_syms_file (optarg);
3980 break;
3981
252b5132
RH
3982 case OPTION_SET_SECTION_FLAGS:
3983 {
2e62b721 3984 struct section_list *p;
252b5132
RH
3985 const char *s;
3986 int len;
3987 char *name;
3988
3989 s = strchr (optarg, '=');
3990 if (s == NULL)
57938635 3991 fatal (_("bad format for %s"), "--set-section-flags");
252b5132
RH
3992
3993 len = s - optarg;
3f5e193b 3994 name = (char *) xmalloc (len + 1);
252b5132
RH
3995 strncpy (name, optarg, len);
3996 name[len] = '\0';
3997
2e62b721 3998 p = find_section_list (name, TRUE, SECTION_CONTEXT_SET_FLAGS);
252b5132 3999
252b5132
RH
4000 p->flags = parse_flags (s + 1);
4001 }
4002 break;
57938635 4003
594ef5db
NC
4004 case OPTION_RENAME_SECTION:
4005 {
4006 flagword flags;
3bcfb3e4
AM
4007 const char *eq, *fl;
4008 char *old_name;
4009 char *new_name;
594ef5db
NC
4010 unsigned int len;
4011
3bcfb3e4
AM
4012 eq = strchr (optarg, '=');
4013 if (eq == NULL)
594ef5db
NC
4014 fatal (_("bad format for %s"), "--rename-section");
4015
3bcfb3e4 4016 len = eq - optarg;
594ef5db 4017 if (len == 0)
3bcfb3e4 4018 fatal (_("bad format for %s"), "--rename-section");
594ef5db 4019
3f5e193b 4020 old_name = (char *) xmalloc (len + 1);
594ef5db
NC
4021 strncpy (old_name, optarg, len);
4022 old_name[len] = 0;
4023
3bcfb3e4
AM
4024 eq++;
4025 fl = strchr (eq, ',');
4026 if (fl)
594ef5db 4027 {
3bcfb3e4
AM
4028 flags = parse_flags (fl + 1);
4029 len = fl - eq;
594ef5db
NC
4030 }
4031 else
4032 {
594ef5db 4033 flags = -1;
3bcfb3e4 4034 len = strlen (eq);
594ef5db
NC
4035 }
4036
3bcfb3e4
AM
4037 if (len == 0)
4038 fatal (_("bad format for %s"), "--rename-section");
4039
3f5e193b 4040 new_name = (char *) xmalloc (len + 1);
3bcfb3e4
AM
4041 strncpy (new_name, eq, len);
4042 new_name[len] = 0;
4043
594ef5db
NC
4044 add_section_rename (old_name, new_name, flags);
4045 }
4046 break;
4047
252b5132
RH
4048 case OPTION_SET_START:
4049 set_start = parse_vma (optarg, "--set-start");
b34976b6 4050 set_start_set = TRUE;
252b5132 4051 break;
57938635 4052
0af11b59
KH
4053 case OPTION_SREC_LEN:
4054 Chunk = parse_vma (optarg, "--srec-len");
4055 break;
420496c1 4056
0af11b59 4057 case OPTION_SREC_FORCES3:
b34976b6 4058 S3Forced = TRUE;
0af11b59 4059 break;
420496c1 4060
16b2b71c 4061 case OPTION_STRIP_SYMBOLS:
047c9024 4062 add_specific_symbols (optarg, strip_specific_htab);
16b2b71c
NC
4063 break;
4064
bcf32829 4065 case OPTION_STRIP_UNNEEDED_SYMBOLS:
047c9024 4066 add_specific_symbols (optarg, strip_unneeded_htab);
bcf32829
JB
4067 break;
4068
16b2b71c 4069 case OPTION_KEEP_SYMBOLS:
047c9024 4070 add_specific_symbols (optarg, keep_specific_htab);
16b2b71c
NC
4071 break;
4072
d58c2e3a
RS
4073 case OPTION_LOCALIZE_HIDDEN:
4074 localize_hidden = TRUE;
4075 break;
4076
16b2b71c 4077 case OPTION_LOCALIZE_SYMBOLS:
047c9024 4078 add_specific_symbols (optarg, localize_specific_htab);
16b2b71c
NC
4079 break;
4080
0408dee6
DK
4081 case OPTION_LONG_SECTION_NAMES:
4082 if (!strcmp ("enable", optarg))
4083 long_section_names = ENABLE;
4084 else if (!strcmp ("disable", optarg))
4085 long_section_names = DISABLE;
4086 else if (!strcmp ("keep", optarg))
4087 long_section_names = KEEP;
4088 else
4089 fatal (_("unknown long section names option '%s'"), optarg);
4090 break;
4091
7b4a0685 4092 case OPTION_GLOBALIZE_SYMBOLS:
047c9024 4093 add_specific_symbols (optarg, globalize_specific_htab);
7b4a0685
NC
4094 break;
4095
16b2b71c 4096 case OPTION_KEEPGLOBAL_SYMBOLS:
047c9024 4097 add_specific_symbols (optarg, keepglobal_specific_htab);
16b2b71c
NC
4098 break;
4099
4100 case OPTION_WEAKEN_SYMBOLS:
047c9024 4101 add_specific_symbols (optarg, weaken_specific_htab);
16b2b71c
NC
4102 break;
4103
1ae8b3d2 4104 case OPTION_ALT_MACH_CODE:
f9d4ad2a
NC
4105 use_alt_mach_code = strtoul (optarg, NULL, 0);
4106 if (use_alt_mach_code == 0)
4107 fatal (_("unable to parse alternative machine code"));
1ae8b3d2
AO
4108 break;
4109
d7fb0dd2
NC
4110 case OPTION_PREFIX_SYMBOLS:
4111 prefix_symbols_string = optarg;
4112 break;
4113
4114 case OPTION_PREFIX_SECTIONS:
4115 prefix_sections_string = optarg;
4116 break;
4117
4118 case OPTION_PREFIX_ALLOC_SECTIONS:
4119 prefix_alloc_sections_string = optarg;
4120 break;
4121
4087920c
MR
4122 case OPTION_READONLY_TEXT:
4123 bfd_flags_to_set |= WP_TEXT;
4124 bfd_flags_to_clear &= ~WP_TEXT;
4125 break;
4126
4127 case OPTION_WRITABLE_TEXT:
4128 bfd_flags_to_clear |= WP_TEXT;
4129 bfd_flags_to_set &= ~WP_TEXT;
4130 break;
4131
4132 case OPTION_PURE:
4133 bfd_flags_to_set |= D_PAGED;
4134 bfd_flags_to_clear &= ~D_PAGED;
4135 break;
4136
4137 case OPTION_IMPURE:
4138 bfd_flags_to_clear |= D_PAGED;
4139 bfd_flags_to_set &= ~D_PAGED;
4140 break;
4141
96109726
CC
4142 case OPTION_EXTRACT_DWO:
4143 strip_symbols = STRIP_NONDWO;
4144 break;
4145
d3e52d40
RS
4146 case OPTION_EXTRACT_SYMBOL:
4147 extract_symbol = TRUE;
4148 break;
4149
9e48b4c6
NC
4150 case OPTION_REVERSE_BYTES:
4151 {
4152 int prev = reverse_bytes;
4153
4154 reverse_bytes = atoi (optarg);
4155 if ((reverse_bytes <= 0) || ((reverse_bytes % 2) != 0))
4156 fatal (_("number of bytes to reverse must be positive and even"));
4157
4158 if (prev && prev != reverse_bytes)
4159 non_fatal (_("Warning: ignoring previous --reverse-bytes value of %d"),
4160 prev);
4161 break;
4162 }
4163
92dd4511
L
4164 case OPTION_FILE_ALIGNMENT:
4165 pe_file_alignment = parse_vma (optarg, "--file-alignment");
4166 break;
955d0b3b 4167
92dd4511
L
4168 case OPTION_HEAP:
4169 {
4170 char *end;
4171 pe_heap_reserve = strtoul (optarg, &end, 0);
4172 if (end == optarg
4173 || (*end != '.' && *end != '\0'))
4174 non_fatal (_("%s: invalid reserve value for --heap"),
4175 optarg);
4176 else if (*end != '\0')
4177 {
4178 pe_heap_commit = strtoul (end + 1, &end, 0);
4179 if (*end != '\0')
4180 non_fatal (_("%s: invalid commit value for --heap"),
4181 optarg);
4182 }
4183 }
4184 break;
955d0b3b 4185
92dd4511
L
4186 case OPTION_IMAGE_BASE:
4187 pe_image_base = parse_vma (optarg, "--image-base");
4188 break;
955d0b3b 4189
92dd4511
L
4190 case OPTION_SECTION_ALIGNMENT:
4191 pe_section_alignment = parse_vma (optarg,
4192 "--section-alignment");
4193 break;
955d0b3b 4194
92dd4511
L
4195 case OPTION_SUBSYSTEM:
4196 set_pe_subsystem (optarg);
4197 break;
955d0b3b 4198
92dd4511
L
4199 case OPTION_STACK:
4200 {
4201 char *end;
4202 pe_stack_reserve = strtoul (optarg, &end, 0);
4203 if (end == optarg
4204 || (*end != '.' && *end != '\0'))
4205 non_fatal (_("%s: invalid reserve value for --stack"),
4206 optarg);
4207 else if (*end != '\0')
4208 {
4209 pe_stack_commit = strtoul (end + 1, &end, 0);
4210 if (*end != '\0')
4211 non_fatal (_("%s: invalid commit value for --stack"),
4212 optarg);
4213 }
4214 }
4215 break;
955d0b3b 4216
252b5132 4217 case 0:
2593f09a
NC
4218 /* We've been given a long option. */
4219 break;
57938635 4220
8b53311e 4221 case 'H':
252b5132
RH
4222 case 'h':
4223 copy_usage (stdout, 0);
57938635 4224
252b5132
RH
4225 default:
4226 copy_usage (stderr, 1);
4227 }
4228 }
4229
7c29036b
NC
4230 if (formats_info)
4231 {
4232 display_info ();
4233 return 0;
4234 }
c1c0eb9e 4235
252b5132
RH
4236 if (show_version)
4237 print_version ("objcopy");
4238
b7dd81f7
NC
4239 if (interleave && copy_byte == -1)
4240 fatal (_("interleave start byte must be set with --byte"));
4241
252b5132
RH
4242 if (copy_byte >= interleave)
4243 fatal (_("byte number must be less than interleave"));
4244
b7dd81f7
NC
4245 if (copy_width > interleave - copy_byte)
4246 fatal (_("interleave width must be less than or equal to interleave - byte`"));
4247
252b5132
RH
4248 if (optind == argc || optind + 2 < argc)
4249 copy_usage (stderr, 1);
4250
4251 input_filename = argv[optind];
4252 if (optind + 1 < argc)
4253 output_filename = argv[optind + 1];
4254
955d0b3b
RM
4255 default_deterministic ();
4256
252b5132
RH
4257 /* Default is to strip no symbols. */
4258 if (strip_symbols == STRIP_UNDEF && discard_locals == LOCALS_UNDEF)
4259 strip_symbols = STRIP_NONE;
4260
d3ba0551 4261 if (output_target == NULL)
252b5132
RH
4262 output_target = input_target;
4263
92dd4511
L
4264 /* Convert input EFI target to PEI target. */
4265 if (input_target != NULL
4266 && strncmp (input_target, "efi-", 4) == 0)
4267 {
4268 char *efi;
4269
4270 efi = xstrdup (output_target + 4);
4271 if (strncmp (efi, "bsdrv-", 6) == 0
4272 || strncmp (efi, "rtdrv-", 6) == 0)
4273 efi += 2;
4274 else if (strncmp (efi, "app-", 4) != 0)
4275 fatal (_("unknown input EFI target: %s"), input_target);
4276
4277 input_target = efi;
4278 convert_efi_target (efi);
4279 }
4280
4281 /* Convert output EFI target to PEI target. */
4282 if (output_target != NULL
4283 && strncmp (output_target, "efi-", 4) == 0)
4284 {
4285 char *efi;
4286
4287 efi = xstrdup (output_target + 4);
4288 if (strncmp (efi, "app-", 4) == 0)
4289 {
4290 if (pe_subsystem == -1)
4291 pe_subsystem = IMAGE_SUBSYSTEM_EFI_APPLICATION;
4292 }
4293 else if (strncmp (efi, "bsdrv-", 6) == 0)
4294 {
4295 if (pe_subsystem == -1)
4296 pe_subsystem = IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER;
4297 efi += 2;
4298 }
4299 else if (strncmp (efi, "rtdrv-", 6) == 0)
4300 {
4301 if (pe_subsystem == -1)
4302 pe_subsystem = IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER;
4303 efi += 2;
4304 }
4305 else
4306 fatal (_("unknown output EFI target: %s"), output_target);
4307
4308 if (pe_file_alignment == (bfd_vma) -1)
4309 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
4310 if (pe_section_alignment == (bfd_vma) -1)
4311 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
4312
4313 output_target = efi;
4314 convert_efi_target (efi);
4315 }
4316
43a0748c
NC
4317 if (preserve_dates)
4318 if (stat (input_filename, & statbuf) < 0)
f24ddbdd
NC
4319 fatal (_("warning: could not locate '%s'. System error message: %s"),
4320 input_filename, strerror (errno));
43a0748c 4321
0fcdcb91 4322 /* If there is no destination file, or the source and destination files
d3ba0551 4323 are the same, then create a temp and rename the result into the input. */
8b6efd89
KT
4324 if (output_filename == NULL
4325 || filename_cmp (input_filename, output_filename) == 0)
12f498a7 4326 tmpname = make_tempname (input_filename);
252b5132 4327 else
12f498a7 4328 tmpname = output_filename;
c1c0eb9e 4329
12f498a7
NS
4330 if (tmpname == NULL)
4331 fatal (_("warning: could not create temporary file whilst copying '%s', (error: %s)"),
4332 input_filename, strerror (errno));
594ef5db 4333
8b31b6c4 4334 copy_file (input_filename, tmpname, input_target, output_target, input_arch);
12f498a7
NS
4335 if (status == 0)
4336 {
4337 if (preserve_dates)
4338 set_times (tmpname, &statbuf);
4339 if (tmpname != output_filename)
92fac5ec
L
4340 status = (smart_rename (tmpname, input_filename,
4341 preserve_dates) != 0);
252b5132 4342 }
12f498a7
NS
4343 else
4344 unlink_if_ordinary (tmpname);
252b5132
RH
4345
4346 if (change_warn)
4347 {
2e62b721
NC
4348 struct section_list *p;
4349
252b5132
RH
4350 for (p = change_sections; p != NULL; p = p->next)
4351 {
4352 if (! p->used)
4353 {
2e62b721 4354 if (p->context & (SECTION_CONTEXT_SET_VMA | SECTION_CONTEXT_ALTER_VMA))
252b5132
RH
4355 {
4356 char buff [20];
4357
4358 sprintf_vma (buff, p->vma_val);
57938635 4359
252b5132 4360 /* xgettext:c-format */
57938635
AM
4361 non_fatal (_("%s %s%c0x%s never used"),
4362 "--change-section-vma",
2e62b721
NC
4363 p->pattern,
4364 p->context & SECTION_CONTEXT_SET_VMA ? '=' : '+',
252b5132
RH
4365 buff);
4366 }
57938635 4367
2e62b721 4368 if (p->context & (SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_ALTER_LMA))
252b5132
RH
4369 {
4370 char buff [20];
4371
4372 sprintf_vma (buff, p->lma_val);
57938635 4373
252b5132 4374 /* xgettext:c-format */
57938635
AM
4375 non_fatal (_("%s %s%c0x%s never used"),
4376 "--change-section-lma",
2e62b721
NC
4377 p->pattern,
4378 p->context & SECTION_CONTEXT_SET_LMA ? '=' : '+',
252b5132
RH
4379 buff);
4380 }
4381 }
4382 }
4383 }
4384
4385 return 0;
4386}
4387
4388int
84e2f313 4389main (int argc, char *argv[])
252b5132
RH
4390{
4391#if defined (HAVE_SETLOCALE) && defined (HAVE_LC_MESSAGES)
4392 setlocale (LC_MESSAGES, "");
3882b010
L
4393#endif
4394#if defined (HAVE_SETLOCALE)
4395 setlocale (LC_CTYPE, "");
252b5132
RH
4396#endif
4397 bindtextdomain (PACKAGE, LOCALEDIR);
4398 textdomain (PACKAGE);
4399
4400 program_name = argv[0];
4401 xmalloc_set_program_name (program_name);
4402
4403 START_PROGRESS (program_name, 0);
4404
869b9d07
MM
4405 expandargv (&argc, &argv);
4406
252b5132
RH
4407 strip_symbols = STRIP_UNDEF;
4408 discard_locals = LOCALS_UNDEF;
4409
4410 bfd_init ();
4411 set_default_bfd_target ();
4412
4413 if (is_strip < 0)
4414 {
4415 int i = strlen (program_name);
5af11cab
AM
4416#ifdef HAVE_DOS_BASED_FILE_SYSTEM
4417 /* Drop the .exe suffix, if any. */
4418 if (i > 4 && FILENAME_CMP (program_name + i - 4, ".exe") == 0)
4419 {
4420 i -= 4;
4421 program_name[i] = '\0';
4422 }
4423#endif
4424 is_strip = (i >= 5 && FILENAME_CMP (program_name + i - 5, "strip") == 0);
252b5132
RH
4425 }
4426
047c9024
NC
4427 create_symbol_htabs ();
4428
86eafac0
NC
4429 if (argv != NULL)
4430 bfd_set_error_program_name (argv[0]);
4431
252b5132
RH
4432 if (is_strip)
4433 strip_main (argc, argv);
4434 else
4435 copy_main (argc, argv);
4436
4437 END_PROGRESS (program_name);
4438
4439 return status;
4440}
This page took 0.92853 seconds and 4 git commands to generate.