diff options
author | Jiong Wang <jiong.wang@arm.com> | 2017-01-23 09:59:10 +0000 |
---|---|---|
committer | Jiong Wang <jiong.wang@arm.com> | 2017-01-23 09:59:10 +0000 |
commit | 9966f7eece39ced8a09c190616b5b328bf97bfe5 (patch) | |
tree | 1b0f298f3af6a9e35d8e794d21d6578c5bfc7fd0 /ld | |
parent | dcd310a08c9ab601b9dc883e706371f1232cdfef (diff) | |
download | gdb-9966f7eece39ced8a09c190616b5b328bf97bfe5.zip gdb-9966f7eece39ced8a09c190616b5b328bf97bfe5.tar.gz gdb-9966f7eece39ced8a09c190616b5b328bf97bfe5.tar.bz2 |
[ld, testsuite] Honor cflags when GCC used as linker driver
ld/
* testsuite/lib/ld-lib.exp (run_ld_link_exec_tests): Append
board_cflags as gcc is used as linker driver.
* testsuite/ld-unique/unique.exp: Likewise
Diffstat (limited to 'ld')
-rw-r--r-- | ld/ChangeLog | 6 | ||||
-rw-r--r-- | ld/testsuite/ld-unique/unique.exp | 11 | ||||
-rw-r--r-- | ld/testsuite/lib/ld-lib.exp | 13 |
3 files changed, 28 insertions, 2 deletions
diff --git a/ld/ChangeLog b/ld/ChangeLog index c710222..3461444 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,9 @@ +2017-01-23 Jiong Wang <jiong.wang@arm.com> + + * testsuite/lib/ld-lib.exp (run_ld_link_exec_tests): Append + board_cflags as gcc is used as linker driver. + * testsuite/ld-unique/unique.exp: Likewise + 2017-01-20 Jiong Wang <jiong.wang@arm.com> * testsuite/ld-aarch64/aarch64-elf.exp (aarch64elflinktests): New tests. diff --git a/ld/testsuite/ld-unique/unique.exp b/ld/testsuite/ld-unique/unique.exp index 0aecf01..f06622f 100644 --- a/ld/testsuite/ld-unique/unique.exp +++ b/ld/testsuite/ld-unique/unique.exp @@ -108,8 +108,17 @@ if ![ld_compile "$CC -c" "$srcdir/$subdir/unique_empty.s" "tmpdir/unique_empty.o set fails [expr $fails + 1] } +# When using GCC as the linker driver, we need to specify board cflags when +# linking because cflags may contain linker options. For example when linker +# options are included in GCC spec files then we need the -specs option. +if [board_info [target_info name] exists cflags] { + set board_cflags " [board_info [target_info name] cflags]" +} else { + set board_cflags "" +} + # Create executable containing unique symbol. -if ![ld_link $CC "tmpdir/unique_prog" "tmpdir/unique.o"] { +if ![ld_link "$CC $board_cflags" "tmpdir/unique_prog" "tmpdir/unique.o"] { fail "Could not link a unique executable" set fails [expr $fails + 1] } diff --git a/ld/testsuite/lib/ld-lib.exp b/ld/testsuite/lib/ld-lib.exp index 5ca700b..a44358e 100644 --- a/ld/testsuite/lib/ld-lib.exp +++ b/ld/testsuite/lib/ld-lib.exp @@ -1381,6 +1381,17 @@ proc run_ld_link_exec_tests { ldtests args } { global CXXFLAGS global errcnt global exec_output + global board_cflags + + # When using GCC as the linker driver, we need to specify board cflags when + # linking because cflags may contain linker options. For example when + # linker options are included in GCC spec files then we need the -specs + # option. + if [board_info [target_info name] exists cflags] { + set board_cflags " [board_info [target_info name] cflags]" + } else { + set board_cflags "" + } foreach testitem $ldtests { foreach target $args { @@ -1440,7 +1451,7 @@ proc run_ld_link_exec_tests { ldtests args } { # compile only pass $testname continue; - } elseif ![$link_proc $link_cmd $binfile "-L$srcdir/$subdir $ld_options $objfiles"] { + } elseif ![$link_proc $link_cmd $binfile "$board_cflags -L$srcdir/$subdir $ld_options $objfiles"] { set failed 1 } |