summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/ChangeLog71
-rw-r--r--tests/Makefile.am11
-rw-r--r--tests/backtrace-dwarf.c38
-rwxr-xr-xtests/run-annobingroup.sh33
-rwxr-xr-xtests/run-readelf-compressed.sh34
-rwxr-xr-xtests/run-readelf-macro.sh4
-rwxr-xr-xtests/run-readelf-macros.sh435
-rwxr-xr-xtests/run-readelf-n.sh127
-rwxr-xr-xtests/run-readelf-zdebug-rel.sh106
-rwxr-xr-xtests/run-readelf-zdebug.sh2
-rwxr-xr-xtests/run-strip-reloc.sh21
-rw-r--r--tests/testfile-annobingroup-x86_64.o.bz2bin0 -> 1437 bytes
-rw-r--r--tests/testfile-bpf-dis1.expect.bz2bin1467 -> 1516 bytes
-rw-r--r--tests/testfile-debug-rel-ppc64-g.o.bz2bin0 -> 1400 bytes
-rw-r--r--tests/testfile-debug-rel-ppc64-z.o.bz2bin0 -> 1420 bytes
-rw-r--r--tests/testfile-debug-rel-ppc64.o.bz2bin0 -> 1103 bytes
-rwxr-xr-xtests/testfile-gnu-property-note.bz2bin0 -> 1146 bytes
-rw-r--r--tests/testfile-gnu-property-note.o.bz2bin0 -> 482 bytes
-rw-r--r--tests/testfile-macros-object.o.bz2bin0 -> 5718 bytes
19 files changed, 864 insertions, 18 deletions
diff --git a/tests/ChangeLog b/tests/ChangeLog
index 4e8b8144..514229b7 100644
--- a/tests/ChangeLog
+++ b/tests/ChangeLog
@@ -1,3 +1,74 @@
+2018-11-09 Mark Wielaard <[email protected]>
+
+ * run-strip-reloc.sh: Also test testfile-debug-rel-ppc64-z.o
+ testfile-debug-rel-ppc64-g.o.
+
+2018-11-12 Mark Wielaard <[email protected]>
+
+ * run-readelf-n.sh: Add testfile-annobingroup.o test.
+
+2018-11-11 Mark Wielaard <[email protected]>
+
+ * run-readelf-n.sh: Fix NT_GNU_ABI_TAG type. Add testfile11 test
+ for NT_VERSION.
+
+2018-11-04 Mark Wielaard <[email protected]>
+
+ * testfile-bpf-reloc.expect.bz2: Update with new expected jump
+ variants.
+
+2018-10-20 Mark Wielaard <[email protected]>
+
+ * run-readelf-compressed.sh: New test.
+ * Makefile.am (TESTS): Add run-readelf-compressed.sh.
+ (EXTRA_DIST): Likewise.
+
+2018-11-09 Mark Wielaard <[email protected]>
+
+ * testfile-debug-rel-ppc64-g.o.bz2: New test file.
+ * testfile-debug-rel-ppc64-z.o.bz2: Likewise.
+ * testfile-debug-rel-ppc64.o.bz2: Likewise.
+ * Makefile.am (EXTRA_DIST): Add testfile-debug-rel-ppc64-g.o.bz2,
+ testfile-debug-rel-ppc64-z.o.bz2 and testfile-debug-rel-ppc64.o.bz2.
+ * run-strip-reloc.sh: Also test on testfile-debug-rel-ppc64.o.
+ * run-readelf-zdebug-rel.sh: Also test on testfile-debug-rel-ppc64*.o.
+
+2018-10-26 Mark Wielaard <[email protected]>
+
+ * run-strip-reloc.sh: Add a test for --reloc-debug-sections-only.
+
+2018-10-18 Mark Wielaard <[email protected]>
+
+ * run-readelf-n.sh: New test.
+ * testfile-gnu-property-note.bz2: New testfile.
+ * testfile-gnu-property-note.o.bz2: Likewise.
+ * Makefile.am (TESTS): Add run-readelf-n.sh.
+ (EXTRA_DIST): Likewise and testfile-gnu-property-note.bz2,
+ testfile-gnu-property-note.o.bz2.
+
+2018-10-12 Mark Wielaard <[email protected]>
+
+ * run-readelf-zdebug.sh: Adjust flags output.
+ * run-readelf-macro.sh: Likewise.
+ * run-readelf-macros.sh: New test.
+ * testfile-macros-object.o.bz2: New test file.
+ * Makefile.am (TESTS): Add run-readelf-macros.sh.
+ (EXTRA_DIST): Add run-readelf-macros.sh and
+ testfile-macros-object.o.bz2.
+
+2018-09-12 Mark Wielaard <[email protected]>
+
+ * run-annobingroup.sh: Add x86_64 ET_REL testcase.
+ * testfile-annobingroup-x86_64.o.bz2: New test file.
+ * Makefile.am (EXTRA_DIST): Add testfile-annobingroup-x86_64.o.bz2.
+
+2018-09-18 Mark Wielaard <[email protected]>
+
+ * backtrace-dwarf.c (thread_callback): Only error when
+ dwfl_thread_getframes returns an error.
+ (main): Don't call abort or assert but print an error when
+ something unexpected happens.
+
2018-09-13 Mark Wielaard <[email protected]>
* run-strip-test-many.sh: New test.
diff --git a/tests/Makefile.am b/tests/Makefile.am
index b060587b..6258685b 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -99,12 +99,14 @@ TESTS = run-arextract.sh run-arsymtest.sh run-ar.sh newfile test-nlist \
run-find-prologues.sh run-allregs.sh run-addrcfi.sh \
run-dwarfcfi.sh \
run-nm-self.sh run-readelf-self.sh run-readelf-info-plus.sh \
+ run-readelf-compressed.sh \
run-readelf-const-values.sh \
run-varlocs-self.sh run-exprlocs-self.sh \
run-readelf-test1.sh run-readelf-test2.sh run-readelf-test3.sh \
run-readelf-test4.sh run-readelf-twofiles.sh \
run-readelf-macro.sh run-readelf-loc.sh run-readelf-ranges.sh \
run-readelf-aranges.sh run-readelf-line.sh run-readelf-z.sh \
+ run-readelf-n.sh \
run-native-test.sh run-bug1-test.sh \
run-debuglink.sh run-debugaltlink.sh run-buildid.sh \
dwfl-bug-addr-overflow run-addrname-test.sh \
@@ -198,6 +200,7 @@ EXTRA_DIST = run-arextract.sh run-arsymtest.sh run-ar.sh \
run-strip-nothing.sh run-strip-remove-keep.sh run-strip-g.sh \
run-annobingroup.sh testfile-annobingroup.o.bz2 \
testfile-annobingroup-i386.o.bz2 \
+ testfile-annobingroup-x86_64.o.bz2 \
run-strip-strmerge.sh run-strip-nobitsalign.sh \
testfile-nobitsalign.bz2 testfile-nobitsalign.strip.bz2 \
run-strip-reloc.sh hello_i386.ko.bz2 hello_x86_64.ko.bz2 \
@@ -213,6 +216,7 @@ EXTRA_DIST = run-arextract.sh run-arsymtest.sh run-ar.sh \
run-ranlib-test3.sh run-ranlib-test4.sh \
run-addrscopes.sh run-strings-test.sh run-funcscopes.sh \
run-nm-self.sh run-readelf-self.sh run-readelf-info-plus.sh \
+ run-readelf-compressed.sh \
run-readelf-const-values.sh testfile-const-values.debug.bz2 \
run-addrcfi.sh run-dwarfcfi.sh \
testfile11-debugframe.bz2 testfile12-debugframe.bz2 \
@@ -270,6 +274,8 @@ EXTRA_DIST = run-arextract.sh run-arsymtest.sh run-ar.sh \
testfile-dwzstr.bz2 testfile-dwzstr.multi.bz2 \
run-readelf-addr.sh run-readelf-str.sh \
run-readelf-types.sh \
+ run-readelf-n.sh \
+ testfile-gnu-property-note.bz2 testfile-gnu-property-note.o.bz2 \
run-allfcts-multi.sh \
test-offset-loop.bz2 test-offset-loop.alt.bz2 \
run-prelink-addr-test.sh \
@@ -407,7 +413,10 @@ EXTRA_DIST = run-arextract.sh run-arsymtest.sh run-ar.sh \
testfile-riscv64.bz2 testfile-riscv64-s.bz2 \
testfile-riscv64-core.bz2 \
run-copyadd-sections.sh run-copymany-sections.sh \
- run-typeiter-many.sh run-strip-test-many.sh
+ run-typeiter-many.sh run-strip-test-many.sh \
+ testfile-debug-rel-ppc64-g.o.bz2 \
+ testfile-debug-rel-ppc64-z.o.bz2 \
+ testfile-debug-rel-ppc64.o.bz2
if USE_VALGRIND
valgrind_cmd='valgrind -q --leak-check=full --error-exitcode=1'
diff --git a/tests/backtrace-dwarf.c b/tests/backtrace-dwarf.c
index 35f25ed6..dfbf1856 100644
--- a/tests/backtrace-dwarf.c
+++ b/tests/backtrace-dwarf.c
@@ -1,5 +1,5 @@
/* Test program for unwinding of complicated DWARF expressions.
- Copyright (C) 2013, 2015 Red Hat, Inc.
+ Copyright (C) 2013, 2015, 2018 Red Hat, Inc.
This file is part of elfutils.
This file is free software; you can redistribute it and/or modify
@@ -16,7 +16,6 @@
along with this program. If not, see <http://www.gnu.org/licenses/>. */
#include <config.h>
-#include <assert.h>
#include <inttypes.h>
#include <stdio_ext.h>
#include <locale.h>
@@ -117,9 +116,11 @@ frame_callback (Dwfl_Frame *state, void *frame_arg)
static int
thread_callback (Dwfl_Thread *thread, void *thread_arg)
{
- dwfl_thread_getframes (thread, frame_callback, NULL);
+ if (dwfl_thread_getframes (thread, frame_callback, NULL) == -1)
+ error (1, 0, "dwfl_thread_getframes: %s", dwfl_errmsg (-1));
+
/* frame_callback shall exit (0) on success. */
- error (1, 0, "dwfl_thread_getframes: %s", dwfl_errmsg (-1));
+ printf ("dwfl_thread_getframes returned, main not found\n");
return DWARF_CB_ABORT;
}
@@ -141,13 +142,18 @@ main (int argc __attribute__ ((unused)), char **argv)
switch (pid)
{
case -1:
- abort ();
+ perror ("fork failed");
+ exit (-1);
case 0:;
long l = ptrace (PTRACE_TRACEME, 0, NULL, NULL);
- assert (errno == 0);
- assert (l == 0);
+ if (l != 0)
+ {
+ perror ("PTRACE_TRACEME failed");
+ exit (-1);
+ }
cleanup_13_main ();
- abort ();
+ printf ("cleanup_13_main returned, impossible...\n");
+ exit (-1);
default:
break;
}
@@ -155,16 +161,20 @@ main (int argc __attribute__ ((unused)), char **argv)
errno = 0;
int status;
pid_t got = waitpid (pid, &status, 0);
- assert (errno == 0);
- assert (got == pid);
- assert (WIFSTOPPED (status));
- assert (WSTOPSIG (status) == SIGABRT);
+ if (got != pid)
+ error (1, errno, "waitpid returned %d", got);
+ if (!WIFSTOPPED (status))
+ error (1, 0, "unexpected wait status %u", status);
+ if (WSTOPSIG (status) != SIGABRT)
+ error (1, 0, "unexpected signal %u", WSTOPSIG (status));
Dwfl *dwfl = pid_to_dwfl (pid);
- dwfl_getthreads (dwfl, thread_callback, NULL);
+ if (dwfl_getthreads (dwfl, thread_callback, NULL) == -1)
+ error (1, 0, "dwfl_getthreads: %s", dwfl_errmsg (-1));
/* There is an exit (0) call if we find the "main" frame, */
- error (1, 0, "dwfl_getthreads: %s", dwfl_errmsg (-1));
+ printf ("dwfl_getthreads returned, main not found\n");
+ exit (-1);
}
#endif /* ! __linux__ */
diff --git a/tests/run-annobingroup.sh b/tests/run-annobingroup.sh
index 700df321..fd36e4ac 100755
--- a/tests/run-annobingroup.sh
+++ b/tests/run-annobingroup.sh
@@ -120,4 +120,37 @@ EOF
testrun ${abs_top_builddir}/src/elfcmp testfile-annobingroup-i386.o remerged.elf
+# echo "void * foo (void) { return foo; }" > testfile-annobingroup-x86_64.c
+# gcc -g -O2 -fplugin=annobin -c testfile-annobingroup-x86_64.c
+testfiles testfile-annobingroup-x86_64.o
+
+testrun_compare ${abs_top_builddir}/src/readelf -g testfile-annobingroup-x86_64.o << EOF
+
+Section group [ 1] '.group' with signature '.text.hot.group' contains 3 entries:
+ [11] .text.hot
+ [12] .gnu.build.attributes.hot
+ [13] .rela.gnu.build.attributes.hot
+
+Section group [ 2] '.group' with signature '.text.unlikely.group' contains 3 entries:
+ [14] .text.unlikely
+ [15] .gnu.build.attributes.unlikely
+ [16] .rela.gnu.build.attributes.unlikely
+
+Section group [ 3] '.group' with signature '.text.hot..group' contains 1 entry:
+ [26] .text.hot
+
+Section group [ 4] '.group' with signature '.text.unlikely..group' contains 1 entry:
+ [27] .text.unlikely
+EOF
+
+testrun ${abs_top_builddir}/src/strip -o stripped.elf -f debugfile.elf testfile-annobingroup-x86_64.o
+
+# This would/should work, except for the unknown NOTEs.
+# testrun ${abs_top_builddir}/src/elflint --gnu stripped.elf
+# testrun ${abs_top_builddir}/src/elflint --gnu --debug debugfile.elf
+
+testrun ${abs_top_builddir}/src/unstrip -o remerged.elf stripped.elf debugfile.elf
+
+testrun ${abs_top_builddir}/src/elfcmp testfile-annobingroup-x86_64.o remerged.elf
+
exit 0
diff --git a/tests/run-readelf-compressed.sh b/tests/run-readelf-compressed.sh
new file mode 100755
index 00000000..a2a04a2a
--- /dev/null
+++ b/tests/run-readelf-compressed.sh
@@ -0,0 +1,34 @@
+#! /bin/sh
+# Copyright (C) 2018 Red Hat, Inc.
+# This file is part of elfutils.
+#
+# This file is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# elfutils is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+. $srcdir/test-subr.sh
+
+# See run-strip-reloc.sh
+testfiles hello_i386.ko
+
+tempfiles hello_i386.ko.bz2 readelf.out.1 readelf.out.2
+
+testrun ${abs_top_builddir}/src/readelf -a hello_i386.ko > readelf.out.1
+bzip2 hello_i386.ko
+testrun ${abs_top_builddir}/src/readelf -a hello_i386.ko.bz2 > readelf.out.2
+
+diff -u readelf.out.1 readelf.out.2
+if [ $? != 0 ]; then
+ exit 1;
+fi
+
+exit 0
diff --git a/tests/run-readelf-macro.sh b/tests/run-readelf-macro.sh
index 86932033..8b17f7da 100755
--- a/tests/run-readelf-macro.sh
+++ b/tests/run-readelf-macro.sh
@@ -65,7 +65,7 @@ DWARF section [32] '.debug_macro' at offset 0x2480:
Offset: 0x0
Version: 4
- Flag: 0x2
+ Flag: 0x2 (debug_line_offset)
Offset length: 4
.debug_line offset: 0x0
@@ -329,7 +329,7 @@ DWARF section [32] '.debug_macro' at offset 0x2480:
Offset: 0x5bc
Version: 4
- Flag: 0x2
+ Flag: 0x2 (debug_line_offset)
Offset length: 4
.debug_line offset: 0x47
diff --git a/tests/run-readelf-macros.sh b/tests/run-readelf-macros.sh
new file mode 100755
index 00000000..cc311b75
--- /dev/null
+++ b/tests/run-readelf-macros.sh
@@ -0,0 +1,435 @@
+#! /bin/sh
+# Copyright (C) 2018 Red Hat, Inc.
+# This file is part of elfutils.
+#
+# This file is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# elfutils is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+. $srcdir/test-subr.sh
+
+# - testfile-macros-object.c
+#
+# #define SUCCESS 0
+# #define FAILURE 0
+#
+# #include <stdbool.h>
+#
+# bool foo (int input)
+# {
+# return input == SUCCESS ? SUCCESS : FAILURE;
+# }
+
+# gcc -g3 -gdwarf-5 -O2 -c testfile-macros-object.c
+
+testfiles testfile-macros-object.o
+
+testrun_compare ${abs_top_builddir}/src/readelf --debug-dump=macro testfile-macros-object.o <<\EOF
+
+DWARF section [12] '.debug_macro' at offset 0x16f:
+
+ Offset: 0x0
+ Version: 5
+ Flag: 0x2 (debug_line_offset)
+ Offset length: 4
+ .debug_line offset: 0x0
+
+ #include offset 0x0
+ start_file 0, [1] /home/mark/build/elfutils-obj/testfile-macros-object.c
+ start_file 31, [2] /usr/include/stdc-predef.h
+ #include offset 0x0
+ end_file
+ #define SUCCESS 0, line 1 (indirect)
+ #define FAILURE 0, line 2 (indirect)
+ start_file 4, [3] /opt/rh/devtoolset-8/root/usr/lib/gcc/x86_64-redhat-linux/8/include/stdbool.h
+ #include offset 0x0
+ end_file
+ end_file
+
+
+DWARF section [14] '.debug_macro' at offset 0x19e:
+
+ Offset: 0x0
+ Version: 5
+ Flag: 0x0
+ Offset length: 4
+
+ #define __STDC__ 1, line 0 (indirect)
+ #define __STDC_VERSION__ 201710L, line 0 (indirect)
+ #define __STDC_UTF_16__ 1, line 0 (indirect)
+ #define __STDC_UTF_32__ 1, line 0 (indirect)
+ #define __STDC_HOSTED__ 1, line 0 (indirect)
+ #define __GNUC__ 8, line 0 (indirect)
+ #define __GNUC_MINOR__ 2, line 0 (indirect)
+ #define __GNUC_PATCHLEVEL__ 1, line 0 (indirect)
+ #define __VERSION__ "8.2.1 20180905 (Red Hat 8.2.1-3)", line 0 (indirect)
+ #define __GNUC_RH_RELEASE__ 3, line 0 (indirect)
+ #define __ATOMIC_RELAXED 0, line 0 (indirect)
+ #define __ATOMIC_SEQ_CST 5, line 0 (indirect)
+ #define __ATOMIC_ACQUIRE 2, line 0 (indirect)
+ #define __ATOMIC_RELEASE 3, line 0 (indirect)
+ #define __ATOMIC_ACQ_REL 4, line 0 (indirect)
+ #define __ATOMIC_CONSUME 1, line 0 (indirect)
+ #define __OPTIMIZE__ 1, line 0 (indirect)
+ #define __FINITE_MATH_ONLY__ 0, line 0 (indirect)
+ #define _LP64 1, line 0 (indirect)
+ #define __LP64__ 1, line 0 (indirect)
+ #define __SIZEOF_INT__ 4, line 0 (indirect)
+ #define __SIZEOF_LONG__ 8, line 0 (indirect)
+ #define __SIZEOF_LONG_LONG__ 8, line 0 (indirect)
+ #define __SIZEOF_SHORT__ 2, line 0 (indirect)
+ #define __SIZEOF_FLOAT__ 4, line 0 (indirect)
+ #define __SIZEOF_DOUBLE__ 8, line 0 (indirect)
+ #define __SIZEOF_LONG_DOUBLE__ 16, line 0 (indirect)
+ #define __SIZEOF_SIZE_T__ 8, line 0 (indirect)
+ #define __CHAR_BIT__ 8, line 0 (indirect)
+ #define __BIGGEST_ALIGNMENT__ 16, line 0 (indirect)
+ #define __ORDER_LITTLE_ENDIAN__ 1234, line 0 (indirect)
+ #define __ORDER_BIG_ENDIAN__ 4321, line 0 (indirect)
+ #define __ORDER_PDP_ENDIAN__ 3412, line 0 (indirect)
+ #define __BYTE_ORDER__ __ORDER_LITTLE_ENDIAN__, line 0 (indirect)
+ #define __FLOAT_WORD_ORDER__ __ORDER_LITTLE_ENDIAN__, line 0 (indirect)
+ #define __SIZEOF_POINTER__ 8, line 0 (indirect)
+ #define __SIZE_TYPE__ long unsigned int, line 0 (indirect)
+ #define __PTRDIFF_TYPE__ long int, line 0 (indirect)
+ #define __WCHAR_TYPE__ int, line 0 (indirect)
+ #define __WINT_TYPE__ unsigned int, line 0 (indirect)
+ #define __INTMAX_TYPE__ long int, line 0 (indirect)
+ #define __UINTMAX_TYPE__ long unsigned int, line 0 (indirect)
+ #define __CHAR16_TYPE__ short unsigned int, line 0 (indirect)
+ #define __CHAR32_TYPE__ unsigned int, line 0 (indirect)
+ #define __SIG_ATOMIC_TYPE__ int, line 0 (indirect)
+ #define __INT8_TYPE__ signed char, line 0 (indirect)
+ #define __INT16_TYPE__ short int, line 0 (indirect)
+ #define __INT32_TYPE__ int, line 0 (indirect)
+ #define __INT64_TYPE__ long int, line 0 (indirect)
+ #define __UINT8_TYPE__ unsigned char, line 0 (indirect)
+ #define __UINT16_TYPE__ short unsigned int, line 0 (indirect)
+ #define __UINT32_TYPE__ unsigned int, line 0 (indirect)
+ #define __UINT64_TYPE__ long unsigned int, line 0 (indirect)
+ #define __INT_LEAST8_TYPE__ signed char, line 0 (indirect)
+ #define __INT_LEAST16_TYPE__ short int, line 0 (indirect)
+ #define __INT_LEAST32_TYPE__ int, line 0 (indirect)
+ #define __INT_LEAST64_TYPE__ long int, line 0 (indirect)
+ #define __UINT_LEAST8_TYPE__ unsigned char, line 0 (indirect)
+ #define __UINT_LEAST16_TYPE__ short unsigned int, line 0 (indirect)
+ #define __UINT_LEAST32_TYPE__ unsigned int, line 0 (indirect)
+ #define __UINT_LEAST64_TYPE__ long unsigned int, line 0 (indirect)
+ #define __INT_FAST8_TYPE__ signed char, line 0 (indirect)
+ #define __INT_FAST16_TYPE__ long int, line 0 (indirect)
+ #define __INT_FAST32_TYPE__ long int, line 0 (indirect)
+ #define __INT_FAST64_TYPE__ long int, line 0 (indirect)
+ #define __UINT_FAST8_TYPE__ unsigned char, line 0 (indirect)
+ #define __UINT_FAST16_TYPE__ long unsigned int, line 0 (indirect)
+ #define __UINT_FAST32_TYPE__ long unsigned int, line 0 (indirect)
+ #define __UINT_FAST64_TYPE__ long unsigned int, line 0 (indirect)
+ #define __INTPTR_TYPE__ long int, line 0 (indirect)
+ #define __UINTPTR_TYPE__ long unsigned int, line 0 (indirect)
+ #define __has_include(STR) __has_include__(STR), line 0 (indirect)
+ #define __has_include_next(STR) __has_include_next__(STR), line 0 (indirect)
+ #define __GXX_ABI_VERSION 1013, line 0 (indirect)
+ #define __SCHAR_MAX__ 0x7f, line 0 (indirect)
+ #define __SHRT_MAX__ 0x7fff, line 0 (indirect)
+ #define __INT_MAX__ 0x7fffffff, line 0 (indirect)
+ #define __LONG_MAX__ 0x7fffffffffffffffL, line 0 (indirect)
+ #define __LONG_LONG_MAX__ 0x7fffffffffffffffLL, line 0 (indirect)
+ #define __WCHAR_MAX__ 0x7fffffff, line 0 (indirect)
+ #define __WCHAR_MIN__ (-__WCHAR_MAX__ - 1), line 0 (indirect)
+ #define __WINT_MAX__ 0xffffffffU, line 0 (indirect)
+ #define __WINT_MIN__ 0U, line 0 (indirect)
+ #define __PTRDIFF_MAX__ 0x7fffffffffffffffL, line 0 (indirect)
+ #define __SIZE_MAX__ 0xffffffffffffffffUL, line 0 (indirect)
+ #define __SCHAR_WIDTH__ 8, line 0 (indirect)
+ #define __SHRT_WIDTH__ 16, line 0 (indirect)
+ #define __INT_WIDTH__ 32, line 0 (indirect)
+ #define __LONG_WIDTH__ 64, line 0 (indirect)
+ #define __LONG_LONG_WIDTH__ 64, line 0 (indirect)
+ #define __WCHAR_WIDTH__ 32, line 0 (indirect)
+ #define __WINT_WIDTH__ 32, line 0 (indirect)
+ #define __PTRDIFF_WIDTH__ 64, line 0 (indirect)
+ #define __SIZE_WIDTH__ 64, line 0 (indirect)
+ #define __INTMAX_MAX__ 0x7fffffffffffffffL, line 0 (indirect)
+ #define __INTMAX_C(c) c ## L, line 0 (indirect)
+ #define __UINTMAX_MAX__ 0xffffffffffffffffUL, line 0 (indirect)
+ #define __UINTMAX_C(c) c ## UL, line 0 (indirect)
+ #define __INTMAX_WIDTH__ 64, line 0 (indirect)
+ #define __SIG_ATOMIC_MAX__ 0x7fffffff, line 0 (indirect)
+ #define __SIG_ATOMIC_MIN__ (-__SIG_ATOMIC_MAX__ - 1), line 0 (indirect)
+ #define __SIG_ATOMIC_WIDTH__ 32, line 0 (indirect)
+ #define __INT8_MAX__ 0x7f, line 0 (indirect)
+ #define __INT16_MAX__ 0x7fff, line 0 (indirect)
+ #define __INT32_MAX__ 0x7fffffff, line 0 (indirect)
+ #define __INT64_MAX__ 0x7fffffffffffffffL, line 0 (indirect)
+ #define __UINT8_MAX__ 0xff, line 0 (indirect)
+ #define __UINT16_MAX__ 0xffff, line 0 (indirect)
+ #define __UINT32_MAX__ 0xffffffffU, line 0 (indirect)
+ #define __UINT64_MAX__ 0xffffffffffffffffUL, line 0 (indirect)
+ #define __INT_LEAST8_MAX__ 0x7f, line 0 (indirect)
+ #define __INT8_C(c) c, line 0 (indirect)
+ #define __INT_LEAST8_WIDTH__ 8, line 0 (indirect)
+ #define __INT_LEAST16_MAX__ 0x7fff, line 0 (indirect)
+ #define __INT16_C(c) c, line 0 (indirect)
+ #define __INT_LEAST16_WIDTH__ 16, line 0 (indirect)
+ #define __INT_LEAST32_MAX__ 0x7fffffff, line 0 (indirect)
+ #define __INT32_C(c) c, line 0 (indirect)
+ #define __INT_LEAST32_WIDTH__ 32, line 0 (indirect)
+ #define __INT_LEAST64_MAX__ 0x7fffffffffffffffL, line 0 (indirect)
+ #define __INT64_C(c) c ## L, line 0 (indirect)
+ #define __INT_LEAST64_WIDTH__ 64, line 0 (indirect)
+ #define __UINT_LEAST8_MAX__ 0xff, line 0 (indirect)
+ #define __UINT8_C(c) c, line 0 (indirect)
+ #define __UINT_LEAST16_MAX__ 0xffff, line 0 (indirect)
+ #define __UINT16_C(c) c, line 0 (indirect)
+ #define __UINT_LEAST32_MAX__ 0xffffffffU, line 0 (indirect)
+ #define __UINT32_C(c) c ## U, line 0 (indirect)
+ #define __UINT_LEAST64_MAX__ 0xffffffffffffffffUL, line 0 (indirect)
+ #define __UINT64_C(c) c ## UL, line 0 (indirect)
+ #define __INT_FAST8_MAX__ 0x7f, line 0 (indirect)
+ #define __INT_FAST8_WIDTH__ 8, line 0 (indirect)
+ #define __INT_FAST16_MAX__ 0x7fffffffffffffffL, line 0 (indirect)
+ #define __INT_FAST16_WIDTH__ 64, line 0 (indirect)
+ #define __INT_FAST32_MAX__ 0x7fffffffffffffffL, line 0 (indirect)
+ #define __INT_FAST32_WIDTH__ 64, line 0 (indirect)
+ #define __INT_FAST64_MAX__ 0x7fffffffffffffffL, line 0 (indirect)
+ #define __INT_FAST64_WIDTH__ 64, line 0 (indirect)
+ #define __UINT_FAST8_MAX__ 0xff, line 0 (indirect)
+ #define __UINT_FAST16_MAX__ 0xffffffffffffffffUL, line 0 (indirect)
+ #define __UINT_FAST32_MAX__ 0xffffffffffffffffUL, line 0 (indirect)
+ #define __UINT_FAST64_MAX__ 0xffffffffffffffffUL, line 0 (indirect)
+ #define __INTPTR_MAX__ 0x7fffffffffffffffL, line 0 (indirect)
+ #define __INTPTR_WIDTH__ 64, line 0 (indirect)
+ #define __UINTPTR_MAX__ 0xffffffffffffffffUL, line 0 (indirect)
+ #define __GCC_IEC_559 2, line 0 (indirect)
+ #define __GCC_IEC_559_COMPLEX 2, line 0 (indirect)
+ #define __FLT_EVAL_METHOD__ 0, line 0 (indirect)
+ #define __FLT_EVAL_METHOD_TS_18661_3__ 0, line 0 (indirect)
+ #define __DEC_EVAL_METHOD__ 2, line 0 (indirect)
+ #define __FLT_RADIX__ 2, line 0 (indirect)
+ #define __FLT_MANT_DIG__ 24, line 0 (indirect)
+ #define __FLT_DIG__ 6, line 0 (indirect)
+ #define __FLT_MIN_EXP__ (-125), line 0 (indirect)
+ #define __FLT_MIN_10_EXP__ (-37), line 0 (indirect)
+ #define __FLT_MAX_EXP__ 128, line 0 (indirect)
+ #define __FLT_MAX_10_EXP__ 38, line 0 (indirect)
+ #define __FLT_DECIMAL_DIG__ 9, line 0 (indirect)
+ #define __FLT_MAX__ 3.40282346638528859811704183484516925e+38F, line 0 (indirect)
+ #define __FLT_MIN__ 1.17549435082228750796873653722224568e-38F, line 0 (indirect)
+ #define __FLT_EPSILON__ 1.19209289550781250000000000000000000e-7F, line 0 (indirect)
+ #define __FLT_DENORM_MIN__ 1.40129846432481707092372958328991613e-45F, line 0 (indirect)
+ #define __FLT_HAS_DENORM__ 1, line 0 (indirect)
+ #define __FLT_HAS_INFINITY__ 1, line 0 (indirect)
+ #define __FLT_HAS_QUIET_NAN__ 1, line 0 (indirect)
+ #define __DBL_MANT_DIG__ 53, line 0 (indirect)
+ #define __DBL_DIG__ 15, line 0 (indirect)
+ #define __DBL_MIN_EXP__ (-1021), line 0 (indirect)
+ #define __DBL_MIN_10_EXP__ (-307), line 0 (indirect)
+ #define __DBL_MAX_EXP__ 1024, line 0 (indirect)
+ #define __DBL_MAX_10_EXP__ 308, line 0 (indirect)
+ #define __DBL_DECIMAL_DIG__ 17, line 0 (indirect)
+ #define __DBL_MAX__ ((double)1.79769313486231570814527423731704357e+308L), line 0 (indirect)
+ #define __DBL_MIN__ ((double)2.22507385850720138309023271733240406e-308L), line 0 (indirect)
+ #define __DBL_EPSILON__ ((double)2.22044604925031308084726333618164062e-16L), line 0 (indirect)
+ #define __DBL_DENORM_MIN__ ((double)4.94065645841246544176568792868221372e-324L), line 0 (indirect)
+ #define __DBL_HAS_DENORM__ 1, line 0 (indirect)
+ #define __DBL_HAS_INFINITY__ 1, line 0 (indirect)
+ #define __DBL_HAS_QUIET_NAN__ 1, line 0 (indirect)
+ #define __LDBL_MANT_DIG__ 64, line 0 (indirect)
+ #define __LDBL_DIG__ 18, line 0 (indirect)
+ #define __LDBL_MIN_EXP__ (-16381), line 0 (indirect)
+ #define __LDBL_MIN_10_EXP__ (-4931), line 0 (indirect)
+ #define __LDBL_MAX_EXP__ 16384, line 0 (indirect)
+ #define __LDBL_MAX_10_EXP__ 4932, line 0 (indirect)
+ #define __DECIMAL_DIG__ 21, line 0 (indirect)
+ #define __LDBL_DECIMAL_DIG__ 21, line 0 (indirect)
+ #define __LDBL_MAX__ 1.18973149535723176502126385303097021e+4932L, line 0 (indirect)
+ #define __LDBL_MIN__ 3.36210314311209350626267781732175260e-4932L, line 0 (indirect)
+ #define __LDBL_EPSILON__ 1.08420217248550443400745280086994171e-19L, line 0 (indirect)
+ #define __LDBL_DENORM_MIN__ 3.64519953188247460252840593361941982e-4951L, line 0 (indirect)
+ #define __LDBL_HAS_DENORM__ 1, line 0 (indirect)
+ #define __LDBL_HAS_INFINITY__ 1, line 0 (indirect)
+ #define __LDBL_HAS_QUIET_NAN__ 1, line 0 (indirect)
+ #define __FLT32_MANT_DIG__ 24, line 0 (indirect)
+ #define __FLT32_DIG__ 6, line 0 (indirect)
+ #define __FLT32_MIN_EXP__ (-125), line 0 (indirect)
+ #define __FLT32_MIN_10_EXP__ (-37), line 0 (indirect)
+ #define __FLT32_MAX_EXP__ 128, line 0 (indirect)
+ #define __FLT32_MAX_10_EXP__ 38, line 0 (indirect)
+ #define __FLT32_DECIMAL_DIG__ 9, line 0 (indirect)
+ #define __FLT32_MAX__ 3.40282346638528859811704183484516925e+38F32, line 0 (indirect)
+ #define __FLT32_MIN__ 1.17549435082228750796873653722224568e-38F32, line 0 (indirect)
+ #define __FLT32_EPSILON__ 1.19209289550781250000000000000000000e-7F32, line 0 (indirect)
+ #define __FLT32_DENORM_MIN__ 1.40129846432481707092372958328991613e-45F32, line 0 (indirect)
+ #define __FLT32_HAS_DENORM__ 1, line 0 (indirect)
+ #define __FLT32_HAS_INFINITY__ 1, line 0 (indirect)
+ #define __FLT32_HAS_QUIET_NAN__ 1, line 0 (indirect)
+ #define __FLT64_MANT_DIG__ 53, line 0 (indirect)
+ #define __FLT64_DIG__ 15, line 0 (indirect)
+ #define __FLT64_MIN_EXP__ (-1021), line 0 (indirect)
+ #define __FLT64_MIN_10_EXP__ (-307), line 0 (indirect)
+ #define __FLT64_MAX_EXP__ 1024, line 0 (indirect)
+ #define __FLT64_MAX_10_EXP__ 308, line 0 (indirect)
+ #define __FLT64_DECIMAL_DIG__ 17, line 0 (indirect)
+ #define __FLT64_MAX__ 1.79769313486231570814527423731704357e+308F64, line 0 (indirect)
+ #define __FLT64_MIN__ 2.22507385850720138309023271733240406e-308F64, line 0 (indirect)
+ #define __FLT64_EPSILON__ 2.22044604925031308084726333618164062e-16F64, line 0 (indirect)
+ #define __FLT64_DENORM_MIN__ 4.94065645841246544176568792868221372e-324F64, line 0 (indirect)
+ #define __FLT64_HAS_DENORM__ 1, line 0 (indirect)
+ #define __FLT64_HAS_INFINITY__ 1, line 0 (indirect)
+ #define __FLT64_HAS_QUIET_NAN__ 1, line 0 (indirect)
+ #define __FLT128_MANT_DIG__ 113, line 0 (indirect)
+ #define __FLT128_DIG__ 33, line 0 (indirect)
+ #define __FLT128_MIN_EXP__ (-16381), line 0 (indirect)
+ #define __FLT128_MIN_10_EXP__ (-4931), line 0 (indirect)
+ #define __FLT128_MAX_EXP__ 16384, line 0 (indirect)
+ #define __FLT128_MAX_10_EXP__ 4932, line 0 (indirect)
+ #define __FLT128_DECIMAL_DIG__ 36, line 0 (indirect)
+ #define __FLT128_MAX__ 1.18973149535723176508575932662800702e+4932F128, line 0 (indirect)
+ #define __FLT128_MIN__ 3.36210314311209350626267781732175260e-4932F128, line 0 (indirect)
+ #define __FLT128_EPSILON__ 1.92592994438723585305597794258492732e-34F128, line 0 (indirect)
+ #define __FLT128_DENORM_MIN__ 6.47517511943802511092443895822764655e-4966F128, line 0 (indirect)
+ #define __FLT128_HAS_DENORM__ 1, line 0 (indirect)
+ #define __FLT128_HAS_INFINITY__ 1, line 0 (indirect)
+ #define __FLT128_HAS_QUIET_NAN__ 1, line 0 (indirect)
+ #define __FLT32X_MANT_DIG__ 53, line 0 (indirect)
+ #define __FLT32X_DIG__ 15, line 0 (indirect)
+ #define __FLT32X_MIN_EXP__ (-1021), line 0 (indirect)
+ #define __FLT32X_MIN_10_EXP__ (-307), line 0 (indirect)
+ #define __FLT32X_MAX_EXP__ 1024, line 0 (indirect)
+ #define __FLT32X_MAX_10_EXP__ 308, line 0 (indirect)
+ #define __FLT32X_DECIMAL_DIG__ 17, line 0 (indirect)
+ #define __FLT32X_MAX__ 1.79769313486231570814527423731704357e+308F32x, line 0 (indirect)
+ #define __FLT32X_MIN__ 2.22507385850720138309023271733240406e-308F32x, line 0 (indirect)
+ #define __FLT32X_EPSILON__ 2.22044604925031308084726333618164062e-16F32x, line 0 (indirect)
+ #define __FLT32X_DENORM_MIN__ 4.94065645841246544176568792868221372e-324F32x, line 0 (indirect)
+ #define __FLT32X_HAS_DENORM__ 1, line 0 (indirect)
+ #define __FLT32X_HAS_INFINITY__ 1, line 0 (indirect)
+ #define __FLT32X_HAS_QUIET_NAN__ 1, line 0 (indirect)
+ #define __FLT64X_MANT_DIG__ 64, line 0 (indirect)
+ #define __FLT64X_DIG__ 18, line 0 (indirect)
+ #define __FLT64X_MIN_EXP__ (-16381), line 0 (indirect)
+ #define __FLT64X_MIN_10_EXP__ (-4931), line 0 (indirect)
+ #define __FLT64X_MAX_EXP__ 16384, line 0 (indirect)
+ #define __FLT64X_MAX_10_EXP__ 4932, line 0 (indirect)
+ #define __FLT64X_DECIMAL_DIG__ 21, line 0 (indirect)
+ #define __FLT64X_MAX__ 1.18973149535723176502126385303097021e+4932F64x, line 0 (indirect)
+ #define __FLT64X_MIN__ 3.36210314311209350626267781732175260e-4932F64x, line 0 (indirect)
+ #define __FLT64X_EPSILON__ 1.08420217248550443400745280086994171e-19F64x, line 0 (indirect)
+ #define __FLT64X_DENORM_MIN__ 3.64519953188247460252840593361941982e-4951F64x, line 0 (indirect)
+ #define __FLT64X_HAS_DENORM__ 1, line 0 (indirect)
+ #define __FLT64X_HAS_INFINITY__ 1, line 0 (indirect)
+ #define __FLT64X_HAS_QUIET_NAN__ 1, line 0 (indirect)
+ #define __DEC32_MANT_DIG__ 7, line 0 (indirect)
+ #define __DEC32_MIN_EXP__ (-94), line 0 (indirect)
+ #define __DEC32_MAX_EXP__ 97, line 0 (indirect)
+ #define __DEC32_MIN__ 1E-95DF, line 0 (indirect)
+ #define __DEC32_MAX__ 9.999999E96DF, line 0 (indirect)
+ #define __DEC32_EPSILON__ 1E-6DF, line 0 (indirect)
+ #define __DEC32_SUBNORMAL_MIN__ 0.000001E-95DF, line 0 (indirect)
+ #define __DEC64_MANT_DIG__ 16, line 0 (indirect)
+ #define __DEC64_MIN_EXP__ (-382), line 0 (indirect)
+ #define __DEC64_MAX_EXP__ 385, line 0 (indirect)
+ #define __DEC64_MIN__ 1E-383DD, line 0 (indirect)
+ #define __DEC64_MAX__ 9.999999999999999E384DD, line 0 (indirect)
+ #define __DEC64_EPSILON__ 1E-15DD, line 0 (indirect)
+ #define __DEC64_SUBNORMAL_MIN__ 0.000000000000001E-383DD, line 0 (indirect)
+ #define __DEC128_MANT_DIG__ 34, line 0 (indirect)
+ #define __DEC128_MIN_EXP__ (-6142), line 0 (indirect)
+ #define __DEC128_MAX_EXP__ 6145, line 0 (indirect)
+ #define __DEC128_MIN__ 1E-6143DL, line 0 (indirect)
+ #define __DEC128_MAX__ 9.999999999999999999999999999999999E6144DL, line 0 (indirect)
+ #define __DEC128_EPSILON__ 1E-33DL, line 0 (indirect)
+ #define __DEC128_SUBNORMAL_MIN__ 0.000000000000000000000000000000001E-6143DL, line 0 (indirect)
+ #define __REGISTER_PREFIX__ , line 0 (indirect)
+ #define __USER_LABEL_PREFIX__ , line 0 (indirect)
+ #define __GNUC_STDC_INLINE__ 1, line 0 (indirect)
+ #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1, line 0 (indirect)
+ #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1, line 0 (indirect)
+ #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1, line 0 (indirect)
+ #define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1, line 0 (indirect)
+ #define __GCC_ATOMIC_BOOL_LOCK_FREE 2, line 0 (indirect)
+ #define __GCC_ATOMIC_CHAR_LOCK_FREE 2, line 0 (indirect)
+ #define __GCC_ATOMIC_CHAR16_T_LOCK_FREE 2, line 0 (indirect)
+ #define __GCC_ATOMIC_CHAR32_T_LOCK_FREE 2, line 0 (indirect)
+ #define __GCC_ATOMIC_WCHAR_T_LOCK_FREE 2, line 0 (indirect)
+ #define __GCC_ATOMIC_SHORT_LOCK_FREE 2, line 0 (indirect)
+ #define __GCC_ATOMIC_INT_LOCK_FREE 2, line 0 (indirect)
+ #define __GCC_ATOMIC_LONG_LOCK_FREE 2, line 0 (indirect)
+ #define __GCC_ATOMIC_LLONG_LOCK_FREE 2, line 0 (indirect)
+ #define __GCC_ATOMIC_TEST_AND_SET_TRUEVAL 1, line 0 (indirect)
+ #define __GCC_ATOMIC_POINTER_LOCK_FREE 2, line 0 (indirect)
+ #define __GCC_HAVE_DWARF2_CFI_ASM 1, line 0 (indirect)
+ #define __PRAGMA_REDEFINE_EXTNAME 1, line 0 (indirect)
+ #define __SIZEOF_INT128__ 16, line 0 (indirect)
+ #define __SIZEOF_WCHAR_T__ 4, line 0 (indirect)
+ #define __SIZEOF_WINT_T__ 4, line 0 (indirect)
+ #define __SIZEOF_PTRDIFF_T__ 8, line 0 (indirect)
+ #define __amd64 1, line 0 (indirect)
+ #define __amd64__ 1, line 0 (indirect)
+ #define __x86_64 1, line 0 (indirect)
+ #define __x86_64__ 1, line 0 (indirect)
+ #define __SIZEOF_FLOAT80__ 16, line 0 (indirect)
+ #define __SIZEOF_FLOAT128__ 16, line 0 (indirect)
+ #define __ATOMIC_HLE_ACQUIRE 65536, line 0 (indirect)
+ #define __ATOMIC_HLE_RELEASE 131072, line 0 (indirect)
+ #define __GCC_ASM_FLAG_OUTPUTS__ 1, line 0 (indirect)
+ #define __k8 1, line 0 (indirect)
+ #define __k8__ 1, line 0 (indirect)
+ #define __code_model_small__ 1, line 0 (indirect)
+ #define __MMX__ 1, line 0 (indirect)
+ #define __SSE__ 1, line 0 (indirect)
+ #define __SSE2__ 1, line 0 (indirect)
+ #define __FXSR__ 1, line 0 (indirect)
+ #define __SSE_MATH__ 1, line 0 (indirect)
+ #define __SSE2_MATH__ 1, line 0 (indirect)
+ #define __SEG_FS 1, line 0 (indirect)
+ #define __SEG_GS 1, line 0 (indirect)
+ #define __gnu_linux__ 1, line 0 (indirect)
+ #define __linux 1, line 0 (indirect)
+ #define __linux__ 1, line 0 (indirect)
+ #define linux 1, line 0 (indirect)
+ #define __unix 1, line 0 (indirect)
+ #define __unix__ 1, line 0 (indirect)
+ #define unix 1, line 0 (indirect)
+ #define __ELF__ 1, line 0 (indirect)
+ #define __DECIMAL_BID_FORMAT__ 1, line 0 (indirect)
+
+
+DWARF section [16] '.debug_macro' at offset 0x98e:
+
+ Offset: 0x0
+ Version: 5
+ Flag: 0x0
+ Offset length: 4
+
+ #define _STDC_PREDEF_H 1, line 19 (indirect)
+ #define __STDC_IEC_559__ 1, line 30 (indirect)
+ #define __STDC_IEC_559_COMPLEX__ 1, line 31 (indirect)
+ #define __STDC_ISO_10646__ 201103L, line 35 (indirect)
+ #define __STDC_NO_THREADS__ 1, line 38 (indirect)
+
+
+DWARF section [18] '.debug_macro' at offset 0x9b0:
+
+ Offset: 0x0
+ Version: 5
+ Flag: 0x0
+ Offset length: 4
+
+ #define _STDBOOL_H , line 29 (indirect)
+ #define bool _Bool, line 33 (indirect)
+ #define true 1, line 34 (indirect)
+ #define false 0, line 35 (indirect)
+ #define __bool_true_false_are_defined 1, line 52 (indirect)
+
+EOF
+
+exit 0
diff --git a/tests/run-readelf-n.sh b/tests/run-readelf-n.sh
new file mode 100755
index 00000000..c2db2ce2
--- /dev/null
+++ b/tests/run-readelf-n.sh
@@ -0,0 +1,127 @@
+# Copyright (C) 2018 Red Hat, Inc.
+# This file is part of elfutils.
+#
+# This file is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# elfutils is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+. $srcdir/test-subr.sh
+
+# - testfile-gnu-property-note.c
+# int
+# main ()
+# {
+# return 0;
+# }
+#
+# gcc -fcf-protection -c testfile-gnu-property-note.c
+# gcc -o testfile-gnu-property-note testfile-gnu-property-note.o
+# eu-strip --strip-sections testfile-gnu-property-note
+
+testfiles testfile-gnu-property-note.o testfile-gnu-property-note
+
+# Test reading notes through sections
+testrun_compare ${abs_top_builddir}/src/readelf -n testfile-gnu-property-note.o << EOF
+
+Note section [ 6] '.note.gnu.property' of 32 bytes at offset 0x80:
+ Owner Data size Type
+ GNU 16 GNU_PROPERTY_TYPE_0
+ X86 FEATURE_1_AND: 00000003 IBT SHSTK
+EOF
+
+# Test reading notes through segments
+testrun_compare ${abs_top_builddir}/src/readelf -n testfile-gnu-property-note << EOF
+
+Note segment of 32 bytes at offset 0x300:
+ Owner Data size Type
+ GNU 16 GNU_PROPERTY_TYPE_0
+ X86 FEATURE_1_AND: 00000003 IBT SHSTK
+
+Note segment of 68 bytes at offset 0x320:
+ Owner Data size Type
+ GNU 16 GNU_ABI_TAG
+ OS: Linux, ABI: 3.2.0
+ GNU 20 GNU_BUILD_ID
+ Build ID: 83cb2229fabd2065d1361f5b46424cd75270f94b
+EOF
+
+# NT_VERSION note type clashes with "GNU" owner type NT_GNU_ABI_TAG.
+# Uses owner name (with zero desc) for version string.
+testfiles testfile11
+testrun_compare ${abs_top_builddir}/src/readelf -n testfile11 << EOF
+
+Note section [ 2] '.note.ABI-tag' of 32 bytes at offset 0x128:
+ Owner Data size Type
+ GNU 16 GNU_ABI_TAG
+ OS: Linux, ABI: 2.2.5
+
+Note section [35] '.note' of 60 bytes at offset 0x13364:
+ Owner Data size Type
+ 01.01 0 VERSION
+ 01.01 0 VERSION
+ 01.01 0 VERSION
+EOF
+
+# See run-annobingroup.sh
+testfiles testfile-annobingroup.o
+testrun_compare ${abs_top_builddir}/src/readelf -n testfile-annobingroup.o << EOF
+
+Note section [ 5] '.gnu.build.attributes' of 272 bytes at offset 0x50:
+ Owner Data size Type
+ GA 16 GNU Build Attribute OPEN
+ Address Range: 0 - 0
+ VERSION: "3p8"
+ GA 0 GNU Build Attribute OPEN
+ TOOL: "gcc 8.1.1 20180712"
+ GA 0 GNU Build Attribute OPEN
+ "GOW": 5
+ GA 0 GNU Build Attribute OPEN
+ STACK_PROT: 0
+ GA 0 GNU Build Attribute OPEN
+ "stack_clash": FALSE
+ GA 0 GNU Build Attribute OPEN
+ "cf_protection": 0
+ GA 0 GNU Build Attribute OPEN
+ PIC: 0
+ GA 0 GNU Build Attribute OPEN
+ SHORT_ENUM: FALSE
+ GA 0 GNU Build Attribute OPEN
+ ABI: c001100000012
+ GA 0 GNU Build Attribute OPEN
+ "stack_realign": FALSE
+
+Note section [ 7] '.gnu.build.attributes..text.unlikely' of 216 bytes at offset 0x160:
+ Owner Data size Type
+ GA 16 GNU Build Attribute FUNC
+ Address Range: 0 - 0
+ ABI: c001100000012
+ GA 0 GNU Build Attribute FUNC
+ "stack_realign": FALSE
+ GA 0 GNU Build Attribute FUNC
+ STACK_PROT: 0
+ GA 0 GNU Build Attribute FUNC
+ "stack_clash": FALSE
+ GA 0 GNU Build Attribute FUNC
+ "cf_protection": 0
+ GA 0 GNU Build Attribute FUNC
+ PIC: 0
+ GA 0 GNU Build Attribute FUNC
+ "GOW": 5
+ GA 0 GNU Build Attribute FUNC
+ SHORT_ENUM: FALSE
+
+Note section [22] '.note.gnu.property' of 48 bytes at offset 0x40c:
+ Owner Data size Type
+ GNU 32 GNU_PROPERTY_TYPE_0
+ X86 0xc0000000 data: 00 00 00 00
+ X86 0xc0000001 data: 00 00 00 00
+EOF
diff --git a/tests/run-readelf-zdebug-rel.sh b/tests/run-readelf-zdebug-rel.sh
index 3f20078c..53fa42a2 100755
--- a/tests/run-readelf-zdebug-rel.sh
+++ b/tests/run-readelf-zdebug-rel.sh
@@ -146,4 +146,110 @@ cat loc.out | sed -e "s/'.debug_loc' at offset 0x185/'.zdebug_loc' at offset 0x1
cat loc.out | sed -e "s/at offset 0x185/at offset 0x150/" | testrun_compare ${abs_top_builddir}/src/readelf -U --debug-dump=loc testfile-debug-rel-z.o
+# Same as above, but on ppc64
+testfiles testfile-debug-rel-ppc64.o
+testfiles testfile-debug-rel-ppc64-g.o testfile-debug-rel-ppc64-z.o
+
+cat > info.out << \EOF
+
+DWARF section [ 6] '.debug_info' at offset 0x80:
+ [Offset]
+ Compilation unit at offset 0:
+ Version: 4, Abbreviation section offset: 0, Address size: 8, Offset size: 4
+ [ b] compile_unit abbrev: 1
+ producer (strp) "GNU C11 7.3.1 20180712 (Red Hat 7.3.1-6) -Asystem=linux -Asystem=unix -Asystem=posix -msecure-plt -g -Og"
+ language (data1) C99 (12)
+ name (strp) "testfile-zdebug-rel.c"
+ comp_dir (strp) "/home/mjw"
+ low_pc (addr) 000000000000000000
+ high_pc (data8) 44 (0x000000000000002c)
+ stmt_list (sec_offset) 0
+ [ 2d] subprogram abbrev: 2
+ external (flag_present) yes
+ name (strp) "main"
+ decl_file (data1) testfile-zdebug-rel.c (1)
+ decl_line (data1) 4
+ prototyped (flag_present) yes
+ type (ref4) [ 82]
+ low_pc (addr) 000000000000000000
+ high_pc (data8) 44 (0x000000000000002c)
+ frame_base (exprloc)
+ [ 0] call_frame_cfa
+ GNU_all_call_sites (flag_present) yes
+ sibling (ref4) [ 82]
+ [ 4e] formal_parameter abbrev: 3
+ name (strp) "argc"
+ decl_file (data1) testfile-zdebug-rel.c (1)
+ decl_line (data1) 4
+ type (ref4) [ 82]
+ location (sec_offset) location list [ 0]
+ [ 5d] formal_parameter abbrev: 4
+ name (strp) "argv"
+ decl_file (data1) testfile-zdebug-rel.c (1)
+ decl_line (data1) 4
+ type (ref4) [ 89]
+ location (exprloc)
+ [ 0] reg4
+ [ 6a] variable abbrev: 5
+ name (string) "a"
+ decl_file (data1) testfile-zdebug-rel.c (1)
+ decl_line (data1) 6
+ type (ref4) [ 9c]
+ const_value (sdata) 18446744073709551607 (-9)
+ [ 74] variable abbrev: 6
+ name (string) "b"
+ decl_file (data1) testfile-zdebug-rel.c (1)
+ decl_line (data1) 7
+ type (ref4) [ 9c]
+ location (sec_offset) location list [ 4e]
+ [ 82] base_type abbrev: 7
+ byte_size (data1) 4
+ encoding (data1) signed (5)
+ name (string) "int"
+ [ 89] pointer_type abbrev: 8
+ byte_size (data1) 8
+ type (ref4) [ 8f]
+ [ 8f] pointer_type abbrev: 8
+ byte_size (data1) 8
+ type (ref4) [ 95]
+ [ 95] base_type abbrev: 9
+ byte_size (data1) 1
+ encoding (data1) unsigned_char (8)
+ name (strp) "char"
+ [ 9c] base_type abbrev: 9
+ byte_size (data1) 8
+ encoding (data1) unsigned (7)
+ name (strp) "long unsigned int"
+EOF
+
+cat info.out | testrun_compare ${abs_top_builddir}/src/readelf -U --debug-dump=info testfile-debug-rel-ppc64.o
+
+cat info.out | sed -e "s/'.debug_info'/'.zdebug_info'/" | testrun_compare ${abs_top_builddir}/src/readelf -U --debug-dump=info testfile-debug-rel-ppc64-g.o
+
+cat info.out | testrun_compare ${abs_top_builddir}/src/readelf -U --debug-dump=info testfile-debug-rel-ppc64-z.o
+
+cat > loc.out << \EOF
+
+DWARF section [ 9] '.debug_loc' at offset 0x1af:
+
+ CU [ b] base: 000000000000000000
+ [ 0] range 0, 4
+ [ 0] reg3
+ range 4, 14
+ [ 0] breg3 -42
+ [ 2] stack_value
+ range 14, 2c
+ [ 0] GNU_entry_value:
+ [ 0] reg3
+ [ 3] stack_value
+ [ 4e] range 8, 18
+ [ 0] reg3
+EOF
+
+cat loc.out | testrun_compare ${abs_top_builddir}/src/readelf -U --debug-dump=loc testfile-debug-rel-ppc64.o
+
+cat loc.out | sed -e "s/'.debug_loc' at offset 0x1af/'.zdebug_loc' at offset 0x15f/" | testrun_compare ${abs_top_builddir}/src/readelf -U --debug-dump=loc testfile-debug-rel-ppc64-g.o
+
+cat loc.out | sed -e "s/at offset 0x1af/at offset 0x177/" | testrun_compare ${abs_top_builddir}/src/readelf -U --debug-dump=loc testfile-debug-rel-ppc64-z.o
+
exit 0
diff --git a/tests/run-readelf-zdebug.sh b/tests/run-readelf-zdebug.sh
index 878e0ba8..9de68deb 100755
--- a/tests/run-readelf-zdebug.sh
+++ b/tests/run-readelf-zdebug.sh
@@ -100,7 +100,7 @@ DWARF section [33] '.debug_macro' at offset 0xab5:
Offset: 0x0
Version: 4
- Flag: 0x2
+ Flag: 0x2 (debug_line_offset)
Offset length: 4
.debug_line offset: 0x0
diff --git a/tests/run-strip-reloc.sh b/tests/run-strip-reloc.sh
index caa7eb52..3523f075 100755
--- a/tests/run-strip-reloc.sh
+++ b/tests/run-strip-reloc.sh
@@ -32,6 +32,8 @@ runtest() {
outfile2=out.stripped2
debugfile2=out.debug2
+ echo "runtest $infile"
+
rm -f $outfile1 $debugfile1 $outfile2 $debugfile2
testrun ${abs_top_builddir}/src/strip -o $outfile1 -f $debugfile1 $infile ||
@@ -67,6 +69,15 @@ runtest() {
testrun_compare cat readelf.out1 < readelf.out2 ||
{ echo "*** failure readelf -w compare $infile"; status=1; }
+
+ testrun ${abs_top_builddir}/src/strip --reloc-debug-sections-only \
+ $debugfile1 ||
+ { echo "*** failure strip --reloc-debug-sections-only $debugfile1"; \
+ status=1; }
+
+ cmp $debugfile1 $debugfile2 ||
+ { echo "*** failure --reloc-debug-sections[-only] $debugfile1 $debugfile2"; \
+ status=1; }
}
# Most simple hello world kernel module for various architectures.
@@ -122,4 +133,14 @@ testrun ${abs_top_builddir}/src/elfcompress -o strip-compressed.o -t zlib \
runtest strip-uncompressed.o 1
runtest strip-compressed.o 1
+# See run-readelf-zdebug-rel.sh
+testfiles testfile-debug-rel-ppc64.o
+runtest testfile-debug-rel-ppc64.o 1
+
+testfiles testfile-debug-rel-ppc64-z.o
+runtest testfile-debug-rel-ppc64-z.o 1
+
+testfiles testfile-debug-rel-ppc64-g.o
+runtest testfile-debug-rel-ppc64-g.o 1
+
exit $status
diff --git a/tests/testfile-annobingroup-x86_64.o.bz2 b/tests/testfile-annobingroup-x86_64.o.bz2
new file mode 100644
index 00000000..ec389db2
--- /dev/null
+++ b/tests/testfile-annobingroup-x86_64.o.bz2
Binary files differ
diff --git a/tests/testfile-bpf-dis1.expect.bz2 b/tests/testfile-bpf-dis1.expect.bz2
index 21b55e94..61a8afb1 100644
--- a/tests/testfile-bpf-dis1.expect.bz2
+++ b/tests/testfile-bpf-dis1.expect.bz2
Binary files differ
diff --git a/tests/testfile-debug-rel-ppc64-g.o.bz2 b/tests/testfile-debug-rel-ppc64-g.o.bz2
new file mode 100644
index 00000000..8c5ec99e
--- /dev/null
+++ b/tests/testfile-debug-rel-ppc64-g.o.bz2
Binary files differ
diff --git a/tests/testfile-debug-rel-ppc64-z.o.bz2 b/tests/testfile-debug-rel-ppc64-z.o.bz2
new file mode 100644
index 00000000..df50465f
--- /dev/null
+++ b/tests/testfile-debug-rel-ppc64-z.o.bz2
Binary files differ
diff --git a/tests/testfile-debug-rel-ppc64.o.bz2 b/tests/testfile-debug-rel-ppc64.o.bz2
new file mode 100644
index 00000000..8340d0ce
--- /dev/null
+++ b/tests/testfile-debug-rel-ppc64.o.bz2
Binary files differ
diff --git a/tests/testfile-gnu-property-note.bz2 b/tests/testfile-gnu-property-note.bz2
new file mode 100755
index 00000000..c03bd9bb
--- /dev/null
+++ b/tests/testfile-gnu-property-note.bz2
Binary files differ
diff --git a/tests/testfile-gnu-property-note.o.bz2 b/tests/testfile-gnu-property-note.o.bz2
new file mode 100644
index 00000000..5147c64f
--- /dev/null
+++ b/tests/testfile-gnu-property-note.o.bz2
Binary files differ
diff --git a/tests/testfile-macros-object.o.bz2 b/tests/testfile-macros-object.o.bz2
new file mode 100644
index 00000000..de5fa1a0
--- /dev/null
+++ b/tests/testfile-macros-object.o.bz2
Binary files differ