This is the mail archive of the gdb-patches@sourceware.org mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

[commit] [patch 1/3] Remove stale dummy frames (gdb2495.exp regression)


On Wed, 13 Jun 2012 17:49:20 +0200, Jan Kratochvil wrote:
> gdb/
> 2012-06-13  Jan Kratochvil  <jan.kratochvil@redhat.com>
> 
> 	Remove stale dummy frames.
> 	* breakpoint.c: Include dummy-frame.h.
> 	(longjmp_breakpoint_ops): New variable.
> 	(update_breakpoints_after_exec, breakpoint_init_inferior): Delete also
> 	bp_longjmp_call_dummy.
> 	(bpstat_what, bptype_string, print_one_breakpoint_location)
> 	(init_bp_location): Support bp_longjmp_call_dummy.
> 	(set_longjmp_breakpoint): Use longjmp_breakpoint_ops.  Comment why.
> 	(set_longjmp_breakpoint_for_call_dummy)
> 	(check_longjmp_breakpoint_for_call_dummy, longjmp_bkpt_dtor): New
> 	functions.
> 	(initialize_breakpoint_ops): Initialize longjmp_breakpoint_ops.
> 	* breakpoint.h (enum bptype): New item bp_longjmp_call_dummy.  Delete
> 	FIXME comment and extend the other comment for bp_call_dummy.
> 	(set_longjmp_breakpoint_for_call_dummy)
> 	(check_longjmp_breakpoint_for_call_dummy): New declarations.
> 	* dummy-frame.c: Include gdbthread.h.
> 	(pop_dummy_frame_bpt): New function.
> 	(pop_dummy_frame): Call pop_dummy_frame_bpt.
> 	(dummy_frame_discard): New function.
> 	(cleanup_dummy_frames): Update the comment about longjmps.
> 	* dummy-frame.h (dummy_frame_discard): New declaration.
> 	* gdbthread.h (struct thread_info): Extend initiating_frame comment.
> 	* infcall.c (call_function_by_hand): New variable longjmp_b.  Call
> 	set_longjmp_breakpoint_for_call_dummy.  Chain its breakpoints with BPT.
> 	* infrun.c (handle_inferior_event) <BPSTAT_WHAT_CLEAR_LONGJMP_RESUME>:
> 	Add case 4 comment.  Call check_longjmp_breakpoint_for_call_dummy and
> 	keep_going if IS_LONGJMP and there is no other reason to stop.
> 
> Gdb/testsuite/
> 2012-06-13  Jan Kratochvil  <jan.kratochvil@redhat.com>
> 
> 	Remove stale dummy frames.
> 	* gdb.base/call-signal-resume.exp (maintenance print dummy-frames)
> 	(maintenance info breakpoints): New tests.
> 	* gdb.base/stale-infcall.c: New file.
> 	* gdb.base/stale-infcall.exp: New file.

Checked in after Mark's comment:
	http://sourceware.org/ml/gdb-cvs/2012-06/msg00139.html

FYI the stale dummy frames removal across longjmps has not yet been tested
anywhere (in Fedora); the other parts have been tested for several months.


Thanks,
Jan


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]