|  | -*- text -*- | 
|  |  | 
|  | * Support for Nios II targets has been removed except in the readelf utility, | 
|  | as this architecture has been EOL'ed by Intel. | 
|  |  | 
|  | * RISC-V disassembly now supports -M,max option like QEMU to dump instruction | 
|  | without checking architecture support as usual. | 
|  |  | 
|  | Changes in 2.43: | 
|  |  | 
|  | * The MIPS port now supports microMIPS MT Application Specific Extension | 
|  | instructions for assembly and disassembly. | 
|  |  | 
|  | * Readelf now displays RELR relocations in full detail. | 
|  |  | 
|  | * Readelf now has a -j/--display-section option which takes the name or index | 
|  | of a section and displays its contents according to its type.  The option can | 
|  | be used multiple times on the command line to display multiple sections. | 
|  |  | 
|  | * Base register 0 is now printed as "0" instead of "%r0" in s390 disassembly. | 
|  |  | 
|  | * When objdump or readelf are used to display the contents of a .eh_frame | 
|  | section they will now also display the contents of the .eh_frame_hdr section, | 
|  | if present. | 
|  |  | 
|  | * Support for the Maverick co-processor (via -mfpu=maverick) on Arm has been | 
|  | removed.  The CPU name ep9312 is still recognized, but treated as an alias | 
|  | for arm920t. | 
|  |  | 
|  | * Support for the FPA co-procossor on Arm has been removed.  In cases where a | 
|  | legacy CPU previously defaulted to using this instruction set extension, the | 
|  | assembler now defaults to no-FPU to avoid quietly misassembling legacy code. | 
|  |  | 
|  | * gprofng: | 
|  | Improved the support for hardware event counters: | 
|  | - Re-designed and streamlined the implementation. | 
|  | - Defined a common set of events for ARM processors. | 
|  | - Added specific events for AMD ZEN3 / ZEN4, and Intel Ice Lake processors. | 
|  | Added a minimal support for RISC-V. | 
|  |  | 
|  | Changes in 2.42: | 
|  |  | 
|  | * The objdump program has a new command line option -Z/--decompress which | 
|  | changes the behaviour of the -s/--full-contents option, forcing it to | 
|  | decompress the contents of any compressed section before they are displayed. | 
|  |  | 
|  | In addition when objdump is displaying sections headers (via the -h/--headers | 
|  | command line option) it will now display "COMPRESSED" in the Flags field of | 
|  | any compressed section. | 
|  |  | 
|  | * The readelf program has a new command line option --extra-sym-info which | 
|  | extends the information displayed by the --symbols option.  When enabled | 
|  | the display will include the name of the section referenced by a symbol's | 
|  | index field (st_shndx).  In the future more information may also be displayed | 
|  | when this option is enabled. | 
|  |  | 
|  | * objcopy --set-section-flags now supports "large" to set SHF_X86_64_LARGE | 
|  | for ELF x86-64 objects. | 
|  |  | 
|  | * objdump --visualize-jumps is now supported on s390 architecture. | 
|  |  | 
|  | * The s390 disassembly now optionally includes the instruction description as | 
|  | comment with the s390-specific disassembler option "insndesc": | 
|  | - For objdump it can be enabled with "objdump -M insndesc ...". | 
|  | - In gdb it can be enabled with "set disassembler-options insndesc". | 
|  |  | 
|  | Changes in 2.41: | 
|  |  | 
|  | * The MIPS port now supports the Sony Interactive Entertainment Allegrex | 
|  | processor, used with the PlayStation Portable, which implements the MIPS | 
|  | II ISA along with a single-precision FPU and a few implementation-specific | 
|  | integer instructions. | 
|  |  | 
|  | * Objdump's --private option can now be used on PE format files to display the | 
|  | fields in the file header and section headers. | 
|  |  | 
|  | * New versioned release of libsframe: libsframe.so.1.  This release introduces | 
|  | versioned symbols with version node name LIBSFRAME_1.0.  This release also | 
|  | updates the ABI in an incompatible way: this includes removal of | 
|  | sframe_get_funcdesc_with_addr API, change in the behavior of | 
|  | sframe_fre_get_ra_offset and sframe_fre_get_fp_offset APIs. | 
|  |  | 
|  | * SFrame Version 2 is now the default (and only) format version supported by | 
|  | gas, ld, readelf and objdump. | 
|  |  | 
|  | * Add command-line option, --strip-section-headers, to objcopy and strip to | 
|  | remove ELF section header from ELF file. | 
|  |  | 
|  | * The RISC-V port now supports the following new standard extensions: | 
|  | - Zicond (conditional zero instructions) | 
|  | - Zfa (additional floating-point instructions) | 
|  | - Zvbb, Zvbc, Zvkg, Zvkned, Zvknh[ab], Zvksed, Zvksh, Zvkn, Zvknc, Zvkng, | 
|  | Zvks, Zvksc, Zvkg, Zvkt (vector crypto instructions) | 
|  |  | 
|  | * The RISC-V port now supports the following vendor-defined extensions: | 
|  | - XVentanaCondOps | 
|  |  | 
|  | * The LoongArch port now supports the following extensions: | 
|  | - LSX (Loongson SIMD eXtension; 128-bit vectors) | 
|  | - LASX (Loongson Advanced SIMD eXtension; 256-bit vectors) | 
|  | - LVZ (Loongson Virtualization extension) | 
|  | - LBT (Loongson Binary Translation extension) | 
|  |  | 
|  | * The LoongArch disassembly output received the following tweaks: | 
|  | - Colored output is now supported. | 
|  | - Some pseudo-instructions are now shown in place of the canonical forms, | 
|  | where semantics are equivalent. A disassembler option '-M no-aliases' is | 
|  | added to disable the new behavior. | 
|  | - Signed immediates are no longer printed with their hex representation. | 
|  | - Unrecognized instruction words are now shown with '.word'. | 
|  |  | 
|  | Changes in 2.40: | 
|  |  | 
|  | * Objdump has a new command line option --show-all-symbols which will make it | 
|  | display all symbols that match a given address when disassembling.  (Normally | 
|  | only the first symbol that matches an address is shown). | 
|  |  | 
|  | * Add --enable-colored-disassembly configure time option to enable colored | 
|  | disassembly output by default, if the output device is a terminal.  Note, | 
|  | this configure option is disabled by default. | 
|  |  | 
|  | * DCO signed contributions are now accepted. | 
|  |  | 
|  | * objcopy --decompress-debug-sections now supports zstd compressed debug | 
|  | sections.  The new option --compress-debug-sections=zstd compresses debug | 
|  | sections with zstd. | 
|  |  | 
|  | * addr2line and objdump --dwarf now support zstd compressed debug sections. | 
|  |  | 
|  | * The dlltool program now accepts --deterministic-libraries and | 
|  | --non-deterministic-libraries as command line options to control whether or | 
|  | not it generates deterministic output libraries.  If neither of these options | 
|  | are used the default is whatever was set when the binutils were configured. | 
|  |  | 
|  | * readelf and objdump now have a newly added option --sframe which dumps the | 
|  | SFrame section. | 
|  |  | 
|  | Changes in 2.39: | 
|  |  | 
|  | * Add --no-weak/-W option to nm to make it ignore weak symbols. | 
|  |  | 
|  | * Add an option to objdump and readelf to prevent attempts to access debuginfod | 
|  | servers when following links. | 
|  |  | 
|  | * objcopy --weaken, --weaken-symbol, and --weaken-symbols now make ELF | 
|  | STB_GNU_UNIQUE symbols weak. | 
|  |  | 
|  | * objdump now supports syntax highlighting of disassembler output for some | 
|  | architectures.  Use the --disassembler-color=MODE command line flag, with | 
|  | mode being either off, color, or extended-color. | 
|  |  | 
|  | Changes in 2.38: | 
|  |  | 
|  | * elfedit: Add --output-abiversion option to update ABIVERSION. | 
|  |  | 
|  | * Add support for the LoongArch instruction set. | 
|  |  | 
|  | * Tools which display symbols or strings (readelf, strings, nm, objdump) | 
|  | have a new command line option which controls how unicode characters are | 
|  | handled.  By default they are treated as normal for the tool.  Using | 
|  | --unicode=locale will display them according to the current locale. | 
|  | Using --unicode=hex will display them as hex byte values, whilst | 
|  | --unicode=escape will display them as escape sequences.  In addition | 
|  | using --unicode=highlight will display them as unicode escape sequences | 
|  | highlighted in red (if supported by the output device). | 
|  |  | 
|  | * readelf -r dumps RELR relative relocations now. | 
|  |  | 
|  | * Support for efi-app-aarch64, efi-rtdrv-aarch64 and efi-bsdrv-aarch64 has been | 
|  | added to objcopy in order to enable UEFI development using binutils. | 
|  |  | 
|  | * ar: Add --thin for creating thin archives. -T is a deprecated alias without | 
|  | diagnostics. In many ar implementations -T has a different meaning, as | 
|  | specified by X/Open System Interface. | 
|  |  | 
|  | Changes in 2.37: | 
|  |  | 
|  | * The readelf tool has a new command line option which can be used to specify | 
|  | how the numeric values of symbols are reported.  --sym-base=0|8|10|16 tells | 
|  | readelf to display the values in base 8, base 10 or base 16.  A sym base of 0 | 
|  | represents the default action of displaying values under 10000 in base 10 and | 
|  | values above that in base 16. | 
|  |  | 
|  | * Binutils now requires a C99 compiler and library to build. | 
|  |  | 
|  | * A new format has been added to the nm program.  Specifying | 
|  | --format=just-symbols (or just using -j) will tell the program to only | 
|  | display symbol names and nothing else. | 
|  |  | 
|  | * A new command line --keep-section-symbols has been added to objcopy and | 
|  | strip.  This stops the removal of unused section symbols when the file is | 
|  | copied.  Removing these symbols saves space, but sometimes they are needed by | 
|  | other tools. | 
|  |  | 
|  | * objcopy --weaken, --weaken-symbol and --weaken-symbols now make undefined | 
|  | symbols weak on targets that support weak symbols. | 
|  |  | 
|  | * Readelf and objdump can now display and use the contents of .debug_sup | 
|  | sections. | 
|  |  | 
|  | * Readelf and objdump will now follow links to separate debug info files by | 
|  | default.  This behaviour can be stopped via the use of the new -wN or | 
|  | --debug-dump=no-follow-links options for readelf and the -WN or | 
|  | --dwarf=no-follow-links options for objdump.  Also the old behaviour can be | 
|  | restored by the use of the --enable-follow-debug-links=no configure time | 
|  | option. | 
|  |  | 
|  | The semantics of the =follow-links option have also been slightly changed. | 
|  | When enabled, the option allows for the loading of symbol tables and string | 
|  | tables from the separate files which can be used to enhance the information | 
|  | displayed when dumping other sections, but it does not automatically imply | 
|  | that information from the separate files should be displayed. | 
|  |  | 
|  | If other debug section display options are also enabled (eg | 
|  | --debug-dump=info) then the contents of matching sections in both the main | 
|  | file and the separate debuginfo file *will* be displayed.  This is because in | 
|  | most cases the debug section will only be present in one of the files. | 
|  |  | 
|  | If however non-debug section display options are enabled (eg --sections) then | 
|  | the contents of matching parts of the separate debuginfo file will *not* be | 
|  | displayed.  This is because in most cases the user probably only wanted to | 
|  | load the symbol information from the separate debuginfo file.  In order to | 
|  | change this behaviour a new command line option --process-links can be used. | 
|  | This will allow di0pslay options to applied to both the main file and any | 
|  | separate debuginfo files. | 
|  |  | 
|  | * Nm has a new command line option: --quiet.  This suppresses "no symbols" | 
|  | diagnostic. | 
|  |  | 
|  | Changes in 2.36: | 
|  |  | 
|  | * Update elfedit and readelf with LAM_U48 and LAM_U57 support. | 
|  |  | 
|  | * Nm has a new command line option: --ifunc-chars=CHARS.  This specifies a | 
|  | string of one or two characters.  The first character is used as the type | 
|  | character when displaying global ifunc symbols.  The second character, if | 
|  | present is used when displaying local ifunc symbols. | 
|  |  | 
|  | In addition a new configure time option --enable-f-for-ifunc-symbols has been | 
|  | created, which if used will change nm's default characters for ifunc symbols | 
|  | from i (both local and global) to F (global) and f (local). | 
|  |  | 
|  | * The ar tool's previously unused l modifier is now used for specifying | 
|  | dependencies of a static library. The arguments of this option | 
|  | (or --record-libdeps long form option) will be stored verbatim in the | 
|  | __.LIBDEP member of the archive, which the linker may read at link time. | 
|  |  | 
|  | * Readelf can now display the contents of LTO symbol table sections when asked | 
|  | to do so via the --lto-syms command line option. | 
|  |  | 
|  | * Readelf now accepts the -C command line option to enable the demangling of | 
|  | symbol names.  In addition the --demangle=<style>, --no-demangle, | 
|  | --recurse-limit and --no-recurse-limit options are also now availale. | 
|  |  | 
|  | * Add support for the SHF_GNU_RETAIN ELF section flag. | 
|  | This flag specifies that the section should not be garbage collected by the | 
|  | linker. | 
|  |  | 
|  | Changes in 2.35: | 
|  |  | 
|  | * Changed readelf's display of symbol names when wide mode is not enabled. | 
|  | If the name is too long it will be truncated and the last five characters | 
|  | replaced with "[...]".  The old behaviour of displaying 5 more characters but | 
|  | not indicating that truncation has happened can be restored by the use of the | 
|  | -T or --silent-truncation options. | 
|  |  | 
|  | * X86 NaCl target support is removed. | 
|  |  | 
|  | * The readelf tool now has a -L or --lint or --enable-checks option which turns | 
|  | on warning messages about possible problems with the file(s) being examined. | 
|  | These checks include things like zero-sized sections, which are allowed by | 
|  | the ELF standard but which nevertheless might be of concern if the user | 
|  | was expecting them to actually contain something. | 
|  |  | 
|  | Changes in 2.34: | 
|  |  | 
|  | * Binutils now supports debuginfod, an HTTP server for distributing | 
|  | ELF/DWARF debugging information as well as source code. When built with | 
|  | debuginfod, readelf and objdump can automatically query debuginfod | 
|  | servers for separate debug files when they otherwise cannot be found. | 
|  | To build binutils with debuginfod, pass --with-debuginfod to configure. | 
|  | This requires libdebuginfod, the debuginfod client library. debuginfod | 
|  | is distributed with elfutils, starting with version 0.178. For more | 
|  | information see https://sourceware.org/elfutils. | 
|  |  | 
|  | * Add --output option to the "ar" program.  This option can be used to specify | 
|  | the output directory when extracting members from an archive. | 
|  |  | 
|  | * Add --keep-section option to objcopy and strip.  This option keeps the | 
|  | specified section from being removed. | 
|  |  | 
|  | * Add visualization of jumps inside a function by drawing an ascii character | 
|  | graph between the address and the disassembler column.  Enabled via the | 
|  | --visualize-jumps command line option for objdump.  Currently supported by | 
|  | the x86, x86_64, and ARM targets.  The output looks something like this: | 
|  |  | 
|  | c6:	|  |     \----------> be 00 00 00 00       	mov    $0x0,%esi | 
|  | cb:	|  |           /----> 48 8b 3d 00 00 00 00 	mov    0x0(%rip),%rdi        # d2 <main+0xd2> | 
|  | d2:	|  |           |      31 c0                	xor    %eax,%eax | 
|  | d4:	|  |           |  /-- e8 00 00 00 00       	callq  d9 <main+0xd9> | 
|  | d9:	|  |           |  \-> bf 02 00 00 00       	mov    $0x2,%edi | 
|  | de:	|  +-----------|----- e8 00 00 00 00       	callq  e3 <main+0xe3> | 
|  | e3:	|  \-----------|----> 48 89 da             	mov    %rbx,%rdx | 
|  | e6:	|              |      be 00 00 00 00       	mov    $0x0,%esi | 
|  | eb:	|              \----- eb de                	jmp    cb <main+0xcb> | 
|  | ed:	\-------------------> 48 8b 16             	mov    (%rsi),%rdx | 
|  |  | 
|  | Additional arguments to the --visualize-jumps option add colors to the | 
|  | output. | 
|  |  | 
|  | Changes in 2.33: | 
|  |  | 
|  | * Add --source-comment[=<txt>] option to objdump which if present, | 
|  | provides a prefix to source code lines displayed in a disassembly. | 
|  |  | 
|  | * Add --set-section-alignment <section-name>=<align> option to objcopy to allow | 
|  | the changing of section alignments. | 
|  |  | 
|  | * Add --verilog-data-width option to objcopy for verilog targets to control | 
|  | width of data elements in verilog hex format. | 
|  |  | 
|  | * Add support for the Armv8.1-M Mainline and M-profile Vector Extension (MVE) | 
|  | instructions. | 
|  |  | 
|  | * The separate debug info file options of readelf (--debug-dump=links | 
|  | and --debug-dump=follow) and objdump (--dwarf=links and | 
|  | --dwarf=follow-links) will now display and/or follow multiple links if | 
|  | more than one are present in a file.  (This usually happens when gcc's | 
|  | -gsplit-dwarf option is used). | 
|  |  | 
|  | In addition objdump's --dwarf=follow-links now also affects its other | 
|  | display options, so that for example, when combined with --syms it will | 
|  | cause the symbol tables in any linked debug info files to also be | 
|  | displayed.  In addition when combined with --disassemble the --dwarf= | 
|  | follow-links option will ensure that any symbol tables in the linked | 
|  | files are read and used when disassembling code in the main file. | 
|  |  | 
|  | * Add support for dumping types encoded in the Compact Type Format | 
|  | to objdump and readelf. | 
|  |  | 
|  | Changes in 2.32: | 
|  |  | 
|  | * The addr2line, c++filt, nm and objdump tools now have a limit on the | 
|  | maximum amount of recursion that is allowed whilst demangling strings. | 
|  | The value for this limit is defined by the DEMANGLE_RECRUSE_LIMIT | 
|  | constant declared in the include/demangle.h header file.  At the time | 
|  | of writing this constant has the value of 2048. | 
|  |  | 
|  | The --no-recurse-limit option can be used to remove the limit, restoring | 
|  | the behaviour of earlier versions of these tools.  This may be needed in | 
|  | order to dmangle truly complicated names, but it also leaves the tools | 
|  | vulnerable to stack exhaustion from maliciously constructed mangled names. | 
|  |  | 
|  | * Objdump's --disassemble option can now take a parameter, specifying the | 
|  | starting symbol for disassembly.  Disassembly will continue from this | 
|  | symbol up to the next symbol or the end of the function. | 
|  |  | 
|  | * The MIPS port now supports the Loongson 2K1000 processor which implements | 
|  | the MIPS64r2 ISA, the Loongson-mmi ASE, Loongson-cam ASE, Loongson-ext ASE, | 
|  | Loongson-ext2 ASE and MSA ASE instructions. Add -march=gs264e option for | 
|  | Loongson 2K1000 processor. | 
|  |  | 
|  | * The MIPS port now supports the Loongson 3A2000/3A3000 processor which | 
|  | implements the MIPS64r2 ISA, the Loongson-mmi ASE, Loongson-cam ASE, | 
|  | Loongson-ext ASE and Loongson-ext2 ASE instructions. Add -march=gs464e | 
|  | option for Loongson 3A2000/3A3000 processor. | 
|  |  | 
|  | * The MIPS port now supports the Loongson 3A1000 processor, aka Loongson3a, | 
|  | which implements the MIPS64r2 ISA, the Loongson-mmi ASE, Loongson-cam ASE | 
|  | and Loongson-ext ASE instructions. Add -march=gs464 option for Loongson | 
|  | 3A1000 processor, The -march=loongson3a is an alias of -march=gs464 for | 
|  | compatibility. | 
|  |  | 
|  | * The size tool now has a new output format '--format=GNU' or '-G'.  The | 
|  | results are displayed in a similar manor to the default berkeley layout, | 
|  | except read-only data is counted in the data column, not the text column. | 
|  | Additionally the total is only included once. | 
|  |  | 
|  | Changes in 2.31: | 
|  |  | 
|  | * Add support for disassembling netronome Flow Processor (NFP) firmware files. | 
|  |  | 
|  | * The AArch64 port now supports showing disassembly notes which are emitted | 
|  | when inconsistencies are found with the instruction that may result in the | 
|  | instruction being invalid.  These can be turned on with the option -M notes | 
|  | to objdump. | 
|  |  | 
|  | * The AArch64 port now emits warnings when a combination of an instruction and | 
|  | a named register could be invalid. | 
|  |  | 
|  | * Added O modifier to ar to display member offsets inside an archive | 
|  |  | 
|  | Changes in 2.30: | 
|  |  | 
|  | * Add --debug-dump=links option to readelf and --dwarf=links option to objdump | 
|  | which displays the contents of any .gnu_debuglink or .gnu_debugaltlink | 
|  | sections. | 
|  |  | 
|  | Add a --debug-dump=follow-links option to readelf and a --dwarf=follow-links | 
|  | option to objdump which causes indirect links into separate debug info files | 
|  | to be followed when dumping other DWARF sections. | 
|  |  | 
|  | Changes in 2.29: | 
|  |  | 
|  | * The MIPS port now supports microMIPS eXtended Physical Addressing (XPA) | 
|  | instructions for assembly and disassembly. | 
|  |  | 
|  | * The MIPS port now supports the microMIPS Release 5 ISA for assembly and | 
|  | disassembly. | 
|  |  | 
|  | * The MIPS port now supports the Imagination interAptiv MR2 processor, | 
|  | which implements the MIPS32r3 ISA, the MIPS16e2 ASE as well as a couple | 
|  | of implementation-specific regular MIPS and MIPS16e2 ASE instructions. | 
|  |  | 
|  | * The SPARC port now supports the SPARC M8 processor, which implements the | 
|  | Oracle SPARC Architecture 2017. | 
|  |  | 
|  | * The MIPS port now supports the MIPS16e2 ASE for assembly and disassembly. | 
|  |  | 
|  | * Add support for ELF SHF_GNU_MBIND and PT_GNU_MBIND_XXX. | 
|  |  | 
|  | * Add support for the wasm32 ELF conversion of the WebAssembly file format. | 
|  |  | 
|  | * Add --inlines option to objdump, which extends the --line-numbers option | 
|  | so that inlined functions will display their nesting information. | 
|  |  | 
|  | * Add --merge-notes options to objcopy to reduce the size of notes in | 
|  | a binary file by merging and deleting redundant notes. | 
|  |  | 
|  | * Add support for locating separate debug info files using the build-id | 
|  | method, where the separate file has a name based upon the build-id of | 
|  | the original file. | 
|  |  | 
|  | Changes in 2.28: | 
|  |  | 
|  | * This version of binutils fixes a problem with PowerPC VLE 16A and 16D | 
|  | relocations which were functionally swapped, for example, | 
|  | R_PPC_VLE_HA16A performed like R_PPC_VLE_HA16D while R_PPC_VLE_HA16D | 
|  | performed like R_PPC_VLE_HA16A.  This could have been fixed by | 
|  | renumbering relocations, which would keep object files created by an | 
|  | older version of gas compatible with a newer ld.  However, that would | 
|  | require an ABI update, affecting other assemblers and linkers that | 
|  | create and process the relocations correctly.  It is recommended that | 
|  | all VLE object files be recompiled, but ld can modify the relocations | 
|  | if --vle-reloc-fixup is passed to ld.  If the new ld command-line | 
|  | option is not used, ld will ld warn on finding relocations inconsistent | 
|  | with the instructions being relocated. | 
|  |  | 
|  | * The nm program has a new command-line option (--with-version-strings) | 
|  | which will display a symbol's version information, if any, after the | 
|  | symbol's name. | 
|  |  | 
|  | * The ARC port of objdump now accepts a -M option to specify the extra | 
|  | instruction class(es) that should be disassembled. | 
|  |  | 
|  | * The --remove-section option for objcopy and strip now accepts section | 
|  | patterns starting with an exclamation point to indicate a non-matching | 
|  | section.  A non-matching section is removed from the set of sections | 
|  | matched by an earlier --remove-section pattern. | 
|  |  | 
|  | * The --only-section option for objcopy now accepts section patterns | 
|  | starting with an exclamation point to indicate a non-matching section. | 
|  | A non-matching section is removed from the set of sections matched by | 
|  | an earlier --only-section pattern. | 
|  |  | 
|  | * New --remove-relocations=SECTIONPATTERN option for objcopy and strip. | 
|  | This option can be used to remove sections containing relocations. | 
|  | The SECTIONPATTERN is the section to which the relocations apply, not | 
|  | the relocation section itself. | 
|  |  | 
|  | Changes in 2.27: | 
|  |  | 
|  | * Add a configure option, --enable-64-bit-archive, to force use of a | 
|  | 64-bit format when creating an archive symbol index. | 
|  |  | 
|  | * Add --elf-stt-common= option to objcopy for ELF targets to control | 
|  | whether to convert common symbols to the STT_COMMON type. | 
|  |  | 
|  | Changes in 2.26: | 
|  |  | 
|  | * Add option to objcopy to insert new symbols into a file: | 
|  | --add-symbol <name>=[<section>:]<value>[,<flags>] | 
|  |  | 
|  | * Add support for the ARC EM/HS, and ARC600/700 architectures. | 
|  |  | 
|  | * Extend objcopy --compress-debug-sections option to support | 
|  | --compress-debug-sections=[none|zlib|zlib-gnu|zlib-gabi] for ELF | 
|  | targets. | 
|  |  | 
|  | * Add --update-section option to objcopy. | 
|  |  | 
|  | * Add --output-separator option to strings. | 
|  |  | 
|  | Changes in 2.25: | 
|  |  | 
|  | * Add --data option to strings to only print strings in loadable, initialized | 
|  | data sections.  Change the default behaviour to be --all, but add a new | 
|  | configure time option of --disable-default-strings-all to restore the old | 
|  | default behaviour. | 
|  |  | 
|  | * Add --include-all-whitespace to strings. | 
|  |  | 
|  | * Add --dump-section option to objcopy. | 
|  |  | 
|  | * Add support for the Andes NDS32. | 
|  |  | 
|  | Changes in 2.24: | 
|  |  | 
|  | * Objcopy now supports wildcard characters in command-line options that take | 
|  | section names. | 
|  |  | 
|  | * Add support for Altera Nios II. | 
|  |  | 
|  | Changes in 2.23: | 
|  |  | 
|  | * Add support for the VLE extension to the PowerPC architecture. | 
|  |  | 
|  | * Add support for x64 Windows target of the delayed-load-library. | 
|  |  | 
|  | * Add support for the Renesas RL78 architecture. | 
|  |  | 
|  | Changes in 2.22: | 
|  |  | 
|  | * Add support for displaying the contents of .debug.macro sections. | 
|  |  | 
|  | * Add --preprocessor-arg option to windres to specify additional options | 
|  | passed to preprocessor. | 
|  |  | 
|  | * Add --dwarf-start and --dwarf-end to readelf and objdump.  These are used by | 
|  | the new Emacs mode, see dwarf-mode.el. | 
|  |  | 
|  | * Add support for the Tilera TILEPro and TILE-Gx architectures. | 
|  |  | 
|  | changes in 2.21: | 
|  |  | 
|  | * Add --interleave-width option to objcopy to allowing copying a range of | 
|  | bytes from the input to the output with the --interleave option. | 
|  |  | 
|  | * Add support for the TMS320C6000 (TI C6X) processor family. | 
|  |  | 
|  | * Readelf can now display ARM unwind tables (.ARM.exidx / .ARM.extab) using | 
|  | the -u / --unwind option. | 
|  |  | 
|  | * Add --dyn-syms to readelf to dump dynamic symbol table. | 
|  |  | 
|  | * A new tool - elfedit - has been added to directly manipulate ELF format | 
|  | binaries. | 
|  |  | 
|  | * Add to dlltool .def file feature of aliasing PE internal symbol name by | 
|  | '== <ID>' option. | 
|  |  | 
|  | * Add a new command-line option -a / --addresses to addr2line to display the | 
|  | address before function name or source filename. | 
|  |  | 
|  | * Add a new command-line option -p / --pretty-print to addr2line to have | 
|  | a more human readable output. | 
|  |  | 
|  | * The hppa/som targets can now be compiled on any host. | 
|  |  | 
|  | Changes in 2.20: | 
|  |  | 
|  | * Add support for delay importing to dlltool.  Use the --output-delaylib <file> | 
|  | switch to create a delay-import library.  The resulting app will load the dll | 
|  | as soon as the first function is called.  It will link to __delayLoadHelper2() | 
|  | from the static delayimp library, which will import LoadLibraryA and | 
|  | GetProcAddress from kernel32. | 
|  |  | 
|  | * Add a new command-line option, --insn-width=WIDTH, to objdump to specify | 
|  | number of bytes to be displayed on a single line when disassembling | 
|  | instructions. | 
|  |  | 
|  | * Readelf can now display the relocated contents of a section as a sequence | 
|  | of bytes via the --relocated-dump=<name|number> command-line option. | 
|  |  | 
|  | * The gprof program has been given a new command-line option: | 
|  | --external-symbols-table=<filename> which reads in symbols from a specified | 
|  | file. | 
|  |  | 
|  | * The plugin target has been added to bfd. It can load the same shared objects | 
|  | used by gold and uses them to provide basic support for new file formats. | 
|  |  | 
|  | * The verilog memory hex dump file format is now supported as an output format | 
|  | for objcopy. | 
|  |  | 
|  | * Add --file-alignment, --heap, --image-base, --section-alignment, | 
|  | --stack and --subsystem command-line options to objcopy, which will | 
|  | set PE optional header. | 
|  |  | 
|  | * Option --dwarf/-W of objdump is now as flexible as readelf --debug-dump/-w. | 
|  |  | 
|  | * --as-needed now links in a dynamic library if it satisfies undefined | 
|  | symbols in regular objects, or in other dynamic libraries.  In the | 
|  | latter case the library is not linked if it is found in a DT_NEEDED | 
|  | entry of one of the libraries already linked. | 
|  |  | 
|  | * Added --prefix=PREFIX and --prefix-strip=LEVEL switches to objdump to | 
|  | add absolute paths for -S. | 
|  |  | 
|  | * Add new option --use-nul-prefixed-import-tables to dlltool to allow fall- | 
|  | back to old import table generation with null element prefix. | 
|  |  | 
|  | * Added --identify-strict switch to cause --identify <implib> to | 
|  | report an error when the import library is associated with | 
|  | multiple DLLs. | 
|  |  | 
|  | * Added --identify <implib> option to dlltool, which determines the | 
|  | name of the DLL associated with the specified <implib>. | 
|  |  | 
|  | * Support for PowerPC booke64 instructions has been removed.  The assembler no | 
|  | longer accepts -mbooke32 or -mbooke64 and the disassembler no longer accepts | 
|  | -Mbooke32 or -Mbooke64.  Instead, -mbooke and -Mbooke should be used. | 
|  |  | 
|  | Changes in 2.19: | 
|  |  | 
|  | * Added -wL switch to dump decoded contents of .debug_line. | 
|  |  | 
|  | * Added support for "thin" archives which contain pathnames pointing to | 
|  | object files rather than the files themselves and which contain a | 
|  | flattened symbol index for all objects, and archives, which have been | 
|  | added to the archive. | 
|  |  | 
|  | * Added -F switch to objdump to include file offsets in the disassembly. | 
|  |  | 
|  | * Added -c switch to readelf to allow string dumps of archive symbol index. | 
|  |  | 
|  | * Support for SSE5 has been added to the i386 port. | 
|  |  | 
|  | * Added -p switch to readelf to allow string dumps of sections. | 
|  |  | 
|  | Changes in 2.18: | 
|  |  | 
|  | * Resolved 37 coding problems in bfd including static array overruns, null | 
|  | pointer dereferences and use of a malloc buffer after it has been freed, as | 
|  | revealed by static analysis donated by Coverity, Inc. (http://scan.coverity.com). | 
|  |  | 
|  | * The binutils sources are now released under version 3 of the GNU General | 
|  | Public License. | 
|  |  | 
|  | * A new tool "windmc" has been added for some targets.  This is a message | 
|  | compiler which attempts to be compatible with the MS version. | 
|  |  | 
|  | * Add codepage support to the windres tool.  It now supports many new | 
|  | resource types (e.g. MANIFEST, TOOLBAR, etc).  The output generation | 
|  | for binary files is done now via bfd itself.  The endianess problems | 
|  | for different hosts are solved.  Dumps of .res files can now be | 
|  | re-compiled by windres without lossing resources or compilation errors. | 
|  | Some problems on dialog resource translations are corrected. | 
|  |  | 
|  | * Add --extract-symbol command-line option to objcopy, which will | 
|  | strip everything out of an ordinary object file or executable except | 
|  | for its symbol table.  Files containing just symbols can be useful | 
|  | to some OSes. | 
|  |  | 
|  | Changes in 2.17: | 
|  |  | 
|  | * Add "-x NAME" to readelf in addition to "-x NUMBER". | 
|  |  | 
|  | * Add -i and -t switches to cxxfilt.  -i disables the display of implementation | 
|  | specific extra demangling information (if any) and -t disables the demangling | 
|  | of types. | 
|  |  | 
|  | * Add support for the "@<file>" syntax to the command lines of all tools, so | 
|  | that extra switches can be read from <file>. | 
|  |  | 
|  | * Add "-W/--dwarf" to objdump to display the contents of the DWARF | 
|  | debug sections. | 
|  |  | 
|  | * Add "-t/--section-details" to readelf to display section details. | 
|  | "-N/--full-section-name" is deprecated. | 
|  |  | 
|  | * powerpc-linux ld now supports a variant form of PLT and GOT for the security | 
|  | conscious.  This form will automatically be chosen when ld detects that all | 
|  | code in regular object files was generated by gcc -msecure-plt.  The old PLT | 
|  | and GOT may be forced by a new ld option, --bss-plt. | 
|  |  | 
|  | * Add "-i/--inlines" to addr2line to print enclosing scope information | 
|  | for inlined function chains, back to first non-inlined function. | 
|  |  | 
|  | * Add "-N/--full-section-name" to readelf to display full section name. | 
|  |  | 
|  | * Add "-M entry:<addr>" switch to objdump to specify a function entry address | 
|  | when disassembling VAX binaries. | 
|  |  | 
|  | * Add "--globalize-symbol <name>" and "--globalize-symbols <filename>" switches | 
|  | to objcopy to convert local symbols into global symbols. | 
|  |  | 
|  | * gprof now allows input files to have histogram records for | 
|  | several memory ranges, provided those ranges are disjoint. | 
|  |  | 
|  | Changes in 2.16: | 
|  |  | 
|  | * Add "-g/--section-groups" to readelf to display section groups. | 
|  |  | 
|  | * objcopy recognizes two new options --strip-unneeded-symbol and | 
|  | --strip-unneeded-symbols, namely for use together with the wildcard | 
|  | matching the original --strip-symbol/--strip-symbols provided, but | 
|  | retaining any symbols matching but needed by relocations. | 
|  |  | 
|  | * readelf can now display address ranges from .debug_range sections.  This | 
|  | happens automatically when a DW_AT_range attribute is encountered.  The | 
|  | command-line switch --debug-dump=Ranges (or -wR) can also be used to display | 
|  | the contents of the .debug_range section. | 
|  |  | 
|  | * nm and objdump now have a switch "--special-syms" to enable the displaying of | 
|  | symbols which the target considers to be special.  By default these symbols | 
|  | are no longer displayed.  Currently the only special symbols are the Mapping | 
|  | symbols used by the ARM port to mark transitions between text and data and | 
|  | between ARM and THUMB code. | 
|  |  | 
|  | * dlltool has a switch "--ext-prefix-alias <prefix>" to generate additional | 
|  | import and export symbols with <preifx> prepended to them. | 
|  |  | 
|  | Changes in 2.15: | 
|  |  | 
|  | * objcopy for MIPS targets now accepts "-M no-aliases" as an option to the | 
|  | disassembler to print the "raw" mips instruction mnemonic instead of some | 
|  | pseudo instruction name.  I.E. print "daddu" or "or" instead of "move", | 
|  | "sll" instead of "nop", etc. | 
|  |  | 
|  | * objcopy and strip can now take wildcard patterns in symbol names specified on | 
|  | the command line provided that the --wildcard switch is used to enable them. | 
|  |  | 
|  | * readelf can now parse archives. | 
|  |  | 
|  | * objdump now accepts --debugging-tags to print the debug information in a | 
|  | format compatible with ctags tool. | 
|  |  | 
|  | * objcopy and strip now accept --only-keep-debug to create a file containing | 
|  | those sections that would be stripped out by --strip-debug.  The idea is that | 
|  | this can be used in conjunction with the --add-gnu-debuglink switch to create | 
|  | a two part program distribution - one a stripped executable and the other the | 
|  | debugging info. | 
|  |  | 
|  | * objcopy now accepts --add-gnu-debuglink=<file> to insert a .gnu_debuglink | 
|  | section into a (presumably stripped) executable.  This allows the debug | 
|  | information for the file to be held in a separate file. | 
|  |  | 
|  | * BFD marks the sections .comment and .note as 'n' in the BSD/POSIX | 
|  | single-character representation.  This can be checked by running nm | 
|  | with the -a switch. | 
|  |  | 
|  | Changes in 2.14: | 
|  |  | 
|  | * Added --info switch to objcopy and strip. | 
|  |  | 
|  | * Support for Vitesse IQ2000 added by Red Hat. | 
|  |  | 
|  | * Added 'S' encoding to strings to allow the display of 8-bit characters. | 
|  |  | 
|  | * Added --prefix-symbols=<text>, --prefix-sections=<text> and | 
|  | --prefix-alloc-sections=<text> to objcopy. | 
|  |  | 
|  | * readelf can handle the extensions to the DWARF2 spec used by the Unified | 
|  | Parallel C compiler. | 
|  |  | 
|  | * BFD no longer declares a "boolean" type, to avoid clashes with other | 
|  | headers that declare the same.  Users of BFD should replace boolean, | 
|  | false and true, with int, 0 and 1, or define their own boolean type. | 
|  |  | 
|  | * Support for IP2K added by Denis Chertykov. | 
|  |  | 
|  | Changes in 2.13: | 
|  |  | 
|  | * Support for the Fujitsu FRV architecture added by Red Hat. Models for FR400 | 
|  | and FR500 included. | 
|  |  | 
|  | Changes in version 2.12: | 
|  |  | 
|  | * Support for Don Knuth's MMIX, by Hans-Peter Nilsson. | 
|  |  | 
|  | * size: Add --totals to display summary of sizes (Berkeley format only). | 
|  |  | 
|  | * readelf: Add --wide option to not break section header or segment listing | 
|  | lines to fit into 80 columns. | 
|  |  | 
|  | * strings: Add --encoding to display wide character strings.  By Markus Kuhn. | 
|  |  | 
|  | * objcopy: Add --rename-section to change section names. | 
|  |  | 
|  | * readelf: Support added for DWARF 2.1 extensions.  Support added for | 
|  | displaying the contents of .debug.macinfo sections. | 
|  |  | 
|  | * New command-line switches added to objcopy to allow symbols to be kept as | 
|  | global symbols, and also to specify files containing lists of such symbols. | 
|  | by Honda Hiroki. | 
|  |  | 
|  | * Support for OpenRISC by Johan Rydberg. | 
|  |  | 
|  | * New command-line switch to objcopy --alt-machine-code which creates a binary | 
|  | with an alternate machine code if one is defined in the architecture | 
|  | description.  Only supported for ELF targets.  By Alexandre Oliva. | 
|  |  | 
|  | * New command-line switch to objcopy -B (or --binary-architecture) which sets | 
|  | the architecture of the output file to the given argument.  This option only | 
|  | makes sense, if the input target is binary.  Otherwise it is ignored. | 
|  | By Stefan Geuken. | 
|  |  | 
|  | * Support for PDP-11 by Lars Brinkhoff. | 
|  |  | 
|  | Changes in binutils 2.11: | 
|  |  | 
|  | * Add support for ARM v5t and v5te architectures and Intel's XScale ARM | 
|  | extenstions. | 
|  |  | 
|  | * Add --srec-len and --srec-forceS3 command-line switch to objcopy. | 
|  | By Luciano Gemme. | 
|  |  | 
|  | * Support for the MIPS32, by Anders Norlander. | 
|  |  | 
|  | * Support for the i860, by Jason Eckhardt. | 
|  |  | 
|  | * Support for CRIS (Axis Communications ETRAX series). | 
|  |  | 
|  | Changes in binutils 2.10: | 
|  |  | 
|  | * Support for 64-bit ELF on HPPA. | 
|  |  | 
|  | * New command-line switch to objdump --file-start-context which shows the | 
|  | entire file contents up to the source line first encountered for a given | 
|  | file. | 
|  |  | 
|  | * New command-line switch to objdump -M (or --disassembler-options) which takes | 
|  | a parameter which can then be interpreted on a per-target basis by the | 
|  | disassembler.  Used by ARM targets to select register name sets, ISA, APCS or | 
|  | raw verions. | 
|  |  | 
|  | * objdump support for -mi386:intel which causes disassembly to be displayed | 
|  | with intel syntax. | 
|  |  | 
|  | * New program: readelf.  This displays the contents of ELF format files, | 
|  | regardless of target machine. | 
|  |  | 
|  | * objcopy now takes --change-section-lma, --change-section-vma, and | 
|  | --change-section-address options.  The old --adjust-section-vma option is | 
|  | equivalent to --change-section-address.  The other --adjust-* options are now | 
|  | renamed to --change-*, although --adjust-* continues to work. | 
|  |  | 
|  | * objcopy has a --redefine-sym option that lets you rename symbols. | 
|  |  | 
|  | * objcopy now takes a -j/--only-section option to copy only the specified | 
|  | sections. | 
|  |  | 
|  | * dlltool now supports the IMPORTS command. | 
|  |  | 
|  | * dlltool now takes --export-all-symbols, --no-export-all-symbols, | 
|  | --exclude-symbols, and --no-default-excludes options. | 
|  |  | 
|  | Changes in binutils 2.9: | 
|  |  | 
|  | * Added windres program, which can be used to manipulate resources in WIN32 | 
|  | files as used on Windows 95 and Windows NT. | 
|  |  | 
|  | * The objcopy --gap-fill and --pad-to options operate on the LMA rather than | 
|  | the VMA of the sections. | 
|  |  | 
|  | * Added S modifier to ar to not build a symbol table. | 
|  |  | 
|  | Changes in binutils 2.8: | 
|  |  | 
|  | * The objdump disassembly format has been changed, and hopefully improved.  Use | 
|  | the new --prefix-addresses option to get the old format.  There are also new | 
|  | --disassemble-zeroes and --no-show-raw-insn options which affect disassembler | 
|  | output. | 
|  |  | 
|  | * Formats may now be specified as configuration triplets.  For example, | 
|  | objdump -b i386-pc-linux.  The triplets are not passed through config.sub, | 
|  | so they must be in canonical form. | 
|  |  | 
|  | * Added new addr2line program.  This uses the debugging information to convert | 
|  | an address into a file name and line number within a program. | 
|  |  | 
|  | * Added --change-leading-char argument to objcopy. | 
|  |  | 
|  | * Added --weaken argument to objcopy. | 
|  |  | 
|  | * objdump --dynamic-reloc now works on ELF executables and shared libraries. | 
|  |  | 
|  | * Added --adjust-vma option to objdump. | 
|  |  | 
|  | * Added -C/--demangle option to objdump. | 
|  |  | 
|  | * Added -p/--preserve-dates option to strip and objcopy. | 
|  |  | 
|  | Changes in binutils 2.7: | 
|  |  | 
|  | * Added --enable-shared and --enable-commonbfdlib options to configure. | 
|  |  | 
|  | * Added --debugging argument to objdump and objcopy. | 
|  |  | 
|  | * Added --defined-only argument to nm. | 
|  |  | 
|  | * Added --remove-leading-char argument to objcopy. | 
|  |  | 
|  | * The objdump --line-numbers option is now meaningful with --reloc. | 
|  |  | 
|  | * Added --line-numbers option to nm. | 
|  |  | 
|  | * Added --endian/-EB/-EL option to objdump. | 
|  |  | 
|  | * Added support for Alpha OpenVMS/AXP. | 
|  |  | 
|  | Changes in binutils 2.6: | 
|  |  | 
|  | * Added -N/--strip-symbol and -K/--keep-symbol arguments to strip and objcopy. | 
|  |  | 
|  | * Added several arguments to objcopy to provide some control over how the new | 
|  | file is laid out in memory.  Also added binary output format to BFD to permit | 
|  | generating plain binary files. | 
|  |  | 
|  | * Added --start-address and --stop-address options to objdump. | 
|  |  | 
|  | * ar and ranlib now work on AIX.  The tools are now built by default on AIX. | 
|  |  | 
|  | Changes in binutils 2.5: | 
|  |  | 
|  | * Changed objdump -dr to dump the relocs interspersed with the assembly | 
|  | listing, for a more useful listing of relocatable files. | 
|  |  | 
|  | * Changed objdump -d/--disassemble to only disassemble SEC_CODE sections. | 
|  | Added -D/--disassemble-all option to disassemble all sections. | 
|  |  | 
|  | * Added --size-sort option to nm. | 
|  |  | 
|  | * strip and objcopy should now be able to handle dynamically linked ELF | 
|  | executables. | 
|  |  | 
|  | Changes in binutils 2.4: | 
|  |  | 
|  | * Support for HP-PA (by Jeff Law), i386 Mach (by David Mackenzie), RS/6000 and | 
|  | PowerPC (except ar and ranlib; by Ian Taylor). | 
|  |  | 
|  | * Support for Irix 5. | 
|  |  | 
|  | * Programs `strip' and `objcopy' will not attempt to write dynamically linked | 
|  | ELF output files, since BFD currently can't create them properly. | 
|  |  | 
|  | Changes in binutils 2.3: | 
|  |  | 
|  | * A new --stabs argument has been added to objdump to dump stabs sections in | 
|  | ELF and COFF files. | 
|  |  | 
|  | * A new program, nlmconv, has been added.  It can convert object files into | 
|  | Novell NetWare Loadable Modules. | 
|  |  | 
|  | * The strings program has been added. | 
|  |  | 
|  | Changes in binutils 2.2: | 
|  |  | 
|  | * The 'copy' program has been renamed to 'objcopy', for consistency with | 
|  | 'objdump', and because 'copy' might more plausibly be used as a synonym for | 
|  | 'cp'. | 
|  |  | 
|  | * The new stand-alone program c++filt is a filter that converts encoded | 
|  | (mangled) C++ assembly-level identifiers to user-level names.  (Note: This | 
|  | may get moved to the gcc distribution.) | 
|  |  | 
|  | * nm -o on an archive now prefixes each line with the archive name, matching | 
|  | the output from BSD nm. | 
|  |  | 
|  | * ar (and ld) can now read (but not write) BSD4.4-style archives. | 
|  |  | 
|  | * New support for H8500, Z8000, and the Hitach SH. | 
|  |  | 
|  | * Dis-assembler interface changed to allow sharing with gdb. | 
|  |  | 
|  | * There is new Elf code, but it is not yet ready for general use. | 
|  |  | 
|  | * There is the beginnings of a test suite. | 
|  |  | 
|  | Changes in binutils 2.1: | 
|  |  | 
|  | * There is now support for writing ECOFF files, so ld and the other utilities | 
|  | should work on Risc/Ultrix and Irix.  Please let us know how well this works. | 
|  |  | 
|  | * ar now automatically creates a symbol table (a __.SYMDEF member, in the BSD | 
|  | version), if there are any object files in the archive.  So running ranlib is | 
|  | now redundant (unless the non-standard q command is used).  This is required | 
|  | for Posix.2 conformance. | 
|  |  | 
|  | * The archive-reading code now reads both BSD-style and SYSV-style archives | 
|  | independently of the selected target format.  This is to encourage people to | 
|  | switch to SYSV-format, which has a number of advantages. | 
|  |  | 
|  | * The strip and copy programs now have options to remove debug-symbols only | 
|  | and/or local symbols only.  They now also support long options. | 
|  |  | 
|  |  | 
|  | Copyright (C) 2012-2024 Free Software Foundation, Inc. | 
|  |  | 
|  | Copying and distribution of this file, with or without modification, | 
|  | are permitted in any medium without royalty provided the copyright | 
|  | notice and this notice are preserved. | 
|  |  | 
|  | Local variables: | 
|  | fill-column: 79 | 
|  | End: |