Check fwrite return code
[deliverable/binutils-gdb.git] / binutils / objcopy.c
CommitLineData
252b5132 1/* objcopy.c -- copy object file from input to output, optionally massaging it.
4b95cf5c 2 Copyright (C) 1991-2014 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, _("\
8b53311e 635 -R --remove-section=<name> 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
d58c2e3a
RS
1144/* Return true if SYM is a hidden symbol. */
1145
1146static bfd_boolean
1147is_hidden_symbol (asymbol *sym)
1148{
1149 elf_symbol_type *elf_sym;
1150
1151 elf_sym = elf_symbol_from (sym->the_bfd, sym);
1152 if (elf_sym != NULL)
1153 switch (ELF_ST_VISIBILITY (elf_sym->internal_elf_sym.st_other))
1154 {
1155 case STV_HIDDEN:
1156 case STV_INTERNAL:
1157 return TRUE;
1158 }
1159 return FALSE;
1160}
1161
252b5132
RH
1162/* Choose which symbol entries to copy; put the result in OSYMS.
1163 We don't copy in place, because that confuses the relocs.
1164 Return the number of symbols to print. */
1165
1166static unsigned int
84e2f313
NC
1167filter_symbols (bfd *abfd, bfd *obfd, asymbol **osyms,
1168 asymbol **isyms, long symcount)
252b5132 1169{
84e2f313 1170 asymbol **from = isyms, **to = osyms;
252b5132 1171 long src_count = 0, dst_count = 0;
e205a099 1172 int relocatable = (abfd->flags & (EXEC_P | DYNAMIC)) == 0;
252b5132
RH
1173
1174 for (; src_count < symcount; src_count++)
1175 {
1176 asymbol *sym = from[src_count];
1177 flagword flags = sym->flags;
d7fb0dd2 1178 char *name = (char *) bfd_asymbol_name (sym);
312aaa3c
NC
1179 bfd_boolean keep;
1180 bfd_boolean used_in_reloc = FALSE;
b34976b6 1181 bfd_boolean undefined;
d7fb0dd2
NC
1182 bfd_boolean rem_leading_char;
1183 bfd_boolean add_leading_char;
1184
1185 undefined = bfd_is_und_section (bfd_get_section (sym));
252b5132 1186
57938635
AM
1187 if (redefine_sym_list)
1188 {
d7fb0dd2 1189 char *old_name, *new_name;
57938635 1190
d7fb0dd2
NC
1191 old_name = (char *) bfd_asymbol_name (sym);
1192 new_name = (char *) lookup_sym_redefinition (old_name);
66491ebc
AM
1193 bfd_asymbol_name (sym) = new_name;
1194 name = new_name;
57938635
AM
1195 }
1196
d7fb0dd2
NC
1197 /* Check if we will remove the current leading character. */
1198 rem_leading_char =
1199 (name[0] == bfd_get_symbol_leading_char (abfd))
1200 && (change_leading_char
1201 || (remove_leading_char
1202 && ((flags & (BSF_GLOBAL | BSF_WEAK)) != 0
1203 || undefined
1204 || bfd_is_com_section (bfd_get_section (sym)))));
1205
1206 /* Check if we will add a new leading character. */
1207 add_leading_char =
1208 change_leading_char
1209 && (bfd_get_symbol_leading_char (obfd) != '\0')
1210 && (bfd_get_symbol_leading_char (abfd) == '\0'
1211 || (name[0] == bfd_get_symbol_leading_char (abfd)));
1212
1213 /* Short circuit for change_leading_char if we can do it in-place. */
1214 if (rem_leading_char && add_leading_char && !prefix_symbols_string)
1215 {
1216 name[0] = bfd_get_symbol_leading_char (obfd);
1217 bfd_asymbol_name (sym) = name;
1218 rem_leading_char = FALSE;
1219 add_leading_char = FALSE;
1220 }
1221
1222 /* Remove leading char. */
1223 if (rem_leading_char)
66491ebc 1224 bfd_asymbol_name (sym) = ++name;
d7fb0dd2
NC
1225
1226 /* Add new leading char and/or prefix. */
1227 if (add_leading_char || prefix_symbols_string)
1228 {
1229 char *n, *ptr;
1230
3f5e193b
NC
1231 ptr = n = (char *) xmalloc (1 + strlen (prefix_symbols_string)
1232 + strlen (name) + 1);
d7fb0dd2
NC
1233 if (add_leading_char)
1234 *ptr++ = bfd_get_symbol_leading_char (obfd);
1235
1236 if (prefix_symbols_string)
1237 {
1238 strcpy (ptr, prefix_symbols_string);
1239 ptr += strlen (prefix_symbols_string);
1240 }
1241
1242 strcpy (ptr, name);
66491ebc
AM
1243 bfd_asymbol_name (sym) = n;
1244 name = n;
252b5132
RH
1245 }
1246
252b5132 1247 if (strip_symbols == STRIP_ALL)
312aaa3c 1248 keep = FALSE;
252b5132
RH
1249 else if ((flags & BSF_KEEP) != 0 /* Used in relocation. */
1250 || ((flags & BSF_SECTION_SYM) != 0
1251 && ((*bfd_get_section (sym)->symbol_ptr_ptr)->flags
1252 & BSF_KEEP) != 0))
312aaa3c
NC
1253 {
1254 keep = TRUE;
1255 used_in_reloc = TRUE;
1256 }
0af11b59 1257 else if (relocatable /* Relocatable file. */
0691f7af
L
1258 && ((flags & (BSF_GLOBAL | BSF_WEAK)) != 0
1259 || bfd_is_com_section (bfd_get_section (sym))))
312aaa3c 1260 keep = TRUE;
16b2b71c
NC
1261 else if (bfd_decode_symclass (sym) == 'I')
1262 /* Global symbols in $idata sections need to be retained
b34976b6 1263 even if relocatable is FALSE. External users of the
16b2b71c
NC
1264 library containing the $idata section may reference these
1265 symbols. */
312aaa3c 1266 keep = TRUE;
252b5132
RH
1267 else if ((flags & BSF_GLOBAL) != 0 /* Global symbol. */
1268 || (flags & BSF_WEAK) != 0
24e01a36 1269 || undefined
252b5132
RH
1270 || bfd_is_com_section (bfd_get_section (sym)))
1271 keep = strip_symbols != STRIP_UNNEEDED;
1272 else if ((flags & BSF_DEBUGGING) != 0) /* Debugging symbol. */
1273 keep = (strip_symbols != STRIP_DEBUG
1274 && strip_symbols != STRIP_UNNEEDED
1275 && ! convert_debugging);
082b7297 1276 else if (bfd_coff_get_comdat_section (abfd, bfd_get_section (sym)))
af3bdff7
NC
1277 /* COMDAT sections store special information in local
1278 symbols, so we cannot risk stripping any of them. */
312aaa3c 1279 keep = TRUE;
252b5132
RH
1280 else /* Local symbol. */
1281 keep = (strip_symbols != STRIP_UNNEEDED
1282 && (discard_locals != LOCALS_ALL
1283 && (discard_locals != LOCALS_START_L
1284 || ! bfd_is_local_label (abfd, sym))));
1285
047c9024 1286 if (keep && is_specified_symbol (name, strip_specific_htab))
312aaa3c
NC
1287 {
1288 /* There are multiple ways to set 'keep' above, but if it
1289 was the relocatable symbol case, then that's an error. */
1290 if (used_in_reloc)
1291 {
1292 non_fatal (_("not stripping symbol `%s' because it is named in a relocation"), name);
1293 status = 1;
1294 }
1295 else
1296 keep = FALSE;
1297 }
1298
bcf32829
JB
1299 if (keep
1300 && !(flags & BSF_KEEP)
047c9024 1301 && is_specified_symbol (name, strip_unneeded_htab))
312aaa3c
NC
1302 keep = FALSE;
1303
1637cd90
JB
1304 if (!keep
1305 && ((keep_file_symbols && (flags & BSF_FILE))
047c9024 1306 || is_specified_symbol (name, keep_specific_htab)))
312aaa3c
NC
1307 keep = TRUE;
1308
252b5132 1309 if (keep && is_strip_section (abfd, bfd_get_section (sym)))
312aaa3c 1310 keep = FALSE;
e0c60db2 1311
7b4a0685 1312 if (keep)
252b5132 1313 {
7b4a0685 1314 if ((flags & BSF_GLOBAL) != 0
047c9024 1315 && (weaken || is_specified_symbol (name, weaken_specific_htab)))
7b4a0685
NC
1316 {
1317 sym->flags &= ~ BSF_GLOBAL;
1318 sym->flags |= BSF_WEAK;
1319 }
252b5132 1320
7b4a0685
NC
1321 if (!undefined
1322 && (flags & (BSF_GLOBAL | BSF_WEAK))
047c9024
NC
1323 && (is_specified_symbol (name, localize_specific_htab)
1324 || (htab_elements (keepglobal_specific_htab) != 0
1325 && ! is_specified_symbol (name, keepglobal_specific_htab))
d58c2e3a 1326 || (localize_hidden && is_hidden_symbol (sym))))
7b4a0685
NC
1327 {
1328 sym->flags &= ~ (BSF_GLOBAL | BSF_WEAK);
1329 sym->flags |= BSF_LOCAL;
1330 }
1331
1332 if (!undefined
c1c0eb9e 1333 && (flags & BSF_LOCAL)
047c9024 1334 && is_specified_symbol (name, globalize_specific_htab))
7b4a0685
NC
1335 {
1336 sym->flags &= ~ BSF_LOCAL;
1337 sym->flags |= BSF_GLOBAL;
1338 }
1339
1340 to[dst_count++] = sym;
1341 }
252b5132
RH
1342 }
1343
1344 to[dst_count] = NULL;
1345
1346 return dst_count;
1347}
1348
594ef5db
NC
1349/* Find the redefined name of symbol SOURCE. */
1350
57938635 1351static const char *
84e2f313 1352lookup_sym_redefinition (const char *source)
57938635 1353{
57938635
AM
1354 struct redefine_node *list;
1355
57938635 1356 for (list = redefine_sym_list; list != NULL; list = list->next)
594ef5db
NC
1357 if (strcmp (source, list->source) == 0)
1358 return list->target;
1359
1360 return source;
57938635
AM
1361}
1362
594ef5db 1363/* Add a node to a symbol redefine list. */
57938635
AM
1364
1365static void
84e2f313 1366redefine_list_append (const char *cause, const char *source, const char *target)
57938635
AM
1367{
1368 struct redefine_node **p;
1369 struct redefine_node *list;
1370 struct redefine_node *new_node;
1371
1372 for (p = &redefine_sym_list; (list = *p) != NULL; p = &list->next)
1373 {
1374 if (strcmp (source, list->source) == 0)
594ef5db 1375 fatal (_("%s: Multiple redefinition of symbol \"%s\""),
92991082 1376 cause, source);
57938635
AM
1377
1378 if (strcmp (target, list->target) == 0)
594ef5db 1379 fatal (_("%s: Symbol \"%s\" is target of more than one redefinition"),
92991082 1380 cause, target);
57938635
AM
1381 }
1382
3f5e193b 1383 new_node = (struct redefine_node *) xmalloc (sizeof (struct redefine_node));
57938635
AM
1384
1385 new_node->source = strdup (source);
1386 new_node->target = strdup (target);
1387 new_node->next = NULL;
1388
1389 *p = new_node;
1390}
1391
92991082
JT
1392/* Handle the --redefine-syms option. Read lines containing "old new"
1393 from the file, and add them to the symbol redefine list. */
1394
2593f09a 1395static void
84e2f313 1396add_redefine_syms_file (const char *filename)
92991082
JT
1397{
1398 FILE *file;
1399 char *buf;
84e2f313
NC
1400 size_t bufsize;
1401 size_t len;
1402 size_t outsym_off;
92991082
JT
1403 int c, lineno;
1404
1405 file = fopen (filename, "r");
d3ba0551 1406 if (file == NULL)
92991082
JT
1407 fatal (_("couldn't open symbol redefinition file %s (error: %s)"),
1408 filename, strerror (errno));
1409
1410 bufsize = 100;
a6da20b5 1411 buf = (char *) xmalloc (bufsize + 1 /* For the terminating NUL. */);
92991082
JT
1412
1413 lineno = 1;
1414 c = getc (file);
1415 len = 0;
1416 outsym_off = 0;
1417 while (c != EOF)
1418 {
1419 /* Collect the input symbol name. */
1420 while (! IS_WHITESPACE (c) && ! IS_LINE_TERMINATOR (c) && c != EOF)
1421 {
1422 if (c == '#')
1423 goto comment;
1424 buf[len++] = c;
1425 if (len >= bufsize)
1426 {
1427 bufsize *= 2;
a6da20b5 1428 buf = (char *) xrealloc (buf, bufsize + 1);
92991082
JT
1429 }
1430 c = getc (file);
1431 }
1432 buf[len++] = '\0';
1433 if (c == EOF)
1434 break;
1435
1436 /* Eat white space between the symbol names. */
1437 while (IS_WHITESPACE (c))
1438 c = getc (file);
1439 if (c == '#' || IS_LINE_TERMINATOR (c))
1440 goto comment;
1441 if (c == EOF)
1442 break;
1443
1444 /* Collect the output symbol name. */
1445 outsym_off = len;
1446 while (! IS_WHITESPACE (c) && ! IS_LINE_TERMINATOR (c) && c != EOF)
1447 {
1448 if (c == '#')
1449 goto comment;
1450 buf[len++] = c;
1451 if (len >= bufsize)
1452 {
1453 bufsize *= 2;
a6da20b5 1454 buf = (char *) xrealloc (buf, bufsize + 1);
92991082
JT
1455 }
1456 c = getc (file);
1457 }
1458 buf[len++] = '\0';
1459 if (c == EOF)
1460 break;
1461
1462 /* Eat white space at end of line. */
1463 while (! IS_LINE_TERMINATOR(c) && c != EOF && IS_WHITESPACE (c))
1464 c = getc (file);
1465 if (c == '#')
1466 goto comment;
1467 /* Handle \r\n. */
1468 if ((c == '\r' && (c = getc (file)) == '\n')
1469 || c == '\n' || c == EOF)
1470 {
1471 end_of_line:
1472 /* Append the redefinition to the list. */
1473 if (buf[0] != '\0')
1474 redefine_list_append (filename, &buf[0], &buf[outsym_off]);
1475
c1c0eb9e 1476 lineno++;
92991082
JT
1477 len = 0;
1478 outsym_off = 0;
1479 if (c == EOF)
1480 break;
1481 c = getc (file);
1482 continue;
1483 }
1484 else
d412a550 1485 fatal (_("%s:%d: garbage found at end of line"), filename, lineno);
92991082
JT
1486 comment:
1487 if (len != 0 && (outsym_off == 0 || outsym_off == len))
d412a550 1488 fatal (_("%s:%d: missing new symbol name"), filename, lineno);
92991082
JT
1489 buf[len++] = '\0';
1490
1491 /* Eat the rest of the line and finish it. */
1492 while (c != '\n' && c != EOF)
1493 c = getc (file);
1494 goto end_of_line;
1495 }
1496
1497 if (len != 0)
d412a550 1498 fatal (_("%s:%d: premature end of file"), filename, lineno);
92991082
JT
1499
1500 free (buf);
1501}
1502
77f762d6
L
1503/* Copy unkown object file IBFD onto OBFD.
1504 Returns TRUE upon success, FALSE otherwise. */
1505
1506static bfd_boolean
1507copy_unknown_object (bfd *ibfd, bfd *obfd)
1508{
1509 char *cbuf;
1510 int tocopy;
1511 long ncopied;
1512 long size;
1513 struct stat buf;
1514
1515 if (bfd_stat_arch_elt (ibfd, &buf) != 0)
1516 {
8d8e0703 1517 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
77f762d6
L
1518 return FALSE;
1519 }
1520
1521 size = buf.st_size;
1522 if (size < 0)
1523 {
1524 non_fatal (_("stat returns negative size for `%s'"),
1525 bfd_get_archive_filename (ibfd));
1526 return FALSE;
1527 }
1528
1529 if (bfd_seek (ibfd, (file_ptr) 0, SEEK_SET) != 0)
1530 {
1531 bfd_nonfatal (bfd_get_archive_filename (ibfd));
1532 return FALSE;
1533 }
1534
1535 if (verbose)
1536 printf (_("copy from `%s' [unknown] to `%s' [unknown]\n"),
1537 bfd_get_archive_filename (ibfd), bfd_get_filename (obfd));
1538
3f5e193b 1539 cbuf = (char *) xmalloc (BUFSIZE);
77f762d6
L
1540 ncopied = 0;
1541 while (ncopied < size)
1542 {
1543 tocopy = size - ncopied;
1544 if (tocopy > BUFSIZE)
1545 tocopy = BUFSIZE;
1546
1547 if (bfd_bread (cbuf, (bfd_size_type) tocopy, ibfd)
1548 != (bfd_size_type) tocopy)
1549 {
8d8e0703 1550 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
77f762d6
L
1551 free (cbuf);
1552 return FALSE;
1553 }
1554
1555 if (bfd_bwrite (cbuf, (bfd_size_type) tocopy, obfd)
1556 != (bfd_size_type) tocopy)
1557 {
2db6cde7 1558 bfd_nonfatal_message (NULL, obfd, NULL, NULL);
77f762d6
L
1559 free (cbuf);
1560 return FALSE;
1561 }
1562
1563 ncopied += tocopy;
1564 }
1565
1e99536a
L
1566 /* We should at least to be able to read it back when copying an
1567 unknown object in an archive. */
1568 chmod (bfd_get_filename (obfd), buf.st_mode | S_IRUSR);
77f762d6
L
1569 free (cbuf);
1570 return TRUE;
1571}
1572
950d48e7 1573/* Copy object file IBFD onto OBFD.
5b8c74e6 1574 Returns TRUE upon success, FALSE otherwise. */
252b5132 1575
950d48e7 1576static bfd_boolean
8b31b6c4 1577copy_object (bfd *ibfd, bfd *obfd, const bfd_arch_info_type *input_arch)
252b5132
RH
1578{
1579 bfd_vma start;
1580 long symcount;
1581 asection **osections = NULL;
84e2f313 1582 asection *gnu_debuglink_section = NULL;
252b5132
RH
1583 bfd_size_type *gaps = NULL;
1584 bfd_size_type max_gap = 0;
1585 long symsize;
84e2f313 1586 void *dhandle;
66491ebc
AM
1587 enum bfd_architecture iarch;
1588 unsigned int imach;
252b5132 1589
23719f39
NC
1590 if (ibfd->xvec->byteorder != obfd->xvec->byteorder
1591 && ibfd->xvec->byteorder != BFD_ENDIAN_UNKNOWN
1592 && obfd->xvec->byteorder != BFD_ENDIAN_UNKNOWN)
950d48e7 1593 fatal (_("Unable to change endianness of input file(s)"));
252b5132
RH
1594
1595 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
950d48e7 1596 {
2db6cde7 1597 bfd_nonfatal_message (NULL, obfd, NULL, NULL);
950d48e7
NC
1598 return FALSE;
1599 }
252b5132
RH
1600
1601 if (verbose)
77f762d6
L
1602 printf (_("copy from `%s' [%s] to `%s' [%s]\n"),
1603 bfd_get_archive_filename (ibfd), bfd_get_target (ibfd),
252b5132
RH
1604 bfd_get_filename (obfd), bfd_get_target (obfd));
1605
d3e52d40
RS
1606 if (extract_symbol)
1607 start = 0;
252b5132 1608 else
d3e52d40
RS
1609 {
1610 if (set_start_set)
1611 start = set_start;
1612 else
1613 start = bfd_get_start_address (ibfd);
1614 start += change_start;
1615 }
252b5132 1616
0af11b59
KH
1617 /* Neither the start address nor the flags
1618 need to be set for a core file. */
4dd67f29
MS
1619 if (bfd_get_format (obfd) != bfd_core)
1620 {
4087920c
MR
1621 flagword flags;
1622
1623 flags = bfd_get_file_flags (ibfd);
1624 flags |= bfd_flags_to_set;
1625 flags &= ~bfd_flags_to_clear;
1626 flags &= bfd_applicable_file_flags (obfd);
1627
3516e984
L
1628 if (strip_symbols == STRIP_ALL)
1629 flags &= ~HAS_RELOC;
1630
4dd67f29 1631 if (!bfd_set_start_address (obfd, start)
4087920c 1632 || !bfd_set_file_flags (obfd, flags))
950d48e7 1633 {
8d8e0703 1634 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
950d48e7
NC
1635 return FALSE;
1636 }
4dd67f29 1637 }
252b5132 1638
594ef5db 1639 /* Copy architecture of input file to output file. */
66491ebc
AM
1640 iarch = bfd_get_arch (ibfd);
1641 imach = bfd_get_mach (ibfd);
8b31b6c4
NC
1642 if (input_arch)
1643 {
1644 if (bfd_get_arch_info (ibfd) == NULL
1645 || bfd_get_arch_info (ibfd)->arch == bfd_arch_unknown)
1646 {
1647 iarch = input_arch->arch;
1648 imach = input_arch->mach;
1649 }
1650 else
1651 non_fatal (_("Input file `%s' ignores binary architecture parameter."),
1652 bfd_get_archive_filename (ibfd));
1653 }
66491ebc 1654 if (!bfd_set_arch_mach (obfd, iarch, imach)
212a3c4d
L
1655 && (ibfd->target_defaulted
1656 || bfd_get_arch (ibfd) != bfd_get_arch (obfd)))
f57a841a
NC
1657 {
1658 if (bfd_get_arch (ibfd) == bfd_arch_unknown)
77f762d6
L
1659 non_fatal (_("Unable to recognise the format of the input file `%s'"),
1660 bfd_get_archive_filename (ibfd));
f57a841a 1661 else
c1e2cb9d 1662 non_fatal (_("Output file cannot represent architecture `%s'"),
77f762d6
L
1663 bfd_printable_arch_mach (bfd_get_arch (ibfd),
1664 bfd_get_mach (ibfd)));
1665 return FALSE;
f57a841a 1666 }
57938635 1667
252b5132 1668 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
950d48e7 1669 {
8d8e0703 1670 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
950d48e7
NC
1671 return FALSE;
1672 }
252b5132 1673
92dd4511
L
1674 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour
1675 && bfd_pei_p (obfd))
1676 {
1677 /* Set up PE parameters. */
1678 pe_data_type *pe = pe_data (obfd);
1679
325c681d
L
1680 /* Copy PE parameters before changing them. */
1681 if (ibfd->xvec->flavour == bfd_target_coff_flavour
1682 && bfd_pei_p (ibfd))
1683 pe->pe_opthdr = pe_data (ibfd)->pe_opthdr;
1684
92dd4511
L
1685 if (pe_file_alignment != (bfd_vma) -1)
1686 pe->pe_opthdr.FileAlignment = pe_file_alignment;
1687 else
1688 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
1689
1690 if (pe_heap_commit != (bfd_vma) -1)
1691 pe->pe_opthdr.SizeOfHeapCommit = pe_heap_commit;
1692
1693 if (pe_heap_reserve != (bfd_vma) -1)
1694 pe->pe_opthdr.SizeOfHeapCommit = pe_heap_reserve;
1695
1696 if (pe_image_base != (bfd_vma) -1)
1697 pe->pe_opthdr.ImageBase = pe_image_base;
1698
1699 if (pe_section_alignment != (bfd_vma) -1)
1700 pe->pe_opthdr.SectionAlignment = pe_section_alignment;
1701 else
1702 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
1703
1704 if (pe_stack_commit != (bfd_vma) -1)
1705 pe->pe_opthdr.SizeOfStackCommit = pe_stack_commit;
1706
1707 if (pe_stack_reserve != (bfd_vma) -1)
1708 pe->pe_opthdr.SizeOfStackCommit = pe_stack_reserve;
1709
1710 if (pe_subsystem != -1)
1711 pe->pe_opthdr.Subsystem = pe_subsystem;
1712
1713 if (pe_major_subsystem_version != -1)
1714 pe->pe_opthdr.MajorSubsystemVersion = pe_major_subsystem_version;
1715
1716 if (pe_minor_subsystem_version != -1)
1717 pe->pe_opthdr.MinorSubsystemVersion = pe_minor_subsystem_version;
1718
1719 if (pe_file_alignment > pe_section_alignment)
1720 {
1721 char file_alignment[20], section_alignment[20];
1722
1723 sprintf_vma (file_alignment, pe_file_alignment);
1724 sprintf_vma (section_alignment, pe_section_alignment);
1725 non_fatal (_("warning: file alignment (0x%s) > section alignment (0x%s)"),
1726
1727 file_alignment, section_alignment);
1728 }
1729 }
1730
252b5132 1731 if (isympp)
62d732f5 1732 free (isympp);
57938635 1733
252b5132 1734 if (osympp != isympp)
62d732f5
AM
1735 free (osympp);
1736
1737 isympp = NULL;
1738 osympp = NULL;
252b5132 1739
c39ada54
AM
1740 symsize = bfd_get_symtab_upper_bound (ibfd);
1741 if (symsize < 0)
1742 {
8d8e0703 1743 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
c39ada54
AM
1744 return FALSE;
1745 }
1746
3f5e193b 1747 osympp = isympp = (asymbol **) xmalloc (symsize);
c39ada54
AM
1748 symcount = bfd_canonicalize_symtab (ibfd, isympp);
1749 if (symcount < 0)
1750 {
2db6cde7 1751 bfd_nonfatal_message (NULL, ibfd, NULL, NULL);
c39ada54
AM
1752 return FALSE;
1753 }
1754
252b5132
RH
1755 /* BFD mandates that all output sections be created and sizes set before
1756 any output is done. Thus, we traverse all sections multiple times. */
d3ba0551 1757 bfd_map_over_sections (ibfd, setup_section, obfd);
252b5132 1758
237dcb53
AM
1759 if (!extract_symbol)
1760 setup_bfd_headers (ibfd, obfd);
80fccad2 1761
252b5132
RH
1762 if (add_sections != NULL)
1763 {
1764 struct section_add *padd;
1765 struct section_list *pset;
1766
1767 for (padd = add_sections; padd != NULL; padd = padd->next)
1768 {
2593f09a
NC
1769 flagword flags;
1770
2e62b721
NC
1771 pset = find_section_list (padd->name, FALSE,
1772 SECTION_CONTEXT_SET_FLAGS);
551b43fd 1773 if (pset != NULL)
551b43fd 1774 flags = pset->flags | SEC_HAS_CONTENTS;
2e62b721
NC
1775 else
1776 flags = SEC_HAS_CONTENTS | SEC_READONLY | SEC_DATA;
551b43fd 1777
c8782eee
NC
1778 /* bfd_make_section_with_flags() does not return very helpful
1779 error codes, so check for the most likely user error first. */
1780 if (bfd_get_section_by_name (obfd, padd->name))
252b5132 1781 {
2db6cde7
NS
1782 bfd_nonfatal_message (NULL, obfd, NULL,
1783 _("can't add section '%s'"), padd->name);
950d48e7 1784 return FALSE;
252b5132 1785 }
c8782eee
NC
1786 else
1787 {
0930eddd
NS
1788 /* We use LINKER_CREATED here so that the backend hooks
1789 will create any special section type information,
1790 instead of presuming we know what we're doing merely
1791 because we set the flags. */
1792 padd->section = bfd_make_section_with_flags
1793 (obfd, padd->name, flags | SEC_LINKER_CREATED);
c8782eee
NC
1794 if (padd->section == NULL)
1795 {
2db6cde7
NS
1796 bfd_nonfatal_message (NULL, obfd, NULL,
1797 _("can't create section `%s'"),
1798 padd->name);
c8782eee
NC
1799 return FALSE;
1800 }
1801 }
252b5132 1802
2593f09a 1803 if (! bfd_set_section_size (obfd, padd->section, padd->size))
950d48e7 1804 {
2db6cde7 1805 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
950d48e7
NC
1806 return FALSE;
1807 }
252b5132 1808
2e62b721
NC
1809 pset = find_section_list (padd->name, FALSE,
1810 SECTION_CONTEXT_SET_VMA | SECTION_CONTEXT_ALTER_VMA);
1811 if (pset != NULL
1812 && ! bfd_set_section_vma (obfd, padd->section, pset->vma_val))
1813 {
1814 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
1815 return FALSE;
1816 }
1817
1818 pset = find_section_list (padd->name, FALSE,
1819 SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_ALTER_LMA);
2593f09a
NC
1820 if (pset != NULL)
1821 {
2e62b721 1822 padd->section->lma = pset->lma_val;
57938635 1823
2e62b721
NC
1824 if (! bfd_set_section_alignment
1825 (obfd, padd->section,
1826 bfd_section_alignment (obfd, padd->section)))
2593f09a 1827 {
2e62b721
NC
1828 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
1829 return FALSE;
252b5132
RH
1830 }
1831 }
1832 }
1833 }
1834
bbad633b
NC
1835 if (dump_sections != NULL)
1836 {
1837 struct section_add * pdump;
1838
1839 for (pdump = dump_sections; pdump != NULL; pdump = pdump->next)
1840 {
1841 asection * sec;
1842
1843 sec = bfd_get_section_by_name (ibfd, pdump->name);
1844 if (sec == NULL)
1845 {
1846 bfd_nonfatal_message (NULL, ibfd, NULL,
1847 _("can't dump section '%s' - it does not exist"),
1848 pdump->name);
1849 continue;
1850 }
1851
1852 if ((bfd_get_section_flags (ibfd, sec) & SEC_HAS_CONTENTS) == 0)
1853 {
1854 bfd_nonfatal_message (NULL, ibfd, sec,
1855 _("can't dump section - it has no contents"));
1856 continue;
1857 }
1858
1859 bfd_size_type size = bfd_get_section_size (sec);
1860 if (size == 0)
1861 {
1862 bfd_nonfatal_message (NULL, ibfd, sec,
1863 _("can't dump section - it is empty"));
1864 continue;
1865 }
1866
1867 FILE * f;
1868 f = fopen (pdump->filename, FOPEN_WB);
1869 if (f == NULL)
1870 {
1871 bfd_nonfatal_message (pdump->filename, NULL, NULL,
1872 _("could not open section dump file"));
1873 continue;
1874 }
1875
1876 bfd_byte * contents = xmalloc (size);
1877 if (bfd_get_section_contents (ibfd, sec, contents, 0, size))
182a105a
AG
1878 {
1879 if (fwrite (contents, 1, size, f) != size)
1880 fatal (_("error writing section contents to %s (error: %s)"),
1881 pdump->filename,
1882 strerror (errno));
1883 }
bbad633b
NC
1884 else
1885 bfd_nonfatal_message (NULL, ibfd, sec,
1886 _("could not retrieve section contents"));
1887
1888 fclose (f);
1889 free (contents);
1890 }
1891 }
1892
2593f09a
NC
1893 if (gnu_debuglink_filename != NULL)
1894 {
d99b05a3
NC
1895 /* PR 15125: Give a helpful warning message if
1896 the debuglink section already exists, and
1897 allow the rest of the copy to complete. */
1898 if (bfd_get_section_by_name (obfd, ".gnu_debuglink"))
950d48e7 1899 {
d99b05a3
NC
1900 non_fatal (_("%s: debuglink section already exists"),
1901 bfd_get_filename (obfd));
1902 gnu_debuglink_filename = NULL;
950d48e7 1903 }
d99b05a3 1904 else
6e2c86ac 1905 {
d99b05a3
NC
1906 gnu_debuglink_section = bfd_create_gnu_debuglink_section
1907 (obfd, gnu_debuglink_filename);
1908
1909 if (gnu_debuglink_section == NULL)
1910 {
1911 bfd_nonfatal_message (NULL, obfd, NULL,
1912 _("cannot create debug link section `%s'"),
1913 gnu_debuglink_filename);
1914 return FALSE;
1915 }
6e2c86ac 1916
d99b05a3
NC
1917 /* Special processing for PE format files. We
1918 have no way to distinguish PE from COFF here. */
1919 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour)
1920 {
1921 bfd_vma debuglink_vma;
1922 asection * highest_section;
1923 asection * sec;
1924
1925 /* The PE spec requires that all sections be adjacent and sorted
1926 in ascending order of VMA. It also specifies that debug
1927 sections should be last. This is despite the fact that debug
1928 sections are not loaded into memory and so in theory have no
1929 use for a VMA.
1930
1931 This means that the debuglink section must be given a non-zero
1932 VMA which makes it contiguous with other debug sections. So
1933 walk the current section list, find the section with the
1934 highest VMA and start the debuglink section after that one. */
1935 for (sec = obfd->sections, highest_section = NULL;
1936 sec != NULL;
1937 sec = sec->next)
1938 if (sec->vma > 0
1939 && (highest_section == NULL
1940 || sec->vma > highest_section->vma))
1941 highest_section = sec;
1942
1943 if (highest_section)
1944 debuglink_vma = BFD_ALIGN (highest_section->vma
1945 + highest_section->size,
1946 /* FIXME: We ought to be using
1947 COFF_PAGE_SIZE here or maybe
1948 bfd_get_section_alignment() (if it
1949 was set) but since this is for PE
1950 and we know the required alignment
1951 it is easier just to hard code it. */
1952 0x1000);
1953 else
1954 /* Umm, not sure what to do in this case. */
1955 debuglink_vma = 0x1000;
1956
1957 bfd_set_section_vma (obfd, gnu_debuglink_section, debuglink_vma);
1958 }
6e2c86ac 1959 }
950d48e7
NC
1960 }
1961
1aa9ef63
L
1962 if (bfd_count_sections (obfd) != 0
1963 && (gap_fill_set || pad_to_set))
252b5132
RH
1964 {
1965 asection **set;
1966 unsigned int c, i;
1967
1968 /* We must fill in gaps between the sections and/or we must pad
1969 the last section to a specified address. We do this by
1970 grabbing a list of the sections, sorting them by VMA, and
1971 increasing the section sizes as required to fill the gaps.
1972 We write out the gap contents below. */
1973
1974 c = bfd_count_sections (obfd);
3f5e193b 1975 osections = (asection **) xmalloc (c * sizeof (asection *));
252b5132 1976 set = osections;
d3ba0551 1977 bfd_map_over_sections (obfd, get_sections, &set);
252b5132
RH
1978
1979 qsort (osections, c, sizeof (asection *), compare_section_lma);
1980
3f5e193b 1981 gaps = (bfd_size_type *) xmalloc (c * sizeof (bfd_size_type));
252b5132
RH
1982 memset (gaps, 0, c * sizeof (bfd_size_type));
1983
1984 if (gap_fill_set)
1985 {
1986 for (i = 0; i < c - 1; i++)
1987 {
1988 flagword flags;
1989 bfd_size_type size;
1990 bfd_vma gap_start, gap_stop;
1991
1992 flags = bfd_get_section_flags (obfd, osections[i]);
1993 if ((flags & SEC_HAS_CONTENTS) == 0
1994 || (flags & SEC_LOAD) == 0)
1995 continue;
1996
1997 size = bfd_section_size (obfd, osections[i]);
1998 gap_start = bfd_section_lma (obfd, osections[i]) + size;
1999 gap_stop = bfd_section_lma (obfd, osections[i + 1]);
2000 if (gap_start < gap_stop)
2001 {
2002 if (! bfd_set_section_size (obfd, osections[i],
2003 size + (gap_stop - gap_start)))
2004 {
2db6cde7
NS
2005 bfd_nonfatal_message (NULL, obfd, osections[i],
2006 _("Can't fill gap after section"));
252b5132
RH
2007 status = 1;
2008 break;
2009 }
2010 gaps[i] = gap_stop - gap_start;
2011 if (max_gap < gap_stop - gap_start)
2012 max_gap = gap_stop - gap_start;
2013 }
2014 }
2015 }
2016
2017 if (pad_to_set)
2018 {
2019 bfd_vma lma;
2020 bfd_size_type size;
2021
2022 lma = bfd_section_lma (obfd, osections[c - 1]);
2023 size = bfd_section_size (obfd, osections[c - 1]);
2024 if (lma + size < pad_to)
2025 {
2026 if (! bfd_set_section_size (obfd, osections[c - 1],
2027 pad_to - lma))
2028 {
2db6cde7
NS
2029 bfd_nonfatal_message (NULL, obfd, osections[c - 1],
2030 _("can't add padding"));
252b5132
RH
2031 status = 1;
2032 }
2033 else
2034 {
2035 gaps[c - 1] = pad_to - (lma + size);
2036 if (max_gap < pad_to - (lma + size))
2037 max_gap = pad_to - (lma + size);
2038 }
2039 }
2040 }
2041 }
2042
594ef5db
NC
2043 /* Symbol filtering must happen after the output sections
2044 have been created, but before their contents are set. */
252b5132 2045 dhandle = NULL;
252b5132 2046 if (convert_debugging)
b922d590 2047 dhandle = read_debugging_info (ibfd, isympp, symcount, FALSE);
57938635
AM
2048
2049 if (strip_symbols == STRIP_DEBUG
252b5132
RH
2050 || strip_symbols == STRIP_ALL
2051 || strip_symbols == STRIP_UNNEEDED
ed1653a7 2052 || strip_symbols == STRIP_NONDEBUG
96109726
CC
2053 || strip_symbols == STRIP_DWO
2054 || strip_symbols == STRIP_NONDWO
252b5132 2055 || discard_locals != LOCALS_UNDEF
d58c2e3a 2056 || localize_hidden
047c9024
NC
2057 || htab_elements (strip_specific_htab) != 0
2058 || htab_elements (keep_specific_htab) != 0
2059 || htab_elements (localize_specific_htab) != 0
2060 || htab_elements (globalize_specific_htab) != 0
2061 || htab_elements (keepglobal_specific_htab) != 0
2062 || htab_elements (weaken_specific_htab) != 0
d7fb0dd2 2063 || prefix_symbols_string
252b5132 2064 || sections_removed
f91ea849 2065 || sections_copied
252b5132
RH
2066 || convert_debugging
2067 || change_leading_char
2068 || remove_leading_char
57938635 2069 || redefine_sym_list
252b5132
RH
2070 || weaken)
2071 {
2072 /* Mark symbols used in output relocations so that they
2073 are kept, even if they are local labels or static symbols.
57938635 2074
252b5132
RH
2075 Note we iterate over the input sections examining their
2076 relocations since the relocations for the output sections
2077 haven't been set yet. mark_symbols_used_in_relocations will
2078 ignore input sections which have no corresponding output
2079 section. */
2080 if (strip_symbols != STRIP_ALL)
2081 bfd_map_over_sections (ibfd,
2082 mark_symbols_used_in_relocations,
d3ba0551 2083 isympp);
3f5e193b 2084 osympp = (asymbol **) xmalloc ((symcount + 1) * sizeof (asymbol *));
252b5132
RH
2085 symcount = filter_symbols (ibfd, obfd, osympp, isympp, symcount);
2086 }
2087
2088 if (convert_debugging && dhandle != NULL)
2089 {
2090 if (! write_debugging_info (obfd, dhandle, &symcount, &osympp))
2091 {
2092 status = 1;
950d48e7 2093 return FALSE;
252b5132
RH
2094 }
2095 }
2096
2097 bfd_set_symtab (obfd, osympp, symcount);
2098
c3989150
L
2099 /* This has to happen before section positions are set. */
2100 bfd_map_over_sections (ibfd, copy_relocations_in_section, obfd);
2101
252b5132 2102 /* This has to happen after the symbol table has been set. */
d3ba0551 2103 bfd_map_over_sections (ibfd, copy_section, obfd);
252b5132
RH
2104
2105 if (add_sections != NULL)
2106 {
2107 struct section_add *padd;
2108
2109 for (padd = add_sections; padd != NULL; padd = padd->next)
2110 {
d3ba0551
AM
2111 if (! bfd_set_section_contents (obfd, padd->section, padd->contents,
2112 0, padd->size))
950d48e7 2113 {
2db6cde7 2114 bfd_nonfatal_message (NULL, obfd, padd->section, NULL);
950d48e7
NC
2115 return FALSE;
2116 }
252b5132
RH
2117 }
2118 }
2119
e7c81c25
NC
2120 if (gnu_debuglink_filename != NULL)
2121 {
2122 if (! bfd_fill_in_gnu_debuglink_section
2123 (obfd, gnu_debuglink_section, gnu_debuglink_filename))
950d48e7 2124 {
2db6cde7
NS
2125 bfd_nonfatal_message (NULL, obfd, NULL,
2126 _("cannot fill debug link section `%s'"),
2127 gnu_debuglink_filename);
950d48e7
NC
2128 return FALSE;
2129 }
e7c81c25
NC
2130 }
2131
252b5132
RH
2132 if (gap_fill_set || pad_to_set)
2133 {
2134 bfd_byte *buf;
2135 int c, i;
2136
2137 /* Fill in the gaps. */
252b5132
RH
2138 if (max_gap > 8192)
2139 max_gap = 8192;
3f5e193b 2140 buf = (bfd_byte *) xmalloc (max_gap);
d3ba0551 2141 memset (buf, gap_fill, max_gap);
252b5132
RH
2142
2143 c = bfd_count_sections (obfd);
2144 for (i = 0; i < c; i++)
2145 {
2146 if (gaps[i] != 0)
2147 {
2148 bfd_size_type left;
2149 file_ptr off;
2150
2151 left = gaps[i];
2152 off = bfd_section_size (obfd, osections[i]) - left;
594ef5db 2153
252b5132
RH
2154 while (left > 0)
2155 {
2156 bfd_size_type now;
2157
2158 if (left > 8192)
2159 now = 8192;
2160 else
2161 now = left;
2162
2163 if (! bfd_set_section_contents (obfd, osections[i], buf,
2164 off, now))
950d48e7 2165 {
2db6cde7 2166 bfd_nonfatal_message (NULL, obfd, osections[i], NULL);
950d48e7
NC
2167 return FALSE;
2168 }
252b5132
RH
2169
2170 left -= now;
2171 off += now;
2172 }
2173 }
2174 }
2175 }
2176
d3e52d40
RS
2177 /* Do not copy backend data if --extract-symbol is passed; anything
2178 that needs to look at the section contents will fail. */
2179 if (extract_symbol)
2180 return TRUE;
2181
252b5132
RH
2182 /* Allow the BFD backend to copy any private data it understands
2183 from the input BFD to the output BFD. This is done last to
2184 permit the routine to look at the filtered symbol table, which is
2185 important for the ECOFF code at least. */
42bb2e33 2186 if (! bfd_copy_private_bfd_data (ibfd, obfd))
252b5132 2187 {
2db6cde7
NS
2188 bfd_nonfatal_message (NULL, obfd, NULL,
2189 _("error copying private BFD data"));
950d48e7 2190 return FALSE;
252b5132 2191 }
1ae8b3d2
AO
2192
2193 /* Switch to the alternate machine code. We have to do this at the
2194 very end, because we only initialize the header when we create
2195 the first section. */
f9d4ad2a
NC
2196 if (use_alt_mach_code != 0)
2197 {
2198 if (! bfd_alt_mach_code (obfd, use_alt_mach_code))
2199 {
2200 non_fatal (_("this target does not support %lu alternative machine codes"),
2201 use_alt_mach_code);
2202 if (bfd_get_flavour (obfd) == bfd_target_elf_flavour)
2203 {
2204 non_fatal (_("treating that number as an absolute e_machine value instead"));
2205 elf_elfheader (obfd)->e_machine = use_alt_mach_code;
2206 }
2207 else
2208 non_fatal (_("ignoring the alternative value"));
2209 }
2210 }
950d48e7
NC
2211
2212 return TRUE;
252b5132
RH
2213}
2214
2215/* Read each archive element in turn from IBFD, copy the
ee873e00
NC
2216 contents to temp file, and keep the temp file handle.
2217 If 'force_output_target' is TRUE then make sure that
2218 all elements in the new archive are of the type
2219 'output_target'. */
252b5132
RH
2220
2221static void
ee873e00 2222copy_archive (bfd *ibfd, bfd *obfd, const char *output_target,
8b31b6c4
NC
2223 bfd_boolean force_output_target,
2224 const bfd_arch_info_type *input_arch)
252b5132
RH
2225{
2226 struct name_list
2227 {
2228 struct name_list *next;
4c168fa3 2229 const char *name;
252b5132
RH
2230 bfd *obfd;
2231 } *list, *l;
2232 bfd **ptr = &obfd->archive_head;
2233 bfd *this_element;
8d8e0703
AM
2234 char *dir;
2235 const char *filename;
252b5132
RH
2236
2237 /* Make a temp directory to hold the contents. */
f9c026a8 2238 dir = make_tempdir (bfd_get_filename (obfd));
f9c026a8
NC
2239 if (dir == NULL)
2240 fatal (_("cannot create tempdir for archive copying (error: %s)"),
2241 strerror (errno));
84e2f313 2242
2e30cb57
CC
2243 if (strip_symbols == STRIP_ALL)
2244 obfd->has_armap = FALSE;
2245 else
2246 obfd->has_armap = ibfd->has_armap;
a8da6403 2247 obfd->is_thin_archive = ibfd->is_thin_archive;
252b5132 2248
2e30cb57
CC
2249 if (deterministic)
2250 obfd->flags |= BFD_DETERMINISTIC_OUTPUT;
2251
252b5132
RH
2252 list = NULL;
2253
2254 this_element = bfd_openr_next_archived_file (ibfd, NULL);
594ef5db 2255
b667df2e 2256 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
8d8e0703
AM
2257 {
2258 status = 1;
2259 bfd_nonfatal_message (NULL, obfd, NULL, NULL);
2260 return;
2261 }
b667df2e 2262
d3ba0551 2263 while (!status && this_element != NULL)
252b5132 2264 {
4c168fa3
AM
2265 char *output_name;
2266 bfd *output_bfd;
252b5132 2267 bfd *last_element;
8066d1a2
AS
2268 struct stat buf;
2269 int stat_status = 0;
3f5e193b 2270 bfd_boolean del = TRUE;
19094d10 2271 bfd_boolean ok_object;
8066d1a2 2272
4c168fa3
AM
2273 /* Create an output file for this member. */
2274 output_name = concat (dir, "/",
2275 bfd_get_filename (this_element), (char *) 0);
2276
2277 /* If the file already exists, make another temp dir. */
2278 if (stat (output_name, &buf) >= 0)
2279 {
f9c026a8
NC
2280 output_name = make_tempdir (output_name);
2281 if (output_name == NULL)
485be063
AM
2282 fatal (_("cannot create tempdir for archive copying (error: %s)"),
2283 strerror (errno));
84e2f313 2284
3f5e193b 2285 l = (struct name_list *) xmalloc (sizeof (struct name_list));
4c168fa3
AM
2286 l->name = output_name;
2287 l->next = list;
2288 l->obfd = NULL;
2289 list = l;
2290 output_name = concat (output_name, "/",
2291 bfd_get_filename (this_element), (char *) 0);
2292 }
2293
8066d1a2
AS
2294 if (preserve_dates)
2295 {
2296 stat_status = bfd_stat_arch_elt (this_element, &buf);
594ef5db 2297
8066d1a2
AS
2298 if (stat_status != 0)
2299 non_fatal (_("internal stat error on %s"),
2300 bfd_get_filename (this_element));
2301 }
252b5132 2302
3f5e193b 2303 l = (struct name_list *) xmalloc (sizeof (struct name_list));
252b5132
RH
2304 l->name = output_name;
2305 l->next = list;
bee59fd2 2306 l->obfd = NULL;
252b5132
RH
2307 list = l;
2308
19094d10
AM
2309 ok_object = bfd_check_format (this_element, bfd_object);
2310 if (!ok_object)
2311 bfd_nonfatal_message (NULL, this_element, NULL,
2312 _("Unable to recognise the format of file"));
2313
2314 /* PR binutils/3110: Cope with archives
2315 containing multiple target types. */
2316 if (force_output_target || !ok_object)
2317 output_bfd = bfd_openw (output_name, output_target);
2318 else
2319 output_bfd = bfd_openw (output_name, bfd_get_target (this_element));
2320
2321 if (output_bfd == NULL)
77f762d6 2322 {
19094d10
AM
2323 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
2324 status = 1;
2325 return;
2326 }
2327
2328 if (ok_object)
2329 {
2330 del = !copy_object (this_element, output_bfd, input_arch);
ee873e00 2331
19094d10
AM
2332 if (del && bfd_get_arch (this_element) == bfd_arch_unknown)
2333 /* Try again as an unknown object file. */
2334 ok_object = FALSE;
2335 else if (!bfd_close (output_bfd))
2db6cde7
NS
2336 {
2337 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
19094d10 2338 /* Error in new object file. Don't change archive. */
2db6cde7 2339 status = 1;
77f762d6 2340 }
77f762d6 2341 }
77f762d6 2342
19094d10
AM
2343 if (!ok_object)
2344 {
3f5e193b 2345 del = !copy_unknown_object (this_element, output_bfd);
77f762d6
L
2346 if (!bfd_close_all_done (output_bfd))
2347 {
8d8e0703 2348 bfd_nonfatal_message (output_name, NULL, NULL, NULL);
77f762d6
L
2349 /* Error in new object file. Don't change archive. */
2350 status = 1;
2351 }
252b5132
RH
2352 }
2353
3f5e193b 2354 if (del)
950d48e7
NC
2355 {
2356 unlink (output_name);
2357 status = 1;
2358 }
2359 else
2360 {
2361 if (preserve_dates && stat_status == 0)
2362 set_times (output_name, &buf);
8066d1a2 2363
950d48e7
NC
2364 /* Open the newly output file and attach to our list. */
2365 output_bfd = bfd_openr (output_name, output_target);
252b5132 2366
950d48e7 2367 l->obfd = output_bfd;
252b5132 2368
950d48e7 2369 *ptr = output_bfd;
cc481421 2370 ptr = &output_bfd->archive_next;
252b5132 2371
950d48e7 2372 last_element = this_element;
252b5132 2373
950d48e7 2374 this_element = bfd_openr_next_archived_file (ibfd, last_element);
252b5132 2375
950d48e7
NC
2376 bfd_close (last_element);
2377 }
252b5132 2378 }
d3ba0551 2379 *ptr = NULL;
252b5132 2380
8d8e0703 2381 filename = bfd_get_filename (obfd);
252b5132 2382 if (!bfd_close (obfd))
8d8e0703
AM
2383 {
2384 status = 1;
2385 bfd_nonfatal_message (filename, NULL, NULL, NULL);
2386 return;
2387 }
252b5132 2388
8d8e0703 2389 filename = bfd_get_filename (ibfd);
252b5132 2390 if (!bfd_close (ibfd))
8d8e0703
AM
2391 {
2392 status = 1;
2393 bfd_nonfatal_message (filename, NULL, NULL, NULL);
2394 return;
2395 }
252b5132
RH
2396
2397 /* Delete all the files that we opened. */
2398 for (l = list; l != NULL; l = l->next)
2399 {
4c168fa3
AM
2400 if (l->obfd == NULL)
2401 rmdir (l->name);
2402 else
2403 {
2404 bfd_close (l->obfd);
2405 unlink (l->name);
2406 }
252b5132
RH
2407 }
2408 rmdir (dir);
2409}
2410
0408dee6
DK
2411static void
2412set_long_section_mode (bfd *output_bfd, bfd *input_bfd, enum long_section_name_handling style)
2413{
2414 /* This is only relevant to Coff targets. */
2415 if (bfd_get_flavour (output_bfd) == bfd_target_coff_flavour)
2416 {
78e82dc3
AM
2417 if (style == KEEP
2418 && bfd_get_flavour (input_bfd) == bfd_target_coff_flavour)
0408dee6
DK
2419 style = bfd_coff_long_section_names (input_bfd) ? ENABLE : DISABLE;
2420 bfd_coff_set_long_section_names (output_bfd, style != DISABLE);
2421 }
2422}
2423
252b5132
RH
2424/* The top-level control. */
2425
2426static void
84e2f313 2427copy_file (const char *input_filename, const char *output_filename,
8b31b6c4
NC
2428 const char *input_target, const char *output_target,
2429 const bfd_arch_info_type *input_arch)
252b5132
RH
2430{
2431 bfd *ibfd;
49c12576
AM
2432 char **obj_matching;
2433 char **core_matching;
52a476ee 2434 off_t size = get_file_size (input_filename);
252b5132 2435
52a476ee 2436 if (size < 1)
f24ddbdd 2437 {
52a476ee
L
2438 if (size == 0)
2439 non_fatal (_("error: the input file '%s' is empty"),
2440 input_filename);
f24ddbdd
NC
2441 status = 1;
2442 return;
2443 }
2444
252b5132
RH
2445 /* To allow us to do "strip *" without dying on the first
2446 non-object file, failures are nonfatal. */
252b5132
RH
2447 ibfd = bfd_openr (input_filename, input_target);
2448 if (ibfd == NULL)
2db6cde7
NS
2449 {
2450 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
2451 status = 1;
2452 return;
2453 }
252b5132 2454
4a114e3e
L
2455 switch (do_debug_sections)
2456 {
2457 case compress:
2458 ibfd->flags |= BFD_COMPRESS;
2459 break;
2460 case decompress:
2461 ibfd->flags |= BFD_DECOMPRESS;
2462 break;
2463 default:
2464 break;
2465 }
2466
252b5132
RH
2467 if (bfd_check_format (ibfd, bfd_archive))
2468 {
ee873e00 2469 bfd_boolean force_output_target;
252b5132
RH
2470 bfd *obfd;
2471
2472 /* bfd_get_target does not return the correct value until
2473 bfd_check_format succeeds. */
2474 if (output_target == NULL)
ee873e00
NC
2475 {
2476 output_target = bfd_get_target (ibfd);
2477 force_output_target = FALSE;
2478 }
2479 else
2480 force_output_target = TRUE;
252b5132
RH
2481
2482 obfd = bfd_openw (output_filename, output_target);
2483 if (obfd == NULL)
2db6cde7
NS
2484 {
2485 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
2486 status = 1;
2487 return;
2488 }
0408dee6
DK
2489 /* This is a no-op on non-Coff targets. */
2490 set_long_section_mode (obfd, ibfd, long_section_names);
252b5132 2491
8b31b6c4 2492 copy_archive (ibfd, obfd, output_target, force_output_target, input_arch);
252b5132 2493 }
49c12576 2494 else if (bfd_check_format_matches (ibfd, bfd_object, &obj_matching))
252b5132
RH
2495 {
2496 bfd *obfd;
49c12576 2497 do_copy:
950d48e7 2498
252b5132
RH
2499 /* bfd_get_target does not return the correct value until
2500 bfd_check_format succeeds. */
2501 if (output_target == NULL)
2502 output_target = bfd_get_target (ibfd);
2503
2504 obfd = bfd_openw (output_filename, output_target);
2505 if (obfd == NULL)
2db6cde7
NS
2506 {
2507 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
2508 status = 1;
2509 return;
2510 }
0408dee6
DK
2511 /* This is a no-op on non-Coff targets. */
2512 set_long_section_mode (obfd, ibfd, long_section_names);
252b5132 2513
8b31b6c4 2514 if (! copy_object (ibfd, obfd, input_arch))
a580b8e0 2515 status = 1;
252b5132
RH
2516
2517 if (!bfd_close (obfd))
8d8e0703
AM
2518 {
2519 status = 1;
2520 bfd_nonfatal_message (output_filename, NULL, NULL, NULL);
2521 return;
2522 }
252b5132
RH
2523
2524 if (!bfd_close (ibfd))
8d8e0703
AM
2525 {
2526 status = 1;
2527 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
2528 return;
2529 }
252b5132
RH
2530 }
2531 else
2532 {
49c12576
AM
2533 bfd_error_type obj_error = bfd_get_error ();
2534 bfd_error_type core_error;
b34976b6 2535
49c12576
AM
2536 if (bfd_check_format_matches (ibfd, bfd_core, &core_matching))
2537 {
2538 /* This probably can't happen.. */
2539 if (obj_error == bfd_error_file_ambiguously_recognized)
2540 free (obj_matching);
2541 goto do_copy;
2542 }
2543
2544 core_error = bfd_get_error ();
2545 /* Report the object error in preference to the core error. */
2546 if (obj_error != core_error)
2547 bfd_set_error (obj_error);
2548
2db6cde7 2549 bfd_nonfatal_message (input_filename, NULL, NULL, NULL);
57938635 2550
49c12576
AM
2551 if (obj_error == bfd_error_file_ambiguously_recognized)
2552 {
2553 list_matching_formats (obj_matching);
2554 free (obj_matching);
2555 }
2556 if (core_error == bfd_error_file_ambiguously_recognized)
252b5132 2557 {
49c12576
AM
2558 list_matching_formats (core_matching);
2559 free (core_matching);
252b5132 2560 }
57938635 2561
252b5132
RH
2562 status = 1;
2563 }
2564}
2565
594ef5db
NC
2566/* Add a name to the section renaming list. */
2567
2568static void
84e2f313
NC
2569add_section_rename (const char * old_name, const char * new_name,
2570 flagword flags)
594ef5db 2571{
91d6fa6a 2572 section_rename * srename;
594ef5db
NC
2573
2574 /* Check for conflicts first. */
91d6fa6a
NC
2575 for (srename = section_rename_list; srename != NULL; srename = srename->next)
2576 if (strcmp (srename->old_name, old_name) == 0)
594ef5db
NC
2577 {
2578 /* Silently ignore duplicate definitions. */
91d6fa6a
NC
2579 if (strcmp (srename->new_name, new_name) == 0
2580 && srename->flags == flags)
594ef5db 2581 return;
0af11b59 2582
594ef5db
NC
2583 fatal (_("Multiple renames of section %s"), old_name);
2584 }
2585
91d6fa6a 2586 srename = (section_rename *) xmalloc (sizeof (* srename));
594ef5db 2587
91d6fa6a
NC
2588 srename->old_name = old_name;
2589 srename->new_name = new_name;
2590 srename->flags = flags;
2591 srename->next = section_rename_list;
0af11b59 2592
91d6fa6a 2593 section_rename_list = srename;
594ef5db
NC
2594}
2595
2596/* Check the section rename list for a new name of the input section
2597 ISECTION. Return the new name if one is found.
2598 Also set RETURNED_FLAGS to the flags to be used for this section. */
2599
2600static const char *
84e2f313
NC
2601find_section_rename (bfd * ibfd ATTRIBUTE_UNUSED, sec_ptr isection,
2602 flagword * returned_flags)
594ef5db
NC
2603{
2604 const char * old_name = bfd_section_name (ibfd, isection);
91d6fa6a 2605 section_rename * srename;
594ef5db
NC
2606
2607 /* Default to using the flags of the input section. */
2608 * returned_flags = bfd_get_section_flags (ibfd, isection);
2609
91d6fa6a
NC
2610 for (srename = section_rename_list; srename != NULL; srename = srename->next)
2611 if (strcmp (srename->old_name, old_name) == 0)
594ef5db 2612 {
91d6fa6a
NC
2613 if (srename->flags != (flagword) -1)
2614 * returned_flags = srename->flags;
594ef5db 2615
91d6fa6a 2616 return srename->new_name;
594ef5db
NC
2617 }
2618
2619 return old_name;
2620}
2621
80fccad2
BW
2622/* Once each of the sections is copied, we may still need to do some
2623 finalization work for private section headers. Do that here. */
2624
2625static void
2626setup_bfd_headers (bfd *ibfd, bfd *obfd)
2627{
80fccad2
BW
2628 /* Allow the BFD backend to copy any private data it understands
2629 from the input section to the output section. */
2630 if (! bfd_copy_private_header_data (ibfd, obfd))
2631 {
2db6cde7
NS
2632 status = 1;
2633 bfd_nonfatal_message (NULL, ibfd, NULL,
8d8e0703 2634 _("error in private header data"));
2db6cde7 2635 return;
80fccad2
BW
2636 }
2637
2638 /* All went well. */
2639 return;
80fccad2
BW
2640}
2641
594ef5db
NC
2642/* Create a section in OBFD with the same
2643 name and attributes as ISECTION in IBFD. */
252b5132
RH
2644
2645static void
84e2f313 2646setup_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
252b5132 2647{
3f5e193b 2648 bfd *obfd = (bfd *) obfdarg;
252b5132
RH
2649 struct section_list *p;
2650 sec_ptr osection;
2651 bfd_size_type size;
2652 bfd_vma vma;
2653 bfd_vma lma;
2654 flagword flags;
1a89cc7d 2655 const char *err;
594ef5db 2656 const char * name;
d7fb0dd2 2657 char *prefix = NULL;
66125551 2658 bfd_boolean make_nobits;
0af11b59 2659
2593f09a 2660 if (is_strip_section (ibfd, isection))
252b5132
RH
2661 return;
2662
594ef5db
NC
2663 /* Get the, possibly new, name of the output section. */
2664 name = find_section_rename (ibfd, isection, & flags);
0af11b59 2665
d7fb0dd2 2666 /* Prefix sections. */
84e2f313
NC
2667 if ((prefix_alloc_sections_string)
2668 && (bfd_get_section_flags (ibfd, isection) & SEC_ALLOC))
d7fb0dd2
NC
2669 prefix = prefix_alloc_sections_string;
2670 else if (prefix_sections_string)
2671 prefix = prefix_sections_string;
2672
2673 if (prefix)
2674 {
2675 char *n;
2676
3f5e193b 2677 n = (char *) xmalloc (strlen (prefix) + strlen (name) + 1);
d7fb0dd2
NC
2678 strcpy (n, prefix);
2679 strcat (n, name);
2680 name = n;
2681 }
66491ebc 2682
66125551 2683 make_nobits = FALSE;
2e62b721
NC
2684
2685 p = find_section_list (bfd_section_name (ibfd, isection), FALSE,
2686 SECTION_CONTEXT_SET_FLAGS);
2687 if (p != NULL)
551b43fd 2688 flags = p->flags | (flags & (SEC_HAS_CONTENTS | SEC_RELOC));
42bb2e33 2689 else if (strip_symbols == STRIP_NONDEBUG
6c67a030
AM
2690 && (flags & (SEC_ALLOC | SEC_GROUP)) != 0
2691 && !(ibfd->xvec->flavour == bfd_target_elf_flavour
2692 && elf_section_type (isection) == SHT_NOTE))
66125551 2693 {
6c67a030 2694 flags &= ~(SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP);
66125551
AM
2695 if (obfd->xvec->flavour == bfd_target_elf_flavour)
2696 {
2697 make_nobits = TRUE;
2698
2699 /* Twiddle the input section flags so that it seems to
2700 elf.c:copy_private_bfd_data that section flags have not
2701 changed between input and output sections. This hack
2702 prevents wholesale rewriting of the program headers. */
6c67a030 2703 isection->flags &= ~(SEC_HAS_CONTENTS | SEC_LOAD | SEC_GROUP);
66125551
AM
2704 }
2705 }
551b43fd
AM
2706
2707 osection = bfd_make_section_anyway_with_flags (obfd, name, flags);
57938635 2708
252b5132
RH
2709 if (osection == NULL)
2710 {
2db6cde7 2711 err = _("failed to create output section");
252b5132
RH
2712 goto loser;
2713 }
2714
66125551 2715 if (make_nobits)
551b43fd
AM
2716 elf_section_type (osection) = SHT_NOBITS;
2717
252b5132
RH
2718 size = bfd_section_size (ibfd, isection);
2719 if (copy_byte >= 0)
b7dd81f7 2720 size = (size + interleave - 1) / interleave * copy_width;
d3e52d40
RS
2721 else if (extract_symbol)
2722 size = 0;
252b5132
RH
2723 if (! bfd_set_section_size (obfd, osection, size))
2724 {
2db6cde7 2725 err = _("failed to set size");
252b5132
RH
2726 goto loser;
2727 }
57938635 2728
252b5132 2729 vma = bfd_section_vma (ibfd, isection);
2e62b721
NC
2730 p = find_section_list (bfd_section_name (ibfd, isection), FALSE,
2731 SECTION_CONTEXT_ALTER_VMA | SECTION_CONTEXT_SET_VMA);
2732 if (p != NULL)
2733 {
2734 if (p->context & SECTION_CONTEXT_SET_VMA)
2735 vma = p->vma_val;
2736 else
2737 vma += p->vma_val;
2738 }
252b5132
RH
2739 else
2740 vma += change_section_address;
57938635 2741
237dcb53 2742 if (! bfd_set_section_vma (obfd, osection, vma))
252b5132 2743 {
2db6cde7 2744 err = _("failed to set vma");
252b5132
RH
2745 goto loser;
2746 }
2747
2748 lma = isection->lma;
2e62b721
NC
2749 p = find_section_list (bfd_section_name (ibfd, isection), FALSE,
2750 SECTION_CONTEXT_ALTER_LMA | SECTION_CONTEXT_SET_LMA);
2751 if (p != NULL)
252b5132 2752 {
2e62b721 2753 if (p->context & SECTION_CONTEXT_ALTER_LMA)
252b5132 2754 lma += p->lma_val;
252b5132 2755 else
2e62b721 2756 lma = p->lma_val;
252b5132
RH
2757 }
2758 else
2759 lma += change_section_address;
57938635 2760
237dcb53 2761 osection->lma = lma;
252b5132
RH
2762
2763 /* FIXME: This is probably not enough. If we change the LMA we
2764 may have to recompute the header for the file as well. */
b34976b6
AM
2765 if (!bfd_set_section_alignment (obfd,
2766 osection,
2767 bfd_section_alignment (ibfd, isection)))
252b5132 2768 {
2db6cde7 2769 err = _("failed to set alignment");
252b5132
RH
2770 goto loser;
2771 }
2772
bc408b8a
JJ
2773 /* Copy merge entity size. */
2774 osection->entsize = isection->entsize;
2775
252b5132
RH
2776 /* This used to be mangle_section; we do here to avoid using
2777 bfd_get_section_by_name since some formats allow multiple
2778 sections with the same name. */
2779 isection->output_section = osection;
237dcb53 2780 isection->output_offset = 0;
d3e52d40
RS
2781
2782 /* Do not copy backend data if --extract-symbol is passed; anything
2783 that needs to look at the section contents will fail. */
2784 if (extract_symbol)
2785 return;
252b5132 2786
119f4245
AM
2787 if ((isection->flags & SEC_GROUP) != 0)
2788 {
2789 asymbol *gsym = group_signature (isection);
2790
2791 if (gsym != NULL)
2792 {
2793 gsym->flags |= BSF_KEEP;
2794 if (ibfd->xvec->flavour == bfd_target_elf_flavour)
2795 elf_group_id (isection) = gsym;
2796 }
2797 }
2798
252b5132
RH
2799 /* Allow the BFD backend to copy any private data it understands
2800 from the input section to the output section. */
42bb2e33 2801 if (!bfd_copy_private_section_data (ibfd, isection, obfd, osection))
252b5132 2802 {
2db6cde7 2803 err = _("failed to copy private data");
252b5132
RH
2804 goto loser;
2805 }
2806
594ef5db 2807 /* All went well. */
252b5132
RH
2808 return;
2809
2810loser:
252b5132 2811 status = 1;
2db6cde7 2812 bfd_nonfatal_message (NULL, obfd, osection, err);
252b5132
RH
2813}
2814
c3989150 2815/* Return TRUE if input section ISECTION should be skipped. */
252b5132 2816
c3989150
L
2817static bfd_boolean
2818skip_section (bfd *ibfd, sec_ptr isection)
252b5132 2819{
252b5132
RH
2820 sec_ptr osection;
2821 bfd_size_type size;
dc156bc0 2822 flagword flags;
252b5132 2823
594ef5db
NC
2824 /* If we have already failed earlier on,
2825 do not keep on generating complaints now. */
252b5132 2826 if (status != 0)
c3989150
L
2827 return TRUE;
2828
2829 if (extract_symbol)
2830 return TRUE;
57938635 2831
2593f09a 2832 if (is_strip_section (ibfd, isection))
c3989150 2833 return TRUE;
252b5132 2834
2593f09a 2835 flags = bfd_get_section_flags (ibfd, isection);
dc156bc0 2836 if ((flags & SEC_GROUP) != 0)
c3989150 2837 return TRUE;
dc156bc0 2838
252b5132 2839 osection = isection->output_section;
135dfb4a 2840 size = bfd_get_section_size (isection);
252b5132
RH
2841
2842 if (size == 0 || osection == 0)
c3989150 2843 return TRUE;
252b5132 2844
c3989150
L
2845 return FALSE;
2846}
2847
2848/* Copy relocations in input section ISECTION of IBFD to an output
2849 section with the same name in OBFDARG. If stripping then don't
2850 copy any relocation info. */
2851
2852static void
2853copy_relocations_in_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
2854{
2855 bfd *obfd = (bfd *) obfdarg;
2856 long relsize;
2857 arelent **relpp;
2858 long relcount;
2859 sec_ptr osection;
2860
2861 if (skip_section (ibfd, isection))
237dcb53
AM
2862 return;
2863
c3989150 2864 osection = isection->output_section;
2593f09a 2865
96109726
CC
2866 /* Core files and DWO files do not need to be relocated. */
2867 if (bfd_get_format (obfd) == bfd_core || strip_symbols == STRIP_NONDWO)
4dd67f29
MS
2868 relsize = 0;
2869 else
ed570f48
NC
2870 {
2871 relsize = bfd_get_reloc_upper_bound (ibfd, isection);
4dd67f29 2872
ed570f48
NC
2873 if (relsize < 0)
2874 {
2875 /* Do not complain if the target does not support relocations. */
2876 if (relsize == -1 && bfd_get_error () == bfd_error_invalid_operation)
2877 relsize = 0;
2878 else
2db6cde7
NS
2879 {
2880 status = 1;
2881 bfd_nonfatal_message (NULL, ibfd, isection, NULL);
2882 return;
2883 }
ed570f48
NC
2884 }
2885 }
57938635 2886
252b5132 2887 if (relsize == 0)
96109726
CC
2888 {
2889 bfd_set_reloc (obfd, osection, NULL, 0);
2890 osection->flags &= ~SEC_RELOC;
2891 }
252b5132
RH
2892 else
2893 {
3f5e193b 2894 relpp = (arelent **) xmalloc (relsize);
252b5132
RH
2895 relcount = bfd_canonicalize_reloc (ibfd, isection, relpp, isympp);
2896 if (relcount < 0)
2db6cde7
NS
2897 {
2898 status = 1;
2899 bfd_nonfatal_message (NULL, ibfd, isection,
2900 _("relocation count is negative"));
2901 return;
2902 }
57938635 2903
252b5132
RH
2904 if (strip_symbols == STRIP_ALL)
2905 {
2906 /* Remove relocations which are not in
0af11b59 2907 keep_strip_specific_list. */
252b5132
RH
2908 arelent **temp_relpp;
2909 long temp_relcount = 0;
2910 long i;
57938635 2911
3f5e193b 2912 temp_relpp = (arelent **) xmalloc (relsize);
252b5132 2913 for (i = 0; i < relcount; i++)
d3ba0551 2914 if (is_specified_symbol (bfd_asymbol_name (*relpp[i]->sym_ptr_ptr),
047c9024 2915 keep_specific_htab))
252b5132
RH
2916 temp_relpp [temp_relcount++] = relpp [i];
2917 relcount = temp_relcount;
2918 free (relpp);
2919 relpp = temp_relpp;
2920 }
e0c60db2 2921
d3ba0551 2922 bfd_set_reloc (obfd, osection, relcount == 0 ? NULL : relpp, relcount);
f0312d39 2923 if (relcount == 0)
c3989150
L
2924 {
2925 osection->flags &= ~SEC_RELOC;
2926 free (relpp);
2927 }
252b5132 2928 }
c3989150
L
2929}
2930
2931/* Copy the data of input section ISECTION of IBFD
2932 to an output section with the same name in OBFD. */
2933
2934static void
2935copy_section (bfd *ibfd, sec_ptr isection, void *obfdarg)
2936{
2937 bfd *obfd = (bfd *) obfdarg;
2938 struct section_list *p;
2939 sec_ptr osection;
2940 bfd_size_type size;
2941
2942 if (skip_section (ibfd, isection))
2943 return;
2944
2945 osection = isection->output_section;
2946 size = bfd_get_section_size (isection);
2947
0af11b59 2948 if (bfd_get_section_flags (ibfd, isection) & SEC_HAS_CONTENTS
4dd67f29 2949 && bfd_get_section_flags (obfd, osection) & SEC_HAS_CONTENTS)
252b5132 2950 {
4a114e3e 2951 bfd_byte *memhunk = NULL;
252b5132 2952
4a114e3e 2953 if (!bfd_get_full_section_contents (ibfd, isection, &memhunk))
2db6cde7
NS
2954 {
2955 status = 1;
2956 bfd_nonfatal_message (NULL, ibfd, isection, NULL);
2957 return;
2958 }
252b5132 2959
9e48b4c6
NC
2960 if (reverse_bytes)
2961 {
2962 /* We don't handle leftover bytes (too many possible behaviors,
2963 and we don't know what the user wants). The section length
2964 must be a multiple of the number of bytes to swap. */
2965 if ((size % reverse_bytes) == 0)
2966 {
2967 unsigned long i, j;
2968 bfd_byte b;
2969
2970 for (i = 0; i < size; i += reverse_bytes)
2971 for (j = 0; j < (unsigned long)(reverse_bytes / 2); j++)
2972 {
2973 bfd_byte *m = (bfd_byte *) memhunk;
2974
2975 b = m[i + j];
2976 m[i + j] = m[(i + reverse_bytes) - (j + 1)];
2977 m[(i + reverse_bytes) - (j + 1)] = b;
2978 }
2979 }
2980 else
2981 /* User must pad the section up in order to do this. */
2982 fatal (_("cannot reverse bytes: length of section %s must be evenly divisible by %d"),
2983 bfd_section_name (ibfd, isection), reverse_bytes);
2984 }
2985
57938635 2986 if (copy_byte >= 0)
5e675b72
AM
2987 {
2988 /* Keep only every `copy_byte'th byte in MEMHUNK. */
2f01ffbf 2989 char *from = (char *) memhunk + copy_byte;
3f5e193b 2990 char *to = (char *) memhunk;
2f01ffbf 2991 char *end = (char *) memhunk + size;
b7dd81f7 2992 int i;
5e675b72
AM
2993
2994 for (; from < end; from += interleave)
b7dd81f7 2995 for (i = 0; i < copy_width; i++)
ee7da987
L
2996 {
2997 if (&from[i] >= end)
2998 break;
2999 *to++ = from[i];
3000 }
5e675b72 3001
b7dd81f7 3002 size = (size + interleave - 1 - copy_byte) / interleave * copy_width;
5e675b72
AM
3003 osection->lma /= interleave;
3004 }
252b5132 3005
d3ba0551 3006 if (!bfd_set_section_contents (obfd, osection, memhunk, 0, size))
2db6cde7
NS
3007 {
3008 status = 1;
3009 bfd_nonfatal_message (NULL, obfd, osection, NULL);
3010 return;
3011 }
252b5132
RH
3012 free (memhunk);
3013 }
2e62b721
NC
3014 else if ((p = find_section_list (bfd_get_section_name (ibfd, isection),
3015 FALSE, SECTION_CONTEXT_SET_FLAGS)) != NULL
3016 && (p->flags & SEC_HAS_CONTENTS) != 0)
252b5132 3017 {
d3ba0551 3018 void *memhunk = xmalloc (size);
252b5132
RH
3019
3020 /* We don't permit the user to turn off the SEC_HAS_CONTENTS
3021 flag--they can just remove the section entirely and add it
3022 back again. However, we do permit them to turn on the
3023 SEC_HAS_CONTENTS flag, and take it to mean that the section
3024 contents should be zeroed out. */
3025
3026 memset (memhunk, 0, size);
d3ba0551 3027 if (! bfd_set_section_contents (obfd, osection, memhunk, 0, size))
2db6cde7
NS
3028 {
3029 status = 1;
3030 bfd_nonfatal_message (NULL, obfd, osection, NULL);
3031 return;
3032 }
252b5132
RH
3033 free (memhunk);
3034 }
3035}
3036
3037/* Get all the sections. This is used when --gap-fill or --pad-to is
3038 used. */
3039
3040static void
84e2f313 3041get_sections (bfd *obfd ATTRIBUTE_UNUSED, asection *osection, void *secppparg)
252b5132 3042{
3f5e193b 3043 asection ***secppp = (asection ***) secppparg;
252b5132
RH
3044
3045 **secppp = osection;
3046 ++(*secppp);
3047}
3048
3049/* Sort sections by VMA. This is called via qsort, and is used when
3050 --gap-fill or --pad-to is used. We force non loadable or empty
3051 sections to the front, where they are easier to ignore. */
3052
3053static int
84e2f313 3054compare_section_lma (const void *arg1, const void *arg2)
252b5132 3055{
3f5e193b
NC
3056 const asection *const *sec1 = (const asection * const *) arg1;
3057 const asection *const *sec2 = (const asection * const *) arg2;
252b5132
RH
3058 flagword flags1, flags2;
3059
3060 /* Sort non loadable sections to the front. */
3061 flags1 = (*sec1)->flags;
3062 flags2 = (*sec2)->flags;
3063 if ((flags1 & SEC_HAS_CONTENTS) == 0
3064 || (flags1 & SEC_LOAD) == 0)
3065 {
3066 if ((flags2 & SEC_HAS_CONTENTS) != 0
3067 && (flags2 & SEC_LOAD) != 0)
3068 return -1;
3069 }
3070 else
3071 {
3072 if ((flags2 & SEC_HAS_CONTENTS) == 0
3073 || (flags2 & SEC_LOAD) == 0)
3074 return 1;
3075 }
3076
3077 /* Sort sections by LMA. */
3078 if ((*sec1)->lma > (*sec2)->lma)
3079 return 1;
3080 else if ((*sec1)->lma < (*sec2)->lma)
3081 return -1;
3082
3083 /* Sort sections with the same LMA by size. */
135dfb4a 3084 if (bfd_get_section_size (*sec1) > bfd_get_section_size (*sec2))
252b5132 3085 return 1;
135dfb4a 3086 else if (bfd_get_section_size (*sec1) < bfd_get_section_size (*sec2))
252b5132
RH
3087 return -1;
3088
3089 return 0;
3090}
3091
3092/* Mark all the symbols which will be used in output relocations with
3093 the BSF_KEEP flag so that those symbols will not be stripped.
3094
3095 Ignore relocations which will not appear in the output file. */
3096
3097static void
84e2f313 3098mark_symbols_used_in_relocations (bfd *ibfd, sec_ptr isection, void *symbolsarg)
252b5132 3099{
3f5e193b 3100 asymbol **symbols = (asymbol **) symbolsarg;
252b5132
RH
3101 long relsize;
3102 arelent **relpp;
3103 long relcount, i;
3104
3105 /* Ignore an input section with no corresponding output section. */
3106 if (isection->output_section == NULL)
3107 return;
3108
3109 relsize = bfd_get_reloc_upper_bound (ibfd, isection);
3110 if (relsize < 0)
ed570f48
NC
3111 {
3112 /* Do not complain if the target does not support relocations. */
3113 if (relsize == -1 && bfd_get_error () == bfd_error_invalid_operation)
3114 return;
3115 bfd_fatal (bfd_get_filename (ibfd));
3116 }
252b5132
RH
3117
3118 if (relsize == 0)
3119 return;
3120
3f5e193b 3121 relpp = (arelent **) xmalloc (relsize);
252b5132
RH
3122 relcount = bfd_canonicalize_reloc (ibfd, isection, relpp, symbols);
3123 if (relcount < 0)
3124 bfd_fatal (bfd_get_filename (ibfd));
3125
ec5d57d5
NC
3126 /* Examine each symbol used in a relocation. If it's not one of the
3127 special bfd section symbols, then mark it with BSF_KEEP. */
252b5132
RH
3128 for (i = 0; i < relcount; i++)
3129 {
ec5d57d5
NC
3130 if (*relpp[i]->sym_ptr_ptr != bfd_com_section_ptr->symbol
3131 && *relpp[i]->sym_ptr_ptr != bfd_abs_section_ptr->symbol
3132 && *relpp[i]->sym_ptr_ptr != bfd_und_section_ptr->symbol)
3133 (*relpp[i]->sym_ptr_ptr)->flags |= BSF_KEEP;
252b5132
RH
3134 }
3135
3136 if (relpp != NULL)
3137 free (relpp);
3138}
3139
3140/* Write out debugging information. */
3141
b34976b6 3142static bfd_boolean
84e2f313
NC
3143write_debugging_info (bfd *obfd, void *dhandle,
3144 long *symcountp ATTRIBUTE_UNUSED,
3145 asymbol ***symppp ATTRIBUTE_UNUSED)
252b5132
RH
3146{
3147 if (bfd_get_flavour (obfd) == bfd_target_ieee_flavour)
3148 return write_ieee_debugging_info (obfd, dhandle);
3149
3150 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour
3151 || bfd_get_flavour (obfd) == bfd_target_elf_flavour)
3152 {
3153 bfd_byte *syms, *strings;
3154 bfd_size_type symsize, stringsize;
3155 asection *stabsec, *stabstrsec;
551b43fd 3156 flagword flags;
252b5132
RH
3157
3158 if (! write_stabs_in_sections_debugging_info (obfd, dhandle, &syms,
3159 &symsize, &strings,
3160 &stringsize))
b34976b6 3161 return FALSE;
252b5132 3162
551b43fd
AM
3163 flags = SEC_HAS_CONTENTS | SEC_READONLY | SEC_DEBUGGING;
3164 stabsec = bfd_make_section_with_flags (obfd, ".stab", flags);
3165 stabstrsec = bfd_make_section_with_flags (obfd, ".stabstr", flags);
252b5132
RH
3166 if (stabsec == NULL
3167 || stabstrsec == NULL
3168 || ! bfd_set_section_size (obfd, stabsec, symsize)
3169 || ! bfd_set_section_size (obfd, stabstrsec, stringsize)
3170 || ! bfd_set_section_alignment (obfd, stabsec, 2)
551b43fd 3171 || ! bfd_set_section_alignment (obfd, stabstrsec, 0))
252b5132 3172 {
2db6cde7
NS
3173 bfd_nonfatal_message (NULL, obfd, NULL,
3174 _("can't create debugging section"));
b34976b6 3175 return FALSE;
252b5132
RH
3176 }
3177
3178 /* We can get away with setting the section contents now because
3179 the next thing the caller is going to do is copy over the
3180 real sections. We may someday have to split the contents
3181 setting out of this function. */
d3ba0551
AM
3182 if (! bfd_set_section_contents (obfd, stabsec, syms, 0, symsize)
3183 || ! bfd_set_section_contents (obfd, stabstrsec, strings, 0,
3184 stringsize))
252b5132 3185 {
2db6cde7
NS
3186 bfd_nonfatal_message (NULL, obfd, NULL,
3187 _("can't set debugging section contents"));
b34976b6 3188 return FALSE;
252b5132
RH
3189 }
3190
b34976b6 3191 return TRUE;
252b5132
RH
3192 }
3193
2db6cde7
NS
3194 bfd_nonfatal_message (NULL, obfd, NULL,
3195 _("don't know how to write debugging information for %s"),
3196 bfd_get_target (obfd));
b34976b6 3197 return FALSE;
252b5132
RH
3198}
3199
955d0b3b
RM
3200/* If neither -D nor -U was specified explicitly,
3201 then use the configured default. */
3202static void
3203default_deterministic (void)
3204{
3205 if (deterministic < 0)
3206 deterministic = DEFAULT_AR_DETERMINISTIC;
3207}
3208
252b5132 3209static int
84e2f313 3210strip_main (int argc, char *argv[])
252b5132 3211{
7c29036b
NC
3212 char *input_target = NULL;
3213 char *output_target = NULL;
b34976b6 3214 bfd_boolean show_version = FALSE;
7c29036b
NC
3215 bfd_boolean formats_info = FALSE;
3216 int c;
3217 int i;
252b5132
RH
3218 char *output_file = NULL;
3219
5fe11841 3220 while ((c = getopt_long (argc, argv, "I:O:F:K:N:R:o:sSpdgxXHhVvw",
252b5132
RH
3221 strip_options, (int *) 0)) != EOF)
3222 {
3223 switch (c)
3224 {
3225 case 'I':
3226 input_target = optarg;
3227 break;
3228 case 'O':
3229 output_target = optarg;
3230 break;
3231 case 'F':
3232 input_target = output_target = optarg;
3233 break;
3234 case 'R':
2e62b721 3235 find_section_list (optarg, TRUE, SECTION_CONTEXT_REMOVE);
b34976b6 3236 sections_removed = TRUE;
252b5132
RH
3237 break;
3238 case 's':
3239 strip_symbols = STRIP_ALL;
3240 break;
3241 case 'S':
3242 case 'g':
db4f6831 3243 case 'd': /* Historic BSD alias for -g. Used by early NetBSD. */
252b5132
RH
3244 strip_symbols = STRIP_DEBUG;
3245 break;
96109726
CC
3246 case OPTION_STRIP_DWO:
3247 strip_symbols = STRIP_DWO;
3248 break;
252b5132
RH
3249 case OPTION_STRIP_UNNEEDED:
3250 strip_symbols = STRIP_UNNEEDED;
3251 break;
3252 case 'K':
047c9024 3253 add_specific_symbol (optarg, keep_specific_htab);
252b5132
RH
3254 break;
3255 case 'N':
047c9024 3256 add_specific_symbol (optarg, strip_specific_htab);
252b5132
RH
3257 break;
3258 case 'o':
3259 output_file = optarg;
3260 break;
3261 case 'p':
b34976b6 3262 preserve_dates = TRUE;
252b5132 3263 break;
2e30cb57
CC
3264 case 'D':
3265 deterministic = TRUE;
3266 break;
955d0b3b
RM
3267 case 'U':
3268 deterministic = FALSE;
3269 break;
252b5132
RH
3270 case 'x':
3271 discard_locals = LOCALS_ALL;
3272 break;
3273 case 'X':
3274 discard_locals = LOCALS_START_L;
3275 break;
3276 case 'v':
b34976b6 3277 verbose = TRUE;
252b5132
RH
3278 break;
3279 case 'V':
b34976b6 3280 show_version = TRUE;
252b5132 3281 break;
7c29036b
NC
3282 case OPTION_FORMATS_INFO:
3283 formats_info = TRUE;
3284 break;
ed1653a7
NC
3285 case OPTION_ONLY_KEEP_DEBUG:
3286 strip_symbols = STRIP_NONDEBUG;
3287 break;
1637cd90
JB
3288 case OPTION_KEEP_FILE_SYMBOLS:
3289 keep_file_symbols = 1;
3290 break;
252b5132 3291 case 0:
594ef5db
NC
3292 /* We've been given a long option. */
3293 break;
5fe11841
NC
3294 case 'w':
3295 wildcard = TRUE;
3296 break;
8b53311e 3297 case 'H':
252b5132
RH
3298 case 'h':
3299 strip_usage (stdout, 0);
3300 default:
3301 strip_usage (stderr, 1);
3302 }
3303 }
3304
84e2f313
NC
3305 if (formats_info)
3306 {
3307 display_info ();
3308 return 0;
3309 }
c1c0eb9e 3310
252b5132
RH
3311 if (show_version)
3312 print_version ("strip");
3313
955d0b3b
RM
3314 default_deterministic ();
3315
252b5132
RH
3316 /* Default is to strip all symbols. */
3317 if (strip_symbols == STRIP_UNDEF
3318 && discard_locals == LOCALS_UNDEF
047c9024 3319 && htab_elements (strip_specific_htab) == 0)
252b5132
RH
3320 strip_symbols = STRIP_ALL;
3321
d3ba0551 3322 if (output_target == NULL)
252b5132
RH
3323 output_target = input_target;
3324
3325 i = optind;
3326 if (i == argc
3327 || (output_file != NULL && (i + 1) < argc))
3328 strip_usage (stderr, 1);
3329
3330 for (; i < argc; i++)
3331 {
3332 int hold_status = status;
3333 struct stat statbuf;
3334 char *tmpname;
3335
f24ddbdd 3336 if (get_file_size (argv[i]) < 1)
d68c385b
NC
3337 {
3338 status = 1;
3339 continue;
3340 }
f24ddbdd 3341
252b5132 3342 if (preserve_dates)
f24ddbdd
NC
3343 /* No need to check the return value of stat().
3344 It has already been checked in get_file_size(). */
3345 stat (argv[i], &statbuf);
252b5132 3346
8b6efd89
KT
3347 if (output_file == NULL
3348 || filename_cmp (argv[i], output_file) == 0)
252b5132 3349 tmpname = make_tempname (argv[i]);
12f498a7
NS
3350 else
3351 tmpname = output_file;
252b5132 3352
f9c026a8
NC
3353 if (tmpname == NULL)
3354 {
2db6cde7
NS
3355 bfd_nonfatal_message (argv[i], NULL, NULL,
3356 _("could not create temporary file to hold stripped copy"));
f9c026a8
NC
3357 status = 1;
3358 continue;
3359 }
3360
d68c385b 3361 status = 0;
8b31b6c4 3362 copy_file (argv[i], tmpname, input_target, output_target, NULL);
252b5132
RH
3363 if (status == 0)
3364 {
3365 if (preserve_dates)
3366 set_times (tmpname, &statbuf);
12f498a7 3367 if (output_file != tmpname)
92fac5ec
L
3368 status = (smart_rename (tmpname,
3369 output_file ? output_file : argv[i],
3370 preserve_dates) != 0);
3371 if (status == 0)
3372 status = hold_status;
252b5132
RH
3373 }
3374 else
bb14f524 3375 unlink_if_ordinary (tmpname);
12f498a7 3376 if (output_file != tmpname)
252b5132
RH
3377 free (tmpname);
3378 }
3379
d68c385b 3380 return status;
252b5132
RH
3381}
3382
92dd4511
L
3383/* Set up PE subsystem. */
3384
3385static void
3386set_pe_subsystem (const char *s)
3387{
3388 const char *version, *subsystem;
3389 size_t i;
3390 static const struct
3391 {
3392 const char *name;
3393 const char set_def;
3394 const short value;
3395 }
3396 v[] =
3397 {
955d0b3b 3398 { "native", 0, IMAGE_SUBSYSTEM_NATIVE },
92dd4511
L
3399 { "windows", 0, IMAGE_SUBSYSTEM_WINDOWS_GUI },
3400 { "console", 0, IMAGE_SUBSYSTEM_WINDOWS_CUI },
3401 { "posix", 0, IMAGE_SUBSYSTEM_POSIX_CUI },
3402 { "wince", 0, IMAGE_SUBSYSTEM_WINDOWS_CE_GUI },
3403 { "efi-app", 1, IMAGE_SUBSYSTEM_EFI_APPLICATION },
3404 { "efi-bsd", 1, IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER },
3405 { "efi-rtd", 1, IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER },
d9118602 3406 { "sal-rtd", 1, IMAGE_SUBSYSTEM_SAL_RUNTIME_DRIVER },
92dd4511
L
3407 { "xbox", 0, IMAGE_SUBSYSTEM_XBOX }
3408 };
3409 short value;
3410 char *copy;
3411 int set_def = -1;
3412
3413 /* Check for the presence of a version number. */
3414 version = strchr (s, ':');
3415 if (version == NULL)
3416 subsystem = s;
3417 else
3418 {
3419 int len = version - s;
3420 copy = xstrdup (s);
3421 subsystem = copy;
3422 copy[len] = '\0';
3423 version = copy + 1 + len;
3424 pe_major_subsystem_version = strtoul (version, &copy, 0);
3425 if (*copy == '.')
3426 pe_minor_subsystem_version = strtoul (copy + 1, &copy, 0);
3427 if (*copy != '\0')
3428 non_fatal (_("%s: bad version in PE subsystem"), s);
3429 }
3430
3431 /* Check for numeric subsystem. */
3432 value = (short) strtol (subsystem, &copy, 0);
3433 if (*copy == '\0')
3434 {
3435 for (i = 0; i < ARRAY_SIZE (v); i++)
3436 if (v[i].value == value)
3437 {
3438 pe_subsystem = value;
3439 set_def = v[i].set_def;
3440 break;
3441 }
3442 }
3443 else
3444 {
3445 /* Search for subsystem by name. */
3446 for (i = 0; i < ARRAY_SIZE (v); i++)
3447 if (strcmp (subsystem, v[i].name) == 0)
3448 {
3449 pe_subsystem = v[i].value;
3450 set_def = v[i].set_def;
3451 break;
3452 }
3453 }
3454
3455 switch (set_def)
3456 {
3457 case -1:
3458 fatal (_("unknown PE subsystem: %s"), s);
3459 break;
3460 case 0:
3461 break;
3462 default:
3463 if (pe_file_alignment == (bfd_vma) -1)
3464 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
3465 if (pe_section_alignment == (bfd_vma) -1)
3466 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
3467 break;
3468 }
0cbf3531
MS
3469 if (s != subsystem)
3470 free ((char *) subsystem);
92dd4511
L
3471}
3472
3473/* Convert EFI target to PEI target. */
3474
3475static void
3476convert_efi_target (char *efi)
3477{
3478 efi[0] = 'p';
3479 efi[1] = 'e';
3480 efi[2] = 'i';
3481
3482 if (strcmp (efi + 4, "ia32") == 0)
3483 {
3484 /* Change ia32 to i386. */
3485 efi[5]= '3';
3486 efi[6]= '8';
3487 efi[7]= '6';
3488 }
3489 else if (strcmp (efi + 4, "x86_64") == 0)
3490 {
3491 /* Change x86_64 to x86-64. */
3492 efi[7] = '-';
3493 }
3494}
3495
252b5132 3496static int
84e2f313 3497copy_main (int argc, char *argv[])
252b5132 3498{
7c29036b
NC
3499 char *input_filename = NULL;
3500 char *output_filename = NULL;
c1c0eb9e 3501 char *tmpname;
7c29036b
NC
3502 char *input_target = NULL;
3503 char *output_target = NULL;
b34976b6
AM
3504 bfd_boolean show_version = FALSE;
3505 bfd_boolean change_warn = TRUE;
7c29036b 3506 bfd_boolean formats_info = FALSE;
252b5132 3507 int c;
252b5132 3508 struct stat statbuf;
8b31b6c4 3509 const bfd_arch_info_type *input_arch = NULL;
252b5132 3510
5fe11841 3511 while ((c = getopt_long (argc, argv, "b:B:i:I:j:K:N:s:O:d:F:L:G:R:SpgxXHhVvW:w",
252b5132
RH
3512 copy_options, (int *) 0)) != EOF)
3513 {
3514 switch (c)
3515 {
3516 case 'b':
3517 copy_byte = atoi (optarg);
3518 if (copy_byte < 0)
3519 fatal (_("byte number must be non-negative"));
3520 break;
57938635 3521
0af11b59 3522 case 'B':
8b31b6c4
NC
3523 input_arch = bfd_scan_arch (optarg);
3524 if (input_arch == NULL)
3525 fatal (_("architecture %s unknown"), optarg);
0af11b59 3526 break;
43a0748c 3527
252b5132 3528 case 'i':
b7dd81f7
NC
3529 if (optarg)
3530 {
3531 interleave = atoi (optarg);
3532 if (interleave < 1)
3533 fatal (_("interleave must be positive"));
3534 }
3535 else
3536 interleave = 4;
3537 break;
3538
3539 case OPTION_INTERLEAVE_WIDTH:
3540 copy_width = atoi (optarg);
3541 if (copy_width < 1)
3542 fatal(_("interleave width must be positive"));
252b5132 3543 break;
57938635 3544
252b5132
RH
3545 case 'I':
3546 case 's': /* "source" - 'I' is preferred */
3547 input_target = optarg;
3548 break;
57938635 3549
252b5132
RH
3550 case 'O':
3551 case 'd': /* "destination" - 'O' is preferred */
3552 output_target = optarg;
3553 break;
57938635 3554
252b5132
RH
3555 case 'F':
3556 input_target = output_target = optarg;
3557 break;
57938635 3558
f91ea849 3559 case 'j':
2e62b721 3560 find_section_list (optarg, TRUE, SECTION_CONTEXT_COPY);
b34976b6 3561 sections_copied = TRUE;
f91ea849 3562 break;
57938635 3563
252b5132 3564 case 'R':
2e62b721 3565 find_section_list (optarg, TRUE, SECTION_CONTEXT_REMOVE);
b34976b6 3566 sections_removed = TRUE;
252b5132 3567 break;
57938635 3568
252b5132
RH
3569 case 'S':
3570 strip_symbols = STRIP_ALL;
3571 break;
57938635 3572
252b5132
RH
3573 case 'g':
3574 strip_symbols = STRIP_DEBUG;
3575 break;
57938635 3576
96109726
CC
3577 case OPTION_STRIP_DWO:
3578 strip_symbols = STRIP_DWO;
3579 break;
3580
252b5132
RH
3581 case OPTION_STRIP_UNNEEDED:
3582 strip_symbols = STRIP_UNNEEDED;
3583 break;
57938635 3584
ed1653a7
NC
3585 case OPTION_ONLY_KEEP_DEBUG:
3586 strip_symbols = STRIP_NONDEBUG;
3587 break;
3588
1637cd90
JB
3589 case OPTION_KEEP_FILE_SYMBOLS:
3590 keep_file_symbols = 1;
3591 break;
3592
2593f09a 3593 case OPTION_ADD_GNU_DEBUGLINK:
9b8bf321 3594 long_section_names = ENABLE ;
2593f09a
NC
3595 gnu_debuglink_filename = optarg;
3596 break;
3597
252b5132 3598 case 'K':
047c9024 3599 add_specific_symbol (optarg, keep_specific_htab);
252b5132 3600 break;
57938635 3601
252b5132 3602 case 'N':
047c9024 3603 add_specific_symbol (optarg, strip_specific_htab);
252b5132 3604 break;
57938635 3605
bcf32829 3606 case OPTION_STRIP_UNNEEDED_SYMBOL:
047c9024 3607 add_specific_symbol (optarg, strip_unneeded_htab);
bcf32829
JB
3608 break;
3609
252b5132 3610 case 'L':
047c9024 3611 add_specific_symbol (optarg, localize_specific_htab);
252b5132 3612 break;
57938635 3613
7b4a0685 3614 case OPTION_GLOBALIZE_SYMBOL:
047c9024 3615 add_specific_symbol (optarg, globalize_specific_htab);
7b4a0685
NC
3616 break;
3617
16b2b71c 3618 case 'G':
047c9024 3619 add_specific_symbol (optarg, keepglobal_specific_htab);
16b2b71c
NC
3620 break;
3621
252b5132 3622 case 'W':
047c9024 3623 add_specific_symbol (optarg, weaken_specific_htab);
252b5132 3624 break;
57938635 3625
252b5132 3626 case 'p':
b34976b6 3627 preserve_dates = TRUE;
252b5132 3628 break;
57938635 3629
2e30cb57
CC
3630 case 'D':
3631 deterministic = TRUE;
3632 break;
3633
955d0b3b
RM
3634 case 'U':
3635 deterministic = FALSE;
3636 break;
3637
5fe11841
NC
3638 case 'w':
3639 wildcard = TRUE;
3640 break;
3641
252b5132
RH
3642 case 'x':
3643 discard_locals = LOCALS_ALL;
3644 break;
57938635 3645
252b5132
RH
3646 case 'X':
3647 discard_locals = LOCALS_START_L;
3648 break;
57938635 3649
252b5132 3650 case 'v':
b34976b6 3651 verbose = TRUE;
252b5132 3652 break;
57938635 3653
252b5132 3654 case 'V':
b34976b6 3655 show_version = TRUE;
252b5132 3656 break;
57938635 3657
7c29036b
NC
3658 case OPTION_FORMATS_INFO:
3659 formats_info = TRUE;
3660 break;
3661
252b5132 3662 case OPTION_WEAKEN:
b34976b6 3663 weaken = TRUE;
252b5132 3664 break;
57938635 3665
252b5132
RH
3666 case OPTION_ADD_SECTION:
3667 {
3668 const char *s;
500ee42e 3669 size_t off, alloc;
252b5132 3670 struct section_add *pa;
252b5132
RH
3671 FILE *f;
3672
3673 s = strchr (optarg, '=');
57938635 3674
252b5132 3675 if (s == NULL)
57938635 3676 fatal (_("bad format for %s"), "--add-section");
252b5132 3677
3f5e193b 3678 pa = (struct section_add *) xmalloc (sizeof (struct section_add));
500ee42e 3679 pa->name = xstrndup (optarg, s - optarg);
252b5132
RH
3680 pa->filename = s + 1;
3681
500ee42e
ILT
3682 /* We don't use get_file_size so that we can do
3683 --add-section .note.GNU_stack=/dev/null
3684 get_file_size doesn't work on /dev/null. */
57938635 3685
500ee42e 3686 f = fopen (pa->filename, FOPEN_RB);
252b5132 3687 if (f == NULL)
84e2f313
NC
3688 fatal (_("cannot open: %s: %s"),
3689 pa->filename, strerror (errno));
57938635 3690
500ee42e
ILT
3691 off = 0;
3692 alloc = 4096;
3693 pa->contents = (bfd_byte *) xmalloc (alloc);
3694 while (!feof (f))
3695 {
3696 off_t got;
3697
3698 if (off == alloc)
3699 {
3700 alloc <<= 1;
3701 pa->contents = (bfd_byte *) xrealloc (pa->contents, alloc);
3702 }
3703
3704 got = fread (pa->contents + off, 1, alloc - off, f);
3705 if (ferror (f))
3706 fatal (_("%s: fread failed"), pa->filename);
3707
3708 off += got;
3709 }
3710
3711 pa->size = off;
252b5132
RH
3712
3713 fclose (f);
3714
3715 pa->next = add_sections;
3716 add_sections = pa;
3717 }
3718 break;
57938635 3719
bbad633b
NC
3720 case OPTION_DUMP_SECTION:
3721 {
3722 const char *s;
3723 struct section_add *pa;
3724
3725 s = strchr (optarg, '=');
3726
3727 if (s == NULL)
3728 fatal (_("bad format for %s"), "--dump-section");
3729
3730 pa = (struct section_add *) xmalloc (sizeof * pa);
3731 pa->name = xstrndup (optarg, s - optarg);
3732 pa->filename = s + 1;
3733 pa->next = dump_sections;
3734 pa->contents = NULL;
3735 dump_sections = pa;
3736 }
3737 break;
3738
252b5132
RH
3739 case OPTION_CHANGE_START:
3740 change_start = parse_vma (optarg, "--change-start");
3741 break;
57938635 3742
252b5132
RH
3743 case OPTION_CHANGE_SECTION_ADDRESS:
3744 case OPTION_CHANGE_SECTION_LMA:
3745 case OPTION_CHANGE_SECTION_VMA:
3746 {
2e62b721 3747 struct section_list * p;
76d8cf45 3748 unsigned int context = 0;
252b5132
RH
3749 const char *s;
3750 int len;
3751 char *name;
b4c96d0d 3752 char *option = NULL;
252b5132 3753 bfd_vma val;
57938635 3754
252b5132
RH
3755 switch (c)
3756 {
b4c96d0d
ILT
3757 case OPTION_CHANGE_SECTION_ADDRESS:
3758 option = "--change-section-address";
2e62b721 3759 context = SECTION_CONTEXT_ALTER_LMA | SECTION_CONTEXT_ALTER_VMA;
b4c96d0d
ILT
3760 break;
3761 case OPTION_CHANGE_SECTION_LMA:
3762 option = "--change-section-lma";
2e62b721 3763 context = SECTION_CONTEXT_ALTER_LMA;
b4c96d0d
ILT
3764 break;
3765 case OPTION_CHANGE_SECTION_VMA:
3766 option = "--change-section-vma";
2e62b721 3767 context = SECTION_CONTEXT_ALTER_VMA;
b4c96d0d 3768 break;
252b5132 3769 }
57938635 3770
252b5132
RH
3771 s = strchr (optarg, '=');
3772 if (s == NULL)
3773 {
3774 s = strchr (optarg, '+');
3775 if (s == NULL)
3776 {
3777 s = strchr (optarg, '-');
3778 if (s == NULL)
3779 fatal (_("bad format for %s"), option);
3780 }
3781 }
2e62b721
NC
3782 else
3783 {
3784 /* Correct the context. */
3785 switch (c)
3786 {
3787 case OPTION_CHANGE_SECTION_ADDRESS:
3788 context = SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_SET_VMA;
3789 break;
3790 case OPTION_CHANGE_SECTION_LMA:
3791 context = SECTION_CONTEXT_SET_LMA;
3792 break;
3793 case OPTION_CHANGE_SECTION_VMA:
3794 context = SECTION_CONTEXT_SET_VMA;
3795 break;
3796 }
3797 }
252b5132
RH
3798
3799 len = s - optarg;
3f5e193b 3800 name = (char *) xmalloc (len + 1);
252b5132
RH
3801 strncpy (name, optarg, len);
3802 name[len] = '\0';
3803
2e62b721 3804 p = find_section_list (name, TRUE, context);
252b5132
RH
3805
3806 val = parse_vma (s + 1, option);
2e62b721
NC
3807 if (*s == '-')
3808 val = - val;
57938635 3809
252b5132
RH
3810 switch (c)
3811 {
3812 case OPTION_CHANGE_SECTION_ADDRESS:
2e62b721 3813 p->vma_val = val;
252b5132 3814 /* Drop through. */
57938635 3815
252b5132 3816 case OPTION_CHANGE_SECTION_LMA:
2e62b721 3817 p->lma_val = val;
252b5132 3818 break;
57938635 3819
252b5132 3820 case OPTION_CHANGE_SECTION_VMA:
2e62b721 3821 p->vma_val = val;
252b5132
RH
3822 break;
3823 }
3824 }
3825 break;
57938635 3826
252b5132
RH
3827 case OPTION_CHANGE_ADDRESSES:
3828 change_section_address = parse_vma (optarg, "--change-addresses");
3829 change_start = change_section_address;
3830 break;
57938635 3831
252b5132 3832 case OPTION_CHANGE_WARNINGS:
b34976b6 3833 change_warn = TRUE;
252b5132 3834 break;
57938635 3835
252b5132 3836 case OPTION_CHANGE_LEADING_CHAR:
b34976b6 3837 change_leading_char = TRUE;
252b5132 3838 break;
57938635 3839
4a114e3e
L
3840 case OPTION_COMPRESS_DEBUG_SECTIONS:
3841 do_debug_sections = compress;
3842 break;
3843
252b5132 3844 case OPTION_DEBUGGING:
b34976b6 3845 convert_debugging = TRUE;
252b5132 3846 break;
57938635 3847
4a114e3e
L
3848 case OPTION_DECOMPRESS_DEBUG_SECTIONS:
3849 do_debug_sections = decompress;
3850 break;
3851
252b5132
RH
3852 case OPTION_GAP_FILL:
3853 {
3854 bfd_vma gap_fill_vma;
3855
3856 gap_fill_vma = parse_vma (optarg, "--gap-fill");
3857 gap_fill = (bfd_byte) gap_fill_vma;
3858 if ((bfd_vma) gap_fill != gap_fill_vma)
3859 {
3860 char buff[20];
57938635 3861
252b5132 3862 sprintf_vma (buff, gap_fill_vma);
57938635 3863
252b5132
RH
3864 non_fatal (_("Warning: truncating gap-fill from 0x%s to 0x%x"),
3865 buff, gap_fill);
3866 }
b34976b6 3867 gap_fill_set = TRUE;
252b5132
RH
3868 }
3869 break;
57938635 3870
252b5132 3871 case OPTION_NO_CHANGE_WARNINGS:
b34976b6 3872 change_warn = FALSE;
252b5132 3873 break;
57938635 3874
252b5132
RH
3875 case OPTION_PAD_TO:
3876 pad_to = parse_vma (optarg, "--pad-to");
b34976b6 3877 pad_to_set = TRUE;
252b5132 3878 break;
57938635 3879
252b5132 3880 case OPTION_REMOVE_LEADING_CHAR:
b34976b6 3881 remove_leading_char = TRUE;
252b5132 3882 break;
57938635
AM
3883
3884 case OPTION_REDEFINE_SYM:
3885 {
3886 /* Push this redefinition onto redefine_symbol_list. */
3887
3888 int len;
3889 const char *s;
3890 const char *nextarg;
3891 char *source, *target;
3892
3893 s = strchr (optarg, '=');
3894 if (s == NULL)
594ef5db 3895 fatal (_("bad format for %s"), "--redefine-sym");
57938635
AM
3896
3897 len = s - optarg;
3f5e193b 3898 source = (char *) xmalloc (len + 1);
57938635
AM
3899 strncpy (source, optarg, len);
3900 source[len] = '\0';
3901
3902 nextarg = s + 1;
3903 len = strlen (nextarg);
3f5e193b 3904 target = (char *) xmalloc (len + 1);
57938635
AM
3905 strcpy (target, nextarg);
3906
92991082 3907 redefine_list_append ("--redefine-sym", source, target);
57938635
AM
3908
3909 free (source);
3910 free (target);
3911 }
3912 break;
3913
92991082
JT
3914 case OPTION_REDEFINE_SYMS:
3915 add_redefine_syms_file (optarg);
3916 break;
3917
252b5132
RH
3918 case OPTION_SET_SECTION_FLAGS:
3919 {
2e62b721 3920 struct section_list *p;
252b5132
RH
3921 const char *s;
3922 int len;
3923 char *name;
3924
3925 s = strchr (optarg, '=');
3926 if (s == NULL)
57938635 3927 fatal (_("bad format for %s"), "--set-section-flags");
252b5132
RH
3928
3929 len = s - optarg;
3f5e193b 3930 name = (char *) xmalloc (len + 1);
252b5132
RH
3931 strncpy (name, optarg, len);
3932 name[len] = '\0';
3933
2e62b721 3934 p = find_section_list (name, TRUE, SECTION_CONTEXT_SET_FLAGS);
252b5132 3935
252b5132
RH
3936 p->flags = parse_flags (s + 1);
3937 }
3938 break;
57938635 3939
594ef5db
NC
3940 case OPTION_RENAME_SECTION:
3941 {
3942 flagword flags;
3bcfb3e4
AM
3943 const char *eq, *fl;
3944 char *old_name;
3945 char *new_name;
594ef5db
NC
3946 unsigned int len;
3947
3bcfb3e4
AM
3948 eq = strchr (optarg, '=');
3949 if (eq == NULL)
594ef5db
NC
3950 fatal (_("bad format for %s"), "--rename-section");
3951
3bcfb3e4 3952 len = eq - optarg;
594ef5db 3953 if (len == 0)
3bcfb3e4 3954 fatal (_("bad format for %s"), "--rename-section");
594ef5db 3955
3f5e193b 3956 old_name = (char *) xmalloc (len + 1);
594ef5db
NC
3957 strncpy (old_name, optarg, len);
3958 old_name[len] = 0;
3959
3bcfb3e4
AM
3960 eq++;
3961 fl = strchr (eq, ',');
3962 if (fl)
594ef5db 3963 {
3bcfb3e4
AM
3964 flags = parse_flags (fl + 1);
3965 len = fl - eq;
594ef5db
NC
3966 }
3967 else
3968 {
594ef5db 3969 flags = -1;
3bcfb3e4 3970 len = strlen (eq);
594ef5db
NC
3971 }
3972
3bcfb3e4
AM
3973 if (len == 0)
3974 fatal (_("bad format for %s"), "--rename-section");
3975
3f5e193b 3976 new_name = (char *) xmalloc (len + 1);
3bcfb3e4
AM
3977 strncpy (new_name, eq, len);
3978 new_name[len] = 0;
3979
594ef5db
NC
3980 add_section_rename (old_name, new_name, flags);
3981 }
3982 break;
3983
252b5132
RH
3984 case OPTION_SET_START:
3985 set_start = parse_vma (optarg, "--set-start");
b34976b6 3986 set_start_set = TRUE;
252b5132 3987 break;
57938635 3988
0af11b59
KH
3989 case OPTION_SREC_LEN:
3990 Chunk = parse_vma (optarg, "--srec-len");
3991 break;
420496c1 3992
0af11b59 3993 case OPTION_SREC_FORCES3:
b34976b6 3994 S3Forced = TRUE;
0af11b59 3995 break;
420496c1 3996
16b2b71c 3997 case OPTION_STRIP_SYMBOLS:
047c9024 3998 add_specific_symbols (optarg, strip_specific_htab);
16b2b71c
NC
3999 break;
4000
bcf32829 4001 case OPTION_STRIP_UNNEEDED_SYMBOLS:
047c9024 4002 add_specific_symbols (optarg, strip_unneeded_htab);
bcf32829
JB
4003 break;
4004
16b2b71c 4005 case OPTION_KEEP_SYMBOLS:
047c9024 4006 add_specific_symbols (optarg, keep_specific_htab);
16b2b71c
NC
4007 break;
4008
d58c2e3a
RS
4009 case OPTION_LOCALIZE_HIDDEN:
4010 localize_hidden = TRUE;
4011 break;
4012
16b2b71c 4013 case OPTION_LOCALIZE_SYMBOLS:
047c9024 4014 add_specific_symbols (optarg, localize_specific_htab);
16b2b71c
NC
4015 break;
4016
0408dee6
DK
4017 case OPTION_LONG_SECTION_NAMES:
4018 if (!strcmp ("enable", optarg))
4019 long_section_names = ENABLE;
4020 else if (!strcmp ("disable", optarg))
4021 long_section_names = DISABLE;
4022 else if (!strcmp ("keep", optarg))
4023 long_section_names = KEEP;
4024 else
4025 fatal (_("unknown long section names option '%s'"), optarg);
4026 break;
4027
7b4a0685 4028 case OPTION_GLOBALIZE_SYMBOLS:
047c9024 4029 add_specific_symbols (optarg, globalize_specific_htab);
7b4a0685
NC
4030 break;
4031
16b2b71c 4032 case OPTION_KEEPGLOBAL_SYMBOLS:
047c9024 4033 add_specific_symbols (optarg, keepglobal_specific_htab);
16b2b71c
NC
4034 break;
4035
4036 case OPTION_WEAKEN_SYMBOLS:
047c9024 4037 add_specific_symbols (optarg, weaken_specific_htab);
16b2b71c
NC
4038 break;
4039
1ae8b3d2 4040 case OPTION_ALT_MACH_CODE:
f9d4ad2a
NC
4041 use_alt_mach_code = strtoul (optarg, NULL, 0);
4042 if (use_alt_mach_code == 0)
4043 fatal (_("unable to parse alternative machine code"));
1ae8b3d2
AO
4044 break;
4045
d7fb0dd2
NC
4046 case OPTION_PREFIX_SYMBOLS:
4047 prefix_symbols_string = optarg;
4048 break;
4049
4050 case OPTION_PREFIX_SECTIONS:
4051 prefix_sections_string = optarg;
4052 break;
4053
4054 case OPTION_PREFIX_ALLOC_SECTIONS:
4055 prefix_alloc_sections_string = optarg;
4056 break;
4057
4087920c
MR
4058 case OPTION_READONLY_TEXT:
4059 bfd_flags_to_set |= WP_TEXT;
4060 bfd_flags_to_clear &= ~WP_TEXT;
4061 break;
4062
4063 case OPTION_WRITABLE_TEXT:
4064 bfd_flags_to_clear |= WP_TEXT;
4065 bfd_flags_to_set &= ~WP_TEXT;
4066 break;
4067
4068 case OPTION_PURE:
4069 bfd_flags_to_set |= D_PAGED;
4070 bfd_flags_to_clear &= ~D_PAGED;
4071 break;
4072
4073 case OPTION_IMPURE:
4074 bfd_flags_to_clear |= D_PAGED;
4075 bfd_flags_to_set &= ~D_PAGED;
4076 break;
4077
96109726
CC
4078 case OPTION_EXTRACT_DWO:
4079 strip_symbols = STRIP_NONDWO;
4080 break;
4081
d3e52d40
RS
4082 case OPTION_EXTRACT_SYMBOL:
4083 extract_symbol = TRUE;
4084 break;
4085
9e48b4c6
NC
4086 case OPTION_REVERSE_BYTES:
4087 {
4088 int prev = reverse_bytes;
4089
4090 reverse_bytes = atoi (optarg);
4091 if ((reverse_bytes <= 0) || ((reverse_bytes % 2) != 0))
4092 fatal (_("number of bytes to reverse must be positive and even"));
4093
4094 if (prev && prev != reverse_bytes)
4095 non_fatal (_("Warning: ignoring previous --reverse-bytes value of %d"),
4096 prev);
4097 break;
4098 }
4099
92dd4511
L
4100 case OPTION_FILE_ALIGNMENT:
4101 pe_file_alignment = parse_vma (optarg, "--file-alignment");
4102 break;
955d0b3b 4103
92dd4511
L
4104 case OPTION_HEAP:
4105 {
4106 char *end;
4107 pe_heap_reserve = strtoul (optarg, &end, 0);
4108 if (end == optarg
4109 || (*end != '.' && *end != '\0'))
4110 non_fatal (_("%s: invalid reserve value for --heap"),
4111 optarg);
4112 else if (*end != '\0')
4113 {
4114 pe_heap_commit = strtoul (end + 1, &end, 0);
4115 if (*end != '\0')
4116 non_fatal (_("%s: invalid commit value for --heap"),
4117 optarg);
4118 }
4119 }
4120 break;
955d0b3b 4121
92dd4511
L
4122 case OPTION_IMAGE_BASE:
4123 pe_image_base = parse_vma (optarg, "--image-base");
4124 break;
955d0b3b 4125
92dd4511
L
4126 case OPTION_SECTION_ALIGNMENT:
4127 pe_section_alignment = parse_vma (optarg,
4128 "--section-alignment");
4129 break;
955d0b3b 4130
92dd4511
L
4131 case OPTION_SUBSYSTEM:
4132 set_pe_subsystem (optarg);
4133 break;
955d0b3b 4134
92dd4511
L
4135 case OPTION_STACK:
4136 {
4137 char *end;
4138 pe_stack_reserve = strtoul (optarg, &end, 0);
4139 if (end == optarg
4140 || (*end != '.' && *end != '\0'))
4141 non_fatal (_("%s: invalid reserve value for --stack"),
4142 optarg);
4143 else if (*end != '\0')
4144 {
4145 pe_stack_commit = strtoul (end + 1, &end, 0);
4146 if (*end != '\0')
4147 non_fatal (_("%s: invalid commit value for --stack"),
4148 optarg);
4149 }
4150 }
4151 break;
955d0b3b 4152
252b5132 4153 case 0:
2593f09a
NC
4154 /* We've been given a long option. */
4155 break;
57938635 4156
8b53311e 4157 case 'H':
252b5132
RH
4158 case 'h':
4159 copy_usage (stdout, 0);
57938635 4160
252b5132
RH
4161 default:
4162 copy_usage (stderr, 1);
4163 }
4164 }
4165
7c29036b
NC
4166 if (formats_info)
4167 {
4168 display_info ();
4169 return 0;
4170 }
c1c0eb9e 4171
252b5132
RH
4172 if (show_version)
4173 print_version ("objcopy");
4174
b7dd81f7
NC
4175 if (interleave && copy_byte == -1)
4176 fatal (_("interleave start byte must be set with --byte"));
4177
252b5132
RH
4178 if (copy_byte >= interleave)
4179 fatal (_("byte number must be less than interleave"));
4180
b7dd81f7
NC
4181 if (copy_width > interleave - copy_byte)
4182 fatal (_("interleave width must be less than or equal to interleave - byte`"));
4183
252b5132
RH
4184 if (optind == argc || optind + 2 < argc)
4185 copy_usage (stderr, 1);
4186
4187 input_filename = argv[optind];
4188 if (optind + 1 < argc)
4189 output_filename = argv[optind + 1];
4190
955d0b3b
RM
4191 default_deterministic ();
4192
252b5132
RH
4193 /* Default is to strip no symbols. */
4194 if (strip_symbols == STRIP_UNDEF && discard_locals == LOCALS_UNDEF)
4195 strip_symbols = STRIP_NONE;
4196
d3ba0551 4197 if (output_target == NULL)
252b5132
RH
4198 output_target = input_target;
4199
92dd4511
L
4200 /* Convert input EFI target to PEI target. */
4201 if (input_target != NULL
4202 && strncmp (input_target, "efi-", 4) == 0)
4203 {
4204 char *efi;
4205
4206 efi = xstrdup (output_target + 4);
4207 if (strncmp (efi, "bsdrv-", 6) == 0
4208 || strncmp (efi, "rtdrv-", 6) == 0)
4209 efi += 2;
4210 else if (strncmp (efi, "app-", 4) != 0)
4211 fatal (_("unknown input EFI target: %s"), input_target);
4212
4213 input_target = efi;
4214 convert_efi_target (efi);
4215 }
4216
4217 /* Convert output EFI target to PEI target. */
4218 if (output_target != NULL
4219 && strncmp (output_target, "efi-", 4) == 0)
4220 {
4221 char *efi;
4222
4223 efi = xstrdup (output_target + 4);
4224 if (strncmp (efi, "app-", 4) == 0)
4225 {
4226 if (pe_subsystem == -1)
4227 pe_subsystem = IMAGE_SUBSYSTEM_EFI_APPLICATION;
4228 }
4229 else if (strncmp (efi, "bsdrv-", 6) == 0)
4230 {
4231 if (pe_subsystem == -1)
4232 pe_subsystem = IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER;
4233 efi += 2;
4234 }
4235 else if (strncmp (efi, "rtdrv-", 6) == 0)
4236 {
4237 if (pe_subsystem == -1)
4238 pe_subsystem = IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER;
4239 efi += 2;
4240 }
4241 else
4242 fatal (_("unknown output EFI target: %s"), output_target);
4243
4244 if (pe_file_alignment == (bfd_vma) -1)
4245 pe_file_alignment = PE_DEF_FILE_ALIGNMENT;
4246 if (pe_section_alignment == (bfd_vma) -1)
4247 pe_section_alignment = PE_DEF_SECTION_ALIGNMENT;
4248
4249 output_target = efi;
4250 convert_efi_target (efi);
4251 }
4252
43a0748c
NC
4253 if (preserve_dates)
4254 if (stat (input_filename, & statbuf) < 0)
f24ddbdd
NC
4255 fatal (_("warning: could not locate '%s'. System error message: %s"),
4256 input_filename, strerror (errno));
43a0748c 4257
0fcdcb91 4258 /* If there is no destination file, or the source and destination files
d3ba0551 4259 are the same, then create a temp and rename the result into the input. */
8b6efd89
KT
4260 if (output_filename == NULL
4261 || filename_cmp (input_filename, output_filename) == 0)
12f498a7 4262 tmpname = make_tempname (input_filename);
252b5132 4263 else
12f498a7 4264 tmpname = output_filename;
c1c0eb9e 4265
12f498a7
NS
4266 if (tmpname == NULL)
4267 fatal (_("warning: could not create temporary file whilst copying '%s', (error: %s)"),
4268 input_filename, strerror (errno));
594ef5db 4269
8b31b6c4 4270 copy_file (input_filename, tmpname, input_target, output_target, input_arch);
12f498a7
NS
4271 if (status == 0)
4272 {
4273 if (preserve_dates)
4274 set_times (tmpname, &statbuf);
4275 if (tmpname != output_filename)
92fac5ec
L
4276 status = (smart_rename (tmpname, input_filename,
4277 preserve_dates) != 0);
252b5132 4278 }
12f498a7
NS
4279 else
4280 unlink_if_ordinary (tmpname);
252b5132
RH
4281
4282 if (change_warn)
4283 {
2e62b721
NC
4284 struct section_list *p;
4285
252b5132
RH
4286 for (p = change_sections; p != NULL; p = p->next)
4287 {
4288 if (! p->used)
4289 {
2e62b721 4290 if (p->context & (SECTION_CONTEXT_SET_VMA | SECTION_CONTEXT_ALTER_VMA))
252b5132
RH
4291 {
4292 char buff [20];
4293
4294 sprintf_vma (buff, p->vma_val);
57938635 4295
252b5132 4296 /* xgettext:c-format */
57938635
AM
4297 non_fatal (_("%s %s%c0x%s never used"),
4298 "--change-section-vma",
2e62b721
NC
4299 p->pattern,
4300 p->context & SECTION_CONTEXT_SET_VMA ? '=' : '+',
252b5132
RH
4301 buff);
4302 }
57938635 4303
2e62b721 4304 if (p->context & (SECTION_CONTEXT_SET_LMA | SECTION_CONTEXT_ALTER_LMA))
252b5132
RH
4305 {
4306 char buff [20];
4307
4308 sprintf_vma (buff, p->lma_val);
57938635 4309
252b5132 4310 /* xgettext:c-format */
57938635
AM
4311 non_fatal (_("%s %s%c0x%s never used"),
4312 "--change-section-lma",
2e62b721
NC
4313 p->pattern,
4314 p->context & SECTION_CONTEXT_SET_LMA ? '=' : '+',
252b5132
RH
4315 buff);
4316 }
4317 }
4318 }
4319 }
4320
4321 return 0;
4322}
4323
4324int
84e2f313 4325main (int argc, char *argv[])
252b5132
RH
4326{
4327#if defined (HAVE_SETLOCALE) && defined (HAVE_LC_MESSAGES)
4328 setlocale (LC_MESSAGES, "");
3882b010
L
4329#endif
4330#if defined (HAVE_SETLOCALE)
4331 setlocale (LC_CTYPE, "");
252b5132
RH
4332#endif
4333 bindtextdomain (PACKAGE, LOCALEDIR);
4334 textdomain (PACKAGE);
4335
4336 program_name = argv[0];
4337 xmalloc_set_program_name (program_name);
4338
4339 START_PROGRESS (program_name, 0);
4340
869b9d07
MM
4341 expandargv (&argc, &argv);
4342
252b5132
RH
4343 strip_symbols = STRIP_UNDEF;
4344 discard_locals = LOCALS_UNDEF;
4345
4346 bfd_init ();
4347 set_default_bfd_target ();
4348
4349 if (is_strip < 0)
4350 {
4351 int i = strlen (program_name);
5af11cab
AM
4352#ifdef HAVE_DOS_BASED_FILE_SYSTEM
4353 /* Drop the .exe suffix, if any. */
4354 if (i > 4 && FILENAME_CMP (program_name + i - 4, ".exe") == 0)
4355 {
4356 i -= 4;
4357 program_name[i] = '\0';
4358 }
4359#endif
4360 is_strip = (i >= 5 && FILENAME_CMP (program_name + i - 5, "strip") == 0);
252b5132
RH
4361 }
4362
047c9024
NC
4363 create_symbol_htabs ();
4364
252b5132
RH
4365 if (is_strip)
4366 strip_main (argc, argv);
4367 else
4368 copy_main (argc, argv);
4369
4370 END_PROGRESS (program_name);
4371
4372 return status;
4373}
This page took 0.916723 seconds and 4 git commands to generate.