Initial bulk commit for "Git on MSys"
[msysgit/historical-msysgit.git] / mingw / man / man1 / objcopy.1
blob7b542b5f4a3537f2701936735681f684fcb42710
1 .\" Automatically generated by Pod::Man version 1.15
2 .\" Thu Jan 19 19:58:14 2006
3 .\"
4 .\" Standard preamble:
5 .\" ======================================================================
6 .de Sh \" Subsection heading
7 .br
8 .if t .Sp
9 .ne 5
10 .PP
11 \fB\\$1\fR
12 .PP
14 .de Sp \" Vertical space (when we can't use .PP)
15 .if t .sp .5v
16 .if n .sp
18 .de Ip \" List item
19 .br
20 .ie \\n(.$>=3 .ne \\$3
21 .el .ne 3
22 .IP "\\$1" \\$2
24 .de Vb \" Begin verbatim text
25 .ft CW
26 .nf
27 .ne \\$1
29 .de Ve \" End verbatim text
30 .ft R
32 .fi
34 .\" Set up some character translations and predefined strings.  \*(-- will
35 .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left
36 .\" double quote, and \*(R" will give a right double quote.  | will give a
37 .\" real vertical bar.  \*(C+ will give a nicer C++.  Capital omega is used
38 .\" to do unbreakable dashes and therefore won't be available.  \*(C` and
39 .\" \*(C' expand to `' in nroff, nothing in troff, for use with C<>
40 .tr \(*W-|\(bv\*(Tr
41 .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p'
42 .ie n \{\
43 .    ds -- \(*W-
44 .    ds PI pi
45 .    if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch
46 .    if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\"  diablo 12 pitch
47 .    ds L" ""
48 .    ds R" ""
49 .    ds C` ""
50 .    ds C' ""
51 'br\}
52 .el\{\
53 .    ds -- \|\(em\|
54 .    ds PI \(*p
55 .    ds L" ``
56 .    ds R" ''
57 'br\}
58 .\"
59 .\" If the F register is turned on, we'll generate index entries on stderr
60 .\" for titles (.TH), headers (.SH), subsections (.Sh), items (.Ip), and
61 .\" index entries marked with X<> in POD.  Of course, you'll have to process
62 .\" the output yourself in some meaningful fashion.
63 .if \nF \{\
64 .    de IX
65 .    tm Index:\\$1\t\\n%\t"\\$2"
67 .    nr % 0
68 .    rr F
69 .\}
70 .\"
71 .\" For nroff, turn off justification.  Always turn off hyphenation; it
72 .\" makes way too many mistakes in technical documents.
73 .hy 0
74 .\"
75 .\" Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2).
76 .\" Fear.  Run.  Save yourself.  No user-serviceable parts.
77 .bd B 3
78 .    \" fudge factors for nroff and troff
79 .if n \{\
80 .    ds #H 0
81 .    ds #V .8m
82 .    ds #F .3m
83 .    ds #[ \f1
84 .    ds #] \fP
85 .\}
86 .if t \{\
87 .    ds #H ((1u-(\\\\n(.fu%2u))*.13m)
88 .    ds #V .6m
89 .    ds #F 0
90 .    ds #[ \&
91 .    ds #] \&
92 .\}
93 .    \" simple accents for nroff and troff
94 .if n \{\
95 .    ds ' \&
96 .    ds ` \&
97 .    ds ^ \&
98 .    ds , \&
99 .    ds ~ ~
100 .    ds /
102 .if t \{\
103 .    ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u"
104 .    ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u'
105 .    ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u'
106 .    ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u'
107 .    ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u'
108 .    ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u'
110 .    \" troff and (daisy-wheel) nroff accents
111 .ds : \\k:\h'-(\\n(.wu*8/10-\*(#H+.1m+\*(#F)'\v'-\*(#V'\z.\h'.2m+\*(#F'.\h'|\\n:u'\v'\*(#V'
112 .ds 8 \h'\*(#H'\(*b\h'-\*(#H'
113 .ds o \\k:\h'-(\\n(.wu+\w'\(de'u-\*(#H)/2u'\v'-.3n'\*(#[\z\(de\v'.3n'\h'|\\n:u'\*(#]
114 .ds d- \h'\*(#H'\(pd\h'-\w'~'u'\v'-.25m'\f2\(hy\fP\v'.25m'\h'-\*(#H'
115 .ds D- D\\k:\h'-\w'D'u'\v'-.11m'\z\(hy\v'.11m'\h'|\\n:u'
116 .ds th \*(#[\v'.3m'\s+1I\s-1\v'-.3m'\h'-(\w'I'u*2/3)'\s-1o\s+1\*(#]
117 .ds Th \*(#[\s+2I\s-2\h'-\w'I'u*3/5'\v'-.3m'o\v'.3m'\*(#]
118 .ds ae a\h'-(\w'a'u*4/10)'e
119 .ds Ae A\h'-(\w'A'u*4/10)'E
120 .    \" corrections for vroff
121 .if v .ds ~ \\k:\h'-(\\n(.wu*9/10-\*(#H)'\s-2\u~\d\s+2\h'|\\n:u'
122 .if v .ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'\v'-.4m'^\v'.4m'\h'|\\n:u'
123 .    \" for low resolution devices (crt and lpr)
124 .if \n(.H>23 .if \n(.V>19 \
126 .    ds : e
127 .    ds 8 ss
128 .    ds o a
129 .    ds d- d\h'-1'\(ga
130 .    ds D- D\h'-1'\(hy
131 .    ds th \o'bp'
132 .    ds Th \o'LP'
133 .    ds ae ae
134 .    ds Ae AE
136 .rm #[ #] #H #V #F C
137 .\" ======================================================================
139 .IX Title "OBJCOPY 1"
140 .TH OBJCOPY 1 "binutils-2.16.91" "2006-01-19" "GNU Development Tools"
142 .SH "NAME"
143 objcopy \- copy and translate object files
144 .SH "SYNOPSIS"
145 .IX Header "SYNOPSIS"
146 objcopy [\fB\-F\fR \fIbfdname\fR|\fB\*(--target=\fR\fIbfdname\fR]
147         [\fB\-I\fR \fIbfdname\fR|\fB\*(--input-target=\fR\fIbfdname\fR]
148         [\fB\-O\fR \fIbfdname\fR|\fB\*(--output-target=\fR\fIbfdname\fR]
149         [\fB\-B\fR \fIbfdarch\fR|\fB\*(--binary-architecture=\fR\fIbfdarch\fR]
150         [\fB\-S\fR|\fB\*(--strip-all\fR]
151         [\fB\-g\fR|\fB\*(--strip-debug\fR]
152         [\fB\-K\fR \fIsymbolname\fR|\fB\*(--keep-symbol=\fR\fIsymbolname\fR]
153         [\fB\-N\fR \fIsymbolname\fR|\fB\*(--strip-symbol=\fR\fIsymbolname\fR]
154         [\fB\*(--strip-unneeded-symbol=\fR\fIsymbolname\fR]
155         [\fB\-G\fR \fIsymbolname\fR|\fB\*(--keep-global-symbol=\fR\fIsymbolname\fR]
156         [\fB\-L\fR \fIsymbolname\fR|\fB\*(--localize-symbol=\fR\fIsymbolname\fR]
157         [\fB\*(--globalize-symbol=\fR\fIsymbolname\fR]
158         [\fB\-W\fR \fIsymbolname\fR|\fB\*(--weaken-symbol=\fR\fIsymbolname\fR]
159         [\fB\-w\fR|\fB\*(--wildcard\fR]
160         [\fB\-x\fR|\fB\*(--discard-all\fR]
161         [\fB\-X\fR|\fB\*(--discard-locals\fR]
162         [\fB\-b\fR \fIbyte\fR|\fB\*(--byte=\fR\fIbyte\fR]
163         [\fB\-i\fR \fIinterleave\fR|\fB\*(--interleave=\fR\fIinterleave\fR]
164         [\fB\-j\fR \fIsectionname\fR|\fB\*(--only-section=\fR\fIsectionname\fR]
165         [\fB\-R\fR \fIsectionname\fR|\fB\*(--remove-section=\fR\fIsectionname\fR]
166         [\fB\-p\fR|\fB\*(--preserve-dates\fR]
167         [\fB\*(--debugging\fR]
168         [\fB\*(--gap-fill=\fR\fIval\fR]
169         [\fB\*(--pad-to=\fR\fIaddress\fR]
170         [\fB\*(--set-start=\fR\fIval\fR]
171         [\fB\*(--adjust-start=\fR\fIincr\fR]
172         [\fB\*(--change-addresses=\fR\fIincr\fR]
173         [\fB\*(--change-section-address\fR \fIsection\fR{=,+,\-}\fIval\fR]
174         [\fB\*(--change-section-lma\fR \fIsection\fR{=,+,\-}\fIval\fR]
175         [\fB\*(--change-section-vma\fR \fIsection\fR{=,+,\-}\fIval\fR]
176         [\fB\*(--change-warnings\fR] [\fB\*(--no-change-warnings\fR]
177         [\fB\*(--set-section-flags\fR \fIsection\fR=\fIflags\fR]
178         [\fB\*(--add-section\fR \fIsectionname\fR=\fIfilename\fR]
179         [\fB\*(--rename-section\fR \fIoldname\fR=\fInewname\fR[,\fIflags\fR]]
180         [\fB\*(--change-leading-char\fR] [\fB\*(--remove-leading-char\fR]
181         [\fB\*(--srec-len=\fR\fIival\fR] [\fB\*(--srec-forceS3\fR]
182         [\fB\*(--redefine-sym\fR \fIold\fR=\fInew\fR]
183         [\fB\*(--redefine-syms=\fR\fIfilename\fR]
184         [\fB\*(--weaken\fR]
185         [\fB\*(--keep-symbols=\fR\fIfilename\fR]
186         [\fB\*(--strip-symbols=\fR\fIfilename\fR]
187         [\fB\*(--strip-unneeded-symbols=\fR\fIfilename\fR]
188         [\fB\*(--keep-global-symbols=\fR\fIfilename\fR]
189         [\fB\*(--localize-symbols=\fR\fIfilename\fR]
190         [\fB\*(--globalize-symbols=\fR\fIfilename\fR]
191         [\fB\*(--weaken-symbols=\fR\fIfilename\fR]
192         [\fB\*(--alt-machine-code=\fR\fIindex\fR]
193         [\fB\*(--prefix-symbols=\fR\fIstring\fR]
194         [\fB\*(--prefix-sections=\fR\fIstring\fR]
195         [\fB\*(--prefix-alloc-sections=\fR\fIstring\fR]
196         [\fB\*(--add-gnu-debuglink=\fR\fIpath-to-file\fR]
197         [\fB\*(--keep-file-symbols\fR]
198         [\fB\*(--only-keep-debug\fR]
199         [\fB\*(--writable-text\fR]
200         [\fB\*(--readonly-text\fR]
201         [\fB\*(--pure\fR]
202         [\fB\*(--impure\fR]
203         [\fB\-v\fR|\fB\*(--verbose\fR]
204         [\fB\-V\fR|\fB\*(--version\fR]  
205         [\fB\*(--help\fR] [\fB\*(--info\fR]
206         \fIinfile\fR [\fIoutfile\fR]
207 .SH "DESCRIPTION"
208 .IX Header "DESCRIPTION"
209 The \s-1GNU\s0 \fBobjcopy\fR utility copies the contents of an object
210 file to another.  \fBobjcopy\fR uses the \s-1GNU\s0 \s-1BFD\s0 Library to
211 read and write the object files.  It can write the destination object
212 file in a format different from that of the source object file.  The
213 exact behavior of \fBobjcopy\fR is controlled by command-line options.
214 Note that \fBobjcopy\fR should be able to copy a fully linked file
215 between any two formats. However, copying a relocatable object file
216 between any two formats may not work as expected.
218 \&\fBobjcopy\fR creates temporary files to do its translations and
219 deletes them afterward.  \fBobjcopy\fR uses \s-1BFD\s0 to do all its
220 translation work; it has access to all the formats described in \s-1BFD\s0
221 and thus is able to recognize most formats without being told
222 explicitly.  
224 \&\fBobjcopy\fR can be used to generate S-records by using an output
225 target of \fBsrec\fR (e.g., use \fB\-O srec\fR).
227 \&\fBobjcopy\fR can be used to generate a raw binary file by using an
228 output target of \fBbinary\fR (e.g., use \fB\-O binary\fR).  When
229 \&\fBobjcopy\fR generates a raw binary file, it will essentially produce
230 a memory dump of the contents of the input object file.  All symbols and
231 relocation information will be discarded.  The memory dump will start at
232 the load address of the lowest section copied into the output file.
234 When generating an S-record or a raw binary file, it may be helpful to
235 use \fB\-S\fR to remove sections containing debugging information.  In
236 some cases \fB\-R\fR will be useful to remove sections which contain
237 information that is not needed by the binary file.
239 Note\-\--\fBobjcopy\fR is not able to change the endianness of its input
240 files.  If the input format has an endianness (some formats do not),
241 \&\fBobjcopy\fR can only copy the inputs into file formats that have the
242 same endianness or which have no endianness (e.g., \fBsrec\fR).
243 .SH "OPTIONS"
244 .IX Header "OPTIONS"
245 .Ip "\fIinfile\fR" 4
246 .IX Item "infile"
247 .PD 0
248 .Ip "\fIoutfile\fR" 4
249 .IX Item "outfile"
251 The input and output files, respectively.
252 If you do not specify \fIoutfile\fR, \fBobjcopy\fR creates a
253 temporary file and destructively renames the result with
254 the name of \fIinfile\fR.
255 .Ip "\fB\-I\fR \fIbfdname\fR" 4
256 .IX Item "-I bfdname"
257 .PD 0
258 .Ip "\fB\*(--input-target=\fR\fIbfdname\fR" 4
259 .IX Item "input-target=bfdname"
261 Consider the source file's object format to be \fIbfdname\fR, rather than
262 attempting to deduce it.  
263 .Ip "\fB\-O\fR \fIbfdname\fR" 4
264 .IX Item "-O bfdname"
265 .PD 0
266 .Ip "\fB\*(--output-target=\fR\fIbfdname\fR" 4
267 .IX Item "output-target=bfdname"
269 Write the output file using the object format \fIbfdname\fR.
270 .Ip "\fB\-F\fR \fIbfdname\fR" 4
271 .IX Item "-F bfdname"
272 .PD 0
273 .Ip "\fB\*(--target=\fR\fIbfdname\fR" 4
274 .IX Item "target=bfdname"
276 Use \fIbfdname\fR as the object format for both the input and the output
277 file; i.e., simply transfer data from source to destination with no
278 translation.  
279 .Ip "\fB\-B\fR \fIbfdarch\fR" 4
280 .IX Item "-B bfdarch"
281 .PD 0
282 .Ip "\fB\*(--binary-architecture=\fR\fIbfdarch\fR" 4
283 .IX Item "binary-architecture=bfdarch"
285 Useful when transforming a raw binary input file into an object file.
286 In this case the output architecture can be set to \fIbfdarch\fR. This
287 option will be ignored if the input file has a known \fIbfdarch\fR. You
288 can access this binary data inside a program by referencing the special
289 symbols that are created by the conversion process.  These symbols are
290 called _binary_\fIobjfile\fR_start, _binary_\fIobjfile\fR_end and
291 _binary_\fIobjfile\fR_size.  e.g. you can transform a picture file into
292 an object file and then access it in your code using these symbols. 
293 .Ip "\fB\-j\fR \fIsectionname\fR" 4
294 .IX Item "-j sectionname"
295 .PD 0
296 .Ip "\fB\*(--only-section=\fR\fIsectionname\fR" 4
297 .IX Item "only-section=sectionname"
299 Copy only the named section from the input file to the output file.
300 This option may be given more than once.  Note that using this option
301 inappropriately may make the output file unusable.
302 .Ip "\fB\-R\fR \fIsectionname\fR" 4
303 .IX Item "-R sectionname"
304 .PD 0
305 .Ip "\fB\*(--remove-section=\fR\fIsectionname\fR" 4
306 .IX Item "remove-section=sectionname"
308 Remove any section named \fIsectionname\fR from the output file.  This
309 option may be given more than once.  Note that using this option
310 inappropriately may make the output file unusable.
311 .Ip "\fB\-S\fR" 4
312 .IX Item "-S"
313 .PD 0
314 .Ip "\fB\*(--strip-all\fR" 4
315 .IX Item "strip-all"
317 Do not copy relocation and symbol information from the source file.
318 .Ip "\fB\-g\fR" 4
319 .IX Item "-g"
320 .PD 0
321 .Ip "\fB\*(--strip-debug\fR" 4
322 .IX Item "strip-debug"
324 Do not copy debugging symbols or sections from the source file.
325 .Ip "\fB\*(--strip-unneeded\fR" 4
326 .IX Item "strip-unneeded"
327 Strip all symbols that are not needed for relocation processing.
328 .Ip "\fB\-K\fR \fIsymbolname\fR" 4
329 .IX Item "-K symbolname"
330 .PD 0
331 .Ip "\fB\*(--keep-symbol=\fR\fIsymbolname\fR" 4
332 .IX Item "keep-symbol=symbolname"
334 When stripping symbols, keep symbol \fIsymbolname\fR even if it would
335 normally be stripped.  This option may be given more than once.
336 .Ip "\fB\-N\fR \fIsymbolname\fR" 4
337 .IX Item "-N symbolname"
338 .PD 0
339 .Ip "\fB\*(--strip-symbol=\fR\fIsymbolname\fR" 4
340 .IX Item "strip-symbol=symbolname"
342 Do not copy symbol \fIsymbolname\fR from the source file.  This option
343 may be given more than once.
344 .Ip "\fB\*(--strip-unneeded-symbol=\fR\fIsymbolname\fR" 4
345 .IX Item "strip-unneeded-symbol=symbolname"
346 Do not copy symbol \fIsymbolname\fR from the source file unless it is needed
347 by a relocation.  This option may be given more than once.
348 .Ip "\fB\-G\fR \fIsymbolname\fR" 4
349 .IX Item "-G symbolname"
350 .PD 0
351 .Ip "\fB\*(--keep-global-symbol=\fR\fIsymbolname\fR" 4
352 .IX Item "keep-global-symbol=symbolname"
354 Keep only symbol \fIsymbolname\fR global.  Make all other symbols local
355 to the file, so that they are not visible externally.  This option may
356 be given more than once.
357 .Ip "\fB\-L\fR \fIsymbolname\fR" 4
358 .IX Item "-L symbolname"
359 .PD 0
360 .Ip "\fB\*(--localize-symbol=\fR\fIsymbolname\fR" 4
361 .IX Item "localize-symbol=symbolname"
363 Make symbol \fIsymbolname\fR local to the file, so that it is not
364 visible externally.  This option may be given more than once.
365 .Ip "\fB\-W\fR \fIsymbolname\fR" 4
366 .IX Item "-W symbolname"
367 .PD 0
368 .Ip "\fB\*(--weaken-symbol=\fR\fIsymbolname\fR" 4
369 .IX Item "weaken-symbol=symbolname"
371 Make symbol \fIsymbolname\fR weak. This option may be given more than once.
372 .Ip "\fB\*(--globalize-symbol=\fR\fIsymbolname\fR" 4
373 .IX Item "globalize-symbol=symbolname"
374 Give symbol \fIsymbolname\fR global scoping so that it is visible
375 outside of the file in which it is defined.  This option may be given
376 more than once.
377 .Ip "\fB\-w\fR" 4
378 .IX Item "-w"
379 .PD 0
380 .Ip "\fB\*(--wildcard\fR" 4
381 .IX Item "wildcard"
383 Permit regular expressions in \fIsymbolname\fRs used in other command
384 line options.  The question mark (?), asterisk (*), backslash (\e) and
385 square brackets ([]) operators can be used anywhere in the symbol
386 name.  If the first character of the symbol name is the exclamation
387 point (!) then the sense of the switch is reversed for that symbol.
388 For example:
390 .Vb 1
391 \&          -w -W !foo -W fo*
393 would cause objcopy to weaken all symbols that start with \*(L"fo\*(R"
394 except for the symbol \*(L"foo\*(R".
395 .Ip "\fB\-x\fR" 4
396 .IX Item "-x"
397 .PD 0
398 .Ip "\fB\*(--discard-all\fR" 4
399 .IX Item "discard-all"
401 Do not copy non-global symbols from the source file.
402 .Ip "\fB\-X\fR" 4
403 .IX Item "-X"
404 .PD 0
405 .Ip "\fB\*(--discard-locals\fR" 4
406 .IX Item "discard-locals"
408 Do not copy compiler-generated local symbols.
409 (These usually start with \fBL\fR or \fB.\fR.)
410 .Ip "\fB\-b\fR \fIbyte\fR" 4
411 .IX Item "-b byte"
412 .PD 0
413 .Ip "\fB\*(--byte=\fR\fIbyte\fR" 4
414 .IX Item "byte=byte"
416 Keep only every \fIbyte\fRth byte of the input file (header data is not
417 affected).  \fIbyte\fR can be in the range from 0 to \fIinterleave\fR\-1,
418 where \fIinterleave\fR is given by the \fB\-i\fR or \fB\*(--interleave\fR
419 option, or the default of 4.  This option is useful for creating files
420 to program \s-1ROM\s0.  It is typically used with an \f(CW\*(C`srec\*(C'\fR output
421 target.
422 .Ip "\fB\-i\fR \fIinterleave\fR" 4
423 .IX Item "-i interleave"
424 .PD 0
425 .Ip "\fB\*(--interleave=\fR\fIinterleave\fR" 4
426 .IX Item "interleave=interleave"
428 Only copy one out of every \fIinterleave\fR bytes.  Select which byte to
429 copy with the \fB\-b\fR or \fB\*(--byte\fR option.  The default is 4.
430 \&\fBobjcopy\fR ignores this option if you do not specify either \fB\-b\fR or
431 \&\fB\*(--byte\fR.
432 .Ip "\fB\-p\fR" 4
433 .IX Item "-p"
434 .PD 0
435 .Ip "\fB\*(--preserve-dates\fR" 4
436 .IX Item "preserve-dates"
438 Set the access and modification dates of the output file to be the same
439 as those of the input file.
440 .Ip "\fB\*(--debugging\fR" 4
441 .IX Item "debugging"
442 Convert debugging information, if possible.  This is not the default
443 because only certain debugging formats are supported, and the
444 conversion process can be time consuming.
445 .Ip "\fB\*(--gap-fill\fR \fIval\fR" 4
446 .IX Item "gap-fill val"
447 Fill gaps between sections with \fIval\fR.  This operation applies to
448 the \fIload address\fR (\s-1LMA\s0) of the sections.  It is done by increasing
449 the size of the section with the lower address, and filling in the extra
450 space created with \fIval\fR.
451 .Ip "\fB\*(--pad-to\fR \fIaddress\fR" 4
452 .IX Item "pad-to address"
453 Pad the output file up to the load address \fIaddress\fR.  This is
454 done by increasing the size of the last section.  The extra space is
455 filled in with the value specified by \fB\*(--gap-fill\fR (default zero).
456 .Ip "\fB\*(--set-start\fR \fIval\fR" 4
457 .IX Item "set-start val"
458 Set the start address of the new file to \fIval\fR.  Not all object file
459 formats support setting the start address.
460 .Ip "\fB\*(--change-start\fR \fIincr\fR" 4
461 .IX Item "change-start incr"
462 .PD 0
463 .Ip "\fB\*(--adjust-start\fR \fIincr\fR" 4
464 .IX Item "adjust-start incr"
466 Change the start address by adding \fIincr\fR.  Not all object file
467 formats support setting the start address.
468 .Ip "\fB\*(--change-addresses\fR \fIincr\fR" 4
469 .IX Item "change-addresses incr"
470 .PD 0
471 .Ip "\fB\*(--adjust-vma\fR \fIincr\fR" 4
472 .IX Item "adjust-vma incr"
474 Change the \s-1VMA\s0 and \s-1LMA\s0 addresses of all sections, as well as the start
475 address, by adding \fIincr\fR.  Some object file formats do not permit
476 section addresses to be changed arbitrarily.  Note that this does not
477 relocate the sections; if the program expects sections to be loaded at a
478 certain address, and this option is used to change the sections such
479 that they are loaded at a different address, the program may fail. 
480 .Ip "\fB\*(--change-section-address\fR \fIsection\fR\fB{=,+,\-}\fR\fIval\fR" 4
481 .IX Item "change-section-address section{=,+,-}val"
482 .PD 0
483 .Ip "\fB\*(--adjust-section-vma\fR \fIsection\fR\fB{=,+,\-}\fR\fIval\fR" 4
484 .IX Item "adjust-section-vma section{=,+,-}val"
486 Set or change both the \s-1VMA\s0 address and the \s-1LMA\s0 address of the named
487 \&\fIsection\fR.  If \fB=\fR is used, the section address is set to
488 \&\fIval\fR.  Otherwise, \fIval\fR is added to or subtracted from the
489 section address.  See the comments under \fB\*(--change-addresses\fR,
490 above. If \fIsection\fR does not exist in the input file, a warning will
491 be issued, unless \fB\*(--no-change-warnings\fR is used.
492 .Ip "\fB\*(--change-section-lma\fR \fIsection\fR\fB{=,+,\-}\fR\fIval\fR" 4
493 .IX Item "change-section-lma section{=,+,-}val"
494 Set or change the \s-1LMA\s0 address of the named \fIsection\fR.  The \s-1LMA\s0
495 address is the address where the section will be loaded into memory at
496 program load time.  Normally this is the same as the \s-1VMA\s0 address, which
497 is the address of the section at program run time, but on some systems,
498 especially those where a program is held in \s-1ROM\s0, the two can be
499 different.  If \fB=\fR is used, the section address is set to
500 \&\fIval\fR.  Otherwise, \fIval\fR is added to or subtracted from the
501 section address.  See the comments under \fB\*(--change-addresses\fR,
502 above.  If \fIsection\fR does not exist in the input file, a warning
503 will be issued, unless \fB\*(--no-change-warnings\fR is used.  
504 .Ip "\fB\*(--change-section-vma\fR \fIsection\fR\fB{=,+,\-}\fR\fIval\fR" 4
505 .IX Item "change-section-vma section{=,+,-}val"
506 Set or change the \s-1VMA\s0 address of the named \fIsection\fR.  The \s-1VMA\s0
507 address is the address where the section will be located once the
508 program has started executing.  Normally this is the same as the \s-1LMA\s0
509 address, which is the address where the section will be loaded into
510 memory, but on some systems, especially those where a program is held in
511 \&\s-1ROM\s0, the two can be different.  If \fB=\fR is used, the section address
512 is set to \fIval\fR.  Otherwise, \fIval\fR is added to or subtracted
513 from the section address.  See the comments under
514 \&\fB\*(--change-addresses\fR, above.  If \fIsection\fR does not exist in
515 the input file, a warning will be issued, unless
516 \&\fB\*(--no-change-warnings\fR is used.   
517 .Ip "\fB\*(--change-warnings\fR" 4
518 .IX Item "change-warnings"
519 .PD 0
520 .Ip "\fB\*(--adjust-warnings\fR" 4
521 .IX Item "adjust-warnings"
523 If \fB\*(--change-section-address\fR or \fB\*(--change-section-lma\fR or
524 \&\fB\*(--change-section-vma\fR is used, and the named section does not
525 exist, issue a warning.  This is the default. 
526 .Ip "\fB\*(--no-change-warnings\fR" 4
527 .IX Item "no-change-warnings"
528 .PD 0
529 .Ip "\fB\*(--no-adjust-warnings\fR" 4
530 .IX Item "no-adjust-warnings"
532 Do not issue a warning if \fB\*(--change-section-address\fR or
533 \&\fB\*(--adjust-section-lma\fR or \fB\*(--adjust-section-vma\fR is used, even
534 if the named section does not exist. 
535 .Ip "\fB\*(--set-section-flags\fR \fIsection\fR\fB=\fR\fIflags\fR" 4
536 .IX Item "set-section-flags section=flags"
537 Set the flags for the named section.  The \fIflags\fR argument is a
538 comma separated string of flag names.  The recognized names are
539 \&\fBalloc\fR, \fBcontents\fR, \fBload\fR, \fBnoload\fR,
540 \&\fBreadonly\fR, \fBcode\fR, \fBdata\fR, \fBrom\fR, \fBshare\fR, and
541 \&\fBdebug\fR.  You can set the \fBcontents\fR flag for a section which
542 does not have contents, but it is not meaningful to clear the
543 \&\fBcontents\fR flag of a section which does have contents\*(--just remove
544 the section instead.  Not all flags are meaningful for all object file
545 formats.
546 .Ip "\fB\*(--add-section\fR \fIsectionname\fR\fB=\fR\fIfilename\fR" 4
547 .IX Item "add-section sectionname=filename"
548 Add a new section named \fIsectionname\fR while copying the file.  The
549 contents of the new section are taken from the file \fIfilename\fR.  The
550 size of the section will be the size of the file.  This option only
551 works on file formats which can support sections with arbitrary names.
552 .Ip "\fB\*(--rename-section\fR \fIoldname\fR\fB=\fR\fInewname\fR\fB[,\fR\fIflags\fR\fB]\fR" 4
553 .IX Item "rename-section oldname=newname[,flags]"
554 Rename a section from \fIoldname\fR to \fInewname\fR, optionally
555 changing the section's flags to \fIflags\fR in the process.  This has
556 the advantage over usng a linker script to perform the rename in that
557 the output stays as an object file and does not become a linked
558 executable.
560 This option is particularly helpful when the input format is binary,
561 since this will always create a section called .data.  If for example,
562 you wanted instead to create a section called .rodata containing binary
563 data you could use the following command line to achieve it:
565 .Vb 3
566 \&          objcopy -I binary -O <output_format> -B <architecture> \e
567 \&           --rename-section .data=.rodata,alloc,load,readonly,data,contents \e
568 \&           <input_binary_file> <output_object_file>
570 .Ip "\fB\*(--change-leading-char\fR" 4
571 .IX Item "change-leading-char"
572 Some object file formats use special characters at the start of
573 symbols.  The most common such character is underscore, which compilers
574 often add before every symbol.  This option tells \fBobjcopy\fR to
575 change the leading character of every symbol when it converts between
576 object file formats.  If the object file formats use the same leading
577 character, this option has no effect.  Otherwise, it will add a
578 character, or remove a character, or change a character, as
579 appropriate.
580 .Ip "\fB\*(--remove-leading-char\fR" 4
581 .IX Item "remove-leading-char"
582 If the first character of a global symbol is a special symbol leading
583 character used by the object file format, remove the character.  The
584 most common symbol leading character is underscore.  This option will
585 remove a leading underscore from all global symbols.  This can be useful
586 if you want to link together objects of different file formats with
587 different conventions for symbol names.  This is different from
588 \&\fB\*(--change-leading-char\fR because it always changes the symbol name
589 when appropriate, regardless of the object file format of the output
590 file.
591 .Ip "\fB\*(--srec-len=\fR\fIival\fR" 4
592 .IX Item "srec-len=ival"
593 Meaningful only for srec output.  Set the maximum length of the Srecords
594 being produced to \fIival\fR.  This length covers both address, data and
595 crc fields.
596 .Ip "\fB\*(--srec-forceS3\fR" 4
597 .IX Item "srec-forceS3"
598 Meaningful only for srec output.  Avoid generation of S1/S2 records, 
599 creating S3\-only record format.
600 .Ip "\fB\*(--redefine-sym\fR \fIold\fR\fB=\fR\fInew\fR" 4
601 .IX Item "redefine-sym old=new"
602 Change the name of a symbol \fIold\fR, to \fInew\fR.  This can be useful
603 when one is trying link two things together for which you have no
604 source, and there are name collisions.
605 .Ip "\fB\*(--redefine-syms=\fR\fIfilename\fR" 4
606 .IX Item "redefine-syms=filename"
607 Apply \fB\*(--redefine-sym\fR to each symbol pair "\fIold\fR \fInew\fR"
608 listed in the file \fIfilename\fR.  \fIfilename\fR is simply a flat file,
609 with one symbol pair per line.  Line comments may be introduced by the hash
610 character.  This option may be given more than once.
611 .Ip "\fB\*(--weaken\fR" 4
612 .IX Item "weaken"
613 Change all global symbols in the file to be weak.  This can be useful
614 when building an object which will be linked against other objects using
615 the \fB\-R\fR option to the linker.  This option is only effective when
616 using an object file format which supports weak symbols.
617 .Ip "\fB\*(--keep-symbols=\fR\fIfilename\fR" 4
618 .IX Item "keep-symbols=filename"
619 Apply \fB\*(--keep-symbol\fR option to each symbol listed in the file
620 \&\fIfilename\fR.  \fIfilename\fR is simply a flat file, with one symbol
621 name per line.  Line comments may be introduced by the hash character.
622 This option may be given more than once.
623 .Ip "\fB\*(--strip-symbols=\fR\fIfilename\fR" 4
624 .IX Item "strip-symbols=filename"
625 Apply \fB\*(--strip-symbol\fR option to each symbol listed in the file
626 \&\fIfilename\fR.  \fIfilename\fR is simply a flat file, with one symbol
627 name per line.  Line comments may be introduced by the hash character.
628 This option may be given more than once.
629 .Ip "\fB\*(--strip-unneeded-symbols=\fR\fIfilename\fR" 4
630 .IX Item "strip-unneeded-symbols=filename"
631 Apply \fB\*(--strip-unneeded-symbol\fR option to each symbol listed in
632 the file \fIfilename\fR.  \fIfilename\fR is simply a flat file, with one
633 symbol name per line.  Line comments may be introduced by the hash
634 character.  This option may be given more than once.
635 .Ip "\fB\*(--keep-global-symbols=\fR\fIfilename\fR" 4
636 .IX Item "keep-global-symbols=filename"
637 Apply \fB\*(--keep-global-symbol\fR option to each symbol listed in the
638 file \fIfilename\fR.  \fIfilename\fR is simply a flat file, with one
639 symbol name per line.  Line comments may be introduced by the hash
640 character.  This option may be given more than once.
641 .Ip "\fB\*(--localize-symbols=\fR\fIfilename\fR" 4
642 .IX Item "localize-symbols=filename"
643 Apply \fB\*(--localize-symbol\fR option to each symbol listed in the file
644 \&\fIfilename\fR.  \fIfilename\fR is simply a flat file, with one symbol
645 name per line.  Line comments may be introduced by the hash character.
646 This option may be given more than once.
647 .Ip "\fB\*(--globalize-symbols=\fR\fIfilename\fR" 4
648 .IX Item "globalize-symbols=filename"
649 Apply \fB\*(--globalize-symbol\fR option to each symbol listed in the file
650 \&\fIfilename\fR.  \fIfilename\fR is simply a flat file, with one symbol
651 name per line.  Line comments may be introduced by the hash character.
652 This option may be given more than once.
653 .Ip "\fB\*(--weaken-symbols=\fR\fIfilename\fR" 4
654 .IX Item "weaken-symbols=filename"
655 Apply \fB\*(--weaken-symbol\fR option to each symbol listed in the file
656 \&\fIfilename\fR.  \fIfilename\fR is simply a flat file, with one symbol
657 name per line.  Line comments may be introduced by the hash character.
658 This option may be given more than once.
659 .Ip "\fB\*(--alt-machine-code=\fR\fIindex\fR" 4
660 .IX Item "alt-machine-code=index"
661 If the output architecture has alternate machine codes, use the
662 \&\fIindex\fRth code instead of the default one.  This is useful in case
663 a machine is assigned an official code and the tool-chain adopts the 
664 new code, but other applications still depend on the original code
665 being used.
666 .Ip "\fB\*(--writable-text\fR" 4
667 .IX Item "writable-text"
668 Mark the output text as writable.  This option isn't meaningful for all
669 object file formats.
670 .Ip "\fB\*(--readonly-text\fR" 4
671 .IX Item "readonly-text"
672 Make the output text write protected.  This option isn't meaningful for all
673 object file formats.
674 .Ip "\fB\*(--pure\fR" 4
675 .IX Item "pure"
676 Mark the output file as demand paged.  This option isn't meaningful for all
677 object file formats.
678 .Ip "\fB\*(--impure\fR" 4
679 .IX Item "impure"
680 Mark the output file as impure.  This option isn't meaningful for all
681 object file formats.
682 .Ip "\fB\*(--prefix-symbols=\fR\fIstring\fR" 4
683 .IX Item "prefix-symbols=string"
684 Prefix all symbols in the output file with \fIstring\fR.
685 .Ip "\fB\*(--prefix-sections=\fR\fIstring\fR" 4
686 .IX Item "prefix-sections=string"
687 Prefix all section names in the output file with \fIstring\fR.
688 .Ip "\fB\*(--prefix-alloc-sections=\fR\fIstring\fR" 4
689 .IX Item "prefix-alloc-sections=string"
690 Prefix all the names of all allocated sections in the output file with
691 \&\fIstring\fR.
692 .Ip "\fB\*(--add-gnu-debuglink=\fR\fIpath-to-file\fR" 4
693 .IX Item "add-gnu-debuglink=path-to-file"
694 Creates a .gnu_debuglink section which contains a reference to \fIpath-to-file\fR
695 and adds it to the output file.
696 .Ip "\fB\*(--keep-file-symbols\fR" 4
697 .IX Item "keep-file-symbols"
698 When stripping a file, perhaps with \fB\*(--strip-debug\fR or
699 \&\fB\*(--strip-unneeded\fR, retain any symbols specifying source file names,
700 which would otherwise get stripped.
701 .Ip "\fB\*(--only-keep-debug\fR" 4
702 .IX Item "only-keep-debug"
703 Strip a file, removing contents of any sections that would not be
704 stripped by \fB\*(--strip-debug\fR and leaving the debugging sections
705 intact.
707 The intention is that this option will be used in conjunction with
708 \&\fB\*(--add-gnu-debuglink\fR to create a two part executable.  One a
709 stripped binary which will occupy less space in \s-1RAM\s0 and in a
710 distribution and the second a debugging information file which is only
711 needed if debugging abilities are required.  The suggested procedure
712 to create these files is as follows:
713 .RS 4
714 .Ip "1.<Link the executable as normal.  Assuming that is is called>" 4
715 .IX Item "1.<Link the executable as normal.  Assuming that is is called>"
716 \&\f(CW\*(C`foo\*(C'\fR then...
717 .if n .Ip "1.<Run \f(CW""""objcopy \-\-only\-keep\-debug foo foo.dbg""""\fR to>" 4
718 .el .Ip "1.<Run \f(CWobjcopy \-\-only\-keep\-debug foo foo.dbg\fR to>" 4
719 .IX Item "1.<Run objcopy --only-keep-debug foo foo.dbg to>"
720 create a file containing the debugging info.
721 .if n .Ip "1.<Run \f(CW""""objcopy \-\-strip\-debug foo""""\fR to create a>" 4
722 .el .Ip "1.<Run \f(CWobjcopy \-\-strip\-debug foo\fR to create a>" 4
723 .IX Item "1.<Run objcopy --strip-debug foo to create a>"
724 stripped executable.
725 .if n .Ip "1.<Run \f(CW""""objcopy \-\-add\-gnu\-debuglink=foo.dbg foo""""\fR>" 4
726 .el .Ip "1.<Run \f(CWobjcopy \-\-add\-gnu\-debuglink=foo.dbg foo\fR>" 4
727 .IX Item "1.<Run objcopy --add-gnu-debuglink=foo.dbg foo>"
728 to add a link to the debugging info into the stripped executable.
730 .RS 4
732 Note \- the choice of \f(CW\*(C`.dbg\*(C'\fR as an extension for the debug info
733 file is arbitrary.  Also the \f(CW\*(C`\-\-only\-keep\-debug\*(C'\fR step is
734 optional.  You could instead do this:
735 .RS 4
737 .Ip "1.<Link the executable as normal.>" 4
738 .IX Item "1.<Link the executable as normal.>"
739 .PD 0
740 .if n .Ip "1.<Copy \f(CW""""foo""""\fR to  \f(CW""""foo.full""""\fR>" 4
741 .el .Ip "1.<Copy \f(CWfoo\fR to  \f(CWfoo.full\fR>" 4
742 .IX Item "1.<Copy foo to  foo.full>"
743 .if n .Ip "1.<Run \f(CW""""objcopy \-\-strip\-debug foo""""\fR>" 4
744 .el .Ip "1.<Run \f(CWobjcopy \-\-strip\-debug foo\fR>" 4
745 .IX Item "1.<Run objcopy --strip-debug foo>"
746 .if n .Ip "1.<Run \f(CW""""objcopy \-\-add\-gnu\-debuglink=foo.full foo""""\fR>" 4
747 .el .Ip "1.<Run \f(CWobjcopy \-\-add\-gnu\-debuglink=foo.full foo\fR>" 4
748 .IX Item "1.<Run objcopy --add-gnu-debuglink=foo.full foo>"
750 .RS 4
753 i.e. the file pointed to by the \fB\*(--add-gnu-debuglink\fR can be the
754 full executable.  It does not have to be a file created by the
755 \&\fB\*(--only-keep-debug\fR switch.
757 .Ip "\fB\-V\fR" 4
758 .IX Item "-V"
759 .PD 0
760 .Ip "\fB\*(--version\fR" 4
761 .IX Item "version"
763 Show the version number of \fBobjcopy\fR.
764 .Ip "\fB\-v\fR" 4
765 .IX Item "-v"
766 .PD 0
767 .Ip "\fB\*(--verbose\fR" 4
768 .IX Item "verbose"
770 Verbose output: list all object files modified.  In the case of
771 archives, \fBobjcopy \-V\fR lists all members of the archive.
772 .Ip "\fB\*(--help\fR" 4
773 .IX Item "help"
774 Show a summary of the options to \fBobjcopy\fR.
775 .Ip "\fB\*(--info\fR" 4
776 .IX Item "info"
777 Display a list showing all architectures and object formats available.
778 .Ip "\fB@\fR\fIfile\fR" 4
779 .IX Item "@file"
780 Read command-line options from \fIfile\fR.  The options read are
781 inserted in place of the original @\fIfile\fR option.  If \fIfile\fR
782 does not exist, or cannot be read, then the option will be treated
783 literally, and not removed.  
785 Options in \fIfile\fR are separated by whitespace.  A whitespace
786 character may be included in an option by surrounding the entire
787 option in either single or double quotes.  Any character (including a
788 backslash) may be included by prefixing the character to be included
789 with a backslash.  The \fIfile\fR may itself contain additional
790 @\fIfile\fR options; any such options will be processed recursively.
791 .SH "SEE ALSO"
792 .IX Header "SEE ALSO"
793 \&\fIld\fR\|(1), \fIobjdump\fR\|(1), and the Info entries for \fIbinutils\fR.
794 .SH "COPYRIGHT"
795 .IX Header "COPYRIGHT"
796 Copyright (c) 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
797 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
799 Permission is granted to copy, distribute and/or modify this document
800 under the terms of the \s-1GNU\s0 Free Documentation License, Version 1.1
801 or any later version published by the Free Software Foundation;
802 with no Invariant Sections, with no Front-Cover Texts, and with no
803 Back-Cover Texts.  A copy of the license is included in the
804 section entitled \*(L"\s-1GNU\s0 Free Documentation License\*(R".