mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-06 12:09:26 +08:00
669d511534
Fixes a few issues: 1) If you use "-fsanitize=address,undefined" in CFLAGS, the Makefile attempt to trim off -fsanitize options left us with ",undefined". 2) ld_compile adds CFLAGS_FOR_TARGET itself, no need to pass it. 3) CFLAGS might be needed linking bootstrap test. * Makefile.am (CFLAGS_FOR_TARGET, CXXFLAGS_FOR_TARGET): Trim off all -fsanitize=*. * Makefile.in: Regenerate. * testsuite/ld-bootstrap/bootstrap.exp: Use CFLAGS when linking. * testsuite/ld-cdtest/cdtest.exp: Use CFLAGS_FOR_TARGET when linking. * testsuite/ld-auto-import/auto-import.exp: Don't pass CFLAGS_FOR_TARGET to ld_compile. * testsuite/ld-cygwin/exe-export.exp: Likewise. * testsuite/ld-elfvers/vers.exp: Likewise. * testsuite/ld-elfvsb/elfvsb.exp: Likewise. * testsuite/ld-elfweak/elfweak.exp: Likewise. * testsuite/ld-gc/gc.exp: Likewise. * testsuite/ld-pe/pe-compile.exp: Likewise. * testsuite/ld-pe/pe-run.exp: Likewise. * testsuite/ld-pe/pe-run2.exp: Likewise. * testsuite/ld-plugin/plugin.exp: Likewise. * testsuite/ld-shared/shared.exp: Likewise. * testsuite/ld-elfcomm/elfcomm.exp: Likewise, and don't allow nios2 testing to trash CFLAGS_FOR_TARGET. * testsuite/ld-scripts/crossref.exp: Don't pass options in CC_FOR_TARGET, do so in CFLAGS_FOR_TARGET instead. * testsuite/ld-srec/srec.exp: Likewise, and for CXX.
148 lines
4.9 KiB
Plaintext
148 lines
4.9 KiB
Plaintext
# Expect script for complex PE tests that require a C compiler and the ability
|
|
# to run target executables natively, in addition to the just-built binutils.
|
|
# Copyright (C) 2006-2021 Free Software Foundation, Inc.
|
|
#
|
|
# This file is part of the GNU Binutils.
|
|
#
|
|
# This program 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.
|
|
#
|
|
# This program 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, write to the Free Software
|
|
# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
|
|
# MA 02110-1301, USA.
|
|
#
|
|
# Written by Pedro Alves <pedro_alves@portugalmail.pt>
|
|
#
|
|
|
|
# Note:
|
|
#
|
|
# This test checks the "direct linking to a dll" functionality.
|
|
#
|
|
# The test has 7 stages:
|
|
#
|
|
# 1. compile and link a test dll with ".dll" extension.
|
|
#
|
|
# 2. compile and link a test dll with ".sl" (i.e. != ".dll") extension.
|
|
#
|
|
# 3. compile and link a client application linking directly to the ".dll" dll built in 1.
|
|
# This should produce no errors.
|
|
#
|
|
# 4. compile and link a client application linking directly to the ".sl" dll built in 2.
|
|
# This should produce no errors.
|
|
#
|
|
# 5. compile and link a client application linking directly to a symlink into
|
|
# the ".dll" dll built in 1.
|
|
# This should produce no errors.
|
|
#
|
|
# 6. compile and link a client application linking directly to a symlink into
|
|
# the ".sl" dll built in 1.
|
|
# This should produce no errors.
|
|
#
|
|
# 7. run the produced executables
|
|
|
|
# This test can only be run on PE/COFF platforms.
|
|
if {![is_pecoff_format]} {
|
|
return
|
|
}
|
|
|
|
# No compiler, no test.
|
|
if { ![check_compiler_available] } {
|
|
untested "Direct linking to dll test"
|
|
return
|
|
}
|
|
|
|
set tmpdir tmpdir
|
|
|
|
proc test_direct_link_dll {} {
|
|
global CC_FOR_TARGET
|
|
global srcdir
|
|
global subdir
|
|
global tmpdir
|
|
|
|
# Compile the dll.
|
|
if ![ld_compile $CC_FOR_TARGET $srcdir/$subdir/direct_dll.c $tmpdir/direct_dll.o ] {
|
|
fail "compiling shared lib"
|
|
} elseif ![ld_link "$CC_FOR_TARGET -shared" $tmpdir/direct_dll.dll "$tmpdir/direct_dll.o" ] {
|
|
fail "linking shared lib (.dll)"
|
|
} elseif ![ld_link "$CC_FOR_TARGET -shared" $tmpdir/direct_dll.sl "$tmpdir/direct_dll.o" ] {
|
|
fail "linking shared lib (.sl)"
|
|
} else {
|
|
# Compile and link the client program.
|
|
if ![ld_compile $CC_FOR_TARGET $srcdir/$subdir/direct_client.c $tmpdir/direct_client.o ] {
|
|
fail "compiling client"
|
|
} else {
|
|
# Check linking directly to direct_dll.dll.
|
|
set msg "linking client (.dll)"
|
|
if [ld_link "$CC_FOR_TARGET -Wl,--enable-auto-import" $tmpdir/direct_client_dll.exe \
|
|
"$tmpdir/direct_client.o $tmpdir/direct_dll.dll" ] {
|
|
pass $msg
|
|
} else {
|
|
fail $msg
|
|
}
|
|
|
|
# Check linking directly to direct_dll.sl.
|
|
set msg "linking client (.sl)"
|
|
if [ld_link "$CC_FOR_TARGET -Wl,--enable-auto-import" $tmpdir/direct_client_sl.exe \
|
|
"$tmpdir/direct_client.o $tmpdir/direct_dll.sl" ] {
|
|
pass $msg
|
|
} else {
|
|
fail $msg
|
|
}
|
|
|
|
# Check dll direct linking through symlink to .dll.
|
|
# Create symbolic link.
|
|
catch "exec ln -fs direct_dll.dll $tmpdir/libdirect_dll.dll.a" ln_catch
|
|
set msg "linking client (symlink -> .dll)"
|
|
if [ld_link "$CC_FOR_TARGET -Wl,--enable-auto-import" $tmpdir/direct_client_symlink_dll.exe \
|
|
"$tmpdir/direct_client.o $tmpdir/libdirect_dll.dll.a" ] {
|
|
pass $msg
|
|
} else {
|
|
fail $msg
|
|
}
|
|
|
|
# Check dll direct linking through symlink to .sl.
|
|
# Create symbolic link.
|
|
catch "exec ln -fs direct_dll.sl $tmpdir/libdirect_sl.dll.a" ln_catch
|
|
set msg "linking client (symlink -> .sl)"
|
|
if [ld_link "$CC_FOR_TARGET -Wl,--enable-auto-import" $tmpdir/direct_client_symlink_sl.exe \
|
|
"$tmpdir/direct_client.o $tmpdir/libdirect_sl.dll.a" ] {
|
|
pass $msg
|
|
} else {
|
|
fail $msg
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
proc directdll_execute {exe msg} {
|
|
set expected ""
|
|
catch "exec $exe" prog_output
|
|
if [string match $expected $prog_output] then {
|
|
pass $msg
|
|
} else {
|
|
verbose $prog_output
|
|
fail $msg
|
|
}
|
|
}
|
|
|
|
test_direct_link_dll
|
|
|
|
# This is as far as we can go with a cross-compiler
|
|
if ![isnative] then {
|
|
verbose "Not running natively, so cannot execute binaries"
|
|
return
|
|
}
|
|
|
|
directdll_execute "$tmpdir/direct_client_dll.exe" "running direct linked dll (.dll)"
|
|
directdll_execute "$tmpdir/direct_client_sl.exe" "running direct linked dll (.sl)"
|
|
directdll_execute "$tmpdir/direct_client_symlink_sl.exe" "running direct linked dll (symlink -> .sl)"
|
|
directdll_execute "$tmpdir/direct_client_symlink_dll.exe" "running direct linked dll (symlink -> .dll)"
|