2017-12-19 17:48:40 +08:00
|
|
|
|
2017-12-19 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 22587
|
|
|
|
|
* readelf.c (process_section_headers): Do not complain about an
|
|
|
|
|
sh_info field of 0 in relocation sections of ET_EXEC or ET_DYN
|
|
|
|
|
type executables.
|
|
|
|
|
|
2017-12-15 14:38:56 +08:00
|
|
|
|
2017-12-19 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/ar.exp (unique_symbol): Don't run AR
|
|
|
|
|
if assembly fails.
|
|
|
|
|
* testsuite/binutils-all/arc/objdump.exp (check_assembly): If
|
|
|
|
|
objfile is empty, fail test.
|
|
|
|
|
* testsuite/binutils-all/arm/objdump.exp: Don't return if assembly
|
|
|
|
|
fails for a test, continue on to other tests.
|
|
|
|
|
* testsuite/binutils-all/bfin/objdump.exp: Likewise.
|
|
|
|
|
* testsuite/binutils-all/hppa/objdump.exp: Likewise.
|
|
|
|
|
* testsuite/binutils-all/m68k/objdump.exp: Likewise.
|
|
|
|
|
* testsuite/binutils-all/vax/objdump.exp: Likewise.
|
|
|
|
|
* testsuite/binutils-all/size.exp: Likewise.
|
|
|
|
|
* testsuite/binutils-all/nm.exp: Likewise. Move PR12753 test.
|
|
|
|
|
* testsuite/binutils-all/objcopy.exp: Don't perror on assembly fail.
|
|
|
|
|
* testsuite/binutils-all/objdump.exp: Report assembly fails.
|
|
|
|
|
|
2017-12-19 01:57:18 +08:00
|
|
|
|
2017-12-18 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 22532
|
|
|
|
|
* dwarf.c (read_and_display_attr_value): Add attributes that might
|
|
|
|
|
use the DW_FORM_exprloc form, and if so, display the decoded
|
|
|
|
|
location expression list.
|
|
|
|
|
|
2017-12-14 16:27:02 +08:00
|
|
|
|
2017-12-14 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/lib/utils-lib.exp (default_binutils_assemble_flags):
|
|
|
|
|
Don't perror on assembler diagnostic output.
|
|
|
|
|
* testsuite/binutils-all/nm.exp: Run unique symbol test on all
|
|
|
|
|
ELF targets. Resolve as "unsupported" on assembly failure.
|
|
|
|
|
|
2017-12-11 23:33:18 +08:00
|
|
|
|
2017-12-11 Renlin Li <renlin.li@arm.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/aarch64/objdump.d: New.
|
|
|
|
|
* testsuite/binutils-all/aarch64/objdump.s: New.
|
|
|
|
|
|
2017-12-08 18:07:14 +08:00
|
|
|
|
2017-12-08 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* objcopy.c (copy_relocations_in_section): Use the orelocations
|
|
|
|
|
field of the input section, if it has been initialised.
|
|
|
|
|
* testsuite/binutils-all/note-2-64.d: Skip test on Sparc64.
|
|
|
|
|
|
2017-12-07 02:34:36 +08:00
|
|
|
|
2017-12-06 Jim Wilson <jimw@sifive.com>
|
|
|
|
|
|
|
|
|
|
PR 22465
|
|
|
|
|
* objcopy.c (copy_section): New local extra. If isection->lma not
|
|
|
|
|
exactly divisible by interleave, then bias from. Also adjust
|
|
|
|
|
osection->lma if necessary.
|
|
|
|
|
|
2017-12-06 15:02:48 +08:00
|
|
|
|
2017-12-06 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 22552
|
|
|
|
|
* readelf.c (process_file_header): Don't assume XINDEX case
|
|
|
|
|
value for e_shstrndx is within bounds.
|
|
|
|
|
(load_debug_section): Sanity test e_shstrndx before attempting
|
|
|
|
|
to read .shstrtab. Wrap long lines.
|
|
|
|
|
|
2017-12-01 15:10:55 +08:00
|
|
|
|
2017-12-01 Oleksandr Pikozh <o.pikozh@gmail.com>
|
|
|
|
|
|
|
|
|
|
* doc/binutils.texi: Add --strip-unneeded to objcopy synopsis.
|
|
|
|
|
|
2017-11-30 18:25:01 +08:00
|
|
|
|
2017-11-30 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 22510
|
|
|
|
|
* readelf.c (load_debug_section): Fail if there are no section
|
|
|
|
|
headers available.
|
|
|
|
|
|
2017-11-29 20:40:43 +08:00
|
|
|
|
2017-11-29 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 22508
|
|
|
|
|
* objdump.c (dump_relocs_in_section): Also check the section's
|
|
|
|
|
relocation count to make sure that it is reasonable before
|
|
|
|
|
attempting to allocate space for the relocs.
|
|
|
|
|
|
2017-11-29 15:42:14 +08:00
|
|
|
|
2017-11-29 Stefan Stroe <stroestefan@gmail.com>
|
|
|
|
|
|
|
|
|
|
* po/Make-in (datadir): Define as @datadir@.
|
|
|
|
|
(localedir): Define as @localedir@.
|
|
|
|
|
(gnulocaledir, gettextsrcdir): Use @datarootdir@.
|
|
|
|
|
|
2017-11-29 00:18:33 +08:00
|
|
|
|
2017-11-28 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/22490
|
|
|
|
|
* readelf.c (process_notes_at): Add an argument for note
|
|
|
|
|
alignment. If note alignment is less than 4, use 4 byte
|
|
|
|
|
alignment. Otherwise, skip notes if alignment isn't 4 nor
|
|
|
|
|
8 bytes.
|
|
|
|
|
(process_corefile_note_segments): Pass segment alignment to
|
|
|
|
|
process_notes_at.
|
|
|
|
|
(process_note_sections): Pass section alignment to
|
|
|
|
|
process_notes_at.
|
|
|
|
|
(process_object): Call load_separate_debug_file only if
|
|
|
|
|
e_shstrndx != SHN_UNDEF.
|
|
|
|
|
|
2017-11-27 19:05:39 +08:00
|
|
|
|
2017-11-27 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 22490
|
|
|
|
|
* readelf.c (dump_section_as_bytes): Check for a NULL string
|
|
|
|
|
section pointer.
|
|
|
|
|
(process_notes_at): Compute the alignment to use if displaying
|
|
|
|
|
notes from a segment.
|
|
|
|
|
|
2017-11-27 02:12:35 +08:00
|
|
|
|
2017-11-26 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (load_separate_debug_info): Rename argument name from
|
|
|
|
|
link to xlink.
|
|
|
|
|
|
2017-11-25 06:49:36 +08:00
|
|
|
|
2017-11-24 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/22444
|
|
|
|
|
* readelf.c (process_notes_at): Use ELF_NOTE_DESC_OFFSET to get
|
|
|
|
|
the offset of the note descriptor. Use ELF_NOTE_NEXT_OFFSET to
|
|
|
|
|
get the offset of the next note entry.
|
|
|
|
|
|
2017-11-23 23:53:04 +08:00
|
|
|
|
2017-11-23 Pavel I. Kryukov <kryukov@frtk.ru>
|
|
|
|
|
|
|
|
|
|
PR 22485
|
|
|
|
|
* readelf.c (process_archive): Use memset to initiaise
|
|
|
|
|
thin_filedata structure.
|
|
|
|
|
|
2017-11-22 05:41:10 +08:00
|
|
|
|
2017-11-21 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/22451
|
|
|
|
|
* testsuite/binutils-all/x86-64/objects.exp: New file.
|
|
|
|
|
* testsuite/binutils-all/x86-64/pr22451.o.bz2: Likewise.
|
|
|
|
|
|
2017-11-21 22:04:22 +08:00
|
|
|
|
2017-11-21 Claudiu Zissulescu <claziss@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/arc/objdump.exp: Update pattern matching
|
|
|
|
|
expression.
|
|
|
|
|
|
2017-11-21 21:12:04 +08:00
|
|
|
|
2017-11-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (dwo_name, dwo_dir, dwo_id, dwo_id_len): New variables.
|
|
|
|
|
(read_and_display_attr_value): Record dwo variables if requested.
|
|
|
|
|
(display_augmentation_data): Rename to display_data and make
|
|
|
|
|
generic.
|
|
|
|
|
(load_dwo_file): New function. Loads a separate dwarf object
|
|
|
|
|
file.
|
|
|
|
|
(load_separate_debug_file): Add reporting and loading of separate
|
|
|
|
|
dwarf objet files.
|
|
|
|
|
* readelf.c (process_section_headers): Add do_debug_links to list
|
|
|
|
|
of flags requiring a debug dump.
|
|
|
|
|
(display_debug_section): Tidy up code.
|
|
|
|
|
* doc/debug.options.texi: Add note that dwo links will also be
|
|
|
|
|
followed.
|
|
|
|
|
* testsuite/binutils-all/debuglink.s: Tidy code.
|
|
|
|
|
* testsuite/binutils-all/dwo.s: New test file.
|
|
|
|
|
* testsuite/binutils-all/readelf.wk2: New file - expected output
|
|
|
|
|
from readelf.
|
|
|
|
|
* testsuite/binutils-all/readelf.exp: Run the new test.
|
|
|
|
|
|
2017-11-18 20:48:22 +08:00
|
|
|
|
2017-11-18 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 22443
|
|
|
|
|
* nm.c (sort_symbols_by_size): Don't attempt to access
|
|
|
|
|
section symbol internal_elf_sym.
|
|
|
|
|
(print_symbol): Likewise. Don't call bfd_get_symbol_version_string
|
|
|
|
|
for section symbols.
|
|
|
|
|
* objdump.c (compare_symbols): Don't attempt to access
|
|
|
|
|
section symbol internal_elf_sym.
|
|
|
|
|
(objdump_print_symname): Don't call bfd_get_symbol_version_string
|
|
|
|
|
for section symbols.
|
|
|
|
|
|
2017-11-18 06:47:52 +08:00
|
|
|
|
2017-11-17 Jim Wilson <jimw@sifive.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (elf/riscv.h): Alphabetize include.
|
|
|
|
|
(is_32bit_inplace_add_reloc, is_32bit_inplace_sub_reloc)
|
|
|
|
|
(is_64bit_inplace_add_reloc, is_64bit_inplace_sub_reloc)
|
|
|
|
|
(is_16bit_inplace_add_reloc, is_16bit_inplace_sub_reloc)
|
|
|
|
|
(is_8bit_inplace_add_reloc, is_8bit_inplace_sub_reloc): New.
|
|
|
|
|
(apply_relocations): New locals reloc_inplace and reloc_subtract.
|
|
|
|
|
Call the new functions and set the new locals. Call byte_get if
|
|
|
|
|
reloc_inplace. Subtract sym->st_value if reloc_subtract.
|
|
|
|
|
|
2017-11-17 20:44:16 +08:00
|
|
|
|
2017-11-17 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 22449
|
|
|
|
|
* ar.c (write_archive): Free the temporary file name.
|
|
|
|
|
|
2017-11-17 20:05:34 +08:00
|
|
|
|
2017-11-17 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (process_archive): Include member name in the
|
|
|
|
|
file_name of the filedata structure.
|
|
|
|
|
|
2017-11-15 19:53:22 +08:00
|
|
|
|
2017-11-15 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 22426
|
|
|
|
|
* objcopy.c (copy_main): Free tmpname.
|
|
|
|
|
|
Add support to readelf and objdump for following links to separate debug information files.
Hi Guys,
I am applying the rather large patch attached to this email to enhance
the readelf and objdump programs so that they now have the ability to
follow links to separate debug info files. (As requested by PR
15152). So for example whereas before we had this output:
$ readelf -wi main.exe
Contents of the .debug_info section:
[...]
<15> DW_AT_comp_dir : (alt indirect string, offset: 0x30c)
[...]
With the new option enabled we get:
$ readelf -wiK main.exe
main.exe: Found separate debug info file: dwz.debug
Contents of the .debug_info section (loaded from main.exe):
[...]
<15> DW_AT_comp_dir : (alt indirect string, offset: 0x30c) /home/nickc/Downloads/dwzm
[...]
The link following feature also means that we can get two lots of
output if the same section exists in both the main file and the
separate debug info file:
$ readelf -wiK main.exe
main.exe: Found separate debug info file: dwz.debug
Contents of the .debug_info section (loaded from main.exe):
[...]
Contents of the .debug_info section (loaded from dwz.debug):
[...]
The patch also adds the ability to display the contents of debuglink
sections:
$ readelf -wk main.exe
Contents of the .gnu_debugaltlink section:
Separate debug info file: dwz.debug
Build-ID (0x14 bytes):
c4 a8 89 8d 64 cf 70 8a 35 68 21 f2 ed 24 45 3e 18 7a 7a 93
Naturally there are long versions of these options (=follow-links and
=links). The documentation has been updated as well, and since both
readelf and objdump use the same set of debug display options, I have
moved the text into a separate file. There are also a couple of new
binutils tests to exercise the new behaviour.
There are a couple of missing features in the current patch however,
although I do intend to address them in follow up submissions:
Firstly the code does not check the build-id inside separate debug
info files when it is searching for a file specified by a
.gnu_debugaltlink section. It just assumes that if the file is there,
then it contains the information being sought.
Secondly I have not checked the DWARF-5 version of these link
features, so there will probably be code to add there.
Thirdly I have only implemented link following for the
DW_FORM_GNU_strp_alt format. Other alternate formats (eg
DW_FORM_GNU_ref_alt) have yet to be implemented.
Lastly, whilst implementing this feature I found it necessary to move
some of the global variables used by readelf (eg section_headers) into
a structure that can be passed around. I have moved all of the global
variables that were necessary to get the patch working, but I need to
complete the operation and move the remaining, file-specific variables
(eg dynamic_strings).
Cheers
Nick
binutils PR 15152
* dwarf.h (enum dwarf_section_display_enum): Add gnu_debuglink,
gnu_debugaltlink and separate_debug_str.
(struct dwarf_section): Add filename field.
Add prototypes for load_separate_debug_file, close_debug_file and
open_debug_file.
* dwarf.c (do_debug_links): New.
(do_follow_links): New.
(separate_debug_file, separate_debug_filename): New.
(fetch_alt_indirect_string): New function. Retrieves a string
from the debug string table in the separate debug info file.
(read_and_display_attr_value): Use it with DW_FORM_GNU_strp_alt.
(load_debug_section_with_follow): New function. Like
load_debug_section, but if the first attempt fails, then tries
again in the separate debug info file.
(introduce): New function.
(process_debug_info): Use load_debug_section_with_follow and
introduce.
(load_debug_info): Likewise.
(display_debug_lines_raw): Likewise.
(display_debug_lines_decoded): Likewise.
(display_debug_macinfo): Likewise.
(display_debug_macro): Likewise.
(display_debug_abbrev): Likewise.
(display_debug_loc): Likewise.
(display_debug_str): Likewise.
(display_debug_aranges): Likewise.
(display_debug_addr); Likewise.
(display_debug_frames): Likewise.
(display_gdb_index): Likewise.
(process_cu_tu_index): Likewise.
(load_cu_tu_indexes): Likewise.
(display_debug_links): New function. Displays the contents of a
.gnu_debuglink or .gnu_debugaltlink section.
(calc_gnu_debuglink_ctc32):New function. Calculates a CRC32
value.
(check_gnu_debuglink): New function. Checks the CRC of a
potential separate debug info file.
(parse_gnu_debuglink): New function. Reads a CRC value out of a
.gnu_debuglink section.
(check_gnu_debugaltlink): New function.
(parse_gnu_debugaltlink): New function. Reads the build-id value
out of a .gnu_debugaltlink section.
(load_separate_debug_info): New function. Finds and loads a
separate debug info file.
(load_separate_debug_file): New function. Attempts to find and
follow a link to a separate debug info file.
(free_debug_memory): Free the separate debug info file
information.
(opts_table): Add "follow-links" and "links".
(dwarf_select_sections_by_letters): Add "k" and "K".
(debug_displays): Reformat. Add .gnu-debuglink and
.gnu_debugaltlink.
Add an extra entry for .debug_str in a separate debug info file.
* doc/binutils.texi: Move description of debug dump features
common to both readelf and objdump into...
* objdump.c (usage): Add -Wk and -WK.
(load_specific_debug_section): Initialise the filename field in
the dwarf_section structure.
(close_debug_file): New function.
(open_debug_file): New function.
(dump_dwarf): Load and dump the separate debug info sections.
* readelf.c (struct filedata): New structure. Contains various
variables that used to be global:
(current_file_size, string_table, string_table_length, elf_header)
(section_headers, program_headers, dump_sects, num_dump_sects):
Move into filedata structure.
(cmdline): New global variable. Contains list of sections to dump
by number, as specified on the command line.
Add filedata parameter to most functions.
(load_debug_section): Load the string table if it has not already
been retrieved.
(close_file): New function.
(close_debug_file): New function.
(open_file): New function.
(open_debug_file): New function.
(process_object): Process sections in any separate debug info files.
* doc/debug.options.texi: New file. Add description of =links and
=follow-links options.
* NEWS: Mention the new feature.
* elfcomm.c: Have the byte gte functions take a const pointer.
* elfcomm.h: Update prototypes.
* testsuite/binutils-all/dw5.W: Update expected output.
* testsuite/binutils-all/objdump.WL: Update expected output.
* testsuite/binutils-all/objdump.exp: Add test of -WK and -Wk.
* testsuite/binutils-all/readelf.exp: Add test of -wK and -wk.
* testsuite/binutils-all/readelf.k: New file.
* testsuite/binutils-all/objdump.Wk: New file.
* testsuite/binutils-all/objdump.WK2: New file.
* testsuite/binutils-all/linkdebug.s: New file.
* testsuite/binutils-all/debuglink.s: New file.
gas * testsuite/gas/avr/large-debug-line-table.d: Update expected
output.
* testsuite/gas/elf/dwarf2-11.d: Likewise.
* testsuite/gas/elf/dwarf2-12.d: Likewise.
* testsuite/gas/elf/dwarf2-13.d: Likewise.
* testsuite/gas/elf/dwarf2-14.d: Likewise.
* testsuite/gas/elf/dwarf2-15.d: Likewise.
* testsuite/gas/elf/dwarf2-16.d: Likewise.
* testsuite/gas/elf/dwarf2-17.d: Likewise.
* testsuite/gas/elf/dwarf2-18.d: Likewise.
* testsuite/gas/elf/dwarf2-5.d: Likewise.
* testsuite/gas/elf/dwarf2-6.d: Likewise.
* testsuite/gas/elf/dwarf2-7.d: Likewise.
ld * testsuite/ld-avr/gc-section-debugline.d: Update expected
output.
2017-11-15 19:34:03 +08:00
|
|
|
|
2017-11-15 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 15152
|
|
|
|
|
* dwarf.h (enum dwarf_section_display_enum): Add gnu_debuglink,
|
|
|
|
|
gnu_debugaltlink and separate_debug_str.
|
|
|
|
|
(struct dwarf_section): Add filename field.
|
|
|
|
|
Add prototypes for load_separate_debug_file, close_debug_file and
|
|
|
|
|
open_debug_file.
|
|
|
|
|
* dwarf.c (do_debug_links): New.
|
|
|
|
|
(do_follow_links): New.
|
|
|
|
|
(separate_debug_file, separate_debug_filename): New.
|
|
|
|
|
(fetch_alt_indirect_string): New function. Retrieves a string
|
|
|
|
|
from the debug string table in the separate debug info file.
|
|
|
|
|
(read_and_display_attr_value): Use it with DW_FORM_GNU_strp_alt.
|
|
|
|
|
(load_debug_section_with_follow): New function. Like
|
|
|
|
|
load_debug_section, but if the first attempt fails, then tries
|
|
|
|
|
again in the separate debug info file.
|
|
|
|
|
(introduce): New function.
|
|
|
|
|
(process_debug_info): Use load_debug_section_with_follow and
|
|
|
|
|
introduce.
|
|
|
|
|
(load_debug_info): Likewise.
|
|
|
|
|
(display_debug_lines_raw): Likewise.
|
|
|
|
|
(display_debug_lines_decoded): Likewise.
|
|
|
|
|
(display_debug_macinfo): Likewise.
|
|
|
|
|
(display_debug_macro): Likewise.
|
|
|
|
|
(display_debug_abbrev): Likewise.
|
|
|
|
|
(display_debug_loc): Likewise.
|
|
|
|
|
(display_debug_str): Likewise.
|
|
|
|
|
(display_debug_aranges): Likewise.
|
|
|
|
|
(display_debug_addr); Likewise.
|
|
|
|
|
(display_debug_frames): Likewise.
|
|
|
|
|
(display_gdb_index): Likewise.
|
|
|
|
|
(process_cu_tu_index): Likewise.
|
|
|
|
|
(load_cu_tu_indexes): Likewise.
|
|
|
|
|
(display_debug_links): New function. Displays the contents of a
|
|
|
|
|
.gnu_debuglink or .gnu_debugaltlink section.
|
|
|
|
|
(calc_gnu_debuglink_ctc32):New function. Calculates a CRC32
|
|
|
|
|
value.
|
|
|
|
|
(check_gnu_debuglink): New function. Checks the CRC of a
|
|
|
|
|
potential separate debug info file.
|
|
|
|
|
(parse_gnu_debuglink): New function. Reads a CRC value out of a
|
|
|
|
|
.gnu_debuglink section.
|
|
|
|
|
(check_gnu_debugaltlink): New function.
|
|
|
|
|
(parse_gnu_debugaltlink): New function. Reads the build-id value
|
|
|
|
|
out of a .gnu_debugaltlink section.
|
|
|
|
|
(load_separate_debug_info): New function. Finds and loads a
|
|
|
|
|
separate debug info file.
|
|
|
|
|
(load_separate_debug_file): New function. Attempts to find and
|
|
|
|
|
follow a link to a separate debug info file.
|
|
|
|
|
(free_debug_memory): Free the separate debug info file
|
|
|
|
|
information.
|
|
|
|
|
(opts_table): Add "follow-links" and "links".
|
|
|
|
|
(dwarf_select_sections_by_letters): Add "k" and "K".
|
|
|
|
|
(debug_displays): Reformat. Add .gnu-debuglink and
|
|
|
|
|
.gnu_debugaltlink.
|
|
|
|
|
Add an extra entry for .debug_str in a separate debug info file.
|
|
|
|
|
* doc/binutils.texi: Move description of debug dump features
|
|
|
|
|
common to both readelf and objdump into...
|
|
|
|
|
* objdump.c (usage): Add -Wk and -WK.
|
|
|
|
|
(load_specific_debug_section): Initialise the filename field in
|
|
|
|
|
the dwarf_section structure.
|
|
|
|
|
(close_debug_file): New function.
|
|
|
|
|
(open_debug_file): New function.
|
|
|
|
|
(dump_dwarf): Load and dump the separate debug info sections.
|
|
|
|
|
* readelf.c (struct filedata): New structure. Contains various
|
|
|
|
|
variables that used to be global:
|
|
|
|
|
(current_file_size, string_table, string_table_length, elf_header)
|
|
|
|
|
(section_headers, program_headers, dump_sects, num_dump_sects):
|
|
|
|
|
Move into filedata structure.
|
|
|
|
|
(cmdline): New global variable. Contains list of sections to dump
|
|
|
|
|
by number, as specified on the command line.
|
|
|
|
|
Add filedata parameter to most functions.
|
|
|
|
|
(load_debug_section): Load the string table if it has not already
|
|
|
|
|
been retrieved.
|
|
|
|
|
(close_file): New function.
|
|
|
|
|
(close_debug_file): New function.
|
|
|
|
|
(open_file): New function.
|
|
|
|
|
(open_debug_file): New function.
|
|
|
|
|
(process_object): Process sections in any separate debug info files.
|
|
|
|
|
* doc/debug.options.texi: New file. Add description of =links and
|
|
|
|
|
=follow-links options.
|
|
|
|
|
* NEWS: Mention the new feature.
|
|
|
|
|
* elfcomm.c: Have the byte get functions take a const pointer.
|
|
|
|
|
* elfcomm.h: Update prototypes.
|
|
|
|
|
* testsuite/binutils-all/dw5.W: Update expected output.
|
|
|
|
|
* testsuite/binutils-all/objdump.WL: Update expected output.
|
|
|
|
|
* testsuite/binutils-all/objdump.exp: Add test of -WK and -Wk.
|
|
|
|
|
* testsuite/binutils-all/readelf.exp: Add test of -wK and -wk.
|
|
|
|
|
* testsuite/binutils-all/readelf.k: New file.
|
|
|
|
|
* testsuite/binutils-all/objdump.Wk: New file.
|
|
|
|
|
* testsuite/binutils-all/objdump.WK2: New file.
|
|
|
|
|
* testsuite/binutils-all/linkdebug.s: New file.
|
|
|
|
|
* testsuite/binutils-all/debuglink.s: New file.
|
|
|
|
|
|
2017-11-11 11:24:45 +08:00
|
|
|
|
2017-11-10 Jim Wilson <jimw@sifive.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/objdump.exp: Expect the debug_ranges test to
|
|
|
|
|
pass.
|
|
|
|
|
|
2017-11-08 01:43:18 +08:00
|
|
|
|
2017-11-07 Jim Wilson <jimw@sifive.com>
|
|
|
|
|
|
|
|
|
|
* MAINTAINERS (RISC-V): Fix typo in my email address.
|
|
|
|
|
|
2017-11-07 09:53:12 +08:00
|
|
|
|
2017-11-07 Palmer Dabbelt <palmer@sifive.com>
|
|
|
|
|
|
|
|
|
|
* MAINTAINERS (RISC-V): Add Jim Wilson as a maintainer.
|
|
|
|
|
Clean up Andrew's entry (remove trailing space, add tabs).
|
|
|
|
|
Change Palmer's email address, and clean up entry (add tabs).
|
|
|
|
|
|
readelf ngettext fixes
This patch is a first pass at fixing readelf message pluralization.
I've deliberately not fixed the "out of memory" errors since it's very
unlikely that they will ever be complaining about not being able to
allocate for a single entry, and a few others where the size is very
unlikely to be 1 byte.
Then there are messages like this one:
"Out of %lu items there are %zu bucket clashes (longest of %zu entries).\n"
I suppose this could be split into three parts, "Of %lu items ",
"there are %zu bucket clashes ", and "(longest of %zu entries).\n",
each part being printed separately, but that might not be ideal for
sentence construction in other languages. For now I'm punting on this
one.
Changes to readelf output require lots of testsuite adjustment..
binutils/
* dwarf.c (read_uleb128): Properly pluralize messages.
(display_debug_lines_raw, display_debug_loc): Likewise.
(display_debug_names, process_cu_tu_index): Likewise.
* od-macho.c (dump_code_signature_superblob): Likewise.
* readelf.c (process_program_headers): Likewise.
(process_section_header, process_relocs): Likewise.
(hppa_process_unwind, arm_process_unwind): Likewise.
(process_dynamic_section, process_version_sections): Likewise.
(process_symbol_table, process_syminfo): Likewise.
(apply_relocations, process_mips_specific): Likewise.
(process_gnu_liblist, process_notes_at): Likewise.
(process_archive): Likewise.
* testsuite/binutils-all/dw2-1.W,
* testsuite/binutils-all/dw2-3.W,
* testsuite/binutils-all/dw2-3gabi.W,
* testsuite/binutils-all/dw5.S,
* testsuite/binutils-all/dw5.W,
* testsuite/binutils-all/i386/compressed-1a.d,
* testsuite/binutils-all/libdw2-compressedgabi.out,
* testsuite/binutils-all/objdump.W,
* testsuite/binutils-all/readelf.r,
* testsuite/binutils-all/readelf.r-64,
* testsuite/binutils-all/x86-64/compressed-1a.d: Update
for pluralization fixes.
gas/
* testsuite/gas/arm/got_prel.d,
* testsuite/gas/elf/dwarf2-1.d,
* testsuite/gas/elf/dwarf2-2.d,
* testsuite/gas/elf/dwarf2-3.d,
* testsuite/gas/elf/dwarf2-5.d,
* testsuite/gas/elf/dwarf2-6.d,
* testsuite/gas/i386/debug1.d,
* testsuite/gas/i386/dw2-compress-1.d,
* testsuite/gas/i386/dw2-compress-3a.d,
* testsuite/gas/i386/dw2-compress-3b.d,
* testsuite/gas/i386/dw2-compressed-1.d,
* testsuite/gas/i386/dw2-compressed-3a.d,
* testsuite/gas/i386/dw2-compressed-3b.d,
* testsuite/gas/i386/ilp32/x86-64-localpic.d,
* testsuite/gas/i386/localpic.d,
* testsuite/gas/i386/x86-64-localpic.d,
* testsuite/gas/ia64/pr13167.d,
* testsuite/gas/mips/loc-swap-2.d,
* testsuite/gas/mips/loc-swap.d,
* testsuite/gas/mips/micromips@loc-swap-2.d,
* testsuite/gas/mips/micromips@loc-swap.d,
* testsuite/gas/mips/mips16-dwarf2-n32.d,
* testsuite/gas/mips/mips16-dwarf2.d,
* testsuite/gas/mips/mips16@loc-swap-2.d,
* testsuite/gas/mips/mips16@loc-swap.d,
* testsuite/gas/mips/mips16e@loc-swap.d,
* testsuite/gas/mmix/bspec-1.d,
* testsuite/gas/mmix/bspec-2.d,
* testsuite/gas/tic6x/unwind-1.d,
* testsuite/gas/tic6x/unwind-2.d,
* testsuite/gas/tic6x/unwind-3.d: Update for pluralization
fixes.
ld/
* testsuite/ld-aarch64/ifunc-13.d,
* testsuite/ld-aarch64/ifunc-15.d,
* testsuite/ld-aarch64/ifunc-20.d,
* testsuite/ld-alpha/tlsbin.rd,
* testsuite/ld-alpha/tlspic.rd,
* testsuite/ld-arm/ifunc-3.rd,
* testsuite/ld-arm/ifunc-9.rd,
* testsuite/ld-arm/unwind-mix.d,
* testsuite/ld-arm/unwind-rel.d,
* testsuite/ld-cris/hiddef1.d,
* testsuite/ld-cris/libdso-13.d,
* testsuite/ld-cris/libdso-2.d,
* testsuite/ld-cris/pr16044.d,
* testsuite/ld-cris/tls-local-63.d,
* testsuite/ld-cris/tls-local-64.d,
* testsuite/ld-cris/tls-und-38.d,
* testsuite/ld-cris/tls-und-42.d,
* testsuite/ld-cris/tls-und-46.d,
* testsuite/ld-cris/tls-und-50.d,
* testsuite/ld-cris/weakref3.d,
* testsuite/ld-cris/weakref4.d,
* testsuite/ld-elf/comm-data2r.rd,
* testsuite/ld-elf/discard1.d,
* testsuite/ld-elf/discard2.d,
* testsuite/ld-elf/pr19539.d,
* testsuite/ld-elf/pr22374-1.r,
* testsuite/ld-elf/pr22374-2.r,
* testsuite/ld-i386/combreloc.d,
* testsuite/ld-i386/emit-relocs-nacl.rd,
* testsuite/ld-i386/emit-relocs.rd,
* testsuite/ld-i386/pr13302.d,
* testsuite/ld-i386/pr17709-nacl.rd,
* testsuite/ld-i386/pr17709.rd,
* testsuite/ld-i386/pr19539.d,
* testsuite/ld-i386/pr19615.d,
* testsuite/ld-i386/pr19636-1a.d,
* testsuite/ld-i386/pr19636-1e.d,
* testsuite/ld-i386/pr19636-1f.d,
* testsuite/ld-i386/pr19636-2a.d,
* testsuite/ld-i386/pr19636-2b.d,
* testsuite/ld-i386/pr19636-2d-nacl.d,
* testsuite/ld-i386/pr19636-2e-nacl.d,
* testsuite/ld-i386/pr19636-3a.d,
* testsuite/ld-i386/pr19636-3d.d,
* testsuite/ld-i386/pr19636-3e.d,
* testsuite/ld-i386/pr19636-4a.d,
* testsuite/ld-i386/pr19645.d,
* testsuite/ld-i386/pr19827-nacl.rd,
* testsuite/ld-i386/pr19827.rd,
* testsuite/ld-i386/pr20253-4a.d,
* testsuite/ld-i386/pr20253-4b.d,
* testsuite/ld-i386/pr20253-5.d,
* testsuite/ld-i386/tlsbin-nacl.rd,
* testsuite/ld-i386/tlsbin.rd,
* testsuite/ld-i386/tlspic-nacl.rd,
* testsuite/ld-i386/tlspic.rd,
* testsuite/ld-i386/undefweakb.d,
* testsuite/ld-ia64/tlsbin.rd,
* testsuite/ld-ia64/tlspic.rd,
* testsuite/ld-ifunc/ifunc-13-i386.d,
* testsuite/ld-ifunc/ifunc-13-x86-64.d,
* testsuite/ld-ifunc/ifunc-15-i386.d,
* testsuite/ld-ifunc/ifunc-15-x86-64.d,
* testsuite/ld-ifunc/ifunc-20-i386.d,
* testsuite/ld-ifunc/ifunc-20-x86-64.d,
* testsuite/ld-ifunc/ifunc-23a-x86.d,
* testsuite/ld-ifunc/ifunc-23b-x86.d,
* testsuite/ld-ifunc/ifunc-23c-x86.d,
* testsuite/ld-ifunc/ifunc-24a-x86.d,
* testsuite/ld-ifunc/ifunc-24b-x86.d,
* testsuite/ld-ifunc/ifunc-24c-x86.d,
* testsuite/ld-ifunc/ifunc-25a-x86.d,
* testsuite/ld-ifunc/ifunc-25b-x86.d,
* testsuite/ld-ifunc/ifunc-25c-x86.d,
* testsuite/ld-m68k/got-1.d,
* testsuite/ld-mips-elf/vxworks1.rd,
* testsuite/ld-powerpc/ambiguousv1.d,
* testsuite/ld-powerpc/ambiguousv1b.d,
* testsuite/ld-powerpc/ambiguousv2.d,
* testsuite/ld-powerpc/ambiguousv2b.d,
* testsuite/ld-powerpc/tlsexe.r,
* testsuite/ld-powerpc/tlsexe32.r,
* testsuite/ld-powerpc/tlsexetoc.r,
* testsuite/ld-powerpc/tlsso.r,
* testsuite/ld-powerpc/tlsso32.r,
* testsuite/ld-powerpc/tlstocso.r,
* testsuite/ld-powerpc/vle-multiseg-1.d,
* testsuite/ld-powerpc/vle-multiseg-2.d,
* testsuite/ld-powerpc/vle-multiseg-3.d,
* testsuite/ld-s390/tlsbin.rd,
* testsuite/ld-s390/tlsbin_64.rd,
* testsuite/ld-s390/tlspic.rd,
* testsuite/ld-s390/tlspic_64.rd,
* testsuite/ld-sh/ld-r-1.d,
* testsuite/ld-sh/sh64/gotplt.d,
* testsuite/ld-sh/shared-1.d,
* testsuite/ld-sh/tlsbin-2.d,
* testsuite/ld-sh/tlspic-2.d,
* testsuite/ld-sparc/gotop32.rd,
* testsuite/ld-sparc/gotop64.rd,
* testsuite/ld-sparc/tlssunpic32.rd,
* testsuite/ld-sparc/tlssunpic64.rd,
* testsuite/ld-sparc/vxworks1-lib.rd,
* testsuite/ld-tic6x/shlib-app-1.rd,
* testsuite/ld-tic6x/shlib-app-1b.rd,
* testsuite/ld-tic6x/shlib-app-1r.rd,
* testsuite/ld-tic6x/shlib-app-1rb.rd,
* testsuite/ld-tic6x/shlib-noindex.rd,
* testsuite/ld-vax-elf/export-class-data.rd,
* testsuite/ld-x86-64/pr13082-1a.d,
* testsuite/ld-x86-64/pr13082-1b.d,
* testsuite/ld-x86-64/pr13082-2a.d,
* testsuite/ld-x86-64/pr13082-2b.d,
* testsuite/ld-x86-64/pr13082-3a.d,
* testsuite/ld-x86-64/pr13082-3c.d,
* testsuite/ld-x86-64/pr13082-4a.d,
* testsuite/ld-x86-64/pr13082-5a.d,
* testsuite/ld-x86-64/pr13082-5b.d,
* testsuite/ld-x86-64/pr13082-6a.d,
* testsuite/ld-x86-64/pr13082-6b.d,
* testsuite/ld-x86-64/pr17709-nacl.rd,
* testsuite/ld-x86-64/pr17709.rd,
* testsuite/ld-x86-64/pr19539a.d,
* testsuite/ld-x86-64/pr19539b.d,
* testsuite/ld-x86-64/pr19615.d,
* testsuite/ld-x86-64/pr19636-1a.d,
* testsuite/ld-x86-64/pr19636-1d.d,
* testsuite/ld-x86-64/pr19636-1e.d,
* testsuite/ld-x86-64/pr19636-2a.d,
* testsuite/ld-x86-64/pr19636-2e.d,
* testsuite/ld-x86-64/pr19636-2f.d,
* testsuite/ld-x86-64/pr19636-3a.d,
* testsuite/ld-x86-64/pr19645.d,
* testsuite/ld-x86-64/pr19807-2b.d,
* testsuite/ld-x86-64/pr19807-2d.d,
* testsuite/ld-x86-64/pr19827-nacl.rd,
* testsuite/ld-x86-64/pr19827.rd,
* testsuite/ld-x86-64/pr20253-4a.d,
* testsuite/ld-x86-64/pr20253-4b.d,
* testsuite/ld-x86-64/pr20253-4d.d,
* testsuite/ld-x86-64/pr20253-4e.d,
* testsuite/ld-x86-64/pr20253-5a.d,
* testsuite/ld-x86-64/pr20253-5b.d,
* testsuite/ld-x86-64/tlsbin-nacl.rd,
* testsuite/ld-x86-64/tlsbin.rd,
* testsuite/ld-x86-64/tlspic-nacl.rd,
* testsuite/ld-x86-64/tlspic.rd,
* testsuite/ld-x86-64/tlspic2-nacl.rd: Update for
pluralization fixes.
2017-11-07 08:48:29 +08:00
|
|
|
|
2017-11-07 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (read_uleb128): Properly pluralize messages.
|
|
|
|
|
(display_debug_lines_raw, display_debug_loc): Likewise.
|
|
|
|
|
(display_debug_names, process_cu_tu_index): Likewise.
|
|
|
|
|
* od-macho.c (dump_code_signature_superblob): Likewise.
|
|
|
|
|
* readelf.c (process_program_headers): Likewise.
|
|
|
|
|
(process_section_header, process_relocs): Likewise.
|
|
|
|
|
(hppa_process_unwind, arm_process_unwind): Likewise.
|
|
|
|
|
(process_dynamic_section, process_version_sections): Likewise.
|
|
|
|
|
(process_symbol_table, process_syminfo): Likewise.
|
|
|
|
|
(apply_relocations, process_mips_specific): Likewise.
|
|
|
|
|
(process_gnu_liblist, process_notes_at): Likewise.
|
|
|
|
|
(process_archive): Likewise.
|
|
|
|
|
* testsuite/binutils-all/dw2-1.W,
|
|
|
|
|
* testsuite/binutils-all/dw2-3.W,
|
|
|
|
|
* testsuite/binutils-all/dw2-3gabi.W,
|
|
|
|
|
* testsuite/binutils-all/dw5.S,
|
|
|
|
|
* testsuite/binutils-all/dw5.W,
|
|
|
|
|
* testsuite/binutils-all/i386/compressed-1a.d,
|
|
|
|
|
* testsuite/binutils-all/libdw2-compressedgabi.out,
|
|
|
|
|
* testsuite/binutils-all/objdump.W,
|
|
|
|
|
* testsuite/binutils-all/readelf.r,
|
|
|
|
|
* testsuite/binutils-all/readelf.r-64,
|
|
|
|
|
* testsuite/binutils-all/x86-64/compressed-1a.d: Update
|
|
|
|
|
for pluralization fixes.
|
|
|
|
|
|
ngettext support
binutils has lacked proper pluralization of output messages for a long
time, for example, readelf will display information about a section
that "contains 1 entries" or "There are 1 section headers". Fixing
this properly requires us to use ngettext, because other languages
have different rules to English.
This patch defines macros for ngettext and friends to handle builds
with --disable-nls, and tidies the existing nls support. I've
redefined gettext rather than just defining "_" as dgettext in bfd and
opcodes in case someone wants to use gettext there (which might
conceivably happen with generated code).
bfd/
* sysdep.h: Formatting, comment fixes.
(gettext, ngettext): Redefine when ENABLE_NLS.
(ngettext, dngettext, dcngettext): Define when !ENABLE_NLS.
(_): Define using gettext.
(textdomain, bindtextdomain): Use safer "do nothing".
* hosts/alphavms.h (textdomain, bindtextdomain): Likewise.
(ngettext, dngettext, dcngettext): Define when !ENABLE_NLS.
opcodes/
* opintl.h: Formatting, comment fixes.
(gettext, ngettext): Redefine when ENABLE_NLS.
(ngettext, dngettext, dcngettext): Define when !ENABLE_NLS.
(_): Define using gettext.
(textdomain, bindtextdomain): Use safer "do nothing".
binutils/
* sysdep.h (textdomain, bindtextdomain): Use safer "do nothing".
(ngettext, dngettext, dcngettext): Define when !ENABLE_NLS.
gas/
* asintl.h (textdomain, bindtextdomain): Use safer "do nothing".
(ngettext, dngettext, dcngettext): Define when !ENABLE_NLS.
gold/
* system.h (textdomain, bindtextdomain): Use safer "do nothing".
(ngettext, dngettext, dcngettext): Define when !ENABLE_NLS.
ld/
* ld.h (textdomain, bindtextdomain): Use safer "do nothing".
(ngettext, dngettext, dcngettext): Define when !ENABLE_NLS.
2017-11-06 12:50:00 +08:00
|
|
|
|
2017-11-07 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* sysdep.h (textdomain, bindtextdomain): Use safer "do nothing".
|
|
|
|
|
(ngettext, dngettext, dcngettext): Define when !ENABLE_NLS.
|
|
|
|
|
|
2017-11-03 22:36:42 +08:00
|
|
|
|
2017-11-03 Claudiu Zissulescu <claziss@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* doc/binutils.texi (ARC): Update disassembler options.
|
|
|
|
|
* testsuite/binutils-all/arc/hexprint.s: New file.
|
|
|
|
|
* testsuite/binutils-all/arc/objdump.exp: Test hex printing
|
|
|
|
|
feature.
|
|
|
|
|
|
2017-11-03 21:57:15 +08:00
|
|
|
|
2017-11-03 Mingi Cho <mgcho.minic@gmail.com>
|
|
|
|
|
Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 22386
|
|
|
|
|
* dwarf.c (read_cie): Use bfd_size_type for
|
|
|
|
|
augmentation_data_len.
|
|
|
|
|
(display_augmentation_data): New function.
|
|
|
|
|
(display_debug_frames): Use it.
|
|
|
|
|
Check for integer overflow when testing augmentation_data_len.
|
|
|
|
|
|
2017-11-03 01:01:08 +08:00
|
|
|
|
2017-11-02 Mingi Cho <mgcho.minic@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 22384
|
|
|
|
|
* readelf.c (print_gnu_property_note): Improve overflow checks so
|
|
|
|
|
that they will work on a 32-bit host.
|
|
|
|
|
|
FT32B is a new FT32 family member. It has a code compression scheme, which requires the use of linker relaxations. The change is quite large, so submission is in several parts.
Part 2 adds a relaxation pass, which actually implements the code compression scheme.
bfd * archures.c: Add bfd_mach_ft32b.
* cpu-ft32.c: Add arch_info_struct.
* elf32-ft32.c: Add R_FT32_RELAX, SC0, SC1,
DIFF32. (ft32_elf_relocate_section): Add clauses
for R_FT32_SC0, SC1, DIFF32. (ft32_reloc_shortable,
elf32_ft32_is_diff_reloc, elf32_ft32_adjust_diff_reloc_value,
elf32_ft32_adjust_reloc_if_spans_insn,
elf32_ft32_relax_delete_bytes, elf32_ft32_relax_is_branch_target,
ft32_elf_relax_section): New function.
* reloc.c: Add BFD_RELOC_FT32_RELAX, SC0, SC1, DIFF32.
* bfd-in2.h: Regenerate.
* libbfd.h: Regenerate.
gas * config/tc-ft32.c (md_assemble): add relaxation reloc
BFD_RELOC_FT32_RELAX. (md_longopts): Add "norelax" and
"no-relax". (md_apply_fix): Add reloc BFD_RELOC_FT32_DIFF32.
(relaxable_section, ft32_validate_fix_sub, ft32_force_relocation,
ft32_allow_local_subtract): New function.
* config/tc-ft32.h: remove unused MD_PCREL_FROM_SECTION.
* testsuite/gas/ft32/insnsc.s: New test exercising all FT32B
shortcodes.
include * elf/ft32.h: Add R_FT32_RELAX, SC0, SC1, DIFF32.
2017-11-01 23:33:24 +08:00
|
|
|
|
2017-11-01 James Bowman <james.bowman@ftdichip.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (is_16bit_abs_reloc): Add entry for FT32.
|
|
|
|
|
|
2017-10-31 21:48:03 +08:00
|
|
|
|
2017-10-31 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (process_relocs): Tell users if no static relocs were
|
|
|
|
|
found, but if they had added --use-dynamic to the command line
|
|
|
|
|
then relocs would have been displayed.
|
|
|
|
|
|
2017-10-28 19:01:16 +08:00
|
|
|
|
2017-10-28 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 22361
|
|
|
|
|
* readelf.c (process_archive_index_and_symbols): Ensure ar_size
|
|
|
|
|
field is zero terminated for strtoul.
|
|
|
|
|
(setup_archive, get_archive_member_name): Likewise.
|
|
|
|
|
|
2017-10-27 21:01:36 +08:00
|
|
|
|
2017-10-27 Simon Marchi <simon.marchi@ericsson.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (struct Frame_Chunk) <cfa_reg>: Change type to
|
|
|
|
|
unsigned int.
|
|
|
|
|
(display_debug_frames): Read CFA reg as an unsigned number.
|
|
|
|
|
|
2017-10-25 13:02:52 +08:00
|
|
|
|
2017-10-25 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* nm.c (filter_symbols): Match "__gnu_lto_slim" optionally prefixed
|
|
|
|
|
with "_".
|
|
|
|
|
|
2017-10-18 22:30:24 +08:00
|
|
|
|
2017-10-18 Eric Botcazou <ebotcazou@adacore.com>
|
|
|
|
|
|
|
|
|
|
* MAINTAINERS: Add myself as Visium maintainer.
|
|
|
|
|
|
2017-10-18 21:36:48 +08:00
|
|
|
|
2017-10-18 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
2017-10-18 21:40:06 +08:00
|
|
|
|
* README-how-to-make-a-release: A note about checking file and
|
|
|
|
|
directory permissions.
|
|
|
|
|
|
|
|
|
|
* MAINTAINERS: Move Svein Seldal to Past Maintainers section.
|
2017-10-18 21:36:48 +08:00
|
|
|
|
|
2017-10-18 09:35:39 +08:00
|
|
|
|
2017-10-18 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 22303
|
|
|
|
|
* readelf.c (print_core_note): Ensure "count" sanity check
|
|
|
|
|
calculation doesn't overflow.
|
|
|
|
|
(process_notes_at): Perform note namesz and descsz checks
|
|
|
|
|
using unsigned comparisons against data remaining. Catch
|
|
|
|
|
alignment overflow of namesz and descsz too. Don't allocate a
|
|
|
|
|
temp for terminating "name" when there is space available
|
|
|
|
|
before descdata.
|
|
|
|
|
|
2017-10-17 23:37:33 +08:00
|
|
|
|
2017-10-17 Tom Tromey <tom@tromey.com>
|
|
|
|
|
|
|
|
|
|
* MAINTAINERS: Add myself as dwarf-mode.el maintainer.
|
|
|
|
|
|
Display more information when decoding DW_AT_endianity, DW_AT_decimal_sign, DW_AT_defaulted and DW_AT_discr_list DWARF attributes.
* dwarf.c (read_and_display_attr_value): Handle DW_AT_endianity,
DW_END_default, DW_END_big, DW_END_little, DW_ATE_UCS,
DW_ATE_ASCII, DW_CC_pass_by_reference, DW_CC_pass_by_value,
DW_CC_GNU_renesas_sh, DW_CC_GNU_borland_fastcall_i386,
DW_AT_decimal_sign, DW_AT_defaulted, DW_AT_discr_list.
(get_TAG_name): Report user generated tag values.
* testsuite/binutils-all/dwarf-attributes.S: New test.
* testsuite/binutils-all/dwarf-attributes.W. Expected output from
readelf.
* testsuite/binutils-all/readelf.exp: Run the new test.
2017-10-11 19:02:51 +08:00
|
|
|
|
2017-10-11 Peeter Joot <peeter.joot@lzlabs.com>
|
|
|
|
|
Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (read_and_display_attr_value): Handle DW_AT_endianity,
|
|
|
|
|
DW_END_default, DW_END_big, DW_END_little, DW_ATE_UCS,
|
|
|
|
|
DW_ATE_ASCII, DW_CC_pass_by_reference, DW_CC_pass_by_value,
|
|
|
|
|
DW_CC_GNU_renesas_sh, DW_CC_GNU_borland_fastcall_i386,
|
|
|
|
|
DW_AT_decimal_sign, DW_AT_defaulted, DW_AT_discr_list.
|
|
|
|
|
(get_TAG_name): Report user generated tag values.
|
|
|
|
|
* testsuite/binutils-all/dwarf-attributes.S: New test.
|
|
|
|
|
* testsuite/binutils-all/dwarf-attributes.W. Expected output from
|
|
|
|
|
readelf.
|
|
|
|
|
* testsuite/binutils-all/readelf.exp: Run the new test.
|
|
|
|
|
|
2017-10-07 04:38:36 +08:00
|
|
|
|
2017-10-10 Tom Tromey <tom@tromey.com>
|
|
|
|
|
|
|
|
|
|
* dwarf-mode.el: Bump to version 1.4.
|
|
|
|
|
|
2017-10-07 04:36:44 +08:00
|
|
|
|
2017-10-10 Tom Tromey <tom@tromey.com>
|
|
|
|
|
|
|
|
|
|
* dwarf-mode.el (dwarf--process, dwarf--deletion-region): New
|
|
|
|
|
defvar.
|
|
|
|
|
(dwarf--check-running, dwarf--sentinel, dwarf--invoke)
|
|
|
|
|
(dwarf--filter): New functions.
|
|
|
|
|
(dwarf-do-insert-substructure, dwarf-do-refresh): Call
|
|
|
|
|
dwarf--check-running, dwarf--invoke.
|
|
|
|
|
(dwarf-browse): Initialize new variables.
|
|
|
|
|
|
2017-10-07 03:42:49 +08:00
|
|
|
|
2017-10-10 Tom Tromey <tom@tromey.com>
|
|
|
|
|
|
|
|
|
|
* dwarf-mode.el: Set lexical-binding.
|
|
|
|
|
|
2017-10-07 03:18:31 +08:00
|
|
|
|
2017-10-10 Tom Tromey <tom@tromey.com>
|
|
|
|
|
|
|
|
|
|
* dwarf-mode.el (dwarf-mode-map): New defvar.
|
|
|
|
|
|
2017-10-10 20:37:58 +08:00
|
|
|
|
2017-10-10 Tom Tromey <tromey@sourceware.org>
|
|
|
|
|
|
|
|
|
|
PR 22249
|
|
|
|
|
* dwarf.c (process_debug_info): Skip any comp unit that ends
|
|
|
|
|
before dwarf_start_die.
|
|
|
|
|
|
2017-10-06 11:44:21 +08:00
|
|
|
|
2017-10-06 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (process_debug_info): Consolidate header length checks.
|
|
|
|
|
(display_debug_pubnames_worker): Use "start" to read header.
|
|
|
|
|
Properly check header length and report errors earlier.
|
|
|
|
|
Simplify loop printing pubnames.
|
|
|
|
|
(get_line_filename_and_dirname): Catch small negative "length"
|
|
|
|
|
values.
|
|
|
|
|
(display_debug_aranges): Likewise. Report header errors
|
|
|
|
|
earlier using standardized message.
|
|
|
|
|
(display_debug_names): Likewise.
|
|
|
|
|
|
2017-10-05 22:19:39 +08:00
|
|
|
|
2017-10-05 Joseph Myers <joseph@codesourcery.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (decode_arm_unwind): Initialize res to TRUE.
|
|
|
|
|
|
2017-10-05 20:48:32 +08:00
|
|
|
|
2017-10-05 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 22260
|
|
|
|
|
* objcopy.c (strip_main): Add 'M' character to short options list
|
|
|
|
|
when calling getopt_long.
|
|
|
|
|
|
2017-10-05 20:25:44 +08:00
|
|
|
|
2017-10-05 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 22262
|
|
|
|
|
* readelf.c (dump_relocations): Do not truncate reloc names when
|
|
|
|
|
displaying output in wide mode.
|
|
|
|
|
|
2017-10-05 17:52:04 +08:00
|
|
|
|
2017-10-05 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* README-how-to-make-a-release: Merge steps 3, 4 and 5, and insert
|
|
|
|
|
the git tag operation at the correct location.
|
|
|
|
|
|
2017-10-05 15:02:18 +08:00
|
|
|
|
2017-10-05 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 22239
|
|
|
|
|
* dwarf.c (read_cie): Don't compare "start" and "end" pointers
|
|
|
|
|
after adding a possibly wild length to "start", compare the length
|
|
|
|
|
to the difference of the pointers instead. Remove now redundant
|
|
|
|
|
"negative" length test.
|
|
|
|
|
|
2017-10-05 12:34:06 +08:00
|
|
|
|
2017-10-05 Tristan Gingold <tgingold@free.fr>
|
|
|
|
|
|
|
|
|
|
* MAINTAINERS: Update email address. Redirect release maintainer
|
|
|
|
|
to global maitainers.
|
|
|
|
|
|
2017-10-01 19:10:23 +08:00
|
|
|
|
2017-10-01 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 22232
|
|
|
|
|
PR 22230
|
|
|
|
|
* objdump.c (load_specific_debug_section): Introduce a temp to
|
|
|
|
|
stop bfd_get_full_section_contents NULLing out section->start.
|
|
|
|
|
|
2017-10-01 09:37:07 +08:00
|
|
|
|
2017-10-01 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 22230
|
|
|
|
|
* objdump.c (load_specific_debug_section): Allocate an extra byte
|
|
|
|
|
for a terminating NUL.
|
|
|
|
|
|
2017-09-30 06:50:08 +08:00
|
|
|
|
2017-09-30 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21978
|
|
|
|
|
* objdump.c: Formatting.
|
|
|
|
|
(show_line): Reset prev_line when function name changes.
|
|
|
|
|
|
2017-09-27 17:42:51 +08:00
|
|
|
|
2017-09-27 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 22219
|
|
|
|
|
* dwarf.c (process_debug_info): Add a check for a negative
|
|
|
|
|
cu_length field.
|
|
|
|
|
|
2017-09-27 13:44:00 +08:00
|
|
|
|
2017-09-27 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 22216
|
|
|
|
|
* readelf.c (process_symbol_table): Check that DT_HASH symbol
|
|
|
|
|
chains are only visited once, and report an error if not. Display
|
|
|
|
|
invalid symbol index if chain is out of range. Use the same logic
|
|
|
|
|
when calculating histograms rather than the PR 17531 fix. Delete
|
|
|
|
|
bogus check that chained index is less than number of buckets.
|
|
|
|
|
|
2017-09-26 19:14:42 +08:00
|
|
|
|
2017-09-26 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 22154
|
|
|
|
|
* dwarf.c (get_line_filename_and_dirname): Add extra checks for
|
|
|
|
|
buffer overruns.
|
|
|
|
|
|
2017-09-26 17:07:23 +08:00
|
|
|
|
2017-09-26 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* README-how-to-make-a-release: New file.
|
|
|
|
|
|
2017-09-26 09:58:04 +08:00
|
|
|
|
2017-09-26 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21732
|
|
|
|
|
* dwarf.c (READ_ULEB): Don't use DWARF_VMA_FMT in translated string.
|
|
|
|
|
(READ_SLEB): Likewise.
|
|
|
|
|
* readelf.c (bfd_vmatoa): New function.
|
|
|
|
|
(get_data, get_dynamic_data): Use it for printing error messages.
|
|
|
|
|
|
2017-09-26 05:07:01 +08:00
|
|
|
|
2017-09-25 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/22203
|
|
|
|
|
* nm.c (display_rel_file): Free memory returned from
|
|
|
|
|
bfd_get_synthetic_symtab.
|
|
|
|
|
|
LVU: dump loclists with locviews
When dumping location lists, also dump locview lists that may be
interspersed with them, and bring view pairs next to the corresponding
location list entries.
This patch supports DW_AT_GNU_locviews as a separate attribute for
DWARF4- loc_lists and split (dwo) loclists, as well as DWARF5
loclists.
It also supports, in DWARF5 loclists, the proposed
DW_LLE_GNU_view_pair loclist entry type proposed for DWARF6.
The tests use 32-bit DWARF, even on 64-bit targets, resolving offsets
to constants so as to reduce the risk that relocations be created for
them, or that the offsets be rejected as nonconstants.
The patch also adds an xfail to an unrelated test, namely dw5, so that
no unexpected fails remain on nds32*-elf, one of the tested targets.
Reviewed-by: Alan Modra <amodra@gmail.com>
for include/ChangeLog
* dwarf2.def (DW_AT_GNU_locviews): New.
* dwarf2.h (enum dwarf_location_list_entry_type): Add
DW_LLE_GNU_view_pair.
(DW_LLE_view_pair): Define.
for binutils/ChangeLog
* dwarf.h (debug_info): Add loc_views and num_loc_views.
* dwarf.c (vm1): New constant.
(print_dwarf_view): New function.
(read_and_display_attr_value): Support DW_AT_GNU_locviews.
(process_debug_info): Keep num_loc_offsets and num_loc_views
in sync.
(display_view_pair_list): New function.
(display_loc_list_dwo): Take vstart_ptr; update it. Dump
location view pairs before the range they apply to, when a
viewlist augments the loc list.
(display_loc_list): Likewise. Check view numbers in range
tests.
(display_loclists_list): Likewise. Handle view pair entries,
and warn on trailing ones.
(loc_views): New variable.
(loc_offsets_compar): Compare loc_views if loc_offsets are the
same.
(display_debug_loc): Check and sort loc_views too. Accept
loc_view as expected_start. Skip if lists and views are the
same. Dump locview list separately in order, and pass the
locview list base to each list dump function. Warn and skip
overlap and hole checking if we find loclists and locviews to
not be adjacent.
* testsuite/binutils-all/locview-1.s: New.
* testsuite/binutils-all/readelf.locview-1: New.
* testsuite/binutils-all/locview-2.s: New.
* testsuite/binutils-all/readelf.locview-2: New.
* testsuite/binutils-all/readelf.exp: Run new tests. Fix
option spelling in pr18374 fail message. XFAIL dw5 test on
nds32*-elf.
2017-09-23 04:05:51 +08:00
|
|
|
|
2017-09-22 Alexandre Oliva <aoliva@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.h (debug_info): Add loc_views and num_loc_views.
|
|
|
|
|
* dwarf.c (vm1): New constant.
|
|
|
|
|
(print_dwarf_view): New function.
|
|
|
|
|
(read_and_display_attr_value): Support DW_AT_GNU_locviews.
|
|
|
|
|
(process_debug_info): Keep num_loc_offsets and num_loc_views
|
|
|
|
|
in sync.
|
|
|
|
|
(display_view_pair_list): New function.
|
|
|
|
|
(display_loc_list_dwo): Take vstart_ptr; update it. Dump
|
|
|
|
|
location view pairs before the range they apply to, when a
|
|
|
|
|
viewlist augments the loc list.
|
|
|
|
|
(display_loc_list): Likewise. Check view numbers in range
|
|
|
|
|
tests.
|
|
|
|
|
(display_loclists_list): Likewise. Handle view pair entries,
|
|
|
|
|
and warn on trailing ones.
|
|
|
|
|
(loc_views): New variable.
|
|
|
|
|
(loc_offsets_compar): Compare loc_views if loc_offsets are the
|
|
|
|
|
same.
|
|
|
|
|
(display_debug_loc): Check and sort loc_views too. Accept
|
|
|
|
|
loc_view as expected_start. Skip if lists and views are the
|
|
|
|
|
same. Dump locview list separately in order, and pass the
|
|
|
|
|
locview list base to each list dump function. Warn and skip
|
|
|
|
|
overlap and hole checking if we find loclists and locviews to
|
|
|
|
|
not be adjacent.
|
|
|
|
|
* testsuite/binutils-all/locview-1.s: New.
|
|
|
|
|
* testsuite/binutils-all/readelf.locview-1: New.
|
|
|
|
|
* testsuite/binutils-all/locview-2.s: New.
|
|
|
|
|
* testsuite/binutils-all/readelf.locview-2: New.
|
|
|
|
|
* testsuite/binutils-all/readelf.exp: Run new tests. Fix
|
|
|
|
|
option spelling in pr18374 fail message. XFAIL dw5 test on
|
|
|
|
|
nds32*-elf.
|
|
|
|
|
|
2017-09-22 06:57:01 +08:00
|
|
|
|
2017-09-22 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/readelf.exp: Don't perror and exit on
|
|
|
|
|
bintest.s assembly failure. Report tests unresolved instead.
|
|
|
|
|
Likewise for version note test, pr18374, decompress, and dw5
|
|
|
|
|
tests.
|
|
|
|
|
(readelf_test): Set testname to include both option and binary
|
|
|
|
|
file name. Use for pass/fail.
|
|
|
|
|
|
2017-09-22 07:54:19 +08:00
|
|
|
|
2017-09-21 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (get_machine_flags) <E_MIPS_MACH_5900>: New case.
|
|
|
|
|
|
2017-09-05 19:09:14 +08:00
|
|
|
|
2017-09-05 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 21995
|
|
|
|
|
* readelf.c (process_mips_specific): Add checks for a NULL data
|
|
|
|
|
pointer.
|
|
|
|
|
|
2017-09-05 06:52:17 +08:00
|
|
|
|
2017-09-05 Alexander Fedotov <alexander.fedotov@nxp.com>
|
|
|
|
|
Edmar Wienskoski <edmar.wienskoski@nxp.com
|
|
|
|
|
|
|
|
|
|
* readelf.c (get_elf_section_flags): Add VLE.
|
|
|
|
|
(process_section_headers): Add VLE key to details.
|
|
|
|
|
|
2017-08-25 10:11:06 +08:00
|
|
|
|
2017-08-25 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21994
|
|
|
|
|
* readelf.c (process_version_sections <SHT_GNU_verdef>): Check
|
|
|
|
|
vd_aux and vda_next for sanity. Delete "end". Correct overflow
|
|
|
|
|
checks.
|
|
|
|
|
(process_version_sections <SHT_GNU_verneed>): Correct overflow
|
|
|
|
|
check. Don't report invalid vna_next on overflow. Do report
|
|
|
|
|
invalid vna_next on size less than aux info.
|
|
|
|
|
|
2017-08-23 14:12:12 +08:00
|
|
|
|
2017-08-23 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21990
|
|
|
|
|
* readelf.c (process_version_sections <SHT_GNU_verneed>): Check
|
|
|
|
|
for invalid vn_next field before adding to idx. Use unsigned
|
|
|
|
|
long for index vars. Move index checks.
|
|
|
|
|
<SHT_GNU_verdef>: Likewise for vd_next.
|
|
|
|
|
|
2017-08-17 21:49:01 +08:00
|
|
|
|
2017-08-17 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/note-3-64.s: New test. Checks assembly
|
|
|
|
|
and decoding of version2 GNU build attribute notes.
|
|
|
|
|
* testsuite/binutils-all/note-3-32.s: New test. 32-bit version of
|
|
|
|
|
the above test.
|
|
|
|
|
* testsuite/binutils-all/note-3-64.d: New test driver.
|
|
|
|
|
* testsuite/binutils-all/note-3-32.d: New test driver.
|
|
|
|
|
* testsuite/binutils-all/objcopy.exp: Run the new test.
|
|
|
|
|
* readelf.c (is_64bit_abs_reloc): Add R_SPARC_64.
|
|
|
|
|
|
2017-08-14 22:48:04 +08:00
|
|
|
|
2017-08-14 Gustavo Romero <gromero@linux.vnet.ibm.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (get_note_type): Handle PPC note types available
|
|
|
|
|
since Linux 4.8.
|
|
|
|
|
|
2017-08-12 14:57:29 +08:00
|
|
|
|
2017-08-12 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (process_note): Qualify NT_GNU_BUILD_ATTRIBUTE notes
|
|
|
|
|
by name data.
|
|
|
|
|
|
2017-08-08 18:57:22 +08:00
|
|
|
|
2017-08-08 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 21909
|
|
|
|
|
* prdbg.c (pr_int_type): Increase size of local string buffer.
|
|
|
|
|
(pr_float_type): Likewise.
|
|
|
|
|
(pr_bool_type): Likewise.
|
|
|
|
|
|
2017-08-02 19:12:37 +08:00
|
|
|
|
2017-08-02 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 21702
|
|
|
|
|
* arsup.c (ar_addmod): Add plugin support for the MRI ADDMOD
|
|
|
|
|
command.
|
|
|
|
|
|
2017-08-02 17:19:22 +08:00
|
|
|
|
2017-08-02 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/objdump.exp (cpus_expected): Add am33-2.
|
|
|
|
|
|
2017-08-02 13:48:56 +08:00
|
|
|
|
2017-08-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (is_32bit_abs_reloc): Add R_IA64_SECREL32MSB and
|
|
|
|
|
R_IA64_DIR32MSB.
|
|
|
|
|
(is_64bit_abs_reloc): Add R_IA64_DIR64MSB.
|
|
|
|
|
(is_64bit_pcrel_reloc): Add R_IA64_PCREL64MSB.
|
|
|
|
|
|
2017-08-01 15:24:22 +08:00
|
|
|
|
2017-08-01 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* po/sv.po: Updated Swedish translation.
|
|
|
|
|
|
2017-07-31 17:31:18 +08:00
|
|
|
|
2017-07-31 Marty Plummer <ntzrmtthihu777@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21861
|
|
|
|
|
* winduni.c (codepages): Use cp1252 for codepage 0.
|
|
|
|
|
|
2017-07-25 16:39:13 +08:00
|
|
|
|
2017-07-25 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 21820
|
|
|
|
|
* readelf.c (dump_section_as_strings): Do not fail if the section
|
|
|
|
|
was empty.
|
|
|
|
|
(dump_section_as_bytes): Likewise.
|
|
|
|
|
|
2017-07-24 20:49:22 +08:00
|
|
|
|
2017-07-24 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 21813
|
|
|
|
|
* rddbg.c (read_symbol_stabs_debugging_info): Check for an empty
|
|
|
|
|
string whilst concatenating symbol names.
|
|
|
|
|
|
2017-07-21 23:01:34 +08:00
|
|
|
|
2017-07-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* po/fr.po: Updated French translation.
|
|
|
|
|
|
2017-07-21 18:42:21 +08:00
|
|
|
|
2017-07-21 Simon Marchi <simon.marchi@ericsson.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (last_pointer_size, warned_about_missing_comp_units):
|
|
|
|
|
Remove.
|
|
|
|
|
(load_debug_info): Remove assignments to those two variables.
|
|
|
|
|
|
2017-07-21 17:09:06 +08:00
|
|
|
|
2017-07-21 Alexandre Oliva <aoliva@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (struct State_Machine_Registers): Add view field.
|
|
|
|
|
(reset_state_machine): Reset view.
|
|
|
|
|
(process_extended_line_op): Reset view when appropriate.
|
|
|
|
|
(display_debug_lines_raw): Increment or reset view when appropriate.
|
|
|
|
|
Print nonzero views. Support print view resets, disabled by default.
|
|
|
|
|
(display_debug_lines_decoded): Likewise. Disambiguate op_code tests,
|
|
|
|
|
enabling printing of end_sequence.
|
|
|
|
|
* testsuite/binutils-all/dw2-1.W: Add nonzero views.
|
|
|
|
|
* testsuite/binutils-all/dw2-3.W: Likewise.
|
|
|
|
|
* testsuite/binutils-all/dw2-3gabi.W: Likewise.
|
|
|
|
|
* testsuite/binutils-all/dw5.W: Add end sequence lines.
|
|
|
|
|
* testsuite/binutils-all/i386/compressed-1a.d: Add nonzero views.
|
|
|
|
|
* testsuite/binutils-all/libdw2-compressedgabi.out: Likewise.
|
|
|
|
|
* testsuite/binutils-all/objdump.W: Likewise.
|
|
|
|
|
* testsuite/binutils-all/objdump.WL: Add end sequence lines.
|
|
|
|
|
* testsuite/binutils-all/x86-64/compressed-1a.d: Add nonzero views.
|
|
|
|
|
|
2017-07-19 15:55:12 +08:00
|
|
|
|
2017-07-19 Tristan Gingold <gingold@adacore.com>
|
|
|
|
|
|
|
|
|
|
* nm.c (show_stats): Remove variable.
|
|
|
|
|
(long_options): Remove --stats option.
|
|
|
|
|
(main): Remove handling of --stats.
|
|
|
|
|
|
2017-07-18 23:58:14 +08:00
|
|
|
|
2017-07-18 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 21775
|
|
|
|
|
* coffgrok.c: Fix spelling typos.
|
|
|
|
|
* readelf.c: Likewise.
|
|
|
|
|
* stabs.c: Likewise.
|
|
|
|
|
* testsuite/binutils-all/objcopy.exp: Likewise.
|
|
|
|
|
|
2017-07-18 19:18:01 +08:00
|
|
|
|
2017-07-18 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* po/sv.po: Updated Swedish translation.
|
|
|
|
|
|
2017-07-18 18:14:38 +08:00
|
|
|
|
2017-07-18 Hans-Peter Nilsson <hp@bitrange.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (display_debug_names): Initialize hash_prev.
|
|
|
|
|
|
2017-07-17 17:51:45 +08:00
|
|
|
|
2017-07-17 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 21433
|
|
|
|
|
* ar.c (main): Skip check for no files on the command line when
|
|
|
|
|
running in MRI mode.
|
|
|
|
|
|
2017-07-13 23:10:57 +08:00
|
|
|
|
2017-07-13 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/objdump.exp: Always delete $testarchive
|
|
|
|
|
first.
|
|
|
|
|
|
2017-07-12 20:49:58 +08:00
|
|
|
|
2017-07-12 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* po/bg.po: Update from translationproject.org/latest/binutils/.
|
|
|
|
|
* po/ca.po: Likewise.
|
|
|
|
|
* po/da.po: Likewise.
|
|
|
|
|
* po/es.po: Likewise.
|
|
|
|
|
* po/fi.po: Likewise.
|
|
|
|
|
* po/fr.po: Likewise.
|
|
|
|
|
* po/hr.po: Likewise.
|
|
|
|
|
* po/id.po: Likewise.
|
|
|
|
|
* po/it.po: Likewise.
|
|
|
|
|
* po/ja.po: Likewise.
|
|
|
|
|
* po/ro.po: Likewise.
|
|
|
|
|
* po/ru.po: Likewise.
|
|
|
|
|
* po/sk.po: Likewise.
|
|
|
|
|
* po/sr.po: Likewise.
|
|
|
|
|
* po/sv.po: Likewise.
|
|
|
|
|
* po/tr.po: Likewise.
|
|
|
|
|
* po/uk.po: Likewise.
|
|
|
|
|
* po/vi.po: Likewise.
|
|
|
|
|
* po/zh_CN.po: Likewise.
|
|
|
|
|
* po/zh_TW.po: Likewise.
|
|
|
|
|
|
2017-07-12 19:17:02 +08:00
|
|
|
|
2017-07-12 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
Fix compile time warnings using gcc 7.1.1.
|
|
|
|
|
* dwarf.c (dwarf_vmatoa_1): Do not pass a NULL string pointer to
|
|
|
|
|
sprintf.
|
|
|
|
|
* srconv.c (walk_tree_type): Initialise the spare field of the
|
|
|
|
|
IT_dty structure.
|
|
|
|
|
|
2017-07-11 23:36:35 +08:00
|
|
|
|
2017-07-11 Andreas Schwab <schwab@suse.de>
|
|
|
|
|
|
|
|
|
|
* readelf.c (process_note): Print newline after description data
|
|
|
|
|
in narrow mode.
|
|
|
|
|
(print_core_note): Print newline if nothing was printed in wide
|
|
|
|
|
mode.
|
|
|
|
|
|
2017-07-10 02:52:18 +08:00
|
|
|
|
2017-07-09 Rafael Fontenelle <rafaelff@gnome.org>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (display_formatted_table): Fix error message typo.
|
|
|
|
|
|
2017-06-29 02:41:41 +08:00
|
|
|
|
2017-07-07 John Baldwin <jhb@FreeBSD.org>
|
|
|
|
|
|
|
|
|
|
* readelf.c (get_freebsd_elfcore_note_type): Handle
|
|
|
|
|
NT_FREEBSD_PTLWPINFO.
|
|
|
|
|
|
2017-07-06 00:04:51 +08:00
|
|
|
|
2017-07-05 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (display_debug_names): Replace index with xindex.
|
|
|
|
|
|
2017-07-04 17:15:33 +08:00
|
|
|
|
2017-07-04 Tristan Gingold <gingold@adacore.com>
|
|
|
|
|
|
|
|
|
|
* configure: Regenerate.
|
|
|
|
|
|
2017-07-04 17:06:02 +08:00
|
|
|
|
2017-07-04 Tristan Gingold <gingold@adacore.com>
|
|
|
|
|
|
|
|
|
|
* NEWS: Add marker for 2.29.
|
|
|
|
|
|
2017-07-03 23:02:01 +08:00
|
|
|
|
2017-07-03 Tristan Gingold <gingold@adacore.com>
|
|
|
|
|
|
|
|
|
|
* po/binutils.pot: Regenerate.
|
|
|
|
|
|
2017-07-03 20:30:32 +08:00
|
|
|
|
2017-07-03 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* strings.c (filename_and_size_t): Delete.
|
|
|
|
|
(strings_a_section): Don't check section size against file size.
|
|
|
|
|
Use bdf_malloc_and_get_section. Report an error on failures.
|
|
|
|
|
Replace arg param with filename and got_a_section param.
|
|
|
|
|
(got_a_section): Move to..
|
|
|
|
|
(strings_object_file): ..an auto var here. Iterate over sections
|
|
|
|
|
rather than calling bfd_map_over_sections. Adjust strings_a_section
|
|
|
|
|
call.
|
|
|
|
|
|
2017-07-03 04:15:05 +08:00
|
|
|
|
2017-07-02 Jan Kratochvil <jan.kratochvil@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c: Include assert.h.
|
|
|
|
|
(MAX, MIN, get_IDX_name, display_debug_names): New.
|
|
|
|
|
(debug_displays): Add .debug_names.
|
|
|
|
|
* dwarf.h: (enum dwarf_section_display_enum): Add debug_names.
|
|
|
|
|
* readelf.c (process_section_headers): Add ".debug_names".
|
|
|
|
|
|
2017-07-01 20:28:10 +08:00
|
|
|
|
2017-07-01 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21665
|
|
|
|
|
* objdump.c (strtab): Make var a bfd_byte*.
|
|
|
|
|
(disassemble_section): Don't limit malloc size. Instead, use
|
|
|
|
|
bfd_malloc_and_get_section.
|
|
|
|
|
(read_section_stabs): Use bfd_malloc_and_get_section. Return
|
|
|
|
|
bfd_byte*.
|
|
|
|
|
(find_stabs_section): Remove now unnecessary cast.
|
|
|
|
|
* objcopy.c (copy_object): Use bfd_malloc_and_get_section. Free
|
|
|
|
|
contents on error return.
|
|
|
|
|
* nlmconv.c (copy_sections): Use bfd_malloc_and_get_section.
|
|
|
|
|
|
2017-06-30 18:03:37 +08:00
|
|
|
|
2017-06-30 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21665
|
|
|
|
|
* objdump.c (disassemble_section): Move check for an overlarge
|
|
|
|
|
section to just before the allocation of memory. Do not check
|
|
|
|
|
section size against file size, but instead use an arbitrary 2Gb
|
|
|
|
|
limit. Issue a warning message if the section is too big.
|
|
|
|
|
|
MIPS: Add microMIPS XPA support
Add support for the base and Virtualization ASE microMIPS instructions
as per the architecture specifications[1][2][3][4].
Most of this change by Andrew Bennett.
[1] "MIPS Architecture for Programmers Volume II-B: The microMIPS32
Instruction Set", MIPS Technologies, Inc., Document Number: MD00582,
Revision 5.04, January 15, 2014, Section 5.5 "Recoded 32-Bit
Instructions", p. 340
[2] "microMIPS32 Architecture for Programmers Volume IV-i:
Virtualization Module of the microMIPS32 Architecture", MIPS
Technologies, Inc., Document Number: MD00848, Revision 1.06,
December 10, 2013, Section 6.1 "Overview", pp. 133, 136
[3] "MIPS Architecture for Programmers Volume II-B: The microMIPS64
Instruction Set", MIPS Technologies, Inc., Document Number: MD00594,
Revision 5.04, January 15, 2014, Section 5.5 "Recoded 32-Bit
Instructions", pp. 415, 444
[4] "microMIPS64 Architecture for Programmers Volume IV-i:
Virtualization Module of the microMIPS64 Architecture", MIPS
Technologies, Inc., Document Number: MD00849, Revision 1.06,
December 10, 2013, Section 6.1 "Overview", pp. 134-135, 139-140
binutils/
* NEWS: Mention microMIPS XPA support.
opcodes/
* micromips-opc.c (XPA, XPAVZ): New macros.
(micromips_opcodes): Add "mfhc0", "mfhgc0", "mthc0" and
"mthgc0".
gas/
* config/tc-mips.c (mips_ases): Add microMIPS XPA support.
* testsuite/gas/mips/micromips@xpa.d: New test.
* testsuite/gas/mips/mips.exp: Run the new test. Enable
`xpa-virt-err' test for `micromips'.
2017-06-30 14:21:56 +08:00
|
|
|
|
2017-06-30 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* NEWS: Mention microMIPS XPA support.
|
|
|
|
|
|
MIPS: Add microMIPS R5 support
Add base microMIPS Release 5 ISA support and the ERETNC instruction in
particular, as per the architecture specifications[1][2].
Most of this change by Andrew Bennett.
References:
[1] "MIPS Architecture for Programmers Volume II-B: The microMIPS32
Instruction Set", MIPS Technologies, Inc., Document Number: MD00582,
Revision 5.04, January 15, 2014, Section 5.5 "Recoded 32-Bit
Instructions", pp. 266-267
[2] "MIPS Architecture for Programmers Volume II-B: The microMIPS64
Instruction Set", MIPS Technologies, Inc., Document Number: MD00594,
Revision 5.04, January 15, 2014, Section 5.5 "Recoded 32-Bit
Instructions", pp. 326-327
binutils/
* NEWS: Mention microMIPS Release 5 ISA support.
opcodes/
* micromips-opc.c (I36): New macro.
(micromips_opcodes): Add "eretnc".
gas/
* testsuite/gas/mips/micromips@r5.d: New test.
* testsuite/gas/mips/mips.exp: Run the new test.
2017-06-30 14:21:56 +08:00
|
|
|
|
2017-06-30 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* NEWS: Mention microMIPS Release 5 ISA support.
|
|
|
|
|
|
2017-06-30 14:21:55 +08:00
|
|
|
|
2017-06-30 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/mips/mips-xpa-virt-1.d: New test.
|
|
|
|
|
* testsuite/binutils-all/mips/mips-xpa-virt-2.d: New test.
|
|
|
|
|
* testsuite/binutils-all/mips/mips-xpa-virt-3.d: New test.
|
|
|
|
|
* testsuite/binutils-all/mips/mips-xpa-virt-4.d: New test.
|
|
|
|
|
* testsuite/binutils-all/mips/mips-xpa-virt.s: New test source.
|
|
|
|
|
* testsuite/binutils-all/mips/mips.exp: Run the new tests.
|
|
|
|
|
|
[ARC] Fix handling of cpu=... disassembler option value
There is a bug in handling of cpu=... disassembler option in case there are
other options after it, for example, `cpu=EM,dsp'. In this case `EM,dsp' is
treated as an option value, and strcasecmp reports is as non-equal to "EM".
This is fixed by using disassembler_options_cmp function, which compares string
treating `,' the same way as `\0'.
This function also solves a problem with option order in parse_option.
Previously, if several option had same prefix (e.g. fpud, fpuda), then the
longer one should have been compared first, otherwise when longer option is
passed it would be treated as a short one, because
CONST_STRNEQ ("fpud", "fpuda")
would be true. The order of options was correct for ARC, so there were no
bugs per se, but with disassembler_option_cmp there is no risk of such a bug
being introduced in the future.
opcodes/ChangeLog:
yyyy-mm-dd Anton Kolesov <Anton.Kolesov@synopsys.com>
* arc-dis.c (parse_option): Use disassembler_options_cmp to compare
disassembler option strings.
(parse_cpu_option): Likewise.
binutils/ChangeLog
yyyy-mm-dd Anton Kolesov <Anton.Kolesov@synopsys.com>
* testsuite/binutils-all/arc/double_store.s: New file.
* testsuite/binutils-all/arc/objdump.exp: Tests for disassembler
options.
(do_objfile): New function.
(check_assembly): Likewise.
2017-06-15 20:58:32 +08:00
|
|
|
|
2017-06-29 Anton Kolesov <Anton.Kolesov@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/arc/double_store.s: New file.
|
|
|
|
|
* testsuite/binutils-all/arc/objdump.exp: Tests for disassembler
|
|
|
|
|
options.
|
|
|
|
|
(do_objfile): New function.
|
|
|
|
|
(check_assembly): Likewise.
|
|
|
|
|
|
2017-06-29 16:30:09 +08:00
|
|
|
|
2017-06-29 Andreas Arnez <arnez@linux.vnet.ibm.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (get_note_type): Add NT_S390_GS_CB and NT_S390_GS_BC.
|
|
|
|
|
|
2017-06-29 02:00:13 +08:00
|
|
|
|
2017-06-28 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* objdump.c (dump_relocs_in_section): Cast to ufile_ptr when
|
|
|
|
|
comparing against bfd_get_file_size return.
|
|
|
|
|
|
2017-06-28 21:52:12 +08:00
|
|
|
|
2017-06-28 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* objcopy.c (merge_gnu_build_notes): Add support for version 2 notes.
|
|
|
|
|
* readelf.c (print_gnu_build_attribute_name): Likewise.
|
|
|
|
|
|
MIPS: Add Imagination interAptiv MR2 MIPS32r3 processor support
Add support for the Imagination interAptiv MR2 MIPS32r3 processor with
the MIPS16e2 ASE as per documentation, including in particular:
1. Support for implementation-specific interAptiv MR2 COPYW and UCOPYW
MIPS16e2 instructions[1], for assembly and disassembly,
2. Support for implementation-specific interAptiv MR2 SAVE and RESTORE
regular MIPS instructions[2], for assembly and disassembly,
3. ELF binary file annotation for the interAptiv MR2 MIPS architecture
extension.
4. Support for interAptiv MR2 architecture selection for assembly, in
the form of the `-march=interaptiv-mr2' command-line option and its
corresponding `arch=interaptiv-mr2' setting for the `.set' and
`.module' pseudo-ops.
5. Support for interAptiv MR2 architecture selection for disassembly,
in the form of the `mips:interaptiv-mr2' target architecture, for
use e.g. with the `-m' command-line option for `objdump'.
Parts of this change by Matthew Fortune and Andrew Bennett.
References:
[1] "MIPS32 interAptiv Multiprocessing System Software User's Manual",
Imagination Technologies Ltd., Document Number: MD00904, Revision
02.01, June 15, 2016, Section 24.3 "MIPS16e2 Implementation Specific
Instructions", pp. 878-883
[2] same, Chapter 25 "Implementation-specific Instructions", pp. 911-917
include/
* elf/mips.h (E_MIPS_MACH_IAMR2): New macro.
(AFL_EXT_INTERAPTIV_MR2): Likewise.
* opcode/mips.h: Document new operand codes defined.
(INSN_INTERAPTIV_MR2): New macro.
(INSN_CHIP_MASK): Adjust accordingly.
(CPU_INTERAPTIV_MR2): New macro.
(cpu_is_member) <CPU_INTERAPTIV_MR2>: New case.
(MIPS16_ALL_ARGS): Rename to...
(MIPS_SVRS_ALL_ARGS): ... this.
(MIPS16_ALL_STATICS): Rename to...
(MIPS_SVRS_ALL_STATICS): ... this.
bfd/
* archures.c (bfd_mach_mips_interaptiv_mr2): New macro.
* cpu-mips.c (I_interaptiv_mr2): New enum value.
(arch_info_struct): Add "mips:interaptiv-mr2" entry.
* elfxx-mips.c (_bfd_elf_mips_mach) <E_MIPS_MACH_IAMR2>: New
case.
(mips_set_isa_flags) <bfd_mach_mips_interaptiv_mr2>: Likewise.
(bfd_mips_isa_ext) <bfd_mach_mips_interaptiv_mr2>: Likewise.
(print_mips_isa_ext) <AFL_EXT_INTERAPTIV_MR2>: Likewise.
(mips_mach_extensions): Add `bfd_mach_mipsisa32r3' and
`bfd_mach_mips_interaptiv_mr2' entries.
* bfd-in2.h: Regenerate.
opcodes/
* mips-formats.h (INT_BIAS): New macro.
(INT_ADJ): Redefine in INT_BIAS terms.
* mips-dis.c (mips_arch_choices): Add "interaptiv-mr2" entry.
(mips_print_save_restore): New function.
(print_insn_arg) <OP_SAVE_RESTORE_LIST>: Update comment.
(validate_insn_args) <OP_SAVE_RESTORE_LIST>: Remove `abort'
call.
(print_insn_args): Handle OP_SAVE_RESTORE_LIST.
(print_mips16_insn_arg): Call `mips_print_save_restore' for
OP_SAVE_RESTORE_LIST handling, factored out from here.
* mips-opc.c (decode_mips_operand) <'-'> <'m'>: New case.
(RD_31, RD_SP, WR_SP, MOD_SP, IAMR2): New macros.
(mips_builtin_opcodes): Add "restore" and "save" entries.
* mips16-opc.c (decode_mips16_operand) <'n', 'o'>: New cases.
(IAMR2): New macro.
(mips16_opcodes): Add "copyw" and "ucopyw" entries.
binutils/
* readelf.c (get_machine_flags) <E_MIPS_MACH_IAMR2>: New case.
(print_mips_isa_ext) <AFL_EXT_INTERAPTIV_MR2>: Likewise.
* NEWS: Mention Imagination interAptiv MR2 processor support.
gas/
* config/tc-mips.c (validate_mips_insn): Handle
OP_SAVE_RESTORE_LIST specially.
(mips_encode_save_restore, mips16_encode_save_restore): New
functions.
(match_save_restore_list_operand): Factor out SAVE/RESTORE
operand insertion into the instruction word or halfword to these
new functions.
(mips_cpu_info_table): Add "interaptiv-mr2" entry.
* doc/c-mips.texi (MIPS Options): Add `interaptiv-mr2' to the
`-march=' argument list.
2017-06-28 09:07:36 +08:00
|
|
|
|
2017-06-28 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
Matthew Fortune <matthew.fortune@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (get_machine_flags) <E_MIPS_MACH_IAMR2>: New case.
|
|
|
|
|
(print_mips_isa_ext) <AFL_EXT_INTERAPTIV_MR2>: Likewise.
|
|
|
|
|
* NEWS: Mention Imagination interAptiv MR2 processor support.
|
|
|
|
|
|
2017-06-26 22:25:08 +08:00
|
|
|
|
2017-06-26 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21665
|
|
|
|
|
* objdump.c (disassemble_section): Skip any section that is bigger
|
|
|
|
|
than the entire file.
|
|
|
|
|
|
2017-06-26 20:25:41 +08:00
|
|
|
|
2017-06-26 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21659
|
|
|
|
|
* bucomm.c (get_file_size): Explicitly warn if the file is a
|
|
|
|
|
directory.
|
|
|
|
|
|
2017-06-24 17:37:47 +08:00
|
|
|
|
2017-06-24 Thomas Preud'homme <thomas.preudhomme@arm.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (arm_attr_tag_CPU_arch): Fill value for ARMv8-R.
|
|
|
|
|
|
2017-06-23 17:22:36 +08:00
|
|
|
|
2017-06-23 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21659
|
|
|
|
|
* strings.c (strings_file): Warn about attempts to run strings on
|
|
|
|
|
a directory.
|
|
|
|
|
|
2017-06-22 20:50:20 +08:00
|
|
|
|
2017-06-22 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (decode_x86_feature): Decode
|
|
|
|
|
GNU_PROPERTY_X86_FEATURE_1_SHSTK.
|
|
|
|
|
* testsuite/binutils-all/i386/shstk.d: New file.
|
|
|
|
|
* testsuite/binutils-all/i386/shstk.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/x86-64/shstk-x32.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/x86-64/shstk.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/x86-64/shstk.s: Likewise.
|
|
|
|
|
|
x86: Support Intel IBT with IBT property and IBT-enable PLT
To support IBT in Intel Control-flow Enforcement Technology (CET)
instructions:
https://software.intel.com/sites/default/files/managed/4d/2a/control-flow-enforcement-technology-preview.pdf
#define GNU_PROPERTY_X86_FEATURE_1_AND 0xc0000002
#define GNU_PROPERTY_X86_FEATURE_1_IBT (1U << 0)
are added to GNU program properties to indicate that all executable
sections are compatible with IBT when ENDBR instruction starts each
valid target where an indirect branch instruction can land.
GNU_PROPERTY_X86_FEATURE_1_IBT is set on output only if it is set on
all relocatable inputs.
The followings changes are made to the Procedure Linkage Table (PLT):
1. For 64-bit x86-64, PLT is changed to
PLT0: push GOT[1]
bnd jmp *GOT[2]
nop
...
PLTn: endbr64
push namen_reloc_index
bnd jmp PLT0
together with the second PLT section:
PLTn: endbr64
bnd jmp *GOT[namen_index]
nop
BND prefix is also added so that IBT-enabled PLT is compatible with MPX.
2. For 32-bit x86-64 (x32) and i386, PLT is changed to
PLT0: push GOT[1]
jmp *GOT[2]
nop
...
PLTn: endbr64 # endbr32 for i386.
push namen_reloc_index
jmp PLT0
together with the second PLT section:
PLTn: endbr64 # endbr32 for i386.
jmp *GOT[namen_index]
nop
BND prefix isn't used since MPX isn't supported on x32 and BND registers
aren't used in parameter passing on i386.
GOT is an array of addresses. Initially, GOT[namen_index] is filled
with the address of the ENDBR instruction of the corresponding entry
in the first PLT section. The function, namen, is called via the
ENDBR instruction in the second PLT entry. GOT[namen_index] is updated
to the actual address of the function, namen, at run-time.
2 linker command line options are added:
1. -z ibtplt: Generate IBT-enabled PLT.
2. -z ibt: Generate GNU_PROPERTY_X86_FEATURE_1_IBT in GNU program
properties as well as IBT-enabled PLT.
bfd/
* elf32-i386.c (elf_i386_lazy_ibt_plt0_entry): New.
(elf_i386_lazy_ibt_plt_entry): Likewise.
(elf_i386_pic_lazy_ibt_plt0_entry): Likewise.
(elf_i386_non_lazy_ibt_plt_entry): Likewise.
(elf_i386_pic_non_lazy_ibt_plt_entry): Likewise.
(elf_i386_eh_frame_lazy_ibt_plt): Likewise.
(elf_i386_lazy_plt_layout): Likewise.
(elf_i386_non_lazy_plt_layout): Likewise.
(elf_i386_link_hash_entry): Add plt_second.
(elf_i386_link_hash_table): Add plt_second and
plt_second_eh_frame.
(elf_i386_allocate_dynrelocs): Use the second PLT if needed.
(elf_i386_size_dynamic_sections): Use .plt.got unwind info for
the second PLT. Check the second PLT.
(elf_i386_relocate_section): Use the second PLT to resolve
PLT reference if needed.
(elf_i386_finish_dynamic_symbol): Fill and use the second PLT if
needed.
(elf_i386_finish_dynamic_sections): Set sh_entsize on the
second PLT. Generate unwind info for the second PLT.
(elf_i386_plt_type): Add plt_second.
(elf_i386_get_synthetic_symtab): Support the second PLT.
(elf_i386_parse_gnu_properties): Support
GNU_PROPERTY_X86_FEATURE_1_AND.
(elf_i386_merge_gnu_properties): Support
GNU_PROPERTY_X86_FEATURE_1_AND. If info->ibt is set, turn
on GNU_PROPERTY_X86_FEATURE_1_IBT
(elf_i386_link_setup_gnu_properties): If info->ibt is set,
turn on GNU_PROPERTY_X86_FEATURE_1_IBT. Use IBT-enabled PLT
for info->ibtplt, info->ibt or GNU_PROPERTY_X86_FEATURE_1_IBT
is set on all relocatable inputs.
* elf64-x86-64.c (elf_x86_64_lazy_ibt_plt_entry): New.
(elf_x32_lazy_ibt_plt_entry): Likewise.
(elf_x86_64_non_lazy_ibt_plt_entry): Likewise.
(elf_x32_non_lazy_ibt_plt_entry): Likewise.
(elf_x86_64_eh_frame_lazy_ibt_plt): Likewise.
(elf_x32_eh_frame_lazy_ibt_plt): Likewise.
(elf_x86_64_lazy_ibt_plt): Likewise.
(elf_x32_lazy_ibt_plt): Likewise.
(elf_x86_64_non_lazy_ibt_plt): Likewise.
(elf_x32_non_lazy_ibt_plt): Likewise.
(elf_x86_64_get_synthetic_symtab): Support the second PLT.
(elf_x86_64_parse_gnu_properties): Support
GNU_PROPERTY_X86_FEATURE_1_AND.
(elf_x86_64_merge_gnu_properties): Support
GNU_PROPERTY_X86_FEATURE_1_AND. If info->ibt is set, turn
on GNU_PROPERTY_X86_FEATURE_1_IBT
(elf_x86_64_link_setup_gnu_properties): If info->ibt is set,
turn on GNU_PROPERTY_X86_FEATURE_1_IBT. Use IBT-enabled PLT
for info->ibtplt, info->ibt or GNU_PROPERTY_X86_FEATURE_1_IBT
is set on all relocatable inputs.
binutils/
* readelf.c (decode_x86_feature): New.
(print_gnu_property_note): Call decode_x86_feature on
GNU_PROPERTY_X86_FEATURE_1_AND.
* testsuite/binutils-all/i386/empty.d: New file.
* testsuite/binutils-all/i386/empty.s: Likewise.
* testsuite/binutils-all/i386/ibt.d: Likewise.
* testsuite/binutils-all/i386/ibt.s: Likewise.
* testsuite/binutils-all/x86-64/empty-x32.d: Likewise.
* testsuite/binutils-all/x86-64/empty.d: Likewise.
* testsuite/binutils-all/x86-64/empty.s: Likewise.
* testsuite/binutils-all/x86-64/ibt-x32.d: Likewise.
* testsuite/binutils-all/x86-64/ibt.d: Likewise.
* testsuite/binutils-all/x86-64/ibt.s: Likewise.
include/
* bfdlink.h (bfd_link_info): Add ibtplt and ibt.
* elf/common.h (GNU_PROPERTY_X86_FEATURE_1_AND): New.
(GNU_PROPERTY_X86_FEATURE_1_IBT): Likewise.
ld/
* Makefile.am (ELF_X86_DEPS): Add $(srcdir)/emulparams/cet.sh.
* Makefile.in: Regenerated.
* NEWS: Mention GNU_PROPERTY_X86_FEATURE_1_IBT, -z ibtplt
and -z ibt.
* emulparams/cet.sh: New file.
* testsuite/ld-i386/ibt-plt-1.d: Likewise.
* testsuite/ld-i386/ibt-plt-1.s: Likewise.
* testsuite/ld-i386/ibt-plt-2.s: Likewise.
* testsuite/ld-i386/ibt-plt-2a.d: Likewise.
* testsuite/ld-i386/ibt-plt-2b.d: Likewise.
* testsuite/ld-i386/ibt-plt-2c.d: Likewise.
* testsuite/ld-i386/ibt-plt-2d.d: Likewise.
* testsuite/ld-i386/ibt-plt-3.s: Likewise.
* testsuite/ld-i386/ibt-plt-3a.d: Likewise.
* testsuite/ld-i386/ibt-plt-3b.d: Likewise.
* testsuite/ld-i386/ibt-plt-3c.d: Likewise.
* testsuite/ld-i386/ibt-plt-3d.d: Likewise.
* testsuite/ld-i386/plt-main-ibt.dd: Likewise.
* testsuite/ld-i386/plt-pie-ibt.dd: Likewise.
* testsuite/ld-i386/property-x86-empty.s: Likewise.
* testsuite/ld-i386/property-x86-ibt.s: Likewise.
* testsuite/ld-i386/property-x86-ibt1a.d: Likewise.
* testsuite/ld-i386/property-x86-ibt1b.d: Likewise.
* testsuite/ld-i386/property-x86-ibt2.d: Likewise.
* testsuite/ld-i386/property-x86-ibt3a.d: Likewise.
* testsuite/ld-i386/property-x86-ibt3b.d: Likewise.
* testsuite/ld-i386/property-x86-ibt4.d: Likewise.
* testsuite/ld-i386/property-x86-ibt5.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-1-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-1.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-1.s: Likewise.
* testsuite/ld-x86-64/ibt-plt-2.s: Likewise.
* testsuite/ld-x86-64/ibt-plt-2a-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-2a.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-2b-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-2b.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-2c-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-2c.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-2d-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-2d.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3.s: Likewise.
* testsuite/ld-x86-64/ibt-plt-3a-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3a.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3b-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3b.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3c-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3c.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3d-x32.d: Likewise.
* testsuite/ld-x86-64/ibt-plt-3d.d: Likewise.
* testsuite/ld-x86-64/plt-main-ibt-now.rd: Likewise.
* testsuite/ld-x86-64/plt-main-ibt-x32.dd: Likewise.
* testsuite/ld-x86-64/plt-main-ibt.dd: Likewise.
* testsuite/ld-x86-64/property-x86-empty.s: Likewise.
* testsuite/ld-x86-64/property-x86-ibt.s: Likewise.
* testsuite/ld-x86-64/property-x86-ibt1a-x32.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt1a.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt1b-x32.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt1b.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt2-x32.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt2.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt3a-x32.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt3a.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt3b-x32.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt3b.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt4-x32.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt4.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt5-x32.d: Likewise.
* testsuite/ld-x86-64/property-x86-ibt5.d: Likewise.
* emulparams/elf32_x86_64.sh: Source emulparams/cet.sh.
(TINY_READONLY_SECTION): Add .plt.sec.
* emulparams/elf_i386.sh: Likewise.
* emulparams/elf_x86_64.sh: Source emulparams/cet.sh.
* ld.texinfo: Document -z ibtplt and -z ibt.
* testsuite/ld-i386/i386.exp: Run IBT and IBT PLT tests.
* testsuite/ld-x86-64/x86-64.exp: Likewise.
* testsuite/ld-x86-64/pr21481b.S (check): Updated for x32.
2017-06-22 20:44:37 +08:00
|
|
|
|
2017-06-22 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (decode_x86_feature): New.
|
|
|
|
|
(print_gnu_property_note): Call decode_x86_feature on
|
|
|
|
|
GNU_PROPERTY_X86_FEATURE_1_AND.
|
|
|
|
|
* testsuite/binutils-all/i386/empty.d: New file.
|
|
|
|
|
* testsuite/binutils-all/i386/empty.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/i386/ibt.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/i386/ibt.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/x86-64/empty-x32.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/x86-64/empty.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/x86-64/empty.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/x86-64/ibt-x32.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/x86-64/ibt.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/x86-64/ibt.s: Likewise.
|
|
|
|
|
|
2017-06-22 06:29:38 +08:00
|
|
|
|
2017-06-21 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (READ_ULEB): Use DWARF_VMA_FMT to report error.
|
|
|
|
|
(READ_SLEB): Likewise.
|
|
|
|
|
|
2017-06-22 01:05:44 +08:00
|
|
|
|
2017-06-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21648
|
|
|
|
|
* dwarf.c (LEB): Rename to SKIP_ULEB and READ_ULEB. Add check for
|
|
|
|
|
reading a value that is too big for the containing variable.
|
|
|
|
|
(SLEB): Rename to SKIP_SLEB and READ_SLEB. Add similar check.
|
|
|
|
|
Replace uses of LEB and SLEB with appropriate new macro.
|
|
|
|
|
(display_debug_frames): Use an unsigned int for the 'reg'
|
|
|
|
|
variable. Use a signed long for the 'l' variable.
|
|
|
|
|
|
2017-06-26 17:07:17 +08:00
|
|
|
|
2017-06-20 Andreas Krebbel <krebbel@linux.vnet.ibm.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (get_s390_segment_type): Add support for the new
|
|
|
|
|
segment type PT_S390_PGSTE.
|
|
|
|
|
(get_segment_type): Call get_s390_segment_type.
|
|
|
|
|
|
2017-06-19 22:57:19 +08:00
|
|
|
|
2017-06-19 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21619
|
|
|
|
|
* objdump.c (disassemble_bytes): Check that there is sufficient
|
|
|
|
|
data available before attempting to display it.
|
|
|
|
|
|
2017-06-06 21:52:31 +08:00
|
|
|
|
2017-06-06 Simon Marchi <simon.marchi@ericsson.com>
|
|
|
|
|
|
|
|
|
|
* sysinfo.y: Free memory allocated by token NAME.
|
|
|
|
|
|
[ARC] Allow CPU to be enforced via disassemble_info options
Currently print_insn_arc relies on BFD mach and ELF private headers to
distinguish between various ARC architectures. Sometimes those values are not
correct or available, mainly in the case of debugging targets without and ELF
file available. Changing a BFD mach is not a problem for the debugger, because
this is a generic BFD field, and GDB, for example, already sets it according to
information provided in XML target description or specified via GDB 'set arch'
command. However, things are more complicated for ELF private headers, since
it requires existing of an actual ELF file. To workaround this problem this
patch allows CPU model to be specified via disassemble info options. If CPU is
specified in options, then it will take a higher precedence than whatever might
be specified in ELF file.
This is mostly needed for ARC EM and ARC HS, because they have the same
"architecture" (mach) ARCv2 and differ in their private ELF headers. Other ARC
architectures can be distinguished between each other purely via "mach" field.
Proposed disassemble option format is "cpu=<CPU>", where CPU can be any valid
ARC CPU name as supported by GAS. Note that this creates a seeming redundancy
with objdump -m/--architecture option, however -mEM and -mHS still result in
"ARCv2" architecture internally, while -Mcpu={HS,EM} would have an actual
effect on disassembler.
opcodes/ChangeLog:
yyyy-mm-dd Anton Kolesov <anton.kolesov@synopsys.com>
* arc-dis.c (enforced_isa_mask): Declare.
(cpu_types): Likewise.
(parse_cpu_option): New function.
(parse_disassembler_options): Use it.
(print_insn_arc): Use enforced_isa_mask.
(print_arc_disassembler_options): Document new options.
binutils/ChangeLog:
yyyy-mm-dd Anton Kolesov <anton.kolesov@synopsys.com>
* doc/binutils.texi: Document new cpu=... disassembler options for ARC.
2017-03-16 20:21:31 +08:00
|
|
|
|
2017-05-30 Anton Kolesov <anton.kolesov@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* doc/binutils.texi: Document new cpu=... disassembler options for ARC.
|
|
|
|
|
|
2017-05-30 21:34:05 +08:00
|
|
|
|
2017-05-30 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21519
|
|
|
|
|
* objdump.c (dump_relocs_in_section): Replace get_file_size
|
|
|
|
|
with bfd_get_file_size to get archive element size.
|
|
|
|
|
* testsuite/binutils-all/objdump.exp (test_objdump_f): New
|
|
|
|
|
proc.
|
|
|
|
|
(test_objdump_h): Likewise.
|
|
|
|
|
(test_objdump_t): Likewise.
|
|
|
|
|
(test_objdump_r): Likewise.
|
|
|
|
|
(test_objdump_s): Likewise.
|
|
|
|
|
Add objdump tests on archive.
|
|
|
|
|
|
2017-05-25 00:23:52 +08:00
|
|
|
|
2017-05-24 Yao Qi <yao.qi@linaro.org>
|
|
|
|
|
|
|
|
|
|
* objdump.c (disassemble_data): Caller update.
|
|
|
|
|
|
2017-05-20 14:45:29 +08:00
|
|
|
|
2017-05-19 Jose E. Marchesi <jose.marchesi@oracle.com>
|
|
|
|
|
|
|
|
|
|
* objcopy.c (merge_gnu_build_notes): Remove workaround that
|
|
|
|
|
prevented deleting relocations in duplicated notes in mips64 and
|
|
|
|
|
sparc.
|
|
|
|
|
|
MIPS/BFD: For n64 hold the number of internal relocs in `->reloc_count'
Revert parts of commit fee24f1c5bfe ("objdump improvements for mips
elf64"), <https://sourceware.org/ml/binutils/2003-03/msg00108.html>, and
make the `->reloc_count' member of `struct bfd_section' hold the actual
number of internal relocations stored in its `->relocation' vector. To
do so adjust `mips_elf64_slurp_one_reloc_table' to set `->reloc_count'
to the actual number of internal relocations retrieved and discard
`mips_elf64_canonicalize_reloc', `mips_elf64_canonicalize_dynamic_reloc'
and their corresponding target macros. Contrary to the description of
`mips_elf64_slurp_one_reloc_table', adjusted appropriately, this makes
generic relocation processing code happy and satisfies the "merge notes
section" binutils test case.
Add extra binutils test cases to expand the coverage of the generic
"merge notes section" test case, now passing with the n64 ABI, across
the MIPS o32, n32 and n64 ABIs regardless of the default ABI selected in
target configuration, and also to verify correctness of the relocations
produced. Conversely, do not provide any additional test cases for the
original issue addressed with the commit referred:
- objdump would display only 1/3 of the total number of relocations,
because it used the external relocation count, but each external
relocation is brought in as 3 internal relocations.
as n64 ABI relocation processing with `objdump -r' and `objdump -R' is
already widely covered across the GAS and LD test suites.
bfd/
* elf64-mips.c (mips_elf64_canonicalize_reloc): Remove prototype
and function.
(mips_elf64_canonicalize_dynamic_reloc): Likewise.
(mips_elf64_slurp_one_reloc_table): Set `reloc_count' to the
actual number of internal relocations retrieved. Adjust
function description.
(bfd_elf64_canonicalize_reloc): Remove macro.
(bfd_elf64_canonicalize_dynamic_reloc): Likewise.
binutils/
* testsuite/binutils-all/mips/mips-note-2.d: New test.
* testsuite/binutils-all/mips/mips-note-2r.d: New test.
* testsuite/binutils-all/mips/mips-note-2-n32.d: New test.
* testsuite/binutils-all/mips/mips-note-2-n64.d: New test.
* testsuite/binutils-all/mips/mips-note-2r-n32.d: New test.
* testsuite/binutils-all/mips/mips-note-2r-n64.d: New test.
* testsuite/binutils-all/mips/mips.exp: Define `has_newabi'.
Run the new tests.
2017-05-19 22:11:31 +08:00
|
|
|
|
2017-05-19 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/mips/mips-note-2.d: New test.
|
|
|
|
|
* testsuite/binutils-all/mips/mips-note-2r.d: New test.
|
|
|
|
|
* testsuite/binutils-all/mips/mips-note-2-n32.d: New test.
|
|
|
|
|
* testsuite/binutils-all/mips/mips-note-2-n64.d: New test.
|
|
|
|
|
* testsuite/binutils-all/mips/mips-note-2r-n32.d: New test.
|
|
|
|
|
* testsuite/binutils-all/mips/mips-note-2r-n64.d: New test.
|
|
|
|
|
* testsuite/binutils-all/mips/mips.exp: Define `has_newabi'.
|
|
|
|
|
Run the new tests.
|
|
|
|
|
|
2017-05-19 22:08:16 +08:00
|
|
|
|
2017-05-19 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/lib/utils-lib.exp (run_dump_test): Handle the `dump'
|
|
|
|
|
option.
|
|
|
|
|
|
binutils: support for the SPARC M8 processor
This patch adds support for the new SPARC M8 processor (implementing OSA
2017) to binutils.
New instructions:
- Dictionary Unpack
+ dictunpack
- Partitioned Compare with shifted result
+ Signed variants: fpcmp{le,gt,eq,ne}{8,16,32}shl
+ Unsigned variants: fpcmpu{le,gt}{8,16,32}shl
- Partitioned Dual-Equal compared, with shifted result
+ fpcmpde{8,16,32}shl
- Partitioned Unsigned Range Compare, with shifted result
+ fpcmpur{8,16,32}shl
- 64-bit shifts on Floating-Point registers
+ fps{ll,ra,rl}64x
- Misaligned loads and stores
+ ldm{sh,uh,sw,uw,x,ux}
+ ldm{sh,uh,sw,uw,x,ux}a
+ ldmf{s,d}
+ ldmf{s,d}a
+ stm{h,w,x}
+ stm{h,w,x}a
+ stmf{s,d}
+ stmf{s,d}a
- Oracle Numbers
+ on{add,sub,mul,div}
- Reverse Bytes/Bits
+ revbitsb
+ revbytes{h,w,x}
- Run-Length instructions
+ rle_burst
+ rle_length
- New crypto instructions
+ sha3
- Instruction to read the new register %entropy
+ rd %entropy
New Alternate Address Identifiers:
- 0x24, #ASI_CORE_COMMIT_COUNT
- 0x24, #ASI_CORE_SELECT_COUNT
- 0x48, #ASI_ARF_ECC_REG
- 0x53, #ASI_ITLB_PROBE
- 0x58, #ASI_DSFAR
- 0x5a, #ASI_DTLB_PROBE_PRIMARY
- 0x5b, #ASI_DTLB_PROBE_REAL
- 0x64, #ASI_CORE_SELECT_COMMIT_NHT
The new assembler command-line options for selecting the M8 architecture
are:
-Av9m8 or -Asparc6 for 64-bit binaries.
-Av8plusm8 for 32-bit (v8+) binaries.
The corresponding disassembler command-line options are:
-msparc:v9m8 for 64-bit binaries.
-msparc:v8plusm8 for 32-bit (v8+) binaries.
Tested for regressions in the following targets:
sparc-aout sparc-linux sparc-vxworks sparc64-linux
bfd/ChangeLog:
2017-05-19 Jose E. Marchesi <jose.marchesi@oracle.com>
* archures.c (bfd_mach_sparc_v9m8): Define.
(bfd_mach_sparc_v8plusm8): Likewise.
(bfd_mach_sparc_v9_p): Adjust to M8.
(bfd_mach_sparc_64bit_p): Likewise.
* aoutx.h (machine_type): Handle bfd_mach_sparc_v9m8 and
bfd_mach_sparc_v8plusm8.
* bfd-in2.h: Regenerated.
* cpu-sparc.c (arch_info_struct): Entries for sparc:v9m8 and
sparc:v8plusm8.
* elfxx-sparc.c (_bfd_sparc_elf_object_p): Handle
bfd_mach_sparc_v8plusm8 and bfd_mach_sparc_v9m8 using the new hw
capabilities ONADDSUB, ONMUL, ONDIV, DICTUNP, FPCPSHL, RLE and
SHA3.
* elf32-sparc.c (elf32_sparc_final_write_processing): Handle
bfd_mach_sparc_v8plusm8.
binutils/ChangeLog:
2017-05-19 Jose E. Marchesi <jose.marchesi@oracle.com>
* NEWS: Mention the SPARC M8 support.
gas/ChangeLog:
2017-05-19 Jose E. Marchesi <jose.marchesi@oracle.com>
* config/tc-sparc.c (sparc_arch_table): Entries for `sparc6',
`v9m8' and `v8plusm8'.
(sparc_md_end): Handle SPARC_OPCODE_ARCH_M8.
(get_hwcap_name): Support the M8 hardware capabilities.
(sparc_ip): Handle new operand types.
* doc/c-sparc.texi (Sparc-Opts): Document -Av9m8, -Av8plusm8 and
-Asparc6, and the corresponding -xarch aliases.
* testsuite/gas/sparc/sparc6.s: New file.
* testsuite/gas/sparc/sparc6.d: Likewise.
* testsuite/gas/sparc/sparc6-diag.s: Likewise.
* testsuite/gas/sparc/sparc6-diag.l: Likewise.
* testsuite/gas/sparc/fpcmpshl.s: Likewise.
* testsuite/gas/sparc/fpcmpshl.d: Likewise.
* testsuite/gas/sparc/fpcmpshl-diag.s: Likewise.
* testsuite/gas/sparc/fpcmpshl-diag.l: Likewise.
* testsuite/gas/sparc/ldm-stm.s: Likewise.
* testsuite/gas/sparc/ldm-stm.d: Likewise.
* testsuite/gas/sparc/ldm-stm-diag.s: Likewise.
* testsuite/gas/sparc/ldm-stm-diag.l: Likewise.
* testsuite/gas/sparc/ldmf-stmf.s: Likewise.
* testsuite/gas/sparc/ldmf-stmf.d: Likewise.
* testsuite/gas/sparc/ldmf-stmf-diag.s: Likewise.
* testsuite/gas/sparc/ldmf-stmf-diag.l: Likewise.
* testsuite/gas/sparc/on.s: Likewise.
* testsuite/gas/sparc/on.d: Likewise.
* testsuite/gas/sparc/on-diag.s: Likewise.
* testsuite/gas/sparc/on-diag.l: Likewise.
* testsuite/gas/sparc/rle.s: Likewise.
* testsuite/gas/sparc/rle.d: Likewise.
* testsuite/gas/sparc/sparc.exp (gas_64_check): Run new tests.
* testsuite/gas/sparc/rdasr.s: Add test for RDENTROPY.
* testsuite/gas/sparc/rdasr.d: Likewise.
include/ChangeLog:
2017-05-19 Jose E. Marchesi <jose.marchesi@oracle.com>
* elf/sparc.h (ELF_SPARC_HWCAP2_SPARC6): Define.
(ELF_SPARC_HWCAP2_ONADDSUB): Likewise.
(ELF_SPARC_HWCAP2_ONMUL): Likewise.
(ELF_SPARC_HWCAP2_ONDIV): Likewise.
(ELF_SPARC_HWCAP2_DICTUNP): Likewise.
(ELF_SPARC_HWCAP2_FPCMPSHL): Likewise.
(ELF_SPARC_HWCAP2_RLE): Likewise.
(ELF_SPARC_HWCAP2_SHA3): Likewise.
* opcode/sparc.h (sparc_opcode_arch_val): Add SPARC_OPCODE_ARCH_M8
and adjust SPARC_OPCODE_ARCH_MAX.
(HWCAP2_SPARC6): Define.
(HWCAP2_ONADDSUB): Likewise.
(HWCAP2_ONMUL): Likewise.
(HWCAP2_ONDIV): Likewise.
(HWCAP2_DICTUNP): Likewise.
(HWCAP2_FPCMPSHL): Likewise.
(HWCAP2_RLE): Likewise.
(HWCAP2_SHA3): Likewise.
(OPM): Likewise.
(OPMI): Likewise.
(ONFCN): Likewise.
(REVFCN): Likewise.
(SIMM10): Likewise.
opcodes/ChangeLog:
2017-05-19 Jose E. Marchesi <jose.marchesi@oracle.com>
* sparc-dis.c (MASK_V9): Include SPARC_OPCODE_ARCH_M8.
(X_IMM2): Define.
(compute_arch_mask): Handle bfd_mach_sparc_v8plusm8 and
bfd_mach_sparc_v9m8.
(print_insn_sparc): Handle new operand types.
* sparc-opc.c (MASK_M8): Define.
(v6): Add MASK_M8.
(v6notlet): Likewise.
(v7): Likewise.
(v8): Likewise.
(v9): Likewise.
(v9a): Likewise.
(v9b): Likewise.
(v9c): Likewise.
(v9d): Likewise.
(v9e): Likewise.
(v9v): Likewise.
(v9m): Likewise.
(v9andleon): Likewise.
(m8): Define.
(HWS_VM8): Define.
(HWS2_VM8): Likewise.
(sparc_opcode_archs): Add entry for "m8".
(sparc_opcodes): Add OSA2017 and M8 instructions
dictunpack, fpcmp{ule,ugt,eq,ne,de,ur}{8,16,32}shl,
fpx{ll,ra,rl}64x,
ldm{sh,uh,sw,uw,x,ux}, ldm{sh,uh,sw,uw,x,ux}a, ldmf{s,d},
ldmf{s,d}a, on{add,sub,mul,div}, rdentropy, revbitsb,
revbytes{h,w,x}, rle_burst, rle_length, sha3, stm{h,w,x},
stm{h,w,x}a, stmf{s,d}, stmf{s,d}a.
(asi_table): New M8 ASIs ASI_CORE_COMMIT_COUNT,
ASI_CORE_SELECT_COUNT, ASI_ARF_ECC_REG, ASI_ITLB_PROBE, ASI_DSFAR,
ASI_DTLB_PROBE_PRIMARY, ASI_DTLB_PROBE_REAL,
ASI_CORE_SELECT_COMMIT_NHT.
2017-05-20 00:27:08 +08:00
|
|
|
|
2017-05-19 Jose E. Marchesi <jose.marchesi@oracle.com>
|
|
|
|
|
|
|
|
|
|
* NEWS: Mention the SPARC M8 support.
|
|
|
|
|
|
2017-05-19 14:53:21 +08:00
|
|
|
|
2017-05-19 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/mips/mips.exp: Bail out right away if
|
|
|
|
|
non-ELF.
|
|
|
|
|
|
2017-05-18 13:17:40 +08:00
|
|
|
|
2017-05-18 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* strings.c: Don't compare boolean values against TRUE or FALSE.
|
|
|
|
|
|
2017-05-16 00:48:41 +08:00
|
|
|
|
2017-05-15 Jeff Law <law@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (display_arc_attribute): Avoid implicit fallthru.
|
|
|
|
|
|
2017-05-15 20:45:42 +08:00
|
|
|
|
2017-05-15 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/mips/mips16-undecoded.d: Add `-mips3'
|
|
|
|
|
to `as' flags.
|
|
|
|
|
* testsuite/binutils-all/mips/mips16e2-undecoded.d: New test.
|
|
|
|
|
* testsuite/binutils-all/mips/mips16e2-extend-insn.d: New test.
|
|
|
|
|
* testsuite/binutils-all/mips/mips16-undecoded.s: Remove
|
|
|
|
|
`.module mips3'.
|
|
|
|
|
* testsuite/binutils-all/mips/mips.exp: Run the new tests.
|
|
|
|
|
|
MIPS16e2: Add MIPS16e2 ASE support
Add MIPS16e2 ASE support as per the architecture specification[1],
including in particular:
1. A new ELF ASE flag to mark MIPS16e2 binaries.
2. MIPS16e2 instruction assembly support, including a relaxation update
to use LUI rather than an LI/SLL instruction pair for loading the
high part of 32-bit addresses.
3. MIPS16e2 instruction disassembly support, including updated rules for
extended forms of instructions that are now subdecoded and therefore
do not alias to the original MIPS16 ISA revision instructions even
for encodings that are not valid in the MIPS16e2 instruction set.
Add `-mmips16e2' and `-mno-mips16e2' GAS command-line options and their
corresponding `mips16e2' and `no-mips16e2' settings for the `.set' and
`.module' pseudo-ops. Control the availability of the MT ASE subset of
the MIPS16e2 instruction set with a combination of these controls and
the preexisting MT ASE controls.
Parts of this change by Matthew Fortune and Andrew Bennett.
References:
[1] "MIPS32 Architecture for Programmers: MIPS16e2 Application-Specific
Extension Technical Reference Manual", Imagination Technologies
Ltd., Document Number: MD01172, Revision 01.00, April 26, 2016
include/
* elf/mips.h (AFL_ASE_MIPS16E2): New macro.
(AFL_ASE_MASK): Adjust accordingly.
* opcode/mips.h: Document new operand codes defined.
(mips_operand_type): Add OP_REG28 enum value.
(INSN2_SHORT_ONLY): Update description.
(ASE_MIPS16E2, ASE_MIPS16E2_MT): New macros.
bfd/
* elfxx-mips.c (print_mips_ases): Handle MIPS16e2 ASE.
opcodes/
* mips-dis.c (mips_arch_choices): Add ASE_MIPS16E2 and
ASE_MIPS16E2_MT flags to the unnamed MIPS16 entry.
(mips_convert_abiflags_ases): Handle the AFL_ASE_MIPS16E2 flag.
(print_insn_arg) <OP_REG28>: Add handler.
(validate_insn_args) <OP_REG28>: Handle.
(print_mips16_insn_arg): Handle MIPS16 instructions that require
32-bit encoding and 9-bit immediates.
(print_insn_mips16): Handle MIPS16 instructions that require
32-bit encoding and MFC0/MTC0 operand decoding.
* mips16-opc.c (decode_mips16_operand) <'>', '9', 'G', 'N', 'O'>
<'Q', 'T', 'b', 'c', 'd', 'r', 'u'>: Add handlers.
(RD_C0, WR_C0, E2, E2MT): New macros.
(mips16_opcodes): Add entries for MIPS16e2 instructions:
GP-relative "addiu" and its "addu" spelling, "andi", "cache",
"di", "ehb", "ei", "ext", "ins", GP-relative "lb", "lbu", "lh",
"lhu", and "lw" instructions, "ll", "lui", "lwl", "lwr", "mfc0",
"movn", "movtn", "movtz", "movz", "mtc0", "ori", "pause",
"pref", "rdhwr", "sc", GP-relative "sb", "sh" and "sw"
instructions, "swl", "swr", "sync" and its "sync_acquire",
"sync_mb", "sync_release", "sync_rmb" and "sync_wmb" aliases,
"xori", "dmt", "dvpe", "emt" and "evpe". Add split
regular/extended entries for original MIPS16 ISA revision
instructions whose extended forms are subdecoded in the MIPS16e2
ISA revision: "li", "sll" and "srl".
binutils/
* readelf.c (print_mips_ases): Handle MIPS16e2 ASE.
* NEWS: Mention MIPS16e2 ASE support.
gas/
* config/tc-mips.c (RELAX_MIPS16_ENCODE): Add `e2' flag.
(RELAX_MIPS16_E2): New macro.
(RELAX_MIPS16_PIC, RELAX_MIPS16_SYM32, RELAX_MIPS16_NOMACRO)
(RELAX_MIPS16_USER_SMALL, RELAX_MIPS16_USER_EXT)
(RELAX_MIPS16_DSLOT, RELAX_MIPS16_JAL_DSLOT)
(RELAX_MIPS16_EXTENDED, RELAX_MIPS16_MARK_EXTENDED)
(RELAX_MIPS16_CLEAR_EXTENDED, RELAX_MIPS16_ALWAYS_EXTENDED)
(RELAX_MIPS16_MARK_ALWAYS_EXTENDED)
(RELAX_MIPS16_CLEAR_ALWAYS_EXTENDED, RELAX_MIPS16_MACRO)
(RELAX_MIPS16_MARK_MACRO, RELAX_MIPS16_CLEAR_MACRO): Shift bits.
(mips16_immed_extend): New prototype.
(options): Add OPTION_MIPS16E2 and OPTION_NO_MIPS16E2 enum
values.
(md_longopts): Add "mmips16e2" and "mno-mips16e2" options.
(mips_ases): Add "mips16e2" entry.
(mips_set_ase): Handle MIPS16e2 ASE.
(insn_insert_operand): Explicitly handle immediates with MIPS16
instructions that require 32-bit encoding.
(is_opcode_valid_16): Pass enabled ASE bitmask on to
`opcode_is_member'.
(validate_mips_insn): Explicitly handle immediates with MIPS16
instructions that require 32-bit encoding.
(operand_reg_mask) <OP_REG28>: Add handler.
(match_reg28_operand): New function.
(match_operand) <OP_REG28>: Add handler.
(append_insn): Pass ASE_MIPS16E2 setting to RELAX_MIPS16_ENCODE.
(match_mips16_insn): Handle MIPS16 instructions that require
32-bit encoding and `V' and `u' operand codes.
(mips16_ip): Allow any characters except from `.' in opcodes.
(mips16_immed_extend): Handle 9-bit immediates. Do not shuffle
immediates whose width is not one of these listed.
(md_estimate_size_before_relax): Handle MIPS16e2 relaxation.
(mips_relax_frag): Likewise.
(md_convert_frag): Likewise.
(mips_convert_ase_flags): Handle MIPS16e2 ASE.
* doc/as.texinfo (Target MIPS options): Add `-mmips16e2' and
`-mno-mips16e2' options.
(-mmips16e2, -mno-mips16e2): New options.
* doc/c-mips.texi (MIPS Options): Add `-mmips16e2' and
`-mno-mips16e2' options.
(MIPS ASE Instruction Generation Overrides): Add `.set mips16e2'
and `.set nomips16e2'.
2017-05-15 20:26:01 +08:00
|
|
|
|
2017-05-15 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (print_mips_ases): Handle MIPS16e2 ASE.
|
|
|
|
|
* NEWS: Mention MIPS16e2 ASE support.
|
|
|
|
|
|
2017-05-12 08:09:36 +08:00
|
|
|
|
2017-05-12 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/mips/mips16-extend-insn.d: Adjust BREAK
|
|
|
|
|
and SDBBP disassembly.
|
|
|
|
|
|
2017-05-11 02:03:15 +08:00
|
|
|
|
2017-05-10 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/mips/mips.exp: Define `tempfile' and
|
|
|
|
|
`copyfile' variables.
|
|
|
|
|
|
[ARC] Object attributes.
gas/
2017-05-10 Claudiu Zissulescu <claziss@synopsys.com>
* testsuite/gas/arc/attr-arc600.d: New file.
* testsuite/gas/arc/attr-arc600_mul32x16.d: Likewise.
* testsuite/gas/arc/attr-arc600_norm.d: Likewise.
* testsuite/gas/arc/attr-arc601.d: Likewise.
* testsuite/gas/arc/attr-arc601_mul32x16.d: Likewise.
* testsuite/gas/arc/attr-arc601_mul64.d: Likewise.
* testsuite/gas/arc/attr-arc601_norm.d: Likewise.
* testsuite/gas/arc/attr-arc700.d: Likewise.
* testsuite/gas/arc/attr-arcem.d: Likewise.
* testsuite/gas/arc/attr-archs.d: Likewise.
* testsuite/gas/arc/attr-autodetect-1.d: Likewise.
* testsuite/gas/arc/attr-autodetect-1.s: Likewise.
* testsuite/gas/arc/attr-cpu-a601.d: Likewise.
* testsuite/gas/arc/attr-cpu-a601.s: Likewise.
* testsuite/gas/arc/attr-cpu-a700.d: Likewise.
* testsuite/gas/arc/attr-cpu-a700.s: Likewise.
* testsuite/gas/arc/attr-cpu-em.d: Likewise.
* testsuite/gas/arc/attr-cpu-em.s: Likewise.
* testsuite/gas/arc/attr-cpu-hs.d: Likewise.
* testsuite/gas/arc/attr-cpu-hs.s: Likewise.
* testsuite/gas/arc/attr-em.d: Likewise.
* testsuite/gas/arc/attr-em4.d: Likewise.
* testsuite/gas/arc/attr-em4_dmips.d: Likewise.
* testsuite/gas/arc/attr-em4_fpuda.d: Likewise.
* testsuite/gas/arc/attr-em4_fpus.d: Likewise.
* testsuite/gas/arc/attr-hs.d: Likewise.
* testsuite/gas/arc/attr-hs34.d: Likewise.
* testsuite/gas/arc/attr-hs38.d: Likewise.
* testsuite/gas/arc/attr-hs38_linux.d: Likewise.
* testsuite/gas/arc/attr-mul64.d: Likewise.
* testsuite/gas/arc/attr-name.d: Likewise.
* testsuite/gas/arc/attr-name.s: Likewise.
* testsuite/gas/arc/attr-nps400.d: Likewise.
* testsuite/gas/arc/attr-override-mcpu.d: Likewise.
* testsuite/gas/arc/attr-override-mcpu.s
* testsuite/gas/arc/attr-quarkse_em.d: Likewise.
* testsuite/gas/arc/blank.s: Likewise.
* testsuite/gas/elf/section2.e-arc: Likewise.
* testsuite/gas/arc/cpu-pseudop-1.d: Update test.
* testsuite/gas/arc/cpu-pseudop-2.d: Likewise.
* testsuite/gas/arc/nps400-0.d: Likewise.
* testsuite/gas/elf/elf.exp: Set target_machine for ARC.
* config/tc-arc.c (opcode/arc-attrs.h): Include.
(ARC_GET_FLAG, ARC_SET_FLAG, streq): Define.
(arc_attribute): Declare new function.
(md_pseudo_table): Add arc_attribute.
(cpu_types): Rename default cpu features.
(selected_cpu): Set the default OSABI flag.
(mpy_option): New variable.
(pic_option): Likewise.
(sda_option): Likewise.
(tls_option): Likewise.
(feature_type, feature_list): Remove.
(arc_initial_eflag): Likewise.
(attributes_set_explicitly): New variable.
(arc_check_feature): Check also for the conflicting features.
(arc_select_cpu): Refactor assignment of selected_cpu.eflags.
(arc_option): Remove setting of private flags and architecture.
(check_cpu_feature): Refactor feature names.
(autodetect_attributes): New function.
(assemble_tokens): Use above function.
(md_parse_option): Refactor feature names.
(arc_attribute): New function.
(arc_set_attribute_int): Likewise.
(arc_set_attribute_string): Likewise.
(arc_stralloc): Likewise.
(arc_set_public_attributes): Likewise.
(arc_md_end): Likewise.
(arc_copy_symbol_attributes): Likewise.
(rc_convert_symbolic_attribute): Likewise.
* config/tc-arc.h (md_end): Define.
(CONVERT_SYMBOLIC_ATTRIBUTE): Likewise.
(TC_COPY_SYMBOL_ATTRIBUTES): Likewise.
* doc/c-arc.texi: Document ARC object attributes.
binutils/
2017-05-10 Claudiu Zissulescu <claziss@synopsys.com>
* readelf.c (decode_ARC_machine_flags): Recognize OSABI v4.
(get_arc_section_type_name): New function.
(get_section_type_name): Use the above function.
(display_arc_attribute): New function.
(process_arc_specific): Likewise.
(process_arch_specific): Handle ARC specific information.
* testsuite/binutils-all/strip-3.d: Consider ARC.attributes
section.
include/
2017-05-10 Claudiu Zissulescu <claziss@synopsys.com>
* elf/arc.h (SHT_ARC_ATTRIBUTES): Define.
(Tag_ARC_*): Define.
(E_ARC_OSABI_V4): Define.
(E_ARC_OSABI_CURRENT): Reassign it.
(TAG_CPU_*): Define.
* opcode/arc-attrs.h: New file.
* opcode/arc.h (insn_subclass_t): Assign enum values.
(insn_subclass_t): Update enum with QUARKSE1, QUARKSE2, and LL64.
(ARC_EA, ARC_CD, ARC_LLOCK, ARC_ATOMIC, ARC_MPY, ARC_MULT)
(ARC_NPS400, ARC_DPFP, ARC_SPFP, ARC_FPU, ARC_FPUDA, ARC_SWAP)
(ARC_NORM, ARC_BSCAN, ARC_UIX, ARC_TSTAMP, ARC_VBFDW)
(ARC_BARREL, ARC_DSPA, ARC_SHIFT, ARC_INTR, ARC_DIV, ARC_XMAC)
(ARC_CRC): Delete.
bfd/
2017-05-10 Claudiu Zissulescu <claziss@synopsys.com>
* elf32-arc.c (FEATURE_LIST_NAME): Define.
(CONFLICT_LIST): Likewise.
(opcode/arc-attrs.h): Include.
(arc_elf_print_private_bfd_data): Print OSABI v4 flag.
(arc_extract_features): New file.
(arc_stralloc): Likewise.
(arc_elf_merge_attributes): Likewise.
(arc_elf_merge_private_bfd_data): Use object attributes.
(bfd_arc_get_mach_from_attributes): New function.
(arc_elf_object_p): Use object attributes.
(arc_elf_final_write_processing): Likewise.
(elf32_arc_obj_attrs_arg_type): New function.
(elf32_arc_obj_attrs_handle_unknown): Likewise.
(elf32_arc_section_from_shdr): Likewise.
(elf_backend_obj_attrs_vendor): Define.
(elf_backend_obj_attrs_section): Likewise.
(elf_backend_obj_attrs_arg_type): Likewise.
(elf_backend_obj_attrs_section_type): Likewise.
(elf_backend_obj_attrs_handle_unknown): Likewise.
(elf_backend_section_from_shdr): Likewise.
ld/
2017-05-10 Claudiu Zissulescu <claziss@synopsys.com>
* testsuite/ld-arc/attr-merge-0.d: New file.
* testsuite/ld-arc/attr-merge-0.s: Likewise.
* testsuite/ld-arc/attr-merge-0e.s: Likewise.
* testsuite/ld-arc/attr-merge-1.d: Likewise.
* testsuite/ld-arc/attr-merge-1.s: Likewise.
* testsuite/ld-arc/attr-merge-1e.s: Likewise.
* testsuite/ld-arc/attr-merge-2.d: Likewise.
* testsuite/ld-arc/attr-merge-2.s: Likewise.
* testsuite/ld-arc/attr-merge-3.d: Likewise.
* testsuite/ld-arc/attr-merge-3.s: Likewise.
* testsuite/ld-arc/attr-merge-3e.s: Likewise.
* testsuite/ld-arc/attr-merge-4.s: Likewise.
* testsuite/ld-arc/attr-merge-5.d: Likewise.
* testsuite/ld-arc/attr-merge-5a.s: Likewise.
* testsuite/ld-arc/attr-merge-5b.s: Likewise.
* testsuite/ld-arc/attr-merge-conflict-isa.d: Likewise.
* testsuite/ld-arc/attr-merge-err-isa.d: Likewise.
* testsuite/ld-arc/attr-merge-incompatible-cpu.d: Likewise.
* testsuite/ld-arc/got-01.d: Update test.
* testsuite/ld-arc/attr-merge-err-quarkse.d: New file.
* testsuite/ld-arc/attr-quarkse.s: Likewise.
* testsuite/ld-arc/attr-quarkse2.s: Likewise.
opcodes/
2017-05-10 Claudiu Zissulescu <claziss@synopsys.com>
* arc-dis.c (parse_option): Update quarkse_em option..
* arc-ext-tbl.h (dsp_fp_flt2i, dsp_fp_i2flt): Change subclass to
QUARKSE1.
(dsp_fp_div, dsp_fp_cmp): Change subclass to QUARKSE2.
2017-05-10 20:42:22 +08:00
|
|
|
|
2017-05-10 Claudiu Zissulescu <claziss@synopsys.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (decode_ARC_machine_flags): Recognize OSABI v4.
|
|
|
|
|
(get_arc_section_type_name): New function.
|
|
|
|
|
(get_section_type_name): Use the above function.
|
|
|
|
|
(display_arc_attribute): New function.
|
|
|
|
|
(process_arc_specific): Likewise.
|
|
|
|
|
(process_arch_specific): Handle ARC specific information.
|
|
|
|
|
|
2017-05-10 08:15:19 +08:00
|
|
|
|
2017-05-09 Kaz Kojima <kkojima@rr.iij4u.or.jp>
|
|
|
|
|
|
|
|
|
|
* MAINTAINERS (SH): Remove myself as SH maintainer.
|
|
|
|
|
|
2017-05-03 03:16:26 +08:00
|
|
|
|
2017-05-02 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* objcopy.c (merge_gnu_build_notes): Cast relcount to unsigned
|
|
|
|
|
long when comparing with sec->reloc_count.
|
|
|
|
|
|
2017-05-02 23:54:53 +08:00
|
|
|
|
2017-05-02 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* objcopy.c (merge_gnu_build_notes): Disable merge if there are
|
|
|
|
|
more internal relocs than external relocs.
|
|
|
|
|
|
2017-05-02 18:53:30 +08:00
|
|
|
|
2017-05-02 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/mips/mips16-undecoded.d: Adjust the
|
|
|
|
|
disassembly of PC-relative LA and LW synthetic instructions.
|
|
|
|
|
|
2017-05-02 18:54:53 +08:00
|
|
|
|
2017-05-02 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 21440
|
|
|
|
|
* objdump.c (dump_relocs_in_section): Check for an excessive
|
|
|
|
|
number of relocs before attempting to dump them.
|
|
|
|
|
|
2017-05-01 12:41:27 +08:00
|
|
|
|
2017-05-01 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* objcopy.c (merge_gnu_build_notes): Correct code deleting
|
|
|
|
|
relocs.
|
|
|
|
|
|
2017-04-28 19:09:14 +08:00
|
|
|
|
2017-04-28 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21439
|
|
|
|
|
* readelf.c (print_gnu_build_attribute_name): Allow for an empty
|
|
|
|
|
name field.
|
|
|
|
|
|
2017-04-28 18:21:53 +08:00
|
|
|
|
2017-04-28 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21437
|
|
|
|
|
* readelf.c (process_version_sections): Check for underflow when
|
|
|
|
|
computing the start address of the auxillary version data.
|
|
|
|
|
|
2017-04-28 17:28:04 +08:00
|
|
|
|
2017-04-28 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21438
|
|
|
|
|
* dwarf.c (process_extended_line_op): Do not assume that the
|
|
|
|
|
string extracted from the section is NUL terminated.
|
|
|
|
|
(fetch_indirect_string): If the string retrieved from the section
|
|
|
|
|
is not NUL terminated, return an error message.
|
|
|
|
|
(fetch_indirect_line_string): Likewise.
|
|
|
|
|
(fetch_indexed_string): Likewise.
|
|
|
|
|
|
2017-04-26 22:42:03 +08:00
|
|
|
|
2017-04-26 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
2017-04-26 22:45:41 +08:00
|
|
|
|
PR binutils/21433
|
2017-04-26 22:42:03 +08:00
|
|
|
|
* bucomm.c (get_file_size): Return -1 if file_name is NULL.
|
|
|
|
|
* ar.c (main): Fail with usage() invocation if no file names are
|
|
|
|
|
provided.
|
|
|
|
|
|
2017-04-26 21:23:26 +08:00
|
|
|
|
2017-04-26 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (process_section_headers): Warn about overlarge
|
|
|
|
|
sections.
|
|
|
|
|
(print_gnu_build_attribute_name): Print the number of unrecognised
|
|
|
|
|
note types. Fix formatting in the presence of errors.
|
|
|
|
|
(testsuite/binutils-all/note-2-32.s): Fix encoding of numeric notes.
|
|
|
|
|
(testsuite/binutils-all/note-2-64.s): Likewise.
|
|
|
|
|
|
2017-04-25 03:41:33 +08:00
|
|
|
|
2017-04-26 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (process_mips_specific): Add static GOT support.
|
|
|
|
|
|
2017-04-12 07:03:41 +08:00
|
|
|
|
2017-04-25 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (process_mips_specific): Remove error reporting from
|
|
|
|
|
GOT[1] processing.
|
|
|
|
|
|
2017-04-12 07:02:13 +08:00
|
|
|
|
2017-04-25 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (process_mips_specific): Remove null GOT data check.
|
|
|
|
|
|
MIPS16/opcodes: Annotate instruction aliases
Complement commit 986e18a5a9fd ("Add a second 'pinfo' member to
mips_opcode to extend number of available bits"),
<https://sourceware.org/ml/binutils/2005-01/msg00261.html>, and annotate
MIPS16 NOP, LA, DLA and the synthetic forms of LD and LW instructions as
aliases. These correspond to MOVE, and the PC-relative ADDIU, DADDIU,
LD and LW hardware instructions respectively.
binutils/
* testsuite/binutils-all/mips/mips16-alias.d: New test.
* testsuite/binutils-all/mips/mips16-noalias.d: New test.
* testsuite/binutils-all/mips/mips16-alias.s: New test source.
* testsuite/binutils-all/mips/mips.exp: Run the new tests.
opcodes/
* mips16-opc.c (AL): New macro.
(mips16_opcodes): Mark "nop", "la", "dla", and synthetic forms
of "ld" and "lw" as aliases.
2017-04-25 18:44:29 +08:00
|
|
|
|
2017-04-25 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/mips/mips16-alias.d: New test.
|
|
|
|
|
* testsuite/binutils-all/mips/mips16-noalias.d: New test.
|
|
|
|
|
* testsuite/binutils-all/mips/mips16-alias.s: New test source.
|
|
|
|
|
* testsuite/binutils-all/mips/mips.exp: Run the new tests.
|
|
|
|
|
|
2017-04-23 16:09:48 +08:00
|
|
|
|
2017-04-23 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21418
|
|
|
|
|
* ar.c (main): Check -a, -b, -i and -N args are given.
|
|
|
|
|
|
2017-04-23 15:58:14 +08:00
|
|
|
|
2017-04-23 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21417
|
|
|
|
|
* ar.c (main): Check that an archive file is given after options.
|
|
|
|
|
|
2017-04-23 17:01:40 +08:00
|
|
|
|
2017-04-23 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21415
|
|
|
|
|
* objdump.c (disassemble_section): Check bfd_get_section_contents
|
|
|
|
|
status.
|
|
|
|
|
|
2017-04-23 12:19:50 +08:00
|
|
|
|
2017-04-23 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR 21408
|
|
|
|
|
* dwarf.c (display_debug_lines_decoded): Don't segfault on NULL
|
|
|
|
|
file_table.
|
|
|
|
|
|
2017-04-21 19:31:59 +08:00
|
|
|
|
2017-04-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21378
|
|
|
|
|
* readelf.c (print_gnu_build_attribute_name): Check for an
|
|
|
|
|
overlarge name field.
|
|
|
|
|
|
2017-04-13 23:06:30 +08:00
|
|
|
|
2017-04-13 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21379
|
|
|
|
|
* readelf.c (process_dynamic_section): Detect over large section
|
|
|
|
|
offsets in the DT_SYMTAB entry.
|
|
|
|
|
|
|
|
|
|
2017-04-13 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21345
|
|
|
|
|
* readelf.c (process_mips_specific): Catch an unfeasible memory
|
|
|
|
|
allocation before it happens and print a suitable error message.
|
|
|
|
|
|
2017-04-13 21:50:56 +08:00
|
|
|
|
2017-04-13 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* objcopy.c: Add --no-merge-notes option to disable note merging.
|
|
|
|
|
Add --[no-]merge-notes option to strip, and enable it by default.
|
|
|
|
|
(num_bytes): New function.
|
|
|
|
|
(merge_gnu_build_notes): Add code to merge stack size notes.
|
|
|
|
|
* binutils.texi: Update strip and objcopy documentation.
|
|
|
|
|
* readelf.c (print_gnu_build_attribute_name): Use defined
|
|
|
|
|
constants for note types.
|
|
|
|
|
|
2017-04-10 23:27:05 +08:00
|
|
|
|
2017-04-10 John Delsignor <john.delsignore@roguewave.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21319
|
|
|
|
|
* dwarf.c (display_gdb_index): Correct test for a corrupt address
|
|
|
|
|
table size.
|
|
|
|
|
|
2017-04-06 00:22:47 +08:00
|
|
|
|
2017-04-05 Jiong Wang <jiong.wang@arm.com>
|
|
|
|
|
|
|
|
|
|
* objcopy.c (struct redefine_node): Delete the field "next".
|
|
|
|
|
(redefine_sym_list): Deleted.
|
|
|
|
|
(redefine_specific_htab): New hash table.
|
|
|
|
|
(redefine_specific_reverse_htab): Likewise.
|
|
|
|
|
(eq_string_redefnode): New function.
|
|
|
|
|
(htab_hash_redefnode): Likewise.
|
|
|
|
|
(create_symbol2redef_htab): Likewise.
|
|
|
|
|
(add_specific_symbol_node): Likewise.
|
|
|
|
|
(create_symbol_htabs): Create redefine_specific_htab and
|
|
|
|
|
redefine_specific_reverse_htab.
|
|
|
|
|
(lookup_sym_redefinition): Use hash table instead of list.
|
|
|
|
|
(redefine_list_append): Likewise, and rename to add_redefine_and_check.
|
|
|
|
|
(copy_main): Use redefine_specific_htab instead of redefine_sym_list.
|
|
|
|
|
Update comments.
|
|
|
|
|
|
Support ELF SHF_GNU_MBIND and PT_GNU_MBIND_XXX
Mark an ALLOC section, which should be placed in special memory area,
with SHF_GNU_MBIND. Its sh_info field indicates the special memory
type. GNU_MBIND section names start with ".mbind" so that they are
placed as orphan sections by linker. All input GNU_MBIND sections
with the same sh_type, sh_flags and sh_info are placed in one output
GNU_MBIND section. In executable and shared object, create a
GNU_MBIND segment for each GNU_MBIND section and its segment type is
PT_GNU_MBIND_LO plus the sh_info value. Each GNU_MBIND segment is
aligned at page boundary.
The assembler syntax:
.section .mbind.foo,"adx",%progbits
^ 0: Special memory type.
|
'd' for SHF_GNU_MBIND.
.section .mbind.foo,"adx",%progbits,0x1
^ 1: Special memory type.
|
'd' for SHF_GNU_MBIND.
.section .mbind.bar,"adG",%progbits,.foo_group,comdat,0x2
^ 2: Special memory type.
|
'd' for SHF_GNU_MBIND.
bfd/
* elf.c (get_program_header_size): Add a GNU_MBIND segment for
each GNU_MBIND section and align GNU_MBIND section to page size.
(_bfd_elf_map_sections_to_segments): Create a GNU_MBIND
segment for each GNU_MBIND section.
(_bfd_elf_init_private_section_data): Copy sh_info from input
for GNU_MBIND section.
binutils/
* NEWS: Mention support for ELF SHF_GNU_MBIND and
PT_GNU_MBIND_XXX.
* readelf.c (get_segment_type): Handle PT_GNU_MBIND_XXX.
(get_elf_section_flags): Handle SHF_GNU_MBIND.
(process_section_headers): Likewise.
* testsuite/binutils-all/mbind1.s: New file.
* testsuite/binutils-all/objcopy.exp: Run readelf test on
mbind1.s.
gas/
* NEWS: Mention support for ELF SHF_GNU_MBIND.
* config/obj-elf.c (section_match): New.
(get_section): Match both sh_info and group name.
(obj_elf_change_section): Add argument for sh_info. Pass both
sh_info and group name to get_section. Issue an error for
SHF_GNU_MBIND section without SHF_ALLOC. Set sh_info.
(obj_elf_parse_section_letters): Set SHF_GNU_MBIND for 'd'.
(obj_elf_section): Support SHF_GNU_MBIND section info.
* config/obj-elf.h (obj_elf_change_section): Add argument for
sh_info.
* config/tc-arm.c (start_unwind_section): Pass 0 as sh_info to
obj_elf_change_section.
* config/tc-ia64.c (obj_elf_vms_common): Likewise.
* config/tc-microblaze.c (microblaze_s_data): Likewise.
(microblaze_s_sdata): Likewise.
(microblaze_s_rdata): Likewise.
(microblaze_s_bss): Likewise.
* config/tc-mips.c (s_change_section): Likewise.
* config/tc-msp430.c (msp430_profiler): Likewise.
* config/tc-rx.c (parse_rx_section): Likewise.
* config/tc-tic6x.c (tic6x_start_unwind_section): Likewise.
* doc/as.texinfo: Document 'd' for SHF_GNU_MBIND.
* testsuite/gas/elf/elf.exp: Run section12a, section12b and
section13.
* testsuite/gas/elf/section10.d: Updated.
* testsuite/gas/elf/section10.s: Likewise.
* testsuite/gas/elf/section12.s: New file.
* testsuite/gas/elf/section12a.d: Likewise.
* testsuite/gas/elf/section12b.d: Likewise.
* testsuite/gas/elf/section13.l: Likewise.
* testsuite/gas/elf/section13.d: Likewise.
* testsuite/gas/elf/section13.s: Likewise.
include/
* elf/common.h (PT_GNU_MBIND_NUM): New.
(PT_GNU_MBIND_LO): Likewise.
(PT_GNU_MBIND_HI): Likewise.
(SHF_GNU_MBIND): Likewise.
ld/
* NEWS: Mention support for ELF SHF_GNU_MBIND and
PT_GNU_MBIND_XXX.
* emultempl/elf32.em (gld${EMULATION_NAME}_place_orphan): Place
input GNU_MBIND sections with the same type, attributes and
sh_info field into a single output GNU_MBIND section.
* testsuite/ld-elf/elf.exp: Run mbind2a and mbind2b.
* testsuite/ld-elf/mbind1.s: New file.
* testsuite/ld-elf/mbind1a.d: Likewise.
* testsuite/ld-elf/mbind1b.d: Likewise.
* testsuite/ld-elf/mbind1c.d: Likewise.
* testsuite/ld-elf/mbind2a.s: Likewise.
* testsuite/ld-elf/mbind2b.c: Likewise.
2017-04-05 00:05:48 +08:00
|
|
|
|
2017-04-04 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
* NEWS: Mention support for ELF SHF_GNU_MBIND and
|
|
|
|
|
PT_GNU_MBIND_XXX.
|
|
|
|
|
* readelf.c (get_segment_type): Handle PT_GNU_MBIND_XXX.
|
|
|
|
|
(get_elf_section_flags): Handle SHF_GNU_MBIND.
|
|
|
|
|
(process_section_headers): Likewise.
|
|
|
|
|
* testsuite/binutils-all/mbind1.s: New file.
|
|
|
|
|
* testsuite/binutils-all/objcopy.exp: Run readelf test on
|
|
|
|
|
mbind1.s.
|
|
|
|
|
|
2017-04-03 19:14:06 +08:00
|
|
|
|
2017-04-03 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21345
|
|
|
|
|
* readelf.c (get_program_headers): Check for there being too many
|
|
|
|
|
program headers before attempting to allocate space for them.
|
|
|
|
|
|
2017-04-03 18:13:21 +08:00
|
|
|
|
2017-04-03 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21344
|
|
|
|
|
* readelf.c (process_mips_specific): Check for an out of range GOT
|
|
|
|
|
entry before reading the module pointer.
|
|
|
|
|
|
2017-04-03 18:01:45 +08:00
|
|
|
|
2017-04-03 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21343
|
|
|
|
|
* readelf.c (get_unwind_section_word): Fix snafu checking for
|
|
|
|
|
invalid word offsets in ARM unwind information.
|
|
|
|
|
|
2017-03-31 20:07:01 +08:00
|
|
|
|
2017-03-31 Pip Cet <pipcet@gmail.com>
|
|
|
|
|
|
|
|
|
|
* NEWS: Use "WebAssembly" consistently.
|
|
|
|
|
* testsuite/binutils-all/wasm32/wasm32.exp: Fix copyright notice.
|
|
|
|
|
|
2017-03-30 17:57:21 +08:00
|
|
|
|
2017-03-30 Pip Cet <pipcet@gmail.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c: Add support for wasm32 ELF format WebAssembly files.
|
|
|
|
|
(guess_is_rela): Likewise.
|
|
|
|
|
(dump_relocations): Likewise.
|
|
|
|
|
(is_32bit_abs_reloc): Likewise.
|
|
|
|
|
(is_none_reloc_): Likewise.
|
|
|
|
|
* NEWS: Mention the new support.
|
|
|
|
|
* testsuite/lib/binutils-common.exp (is_elf_format): Mark wasm32
|
|
|
|
|
as ELF target.
|
|
|
|
|
(supports_gnu_unique): Mark wasm32 as supporting STB_GNU_UNIQUE.
|
|
|
|
|
* testsuite/binutils-all/nm.exp: Mark wasm32 as requiring .size annotations.
|
|
|
|
|
* testsuite/binutils-all/wasm32: New directory.
|
|
|
|
|
* testsuite/binutils-all/wasm32/create-wasm.d: New file.
|
|
|
|
|
* testsuite/binutils-all/wasm32/create-wasm.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/wasm32/custom-section.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/wasm32/custom-section.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/wasm32/invalid-wasm-1.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/wasm32/invalid-wasm-1.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/wasm32/long-sections.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/wasm32/long-sections.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/wasm32/parse-wasm.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/wasm32/parse-wasm.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/wasm32/parse-wasm-2.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/wasm32/parse-wasm-2.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/wasm32/prepared-section.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/wasm32/prepared-section.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/wasm32/wasm32.exp: New file, run tests.
|
|
|
|
|
|
2017-03-29 11:13:06 +08:00
|
|
|
|
2017-03-29 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* doc/binutils.texi (objdump): Document PowerPC -M options.
|
|
|
|
|
|
2017-03-21 21:05:19 +08:00
|
|
|
|
2017-03-21 Andi Kleen <ak@linux.intel.com>
|
|
|
|
|
|
|
|
|
|
* objdump.c (unwind_inlines): Add.
|
|
|
|
|
(option_values): Add OPTION_INLINES.
|
|
|
|
|
(show_line): Unwind inlines if requested.
|
|
|
|
|
(main): Parse OPTION_INLINES.
|
|
|
|
|
(usage): Document --inlines.
|
|
|
|
|
* doc/binutils.texi: Document --inlines.
|
|
|
|
|
* NEWS: Likewise.
|
|
|
|
|
|
2017-03-21 19:48:57 +08:00
|
|
|
|
2017-03-21 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (print_gnu_build_attribute_name): Allow stack
|
|
|
|
|
protection notes to contain numeric values. Use a colon rather
|
|
|
|
|
than a space to separate a string name from its values. Decode
|
|
|
|
|
the numeric value of a stack protection note.
|
|
|
|
|
* objcopy.c (merge_gnu_build_notes): Allow version notes to
|
|
|
|
|
contain extra text after the protocol version number.
|
|
|
|
|
|
2017-03-20 22:32:34 +08:00
|
|
|
|
2017-03-20 Mark Wielaard <mark@klomp.org>
|
|
|
|
|
|
|
|
|
|
* readelf.c (process_program_headers): Move dynamic_addr check
|
|
|
|
|
after .dynamic section cross check.
|
|
|
|
|
|
2017-03-18 01:36:51 +08:00
|
|
|
|
2017-03-17 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (print_gnu_build_attribute_name): Fix off by one error
|
|
|
|
|
printing the value for a build note with an ascii name.
|
|
|
|
|
|
2017-03-17 00:44:55 +08:00
|
|
|
|
2017-03-16 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (print_gnu_build_attribute_name): Add support for
|
|
|
|
|
GNU_BUILD_ATTRIBUTE_SHORT_ENUM.
|
|
|
|
|
|
2017-03-14 20:57:09 +08:00
|
|
|
|
2017-03-14 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (print_gnu_build_attribute_description): Move symbol
|
|
|
|
|
printing code to...
|
|
|
|
|
(print_symbol_for_build_attribute): New function. ...here.
|
|
|
|
|
Add to find the best symbol to associate with an OPEN note.
|
|
|
|
|
Add code to cache the symbol table and string table, so that they
|
|
|
|
|
are not loaded every time a note is displayed.
|
|
|
|
|
* testsuite/binutils-all/note-2-32.s: Add a function symbol.
|
|
|
|
|
* testsuite/binutils-all/note-2-64.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/note-2-32.d: Update expected note output.
|
|
|
|
|
* testsuite/binutils-all/note-2-64.d: Likewise.
|
|
|
|
|
|
2017-03-13 18:26:25 +08:00
|
|
|
|
2017-03-13 Alan Modra <amodra@gmail.com>
|
|
|
|
|
Taeung Song <treeze.taeung@gmail.com>
|
|
|
|
|
|
|
|
|
|
* objdump.c (update_source_path): Add abfd param. Add struct
|
|
|
|
|
stat var. Pass to try_print_file_open. Warn if source is more
|
|
|
|
|
recent than object.
|
|
|
|
|
(try_print_file_open, slurp_file): Add struct stat param to
|
|
|
|
|
return fstat.
|
|
|
|
|
(show_line): Call update_source_path with bfd.
|
|
|
|
|
|
2017-03-11 00:29:58 +08:00
|
|
|
|
2017-03-10 Chia-Hao Lo <fcamel@gmail.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21235
|
|
|
|
|
* objdump.c (main): Set do_wide with --wide.
|
|
|
|
|
|
2017-03-10 18:50:34 +08:00
|
|
|
|
2017-03-10 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (get_machine_name): Rearrange switch table in order of
|
|
|
|
|
increasing machine number. Add missing entries.
|
|
|
|
|
|
2017-03-08 23:44:04 +08:00
|
|
|
|
2017-03-08 H.J. Lu <hongjiu.lu@intel.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21231
|
|
|
|
|
* readelf.c (decode_x86_isa): Change argument to unsigned int.
|
|
|
|
|
(print_gnu_property_note): Retrieve property type and datasz as
|
|
|
|
|
4-byte integer. Consolidate property datasz check. Check
|
|
|
|
|
GNU_PROPERTY_LOPROC and GNU_PROPERTY_LOUSER.
|
|
|
|
|
* testsuite/binutils-all/i386/pr21231a.d: New file.
|
|
|
|
|
* testsuite/binutils-all/i386/pr21231a.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/i386/pr21231b.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/i386/pr21231b.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/x86-64/pr21231a.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/x86-64/pr21231a.s: Likewise.
|
|
|
|
|
* testsuite/binutils-all/x86-64/pr21231b.d: Likewise.
|
|
|
|
|
* testsuite/binutils-all/x86-64/pr21231b.s: Likewise.
|
|
|
|
|
|
2017-03-07 01:21:04 +08:00
|
|
|
|
2017-03-06 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (print_gnu_build_attribute_name): Read byte values
|
|
|
|
|
from the name string as unsigned bytes.
|
|
|
|
|
(process_notes_at): Use memcpy to copy an unterminated name
|
|
|
|
|
string.
|
|
|
|
|
|
2017-03-03 22:14:35 +08:00
|
|
|
|
2017-03-06 Sam Thursfield <sam.thursfield@codethink.co.uk>
|
|
|
|
|
|
|
|
|
|
* configure.ac (AC_CHECK_DECLS): Add asprintf.
|
|
|
|
|
* config.in: Regenerate.
|
|
|
|
|
* configure: Regenerate.
|
|
|
|
|
|
2017-03-02 18:52:51 +08:00
|
|
|
|
2017-03-02 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (print_gnu_build_attribute_description): Use global
|
|
|
|
|
symbols for OPEN attributes if at all possible.
|
2017-03-03 01:10:20 +08:00
|
|
|
|
* objcopy.c (is_merged_note_section): Support build note sections
|
|
|
|
|
without the SHF_GNU_BUILD_NOTE section flag set.
|
2017-03-02 18:52:51 +08:00
|
|
|
|
|
2017-03-02 17:58:19 +08:00
|
|
|
|
2017-03-02 Jan Kratochvil <jan.kratochvil@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (debug_displays_assert): New static assertion.
|
|
|
|
|
|
2017-03-02 17:06:00 +08:00
|
|
|
|
2017-03-02 Jan Kratochvil <jan.kratochvil@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.h (enum dwarf_section_display_enum): Add loclists and rnglists.
|
|
|
|
|
|
2017-03-01 19:09:46 +08:00
|
|
|
|
2017-03-01 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (get_note_type): Add support for GNU_BUILD_NOTEs.
|
|
|
|
|
(get_gnu_elf_note_type): Add support for GNU_PROPERTY_NOTEs.
|
|
|
|
|
(decode_x86_isa): New function.
|
|
|
|
|
(print_gnu_property_note): New function.
|
|
|
|
|
(print_gnu_note): Handle GNU_PROPERTY_NOTEs.
|
|
|
|
|
(print_gnu_build_attribute_description): New function.
|
|
|
|
|
(print_gnu_build_attribute_name): New function.
|
|
|
|
|
(process_note): Add support for GNU_BUILD_NOTEs.
|
|
|
|
|
* objcopy.c (--merge-notes): New command line option.
|
|
|
|
|
(copy_options): Add merge-notes.
|
|
|
|
|
(copy_usage): Likewise.
|
|
|
|
|
(is_merge_note_section): New function.
|
|
|
|
|
(merge_gnu_build_notes): New function.
|
|
|
|
|
(copy_object): Merge note sections if asked to do so.
|
|
|
|
|
(skip_section): Add skip_copy parameter. Add support for skipping
|
|
|
|
|
merged note sections.
|
|
|
|
|
(copy_relocations_in_section): Update call to skip_section.
|
|
|
|
|
(copy_section): Likewise.
|
|
|
|
|
(copy_main): Add support for merge-notes option.
|
|
|
|
|
* doc/binutils.texi: Document the new option to objcopy.
|
|
|
|
|
* NEWS: Mention the new feature.
|
|
|
|
|
* testsuite/binutils-all/note-2-32.d: New test. Checks note
|
|
|
|
|
merging on 32-bit targets.
|
|
|
|
|
* testsuite/binutils-all/note-2-32.s: New test source file.
|
|
|
|
|
* testsuite/binutils-all/note-2-64.d: New test. Like note-2-32.d
|
|
|
|
|
but for 64-bit targets.
|
|
|
|
|
* testsuite/binutils-all/note-2-64.s: New test source file.
|
|
|
|
|
* testsuite/binutils-all/objcopy.exp: Run the new test.
|
|
|
|
|
|
2017-03-01 02:32:07 +08:00
|
|
|
|
2017-02-28 Peter Bergner <bergner@vnet.ibm.com>
|
|
|
|
|
|
|
|
|
|
* objdump.c (main): Use remove_whitespace_and_extra_commas.
|
|
|
|
|
|
2017-02-28 06:22:53 +08:00
|
|
|
|
2017-02-27 Jan Kratochvil <jan.kratochvil@redhat.com>
|
|
|
|
|
|
|
|
|
|
Fix compilation with GCC 4.4.7.
|
|
|
|
|
* dwarf.c (display_loclists_list, display_debug_rnglists_list):
|
|
|
|
|
Initialize begin and end.
|
|
|
|
|
|
2017-02-24 21:28:50 +08:00
|
|
|
|
2017-02-25 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/dw5.S: Replace .string with .asciz.
|
|
|
|
|
Support hpux .comm variant.
|
|
|
|
|
* testsuite/binutils-all/readelf.exp: Define HPUX when assembling
|
|
|
|
|
dw5 test for hppa64-hpux.
|
|
|
|
|
|
Tidy up readelf's use of boolean values.
* readelf.c (show_name, do_dynamic, do_syms, do_dyn_syms,
(do_reloc, do_sections, do_section_groups, do_section_details,
(do_segments, do_unwind, do_using_dynamic, do_header, do_dump,
(do_version, do_histogram, do_debugging, do_arch, do_notes,
(do_archive_index, is_32bit_elf, decompress_dumps): Use
bfd_boolean type.
(parse_args): Treat the do_* variables as booleans.
(print_vma): Return an unsigned int.
(print_symbol): Change width parameter to signed int.
(is_ia64_vms): Change return type to bfd_boolean.
(guess_is_rela): Likewise.
(slurp_rela_relocs): Likewise.
(slurp_rel_relocs): Likewise.
(dump_relocations): Likewise.
(process_file_header): Likewise.
(get_program_headers): Likewise.
(process_program_headers): Likewise.
(process_section_headers): Likewise.
(process_section_groups): Likewise.
(dump_ia64_vms_dynamic_fixups): Likewise.
(dump_ia64_vms_dynamic_relocs): Likewise.
(process_ia64_vms_dynamic_relocs): Likewise.
(process_relocs): Likewise.
(dump_ia64_unwind): Likewise.
(ia64_process_unwind): Likewise.
(dump_hppa_unwind): Likewise.
(slurp_hppa_unwind_table): Likewise.
(hppa_process_unwind): Likewise.
(decode_arm_unwind_bytecode): Likewise.
(decode_tic6x_unwind_bytecode): Likewise.
(decode_arm_unwind): Likewise.
(dump_arm_unwind): Likewise.
(arm_process_unwind): Likewise.
(process_unwind): Likewise.
(get_32bit_dynamic_section): Likewise.
(get_64bit_dynamic_section): Likewise.
(process_dynamic_section): Likewise.
(process_version_sections): Likewise.
(process_symbol_table): Likewise.
(process_syminfo): Likewise.
(apply_relocations): Likewise.
(disassemble_section): Likewise.
(dump_section_as_strings): Likewise.
(dump_section_as_bytes): Likewise.
(load_specific_debug_section): Likewise.
(load_debug_section): Likewise.
(display_debug_section): Likewise.
(process_section_contents): Likewise.
(process_attributes): Likewise.
(process_nds32_specific): Likewise.
(process_gnu_liblist): Likewise.
(print_core_note): Likewise.
(print_gnu_note): Likewise.
(print_v850_note): Likewise.
(process_netbsd_elf_note): Likewise.
(print_stapsdt_note): Likewise.
(print_ia64_vms_note): Likewise.
(process_note): Likewise.
(process_notes_at): Likewise.
(process_corefile_note_segments): Likewise.
(process_v850_notes): Likewise.
(process_note_sections): Likewise.
(process_notes): Likewise.
(process_arch_specific): Likewise.
(get_file_header): Likewise.
(process_object): Likewise.
(process_archive): Likewise.
(process_file): Likewise.
(section_subset): Make static.
(get_mips_reg_size): Return a signed integer.
(process_object): Reverse the logic of the return value.
(process_archive): Likewise.
(process_file): Likewise.
2017-02-24 22:48:19 +08:00
|
|
|
|
2017-02-24 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (show_name, do_dynamic, do_syms, do_dyn_syms,
|
|
|
|
|
(do_reloc, do_sections, do_section_groups, do_section_details,
|
|
|
|
|
(do_segments, do_unwind, do_using_dynamic, do_header, do_dump,
|
|
|
|
|
(do_version, do_histogram, do_debugging, do_arch, do_notes,
|
|
|
|
|
(do_archive_index, is_32bit_elf, decompress_dumps): Use
|
|
|
|
|
bfd_boolean type.
|
|
|
|
|
(parse_args): Treat the do_* variables as booleans.
|
|
|
|
|
(print_vma): Return an unsigned int.
|
|
|
|
|
(print_symbol): Change width parameter to signed int.
|
|
|
|
|
(is_ia64_vms): Change return type to bfd_boolean.
|
|
|
|
|
(guess_is_rela): Likewise.
|
|
|
|
|
(slurp_rela_relocs): Likewise.
|
|
|
|
|
(slurp_rel_relocs): Likewise.
|
|
|
|
|
(dump_relocations): Likewise.
|
|
|
|
|
(process_file_header): Likewise.
|
|
|
|
|
(get_program_headers): Likewise.
|
|
|
|
|
(process_program_headers): Likewise.
|
|
|
|
|
(process_section_headers): Likewise.
|
|
|
|
|
(process_section_groups): Likewise.
|
|
|
|
|
(dump_ia64_vms_dynamic_fixups): Likewise.
|
|
|
|
|
(dump_ia64_vms_dynamic_relocs): Likewise.
|
|
|
|
|
(process_ia64_vms_dynamic_relocs): Likewise.
|
|
|
|
|
(process_relocs): Likewise.
|
|
|
|
|
(dump_ia64_unwind): Likewise.
|
|
|
|
|
(ia64_process_unwind): Likewise.
|
|
|
|
|
(dump_hppa_unwind): Likewise.
|
|
|
|
|
(slurp_hppa_unwind_table): Likewise.
|
|
|
|
|
(hppa_process_unwind): Likewise.
|
|
|
|
|
(decode_arm_unwind_bytecode): Likewise.
|
|
|
|
|
(decode_tic6x_unwind_bytecode): Likewise.
|
|
|
|
|
(decode_arm_unwind): Likewise.
|
|
|
|
|
(dump_arm_unwind): Likewise.
|
|
|
|
|
(arm_process_unwind): Likewise.
|
|
|
|
|
(process_unwind): Likewise.
|
|
|
|
|
(get_32bit_dynamic_section): Likewise.
|
|
|
|
|
(get_64bit_dynamic_section): Likewise.
|
|
|
|
|
(process_dynamic_section): Likewise.
|
|
|
|
|
(process_version_sections): Likewise.
|
|
|
|
|
(process_symbol_table): Likewise.
|
|
|
|
|
(process_syminfo): Likewise.
|
|
|
|
|
(apply_relocations): Likewise.
|
|
|
|
|
(disassemble_section): Likewise.
|
|
|
|
|
(dump_section_as_strings): Likewise.
|
|
|
|
|
(dump_section_as_bytes): Likewise.
|
|
|
|
|
(load_specific_debug_section): Likewise.
|
|
|
|
|
(load_debug_section): Likewise.
|
|
|
|
|
(display_debug_section): Likewise.
|
|
|
|
|
(process_section_contents): Likewise.
|
|
|
|
|
(process_attributes): Likewise.
|
|
|
|
|
(process_nds32_specific): Likewise.
|
|
|
|
|
(process_gnu_liblist): Likewise.
|
|
|
|
|
(print_core_note): Likewise.
|
|
|
|
|
(print_gnu_note): Likewise.
|
|
|
|
|
(print_v850_note): Likewise.
|
|
|
|
|
(process_netbsd_elf_note): Likewise.
|
|
|
|
|
(print_stapsdt_note): Likewise.
|
|
|
|
|
(print_ia64_vms_note): Likewise.
|
|
|
|
|
(process_note): Likewise.
|
|
|
|
|
(process_notes_at): Likewise.
|
|
|
|
|
(process_corefile_note_segments): Likewise.
|
|
|
|
|
(process_v850_notes): Likewise.
|
|
|
|
|
(process_note_sections): Likewise.
|
|
|
|
|
(process_notes): Likewise.
|
|
|
|
|
(process_arch_specific): Likewise.
|
|
|
|
|
(get_file_header): Likewise.
|
|
|
|
|
(process_object): Likewise.
|
|
|
|
|
(process_archive): Likewise.
|
|
|
|
|
(process_file): Likewise.
|
|
|
|
|
(section_subset): Make static.
|
|
|
|
|
(get_mips_reg_size): Return a signed integer.
|
|
|
|
|
(process_object): Reverse the logic of the return value.
|
|
|
|
|
(process_archive): Likewise.
|
|
|
|
|
(process_file): Likewise.
|
2017-02-25 02:15:12 +08:00
|
|
|
|
(process_program_headers): Fix snafu - if the program headers are
|
|
|
|
|
not available then this is not a cause to fail.
|
|
|
|
|
(process_corefile_note_segments): Likewise.
|
Tidy up readelf's use of boolean values.
* readelf.c (show_name, do_dynamic, do_syms, do_dyn_syms,
(do_reloc, do_sections, do_section_groups, do_section_details,
(do_segments, do_unwind, do_using_dynamic, do_header, do_dump,
(do_version, do_histogram, do_debugging, do_arch, do_notes,
(do_archive_index, is_32bit_elf, decompress_dumps): Use
bfd_boolean type.
(parse_args): Treat the do_* variables as booleans.
(print_vma): Return an unsigned int.
(print_symbol): Change width parameter to signed int.
(is_ia64_vms): Change return type to bfd_boolean.
(guess_is_rela): Likewise.
(slurp_rela_relocs): Likewise.
(slurp_rel_relocs): Likewise.
(dump_relocations): Likewise.
(process_file_header): Likewise.
(get_program_headers): Likewise.
(process_program_headers): Likewise.
(process_section_headers): Likewise.
(process_section_groups): Likewise.
(dump_ia64_vms_dynamic_fixups): Likewise.
(dump_ia64_vms_dynamic_relocs): Likewise.
(process_ia64_vms_dynamic_relocs): Likewise.
(process_relocs): Likewise.
(dump_ia64_unwind): Likewise.
(ia64_process_unwind): Likewise.
(dump_hppa_unwind): Likewise.
(slurp_hppa_unwind_table): Likewise.
(hppa_process_unwind): Likewise.
(decode_arm_unwind_bytecode): Likewise.
(decode_tic6x_unwind_bytecode): Likewise.
(decode_arm_unwind): Likewise.
(dump_arm_unwind): Likewise.
(arm_process_unwind): Likewise.
(process_unwind): Likewise.
(get_32bit_dynamic_section): Likewise.
(get_64bit_dynamic_section): Likewise.
(process_dynamic_section): Likewise.
(process_version_sections): Likewise.
(process_symbol_table): Likewise.
(process_syminfo): Likewise.
(apply_relocations): Likewise.
(disassemble_section): Likewise.
(dump_section_as_strings): Likewise.
(dump_section_as_bytes): Likewise.
(load_specific_debug_section): Likewise.
(load_debug_section): Likewise.
(display_debug_section): Likewise.
(process_section_contents): Likewise.
(process_attributes): Likewise.
(process_nds32_specific): Likewise.
(process_gnu_liblist): Likewise.
(print_core_note): Likewise.
(print_gnu_note): Likewise.
(print_v850_note): Likewise.
(process_netbsd_elf_note): Likewise.
(print_stapsdt_note): Likewise.
(print_ia64_vms_note): Likewise.
(process_note): Likewise.
(process_notes_at): Likewise.
(process_corefile_note_segments): Likewise.
(process_v850_notes): Likewise.
(process_note_sections): Likewise.
(process_notes): Likewise.
(process_arch_specific): Likewise.
(get_file_header): Likewise.
(process_object): Likewise.
(process_archive): Likewise.
(process_file): Likewise.
(section_subset): Make static.
(get_mips_reg_size): Return a signed integer.
(process_object): Reverse the logic of the return value.
(process_archive): Likewise.
(process_file): Likewise.
2017-02-24 22:48:19 +08:00
|
|
|
|
|
2017-02-24 02:18:51 +08:00
|
|
|
|
2017-02-24 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (get_ver_flags): Tidy the formatting of the string
|
|
|
|
|
returned
|
|
|
|
|
|
2017-02-24 02:16:55 +08:00
|
|
|
|
2017-02-24 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (process_version_sections) <SHT_GNU_verdef>: Make
|
|
|
|
|
`isum' unsigned.
|
|
|
|
|
<SHT_GNU_verneed>: Likewise.
|
|
|
|
|
|
2017-02-24 02:16:11 +08:00
|
|
|
|
2017-02-24 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (process_version_sections) <SHT_GNU_verdef>: Limit
|
|
|
|
|
the number of entries processed by the section size. Don't
|
|
|
|
|
break out of the loop if `ent.vd_next' is 0.
|
|
|
|
|
|
2017-02-24 05:54:02 +08:00
|
|
|
|
2017-02-23 Jan Kratochvil <jan.kratochvil@redhat.com>
|
|
|
|
|
|
|
|
|
|
* testsuite/binutils-all/dw5.S: New file.
|
|
|
|
|
* testsuite/binutils-all/dw5.W: New file.
|
|
|
|
|
* testsuite/binutils-all/readelf.exp (readelf -wiaoRlL): New test.
|
|
|
|
|
|
2017-02-24 05:54:02 +08:00
|
|
|
|
2017-02-23 Jan Kratochvil <jan.kratochvil@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (read_and_display_attr_value): Support DW_FORM_data16.
|
|
|
|
|
|
2017-02-24 05:54:01 +08:00
|
|
|
|
2017-02-23 Jan Kratochvil <jan.kratochvil@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (display_debug_macro): Support DWARF-5. Rename
|
|
|
|
|
DW_MACRO_GNU_*.
|
|
|
|
|
|
2017-02-24 05:54:01 +08:00
|
|
|
|
2017-02-23 Jan Kratochvil <jan.kratochvil@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (decode_location_expression): Support DW_OP_implicit_pointer,
|
|
|
|
|
DW_OP_const_type, DW_OP_regval_type, DW_OP_deref_type, DW_OP_convert
|
|
|
|
|
and DW_OP_reinterpret.
|
|
|
|
|
(read_and_display_attr_value): Support DW_AT_call_value,
|
|
|
|
|
DW_AT_call_data_value, DW_AT_call_target and
|
|
|
|
|
DW_AT_call_target_clobbered.
|
|
|
|
|
|
2017-02-24 05:54:01 +08:00
|
|
|
|
2017-02-23 Jan Kratochvil <jan.kratochvil@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (fetch_indirect_line_string): New function.
|
|
|
|
|
(abbrev_attr): New field implicit_const.
|
|
|
|
|
(add_abbrev_attr): New parameter implicit_const.
|
|
|
|
|
(process_abbrev_section): Support DW_FORM_implicit_const.
|
|
|
|
|
(decode_location_expression): Support DW_OP_entry_value.
|
|
|
|
|
(read_and_display_attr_value): Add parameter implicit_const. Support
|
|
|
|
|
DW_FORM_line_strp and DW_FORM_implicit_const.
|
|
|
|
|
(read_and_display_attr): Add parameter implicit_const.
|
|
|
|
|
(process_debug_info): Support line_str and DWARF-5.
|
|
|
|
|
(read_debug_line_header): Support DWARF-5.
|
|
|
|
|
(display_formatted_table): New function.
|
|
|
|
|
(display_debug_lines_raw): New parameter file. Support DWARF-5.
|
|
|
|
|
(display_debug_lines_decoded): New parameter fileptr. Support DWARF-5.
|
|
|
|
|
(display_debug_lines): Pass file parameter.
|
|
|
|
|
(display_debug_macro): Update read_and_display_attr_value caller.
|
|
|
|
|
(display_debug_abbrev): Support DW_FORM_implicit_const.
|
|
|
|
|
(display_loclists_list): New function.
|
|
|
|
|
(display_loc_list): Support .debug_loclists.
|
|
|
|
|
(display_debug_ranges_list): New function from display_debug_ranges.
|
|
|
|
|
(display_debug_rnglists_list): New function.
|
|
|
|
|
(display_debug_ranges): Support .debug_rnglists.
|
|
|
|
|
(debug_displays): Add .debug_line_str, .debug_loclists and
|
|
|
|
|
.debug_rnglists.
|
|
|
|
|
* dwarf.h: Include dwarf2.h
|
|
|
|
|
(DWARF2_Internal_LineInfo): Add li_offset_size.
|
|
|
|
|
(DWARF2_Internal_CompUnit): Add cu_unit_type.
|
|
|
|
|
(enum dwarf_section_display_enum): Add line_str.
|
|
|
|
|
* readelf.c (process_section_headers): Add rnglists and loclists.
|
|
|
|
|
|
2017-02-24 05:54:00 +08:00
|
|
|
|
2017-02-23 Jan Kratochvil <jan.kratochvil@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (display_block): Add parameter delimiter.
|
|
|
|
|
(decode_location_expression): Update display_block callers.
|
|
|
|
|
(read_and_display_attr_value): Add parameter delimiter.
|
|
|
|
|
(read_and_display_attr, display_debug_macro): Update
|
|
|
|
|
read_and_display_attr_value caller.
|
|
|
|
|
|
2017-02-24 04:37:31 +08:00
|
|
|
|
2017-02-23 Jan Kratochvil <jan.kratochvil@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (display_loc_list): Use dwarf_vma for offset, base_address
|
|
|
|
|
and off.
|
|
|
|
|
(display_loc_list_dwo): Use dwarf_vma for offset.
|
|
|
|
|
(display_debug_loc): Use dwarf_vma for offset, base_address.
|
|
|
|
|
(struct range_entry, range_entry_compar): Use dwarf_vma for
|
|
|
|
|
ranges_offset.
|
|
|
|
|
(display_debug_ranges): Use dwarf_vma for ranges_offset, offset and
|
|
|
|
|
base_address.
|
|
|
|
|
|
2017-02-23 21:45:21 +08:00
|
|
|
|
2017-02-23 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (display_tag_value): Use an explicit signed type for
|
|
|
|
|
the tag parameter.
|
|
|
|
|
(display_gnu_attributes): Use an unsigned integer type for
|
|
|
|
|
attribute tags.
|
|
|
|
|
(display_power_gnu_attribute): Likewise.
|
|
|
|
|
(display_s390_gnu_attribute): Likewise.
|
|
|
|
|
(display_sparc_hwcaps): Likewise.
|
|
|
|
|
(display_sparc_hwcaps2): Likewise.
|
|
|
|
|
(display_sparc_gnu_attribute): Likewise.
|
|
|
|
|
(display_mips_gnu_attribute): Likewise.
|
|
|
|
|
(display_tic6x_attribute): Likewise.
|
|
|
|
|
(display_raw_attribute): Likewise.
|
|
|
|
|
(process_attributes): Likewise.
|
|
|
|
|
(process_arm_specific): Delete redundant function.
|
|
|
|
|
(process_power_specific): Likewise.
|
|
|
|
|
(process_s390_specific): Likewise.
|
|
|
|
|
(process_sparc_specific): Likewise.
|
|
|
|
|
(process_tic6x_specific): Likewise.
|
|
|
|
|
(process_msp430x_specific): Likewise.
|
|
|
|
|
(display_public_gnu_attributes): New function. Displays known
|
|
|
|
|
information about an unknown gnu attribute.
|
|
|
|
|
(display_generic_attribute): New function. Calls
|
|
|
|
|
display_tag_value for non-nul tags.
|
|
|
|
|
(process_arch_specific): Call process_attributes even for
|
|
|
|
|
architectures not known to specifically support gnu attributes.
|
|
|
|
|
|
2017-02-23 03:22:59 +08:00
|
|
|
|
2017-02-22 Jan Kratochvil <jan.kratochvil@redhat.com>
|
|
|
|
|
|
|
|
|
|
* dwarf.c (decode_location_expression): Display also OP.
|
|
|
|
|
|
2017-02-23 02:09:41 +08:00
|
|
|
|
2017-02-22 Maciej W. Rozycki <macro@imgtec.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (process_version_sections) <SHT_GNU_verdef>: Print a
|
|
|
|
|
new line between the heading and the first version definition
|
|
|
|
|
entry.
|
|
|
|
|
|
2017-02-20 22:40:39 +08:00
|
|
|
|
2017-02-20 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21156
|
|
|
|
|
* dwarf.c (cu_tu_indexes_read): Move into...
|
|
|
|
|
(load_cu_tu_indexes): ... here. Change the variable into
|
|
|
|
|
tri-state. Change the function into boolean, returning
|
|
|
|
|
false if the indicies could not be loaded.
|
|
|
|
|
(find_cu_tu_set): Return NULL if the indicies could not be
|
|
|
|
|
loaded.
|
|
|
|
|
|
2017-02-17 23:59:45 +08:00
|
|
|
|
2017-02-17 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21156
|
|
|
|
|
* readelf.c (find_section_in_set): Test for invalid section
|
|
|
|
|
indicies.
|
|
|
|
|
|
2017-02-17 23:31:54 +08:00
|
|
|
|
2017-02-17 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (get_section_type_name): Add decoding of GNU section
|
|
|
|
|
types.
|
|
|
|
|
|
2017-02-15 17:42:38 +08:00
|
|
|
|
2017-02-15 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* MAINTAINERS: (MIPS, MN10300): Move Eric Christopher to Past
|
|
|
|
|
Maintainers section.
|
|
|
|
|
|
2017-02-14 23:10:34 +08:00
|
|
|
|
2017-02-14 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21159
|
|
|
|
|
* readelf.c (dump_section_as_strings): Reset the start address if
|
|
|
|
|
no decompression is perfromed.
|
|
|
|
|
(dump_section_as_bytes): Likewise.
|
|
|
|
|
|
2017-02-14 22:17:09 +08:00
|
|
|
|
2017-02-14 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21158
|
|
|
|
|
* rddbg.c (read_symbol_stabs_debugging_info): Check for a null or
|
|
|
|
|
empty symbol name.
|
|
|
|
|
|
2017-02-14 22:07:29 +08:00
|
|
|
|
2017-02-14 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21157
|
|
|
|
|
* stabs.c (parse_stab_enum_type): Check for corrupt NAME:VALUE
|
|
|
|
|
pairs.
|
|
|
|
|
(parse_number): Exit early if passed an empty string.
|
|
|
|
|
|
2017-02-14 21:24:09 +08:00
|
|
|
|
2017-02-14 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21155
|
|
|
|
|
* readelf.c (IN_RANGE): New macro. Tests for an address + offset
|
|
|
|
|
being within a given range.
|
|
|
|
|
(target_specific_reloc_handling): Use macro to test for underflow
|
|
|
|
|
as well as overflow of reloc offset.
|
|
|
|
|
|
2017-02-14 01:23:10 +08:00
|
|
|
|
2017-02-13 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21150
|
|
|
|
|
* nm.c (file_symbol): Add test of string length before testing
|
|
|
|
|
string characters.
|
|
|
|
|
|
2017-02-13 23:04:37 +08:00
|
|
|
|
2017-02-13 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21135
|
|
|
|
|
* readelf.c (dump_section_as_bytes): Handle the case where
|
|
|
|
|
uncompress_section_contents returns false.
|
2017-02-13 23:19:48 +08:00
|
|
|
|
(dump_section_as_bytes, load_specific_debug_section): Likewise.
|
2017-02-13 23:04:37 +08:00
|
|
|
|
|
2017-02-13 22:52:48 +08:00
|
|
|
|
2017-02-13 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21149
|
|
|
|
|
* readelf.c (get_compression_header): Add size parameter. Check
|
|
|
|
|
size against sizeof compression header before attempting to
|
|
|
|
|
extract the header.
|
|
|
|
|
(process_section_headers): Pass size to get_compression_header.
|
|
|
|
|
(dump_section_as_strings): Likewise.
|
|
|
|
|
(dump_section_as_bytes): Likewise.
|
|
|
|
|
(load_specific_debug_section): Likewise.
|
|
|
|
|
|
2017-02-13 22:35:24 +08:00
|
|
|
|
2017-02-13 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21148
|
|
|
|
|
* readelf.c (process_version_sections): Include size of auxillary
|
|
|
|
|
version information when checking for buffer overflow.
|
|
|
|
|
|
2017-02-13 22:17:07 +08:00
|
|
|
|
2017-02-13 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21147
|
|
|
|
|
* readelf.c (process_section_contents): Fix off by one error
|
|
|
|
|
reporting un-dumped sections.
|
|
|
|
|
|
2017-02-13 22:03:22 +08:00
|
|
|
|
2017-02-13 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21139
|
|
|
|
|
* readelf.c (target_specific_reloc_handling): Add num_syms
|
|
|
|
|
parameter. Check for symbol table overflow before accessing
|
|
|
|
|
symbol value. If reloc pointer is NULL, discard all saved state.
|
|
|
|
|
(apply_relocations): Pass num_syms to target_specific_reloc_handling.
|
|
|
|
|
Call target_specific_reloc_handling with a NULL reloc pointer
|
|
|
|
|
after processing all of the relocs.
|
|
|
|
|
|
2017-02-13 21:08:32 +08:00
|
|
|
|
2017-02-13 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/21137
|
|
|
|
|
* readelf.c (target_specific_reloc_handling): Add end parameter.
|
|
|
|
|
Check for buffer overflow before writing relocated values.
|
|
|
|
|
(apply_relocations): Pass end to target_specific_reloc_handling.
|
|
|
|
|
|
2017-01-27 21:20:24 +08:00
|
|
|
|
2017-01-27 Dilyan Palauzov <dilyan.palauzov@aegee.org>
|
|
|
|
|
Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 20343
|
|
|
|
|
* doc/binutils.texi (ar): Extend documentation of the --plugin
|
|
|
|
|
option. Include a description of where the plugins should be
|
|
|
|
|
located.
|
|
|
|
|
(nm): Likewise.
|
|
|
|
|
|
2017-01-24 00:16:55 +08:00
|
|
|
|
2017-01-23 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* MAINTAINERS: Add Bernd to Past Maintainers section.
|
2017-01-24 00:28:46 +08:00
|
|
|
|
(SCORE): Remove Mei Ligang as maintainer. Add to Past Maintainers
|
2017-01-24 00:20:57 +08:00
|
|
|
|
section.
|
2017-01-24 00:16:55 +08:00
|
|
|
|
|
2017-01-23 22:00:23 +08:00
|
|
|
|
2017-01-23 Bernd Schmidt <bschmidt@redhat.com>
|
|
|
|
|
|
|
|
|
|
* MAINTAINERS (BFIN): Remove myself as Blackfin maintainer.
|
|
|
|
|
|
2016-12-28 21:22:44 +08:00
|
|
|
|
2017-01-20 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
|
|
|
|
|
|
* objdump.c (dump_section_header): Extract max section name length
|
|
|
|
|
from data parameter, use this when formatting output.
|
|
|
|
|
(find_longest_section_name): New function.
|
|
|
|
|
(dump_headers): Calculate longest section name when in wide mode,
|
|
|
|
|
reformat to unify printing of header line.
|
|
|
|
|
|
2017-01-18 21:38:27 +08:00
|
|
|
|
2017-01-18 Bernhard Rosenkranzer <bero@lindev.ch>
|
|
|
|
|
|
|
|
|
|
PR 21059
|
|
|
|
|
* arlex.l: Support processing with flex 2.6.3.
|
|
|
|
|
* deflex.l: Likewise.
|
|
|
|
|
|
2017-01-18 19:40:06 +08:00
|
|
|
|
2017-01-17 Dmitry Timoshkov <dmitry@baikal.ru>
|
|
|
|
|
|
|
|
|
|
* resbin.c: Optional dialog control data immediately follows
|
|
|
|
|
the control description without alignment.
|
|
|
|
|
* testsuite/binutils-all/windres/controldata.rc: New test.
|
|
|
|
|
source.
|
|
|
|
|
* testsuite/binutils-all/windres/controldata.rsd: New test.
|
|
|
|
|
|
2017-01-13 00:56:54 +08:00
|
|
|
|
2017-01-12 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR binutils/20876
|
|
|
|
|
* NEWS: Mention the new feature.
|
|
|
|
|
* testsuite/binutils-all/objdump.exp (test_build_id_debuglink):
|
|
|
|
|
New proc to test the location of separate debug info files using
|
|
|
|
|
the build-id method.
|
|
|
|
|
|
2017-01-10 19:45:12 +08:00
|
|
|
|
2017-01-10 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
PR 21034
|
|
|
|
|
* stabs.c (parse_stab_members): Fix thinko checking for g++
|
|
|
|
|
version 1 stabs information.
|
|
|
|
|
|
2017-01-10 00:49:48 +08:00
|
|
|
|
2017-01-09 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* objdump.c (display_file): Add new parameter 'last_file'. If
|
|
|
|
|
last_file is true, do not call bfd_close at the end of the
|
|
|
|
|
function.
|
|
|
|
|
(main): Set the value of the last_file parameter when calling
|
|
|
|
|
display_file.
|
|
|
|
|
|
2017-01-09 09:38:00 +08:00
|
|
|
|
2017-01-09 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
* readelf.c (process_section_headers): Correct .rel.dyn/.rela.dyn
|
|
|
|
|
comment.
|
|
|
|
|
|
2017-01-06 20:24:54 +08:00
|
|
|
|
2017-01-06 Nick Clifton <nickc@redhat.com>
|
|
|
|
|
|
|
|
|
|
* MAINTAINERS: Move Paul Brook to the Past Maintainers section.
|
|
|
|
|
|
2017-01-05 00:05:22 +08:00
|
|
|
|
2017-01-04 Dilan Palauzov <dilyan.palauzov@aegee.org>
|
|
|
|
|
|
|
|
|
|
PR 20958
|
|
|
|
|
* syslex.l (option): Add noyywrap
|
|
|
|
|
(yywrap): Delete.
|
|
|
|
|
|
2017-01-02 11:36:43 +08:00
|
|
|
|
2017-01-02 Alan Modra <amodra@gmail.com>
|
|
|
|
|
|
|
|
|
|
Update year range in copyright notice of all files.
|
|
|
|
|
|
2017-01-02 11:25:05 +08:00
|
|
|
|
For older changes see ChangeLog-2016
|
2016-01-01 18:44:31 +08:00
|
|
|
|
|
2017-01-02 11:25:05 +08:00
|
|
|
|
Copyright (C) 2017 Free Software Foundation, Inc.
|
2016-01-01 18:44:31 +08:00
|
|
|
|
|
|
|
|
|
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:
|
|
|
|
|
mode: change-log
|
|
|
|
|
left-margin: 8
|
|
|
|
|
fill-column: 74
|
|
|
|
|
version-control: never
|
|
|
|
|
End:
|