diff options
author | Alan Hayward <alan.hayward@arm.com> | 2019-08-21 15:36:37 +0100 |
---|---|---|
committer | Alan Hayward <alan.hayward@arm.com> | 2019-09-02 14:00:42 +0100 |
commit | d90b8f2632cded4792f18d8bb92bacc21d93eb0a (patch) | |
tree | db5986705da30adea805e4f0fae61d0631458260 /gdb/ChangeLog | |
parent | fe01123efb30a273645dc194ae2100197f93a00a (diff) | |
download | gdb-d90b8f2632cded4792f18d8bb92bacc21d93eb0a.zip gdb-d90b8f2632cded4792f18d8bb92bacc21d93eb0a.tar.gz gdb-d90b8f2632cded4792f18d8bb92bacc21d93eb0a.tar.bz2 |
Check arguments for all probes before using them
There is a long standing bug in the Arm toolchain where invalid
stap probes get created due to the probes referring to symbols which
have been resolved away.
More details are here:
https://bugzilla.redhat.com/show_bug.cgi?id=1196181
When these invalid probes are present, GDB will create the breakpoints
and then fail to stop. The errors are only spotted the first time
GDB stops, which is too late.
The solution is to ensure the arguments for all the probes are
resolved before using them.
This fixes >100 timeouts when running break-interp.exp when using
bad probes.
gdb/ChangeLog:
* solib-svr4.c (svr4_find_and_create_probe_breakpoints): Check all
probe arguments.
Diffstat (limited to 'gdb/ChangeLog')
-rw-r--r-- | gdb/ChangeLog | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index d0e4258..08615f4 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,5 +1,10 @@ 2019-09-02 Alan Hayward <alan.hayward@arm.com> + * solib-svr4.c (svr4_find_and_create_probe_breakpoints): Check all + probe arguments. + +2019-09-02 Alan Hayward <alan.hayward@arm.com> + * break-catch-throw.c (fetch_probe_arguments): Use gdbarch. * dtrace-probe.c (dtrace_probe::get_argument_count): Likewise. * probe.c (probe_safe_evaluate_at_pc) (compute_probe_arg) |