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 | |
parent | 9f757bf7fcb8834ead780e0c4a76d6029b1402c2 (diff) | |
download | binutils-6f156d7a4ad1c245b357dc50f63f3564d397839e.zip binutils-6f156d7a4ad1c245b357dc50f63f3564d397839e.tar.gz binutils-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')
-rw-r--r-- | binutils/testsuite/binutils-all/mips/mips-note-2r-n32.d | 6 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/mips/mips-note-2r-n64.d | 10 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/mips/mips-note-2r.d | 6 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/note-2-32.d | 16 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/note-2-32.s | 18 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/note-2-64.d | 16 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/note-2-64.s | 15 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/note-3-32.d | 16 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/note-3-32.s | 1 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/note-3-64.d | 16 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/note-3-64.s | 1 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/note-4-32.d | 19 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/note-4-32.s | 74 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/note-4-64.d | 19 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/note-4-64.s | 78 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/objcopy.exp | 2 |
16 files changed, 250 insertions, 63 deletions
diff --git a/binutils/testsuite/binutils-all/mips/mips-note-2r-n32.d b/binutils/testsuite/binutils-all/mips/mips-note-2r-n32.d index caf9972..e76466e 100644 --- a/binutils/testsuite/binutils-all/mips/mips-note-2r-n32.d +++ b/binutils/testsuite/binutils-all/mips/mips-note-2r-n32.d @@ -5,7 +5,5 @@ #as: -n32 -mips3 #source: ../note-2-32.s -Relocation section '\.rela\.gnu\.build\.attributes' at offset .* contains 2 entries: - Offset Info Type Sym\.Value Sym\. Name \+ Addend -00000010 ......02 R_MIPS_32 00000100 note1\.s \+ 0 -0000006c ......02 R_MIPS_32 00000104 note2\.s \+ 0 +There are no relocations in this file. +#... diff --git a/binutils/testsuite/binutils-all/mips/mips-note-2r-n64.d b/binutils/testsuite/binutils-all/mips/mips-note-2r-n64.d index 0fbcc39..033dd9b 100644 --- a/binutils/testsuite/binutils-all/mips/mips-note-2r-n64.d +++ b/binutils/testsuite/binutils-all/mips/mips-note-2r-n64.d @@ -5,11 +5,5 @@ #as: -64 -mips3 #source: ../note-2-64.s -Relocation section '\.rela\.gnu\.build\.attributes' at offset .* contains 2 entries: - Offset Info Type Sym\. Value Sym\. Name \+ Addend -000000000010 ....00000012 R_MIPS_64 0000000000000100 note1\.s \+ 0 - Type2: R_MIPS_NONE - Type3: R_MIPS_NONE -000000000070 ....00000012 R_MIPS_64 0000000000000104 note2\.s \+ 0 - Type2: R_MIPS_NONE - Type3: R_MIPS_NONE +There are no relocations in this file. +#... diff --git a/binutils/testsuite/binutils-all/mips/mips-note-2r.d b/binutils/testsuite/binutils-all/mips/mips-note-2r.d index c025727..c130528 100644 --- a/binutils/testsuite/binutils-all/mips/mips-note-2r.d +++ b/binutils/testsuite/binutils-all/mips/mips-note-2r.d @@ -5,7 +5,5 @@ #as: -32 #source: ../note-2-32.s -Relocation section '\.rel\.gnu\.build\.attributes' at offset .* contains 2 entries: - Offset Info Type Sym\.Value Sym\. Name -00000010 ......02 R_MIPS_32 00000100 note1\.s -0000006c ......02 R_MIPS_32 00000104 note2\.s +There are no relocations in this file. +#... diff --git a/binutils/testsuite/binutils-all/note-2-32.d b/binutils/testsuite/binutils-all/note-2-32.d index 8deb7f6..a684032 100644 --- a/binutils/testsuite/binutils-all/note-2-32.d +++ b/binutils/testsuite/binutils-all/note-2-32.d @@ -6,12 +6,12 @@ #... Owner Data size Description -[ ]+\$<version>1[ ]+0x00000004[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 \(file: note1.s\) -[ ]+\$<tool>gcc 7.0.1[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+\+<stack prot>true[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+\*<PIC>static[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+\*<ABI>0x0[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+\$<version>1[ ]+0x00000004[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x10. \(file: note2.s\) -[ ]+!<stack prot>false[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x10. -[ ]+\*<PIC>pic[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_FUNC[ ]+Applies to func at 0x10. \(func: func1\) +[ ]+\$<version>1[ ]+0x00000004[ ]+OPEN[ ]+Applies to region from 0x100 \(note1.s\) +[ ]+\$<tool>gcc 7.0.1[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 +[ ]+\+<stack prot>true[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 +[ ]+\*<PIC>static[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 +[ ]+\*<ABI>0x0[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 +[ ]+\$<version>1[ ]+0x00000004[ ]+OPEN[ ]+Applies to region from 0x104 \(note2.s\) +[ ]+!<stack prot>false[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x104 +[ ]+\*<PIC>pic[ ]+0x00000004[ ]+func[ ]+Applies to region from 0x104 \(func1\) #... diff --git a/binutils/testsuite/binutils-all/note-2-32.s b/binutils/testsuite/binutils-all/note-2-32.s index 9aed3df..7b025ae 100644 --- a/binutils/testsuite/binutils-all/note-2-32.s +++ b/binutils/testsuite/binutils-all/note-2-32.s @@ -2,7 +2,7 @@ .org 0x100 .global note1.s note1.s: - .word 0 + .dc.l 0 .pushsection .gnu.build.attributes, "0x100000", %note .balign 4 @@ -10,7 +10,7 @@ note1.s: .dc.l 4 .dc.l 0x100 .asciz "$1" - .dc.l note1.s + .dc.l 0x100 .dc.l 12 .dc.l 0 @@ -39,14 +39,14 @@ note1.s: note2.s: .type func1, STT_FUNC func1: - .word 0x100 + .dc.l 0x100 .pushsection .gnu.build.attributes, "0x100000", %note .dc.l 4 .dc.l 4 .dc.l 0x100 .asciz "$1" - .dc.l note2.s + .dc.l 0x104 .dc.l 12 .dc.l 0 @@ -60,26 +60,28 @@ func1: .dc.b 0 .dc.l 4 - .dc.l 0 + .dc.l 4 .dc.l 0x101 .dc.b 0x2a, 0x7, 1, 0 - + .dc.l 0x104 + .dc.l 4 .dc.l 0 .dc.l 0x100 .dc.b 0x2a, 0x6, 0, 0 .popsection + .global note3.s note3.s: - .word 0x100 + .dc.l 0x100 .pushsection .gnu.build.attributes, "0x100000", %note .dc.l 4 .dc.l 4 .dc.l 0x100 .asciz "$1" - .dc.l note3.s + .dc.l 0x108 .dc.l 12 .dc.l 0 diff --git a/binutils/testsuite/binutils-all/note-2-64.d b/binutils/testsuite/binutils-all/note-2-64.d index f9be897..17917d5 100644 --- a/binutils/testsuite/binutils-all/note-2-64.d +++ b/binutils/testsuite/binutils-all/note-2-64.d @@ -10,12 +10,12 @@ #... Owner Data size Description -[ ]+\$<version>1[ ]+0x00000008[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 \(file: note1.s\) -[ ]+\$<tool>gcc 7.0.1[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+\+<stack prot>true[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+\*<PIC>static[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+\*<ABI>0x0[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+\$<version>1[ ]+0x00000008[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x10. \(file: note2.s\) -[ ]+!<stack prot>false[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x10. -[ ]+\*<PIC>pic[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_FUNC[ ]+Applies to func at 0x10. \(func: func1\) +[ ]+\$<version>1[ ]+0x00000008[ ]+OPEN[ ]+Applies to region from 0x100 \(note1.s\) +[ ]+\$<tool>gcc 7.0.1[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 +[ ]+\+<stack prot>true[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 +[ ]+\*<PIC>static[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 +[ ]+\*<ABI>0x0[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 +[ ]+\$<version>1[ ]+0x00000008[ ]+OPEN[ ]+Applies to region from 0x104 \(note2.s\) +[ ]+!<stack prot>false[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x104 +[ ]+\*<PIC>pic[ ]+0x00000008[ ]+func[ ]+Applies to region from 0x104 \(func1\) #... diff --git a/binutils/testsuite/binutils-all/note-2-64.s b/binutils/testsuite/binutils-all/note-2-64.s index 885e947..02b84e4 100644 --- a/binutils/testsuite/binutils-all/note-2-64.s +++ b/binutils/testsuite/binutils-all/note-2-64.s @@ -2,7 +2,7 @@ .org 0x100 .global note1.s note1.s: - .word 0 + .dc.l 0 .pushsection .gnu.build.attributes, "0x100000", %note .balign 4 @@ -10,7 +10,7 @@ note1.s: .dc.l 8 .dc.l 0x100 .asciz "$1" - .8byte note1.s + .8byte 0x100 .dc.l 12 .dc.l 0 @@ -40,14 +40,14 @@ note2.s: .global func1 .type func1, STT_FUNC func1: - .word 0x100 + .dc.l 0x100 .pushsection .gnu.build.attributes, "0x100000", %note .dc.l 4 .dc.l 8 .dc.l 0x100 .asciz "$1" - .8byte note2.s + .8byte 0x104 .dc.l 12 .dc.l 0 @@ -61,9 +61,10 @@ func1: .dc.b 0 .dc.l 4 - .dc.l 0 + .dc.l 8 .dc.l 0x101 .dc.b 0x2a, 0x7, 1, 0 + .8byte 0x104 .dc.l 4 .dc.l 0 @@ -74,14 +75,14 @@ func1: .global note3.s note3.s: - .word 0x100 + .dc.l 0x100 .pushsection .gnu.build.attributes, "0x100000", %note .dc.l 4 .dc.l 8 .dc.l 0x100 .asciz "$1" - .8byte note3.s + .8byte 0x108 .dc.l 12 .dc.l 0 diff --git a/binutils/testsuite/binutils-all/note-3-32.d b/binutils/testsuite/binutils-all/note-3-32.d index fa571b0..e35e9cc 100644 --- a/binutils/testsuite/binutils-all/note-3-32.d +++ b/binutils/testsuite/binutils-all/note-3-32.d @@ -7,12 +7,12 @@ #... Displaying notes found in: .gnu.build.attributes [ ]+Owner[ ]+Data size[ ]+Description -[ ]+GA\$<version>2p1[ ]+0x0000000.[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 \(file: note_1.s\) -[ ]+GA\$<tool>gcc 6.3.1 20161221[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+GA\*GOW:0x700[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+GA\*<stack prot>off[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+GA\*FORTIFY:0xff[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+GA\*<PIC>PIC[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+GA\!<short enum>false[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+GA\*<ABI>0x[0-9a-f]+[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 +[ ]+GA\$<version>2p1[ ]+0x0000000.[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 \(note_1.s\) +[ ]+GA\$<tool>gcc 6.3.1 20161221[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 +[ ]+GA\*GOW:0x700[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 +[ ]+GA\*<stack prot>off[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 +[ ]+GA\*FORTIFY:0xff[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 +[ ]+GA\*<PIC>PIC[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 +[ ]+GA\!<short enum>false[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 +[ ]+GA\*<ABI>0x[0-9a-f]+[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 #... diff --git a/binutils/testsuite/binutils-all/note-3-32.s b/binutils/testsuite/binutils-all/note-3-32.s index 4dbbebe..e2e06f9 100644 --- a/binutils/testsuite/binutils-all/note-3-32.s +++ b/binutils/testsuite/binutils-all/note-3-32.s @@ -1,6 +1,7 @@ .text .org 0x100 .global note_1.s + .size note_1.s, 0x22 note_1.s: .word 0 diff --git a/binutils/testsuite/binutils-all/note-3-64.d b/binutils/testsuite/binutils-all/note-3-64.d index f048e8b..9899ea1 100644 --- a/binutils/testsuite/binutils-all/note-3-64.d +++ b/binutils/testsuite/binutils-all/note-3-64.d @@ -7,12 +7,12 @@ #... Displaying notes found in: .gnu.build.attributes [ ]+Owner[ ]+Data size[ ]+Description -[ ]+GA\$<version>2p1[ ]+0x0000000.[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 \(file: note_1.s\) -[ ]+GA\$<tool>gcc 6.3.1 20161221[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+GA\*GOW:0x700[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+GA\*<stack prot>off[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+GA\*FORTIFY:0xff[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+GA\*<PIC>PIC[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+GA\!<short enum>false[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 -[ ]+GA\*<ABI>0x[0-9a-f]+[ ]+0x00000000[ ]+NT_GNU_BUILD_ATTRIBUTE_OPEN[ ]+Applies from offset 0x100 +[ ]+GA\$<version>2p1[ ]+0x0000000.[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 \(note_1.s\) +[ ]+GA\$<tool>gcc 6.3.1 20161221[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 +[ ]+GA\*GOW:0x700[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 +[ ]+GA\*<stack prot>off[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 +[ ]+GA\*FORTIFY:0xff[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 +[ ]+GA\*<PIC>PIC[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 +[ ]+GA\!<short enum>false[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 +[ ]+GA\*<ABI>0x[0-9a-f]+[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x122 #... diff --git a/binutils/testsuite/binutils-all/note-3-64.s b/binutils/testsuite/binutils-all/note-3-64.s index 42f3e48..e7d27d2 100644 --- a/binutils/testsuite/binutils-all/note-3-64.s +++ b/binutils/testsuite/binutils-all/note-3-64.s @@ -1,6 +1,7 @@ .text .org 0x100 .global note_1.s + .size note_1.s, 0x22 note_1.s: .word 0 diff --git a/binutils/testsuite/binutils-all/note-4-32.d b/binutils/testsuite/binutils-all/note-4-32.d new file mode 100644 index 0000000..567af90 --- /dev/null +++ b/binutils/testsuite/binutils-all/note-4-32.d @@ -0,0 +1,19 @@ +#PROG: objcopy +#readelf: --notes --wide +#objcopy: --merge-notes +#name: v3 gnu build attribute notes (32-bit) +#source: note-4-32.s + +#... +Displaying notes found in: .gnu.build.attributes +[ ]+Owner[ ]+Data size[ ]+Description +[ ]+GA\$<version>3p3[ ]+0x00000008[ ]+OPEN[ ]+Applies to region from 0x100 to 0x110 \(note_4.s\) +[ ]+GA\$<tool>gcc 7.2.1 20170915[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x110 +[ ]+GA\*GOW:0x700[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x110 +[ ]+GA\*<stack prot>off[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x110 +[ ]+GA\*FORTIFY:0xff[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x110 +[ ]+GA\*<PIC>PIC[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x110 +[ ]+GA\!<short enum>false[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x110 +[ ]+GA\*<ABI>0x[0-9a-f]+[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x110 +[ ]+GA\*<stack prot>strong[ ]+0x00000008[ ]+func[ ]+Applies to region from 0x108 to 0x10c.* +#... diff --git a/binutils/testsuite/binutils-all/note-4-32.s b/binutils/testsuite/binutils-all/note-4-32.s new file mode 100644 index 0000000..09c5652 --- /dev/null +++ b/binutils/testsuite/binutils-all/note-4-32.s @@ -0,0 +1,74 @@ + .text + .org 0x100 +note_4.s: + .dc.l 0 + .dc.l 0 + + .type bar, STT_FUNC +bar: + .dc.l 0 +bar_end: + .dc.l 0 +note_4.s_end: + + .pushsection .gnu.build.attributes, "", %note + .balign 4 + + .dc.l 8 + .dc.l 8 + .dc.l 0x100 + .asciz "GA$3p3" + .dc.l note_4.s + .dc.l note_4.s_end + + .dc.l 23 + .dc.l 0 + .dc.l 0x100 + .asciz "GA$gcc 7.2.1 20170915" + .dc.b 0 + + .dc.l 10 + .dc.l 0 + .dc.l 0x100 + .dc.b 0x47, 0x41, 0x2a, 0x47, 0x4f, 0x57, 0, 0, 0x7, 0 + .dc.b 0, 0 + + .dc.l 6 + .dc.l 0 + .dc.l 0x100 + .dc.b 0x47, 0x41, 0x2a, 0x2, 0, 0 + .dc.b 0, 0 + + .dc.l 13 + .dc.l 0 + .dc.l 0x100 + .dc.b 0x47, 0x41, 0x2a, 0x46, 0x4f, 0x52, 0x54, 0x49, 0x46, 0x59, 0, 0xff, 0 + .dc.b 0, 0, 0 + + .dc.l 6 + .dc.l 0 + .dc.l 0x100 + .dc.b 0x47, 0x41, 0x2a, 0x7, 0x2, 0 + .dc.b 0, 0 + + .dc.l 5 + .dc.l 0 + .dc.l 0x100 + .dc.b 0x47, 0x41, 0x21, 0x8, 0 + .dc.b 0, 0, 0 + + .dc.l 13 + .dc.l 0 + .dc.l 0x100 + .dc.b 0x47, 0x41, 0x2a, 0x6, 0xf2, 0x3, 0x38, 0xee, 0xce, 0xfa, 0x5e, 0x3c, 0 + .dc.b 0, 0, 0 + + .dc.l 6 + .dc.l 8 + .dc.l 0x101 + .dc.b 0x47, 0x41, 0x2a, 0x2, 0x3, 0 + .dc.b 0, 0 + .dc.l bar + .dc.l bar_end + + .popsection diff --git a/binutils/testsuite/binutils-all/note-4-64.d b/binutils/testsuite/binutils-all/note-4-64.d new file mode 100644 index 0000000..f81c9c4 --- /dev/null +++ b/binutils/testsuite/binutils-all/note-4-64.d @@ -0,0 +1,19 @@ +#PROG: objcopy +#readelf: --notes --wide +#objcopy: --merge-notes +#name: v3 gnu build attribute notes (64-bit) +#source: note-4-64.s + +#... +Displaying notes found in: .gnu.build.attributes +[ ]+Owner[ ]+Data size[ ]+Description +[ ]+GA\$<version>3p3[ ]+0x00000010[ ]+OPEN[ ]+Applies to region from 0x100 to 0x120 \(note_4.s\) +[ ]+GA\$<tool>gcc 7.2.1 20170915[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x120 +[ ]+GA\*GOW:0x700[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x120 +[ ]+GA\*<stack prot>off[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x120 +[ ]+GA\*FORTIFY:0xff[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x120 +[ ]+GA\*<PIC>PIC[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x120 +[ ]+GA\!<short enum>false[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x120 +[ ]+GA\*<ABI>0x[0-9a-f]+[ ]+0x00000000[ ]+OPEN[ ]+Applies to region from 0x100 to 0x120 +[ ]+GA\*<stack prot>strong[ ]+0x00000010[ ]+func[ ]+Applies to region from 0x110 to 0x11c.* +#... diff --git a/binutils/testsuite/binutils-all/note-4-64.s b/binutils/testsuite/binutils-all/note-4-64.s new file mode 100644 index 0000000..4f53298 --- /dev/null +++ b/binutils/testsuite/binutils-all/note-4-64.s @@ -0,0 +1,78 @@ + .text + .org 0x100 +note_4.s: + .dc.l 0 + .dc.l 0 + .dc.l 0 + .dc.l 0 + + .type bar, @function +bar: + .dc.l 0 + .dc.l 0 + .dc.l 0 +bar_end: + .dc.l 0 +note_4.s_end: + + .pushsection .gnu.build.attributes, "", %note + .balign 4 + + .dc.l 8 + .dc.l 16 + .dc.l 0x100 + .asciz "GA$3p3" + .8byte note_4.s + .8byte note_4.s_end + + .dc.l 23 + .dc.l 0 + .dc.l 0x100 + .asciz "GA$gcc 7.2.1 20170915" + .dc.b 0 + + .dc.l 10 + .dc.l 0 + .dc.l 0x100 + .dc.b 0x47, 0x41, 0x2a, 0x47, 0x4f, 0x57, 0, 0, 0x7, 0 + .dc.b 0, 0 + + .dc.l 6 + .dc.l 0 + .dc.l 0x100 + .dc.b 0x47, 0x41, 0x2a, 0x2, 0, 0 + .dc.b 0, 0 + + .dc.l 13 + .dc.l 0 + .dc.l 0x100 + .dc.b 0x47, 0x41, 0x2a, 0x46, 0x4f, 0x52, 0x54, 0x49, 0x46, 0x59, 0, 0xff, 0 + .dc.b 0, 0, 0 + + .dc.l 6 + .dc.l 0 + .dc.l 0x100 + .dc.b 0x47, 0x41, 0x2a, 0x7, 0x2, 0 + .dc.b 0, 0 + + .dc.l 5 + .dc.l 0 + .dc.l 0x100 + .dc.b 0x47, 0x41, 0x21, 0x8, 0 + .dc.b 0, 0, 0 + + .dc.l 13 + .dc.l 0 + .dc.l 0x100 + .dc.b 0x47, 0x41, 0x2a, 0x6, 0xf2, 0x3, 0x38, 0xee, 0xce, 0xfa, 0x5e, 0x3c, 0 + .dc.b 0, 0, 0 + + .dc.l 6 + .dc.l 16 + .dc.l 0x101 + .dc.b 0x47, 0x41, 0x2a, 0x2, 0x3, 0 + .dc.b 0, 0 + .8byte bar + .8byte bar_end + + .popsection 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" } } |