diff options
author | Jan Kratochvil <jan.kratochvil@redhat.com> | 2010-10-17 17:45:17 +0000 |
---|---|---|
committer | Jan Kratochvil <jan.kratochvil@redhat.com> | 2010-10-17 17:45:17 +0000 |
commit | c1e56572463d2126e46eda8ce8d4bce221667f98 (patch) | |
tree | 3f7dae8a1dd565c8c77dc068337ad5896d2f91ce /gdb/testsuite/gdb.base | |
parent | 0c91cf04574d756ea883ec506a84fb7ac9589459 (diff) | |
download | gdb-c1e56572463d2126e46eda8ce8d4bce221667f98.zip gdb-c1e56572463d2126e46eda8ce8d4bce221667f98.tar.gz gdb-c1e56572463d2126e46eda8ce8d4bce221667f98.tar.bz2 |
gdb/
* infrun.c (follow_exec): Replace symbol_file_add_main by
symbol_file_add with SYMFILE_DEFER_BP_RESET, set_initial_language and
breakpoint_re_set.
* m32r-rom.c (m32r_load, m32r_upload_command): Use parameter 0 for
clear_symtab_users.
* objfiles.c (free_all_objfiles): Likewise.
* remote-m32r-sdi.c (m32r_load): Likewise.
* solib-som.c (som_solib_create_inferior_hook): Likewise.
* symfile.c (new_symfile_objfile): New comment for add_flags. Call
clear_symtab_users with ADD_FLAGS.
(reread_symbols): Use parameter 0 for clear_symtab_users.
(clear_symtab_users): New parameter add_flags. Do not call
breakpoint_re_set if SYMFILE_DEFER_BP_RESET.
(clear_symtab_users_cleanup): Use parameter 0 for clear_symtab_users.
* symtab.h (clear_symtab_users): New parameter add_flags.
gdb/testsuite/
* gdb.base/pie-execl.exp: New file.
* gdb.base/pie-execl.c: New file.
Diffstat (limited to 'gdb/testsuite/gdb.base')
-rw-r--r-- | gdb/testsuite/gdb.base/pie-execl.c | 51 | ||||
-rw-r--r-- | gdb/testsuite/gdb.base/pie-execl.exp | 100 |
2 files changed, 151 insertions, 0 deletions
diff --git a/gdb/testsuite/gdb.base/pie-execl.c b/gdb/testsuite/gdb.base/pie-execl.c new file mode 100644 index 0000000..6c33769 --- /dev/null +++ b/gdb/testsuite/gdb.base/pie-execl.c @@ -0,0 +1,51 @@ +/* This testcase is part of GDB, the GNU debugger. + + Copyright 2010 Free Software Foundation, Inc. + + 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, see <http://www.gnu.org/licenses/>. */ + +#include <stdio.h> +#include <unistd.h> +#include <assert.h> + +static void pie_execl_marker (void); + +int +main (int argc, char **argv) +{ + setbuf (stdout, NULL); + +#if BIN == 1 + if (argc == 2) + { + printf ("pie-execl: re-exec: %s\n", argv[1]); + execl (argv[1], argv[1], NULL); + assert (0); + } +#endif + + pie_execl_marker (); + + return 0; +} + +/* pie_execl_marker must be on a different address than in `pie-execl2.c'. */ + +volatile int v; + +static void +pie_execl_marker (void) +{ + v = 1; +} diff --git a/gdb/testsuite/gdb.base/pie-execl.exp b/gdb/testsuite/gdb.base/pie-execl.exp new file mode 100644 index 0000000..b9c74ae --- /dev/null +++ b/gdb/testsuite/gdb.base/pie-execl.exp @@ -0,0 +1,100 @@ +# Copyright 2010 Free Software Foundation, Inc. + +# 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, see <http://www.gnu.org/licenses/>. + +# The problem was due to amd64_skip_prologue attempting to access inferior +# memory before the PIE (Position Independent Executable) gets relocated. + +if ![istarget *-linux*] { + continue +} + +# Remote protocol does not support follow-exec notifications. + +if [is_remote target] { + continue +} + +set testfile "pie-execl" +set srcfile ${testfile}.c +set executable1 ${testfile}1 +set executable2 ${testfile}2 +set binfile1 ${objdir}/${subdir}/${executable1} +set binfile2 ${objdir}/${subdir}/${executable2} + +# Use conditional compilation according to `BIN' as GDB remembers the source +# file name of the breakpoint. + +set opts [list debug {additional_flags=-fPIE -pie}] +if {[build_executable ${testfile}.exp $executable1 $srcfile [concat $opts {additional_flags=-DBIN=1}]] == "" + || [build_executable ${testfile}.exp $executable2 $srcfile [concat $opts {additional_flags=-DBIN=2}]] == ""} { + return -1 +} + +clean_restart ${executable1} + +gdb_test_no_output "set args ${binfile2}" + +if ![runto_main] { + return -1 +} + +# Do not stop on `main' after re-exec. +delete_breakpoints + +gdb_breakpoint "pie_execl_marker" +gdb_test "info breakpoints" ".*" "" + +set addr1 "" +set test "pie_execl_marker address first" +gdb_test_multiple "p/x &pie_execl_marker" $test { + -re " = (0x\[0-9a-f\]+)\r\n$gdb_prompt $" { + set addr1 $expect_out(1,string) + pass $test + } +} +verbose -log "addr1 is $addr1" + +set test "continue" +gdb_test_multiple $test $test { + -re "Error in re-setting breakpoint" { + fail $test + } + -re "Cannot access memory" { + fail $test + } + -re "pie-execl: re-exec.*executing new program.*\r\nBreakpoint \[0-9\]+,\[^\r\n\]* pie_execl_marker .*\r\n$gdb_prompt $" { + pass $test + } +} + +gdb_test "info breakpoints" ".*" "" + +set addr2 "" +set test "pie_execl_marker address second" +gdb_test_multiple "p/x &pie_execl_marker" $test { + -re " = (0x\[0-9a-f\]+)\r\n$gdb_prompt $" { + set addr2 $expect_out(1,string) + pass $test + } +} +verbose -log "addr2 is $addr2" + +# Ensure we cannot get a false PASS and the inferior has really changed. +set test "pie_execl_marker address has changed" +if [string equal $addr1 $addr2] { + fail $test +} else { + pass $test +} |