[RFA] Implement support for PowerPC BookE ranged breakpoints

Ulrich Weigand uweigand@de.ibm.com
Tue Mar 29 13:10:00 GMT 2011


Thiago Jung Bauermann wrote:

> In this patch I had to modify print_recreate_ranged_breakpoint to use
> addr_string_range_end since I don't use exp_string anymore. I could
> change print_mention_ranged_breakpoint to use it too, since it's
> formatted consistently. However, breakpoint.c:mention doesn't use
> b->addr_string and instead uses b->source_file and b->line_number, so
> I'm not sure if I should use b->addr_string_range_end. I left that out
> for now.

OK, that's fine with me.

> +  /* We call decode_line_n1 directly here instead of using

Typo: decode_line_1

> +     parse_breakpoint_sals because we need to specify the start location's
> +     symtab and line as the default symtab and line for the end of the
> +     range.  This makes it possible to have ranges like "foo.c:27, +14",
> +     where +14 means 14 lines from the start location.  */
> +  sals_end = decode_line_1 (&arg, 1, sal_start.symtab, sal_start.line,
> +                           &canonical_end, NULL);


> 2011-03-27  Thiago Jung Bauermann  <bauerman@br.ibm.com>
> 	    Sergio Durigan Junior  <sergiodj@linux.vnet.ibm.com>
> 
> 	Implement support for PowerPC BookE ranged breakpoints.
> 
> gdb/
> 	* NEWS: Mention support for ranged breakpoints on embedded PowerPC.
> 	* breakpoint.h (struct bp_target_info) <length>: New member
> 	variable.
> 	(struct breakpoint_ops) <breakpoint_hit>: Take struct bp_location
> 	instead of struct breakpoint as argument, and also add ASPACE
> 	and BP_ADDR arguments.  Update all callers.
> 	(struct breakpoint_ops) <print_one_detail>: New method.
> 	(struct breakpoint) <addr_string_range_end>: New member variable.
> 	* breakpoint.c (breakpoint_location_address_match): Add function
> 	prototype.
> 	(insert_bp_location): Set bl->target_info.length.
> 	(breakpoint_here_p): Call breakpoint_location_address_match.
> 	(moribund_breakpoint_here_p): Likewise.
> 	(regular_breakpoint_inserted_here_p): Likewise.
> 	(breakpoint_thread_match): Likewise.
> 	(bpstat_stop_status): Likewise.
> 	(bpstat_check_location): Move call to
> 	breakpoint_ops.breakpoint_hit to the top.
> 	(print_one_breakpoint_location): Call
> 	breakpoint_ops.print_one_detail if available.
> 	(breakpoint_address_match_range): New function.
> 	(breakpoint_location_address_match): Likewise.
> 	(breakpoint_locations_match): Compare the length field of the
> 	locations too.
> 	(hw_breakpoint_used_count): Count resources used by all locations
> 	in a breakpoint, and use breakpoint_ops.resources_needed if
> 	available.
> 	(breakpoint_hit_ranged_breakpoint): New function.
> 	(resources_needed_ranged_breakpoint): Likewise.
> 	(print_it_ranged_breakpoint): Likewise.
> 	(print_one_ranged_breakpoint): Likewise.
> 	(print_one_detail_ranged_breakpoint): Likewise.
> 	(print_mention_ranged_breakpoint): Likewise.
> 	(print_recreate_ranged_breakpoint): Likewise.
> 	(ranged_breakpoint_ops): New structure.
> 	(find_breakpoint_range_end): New function.
> 	(break_range_command): Likewise.
> 	(delete_breakpoint): Free addr_string_range_end.
> 	(update_breakpoint_locations): Add SALS_END argument.  Calculate
> 	breakpoint length if a non-zero SALS_END is given.  Call
> 	breakpoint_locations_match instead of breakpoint_address_match.
> 	(reset_breakpoint): Find SaL of the end of the range if B is a
> 	ranged breakpoint.
> 	(_initialize_breakpoint): Register break-range command.
> 	* defs.h (print_core_address): Add function prototype.
> 	* ppc-linux-nat.c (ppc_linux_ranged_break_num_registers): New
> 	function.
> 	(ppc_linux_insert_hw_breakpoint): Support ranged breakpoints.
> 	(ppc_linux_remove_hw_breakpoint): Likewise.
> 	(_initialize_ppc_linux_nat): Initialize
> 	to_ranged_break_num_registers.
> 	* target.c (update_current_target): Add comment about
> 	to_ranged_break_num_registers.
> 	(target_ranged_break_num_registers): New function.
> 	* target.h (struct target_ops) <to_ranged_break_num_registers>:
> 	New method.
> 	(target_ranged_break_num_registers): Add function prototype.
> 	* ui-out.c (ui_out_field_core_addr): Move address-printing logic to ...
> 	* utils.c (print_core_address): ... here.
> 
> gdb/doc/
> 	* gdb.texinfo (PowerPC Embedded): Document ranged breakpoints.

Otherwise, this is OK.

Thanks,
Ulrich

-- 
  Dr. Ulrich Weigand
  GNU Toolchain for Linux on System z and Cell BE
  Ulrich.Weigand@de.ibm.com



More information about the Gdb-patches mailing list