Enable hardware watchpoints on attach for aarch64
This commit fixes a bug whereby hardware watchpoints are not used on aarch64 when attaching to a target. The fix adds an aarch64 specialization of post_attach which records the number of available hardware debug registers using aarch64_linux_get_debug_reg_capacity. This implementation mirrors that of aarch64_linux_child_post_startup_inferior which successfully enables the use of hardware watchpoints when launching the target under the debugger. gdb/ChangeLog: * aarch64-linux-nat.c (post_attach): New. (aarch64_linux_nat_target::post_attach): Override post_attach to record the number of hardware debug registers. gdb/testsuite/ChangeLog: * gdb.base/watchpoint-hw-attach.c: New test. * gdb.base/watchpoint-hw-attach.exp: New file.
This commit is contained in:
parent
57c0d77c2c
commit
8363f9d5f2
@ -1,3 +1,10 @@
|
||||
2018-06-21 Richard Bunt <richard.bunt@arm.com>
|
||||
Dirk Schubert <dirk.schubert@arm.com>
|
||||
|
||||
* aarch64-linux-nat.c (post_attach): New.
|
||||
(aarch64_linux_nat_target::post_attach): Override post_attach to
|
||||
record the number of hardware debug registers.
|
||||
|
||||
2018-06-20 Tom Tromey <tom@tromey.com>
|
||||
|
||||
* python/py-param.c (add_setshow_generic): Make parameters const.
|
||||
|
@ -77,6 +77,9 @@ public:
|
||||
/* Override the GNU/Linux inferior startup hook. */
|
||||
void post_startup_inferior (ptid_t) override;
|
||||
|
||||
/* Override the GNU/Linux post attach hook. */
|
||||
void post_attach (int pid) override;
|
||||
|
||||
/* These three defer to common nat/ code. */
|
||||
void low_new_thread (struct lwp_info *lp) override
|
||||
{ aarch64_linux_new_thread (lp); }
|
||||
@ -568,6 +571,21 @@ aarch64_linux_nat_target::post_startup_inferior (ptid_t ptid)
|
||||
linux_nat_target::post_startup_inferior (ptid);
|
||||
}
|
||||
|
||||
/* Implement the "post_attach" target_ops method. */
|
||||
|
||||
void
|
||||
aarch64_linux_nat_target::post_attach (int pid)
|
||||
{
|
||||
low_forget_process (pid);
|
||||
/* Set the hardware debug register capacity. If
|
||||
aarch64_linux_get_debug_reg_capacity is not called
|
||||
(as it is in aarch64_linux_child_post_startup_inferior) then
|
||||
software watchpoints will be used instead of hardware
|
||||
watchpoints when attaching to a target. */
|
||||
aarch64_linux_get_debug_reg_capacity (pid);
|
||||
linux_nat_target::post_attach (pid);
|
||||
}
|
||||
|
||||
extern struct target_desc *tdesc_arm_with_neon;
|
||||
|
||||
/* Implement the "read_description" target_ops method. */
|
||||
|
@ -1,3 +1,8 @@
|
||||
2018-06-21 Richard Bunt <richard.bunt@arm.com>
|
||||
|
||||
* gdb.base/watchpoint-hw-attach.c: New test.
|
||||
* gdb.base/watchpoint-hw-attach.exp: New file.
|
||||
|
||||
2018-06-20 Simon Marchi <simon.marchi@ericsson.com>
|
||||
|
||||
* boards/cc-with-tweaks.exp: Don't call cc-with-tweaks.sh
|
||||
|
44
gdb/testsuite/gdb.base/watchpoint-hw-attach.c
Normal file
44
gdb/testsuite/gdb.base/watchpoint-hw-attach.c
Normal file
@ -0,0 +1,44 @@
|
||||
/* This testcase is part of GDB, the GNU debugger.
|
||||
|
||||
Copyright 2018 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 <sys/types.h>
|
||||
#include <unistd.h>
|
||||
|
||||
/* This is set to 1 by the debugger post attach to continue to the
|
||||
watchpoint trigger. */
|
||||
volatile int should_continue = 0;
|
||||
/* The variable to place a watchpoint on. */
|
||||
volatile int watched_variable = 0;
|
||||
|
||||
int
|
||||
main (void)
|
||||
{
|
||||
unsigned int counter = 1;
|
||||
int mypid = getpid ();
|
||||
|
||||
/* Wait for the debugger to attach, but not indefinitely so this
|
||||
test program is not left hanging around. */
|
||||
for (counter = 0; !should_continue && counter < 100; counter++)
|
||||
sleep (1); /* pidacquired */
|
||||
|
||||
watched_variable = 0; /* prewatchtrigger */
|
||||
/* Trigger a watchpoint. */
|
||||
watched_variable = 4;
|
||||
printf ("My variable is %d\n", watched_variable);
|
||||
return 0;
|
||||
}
|
71
gdb/testsuite/gdb.base/watchpoint-hw-attach.exp
Normal file
71
gdb/testsuite/gdb.base/watchpoint-hw-attach.exp
Normal file
@ -0,0 +1,71 @@
|
||||
# Copyright 2018 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/>.
|
||||
|
||||
# watchpoint-hw-attach.exp -- Test if hardware watchpoints are used
|
||||
# when attaching to a target.
|
||||
|
||||
if {[skip_hw_watchpoint_tests]} {
|
||||
return 0
|
||||
}
|
||||
|
||||
if {![can_spawn_for_attach]} {
|
||||
return 0
|
||||
}
|
||||
|
||||
standard_testfile
|
||||
|
||||
if {[prepare_for_testing "failed to prepare" $testfile $srcfile debug]} {
|
||||
return -1
|
||||
}
|
||||
|
||||
clean_restart $binfile
|
||||
|
||||
if ![runto_main] {
|
||||
untested "can't run to main"
|
||||
return -1
|
||||
}
|
||||
|
||||
# Run to the point where mypid in the test program has been
|
||||
# populated.
|
||||
gdb_breakpoint [gdb_get_line_number "pidacquired"]
|
||||
gdb_continue_to_breakpoint "pidacquired"
|
||||
|
||||
# Get the PID of the test process.
|
||||
set testpid [get_integer_valueof "mypid" 0]
|
||||
|
||||
gdb_test "detach" "Detaching from program: .*, process $testpid\r\n\\\[Inferior $decimal \\(process $testpid\\) detached\\\]"
|
||||
|
||||
if {$testpid == ""} {
|
||||
return -1
|
||||
}
|
||||
|
||||
# A clean restart is needed to force the hardware watchpoint setup
|
||||
# logic to run post attach rather than post inferior launch.
|
||||
clean_restart $binfile
|
||||
|
||||
gdb_test "attach $testpid" "Attaching to program: .*, process $testpid.*"
|
||||
|
||||
gdb_test_no_output "set should_continue = 1"
|
||||
|
||||
# Ensure the test program is in the top frame so the required
|
||||
# variables are in scope.
|
||||
gdb_breakpoint [gdb_get_line_number "prewatchtrigger"]
|
||||
gdb_continue_to_breakpoint "prewatchtrigger"
|
||||
|
||||
gdb_test "watch watched_variable" \
|
||||
"Hardware watchpoint $decimal: watched_variable"
|
||||
|
||||
gdb_test "continue" \
|
||||
"continue.*Continuing.*\.Hardware watchpoint $decimal: watched_variable.*Old value = 0.*New value = 4.*watched_variable\\);"
|
Loading…
x
Reference in New Issue
Block a user