summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon Marchi <simon.marchi@efficios.com>2022-04-07 15:08:57 -0400
committerSimon Marchi <simon.marchi@efficios.com>2022-04-08 09:55:29 -0400
commit0c80fce42a81d306ba92d8c044778227a1e5a5e0 (patch)
tree44c3b631eaa9b56c9e1967bac09c5ca53098f90a
parent129f0aaa9d8179a2562a9c4d88e8d4d6e9d8096e (diff)
downloadbinutils-gdb-0c80fce42a81d306ba92d8c044778227a1e5a5e0.tar.gz
gdb/testsuite: use nopie in gdb.dwarf2/dw2-inline-param.exp
I see this failure: (gdb) run ^M Starting program: /home/smarchi/build/binutils-gdb/gdb/testsuite/outputs/gdb.dwarf2/dw2-inline-param/dw2-inline-param ^M Warning:^M Cannot insert breakpoint 1.^M Cannot access memory at address 0x113b^M ^M (gdb) FAIL: gdb.dwarf2/dw2-inline-param.exp: runto: run to *0x113b The test loads the binary in GDB, grabs the address of a symbol, strips the binary, reloads it in GDB, runs the program, and then tries to place a breakpoint at that address. The problem is that the binary is built as position independent, so the address GDB grabs in the first place isn't where the code ends up after running. Fix this by linking the binary as non-position-independent. The alternative would be to compute the relocated address where to place the breakpoint, but that's not very straightforward, unfortunately. I was confused for a while, I was trying to load the binary in GDB manually to get the symbol address, but GDB was telling me the symbol could not be found. Meanwhile, it clearly worked in gdb.log. The thing is that GDB strips the binary in-place, so we don't have access to the intermediary binary with symbols. Change the test to output the stripped binary to a separate file instead. Change-Id: I66c56293df71b1ff49cf748d6784bd0e935211ba
-rw-r--r--gdb/testsuite/gdb.dwarf2/dw2-inline-param.exp8
1 files changed, 5 insertions, 3 deletions
diff --git a/gdb/testsuite/gdb.dwarf2/dw2-inline-param.exp b/gdb/testsuite/gdb.dwarf2/dw2-inline-param.exp
index 3cb11c8c014..c0675141012 100644
--- a/gdb/testsuite/gdb.dwarf2/dw2-inline-param.exp
+++ b/gdb/testsuite/gdb.dwarf2/dw2-inline-param.exp
@@ -21,8 +21,10 @@ if {![dwarf2_support]} {
standard_testfile .S -main.c
+set binfile_stripped ${binfile}-stripped
+
if { [prepare_for_testing "failed to prepare" "${testfile}" \
- [list $srcfile2 $srcfile] {nodebug}] } {
+ [list $srcfile2 $srcfile] {nodebug nopie}] } {
return -1
}
@@ -40,7 +42,7 @@ gdb_unload
# Strip out any labels there as they could corrupt the `main' name.
set objcopy_program [gdb_find_objcopy]
-set command "$objcopy_program -N block_start -N block_end -N break_at ${binfile}"
+set command "$objcopy_program -N block_start -N block_end -N break_at ${binfile} ${binfile_stripped}"
verbose -log "Executing: $command"
set result [catch "exec $command" output]
verbose "result is $result"
@@ -49,7 +51,7 @@ if {$result != 0} {
return -1
}
-gdb_load ${binfile}
+gdb_load ${binfile_stripped}
if ![runto "*${break_at}"] {
return -1