From: Alan Modra Date: Wed, 29 Jun 2022 00:40:15 +0000 (+0930) Subject: Re: ld/x86: skip p_align-1 tests with unsuitable compiler X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=22a8ddfe934283113c8e88de3b49caee40343e14;p=binutils-gdb.git Re: ld/x86: skip p_align-1 tests with unsuitable compiler commit d0e0f9c87a3e results "ERROR: i586-linux-cc does not exist" if cross-building an i586-linux target without a target compiler installed. * testsuite/ld-elf/linux-x86.exp (compiler_honours_aligned): New. Use it after first testing check_compiler_available. --- diff --git a/ld/testsuite/ld-elf/linux-x86.exp b/ld/testsuite/ld-elf/linux-x86.exp index ae0ed6ac0d2..6035ecd6829 100644 --- a/ld/testsuite/ld-elf/linux-x86.exp +++ b/ld/testsuite/ld-elf/linux-x86.exp @@ -188,9 +188,17 @@ run_ld_link_exec_tests [list \ ] # Old gcc silently ignores __attribute__ ((aligned())) with too big alignment. -ld_compile $CC_FOR_TARGET $srcdir/$subdir/p_align-1.c tmpdir/p_align-1.o -set output [run_host_cmd "$READELF" "-SW tmpdir/p_align-1.o"] -if { [regexp { [.]data *PROGBITS .* 8388608[\n]} $output] } then { +proc compiler_honours_aligned { } { + global CC_FOR_TARGET READELF srcdir subdir + ld_compile $CC_FOR_TARGET $srcdir/$subdir/p_align-1.c tmpdir/p_align-1.o + set output [run_host_cmd "$READELF" "-SW tmpdir/p_align-1.o"] + if { [regexp { [.]data *PROGBITS .* 8388608[\n]} $output] } { + return 1 + } + return 0 +} + +if { [check_compiler_available] && [compiler_honours_aligned] } { run_ld_link_exec_tests [list \ [list \ "Run p_align-1a without PIE" \