diff options
Diffstat (limited to 'gdb/tracepoint.c')
-rw-r--r-- | gdb/tracepoint.c | 1804 |
1 files changed, 912 insertions, 892 deletions
diff --git a/gdb/tracepoint.c b/gdb/tracepoint.c index 1eb39d1549c..f4b41f45cc4 100644 --- a/gdb/tracepoint.c +++ b/gdb/tracepoint.c @@ -1,21 +1,22 @@ /* Tracing functionality for remote targets in custom GDB protocol Copyright 1997, 1998 Free Software Foundation, Inc. -This file is part of GDB. + This file is part of GDB. -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 2 of the License, or -(at your option) any later version. + 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 2 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. + 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, write to the Free Software -Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. */ #include "defs.h" #include "symtab.h" @@ -48,18 +49,18 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ (which includes everything -- including the checksum), and assumes the worst case of maximum length for each of the pieces of a continuation packet. - + NOTE: expressions get mem2hex'ed otherwise this would be twice as large. (400 - 31)/2 == 184 */ #define MAX_AGENT_EXPR_LEN 184 extern int info_verbose; -extern void (*readline_begin_hook) PARAMS ((char *, ...)); -extern char * (*readline_hook) PARAMS ((char *)); +extern void (*readline_begin_hook) PARAMS ((char *,...)); +extern char *(*readline_hook) PARAMS ((char *)); extern void (*readline_end_hook) PARAMS ((void)); extern void x_command PARAMS ((char *, int)); -extern int addressprint; /* Print machine addresses? */ +extern int addressprint; /* Print machine addresses? */ /* If this definition isn't overridden by the header files, assume that isatty and fileno exist on this system. */ @@ -90,7 +91,7 @@ extern int addressprint; /* Print machine addresses? */ $trace_line : source line of trace frame currently being debugged. $trace_file : source file of trace frame currently being debugged. $tracepoint : tracepoint number of trace frame currently being debugged. - */ + */ /* ======= Important global variables: ======= */ @@ -117,36 +118,36 @@ static struct symtab_and_line traceframe_sal; static struct cmd_list_element *tfindlist; /* ======= Important command functions: ======= */ -static void trace_command PARAMS ((char *, int)); -static void tracepoints_info PARAMS ((char *, int)); -static void delete_trace_command PARAMS ((char *, int)); -static void enable_trace_command PARAMS ((char *, int)); -static void disable_trace_command PARAMS ((char *, int)); -static void trace_pass_command PARAMS ((char *, int)); -static void trace_actions_command PARAMS ((char *, int)); -static void trace_start_command PARAMS ((char *, int)); -static void trace_stop_command PARAMS ((char *, int)); -static void trace_status_command PARAMS ((char *, int)); -static void trace_find_command PARAMS ((char *, int)); -static void trace_find_pc_command PARAMS ((char *, int)); +static void trace_command PARAMS ((char *, int)); +static void tracepoints_info PARAMS ((char *, int)); +static void delete_trace_command PARAMS ((char *, int)); +static void enable_trace_command PARAMS ((char *, int)); +static void disable_trace_command PARAMS ((char *, int)); +static void trace_pass_command PARAMS ((char *, int)); +static void trace_actions_command PARAMS ((char *, int)); +static void trace_start_command PARAMS ((char *, int)); +static void trace_stop_command PARAMS ((char *, int)); +static void trace_status_command PARAMS ((char *, int)); +static void trace_find_command PARAMS ((char *, int)); +static void trace_find_pc_command PARAMS ((char *, int)); static void trace_find_tracepoint_command PARAMS ((char *, int)); -static void trace_find_line_command PARAMS ((char *, int)); -static void trace_find_range_command PARAMS ((char *, int)); -static void trace_find_outside_command PARAMS ((char *, int)); -static void tracepoint_save_command PARAMS ((char *, int)); -static void trace_dump_command PARAMS ((char *, int)); +static void trace_find_line_command PARAMS ((char *, int)); +static void trace_find_range_command PARAMS ((char *, int)); +static void trace_find_outside_command PARAMS ((char *, int)); +static void tracepoint_save_command PARAMS ((char *, int)); +static void trace_dump_command PARAMS ((char *, int)); /* support routines */ -static void trace_mention PARAMS ((struct tracepoint *)); +static void trace_mention PARAMS ((struct tracepoint *)); #if __STDC__ struct collection_list; #endif static void add_aexpr PARAMS ((struct collection_list *, struct agent_expr *)); -static unsigned char *mem2hex(unsigned char *, unsigned char *, int); -static void add_register PARAMS ((struct collection_list *collection, unsigned long regno)); +static unsigned char *mem2hex (unsigned char *, unsigned char *, int); +static void add_register PARAMS ((struct collection_list * collection, unsigned long regno)); static void free_actions_list PARAMS ((char **actions_list)); -static void free_actions_list_cleanup_wrapper PARAMS ((void*)); +static void free_actions_list_cleanup_wrapper PARAMS ((void *)); extern void _initialize_tracepoint PARAMS ((void)); @@ -162,19 +163,19 @@ target_is_remote () } /* Utility: generate error from an incoming stub packet. */ -static void +static void trace_error (buf) char *buf; { if (*buf++ != 'E') return; /* not an error msg */ - switch (*buf) + switch (*buf) { case '1': /* malformed packet error */ if (*++buf == '0') /* general case: */ error ("tracepoint.c: error in outgoing packet."); else - error ("tracepoint.c: error in outgoing packet at field #%d.", + error ("tracepoint.c: error in outgoing packet at field #%d.", strtol (buf, NULL, 16)); case '2': error ("trace API error 0x%s.", ++buf); @@ -188,9 +189,9 @@ static char * remote_get_noisy_reply (buf) char *buf; { - do /* loop on reply from remote stub */ + do /* loop on reply from remote stub */ { - QUIT; /* allow user to bail out with ^C */ + QUIT; /* allow user to bail out with ^C */ getpkt (buf, 0); if (buf[0] == 0) error ("Target does not support this command."); @@ -200,8 +201,9 @@ remote_get_noisy_reply (buf) buf[1] != 'K') remote_console_output (buf + 1); /* 'O' message from stub */ else - return buf; /* here's the actual reply */ - } while (1); + return buf; /* here's the actual reply */ + } + while (1); } /* Set tracepoint count to NUM. */ @@ -242,25 +244,25 @@ set_traceframe_context (trace_pc) CORE_ADDR trace_pc; { static struct type *func_string, *file_string; - static struct type *func_range, *file_range; - static value_ptr func_val, file_val; + static struct type *func_range, *file_range; + static value_ptr func_val, file_val; static struct type *charstar; int len; if (charstar == (struct type *) NULL) charstar = lookup_pointer_type (builtin_type_char); - if (trace_pc == -1) /* cease debugging any trace buffers */ + if (trace_pc == -1) /* cease debugging any trace buffers */ { traceframe_fun = 0; traceframe_sal.pc = traceframe_sal.line = 0; traceframe_sal.symtab = NULL; - set_internalvar (lookup_internalvar ("trace_func"), + set_internalvar (lookup_internalvar ("trace_func"), value_from_longest (charstar, (LONGEST) 0)); - set_internalvar (lookup_internalvar ("trace_file"), + set_internalvar (lookup_internalvar ("trace_file"), value_from_longest (charstar, (LONGEST) 0)); set_internalvar (lookup_internalvar ("trace_line"), - value_from_longest (builtin_type_int, (LONGEST) -1)); + value_from_longest (builtin_type_int, (LONGEST) - 1)); return; } @@ -270,46 +272,46 @@ set_traceframe_context (trace_pc) /* save linenumber as "$trace_line", a debugger variable visible to users */ set_internalvar (lookup_internalvar ("trace_line"), - value_from_longest (builtin_type_int, + value_from_longest (builtin_type_int, (LONGEST) traceframe_sal.line)); /* save func name as "$trace_func", a debugger variable visible to users */ - if (traceframe_fun == NULL || + if (traceframe_fun == NULL || SYMBOL_NAME (traceframe_fun) == NULL) - set_internalvar (lookup_internalvar ("trace_func"), + set_internalvar (lookup_internalvar ("trace_func"), value_from_longest (charstar, (LONGEST) 0)); else { len = strlen (SYMBOL_NAME (traceframe_fun)); - func_range = create_range_type (func_range, - builtin_type_int, 0, len - 1); - func_string = create_array_type (func_string, + func_range = create_range_type (func_range, + builtin_type_int, 0, len - 1); + func_string = create_array_type (func_string, builtin_type_char, func_range); func_val = allocate_value (func_string); VALUE_TYPE (func_val) = func_string; - memcpy (VALUE_CONTENTS_RAW (func_val), - SYMBOL_NAME (traceframe_fun), + memcpy (VALUE_CONTENTS_RAW (func_val), + SYMBOL_NAME (traceframe_fun), len); func_val->modifiable = 0; set_internalvar (lookup_internalvar ("trace_func"), func_val); } /* save file name as "$trace_file", a debugger variable visible to users */ - if (traceframe_sal.symtab == NULL || + if (traceframe_sal.symtab == NULL || traceframe_sal.symtab->filename == NULL) - set_internalvar (lookup_internalvar ("trace_file"), + set_internalvar (lookup_internalvar ("trace_file"), value_from_longest (charstar, (LONGEST) 0)); else { len = strlen (traceframe_sal.symtab->filename); - file_range = create_range_type (file_range, - builtin_type_int, 0, len - 1); - file_string = create_array_type (file_string, + file_range = create_range_type (file_range, + builtin_type_int, 0, len - 1); + file_string = create_array_type (file_string, builtin_type_char, file_range); file_val = allocate_value (file_string); VALUE_TYPE (file_val) = file_string; - memcpy (VALUE_CONTENTS_RAW (file_val), - traceframe_sal.symtab->filename, + memcpy (VALUE_CONTENTS_RAW (file_val), + traceframe_sal.symtab->filename, len); file_val->modifiable = 0; set_internalvar (lookup_internalvar ("trace_file"), file_val); @@ -339,17 +341,17 @@ set_raw_tracepoint (sal) if (sal.symtab == NULL) t->source_file = NULL; else - t->source_file = savestring (sal.symtab->filename, + t->source_file = savestring (sal.symtab->filename, strlen (sal.symtab->filename)); - t->section = sal.section; - t->language = current_language->la_language; + t->section = sal.section; + t->language = current_language->la_language; t->input_radix = input_radix; t->line_number = sal.line; - t->enabled = enabled; - t->next = 0; - t->step_count = 0; - t->pass_count = 0; + t->enabled = enabled; + t->next = 0; + t->step_count = 0; + t->pass_count = 0; t->addr_string = NULL; /* Add this tracepoint to the end of the chain @@ -375,7 +377,7 @@ trace_command (arg, from_tty) char *arg; int from_tty; { - char **canonical = (char **)NULL; + char **canonical = (char **) NULL; struct symtabs_and_lines sals; struct symtab_and_line sal; struct tracepoint *t; @@ -389,10 +391,10 @@ trace_command (arg, from_tty) printf_filtered ("TRACE %s\n", arg); addr_start = arg; - sals = decode_line_1 (&arg, 1, (struct symtab *)NULL, 0, &canonical); - addr_end = arg; - if (! sals.nelts) - return; /* ??? Presumably decode_line_1 has already warned? */ + sals = decode_line_1 (&arg, 1, (struct symtab *) NULL, 0, &canonical); + addr_end = arg; + if (!sals.nelts) + return; /* ??? Presumably decode_line_1 has already warned? */ /* Resolve all line numbers to PC's */ for (i = 0; i < sals.nelts; i++) @@ -408,8 +410,8 @@ trace_command (arg, from_tty) t->number = tracepoint_count; /* If a canonical line spec is needed use that instead of the - command string. */ - if (canonical != (char **)NULL && canonical[i] != NULL) + command string. */ + if (canonical != (char **) NULL && canonical[i] != NULL) t->addr_string = canonical[i]; else if (addr_start) t->addr_string = savestring (addr_start, addr_end - addr_start); @@ -467,70 +469,70 @@ tracepoints_info (tpnum_exp, from_tty) ALL_TRACEPOINTS (t) if (tpnum == -1 || tpnum == t->number) - { - extern int addressprint; /* print machine addresses? */ + { + extern int addressprint; /* print machine addresses? */ - if (!found_a_tracepoint++) - { - printf_filtered ("Num Enb "); - if (addressprint) - printf_filtered ("Address "); - printf_filtered ("PassC StepC What\n"); - } - strcpy (wrap_indent, " "); - if (addressprint) - strcat (wrap_indent, " "); - - printf_filtered ("%-3d %-3s ", t->number, - t->enabled == enabled ? "y" : "n"); - if (addressprint) - printf_filtered ("%s ", - local_hex_string_custom ((unsigned long) t->address, - "08l")); - printf_filtered ("%-5d %-5d ", t->pass_count, t->step_count); - - if (t->source_file) - { - sym = find_pc_sect_function (t->address, t->section); - if (sym) - { - fputs_filtered ("in ", gdb_stdout); - fputs_filtered (SYMBOL_SOURCE_NAME (sym), gdb_stdout); - wrap_here (wrap_indent); - fputs_filtered (" at ", gdb_stdout); - } - fputs_filtered (t->source_file, gdb_stdout); - printf_filtered (":%d", t->line_number); - } - else - print_address_symbolic (t->address, gdb_stdout, demangle, " "); + if (!found_a_tracepoint++) + { + printf_filtered ("Num Enb "); + if (addressprint) + printf_filtered ("Address "); + printf_filtered ("PassC StepC What\n"); + } + strcpy (wrap_indent, " "); + if (addressprint) + strcat (wrap_indent, " "); + + printf_filtered ("%-3d %-3s ", t->number, + t->enabled == enabled ? "y" : "n"); + if (addressprint) + printf_filtered ("%s ", + local_hex_string_custom ((unsigned long) t->address, + "08l")); + printf_filtered ("%-5d %-5d ", t->pass_count, t->step_count); + + if (t->source_file) + { + sym = find_pc_sect_function (t->address, t->section); + if (sym) + { + fputs_filtered ("in ", gdb_stdout); + fputs_filtered (SYMBOL_SOURCE_NAME (sym), gdb_stdout); + wrap_here (wrap_indent); + fputs_filtered (" at ", gdb_stdout); + } + fputs_filtered (t->source_file, gdb_stdout); + printf_filtered (":%d", t->line_number); + } + else + print_address_symbolic (t->address, gdb_stdout, demangle, " "); - printf_filtered ("\n"); - if (t->actions) - { - printf_filtered (" Actions for tracepoint %d: \n", t->number); - for (action = t->actions; action; action = action->next) - { - printf_filtered ("\t%s\n", action->action); - } - } - } + printf_filtered ("\n"); + if (t->actions) + { + printf_filtered (" Actions for tracepoint %d: \n", t->number); + for (action = t->actions; action; action = action->next) + { + printf_filtered ("\t%s\n", action->action); + } + } + } if (!found_a_tracepoint) { if (tpnum == -1) - printf_filtered ("No tracepoints.\n"); + printf_filtered ("No tracepoints.\n"); else - printf_filtered ("No tracepoint number %d.\n", tpnum); + printf_filtered ("No tracepoint number %d.\n", tpnum); } } /* Optimization: the code to parse an enable, disable, or delete TP command is virtually identical except for whether it performs an enable, disable, or delete. Therefore I've combined them into one function with an opcode. - */ -enum tracepoint_opcode + */ +enum tracepoint_opcode { - enable, + enable, disable, delete }; @@ -544,42 +546,43 @@ tracepoint_operation (t, from_tty, opcode) { struct tracepoint *t2; - switch (opcode) { - case enable: - t->enabled = enabled; - if (modify_tracepoint_hook) - modify_tracepoint_hook (t); - break; - case disable: - t->enabled = disabled; - if (modify_tracepoint_hook) - modify_tracepoint_hook (t); - break; - case delete: - if (tracepoint_chain == t) - tracepoint_chain = t->next; + switch (opcode) + { + case enable: + t->enabled = enabled; + if (modify_tracepoint_hook) + modify_tracepoint_hook (t); + break; + case disable: + t->enabled = disabled; + if (modify_tracepoint_hook) + modify_tracepoint_hook (t); + break; + case delete: + if (tracepoint_chain == t) + tracepoint_chain = t->next; - ALL_TRACEPOINTS (t2) - if (t2->next == t) + ALL_TRACEPOINTS (t2) + if (t2->next == t) { t2->next = t->next; break; } - /* Let the UI know of any deletions */ - if (delete_tracepoint_hook) - delete_tracepoint_hook (t); + /* Let the UI know of any deletions */ + if (delete_tracepoint_hook) + delete_tracepoint_hook (t); - if (t->addr_string) - free (t->addr_string); - if (t->source_file) - free (t->source_file); - if (t->actions) - free_actions (t); + if (t->addr_string) + free (t->addr_string); + if (t->source_file) + free (t->source_file); + if (t->actions) + free_actions (t); - free (t); - break; - } + free (t); + break; + } } /* Utility: parse a tracepoint number and look it up in the list. */ @@ -600,9 +603,9 @@ get_tracepoint_by_number (arg) else if (**arg == '$') /* handle convenience variable */ { /* Make a copy of the name, so we can null-terminate it - to pass to lookup_internalvar(). */ + to pass to lookup_internalvar(). */ end = *arg + 1; - while (isalnum(*end) || *end == '_') + while (isalnum (*end) || *end == '_') end++; copy = (char *) alloca (end - *arg); strncpy (copy, *arg + 1, (end - *arg - 1)); @@ -610,11 +613,12 @@ get_tracepoint_by_number (arg) *arg = end; val = value_of_internalvar (lookup_internalvar (copy)); - if (TYPE_CODE( VALUE_TYPE (val)) != TYPE_CODE_INT) + if (TYPE_CODE (VALUE_TYPE (val)) != TYPE_CODE_INT) error ("Convenience variable must have integral type."); tpnum = (int) value_as_long (val); } - else /* handle tracepoint number */ + else + /* handle tracepoint number */ { tpnum = strtol (*arg, arg, 0); if (tpnum == 0) /* possible strtol failure */ @@ -623,9 +627,9 @@ get_tracepoint_by_number (arg) } ALL_TRACEPOINTS (t) if (t->number == tpnum) - { - return t; - } + { + return t; + } printf_unfiltered ("No tracepoint number %d.\n", tpnum); return NULL; } @@ -647,7 +651,7 @@ map_args_over_tracepoints (args, from_tty, opcode) else while (*args) { - QUIT; /* give user option to bail out with ^C */ + QUIT; /* give user option to bail out with ^C */ t = get_tracepoint_by_number (&args); if (t) tracepoint_operation (t, from_tty, opcode); @@ -685,7 +689,7 @@ delete_trace_command (args, from_tty) dont_repeat (); if (!args || !*args) /* No args implies all tracepoints; */ if (from_tty) /* confirm only if from_tty... */ - if (tracepoint_chain) /* and if there are tracepoints to delete! */ + if (tracepoint_chain) /* and if there are tracepoints to delete! */ if (!query ("Delete all tracepoints? ")) return; @@ -715,7 +719,7 @@ trace_pass_command (args, from_tty) args++; if (*args && strncasecmp (args, "all", 3) == 0) - args += 3; /* skip special argument "all" */ + args += 3; /* skip special argument "all" */ else t1 = get_tracepoint_by_number (&args); @@ -723,40 +727,40 @@ trace_pass_command (args, from_tty) error ("Junk at end of arguments."); if (t1 == NULL) - return; /* error, bad tracepoint number */ + return; /* error, bad tracepoint number */ ALL_TRACEPOINTS (t2) if (t1 == (struct tracepoint *) -1 || t1 == t2) - { - t2->pass_count = count; - if (modify_tracepoint_hook) - modify_tracepoint_hook (t2); - if (from_tty) - printf_filtered ("Setting tracepoint %d's passcount to %d\n", - t2->number, count); - } + { + t2->pass_count = count; + if (modify_tracepoint_hook) + modify_tracepoint_hook (t2); + if (from_tty) + printf_filtered ("Setting tracepoint %d's passcount to %d\n", + t2->number, count); + } } /* ACTIONS functions: */ /* Prototypes for action-parsing utility commands */ -static void read_actions PARAMS((struct tracepoint *)); +static void read_actions PARAMS ((struct tracepoint *)); static char *parse_and_eval_memrange PARAMS ((char *, - CORE_ADDR, + CORE_ADDR, long *, bfd_signed_vma *, long *)); /* The three functions: - collect_pseudocommand, - while_stepping_pseudocommand, and - end_actions_pseudocommand + collect_pseudocommand, + while_stepping_pseudocommand, and + end_actions_pseudocommand are placeholders for "commands" that are actually ONLY to be used within a tracepoint action list. If the actual function is ever called, it means that somebody issued the "command" at the top level, which is always an error. */ -static void +static void end_actions_pseudocommand (args, from_tty) char *args; int from_tty; @@ -840,13 +844,13 @@ read_actions (t) signal (STOP_SIGNAL, handle_stop_sig); else signal (STOP_SIGNAL, stop_sig); - } + } #endif old_chain = make_cleanup ((make_cleanup_func) free_actions, (void *) t); while (1) { /* Make sure that all output has been output. Some machines may let - you get away with leaving out some of the gdb_flush, but not all. */ + you get away with leaving out some of the gdb_flush, but not all. */ wrap_here (""); gdb_flush (gdb_stdout); gdb_flush (gdb_stderr); @@ -856,7 +860,7 @@ read_actions (t) else if (instream == stdin && ISATTY (instream)) { line = readline (prompt); - if (line && *line) /* add it to command history */ + if (line && *line) /* add it to command history */ add_history (line); } else @@ -864,7 +868,7 @@ read_actions (t) linetype = validate_actionline (&line, t); if (linetype == BADLINE) - continue; /* already warned -- collect another line */ + continue; /* already warned -- collect another line */ temp = xmalloc (sizeof (struct action_line)); temp->next = NULL; @@ -895,7 +899,7 @@ read_actions (t) prompt = prompt1; /* end of single-stepping actions */ } else - { /* end of actions */ + { /* end of actions */ if (t->actions->next == NULL) { /* an "end" all by itself with no other actions means @@ -926,14 +930,14 @@ validate_actionline (line, t) struct cleanup *old_chain = NULL; char *p; - for (p = *line; isspace (*p); ) + for (p = *line; isspace (*p);) p++; /* symbol lookup etc. */ - if (*p == '\0') /* empty line: just prompt for another line. */ + if (*p == '\0') /* empty line: just prompt for another line. */ return BADLINE; - if (*p == '#') /* comment line */ + if (*p == '#') /* comment line */ return GENERIC; c = lookup_cmd (&p, cmdlist, "", -1, 1); @@ -942,79 +946,81 @@ validate_actionline (line, t) warning ("'%s' is not an action that I know, or is ambiguous.", p); return BADLINE; } - + if (c->function.cfunc == collect_pseudocommand) { struct agent_expr *aexpr; struct agent_reqs areqs; - do { /* repeat over a comma-separated list */ - QUIT; /* allow user to bail out with ^C */ - while (isspace (*p)) - p++; + do + { /* repeat over a comma-separated list */ + QUIT; /* allow user to bail out with ^C */ + while (isspace (*p)) + p++; - if (*p == '$') /* look for special pseudo-symbols */ - { - long typecode, size; - bfd_signed_vma offset; + if (*p == '$') /* look for special pseudo-symbols */ + { + long typecode, size; + bfd_signed_vma offset; - if ((0 == strncasecmp ("reg", p + 1, 3)) || - (0 == strncasecmp ("arg", p + 1, 3)) || - (0 == strncasecmp ("loc", p + 1, 3))) - { - p = strchr (p, ','); - continue; - } - /* else fall thru, treat p as an expression and parse it! */ - } - exp = parse_exp_1 (&p, block_for_pc (t->address), 1); - old_chain = make_cleanup ((make_cleanup_func) free_current_contents, - &exp); + if ((0 == strncasecmp ("reg", p + 1, 3)) || + (0 == strncasecmp ("arg", p + 1, 3)) || + (0 == strncasecmp ("loc", p + 1, 3))) + { + p = strchr (p, ','); + continue; + } + /* else fall thru, treat p as an expression and parse it! */ + } + exp = parse_exp_1 (&p, block_for_pc (t->address), 1); + old_chain = make_cleanup ((make_cleanup_func) free_current_contents, + &exp); - if (exp->elts[0].opcode == OP_VAR_VALUE) - { - if (SYMBOL_CLASS (exp->elts[2].symbol) == LOC_CONST) - { - warning ("%s is constant (value %d): will not be collected.", - SYMBOL_NAME (exp->elts[2].symbol), - SYMBOL_VALUE (exp->elts[2].symbol)); - return BADLINE; - } - else if (SYMBOL_CLASS (exp->elts[2].symbol) == LOC_OPTIMIZED_OUT) - { - warning ("%s is optimized away and cannot be collected.", - SYMBOL_NAME (exp->elts[2].symbol)); - return BADLINE; - } - } + if (exp->elts[0].opcode == OP_VAR_VALUE) + { + if (SYMBOL_CLASS (exp->elts[2].symbol) == LOC_CONST) + { + warning ("%s is constant (value %d): will not be collected.", + SYMBOL_NAME (exp->elts[2].symbol), + SYMBOL_VALUE (exp->elts[2].symbol)); + return BADLINE; + } + else if (SYMBOL_CLASS (exp->elts[2].symbol) == LOC_OPTIMIZED_OUT) + { + warning ("%s is optimized away and cannot be collected.", + SYMBOL_NAME (exp->elts[2].symbol)); + return BADLINE; + } + } - /* we have something to collect, make sure that the expr to - bytecode translator can handle it and that it's not too long */ - aexpr = gen_trace_for_expr (t->address, exp); - (void) make_cleanup ((make_cleanup_func) free_agent_expr, aexpr); + /* we have something to collect, make sure that the expr to + bytecode translator can handle it and that it's not too long */ + aexpr = gen_trace_for_expr (t->address, exp); + (void) make_cleanup ((make_cleanup_func) free_agent_expr, aexpr); - if (aexpr->len > MAX_AGENT_EXPR_LEN) - error ("expression too complicated, try simplifying"); + if (aexpr->len > MAX_AGENT_EXPR_LEN) + error ("expression too complicated, try simplifying"); - ax_reqs(aexpr, &areqs); - (void) make_cleanup (free, areqs.reg_mask); + ax_reqs (aexpr, &areqs); + (void) make_cleanup (free, areqs.reg_mask); - if (areqs.flaw != agent_flaw_none) - error ("malformed expression"); + if (areqs.flaw != agent_flaw_none) + error ("malformed expression"); - if (areqs.min_height < 0) - error ("gdb: Internal error: expression has min height < 0"); + if (areqs.min_height < 0) + error ("gdb: Internal error: expression has min height < 0"); - if (areqs.max_height > 20) - error ("expression too complicated, try simplifying"); + if (areqs.max_height > 20) + error ("expression too complicated, try simplifying"); - do_cleanups (old_chain); - } while (p && *p++ == ','); + do_cleanups (old_chain); + } + while (p && *p++ == ','); return GENERIC; } else if (c->function.cfunc == while_stepping_pseudocommand) { - char *steparg; /* in case warning is necessary */ + char *steparg; /* in case warning is necessary */ while (isspace (*p)) p++; @@ -1038,7 +1044,7 @@ validate_actionline (line, t) } /* worker function */ -void +void free_actions (t) struct tracepoint *t; { @@ -1047,29 +1053,32 @@ free_actions (t) for (line = t->actions; line; line = next) { next = line->next; - if (line->action) + if (line->action) free (line->action); free (line); } t->actions = NULL; } -struct memrange { - int type; /* 0 for absolute memory range, else basereg number */ +struct memrange +{ + int type; /* 0 for absolute memory range, else basereg number */ bfd_signed_vma start; bfd_signed_vma end; }; -struct collection_list { - unsigned char regs_mask[8]; /* room for up to 256 regs */ - long listsize; - long next_memrange; - struct memrange *list; - long aexpr_listsize; /* size of array pointed to by expr_list elt */ - long next_aexpr_elt; - struct agent_expr **aexpr_list; - -} tracepoint_list, stepping_list; +struct collection_list + { + unsigned char regs_mask[8]; /* room for up to 256 regs */ + long listsize; + long next_memrange; + struct memrange *list; + long aexpr_listsize; /* size of array pointed to by expr_list elt */ + long next_aexpr_elt; + struct agent_expr **aexpr_list; + + } +tracepoint_list, stepping_list; /* MEMRANGE functions: */ @@ -1086,18 +1095,20 @@ memrange_cmp (va, vb) if (a->type < b->type) return -1; if (a->type > b->type) - return 1; + return 1; if (a->type == 0) { - if ((bfd_vma) a->start < (bfd_vma) b->start) return -1; - if ((bfd_vma) a->start > (bfd_vma) b->start) return 1; + if ((bfd_vma) a->start < (bfd_vma) b->start) + return -1; + if ((bfd_vma) a->start > (bfd_vma) b->start) + return 1; } else { - if (a->start < b->start) + if (a->start < b->start) return -1; - if (a->start > b->start) - return 1; + if (a->start > b->start) + return 1; } return 0; } @@ -1109,14 +1120,14 @@ memrange_sortmerge (memranges) { int a, b; - qsort (memranges->list, memranges->next_memrange, + qsort (memranges->list, memranges->next_memrange, sizeof (struct memrange), memrange_cmp); if (memranges->next_memrange > 0) { for (a = 0, b = 1; b < memranges->next_memrange; b++) { if (memranges->list[a].type == memranges->list[b].type && - memranges->list[b].start - memranges->list[a].end <= + memranges->list[b].start - memranges->list[a].end <= MAX_REGISTER_VIRTUAL_SIZE) { /* memrange b starts before memrange a ends; merge them. */ @@ -1126,7 +1137,7 @@ memrange_sortmerge (memranges) } a++; /* next a */ if (a != b) - memcpy (&memranges->list[a], &memranges->list[b], + memcpy (&memranges->list[a], &memranges->list[b], sizeof (struct memrange)); } memranges->next_memrange = a + 1; @@ -1144,7 +1155,7 @@ add_register (collection, regno) if (regno > (8 * sizeof (collection->regs_mask))) error ("Internal: register number %d too large for tracepoint", regno); - collection->regs_mask [regno / 8] |= 1 << (regno % 8); + collection->regs_mask[regno / 8] |= 1 << (regno % 8); } /* Add a memrange to a collection list */ @@ -1158,20 +1169,20 @@ add_memrange (memranges, type, base, len) if (info_verbose) printf_filtered ("(%d,0x%x,%d)\n", type, base, len); /* type: 0 == memory, n == basereg */ - memranges->list[memranges->next_memrange].type = type; + memranges->list[memranges->next_memrange].type = type; /* base: addr if memory, offset if reg relative. */ memranges->list[memranges->next_memrange].start = base; /* len: we actually save end (base + len) for convenience */ - memranges->list[memranges->next_memrange].end = base + len; + memranges->list[memranges->next_memrange].end = base + len; memranges->next_memrange++; if (memranges->next_memrange >= memranges->listsize) { memranges->listsize *= 2; - memranges->list = xrealloc (memranges->list, + memranges->list = xrealloc (memranges->list, memranges->listsize); } - if (type != -1) /* better collect the base register! */ + if (type != -1) /* better collect the base register! */ add_register (memranges, type); } @@ -1183,97 +1194,98 @@ collect_symbol (collect, sym, frame_regno, frame_offset) long frame_regno; long frame_offset; { - unsigned long len; - unsigned long reg; + unsigned long len; + unsigned long reg; bfd_signed_vma offset; - len = TYPE_LENGTH (check_typedef (SYMBOL_TYPE (sym))); - switch (SYMBOL_CLASS (sym)) { - default: - printf_filtered ("%s: don't know symbol class %d\n", - SYMBOL_NAME (sym), SYMBOL_CLASS (sym)); - break; - case LOC_CONST: - printf_filtered ("%s is constant, value is %d: will not be collected.\n", - SYMBOL_NAME (sym), SYMBOL_VALUE (sym)); - break; - case LOC_STATIC: - offset = SYMBOL_VALUE_ADDRESS (sym); - if (info_verbose) - printf_filtered ("LOC_STATIC %s: collect %d bytes at 0x%08x\n", - SYMBOL_NAME (sym), len, offset); - add_memrange (collect, -1, offset, len); /* 0 == memory */ - break; - case LOC_REGISTER: - case LOC_REGPARM: - reg = SYMBOL_VALUE (sym); - if (info_verbose) - printf_filtered ("LOC_REG[parm] %s: ", SYMBOL_NAME (sym)); - add_register (collect, reg); - /* check for doubles stored in two registers */ - /* FIXME: how about larger types stored in 3 or more regs? */ - if (TYPE_CODE (SYMBOL_TYPE (sym)) == TYPE_CODE_FLT && - len > REGISTER_RAW_SIZE (reg)) - add_register (collect, reg + 1); - break; - case LOC_REF_ARG: - printf_filtered ("Sorry, don't know how to do LOC_REF_ARG yet.\n"); - printf_filtered (" (will not collect %s)\n", - SYMBOL_NAME (sym)); - break; - case LOC_ARG: - reg = frame_regno; - offset = frame_offset + SYMBOL_VALUE (sym); - if (info_verbose) - { - printf_filtered ("LOC_LOCAL %s: Collect %d bytes at offset", - SYMBOL_NAME (sym), len); - printf_filtered (" %d from frame ptr reg %d\n", offset, reg); - } - add_memrange (collect, reg, offset, len); - break; - case LOC_REGPARM_ADDR: - reg = SYMBOL_VALUE (sym); - offset = 0; - if (info_verbose) - { - printf_filtered ("LOC_REGPARM_ADDR %s: Collect %d bytes at offset", - SYMBOL_NAME (sym), len); - printf_filtered (" %d from reg %d\n", offset, reg); - } - add_memrange (collect, reg, offset, len); - break; - case LOC_LOCAL: - case LOC_LOCAL_ARG: - reg = frame_regno; - offset = frame_offset + SYMBOL_VALUE (sym); - if (info_verbose) - { - printf_filtered ("LOC_LOCAL %s: Collect %d bytes at offset", - SYMBOL_NAME (sym), len); - printf_filtered (" %d from frame ptr reg %d\n", offset, reg); - } - add_memrange (collect, reg, offset, len); - break; - case LOC_BASEREG: - case LOC_BASEREG_ARG: - reg = SYMBOL_BASEREG (sym); - offset = SYMBOL_VALUE (sym); - if (info_verbose) - { - printf_filtered ("LOC_BASEREG %s: collect %d bytes at offset %d from basereg %d\n", - SYMBOL_NAME (sym), len, offset, reg); - } - add_memrange (collect, reg, offset, len); - break; - case LOC_UNRESOLVED: - printf_filtered ("Don't know LOC_UNRESOLVED %s\n", SYMBOL_NAME (sym)); - break; - case LOC_OPTIMIZED_OUT: - printf_filtered ("%s has been optimized out of existance.\n", - SYMBOL_NAME (sym)); - break; - } + len = TYPE_LENGTH (check_typedef (SYMBOL_TYPE (sym))); + switch (SYMBOL_CLASS (sym)) + { + default: + printf_filtered ("%s: don't know symbol class %d\n", + SYMBOL_NAME (sym), SYMBOL_CLASS (sym)); + break; + case LOC_CONST: + printf_filtered ("%s is constant, value is %d: will not be collected.\n", + SYMBOL_NAME (sym), SYMBOL_VALUE (sym)); + break; + case LOC_STATIC: + offset = SYMBOL_VALUE_ADDRESS (sym); + if (info_verbose) + printf_filtered ("LOC_STATIC %s: collect %d bytes at 0x%08x\n", + SYMBOL_NAME (sym), len, offset); + add_memrange (collect, -1, offset, len); /* 0 == memory */ + break; + case LOC_REGISTER: + case LOC_REGPARM: + reg = SYMBOL_VALUE (sym); + if (info_verbose) + printf_filtered ("LOC_REG[parm] %s: ", SYMBOL_NAME (sym)); + add_register (collect, reg); + /* check for doubles stored in two registers */ + /* FIXME: how about larger types stored in 3 or more regs? */ + if (TYPE_CODE (SYMBOL_TYPE (sym)) == TYPE_CODE_FLT && + len > REGISTER_RAW_SIZE (reg)) + add_register (collect, reg + 1); + break; + case LOC_REF_ARG: + printf_filtered ("Sorry, don't know how to do LOC_REF_ARG yet.\n"); + printf_filtered (" (will not collect %s)\n", + SYMBOL_NAME (sym)); + break; + case LOC_ARG: + reg = frame_regno; + offset = frame_offset + SYMBOL_VALUE (sym); + if (info_verbose) + { + printf_filtered ("LOC_LOCAL %s: Collect %d bytes at offset", + SYMBOL_NAME (sym), len); + printf_filtered (" %d from frame ptr reg %d\n", offset, reg); + } + add_memrange (collect, reg, offset, len); + break; + case LOC_REGPARM_ADDR: + reg = SYMBOL_VALUE (sym); + offset = 0; + if (info_verbose) + { + printf_filtered ("LOC_REGPARM_ADDR %s: Collect %d bytes at offset", + SYMBOL_NAME (sym), len); + printf_filtered (" %d from reg %d\n", offset, reg); + } + add_memrange (collect, reg, offset, len); + break; + case LOC_LOCAL: + case LOC_LOCAL_ARG: + reg = frame_regno; + offset = frame_offset + SYMBOL_VALUE (sym); + if (info_verbose) + { + printf_filtered ("LOC_LOCAL %s: Collect %d bytes at offset", + SYMBOL_NAME (sym), len); + printf_filtered (" %d from frame ptr reg %d\n", offset, reg); + } + add_memrange (collect, reg, offset, len); + break; + case LOC_BASEREG: + case LOC_BASEREG_ARG: + reg = SYMBOL_BASEREG (sym); + offset = SYMBOL_VALUE (sym); + if (info_verbose) + { + printf_filtered ("LOC_BASEREG %s: collect %d bytes at offset %d from basereg %d\n", + SYMBOL_NAME (sym), len, offset, reg); + } + add_memrange (collect, reg, offset, len); + break; + case LOC_UNRESOLVED: + printf_filtered ("Don't know LOC_UNRESOLVED %s\n", SYMBOL_NAME (sym)); + break; + case LOC_OPTIMIZED_OUT: + printf_filtered ("%s has been optimized out of existance.\n", + SYMBOL_NAME (sym)); + break; + } } /* Add all locals (or args) symbols to collection list */ @@ -1286,40 +1298,41 @@ add_local_symbols (collect, pc, frame_regno, frame_offset, type) int type; { struct symbol *sym; - struct block *block; + struct block *block; int i, nsyms, count = 0; block = block_for_pc (pc); while (block != 0) { - QUIT; /* allow user to bail out with ^C */ + QUIT; /* allow user to bail out with ^C */ nsyms = BLOCK_NSYMS (block); for (i = 0; i < nsyms; i++) { sym = BLOCK_SYM (block, i); - switch (SYMBOL_CLASS (sym)) { - case LOC_LOCAL: - case LOC_STATIC: - case LOC_REGISTER: - case LOC_BASEREG: - if (type == 'L') /* collecting Locals */ - { - count++; - collect_symbol (collect, sym, frame_regno, frame_offset); - } - break; - case LOC_ARG: - case LOC_LOCAL_ARG: - case LOC_REF_ARG: - case LOC_REGPARM: - case LOC_REGPARM_ADDR: - case LOC_BASEREG_ARG: - if (type == 'A') /* collecting Arguments */ - { - count++; - collect_symbol (collect, sym, frame_regno, frame_offset); - } - } + switch (SYMBOL_CLASS (sym)) + { + case LOC_LOCAL: + case LOC_STATIC: + case LOC_REGISTER: + case LOC_BASEREG: + if (type == 'L') /* collecting Locals */ + { + count++; + collect_symbol (collect, sym, frame_regno, frame_offset); + } + break; + case LOC_ARG: + case LOC_LOCAL_ARG: + case LOC_REF_ARG: + case LOC_REGPARM: + case LOC_REGPARM_ADDR: + case LOC_BASEREG_ARG: + if (type == 'A') /* collecting Arguments */ + { + count++; + collect_symbol (collect, sym, frame_regno, frame_offset); + } + } } if (BLOCK_FUNCTION (block)) break; @@ -1340,7 +1353,7 @@ clear_collection_list (list) list->next_memrange = 0; for (ndx = 0; ndx < list->next_aexpr_elt; ndx++) { - free_agent_expr(list->aexpr_list[ndx]); + free_agent_expr (list->aexpr_list[ndx]); list->aexpr_list[ndx] = NULL; } list->next_aexpr_elt = 0; @@ -1358,10 +1371,10 @@ stringify_collection_list (list, string) int ndx = 0; char *(*str_list)[]; char *end; - long i; + long i; count = 1 + list->next_memrange + list->next_aexpr_elt + 1; - str_list = (char *(*)[])xmalloc(count * sizeof (char *)); + str_list = (char *(*)[]) xmalloc (count * sizeof (char *)); for (i = sizeof (list->regs_mask) - 1; i > 0; i--) if (list->regs_mask[i] != 0) /* skip leading zeroes in regs_mask */ @@ -1371,16 +1384,16 @@ stringify_collection_list (list, string) if (info_verbose) printf_filtered ("\nCollecting registers (mask): 0x"); end = temp_buf; - *end++='R'; + *end++ = 'R'; for (; i >= 0; i--) { - QUIT; /* allow user to bail out with ^C */ + QUIT; /* allow user to bail out with ^C */ if (info_verbose) printf_filtered ("%02X", list->regs_mask[i]); - sprintf (end, "%02X", list->regs_mask[i]); + sprintf (end, "%02X", list->regs_mask[i]); end += 2; } - (*str_list)[ndx] = savestring(temp_buf, end - temp_buf); + (*str_list)[ndx] = savestring (temp_buf, end - temp_buf); ndx++; } if (info_verbose) @@ -1391,20 +1404,20 @@ stringify_collection_list (list, string) { QUIT; /* allow user to bail out with ^C */ if (info_verbose) - printf_filtered ("(%d, 0x%x, %d)\n", - list->list[i].type, - list->list[i].start, + printf_filtered ("(%d, 0x%x, %d)\n", + list->list[i].type, + list->list[i].start, list->list[i].end - list->list[i].start); if (count + 27 > MAX_AGENT_EXPR_LEN) { - (*str_list)[ndx] = savestring(temp_buf, count); + (*str_list)[ndx] = savestring (temp_buf, count); ndx++; count = 0; end = temp_buf; } - sprintf (end, "M%X,%X,%X", - list->list[i].type, - list->list[i].start, + sprintf (end, "M%X,%X,%X", + list->list[i].type, + list->list[i].start, list->list[i].end - list->list[i].start); count += strlen (end); end += strlen (end); @@ -1415,7 +1428,7 @@ stringify_collection_list (list, string) QUIT; /* allow user to bail out with ^C */ if ((count + 10 + 2 * list->aexpr_list[i]->len) > MAX_AGENT_EXPR_LEN) { - (*str_list)[ndx] = savestring(temp_buf, count); + (*str_list)[ndx] = savestring (temp_buf, count); ndx++; count = 0; end = temp_buf; @@ -1424,13 +1437,13 @@ stringify_collection_list (list, string) end += 10; /* 'X' + 8 hex digits + ',' */ count += 10; - end = mem2hex(list->aexpr_list[i]->buf, end, list->aexpr_list[i]->len); + end = mem2hex (list->aexpr_list[i]->buf, end, list->aexpr_list[i]->len); count += 2 * list->aexpr_list[i]->len; } if (count != 0) { - (*str_list)[ndx] = savestring(temp_buf, count); + (*str_list)[ndx] = savestring (temp_buf, count); ndx++; count = 0; end = temp_buf; @@ -1451,7 +1464,7 @@ free_actions_list_cleanup_wrapper (al) } static void -free_actions_list(actions_list) +free_actions_list (actions_list) char **actions_list; { int ndx; @@ -1460,29 +1473,29 @@ free_actions_list(actions_list) return; for (ndx = 0; actions_list[ndx]; ndx++) - free(actions_list[ndx]); + free (actions_list[ndx]); - free(actions_list); + free (actions_list); } /* render all actions into gdb protocol */ static void encode_actions (t, tdp_actions, stepping_actions) - struct tracepoint *t; - char ***tdp_actions; - char ***stepping_actions; + struct tracepoint *t; + char ***tdp_actions; + char ***stepping_actions; { - static char tdp_buff[2048], step_buff[2048]; - char *action_exp; - struct expression *exp = NULL; + static char tdp_buff[2048], step_buff[2048]; + char *action_exp; + struct expression *exp = NULL; struct action_line *action; - bfd_signed_vma offset; - long i; - value_ptr tempval; - struct collection_list *collect; + bfd_signed_vma offset; + long i; + value_ptr tempval; + struct collection_list *collect; struct cmd_list_element *cmd; struct agent_expr *aexpr; - long frame_reg, frame_offset; + long frame_reg, frame_offset; clear_collection_list (&tracepoint_list); @@ -1510,112 +1523,115 @@ encode_actions (t, tdp_actions, stepping_actions) if (cmd->function.cfunc == collect_pseudocommand) { - do { /* repeat over a comma-separated list */ - QUIT; /* allow user to bail out with ^C */ - while (isspace (*action_exp)) - action_exp++; + do + { /* repeat over a comma-separated list */ + QUIT; /* allow user to bail out with ^C */ + while (isspace (*action_exp)) + action_exp++; - if (0 == strncasecmp ("$reg", action_exp, 4)) - { - for (i = 0; i < NUM_REGS; i++) - add_register (collect, i); - action_exp = strchr (action_exp, ','); /* more? */ - } - else if (0 == strncasecmp ("$arg", action_exp, 4)) - { - add_local_symbols (collect, - t->address, - frame_reg, - frame_offset, - 'A'); - action_exp = strchr (action_exp, ','); /* more? */ - } - else if (0 == strncasecmp ("$loc", action_exp, 4)) - { - add_local_symbols (collect, - t->address, - frame_reg, - frame_offset, - 'L'); - action_exp = strchr (action_exp, ','); /* more? */ - } - else - { - unsigned long addr, len; - struct cleanup *old_chain = NULL; - struct cleanup *old_chain1 = NULL; - struct agent_reqs areqs; - - exp = parse_exp_1 (&action_exp, block_for_pc (t->address), 1); - old_chain = make_cleanup ((make_cleanup_func) - free_current_contents, &exp); - - switch (exp->elts[0].opcode) { - case OP_REGISTER: - i = exp->elts[1].longconst; - if (info_verbose) - printf_filtered ("OP_REGISTER: "); - add_register (collect, i); - break; - - case UNOP_MEMVAL: - /* safe because we know it's a simple expression */ - tempval = evaluate_expression (exp); - addr = VALUE_ADDRESS (tempval) + VALUE_OFFSET (tempval); - len = TYPE_LENGTH (check_typedef (exp->elts[1].type)); - add_memrange (collect, -1, addr, len); - break; - - case OP_VAR_VALUE: - collect_symbol (collect, - exp->elts[2].symbol, - frame_reg, - frame_offset); - break; - - default: /* full-fledged expression */ - aexpr = gen_trace_for_expr (t->address, exp); - - old_chain1 = make_cleanup ((make_cleanup_func) - free_agent_expr, aexpr); - - ax_reqs (aexpr, &areqs); - if (areqs.flaw != agent_flaw_none) - error ("malformed expression"); - - if (areqs.min_height < 0) - error ("gdb: Internal error: expression has min height < 0"); - if (areqs.max_height > 20) - error ("expression too complicated, try simplifying"); - - discard_cleanups (old_chain1); - add_aexpr (collect, aexpr); - - /* take care of the registers */ - if (areqs.reg_mask_len > 0) - { - int ndx1; - int ndx2; + if (0 == strncasecmp ("$reg", action_exp, 4)) + { + for (i = 0; i < NUM_REGS; i++) + add_register (collect, i); + action_exp = strchr (action_exp, ','); /* more? */ + } + else if (0 == strncasecmp ("$arg", action_exp, 4)) + { + add_local_symbols (collect, + t->address, + frame_reg, + frame_offset, + 'A'); + action_exp = strchr (action_exp, ','); /* more? */ + } + else if (0 == strncasecmp ("$loc", action_exp, 4)) + { + add_local_symbols (collect, + t->address, + frame_reg, + frame_offset, + 'L'); + action_exp = strchr (action_exp, ','); /* more? */ + } + else + { + unsigned long addr, len; + struct cleanup *old_chain = NULL; + struct cleanup *old_chain1 = NULL; + struct agent_reqs areqs; + + exp = parse_exp_1 (&action_exp, block_for_pc (t->address), 1); + old_chain = make_cleanup ((make_cleanup_func) + free_current_contents, &exp); - for (ndx1 = 0; ndx1 < areqs.reg_mask_len; ndx1++) + switch (exp->elts[0].opcode) + { + case OP_REGISTER: + i = exp->elts[1].longconst; + if (info_verbose) + printf_filtered ("OP_REGISTER: "); + add_register (collect, i); + break; + + case UNOP_MEMVAL: + /* safe because we know it's a simple expression */ + tempval = evaluate_expression (exp); + addr = VALUE_ADDRESS (tempval) + VALUE_OFFSET (tempval); + len = TYPE_LENGTH (check_typedef (exp->elts[1].type)); + add_memrange (collect, -1, addr, len); + break; + + case OP_VAR_VALUE: + collect_symbol (collect, + exp->elts[2].symbol, + frame_reg, + frame_offset); + break; + + default: /* full-fledged expression */ + aexpr = gen_trace_for_expr (t->address, exp); + + old_chain1 = make_cleanup ((make_cleanup_func) + free_agent_expr, aexpr); + + ax_reqs (aexpr, &areqs); + if (areqs.flaw != agent_flaw_none) + error ("malformed expression"); + + if (areqs.min_height < 0) + error ("gdb: Internal error: expression has min height < 0"); + if (areqs.max_height > 20) + error ("expression too complicated, try simplifying"); + + discard_cleanups (old_chain1); + add_aexpr (collect, aexpr); + + /* take care of the registers */ + if (areqs.reg_mask_len > 0) { - QUIT; /* allow user to bail out with ^C */ - if (areqs.reg_mask[ndx1] != 0) + int ndx1; + int ndx2; + + for (ndx1 = 0; ndx1 < areqs.reg_mask_len; ndx1++) { - /* assume chars have 8 bits */ - for (ndx2 = 0; ndx2 < 8; ndx2++) - if (areqs.reg_mask[ndx1] & (1 << ndx2)) - /* it's used -- record it */ - add_register (collect, ndx1 * 8 + ndx2); + QUIT; /* allow user to bail out with ^C */ + if (areqs.reg_mask[ndx1] != 0) + { + /* assume chars have 8 bits */ + for (ndx2 = 0; ndx2 < 8; ndx2++) + if (areqs.reg_mask[ndx1] & (1 << ndx2)) + /* it's used -- record it */ + add_register (collect, ndx1 * 8 + ndx2); + } } } - } - break; - } /* switch */ - do_cleanups (old_chain); - } /* do */ - } while (action_exp && *action_exp++ == ','); - } /* if */ + break; + } /* switch */ + do_cleanups (old_chain); + } /* do */ + } + while (action_exp && *action_exp++ == ','); + } /* if */ else if (cmd->function.cfunc == while_stepping_pseudocommand) { collect = &stepping_list; @@ -1625,18 +1641,18 @@ encode_actions (t, tdp_actions, stepping_actions) if (collect == &stepping_list) /* end stepping actions */ collect = &tracepoint_list; else - break; /* end tracepoint actions */ + break; /* end tracepoint actions */ } - } /* for */ - memrange_sortmerge (&tracepoint_list); - memrange_sortmerge (&stepping_list); + } /* for */ + memrange_sortmerge (&tracepoint_list); + memrange_sortmerge (&stepping_list); - *tdp_actions = stringify_collection_list (&tracepoint_list, &tdp_buff); - *stepping_actions = stringify_collection_list (&stepping_list, &step_buff); + *tdp_actions = stringify_collection_list (&tracepoint_list, &tdp_buff); + *stepping_actions = stringify_collection_list (&stepping_list, &step_buff); } static void -add_aexpr(collect, aexpr) +add_aexpr (collect, aexpr) struct collection_list *collect; struct agent_expr *aexpr; { @@ -1644,7 +1660,7 @@ add_aexpr(collect, aexpr) { collect->aexpr_list = xrealloc (collect->aexpr_list, - 2 * collect->aexpr_listsize * sizeof (struct agent_expr *)); + 2 * collect->aexpr_listsize * sizeof (struct agent_expr *)); collect->aexpr_listsize *= 2; } collect->aexpr_list[collect->next_aexpr_elt] = aexpr; @@ -1670,20 +1686,20 @@ remote_set_transparent_ranges (void) int anysecs = 0; if (!exec_bfd) - return; /* no information to give. */ + return; /* no information to give. */ strcpy (target_buf, "QTro"); for (s = exec_bfd->sections; s; s = s->next) { char tmp[40]; - if ((s->flags & SEC_LOAD) == 0 || - /* (s->flags & SEC_CODE) == 0 || */ + if ((s->flags & SEC_LOAD) == 0 || + /* (s->flags & SEC_CODE) == 0 || */ (s->flags & SEC_READONLY) == 0) continue; anysecs = 1; - lma = s->lma; + lma = s->lma; size = bfd_get_section_size_before_reloc (s); sprintf (tmp, ":%x,%x", lma, lma + size); strcat (target_buf, tmp); @@ -1696,7 +1712,7 @@ remote_set_transparent_ranges (void) } /* tstart command: - + Tell target to clear any previous trace experiment. Walk the list of tracepoints, and send them (and their actions) to the target. If no errors, @@ -1706,7 +1722,7 @@ static void trace_start_command (args, from_tty) char *args; int from_tty; -{ /* STUB_COMM MOSTLY_IMPLEMENTED */ +{ /* STUB_COMM MOSTLY_IMPLEMENTED */ struct tracepoint *t; char buf[2048]; char **tdp_actions; @@ -1714,8 +1730,8 @@ trace_start_command (args, from_tty) int ndx; struct cleanup *old_chain = NULL; - dont_repeat (); /* like "run", dangerous to repeat accidentally */ - + dont_repeat (); /* like "run", dangerous to repeat accidentally */ + if (target_is_remote ()) { putpkt ("QTinit"); @@ -1724,67 +1740,67 @@ trace_start_command (args, from_tty) error ("Target does not support this command."); ALL_TRACEPOINTS (t) - { - int ss_count; /* if actions include singlestepping */ - int disable_mask; /* ??? */ - int enable_mask; /* ??? */ - - sprintf (buf, "QTDP:%x:%x:%c:%x:%x", t->number, t->address, - t->enabled == enabled ? 'E' : 'D', - t->step_count, t->pass_count); - - if (t->actions) - strcat (buf, "-"); - putpkt (buf); - remote_get_noisy_reply (target_buf); - if (strcmp (target_buf, "OK")) - error ("Target does not support tracepoints."); - - if (t->actions) - { - encode_actions (t, &tdp_actions, &stepping_actions); - old_chain = make_cleanup (free_actions_list_cleanup_wrapper, - tdp_actions); - (void) make_cleanup (free_actions_list_cleanup_wrapper, - stepping_actions); - - /* do_single_steps (t); */ - if (tdp_actions) - { - for (ndx = 0; tdp_actions[ndx]; ndx++) - { - QUIT; /* allow user to bail out with ^C */ - sprintf (buf, "QTDP:-%x:%x:%s%c", - t->number, t->address, - tdp_actions[ndx], - ((tdp_actions[ndx+1] || stepping_actions) - ? '-' : 0)); - putpkt (buf); - remote_get_noisy_reply (target_buf); - if (strcmp (target_buf, "OK")) - error ("Error on target while setting tracepoints."); - } - } - if (stepping_actions) - { - for (ndx = 0; stepping_actions[ndx]; ndx++) - { - QUIT; /* allow user to bail out with ^C */ - sprintf (buf, "QTDP:-%x:%x:%s%s%s", - t->number, t->address, - ((ndx == 0) ? "S" : ""), - stepping_actions[ndx], - (stepping_actions[ndx+1] ? "-" : "")); - putpkt (buf); - remote_get_noisy_reply (target_buf); - if (strcmp (target_buf, "OK")) - error ("Error on target while setting tracepoints."); - } - } + { + int ss_count; /* if actions include singlestepping */ + int disable_mask; /* ??? */ + int enable_mask; /* ??? */ - do_cleanups (old_chain); - } - } + sprintf (buf, "QTDP:%x:%x:%c:%x:%x", t->number, t->address, + t->enabled == enabled ? 'E' : 'D', + t->step_count, t->pass_count); + + if (t->actions) + strcat (buf, "-"); + putpkt (buf); + remote_get_noisy_reply (target_buf); + if (strcmp (target_buf, "OK")) + error ("Target does not support tracepoints."); + + if (t->actions) + { + encode_actions (t, &tdp_actions, &stepping_actions); + old_chain = make_cleanup (free_actions_list_cleanup_wrapper, + tdp_actions); + (void) make_cleanup (free_actions_list_cleanup_wrapper, + stepping_actions); + + /* do_single_steps (t); */ + if (tdp_actions) + { + for (ndx = 0; tdp_actions[ndx]; ndx++) + { + QUIT; /* allow user to bail out with ^C */ + sprintf (buf, "QTDP:-%x:%x:%s%c", + t->number, t->address, + tdp_actions[ndx], + ((tdp_actions[ndx + 1] || stepping_actions) + ? '-' : 0)); + putpkt (buf); + remote_get_noisy_reply (target_buf); + if (strcmp (target_buf, "OK")) + error ("Error on target while setting tracepoints."); + } + } + if (stepping_actions) + { + for (ndx = 0; stepping_actions[ndx]; ndx++) + { + QUIT; /* allow user to bail out with ^C */ + sprintf (buf, "QTDP:-%x:%x:%s%s%s", + t->number, t->address, + ((ndx == 0) ? "S" : ""), + stepping_actions[ndx], + (stepping_actions[ndx + 1] ? "-" : "")); + putpkt (buf); + remote_get_noisy_reply (target_buf); + if (strcmp (target_buf, "OK")) + error ("Error on target while setting tracepoints."); + } + } + + do_cleanups (old_chain); + } + } /* Tell target to treat text-like sections as transparent */ remote_set_transparent_ranges (); /* Now insert traps and begin collecting data */ @@ -1794,11 +1810,11 @@ trace_start_command (args, from_tty) error ("Bogus reply from target: %s", target_buf); set_traceframe_num (-1); /* all old traceframes invalidated */ set_tracepoint_num (-1); - set_traceframe_context(-1); + set_traceframe_context (-1); trace_running_p = 1; if (trace_start_stop_hook) - trace_start_stop_hook(1, from_tty); - + trace_start_stop_hook (1, from_tty); + } else error ("Trace can only be run on remote targets."); @@ -1809,7 +1825,7 @@ static void trace_stop_command (args, from_tty) char *args; int from_tty; -{ /* STUB_COMM IS_IMPLEMENTED */ +{ /* STUB_COMM IS_IMPLEMENTED */ if (target_is_remote ()) { putpkt ("QTStop"); @@ -1818,7 +1834,7 @@ trace_stop_command (args, from_tty) error ("Bogus reply from target: %s", target_buf); trace_running_p = 0; if (trace_start_stop_hook) - trace_start_stop_hook(0, from_tty); + trace_start_stop_hook (0, from_tty); } else error ("Trace can only be run on remote targets."); @@ -1831,7 +1847,7 @@ static void trace_status_command (args, from_tty) char *args; int from_tty; -{ /* STUB_COMM IS_IMPLEMENTED */ +{ /* STUB_COMM IS_IMPLEMENTED */ if (target_is_remote ()) { putpkt ("qTStatus"); @@ -1860,63 +1876,64 @@ finish_tfind_command (msg, from_tty) char *reply; old_frame_addr = FRAME_FP (get_current_frame ()); - old_func = find_pc_function (read_pc ()); + old_func = find_pc_function (read_pc ()); putpkt (msg); reply = remote_get_noisy_reply (msg); while (reply && *reply) - switch (*reply) { - case 'F': - if ((target_frameno = (int) strtol (++reply, &reply, 16)) == -1) - { - /* A request for a non-existant trace frame has failed. - Our response will be different, depending on FROM_TTY: - - If FROM_TTY is true, meaning that this command was - typed interactively by the user, then give an error - and DO NOT change the state of traceframe_number etc. - - However if FROM_TTY is false, meaning that we're either - in a script, a loop, or a user-defined command, then - DON'T give an error, but DO change the state of - traceframe_number etc. to invalid. - - The rationalle is that if you typed the command, you - might just have committed a typo or something, and you'd - like to NOT lose your current debugging state. However - if you're in a user-defined command or especially in a - loop, then you need a way to detect that the command - failed WITHOUT aborting. This allows you to write - scripts that search thru the trace buffer until the end, - and then continue on to do something else. */ - - if (from_tty) - error ("Target failed to find requested trace frame."); - else - { - if (info_verbose) - printf_filtered ("End of trace buffer.\n"); - /* The following will not recurse, since it's special-cased */ - trace_find_command ("-1", from_tty); - reply = NULL; /* break out of loop, + switch (*reply) + { + case 'F': + if ((target_frameno = (int) strtol (++reply, &reply, 16)) == -1) + { + /* A request for a non-existant trace frame has failed. + Our response will be different, depending on FROM_TTY: + + If FROM_TTY is true, meaning that this command was + typed interactively by the user, then give an error + and DO NOT change the state of traceframe_number etc. + + However if FROM_TTY is false, meaning that we're either + in a script, a loop, or a user-defined command, then + DON'T give an error, but DO change the state of + traceframe_number etc. to invalid. + + The rationalle is that if you typed the command, you + might just have committed a typo or something, and you'd + like to NOT lose your current debugging state. However + if you're in a user-defined command or especially in a + loop, then you need a way to detect that the command + failed WITHOUT aborting. This allows you to write + scripts that search thru the trace buffer until the end, + and then continue on to do something else. */ + + if (from_tty) + error ("Target failed to find requested trace frame."); + else + { + if (info_verbose) + printf_filtered ("End of trace buffer.\n"); + /* The following will not recurse, since it's special-cased */ + trace_find_command ("-1", from_tty); + reply = NULL; /* break out of loop, (avoid recursive nonsense) */ - } - } - break; - case 'T': - if ((target_tracept = (int) strtol (++reply, &reply, 16)) == -1) - error ("Target failed to find requested trace frame."); - break; - case 'O': /* "OK"? */ - if (reply[1] == 'K' && reply[2] == '\0') - reply += 2; - else + } + } + break; + case 'T': + if ((target_tracept = (int) strtol (++reply, &reply, 16)) == -1) + error ("Target failed to find requested trace frame."); + break; + case 'O': /* "OK"? */ + if (reply[1] == 'K' && reply[2] == '\0') + reply += 2; + else + error ("Bogus reply from target: %s", reply); + break; + default: error ("Bogus reply from target: %s", reply); - break; - default: - error ("Bogus reply from target: %s", reply); - } + } flush_cached_frames (); registers_changed (); @@ -1933,22 +1950,22 @@ finish_tfind_command (msg, from_tty) int source_only; /* NOTE: in immitation of the step command, try to determine - whether we have made a transition from one function to another. - If so, we'll print the "stack frame" (ie. the new function and - it's arguments) -- otherwise we'll just show the new source line. - - This determination is made by checking (1) whether the current - function has changed, and (2) whether the current FP has changed. - Hack: if the FP wasn't collected, either at the current or the - previous frame, assume that the FP has NOT changed. */ - - if (old_func == find_pc_function (read_pc ()) && - (old_frame_addr == 0 || - FRAME_FP (get_current_frame ()) == 0 || - old_frame_addr == FRAME_FP (get_current_frame ()))) + whether we have made a transition from one function to another. + If so, we'll print the "stack frame" (ie. the new function and + it's arguments) -- otherwise we'll just show the new source line. + + This determination is made by checking (1) whether the current + function has changed, and (2) whether the current FP has changed. + Hack: if the FP wasn't collected, either at the current or the + previous frame, assume that the FP has NOT changed. */ + + if (old_func == find_pc_function (read_pc ()) && + (old_frame_addr == 0 || + FRAME_FP (get_current_frame ()) == 0 || + old_frame_addr == FRAME_FP (get_current_frame ()))) source_only = -1; else - source_only = 1; + source_only = 1; print_stack_frame (selected_frame, selected_frame_level, source_only); do_displays (); @@ -1965,16 +1982,16 @@ finish_tfind_command (msg, from_tty) target does not give us a frame number or a tracepoint number). Instead of that, the target may send us a string containing any combination of: - F<hexnum> (gives the selected frame number) - T<hexnum> (gives the selected tracepoint number) - */ + F<hexnum> (gives the selected frame number) + T<hexnum> (gives the selected tracepoint number) + */ /* tfind command */ static void trace_find_command (args, from_tty) char *args; int from_tty; -{ /* STUB_COMM PART_IMPLEMENTED */ +{ /* STUB_COMM PART_IMPLEMENTED */ /* this should only be called with a numeric argument */ int frameno = -1; char *tmp; @@ -1982,10 +1999,10 @@ trace_find_command (args, from_tty) if (target_is_remote ()) { if (trace_find_hook) - trace_find_hook (args, from_tty); - + trace_find_hook (args, from_tty); + if (args == 0 || *args == 0) - { /* TFIND with no args means find NEXT trace frame. */ + { /* TFIND with no args means find NEXT trace frame. */ if (traceframe_number == -1) frameno = 0; /* "next" is first one */ else @@ -2045,7 +2062,7 @@ static void trace_find_pc_command (args, from_tty) char *args; int from_tty; -{ /* STUB_COMM PART_IMPLEMENTED */ +{ /* STUB_COMM PART_IMPLEMENTED */ CORE_ADDR pc; char *tmp; @@ -2068,7 +2085,7 @@ static void trace_find_tracepoint_command (args, from_tty) char *args; int from_tty; -{ /* STUB_COMM PART_IMPLEMENTED */ +{ /* STUB_COMM PART_IMPLEMENTED */ int tdp; char buf[40], *tmp; @@ -2090,10 +2107,10 @@ trace_find_tracepoint_command (args, from_tty) } /* TFIND LINE command: - + This command will take a sourceline for argument, just like BREAK or TRACE (ie. anything that "decode_line_1" can handle). - + With no argument, this command will find the next trace frame corresponding to a source line OTHER THAN THE CURRENT ONE. */ @@ -2101,7 +2118,7 @@ static void trace_find_line_command (args, from_tty) char *args; int from_tty; -{ /* STUB_COMM PART_IMPLEMENTED */ +{ /* STUB_COMM PART_IMPLEMENTED */ static CORE_ADDR start_pc, end_pc; struct symtabs_and_lines sals; struct symtab_and_line sal; @@ -2121,7 +2138,7 @@ trace_find_line_command (args, from_tty) else { sals = decode_line_spec (args, 1); - sal = sals.sals[0]; + sal = sals.sals[0]; } old_chain = make_cleanup (free, sals.sals); @@ -2131,8 +2148,8 @@ trace_find_line_command (args, from_tty) if (sal.pc != 0) { /* This is useful for "info line *0x7f34". If we can't tell the - user about a source line, at least let them have the symbolic - address. */ + user about a source line, at least let them have the symbolic + address. */ printf_filtered (" for address "); wrap_here (" "); print_address (sal.pc, gdb_stdout); @@ -2141,7 +2158,7 @@ trace_find_line_command (args, from_tty) else { printf_filtered (".\n"); - return; /* no line, no PC; what can we do? */ + return; /* no line, no PC; what can we do? */ } } else if (sal.line > 0 @@ -2181,7 +2198,7 @@ trace_find_line_command (args, from_tty) do_cleanups (old_chain); } else - error ("Trace can only be run on remote targets."); + error ("Trace can only be run on remote targets."); } /* tfind range command */ @@ -2189,37 +2206,37 @@ static void trace_find_range_command (args, from_tty) char *args; int from_tty; -{ /* STUB_COMM PART_IMPLEMENTED */ +{ /* STUB_COMM PART_IMPLEMENTED */ static CORE_ADDR start, stop; char *tmp; if (target_is_remote ()) { if (args == 0 || *args == 0) - { /* XXX FIXME: what should default behavior be? */ + { /* XXX FIXME: what should default behavior be? */ printf_filtered ("Usage: tfind range <startaddr>,<endaddr>\n"); return; } - if (0 != (tmp = strchr (args, ',' ))) + if (0 != (tmp = strchr (args, ','))) { *tmp++ = '\0'; /* terminate start address */ while (isspace (*tmp)) tmp++; start = parse_and_eval_address (args); - stop = parse_and_eval_address (tmp); + stop = parse_and_eval_address (tmp); } else - { /* no explicit end address? */ + { /* no explicit end address? */ start = parse_and_eval_address (args); - stop = start + 1; /* ??? */ + stop = start + 1; /* ??? */ } sprintf (target_buf, "QTFrame:range:%x:%x", start, stop); finish_tfind_command (target_buf, from_tty); } else - error ("Trace can only be run on remote targets."); + error ("Trace can only be run on remote targets."); } /* tfind outside command */ @@ -2227,37 +2244,37 @@ static void trace_find_outside_command (args, from_tty) char *args; int from_tty; -{ /* STUB_COMM PART_IMPLEMENTED */ +{ /* STUB_COMM PART_IMPLEMENTED */ CORE_ADDR start, stop; char *tmp; if (target_is_remote ()) { if (args == 0 || *args == 0) - { /* XXX FIXME: what should default behavior be? */ + { /* XXX FIXME: what should default behavior be? */ printf_filtered ("Usage: tfind outside <startaddr>,<endaddr>\n"); return; } - if (0 != (tmp = strchr (args, ',' ))) + if (0 != (tmp = strchr (args, ','))) { *tmp++ = '\0'; /* terminate start address */ while (isspace (*tmp)) tmp++; start = parse_and_eval_address (args); - stop = parse_and_eval_address (tmp); + stop = parse_and_eval_address (tmp); } else - { /* no explicit end address? */ + { /* no explicit end address? */ start = parse_and_eval_address (args); - stop = start + 1; /* ??? */ + stop = start + 1; /* ??? */ } sprintf (target_buf, "QTFrame:outside:%x:%x", start, stop); finish_tfind_command (target_buf, from_tty); } else - error ("Trace can only be run on remote targets."); + error ("Trace can only be run on remote targets."); } /* save-tracepoints command */ @@ -2266,7 +2283,7 @@ tracepoint_save_command (args, from_tty) char *args; int from_tty; { - struct tracepoint *tp; + struct tracepoint *tp; struct action_line *line; FILE *fp; char *i1 = " ", *i2 = " "; @@ -2285,42 +2302,42 @@ tracepoint_save_command (args, from_tty) error ("Unable to open file '%s' for saving tracepoints"); ALL_TRACEPOINTS (tp) - { - if (tp->addr_string) - fprintf (fp, "trace %s\n", tp->addr_string); - else - fprintf (fp, "trace *0x%x\n", tp->address); + { + if (tp->addr_string) + fprintf (fp, "trace %s\n", tp->addr_string); + else + fprintf (fp, "trace *0x%x\n", tp->address); - if (tp->pass_count) - fprintf (fp, " passcount %d\n", tp->pass_count); + if (tp->pass_count) + fprintf (fp, " passcount %d\n", tp->pass_count); - if (tp->actions) - { - fprintf (fp, " actions\n"); - indent = i1; - for (line = tp->actions; line; line = line->next) - { - struct cmd_list_element *cmd; + if (tp->actions) + { + fprintf (fp, " actions\n"); + indent = i1; + for (line = tp->actions; line; line = line->next) + { + struct cmd_list_element *cmd; - QUIT; /* allow user to bail out with ^C */ - actionline = line->action; - while (isspace(*actionline)) - actionline++; + QUIT; /* allow user to bail out with ^C */ + actionline = line->action; + while (isspace (*actionline)) + actionline++; - fprintf (fp, "%s%s\n", indent, actionline); - if (*actionline != '#') /* skip for comment lines */ - { - cmd = lookup_cmd (&actionline, cmdlist, "", -1, 1); - if (cmd == 0) - error ("Bad action list item: %s", actionline); - if (cmd->function.cfunc == while_stepping_pseudocommand) - indent = i2; - else if (cmd->function.cfunc == end_actions_pseudocommand) - indent = i1; - } - } - } - } + fprintf (fp, "%s%s\n", indent, actionline); + if (*actionline != '#') /* skip for comment lines */ + { + cmd = lookup_cmd (&actionline, cmdlist, "", -1, 1); + if (cmd == 0) + error ("Bad action list item: %s", actionline); + if (cmd->function.cfunc == while_stepping_pseudocommand) + indent = i2; + else if (cmd->function.cfunc == end_actions_pseudocommand) + indent = i1; + } + } + } + } fclose (fp); if (from_tty) printf_filtered ("Tracepoints saved to file '%s'.\n", args); @@ -2346,7 +2363,7 @@ scope_info (args, from_tty) sals = decode_line_1 (&args, 1, NULL, 0, &canonical); if (sals.nelts == 0) - return; /* presumably decode_line_1 has already warned */ + return; /* presumably decode_line_1 has already warned */ /* Resolve line numbers to PC */ resolve_sal_pc (&sals.sals[0]); @@ -2354,107 +2371,108 @@ scope_info (args, from_tty) while (block != 0) { - QUIT; /* allow user to bail out with ^C */ + QUIT; /* allow user to bail out with ^C */ nsyms = BLOCK_NSYMS (block); for (i = 0; i < nsyms; i++) { - QUIT; /* allow user to bail out with ^C */ + QUIT; /* allow user to bail out with ^C */ if (count == 0) printf_filtered ("Scope for %s:\n", save_args); count++; sym = BLOCK_SYM (block, i); symname = SYMBOL_NAME (sym); if (symname == NULL || *symname == '\0') - continue; /* probably botched, certainly useless */ + continue; /* probably botched, certainly useless */ printf_filtered ("Symbol %s is ", symname); - switch (SYMBOL_CLASS (sym)) { - default: - case LOC_UNDEF: /* messed up symbol? */ - printf_filtered ("a bogus symbol, class %d.\n", - SYMBOL_CLASS (sym)); - count--; /* don't count this one */ - continue; - case LOC_CONST: - printf_filtered ("a constant with value %d (0x%x)", - SYMBOL_VALUE (sym), SYMBOL_VALUE (sym)); - break; - case LOC_CONST_BYTES: - printf_filtered ("constant bytes: "); - if (SYMBOL_TYPE (sym)) - for (j = 0; j < TYPE_LENGTH (SYMBOL_TYPE (sym)); j++) - fprintf_filtered (gdb_stdout, " %02x", - (unsigned) SYMBOL_VALUE_BYTES (sym) [j]); - break; - case LOC_STATIC: - printf_filtered ("in static storage at address "); - print_address_numeric (SYMBOL_VALUE_ADDRESS (sym), 1, gdb_stdout); - break; - case LOC_REGISTER: - printf_filtered ("a local variable in register $%s", - REGISTER_NAME (SYMBOL_VALUE (sym))); - break; - case LOC_ARG: - case LOC_LOCAL_ARG: - printf_filtered ("an argument at stack/frame offset %ld", - SYMBOL_VALUE (sym)); - break; - case LOC_LOCAL: - printf_filtered ("a local variable at frame offset %ld", - SYMBOL_VALUE (sym)); - break; - case LOC_REF_ARG: - printf_filtered ("a reference argument at offset %ld", - SYMBOL_VALUE (sym)); - break; - case LOC_REGPARM: - printf_filtered ("an argument in register $%s", - REGISTER_NAME (SYMBOL_VALUE (sym))); - break; - case LOC_REGPARM_ADDR: - printf_filtered ("the address of an argument, in register $%s", - REGISTER_NAME (SYMBOL_VALUE (sym))); - break; - case LOC_TYPEDEF: - printf_filtered ("a typedef.\n"); - continue; - case LOC_LABEL: - printf_filtered ("a label at address "); - print_address_numeric (SYMBOL_VALUE_ADDRESS (sym), 1, gdb_stdout); - break; - case LOC_BLOCK: - printf_filtered ("a function at address "); - print_address_numeric (BLOCK_START (SYMBOL_BLOCK_VALUE (sym)), 1, - gdb_stdout); - break; - case LOC_BASEREG: - printf_filtered ("a variable at offset %d from register $%s", - SYMBOL_VALUE (sym), - REGISTER_NAME (SYMBOL_BASEREG (sym))); - break; - case LOC_BASEREG_ARG: - printf_filtered ("an argument at offset %d from register $%s", - SYMBOL_VALUE (sym), - REGISTER_NAME (SYMBOL_BASEREG (sym))); - break; - case LOC_UNRESOLVED: - msym = lookup_minimal_symbol (SYMBOL_NAME (sym), NULL, NULL); - if (msym == NULL) - printf_filtered ("Unresolved Static"); - else - { - printf_filtered ("static storage at address "); - print_address_numeric (SYMBOL_VALUE_ADDRESS (msym), 1, - gdb_stdout); - } - break; - case LOC_OPTIMIZED_OUT: - printf_filtered ("optimized out.\n"); - continue; - } + switch (SYMBOL_CLASS (sym)) + { + default: + case LOC_UNDEF: /* messed up symbol? */ + printf_filtered ("a bogus symbol, class %d.\n", + SYMBOL_CLASS (sym)); + count--; /* don't count this one */ + continue; + case LOC_CONST: + printf_filtered ("a constant with value %d (0x%x)", + SYMBOL_VALUE (sym), SYMBOL_VALUE (sym)); + break; + case LOC_CONST_BYTES: + printf_filtered ("constant bytes: "); + if (SYMBOL_TYPE (sym)) + for (j = 0; j < TYPE_LENGTH (SYMBOL_TYPE (sym)); j++) + fprintf_filtered (gdb_stdout, " %02x", + (unsigned) SYMBOL_VALUE_BYTES (sym)[j]); + break; + case LOC_STATIC: + printf_filtered ("in static storage at address "); + print_address_numeric (SYMBOL_VALUE_ADDRESS (sym), 1, gdb_stdout); + break; + case LOC_REGISTER: + printf_filtered ("a local variable in register $%s", + REGISTER_NAME (SYMBOL_VALUE (sym))); + break; + case LOC_ARG: + case LOC_LOCAL_ARG: + printf_filtered ("an argument at stack/frame offset %ld", + SYMBOL_VALUE (sym)); + break; + case LOC_LOCAL: + printf_filtered ("a local variable at frame offset %ld", + SYMBOL_VALUE (sym)); + break; + case LOC_REF_ARG: + printf_filtered ("a reference argument at offset %ld", + SYMBOL_VALUE (sym)); + break; + case LOC_REGPARM: + printf_filtered ("an argument in register $%s", + REGISTER_NAME (SYMBOL_VALUE (sym))); + break; + case LOC_REGPARM_ADDR: + printf_filtered ("the address of an argument, in register $%s", + REGISTER_NAME (SYMBOL_VALUE (sym))); + break; + case LOC_TYPEDEF: + printf_filtered ("a typedef.\n"); + continue; + case LOC_LABEL: + printf_filtered ("a label at address "); + print_address_numeric (SYMBOL_VALUE_ADDRESS (sym), 1, gdb_stdout); + break; + case LOC_BLOCK: + printf_filtered ("a function at address "); + print_address_numeric (BLOCK_START (SYMBOL_BLOCK_VALUE (sym)), 1, + gdb_stdout); + break; + case LOC_BASEREG: + printf_filtered ("a variable at offset %d from register $%s", + SYMBOL_VALUE (sym), + REGISTER_NAME (SYMBOL_BASEREG (sym))); + break; + case LOC_BASEREG_ARG: + printf_filtered ("an argument at offset %d from register $%s", + SYMBOL_VALUE (sym), + REGISTER_NAME (SYMBOL_BASEREG (sym))); + break; + case LOC_UNRESOLVED: + msym = lookup_minimal_symbol (SYMBOL_NAME (sym), NULL, NULL); + if (msym == NULL) + printf_filtered ("Unresolved Static"); + else + { + printf_filtered ("static storage at address "); + print_address_numeric (SYMBOL_VALUE_ADDRESS (msym), 1, + gdb_stdout); + } + break; + case LOC_OPTIMIZED_OUT: + printf_filtered ("optimized out.\n"); + continue; + } if (SYMBOL_TYPE (sym)) - printf_filtered (", length %d.\n", - TYPE_LENGTH (check_typedef (SYMBOL_TYPE (sym)))); + printf_filtered (", length %d.\n", + TYPE_LENGTH (check_typedef (SYMBOL_TYPE (sym)))); } if (BLOCK_FUNCTION (block)) break; @@ -2480,12 +2498,12 @@ trace_dump_command (args, from_tty) char *args; int from_tty; { - struct tracepoint *t; + struct tracepoint *t; struct action_line *action; - char *action_exp, *next_comma; - struct cleanup *old_cleanups; - int stepping_actions = 0; - int stepping_frame = 0; + char *action_exp, *next_comma; + struct cleanup *old_cleanups; + int stepping_actions = 0; + int stepping_frame = 0; if (!target_is_remote ()) { @@ -2501,34 +2519,34 @@ trace_dump_command (args, from_tty) ALL_TRACEPOINTS (t) if (t->number == tracepoint_number) - break; + break; if (t == NULL) - error ("No known tracepoint matches 'current' tracepoint #%d.", + error ("No known tracepoint matches 'current' tracepoint #%d.", tracepoint_number); old_cleanups = make_cleanup (null_cleanup, NULL); - printf_filtered ("Data collected at tracepoint %d, trace frame %d:\n", + printf_filtered ("Data collected at tracepoint %d, trace frame %d:\n", tracepoint_number, traceframe_number); /* The current frame is a trap frame if the frame PC is equal to the tracepoint PC. If not, then the current frame was collected during single-stepping. */ - stepping_frame = (t->address != read_pc()); + stepping_frame = (t->address != read_pc ()); for (action = t->actions; action; action = action->next) { struct cmd_list_element *cmd; - QUIT; /* allow user to bail out with ^C */ + QUIT; /* allow user to bail out with ^C */ action_exp = action->action; while (isspace (*action_exp)) action_exp++; /* The collection actions to be done while stepping are - bracketed by the commands "while-stepping" and "end". */ + bracketed by the commands "while-stepping" and "end". */ if (*action_exp == '#') /* comment line */ continue; @@ -2550,36 +2568,38 @@ trace_dump_command (args, from_tty) STEPPING_FRAME and STEPPING_ACTIONS should be equal. */ if (stepping_frame == stepping_actions) { - do { /* repeat over a comma-separated list */ - QUIT; /* allow user to bail out with ^C */ - if (*action_exp == ',') - action_exp++; - while (isspace (*action_exp)) - action_exp++; - - next_comma = strchr (action_exp, ','); - - if (0 == strncasecmp (action_exp, "$reg", 4)) - registers_info (NULL, from_tty); - else if (0 == strncasecmp (action_exp, "$loc", 4)) - locals_info (NULL, from_tty); - else if (0 == strncasecmp (action_exp, "$arg", 4)) - args_info (NULL, from_tty); - else - { /* variable */ - if (next_comma) - { - make_cleanup (replace_comma, next_comma); - *next_comma = '\0'; - } - printf_filtered ("%s = ", action_exp); - output_command (action_exp, from_tty); - printf_filtered ("\n"); - } - if (next_comma) - *next_comma = ','; - action_exp = next_comma; - } while (action_exp && *action_exp == ','); + do + { /* repeat over a comma-separated list */ + QUIT; /* allow user to bail out with ^C */ + if (*action_exp == ',') + action_exp++; + while (isspace (*action_exp)) + action_exp++; + + next_comma = strchr (action_exp, ','); + + if (0 == strncasecmp (action_exp, "$reg", 4)) + registers_info (NULL, from_tty); + else if (0 == strncasecmp (action_exp, "$loc", 4)) + locals_info (NULL, from_tty); + else if (0 == strncasecmp (action_exp, "$arg", 4)) + args_info (NULL, from_tty); + else + { /* variable */ + if (next_comma) + { + make_cleanup (replace_comma, next_comma); + *next_comma = '\0'; + } + printf_filtered ("%s = ", action_exp); + output_command (action_exp, from_tty); + printf_filtered ("\n"); + } + if (next_comma) + *next_comma = ','; + action_exp = next_comma; + } + while (action_exp && *action_exp == ','); } } } @@ -2591,10 +2611,10 @@ trace_dump_command (args, from_tty) * "stolen" from sparc-stub.c */ -static const char hexchars[]="0123456789abcdef"; +static const char hexchars[] = "0123456789abcdef"; static unsigned char * -mem2hex(mem, buf, count) +mem2hex (mem, buf, count) unsigned char *mem; unsigned char *buf; int count; @@ -2614,9 +2634,10 @@ mem2hex(mem, buf, count) return buf; } -int get_traceframe_number() +int +get_traceframe_number () { - return traceframe_number; + return traceframe_number; } @@ -2624,20 +2645,20 @@ int get_traceframe_number() void _initialize_tracepoint () { - tracepoint_chain = 0; - tracepoint_count = 0; + tracepoint_chain = 0; + tracepoint_count = 0; traceframe_number = -1; tracepoint_number = -1; - set_internalvar (lookup_internalvar ("tpnum"), + set_internalvar (lookup_internalvar ("tpnum"), value_from_longest (builtin_type_int, (LONGEST) 0)); - set_internalvar (lookup_internalvar ("trace_frame"), - value_from_longest (builtin_type_int, (LONGEST) -1)); + set_internalvar (lookup_internalvar ("trace_frame"), + value_from_longest (builtin_type_int, (LONGEST) - 1)); if (tracepoint_list.list == NULL) { tracepoint_list.listsize = 128; - tracepoint_list.list = xmalloc + tracepoint_list.list = xmalloc (tracepoint_list.listsize * sizeof (struct memrange)); } if (tracepoint_list.aexpr_list == NULL) @@ -2650,7 +2671,7 @@ _initialize_tracepoint () if (stepping_list.list == NULL) { stepping_list.listsize = 128; - stepping_list.list = xmalloc + stepping_list.list = xmalloc (stepping_list.listsize * sizeof (struct memrange)); } @@ -2661,11 +2682,11 @@ _initialize_tracepoint () (stepping_list.aexpr_listsize * sizeof (struct agent_expr *)); } - add_info ("scope", scope_info, + add_info ("scope", scope_info, "List the variables local to a scope"); - add_cmd ("tracepoints", class_trace, NO_FUNCTION, - "Tracing of program execution without stopping the program.", + add_cmd ("tracepoints", class_trace, NO_FUNCTION, + "Tracing of program execution without stopping the program.", &cmdlist); add_info ("tracepoints", tracepoints_info, @@ -2675,26 +2696,26 @@ last tracepoint set."); add_info_alias ("tp", "tracepoints", 1); - add_com ("save-tracepoints", class_trace, tracepoint_save_command, + add_com ("save-tracepoints", class_trace, tracepoint_save_command, "Save current tracepoint definitions as a script.\n\ Use the 'source' command in another debug session to restore them."); - add_com ("tdump", class_trace, trace_dump_command, + add_com ("tdump", class_trace, trace_dump_command, "Print everything collected at the current tracepoint."); - add_prefix_cmd ("tfind", class_trace, trace_find_command, + add_prefix_cmd ("tfind", class_trace, trace_find_command, "Select a trace frame;\n\ No argument means forward by one frame; '-' meand backward by one frame.", &tfindlist, "tfind ", 1, &cmdlist); add_cmd ("outside", class_trace, trace_find_outside_command, "Select a trace frame whose PC is outside the given \ -range.\nUsage: tfind outside addr1, addr2", +range.\nUsage: tfind outside addr1, addr2", &tfindlist); add_cmd ("range", class_trace, trace_find_range_command, "Select a trace frame whose PC is in the given range.\n\ -Usage: tfind range addr1,addr2", +Usage: tfind range addr1,addr2", &tfindlist); add_cmd ("line", class_trace, trace_find_line_command, @@ -2727,16 +2748,16 @@ De-select any trace frame and resume 'live' debugging.", "Select the first trace frame in the trace buffer.", &tfindlist); - add_com ("tstatus", class_trace, trace_status_command, + add_com ("tstatus", class_trace, trace_status_command, "Display the status of the current trace data collection."); - add_com ("tstop", class_trace, trace_stop_command, + add_com ("tstop", class_trace, trace_stop_command, "Stop trace data collection."); add_com ("tstart", class_trace, trace_start_command, "Start trace data collection."); - add_com ("passcount", class_trace, trace_pass_command, + add_com ("passcount", class_trace, trace_pass_command, "Set the passcount for a tracepoint.\n\ The trace will end when the tracepoint has been passed 'count' times.\n\ Usage: passcount COUNT TPNUM, where TPNUM may also be \"all\";\n\ @@ -2757,10 +2778,10 @@ one or more \"collect\" commands, to specify what to collect\n\ while single-stepping.\n\n\ Note: this command can only be used in a tracepoint \"actions\" list."); - add_com_alias ("ws", "while-stepping", class_alias, 0); - add_com_alias ("stepping", "while-stepping", class_alias, 0); + add_com_alias ("ws", "while-stepping", class_alias, 0); + add_com_alias ("stepping", "while-stepping", class_alias, 0); - add_com ("collect", class_trace, collect_pseudocommand, + add_com ("collect", class_trace, collect_pseudocommand, "Specify one or more data items to be collected at a tracepoint.\n\ Accepts a comma-separated list of (one or more) expressions. GDB will\n\ collect all data (variables, registers) referenced by that expression.\n\ @@ -2776,19 +2797,19 @@ Tracepoint actions may include collecting of specified data, \n\ single-stepping, or enabling/disabling other tracepoints, \n\ depending on target's capabilities."); - add_cmd ("tracepoints", class_trace, delete_trace_command, + add_cmd ("tracepoints", class_trace, delete_trace_command, "Delete specified tracepoints.\n\ Arguments are tracepoint numbers, separated by spaces.\n\ No argument means delete all tracepoints.", &deletelist); - add_cmd ("tracepoints", class_trace, disable_trace_command, + add_cmd ("tracepoints", class_trace, disable_trace_command, "Disable specified tracepoints.\n\ Arguments are tracepoint numbers, separated by spaces.\n\ No argument means disable all tracepoints.", &disablelist); - add_cmd ("tracepoints", class_trace, enable_trace_command, + add_cmd ("tracepoints", class_trace, enable_trace_command, "Enable specified tracepoints.\n\ Arguments are tracepoint numbers, separated by spaces.\n\ No argument means enable all tracepoints.", @@ -2801,9 +2822,8 @@ For a line number or function, trace at the start of its code.\n\ If an address is specified, trace at that exact address.\n\n\ Do \"help tracepoints\" for info on other tracepoint commands."); - add_com_alias ("tp", "trace", class_alias, 0); - add_com_alias ("tr", "trace", class_alias, 1); - add_com_alias ("tra", "trace", class_alias, 1); + add_com_alias ("tp", "trace", class_alias, 0); + add_com_alias ("tr", "trace", class_alias, 1); + add_com_alias ("tra", "trace", class_alias, 1); add_com_alias ("trac", "trace", class_alias, 1); } - |