From 734b0e4bda4c56d0003182cdc3f5137d4bea00d4 Mon Sep 17 00:00:00 2001 From: Markus Metzger Date: Wed, 13 Nov 2013 15:31:07 +0100 Subject: btrace: add struct btrace_data Add a structure to hold the branch trace data and an enum to describe the format of that data. So far, only BTS is supported. Also added a NONE format to indicate that no branch trace data is available. This will make it easier to support different branch trace formats in the future. 2015-02-09 Markus Metzger * Makefile.in (SFILES): Add common/btrace-common.c. (COMMON_OBS): Add common/btrace-common.o. (btrace-common.o): Add build rules. * btrace.c (parse_xml_btrace): Update parameters. (parse_xml_btrace_block): Set format field. (btrace_add_pc, btrace_fetch): Use struct btrace_data. (do_btrace_data_cleanup, make_cleanup_btrace_data): New. (btrace_compute_ftrace): Split into this and... (btrace_compute_ftrace_bts): ...this. (btrace_stitch_trace): Split into this and... (btrace_stitch_bts): ...this. * btrace.h (parse_xml_btrace): Update parameters. (make_cleanup_btrace_data): New. * common/btrace-common.c: New. * common/btrace-common.h: Include common-defs.h. (btrace_block_s): Update comment. (btrace_format): New. (btrace_format_string): New. (btrace_data_bts): New. (btrace_data): New. (btrace_data_init, btrace_data_fini, btrace_data_empty): New. * remote.c (remote_read_btrace): Update parameters. * target.c (target_read_btrace): Update parameters. * target.h (target_read_btrace): Update parameters. (target_ops): Update parameters. * x86-linux-nat.c (x86_linux_read_btrace): Update parameters. * target-delegates.c: Regenerate. * target-debug (target_debug_print_struct_btrace_data_p): New. * nat/linux-btrace.c (linux_read_btrace): Split into this and... (linux_read_bts): ...this. * nat/linux-btrace.h (linux_read_btrace): Update parameters. gdbserver/ * Makefile.in (SFILES): Add common/btrace-common.c. (OBS): Add common/btrace-common.o. (btrace-common.o): Add build rules. * linux-low: Include btrace-common.h. (linux_low_read_btrace): Use struct btrace_data. Call btrace_data_init and btrace_data_fini. --- gdb/remote.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'gdb/remote.c') diff --git a/gdb/remote.c b/gdb/remote.c index e971a29..e7557d7 100644 --- a/gdb/remote.c +++ b/gdb/remote.c @@ -11419,7 +11419,7 @@ remote_teardown_btrace (struct target_ops *self, static enum btrace_error remote_read_btrace (struct target_ops *self, - VEC (btrace_block_s) **btrace, + struct btrace_data *btrace, struct btrace_target_info *tinfo, enum btrace_read_type type) { @@ -11459,7 +11459,7 @@ remote_read_btrace (struct target_ops *self, return BTRACE_ERR_UNKNOWN; cleanup = make_cleanup (xfree, xml); - *btrace = parse_xml_btrace (xml); + parse_xml_btrace (btrace, xml); do_cleanups (cleanup); return BTRACE_ERR_NONE; -- cgit v1.1