Add the ability for nm to display symbol version information.
[external/binutils.git] / binutils / NEWS
1 -*- text -*-
2
3 * The nm program has a new command lien option (--with-version-strings)
4   which will display a symbol's version information, if any, after the
5   symbol's name.
6
7 * The ARC port of objdump now accepts a -M option to specify the extra
8   instruction class(es) that should be disassembled.
9
10 * The --remove-section option for objcopy and strip now accepts section
11   patterns starting with an exclamation point to indicate a non-matching
12   section.  A non-matching section is removed from the set of sections
13   matched by an earlier --remove-section pattern.
14
15 * The --only-section option for objcopy now accepts section patterns
16   starting with an exclamation point to indicate a non-matching section.
17   A non-matching section is removed from the set of sections matched by
18   an earlier --only-section pattern.
19
20 * New --remove-relocations=SECTIONPATTERN option for objcopy and strip.
21   This option can be used to remove sections containing relocations.
22   The SECTIONPATTERN is the section to which the relocations apply, not
23   the relocation section itself.
24
25 Changes in 2.27:
26
27 * Add a configure option, --enable-64-bit-archive, to force use of a
28   64-bit format when creating an archive symbol index.
29
30 * Add --elf-stt-common= option to objcopy for ELF targets to control
31   whether to convert common symbols to the STT_COMMON type.
32
33 Changes in 2.26:
34
35 * Add option to objcopy to insert new symbols into a file:
36   --add-symbol <name>=[<section>:]<value>[,<flags>]
37
38 * Add support for the ARC EM/HS, and ARC600/700 architectures.
39
40 * Extend objcopy --compress-debug-sections option to support
41   --compress-debug-sections=[none|zlib|zlib-gnu|zlib-gabi] for ELF
42   targets.
43
44 * Add --update-section option to objcopy.
45
46 * Add --output-separator option to strings.
47
48 Changes in 2.25:
49
50 * Add --data option to strings to only print strings in loadable, initialized
51   data sections.  Change the default behaviour to be --all, but add a new
52   configure time option of --disable-default-strings-all to restore the old
53   default behaviour.
54
55 * Add --include-all-whitespace to strings.
56
57 * Add --dump-section option to objcopy.
58
59 * Add support for the Andes NDS32.
60
61 Changes in 2.24:
62
63 * Objcopy now supports wildcard characters in command line options that take
64   section names.
65
66 * Add support for Altera Nios II.
67
68 Changes in 2.23:
69
70 * Add support for the VLE extension to the PowerPC architecture.
71
72 * Add support for x64 Windows target of the delayed-load-library.
73
74 * Add support for the Renesas RL78 architecture.
75
76 Changes in 2.22:
77
78 * Add support for displaying the contents of .debug.macro sections.
79
80 * Add --preprocessor-arg option to windres to specify additional options
81   passed to preprocessor.
82
83 * Add --dwarf-start and --dwarf-end to readelf and objdump.  These are used by
84   the new Emacs mode, see dwarf-mode.el.
85
86 * Add support for the Tilera TILEPro and TILE-Gx architectures.
87
88 changes in 2.21:
89
90 * Add --interleave-width option to objcopy to allowing copying a range of
91   bytes from the input to the output with the --interleave option.
92
93 * Add support for the TMS320C6000 (TI C6X) processor family.
94
95 * Readelf can now display ARM unwind tables (.ARM.exidx / .ARM.extab) using
96   the -u / --unwind option.
97
98 * Add --dyn-syms to readelf to dump dynamic symbol table.
99
100 * A new tool - elfedit - has been added to directly manipulate ELF format
101   binaries.
102
103 * Add to dlltool .def file feature of aliasing PE internal symbol name by
104   '== <ID>' option.
105
106 * Add a new command line option -a / --addresses to addr2line to display the
107   address before function name or source filename.
108
109 * Add a new command line option -p / --pretty-print to addr2line to have
110   a more human readable output.
111
112 * The hppa/som targets can now be compiled on any host.
113
114 Changes in 2.20:
115
116 * Add support for delay importing to dlltool.  Use the --output-delaylib <file>
117   switch to create a delay-import library.  The resulting app will load the dll
118   as soon as the first function is called.  It will link to __delayLoadHelper2()
119   from the static delayimp library, which will import LoadLibraryA and
120   GetProcAddress from kernel32.
121
122 * Add a new command line option, --insn-width=WIDTH, to objdump to specify
123   number of bytes to be displayed on a single line when disassembling
124   instructions.
125
126 * Readelf can now display the relocated contents of a section as a sequence
127   of bytes via the --relocated-dump=<name|number> command line option.
128
129 * The gprof program has been given a new command line option:
130   --external-symbols-table=<filename> which reads in symbols from a specified
131   file.
132
133 * The plugin target has been added to bfd. It can load the same shared objects
134   used by gold and uses them to provide basic support for new file formats.
135
136 * The verilog memory hex dump file format is now supported as an output format
137   for objcopy.
138
139 * Add --file-alignment, --heap, --image-base, --section-alignment,
140   --stack and --subsystem command line options to objcopy, which will
141   set PE optional header.
142
143 * Option --dwarf/-W of objdump is now as flexible as readelf --debug-dump/-w.
144
145 * --as-needed now links in a dynamic library if it satisfies undefined
146   symbols in regular objects, or in other dynamic libraries.  In the
147   latter case the library is not linked if it is found in a DT_NEEDED
148   entry of one of the libraries already linked.
149
150 * Added --prefix=PREFIX and --prefix-strip=LEVEL switches to objdump to
151   add absolute paths for -S.
152
153 * Add new option --use-nul-prefixed-import-tables to dlltool to allow fall-
154   back to old import table generation with null element prefix.
155
156 * Added --identify-strict switch to cause --identify <implib> to
157   report an error when the import library is associated with
158   multiple DLLs.
159
160 * Added --identify <implib> option to dlltool, which determines the
161   name of the DLL associated with the specified <implib>.
162
163 * Support for PowerPC booke64 instructions has been removed.  The assembler no
164   longer accepts -mbooke32 or -mbooke64 and the disassembler no longer accepts
165   -Mbooke32 or -Mbooke64.  Instead, -mbooke and -Mbooke should be used.
166
167 Changes in 2.19:
168
169 * Added -wL switch to dump decoded contents of .debug_line.
170
171 * Added support for "thin" archives which contain pathnames pointing to
172   object files rather than the files themselves and which contain a
173   flattened symbol index for all objects, and archives, which have been
174   added to the archive.
175
176 * Added -F switch to objdump to include file offsets in the disassembly.
177
178 * Added -c switch to readelf to allow string dumps of archive symbol index.
179
180 * Support for SSE5 has been added to the i386 port.
181
182 * Added -p switch to readelf to allow string dumps of sections.
183
184 Changes in 2.18:
185
186 * Resolved 37 coding problems in bfd including static array overruns, null
187   pointer dereferences and use of a malloc buffer after it has been freed, as
188   revealed by static analysis donated by Coverity, Inc. (http://scan.coverity.com).
189
190 * The binutils sources are now released under version 3 of the GNU General
191   Public License.
192
193 * A new tool "windmc" has been added for some targets.  This is a message
194   compiler which attempts to be compatible with the MS version.
195
196 * Add codepage support to the windres tool.  It now supports many new
197   resource types (e.g. MANIFEST, TOOLBAR, etc).  The output generation
198   for binary files is done now via bfd itself.  The endianess problems
199   for different hosts are solved.  Dumps of .res files can now be
200   re-compiled by windres without lossing resources or compilation errors.
201   Some problems on dialog resource translations are corrected.
202
203 * Add --extract-symbol command line option to objcopy, which will
204   strip everything out of an ordinary object file or executable except
205   for its symbol table.  Files containing just symbols can be useful
206   to some OSes.
207
208 Changes in 2.17:
209
210 * Add "-x NAME" to readelf in addition to "-x NUMBER".
211
212 * Add -i and -t switches to cxxfilt.  -i disables the display of implementation
213   specific extra demangling information (if any) and -t disables the demangling
214   of types.
215
216 * Add support for the "@<file>" syntax to the command lines of all tools, so
217   that extra switches can be read from <file>.
218
219 * Add "-W/--dwarf" to objdump to display the contents of the DWARF
220   debug sections.
221
222 * Add "-t/--section-details" to readelf to display section details.
223   "-N/--full-section-name" is deprecated.
224
225 * powerpc-linux ld now supports a variant form of PLT and GOT for the security
226   conscious.  This form will automatically be chosen when ld detects that all
227   code in regular object files was generated by gcc -msecure-plt.  The old PLT
228   and GOT may be forced by a new ld option, --bss-plt.
229
230 * Add "-i/--inlines" to addr2line to print enclosing scope information
231   for inlined function chains, back to first non-inlined function.
232
233 * Add "-N/--full-section-name" to readelf to display full section name.
234
235 * Add "-M entry:<addr>" switch to objdump to specify a function entry address
236   when disassembling VAX binaries.
237
238 * Add "--globalize-symbol <name>" and "--globalize-symbols <filename>" switches
239   to objcopy to convert local symbols into global symbols.
240
241 * gprof now allows input files to have histogram records for
242   several memory ranges, provided those ranges are disjoint.
243
244 Changes in 2.16:
245
246 * Add "-g/--section-groups" to readelf to display section groups.
247
248 * objcopy recognizes two new options --strip-unneeded-symbol and
249   --strip-unneeded-symbols, namely for use together with the wildcard
250   matching the original --strip-symbol/--strip-symbols provided, but
251   retaining any symbols matching but needed by relocations.
252
253 * readelf can now display address ranges from .debug_range sections.  This
254   happens automatically when a DW_AT_range attribute is encountered.  The
255   command line switch --debug-dump=Ranges (or -wR) can also be used to display
256   the contents of the .debug_range section.
257
258 * nm and objdump now have a switch "--special-syms" to enable the displaying of
259   symbols which the target considers to be special.  By default these symbols
260   are no longer displayed.  Currently the only special symbols are the Mapping
261   symbols used by the ARM port to mark transitions between text and data and
262   between ARM and THUMB code.
263
264 * dlltool has a switch "--ext-prefix-alias <prefix>" to generate additional
265   import and export symbols with <preifx> prepended to them.
266
267 Changes in 2.15:
268
269 * objcopy for MIPS targets now accepts "-M no-aliases" as an option to the
270   disassembler to print the "raw" mips instruction mnemonic instead of some
271   pseudo instruction name.  I.E. print "daddu" or "or" instead of "move",
272   "sll" instead of "nop", etc.
273
274 * objcopy and strip can now take wildcard patterns in symbol names specified on
275   the command line provided that the --wildcard switch is used to enable them.
276
277 * readelf can now parse archives.
278
279 * objdump now accepts --debugging-tags to print the debug information in a
280   format compatible with ctags tool.
281
282 * objcopy and strip now accept --only-keep-debug to create a file containing
283   those sections that would be stripped out by --strip-debug.  The idea is that
284   this can be used in conjunction with the --add-gnu-debuglink switch to create
285   a two part program distribution - one a stripped executable and the other the
286   debugging info.
287
288 * objcopy now accepts --add-gnu-debuglink=<file> to insert a .gnu_debuglink
289   section into a (presumably stripped) executable.  This allows the debug
290   information for the file to be held in a separate file.
291
292 * BFD marks the sections .comment and .note as 'n' in the BSD/POSIX
293   single-character representation.  This can be checked by running nm
294   with the -a switch.
295
296 Changes in 2.14:
297
298 * Added --info switch to objcopy and strip.
299
300 * Support for Vitesse IQ2000 added by Red Hat.
301
302 * Added 'S' encoding to strings to allow the display of 8-bit characters.
303
304 * Added --prefix-symbols=<text>, --prefix-sections=<text> and
305   --prefix-alloc-sections=<text> to objcopy.
306
307 * readelf can handle the extensions to the DWARF2 spec used by the Unified
308   Parallel C compiler.
309
310 * BFD no longer declares a "boolean" type, to avoid clashes with other
311   headers that declare the same.  Users of BFD should replace boolean,
312   false and true, with int, 0 and 1, or define their own boolean type.
313
314 * Support for IP2K added by Denis Chertykov.
315
316 Changes in 2.13:
317
318 * Support for the Fujitsu FRV architecture added by Red Hat. Models for FR400
319   and FR500 included.
320
321 Changes in version 2.12:
322
323 * Support for Don Knuth's MMIX, by Hans-Peter Nilsson.
324
325 * size: Add --totals to display summary of sizes (Berkeley format only).
326
327 * readelf: Add --wide option to not break section header or segment listing
328   lines to fit into 80 columns.
329
330 * strings: Add --encoding to display wide character strings.  By Markus Kuhn.
331
332 * objcopy: Add --rename-section to change section names.
333
334 * readelf: Support added for DWARF 2.1 extensions.  Support added for
335   displaying the contents of .debug.macinfo sections.
336
337 * New command line switches added to objcopy to allow symbols to be kept as
338   global symbols, and also to specify files containing lists of such symbols.
339   by Honda Hiroki.
340
341 * Support for OpenRISC by Johan Rydberg.
342
343 * New command line switch to objcopy --alt-machine-code which creates a binary
344   with an alternate machine code if one is defined in the architecture
345   description.  Only supported for ELF targets.  By Alexandre Oliva.
346
347 * New command line switch to objcopy -B (or --binary-architecture) which sets
348   the architecture of the output file to the given argument.  This option only
349   makes sense, if the input target is binary.  Otherwise it is ignored.
350   By Stefan Geuken.
351
352 * Support for PDP-11 by Lars Brinkhoff.
353
354 Changes in binutils 2.11:
355
356 * Add support for ARM v5t and v5te architectures and Intel's XScale ARM
357   extenstions.
358
359 * Add --srec-len and --srec-forceS3 command line switch to objcopy.
360   By Luciano Gemme.
361
362 * Support for the MIPS32, by Anders Norlander.
363
364 * Support for the i860, by Jason Eckhardt.
365
366 * Support for CRIS (Axis Communications ETRAX series).
367
368 Changes in binutils 2.10:
369
370 * Support for 64-bit ELF on HPPA.
371
372 * New command line switch to objdump --file-start-context which shows the
373   entire file contents up to the source line first encountered for a given
374   file.
375
376 * New command line switch to objdump -M (or --disassembler-options) which takes
377   a parameter which can then be interpreted on a per-target basis by the
378   disassembler.  Used by ARM targets to select register name sets, ISA, APCS or
379   raw verions.
380
381 * objdump support for -mi386:intel which causes disassembly to be displayed
382   with intel syntax.
383
384 * New program: readelf.  This displays the contents of ELF format files,
385   regardless of target machine.
386
387 * objcopy now takes --change-section-lma, --change-section-vma, and
388   --change-section-address options.  The old --adjust-section-vma option is
389   equivalent to --change-section-address.  The other --adjust-* options are now
390   renamed to --change-*, although --adjust-* continues to work.
391
392 * objcopy has a --redefine-sym option that lets you rename symbols.
393
394 * objcopy now takes a -j/--only-section option to copy only the specified
395   sections.
396
397 * dlltool now supports the IMPORTS command.
398
399 * dlltool now takes --export-all-symbols, --no-export-all-symbols,
400   --exclude-symbols, and --no-default-excludes options.
401
402 Changes in binutils 2.9:
403
404 * Added windres program, which can be used to manipulate resources in WIN32
405   files as used on Windows 95 and Windows NT.
406
407 * The objcopy --gap-fill and --pad-to options operate on the LMA rather than
408   the VMA of the sections.
409
410 * Added S modifier to ar to not build a symbol table.
411
412 Changes in binutils 2.8:
413
414 * The objdump disassembly format has been changed, and hopefully improved.  Use
415   the new --prefix-addresses option to get the old format.  There are also new
416   --disassemble-zeroes and --no-show-raw-insn options which affect disassembler
417   output.
418
419 * Formats may now be specified as configuration triplets.  For example,
420   objdump -b i386-pc-linux.  The triplets are not passed through config.sub,
421   so they must be in canonical form.
422
423 * Added new addr2line program.  This uses the debugging information to convert
424   an address into a file name and line number within a program.
425
426 * Added --change-leading-char argument to objcopy.
427
428 * Added --weaken argument to objcopy.
429
430 * objdump --dynamic-reloc now works on ELF executables and shared libraries.
431
432 * Added --adjust-vma option to objdump.
433
434 * Added -C/--demangle option to objdump.
435
436 * Added -p/--preserve-dates option to strip and objcopy.
437
438 Changes in binutils 2.7:
439
440 * Added --enable-shared and --enable-commonbfdlib options to configure.
441
442 * Added --debugging argument to objdump and objcopy.
443
444 * Added --defined-only argument to nm.
445
446 * Added --remove-leading-char argument to objcopy.
447
448 * The objdump --line-numbers option is now meaningful with --reloc.
449
450 * Added --line-numbers option to nm.
451
452 * Added --endian/-EB/-EL option to objdump.
453
454 * Added support for Alpha OpenVMS/AXP.
455
456 Changes in binutils 2.6:
457
458 * Added -N/--strip-symbol and -K/--keep-symbol arguments to strip and objcopy.
459
460 * Added several arguments to objcopy to provide some control over how the new
461   file is laid out in memory.  Also added binary output format to BFD to permit
462   generating plain binary files.
463
464 * Added --start-address and --stop-address options to objdump.
465
466 * ar and ranlib now work on AIX.  The tools are now built by default on AIX.
467
468 Changes in binutils 2.5:
469
470 * Changed objdump -dr to dump the relocs interspersed with the assembly
471   listing, for a more useful listing of relocatable files.
472
473 * Changed objdump -d/--disassemble to only disassemble SEC_CODE sections.
474   Added -D/--disassemble-all option to disassemble all sections.
475
476 * Added --size-sort option to nm.
477
478 * strip and objcopy should now be able to handle dynamically linked ELF
479   executables.
480
481 Changes in binutils 2.4:
482
483 * Support for HP-PA (by Jeff Law), i386 Mach (by David Mackenzie), RS/6000 and
484   PowerPC (except ar and ranlib; by Ian Taylor).
485
486 * Support for Irix 5.
487
488 * Programs `strip' and `objcopy' will not attempt to write dynamically linked
489   ELF output files, since BFD currently can't create them properly.
490
491 Changes in binutils 2.3:
492
493 * A new --stabs argument has been added to objdump to dump stabs sections in
494   ELF and COFF files.
495
496 * A new program, nlmconv, has been added.  It can convert object files into
497   Novell NetWare Loadable Modules.
498
499 * The strings program has been added.
500
501 Changes in binutils 2.2:
502
503 * The 'copy' program has been renamed to 'objcopy', for consistency with
504   'objdump', and because 'copy' might more plausibly be used as a synonym for
505   'cp'.
506
507 * The new stand-alone program c++filt is a filter that converts encoded
508   (mangled) C++ assembly-level identifiers to user-level names.  (Note: This
509   may get moved to the gcc distribution.)
510
511 * nm -o on an archive now prefixes each line with the archive name, matching
512   the output from BSD nm.
513
514 * ar (and ld) can now read (but not write) BSD4.4-style archives.
515
516 * New support for H8500, Z8000, and the Hitach SH.
517
518 * Dis-assembler interface changed to allow sharing with gdb.
519
520 * There is new Elf code, but it is not yet ready for general use.
521
522 * There is the beginnings of a test suite.
523
524 Changes in binutils 2.1:
525
526 * There is now support for writing ECOFF files, so ld and the other utilities
527   should work on Risc/Ultrix and Irix.  Please let us know how well this works.
528
529 * ar now automatically creates a symbol table (a __.SYMDEF member, in the BSD
530   version), if there are any object files in the archive.  So running ranlib is
531   now redundant (unless the non-standard q command is used).  This is required
532   for Posix.2 conformance.
533
534 * The archive-reading code now reads both BSD-style and SYSV-style archives
535   independently of the selected target format.  This is to encourage people to
536   switch to SYSV-format, which has a number of advantages.
537
538 * The strip and copy programs now have options to remove debug-symbols only
539   and/or local symbols only.  They now also support long options.
540
541 \f
542 Copyright (C) 2012-2016 Free Software Foundation, Inc.
543
544 Copying and distribution of this file, with or without modification,
545 are permitted in any medium without royalty provided the copyright
546 notice and this notice are preserved.
547
548 Local variables:
549 fill-column: 79
550 End: