From 9afa44a338b1780d603ac39c4693aadd1f4026ca Mon Sep 17 00:00:00 2001 From: Tristan Gingold Date: Mon, 19 Aug 2013 15:08:52 +0000 Subject: binutils/ 2013-08-19 Tristan Gingold * nm.c (print_size_symbols): Directly get symbol size. binutils/testsuite/ 2013-08-19 Tristan Gingold * binutils-all/nm.exp: Add a test for nm --size-sort * binutils-all/nm-elf-1.s: New file. * binutils-all/nm-1.s: New file. --- binutils/testsuite/ChangeLog | 6 ++++++ binutils/testsuite/binutils-all/nm-1.s | 13 ++++++++++++ binutils/testsuite/binutils-all/nm-elf-1.s | 16 ++++++++++++++ binutils/testsuite/binutils-all/nm.exp | 34 ++++++++++++++++++++++++++++++ 4 files changed, 69 insertions(+) create mode 100644 binutils/testsuite/binutils-all/nm-1.s create mode 100644 binutils/testsuite/binutils-all/nm-elf-1.s (limited to 'binutils/testsuite') diff --git a/binutils/testsuite/ChangeLog b/binutils/testsuite/ChangeLog index ac10932fe2..d2d2f7da54 100644 --- a/binutils/testsuite/ChangeLog +++ b/binutils/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2013-08-19 Tristan Gingold + + * binutils-all/nm.exp: Add a test for nm --size-sort + * binutils-all/nm-elf-1.s: New file. + * binutils-all/nm-1.s: New file. + 2013-05-31 H.J. Lu * binutils-all/i386/compressed-1b.d: Updated for text/data/bss diff --git a/binutils/testsuite/binutils-all/nm-1.s b/binutils/testsuite/binutils-all/nm-1.s new file mode 100644 index 0000000000..5fe4cd7695 --- /dev/null +++ b/binutils/testsuite/binutils-all/nm-1.s @@ -0,0 +1,13 @@ + .globl text_symbol1 + .globl text_symbol2 + .globl text_symbol3 + .text +text_symbol1: + .long 0 + .long 0 + .long 0 +text_symbol2: + .long 0 + .long 0 +text_symbol3: + .long 0 diff --git a/binutils/testsuite/binutils-all/nm-elf-1.s b/binutils/testsuite/binutils-all/nm-elf-1.s new file mode 100644 index 0000000000..8e2f1f4810 --- /dev/null +++ b/binutils/testsuite/binutils-all/nm-elf-1.s @@ -0,0 +1,16 @@ + .globl text_symbol1 + .globl text_symbol2 + .globl text_symbol3 + .text +text_symbol1: + .long 0 + .long 0 + .long 0 + .size text_symbol1, . - text_symbol1 +text_symbol2: + .long 0 + .long 0 + .size text_symbol2, . - text_symbol2 +text_symbol3: + .long 0 + .size text_symbol3, . - text_symbol3 diff --git a/binutils/testsuite/binutils-all/nm.exp b/binutils/testsuite/binutils-all/nm.exp index 685794d323..226704b779 100644 --- a/binutils/testsuite/binutils-all/nm.exp +++ b/binutils/testsuite/binutils-all/nm.exp @@ -155,4 +155,38 @@ if [regexp $want $got] then { fail "nm -P" } +# Test nm --size-sort + +if [is_elf_format] { + set nm_1_src "nm-elf-1.s" +} else { + set nm_1_src "nm-1.s" +} + +if {![binutils_assemble $srcdir/$subdir/$nm_1_src tmpdir/nm-1.o]} then { + return +} + +if [is_remote host] { + set tempfile [remote_download host tmpdir/nm-1.o] +} else { + set tempfile tmpdir/nm-1.o +} + +# This test does not work correctly on ECOFF targets, because ECOFF +# stores most symbols twice, which messes up the nm output. +setup_xfail "alpha*-*-osf*" "alpha*-*-netware*" +setup_xfail "mips*-*-ultrix*" "mips*-*-ecoff*" "mips*-*-irix4*" +setup_xfail "mips*-*-riscos*" "mips*-*-sysv3*" "mips*-sony-bsd*" + +set got [binutils_run $NM "$NMFLAGS --size-sort $tempfile"] + +set want "0*4 T text_symbol3.*0*8 T text_symbol2.*0*c T text_symbol1" + +if [regexp $want $got] then { + pass "nm --size-sort" +} else { + fail "nm --size-sort" +} + # There are certainly other tests that could be run. -- cgit v1.2.1