diff options
author | Nick Clifton <nickc@redhat.com> | 2018-01-03 10:28:33 +0000 |
---|---|---|
committer | Nick Clifton <nickc@redhat.com> | 2018-01-03 10:30:07 +0000 |
commit | 6f156d7a4ad1c245b357dc50f63f3564d397839e (patch) | |
tree | a247aad883eb6ba6eeb0c9715c218527fc25c869 /binutils/testsuite/binutils-all/objcopy.exp | |
parent | 9f757bf7fcb8834ead780e0c4a76d6029b1402c2 (diff) | |
download | gdb-6f156d7a4ad1c245b357dc50f63f3564d397839e.zip gdb-6f156d7a4ad1c245b357dc50f63f3564d397839e.tar.gz gdb-6f156d7a4ad1c245b357dc50f63f3564d397839e.tar.bz2 |
Add support for v3 binary annotation notes.
I am checking in the attached patch which updates the binutils
support for version 3 binary annotation notes. (Version 3 adds
an end address to the ranges covered by the notes, so that it
is possible to detect gaps in the coverage).
This patch also stops the note merging feature of objcopy from
executing if the notes have relocations against them. This makes the
code simpler, and prevents the problems with architectures which have
unusual relocation management issues.
* objcopy.c (objcopy_internal_note): New structure.
(gap_exists): New function.
(is_open_note): New function.
(is_func_note): New function.
(is_64bit): New function.
(merge_gnu_build_notes): Handle v3 notes. Do not merge
if there are relocations against the notes.
* readelf.c (get_note_type): Use short names for build attribute
notes.
(print_symbol_for_build_attribute): Rename to
get_symbol_for_build_attribute. Returns the found symbol rather
than printing it.
(print_gnu_build_attribute_description): Maintain address ranges
for function notes as well as global notes. Handle v3 notes.
(print_gnu_build_attribute_name): Use more space for printing the
name in wide mode.
* testsuite/binutils-all/note-2-32.s: Use .dc.l instead of .word.
Eliminate symbol references in order to remove the need for
relocations.
* testsuite/binutils-all/note-2-64.s: Likewise.
* testsuite/binutils-all/note-3-32.s: Add a size to the note_1
symbol.
* testsuite/binutils-all/note-3-64.s: Likewise.
* testsuite/binutils-all/mips/mips-note-2r-n32.d: Update expected
output.
* testsuite/binutils-all/mips/mips-note-2r-n64.d: Likewise.
* testsuite/binutils-all/mips/mips-note-2r.d: Likewise.
* testsuite/binutils-all/note-2-32.d: Likewise.
* testsuite/binutils-all/note-2-64.d: Likewise.
* testsuite/binutils-all/note-3-32.d: Likewise.
* testsuite/binutils-all/note-3-64.d: Likewise.
* testsuite/binutils-all/note-4-64.s: New test. Checks v3 notes.
* testsuite/binutils-all/note-4-32.s: New test.
* testsuite/binutils-all/note-4-64.d: New test result file.
* testsuite/binutils-all/note-4-32.d: New test result file.
Diffstat (limited to 'binutils/testsuite/binutils-all/objcopy.exp')
-rw-r--r-- | binutils/testsuite/binutils-all/objcopy.exp | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/binutils/testsuite/binutils-all/objcopy.exp b/binutils/testsuite/binutils-all/objcopy.exp index 8308adc..377f88c 100644 --- a/binutils/testsuite/binutils-all/objcopy.exp +++ b/binutils/testsuite/binutils-all/objcopy.exp @@ -1056,9 +1056,11 @@ if [is_elf_format] { if [is_elf64 tmpdir/bintest.o] { run_dump_test "note-2-64" run_dump_test "note-3-64" + run_dump_test "note-4-64" } else { run_dump_test "note-2-32" run_dump_test "note-3-32" + run_dump_test "note-4-32" } } |