gdb/testsuite: link some dwarf2 tests with nopie
authorSimon Marchi <simon.marchi@polymtl.ca>
Wed, 5 Aug 2020 21:38:28 +0000 (17:38 -0400)
committerSimon Marchi <simon.marchi@efficios.com>
Wed, 5 Aug 2020 21:38:28 +0000 (17:38 -0400)
I noticed some gdb.dwarf2 tests not running on my machine because of
this:

    Running /home/simark/src/binutils-gdb/gdb/testsuite/gdb.dwarf2/dw2-single-line-discriminators.exp ...
    gdb compile failed, /usr/bin/ld: /home/simark/build/binutils-gdb/gdb/testsuite/outputs/gdb.dwarf2/dw2-single-line-discriminators/dw2-single-line-discriminators0.o: relocation R_X86_64_32S against
     symbol `x' can not be used when making a PIE object; recompile with -fPIE
    collect2: error: ld returned 1 exit status

We get this when the target toolchain produces position-independent
executables by default.  These tests are built from some assembly which
produces some relocations incompatible with position-independent
executables.

Add `nopie` to the compilation flags of these tests to force the
toolchain to produce non-position-independent executables.  With this,
the changed tests run successfully on my machine.

gdb/ChangeLog:

* gdb.dwarf2/clztest.exp, gdb.dwarf2/dw2-common-block.exp,
gdb.dwarf2/dw2-dup-frame.exp, gdb.dwarf2/dw2-reg-undefined.exp,
gdb.dwarf2/dw2-single-line-discriminators.exp,
dw2-undefined-ret-addr.exp: Pass nopie to compilation options.

Change-Id: Ie06c946f8e56a6030be247d1c57f416fa8b67e4c

gdb/ChangeLog
gdb/testsuite/gdb.dwarf2/clztest.exp
gdb/testsuite/gdb.dwarf2/dw2-common-block.exp
gdb/testsuite/gdb.dwarf2/dw2-dup-frame.exp
gdb/testsuite/gdb.dwarf2/dw2-reg-undefined.exp
gdb/testsuite/gdb.dwarf2/dw2-single-line-discriminators.exp
gdb/testsuite/gdb.dwarf2/dw2-undefined-ret-addr.exp

index fc4fe7cdaac2ecba3b875d3e7428fa360e5b943a..1d510321d3b2e896eed82ac32ffcfabdaacf1c34 100644 (file)
@@ -1,3 +1,10 @@
+2020-08-05  Simon Marchi  <simon.marchi@polymtl.ca>
+
+       * gdb.dwarf2/clztest.exp, gdb.dwarf2/dw2-common-block.exp,
+       gdb.dwarf2/dw2-dup-frame.exp, gdb.dwarf2/dw2-reg-undefined.exp,
+       gdb.dwarf2/dw2-single-line-discriminators.exp,
+       dw2-undefined-ret-addr.exp: Pass nopie to compilation options.
+
 2020-08-05  Tom Tromey  <tromey@adacore.com>
 
        PR rust/26197:
index b83b4a94e92e8e7c00404e61e0ff2f38b6a44107..95c326660f5266b4012d7f9344a4155e6621f3a1 100644 (file)
@@ -28,7 +28,8 @@ if {![istarget x86_64-*] || ![is_lp64_target]} {
     return 0
 }
 
-if { [prepare_for_testing "failed to prepare" "${test}" ${test}.S {nodebug additional_flags=-nostdlib}] } {
+if { [prepare_for_testing "failed to prepare" "${test}" ${test}.S \
+      {nodebug nopie additional_flags=-nostdlib}] } {
     return -1
 }
 
index 9bcf06b17f9d3b4b3dd2aebf0402916bd3bd7d6f..6a10ced6cacd7995f459da1a4f92a03646a2d533 100644 (file)
@@ -33,7 +33,7 @@ if {[skip_fortran_tests]} {
 standard_testfile .S
 
 if { [prepare_for_testing "failed to prepare" "${testfile}" $srcfile \
-         {nodebug f90}] } {
+      {nodebug nopie f90}] } {
     return -1
 }
 
index 0c2c88e9c711c0a5512fa3a7cd85ae5c71bda263..b6151084f208bad86593a198ed12562edc72afe3 100644 (file)
@@ -26,7 +26,7 @@ if {![istarget "x86_64-*-*"] || ![is_lp64_target]} {
 
 standard_testfile .S
 
-if { [prepare_for_testing "failed to prepare" $testfile $srcfile {nodebug}] } {
+if { [prepare_for_testing "failed to prepare" $testfile $srcfile {nodebug nopie}] } {
     return -1
 }
 
index 564ca91ab9bffc64f70d1eaaff4339a14eea7ffb..29564face30b6fe97042b6722d203250578755c9 100644 (file)
@@ -26,7 +26,7 @@ if {![istarget "x86_64-*-*"] || ![is_lp64_target]} {
 
 standard_testfile .S
 
-if { [prepare_for_testing "failed to prepare" $testfile $srcfile {nodebug}] } {
+if { [prepare_for_testing "failed to prepare" $testfile $srcfile {nodebug nopie}] } {
     return -1
 }
 
index 4ca258a3f1433ce02efefecc13ea19b9730bf9fb..9803ef829a84b415efdb61fffee768177a0789d7 100644 (file)
@@ -31,7 +31,7 @@ if {![istarget x86_64-*] || ![is_lp64_target]} {
 standard_testfile .S
 set csrcfile ${testfile}.c
 
-if { [prepare_for_testing "failed to prepare" "${testfile}" $srcfile {nodebug}] } {
+if { [prepare_for_testing "failed to prepare" "${testfile}" $srcfile {nodebug nopie}] } {
     return -1
 }
 
index e78d7112bed465e8067ebeaabb3bcce4902e1ff8..668ecfc9ab7fa5d4069b072ec20ce85506303020 100644 (file)
@@ -26,7 +26,7 @@ if {![istarget x86_64-*] || ![is_lp64_target]} {
     return 0
 }
 
-if {[prepare_for_testing "failed to prepare" "$testfile" $srcfile {nodebug}]} {
+if {[prepare_for_testing "failed to prepare" "$testfile" $srcfile {nodebug nopie}]} {
     return -1
 }