mirror of
https://github.com/espressif/binutils-gdb.git
synced 2025-06-22 02:50:08 +08:00
Tidy elf.exp
* testsuite/ld-elf/elf.exp: Merge some conditionals, a better name than "shared library for next test", and use xfail arg of run_ld_link_tests in a few places.
This commit is contained in:
@ -1,3 +1,9 @@
|
|||||||
|
2017-11-01 Alan Modra <amodra@gmail.com>
|
||||||
|
|
||||||
|
* testsuite/ld-elf/elf.exp: Merge some conditionals, a better
|
||||||
|
name than "shared library for next test", and use xfail arg
|
||||||
|
of run_ld_link_tests in a few places.
|
||||||
|
|
||||||
2017-10-26 Renlin Li <renlin.li@arm.com>
|
2017-10-26 Renlin Li <renlin.li@arm.com>
|
||||||
|
|
||||||
* testsuite/ld-elf/elf.exp: xfail pr21703 tests on specific targets.
|
* testsuite/ld-elf/elf.exp: xfail pr21703 tests on specific targets.
|
||||||
|
@ -70,55 +70,41 @@ run_ld_link_tests [list \
|
|||||||
{symbol3w.s} {} "symbol3w.a" ] \
|
{symbol3w.s} {} "symbol3w.a" ] \
|
||||||
]
|
]
|
||||||
|
|
||||||
# These targets use _bfd_generic_link_add_symbols instead of
|
# Targets that use _bfd_generic_link_add_symbols won't pass pr21703 tests
|
||||||
# bfd_elf_link_add_symbols
|
|
||||||
setup_xfail "d30v-*-*" "dlx-*-*" "pj-*-*"
|
|
||||||
run_ld_link_tests {
|
run_ld_link_tests {
|
||||||
{"PR ld/21703"
|
{"PR ld/21703"
|
||||||
"--allow-multiple-definition tmpdir/pr21703-1.o tmpdir/pr21703-2.o" "" "" \
|
"--allow-multiple-definition tmpdir/pr21703-1.o tmpdir/pr21703-2.o" "" "" \
|
||||||
{pr21703-1.s pr21703-2.s} {{readelf {-s} pr21703.sd}} "pr21703" }
|
{pr21703-1.s pr21703-2.s} {{readelf {-s} pr21703.sd}} "pr21703" }
|
||||||
}
|
|
||||||
|
|
||||||
# These targets use _bfd_generic_link_add_symbols instead of
|
|
||||||
# bfd_elf_link_add_symbols
|
|
||||||
setup_xfail "d30v-*-*" "dlx-*-*" "pj-*-*"
|
|
||||||
run_ld_link_tests {
|
|
||||||
{"PR ld/21703 -r"
|
{"PR ld/21703 -r"
|
||||||
"-r --allow-multiple-definition tmpdir/pr21703-3.o tmpdir/pr21703-4.o" "" "" \
|
"-r --allow-multiple-definition tmpdir/pr21703-3.o tmpdir/pr21703-4.o" "" "" \
|
||||||
{pr21703-3.s pr21703-4.s} {{readelf {-s} pr21703-r.sd}} "pr21703.o" }
|
{pr21703-3.s pr21703-4.s} {{readelf {-s} pr21703-r.sd}} "pr21703.o" }
|
||||||
}
|
} "d30v-*-*" "dlx-*-*" "pj-*-*"
|
||||||
|
|
||||||
|
# Only run these tests on targets that support creating shared libraries.
|
||||||
if { [check_shared_lib_support] } then {
|
if { [check_shared_lib_support] } then {
|
||||||
run_ld_link_tests {
|
run_ld_link_tests {
|
||||||
{"Build pr14170a.o" "" "" "" {pr14170a.s} {} "pr14170.a" }
|
{"Build pr14170a.o" "" "" "" {pr14170a.s} {} "pr14170.a" }
|
||||||
}
|
}
|
||||||
setup_xfail "tic6x-*-*"
|
|
||||||
run_ld_link_tests {
|
run_ld_link_tests {
|
||||||
{"Build shared library for pr14170"
|
{"Build shared library for pr14170"
|
||||||
"-shared" "" "" "pr14170b.s" {} "pr14170.so" }
|
"-shared" "" "" "pr14170b.s" {} "pr14170.so" }
|
||||||
}
|
} "tic6x-*-*"
|
||||||
|
|
||||||
# bfin does not currently support copy relocs.
|
# bfin does not currently support copy relocs.
|
||||||
setup_xfail "bfin-*-*"
|
|
||||||
run_ld_link_tests [list \
|
run_ld_link_tests [list \
|
||||||
[list "PR ld/14170" \
|
[list "PR ld/14170" \
|
||||||
"--no-dynamic-linker tmpdir/pr14170a.o tmpdir/pr14170.so" "" $hpux \
|
"--no-dynamic-linker tmpdir/pr14170a.o tmpdir/pr14170.so" "" $hpux \
|
||||||
{pr14170c.s} { } "pr14170" ] \
|
{pr14170c.s} { } "pr14170" ] \
|
||||||
]
|
] "bfin-*-*"
|
||||||
|
|
||||||
# These targets use _bfd_generic_link_add_symbols instead of
|
# Targets that use _bfd_generic_link_add_symbols won't pass pr21703 tests
|
||||||
# bfd_elf_link_add_symbols
|
# Not will tic6x with PIC/PID warning, or hppa64 with dot-symbols
|
||||||
setup_xfail "d30v-*-*" "dlx-*-*" "pj-*-*"
|
|
||||||
setup_xfail "tic6x-*-*" "hppa64-*-*"
|
|
||||||
run_ld_link_tests {
|
run_ld_link_tests {
|
||||||
{"PR ld/21703 shared"
|
{"PR ld/21703 shared"
|
||||||
"-shared --allow-multiple-definition --version-script pr21703.ver tmpdir/pr21703-3.o tmpdir/pr21703-4.o" "" "" \
|
"-shared --allow-multiple-definition --version-script pr21703.ver tmpdir/pr21703-3.o tmpdir/pr21703-4.o" "" "" \
|
||||||
{pr21703-3.s pr21703-4.s} {{readelf {--dyn-syms} pr21703-shared.sd}} "pr21703.so" }
|
{pr21703-3.s pr21703-4.s} {{readelf {--dyn-syms} pr21703-shared.sd}} "pr21703.so" }
|
||||||
}
|
} "d30v-*-*" "dlx-*-*" "pj-*-*" "tic6x-*-*" "hppa64-*-*"
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
# Only run these tests on targets that support creating shared libraries.
|
|
||||||
if { [check_shared_lib_support] } then {
|
|
||||||
# This target requires extra GAS options when building non-PIC code
|
# This target requires extra GAS options when building non-PIC code
|
||||||
# for linking with shared libraries.
|
# for linking with shared libraries.
|
||||||
set AFLAGS_NONPIC ""
|
set AFLAGS_NONPIC ""
|
||||||
@ -130,15 +116,17 @@ if { [check_shared_lib_support] } then {
|
|||||||
# script that accidentally marks dynamic sections as notes. The
|
# script that accidentally marks dynamic sections as notes. The
|
||||||
# resulting executable is not expected to work, but the linker
|
# resulting executable is not expected to work, but the linker
|
||||||
# should not seg-fault whilst creating the binary.
|
# should not seg-fault whilst creating the binary.
|
||||||
|
# Note: setup_xfail before run_ld_link_tests xfails only the first test.
|
||||||
setup_xfail "tic6x-*-*"
|
setup_xfail "tic6x-*-*"
|
||||||
run_ld_link_tests {
|
run_ld_link_tests {
|
||||||
{"Build shared library for next test"
|
{"Build shared library for broken linker scrip test"
|
||||||
"-shared --hash-style=sysv" "" "" "note-3.s" {} "note-3.so" }
|
"-shared --hash-style=sysv" "" "" "note-3.s" {} "note-3.so" }
|
||||||
{"Link using broken linker script"
|
{"Link using broken linker script"
|
||||||
"--script note-3.t tmpdir/note-3.so" "" "" ""
|
"--script note-3.t tmpdir/note-3.so" "" "" ""
|
||||||
{ { ld "note-3.l" } }
|
{ { ld "note-3.l" } }
|
||||||
"a.out" }
|
"a.out" }
|
||||||
}
|
}
|
||||||
|
|
||||||
setup_xfail "tic6x-*-*"
|
setup_xfail "tic6x-*-*"
|
||||||
run_ld_link_tests {
|
run_ld_link_tests {
|
||||||
{"Build pr17068.so"
|
{"Build pr17068.so"
|
||||||
@ -151,42 +139,40 @@ if { [check_shared_lib_support] } then {
|
|||||||
"" "" ""
|
"" "" ""
|
||||||
{pr17068b.s pr17068e.s} {} "pr17068b.a"}
|
{pr17068b.s pr17068e.s} {} "pr17068b.a"}
|
||||||
}
|
}
|
||||||
|
|
||||||
# bfin does not currently support copy relocs.
|
# bfin does not currently support copy relocs.
|
||||||
setup_xfail "bfin-*-*"
|
|
||||||
run_ld_link_tests {
|
run_ld_link_tests {
|
||||||
{"pr17068 link --as-needed lib in group"
|
{"pr17068 link --as-needed lib in group"
|
||||||
"--as-needed --no-dynamic-linker" "--start-group tmpdir/pr17068a.a tmpdir/pr17068.so tmpdir/pr17068b.a --end-group" ""
|
"--as-needed --no-dynamic-linker" "--start-group tmpdir/pr17068a.a tmpdir/pr17068.so tmpdir/pr17068b.a --end-group" ""
|
||||||
{start.s pr17068.s} {} "pr17068"}
|
{start.s pr17068.s} {} "pr17068"}
|
||||||
}
|
} "bfin-*-*"
|
||||||
|
|
||||||
# xfail on tic6x due to non-PIC/non-PID warnings
|
# xfail on tic6x due to non-PIC/non-PID warnings
|
||||||
setup_xfail "tic6x-*-*"
|
# Fails on MIPS because ABI trickery means that a NULL reloc is emitted.
|
||||||
# Fails on MIPS because ABI trickery means that a NULL reloc is also emitted.
|
|
||||||
setup_xfail "mips*-*-*"
|
|
||||||
# Fails on bfin because relocations are not created.
|
# Fails on bfin because relocations are not created.
|
||||||
setup_xfail "bfin-*-*"
|
|
||||||
run_ld_link_tests {
|
run_ld_link_tests {
|
||||||
{"-Bsymbolic-functions"
|
{"-Bsymbolic-functions"
|
||||||
"-shared -Bsymbolic-functions" "" ""
|
"-shared -Bsymbolic-functions" "" ""
|
||||||
{symbolic-func.s} {{readelf {-r --wide} symbolic-func.r}}
|
{symbolic-func.s} {{readelf {-r --wide} symbolic-func.r}}
|
||||||
"symbolic-func.so"}
|
"symbolic-func.so"}
|
||||||
}
|
} "tic6x-*-*" "mips*-*-*" "bfin-*-*"
|
||||||
|
|
||||||
# xfail on tic6x due to non-PIC/non-PID warnings
|
# xfail on tic6x due to non-PIC/non-PID warnings
|
||||||
setup_xfail "tic6x-*-*"
|
|
||||||
run_ld_link_tests {
|
run_ld_link_tests {
|
||||||
{"Build pr20995.so"
|
{"Build pr20995.so"
|
||||||
"-shared" "" ""
|
"-shared" "" ""
|
||||||
{pr20995b.s} {} "pr20995.so"}
|
{pr20995b.s} {} "pr20995.so"}
|
||||||
}
|
} "tic6x-*-*"
|
||||||
setup_xfail "tic6x-*-*"
|
|
||||||
# xfail on arm*-*-eabi*. The list can be enlarged to those targets that
|
# xfail on arm*-*-eabi*. The list can be enlarged to those targets that
|
||||||
# don't support GNU_RELRO. For more details, please see discussions at:
|
# don't support GNU_RELRO. For more details, please see discussions at:
|
||||||
# https://sourceware.org/ml/binutils/2017-01/msg00441.html
|
# https://sourceware.org/ml/binutils/2017-01/msg00441.html
|
||||||
setup_xfail "arm*-*-eabi*" "hppa*64*-*-hpux*"
|
|
||||||
run_ld_link_tests {
|
run_ld_link_tests {
|
||||||
{"Build pr20995-2.so"
|
{"Build pr20995-2.so"
|
||||||
"-shared -z relro" "" ""
|
"-shared -z relro" "" ""
|
||||||
{pr20995c.s} {{readelf {-l --wide} pr20995-2so.r}} "pr20995-2.so"}
|
{pr20995c.s} {{readelf {-l --wide} pr20995-2so.r}} "pr20995-2.so"}
|
||||||
}
|
} "tic6x-*-*" "arm*-*-eabi*" "hppa*64*-*-hpux*"
|
||||||
|
|
||||||
# These targets don't copy dynamic variables into .bss.
|
# These targets don't copy dynamic variables into .bss.
|
||||||
setup_xfail "alpha-*-*" "bfin-*-*" "ia64-*-*" "xtensa-*-*"
|
setup_xfail "alpha-*-*" "bfin-*-*" "ia64-*-*" "xtensa-*-*"
|
||||||
# or don't have .data.rel.ro
|
# or don't have .data.rel.ro
|
||||||
@ -196,6 +182,7 @@ if { [check_shared_lib_support] } then {
|
|||||||
"pr20995" \
|
"pr20995" \
|
||||||
"" "tmpdir/pr20995.so" "$AFLAGS_NONPIC" \
|
"" "tmpdir/pr20995.so" "$AFLAGS_NONPIC" \
|
||||||
{pr20995a.s} {{readelf {-S --wide} pr20995.r}} "pr20995"]]
|
{pr20995a.s} {{readelf {-S --wide} pr20995.r}} "pr20995"]]
|
||||||
|
|
||||||
# xfail on arm*-*-eabi* is particularly because of no support of GNU_RELRO.
|
# xfail on arm*-*-eabi* is particularly because of no support of GNU_RELRO.
|
||||||
# Please see the link above for details.
|
# Please see the link above for details.
|
||||||
setup_xfail "alpha-*-*" "bfin-*-*" "ia64-*-*" "xtensa-*-*" "arm*-*-eabi*"
|
setup_xfail "alpha-*-*" "bfin-*-*" "ia64-*-*" "xtensa-*-*" "arm*-*-eabi*"
|
||||||
|
Reference in New Issue
Block a user