daily update
[binutils.git] / binutils / objcopy.c
blob1accad41931160dd57c2724430456a42f645a873
1 /* objcopy.c -- copy object file from input to output, optionally massaging it.
2 Copyright 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000,
3 2001, 2002
4 Free Software Foundation, Inc.
6 This file is part of GNU Binutils.
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
21 02111-1307, USA. */
23 #include "bfd.h"
24 #include "progress.h"
25 #include "bucomm.h"
26 #include "getopt.h"
27 #include "libiberty.h"
28 #include "budbg.h"
29 #include "filenames.h"
30 #include <sys/stat.h>
32 /* A list of symbols to explicitly strip out, or to keep. A linked
33 list is good enough for a small number from the command line, but
34 this will slow things down a lot if many symbols are being
35 deleted. */
37 struct symlist
39 const char *name;
40 struct symlist *next;
43 /* A list to support redefine_sym. */
44 struct redefine_node
46 char *source;
47 char *target;
48 struct redefine_node *next;
51 typedef struct section_rename
53 const char * old_name;
54 const char * new_name;
55 flagword flags;
56 struct section_rename * next;
58 section_rename;
60 /* List of sections to be renamed. */
61 static section_rename * section_rename_list;
63 static void copy_usage PARAMS ((FILE *, int));
64 static void strip_usage PARAMS ((FILE *, int));
65 static flagword parse_flags PARAMS ((const char *));
66 static struct section_list *find_section_list PARAMS ((const char *, boolean));
67 static void setup_section PARAMS ((bfd *, asection *, PTR));
68 static void copy_section PARAMS ((bfd *, asection *, PTR));
69 static void get_sections PARAMS ((bfd *, asection *, PTR));
70 static int compare_section_lma PARAMS ((const PTR, const PTR));
71 static void add_specific_symbol PARAMS ((const char *, struct symlist **));
72 static void add_specific_symbols PARAMS ((const char *, struct symlist **));
73 static boolean is_specified_symbol PARAMS ((const char *, struct symlist *));
74 static boolean is_strip_section PARAMS ((bfd *, asection *));
75 static unsigned int filter_symbols
76 PARAMS ((bfd *, bfd *, asymbol **, asymbol **, long));
77 static void mark_symbols_used_in_relocations PARAMS ((bfd *, asection *, PTR));
78 static void filter_bytes PARAMS ((char *, bfd_size_type *));
79 static boolean write_debugging_info PARAMS ((bfd *, PTR, long *, asymbol ***));
80 static void copy_object PARAMS ((bfd *, bfd *));
81 static void copy_archive PARAMS ((bfd *, bfd *, const char *));
82 static void copy_file
83 PARAMS ((const char *, const char *, const char *, const char *));
84 static int strip_main PARAMS ((int, char **));
85 static int copy_main PARAMS ((int, char **));
86 static const char *lookup_sym_redefinition PARAMS((const char *));
87 static void redefine_list_append PARAMS ((const char *, const char *));
88 static const char * find_section_rename PARAMS ((bfd *, sec_ptr, flagword *));
89 static void add_section_rename PARAMS ((const char *, const char *, flagword));
91 #define RETURN_NONFATAL(s) {bfd_nonfatal (s); status = 1; return;}
93 static asymbol **isympp = NULL; /* Input symbols */
94 static asymbol **osympp = NULL; /* Output symbols that survive stripping */
96 /* If `copy_byte' >= 0, copy only that byte of every `interleave' bytes. */
97 static int copy_byte = -1;
98 static int interleave = 4;
100 static boolean verbose; /* Print file and target names. */
101 static boolean preserve_dates; /* Preserve input file timestamp. */
102 static int status = 0; /* Exit status. */
104 enum strip_action
106 STRIP_UNDEF,
107 STRIP_NONE, /* don't strip */
108 STRIP_DEBUG, /* strip all debugger symbols */
109 STRIP_UNNEEDED, /* strip unnecessary symbols */
110 STRIP_ALL /* strip all symbols */
113 /* Which symbols to remove. */
114 static enum strip_action strip_symbols;
116 enum locals_action
118 LOCALS_UNDEF,
119 LOCALS_START_L, /* discard locals starting with L */
120 LOCALS_ALL /* discard all locals */
123 /* Which local symbols to remove. Overrides STRIP_ALL. */
124 static enum locals_action discard_locals;
126 /* What kind of change to perform. */
127 enum change_action
129 CHANGE_IGNORE,
130 CHANGE_MODIFY,
131 CHANGE_SET
134 /* Structure used to hold lists of sections and actions to take. */
135 struct section_list
137 struct section_list * next; /* Next section to change. */
138 const char * name; /* Section name. */
139 boolean used; /* Whether this entry was used. */
140 boolean remove; /* Whether to remove this section. */
141 boolean copy; /* Whether to copy this section. */
142 enum change_action change_vma;/* Whether to change or set VMA. */
143 bfd_vma vma_val; /* Amount to change by or set to. */
144 enum change_action change_lma;/* Whether to change or set LMA. */
145 bfd_vma lma_val; /* Amount to change by or set to. */
146 boolean set_flags; /* Whether to set the section flags. */
147 flagword flags; /* What to set the section flags to. */
150 static struct section_list *change_sections;
152 /* True if some sections are to be removed. */
153 static boolean sections_removed;
155 /* True if only some sections are to be copied. */
156 static boolean sections_copied;
158 /* Changes to the start address. */
159 static bfd_vma change_start = 0;
160 static boolean set_start_set = false;
161 static bfd_vma set_start;
163 /* Changes to section addresses. */
164 static bfd_vma change_section_address = 0;
166 /* Filling gaps between sections. */
167 static boolean gap_fill_set = false;
168 static bfd_byte gap_fill = 0;
170 /* Pad to a given address. */
171 static boolean pad_to_set = false;
172 static bfd_vma pad_to;
174 /* Use alternate machine code? */
175 static int use_alt_mach_code = 0;
177 /* List of sections to add. */
178 struct section_add
180 /* Next section to add. */
181 struct section_add *next;
182 /* Name of section to add. */
183 const char *name;
184 /* Name of file holding section contents. */
185 const char *filename;
186 /* Size of file. */
187 size_t size;
188 /* Contents of file. */
189 bfd_byte *contents;
190 /* BFD section, after it has been added. */
191 asection *section;
194 /* List of sections to add to the output BFD. */
195 static struct section_add *add_sections;
197 /* Whether to convert debugging information. */
198 static boolean convert_debugging = false;
200 /* Whether to change the leading character in symbol names. */
201 static boolean change_leading_char = false;
203 /* Whether to remove the leading character from global symbol names. */
204 static boolean remove_leading_char = false;
206 /* List of symbols to strip, keep, localize, keep-global, weaken,
207 or redefine. */
208 static struct symlist *strip_specific_list = NULL;
209 static struct symlist *keep_specific_list = NULL;
210 static struct symlist *localize_specific_list = NULL;
211 static struct symlist *keepglobal_specific_list = NULL;
212 static struct symlist *weaken_specific_list = NULL;
213 static struct redefine_node *redefine_sym_list = NULL;
215 /* If this is true, we weaken global symbols (set BSF_WEAK). */
216 static boolean weaken = false;
218 /* 150 isn't special; it's just an arbitrary non-ASCII char value. */
220 #define OPTION_ADD_SECTION 150
221 #define OPTION_CHANGE_ADDRESSES (OPTION_ADD_SECTION + 1)
222 #define OPTION_CHANGE_LEADING_CHAR (OPTION_CHANGE_ADDRESSES + 1)
223 #define OPTION_CHANGE_START (OPTION_CHANGE_LEADING_CHAR + 1)
224 #define OPTION_CHANGE_SECTION_ADDRESS (OPTION_CHANGE_START + 1)
225 #define OPTION_CHANGE_SECTION_LMA (OPTION_CHANGE_SECTION_ADDRESS + 1)
226 #define OPTION_CHANGE_SECTION_VMA (OPTION_CHANGE_SECTION_LMA + 1)
227 #define OPTION_CHANGE_WARNINGS (OPTION_CHANGE_SECTION_VMA + 1)
228 #define OPTION_DEBUGGING (OPTION_CHANGE_WARNINGS + 1)
229 #define OPTION_GAP_FILL (OPTION_DEBUGGING + 1)
230 #define OPTION_NO_CHANGE_WARNINGS (OPTION_GAP_FILL + 1)
231 #define OPTION_PAD_TO (OPTION_NO_CHANGE_WARNINGS + 1)
232 #define OPTION_REMOVE_LEADING_CHAR (OPTION_PAD_TO + 1)
233 #define OPTION_SET_SECTION_FLAGS (OPTION_REMOVE_LEADING_CHAR + 1)
234 #define OPTION_SET_START (OPTION_SET_SECTION_FLAGS + 1)
235 #define OPTION_STRIP_UNNEEDED (OPTION_SET_START + 1)
236 #define OPTION_WEAKEN (OPTION_STRIP_UNNEEDED + 1)
237 #define OPTION_REDEFINE_SYM (OPTION_WEAKEN + 1)
238 #define OPTION_SREC_LEN (OPTION_REDEFINE_SYM + 1)
239 #define OPTION_SREC_FORCES3 (OPTION_SREC_LEN + 1)
240 #define OPTION_STRIP_SYMBOLS (OPTION_SREC_FORCES3 + 1)
241 #define OPTION_KEEP_SYMBOLS (OPTION_STRIP_SYMBOLS + 1)
242 #define OPTION_LOCALIZE_SYMBOLS (OPTION_KEEP_SYMBOLS + 1)
243 #define OPTION_KEEPGLOBAL_SYMBOLS (OPTION_LOCALIZE_SYMBOLS + 1)
244 #define OPTION_WEAKEN_SYMBOLS (OPTION_KEEPGLOBAL_SYMBOLS + 1)
245 #define OPTION_RENAME_SECTION (OPTION_WEAKEN_SYMBOLS + 1)
246 #define OPTION_ALT_MACH_CODE (OPTION_RENAME_SECTION + 1)
248 /* Options to handle if running as "strip". */
250 static struct option strip_options[] =
252 {"discard-all", no_argument, 0, 'x'},
253 {"discard-locals", no_argument, 0, 'X'},
254 {"format", required_argument, 0, 'F'}, /* Obsolete */
255 {"help", no_argument, 0, 'h'},
256 {"input-format", required_argument, 0, 'I'}, /* Obsolete */
257 {"input-target", required_argument, 0, 'I'},
258 {"keep-symbol", required_argument, 0, 'K'},
259 {"output-format", required_argument, 0, 'O'}, /* Obsolete */
260 {"output-target", required_argument, 0, 'O'},
261 {"output-file", required_argument, 0, 'o'},
262 {"preserve-dates", no_argument, 0, 'p'},
263 {"remove-section", required_argument, 0, 'R'},
264 {"strip-all", no_argument, 0, 's'},
265 {"strip-debug", no_argument, 0, 'S'},
266 {"strip-unneeded", no_argument, 0, OPTION_STRIP_UNNEEDED},
267 {"strip-symbol", required_argument, 0, 'N'},
268 {"target", required_argument, 0, 'F'},
269 {"verbose", no_argument, 0, 'v'},
270 {"version", no_argument, 0, 'V'},
271 {0, no_argument, 0, 0}
274 /* Options to handle if running as "objcopy". */
276 static struct option copy_options[] =
278 {"add-section", required_argument, 0, OPTION_ADD_SECTION},
279 {"adjust-start", required_argument, 0, OPTION_CHANGE_START},
280 {"adjust-vma", required_argument, 0, OPTION_CHANGE_ADDRESSES},
281 {"adjust-section-vma", required_argument, 0, OPTION_CHANGE_SECTION_ADDRESS},
282 {"adjust-warnings", no_argument, 0, OPTION_CHANGE_WARNINGS},
283 {"binary-architecture", required_argument, 0, 'B'},
284 {"byte", required_argument, 0, 'b'},
285 {"change-addresses", required_argument, 0, OPTION_CHANGE_ADDRESSES},
286 {"change-leading-char", no_argument, 0, OPTION_CHANGE_LEADING_CHAR},
287 {"change-section-address", required_argument, 0, OPTION_CHANGE_SECTION_ADDRESS},
288 {"change-section-lma", required_argument, 0, OPTION_CHANGE_SECTION_LMA},
289 {"change-section-vma", required_argument, 0, OPTION_CHANGE_SECTION_VMA},
290 {"change-start", required_argument, 0, OPTION_CHANGE_START},
291 {"change-warnings", no_argument, 0, OPTION_CHANGE_WARNINGS},
292 {"debugging", no_argument, 0, OPTION_DEBUGGING},
293 {"discard-all", no_argument, 0, 'x'},
294 {"discard-locals", no_argument, 0, 'X'},
295 {"only-section", required_argument, 0, 'j'},
296 {"format", required_argument, 0, 'F'}, /* Obsolete */
297 {"gap-fill", required_argument, 0, OPTION_GAP_FILL},
298 {"help", no_argument, 0, 'h'},
299 {"input-format", required_argument, 0, 'I'}, /* Obsolete */
300 {"input-target", required_argument, 0, 'I'},
301 {"interleave", required_argument, 0, 'i'},
302 {"keep-symbol", required_argument, 0, 'K'},
303 {"no-adjust-warnings", no_argument, 0, OPTION_NO_CHANGE_WARNINGS},
304 {"no-change-warnings", no_argument, 0, OPTION_NO_CHANGE_WARNINGS},
305 {"output-format", required_argument, 0, 'O'}, /* Obsolete */
306 {"output-target", required_argument, 0, 'O'},
307 {"pad-to", required_argument, 0, OPTION_PAD_TO},
308 {"preserve-dates", no_argument, 0, 'p'},
309 {"localize-symbol", required_argument, 0, 'L'},
310 {"keep-global-symbol", required_argument, 0, 'G'},
311 {"remove-leading-char", no_argument, 0, OPTION_REMOVE_LEADING_CHAR},
312 {"remove-section", required_argument, 0, 'R'},
313 {"rename-section", required_argument, 0, OPTION_RENAME_SECTION},
314 {"set-section-flags", required_argument, 0, OPTION_SET_SECTION_FLAGS},
315 {"set-start", required_argument, 0, OPTION_SET_START},
316 {"strip-all", no_argument, 0, 'S'},
317 {"strip-debug", no_argument, 0, 'g'},
318 {"strip-unneeded", no_argument, 0, OPTION_STRIP_UNNEEDED},
319 {"strip-symbol", required_argument, 0, 'N'},
320 {"target", required_argument, 0, 'F'},
321 {"verbose", no_argument, 0, 'v'},
322 {"version", no_argument, 0, 'V'},
323 {"weaken", no_argument, 0, OPTION_WEAKEN},
324 {"weaken-symbol", required_argument, 0, 'W'},
325 {"redefine-sym", required_argument, 0, OPTION_REDEFINE_SYM},
326 {"srec-len", required_argument, 0, OPTION_SREC_LEN},
327 {"srec-forceS3", no_argument, 0, OPTION_SREC_FORCES3},
328 {"keep-symbols", required_argument, 0, OPTION_KEEP_SYMBOLS},
329 {"strip-symbols", required_argument, 0, OPTION_STRIP_SYMBOLS},
330 {"keep-global-symbols", required_argument, 0, OPTION_KEEPGLOBAL_SYMBOLS},
331 {"localize-symbols", required_argument, 0, OPTION_LOCALIZE_SYMBOLS},
332 {"weaken-symbols", required_argument, 0, OPTION_WEAKEN_SYMBOLS},
333 {"alt-machine-code", required_argument, 0, OPTION_ALT_MACH_CODE},
334 {0, no_argument, 0, 0}
337 /* IMPORTS */
338 extern char *program_name;
340 /* This flag distinguishes between strip and objcopy:
341 1 means this is 'strip'; 0 means this is 'objcopy'.
342 -1 means if we should use argv[0] to decide. */
343 extern int is_strip;
345 /* The maximum length of an S record. This variable is declared in srec.c
346 and can be modified by the --srec-len parameter. */
347 extern unsigned int Chunk;
349 /* Restrict the generation of Srecords to type S3 only.
350 This variable is declare in bfd/srec.c and can be toggled
351 on by the --srec-forceS3 command line switch. */
352 extern boolean S3Forced;
354 /* Defined in bfd/binary.c. Used to set architecture of input binary files. */
355 extern enum bfd_architecture bfd_external_binary_architecture;
358 static void
359 copy_usage (stream, exit_status)
360 FILE *stream;
361 int exit_status;
363 fprintf (stream, _("Usage: %s [option(s)] in-file [out-file]\n"), program_name);
364 fprintf (stream, _(" Copies a binary file, possibly transforming it in the process\n"));
365 fprintf (stream, _(" The options are:\n"));
366 fprintf (stream, _("\
367 -I --input-target <bfdname> Assume input file is in format <bfdname>\n\
368 -O --output-target <bfdname> Create an output file in format <bfdname>\n\
369 -B --binary-architecture <arch> Set arch of output file, when input is binary\n\
370 -F --target <bfdname> Set both input and output format to <bfdname>\n\
371 --debugging Convert debugging information, if possible\n\
372 -p --preserve-dates Copy modified/access timestamps to the output\n\
373 -j --only-section <name> Only copy section <name> into the output\n\
374 -R --remove-section <name> Remove section <name> from the output\n\
375 -S --strip-all Remove all symbol and relocation information\n\
376 -g --strip-debug Remove all debugging symbols\n\
377 --strip-unneeded Remove all symbols not needed by relocations\n\
378 -N --strip-symbol <name> Do not copy symbol <name>\n\
379 -K --keep-symbol <name> Only copy symbol <name>\n\
380 -L --localize-symbol <name> Force symbol <name> to be marked as a local\n\
381 -G --keep-global-symbol <name> Localize all symbols except <name>\n\
382 -W --weaken-symbol <name> Force symbol <name> to be marked as a weak\n\
383 --weaken Force all global symbols to be marked as weak\n\
384 -x --discard-all Remove all non-global symbols\n\
385 -X --discard-locals Remove any compiler-generated symbols\n\
386 -i --interleave <number> Only copy one out of every <number> bytes\n\
387 -b --byte <num> Select byte <num> in every interleaved block\n\
388 --gap-fill <val> Fill gaps between sections with <val>\n\
389 --pad-to <addr> Pad the last section up to address <addr>\n\
390 --set-start <addr> Set the start address to <addr>\n\
391 {--change-start|--adjust-start} <incr>\n\
392 Add <incr> to the start address\n\
393 {--change-addresses|--adjust-vma} <incr>\n\
394 Add <incr> to LMA, VMA and start addresses\n\
395 {--change-section-address|--adjust-section-vma} <name>{=|+|-}<val>\n\
396 Change LMA and VMA of section <name> by <val>\n\
397 --change-section-lma <name>{=|+|-}<val>\n\
398 Change the LMA of section <name> by <val>\n\
399 --change-section-vma <name>{=|+|-}<val>\n\
400 Change the VMA of section <name> by <val>\n\
401 {--[no-]change-warnings|--[no-]adjust-warnings}\n\
402 Warn if a named section does not exist\n\
403 --set-section-flags <name>=<flags>\n\
404 Set section <name>'s properties to <flags>\n\
405 --add-section <name>=<file> Add section <name> found in <file> to output\n\
406 --rename-section <old>=<new>[,<flags>] Rename section <old> to <new>\n\
407 --change-leading-char Force output format's leading character style\n\
408 --remove-leading-char Remove leading character from global symbols\n\
409 --redefine-sym <old>=<new> Redefine symbol name <old> to <new>\n\
410 --srec-len <number> Restrict the length of generated Srecords\n\
411 --srec-forceS3 Restrict the type of generated Srecords to S3\n\
412 --strip-symbols <file> -N for all symbols listed in <file>\n\
413 --keep-symbols <file> -K for all symbols listed in <file>\n\
414 --localize-symbols <file> -L for all symbols listed in <file>\n\
415 --keep-global-symbols <file> -G for all symbols listed in <file>\n\
416 --weaken-symbols <file> -W for all symbols listed in <file>\n\
417 --alt-machine-code <index> Use alternate machine code for output\n\
418 -v --verbose List all object files modified\n\
419 -V --version Display this program's version number\n\
420 -h --help Display this output\n\
421 "));
422 list_supported_targets (program_name, stream);
423 if (exit_status == 0)
424 fprintf (stream, _("Report bugs to %s\n"), REPORT_BUGS_TO);
425 exit (exit_status);
428 static void
429 strip_usage (stream, exit_status)
430 FILE *stream;
431 int exit_status;
433 fprintf (stream, _("Usage: %s <option(s)> in-file(s)\n"), program_name);
434 fprintf (stream, _(" Removes symbols and sections from files\n"));
435 fprintf (stream, _(" The options are:\n"));
436 fprintf (stream, _("\
437 -I --input-target=<bfdname> Assume input file is in format <bfdname>\n\
438 -O --output-target=<bfdname> Create an output file in format <bfdname>\n\
439 -F --target=<bfdname> Set both input and output format to <bfdname>\n\
440 -p --preserve-dates Copy modified/access timestamps to the output\n\
441 -R --remove-section=<name> Remove section <name> from the output\n\
442 -s --strip-all Remove all symbol and relocation information\n\
443 -g -S -d --strip-debug Remove all debugging symbols\n\
444 --strip-unneeded Remove all symbols not needed by relocations\n\
445 -N --strip-symbol=<name> Do not copy symbol <name>\n\
446 -K --keep-symbol=<name> Only copy symbol <name>\n\
447 -x --discard-all Remove all non-global symbols\n\
448 -X --discard-locals Remove any compiler-generated symbols\n\
449 -v --verbose List all object files modified\n\
450 -V --version Display this program's version number\n\
451 -h --help Display this output\n\
452 -o <file> Place stripped output into <file>\n\
453 "));
455 list_supported_targets (program_name, stream);
456 if (exit_status == 0)
457 fprintf (stream, _("Report bugs to %s\n"), REPORT_BUGS_TO);
458 exit (exit_status);
461 /* Parse section flags into a flagword, with a fatal error if the
462 string can't be parsed. */
464 static flagword
465 parse_flags (s)
466 const char *s;
468 flagword ret;
469 const char *snext;
470 int len;
472 ret = SEC_NO_FLAGS;
476 snext = strchr (s, ',');
477 if (snext == NULL)
478 len = strlen (s);
479 else
481 len = snext - s;
482 ++snext;
485 if (0) ;
486 #define PARSE_FLAG(fname,fval) \
487 else if (strncasecmp (fname, s, len) == 0) ret |= fval
488 PARSE_FLAG ("alloc", SEC_ALLOC);
489 PARSE_FLAG ("load", SEC_LOAD);
490 PARSE_FLAG ("noload", SEC_NEVER_LOAD);
491 PARSE_FLAG ("readonly", SEC_READONLY);
492 PARSE_FLAG ("debug", SEC_DEBUGGING);
493 PARSE_FLAG ("code", SEC_CODE);
494 PARSE_FLAG ("data", SEC_DATA);
495 PARSE_FLAG ("rom", SEC_ROM);
496 PARSE_FLAG ("share", SEC_SHARED);
497 PARSE_FLAG ("contents", SEC_HAS_CONTENTS);
498 #undef PARSE_FLAG
499 else
501 char *copy;
503 copy = xmalloc (len + 1);
504 strncpy (copy, s, len);
505 copy[len] = '\0';
506 non_fatal (_("unrecognized section flag `%s'"), copy);
507 fatal (_("supported flags: %s"),
508 "alloc, load, noload, readonly, debug, code, data, rom, share, contents");
511 s = snext;
513 while (s != NULL);
515 return ret;
518 /* Find and optionally add an entry in the change_sections list. */
520 static struct section_list *
521 find_section_list (name, add)
522 const char *name;
523 boolean add;
525 register struct section_list *p;
527 for (p = change_sections; p != NULL; p = p->next)
528 if (strcmp (p->name, name) == 0)
529 return p;
531 if (! add)
532 return NULL;
534 p = (struct section_list *) xmalloc (sizeof (struct section_list));
535 p->name = name;
536 p->used = false;
537 p->remove = false;
538 p->copy = false;
539 p->change_vma = CHANGE_IGNORE;
540 p->change_lma = CHANGE_IGNORE;
541 p->vma_val = 0;
542 p->lma_val = 0;
543 p->set_flags = false;
544 p->flags = 0;
546 p->next = change_sections;
547 change_sections = p;
549 return p;
552 /* Add a symbol to strip_specific_list. */
554 static void
555 add_specific_symbol (name, list)
556 const char *name;
557 struct symlist **list;
559 struct symlist *tmp_list;
561 tmp_list = (struct symlist *) xmalloc (sizeof (struct symlist));
562 tmp_list->name = name;
563 tmp_list->next = *list;
564 *list = tmp_list;
567 /* Add symbols listed in `filename' to strip_specific_list. */
569 #define IS_WHITESPACE(c) ((c) == ' ' || (c) == '\t')
570 #define IS_LINE_TERMINATOR(c) ((c) == '\n' || (c) == '\r' || (c) == '\0')
572 static void
573 add_specific_symbols (filename, list)
574 const char *filename;
575 struct symlist **list;
577 struct stat st;
578 FILE * f;
579 char * line;
580 char * buffer;
581 unsigned int line_count;
583 if (stat (filename, & st) < 0)
584 fatal (_("cannot stat: %s: %s"), filename, strerror (errno));
585 if (st.st_size == 0)
586 return;
588 buffer = (char *) xmalloc (st.st_size + 2);
589 f = fopen (filename, FOPEN_RT);
590 if (f == NULL)
591 fatal (_("cannot open: %s: %s"), filename, strerror (errno));
593 if (fread (buffer, 1, st.st_size, f) == 0 || ferror (f))
594 fatal (_("%s: fread failed"), filename);
596 fclose (f);
597 buffer [st.st_size] = '\n';
598 buffer [st.st_size + 1] = '\0';
600 line_count = 1;
602 for (line = buffer; * line != '\0'; line ++)
604 char * eol;
605 char * name;
606 char * name_end;
607 int finished = false;
609 for (eol = line;; eol ++)
611 switch (* eol)
613 case '\n':
614 * eol = '\0';
615 /* Cope with \n\r. */
616 if (eol[1] == '\r')
617 ++ eol;
618 finished = true;
619 break;
621 case '\r':
622 * eol = '\0';
623 /* Cope with \r\n. */
624 if (eol[1] == '\n')
625 ++ eol;
626 finished = true;
627 break;
629 case 0:
630 finished = true;
631 break;
633 case '#':
634 /* Line comment, Terminate the line here, in case a
635 name is present and then allow the rest of the
636 loop to find the real end of the line. */
637 * eol = '\0';
638 break;
640 default:
641 break;
644 if (finished)
645 break;
648 /* A name may now exist somewhere between 'line' and 'eol'.
649 Strip off leading whitespace and trailing whitespace,
650 then add it to the list. */
651 for (name = line; IS_WHITESPACE (* name); name ++)
653 for (name_end = name;
654 (! IS_WHITESPACE (* name_end))
655 && (! IS_LINE_TERMINATOR (* name_end));
656 name_end ++)
659 if (! IS_LINE_TERMINATOR (* name_end))
661 char * extra;
663 for (extra = name_end + 1; IS_WHITESPACE (* extra); extra ++)
666 if (! IS_LINE_TERMINATOR (* extra))
667 non_fatal (_("Ignoring rubbish found on line %d of %s"),
668 line_count, filename);
671 * name_end = '\0';
673 if (name_end > name)
674 add_specific_symbol (name, list);
676 /* Advance line pointer to end of line. The 'eol ++' in the for
677 loop above will then advance us to the start of the next line. */
678 line = eol;
679 line_count ++;
683 /* See whether a symbol should be stripped or kept based on
684 strip_specific_list and keep_symbols. */
686 static boolean
687 is_specified_symbol (name, list)
688 const char *name;
689 struct symlist *list;
691 struct symlist *tmp_list;
693 for (tmp_list = list; tmp_list; tmp_list = tmp_list->next)
694 if (strcmp (name, tmp_list->name) == 0)
695 return true;
697 return false;
700 /* See if a section is being removed. */
702 static boolean
703 is_strip_section (abfd, sec)
704 bfd *abfd ATTRIBUTE_UNUSED;
705 asection *sec;
707 struct section_list *p;
709 if ((bfd_get_section_flags (abfd, sec) & SEC_DEBUGGING) != 0
710 && (strip_symbols == STRIP_DEBUG
711 || strip_symbols == STRIP_UNNEEDED
712 || strip_symbols == STRIP_ALL
713 || discard_locals == LOCALS_ALL
714 || convert_debugging))
715 return true;
717 if (! sections_removed && ! sections_copied)
718 return false;
720 p = find_section_list (bfd_get_section_name (abfd, sec), false);
721 if (sections_removed && p != NULL && p->remove)
722 return true;
723 if (sections_copied && (p == NULL || ! p->copy))
724 return true;
725 return false;
728 /* Choose which symbol entries to copy; put the result in OSYMS.
729 We don't copy in place, because that confuses the relocs.
730 Return the number of symbols to print. */
732 static unsigned int
733 filter_symbols (abfd, obfd, osyms, isyms, symcount)
734 bfd *abfd;
735 bfd *obfd;
736 asymbol **osyms, **isyms;
737 long symcount;
739 register asymbol **from = isyms, **to = osyms;
740 long src_count = 0, dst_count = 0;
741 int relocatable = (abfd->flags & (HAS_RELOC | EXEC_P | DYNAMIC))
742 == HAS_RELOC;
744 for (; src_count < symcount; src_count++)
746 asymbol *sym = from[src_count];
747 flagword flags = sym->flags;
748 const char *name = bfd_asymbol_name (sym);
749 int keep;
750 boolean undefined;
752 if (redefine_sym_list)
754 const char *old_name, *new_name;
756 old_name = bfd_asymbol_name (sym);
757 new_name = lookup_sym_redefinition (old_name);
758 name = bfd_asymbol_name (sym) = new_name;
761 if (change_leading_char
762 && (bfd_get_symbol_leading_char (abfd)
763 != bfd_get_symbol_leading_char (obfd))
764 && (bfd_get_symbol_leading_char (abfd) == '\0'
765 || (name[0] == bfd_get_symbol_leading_char (abfd))))
767 if (bfd_get_symbol_leading_char (obfd) == '\0')
768 name = bfd_asymbol_name (sym) = name + 1;
769 else
771 char *n;
773 n = xmalloc (strlen (name) + 2);
774 n[0] = bfd_get_symbol_leading_char (obfd);
775 if (bfd_get_symbol_leading_char (abfd) == '\0')
776 strcpy (n + 1, name);
777 else
778 strcpy (n + 1, name + 1);
779 name = bfd_asymbol_name (sym) = n;
783 undefined = bfd_is_und_section (bfd_get_section (sym));
785 if (remove_leading_char
786 && ((flags & BSF_GLOBAL) != 0
787 || (flags & BSF_WEAK) != 0
788 || undefined
789 || bfd_is_com_section (bfd_get_section (sym)))
790 && name[0] == bfd_get_symbol_leading_char (abfd))
791 name = bfd_asymbol_name (sym) = name + 1;
793 if (strip_symbols == STRIP_ALL)
794 keep = 0;
795 else if ((flags & BSF_KEEP) != 0 /* Used in relocation. */
796 || ((flags & BSF_SECTION_SYM) != 0
797 && ((*bfd_get_section (sym)->symbol_ptr_ptr)->flags
798 & BSF_KEEP) != 0))
799 keep = 1;
800 else if (relocatable /* Relocatable file. */
801 && (flags & (BSF_GLOBAL | BSF_WEAK)) != 0)
802 keep = 1;
803 else if (bfd_decode_symclass (sym) == 'I')
804 /* Global symbols in $idata sections need to be retained
805 even if relocatable is false. External users of the
806 library containing the $idata section may reference these
807 symbols. */
808 keep = 1;
809 else if ((flags & BSF_GLOBAL) != 0 /* Global symbol. */
810 || (flags & BSF_WEAK) != 0
811 || undefined
812 || bfd_is_com_section (bfd_get_section (sym)))
813 keep = strip_symbols != STRIP_UNNEEDED;
814 else if ((flags & BSF_DEBUGGING) != 0) /* Debugging symbol. */
815 keep = (strip_symbols != STRIP_DEBUG
816 && strip_symbols != STRIP_UNNEEDED
817 && ! convert_debugging);
818 else if (bfd_get_section (sym)->comdat)
819 /* COMDAT sections store special information in local
820 symbols, so we cannot risk stripping any of them. */
821 keep = 1;
822 else /* Local symbol. */
823 keep = (strip_symbols != STRIP_UNNEEDED
824 && (discard_locals != LOCALS_ALL
825 && (discard_locals != LOCALS_START_L
826 || ! bfd_is_local_label (abfd, sym))));
828 if (keep && is_specified_symbol (name, strip_specific_list))
829 keep = 0;
830 if (!keep && is_specified_symbol (name, keep_specific_list))
831 keep = 1;
832 if (keep && is_strip_section (abfd, bfd_get_section (sym)))
833 keep = 0;
835 if (keep && (flags & BSF_GLOBAL) != 0
836 && (weaken || is_specified_symbol (name, weaken_specific_list)))
838 sym->flags &=~ BSF_GLOBAL;
839 sym->flags |= BSF_WEAK;
841 if (keep && !undefined && (flags & (BSF_GLOBAL | BSF_WEAK))
842 && (is_specified_symbol (name, localize_specific_list)
843 || (keepglobal_specific_list != NULL
844 && ! is_specified_symbol (name, keepglobal_specific_list))))
846 sym->flags &= ~(BSF_GLOBAL | BSF_WEAK);
847 sym->flags |= BSF_LOCAL;
850 if (keep)
851 to[dst_count++] = sym;
854 to[dst_count] = NULL;
856 return dst_count;
859 /* Find the redefined name of symbol SOURCE. */
861 static const char *
862 lookup_sym_redefinition (source)
863 const char *source;
865 struct redefine_node *list;
867 for (list = redefine_sym_list; list != NULL; list = list->next)
868 if (strcmp (source, list->source) == 0)
869 return list->target;
871 return source;
874 /* Add a node to a symbol redefine list. */
876 static void
877 redefine_list_append (source, target)
878 const char *source;
879 const char *target;
881 struct redefine_node **p;
882 struct redefine_node *list;
883 struct redefine_node *new_node;
885 for (p = &redefine_sym_list; (list = *p) != NULL; p = &list->next)
887 if (strcmp (source, list->source) == 0)
888 fatal (_("%s: Multiple redefinition of symbol \"%s\""),
889 "--redefine-sym",
890 source);
892 if (strcmp (target, list->target) == 0)
893 fatal (_("%s: Symbol \"%s\" is target of more than one redefinition"),
894 "--redefine-sym",
895 target);
898 new_node = (struct redefine_node *) xmalloc (sizeof (struct redefine_node));
900 new_node->source = strdup (source);
901 new_node->target = strdup (target);
902 new_node->next = NULL;
904 *p = new_node;
907 /* Keep only every `copy_byte'th byte in MEMHUNK, which is *SIZE bytes long.
908 Adjust *SIZE. */
910 static void
911 filter_bytes (memhunk, size)
912 char *memhunk;
913 bfd_size_type *size;
915 char *from = memhunk + copy_byte, *to = memhunk, *end = memhunk + *size;
917 for (; from < end; from += interleave)
918 *to++ = *from;
920 if (*size % interleave > (bfd_size_type) copy_byte)
921 *size = (*size / interleave) + 1;
922 else
923 *size /= interleave;
926 /* Copy object file IBFD onto OBFD. */
928 static void
929 copy_object (ibfd, obfd)
930 bfd *ibfd;
931 bfd *obfd;
933 bfd_vma start;
934 long symcount;
935 asection **osections = NULL;
936 bfd_size_type *gaps = NULL;
937 bfd_size_type max_gap = 0;
938 long symsize;
939 PTR dhandle;
941 if (ibfd->xvec->byteorder != obfd->xvec->byteorder
942 && ibfd->xvec->byteorder != BFD_ENDIAN_UNKNOWN
943 && obfd->xvec->byteorder != BFD_ENDIAN_UNKNOWN)
945 fatal (_("Unable to change endianness of input file(s)"));
946 return;
949 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
950 RETURN_NONFATAL (bfd_get_filename (obfd));
952 if (verbose)
953 printf (_("copy from %s(%s) to %s(%s)\n"),
954 bfd_get_filename (ibfd), bfd_get_target (ibfd),
955 bfd_get_filename (obfd), bfd_get_target (obfd));
957 if (set_start_set)
958 start = set_start;
959 else
960 start = bfd_get_start_address (ibfd);
961 start += change_start;
963 /* Neither the start address nor the flags
964 need to be set for a core file. */
965 if (bfd_get_format (obfd) != bfd_core)
967 if (!bfd_set_start_address (obfd, start)
968 || !bfd_set_file_flags (obfd,
969 (bfd_get_file_flags (ibfd)
970 & bfd_applicable_file_flags (obfd))))
971 RETURN_NONFATAL (bfd_get_filename (ibfd));
974 /* Copy architecture of input file to output file. */
975 if (!bfd_set_arch_mach (obfd, bfd_get_arch (ibfd),
976 bfd_get_mach (ibfd))
977 && (ibfd->target_defaulted
978 || bfd_get_arch (ibfd) != bfd_get_arch (obfd)))
979 non_fatal (_("Warning: Output file cannot represent architecture %s"),
980 bfd_printable_arch_mach (bfd_get_arch (ibfd),
981 bfd_get_mach (ibfd)));
983 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
984 RETURN_NONFATAL (bfd_get_filename (ibfd));
986 if (isympp)
987 free (isympp);
989 if (osympp != isympp)
990 free (osympp);
992 /* BFD mandates that all output sections be created and sizes set before
993 any output is done. Thus, we traverse all sections multiple times. */
994 bfd_map_over_sections (ibfd, setup_section, (void *) obfd);
996 if (add_sections != NULL)
998 struct section_add *padd;
999 struct section_list *pset;
1001 for (padd = add_sections; padd != NULL; padd = padd->next)
1003 padd->section = bfd_make_section (obfd, padd->name);
1004 if (padd->section == NULL)
1006 non_fatal (_("can't create section `%s': %s"),
1007 padd->name, bfd_errmsg (bfd_get_error ()));
1008 status = 1;
1009 return;
1011 else
1013 flagword flags;
1015 if (! bfd_set_section_size (obfd, padd->section, padd->size))
1016 RETURN_NONFATAL (bfd_get_filename (obfd));
1018 pset = find_section_list (padd->name, false);
1019 if (pset != NULL)
1020 pset->used = true;
1022 if (pset != NULL && pset->set_flags)
1023 flags = pset->flags | SEC_HAS_CONTENTS;
1024 else
1025 flags = SEC_HAS_CONTENTS | SEC_READONLY | SEC_DATA;
1027 if (! bfd_set_section_flags (obfd, padd->section, flags))
1028 RETURN_NONFATAL (bfd_get_filename (obfd));
1030 if (pset != NULL)
1032 if (pset->change_vma != CHANGE_IGNORE)
1033 if (! bfd_set_section_vma (obfd, padd->section, pset->vma_val))
1034 RETURN_NONFATAL (bfd_get_filename (obfd));
1036 if (pset->change_lma != CHANGE_IGNORE)
1038 padd->section->lma = pset->lma_val;
1040 if (! bfd_set_section_alignment
1041 (obfd, padd->section,
1042 bfd_section_alignment (obfd, padd->section)))
1043 RETURN_NONFATAL (bfd_get_filename (obfd));
1050 if (gap_fill_set || pad_to_set)
1052 asection **set;
1053 unsigned int c, i;
1055 /* We must fill in gaps between the sections and/or we must pad
1056 the last section to a specified address. We do this by
1057 grabbing a list of the sections, sorting them by VMA, and
1058 increasing the section sizes as required to fill the gaps.
1059 We write out the gap contents below. */
1061 c = bfd_count_sections (obfd);
1062 osections = (asection **) xmalloc (c * sizeof (asection *));
1063 set = osections;
1064 bfd_map_over_sections (obfd, get_sections, (void *) &set);
1066 qsort (osections, c, sizeof (asection *), compare_section_lma);
1068 gaps = (bfd_size_type *) xmalloc (c * sizeof (bfd_size_type));
1069 memset (gaps, 0, c * sizeof (bfd_size_type));
1071 if (gap_fill_set)
1073 for (i = 0; i < c - 1; i++)
1075 flagword flags;
1076 bfd_size_type size;
1077 bfd_vma gap_start, gap_stop;
1079 flags = bfd_get_section_flags (obfd, osections[i]);
1080 if ((flags & SEC_HAS_CONTENTS) == 0
1081 || (flags & SEC_LOAD) == 0)
1082 continue;
1084 size = bfd_section_size (obfd, osections[i]);
1085 gap_start = bfd_section_lma (obfd, osections[i]) + size;
1086 gap_stop = bfd_section_lma (obfd, osections[i + 1]);
1087 if (gap_start < gap_stop)
1089 if (! bfd_set_section_size (obfd, osections[i],
1090 size + (gap_stop - gap_start)))
1092 non_fatal (_("Can't fill gap after %s: %s"),
1093 bfd_get_section_name (obfd, osections[i]),
1094 bfd_errmsg (bfd_get_error ()));
1095 status = 1;
1096 break;
1098 gaps[i] = gap_stop - gap_start;
1099 if (max_gap < gap_stop - gap_start)
1100 max_gap = gap_stop - gap_start;
1105 if (pad_to_set)
1107 bfd_vma lma;
1108 bfd_size_type size;
1110 lma = bfd_section_lma (obfd, osections[c - 1]);
1111 size = bfd_section_size (obfd, osections[c - 1]);
1112 if (lma + size < pad_to)
1114 if (! bfd_set_section_size (obfd, osections[c - 1],
1115 pad_to - lma))
1117 non_fatal (_("Can't add padding to %s: %s"),
1118 bfd_get_section_name (obfd, osections[c - 1]),
1119 bfd_errmsg (bfd_get_error ()));
1120 status = 1;
1122 else
1124 gaps[c - 1] = pad_to - (lma + size);
1125 if (max_gap < pad_to - (lma + size))
1126 max_gap = pad_to - (lma + size);
1132 /* Symbol filtering must happen after the output sections
1133 have been created, but before their contents are set. */
1134 dhandle = NULL;
1135 symsize = bfd_get_symtab_upper_bound (ibfd);
1136 if (symsize < 0)
1137 RETURN_NONFATAL (bfd_get_filename (ibfd));
1139 osympp = isympp = (asymbol **) xmalloc (symsize);
1140 symcount = bfd_canonicalize_symtab (ibfd, isympp);
1141 if (symcount < 0)
1142 RETURN_NONFATAL (bfd_get_filename (ibfd));
1144 if (convert_debugging)
1145 dhandle = read_debugging_info (ibfd, isympp, symcount);
1147 if (strip_symbols == STRIP_DEBUG
1148 || strip_symbols == STRIP_ALL
1149 || strip_symbols == STRIP_UNNEEDED
1150 || discard_locals != LOCALS_UNDEF
1151 || strip_specific_list != NULL
1152 || keep_specific_list != NULL
1153 || localize_specific_list != NULL
1154 || keepglobal_specific_list != NULL
1155 || weaken_specific_list != NULL
1156 || sections_removed
1157 || sections_copied
1158 || convert_debugging
1159 || change_leading_char
1160 || remove_leading_char
1161 || redefine_sym_list
1162 || weaken)
1164 /* Mark symbols used in output relocations so that they
1165 are kept, even if they are local labels or static symbols.
1167 Note we iterate over the input sections examining their
1168 relocations since the relocations for the output sections
1169 haven't been set yet. mark_symbols_used_in_relocations will
1170 ignore input sections which have no corresponding output
1171 section. */
1172 if (strip_symbols != STRIP_ALL)
1173 bfd_map_over_sections (ibfd,
1174 mark_symbols_used_in_relocations,
1175 (PTR)isympp);
1176 osympp = (asymbol **) xmalloc ((symcount + 1) * sizeof (asymbol *));
1177 symcount = filter_symbols (ibfd, obfd, osympp, isympp, symcount);
1180 if (convert_debugging && dhandle != NULL)
1182 if (! write_debugging_info (obfd, dhandle, &symcount, &osympp))
1184 status = 1;
1185 return;
1189 bfd_set_symtab (obfd, osympp, symcount);
1191 /* This has to happen after the symbol table has been set. */
1192 bfd_map_over_sections (ibfd, copy_section, (void *) obfd);
1194 if (add_sections != NULL)
1196 struct section_add *padd;
1198 for (padd = add_sections; padd != NULL; padd = padd->next)
1200 if (! bfd_set_section_contents (obfd, padd->section,
1201 (PTR) padd->contents,
1202 (file_ptr) 0,
1203 (bfd_size_type) padd->size))
1204 RETURN_NONFATAL (bfd_get_filename (obfd));
1208 if (gap_fill_set || pad_to_set)
1210 bfd_byte *buf;
1211 int c, i;
1213 /* Fill in the gaps. */
1214 if (max_gap > 8192)
1215 max_gap = 8192;
1216 buf = (bfd_byte *) xmalloc (max_gap);
1217 memset (buf, gap_fill, (size_t) max_gap);
1219 c = bfd_count_sections (obfd);
1220 for (i = 0; i < c; i++)
1222 if (gaps[i] != 0)
1224 bfd_size_type left;
1225 file_ptr off;
1227 left = gaps[i];
1228 off = bfd_section_size (obfd, osections[i]) - left;
1230 while (left > 0)
1232 bfd_size_type now;
1234 if (left > 8192)
1235 now = 8192;
1236 else
1237 now = left;
1239 if (! bfd_set_section_contents (obfd, osections[i], buf,
1240 off, now))
1241 RETURN_NONFATAL (bfd_get_filename (obfd));
1243 left -= now;
1244 off += now;
1250 /* Allow the BFD backend to copy any private data it understands
1251 from the input BFD to the output BFD. This is done last to
1252 permit the routine to look at the filtered symbol table, which is
1253 important for the ECOFF code at least. */
1254 if (! bfd_copy_private_bfd_data (ibfd, obfd))
1256 non_fatal (_("%s: error copying private BFD data: %s"),
1257 bfd_get_filename (obfd),
1258 bfd_errmsg (bfd_get_error ()));
1259 status = 1;
1260 return;
1263 /* Switch to the alternate machine code. We have to do this at the
1264 very end, because we only initialize the header when we create
1265 the first section. */
1266 if (use_alt_mach_code != 0)
1268 if (!bfd_alt_mach_code (obfd, use_alt_mach_code))
1269 non_fatal (_("unknown alternate machine code, ignored"));
1273 #undef MKDIR
1274 #if defined (_WIN32) && !defined (__CYGWIN32__)
1275 #define MKDIR(DIR, MODE) mkdir (DIR)
1276 #else
1277 #define MKDIR(DIR, MODE) mkdir (DIR, MODE)
1278 #endif
1280 /* Read each archive element in turn from IBFD, copy the
1281 contents to temp file, and keep the temp file handle. */
1283 static void
1284 copy_archive (ibfd, obfd, output_target)
1285 bfd *ibfd;
1286 bfd *obfd;
1287 const char *output_target;
1289 struct name_list
1291 struct name_list *next;
1292 const char *name;
1293 bfd *obfd;
1294 } *list, *l;
1295 bfd **ptr = &obfd->archive_head;
1296 bfd *this_element;
1297 char *dir = make_tempname (bfd_get_filename (obfd));
1299 /* Make a temp directory to hold the contents. */
1300 if (MKDIR (dir, 0700) != 0)
1302 fatal (_("cannot mkdir %s for archive copying (error: %s)"),
1303 dir, strerror (errno));
1305 obfd->has_armap = ibfd->has_armap;
1307 list = NULL;
1309 this_element = bfd_openr_next_archived_file (ibfd, NULL);
1311 if (!bfd_set_format (obfd, bfd_get_format (ibfd)))
1312 RETURN_NONFATAL (bfd_get_filename (obfd));
1314 while (!status && this_element != (bfd *) NULL)
1316 char *output_name;
1317 bfd *output_bfd;
1318 bfd *last_element;
1319 struct stat buf;
1320 int stat_status = 0;
1322 /* Create an output file for this member. */
1323 output_name = concat (dir, "/",
1324 bfd_get_filename (this_element), (char *) 0);
1326 /* If the file already exists, make another temp dir. */
1327 if (stat (output_name, &buf) >= 0)
1329 output_name = make_tempname (output_name);
1330 if (MKDIR (output_name, 0700) != 0)
1332 fatal (_("cannot mkdir %s for archive copying (error: %s)"),
1333 output_name, strerror (errno));
1335 l = (struct name_list *) xmalloc (sizeof (struct name_list));
1336 l->name = output_name;
1337 l->next = list;
1338 l->obfd = NULL;
1339 list = l;
1340 output_name = concat (output_name, "/",
1341 bfd_get_filename (this_element), (char *) 0);
1344 output_bfd = bfd_openw (output_name, output_target);
1345 if (preserve_dates)
1347 stat_status = bfd_stat_arch_elt (this_element, &buf);
1349 if (stat_status != 0)
1350 non_fatal (_("internal stat error on %s"),
1351 bfd_get_filename (this_element));
1354 l = (struct name_list *) xmalloc (sizeof (struct name_list));
1355 l->name = output_name;
1356 l->next = list;
1357 list = l;
1359 if (output_bfd == (bfd *) NULL)
1360 RETURN_NONFATAL (output_name);
1362 if (bfd_check_format (this_element, bfd_object) == true)
1363 copy_object (this_element, output_bfd);
1365 if (!bfd_close (output_bfd))
1367 bfd_nonfatal (bfd_get_filename (output_bfd));
1368 /* Error in new object file. Don't change archive. */
1369 status = 1;
1372 if (preserve_dates && stat_status == 0)
1373 set_times (output_name, &buf);
1375 /* Open the newly output file and attach to our list. */
1376 output_bfd = bfd_openr (output_name, output_target);
1378 l->obfd = output_bfd;
1380 *ptr = output_bfd;
1381 ptr = &output_bfd->next;
1383 last_element = this_element;
1385 this_element = bfd_openr_next_archived_file (ibfd, last_element);
1387 bfd_close (last_element);
1389 *ptr = (bfd *) NULL;
1391 if (!bfd_close (obfd))
1392 RETURN_NONFATAL (bfd_get_filename (obfd));
1394 if (!bfd_close (ibfd))
1395 RETURN_NONFATAL (bfd_get_filename (ibfd));
1397 /* Delete all the files that we opened. */
1398 for (l = list; l != NULL; l = l->next)
1400 if (l->obfd == NULL)
1401 rmdir (l->name);
1402 else
1404 bfd_close (l->obfd);
1405 unlink (l->name);
1408 rmdir (dir);
1411 /* The top-level control. */
1413 static void
1414 copy_file (input_filename, output_filename, input_target, output_target)
1415 const char *input_filename;
1416 const char *output_filename;
1417 const char *input_target;
1418 const char *output_target;
1420 bfd *ibfd;
1421 char **matching;
1423 /* To allow us to do "strip *" without dying on the first
1424 non-object file, failures are nonfatal. */
1425 ibfd = bfd_openr (input_filename, input_target);
1426 if (ibfd == NULL)
1427 RETURN_NONFATAL (input_filename);
1429 if (bfd_check_format (ibfd, bfd_archive))
1431 bfd *obfd;
1433 /* bfd_get_target does not return the correct value until
1434 bfd_check_format succeeds. */
1435 if (output_target == NULL)
1436 output_target = bfd_get_target (ibfd);
1438 obfd = bfd_openw (output_filename, output_target);
1439 if (obfd == NULL)
1440 RETURN_NONFATAL (output_filename);
1442 copy_archive (ibfd, obfd, output_target);
1444 else if (bfd_check_format_matches (ibfd, bfd_object, &matching)
1445 || bfd_check_format_matches (ibfd, bfd_core, &matching))
1447 bfd *obfd;
1449 /* bfd_get_target does not return the correct value until
1450 bfd_check_format succeeds. */
1451 if (output_target == NULL)
1452 output_target = bfd_get_target (ibfd);
1454 obfd = bfd_openw (output_filename, output_target);
1455 if (obfd == NULL)
1456 RETURN_NONFATAL (output_filename);
1458 copy_object (ibfd, obfd);
1460 if (!bfd_close (obfd))
1461 RETURN_NONFATAL (output_filename);
1463 if (!bfd_close (ibfd))
1464 RETURN_NONFATAL (input_filename);
1466 else
1468 bfd_nonfatal (input_filename);
1470 if (bfd_get_error () == bfd_error_file_ambiguously_recognized)
1472 list_matching_formats (matching);
1473 free (matching);
1476 status = 1;
1480 /* Add a name to the section renaming list. */
1482 static void
1483 add_section_rename (old_name, new_name, flags)
1484 const char * old_name;
1485 const char * new_name;
1486 flagword flags;
1488 section_rename * rename;
1490 /* Check for conflicts first. */
1491 for (rename = section_rename_list; rename != NULL; rename = rename->next)
1492 if (strcmp (rename->old_name, old_name) == 0)
1494 /* Silently ignore duplicate definitions. */
1495 if (strcmp (rename->new_name, new_name) == 0
1496 && rename->flags == flags)
1497 return;
1499 fatal (_("Multiple renames of section %s"), old_name);
1502 rename = (section_rename *) xmalloc (sizeof (* rename));
1504 rename->old_name = old_name;
1505 rename->new_name = new_name;
1506 rename->flags = flags;
1507 rename->next = section_rename_list;
1509 section_rename_list = rename;
1512 /* Check the section rename list for a new name of the input section
1513 ISECTION. Return the new name if one is found.
1514 Also set RETURNED_FLAGS to the flags to be used for this section. */
1516 static const char *
1517 find_section_rename (ibfd, isection, returned_flags)
1518 bfd * ibfd ATTRIBUTE_UNUSED;
1519 sec_ptr isection;
1520 flagword * returned_flags;
1522 const char * old_name = bfd_section_name (ibfd, isection);
1523 section_rename * rename;
1525 /* Default to using the flags of the input section. */
1526 * returned_flags = bfd_get_section_flags (ibfd, isection);
1528 for (rename = section_rename_list; rename != NULL; rename = rename->next)
1529 if (strcmp (rename->old_name, old_name) == 0)
1531 if (rename->flags != (flagword) -1)
1532 * returned_flags = rename->flags;
1534 return rename->new_name;
1537 return old_name;
1540 /* Create a section in OBFD with the same
1541 name and attributes as ISECTION in IBFD. */
1543 static void
1544 setup_section (ibfd, isection, obfdarg)
1545 bfd *ibfd;
1546 sec_ptr isection;
1547 PTR obfdarg;
1549 bfd *obfd = (bfd *) obfdarg;
1550 struct section_list *p;
1551 sec_ptr osection;
1552 bfd_size_type size;
1553 bfd_vma vma;
1554 bfd_vma lma;
1555 flagword flags;
1556 const char *err;
1557 const char * name;
1559 if ((bfd_get_section_flags (ibfd, isection) & SEC_DEBUGGING) != 0
1560 && (strip_symbols == STRIP_DEBUG
1561 || strip_symbols == STRIP_UNNEEDED
1562 || strip_symbols == STRIP_ALL
1563 || discard_locals == LOCALS_ALL
1564 || convert_debugging))
1565 return;
1567 p = find_section_list (bfd_section_name (ibfd, isection), false);
1568 if (p != NULL)
1569 p->used = true;
1571 if (sections_removed && p != NULL && p->remove)
1572 return;
1573 if (sections_copied && (p == NULL || ! p->copy))
1574 return;
1576 /* Get the, possibly new, name of the output section. */
1577 name = find_section_rename (ibfd, isection, & flags);
1579 osection = bfd_make_section_anyway (obfd, name);
1581 if (osection == NULL)
1583 err = _("making");
1584 goto loser;
1587 size = bfd_section_size (ibfd, isection);
1588 if (copy_byte >= 0)
1589 size = (size + interleave - 1) / interleave;
1590 if (! bfd_set_section_size (obfd, osection, size))
1592 err = _("size");
1593 goto loser;
1596 vma = bfd_section_vma (ibfd, isection);
1597 if (p != NULL && p->change_vma == CHANGE_MODIFY)
1598 vma += p->vma_val;
1599 else if (p != NULL && p->change_vma == CHANGE_SET)
1600 vma = p->vma_val;
1601 else
1602 vma += change_section_address;
1604 if (! bfd_set_section_vma (obfd, osection, vma))
1606 err = _("vma");
1607 goto loser;
1610 lma = isection->lma;
1611 if ((p != NULL) && p->change_lma != CHANGE_IGNORE)
1613 if (p->change_lma == CHANGE_MODIFY)
1614 lma += p->lma_val;
1615 else if (p->change_lma == CHANGE_SET)
1616 lma = p->lma_val;
1617 else
1618 abort ();
1620 else
1621 lma += change_section_address;
1623 osection->lma = lma;
1625 /* FIXME: This is probably not enough. If we change the LMA we
1626 may have to recompute the header for the file as well. */
1627 if (bfd_set_section_alignment (obfd,
1628 osection,
1629 bfd_section_alignment (ibfd, isection))
1630 == false)
1632 err = _("alignment");
1633 goto loser;
1636 if (p != NULL && p->set_flags)
1637 flags = p->flags | (flags & (SEC_HAS_CONTENTS | SEC_RELOC));
1638 if (!bfd_set_section_flags (obfd, osection, flags))
1640 err = _("flags");
1641 goto loser;
1644 /* Copy merge entity size. */
1645 osection->entsize = isection->entsize;
1647 /* This used to be mangle_section; we do here to avoid using
1648 bfd_get_section_by_name since some formats allow multiple
1649 sections with the same name. */
1650 isection->output_section = osection;
1651 isection->output_offset = 0;
1653 /* Allow the BFD backend to copy any private data it understands
1654 from the input section to the output section. */
1655 if (!bfd_copy_private_section_data (ibfd, isection, obfd, osection))
1657 err = _("private data");
1658 goto loser;
1661 /* All went well. */
1662 return;
1664 loser:
1665 non_fatal (_("%s: section `%s': error in %s: %s"),
1666 bfd_get_filename (ibfd),
1667 bfd_section_name (ibfd, isection),
1668 err, bfd_errmsg (bfd_get_error ()));
1669 status = 1;
1672 /* Copy the data of input section ISECTION of IBFD
1673 to an output section with the same name in OBFD.
1674 If stripping then don't copy any relocation info. */
1676 static void
1677 copy_section (ibfd, isection, obfdarg)
1678 bfd *ibfd;
1679 sec_ptr isection;
1680 PTR obfdarg;
1682 bfd *obfd = (bfd *) obfdarg;
1683 struct section_list *p;
1684 arelent **relpp;
1685 long relcount;
1686 sec_ptr osection;
1687 bfd_size_type size;
1688 long relsize;
1689 flagword flags;
1691 /* If we have already failed earlier on,
1692 do not keep on generating complaints now. */
1693 if (status != 0)
1694 return;
1696 flags = bfd_get_section_flags (ibfd, isection);
1697 if ((flags & SEC_DEBUGGING) != 0
1698 && (strip_symbols == STRIP_DEBUG
1699 || strip_symbols == STRIP_UNNEEDED
1700 || strip_symbols == STRIP_ALL
1701 || discard_locals == LOCALS_ALL
1702 || convert_debugging))
1703 return;
1705 if ((flags & SEC_GROUP) != 0)
1706 return;
1708 p = find_section_list (bfd_section_name (ibfd, isection), false);
1710 if (sections_removed && p != NULL && p->remove)
1711 return;
1712 if (sections_copied && (p == NULL || ! p->copy))
1713 return;
1715 osection = isection->output_section;
1716 size = bfd_get_section_size_before_reloc (isection);
1718 if (size == 0 || osection == 0)
1719 return;
1721 /* Core files do not need to be relocated. */
1722 if (bfd_get_format (obfd) == bfd_core)
1723 relsize = 0;
1724 else
1725 relsize = bfd_get_reloc_upper_bound (ibfd, isection);
1727 if (relsize < 0)
1728 RETURN_NONFATAL (bfd_get_filename (ibfd));
1730 if (relsize == 0)
1731 bfd_set_reloc (obfd, osection, (arelent **) NULL, 0);
1732 else
1734 relpp = (arelent **) xmalloc (relsize);
1735 relcount = bfd_canonicalize_reloc (ibfd, isection, relpp, isympp);
1736 if (relcount < 0)
1737 RETURN_NONFATAL (bfd_get_filename (ibfd));
1739 if (strip_symbols == STRIP_ALL)
1741 /* Remove relocations which are not in
1742 keep_strip_specific_list. */
1743 arelent **temp_relpp;
1744 long temp_relcount = 0;
1745 long i;
1747 temp_relpp = (arelent **) xmalloc (relsize);
1748 for (i = 0; i < relcount; i++)
1749 if (is_specified_symbol
1750 (bfd_asymbol_name (*relpp [i]->sym_ptr_ptr),
1751 keep_specific_list))
1752 temp_relpp [temp_relcount++] = relpp [i];
1753 relcount = temp_relcount;
1754 free (relpp);
1755 relpp = temp_relpp;
1758 bfd_set_reloc (obfd, osection,
1759 (relcount == 0 ? (arelent **) NULL : relpp), relcount);
1762 isection->_cooked_size = isection->_raw_size;
1763 isection->reloc_done = true;
1765 if (bfd_get_section_flags (ibfd, isection) & SEC_HAS_CONTENTS
1766 && bfd_get_section_flags (obfd, osection) & SEC_HAS_CONTENTS)
1768 PTR memhunk = (PTR) xmalloc ((unsigned) size);
1770 if (!bfd_get_section_contents (ibfd, isection, memhunk, (file_ptr) 0,
1771 size))
1772 RETURN_NONFATAL (bfd_get_filename (ibfd));
1774 if (copy_byte >= 0)
1775 filter_bytes (memhunk, &size);
1777 if (!bfd_set_section_contents (obfd, osection, memhunk, (file_ptr) 0,
1778 size))
1779 RETURN_NONFATAL (bfd_get_filename (obfd));
1781 free (memhunk);
1783 else if (p != NULL && p->set_flags && (p->flags & SEC_HAS_CONTENTS) != 0)
1785 PTR memhunk = (PTR) xmalloc ((unsigned) size);
1787 /* We don't permit the user to turn off the SEC_HAS_CONTENTS
1788 flag--they can just remove the section entirely and add it
1789 back again. However, we do permit them to turn on the
1790 SEC_HAS_CONTENTS flag, and take it to mean that the section
1791 contents should be zeroed out. */
1793 memset (memhunk, 0, size);
1794 if (! bfd_set_section_contents (obfd, osection, memhunk, (file_ptr) 0,
1795 size))
1796 RETURN_NONFATAL (bfd_get_filename (obfd));
1797 free (memhunk);
1801 /* Get all the sections. This is used when --gap-fill or --pad-to is
1802 used. */
1804 static void
1805 get_sections (obfd, osection, secppparg)
1806 bfd *obfd ATTRIBUTE_UNUSED;
1807 asection *osection;
1808 PTR secppparg;
1810 asection ***secppp = (asection ***) secppparg;
1812 **secppp = osection;
1813 ++(*secppp);
1816 /* Sort sections by VMA. This is called via qsort, and is used when
1817 --gap-fill or --pad-to is used. We force non loadable or empty
1818 sections to the front, where they are easier to ignore. */
1820 static int
1821 compare_section_lma (arg1, arg2)
1822 const PTR arg1;
1823 const PTR arg2;
1825 const asection **sec1 = (const asection **) arg1;
1826 const asection **sec2 = (const asection **) arg2;
1827 flagword flags1, flags2;
1829 /* Sort non loadable sections to the front. */
1830 flags1 = (*sec1)->flags;
1831 flags2 = (*sec2)->flags;
1832 if ((flags1 & SEC_HAS_CONTENTS) == 0
1833 || (flags1 & SEC_LOAD) == 0)
1835 if ((flags2 & SEC_HAS_CONTENTS) != 0
1836 && (flags2 & SEC_LOAD) != 0)
1837 return -1;
1839 else
1841 if ((flags2 & SEC_HAS_CONTENTS) == 0
1842 || (flags2 & SEC_LOAD) == 0)
1843 return 1;
1846 /* Sort sections by LMA. */
1847 if ((*sec1)->lma > (*sec2)->lma)
1848 return 1;
1849 else if ((*sec1)->lma < (*sec2)->lma)
1850 return -1;
1852 /* Sort sections with the same LMA by size. */
1853 if ((*sec1)->_raw_size > (*sec2)->_raw_size)
1854 return 1;
1855 else if ((*sec1)->_raw_size < (*sec2)->_raw_size)
1856 return -1;
1858 return 0;
1861 /* Mark all the symbols which will be used in output relocations with
1862 the BSF_KEEP flag so that those symbols will not be stripped.
1864 Ignore relocations which will not appear in the output file. */
1866 static void
1867 mark_symbols_used_in_relocations (ibfd, isection, symbolsarg)
1868 bfd *ibfd;
1869 sec_ptr isection;
1870 PTR symbolsarg;
1872 asymbol **symbols = (asymbol **) symbolsarg;
1873 long relsize;
1874 arelent **relpp;
1875 long relcount, i;
1877 /* Ignore an input section with no corresponding output section. */
1878 if (isection->output_section == NULL)
1879 return;
1881 relsize = bfd_get_reloc_upper_bound (ibfd, isection);
1882 if (relsize < 0)
1883 bfd_fatal (bfd_get_filename (ibfd));
1885 if (relsize == 0)
1886 return;
1888 relpp = (arelent **) xmalloc (relsize);
1889 relcount = bfd_canonicalize_reloc (ibfd, isection, relpp, symbols);
1890 if (relcount < 0)
1891 bfd_fatal (bfd_get_filename (ibfd));
1893 /* Examine each symbol used in a relocation. If it's not one of the
1894 special bfd section symbols, then mark it with BSF_KEEP. */
1895 for (i = 0; i < relcount; i++)
1897 if (*relpp[i]->sym_ptr_ptr != bfd_com_section_ptr->symbol
1898 && *relpp[i]->sym_ptr_ptr != bfd_abs_section_ptr->symbol
1899 && *relpp[i]->sym_ptr_ptr != bfd_und_section_ptr->symbol)
1900 (*relpp[i]->sym_ptr_ptr)->flags |= BSF_KEEP;
1903 if (relpp != NULL)
1904 free (relpp);
1907 /* Write out debugging information. */
1909 static boolean
1910 write_debugging_info (obfd, dhandle, symcountp, symppp)
1911 bfd *obfd;
1912 PTR dhandle;
1913 long *symcountp ATTRIBUTE_UNUSED;
1914 asymbol ***symppp ATTRIBUTE_UNUSED;
1916 if (bfd_get_flavour (obfd) == bfd_target_ieee_flavour)
1917 return write_ieee_debugging_info (obfd, dhandle);
1919 if (bfd_get_flavour (obfd) == bfd_target_coff_flavour
1920 || bfd_get_flavour (obfd) == bfd_target_elf_flavour)
1922 bfd_byte *syms, *strings;
1923 bfd_size_type symsize, stringsize;
1924 asection *stabsec, *stabstrsec;
1926 if (! write_stabs_in_sections_debugging_info (obfd, dhandle, &syms,
1927 &symsize, &strings,
1928 &stringsize))
1929 return false;
1931 stabsec = bfd_make_section (obfd, ".stab");
1932 stabstrsec = bfd_make_section (obfd, ".stabstr");
1933 if (stabsec == NULL
1934 || stabstrsec == NULL
1935 || ! bfd_set_section_size (obfd, stabsec, symsize)
1936 || ! bfd_set_section_size (obfd, stabstrsec, stringsize)
1937 || ! bfd_set_section_alignment (obfd, stabsec, 2)
1938 || ! bfd_set_section_alignment (obfd, stabstrsec, 0)
1939 || ! bfd_set_section_flags (obfd, stabsec,
1940 (SEC_HAS_CONTENTS
1941 | SEC_READONLY
1942 | SEC_DEBUGGING))
1943 || ! bfd_set_section_flags (obfd, stabstrsec,
1944 (SEC_HAS_CONTENTS
1945 | SEC_READONLY
1946 | SEC_DEBUGGING)))
1948 non_fatal (_("%s: can't create debugging section: %s"),
1949 bfd_get_filename (obfd),
1950 bfd_errmsg (bfd_get_error ()));
1951 return false;
1954 /* We can get away with setting the section contents now because
1955 the next thing the caller is going to do is copy over the
1956 real sections. We may someday have to split the contents
1957 setting out of this function. */
1958 if (! bfd_set_section_contents (obfd, stabsec, syms, (file_ptr) 0,
1959 symsize)
1960 || ! bfd_set_section_contents (obfd, stabstrsec, strings,
1961 (file_ptr) 0, stringsize))
1963 non_fatal (_("%s: can't set debugging section contents: %s"),
1964 bfd_get_filename (obfd),
1965 bfd_errmsg (bfd_get_error ()));
1966 return false;
1969 return true;
1972 non_fatal (_("%s: don't know how to write debugging information for %s"),
1973 bfd_get_filename (obfd), bfd_get_target (obfd));
1974 return false;
1977 static int
1978 strip_main (argc, argv)
1979 int argc;
1980 char *argv[];
1982 char *input_target = NULL, *output_target = NULL;
1983 boolean show_version = false;
1984 int c, i;
1985 struct section_list *p;
1986 char *output_file = NULL;
1988 while ((c = getopt_long (argc, argv, "I:O:F:K:N:R:o:sSpdgxXHhVv",
1989 strip_options, (int *) 0)) != EOF)
1991 switch (c)
1993 case 'I':
1994 input_target = optarg;
1995 break;
1996 case 'O':
1997 output_target = optarg;
1998 break;
1999 case 'F':
2000 input_target = output_target = optarg;
2001 break;
2002 case 'R':
2003 p = find_section_list (optarg, true);
2004 p->remove = true;
2005 sections_removed = true;
2006 break;
2007 case 's':
2008 strip_symbols = STRIP_ALL;
2009 break;
2010 case 'S':
2011 case 'g':
2012 case 'd': /* Historic BSD alias for -g. Used by early NetBSD. */
2013 strip_symbols = STRIP_DEBUG;
2014 break;
2015 case OPTION_STRIP_UNNEEDED:
2016 strip_symbols = STRIP_UNNEEDED;
2017 break;
2018 case 'K':
2019 add_specific_symbol (optarg, &keep_specific_list);
2020 break;
2021 case 'N':
2022 add_specific_symbol (optarg, &strip_specific_list);
2023 break;
2024 case 'o':
2025 output_file = optarg;
2026 break;
2027 case 'p':
2028 preserve_dates = true;
2029 break;
2030 case 'x':
2031 discard_locals = LOCALS_ALL;
2032 break;
2033 case 'X':
2034 discard_locals = LOCALS_START_L;
2035 break;
2036 case 'v':
2037 verbose = true;
2038 break;
2039 case 'V':
2040 show_version = true;
2041 break;
2042 case 0:
2043 /* We've been given a long option. */
2044 break;
2045 case 'H':
2046 case 'h':
2047 strip_usage (stdout, 0);
2048 default:
2049 strip_usage (stderr, 1);
2053 if (show_version)
2054 print_version ("strip");
2056 /* Default is to strip all symbols. */
2057 if (strip_symbols == STRIP_UNDEF
2058 && discard_locals == LOCALS_UNDEF
2059 && strip_specific_list == NULL)
2060 strip_symbols = STRIP_ALL;
2062 if (output_target == (char *) NULL)
2063 output_target = input_target;
2065 i = optind;
2066 if (i == argc
2067 || (output_file != NULL && (i + 1) < argc))
2068 strip_usage (stderr, 1);
2070 for (; i < argc; i++)
2072 int hold_status = status;
2073 struct stat statbuf;
2074 char *tmpname;
2076 if (preserve_dates)
2078 if (stat (argv[i], &statbuf) < 0)
2080 non_fatal (_("%s: cannot stat: %s"), argv[i], strerror (errno));
2081 continue;
2085 if (output_file != NULL)
2086 tmpname = output_file;
2087 else
2088 tmpname = make_tempname (argv[i]);
2089 status = 0;
2091 copy_file (argv[i], tmpname, input_target, output_target);
2092 if (status == 0)
2094 if (preserve_dates)
2095 set_times (tmpname, &statbuf);
2096 if (output_file == NULL)
2097 smart_rename (tmpname, argv[i], preserve_dates);
2098 status = hold_status;
2100 else
2101 unlink (tmpname);
2102 if (output_file == NULL)
2103 free (tmpname);
2106 return 0;
2109 static int
2110 copy_main (argc, argv)
2111 int argc;
2112 char *argv[];
2114 char * binary_architecture = NULL;
2115 char *input_filename = NULL, *output_filename = NULL;
2116 char *input_target = NULL, *output_target = NULL;
2117 boolean show_version = false;
2118 boolean change_warn = true;
2119 int c;
2120 struct section_list *p;
2121 struct stat statbuf;
2123 while ((c = getopt_long (argc, argv, "b:B:i:I:j:K:N:s:O:d:F:L:G:R:SpgxXHhVvW:",
2124 copy_options, (int *) 0)) != EOF)
2126 switch (c)
2128 case 'b':
2129 copy_byte = atoi (optarg);
2130 if (copy_byte < 0)
2131 fatal (_("byte number must be non-negative"));
2132 break;
2134 case 'B':
2135 binary_architecture = optarg;
2136 break;
2138 case 'i':
2139 interleave = atoi (optarg);
2140 if (interleave < 1)
2141 fatal (_("interleave must be positive"));
2142 break;
2144 case 'I':
2145 case 's': /* "source" - 'I' is preferred */
2146 input_target = optarg;
2147 break;
2149 case 'O':
2150 case 'd': /* "destination" - 'O' is preferred */
2151 output_target = optarg;
2152 break;
2154 case 'F':
2155 input_target = output_target = optarg;
2156 break;
2158 case 'j':
2159 p = find_section_list (optarg, true);
2160 if (p->remove)
2161 fatal (_("%s both copied and removed"), optarg);
2162 p->copy = true;
2163 sections_copied = true;
2164 break;
2166 case 'R':
2167 p = find_section_list (optarg, true);
2168 if (p->copy)
2169 fatal (_("%s both copied and removed"), optarg);
2170 p->remove = true;
2171 sections_removed = true;
2172 break;
2174 case 'S':
2175 strip_symbols = STRIP_ALL;
2176 break;
2178 case 'g':
2179 strip_symbols = STRIP_DEBUG;
2180 break;
2182 case OPTION_STRIP_UNNEEDED:
2183 strip_symbols = STRIP_UNNEEDED;
2184 break;
2186 case 'K':
2187 add_specific_symbol (optarg, &keep_specific_list);
2188 break;
2190 case 'N':
2191 add_specific_symbol (optarg, &strip_specific_list);
2192 break;
2194 case 'L':
2195 add_specific_symbol (optarg, &localize_specific_list);
2196 break;
2198 case 'G':
2199 add_specific_symbol (optarg, &keepglobal_specific_list);
2200 break;
2202 case 'W':
2203 add_specific_symbol (optarg, &weaken_specific_list);
2204 break;
2206 case 'p':
2207 preserve_dates = true;
2208 break;
2210 case 'x':
2211 discard_locals = LOCALS_ALL;
2212 break;
2214 case 'X':
2215 discard_locals = LOCALS_START_L;
2216 break;
2218 case 'v':
2219 verbose = true;
2220 break;
2222 case 'V':
2223 show_version = true;
2224 break;
2226 case OPTION_WEAKEN:
2227 weaken = true;
2228 break;
2230 case OPTION_ADD_SECTION:
2232 const char *s;
2233 struct stat st;
2234 struct section_add *pa;
2235 int len;
2236 char *name;
2237 FILE *f;
2239 s = strchr (optarg, '=');
2241 if (s == NULL)
2242 fatal (_("bad format for %s"), "--add-section");
2244 if (stat (s + 1, & st) < 0)
2245 fatal (_("cannot stat: %s: %s"), s + 1, strerror (errno));
2247 pa = (struct section_add *) xmalloc (sizeof (struct section_add));
2249 len = s - optarg;
2250 name = (char *) xmalloc (len + 1);
2251 strncpy (name, optarg, len);
2252 name[len] = '\0';
2253 pa->name = name;
2255 pa->filename = s + 1;
2257 pa->size = st.st_size;
2259 pa->contents = (bfd_byte *) xmalloc (pa->size);
2260 f = fopen (pa->filename, FOPEN_RB);
2262 if (f == NULL)
2263 fatal (_("cannot open: %s: %s"), pa->filename, strerror (errno));
2265 if (fread (pa->contents, 1, pa->size, f) == 0
2266 || ferror (f))
2267 fatal (_("%s: fread failed"), pa->filename);
2269 fclose (f);
2271 pa->next = add_sections;
2272 add_sections = pa;
2274 break;
2276 case OPTION_CHANGE_START:
2277 change_start = parse_vma (optarg, "--change-start");
2278 break;
2280 case OPTION_CHANGE_SECTION_ADDRESS:
2281 case OPTION_CHANGE_SECTION_LMA:
2282 case OPTION_CHANGE_SECTION_VMA:
2284 const char *s;
2285 int len;
2286 char *name;
2287 char *option = NULL;
2288 bfd_vma val;
2289 enum change_action what = CHANGE_IGNORE;
2291 switch (c)
2293 case OPTION_CHANGE_SECTION_ADDRESS:
2294 option = "--change-section-address";
2295 break;
2296 case OPTION_CHANGE_SECTION_LMA:
2297 option = "--change-section-lma";
2298 break;
2299 case OPTION_CHANGE_SECTION_VMA:
2300 option = "--change-section-vma";
2301 break;
2304 s = strchr (optarg, '=');
2305 if (s == NULL)
2307 s = strchr (optarg, '+');
2308 if (s == NULL)
2310 s = strchr (optarg, '-');
2311 if (s == NULL)
2312 fatal (_("bad format for %s"), option);
2316 len = s - optarg;
2317 name = (char *) xmalloc (len + 1);
2318 strncpy (name, optarg, len);
2319 name[len] = '\0';
2321 p = find_section_list (name, true);
2323 val = parse_vma (s + 1, option);
2325 switch (*s)
2327 case '=': what = CHANGE_SET; break;
2328 case '-': val = - val; /* Drop through. */
2329 case '+': what = CHANGE_MODIFY; break;
2332 switch (c)
2334 case OPTION_CHANGE_SECTION_ADDRESS:
2335 p->change_vma = what;
2336 p->vma_val = val;
2337 /* Drop through. */
2339 case OPTION_CHANGE_SECTION_LMA:
2340 p->change_lma = what;
2341 p->lma_val = val;
2342 break;
2344 case OPTION_CHANGE_SECTION_VMA:
2345 p->change_vma = what;
2346 p->vma_val = val;
2347 break;
2350 break;
2352 case OPTION_CHANGE_ADDRESSES:
2353 change_section_address = parse_vma (optarg, "--change-addresses");
2354 change_start = change_section_address;
2355 break;
2357 case OPTION_CHANGE_WARNINGS:
2358 change_warn = true;
2359 break;
2361 case OPTION_CHANGE_LEADING_CHAR:
2362 change_leading_char = true;
2363 break;
2365 case OPTION_DEBUGGING:
2366 convert_debugging = true;
2367 break;
2369 case OPTION_GAP_FILL:
2371 bfd_vma gap_fill_vma;
2373 gap_fill_vma = parse_vma (optarg, "--gap-fill");
2374 gap_fill = (bfd_byte) gap_fill_vma;
2375 if ((bfd_vma) gap_fill != gap_fill_vma)
2377 char buff[20];
2379 sprintf_vma (buff, gap_fill_vma);
2381 non_fatal (_("Warning: truncating gap-fill from 0x%s to 0x%x"),
2382 buff, gap_fill);
2384 gap_fill_set = true;
2386 break;
2388 case OPTION_NO_CHANGE_WARNINGS:
2389 change_warn = false;
2390 break;
2392 case OPTION_PAD_TO:
2393 pad_to = parse_vma (optarg, "--pad-to");
2394 pad_to_set = true;
2395 break;
2397 case OPTION_REMOVE_LEADING_CHAR:
2398 remove_leading_char = true;
2399 break;
2401 case OPTION_REDEFINE_SYM:
2403 /* Push this redefinition onto redefine_symbol_list. */
2405 int len;
2406 const char *s;
2407 const char *nextarg;
2408 char *source, *target;
2410 s = strchr (optarg, '=');
2411 if (s == NULL)
2412 fatal (_("bad format for %s"), "--redefine-sym");
2414 len = s - optarg;
2415 source = (char *) xmalloc (len + 1);
2416 strncpy (source, optarg, len);
2417 source[len] = '\0';
2419 nextarg = s + 1;
2420 len = strlen (nextarg);
2421 target = (char *) xmalloc (len + 1);
2422 strcpy (target, nextarg);
2424 redefine_list_append (source, target);
2426 free (source);
2427 free (target);
2429 break;
2431 case OPTION_SET_SECTION_FLAGS:
2433 const char *s;
2434 int len;
2435 char *name;
2437 s = strchr (optarg, '=');
2438 if (s == NULL)
2439 fatal (_("bad format for %s"), "--set-section-flags");
2441 len = s - optarg;
2442 name = (char *) xmalloc (len + 1);
2443 strncpy (name, optarg, len);
2444 name[len] = '\0';
2446 p = find_section_list (name, true);
2448 p->set_flags = true;
2449 p->flags = parse_flags (s + 1);
2451 break;
2453 case OPTION_RENAME_SECTION:
2455 flagword flags;
2456 const char *eq, *fl;
2457 char *old_name;
2458 char *new_name;
2459 unsigned int len;
2461 eq = strchr (optarg, '=');
2462 if (eq == NULL)
2463 fatal (_("bad format for %s"), "--rename-section");
2465 len = eq - optarg;
2466 if (len == 0)
2467 fatal (_("bad format for %s"), "--rename-section");
2469 old_name = (char *) xmalloc (len + 1);
2470 strncpy (old_name, optarg, len);
2471 old_name[len] = 0;
2473 eq++;
2474 fl = strchr (eq, ',');
2475 if (fl)
2477 flags = parse_flags (fl + 1);
2478 len = fl - eq;
2480 else
2482 flags = -1;
2483 len = strlen (eq);
2486 if (len == 0)
2487 fatal (_("bad format for %s"), "--rename-section");
2489 new_name = (char *) xmalloc (len + 1);
2490 strncpy (new_name, eq, len);
2491 new_name[len] = 0;
2493 add_section_rename (old_name, new_name, flags);
2495 break;
2497 case OPTION_SET_START:
2498 set_start = parse_vma (optarg, "--set-start");
2499 set_start_set = true;
2500 break;
2502 case OPTION_SREC_LEN:
2503 Chunk = parse_vma (optarg, "--srec-len");
2504 break;
2506 case OPTION_SREC_FORCES3:
2507 S3Forced = true;
2508 break;
2510 case OPTION_STRIP_SYMBOLS:
2511 add_specific_symbols (optarg, &strip_specific_list);
2512 break;
2514 case OPTION_KEEP_SYMBOLS:
2515 add_specific_symbols (optarg, &keep_specific_list);
2516 break;
2518 case OPTION_LOCALIZE_SYMBOLS:
2519 add_specific_symbols (optarg, &localize_specific_list);
2520 break;
2522 case OPTION_KEEPGLOBAL_SYMBOLS:
2523 add_specific_symbols (optarg, &keepglobal_specific_list);
2524 break;
2526 case OPTION_WEAKEN_SYMBOLS:
2527 add_specific_symbols (optarg, &weaken_specific_list);
2528 break;
2530 case OPTION_ALT_MACH_CODE:
2531 use_alt_mach_code = atoi (optarg);
2532 if (use_alt_mach_code <= 0)
2533 fatal (_("alternate machine code index must be positive"));
2534 break;
2536 case 0:
2537 break; /* we've been given a long option */
2539 case 'H':
2540 case 'h':
2541 copy_usage (stdout, 0);
2543 default:
2544 copy_usage (stderr, 1);
2548 if (show_version)
2549 print_version ("objcopy");
2551 if (copy_byte >= interleave)
2552 fatal (_("byte number must be less than interleave"));
2554 if (optind == argc || optind + 2 < argc)
2555 copy_usage (stderr, 1);
2557 input_filename = argv[optind];
2558 if (optind + 1 < argc)
2559 output_filename = argv[optind + 1];
2561 /* Default is to strip no symbols. */
2562 if (strip_symbols == STRIP_UNDEF && discard_locals == LOCALS_UNDEF)
2563 strip_symbols = STRIP_NONE;
2565 if (output_target == (char *) NULL)
2566 output_target = input_target;
2568 if (binary_architecture != (char *) NULL)
2570 if (input_target && strcmp (input_target, "binary") == 0)
2572 const bfd_arch_info_type * temp_arch_info;
2574 temp_arch_info = bfd_scan_arch (binary_architecture);
2576 if (temp_arch_info != NULL)
2577 bfd_external_binary_architecture = temp_arch_info->arch;
2578 else
2579 fatal (_("architecture %s unknown"), binary_architecture);
2581 else
2583 non_fatal (_("Warning: input target 'binary' required for binary architecture parameter."));
2584 non_fatal (_(" Argument %s ignored"), binary_architecture);
2588 if (preserve_dates)
2589 if (stat (input_filename, & statbuf) < 0)
2590 fatal (_("Cannot stat: %s: %s"), input_filename, strerror (errno));
2592 /* If there is no destination file then create a temp and rename
2593 the result into the input. */
2595 if (output_filename == (char *) NULL)
2597 char *tmpname = make_tempname (input_filename);
2599 copy_file (input_filename, tmpname, input_target, output_target);
2600 if (status == 0)
2602 if (preserve_dates)
2603 set_times (tmpname, &statbuf);
2604 smart_rename (tmpname, input_filename, preserve_dates);
2606 else
2607 unlink (tmpname);
2609 else
2611 copy_file (input_filename, output_filename, input_target, output_target);
2613 if (status == 0 && preserve_dates)
2614 set_times (output_filename, &statbuf);
2617 if (change_warn)
2619 for (p = change_sections; p != NULL; p = p->next)
2621 if (! p->used)
2623 if (p->change_vma != CHANGE_IGNORE)
2625 char buff [20];
2627 sprintf_vma (buff, p->vma_val);
2629 /* xgettext:c-format */
2630 non_fatal (_("%s %s%c0x%s never used"),
2631 "--change-section-vma",
2632 p->name,
2633 p->change_vma == CHANGE_SET ? '=' : '+',
2634 buff);
2637 if (p->change_lma != CHANGE_IGNORE)
2639 char buff [20];
2641 sprintf_vma (buff, p->lma_val);
2643 /* xgettext:c-format */
2644 non_fatal (_("%s %s%c0x%s never used"),
2645 "--change-section-lma",
2646 p->name,
2647 p->change_lma == CHANGE_SET ? '=' : '+',
2648 buff);
2654 return 0;
2657 int main PARAMS ((int, char **));
2660 main (argc, argv)
2661 int argc;
2662 char *argv[];
2664 #if defined (HAVE_SETLOCALE) && defined (HAVE_LC_MESSAGES)
2665 setlocale (LC_MESSAGES, "");
2666 #endif
2667 #if defined (HAVE_SETLOCALE)
2668 setlocale (LC_CTYPE, "");
2669 #endif
2670 bindtextdomain (PACKAGE, LOCALEDIR);
2671 textdomain (PACKAGE);
2673 program_name = argv[0];
2674 xmalloc_set_program_name (program_name);
2676 START_PROGRESS (program_name, 0);
2678 strip_symbols = STRIP_UNDEF;
2679 discard_locals = LOCALS_UNDEF;
2681 bfd_init ();
2682 set_default_bfd_target ();
2684 if (is_strip < 0)
2686 int i = strlen (program_name);
2687 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
2688 /* Drop the .exe suffix, if any. */
2689 if (i > 4 && FILENAME_CMP (program_name + i - 4, ".exe") == 0)
2691 i -= 4;
2692 program_name[i] = '\0';
2694 #endif
2695 is_strip = (i >= 5 && FILENAME_CMP (program_name + i - 5, "strip") == 0);
2698 if (is_strip)
2699 strip_main (argc, argv);
2700 else
2701 copy_main (argc, argv);
2703 END_PROGRESS (program_name);
2705 return status;