]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blob - gdb/tracepoint.c
Remove char_ptr typedef
[thirdparty/binutils-gdb.git] / gdb / tracepoint.c
1 /* Tracing functionality for remote targets in custom GDB protocol
2
3 Copyright (C) 1997-2018 Free Software Foundation, Inc.
4
5 This file is part of GDB.
6
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
11
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
19
20 #include "defs.h"
21 #include "arch-utils.h"
22 #include "symtab.h"
23 #include "frame.h"
24 #include "gdbtypes.h"
25 #include "expression.h"
26 #include "gdbcmd.h"
27 #include "value.h"
28 #include "target.h"
29 #include "target-dcache.h"
30 #include "language.h"
31 #include "inferior.h"
32 #include "breakpoint.h"
33 #include "tracepoint.h"
34 #include "linespec.h"
35 #include "regcache.h"
36 #include "completer.h"
37 #include "block.h"
38 #include "dictionary.h"
39 #include "observable.h"
40 #include "user-regs.h"
41 #include "valprint.h"
42 #include "gdbcore.h"
43 #include "objfiles.h"
44 #include "filenames.h"
45 #include "gdbthread.h"
46 #include "stack.h"
47 #include "remote.h"
48 #include "source.h"
49 #include "ax.h"
50 #include "ax-gdb.h"
51 #include "memrange.h"
52 #include "cli/cli-utils.h"
53 #include "probe.h"
54 #include "ctf.h"
55 #include "filestuff.h"
56 #include "rsp-low.h"
57 #include "tracefile.h"
58 #include "location.h"
59 #include <algorithm>
60
61 /* readline include files */
62 #include "readline/readline.h"
63 #include "readline/history.h"
64
65 /* readline defines this. */
66 #undef savestring
67
68 #include <unistd.h>
69
70 /* Maximum length of an agent aexpression.
71 This accounts for the fact that packets are limited to 400 bytes
72 (which includes everything -- including the checksum), and assumes
73 the worst case of maximum length for each of the pieces of a
74 continuation packet.
75
76 NOTE: expressions get mem2hex'ed otherwise this would be twice as
77 large. (400 - 31)/2 == 184 */
78 #define MAX_AGENT_EXPR_LEN 184
79
80 /* A hook used to notify the UI of tracepoint operations. */
81
82 void (*deprecated_trace_find_hook) (char *arg, int from_tty);
83 void (*deprecated_trace_start_stop_hook) (int start, int from_tty);
84
85 /*
86 Tracepoint.c:
87
88 This module defines the following debugger commands:
89 trace : set a tracepoint on a function, line, or address.
90 info trace : list all debugger-defined tracepoints.
91 delete trace : delete one or more tracepoints.
92 enable trace : enable one or more tracepoints.
93 disable trace : disable one or more tracepoints.
94 actions : specify actions to be taken at a tracepoint.
95 passcount : specify a pass count for a tracepoint.
96 tstart : start a trace experiment.
97 tstop : stop a trace experiment.
98 tstatus : query the status of a trace experiment.
99 tfind : find a trace frame in the trace buffer.
100 tdump : print everything collected at the current tracepoint.
101 save-tracepoints : write tracepoint setup into a file.
102
103 This module defines the following user-visible debugger variables:
104 $trace_frame : sequence number of trace frame currently being debugged.
105 $trace_line : source line of trace frame currently being debugged.
106 $trace_file : source file of trace frame currently being debugged.
107 $tracepoint : tracepoint number of trace frame currently being debugged.
108 */
109
110
111 /* ======= Important global variables: ======= */
112
113 /* The list of all trace state variables. We don't retain pointers to
114 any of these for any reason - API is by name or number only - so it
115 works to have a vector of objects. */
116
117 typedef struct trace_state_variable tsv_s;
118 DEF_VEC_O(tsv_s);
119
120 static VEC(tsv_s) *tvariables;
121
122 /* The next integer to assign to a variable. */
123
124 static int next_tsv_number = 1;
125
126 /* Number of last traceframe collected. */
127 static int traceframe_number;
128
129 /* Tracepoint for last traceframe collected. */
130 static int tracepoint_number;
131
132 /* The traceframe info of the current traceframe. NULL if we haven't
133 yet attempted to fetch it, or if the target does not support
134 fetching this object, or if we're not inspecting a traceframe
135 presently. */
136 static traceframe_info_up current_traceframe_info;
137
138 /* Tracing command lists. */
139 static struct cmd_list_element *tfindlist;
140
141 /* List of expressions to collect by default at each tracepoint hit. */
142 char *default_collect;
143
144 static int disconnected_tracing;
145
146 /* This variable controls whether we ask the target for a linear or
147 circular trace buffer. */
148
149 static int circular_trace_buffer;
150
151 /* This variable is the requested trace buffer size, or -1 to indicate
152 that we don't care and leave it up to the target to set a size. */
153
154 static int trace_buffer_size = -1;
155
156 /* Textual notes applying to the current and/or future trace runs. */
157
158 char *trace_user = NULL;
159
160 /* Textual notes applying to the current and/or future trace runs. */
161
162 char *trace_notes = NULL;
163
164 /* Textual notes applying to the stopping of a trace. */
165
166 char *trace_stop_notes = NULL;
167
168 /* support routines */
169
170 struct collection_list;
171 static char *mem2hex (gdb_byte *, char *, int);
172
173 static struct command_line *
174 all_tracepoint_actions_and_cleanup (struct breakpoint *t);
175
176 static struct trace_status trace_status;
177
178 const char *stop_reason_names[] = {
179 "tunknown",
180 "tnotrun",
181 "tstop",
182 "tfull",
183 "tdisconnected",
184 "tpasscount",
185 "terror"
186 };
187
188 struct trace_status *
189 current_trace_status (void)
190 {
191 return &trace_status;
192 }
193
194 /* Free and clear the traceframe info cache of the current
195 traceframe. */
196
197 static void
198 clear_traceframe_info (void)
199 {
200 current_traceframe_info = NULL;
201 }
202
203 /* Set traceframe number to NUM. */
204 static void
205 set_traceframe_num (int num)
206 {
207 traceframe_number = num;
208 set_internalvar_integer (lookup_internalvar ("trace_frame"), num);
209 }
210
211 /* Set tracepoint number to NUM. */
212 static void
213 set_tracepoint_num (int num)
214 {
215 tracepoint_number = num;
216 set_internalvar_integer (lookup_internalvar ("tracepoint"), num);
217 }
218
219 /* Set externally visible debug variables for querying/printing
220 the traceframe context (line, function, file). */
221
222 static void
223 set_traceframe_context (struct frame_info *trace_frame)
224 {
225 CORE_ADDR trace_pc;
226 struct symbol *traceframe_fun;
227 symtab_and_line traceframe_sal;
228
229 /* Save as globals for internal use. */
230 if (trace_frame != NULL
231 && get_frame_pc_if_available (trace_frame, &trace_pc))
232 {
233 traceframe_sal = find_pc_line (trace_pc, 0);
234 traceframe_fun = find_pc_function (trace_pc);
235
236 /* Save linenumber as "$trace_line", a debugger variable visible to
237 users. */
238 set_internalvar_integer (lookup_internalvar ("trace_line"),
239 traceframe_sal.line);
240 }
241 else
242 {
243 traceframe_fun = NULL;
244 set_internalvar_integer (lookup_internalvar ("trace_line"), -1);
245 }
246
247 /* Save func name as "$trace_func", a debugger variable visible to
248 users. */
249 if (traceframe_fun == NULL
250 || SYMBOL_LINKAGE_NAME (traceframe_fun) == NULL)
251 clear_internalvar (lookup_internalvar ("trace_func"));
252 else
253 set_internalvar_string (lookup_internalvar ("trace_func"),
254 SYMBOL_LINKAGE_NAME (traceframe_fun));
255
256 /* Save file name as "$trace_file", a debugger variable visible to
257 users. */
258 if (traceframe_sal.symtab == NULL)
259 clear_internalvar (lookup_internalvar ("trace_file"));
260 else
261 set_internalvar_string (lookup_internalvar ("trace_file"),
262 symtab_to_filename_for_display (traceframe_sal.symtab));
263 }
264
265 /* Create a new trace state variable with the given name. */
266
267 struct trace_state_variable *
268 create_trace_state_variable (const char *name)
269 {
270 struct trace_state_variable tsv;
271
272 memset (&tsv, 0, sizeof (tsv));
273 tsv.name = xstrdup (name);
274 tsv.number = next_tsv_number++;
275 return VEC_safe_push (tsv_s, tvariables, &tsv);
276 }
277
278 /* Look for a trace state variable of the given name. */
279
280 struct trace_state_variable *
281 find_trace_state_variable (const char *name)
282 {
283 struct trace_state_variable *tsv;
284 int ix;
285
286 for (ix = 0; VEC_iterate (tsv_s, tvariables, ix, tsv); ++ix)
287 if (strcmp (name, tsv->name) == 0)
288 return tsv;
289
290 return NULL;
291 }
292
293 /* Look for a trace state variable of the given number. Return NULL if
294 not found. */
295
296 struct trace_state_variable *
297 find_trace_state_variable_by_number (int number)
298 {
299 struct trace_state_variable *tsv;
300 int ix;
301
302 for (ix = 0; VEC_iterate (tsv_s, tvariables, ix, tsv); ++ix)
303 if (tsv->number == number)
304 return tsv;
305
306 return NULL;
307 }
308
309 static void
310 delete_trace_state_variable (const char *name)
311 {
312 struct trace_state_variable *tsv;
313 int ix;
314
315 for (ix = 0; VEC_iterate (tsv_s, tvariables, ix, tsv); ++ix)
316 if (strcmp (name, tsv->name) == 0)
317 {
318 gdb::observers::tsv_deleted.notify (tsv);
319
320 xfree ((void *)tsv->name);
321 VEC_unordered_remove (tsv_s, tvariables, ix);
322
323 return;
324 }
325
326 warning (_("No trace variable named \"$%s\", not deleting"), name);
327 }
328
329 /* Throws an error if NAME is not valid syntax for a trace state
330 variable's name. */
331
332 void
333 validate_trace_state_variable_name (const char *name)
334 {
335 const char *p;
336
337 if (*name == '\0')
338 error (_("Must supply a non-empty variable name"));
339
340 /* All digits in the name is reserved for value history
341 references. */
342 for (p = name; isdigit (*p); p++)
343 ;
344 if (*p == '\0')
345 error (_("$%s is not a valid trace state variable name"), name);
346
347 for (p = name; isalnum (*p) || *p == '_'; p++)
348 ;
349 if (*p != '\0')
350 error (_("$%s is not a valid trace state variable name"), name);
351 }
352
353 /* The 'tvariable' command collects a name and optional expression to
354 evaluate into an initial value. */
355
356 static void
357 trace_variable_command (const char *args, int from_tty)
358 {
359 LONGEST initval = 0;
360 struct trace_state_variable *tsv;
361 const char *name_start, *p;
362
363 if (!args || !*args)
364 error_no_arg (_("Syntax is $NAME [ = EXPR ]"));
365
366 /* Only allow two syntaxes; "$name" and "$name=value". */
367 p = skip_spaces (args);
368
369 if (*p++ != '$')
370 error (_("Name of trace variable should start with '$'"));
371
372 name_start = p;
373 while (isalnum (*p) || *p == '_')
374 p++;
375 std::string name (name_start, p - name_start);
376
377 p = skip_spaces (p);
378 if (*p != '=' && *p != '\0')
379 error (_("Syntax must be $NAME [ = EXPR ]"));
380
381 validate_trace_state_variable_name (name.c_str ());
382
383 if (*p == '=')
384 initval = value_as_long (parse_and_eval (++p));
385
386 /* If the variable already exists, just change its initial value. */
387 tsv = find_trace_state_variable (name.c_str ());
388 if (tsv)
389 {
390 if (tsv->initial_value != initval)
391 {
392 tsv->initial_value = initval;
393 gdb::observers::tsv_modified.notify (tsv);
394 }
395 printf_filtered (_("Trace state variable $%s "
396 "now has initial value %s.\n"),
397 tsv->name, plongest (tsv->initial_value));
398 return;
399 }
400
401 /* Create a new variable. */
402 tsv = create_trace_state_variable (name.c_str ());
403 tsv->initial_value = initval;
404
405 gdb::observers::tsv_created.notify (tsv);
406
407 printf_filtered (_("Trace state variable $%s "
408 "created, with initial value %s.\n"),
409 tsv->name, plongest (tsv->initial_value));
410 }
411
412 static void
413 delete_trace_variable_command (const char *args, int from_tty)
414 {
415 if (args == NULL)
416 {
417 if (query (_("Delete all trace state variables? ")))
418 VEC_free (tsv_s, tvariables);
419 dont_repeat ();
420 gdb::observers::tsv_deleted.notify (NULL);
421 return;
422 }
423
424 gdb_argv argv (args);
425
426 for (char *arg : argv)
427 {
428 if (*arg == '$')
429 delete_trace_state_variable (arg + 1);
430 else
431 warning (_("Name \"%s\" not prefixed with '$', ignoring"), arg);
432 }
433
434 dont_repeat ();
435 }
436
437 void
438 tvariables_info_1 (void)
439 {
440 struct trace_state_variable *tsv;
441 int ix;
442 int count = 0;
443 struct ui_out *uiout = current_uiout;
444
445 if (VEC_length (tsv_s, tvariables) == 0 && !uiout->is_mi_like_p ())
446 {
447 printf_filtered (_("No trace state variables.\n"));
448 return;
449 }
450
451 /* Try to acquire values from the target. */
452 for (ix = 0; VEC_iterate (tsv_s, tvariables, ix, tsv); ++ix, ++count)
453 tsv->value_known = target_get_trace_state_variable_value (tsv->number,
454 &(tsv->value));
455
456 ui_out_emit_table table_emitter (uiout, 3, count, "trace-variables");
457 uiout->table_header (15, ui_left, "name", "Name");
458 uiout->table_header (11, ui_left, "initial", "Initial");
459 uiout->table_header (11, ui_left, "current", "Current");
460
461 uiout->table_body ();
462
463 for (ix = 0; VEC_iterate (tsv_s, tvariables, ix, tsv); ++ix)
464 {
465 const char *c;
466
467 ui_out_emit_tuple tuple_emitter (uiout, "variable");
468
469 std::string name = std::string ("$") + tsv->name;
470 uiout->field_string ("name", name.c_str ());
471 uiout->field_string ("initial", plongest (tsv->initial_value));
472
473 if (tsv->value_known)
474 c = plongest (tsv->value);
475 else if (uiout->is_mi_like_p ())
476 /* For MI, we prefer not to use magic string constants, but rather
477 omit the field completely. The difference between unknown and
478 undefined does not seem important enough to represent. */
479 c = NULL;
480 else if (current_trace_status ()->running || traceframe_number >= 0)
481 /* The value is/was defined, but we don't have it. */
482 c = "<unknown>";
483 else
484 /* It is not meaningful to ask about the value. */
485 c = "<undefined>";
486 if (c)
487 uiout->field_string ("current", c);
488 uiout->text ("\n");
489 }
490 }
491
492 /* List all the trace state variables. */
493
494 static void
495 info_tvariables_command (const char *args, int from_tty)
496 {
497 tvariables_info_1 ();
498 }
499
500 /* Stash definitions of tsvs into the given file. */
501
502 void
503 save_trace_state_variables (struct ui_file *fp)
504 {
505 struct trace_state_variable *tsv;
506 int ix;
507
508 for (ix = 0; VEC_iterate (tsv_s, tvariables, ix, tsv); ++ix)
509 {
510 fprintf_unfiltered (fp, "tvariable $%s", tsv->name);
511 if (tsv->initial_value)
512 fprintf_unfiltered (fp, " = %s", plongest (tsv->initial_value));
513 fprintf_unfiltered (fp, "\n");
514 }
515 }
516
517 /* ACTIONS functions: */
518
519 /* The three functions:
520 collect_pseudocommand,
521 while_stepping_pseudocommand, and
522 end_actions_pseudocommand
523 are placeholders for "commands" that are actually ONLY to be used
524 within a tracepoint action list. If the actual function is ever called,
525 it means that somebody issued the "command" at the top level,
526 which is always an error. */
527
528 static void
529 end_actions_pseudocommand (const char *args, int from_tty)
530 {
531 error (_("This command cannot be used at the top level."));
532 }
533
534 static void
535 while_stepping_pseudocommand (const char *args, int from_tty)
536 {
537 error (_("This command can only be used in a tracepoint actions list."));
538 }
539
540 static void
541 collect_pseudocommand (const char *args, int from_tty)
542 {
543 error (_("This command can only be used in a tracepoint actions list."));
544 }
545
546 static void
547 teval_pseudocommand (const char *args, int from_tty)
548 {
549 error (_("This command can only be used in a tracepoint actions list."));
550 }
551
552 /* Parse any collection options, such as /s for strings. */
553
554 const char *
555 decode_agent_options (const char *exp, int *trace_string)
556 {
557 struct value_print_options opts;
558
559 *trace_string = 0;
560
561 if (*exp != '/')
562 return exp;
563
564 /* Call this to borrow the print elements default for collection
565 size. */
566 get_user_print_options (&opts);
567
568 exp++;
569 if (*exp == 's')
570 {
571 if (target_supports_string_tracing ())
572 {
573 /* Allow an optional decimal number giving an explicit maximum
574 string length, defaulting it to the "print elements" value;
575 so "collect/s80 mystr" gets at most 80 bytes of string. */
576 *trace_string = opts.print_max;
577 exp++;
578 if (*exp >= '0' && *exp <= '9')
579 *trace_string = atoi (exp);
580 while (*exp >= '0' && *exp <= '9')
581 exp++;
582 }
583 else
584 error (_("Target does not support \"/s\" option for string tracing."));
585 }
586 else
587 error (_("Undefined collection format \"%c\"."), *exp);
588
589 exp = skip_spaces (exp);
590
591 return exp;
592 }
593
594 /* Enter a list of actions for a tracepoint. */
595 static void
596 actions_command (const char *args, int from_tty)
597 {
598 struct tracepoint *t;
599
600 t = get_tracepoint_by_number (&args, NULL);
601 if (t)
602 {
603 std::string tmpbuf =
604 string_printf ("Enter actions for tracepoint %d, one per line.",
605 t->number);
606
607 command_line_up l = read_command_lines (&tmpbuf[0], from_tty, 1,
608 check_tracepoint_command, t);
609 breakpoint_set_commands (t, std::move (l));
610 }
611 /* else just return */
612 }
613
614 /* Report the results of checking the agent expression, as errors or
615 internal errors. */
616
617 static void
618 report_agent_reqs_errors (struct agent_expr *aexpr)
619 {
620 /* All of the "flaws" are serious bytecode generation issues that
621 should never occur. */
622 if (aexpr->flaw != agent_flaw_none)
623 internal_error (__FILE__, __LINE__, _("expression is malformed"));
624
625 /* If analysis shows a stack underflow, GDB must have done something
626 badly wrong in its bytecode generation. */
627 if (aexpr->min_height < 0)
628 internal_error (__FILE__, __LINE__,
629 _("expression has min height < 0"));
630
631 /* Issue this error if the stack is predicted to get too deep. The
632 limit is rather arbitrary; a better scheme might be for the
633 target to report how much stack it will have available. The
634 depth roughly corresponds to parenthesization, so a limit of 20
635 amounts to 20 levels of expression nesting, which is actually
636 a pretty big hairy expression. */
637 if (aexpr->max_height > 20)
638 error (_("Expression is too complicated."));
639 }
640
641 /* worker function */
642 void
643 validate_actionline (const char *line, struct breakpoint *b)
644 {
645 struct cmd_list_element *c;
646 const char *tmp_p;
647 const char *p;
648 struct bp_location *loc;
649 struct tracepoint *t = (struct tracepoint *) b;
650
651 /* If EOF is typed, *line is NULL. */
652 if (line == NULL)
653 return;
654
655 p = skip_spaces (line);
656
657 /* Symbol lookup etc. */
658 if (*p == '\0') /* empty line: just prompt for another line. */
659 return;
660
661 if (*p == '#') /* comment line */
662 return;
663
664 c = lookup_cmd (&p, cmdlist, "", -1, 1);
665 if (c == 0)
666 error (_("`%s' is not a tracepoint action, or is ambiguous."), p);
667
668 if (cmd_cfunc_eq (c, collect_pseudocommand))
669 {
670 int trace_string = 0;
671
672 if (*p == '/')
673 p = decode_agent_options (p, &trace_string);
674
675 do
676 { /* Repeat over a comma-separated list. */
677 QUIT; /* Allow user to bail out with ^C. */
678 p = skip_spaces (p);
679
680 if (*p == '$') /* Look for special pseudo-symbols. */
681 {
682 if (0 == strncasecmp ("reg", p + 1, 3)
683 || 0 == strncasecmp ("arg", p + 1, 3)
684 || 0 == strncasecmp ("loc", p + 1, 3)
685 || 0 == strncasecmp ("_ret", p + 1, 4)
686 || 0 == strncasecmp ("_sdata", p + 1, 6))
687 {
688 p = strchr (p, ',');
689 continue;
690 }
691 /* else fall thru, treat p as an expression and parse it! */
692 }
693 tmp_p = p;
694 for (loc = t->loc; loc; loc = loc->next)
695 {
696 p = tmp_p;
697 expression_up exp = parse_exp_1 (&p, loc->address,
698 block_for_pc (loc->address), 1);
699
700 if (exp->elts[0].opcode == OP_VAR_VALUE)
701 {
702 if (SYMBOL_CLASS (exp->elts[2].symbol) == LOC_CONST)
703 {
704 error (_("constant `%s' (value %s) "
705 "will not be collected."),
706 SYMBOL_PRINT_NAME (exp->elts[2].symbol),
707 plongest (SYMBOL_VALUE (exp->elts[2].symbol)));
708 }
709 else if (SYMBOL_CLASS (exp->elts[2].symbol)
710 == LOC_OPTIMIZED_OUT)
711 {
712 error (_("`%s' is optimized away "
713 "and cannot be collected."),
714 SYMBOL_PRINT_NAME (exp->elts[2].symbol));
715 }
716 }
717
718 /* We have something to collect, make sure that the expr to
719 bytecode translator can handle it and that it's not too
720 long. */
721 agent_expr_up aexpr = gen_trace_for_expr (loc->address,
722 exp.get (),
723 trace_string);
724
725 if (aexpr->len > MAX_AGENT_EXPR_LEN)
726 error (_("Expression is too complicated."));
727
728 ax_reqs (aexpr.get ());
729
730 report_agent_reqs_errors (aexpr.get ());
731 }
732 }
733 while (p && *p++ == ',');
734 }
735
736 else if (cmd_cfunc_eq (c, teval_pseudocommand))
737 {
738 do
739 { /* Repeat over a comma-separated list. */
740 QUIT; /* Allow user to bail out with ^C. */
741 p = skip_spaces (p);
742
743 tmp_p = p;
744 for (loc = t->loc; loc; loc = loc->next)
745 {
746 p = tmp_p;
747
748 /* Only expressions are allowed for this action. */
749 expression_up exp = parse_exp_1 (&p, loc->address,
750 block_for_pc (loc->address), 1);
751
752 /* We have something to evaluate, make sure that the expr to
753 bytecode translator can handle it and that it's not too
754 long. */
755 agent_expr_up aexpr = gen_eval_for_expr (loc->address, exp.get ());
756
757 if (aexpr->len > MAX_AGENT_EXPR_LEN)
758 error (_("Expression is too complicated."));
759
760 ax_reqs (aexpr.get ());
761 report_agent_reqs_errors (aexpr.get ());
762 }
763 }
764 while (p && *p++ == ',');
765 }
766
767 else if (cmd_cfunc_eq (c, while_stepping_pseudocommand))
768 {
769 char *endp;
770
771 p = skip_spaces (p);
772 t->step_count = strtol (p, &endp, 0);
773 if (endp == p || t->step_count == 0)
774 error (_("while-stepping step count `%s' is malformed."), line);
775 p = endp;
776 }
777
778 else if (cmd_cfunc_eq (c, end_actions_pseudocommand))
779 ;
780
781 else
782 error (_("`%s' is not a supported tracepoint action."), line);
783 }
784
785 enum {
786 memrange_absolute = -1
787 };
788
789 /* MEMRANGE functions: */
790
791 /* Compare memranges for std::sort. */
792
793 static bool
794 memrange_comp (const memrange &a, const memrange &b)
795 {
796 if (a.type == b.type)
797 {
798 if (a.type == memrange_absolute)
799 return (bfd_vma) a.start < (bfd_vma) b.start;
800 else
801 return a.start < b.start;
802 }
803
804 return a.type < b.type;
805 }
806
807 /* Sort the memrange list using std::sort, and merge adjacent memranges. */
808
809 static void
810 memrange_sortmerge (std::vector<memrange> &memranges)
811 {
812 if (!memranges.empty ())
813 {
814 int a, b;
815
816 std::sort (memranges.begin (), memranges.end (), memrange_comp);
817
818 for (a = 0, b = 1; b < memranges.size (); b++)
819 {
820 /* If memrange b overlaps or is adjacent to memrange a,
821 merge them. */
822 if (memranges[a].type == memranges[b].type
823 && memranges[b].start <= memranges[a].end)
824 {
825 if (memranges[b].end > memranges[a].end)
826 memranges[a].end = memranges[b].end;
827 continue; /* next b, same a */
828 }
829 a++; /* next a */
830 if (a != b)
831 memranges[a] = memranges[b];
832 }
833 memranges.resize (a + 1);
834 }
835 }
836
837 /* Add a register to a collection list. */
838
839 void
840 collection_list::add_register (unsigned int regno)
841 {
842 if (info_verbose)
843 printf_filtered ("collect register %d\n", regno);
844 if (regno >= (8 * sizeof (m_regs_mask)))
845 error (_("Internal: register number %d too large for tracepoint"),
846 regno);
847 m_regs_mask[regno / 8] |= 1 << (regno % 8);
848 }
849
850 /* Add a memrange to a collection list. */
851
852 void
853 collection_list::add_memrange (struct gdbarch *gdbarch,
854 int type, bfd_signed_vma base,
855 unsigned long len)
856 {
857 if (info_verbose)
858 printf_filtered ("(%d,%s,%ld)\n", type, paddress (gdbarch, base), len);
859
860 /* type: memrange_absolute == memory, other n == basereg */
861 /* base: addr if memory, offset if reg relative. */
862 /* len: we actually save end (base + len) for convenience */
863 m_memranges.emplace_back (type, base, base + len);
864
865 if (type != memrange_absolute) /* Better collect the base register! */
866 add_register (type);
867 }
868
869 /* Add a symbol to a collection list. */
870
871 void
872 collection_list::collect_symbol (struct symbol *sym,
873 struct gdbarch *gdbarch,
874 long frame_regno, long frame_offset,
875 CORE_ADDR scope,
876 int trace_string)
877 {
878 unsigned long len;
879 unsigned int reg;
880 bfd_signed_vma offset;
881 int treat_as_expr = 0;
882
883 len = TYPE_LENGTH (check_typedef (SYMBOL_TYPE (sym)));
884 switch (SYMBOL_CLASS (sym))
885 {
886 default:
887 printf_filtered ("%s: don't know symbol class %d\n",
888 SYMBOL_PRINT_NAME (sym),
889 SYMBOL_CLASS (sym));
890 break;
891 case LOC_CONST:
892 printf_filtered ("constant %s (value %s) will not be collected.\n",
893 SYMBOL_PRINT_NAME (sym), plongest (SYMBOL_VALUE (sym)));
894 break;
895 case LOC_STATIC:
896 offset = SYMBOL_VALUE_ADDRESS (sym);
897 if (info_verbose)
898 {
899 printf_filtered ("LOC_STATIC %s: collect %ld bytes at %s.\n",
900 SYMBOL_PRINT_NAME (sym), len,
901 paddress (gdbarch, offset));
902 }
903 /* A struct may be a C++ class with static fields, go to general
904 expression handling. */
905 if (TYPE_CODE (SYMBOL_TYPE (sym)) == TYPE_CODE_STRUCT)
906 treat_as_expr = 1;
907 else
908 add_memrange (gdbarch, memrange_absolute, offset, len);
909 break;
910 case LOC_REGISTER:
911 reg = SYMBOL_REGISTER_OPS (sym)->register_number (sym, gdbarch);
912 if (info_verbose)
913 printf_filtered ("LOC_REG[parm] %s: ",
914 SYMBOL_PRINT_NAME (sym));
915 add_register (reg);
916 /* Check for doubles stored in two registers. */
917 /* FIXME: how about larger types stored in 3 or more regs? */
918 if (TYPE_CODE (SYMBOL_TYPE (sym)) == TYPE_CODE_FLT &&
919 len > register_size (gdbarch, reg))
920 add_register (reg + 1);
921 break;
922 case LOC_REF_ARG:
923 printf_filtered ("Sorry, don't know how to do LOC_REF_ARG yet.\n");
924 printf_filtered (" (will not collect %s)\n",
925 SYMBOL_PRINT_NAME (sym));
926 break;
927 case LOC_ARG:
928 reg = frame_regno;
929 offset = frame_offset + SYMBOL_VALUE (sym);
930 if (info_verbose)
931 {
932 printf_filtered ("LOC_LOCAL %s: Collect %ld bytes at offset %s"
933 " from frame ptr reg %d\n",
934 SYMBOL_PRINT_NAME (sym), len,
935 paddress (gdbarch, offset), reg);
936 }
937 add_memrange (gdbarch, reg, offset, len);
938 break;
939 case LOC_REGPARM_ADDR:
940 reg = SYMBOL_VALUE (sym);
941 offset = 0;
942 if (info_verbose)
943 {
944 printf_filtered ("LOC_REGPARM_ADDR %s: Collect %ld bytes at offset %s"
945 " from reg %d\n",
946 SYMBOL_PRINT_NAME (sym), len,
947 paddress (gdbarch, offset), reg);
948 }
949 add_memrange (gdbarch, reg, offset, len);
950 break;
951 case LOC_LOCAL:
952 reg = frame_regno;
953 offset = frame_offset + SYMBOL_VALUE (sym);
954 if (info_verbose)
955 {
956 printf_filtered ("LOC_LOCAL %s: Collect %ld bytes at offset %s"
957 " from frame ptr reg %d\n",
958 SYMBOL_PRINT_NAME (sym), len,
959 paddress (gdbarch, offset), reg);
960 }
961 add_memrange (gdbarch, reg, offset, len);
962 break;
963
964 case LOC_UNRESOLVED:
965 treat_as_expr = 1;
966 break;
967
968 case LOC_OPTIMIZED_OUT:
969 printf_filtered ("%s has been optimized out of existence.\n",
970 SYMBOL_PRINT_NAME (sym));
971 break;
972
973 case LOC_COMPUTED:
974 treat_as_expr = 1;
975 break;
976 }
977
978 /* Expressions are the most general case. */
979 if (treat_as_expr)
980 {
981 agent_expr_up aexpr = gen_trace_for_var (scope, gdbarch,
982 sym, trace_string);
983
984 /* It can happen that the symbol is recorded as a computed
985 location, but it's been optimized away and doesn't actually
986 have a location expression. */
987 if (!aexpr)
988 {
989 printf_filtered ("%s has been optimized out of existence.\n",
990 SYMBOL_PRINT_NAME (sym));
991 return;
992 }
993
994 ax_reqs (aexpr.get ());
995
996 report_agent_reqs_errors (aexpr.get ());
997
998 /* Take care of the registers. */
999 if (aexpr->reg_mask_len > 0)
1000 {
1001 for (int ndx1 = 0; ndx1 < aexpr->reg_mask_len; ndx1++)
1002 {
1003 QUIT; /* Allow user to bail out with ^C. */
1004 if (aexpr->reg_mask[ndx1] != 0)
1005 {
1006 /* Assume chars have 8 bits. */
1007 for (int ndx2 = 0; ndx2 < 8; ndx2++)
1008 if (aexpr->reg_mask[ndx1] & (1 << ndx2))
1009 /* It's used -- record it. */
1010 add_register (ndx1 * 8 + ndx2);
1011 }
1012 }
1013 }
1014
1015 add_aexpr (std::move (aexpr));
1016 }
1017 }
1018
1019 /* Data to be passed around in the calls to the locals and args
1020 iterators. */
1021
1022 struct add_local_symbols_data
1023 {
1024 struct collection_list *collect;
1025 struct gdbarch *gdbarch;
1026 CORE_ADDR pc;
1027 long frame_regno;
1028 long frame_offset;
1029 int count;
1030 int trace_string;
1031 };
1032
1033 /* The callback for the locals and args iterators. */
1034
1035 static void
1036 do_collect_symbol (const char *print_name,
1037 struct symbol *sym,
1038 void *cb_data)
1039 {
1040 struct add_local_symbols_data *p = (struct add_local_symbols_data *) cb_data;
1041
1042 p->collect->collect_symbol (sym, p->gdbarch, p->frame_regno,
1043 p->frame_offset, p->pc, p->trace_string);
1044 p->count++;
1045
1046 p->collect->add_wholly_collected (print_name);
1047 }
1048
1049 void
1050 collection_list::add_wholly_collected (const char *print_name)
1051 {
1052 m_wholly_collected.push_back (print_name);
1053 }
1054
1055 /* Add all locals (or args) symbols to collection list. */
1056
1057 void
1058 collection_list::add_local_symbols (struct gdbarch *gdbarch, CORE_ADDR pc,
1059 long frame_regno, long frame_offset, int type,
1060 int trace_string)
1061 {
1062 const struct block *block;
1063 struct add_local_symbols_data cb_data;
1064
1065 cb_data.collect = this;
1066 cb_data.gdbarch = gdbarch;
1067 cb_data.pc = pc;
1068 cb_data.frame_regno = frame_regno;
1069 cb_data.frame_offset = frame_offset;
1070 cb_data.count = 0;
1071 cb_data.trace_string = trace_string;
1072
1073 if (type == 'L')
1074 {
1075 block = block_for_pc (pc);
1076 if (block == NULL)
1077 {
1078 warning (_("Can't collect locals; "
1079 "no symbol table info available.\n"));
1080 return;
1081 }
1082
1083 iterate_over_block_local_vars (block, do_collect_symbol, &cb_data);
1084 if (cb_data.count == 0)
1085 warning (_("No locals found in scope."));
1086 }
1087 else
1088 {
1089 pc = get_pc_function_start (pc);
1090 block = block_for_pc (pc);
1091 if (block == NULL)
1092 {
1093 warning (_("Can't collect args; no symbol table info available."));
1094 return;
1095 }
1096
1097 iterate_over_block_arg_vars (block, do_collect_symbol, &cb_data);
1098 if (cb_data.count == 0)
1099 warning (_("No args found in scope."));
1100 }
1101 }
1102
1103 void
1104 collection_list::add_static_trace_data ()
1105 {
1106 if (info_verbose)
1107 printf_filtered ("collect static trace data\n");
1108 m_strace_data = true;
1109 }
1110
1111 collection_list::collection_list ()
1112 : m_regs_mask (),
1113 m_strace_data (false)
1114 {
1115 m_memranges.reserve (128);
1116 m_aexprs.reserve (128);
1117 }
1118
1119 /* Reduce a collection list to string form (for gdb protocol). */
1120
1121 std::vector<std::string>
1122 collection_list::stringify ()
1123 {
1124 char temp_buf[2048];
1125 int count;
1126 char *end;
1127 long i;
1128 std::vector<std::string> str_list;
1129
1130 if (m_strace_data)
1131 {
1132 if (info_verbose)
1133 printf_filtered ("\nCollecting static trace data\n");
1134 end = temp_buf;
1135 *end++ = 'L';
1136 str_list.emplace_back (temp_buf, end - temp_buf);
1137 }
1138
1139 for (i = sizeof (m_regs_mask) - 1; i > 0; i--)
1140 if (m_regs_mask[i] != 0) /* Skip leading zeroes in regs_mask. */
1141 break;
1142 if (m_regs_mask[i] != 0) /* Prepare to send regs_mask to the stub. */
1143 {
1144 if (info_verbose)
1145 printf_filtered ("\nCollecting registers (mask): 0x");
1146 end = temp_buf;
1147 *end++ = 'R';
1148 for (; i >= 0; i--)
1149 {
1150 QUIT; /* Allow user to bail out with ^C. */
1151 if (info_verbose)
1152 printf_filtered ("%02X", m_regs_mask[i]);
1153 sprintf (end, "%02X", m_regs_mask[i]);
1154 end += 2;
1155 }
1156 str_list.emplace_back (temp_buf);
1157 }
1158 if (info_verbose)
1159 printf_filtered ("\n");
1160 if (!m_memranges.empty () && info_verbose)
1161 printf_filtered ("Collecting memranges: \n");
1162 for (i = 0, count = 0, end = temp_buf; i < m_memranges.size (); i++)
1163 {
1164 QUIT; /* Allow user to bail out with ^C. */
1165 if (info_verbose)
1166 {
1167 printf_filtered ("(%d, %s, %ld)\n",
1168 m_memranges[i].type,
1169 paddress (target_gdbarch (),
1170 m_memranges[i].start),
1171 (long) (m_memranges[i].end
1172 - m_memranges[i].start));
1173 }
1174 if (count + 27 > MAX_AGENT_EXPR_LEN)
1175 {
1176 str_list.emplace_back (temp_buf, count);
1177 count = 0;
1178 end = temp_buf;
1179 }
1180
1181 {
1182 bfd_signed_vma length
1183 = m_memranges[i].end - m_memranges[i].start;
1184
1185 /* The "%X" conversion specifier expects an unsigned argument,
1186 so passing -1 (memrange_absolute) to it directly gives you
1187 "FFFFFFFF" (or more, depending on sizeof (unsigned)).
1188 Special-case it. */
1189 if (m_memranges[i].type == memrange_absolute)
1190 sprintf (end, "M-1,%s,%lX", phex_nz (m_memranges[i].start, 0),
1191 (long) length);
1192 else
1193 sprintf (end, "M%X,%s,%lX", m_memranges[i].type,
1194 phex_nz (m_memranges[i].start, 0), (long) length);
1195 }
1196
1197 count += strlen (end);
1198 end = temp_buf + count;
1199 }
1200
1201 for (i = 0; i < m_aexprs.size (); i++)
1202 {
1203 QUIT; /* Allow user to bail out with ^C. */
1204 if ((count + 10 + 2 * m_aexprs[i]->len) > MAX_AGENT_EXPR_LEN)
1205 {
1206 str_list.emplace_back (temp_buf, count);
1207 count = 0;
1208 end = temp_buf;
1209 }
1210 sprintf (end, "X%08X,", m_aexprs[i]->len);
1211 end += 10; /* 'X' + 8 hex digits + ',' */
1212 count += 10;
1213
1214 end = mem2hex (m_aexprs[i]->buf, end, m_aexprs[i]->len);
1215 count += 2 * m_aexprs[i]->len;
1216 }
1217
1218 if (count != 0)
1219 {
1220 str_list.emplace_back (temp_buf, count);
1221 count = 0;
1222 end = temp_buf;
1223 }
1224
1225 return str_list;
1226 }
1227
1228 /* Add the printed expression EXP to *LIST. */
1229
1230 void
1231 collection_list::append_exp (struct expression *exp)
1232 {
1233 string_file tmp_stream;
1234
1235 print_expression (exp, &tmp_stream);
1236
1237 m_computed.push_back (std::move (tmp_stream.string ()));
1238 }
1239
1240 void
1241 collection_list::finish ()
1242 {
1243 memrange_sortmerge (m_memranges);
1244 }
1245
1246 static void
1247 encode_actions_1 (struct command_line *action,
1248 struct bp_location *tloc,
1249 int frame_reg,
1250 LONGEST frame_offset,
1251 struct collection_list *collect,
1252 struct collection_list *stepping_list)
1253 {
1254 const char *action_exp;
1255 int i;
1256 struct value *tempval;
1257 struct cmd_list_element *cmd;
1258
1259 for (; action; action = action->next)
1260 {
1261 QUIT; /* Allow user to bail out with ^C. */
1262 action_exp = action->line;
1263 action_exp = skip_spaces (action_exp);
1264
1265 cmd = lookup_cmd (&action_exp, cmdlist, "", -1, 1);
1266 if (cmd == 0)
1267 error (_("Bad action list item: %s"), action_exp);
1268
1269 if (cmd_cfunc_eq (cmd, collect_pseudocommand))
1270 {
1271 int trace_string = 0;
1272
1273 if (*action_exp == '/')
1274 action_exp = decode_agent_options (action_exp, &trace_string);
1275
1276 do
1277 { /* Repeat over a comma-separated list. */
1278 QUIT; /* Allow user to bail out with ^C. */
1279 action_exp = skip_spaces (action_exp);
1280
1281 if (0 == strncasecmp ("$reg", action_exp, 4))
1282 {
1283 for (i = 0; i < gdbarch_num_regs (target_gdbarch ()); i++)
1284 collect->add_register (i);
1285 action_exp = strchr (action_exp, ','); /* more? */
1286 }
1287 else if (0 == strncasecmp ("$arg", action_exp, 4))
1288 {
1289 collect->add_local_symbols (target_gdbarch (),
1290 tloc->address,
1291 frame_reg,
1292 frame_offset,
1293 'A',
1294 trace_string);
1295 action_exp = strchr (action_exp, ','); /* more? */
1296 }
1297 else if (0 == strncasecmp ("$loc", action_exp, 4))
1298 {
1299 collect->add_local_symbols (target_gdbarch (),
1300 tloc->address,
1301 frame_reg,
1302 frame_offset,
1303 'L',
1304 trace_string);
1305 action_exp = strchr (action_exp, ','); /* more? */
1306 }
1307 else if (0 == strncasecmp ("$_ret", action_exp, 5))
1308 {
1309 agent_expr_up aexpr
1310 = gen_trace_for_return_address (tloc->address,
1311 target_gdbarch (),
1312 trace_string);
1313
1314 ax_reqs (aexpr.get ());
1315 report_agent_reqs_errors (aexpr.get ());
1316
1317 /* take care of the registers */
1318 if (aexpr->reg_mask_len > 0)
1319 {
1320 for (int ndx1 = 0; ndx1 < aexpr->reg_mask_len; ndx1++)
1321 {
1322 QUIT; /* allow user to bail out with ^C */
1323 if (aexpr->reg_mask[ndx1] != 0)
1324 {
1325 /* assume chars have 8 bits */
1326 for (int ndx2 = 0; ndx2 < 8; ndx2++)
1327 if (aexpr->reg_mask[ndx1] & (1 << ndx2))
1328 {
1329 /* It's used -- record it. */
1330 collect->add_register (ndx1 * 8 + ndx2);
1331 }
1332 }
1333 }
1334 }
1335
1336 collect->add_aexpr (std::move (aexpr));
1337 action_exp = strchr (action_exp, ','); /* more? */
1338 }
1339 else if (0 == strncasecmp ("$_sdata", action_exp, 7))
1340 {
1341 collect->add_static_trace_data ();
1342 action_exp = strchr (action_exp, ','); /* more? */
1343 }
1344 else
1345 {
1346 unsigned long addr;
1347
1348 expression_up exp = parse_exp_1 (&action_exp, tloc->address,
1349 block_for_pc (tloc->address),
1350 1);
1351
1352 switch (exp->elts[0].opcode)
1353 {
1354 case OP_REGISTER:
1355 {
1356 const char *name = &exp->elts[2].string;
1357
1358 i = user_reg_map_name_to_regnum (target_gdbarch (),
1359 name, strlen (name));
1360 if (i == -1)
1361 internal_error (__FILE__, __LINE__,
1362 _("Register $%s not available"),
1363 name);
1364 if (info_verbose)
1365 printf_filtered ("OP_REGISTER: ");
1366 collect->add_register (i);
1367 break;
1368 }
1369
1370 case UNOP_MEMVAL:
1371 /* Safe because we know it's a simple expression. */
1372 tempval = evaluate_expression (exp.get ());
1373 addr = value_address (tempval);
1374 /* Initialize the TYPE_LENGTH if it is a typedef. */
1375 check_typedef (exp->elts[1].type);
1376 collect->add_memrange (target_gdbarch (),
1377 memrange_absolute, addr,
1378 TYPE_LENGTH (exp->elts[1].type));
1379 collect->append_exp (exp.get ());
1380 break;
1381
1382 case OP_VAR_VALUE:
1383 {
1384 struct symbol *sym = exp->elts[2].symbol;
1385 const char *name = SYMBOL_NATURAL_NAME (sym);
1386
1387 collect->collect_symbol (exp->elts[2].symbol,
1388 target_gdbarch (),
1389 frame_reg,
1390 frame_offset,
1391 tloc->address,
1392 trace_string);
1393 collect->add_wholly_collected (name);
1394 }
1395 break;
1396
1397 default: /* Full-fledged expression. */
1398 agent_expr_up aexpr = gen_trace_for_expr (tloc->address,
1399 exp.get (),
1400 trace_string);
1401
1402 ax_reqs (aexpr.get ());
1403
1404 report_agent_reqs_errors (aexpr.get ());
1405
1406 /* Take care of the registers. */
1407 if (aexpr->reg_mask_len > 0)
1408 {
1409 for (int ndx1 = 0; ndx1 < aexpr->reg_mask_len; ndx1++)
1410 {
1411 QUIT; /* Allow user to bail out with ^C. */
1412 if (aexpr->reg_mask[ndx1] != 0)
1413 {
1414 /* Assume chars have 8 bits. */
1415 for (int ndx2 = 0; ndx2 < 8; ndx2++)
1416 if (aexpr->reg_mask[ndx1] & (1 << ndx2))
1417 {
1418 /* It's used -- record it. */
1419 collect->add_register (ndx1 * 8 + ndx2);
1420 }
1421 }
1422 }
1423 }
1424
1425 collect->add_aexpr (std::move (aexpr));
1426 collect->append_exp (exp.get ());
1427 break;
1428 } /* switch */
1429 } /* do */
1430 }
1431 while (action_exp && *action_exp++ == ',');
1432 } /* if */
1433 else if (cmd_cfunc_eq (cmd, teval_pseudocommand))
1434 {
1435 do
1436 { /* Repeat over a comma-separated list. */
1437 QUIT; /* Allow user to bail out with ^C. */
1438 action_exp = skip_spaces (action_exp);
1439
1440 {
1441 expression_up exp = parse_exp_1 (&action_exp, tloc->address,
1442 block_for_pc (tloc->address),
1443 1);
1444
1445 agent_expr_up aexpr = gen_eval_for_expr (tloc->address,
1446 exp.get ());
1447
1448 ax_reqs (aexpr.get ());
1449 report_agent_reqs_errors (aexpr.get ());
1450
1451 /* Even though we're not officially collecting, add
1452 to the collect list anyway. */
1453 collect->add_aexpr (std::move (aexpr));
1454 } /* do */
1455 }
1456 while (action_exp && *action_exp++ == ',');
1457 } /* if */
1458 else if (cmd_cfunc_eq (cmd, while_stepping_pseudocommand))
1459 {
1460 /* We check against nested while-stepping when setting
1461 breakpoint action, so no way to run into nested
1462 here. */
1463 gdb_assert (stepping_list);
1464
1465 encode_actions_1 (action->body_list[0], tloc, frame_reg,
1466 frame_offset, stepping_list, NULL);
1467 }
1468 else
1469 error (_("Invalid tracepoint command '%s'"), action->line);
1470 } /* for */
1471 }
1472
1473 /* Encode actions of tracepoint TLOC->owner and fill TRACEPOINT_LIST
1474 and STEPPING_LIST. */
1475
1476 void
1477 encode_actions (struct bp_location *tloc,
1478 struct collection_list *tracepoint_list,
1479 struct collection_list *stepping_list)
1480 {
1481 struct command_line *actions;
1482 int frame_reg;
1483 LONGEST frame_offset;
1484
1485 gdbarch_virtual_frame_pointer (tloc->gdbarch,
1486 tloc->address, &frame_reg, &frame_offset);
1487
1488 actions = all_tracepoint_actions_and_cleanup (tloc->owner);
1489
1490 encode_actions_1 (actions, tloc, frame_reg, frame_offset,
1491 tracepoint_list, stepping_list);
1492
1493 tracepoint_list->finish ();
1494 stepping_list->finish ();
1495 }
1496
1497 /* Render all actions into gdb protocol. */
1498
1499 void
1500 encode_actions_rsp (struct bp_location *tloc,
1501 std::vector<std::string> *tdp_actions,
1502 std::vector<std::string> *stepping_actions)
1503 {
1504 struct collection_list tracepoint_list, stepping_list;
1505
1506 encode_actions (tloc, &tracepoint_list, &stepping_list);
1507
1508 *tdp_actions = tracepoint_list.stringify ();
1509 *stepping_actions = stepping_list.stringify ();
1510 }
1511
1512 void
1513 collection_list::add_aexpr (agent_expr_up aexpr)
1514 {
1515 m_aexprs.push_back (std::move (aexpr));
1516 }
1517
1518 static void
1519 process_tracepoint_on_disconnect (void)
1520 {
1521 VEC(breakpoint_p) *tp_vec = NULL;
1522 int ix;
1523 struct breakpoint *b;
1524 int has_pending_p = 0;
1525
1526 /* Check whether we still have pending tracepoint. If we have, warn the
1527 user that pending tracepoint will no longer work. */
1528 tp_vec = all_tracepoints ();
1529 for (ix = 0; VEC_iterate (breakpoint_p, tp_vec, ix, b); ix++)
1530 {
1531 if (b->loc == NULL)
1532 {
1533 has_pending_p = 1;
1534 break;
1535 }
1536 else
1537 {
1538 struct bp_location *loc1;
1539
1540 for (loc1 = b->loc; loc1; loc1 = loc1->next)
1541 {
1542 if (loc1->shlib_disabled)
1543 {
1544 has_pending_p = 1;
1545 break;
1546 }
1547 }
1548
1549 if (has_pending_p)
1550 break;
1551 }
1552 }
1553 VEC_free (breakpoint_p, tp_vec);
1554
1555 if (has_pending_p)
1556 warning (_("Pending tracepoints will not be resolved while"
1557 " GDB is disconnected\n"));
1558 }
1559
1560 /* Reset local state of tracing. */
1561
1562 void
1563 trace_reset_local_state (void)
1564 {
1565 set_traceframe_num (-1);
1566 set_tracepoint_num (-1);
1567 set_traceframe_context (NULL);
1568 clear_traceframe_info ();
1569 }
1570
1571 void
1572 start_tracing (const char *notes)
1573 {
1574 VEC(breakpoint_p) *tp_vec = NULL;
1575 int ix;
1576 struct breakpoint *b;
1577 struct trace_state_variable *tsv;
1578 int any_enabled = 0, num_to_download = 0;
1579 int ret;
1580
1581 tp_vec = all_tracepoints ();
1582
1583 /* No point in tracing without any tracepoints... */
1584 if (VEC_length (breakpoint_p, tp_vec) == 0)
1585 {
1586 VEC_free (breakpoint_p, tp_vec);
1587 error (_("No tracepoints defined, not starting trace"));
1588 }
1589
1590 for (ix = 0; VEC_iterate (breakpoint_p, tp_vec, ix, b); ix++)
1591 {
1592 if (b->enable_state == bp_enabled)
1593 any_enabled = 1;
1594
1595 if ((b->type == bp_fast_tracepoint
1596 ? may_insert_fast_tracepoints
1597 : may_insert_tracepoints))
1598 ++num_to_download;
1599 else
1600 warning (_("May not insert %stracepoints, skipping tracepoint %d"),
1601 (b->type == bp_fast_tracepoint ? "fast " : ""), b->number);
1602 }
1603
1604 if (!any_enabled)
1605 {
1606 if (target_supports_enable_disable_tracepoint ())
1607 warning (_("No tracepoints enabled"));
1608 else
1609 {
1610 /* No point in tracing with only disabled tracepoints that
1611 cannot be re-enabled. */
1612 VEC_free (breakpoint_p, tp_vec);
1613 error (_("No tracepoints enabled, not starting trace"));
1614 }
1615 }
1616
1617 if (num_to_download <= 0)
1618 {
1619 VEC_free (breakpoint_p, tp_vec);
1620 error (_("No tracepoints that may be downloaded, not starting trace"));
1621 }
1622
1623 target_trace_init ();
1624
1625 for (ix = 0; VEC_iterate (breakpoint_p, tp_vec, ix, b); ix++)
1626 {
1627 struct tracepoint *t = (struct tracepoint *) b;
1628 struct bp_location *loc;
1629 int bp_location_downloaded = 0;
1630
1631 /* Clear `inserted' flag. */
1632 for (loc = b->loc; loc; loc = loc->next)
1633 loc->inserted = 0;
1634
1635 if ((b->type == bp_fast_tracepoint
1636 ? !may_insert_fast_tracepoints
1637 : !may_insert_tracepoints))
1638 continue;
1639
1640 t->number_on_target = 0;
1641
1642 for (loc = b->loc; loc; loc = loc->next)
1643 {
1644 /* Since tracepoint locations are never duplicated, `inserted'
1645 flag should be zero. */
1646 gdb_assert (!loc->inserted);
1647
1648 target_download_tracepoint (loc);
1649
1650 loc->inserted = 1;
1651 bp_location_downloaded = 1;
1652 }
1653
1654 t->number_on_target = b->number;
1655
1656 for (loc = b->loc; loc; loc = loc->next)
1657 if (loc->probe.prob != NULL)
1658 loc->probe.prob->set_semaphore (loc->probe.objfile,
1659 loc->gdbarch);
1660
1661 if (bp_location_downloaded)
1662 gdb::observers::breakpoint_modified.notify (b);
1663 }
1664 VEC_free (breakpoint_p, tp_vec);
1665
1666 /* Send down all the trace state variables too. */
1667 for (ix = 0; VEC_iterate (tsv_s, tvariables, ix, tsv); ++ix)
1668 {
1669 target_download_trace_state_variable (tsv);
1670 }
1671
1672 /* Tell target to treat text-like sections as transparent. */
1673 target_trace_set_readonly_regions ();
1674 /* Set some mode flags. */
1675 target_set_disconnected_tracing (disconnected_tracing);
1676 target_set_circular_trace_buffer (circular_trace_buffer);
1677 target_set_trace_buffer_size (trace_buffer_size);
1678
1679 if (!notes)
1680 notes = trace_notes;
1681 ret = target_set_trace_notes (trace_user, notes, NULL);
1682
1683 if (!ret && (trace_user || notes))
1684 warning (_("Target does not support trace user/notes, info ignored"));
1685
1686 /* Now insert traps and begin collecting data. */
1687 target_trace_start ();
1688
1689 /* Reset our local state. */
1690 trace_reset_local_state ();
1691 current_trace_status()->running = 1;
1692 }
1693
1694 /* The tstart command requests the target to start a new trace run.
1695 The command passes any arguments it has to the target verbatim, as
1696 an optional "trace note". This is useful as for instance a warning
1697 to other users if the trace runs disconnected, and you don't want
1698 anybody else messing with the target. */
1699
1700 static void
1701 tstart_command (const char *args, int from_tty)
1702 {
1703 dont_repeat (); /* Like "run", dangerous to repeat accidentally. */
1704
1705 if (current_trace_status ()->running)
1706 {
1707 if (from_tty
1708 && !query (_("A trace is running already. Start a new run? ")))
1709 error (_("New trace run not started."));
1710 }
1711
1712 start_tracing (args);
1713 }
1714
1715 /* The tstop command stops the tracing run. The command passes any
1716 supplied arguments to the target verbatim as a "stop note"; if the
1717 target supports trace notes, then it will be reported back as part
1718 of the trace run's status. */
1719
1720 static void
1721 tstop_command (const char *args, int from_tty)
1722 {
1723 if (!current_trace_status ()->running)
1724 error (_("Trace is not running."));
1725
1726 stop_tracing (args);
1727 }
1728
1729 void
1730 stop_tracing (const char *note)
1731 {
1732 int ret;
1733 VEC(breakpoint_p) *tp_vec = NULL;
1734 int ix;
1735 struct breakpoint *t;
1736
1737 target_trace_stop ();
1738
1739 tp_vec = all_tracepoints ();
1740 for (ix = 0; VEC_iterate (breakpoint_p, tp_vec, ix, t); ix++)
1741 {
1742 struct bp_location *loc;
1743
1744 if ((t->type == bp_fast_tracepoint
1745 ? !may_insert_fast_tracepoints
1746 : !may_insert_tracepoints))
1747 continue;
1748
1749 for (loc = t->loc; loc; loc = loc->next)
1750 {
1751 /* GDB can be totally absent in some disconnected trace scenarios,
1752 but we don't really care if this semaphore goes out of sync.
1753 That's why we are decrementing it here, but not taking care
1754 in other places. */
1755 if (loc->probe.prob != NULL)
1756 loc->probe.prob->clear_semaphore (loc->probe.objfile,
1757 loc->gdbarch);
1758 }
1759 }
1760
1761 VEC_free (breakpoint_p, tp_vec);
1762
1763 if (!note)
1764 note = trace_stop_notes;
1765 ret = target_set_trace_notes (NULL, NULL, note);
1766
1767 if (!ret && note)
1768 warning (_("Target does not support trace notes, note ignored"));
1769
1770 /* Should change in response to reply? */
1771 current_trace_status ()->running = 0;
1772 }
1773
1774 /* tstatus command */
1775 static void
1776 tstatus_command (const char *args, int from_tty)
1777 {
1778 struct trace_status *ts = current_trace_status ();
1779 int status, ix;
1780 VEC(breakpoint_p) *tp_vec = NULL;
1781 struct breakpoint *t;
1782
1783 status = target_get_trace_status (ts);
1784
1785 if (status == -1)
1786 {
1787 if (ts->filename != NULL)
1788 printf_filtered (_("Using a trace file.\n"));
1789 else
1790 {
1791 printf_filtered (_("Trace can not be run on this target.\n"));
1792 return;
1793 }
1794 }
1795
1796 if (!ts->running_known)
1797 {
1798 printf_filtered (_("Run/stop status is unknown.\n"));
1799 }
1800 else if (ts->running)
1801 {
1802 printf_filtered (_("Trace is running on the target.\n"));
1803 }
1804 else
1805 {
1806 switch (ts->stop_reason)
1807 {
1808 case trace_never_run:
1809 printf_filtered (_("No trace has been run on the target.\n"));
1810 break;
1811 case trace_stop_command:
1812 if (ts->stop_desc)
1813 printf_filtered (_("Trace stopped by a tstop command (%s).\n"),
1814 ts->stop_desc);
1815 else
1816 printf_filtered (_("Trace stopped by a tstop command.\n"));
1817 break;
1818 case trace_buffer_full:
1819 printf_filtered (_("Trace stopped because the buffer was full.\n"));
1820 break;
1821 case trace_disconnected:
1822 printf_filtered (_("Trace stopped because of disconnection.\n"));
1823 break;
1824 case tracepoint_passcount:
1825 printf_filtered (_("Trace stopped by tracepoint %d.\n"),
1826 ts->stopping_tracepoint);
1827 break;
1828 case tracepoint_error:
1829 if (ts->stopping_tracepoint)
1830 printf_filtered (_("Trace stopped by an "
1831 "error (%s, tracepoint %d).\n"),
1832 ts->stop_desc, ts->stopping_tracepoint);
1833 else
1834 printf_filtered (_("Trace stopped by an error (%s).\n"),
1835 ts->stop_desc);
1836 break;
1837 case trace_stop_reason_unknown:
1838 printf_filtered (_("Trace stopped for an unknown reason.\n"));
1839 break;
1840 default:
1841 printf_filtered (_("Trace stopped for some other reason (%d).\n"),
1842 ts->stop_reason);
1843 break;
1844 }
1845 }
1846
1847 if (ts->traceframes_created >= 0
1848 && ts->traceframe_count != ts->traceframes_created)
1849 {
1850 printf_filtered (_("Buffer contains %d trace "
1851 "frames (of %d created total).\n"),
1852 ts->traceframe_count, ts->traceframes_created);
1853 }
1854 else if (ts->traceframe_count >= 0)
1855 {
1856 printf_filtered (_("Collected %d trace frames.\n"),
1857 ts->traceframe_count);
1858 }
1859
1860 if (ts->buffer_free >= 0)
1861 {
1862 if (ts->buffer_size >= 0)
1863 {
1864 printf_filtered (_("Trace buffer has %d bytes of %d bytes free"),
1865 ts->buffer_free, ts->buffer_size);
1866 if (ts->buffer_size > 0)
1867 printf_filtered (_(" (%d%% full)"),
1868 ((int) ((((long long) (ts->buffer_size
1869 - ts->buffer_free)) * 100)
1870 / ts->buffer_size)));
1871 printf_filtered (_(".\n"));
1872 }
1873 else
1874 printf_filtered (_("Trace buffer has %d bytes free.\n"),
1875 ts->buffer_free);
1876 }
1877
1878 if (ts->disconnected_tracing)
1879 printf_filtered (_("Trace will continue if GDB disconnects.\n"));
1880 else
1881 printf_filtered (_("Trace will stop if GDB disconnects.\n"));
1882
1883 if (ts->circular_buffer)
1884 printf_filtered (_("Trace buffer is circular.\n"));
1885
1886 if (ts->user_name && strlen (ts->user_name) > 0)
1887 printf_filtered (_("Trace user is %s.\n"), ts->user_name);
1888
1889 if (ts->notes && strlen (ts->notes) > 0)
1890 printf_filtered (_("Trace notes: %s.\n"), ts->notes);
1891
1892 /* Now report on what we're doing with tfind. */
1893 if (traceframe_number >= 0)
1894 printf_filtered (_("Looking at trace frame %d, tracepoint %d.\n"),
1895 traceframe_number, tracepoint_number);
1896 else
1897 printf_filtered (_("Not looking at any trace frame.\n"));
1898
1899 /* Report start/stop times if supplied. */
1900 if (ts->start_time)
1901 {
1902 if (ts->stop_time)
1903 {
1904 LONGEST run_time = ts->stop_time - ts->start_time;
1905
1906 /* Reporting a run time is more readable than two long numbers. */
1907 printf_filtered (_("Trace started at %ld.%06ld secs, stopped %ld.%06ld secs later.\n"),
1908 (long int) (ts->start_time / 1000000),
1909 (long int) (ts->start_time % 1000000),
1910 (long int) (run_time / 1000000),
1911 (long int) (run_time % 1000000));
1912 }
1913 else
1914 printf_filtered (_("Trace started at %ld.%06ld secs.\n"),
1915 (long int) (ts->start_time / 1000000),
1916 (long int) (ts->start_time % 1000000));
1917 }
1918 else if (ts->stop_time)
1919 printf_filtered (_("Trace stopped at %ld.%06ld secs.\n"),
1920 (long int) (ts->stop_time / 1000000),
1921 (long int) (ts->stop_time % 1000000));
1922
1923 /* Now report any per-tracepoint status available. */
1924 tp_vec = all_tracepoints ();
1925
1926 for (ix = 0; VEC_iterate (breakpoint_p, tp_vec, ix, t); ix++)
1927 target_get_tracepoint_status (t, NULL);
1928
1929 VEC_free (breakpoint_p, tp_vec);
1930 }
1931
1932 /* Report the trace status to uiout, in a way suitable for MI, and not
1933 suitable for CLI. If ON_STOP is true, suppress a few fields that
1934 are not meaningful in the -trace-stop response.
1935
1936 The implementation is essentially parallel to trace_status_command, but
1937 merging them will result in unreadable code. */
1938 void
1939 trace_status_mi (int on_stop)
1940 {
1941 struct ui_out *uiout = current_uiout;
1942 struct trace_status *ts = current_trace_status ();
1943 int status;
1944
1945 status = target_get_trace_status (ts);
1946
1947 if (status == -1 && ts->filename == NULL)
1948 {
1949 uiout->field_string ("supported", "0");
1950 return;
1951 }
1952
1953 if (ts->filename != NULL)
1954 uiout->field_string ("supported", "file");
1955 else if (!on_stop)
1956 uiout->field_string ("supported", "1");
1957
1958 if (ts->filename != NULL)
1959 uiout->field_string ("trace-file", ts->filename);
1960
1961 gdb_assert (ts->running_known);
1962
1963 if (ts->running)
1964 {
1965 uiout->field_string ("running", "1");
1966
1967 /* Unlike CLI, do not show the state of 'disconnected-tracing' variable.
1968 Given that the frontend gets the status either on -trace-stop, or from
1969 -trace-status after re-connection, it does not seem like this
1970 information is necessary for anything. It is not necessary for either
1971 figuring the vital state of the target nor for navigation of trace
1972 frames. If the frontend wants to show the current state is some
1973 configure dialog, it can request the value when such dialog is
1974 invoked by the user. */
1975 }
1976 else
1977 {
1978 const char *stop_reason = NULL;
1979 int stopping_tracepoint = -1;
1980
1981 if (!on_stop)
1982 uiout->field_string ("running", "0");
1983
1984 if (ts->stop_reason != trace_stop_reason_unknown)
1985 {
1986 switch (ts->stop_reason)
1987 {
1988 case trace_stop_command:
1989 stop_reason = "request";
1990 break;
1991 case trace_buffer_full:
1992 stop_reason = "overflow";
1993 break;
1994 case trace_disconnected:
1995 stop_reason = "disconnection";
1996 break;
1997 case tracepoint_passcount:
1998 stop_reason = "passcount";
1999 stopping_tracepoint = ts->stopping_tracepoint;
2000 break;
2001 case tracepoint_error:
2002 stop_reason = "error";
2003 stopping_tracepoint = ts->stopping_tracepoint;
2004 break;
2005 }
2006
2007 if (stop_reason)
2008 {
2009 uiout->field_string ("stop-reason", stop_reason);
2010 if (stopping_tracepoint != -1)
2011 uiout->field_int ("stopping-tracepoint",
2012 stopping_tracepoint);
2013 if (ts->stop_reason == tracepoint_error)
2014 uiout->field_string ("error-description",
2015 ts->stop_desc);
2016 }
2017 }
2018 }
2019
2020 if (ts->traceframe_count != -1)
2021 uiout->field_int ("frames", ts->traceframe_count);
2022 if (ts->traceframes_created != -1)
2023 uiout->field_int ("frames-created", ts->traceframes_created);
2024 if (ts->buffer_size != -1)
2025 uiout->field_int ("buffer-size", ts->buffer_size);
2026 if (ts->buffer_free != -1)
2027 uiout->field_int ("buffer-free", ts->buffer_free);
2028
2029 uiout->field_int ("disconnected", ts->disconnected_tracing);
2030 uiout->field_int ("circular", ts->circular_buffer);
2031
2032 uiout->field_string ("user-name", ts->user_name);
2033 uiout->field_string ("notes", ts->notes);
2034
2035 {
2036 char buf[100];
2037
2038 xsnprintf (buf, sizeof buf, "%ld.%06ld",
2039 (long int) (ts->start_time / 1000000),
2040 (long int) (ts->start_time % 1000000));
2041 uiout->field_string ("start-time", buf);
2042 xsnprintf (buf, sizeof buf, "%ld.%06ld",
2043 (long int) (ts->stop_time / 1000000),
2044 (long int) (ts->stop_time % 1000000));
2045 uiout->field_string ("stop-time", buf);
2046 }
2047 }
2048
2049 /* Check if a trace run is ongoing. If so, and FROM_TTY, query the
2050 user if she really wants to detach. */
2051
2052 void
2053 query_if_trace_running (int from_tty)
2054 {
2055 if (!from_tty)
2056 return;
2057
2058 /* It can happen that the target that was tracing went away on its
2059 own, and we didn't notice. Get a status update, and if the
2060 current target doesn't even do tracing, then assume it's not
2061 running anymore. */
2062 if (target_get_trace_status (current_trace_status ()) < 0)
2063 current_trace_status ()->running = 0;
2064
2065 /* If running interactively, give the user the option to cancel and
2066 then decide what to do differently with the run. Scripts are
2067 just going to disconnect and let the target deal with it,
2068 according to how it's been instructed previously via
2069 disconnected-tracing. */
2070 if (current_trace_status ()->running)
2071 {
2072 process_tracepoint_on_disconnect ();
2073
2074 if (current_trace_status ()->disconnected_tracing)
2075 {
2076 if (!query (_("Trace is running and will "
2077 "continue after detach; detach anyway? ")))
2078 error (_("Not confirmed."));
2079 }
2080 else
2081 {
2082 if (!query (_("Trace is running but will "
2083 "stop on detach; detach anyway? ")))
2084 error (_("Not confirmed."));
2085 }
2086 }
2087 }
2088
2089 /* This function handles the details of what to do about an ongoing
2090 tracing run if the user has asked to detach or otherwise disconnect
2091 from the target. */
2092
2093 void
2094 disconnect_tracing (void)
2095 {
2096 /* Also we want to be out of tfind mode, otherwise things can get
2097 confusing upon reconnection. Just use these calls instead of
2098 full tfind_1 behavior because we're in the middle of detaching,
2099 and there's no point to updating current stack frame etc. */
2100 trace_reset_local_state ();
2101 }
2102
2103 /* Worker function for the various flavors of the tfind command. */
2104 void
2105 tfind_1 (enum trace_find_type type, int num,
2106 CORE_ADDR addr1, CORE_ADDR addr2,
2107 int from_tty)
2108 {
2109 int target_frameno = -1, target_tracept = -1;
2110 struct frame_id old_frame_id = null_frame_id;
2111 struct tracepoint *tp;
2112 struct ui_out *uiout = current_uiout;
2113
2114 /* Only try to get the current stack frame if we have a chance of
2115 succeeding. In particular, if we're trying to get a first trace
2116 frame while all threads are running, it's not going to succeed,
2117 so leave it with a default value and let the frame comparison
2118 below (correctly) decide to print out the source location of the
2119 trace frame. */
2120 if (!(type == tfind_number && num == -1)
2121 && (has_stack_frames () || traceframe_number >= 0))
2122 old_frame_id = get_frame_id (get_current_frame ());
2123
2124 target_frameno = target_trace_find (type, num, addr1, addr2,
2125 &target_tracept);
2126
2127 if (type == tfind_number
2128 && num == -1
2129 && target_frameno == -1)
2130 {
2131 /* We told the target to get out of tfind mode, and it did. */
2132 }
2133 else if (target_frameno == -1)
2134 {
2135 /* A request for a non-existent trace frame has failed.
2136 Our response will be different, depending on FROM_TTY:
2137
2138 If FROM_TTY is true, meaning that this command was
2139 typed interactively by the user, then give an error
2140 and DO NOT change the state of traceframe_number etc.
2141
2142 However if FROM_TTY is false, meaning that we're either
2143 in a script, a loop, or a user-defined command, then
2144 DON'T give an error, but DO change the state of
2145 traceframe_number etc. to invalid.
2146
2147 The rationalle is that if you typed the command, you
2148 might just have committed a typo or something, and you'd
2149 like to NOT lose your current debugging state. However
2150 if you're in a user-defined command or especially in a
2151 loop, then you need a way to detect that the command
2152 failed WITHOUT aborting. This allows you to write
2153 scripts that search thru the trace buffer until the end,
2154 and then continue on to do something else. */
2155
2156 if (from_tty)
2157 error (_("Target failed to find requested trace frame."));
2158 else
2159 {
2160 if (info_verbose)
2161 printf_filtered ("End of trace buffer.\n");
2162 #if 0 /* dubious now? */
2163 /* The following will not recurse, since it's
2164 special-cased. */
2165 tfind_command ("-1", from_tty);
2166 #endif
2167 }
2168 }
2169
2170 tp = get_tracepoint_by_number_on_target (target_tracept);
2171
2172 reinit_frame_cache ();
2173 target_dcache_invalidate ();
2174
2175 set_tracepoint_num (tp ? tp->number : target_tracept);
2176
2177 if (target_frameno != get_traceframe_number ())
2178 gdb::observers::traceframe_changed.notify (target_frameno, tracepoint_number);
2179
2180 set_current_traceframe (target_frameno);
2181
2182 if (target_frameno == -1)
2183 set_traceframe_context (NULL);
2184 else
2185 set_traceframe_context (get_current_frame ());
2186
2187 if (traceframe_number >= 0)
2188 {
2189 /* Use different branches for MI and CLI to make CLI messages
2190 i18n-eable. */
2191 if (uiout->is_mi_like_p ())
2192 {
2193 uiout->field_string ("found", "1");
2194 uiout->field_int ("tracepoint", tracepoint_number);
2195 uiout->field_int ("traceframe", traceframe_number);
2196 }
2197 else
2198 {
2199 printf_unfiltered (_("Found trace frame %d, tracepoint %d\n"),
2200 traceframe_number, tracepoint_number);
2201 }
2202 }
2203 else
2204 {
2205 if (uiout->is_mi_like_p ())
2206 uiout->field_string ("found", "0");
2207 else if (type == tfind_number && num == -1)
2208 printf_unfiltered (_("No longer looking at any trace frame\n"));
2209 else /* This case may never occur, check. */
2210 printf_unfiltered (_("No trace frame found\n"));
2211 }
2212
2213 /* If we're in nonstop mode and getting out of looking at trace
2214 frames, there won't be any current frame to go back to and
2215 display. */
2216 if (from_tty
2217 && (has_stack_frames () || traceframe_number >= 0))
2218 {
2219 enum print_what print_what;
2220
2221 /* NOTE: in imitation of the step command, try to determine
2222 whether we have made a transition from one function to
2223 another. If so, we'll print the "stack frame" (ie. the new
2224 function and it's arguments) -- otherwise we'll just show the
2225 new source line. */
2226
2227 if (frame_id_eq (old_frame_id,
2228 get_frame_id (get_current_frame ())))
2229 print_what = SRC_LINE;
2230 else
2231 print_what = SRC_AND_LOC;
2232
2233 print_stack_frame (get_selected_frame (NULL), 1, print_what, 1);
2234 do_displays ();
2235 }
2236 }
2237
2238 /* Error on looking at traceframes while trace is running. */
2239
2240 void
2241 check_trace_running (struct trace_status *status)
2242 {
2243 if (status->running && status->filename == NULL)
2244 error (_("May not look at trace frames while trace is running."));
2245 }
2246
2247 /* trace_find_command takes a trace frame number n,
2248 sends "QTFrame:<n>" to the target,
2249 and accepts a reply that may contain several optional pieces
2250 of information: a frame number, a tracepoint number, and an
2251 indication of whether this is a trap frame or a stepping frame.
2252
2253 The minimal response is just "OK" (which indicates that the
2254 target does not give us a frame number or a tracepoint number).
2255 Instead of that, the target may send us a string containing
2256 any combination of:
2257 F<hexnum> (gives the selected frame number)
2258 T<hexnum> (gives the selected tracepoint number)
2259 */
2260
2261 /* tfind command */
2262 static void
2263 tfind_command_1 (const char *args, int from_tty)
2264 { /* This should only be called with a numeric argument. */
2265 int frameno = -1;
2266
2267 check_trace_running (current_trace_status ());
2268
2269 if (args == 0 || *args == 0)
2270 { /* TFIND with no args means find NEXT trace frame. */
2271 if (traceframe_number == -1)
2272 frameno = 0; /* "next" is first one. */
2273 else
2274 frameno = traceframe_number + 1;
2275 }
2276 else if (0 == strcmp (args, "-"))
2277 {
2278 if (traceframe_number == -1)
2279 error (_("not debugging trace buffer"));
2280 else if (from_tty && traceframe_number == 0)
2281 error (_("already at start of trace buffer"));
2282
2283 frameno = traceframe_number - 1;
2284 }
2285 /* A hack to work around eval's need for fp to have been collected. */
2286 else if (0 == strcmp (args, "-1"))
2287 frameno = -1;
2288 else
2289 frameno = parse_and_eval_long (args);
2290
2291 if (frameno < -1)
2292 error (_("invalid input (%d is less than zero)"), frameno);
2293
2294 tfind_1 (tfind_number, frameno, 0, 0, from_tty);
2295 }
2296
2297 static void
2298 tfind_command (const char *args, int from_tty)
2299 {
2300 tfind_command_1 (args, from_tty);
2301 }
2302
2303 /* tfind end */
2304 static void
2305 tfind_end_command (const char *args, int from_tty)
2306 {
2307 tfind_command_1 ("-1", from_tty);
2308 }
2309
2310 /* tfind start */
2311 static void
2312 tfind_start_command (const char *args, int from_tty)
2313 {
2314 tfind_command_1 ("0", from_tty);
2315 }
2316
2317 /* tfind pc command */
2318 static void
2319 tfind_pc_command (const char *args, int from_tty)
2320 {
2321 CORE_ADDR pc;
2322
2323 check_trace_running (current_trace_status ());
2324
2325 if (args == 0 || *args == 0)
2326 pc = regcache_read_pc (get_current_regcache ());
2327 else
2328 pc = parse_and_eval_address (args);
2329
2330 tfind_1 (tfind_pc, 0, pc, 0, from_tty);
2331 }
2332
2333 /* tfind tracepoint command */
2334 static void
2335 tfind_tracepoint_command (const char *args, int from_tty)
2336 {
2337 int tdp;
2338 struct tracepoint *tp;
2339
2340 check_trace_running (current_trace_status ());
2341
2342 if (args == 0 || *args == 0)
2343 {
2344 if (tracepoint_number == -1)
2345 error (_("No current tracepoint -- please supply an argument."));
2346 else
2347 tdp = tracepoint_number; /* Default is current TDP. */
2348 }
2349 else
2350 tdp = parse_and_eval_long (args);
2351
2352 /* If we have the tracepoint on hand, use the number that the
2353 target knows about (which may be different if we disconnected
2354 and reconnected). */
2355 tp = get_tracepoint (tdp);
2356 if (tp)
2357 tdp = tp->number_on_target;
2358
2359 tfind_1 (tfind_tp, tdp, 0, 0, from_tty);
2360 }
2361
2362 /* TFIND LINE command:
2363
2364 This command will take a sourceline for argument, just like BREAK
2365 or TRACE (ie. anything that "decode_line_1" can handle).
2366
2367 With no argument, this command will find the next trace frame
2368 corresponding to a source line OTHER THAN THE CURRENT ONE. */
2369
2370 static void
2371 tfind_line_command (const char *args, int from_tty)
2372 {
2373 check_trace_running (current_trace_status ());
2374
2375 symtab_and_line sal;
2376 if (args == 0 || *args == 0)
2377 {
2378 sal = find_pc_line (get_frame_pc (get_current_frame ()), 0);
2379 }
2380 else
2381 {
2382 std::vector<symtab_and_line> sals
2383 = decode_line_with_current_source (args, DECODE_LINE_FUNFIRSTLINE);
2384 sal = sals[0];
2385 }
2386
2387 if (sal.symtab == 0)
2388 error (_("No line number information available."));
2389
2390 CORE_ADDR start_pc, end_pc;
2391 if (sal.line > 0 && find_line_pc_range (sal, &start_pc, &end_pc))
2392 {
2393 if (start_pc == end_pc)
2394 {
2395 printf_filtered ("Line %d of \"%s\"",
2396 sal.line,
2397 symtab_to_filename_for_display (sal.symtab));
2398 wrap_here (" ");
2399 printf_filtered (" is at address ");
2400 print_address (get_current_arch (), start_pc, gdb_stdout);
2401 wrap_here (" ");
2402 printf_filtered (" but contains no code.\n");
2403 sal = find_pc_line (start_pc, 0);
2404 if (sal.line > 0
2405 && find_line_pc_range (sal, &start_pc, &end_pc)
2406 && start_pc != end_pc)
2407 printf_filtered ("Attempting to find line %d instead.\n",
2408 sal.line);
2409 else
2410 error (_("Cannot find a good line."));
2411 }
2412 }
2413 else
2414 /* Is there any case in which we get here, and have an address
2415 which the user would want to see? If we have debugging
2416 symbols and no line numbers? */
2417 error (_("Line number %d is out of range for \"%s\"."),
2418 sal.line, symtab_to_filename_for_display (sal.symtab));
2419
2420 /* Find within range of stated line. */
2421 if (args && *args)
2422 tfind_1 (tfind_range, 0, start_pc, end_pc - 1, from_tty);
2423 else
2424 tfind_1 (tfind_outside, 0, start_pc, end_pc - 1, from_tty);
2425 }
2426
2427 /* tfind range command */
2428 static void
2429 tfind_range_command (const char *args, int from_tty)
2430 {
2431 static CORE_ADDR start, stop;
2432 const char *tmp;
2433
2434 check_trace_running (current_trace_status ());
2435
2436 if (args == 0 || *args == 0)
2437 { /* XXX FIXME: what should default behavior be? */
2438 printf_filtered ("Usage: tfind range <startaddr>,<endaddr>\n");
2439 return;
2440 }
2441
2442 if (0 != (tmp = strchr (args, ',')))
2443 {
2444 std::string start_addr (args, tmp);
2445 ++tmp;
2446 tmp = skip_spaces (tmp);
2447 start = parse_and_eval_address (start_addr.c_str ());
2448 stop = parse_and_eval_address (tmp);
2449 }
2450 else
2451 { /* No explicit end address? */
2452 start = parse_and_eval_address (args);
2453 stop = start + 1; /* ??? */
2454 }
2455
2456 tfind_1 (tfind_range, 0, start, stop, from_tty);
2457 }
2458
2459 /* tfind outside command */
2460 static void
2461 tfind_outside_command (const char *args, int from_tty)
2462 {
2463 CORE_ADDR start, stop;
2464 const char *tmp;
2465
2466 if (current_trace_status ()->running
2467 && current_trace_status ()->filename == NULL)
2468 error (_("May not look at trace frames while trace is running."));
2469
2470 if (args == 0 || *args == 0)
2471 { /* XXX FIXME: what should default behavior be? */
2472 printf_filtered ("Usage: tfind outside <startaddr>,<endaddr>\n");
2473 return;
2474 }
2475
2476 if (0 != (tmp = strchr (args, ',')))
2477 {
2478 std::string start_addr (args, tmp);
2479 ++tmp;
2480 tmp = skip_spaces (tmp);
2481 start = parse_and_eval_address (start_addr.c_str ());
2482 stop = parse_and_eval_address (tmp);
2483 }
2484 else
2485 { /* No explicit end address? */
2486 start = parse_and_eval_address (args);
2487 stop = start + 1; /* ??? */
2488 }
2489
2490 tfind_1 (tfind_outside, 0, start, stop, from_tty);
2491 }
2492
2493 /* info scope command: list the locals for a scope. */
2494 static void
2495 info_scope_command (const char *args_in, int from_tty)
2496 {
2497 struct symbol *sym;
2498 struct bound_minimal_symbol msym;
2499 const struct block *block;
2500 const char *symname;
2501 const char *save_args = args_in;
2502 struct block_iterator iter;
2503 int j, count = 0;
2504 struct gdbarch *gdbarch;
2505 int regno;
2506 const char *args = args_in;
2507
2508 if (args == 0 || *args == 0)
2509 error (_("requires an argument (function, "
2510 "line or *addr) to define a scope"));
2511
2512 event_location_up location = string_to_event_location (&args,
2513 current_language);
2514 std::vector<symtab_and_line> sals
2515 = decode_line_1 (location.get (), DECODE_LINE_FUNFIRSTLINE,
2516 NULL, NULL, 0);
2517 if (sals.empty ())
2518 {
2519 /* Presumably decode_line_1 has already warned. */
2520 return;
2521 }
2522
2523 /* Resolve line numbers to PC. */
2524 resolve_sal_pc (&sals[0]);
2525 block = block_for_pc (sals[0].pc);
2526
2527 while (block != 0)
2528 {
2529 QUIT; /* Allow user to bail out with ^C. */
2530 ALL_BLOCK_SYMBOLS (block, iter, sym)
2531 {
2532 QUIT; /* Allow user to bail out with ^C. */
2533 if (count == 0)
2534 printf_filtered ("Scope for %s:\n", save_args);
2535 count++;
2536
2537 symname = SYMBOL_PRINT_NAME (sym);
2538 if (symname == NULL || *symname == '\0')
2539 continue; /* Probably botched, certainly useless. */
2540
2541 gdbarch = symbol_arch (sym);
2542
2543 printf_filtered ("Symbol %s is ", symname);
2544
2545 if (SYMBOL_COMPUTED_OPS (sym) != NULL)
2546 SYMBOL_COMPUTED_OPS (sym)->describe_location (sym,
2547 BLOCK_START (block),
2548 gdb_stdout);
2549 else
2550 {
2551 switch (SYMBOL_CLASS (sym))
2552 {
2553 default:
2554 case LOC_UNDEF: /* Messed up symbol? */
2555 printf_filtered ("a bogus symbol, class %d.\n",
2556 SYMBOL_CLASS (sym));
2557 count--; /* Don't count this one. */
2558 continue;
2559 case LOC_CONST:
2560 printf_filtered ("a constant with value %s (%s)",
2561 plongest (SYMBOL_VALUE (sym)),
2562 hex_string (SYMBOL_VALUE (sym)));
2563 break;
2564 case LOC_CONST_BYTES:
2565 printf_filtered ("constant bytes: ");
2566 if (SYMBOL_TYPE (sym))
2567 for (j = 0; j < TYPE_LENGTH (SYMBOL_TYPE (sym)); j++)
2568 fprintf_filtered (gdb_stdout, " %02x",
2569 (unsigned) SYMBOL_VALUE_BYTES (sym)[j]);
2570 break;
2571 case LOC_STATIC:
2572 printf_filtered ("in static storage at address ");
2573 printf_filtered ("%s", paddress (gdbarch,
2574 SYMBOL_VALUE_ADDRESS (sym)));
2575 break;
2576 case LOC_REGISTER:
2577 /* GDBARCH is the architecture associated with the objfile
2578 the symbol is defined in; the target architecture may be
2579 different, and may provide additional registers. However,
2580 we do not know the target architecture at this point.
2581 We assume the objfile architecture will contain all the
2582 standard registers that occur in debug info in that
2583 objfile. */
2584 regno = SYMBOL_REGISTER_OPS (sym)->register_number (sym,
2585 gdbarch);
2586
2587 if (SYMBOL_IS_ARGUMENT (sym))
2588 printf_filtered ("an argument in register $%s",
2589 gdbarch_register_name (gdbarch, regno));
2590 else
2591 printf_filtered ("a local variable in register $%s",
2592 gdbarch_register_name (gdbarch, regno));
2593 break;
2594 case LOC_ARG:
2595 printf_filtered ("an argument at stack/frame offset %s",
2596 plongest (SYMBOL_VALUE (sym)));
2597 break;
2598 case LOC_LOCAL:
2599 printf_filtered ("a local variable at frame offset %s",
2600 plongest (SYMBOL_VALUE (sym)));
2601 break;
2602 case LOC_REF_ARG:
2603 printf_filtered ("a reference argument at offset %s",
2604 plongest (SYMBOL_VALUE (sym)));
2605 break;
2606 case LOC_REGPARM_ADDR:
2607 /* Note comment at LOC_REGISTER. */
2608 regno = SYMBOL_REGISTER_OPS (sym)->register_number (sym,
2609 gdbarch);
2610 printf_filtered ("the address of an argument, in register $%s",
2611 gdbarch_register_name (gdbarch, regno));
2612 break;
2613 case LOC_TYPEDEF:
2614 printf_filtered ("a typedef.\n");
2615 continue;
2616 case LOC_LABEL:
2617 printf_filtered ("a label at address ");
2618 printf_filtered ("%s", paddress (gdbarch,
2619 SYMBOL_VALUE_ADDRESS (sym)));
2620 break;
2621 case LOC_BLOCK:
2622 printf_filtered ("a function at address ");
2623 printf_filtered ("%s",
2624 paddress (gdbarch, BLOCK_START (SYMBOL_BLOCK_VALUE (sym))));
2625 break;
2626 case LOC_UNRESOLVED:
2627 msym = lookup_minimal_symbol (SYMBOL_LINKAGE_NAME (sym),
2628 NULL, NULL);
2629 if (msym.minsym == NULL)
2630 printf_filtered ("Unresolved Static");
2631 else
2632 {
2633 printf_filtered ("static storage at address ");
2634 printf_filtered ("%s",
2635 paddress (gdbarch,
2636 BMSYMBOL_VALUE_ADDRESS (msym)));
2637 }
2638 break;
2639 case LOC_OPTIMIZED_OUT:
2640 printf_filtered ("optimized out.\n");
2641 continue;
2642 case LOC_COMPUTED:
2643 gdb_assert_not_reached (_("LOC_COMPUTED variable missing a method"));
2644 }
2645 }
2646 if (SYMBOL_TYPE (sym))
2647 printf_filtered (", length %d.\n",
2648 TYPE_LENGTH (check_typedef (SYMBOL_TYPE (sym))));
2649 }
2650 if (BLOCK_FUNCTION (block))
2651 break;
2652 else
2653 block = BLOCK_SUPERBLOCK (block);
2654 }
2655 if (count <= 0)
2656 printf_filtered ("Scope for %s contains no locals or arguments.\n",
2657 save_args);
2658 }
2659
2660 /* Helper for trace_dump_command. Dump the action list starting at
2661 ACTION. STEPPING_ACTIONS is true if we're iterating over the
2662 actions of the body of a while-stepping action. STEPPING_FRAME is
2663 set if the current traceframe was determined to be a while-stepping
2664 traceframe. */
2665
2666 static void
2667 trace_dump_actions (struct command_line *action,
2668 int stepping_actions, int stepping_frame,
2669 int from_tty)
2670 {
2671 const char *action_exp, *next_comma;
2672
2673 for (; action != NULL; action = action->next)
2674 {
2675 struct cmd_list_element *cmd;
2676
2677 QUIT; /* Allow user to bail out with ^C. */
2678 action_exp = action->line;
2679 action_exp = skip_spaces (action_exp);
2680
2681 /* The collection actions to be done while stepping are
2682 bracketed by the commands "while-stepping" and "end". */
2683
2684 if (*action_exp == '#') /* comment line */
2685 continue;
2686
2687 cmd = lookup_cmd (&action_exp, cmdlist, "", -1, 1);
2688 if (cmd == 0)
2689 error (_("Bad action list item: %s"), action_exp);
2690
2691 if (cmd_cfunc_eq (cmd, while_stepping_pseudocommand))
2692 {
2693 int i;
2694
2695 for (i = 0; i < action->body_count; ++i)
2696 trace_dump_actions (action->body_list[i],
2697 1, stepping_frame, from_tty);
2698 }
2699 else if (cmd_cfunc_eq (cmd, collect_pseudocommand))
2700 {
2701 /* Display the collected data.
2702 For the trap frame, display only what was collected at
2703 the trap. Likewise for stepping frames, display only
2704 what was collected while stepping. This means that the
2705 two boolean variables, STEPPING_FRAME and
2706 STEPPING_ACTIONS should be equal. */
2707 if (stepping_frame == stepping_actions)
2708 {
2709 char *cmd = NULL;
2710 struct cleanup *old_chain
2711 = make_cleanup (free_current_contents, &cmd);
2712 int trace_string = 0;
2713
2714 if (*action_exp == '/')
2715 action_exp = decode_agent_options (action_exp, &trace_string);
2716
2717 do
2718 { /* Repeat over a comma-separated list. */
2719 QUIT; /* Allow user to bail out with ^C. */
2720 if (*action_exp == ',')
2721 action_exp++;
2722 action_exp = skip_spaces (action_exp);
2723
2724 next_comma = strchr (action_exp, ',');
2725
2726 if (0 == strncasecmp (action_exp, "$reg", 4))
2727 registers_info (NULL, from_tty);
2728 else if (0 == strncasecmp (action_exp, "$_ret", 5))
2729 ;
2730 else if (0 == strncasecmp (action_exp, "$loc", 4))
2731 info_locals_command (NULL, from_tty);
2732 else if (0 == strncasecmp (action_exp, "$arg", 4))
2733 info_args_command (NULL, from_tty);
2734 else
2735 { /* variable */
2736 if (next_comma != NULL)
2737 {
2738 size_t len = next_comma - action_exp;
2739
2740 cmd = (char *) xrealloc (cmd, len + 1);
2741 memcpy (cmd, action_exp, len);
2742 cmd[len] = 0;
2743 }
2744 else
2745 {
2746 size_t len = strlen (action_exp);
2747
2748 cmd = (char *) xrealloc (cmd, len + 1);
2749 memcpy (cmd, action_exp, len + 1);
2750 }
2751
2752 printf_filtered ("%s = ", cmd);
2753 output_command_const (cmd, from_tty);
2754 printf_filtered ("\n");
2755 }
2756 action_exp = next_comma;
2757 }
2758 while (action_exp && *action_exp == ',');
2759
2760 do_cleanups (old_chain);
2761 }
2762 }
2763 }
2764 }
2765
2766 /* Return bp_location of the tracepoint associated with the current
2767 traceframe. Set *STEPPING_FRAME_P to 1 if the current traceframe
2768 is a stepping traceframe. */
2769
2770 struct bp_location *
2771 get_traceframe_location (int *stepping_frame_p)
2772 {
2773 struct tracepoint *t;
2774 struct bp_location *tloc;
2775 struct regcache *regcache;
2776
2777 if (tracepoint_number == -1)
2778 error (_("No current trace frame."));
2779
2780 t = get_tracepoint (tracepoint_number);
2781
2782 if (t == NULL)
2783 error (_("No known tracepoint matches 'current' tracepoint #%d."),
2784 tracepoint_number);
2785
2786 /* The current frame is a trap frame if the frame PC is equal to the
2787 tracepoint PC. If not, then the current frame was collected
2788 during single-stepping. */
2789 regcache = get_current_regcache ();
2790
2791 /* If the traceframe's address matches any of the tracepoint's
2792 locations, assume it is a direct hit rather than a while-stepping
2793 frame. (FIXME this is not reliable, should record each frame's
2794 type.) */
2795 for (tloc = t->loc; tloc; tloc = tloc->next)
2796 if (tloc->address == regcache_read_pc (regcache))
2797 {
2798 *stepping_frame_p = 0;
2799 return tloc;
2800 }
2801
2802 /* If this is a stepping frame, we don't know which location
2803 triggered. The first is as good (or bad) a guess as any... */
2804 *stepping_frame_p = 1;
2805 return t->loc;
2806 }
2807
2808 /* Return all the actions, including default collect, of a tracepoint
2809 T. It constructs cleanups into the chain, and leaves the caller to
2810 handle them (call do_cleanups). */
2811
2812 static struct command_line *
2813 all_tracepoint_actions_and_cleanup (struct breakpoint *t)
2814 {
2815 struct command_line *actions;
2816
2817 actions = breakpoint_commands (t);
2818
2819 /* If there are default expressions to collect, make up a collect
2820 action and prepend to the action list to encode. Note that since
2821 validation is per-tracepoint (local var "xyz" might be valid for
2822 one tracepoint and not another, etc), we make up the action on
2823 the fly, and don't cache it. */
2824 if (*default_collect)
2825 {
2826 struct command_line *default_collect_action;
2827 char *default_collect_line;
2828
2829 default_collect_line = xstrprintf ("collect %s", default_collect);
2830 make_cleanup (xfree, default_collect_line);
2831
2832 validate_actionline (default_collect_line, t);
2833 default_collect_action = XNEW (struct command_line);
2834 make_cleanup (xfree, default_collect_action);
2835 default_collect_action->next = actions;
2836 default_collect_action->line = default_collect_line;
2837 actions = default_collect_action;
2838 }
2839
2840 return actions;
2841 }
2842
2843 /* The tdump command. */
2844
2845 static void
2846 tdump_command (const char *args, int from_tty)
2847 {
2848 int stepping_frame = 0;
2849 struct bp_location *loc;
2850 struct command_line *actions;
2851
2852 /* This throws an error is not inspecting a trace frame. */
2853 loc = get_traceframe_location (&stepping_frame);
2854
2855 printf_filtered ("Data collected at tracepoint %d, trace frame %d:\n",
2856 tracepoint_number, traceframe_number);
2857
2858 /* This command only makes sense for the current frame, not the
2859 selected frame. */
2860 scoped_restore_current_thread restore_thread;
2861
2862 select_frame (get_current_frame ());
2863
2864 actions = all_tracepoint_actions_and_cleanup (loc->owner);
2865
2866 trace_dump_actions (actions, 0, stepping_frame, from_tty);
2867 }
2868
2869 /* Encode a piece of a tracepoint's source-level definition in a form
2870 that is suitable for both protocol and saving in files. */
2871 /* This version does not do multiple encodes for long strings; it should
2872 return an offset to the next piece to encode. FIXME */
2873
2874 int
2875 encode_source_string (int tpnum, ULONGEST addr,
2876 const char *srctype, const char *src,
2877 char *buf, int buf_size)
2878 {
2879 if (80 + strlen (srctype) > buf_size)
2880 error (_("Buffer too small for source encoding"));
2881 sprintf (buf, "%x:%s:%s:%x:%x:",
2882 tpnum, phex_nz (addr, sizeof (addr)),
2883 srctype, 0, (int) strlen (src));
2884 if (strlen (buf) + strlen (src) * 2 >= buf_size)
2885 error (_("Source string too long for buffer"));
2886 bin2hex ((gdb_byte *) src, buf + strlen (buf), strlen (src));
2887 return -1;
2888 }
2889
2890 /* Tell the target what to do with an ongoing tracing run if GDB
2891 disconnects for some reason. */
2892
2893 static void
2894 set_disconnected_tracing (const char *args, int from_tty,
2895 struct cmd_list_element *c)
2896 {
2897 target_set_disconnected_tracing (disconnected_tracing);
2898 }
2899
2900 static void
2901 set_circular_trace_buffer (const char *args, int from_tty,
2902 struct cmd_list_element *c)
2903 {
2904 target_set_circular_trace_buffer (circular_trace_buffer);
2905 }
2906
2907 static void
2908 set_trace_buffer_size (const char *args, int from_tty,
2909 struct cmd_list_element *c)
2910 {
2911 target_set_trace_buffer_size (trace_buffer_size);
2912 }
2913
2914 static void
2915 set_trace_user (const char *args, int from_tty,
2916 struct cmd_list_element *c)
2917 {
2918 int ret;
2919
2920 ret = target_set_trace_notes (trace_user, NULL, NULL);
2921
2922 if (!ret)
2923 warning (_("Target does not support trace notes, user ignored"));
2924 }
2925
2926 static void
2927 set_trace_notes (const char *args, int from_tty,
2928 struct cmd_list_element *c)
2929 {
2930 int ret;
2931
2932 ret = target_set_trace_notes (NULL, trace_notes, NULL);
2933
2934 if (!ret)
2935 warning (_("Target does not support trace notes, note ignored"));
2936 }
2937
2938 static void
2939 set_trace_stop_notes (const char *args, int from_tty,
2940 struct cmd_list_element *c)
2941 {
2942 int ret;
2943
2944 ret = target_set_trace_notes (NULL, NULL, trace_stop_notes);
2945
2946 if (!ret)
2947 warning (_("Target does not support trace notes, stop note ignored"));
2948 }
2949
2950 /* Convert the memory pointed to by mem into hex, placing result in buf.
2951 * Return a pointer to the last char put in buf (null)
2952 * "stolen" from sparc-stub.c
2953 */
2954
2955 static const char hexchars[] = "0123456789abcdef";
2956
2957 static char *
2958 mem2hex (gdb_byte *mem, char *buf, int count)
2959 {
2960 gdb_byte ch;
2961
2962 while (count-- > 0)
2963 {
2964 ch = *mem++;
2965
2966 *buf++ = hexchars[ch >> 4];
2967 *buf++ = hexchars[ch & 0xf];
2968 }
2969
2970 *buf = 0;
2971
2972 return buf;
2973 }
2974
2975 int
2976 get_traceframe_number (void)
2977 {
2978 return traceframe_number;
2979 }
2980
2981 int
2982 get_tracepoint_number (void)
2983 {
2984 return tracepoint_number;
2985 }
2986
2987 /* Make the traceframe NUM be the current trace frame. Does nothing
2988 if NUM is already current. */
2989
2990 void
2991 set_current_traceframe (int num)
2992 {
2993 int newnum;
2994
2995 if (traceframe_number == num)
2996 {
2997 /* Nothing to do. */
2998 return;
2999 }
3000
3001 newnum = target_trace_find (tfind_number, num, 0, 0, NULL);
3002
3003 if (newnum != num)
3004 warning (_("could not change traceframe"));
3005
3006 set_traceframe_num (newnum);
3007
3008 /* Changing the traceframe changes our view of registers and of the
3009 frame chain. */
3010 registers_changed ();
3011
3012 clear_traceframe_info ();
3013 }
3014
3015 /* A cleanup used when switching away and back from tfind mode. */
3016
3017 struct current_traceframe_cleanup
3018 {
3019 /* The traceframe we were inspecting. */
3020 int traceframe_number;
3021 };
3022
3023 static void
3024 do_restore_current_traceframe_cleanup (void *arg)
3025 {
3026 struct current_traceframe_cleanup *old
3027 = (struct current_traceframe_cleanup *) arg;
3028
3029 set_current_traceframe (old->traceframe_number);
3030 }
3031
3032 static void
3033 restore_current_traceframe_cleanup_dtor (void *arg)
3034 {
3035 struct current_traceframe_cleanup *old
3036 = (struct current_traceframe_cleanup *) arg;
3037
3038 xfree (old);
3039 }
3040
3041 struct cleanup *
3042 make_cleanup_restore_current_traceframe (void)
3043 {
3044 struct current_traceframe_cleanup *old =
3045 XNEW (struct current_traceframe_cleanup);
3046
3047 old->traceframe_number = traceframe_number;
3048
3049 return make_cleanup_dtor (do_restore_current_traceframe_cleanup, old,
3050 restore_current_traceframe_cleanup_dtor);
3051 }
3052
3053 /* Given a number and address, return an uploaded tracepoint with that
3054 number, creating if necessary. */
3055
3056 struct uploaded_tp *
3057 get_uploaded_tp (int num, ULONGEST addr, struct uploaded_tp **utpp)
3058 {
3059 struct uploaded_tp *utp;
3060
3061 for (utp = *utpp; utp; utp = utp->next)
3062 if (utp->number == num && utp->addr == addr)
3063 return utp;
3064
3065 utp = new uploaded_tp;
3066 utp->number = num;
3067 utp->addr = addr;
3068 utp->next = *utpp;
3069 *utpp = utp;
3070
3071 return utp;
3072 }
3073
3074 void
3075 free_uploaded_tps (struct uploaded_tp **utpp)
3076 {
3077 struct uploaded_tp *next_one;
3078
3079 while (*utpp)
3080 {
3081 next_one = (*utpp)->next;
3082 delete *utpp;
3083 *utpp = next_one;
3084 }
3085 }
3086
3087 /* Given a number and address, return an uploaded tracepoint with that
3088 number, creating if necessary. */
3089
3090 struct uploaded_tsv *
3091 get_uploaded_tsv (int num, struct uploaded_tsv **utsvp)
3092 {
3093 struct uploaded_tsv *utsv;
3094
3095 for (utsv = *utsvp; utsv; utsv = utsv->next)
3096 if (utsv->number == num)
3097 return utsv;
3098
3099 utsv = XCNEW (struct uploaded_tsv);
3100 utsv->number = num;
3101 utsv->next = *utsvp;
3102 *utsvp = utsv;
3103
3104 return utsv;
3105 }
3106
3107 void
3108 free_uploaded_tsvs (struct uploaded_tsv **utsvp)
3109 {
3110 struct uploaded_tsv *next_one;
3111
3112 while (*utsvp)
3113 {
3114 next_one = (*utsvp)->next;
3115 xfree (*utsvp);
3116 *utsvp = next_one;
3117 }
3118 }
3119
3120 /* FIXME this function is heuristic and will miss the cases where the
3121 conditional is semantically identical but differs in whitespace,
3122 such as "x == 0" vs "x==0". */
3123
3124 static int
3125 cond_string_is_same (char *str1, char *str2)
3126 {
3127 if (str1 == NULL || str2 == NULL)
3128 return (str1 == str2);
3129
3130 return (strcmp (str1, str2) == 0);
3131 }
3132
3133 /* Look for an existing tracepoint that seems similar enough to the
3134 uploaded one. Enablement isn't compared, because the user can
3135 toggle that freely, and may have done so in anticipation of the
3136 next trace run. Return the location of matched tracepoint. */
3137
3138 static struct bp_location *
3139 find_matching_tracepoint_location (struct uploaded_tp *utp)
3140 {
3141 VEC(breakpoint_p) *tp_vec = all_tracepoints ();
3142 int ix;
3143 struct breakpoint *b;
3144 struct bp_location *loc;
3145
3146 for (ix = 0; VEC_iterate (breakpoint_p, tp_vec, ix, b); ix++)
3147 {
3148 struct tracepoint *t = (struct tracepoint *) b;
3149
3150 if (b->type == utp->type
3151 && t->step_count == utp->step
3152 && t->pass_count == utp->pass
3153 && cond_string_is_same (t->cond_string, utp->cond_string)
3154 /* FIXME also test actions. */
3155 )
3156 {
3157 /* Scan the locations for an address match. */
3158 for (loc = b->loc; loc; loc = loc->next)
3159 {
3160 if (loc->address == utp->addr)
3161 return loc;
3162 }
3163 }
3164 }
3165 return NULL;
3166 }
3167
3168 /* Given a list of tracepoints uploaded from a target, attempt to
3169 match them up with existing tracepoints, and create new ones if not
3170 found. */
3171
3172 void
3173 merge_uploaded_tracepoints (struct uploaded_tp **uploaded_tps)
3174 {
3175 struct uploaded_tp *utp;
3176 /* A set of tracepoints which are modified. */
3177 VEC(breakpoint_p) *modified_tp = NULL;
3178 int ix;
3179 struct breakpoint *b;
3180
3181 /* Look for GDB tracepoints that match up with our uploaded versions. */
3182 for (utp = *uploaded_tps; utp; utp = utp->next)
3183 {
3184 struct bp_location *loc;
3185 struct tracepoint *t;
3186
3187 loc = find_matching_tracepoint_location (utp);
3188 if (loc)
3189 {
3190 int found = 0;
3191
3192 /* Mark this location as already inserted. */
3193 loc->inserted = 1;
3194 t = (struct tracepoint *) loc->owner;
3195 printf_filtered (_("Assuming tracepoint %d is same "
3196 "as target's tracepoint %d at %s.\n"),
3197 loc->owner->number, utp->number,
3198 paddress (loc->gdbarch, utp->addr));
3199
3200 /* The tracepoint LOC->owner was modified (the location LOC
3201 was marked as inserted in the target). Save it in
3202 MODIFIED_TP if not there yet. The 'breakpoint-modified'
3203 observers will be notified later once for each tracepoint
3204 saved in MODIFIED_TP. */
3205 for (ix = 0;
3206 VEC_iterate (breakpoint_p, modified_tp, ix, b);
3207 ix++)
3208 if (b == loc->owner)
3209 {
3210 found = 1;
3211 break;
3212 }
3213 if (!found)
3214 VEC_safe_push (breakpoint_p, modified_tp, loc->owner);
3215 }
3216 else
3217 {
3218 t = create_tracepoint_from_upload (utp);
3219 if (t)
3220 printf_filtered (_("Created tracepoint %d for "
3221 "target's tracepoint %d at %s.\n"),
3222 t->number, utp->number,
3223 paddress (get_current_arch (), utp->addr));
3224 else
3225 printf_filtered (_("Failed to create tracepoint for target's "
3226 "tracepoint %d at %s, skipping it.\n"),
3227 utp->number,
3228 paddress (get_current_arch (), utp->addr));
3229 }
3230 /* Whether found or created, record the number used by the
3231 target, to help with mapping target tracepoints back to their
3232 counterparts here. */
3233 if (t)
3234 t->number_on_target = utp->number;
3235 }
3236
3237 /* Notify 'breakpoint-modified' observer that at least one of B's
3238 locations was changed. */
3239 for (ix = 0; VEC_iterate (breakpoint_p, modified_tp, ix, b); ix++)
3240 gdb::observers::breakpoint_modified.notify (b);
3241
3242 VEC_free (breakpoint_p, modified_tp);
3243 free_uploaded_tps (uploaded_tps);
3244 }
3245
3246 /* Trace state variables don't have much to identify them beyond their
3247 name, so just use that to detect matches. */
3248
3249 static struct trace_state_variable *
3250 find_matching_tsv (struct uploaded_tsv *utsv)
3251 {
3252 if (!utsv->name)
3253 return NULL;
3254
3255 return find_trace_state_variable (utsv->name);
3256 }
3257
3258 static struct trace_state_variable *
3259 create_tsv_from_upload (struct uploaded_tsv *utsv)
3260 {
3261 const char *namebase;
3262 std::string buf;
3263 int try_num = 0;
3264 struct trace_state_variable *tsv;
3265
3266 if (utsv->name)
3267 {
3268 namebase = utsv->name;
3269 buf = namebase;
3270 }
3271 else
3272 {
3273 namebase = "__tsv";
3274 buf = string_printf ("%s_%d", namebase, try_num++);
3275 }
3276
3277 /* Fish for a name that is not in use. */
3278 /* (should check against all internal vars?) */
3279 while (find_trace_state_variable (buf.c_str ()))
3280 buf = string_printf ("%s_%d", namebase, try_num++);
3281
3282 /* We have an available name, create the variable. */
3283 tsv = create_trace_state_variable (buf.c_str ());
3284 tsv->initial_value = utsv->initial_value;
3285 tsv->builtin = utsv->builtin;
3286
3287 gdb::observers::tsv_created.notify (tsv);
3288
3289 return tsv;
3290 }
3291
3292 /* Given a list of uploaded trace state variables, try to match them
3293 up with existing variables, or create additional ones. */
3294
3295 void
3296 merge_uploaded_trace_state_variables (struct uploaded_tsv **uploaded_tsvs)
3297 {
3298 int ix;
3299 struct uploaded_tsv *utsv;
3300 struct trace_state_variable *tsv;
3301 int highest;
3302
3303 /* Most likely some numbers will have to be reassigned as part of
3304 the merge, so clear them all in anticipation. */
3305 for (ix = 0; VEC_iterate (tsv_s, tvariables, ix, tsv); ++ix)
3306 tsv->number = 0;
3307
3308 for (utsv = *uploaded_tsvs; utsv; utsv = utsv->next)
3309 {
3310 tsv = find_matching_tsv (utsv);
3311 if (tsv)
3312 {
3313 if (info_verbose)
3314 printf_filtered (_("Assuming trace state variable $%s "
3315 "is same as target's variable %d.\n"),
3316 tsv->name, utsv->number);
3317 }
3318 else
3319 {
3320 tsv = create_tsv_from_upload (utsv);
3321 if (info_verbose)
3322 printf_filtered (_("Created trace state variable "
3323 "$%s for target's variable %d.\n"),
3324 tsv->name, utsv->number);
3325 }
3326 /* Give precedence to numberings that come from the target. */
3327 if (tsv)
3328 tsv->number = utsv->number;
3329 }
3330
3331 /* Renumber everything that didn't get a target-assigned number. */
3332 highest = 0;
3333 for (ix = 0; VEC_iterate (tsv_s, tvariables, ix, tsv); ++ix)
3334 if (tsv->number > highest)
3335 highest = tsv->number;
3336
3337 ++highest;
3338 for (ix = 0; VEC_iterate (tsv_s, tvariables, ix, tsv); ++ix)
3339 if (tsv->number == 0)
3340 tsv->number = highest++;
3341
3342 free_uploaded_tsvs (uploaded_tsvs);
3343 }
3344
3345 /* Parse the part of trace status syntax that is shared between
3346 the remote protocol and the trace file reader. */
3347
3348 void
3349 parse_trace_status (const char *line, struct trace_status *ts)
3350 {
3351 const char *p = line, *p1, *p2, *p3, *p_temp;
3352 int end;
3353 ULONGEST val;
3354
3355 ts->running_known = 1;
3356 ts->running = (*p++ == '1');
3357 ts->stop_reason = trace_stop_reason_unknown;
3358 xfree (ts->stop_desc);
3359 ts->stop_desc = NULL;
3360 ts->traceframe_count = -1;
3361 ts->traceframes_created = -1;
3362 ts->buffer_free = -1;
3363 ts->buffer_size = -1;
3364 ts->disconnected_tracing = 0;
3365 ts->circular_buffer = 0;
3366 xfree (ts->user_name);
3367 ts->user_name = NULL;
3368 xfree (ts->notes);
3369 ts->notes = NULL;
3370 ts->start_time = ts->stop_time = 0;
3371
3372 while (*p++)
3373 {
3374 p1 = strchr (p, ':');
3375 if (p1 == NULL)
3376 error (_("Malformed trace status, at %s\n\
3377 Status line: '%s'\n"), p, line);
3378 p3 = strchr (p, ';');
3379 if (p3 == NULL)
3380 p3 = p + strlen (p);
3381 if (strncmp (p, stop_reason_names[trace_buffer_full], p1 - p) == 0)
3382 {
3383 p = unpack_varlen_hex (++p1, &val);
3384 ts->stop_reason = trace_buffer_full;
3385 }
3386 else if (strncmp (p, stop_reason_names[trace_never_run], p1 - p) == 0)
3387 {
3388 p = unpack_varlen_hex (++p1, &val);
3389 ts->stop_reason = trace_never_run;
3390 }
3391 else if (strncmp (p, stop_reason_names[tracepoint_passcount],
3392 p1 - p) == 0)
3393 {
3394 p = unpack_varlen_hex (++p1, &val);
3395 ts->stop_reason = tracepoint_passcount;
3396 ts->stopping_tracepoint = val;
3397 }
3398 else if (strncmp (p, stop_reason_names[trace_stop_command], p1 - p) == 0)
3399 {
3400 p2 = strchr (++p1, ':');
3401 if (!p2 || p2 > p3)
3402 {
3403 /*older style*/
3404 p2 = p1;
3405 }
3406 else if (p2 != p1)
3407 {
3408 ts->stop_desc = (char *) xmalloc (strlen (line));
3409 end = hex2bin (p1, (gdb_byte *) ts->stop_desc, (p2 - p1) / 2);
3410 ts->stop_desc[end] = '\0';
3411 }
3412 else
3413 ts->stop_desc = xstrdup ("");
3414
3415 p = unpack_varlen_hex (++p2, &val);
3416 ts->stop_reason = trace_stop_command;
3417 }
3418 else if (strncmp (p, stop_reason_names[trace_disconnected], p1 - p) == 0)
3419 {
3420 p = unpack_varlen_hex (++p1, &val);
3421 ts->stop_reason = trace_disconnected;
3422 }
3423 else if (strncmp (p, stop_reason_names[tracepoint_error], p1 - p) == 0)
3424 {
3425 p2 = strchr (++p1, ':');
3426 if (p2 != p1)
3427 {
3428 ts->stop_desc = (char *) xmalloc ((p2 - p1) / 2 + 1);
3429 end = hex2bin (p1, (gdb_byte *) ts->stop_desc, (p2 - p1) / 2);
3430 ts->stop_desc[end] = '\0';
3431 }
3432 else
3433 ts->stop_desc = xstrdup ("");
3434
3435 p = unpack_varlen_hex (++p2, &val);
3436 ts->stopping_tracepoint = val;
3437 ts->stop_reason = tracepoint_error;
3438 }
3439 else if (strncmp (p, "tframes", p1 - p) == 0)
3440 {
3441 p = unpack_varlen_hex (++p1, &val);
3442 ts->traceframe_count = val;
3443 }
3444 else if (strncmp (p, "tcreated", p1 - p) == 0)
3445 {
3446 p = unpack_varlen_hex (++p1, &val);
3447 ts->traceframes_created = val;
3448 }
3449 else if (strncmp (p, "tfree", p1 - p) == 0)
3450 {
3451 p = unpack_varlen_hex (++p1, &val);
3452 ts->buffer_free = val;
3453 }
3454 else if (strncmp (p, "tsize", p1 - p) == 0)
3455 {
3456 p = unpack_varlen_hex (++p1, &val);
3457 ts->buffer_size = val;
3458 }
3459 else if (strncmp (p, "disconn", p1 - p) == 0)
3460 {
3461 p = unpack_varlen_hex (++p1, &val);
3462 ts->disconnected_tracing = val;
3463 }
3464 else if (strncmp (p, "circular", p1 - p) == 0)
3465 {
3466 p = unpack_varlen_hex (++p1, &val);
3467 ts->circular_buffer = val;
3468 }
3469 else if (strncmp (p, "starttime", p1 - p) == 0)
3470 {
3471 p = unpack_varlen_hex (++p1, &val);
3472 ts->start_time = val;
3473 }
3474 else if (strncmp (p, "stoptime", p1 - p) == 0)
3475 {
3476 p = unpack_varlen_hex (++p1, &val);
3477 ts->stop_time = val;
3478 }
3479 else if (strncmp (p, "username", p1 - p) == 0)
3480 {
3481 ++p1;
3482 ts->user_name = (char *) xmalloc (strlen (p) / 2);
3483 end = hex2bin (p1, (gdb_byte *) ts->user_name, (p3 - p1) / 2);
3484 ts->user_name[end] = '\0';
3485 p = p3;
3486 }
3487 else if (strncmp (p, "notes", p1 - p) == 0)
3488 {
3489 ++p1;
3490 ts->notes = (char *) xmalloc (strlen (p) / 2);
3491 end = hex2bin (p1, (gdb_byte *) ts->notes, (p3 - p1) / 2);
3492 ts->notes[end] = '\0';
3493 p = p3;
3494 }
3495 else
3496 {
3497 /* Silently skip unknown optional info. */
3498 p_temp = strchr (p1 + 1, ';');
3499 if (p_temp)
3500 p = p_temp;
3501 else
3502 /* Must be at the end. */
3503 break;
3504 }
3505 }
3506 }
3507
3508 void
3509 parse_tracepoint_status (const char *p, struct breakpoint *bp,
3510 struct uploaded_tp *utp)
3511 {
3512 ULONGEST uval;
3513 struct tracepoint *tp = (struct tracepoint *) bp;
3514
3515 p = unpack_varlen_hex (p, &uval);
3516 if (tp)
3517 tp->hit_count += uval;
3518 else
3519 utp->hit_count += uval;
3520 p = unpack_varlen_hex (p + 1, &uval);
3521 if (tp)
3522 tp->traceframe_usage += uval;
3523 else
3524 utp->traceframe_usage += uval;
3525 /* Ignore any extra, allowing for future extensions. */
3526 }
3527
3528 /* Given a line of text defining a part of a tracepoint, parse it into
3529 an "uploaded tracepoint". */
3530
3531 void
3532 parse_tracepoint_definition (const char *line, struct uploaded_tp **utpp)
3533 {
3534 const char *p;
3535 char piece;
3536 ULONGEST num, addr, step, pass, orig_size, xlen, start;
3537 int enabled, end;
3538 enum bptype type;
3539 const char *srctype;
3540 char *cond, *buf;
3541 struct uploaded_tp *utp = NULL;
3542
3543 p = line;
3544 /* Both tracepoint and action definitions start with the same number
3545 and address sequence. */
3546 piece = *p++;
3547 p = unpack_varlen_hex (p, &num);
3548 p++; /* skip a colon */
3549 p = unpack_varlen_hex (p, &addr);
3550 p++; /* skip a colon */
3551 if (piece == 'T')
3552 {
3553 enabled = (*p++ == 'E');
3554 p++; /* skip a colon */
3555 p = unpack_varlen_hex (p, &step);
3556 p++; /* skip a colon */
3557 p = unpack_varlen_hex (p, &pass);
3558 type = bp_tracepoint;
3559 cond = NULL;
3560 /* Thumb through optional fields. */
3561 while (*p == ':')
3562 {
3563 p++; /* skip a colon */
3564 if (*p == 'F')
3565 {
3566 type = bp_fast_tracepoint;
3567 p++;
3568 p = unpack_varlen_hex (p, &orig_size);
3569 }
3570 else if (*p == 'S')
3571 {
3572 type = bp_static_tracepoint;
3573 p++;
3574 }
3575 else if (*p == 'X')
3576 {
3577 p++;
3578 p = unpack_varlen_hex (p, &xlen);
3579 p++; /* skip a comma */
3580 cond = (char *) xmalloc (2 * xlen + 1);
3581 strncpy (cond, p, 2 * xlen);
3582 cond[2 * xlen] = '\0';
3583 p += 2 * xlen;
3584 }
3585 else
3586 warning (_("Unrecognized char '%c' in tracepoint "
3587 "definition, skipping rest"), *p);
3588 }
3589 utp = get_uploaded_tp (num, addr, utpp);
3590 utp->type = type;
3591 utp->enabled = enabled;
3592 utp->step = step;
3593 utp->pass = pass;
3594 utp->cond = cond;
3595 }
3596 else if (piece == 'A')
3597 {
3598 utp = get_uploaded_tp (num, addr, utpp);
3599 utp->actions.push_back (xstrdup (p));
3600 }
3601 else if (piece == 'S')
3602 {
3603 utp = get_uploaded_tp (num, addr, utpp);
3604 utp->step_actions.push_back (xstrdup (p));
3605 }
3606 else if (piece == 'Z')
3607 {
3608 /* Parse a chunk of source form definition. */
3609 utp = get_uploaded_tp (num, addr, utpp);
3610 srctype = p;
3611 p = strchr (p, ':');
3612 p++; /* skip a colon */
3613 p = unpack_varlen_hex (p, &start);
3614 p++; /* skip a colon */
3615 p = unpack_varlen_hex (p, &xlen);
3616 p++; /* skip a colon */
3617
3618 buf = (char *) alloca (strlen (line));
3619
3620 end = hex2bin (p, (gdb_byte *) buf, strlen (p) / 2);
3621 buf[end] = '\0';
3622
3623 if (startswith (srctype, "at:"))
3624 utp->at_string = xstrdup (buf);
3625 else if (startswith (srctype, "cond:"))
3626 utp->cond_string = xstrdup (buf);
3627 else if (startswith (srctype, "cmd:"))
3628 utp->cmd_strings.push_back (xstrdup (buf));
3629 }
3630 else if (piece == 'V')
3631 {
3632 utp = get_uploaded_tp (num, addr, utpp);
3633
3634 parse_tracepoint_status (p, NULL, utp);
3635 }
3636 else
3637 {
3638 /* Don't error out, the target might be sending us optional
3639 info that we don't care about. */
3640 warning (_("Unrecognized tracepoint piece '%c', ignoring"), piece);
3641 }
3642 }
3643
3644 /* Convert a textual description of a trace state variable into an
3645 uploaded object. */
3646
3647 void
3648 parse_tsv_definition (const char *line, struct uploaded_tsv **utsvp)
3649 {
3650 const char *p;
3651 char *buf;
3652 ULONGEST num, initval, builtin;
3653 int end;
3654 struct uploaded_tsv *utsv = NULL;
3655
3656 buf = (char *) alloca (strlen (line));
3657
3658 p = line;
3659 p = unpack_varlen_hex (p, &num);
3660 p++; /* skip a colon */
3661 p = unpack_varlen_hex (p, &initval);
3662 p++; /* skip a colon */
3663 p = unpack_varlen_hex (p, &builtin);
3664 p++; /* skip a colon */
3665 end = hex2bin (p, (gdb_byte *) buf, strlen (p) / 2);
3666 buf[end] = '\0';
3667
3668 utsv = get_uploaded_tsv (num, utsvp);
3669 utsv->initial_value = initval;
3670 utsv->builtin = builtin;
3671 utsv->name = xstrdup (buf);
3672 }
3673
3674 /* Given a line of text defining a static tracepoint marker, parse it
3675 into a "static tracepoint marker" object. Throws an error is
3676 parsing fails. If PP is non-null, it points to one past the end of
3677 the parsed marker definition. */
3678
3679 void
3680 parse_static_tracepoint_marker_definition (const char *line, const char **pp,
3681 static_tracepoint_marker *marker)
3682 {
3683 const char *p, *endp;
3684 ULONGEST addr;
3685
3686 p = line;
3687 p = unpack_varlen_hex (p, &addr);
3688 p++; /* skip a colon */
3689
3690 marker->gdbarch = target_gdbarch ();
3691 marker->address = (CORE_ADDR) addr;
3692
3693 endp = strchr (p, ':');
3694 if (endp == NULL)
3695 error (_("bad marker definition: %s"), line);
3696
3697 marker->str_id = hex2str (p, (endp - p) / 2);
3698
3699 p = endp;
3700 p++; /* skip a colon */
3701
3702 /* This definition may be followed by another one, separated by a comma. */
3703 int hex_len;
3704 endp = strchr (p, ',');
3705 if (endp != nullptr)
3706 hex_len = endp - p;
3707 else
3708 hex_len = strlen (p);
3709
3710 marker->extra = hex2str (p, hex_len / 2);
3711
3712 if (pp != nullptr)
3713 *pp = p + hex_len;
3714 }
3715
3716 /* Print MARKER to gdb_stdout. */
3717
3718 static void
3719 print_one_static_tracepoint_marker (int count,
3720 const static_tracepoint_marker &marker)
3721 {
3722 struct symbol *sym;
3723
3724 char wrap_indent[80];
3725 char extra_field_indent[80];
3726 struct ui_out *uiout = current_uiout;
3727 VEC(breakpoint_p) *tracepoints;
3728
3729 symtab_and_line sal;
3730 sal.pc = marker.address;
3731
3732 tracepoints = static_tracepoints_here (marker.address);
3733
3734 ui_out_emit_tuple tuple_emitter (uiout, "marker");
3735
3736 /* A counter field to help readability. This is not a stable
3737 identifier! */
3738 uiout->field_int ("count", count);
3739
3740 uiout->field_string ("marker-id", marker.str_id.c_str ());
3741
3742 uiout->field_fmt ("enabled", "%c",
3743 !VEC_empty (breakpoint_p, tracepoints) ? 'y' : 'n');
3744 uiout->spaces (2);
3745
3746 strcpy (wrap_indent, " ");
3747
3748 if (gdbarch_addr_bit (marker.gdbarch) <= 32)
3749 strcat (wrap_indent, " ");
3750 else
3751 strcat (wrap_indent, " ");
3752
3753 strcpy (extra_field_indent, " ");
3754
3755 uiout->field_core_addr ("addr", marker.gdbarch, marker.address);
3756
3757 sal = find_pc_line (marker.address, 0);
3758 sym = find_pc_sect_function (marker.address, NULL);
3759 if (sym)
3760 {
3761 uiout->text ("in ");
3762 uiout->field_string ("func",
3763 SYMBOL_PRINT_NAME (sym));
3764 uiout->wrap_hint (wrap_indent);
3765 uiout->text (" at ");
3766 }
3767 else
3768 uiout->field_skip ("func");
3769
3770 if (sal.symtab != NULL)
3771 {
3772 uiout->field_string ("file",
3773 symtab_to_filename_for_display (sal.symtab));
3774 uiout->text (":");
3775
3776 if (uiout->is_mi_like_p ())
3777 {
3778 const char *fullname = symtab_to_fullname (sal.symtab);
3779
3780 uiout->field_string ("fullname", fullname);
3781 }
3782 else
3783 uiout->field_skip ("fullname");
3784
3785 uiout->field_int ("line", sal.line);
3786 }
3787 else
3788 {
3789 uiout->field_skip ("fullname");
3790 uiout->field_skip ("line");
3791 }
3792
3793 uiout->text ("\n");
3794 uiout->text (extra_field_indent);
3795 uiout->text (_("Data: \""));
3796 uiout->field_string ("extra-data", marker.extra.c_str ());
3797 uiout->text ("\"\n");
3798
3799 if (!VEC_empty (breakpoint_p, tracepoints))
3800 {
3801 int ix;
3802 struct breakpoint *b;
3803
3804 {
3805 ui_out_emit_tuple tuple_emitter (uiout, "tracepoints-at");
3806
3807 uiout->text (extra_field_indent);
3808 uiout->text (_("Probed by static tracepoints: "));
3809 for (ix = 0; VEC_iterate(breakpoint_p, tracepoints, ix, b); ix++)
3810 {
3811 if (ix > 0)
3812 uiout->text (", ");
3813 uiout->text ("#");
3814 uiout->field_int ("tracepoint-id", b->number);
3815 }
3816 }
3817
3818 if (uiout->is_mi_like_p ())
3819 uiout->field_int ("number-of-tracepoints",
3820 VEC_length(breakpoint_p, tracepoints));
3821 else
3822 uiout->text ("\n");
3823 }
3824 VEC_free (breakpoint_p, tracepoints);
3825 }
3826
3827 static void
3828 info_static_tracepoint_markers_command (const char *arg, int from_tty)
3829 {
3830 struct ui_out *uiout = current_uiout;
3831 std::vector<static_tracepoint_marker> markers
3832 = target_static_tracepoint_markers_by_strid (NULL);
3833
3834 /* We don't have to check target_can_use_agent and agent's capability on
3835 static tracepoint here, in order to be compatible with older GDBserver.
3836 We don't check USE_AGENT is true or not, because static tracepoints
3837 don't work without in-process agent, so we don't bother users to type
3838 `set agent on' when to use static tracepoint. */
3839
3840 ui_out_emit_table table_emitter (uiout, 5, -1,
3841 "StaticTracepointMarkersTable");
3842
3843 uiout->table_header (7, ui_left, "counter", "Cnt");
3844
3845 uiout->table_header (40, ui_left, "marker-id", "ID");
3846
3847 uiout->table_header (3, ui_left, "enabled", "Enb");
3848 if (gdbarch_addr_bit (target_gdbarch ()) <= 32)
3849 uiout->table_header (10, ui_left, "addr", "Address");
3850 else
3851 uiout->table_header (18, ui_left, "addr", "Address");
3852 uiout->table_header (40, ui_noalign, "what", "What");
3853
3854 uiout->table_body ();
3855
3856 for (int i = 0; i < markers.size (); i++)
3857 print_one_static_tracepoint_marker (i + 1, markers[i]);
3858 }
3859
3860 /* The $_sdata convenience variable is a bit special. We don't know
3861 for sure type of the value until we actually have a chance to fetch
3862 the data --- the size of the object depends on what has been
3863 collected. We solve this by making $_sdata be an internalvar that
3864 creates a new value on access. */
3865
3866 /* Return a new value with the correct type for the sdata object of
3867 the current trace frame. Return a void value if there's no object
3868 available. */
3869
3870 static struct value *
3871 sdata_make_value (struct gdbarch *gdbarch, struct internalvar *var,
3872 void *ignore)
3873 {
3874 LONGEST size;
3875 gdb_byte *buf;
3876
3877 /* We need to read the whole object before we know its size. */
3878 size = target_read_alloc (&current_target,
3879 TARGET_OBJECT_STATIC_TRACE_DATA,
3880 NULL, &buf);
3881 if (size >= 0)
3882 {
3883 struct value *v;
3884 struct type *type;
3885
3886 type = init_vector_type (builtin_type (gdbarch)->builtin_true_char,
3887 size);
3888 v = allocate_value (type);
3889 memcpy (value_contents_raw (v), buf, size);
3890 xfree (buf);
3891 return v;
3892 }
3893 else
3894 return allocate_value (builtin_type (gdbarch)->builtin_void);
3895 }
3896
3897 #if !defined(HAVE_LIBEXPAT)
3898
3899 struct std::unique_ptr<traceframe_info>
3900 parse_traceframe_info (const char *tframe_info)
3901 {
3902 static int have_warned;
3903
3904 if (!have_warned)
3905 {
3906 have_warned = 1;
3907 warning (_("Can not parse XML trace frame info; XML support "
3908 "was disabled at compile time"));
3909 }
3910
3911 return NULL;
3912 }
3913
3914 #else /* HAVE_LIBEXPAT */
3915
3916 #include "xml-support.h"
3917
3918 /* Handle the start of a <memory> element. */
3919
3920 static void
3921 traceframe_info_start_memory (struct gdb_xml_parser *parser,
3922 const struct gdb_xml_element *element,
3923 void *user_data,
3924 std::vector<gdb_xml_value> &attributes)
3925 {
3926 struct traceframe_info *info = (struct traceframe_info *) user_data;
3927 ULONGEST *start_p, *length_p;
3928
3929 start_p
3930 = (ULONGEST *) xml_find_attribute (attributes, "start")->value.get ();
3931 length_p
3932 = (ULONGEST *) xml_find_attribute (attributes, "length")->value.get ();
3933
3934 info->memory.emplace_back (*start_p, *length_p);
3935 }
3936
3937 /* Handle the start of a <tvar> element. */
3938
3939 static void
3940 traceframe_info_start_tvar (struct gdb_xml_parser *parser,
3941 const struct gdb_xml_element *element,
3942 void *user_data,
3943 std::vector<gdb_xml_value> &attributes)
3944 {
3945 struct traceframe_info *info = (struct traceframe_info *) user_data;
3946 const char *id_attrib
3947 = (const char *) xml_find_attribute (attributes, "id")->value.get ();
3948 int id = gdb_xml_parse_ulongest (parser, id_attrib);
3949
3950 info->tvars.push_back (id);
3951 }
3952
3953 /* The allowed elements and attributes for an XML memory map. */
3954
3955 static const struct gdb_xml_attribute memory_attributes[] = {
3956 { "start", GDB_XML_AF_NONE, gdb_xml_parse_attr_ulongest, NULL },
3957 { "length", GDB_XML_AF_NONE, gdb_xml_parse_attr_ulongest, NULL },
3958 { NULL, GDB_XML_AF_NONE, NULL, NULL }
3959 };
3960
3961 static const struct gdb_xml_attribute tvar_attributes[] = {
3962 { "id", GDB_XML_AF_NONE, NULL, NULL },
3963 { NULL, GDB_XML_AF_NONE, NULL, NULL }
3964 };
3965
3966 static const struct gdb_xml_element traceframe_info_children[] = {
3967 { "memory", memory_attributes, NULL,
3968 GDB_XML_EF_REPEATABLE | GDB_XML_EF_OPTIONAL,
3969 traceframe_info_start_memory, NULL },
3970 { "tvar", tvar_attributes, NULL,
3971 GDB_XML_EF_REPEATABLE | GDB_XML_EF_OPTIONAL,
3972 traceframe_info_start_tvar, NULL },
3973 { NULL, NULL, NULL, GDB_XML_EF_NONE, NULL, NULL }
3974 };
3975
3976 static const struct gdb_xml_element traceframe_info_elements[] = {
3977 { "traceframe-info", NULL, traceframe_info_children, GDB_XML_EF_NONE,
3978 NULL, NULL },
3979 { NULL, NULL, NULL, GDB_XML_EF_NONE, NULL, NULL }
3980 };
3981
3982 /* Parse a traceframe-info XML document. */
3983
3984 traceframe_info_up
3985 parse_traceframe_info (const char *tframe_info)
3986 {
3987 traceframe_info_up result (new traceframe_info);
3988
3989 if (gdb_xml_parse_quick (_("trace frame info"),
3990 "traceframe-info.dtd", traceframe_info_elements,
3991 tframe_info, result.get ()) == 0)
3992 return result;
3993
3994 return NULL;
3995 }
3996
3997 #endif /* HAVE_LIBEXPAT */
3998
3999 /* Returns the traceframe_info object for the current traceframe.
4000 This is where we avoid re-fetching the object from the target if we
4001 already have it cached. */
4002
4003 struct traceframe_info *
4004 get_traceframe_info (void)
4005 {
4006 if (current_traceframe_info == NULL)
4007 current_traceframe_info = target_traceframe_info ();
4008
4009 return current_traceframe_info.get ();
4010 }
4011
4012 /* If the target supports the query, return in RESULT the set of
4013 collected memory in the current traceframe, found within the LEN
4014 bytes range starting at MEMADDR. Returns true if the target
4015 supports the query, otherwise returns false, and RESULT is left
4016 undefined. */
4017
4018 int
4019 traceframe_available_memory (std::vector<mem_range> *result,
4020 CORE_ADDR memaddr, ULONGEST len)
4021 {
4022 struct traceframe_info *info = get_traceframe_info ();
4023
4024 if (info != NULL)
4025 {
4026 result->clear ();
4027
4028 for (mem_range &r : info->memory)
4029 if (mem_ranges_overlap (r.start, r.length, memaddr, len))
4030 {
4031 ULONGEST lo1, hi1, lo2, hi2;
4032
4033 lo1 = memaddr;
4034 hi1 = memaddr + len;
4035
4036 lo2 = r.start;
4037 hi2 = r.start + r.length;
4038
4039 CORE_ADDR start = std::max (lo1, lo2);
4040 int length = std::min (hi1, hi2) - start;
4041
4042 result->emplace_back (start, length);
4043 }
4044
4045 normalize_mem_ranges (result);
4046 return 1;
4047 }
4048
4049 return 0;
4050 }
4051
4052 /* Implementation of `sdata' variable. */
4053
4054 static const struct internalvar_funcs sdata_funcs =
4055 {
4056 sdata_make_value,
4057 NULL,
4058 NULL
4059 };
4060
4061 /* module initialization */
4062 void
4063 _initialize_tracepoint (void)
4064 {
4065 struct cmd_list_element *c;
4066
4067 /* Explicitly create without lookup, since that tries to create a
4068 value with a void typed value, and when we get here, gdbarch
4069 isn't initialized yet. At this point, we're quite sure there
4070 isn't another convenience variable of the same name. */
4071 create_internalvar_type_lazy ("_sdata", &sdata_funcs, NULL);
4072
4073 traceframe_number = -1;
4074 tracepoint_number = -1;
4075
4076 add_info ("scope", info_scope_command,
4077 _("List the variables local to a scope"));
4078
4079 add_cmd ("tracepoints", class_trace,
4080 _("Tracing of program execution without stopping the program."),
4081 &cmdlist);
4082
4083 add_com ("tdump", class_trace, tdump_command,
4084 _("Print everything collected at the current tracepoint."));
4085
4086 c = add_com ("tvariable", class_trace, trace_variable_command,_("\
4087 Define a trace state variable.\n\
4088 Argument is a $-prefixed name, optionally followed\n\
4089 by '=' and an expression that sets the initial value\n\
4090 at the start of tracing."));
4091 set_cmd_completer (c, expression_completer);
4092
4093 add_cmd ("tvariable", class_trace, delete_trace_variable_command, _("\
4094 Delete one or more trace state variables.\n\
4095 Arguments are the names of the variables to delete.\n\
4096 If no arguments are supplied, delete all variables."), &deletelist);
4097 /* FIXME add a trace variable completer. */
4098
4099 add_info ("tvariables", info_tvariables_command, _("\
4100 Status of trace state variables and their values.\n\
4101 "));
4102
4103 add_info ("static-tracepoint-markers",
4104 info_static_tracepoint_markers_command, _("\
4105 List target static tracepoints markers.\n\
4106 "));
4107
4108 add_prefix_cmd ("tfind", class_trace, tfind_command, _("\
4109 Select a trace frame;\n\
4110 No argument means forward by one frame; '-' means backward by one frame."),
4111 &tfindlist, "tfind ", 1, &cmdlist);
4112
4113 add_cmd ("outside", class_trace, tfind_outside_command, _("\
4114 Select a trace frame whose PC is outside the given range (exclusive).\n\
4115 Usage: tfind outside addr1, addr2"),
4116 &tfindlist);
4117
4118 add_cmd ("range", class_trace, tfind_range_command, _("\
4119 Select a trace frame whose PC is in the given range (inclusive).\n\
4120 Usage: tfind range addr1,addr2"),
4121 &tfindlist);
4122
4123 add_cmd ("line", class_trace, tfind_line_command, _("\
4124 Select a trace frame by source line.\n\
4125 Argument can be a line number (with optional source file),\n\
4126 a function name, or '*' followed by an address.\n\
4127 Default argument is 'the next source line that was traced'."),
4128 &tfindlist);
4129
4130 add_cmd ("tracepoint", class_trace, tfind_tracepoint_command, _("\
4131 Select a trace frame by tracepoint number.\n\
4132 Default is the tracepoint for the current trace frame."),
4133 &tfindlist);
4134
4135 add_cmd ("pc", class_trace, tfind_pc_command, _("\
4136 Select a trace frame by PC.\n\
4137 Default is the current PC, or the PC of the current trace frame."),
4138 &tfindlist);
4139
4140 add_cmd ("end", class_trace, tfind_end_command, _("\
4141 De-select any trace frame and resume 'live' debugging."),
4142 &tfindlist);
4143
4144 add_alias_cmd ("none", "end", class_trace, 0, &tfindlist);
4145
4146 add_cmd ("start", class_trace, tfind_start_command,
4147 _("Select the first trace frame in the trace buffer."),
4148 &tfindlist);
4149
4150 add_com ("tstatus", class_trace, tstatus_command,
4151 _("Display the status of the current trace data collection."));
4152
4153 add_com ("tstop", class_trace, tstop_command, _("\
4154 Stop trace data collection.\n\
4155 Usage: tstop [ <notes> ... ]\n\
4156 Any arguments supplied are recorded with the trace as a stop reason and\n\
4157 reported by tstatus (if the target supports trace notes)."));
4158
4159 add_com ("tstart", class_trace, tstart_command, _("\
4160 Start trace data collection.\n\
4161 Usage: tstart [ <notes> ... ]\n\
4162 Any arguments supplied are recorded with the trace as a note and\n\
4163 reported by tstatus (if the target supports trace notes)."));
4164
4165 add_com ("end", class_trace, end_actions_pseudocommand, _("\
4166 Ends a list of commands or actions.\n\
4167 Several GDB commands allow you to enter a list of commands or actions.\n\
4168 Entering \"end\" on a line by itself is the normal way to terminate\n\
4169 such a list.\n\n\
4170 Note: the \"end\" command cannot be used at the gdb prompt."));
4171
4172 add_com ("while-stepping", class_trace, while_stepping_pseudocommand, _("\
4173 Specify single-stepping behavior at a tracepoint.\n\
4174 Argument is number of instructions to trace in single-step mode\n\
4175 following the tracepoint. This command is normally followed by\n\
4176 one or more \"collect\" commands, to specify what to collect\n\
4177 while single-stepping.\n\n\
4178 Note: this command can only be used in a tracepoint \"actions\" list."));
4179
4180 add_com_alias ("ws", "while-stepping", class_alias, 0);
4181 add_com_alias ("stepping", "while-stepping", class_alias, 0);
4182
4183 add_com ("collect", class_trace, collect_pseudocommand, _("\
4184 Specify one or more data items to be collected at a tracepoint.\n\
4185 Accepts a comma-separated list of (one or more) expressions. GDB will\n\
4186 collect all data (variables, registers) referenced by that expression.\n\
4187 Also accepts the following special arguments:\n\
4188 $regs -- all registers.\n\
4189 $args -- all function arguments.\n\
4190 $locals -- all variables local to the block/function scope.\n\
4191 $_sdata -- static tracepoint data (ignored for non-static tracepoints).\n\
4192 Note: this command can only be used in a tracepoint \"actions\" list."));
4193
4194 add_com ("teval", class_trace, teval_pseudocommand, _("\
4195 Specify one or more expressions to be evaluated at a tracepoint.\n\
4196 Accepts a comma-separated list of (one or more) expressions.\n\
4197 The result of each evaluation will be discarded.\n\
4198 Note: this command can only be used in a tracepoint \"actions\" list."));
4199
4200 add_com ("actions", class_trace, actions_command, _("\
4201 Specify the actions to be taken at a tracepoint.\n\
4202 Tracepoint actions may include collecting of specified data,\n\
4203 single-stepping, or enabling/disabling other tracepoints,\n\
4204 depending on target's capabilities."));
4205
4206 default_collect = xstrdup ("");
4207 add_setshow_string_cmd ("default-collect", class_trace,
4208 &default_collect, _("\
4209 Set the list of expressions to collect by default"), _("\
4210 Show the list of expressions to collect by default"), NULL,
4211 NULL, NULL,
4212 &setlist, &showlist);
4213
4214 add_setshow_boolean_cmd ("disconnected-tracing", no_class,
4215 &disconnected_tracing, _("\
4216 Set whether tracing continues after GDB disconnects."), _("\
4217 Show whether tracing continues after GDB disconnects."), _("\
4218 Use this to continue a tracing run even if GDB disconnects\n\
4219 or detaches from the target. You can reconnect later and look at\n\
4220 trace data collected in the meantime."),
4221 set_disconnected_tracing,
4222 NULL,
4223 &setlist,
4224 &showlist);
4225
4226 add_setshow_boolean_cmd ("circular-trace-buffer", no_class,
4227 &circular_trace_buffer, _("\
4228 Set target's use of circular trace buffer."), _("\
4229 Show target's use of circular trace buffer."), _("\
4230 Use this to make the trace buffer into a circular buffer,\n\
4231 which will discard traceframes (oldest first) instead of filling\n\
4232 up and stopping the trace run."),
4233 set_circular_trace_buffer,
4234 NULL,
4235 &setlist,
4236 &showlist);
4237
4238 add_setshow_zuinteger_unlimited_cmd ("trace-buffer-size", no_class,
4239 &trace_buffer_size, _("\
4240 Set requested size of trace buffer."), _("\
4241 Show requested size of trace buffer."), _("\
4242 Use this to choose a size for the trace buffer. Some targets\n\
4243 may have fixed or limited buffer sizes. Specifying \"unlimited\" or -1\n\
4244 disables any attempt to set the buffer size and lets the target choose."),
4245 set_trace_buffer_size, NULL,
4246 &setlist, &showlist);
4247
4248 add_setshow_string_cmd ("trace-user", class_trace,
4249 &trace_user, _("\
4250 Set the user name to use for current and future trace runs"), _("\
4251 Show the user name to use for current and future trace runs"), NULL,
4252 set_trace_user, NULL,
4253 &setlist, &showlist);
4254
4255 add_setshow_string_cmd ("trace-notes", class_trace,
4256 &trace_notes, _("\
4257 Set notes string to use for current and future trace runs"), _("\
4258 Show the notes string to use for current and future trace runs"), NULL,
4259 set_trace_notes, NULL,
4260 &setlist, &showlist);
4261
4262 add_setshow_string_cmd ("trace-stop-notes", class_trace,
4263 &trace_stop_notes, _("\
4264 Set notes string to use for future tstop commands"), _("\
4265 Show the notes string to use for future tstop commands"), NULL,
4266 set_trace_stop_notes, NULL,
4267 &setlist, &showlist);
4268 }