printcmd.c revision 1.8 1 1.1 christos /* Print values for GNU debugger GDB.
2 1.1 christos
3 1.8 christos Copyright (C) 1986-2019 Free Software Foundation, Inc.
4 1.1 christos
5 1.1 christos This file is part of GDB.
6 1.1 christos
7 1.1 christos This program is free software; you can redistribute it and/or modify
8 1.1 christos it under the terms of the GNU General Public License as published by
9 1.1 christos the Free Software Foundation; either version 3 of the License, or
10 1.1 christos (at your option) any later version.
11 1.1 christos
12 1.1 christos This program is distributed in the hope that it will be useful,
13 1.1 christos but WITHOUT ANY WARRANTY; without even the implied warranty of
14 1.1 christos MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 1.1 christos GNU General Public License for more details.
16 1.1 christos
17 1.1 christos You should have received a copy of the GNU General Public License
18 1.1 christos along with this program. If not, see <http://www.gnu.org/licenses/>. */
19 1.1 christos
20 1.1 christos #include "defs.h"
21 1.1 christos #include "frame.h"
22 1.1 christos #include "symtab.h"
23 1.1 christos #include "gdbtypes.h"
24 1.1 christos #include "value.h"
25 1.1 christos #include "language.h"
26 1.1 christos #include "expression.h"
27 1.1 christos #include "gdbcore.h"
28 1.1 christos #include "gdbcmd.h"
29 1.1 christos #include "target.h"
30 1.1 christos #include "breakpoint.h"
31 1.1 christos #include "demangle.h"
32 1.1 christos #include "gdb-demangle.h"
33 1.1 christos #include "valprint.h"
34 1.1 christos #include "annotate.h"
35 1.1 christos #include "symfile.h" /* for overlay functions */
36 1.1 christos #include "objfiles.h" /* ditto */
37 1.1 christos #include "completer.h" /* for completion functions */
38 1.1 christos #include "ui-out.h"
39 1.1 christos #include "block.h"
40 1.1 christos #include "disasm.h"
41 1.8 christos #include "target-float.h"
42 1.8 christos #include "observable.h"
43 1.1 christos #include "solist.h"
44 1.1 christos #include "parser-defs.h"
45 1.1 christos #include "charset.h"
46 1.1 christos #include "arch-utils.h"
47 1.1 christos #include "cli/cli-utils.h"
48 1.7 christos #include "cli/cli-script.h"
49 1.8 christos #include "cli/cli-style.h"
50 1.8 christos #include "common/format.h"
51 1.1 christos #include "source.h"
52 1.8 christos #include "common/byte-vector.h"
53 1.1 christos
54 1.1 christos /* Last specified output format. */
55 1.1 christos
56 1.1 christos static char last_format = 0;
57 1.1 christos
58 1.1 christos /* Last specified examination size. 'b', 'h', 'w' or `q'. */
59 1.1 christos
60 1.1 christos static char last_size = 'w';
61 1.1 christos
62 1.8 christos /* Last specified count for the 'x' command. */
63 1.8 christos
64 1.8 christos static int last_count;
65 1.8 christos
66 1.1 christos /* Default address to examine next, and associated architecture. */
67 1.1 christos
68 1.1 christos static struct gdbarch *next_gdbarch;
69 1.1 christos static CORE_ADDR next_address;
70 1.1 christos
71 1.1 christos /* Number of delay instructions following current disassembled insn. */
72 1.1 christos
73 1.1 christos static int branch_delay_insns;
74 1.1 christos
75 1.1 christos /* Last address examined. */
76 1.1 christos
77 1.1 christos static CORE_ADDR last_examine_address;
78 1.1 christos
79 1.1 christos /* Contents of last address examined.
80 1.1 christos This is not valid past the end of the `x' command! */
81 1.1 christos
82 1.8 christos static value_ref_ptr last_examine_value;
83 1.1 christos
84 1.1 christos /* Largest offset between a symbolic value and an address, that will be
85 1.1 christos printed as `0x1234 <symbol+offset>'. */
86 1.1 christos
87 1.1 christos static unsigned int max_symbolic_offset = UINT_MAX;
88 1.1 christos static void
89 1.1 christos show_max_symbolic_offset (struct ui_file *file, int from_tty,
90 1.1 christos struct cmd_list_element *c, const char *value)
91 1.1 christos {
92 1.1 christos fprintf_filtered (file,
93 1.1 christos _("The largest offset that will be "
94 1.1 christos "printed in <symbol+1234> form is %s.\n"),
95 1.1 christos value);
96 1.1 christos }
97 1.1 christos
98 1.1 christos /* Append the source filename and linenumber of the symbol when
99 1.1 christos printing a symbolic value as `<symbol at filename:linenum>' if set. */
100 1.1 christos static int print_symbol_filename = 0;
101 1.1 christos static void
102 1.1 christos show_print_symbol_filename (struct ui_file *file, int from_tty,
103 1.1 christos struct cmd_list_element *c, const char *value)
104 1.1 christos {
105 1.1 christos fprintf_filtered (file, _("Printing of source filename and "
106 1.1 christos "line number with <symbol> is %s.\n"),
107 1.1 christos value);
108 1.1 christos }
109 1.1 christos
110 1.1 christos /* Number of auto-display expression currently being displayed.
111 1.1 christos So that we can disable it if we get a signal within it.
112 1.1 christos -1 when not doing one. */
113 1.1 christos
114 1.1 christos static int current_display_number;
115 1.1 christos
116 1.1 christos struct display
117 1.1 christos {
118 1.1 christos /* Chain link to next auto-display item. */
119 1.1 christos struct display *next;
120 1.1 christos
121 1.1 christos /* The expression as the user typed it. */
122 1.1 christos char *exp_string;
123 1.1 christos
124 1.1 christos /* Expression to be evaluated and displayed. */
125 1.7 christos expression_up exp;
126 1.1 christos
127 1.1 christos /* Item number of this auto-display item. */
128 1.1 christos int number;
129 1.1 christos
130 1.1 christos /* Display format specified. */
131 1.1 christos struct format_data format;
132 1.1 christos
133 1.1 christos /* Program space associated with `block'. */
134 1.1 christos struct program_space *pspace;
135 1.1 christos
136 1.1 christos /* Innermost block required by this expression when evaluated. */
137 1.1 christos const struct block *block;
138 1.1 christos
139 1.1 christos /* Status of this display (enabled or disabled). */
140 1.1 christos int enabled_p;
141 1.1 christos };
142 1.1 christos
143 1.1 christos /* Chain of expressions whose values should be displayed
144 1.1 christos automatically each time the program stops. */
145 1.1 christos
146 1.1 christos static struct display *display_chain;
147 1.1 christos
148 1.1 christos static int display_number;
149 1.1 christos
150 1.1 christos /* Walk the following statement or block through all displays.
151 1.1 christos ALL_DISPLAYS_SAFE does so even if the statement deletes the current
152 1.1 christos display. */
153 1.1 christos
154 1.1 christos #define ALL_DISPLAYS(B) \
155 1.1 christos for (B = display_chain; B; B = B->next)
156 1.1 christos
157 1.1 christos #define ALL_DISPLAYS_SAFE(B,TMP) \
158 1.1 christos for (B = display_chain; \
159 1.1 christos B ? (TMP = B->next, 1): 0; \
160 1.1 christos B = TMP)
161 1.1 christos
162 1.1 christos /* Prototypes for local functions. */
163 1.1 christos
164 1.1 christos static void do_one_display (struct display *);
165 1.1 christos
166 1.1 christos
168 1.1 christos /* Decode a format specification. *STRING_PTR should point to it.
169 1.1 christos OFORMAT and OSIZE are used as defaults for the format and size
170 1.1 christos if none are given in the format specification.
171 1.1 christos If OSIZE is zero, then the size field of the returned value
172 1.1 christos should be set only if a size is explicitly specified by the
173 1.1 christos user.
174 1.1 christos The structure returned describes all the data
175 1.1 christos found in the specification. In addition, *STRING_PTR is advanced
176 1.1 christos past the specification and past all whitespace following it. */
177 1.1 christos
178 1.1 christos static struct format_data
179 1.1 christos decode_format (const char **string_ptr, int oformat, int osize)
180 1.1 christos {
181 1.1 christos struct format_data val;
182 1.1 christos const char *p = *string_ptr;
183 1.1 christos
184 1.1 christos val.format = '?';
185 1.1 christos val.size = '?';
186 1.1 christos val.count = 1;
187 1.1 christos val.raw = 0;
188 1.6 christos
189 1.6 christos if (*p == '-')
190 1.6 christos {
191 1.6 christos val.count = -1;
192 1.6 christos p++;
193 1.1 christos }
194 1.6 christos if (*p >= '0' && *p <= '9')
195 1.1 christos val.count *= atoi (p);
196 1.1 christos while (*p >= '0' && *p <= '9')
197 1.1 christos p++;
198 1.1 christos
199 1.1 christos /* Now process size or format letters that follow. */
200 1.1 christos
201 1.1 christos while (1)
202 1.1 christos {
203 1.1 christos if (*p == 'b' || *p == 'h' || *p == 'w' || *p == 'g')
204 1.1 christos val.size = *p++;
205 1.1 christos else if (*p == 'r')
206 1.1 christos {
207 1.1 christos val.raw = 1;
208 1.1 christos p++;
209 1.1 christos }
210 1.1 christos else if (*p >= 'a' && *p <= 'z')
211 1.1 christos val.format = *p++;
212 1.1 christos else
213 1.1 christos break;
214 1.1 christos }
215 1.8 christos
216 1.1 christos *string_ptr = skip_spaces (p);
217 1.1 christos
218 1.1 christos /* Set defaults for format and size if not specified. */
219 1.1 christos if (val.format == '?')
220 1.1 christos {
221 1.1 christos if (val.size == '?')
222 1.1 christos {
223 1.1 christos /* Neither has been specified. */
224 1.1 christos val.format = oformat;
225 1.1 christos val.size = osize;
226 1.1 christos }
227 1.1 christos else
228 1.1 christos /* If a size is specified, any format makes a reasonable
229 1.1 christos default except 'i'. */
230 1.1 christos val.format = oformat == 'i' ? 'x' : oformat;
231 1.1 christos }
232 1.1 christos else if (val.size == '?')
233 1.1 christos switch (val.format)
234 1.1 christos {
235 1.1 christos case 'a':
236 1.1 christos /* Pick the appropriate size for an address. This is deferred
237 1.1 christos until do_examine when we know the actual architecture to use.
238 1.1 christos A special size value of 'a' is used to indicate this case. */
239 1.1 christos val.size = osize ? 'a' : osize;
240 1.1 christos break;
241 1.1 christos case 'f':
242 1.1 christos /* Floating point has to be word or giantword. */
243 1.1 christos if (osize == 'w' || osize == 'g')
244 1.1 christos val.size = osize;
245 1.1 christos else
246 1.1 christos /* Default it to giantword if the last used size is not
247 1.1 christos appropriate. */
248 1.1 christos val.size = osize ? 'g' : osize;
249 1.1 christos break;
250 1.1 christos case 'c':
251 1.1 christos /* Characters default to one byte. */
252 1.1 christos val.size = osize ? 'b' : osize;
253 1.1 christos break;
254 1.1 christos case 's':
255 1.1 christos /* Display strings with byte size chars unless explicitly
256 1.1 christos specified. */
257 1.1 christos val.size = '\0';
258 1.1 christos break;
259 1.1 christos
260 1.1 christos default:
261 1.1 christos /* The default is the size most recently specified. */
262 1.1 christos val.size = osize;
263 1.1 christos }
264 1.1 christos
265 1.1 christos return val;
266 1.1 christos }
267 1.1 christos
268 1.1 christos /* Print value VAL on stream according to OPTIONS.
270 1.1 christos Do not end with a newline.
271 1.1 christos SIZE is the letter for the size of datum being printed.
272 1.1 christos This is used to pad hex numbers so they line up. SIZE is 0
273 1.1 christos for print / output and set for examine. */
274 1.1 christos
275 1.1 christos static void
276 1.1 christos print_formatted (struct value *val, int size,
277 1.1 christos const struct value_print_options *options,
278 1.1 christos struct ui_file *stream)
279 1.1 christos {
280 1.1 christos struct type *type = check_typedef (value_type (val));
281 1.1 christos int len = TYPE_LENGTH (type);
282 1.1 christos
283 1.1 christos if (VALUE_LVAL (val) == lval_memory)
284 1.1 christos next_address = value_address (val) + len;
285 1.1 christos
286 1.1 christos if (size)
287 1.1 christos {
288 1.1 christos switch (options->format)
289 1.1 christos {
290 1.1 christos case 's':
291 1.1 christos {
292 1.1 christos struct type *elttype = value_type (val);
293 1.1 christos
294 1.1 christos next_address = (value_address (val)
295 1.1 christos + val_print_string (elttype, NULL,
296 1.1 christos value_address (val), -1,
297 1.1 christos stream, options) * len);
298 1.1 christos }
299 1.1 christos return;
300 1.1 christos
301 1.1 christos case 'i':
302 1.1 christos /* We often wrap here if there are long symbolic names. */
303 1.1 christos wrap_here (" ");
304 1.1 christos next_address = (value_address (val)
305 1.1 christos + gdb_print_insn (get_type_arch (type),
306 1.1 christos value_address (val), stream,
307 1.1 christos &branch_delay_insns));
308 1.1 christos return;
309 1.1 christos }
310 1.1 christos }
311 1.1 christos
312 1.1 christos if (options->format == 0 || options->format == 's'
313 1.1 christos || TYPE_CODE (type) == TYPE_CODE_REF
314 1.1 christos || TYPE_CODE (type) == TYPE_CODE_ARRAY
315 1.1 christos || TYPE_CODE (type) == TYPE_CODE_STRING
316 1.1 christos || TYPE_CODE (type) == TYPE_CODE_STRUCT
317 1.1 christos || TYPE_CODE (type) == TYPE_CODE_UNION
318 1.1 christos || TYPE_CODE (type) == TYPE_CODE_NAMESPACE)
319 1.1 christos value_print (val, stream, options);
320 1.1 christos else
321 1.1 christos /* User specified format, so don't look to the type to tell us
322 1.1 christos what to do. */
323 1.1 christos val_print_scalar_formatted (type,
324 1.1 christos value_embedded_offset (val),
325 1.1 christos val,
326 1.1 christos options, size, stream);
327 1.1 christos }
328 1.1 christos
329 1.1 christos /* Return builtin floating point type of same length as TYPE.
330 1.1 christos If no such type is found, return TYPE itself. */
331 1.1 christos static struct type *
332 1.1 christos float_type_from_length (struct type *type)
333 1.1 christos {
334 1.1 christos struct gdbarch *gdbarch = get_type_arch (type);
335 1.1 christos const struct builtin_type *builtin = builtin_type (gdbarch);
336 1.1 christos
337 1.1 christos if (TYPE_LENGTH (type) == TYPE_LENGTH (builtin->builtin_float))
338 1.1 christos type = builtin->builtin_float;
339 1.1 christos else if (TYPE_LENGTH (type) == TYPE_LENGTH (builtin->builtin_double))
340 1.1 christos type = builtin->builtin_double;
341 1.1 christos else if (TYPE_LENGTH (type) == TYPE_LENGTH (builtin->builtin_long_double))
342 1.1 christos type = builtin->builtin_long_double;
343 1.1 christos
344 1.1 christos return type;
345 1.1 christos }
346 1.1 christos
347 1.1 christos /* Print a scalar of data of type TYPE, pointed to in GDB by VALADDR,
348 1.1 christos according to OPTIONS and SIZE on STREAM. Formats s and i are not
349 1.1 christos supported at this level. */
350 1.6 christos
351 1.1 christos void
352 1.1 christos print_scalar_formatted (const gdb_byte *valaddr, struct type *type,
353 1.1 christos const struct value_print_options *options,
354 1.1 christos int size, struct ui_file *stream)
355 1.1 christos {
356 1.1 christos struct gdbarch *gdbarch = get_type_arch (type);
357 1.1 christos unsigned int len = TYPE_LENGTH (type);
358 1.1 christos enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
359 1.1 christos
360 1.1 christos /* String printing should go through val_print_scalar_formatted. */
361 1.1 christos gdb_assert (options->format != 's');
362 1.1 christos
363 1.1 christos /* If the value is a pointer, and pointers and addresses are not the
364 1.1 christos same, then at this point, the value's length (in target bytes) is
365 1.1 christos gdbarch_addr_bit/TARGET_CHAR_BIT, not TYPE_LENGTH (type). */
366 1.1 christos if (TYPE_CODE (type) == TYPE_CODE_PTR)
367 1.1 christos len = gdbarch_addr_bit (gdbarch) / TARGET_CHAR_BIT;
368 1.1 christos
369 1.1 christos /* If we are printing it as unsigned, truncate it in case it is actually
370 1.8 christos a negative signed value (e.g. "print/u (short)-1" should print 65535
371 1.8 christos (if shorts are 16 bits) instead of 4294967295). */
372 1.1 christos if (options->format != 'c'
373 1.8 christos && (options->format != 'd' || TYPE_UNSIGNED (type)))
374 1.8 christos {
375 1.1 christos if (len < TYPE_LENGTH (type) && byte_order == BFD_ENDIAN_BIG)
376 1.1 christos valaddr += TYPE_LENGTH (type) - len;
377 1.8 christos }
378 1.1 christos
379 1.8 christos if (size != 0 && (options->format == 'x' || options->format == 't'))
380 1.8 christos {
381 1.8 christos /* Truncate to fit. */
382 1.1 christos unsigned newlen;
383 1.8 christos switch (size)
384 1.8 christos {
385 1.8 christos case 'b':
386 1.8 christos newlen = 1;
387 1.8 christos break;
388 1.8 christos case 'h':
389 1.8 christos newlen = 2;
390 1.8 christos break;
391 1.8 christos case 'w':
392 1.8 christos newlen = 4;
393 1.8 christos break;
394 1.8 christos case 'g':
395 1.8 christos newlen = 8;
396 1.8 christos break;
397 1.1 christos default:
398 1.8 christos error (_("Undefined output size \"%c\"."), size);
399 1.8 christos }
400 1.8 christos if (newlen < len && byte_order == BFD_ENDIAN_BIG)
401 1.8 christos valaddr += len - newlen;
402 1.8 christos len = newlen;
403 1.8 christos }
404 1.8 christos
405 1.8 christos /* Historically gdb has printed floats by first casting them to a
406 1.8 christos long, and then printing the long. PR cli/16242 suggests changing
407 1.8 christos this to using C-style hex float format. */
408 1.8 christos gdb::byte_vector converted_float_bytes;
409 1.8 christos if (TYPE_CODE (type) == TYPE_CODE_FLT
410 1.8 christos && (options->format == 'o'
411 1.8 christos || options->format == 'x'
412 1.8 christos || options->format == 't'
413 1.8 christos || options->format == 'z'
414 1.8 christos || options->format == 'd'
415 1.8 christos || options->format == 'u'))
416 1.8 christos {
417 1.8 christos LONGEST val_long = unpack_long (type, valaddr);
418 1.8 christos converted_float_bytes.resize (TYPE_LENGTH (type));
419 1.8 christos store_signed_integer (converted_float_bytes.data (), TYPE_LENGTH (type),
420 1.8 christos byte_order, val_long);
421 1.8 christos valaddr = converted_float_bytes.data ();
422 1.8 christos }
423 1.8 christos
424 1.8 christos /* Printing a non-float type as 'f' will interpret the data as if it were
425 1.8 christos of a floating-point type of the same length, if that exists. Otherwise,
426 1.8 christos the data is printed as integer. */
427 1.8 christos char format = options->format;
428 1.8 christos if (format == 'f' && TYPE_CODE (type) != TYPE_CODE_FLT)
429 1.8 christos {
430 1.8 christos type = float_type_from_length (type);
431 1.8 christos if (TYPE_CODE (type) != TYPE_CODE_FLT)
432 1.8 christos format = 0;
433 1.8 christos }
434 1.8 christos
435 1.8 christos switch (format)
436 1.8 christos {
437 1.1 christos case 'o':
438 1.1 christos print_octal_chars (stream, valaddr, len, byte_order);
439 1.8 christos break;
440 1.1 christos case 'd':
441 1.1 christos print_decimal_chars (stream, valaddr, len, true, byte_order);
442 1.8 christos break;
443 1.8 christos case 'u':
444 1.8 christos print_decimal_chars (stream, valaddr, len, false, byte_order);
445 1.8 christos break;
446 1.8 christos case 0:
447 1.8 christos if (TYPE_CODE (type) != TYPE_CODE_FLT)
448 1.8 christos {
449 1.8 christos print_decimal_chars (stream, valaddr, len, !TYPE_UNSIGNED (type),
450 1.8 christos byte_order);
451 1.8 christos break;
452 1.8 christos }
453 1.8 christos /* FALLTHROUGH */
454 1.1 christos case 'f':
455 1.1 christos print_floating (valaddr, type, stream);
456 1.8 christos break;
457 1.8 christos
458 1.8 christos case 't':
459 1.8 christos print_binary_chars (stream, valaddr, len, byte_order, size > 0);
460 1.8 christos break;
461 1.1 christos case 'x':
462 1.8 christos print_hex_chars (stream, valaddr, len, byte_order, size > 0);
463 1.8 christos break;
464 1.1 christos case 'z':
465 1.1 christos print_hex_chars (stream, valaddr, len, byte_order, true);
466 1.1 christos break;
467 1.1 christos case 'c':
468 1.1 christos {
469 1.8 christos struct value_print_options opts = *options;
470 1.8 christos
471 1.1 christos LONGEST val_long = unpack_long (type, valaddr);
472 1.1 christos
473 1.1 christos opts.format = 0;
474 1.1 christos if (TYPE_UNSIGNED (type))
475 1.1 christos type = builtin_type (gdbarch)->builtin_true_unsigned_char;
476 1.1 christos else
477 1.1 christos type = builtin_type (gdbarch)->builtin_true_char;
478 1.1 christos
479 1.1 christos value_print (value_from_longest (type, val_long), stream, &opts);
480 1.1 christos }
481 1.8 christos break;
482 1.1 christos
483 1.8 christos case 'a':
484 1.1 christos {
485 1.8 christos CORE_ADDR addr = unpack_pointer (type, valaddr);
486 1.1 christos
487 1.1 christos print_address (gdbarch, addr, stream);
488 1.1 christos }
489 1.1 christos break;
490 1.8 christos
491 1.1 christos default:
492 1.1 christos error (_("Undefined output format \"%c\"."), format);
493 1.1 christos }
494 1.1 christos }
495 1.1 christos
496 1.1 christos /* Specify default address for `x' command.
497 1.1 christos The `info lines' command uses this. */
498 1.1 christos
499 1.1 christos void
500 1.1 christos set_next_address (struct gdbarch *gdbarch, CORE_ADDR addr)
501 1.1 christos {
502 1.1 christos struct type *ptr_type = builtin_type (gdbarch)->builtin_data_ptr;
503 1.1 christos
504 1.1 christos next_gdbarch = gdbarch;
505 1.1 christos next_address = addr;
506 1.1 christos
507 1.1 christos /* Make address available to the user as $_. */
508 1.1 christos set_internalvar (lookup_internalvar ("_"),
509 1.1 christos value_from_pointer (ptr_type, addr));
510 1.1 christos }
511 1.1 christos
512 1.1 christos /* Optionally print address ADDR symbolically as <SYMBOL+OFFSET> on STREAM,
513 1.1 christos after LEADIN. Print nothing if no symbolic name is found nearby.
514 1.1 christos Optionally also print source file and line number, if available.
515 1.1 christos DO_DEMANGLE controls whether to print a symbol in its native "raw" form,
516 1.1 christos or to interpret it as a possible C++ name and convert it back to source
517 1.1 christos form. However note that DO_DEMANGLE can be overridden by the specific
518 1.1 christos settings of the demangle and asm_demangle variables. Returns
519 1.1 christos non-zero if anything was printed; zero otherwise. */
520 1.1 christos
521 1.1 christos int
522 1.7 christos print_address_symbolic (struct gdbarch *gdbarch, CORE_ADDR addr,
523 1.1 christos struct ui_file *stream,
524 1.8 christos int do_demangle, const char *leadin)
525 1.1 christos {
526 1.1 christos std::string name, filename;
527 1.1 christos int unmapped = 0;
528 1.1 christos int offset = 0;
529 1.1 christos int line = 0;
530 1.1 christos
531 1.8 christos if (build_address_symbolic (gdbarch, addr, do_demangle, &name, &offset,
532 1.1 christos &filename, &line, &unmapped))
533 1.1 christos return 0;
534 1.1 christos
535 1.1 christos fputs_filtered (leadin, stream);
536 1.1 christos if (unmapped)
537 1.1 christos fputs_filtered ("<*", stream);
538 1.8 christos else
539 1.1 christos fputs_filtered ("<", stream);
540 1.1 christos fputs_styled (name.c_str (), function_name_style.style (), stream);
541 1.1 christos if (offset != 0)
542 1.1 christos fprintf_filtered (stream, "+%u", (unsigned int) offset);
543 1.1 christos
544 1.8 christos /* Append source filename and line number if desired. Give specific
545 1.1 christos line # of this addr, if we have it; else line # of the nearest symbol. */
546 1.8 christos if (print_symbol_filename && !filename.empty ())
547 1.8 christos {
548 1.1 christos fputs_filtered (line == -1 ? " in " : " at ", stream);
549 1.8 christos fputs_styled (filename.c_str (), file_name_style.style (), stream);
550 1.1 christos if (line != -1)
551 1.1 christos fprintf_filtered (stream, ":%d", line);
552 1.1 christos }
553 1.1 christos if (unmapped)
554 1.1 christos fputs_filtered ("*>", stream);
555 1.1 christos else
556 1.1 christos fputs_filtered (">", stream);
557 1.1 christos
558 1.1 christos return 1;
559 1.8 christos }
560 1.8 christos
561 1.1 christos /* See valprint.h. */
562 1.1 christos
563 1.1 christos int
564 1.1 christos build_address_symbolic (struct gdbarch *gdbarch,
565 1.8 christos CORE_ADDR addr, /* IN */
566 1.1 christos int do_demangle, /* IN */
567 1.8 christos std::string *name, /* OUT */
568 1.1 christos int *offset, /* OUT */
569 1.1 christos std::string *filename, /* OUT */
570 1.1 christos int *line, /* OUT */
571 1.3 christos int *unmapped) /* OUT */
572 1.1 christos {
573 1.1 christos struct bound_minimal_symbol msymbol;
574 1.1 christos struct symbol *symbol;
575 1.1 christos CORE_ADDR name_location = 0;
576 1.1 christos struct obj_section *section = NULL;
577 1.1 christos const char *name_temp = "";
578 1.1 christos
579 1.1 christos /* Let's say it is mapped (not unmapped). */
580 1.1 christos *unmapped = 0;
581 1.1 christos
582 1.1 christos /* Determine if the address is in an overlay, and whether it is
583 1.1 christos mapped. */
584 1.1 christos if (overlay_debugging)
585 1.1 christos {
586 1.1 christos section = find_pc_overlay (addr);
587 1.1 christos if (pc_in_unmapped_range (addr, section))
588 1.1 christos {
589 1.1 christos *unmapped = 1;
590 1.1 christos addr = overlay_mapped_address (addr, section);
591 1.1 christos }
592 1.1 christos }
593 1.1 christos
594 1.1 christos /* First try to find the address in the symbol table, then
595 1.1 christos in the minsyms. Take the closest one. */
596 1.1 christos
597 1.1 christos /* This is defective in the sense that it only finds text symbols. So
598 1.1 christos really this is kind of pointless--we should make sure that the
599 1.1 christos minimal symbols have everything we need (by changing that we could
600 1.1 christos save some memory, but for many debug format--ELF/DWARF or
601 1.3 christos anything/stabs--it would be inconvenient to eliminate those minimal
602 1.1 christos symbols anyway). */
603 1.1 christos msymbol = lookup_minimal_symbol_by_pc_section (addr, section);
604 1.1 christos symbol = find_pc_sect_function (addr, section);
605 1.1 christos
606 1.1 christos if (symbol)
607 1.1 christos {
608 1.1 christos /* If this is a function (i.e. a code address), strip out any
609 1.1 christos non-address bits. For instance, display a pointer to the
610 1.1 christos first instruction of a Thumb function as <function>; the
611 1.1 christos second instruction will be <function+2>, even though the
612 1.1 christos pointer is <function+3>. This matches the ISA behavior. */
613 1.8 christos addr = gdbarch_addr_bits_remove (gdbarch, addr);
614 1.1 christos
615 1.1 christos name_location = BLOCK_ENTRY_PC (SYMBOL_BLOCK_VALUE (symbol));
616 1.1 christos if (do_demangle || asm_demangle)
617 1.1 christos name_temp = SYMBOL_PRINT_NAME (symbol);
618 1.1 christos else
619 1.1 christos name_temp = SYMBOL_LINKAGE_NAME (symbol);
620 1.3 christos }
621 1.3 christos
622 1.3 christos if (msymbol.minsym != NULL
623 1.3 christos && MSYMBOL_HAS_SIZE (msymbol.minsym)
624 1.3 christos && MSYMBOL_SIZE (msymbol.minsym) == 0
625 1.3 christos && MSYMBOL_TYPE (msymbol.minsym) != mst_text
626 1.3 christos && MSYMBOL_TYPE (msymbol.minsym) != mst_text_gnu_ifunc
627 1.1 christos && MSYMBOL_TYPE (msymbol.minsym) != mst_file_text)
628 1.3 christos msymbol.minsym = NULL;
629 1.1 christos
630 1.3 christos if (msymbol.minsym != NULL)
631 1.1 christos {
632 1.1 christos if (BMSYMBOL_VALUE_ADDRESS (msymbol) > name_location || symbol == NULL)
633 1.1 christos {
634 1.1 christos /* If this is a function (i.e. a code address), strip out any
635 1.1 christos non-address bits. For instance, display a pointer to the
636 1.1 christos first instruction of a Thumb function as <function>; the
637 1.3 christos second instruction will be <function+2>, even though the
638 1.3 christos pointer is <function+3>. This matches the ISA behavior. */
639 1.3 christos if (MSYMBOL_TYPE (msymbol.minsym) == mst_text
640 1.3 christos || MSYMBOL_TYPE (msymbol.minsym) == mst_text_gnu_ifunc
641 1.1 christos || MSYMBOL_TYPE (msymbol.minsym) == mst_file_text
642 1.1 christos || MSYMBOL_TYPE (msymbol.minsym) == mst_solib_trampoline)
643 1.1 christos addr = gdbarch_addr_bits_remove (gdbarch, addr);
644 1.1 christos
645 1.1 christos /* The msymbol is closer to the address than the symbol;
646 1.3 christos use the msymbol instead. */
647 1.1 christos symbol = 0;
648 1.3 christos name_location = BMSYMBOL_VALUE_ADDRESS (msymbol);
649 1.1 christos if (do_demangle || asm_demangle)
650 1.3 christos name_temp = MSYMBOL_PRINT_NAME (msymbol.minsym);
651 1.1 christos else
652 1.1 christos name_temp = MSYMBOL_LINKAGE_NAME (msymbol.minsym);
653 1.3 christos }
654 1.1 christos }
655 1.1 christos if (symbol == NULL && msymbol.minsym == NULL)
656 1.1 christos return 1;
657 1.1 christos
658 1.1 christos /* If the nearest symbol is too far away, don't print anything symbolic. */
659 1.1 christos
660 1.1 christos /* For when CORE_ADDR is larger than unsigned int, we do math in
661 1.1 christos CORE_ADDR. But when we detect unsigned wraparound in the
662 1.1 christos CORE_ADDR math, we ignore this test and print the offset,
663 1.1 christos because addr+max_symbolic_offset has wrapped through the end
664 1.1 christos of the address space back to the beginning, giving bogus comparison. */
665 1.1 christos if (addr > name_location + max_symbolic_offset
666 1.1 christos && name_location + max_symbolic_offset > name_location)
667 1.1 christos return 1;
668 1.1 christos
669 1.8 christos *offset = addr - name_location;
670 1.1 christos
671 1.1 christos *name = name_temp;
672 1.1 christos
673 1.1 christos if (print_symbol_filename)
674 1.1 christos {
675 1.1 christos struct symtab_and_line sal;
676 1.1 christos
677 1.1 christos sal = find_pc_sect_line (addr, section, 0);
678 1.1 christos
679 1.8 christos if (sal.symtab)
680 1.1 christos {
681 1.1 christos *filename = symtab_to_filename_for_display (sal.symtab);
682 1.1 christos *line = sal.line;
683 1.1 christos }
684 1.1 christos }
685 1.1 christos return 0;
686 1.1 christos }
687 1.1 christos
688 1.1 christos
689 1.1 christos /* Print address ADDR symbolically on STREAM.
690 1.1 christos First print it as a number. Then perhaps print
691 1.1 christos <SYMBOL + OFFSET> after the number. */
692 1.1 christos
693 1.1 christos void
694 1.1 christos print_address (struct gdbarch *gdbarch,
695 1.8 christos CORE_ADDR addr, struct ui_file *stream)
696 1.1 christos {
697 1.1 christos fputs_styled (paddress (gdbarch, addr), address_style.style (), stream);
698 1.1 christos print_address_symbolic (gdbarch, addr, stream, asm_demangle, " ");
699 1.1 christos }
700 1.1 christos
701 1.1 christos /* Return a prefix for instruction address:
702 1.1 christos "=> " for current instruction, else " ". */
703 1.1 christos
704 1.1 christos const char *
705 1.1 christos pc_prefix (CORE_ADDR addr)
706 1.1 christos {
707 1.1 christos if (has_stack_frames ())
708 1.1 christos {
709 1.1 christos struct frame_info *frame;
710 1.1 christos CORE_ADDR pc;
711 1.1 christos
712 1.1 christos frame = get_selected_frame (NULL);
713 1.1 christos if (get_frame_pc_if_available (frame, &pc) && pc == addr)
714 1.1 christos return "=> ";
715 1.1 christos }
716 1.1 christos return " ";
717 1.1 christos }
718 1.1 christos
719 1.1 christos /* Print address ADDR symbolically on STREAM. Parameter DEMANGLE
720 1.1 christos controls whether to print the symbolic name "raw" or demangled.
721 1.1 christos Return non-zero if anything was printed; zero otherwise. */
722 1.1 christos
723 1.1 christos int
724 1.1 christos print_address_demangle (const struct value_print_options *opts,
725 1.1 christos struct gdbarch *gdbarch, CORE_ADDR addr,
726 1.1 christos struct ui_file *stream, int do_demangle)
727 1.1 christos {
728 1.8 christos if (opts->addressprint)
729 1.1 christos {
730 1.1 christos fputs_styled (paddress (gdbarch, addr), address_style.style (), stream);
731 1.1 christos print_address_symbolic (gdbarch, addr, stream, do_demangle, " ");
732 1.1 christos }
733 1.1 christos else
734 1.1 christos {
735 1.1 christos return print_address_symbolic (gdbarch, addr, stream, do_demangle, "");
736 1.1 christos }
737 1.1 christos return 1;
738 1.1 christos }
739 1.6 christos
740 1.6 christos
742 1.6 christos /* Find the address of the instruction that is INST_COUNT instructions before
743 1.6 christos the instruction at ADDR.
744 1.6 christos Since some architectures have variable-length instructions, we can't just
745 1.6 christos simply subtract INST_COUNT * INSN_LEN from ADDR. Instead, we use line
746 1.6 christos number information to locate the nearest known instruction boundary,
747 1.6 christos and disassemble forward from there. If we go out of the symbol range
748 1.6 christos during disassembling, we return the lowest address we've got so far and
749 1.6 christos set the number of instructions read to INST_READ. */
750 1.6 christos
751 1.6 christos static CORE_ADDR
752 1.6 christos find_instruction_backward (struct gdbarch *gdbarch, CORE_ADDR addr,
753 1.6 christos int inst_count, int *inst_read)
754 1.6 christos {
755 1.7 christos /* The vector PCS is used to store instruction addresses within
756 1.6 christos a pc range. */
757 1.6 christos CORE_ADDR loop_start, loop_end, p;
758 1.6 christos std::vector<CORE_ADDR> pcs;
759 1.6 christos struct symtab_and_line sal;
760 1.6 christos
761 1.6 christos *inst_read = 0;
762 1.6 christos loop_start = loop_end = addr;
763 1.6 christos
764 1.6 christos /* In each iteration of the outer loop, we get a pc range that ends before
765 1.6 christos LOOP_START, then we count and store every instruction address of the range
766 1.6 christos iterated in the loop.
767 1.6 christos If the number of instructions counted reaches INST_COUNT, return the
768 1.6 christos stored address that is located INST_COUNT instructions back from ADDR.
769 1.6 christos If INST_COUNT is not reached, we subtract the number of counted
770 1.7 christos instructions from INST_COUNT, and go to the next iteration. */
771 1.6 christos do
772 1.6 christos {
773 1.6 christos pcs.clear ();
774 1.6 christos sal = find_pc_sect_line (loop_start, NULL, 1);
775 1.6 christos if (sal.line <= 0)
776 1.6 christos {
777 1.6 christos /* We reach here when line info is not available. In this case,
778 1.6 christos we print a message and just exit the loop. The return value
779 1.6 christos is calculated after the loop. */
780 1.6 christos printf_filtered (_("No line number information available "
781 1.6 christos "for address "));
782 1.6 christos wrap_here (" ");
783 1.6 christos print_address (gdbarch, loop_start - 1, gdb_stdout);
784 1.6 christos printf_filtered ("\n");
785 1.6 christos break;
786 1.6 christos }
787 1.6 christos
788 1.6 christos loop_end = loop_start;
789 1.6 christos loop_start = sal.pc;
790 1.6 christos
791 1.6 christos /* This loop pushes instruction addresses in the range from
792 1.7 christos LOOP_START to LOOP_END. */
793 1.6 christos for (p = loop_start; p < loop_end;)
794 1.6 christos {
795 1.6 christos pcs.push_back (p);
796 1.7 christos p += gdb_insn_length (gdbarch, p);
797 1.7 christos }
798 1.6 christos
799 1.6 christos inst_count -= pcs.size ();
800 1.6 christos *inst_read += pcs.size ();
801 1.6 christos }
802 1.6 christos while (inst_count > 0);
803 1.6 christos
804 1.6 christos /* After the loop, the vector PCS has instruction addresses of the last
805 1.6 christos source line we processed, and INST_COUNT has a negative value.
806 1.6 christos We return the address at the index of -INST_COUNT in the vector for
807 1.6 christos the reason below.
808 1.6 christos Let's assume the following instruction addresses and run 'x/-4i 0x400e'.
809 1.6 christos Line X of File
810 1.6 christos 0x4000
811 1.6 christos 0x4001
812 1.6 christos 0x4005
813 1.6 christos Line Y of File
814 1.6 christos 0x4009
815 1.6 christos 0x400c
816 1.6 christos => 0x400e
817 1.6 christos 0x4011
818 1.6 christos find_instruction_backward is called with INST_COUNT = 4 and expected to
819 1.6 christos return 0x4001. When we reach here, INST_COUNT is set to -1 because
820 1.6 christos it was subtracted by 2 (from Line Y) and 3 (from Line X). The value
821 1.6 christos 4001 is located at the index 1 of the last iterated line (= Line X),
822 1.6 christos which is simply calculated by -INST_COUNT.
823 1.7 christos The case when the length of PCS is 0 means that we reached an area for
824 1.6 christos which line info is not available. In such case, we return LOOP_START,
825 1.6 christos which was the lowest instruction address that had line info. */
826 1.6 christos p = pcs.size () > 0 ? pcs[-inst_count] : loop_start;
827 1.6 christos
828 1.6 christos /* INST_READ includes all instruction addresses in a pc range. Need to
829 1.6 christos exclude the beginning part up to the address we're returning. That
830 1.6 christos is, exclude {0x4000} in the example above. */
831 1.6 christos if (inst_count < 0)
832 1.6 christos *inst_read += inst_count;
833 1.6 christos
834 1.6 christos return p;
835 1.6 christos }
836 1.6 christos
837 1.6 christos /* Backward read LEN bytes of target memory from address MEMADDR + LEN,
838 1.6 christos placing the results in GDB's memory from MYADDR + LEN. Returns
839 1.6 christos a count of the bytes actually read. */
840 1.6 christos
841 1.6 christos static int
842 1.6 christos read_memory_backward (struct gdbarch *gdbarch,
843 1.6 christos CORE_ADDR memaddr, gdb_byte *myaddr, int len)
844 1.6 christos {
845 1.6 christos int errcode;
846 1.6 christos int nread; /* Number of bytes actually read. */
847 1.6 christos
848 1.6 christos /* First try a complete read. */
849 1.6 christos errcode = target_read_memory (memaddr, myaddr, len);
850 1.6 christos if (errcode == 0)
851 1.6 christos {
852 1.6 christos /* Got it all. */
853 1.6 christos nread = len;
854 1.6 christos }
855 1.6 christos else
856 1.6 christos {
857 1.6 christos /* Loop, reading one byte at a time until we get as much as we can. */
858 1.6 christos memaddr += len;
859 1.6 christos myaddr += len;
860 1.6 christos for (nread = 0; nread < len; ++nread)
861 1.6 christos {
862 1.6 christos errcode = target_read_memory (--memaddr, --myaddr, 1);
863 1.6 christos if (errcode != 0)
864 1.6 christos {
865 1.6 christos /* The read was unsuccessful, so exit the loop. */
866 1.6 christos printf_filtered (_("Cannot access memory at address %s\n"),
867 1.6 christos paddress (gdbarch, memaddr));
868 1.6 christos break;
869 1.6 christos }
870 1.6 christos }
871 1.6 christos }
872 1.6 christos return nread;
873 1.6 christos }
874 1.6 christos
875 1.6 christos /* Returns true if X (which is LEN bytes wide) is the number zero. */
876 1.6 christos
877 1.6 christos static int
878 1.6 christos integer_is_zero (const gdb_byte *x, int len)
879 1.6 christos {
880 1.6 christos int i = 0;
881 1.6 christos
882 1.6 christos while (i < len && x[i] == 0)
883 1.6 christos ++i;
884 1.6 christos return (i == len);
885 1.6 christos }
886 1.6 christos
887 1.6 christos /* Find the start address of a string in which ADDR is included.
888 1.6 christos Basically we search for '\0' and return the next address,
889 1.6 christos but if OPTIONS->PRINT_MAX is smaller than the length of a string,
890 1.6 christos we stop searching and return the address to print characters as many as
891 1.6 christos PRINT_MAX from the string. */
892 1.6 christos
893 1.6 christos static CORE_ADDR
894 1.6 christos find_string_backward (struct gdbarch *gdbarch,
895 1.6 christos CORE_ADDR addr, int count, int char_size,
896 1.6 christos const struct value_print_options *options,
897 1.6 christos int *strings_counted)
898 1.6 christos {
899 1.6 christos const int chunk_size = 0x20;
900 1.6 christos int read_error = 0;
901 1.6 christos int chars_read = 0;
902 1.6 christos int chars_to_read = chunk_size;
903 1.6 christos int chars_counted = 0;
904 1.6 christos int count_original = count;
905 1.8 christos CORE_ADDR string_start_addr = addr;
906 1.6 christos
907 1.6 christos gdb_assert (char_size == 1 || char_size == 2 || char_size == 4);
908 1.6 christos gdb::byte_vector buffer (chars_to_read * char_size);
909 1.6 christos while (count > 0 && read_error == 0)
910 1.6 christos {
911 1.8 christos int i;
912 1.6 christos
913 1.6 christos addr -= chars_to_read * char_size;
914 1.6 christos chars_read = read_memory_backward (gdbarch, addr, buffer.data (),
915 1.6 christos chars_to_read * char_size);
916 1.6 christos chars_read /= char_size;
917 1.6 christos read_error = (chars_read == chars_to_read) ? 0 : 1;
918 1.6 christos /* Searching for '\0' from the end of buffer in backward direction. */
919 1.6 christos for (i = 0; i < chars_read && count > 0 ; ++i, ++chars_counted)
920 1.8 christos {
921 1.6 christos int offset = (chars_to_read - i - 1) * char_size;
922 1.6 christos
923 1.6 christos if (integer_is_zero (&buffer[offset], char_size)
924 1.6 christos || chars_counted == options->print_max)
925 1.6 christos {
926 1.6 christos /* Found '\0' or reached print_max. As OFFSET is the offset to
927 1.6 christos '\0', we add CHAR_SIZE to return the start address of
928 1.6 christos a string. */
929 1.6 christos --count;
930 1.6 christos string_start_addr = addr + offset + char_size;
931 1.6 christos chars_counted = 0;
932 1.6 christos }
933 1.6 christos }
934 1.6 christos }
935 1.6 christos
936 1.6 christos /* Update STRINGS_COUNTED with the actual number of loaded strings. */
937 1.6 christos *strings_counted = count_original - count;
938 1.6 christos
939 1.6 christos if (read_error != 0)
940 1.6 christos {
941 1.6 christos /* In error case, STRING_START_ADDR is pointing to the string that
942 1.6 christos was last successfully loaded. Rewind the partially loaded string. */
943 1.6 christos string_start_addr -= chars_counted * char_size;
944 1.6 christos }
945 1.6 christos
946 1.1 christos return string_start_addr;
947 1.1 christos }
948 1.1 christos
949 1.1 christos /* Examine data at address ADDR in format FMT.
950 1.1 christos Fetch it from memory and print on gdb_stdout. */
951 1.1 christos
952 1.1 christos static void
953 1.1 christos do_examine (struct format_data fmt, struct gdbarch *gdbarch, CORE_ADDR addr)
954 1.1 christos {
955 1.1 christos char format = 0;
956 1.1 christos char size;
957 1.1 christos int count = 1;
958 1.1 christos struct type *val_type = NULL;
959 1.6 christos int i;
960 1.6 christos int maxelts;
961 1.1 christos struct value_print_options opts;
962 1.1 christos int need_to_update_next_address = 0;
963 1.1 christos CORE_ADDR addr_rewound = 0;
964 1.1 christos
965 1.1 christos format = fmt.format;
966 1.1 christos size = fmt.size;
967 1.1 christos count = fmt.count;
968 1.1 christos next_gdbarch = gdbarch;
969 1.1 christos next_address = addr;
970 1.1 christos
971 1.1 christos /* Instruction format implies fetch single bytes
972 1.1 christos regardless of the specified size.
973 1.1 christos The case of strings is handled in decode_format, only explicit
974 1.1 christos size operator are not changed to 'b'. */
975 1.1 christos if (format == 'i')
976 1.1 christos size = 'b';
977 1.1 christos
978 1.1 christos if (size == 'a')
979 1.1 christos {
980 1.1 christos /* Pick the appropriate size for an address. */
981 1.1 christos if (gdbarch_ptr_bit (next_gdbarch) == 64)
982 1.1 christos size = 'g';
983 1.1 christos else if (gdbarch_ptr_bit (next_gdbarch) == 32)
984 1.1 christos size = 'w';
985 1.1 christos else if (gdbarch_ptr_bit (next_gdbarch) == 16)
986 1.1 christos size = 'h';
987 1.1 christos else
988 1.1 christos /* Bad value for gdbarch_ptr_bit. */
989 1.1 christos internal_error (__FILE__, __LINE__,
990 1.1 christos _("failed internal consistency check"));
991 1.1 christos }
992 1.1 christos
993 1.1 christos if (size == 'b')
994 1.1 christos val_type = builtin_type (next_gdbarch)->builtin_int8;
995 1.1 christos else if (size == 'h')
996 1.1 christos val_type = builtin_type (next_gdbarch)->builtin_int16;
997 1.1 christos else if (size == 'w')
998 1.1 christos val_type = builtin_type (next_gdbarch)->builtin_int32;
999 1.1 christos else if (size == 'g')
1000 1.1 christos val_type = builtin_type (next_gdbarch)->builtin_int64;
1001 1.1 christos
1002 1.1 christos if (format == 's')
1003 1.1 christos {
1004 1.1 christos struct type *char_type = NULL;
1005 1.1 christos
1006 1.1 christos /* Search for "char16_t" or "char32_t" types or fall back to 8-bit char
1007 1.1 christos if type is not found. */
1008 1.1 christos if (size == 'h')
1009 1.1 christos char_type = builtin_type (next_gdbarch)->builtin_char16;
1010 1.1 christos else if (size == 'w')
1011 1.1 christos char_type = builtin_type (next_gdbarch)->builtin_char32;
1012 1.1 christos if (char_type)
1013 1.1 christos val_type = char_type;
1014 1.1 christos else
1015 1.1 christos {
1016 1.1 christos if (size != '\0' && size != 'b')
1017 1.1 christos warning (_("Unable to display strings with "
1018 1.1 christos "size '%c', using 'b' instead."), size);
1019 1.1 christos size = 'b';
1020 1.1 christos val_type = builtin_type (next_gdbarch)->builtin_int8;
1021 1.1 christos }
1022 1.1 christos }
1023 1.1 christos
1024 1.1 christos maxelts = 8;
1025 1.1 christos if (size == 'w')
1026 1.1 christos maxelts = 4;
1027 1.1 christos if (size == 'g')
1028 1.1 christos maxelts = 2;
1029 1.1 christos if (format == 's' || format == 'i')
1030 1.1 christos maxelts = 1;
1031 1.6 christos
1032 1.6 christos get_formatted_print_options (&opts, format);
1033 1.6 christos
1034 1.6 christos if (count < 0)
1035 1.6 christos {
1036 1.6 christos /* This is the negative repeat count case.
1037 1.6 christos We rewind the address based on the given repeat count and format,
1038 1.6 christos then examine memory from there in forward direction. */
1039 1.6 christos
1040 1.6 christos count = -count;
1041 1.6 christos if (format == 'i')
1042 1.6 christos {
1043 1.6 christos next_address = find_instruction_backward (gdbarch, addr, count,
1044 1.6 christos &count);
1045 1.6 christos }
1046 1.6 christos else if (format == 's')
1047 1.6 christos {
1048 1.6 christos next_address = find_string_backward (gdbarch, addr, count,
1049 1.6 christos TYPE_LENGTH (val_type),
1050 1.6 christos &opts, &count);
1051 1.6 christos }
1052 1.6 christos else
1053 1.6 christos {
1054 1.6 christos next_address = addr - count * TYPE_LENGTH (val_type);
1055 1.6 christos }
1056 1.6 christos
1057 1.6 christos /* The following call to print_formatted updates next_address in every
1058 1.6 christos iteration. In backward case, we store the start address here
1059 1.6 christos and update next_address with it before exiting the function. */
1060 1.6 christos addr_rewound = (format == 's'
1061 1.6 christos ? next_address - TYPE_LENGTH (val_type)
1062 1.6 christos : next_address);
1063 1.1 christos need_to_update_next_address = 1;
1064 1.1 christos }
1065 1.1 christos
1066 1.1 christos /* Print as many objects as specified in COUNT, at most maxelts per line,
1067 1.1 christos with the address of the next one at the start of each line. */
1068 1.1 christos
1069 1.1 christos while (count > 0)
1070 1.1 christos {
1071 1.1 christos QUIT;
1072 1.1 christos if (format == 'i')
1073 1.1 christos fputs_filtered (pc_prefix (next_address), gdb_stdout);
1074 1.1 christos print_address (next_gdbarch, next_address, gdb_stdout);
1075 1.1 christos printf_filtered (":");
1076 1.1 christos for (i = maxelts;
1077 1.1 christos i > 0 && count > 0;
1078 1.1 christos i--, count--)
1079 1.1 christos {
1080 1.1 christos printf_filtered ("\t");
1081 1.1 christos /* Note that print_formatted sets next_address for the next
1082 1.1 christos object. */
1083 1.1 christos last_examine_address = next_address;
1084 1.1 christos
1085 1.1 christos /* The value to be displayed is not fetched greedily.
1086 1.1 christos Instead, to avoid the possibility of a fetched value not
1087 1.1 christos being used, its retrieval is delayed until the print code
1088 1.1 christos uses it. When examining an instruction stream, the
1089 1.1 christos disassembler will perform its own memory fetch using just
1090 1.1 christos the address stored in LAST_EXAMINE_VALUE. FIXME: Should
1091 1.8 christos the disassembler be modified so that LAST_EXAMINE_VALUE
1092 1.8 christos is left with the byte sequence from the last complete
1093 1.1 christos instruction fetched from memory? */
1094 1.8 christos last_examine_value
1095 1.1 christos = release_value (value_at_lazy (val_type, next_address));
1096 1.1 christos
1097 1.1 christos print_formatted (last_examine_value.get (), size, &opts, gdb_stdout);
1098 1.1 christos
1099 1.1 christos /* Display any branch delay slots following the final insn. */
1100 1.1 christos if (format == 'i' && count == 1)
1101 1.1 christos count += branch_delay_insns;
1102 1.1 christos }
1103 1.6 christos printf_filtered ("\n");
1104 1.6 christos gdb_flush (gdb_stdout);
1105 1.6 christos }
1106 1.1 christos
1107 1.1 christos if (need_to_update_next_address)
1108 1.1 christos next_address = addr_rewound;
1109 1.5 christos }
1110 1.1 christos
1111 1.1 christos static void
1113 1.1 christos validate_format (struct format_data fmt, const char *cmdname)
1114 1.1 christos {
1115 1.1 christos if (fmt.size != 0)
1116 1.1 christos error (_("Size letters are meaningless in \"%s\" command."), cmdname);
1117 1.1 christos if (fmt.count != 1)
1118 1.1 christos error (_("Item count other than 1 is meaningless in \"%s\" command."),
1119 1.1 christos cmdname);
1120 1.1 christos if (fmt.format == 'i')
1121 1.5 christos error (_("Format letter \"%c\" is meaningless in \"%s\" command."),
1122 1.5 christos fmt.format, cmdname);
1123 1.5 christos }
1124 1.5 christos
1125 1.5 christos /* Parse print command format string into *FMTP and update *EXPP.
1126 1.5 christos CMDNAME should name the current command. */
1127 1.5 christos
1128 1.5 christos void
1129 1.5 christos print_command_parse_format (const char **expp, const char *cmdname,
1130 1.5 christos struct format_data *fmtp)
1131 1.5 christos {
1132 1.5 christos const char *exp = *expp;
1133 1.5 christos
1134 1.5 christos if (exp && *exp == '/')
1135 1.5 christos {
1136 1.5 christos exp++;
1137 1.5 christos *fmtp = decode_format (&exp, last_format, 0);
1138 1.5 christos validate_format (*fmtp, cmdname);
1139 1.5 christos last_format = fmtp->format;
1140 1.5 christos }
1141 1.5 christos else
1142 1.5 christos {
1143 1.5 christos fmtp->count = 1;
1144 1.5 christos fmtp->format = 0;
1145 1.5 christos fmtp->size = 0;
1146 1.5 christos fmtp->raw = 0;
1147 1.5 christos }
1148 1.5 christos
1149 1.5 christos *expp = exp;
1150 1.5 christos }
1151 1.5 christos
1152 1.5 christos /* Print VAL to console according to *FMTP, including recording it to
1153 1.5 christos the history. */
1154 1.5 christos
1155 1.5 christos void
1156 1.5 christos print_value (struct value *val, const struct format_data *fmtp)
1157 1.5 christos {
1158 1.5 christos struct value_print_options opts;
1159 1.5 christos int histindex = record_latest_value (val);
1160 1.5 christos
1161 1.5 christos annotate_value_history_begin (histindex, value_type (val));
1162 1.5 christos
1163 1.5 christos printf_filtered ("$%d = ", histindex);
1164 1.5 christos
1165 1.5 christos annotate_value_history_value ();
1166 1.5 christos
1167 1.5 christos get_formatted_print_options (&opts, fmtp->format);
1168 1.5 christos opts.raw = fmtp->raw;
1169 1.5 christos
1170 1.5 christos print_formatted (val, fmtp->size, &opts, gdb_stdout);
1171 1.5 christos printf_filtered ("\n");
1172 1.1 christos
1173 1.1 christos annotate_value_history_end ();
1174 1.1 christos }
1175 1.1 christos
1176 1.1 christos /* Evaluate string EXP as an expression in the current language and
1177 1.1 christos print the resulting value. EXP may contain a format specifier as the
1178 1.1 christos first argument ("/x myvar" for example, to print myvar in hex). */
1179 1.1 christos
1180 1.1 christos static void
1181 1.1 christos print_command_1 (const char *exp, int voidprint)
1182 1.5 christos {
1183 1.1 christos struct value *val;
1184 1.1 christos struct format_data fmt;
1185 1.1 christos
1186 1.7 christos print_command_parse_format (&exp, "print", &fmt);
1187 1.7 christos
1188 1.1 christos if (exp && *exp)
1189 1.1 christos {
1190 1.1 christos expression_up expr = parse_expression (exp);
1191 1.1 christos val = evaluate_expression (expr.get ());
1192 1.1 christos }
1193 1.1 christos else
1194 1.5 christos val = access_value_history (0);
1195 1.1 christos
1196 1.1 christos if (voidprint || (val && value_type (val) &&
1197 1.1 christos TYPE_CODE (value_type (val)) != TYPE_CODE_VOID))
1198 1.8 christos print_value (val, &fmt);
1199 1.1 christos }
1200 1.1 christos
1201 1.1 christos static void
1202 1.1 christos print_command (const char *exp, int from_tty)
1203 1.1 christos {
1204 1.1 christos print_command_1 (exp, 1);
1205 1.8 christos }
1206 1.1 christos
1207 1.1 christos /* Same as print, except it doesn't print void results. */
1208 1.1 christos static void
1209 1.1 christos call_command (const char *exp, int from_tty)
1210 1.1 christos {
1211 1.1 christos print_command_1 (exp, 0);
1212 1.1 christos }
1213 1.8 christos
1214 1.1 christos /* Implementation of the "output" command. */
1215 1.1 christos
1216 1.1 christos void
1217 1.1 christos output_command (const char *exp, int from_tty)
1218 1.1 christos {
1219 1.1 christos char format = 0;
1220 1.1 christos struct value *val;
1221 1.1 christos struct format_data fmt;
1222 1.1 christos struct value_print_options opts;
1223 1.1 christos
1224 1.1 christos fmt.size = 0;
1225 1.1 christos fmt.raw = 0;
1226 1.1 christos
1227 1.1 christos if (exp && *exp == '/')
1228 1.1 christos {
1229 1.1 christos exp++;
1230 1.1 christos fmt = decode_format (&exp, 0, 0);
1231 1.7 christos validate_format (fmt, "output");
1232 1.1 christos format = fmt.format;
1233 1.7 christos }
1234 1.1 christos
1235 1.1 christos expression_up expr = parse_expression (exp);
1236 1.1 christos
1237 1.1 christos val = evaluate_expression (expr.get ());
1238 1.1 christos
1239 1.1 christos annotate_value_begin (value_type (val));
1240 1.1 christos
1241 1.1 christos get_formatted_print_options (&opts, format);
1242 1.1 christos opts.raw = fmt.raw;
1243 1.1 christos print_formatted (val, fmt.size, &opts, gdb_stdout);
1244 1.1 christos
1245 1.1 christos annotate_value_end ();
1246 1.1 christos
1247 1.1 christos wrap_here ("");
1248 1.8 christos gdb_flush (gdb_stdout);
1249 1.1 christos }
1250 1.7 christos
1251 1.1 christos static void
1252 1.1 christos set_command (const char *exp, int from_tty)
1253 1.1 christos {
1254 1.1 christos expression_up expr = parse_expression (exp);
1255 1.1 christos
1256 1.1 christos if (expr->nelts >= 1)
1257 1.1 christos switch (expr->elts[0].opcode)
1258 1.1 christos {
1259 1.1 christos case UNOP_PREINCREMENT:
1260 1.1 christos case UNOP_POSTINCREMENT:
1261 1.1 christos case UNOP_PREDECREMENT:
1262 1.1 christos case UNOP_POSTDECREMENT:
1263 1.1 christos case BINOP_ASSIGN:
1264 1.1 christos case BINOP_ASSIGN_MODIFY:
1265 1.1 christos case BINOP_COMMA:
1266 1.1 christos break;
1267 1.1 christos default:
1268 1.7 christos warning
1269 1.1 christos (_("Expression is not an assignment (and might have no effect)"));
1270 1.1 christos }
1271 1.1 christos
1272 1.8 christos evaluate_expression (expr.get ());
1273 1.1 christos }
1274 1.1 christos
1275 1.1 christos static void
1276 1.1 christos info_symbol_command (const char *arg, int from_tty)
1277 1.1 christos {
1278 1.1 christos struct minimal_symbol *msymbol;
1279 1.1 christos struct obj_section *osect;
1280 1.1 christos CORE_ADDR addr, sect_addr;
1281 1.1 christos int matches = 0;
1282 1.1 christos unsigned int offset;
1283 1.1 christos
1284 1.8 christos if (!arg)
1285 1.8 christos error_no_arg (_("address"));
1286 1.1 christos
1287 1.8 christos addr = parse_and_eval_address (arg);
1288 1.8 christos for (objfile *objfile : current_program_space->objfiles ())
1289 1.8 christos ALL_OBJFILE_OSECTIONS (objfile, osect)
1290 1.8 christos {
1291 1.8 christos /* Only process each object file once, even if there's a separate
1292 1.8 christos debug file. */
1293 1.8 christos if (objfile->separate_debug_objfile_backlink)
1294 1.8 christos continue;
1295 1.8 christos
1296 1.8 christos sect_addr = overlay_mapped_address (addr, osect);
1297 1.8 christos
1298 1.8 christos if (obj_section_addr (osect) <= sect_addr
1299 1.8 christos && sect_addr < obj_section_endaddr (osect)
1300 1.8 christos && (msymbol
1301 1.8 christos = lookup_minimal_symbol_by_pc_section (sect_addr,
1302 1.1 christos osect).minsym))
1303 1.8 christos {
1304 1.8 christos const char *obj_name, *mapped, *sec_name, *msym_name;
1305 1.8 christos const char *loc_string;
1306 1.8 christos
1307 1.8 christos matches = 1;
1308 1.8 christos offset = sect_addr - MSYMBOL_VALUE_ADDRESS (objfile, msymbol);
1309 1.8 christos mapped = section_is_mapped (osect) ? _("mapped") : _("unmapped");
1310 1.8 christos sec_name = osect->the_bfd_section->name;
1311 1.8 christos msym_name = MSYMBOL_PRINT_NAME (msymbol);
1312 1.8 christos
1313 1.8 christos /* Don't print the offset if it is zero.
1314 1.8 christos We assume there's no need to handle i18n of "sym + offset". */
1315 1.8 christos std::string string_holder;
1316 1.8 christos if (offset)
1317 1.1 christos {
1318 1.8 christos string_holder = string_printf ("%s + %u", msym_name, offset);
1319 1.8 christos loc_string = string_holder.c_str ();
1320 1.8 christos }
1321 1.8 christos else
1322 1.8 christos loc_string = msym_name;
1323 1.8 christos
1324 1.8 christos gdb_assert (osect->objfile && objfile_name (osect->objfile));
1325 1.8 christos obj_name = objfile_name (osect->objfile);
1326 1.8 christos
1327 1.8 christos if (MULTI_OBJFILE_P ())
1328 1.8 christos if (pc_in_unmapped_range (addr, osect))
1329 1.8 christos if (section_is_overlay (osect))
1330 1.8 christos printf_filtered (_("%s in load address range of "
1331 1.8 christos "%s overlay section %s of %s\n"),
1332 1.8 christos loc_string, mapped, sec_name, obj_name);
1333 1.8 christos else
1334 1.8 christos printf_filtered (_("%s in load address range of "
1335 1.8 christos "section %s of %s\n"),
1336 1.8 christos loc_string, sec_name, obj_name);
1337 1.8 christos else
1338 1.8 christos if (section_is_overlay (osect))
1339 1.8 christos printf_filtered (_("%s in %s overlay section %s of %s\n"),
1340 1.1 christos loc_string, mapped, sec_name, obj_name);
1341 1.8 christos else
1342 1.8 christos printf_filtered (_("%s in section %s of %s\n"),
1343 1.8 christos loc_string, sec_name, obj_name);
1344 1.8 christos else
1345 1.8 christos if (pc_in_unmapped_range (addr, osect))
1346 1.8 christos if (section_is_overlay (osect))
1347 1.8 christos printf_filtered (_("%s in load address range of %s overlay "
1348 1.8 christos "section %s\n"),
1349 1.8 christos loc_string, mapped, sec_name);
1350 1.8 christos else
1351 1.8 christos printf_filtered
1352 1.8 christos (_("%s in load address range of section %s\n"),
1353 1.8 christos loc_string, sec_name);
1354 1.8 christos else
1355 1.8 christos if (section_is_overlay (osect))
1356 1.8 christos printf_filtered (_("%s in %s overlay section %s\n"),
1357 1.8 christos loc_string, mapped, sec_name);
1358 1.1 christos else
1359 1.1 christos printf_filtered (_("%s in section %s\n"),
1360 1.1 christos loc_string, sec_name);
1361 1.1 christos }
1362 1.1 christos }
1363 1.1 christos if (matches == 0)
1364 1.8 christos printf_filtered (_("No symbol matches %s.\n"), arg);
1365 1.1 christos }
1366 1.1 christos
1367 1.1 christos static void
1368 1.1 christos info_address_command (const char *exp, int from_tty)
1369 1.1 christos {
1370 1.1 christos struct gdbarch *gdbarch;
1371 1.1 christos int regno;
1372 1.1 christos struct symbol *sym;
1373 1.1 christos struct bound_minimal_symbol msymbol;
1374 1.1 christos long val;
1375 1.1 christos struct obj_section *section;
1376 1.1 christos CORE_ADDR load_addr, context_pc = 0;
1377 1.1 christos struct field_of_this_result is_a_field_of_this;
1378 1.1 christos
1379 1.6 christos if (exp == 0)
1380 1.1 christos error (_("Argument required."));
1381 1.1 christos
1382 1.1 christos sym = lookup_symbol (exp, get_selected_block (&context_pc), VAR_DOMAIN,
1383 1.1 christos &is_a_field_of_this).symbol;
1384 1.1 christos if (sym == NULL)
1385 1.1 christos {
1386 1.1 christos if (is_a_field_of_this.type != NULL)
1387 1.1 christos {
1388 1.1 christos printf_filtered ("Symbol \"");
1389 1.1 christos fprintf_symbol_filtered (gdb_stdout, exp,
1390 1.1 christos current_language->la_language, DMGL_ANSI);
1391 1.1 christos printf_filtered ("\" is a field of the local class variable ");
1392 1.1 christos if (current_language->la_language == language_objc)
1393 1.1 christos printf_filtered ("`self'\n"); /* ObjC equivalent of "this" */
1394 1.1 christos else
1395 1.1 christos printf_filtered ("`this'\n");
1396 1.1 christos return;
1397 1.1 christos }
1398 1.1 christos
1399 1.1 christos msymbol = lookup_bound_minimal_symbol (exp);
1400 1.1 christos
1401 1.1 christos if (msymbol.minsym != NULL)
1402 1.3 christos {
1403 1.1 christos struct objfile *objfile = msymbol.objfile;
1404 1.1 christos
1405 1.1 christos gdbarch = get_objfile_arch (objfile);
1406 1.1 christos load_addr = BMSYMBOL_VALUE_ADDRESS (msymbol);
1407 1.1 christos
1408 1.8 christos printf_filtered ("Symbol \"");
1409 1.8 christos fprintf_symbol_filtered (gdb_stdout, exp,
1410 1.1 christos current_language->la_language, DMGL_ANSI);
1411 1.3 christos printf_filtered ("\" is at ");
1412 1.1 christos fputs_styled (paddress (gdbarch, load_addr), address_style.style (),
1413 1.1 christos gdb_stdout);
1414 1.1 christos printf_filtered (" in a file compiled without debugging");
1415 1.1 christos section = MSYMBOL_OBJ_SECTION (objfile, msymbol.minsym);
1416 1.8 christos if (section_is_overlay (section))
1417 1.8 christos {
1418 1.8 christos load_addr = overlay_unmapped_address (load_addr, section);
1419 1.1 christos printf_filtered (",\n -- loaded at ");
1420 1.1 christos fputs_styled (paddress (gdbarch, load_addr),
1421 1.1 christos address_style.style (),
1422 1.1 christos gdb_stdout);
1423 1.1 christos printf_filtered (" in overlay section %s",
1424 1.1 christos section->the_bfd_section->name);
1425 1.1 christos }
1426 1.1 christos printf_filtered (".\n");
1427 1.1 christos }
1428 1.1 christos else
1429 1.1 christos error (_("No symbol \"%s\" in current context."), exp);
1430 1.1 christos return;
1431 1.1 christos }
1432 1.1 christos
1433 1.1 christos printf_filtered ("Symbol \"");
1434 1.3 christos fprintf_symbol_filtered (gdb_stdout, SYMBOL_PRINT_NAME (sym),
1435 1.3 christos current_language->la_language, DMGL_ANSI);
1436 1.3 christos printf_filtered ("\" is ");
1437 1.3 christos val = SYMBOL_VALUE (sym);
1438 1.3 christos if (SYMBOL_OBJFILE_OWNED (sym))
1439 1.1 christos section = SYMBOL_OBJ_SECTION (symbol_objfile (sym), sym);
1440 1.1 christos else
1441 1.1 christos section = NULL;
1442 1.1 christos gdbarch = symbol_arch (sym);
1443 1.1 christos
1444 1.1 christos if (SYMBOL_COMPUTED_OPS (sym) != NULL)
1445 1.1 christos {
1446 1.1 christos SYMBOL_COMPUTED_OPS (sym)->describe_location (sym, context_pc,
1447 1.1 christos gdb_stdout);
1448 1.1 christos printf_filtered (".\n");
1449 1.1 christos return;
1450 1.1 christos }
1451 1.1 christos
1452 1.1 christos switch (SYMBOL_CLASS (sym))
1453 1.1 christos {
1454 1.1 christos case LOC_CONST:
1455 1.1 christos case LOC_CONST_BYTES:
1456 1.1 christos printf_filtered ("constant");
1457 1.1 christos break;
1458 1.8 christos
1459 1.8 christos case LOC_LABEL:
1460 1.1 christos printf_filtered ("a label at address ");
1461 1.1 christos load_addr = SYMBOL_VALUE_ADDRESS (sym);
1462 1.1 christos fputs_styled (paddress (gdbarch, load_addr), address_style.style (),
1463 1.1 christos gdb_stdout);
1464 1.8 christos if (section_is_overlay (section))
1465 1.8 christos {
1466 1.1 christos load_addr = overlay_unmapped_address (load_addr, section);
1467 1.1 christos printf_filtered (",\n -- loaded at ");
1468 1.1 christos fputs_styled (paddress (gdbarch, load_addr), address_style.style (),
1469 1.1 christos gdb_stdout);
1470 1.1 christos printf_filtered (" in overlay section %s",
1471 1.1 christos section->the_bfd_section->name);
1472 1.1 christos }
1473 1.1 christos break;
1474 1.1 christos
1475 1.1 christos case LOC_COMPUTED:
1476 1.1 christos gdb_assert_not_reached (_("LOC_COMPUTED variable missing a method"));
1477 1.1 christos
1478 1.1 christos case LOC_REGISTER:
1479 1.1 christos /* GDBARCH is the architecture associated with the objfile the symbol
1480 1.1 christos is defined in; the target architecture may be different, and may
1481 1.1 christos provide additional registers. However, we do not know the target
1482 1.1 christos architecture at this point. We assume the objfile architecture
1483 1.1 christos will contain all the standard registers that occur in debug info
1484 1.1 christos in that objfile. */
1485 1.1 christos regno = SYMBOL_REGISTER_OPS (sym)->register_number (sym, gdbarch);
1486 1.1 christos
1487 1.1 christos if (SYMBOL_IS_ARGUMENT (sym))
1488 1.1 christos printf_filtered (_("an argument in register %s"),
1489 1.1 christos gdbarch_register_name (gdbarch, regno));
1490 1.1 christos else
1491 1.1 christos printf_filtered (_("a variable in register %s"),
1492 1.1 christos gdbarch_register_name (gdbarch, regno));
1493 1.1 christos break;
1494 1.8 christos
1495 1.8 christos case LOC_STATIC:
1496 1.1 christos printf_filtered (_("static storage at address "));
1497 1.1 christos load_addr = SYMBOL_VALUE_ADDRESS (sym);
1498 1.1 christos fputs_styled (paddress (gdbarch, load_addr), address_style.style (),
1499 1.1 christos gdb_stdout);
1500 1.8 christos if (section_is_overlay (section))
1501 1.8 christos {
1502 1.1 christos load_addr = overlay_unmapped_address (load_addr, section);
1503 1.1 christos printf_filtered (_(",\n -- loaded at "));
1504 1.1 christos fputs_styled (paddress (gdbarch, load_addr), address_style.style (),
1505 1.1 christos gdb_stdout);
1506 1.1 christos printf_filtered (_(" in overlay section %s"),
1507 1.1 christos section->the_bfd_section->name);
1508 1.1 christos }
1509 1.1 christos break;
1510 1.1 christos
1511 1.1 christos case LOC_REGPARM_ADDR:
1512 1.1 christos /* Note comment at LOC_REGISTER. */
1513 1.1 christos regno = SYMBOL_REGISTER_OPS (sym)->register_number (sym, gdbarch);
1514 1.1 christos printf_filtered (_("address of an argument in register %s"),
1515 1.1 christos gdbarch_register_name (gdbarch, regno));
1516 1.1 christos break;
1517 1.1 christos
1518 1.1 christos case LOC_ARG:
1519 1.1 christos printf_filtered (_("an argument at offset %ld"), val);
1520 1.1 christos break;
1521 1.1 christos
1522 1.1 christos case LOC_LOCAL:
1523 1.1 christos printf_filtered (_("a local variable at frame offset %ld"), val);
1524 1.1 christos break;
1525 1.1 christos
1526 1.1 christos case LOC_REF_ARG:
1527 1.1 christos printf_filtered (_("a reference argument at offset %ld"), val);
1528 1.1 christos break;
1529 1.1 christos
1530 1.1 christos case LOC_TYPEDEF:
1531 1.1 christos printf_filtered (_("a typedef"));
1532 1.8 christos break;
1533 1.8 christos
1534 1.8 christos case LOC_BLOCK:
1535 1.1 christos printf_filtered (_("a function at address "));
1536 1.1 christos load_addr = BLOCK_ENTRY_PC (SYMBOL_BLOCK_VALUE (sym));
1537 1.1 christos fputs_styled (paddress (gdbarch, load_addr), address_style.style (),
1538 1.1 christos gdb_stdout);
1539 1.8 christos if (section_is_overlay (section))
1540 1.8 christos {
1541 1.1 christos load_addr = overlay_unmapped_address (load_addr, section);
1542 1.1 christos printf_filtered (_(",\n -- loaded at "));
1543 1.1 christos fputs_styled (paddress (gdbarch, load_addr), address_style.style (),
1544 1.1 christos gdb_stdout);
1545 1.1 christos printf_filtered (_(" in overlay section %s"),
1546 1.1 christos section->the_bfd_section->name);
1547 1.1 christos }
1548 1.1 christos break;
1549 1.1 christos
1550 1.8 christos case LOC_UNRESOLVED:
1551 1.1 christos {
1552 1.1 christos struct bound_minimal_symbol msym;
1553 1.1 christos
1554 1.1 christos msym = lookup_bound_minimal_symbol (SYMBOL_LINKAGE_NAME (sym));
1555 1.3 christos if (msym.minsym == NULL)
1556 1.1 christos printf_filtered ("unresolved");
1557 1.1 christos else
1558 1.1 christos {
1559 1.6 christos section = MSYMBOL_OBJ_SECTION (msym.objfile, msym.minsym);
1560 1.6 christos
1561 1.6 christos if (section
1562 1.6 christos && (section->the_bfd_section->flags & SEC_THREAD_LOCAL) != 0)
1563 1.6 christos {
1564 1.6 christos load_addr = MSYMBOL_VALUE_RAW_ADDRESS (msym.minsym);
1565 1.6 christos printf_filtered (_("a thread-local variable at offset %s "
1566 1.1 christos "in the thread-local storage for `%s'"),
1567 1.1 christos paddress (gdbarch, load_addr),
1568 1.6 christos objfile_name (section->objfile));
1569 1.1 christos }
1570 1.8 christos else
1571 1.8 christos {
1572 1.1 christos load_addr = BMSYMBOL_VALUE_ADDRESS (msym);
1573 1.1 christos printf_filtered (_("static storage at address "));
1574 1.1 christos fputs_styled (paddress (gdbarch, load_addr),
1575 1.1 christos address_style.style (), gdb_stdout);
1576 1.8 christos if (section_is_overlay (section))
1577 1.8 christos {
1578 1.8 christos load_addr = overlay_unmapped_address (load_addr, section);
1579 1.1 christos printf_filtered (_(",\n -- loaded at "));
1580 1.1 christos fputs_styled (paddress (gdbarch, load_addr),
1581 1.1 christos address_style.style (),
1582 1.1 christos gdb_stdout);
1583 1.1 christos printf_filtered (_(" in overlay section %s"),
1584 1.1 christos section->the_bfd_section->name);
1585 1.1 christos }
1586 1.1 christos }
1587 1.1 christos }
1588 1.1 christos }
1589 1.1 christos break;
1590 1.1 christos
1591 1.1 christos case LOC_OPTIMIZED_OUT:
1592 1.1 christos printf_filtered (_("optimized out"));
1593 1.1 christos break;
1594 1.1 christos
1595 1.1 christos default:
1596 1.1 christos printf_filtered (_("of unknown (botched) type"));
1597 1.1 christos break;
1598 1.1 christos }
1599 1.1 christos printf_filtered (".\n");
1600 1.8 christos }
1601 1.1 christos
1602 1.1 christos
1604 1.1 christos static void
1605 1.1 christos x_command (const char *exp, int from_tty)
1606 1.1 christos {
1607 1.1 christos struct format_data fmt;
1608 1.1 christos struct value *val;
1609 1.1 christos
1610 1.8 christos fmt.format = last_format ? last_format : 'x';
1611 1.8 christos fmt.size = last_size;
1612 1.8 christos fmt.count = 1;
1613 1.8 christos fmt.raw = 0;
1614 1.8 christos
1615 1.1 christos /* If there is no expression and no format, use the most recent
1616 1.1 christos count. */
1617 1.1 christos if (exp == nullptr && last_count > 0)
1618 1.1 christos fmt.count = last_count;
1619 1.1 christos
1620 1.1 christos if (exp && *exp == '/')
1621 1.1 christos {
1622 1.1 christos const char *tmp = exp + 1;
1623 1.8 christos
1624 1.8 christos fmt = decode_format (&tmp, last_format, last_size);
1625 1.1 christos exp = (char *) tmp;
1626 1.1 christos }
1627 1.1 christos
1628 1.1 christos last_count = fmt.count;
1629 1.7 christos
1630 1.1 christos /* If we have an expression, evaluate it and use it as the address. */
1631 1.1 christos
1632 1.1 christos if (exp != 0 && *exp != 0)
1633 1.1 christos {
1634 1.8 christos expression_up expr = parse_expression (exp);
1635 1.7 christos /* Cause expression not to be there any more if this command is
1636 1.7 christos repeated with Newline. But don't clobber a user-defined
1637 1.1 christos command's definition. */
1638 1.1 christos if (from_tty)
1639 1.1 christos set_repeat_arguments ("");
1640 1.1 christos val = evaluate_expression (expr.get ());
1641 1.1 christos if (TYPE_IS_REFERENCE (value_type (val)))
1642 1.1 christos val = coerce_ref (val);
1643 1.1 christos /* In rvalue contexts, such as this, functions are coerced into
1644 1.1 christos pointers to functions. This makes "x/i main" work. */
1645 1.1 christos if (/* last_format == 'i' && */
1646 1.1 christos TYPE_CODE (value_type (val)) == TYPE_CODE_FUNC
1647 1.1 christos && VALUE_LVAL (val) == lval_memory)
1648 1.1 christos next_address = value_address (val);
1649 1.1 christos else
1650 1.1 christos next_address = value_as_address (val);
1651 1.1 christos
1652 1.1 christos next_gdbarch = expr->gdbarch;
1653 1.1 christos }
1654 1.1 christos
1655 1.1 christos if (!next_gdbarch)
1656 1.1 christos error_no_arg (_("starting display address"));
1657 1.1 christos
1658 1.1 christos do_examine (fmt, next_gdbarch, next_address);
1659 1.1 christos
1660 1.1 christos /* If the examine succeeds, we remember its size and format for next
1661 1.1 christos time. Set last_size to 'b' for strings. */
1662 1.1 christos if (fmt.format == 's')
1663 1.1 christos last_size = 'b';
1664 1.8 christos else
1665 1.1 christos last_size = fmt.size;
1666 1.1 christos last_format = fmt.format;
1667 1.1 christos
1668 1.1 christos /* Set a couple of internal variables if appropriate. */
1669 1.8 christos if (last_examine_value != nullptr)
1670 1.1 christos {
1671 1.1 christos /* Make last address examined available to the user as $_. Use
1672 1.1 christos the correct pointer type. */
1673 1.1 christos struct type *pointer_type
1674 1.1 christos = lookup_pointer_type (value_type (last_examine_value.get ()));
1675 1.1 christos set_internalvar (lookup_internalvar ("_"),
1676 1.1 christos value_from_pointer (pointer_type,
1677 1.1 christos last_examine_address));
1678 1.8 christos
1679 1.1 christos /* Make contents of last address examined available to the user
1680 1.1 christos as $__. If the last value has not been fetched from memory
1681 1.8 christos then don't fetch it now; instead mark it by voiding the $__
1682 1.1 christos variable. */
1683 1.1 christos if (value_lazy (last_examine_value.get ()))
1684 1.1 christos clear_internalvar (lookup_internalvar ("__"));
1685 1.1 christos else
1686 1.1 christos set_internalvar (lookup_internalvar ("__"), last_examine_value.get ());
1687 1.1 christos }
1688 1.1 christos }
1689 1.1 christos
1690 1.8 christos
1692 1.1 christos /* Add an expression to the auto-display chain.
1693 1.5 christos Specify the expression. */
1694 1.1 christos
1695 1.1 christos static void
1696 1.5 christos display_command (const char *arg, int from_tty)
1697 1.5 christos {
1698 1.5 christos struct format_data fmt;
1699 1.5 christos struct display *newobj;
1700 1.5 christos const char *exp = arg;
1701 1.1 christos
1702 1.5 christos if (exp == 0)
1703 1.1 christos {
1704 1.5 christos do_displays ();
1705 1.5 christos return;
1706 1.5 christos }
1707 1.5 christos
1708 1.5 christos if (*exp == '/')
1709 1.5 christos {
1710 1.5 christos exp++;
1711 1.5 christos fmt = decode_format (&exp, 0, 0);
1712 1.5 christos if (fmt.size && fmt.format == 0)
1713 1.5 christos fmt.format = 'x';
1714 1.5 christos if (fmt.format == 'i' || fmt.format == 's')
1715 1.5 christos fmt.size = 'b';
1716 1.5 christos }
1717 1.5 christos else
1718 1.1 christos {
1719 1.8 christos fmt.format = 0;
1720 1.7 christos fmt.size = 0;
1721 1.1 christos fmt.count = 0;
1722 1.7 christos fmt.raw = 0;
1723 1.1 christos }
1724 1.5 christos
1725 1.7 christos innermost_block.reset ();
1726 1.8 christos expression_up expr = parse_expression (exp);
1727 1.5 christos
1728 1.5 christos newobj = new display ();
1729 1.5 christos
1730 1.5 christos newobj->exp_string = xstrdup (exp);
1731 1.6 christos newobj->exp = std::move (expr);
1732 1.6 christos newobj->block = innermost_block.block ();
1733 1.6 christos newobj->pspace = current_program_space;
1734 1.6 christos newobj->number = ++display_number;
1735 1.6 christos newobj->format = fmt;
1736 1.6 christos newobj->enabled_p = 1;
1737 1.6 christos newobj->next = NULL;
1738 1.6 christos
1739 1.6 christos if (display_chain == NULL)
1740 1.6 christos display_chain = newobj;
1741 1.6 christos else
1742 1.6 christos {
1743 1.1 christos struct display *last;
1744 1.5 christos
1745 1.5 christos for (last = display_chain; last->next != NULL; last = last->next)
1746 1.1 christos ;
1747 1.5 christos last->next = newobj;
1748 1.1 christos }
1749 1.1 christos
1750 1.1 christos if (from_tty)
1751 1.1 christos do_one_display (newobj);
1752 1.1 christos
1753 1.1 christos dont_repeat ();
1754 1.7 christos }
1755 1.1 christos
1756 1.1 christos static void
1757 1.1 christos free_display (struct display *d)
1758 1.1 christos {
1759 1.1 christos xfree (d->exp_string);
1760 1.1 christos delete d;
1761 1.1 christos }
1762 1.1 christos
1763 1.1 christos /* Clear out the display_chain. Done when new symtabs are loaded,
1764 1.1 christos since this invalidates the types stored in many expressions. */
1765 1.1 christos
1766 1.1 christos void
1767 1.1 christos clear_displays (void)
1768 1.1 christos {
1769 1.1 christos struct display *d;
1770 1.1 christos
1771 1.1 christos while ((d = display_chain) != NULL)
1772 1.1 christos {
1773 1.1 christos display_chain = d->next;
1774 1.1 christos free_display (d);
1775 1.1 christos }
1776 1.1 christos }
1777 1.1 christos
1778 1.1 christos /* Delete the auto-display DISPLAY. */
1779 1.1 christos
1780 1.1 christos static void
1781 1.1 christos delete_display (struct display *display)
1782 1.1 christos {
1783 1.1 christos struct display *d;
1784 1.1 christos
1785 1.1 christos gdb_assert (display != NULL);
1786 1.1 christos
1787 1.1 christos if (display_chain == display)
1788 1.1 christos display_chain = display->next;
1789 1.1 christos
1790 1.1 christos ALL_DISPLAYS (d)
1791 1.1 christos if (d->next == display)
1792 1.1 christos {
1793 1.1 christos d->next = display->next;
1794 1.1 christos break;
1795 1.1 christos }
1796 1.1 christos
1797 1.1 christos free_display (display);
1798 1.8 christos }
1799 1.1 christos
1800 1.1 christos /* Call FUNCTION on each of the displays whose numbers are given in
1801 1.1 christos ARGS. DATA is passed unmodified to FUNCTION. */
1802 1.1 christos
1803 1.1 christos static void
1804 1.1 christos map_display_numbers (const char *args,
1805 1.1 christos void (*function) (struct display *,
1806 1.1 christos void *),
1807 1.1 christos void *data)
1808 1.7 christos {
1809 1.1 christos int num;
1810 1.7 christos
1811 1.1 christos if (args == NULL)
1812 1.7 christos error_no_arg (_("one or more display numbers"));
1813 1.1 christos
1814 1.7 christos number_or_range_parser parser (args);
1815 1.1 christos
1816 1.1 christos while (!parser.finished ())
1817 1.1 christos {
1818 1.1 christos const char *p = parser.cur_tok ();
1819 1.1 christos
1820 1.1 christos num = parser.get_number ();
1821 1.1 christos if (num == 0)
1822 1.1 christos warning (_("bad display number at or near '%s'"), p);
1823 1.1 christos else
1824 1.1 christos {
1825 1.1 christos struct display *d, *tmp;
1826 1.1 christos
1827 1.1 christos ALL_DISPLAYS_SAFE (d, tmp)
1828 1.1 christos if (d->number == num)
1829 1.1 christos break;
1830 1.1 christos if (d == NULL)
1831 1.1 christos printf_unfiltered (_("No display number %d.\n"), num);
1832 1.1 christos else
1833 1.1 christos function (d, data);
1834 1.1 christos }
1835 1.1 christos }
1836 1.1 christos }
1837 1.1 christos
1838 1.1 christos /* Callback for map_display_numbers, that deletes a display. */
1839 1.1 christos
1840 1.1 christos static void
1841 1.1 christos do_delete_display (struct display *d, void *data)
1842 1.1 christos {
1843 1.8 christos delete_display (d);
1844 1.1 christos }
1845 1.1 christos
1846 1.1 christos /* "undisplay" command. */
1847 1.1 christos
1848 1.1 christos static void
1849 1.1 christos undisplay_command (const char *args, int from_tty)
1850 1.1 christos {
1851 1.1 christos if (args == NULL)
1852 1.1 christos {
1853 1.1 christos if (query (_("Delete all auto-display expressions? ")))
1854 1.1 christos clear_displays ();
1855 1.1 christos dont_repeat ();
1856 1.1 christos return;
1857 1.1 christos }
1858 1.1 christos
1859 1.1 christos map_display_numbers (args, do_delete_display, NULL);
1860 1.1 christos dont_repeat ();
1861 1.1 christos }
1862 1.1 christos
1863 1.1 christos /* Display a single auto-display.
1864 1.1 christos Do nothing if the display cannot be printed in the current context,
1865 1.1 christos or if the display is disabled. */
1866 1.1 christos
1867 1.1 christos static void
1868 1.1 christos do_one_display (struct display *d)
1869 1.1 christos {
1870 1.1 christos int within_current_scope;
1871 1.1 christos
1872 1.1 christos if (d->enabled_p == 0)
1873 1.1 christos return;
1874 1.1 christos
1875 1.1 christos /* The expression carries the architecture that was used at parse time.
1876 1.1 christos This is a problem if the expression depends on architecture features
1877 1.1 christos (e.g. register numbers), and the current architecture is now different.
1878 1.7 christos For example, a display statement like "display/i $pc" is expected to
1879 1.1 christos display the PC register of the current architecture, not the arch at
1880 1.1 christos the time the display command was given. Therefore, we re-parse the
1881 1.1 christos expression if the current architecture has changed. */
1882 1.1 christos if (d->exp != NULL && d->exp->gdbarch != get_current_arch ())
1883 1.1 christos {
1884 1.1 christos d->exp.reset ();
1885 1.5 christos d->block = NULL;
1886 1.1 christos }
1887 1.8 christos
1888 1.1 christos if (d->exp == NULL)
1889 1.8 christos {
1890 1.1 christos
1891 1.5 christos TRY
1892 1.1 christos {
1893 1.1 christos innermost_block.reset ();
1894 1.1 christos d->exp = parse_expression (d->exp_string);
1895 1.1 christos d->block = innermost_block.block ();
1896 1.1 christos }
1897 1.1 christos CATCH (ex, RETURN_MASK_ALL)
1898 1.1 christos {
1899 1.5 christos /* Can't re-parse the expression. Disable this display item. */
1900 1.1 christos d->enabled_p = 0;
1901 1.1 christos warning (_("Unable to display \"%s\": %s"),
1902 1.1 christos d->exp_string, ex.message);
1903 1.1 christos return;
1904 1.1 christos }
1905 1.1 christos END_CATCH
1906 1.1 christos }
1907 1.1 christos
1908 1.1 christos if (d->block)
1909 1.1 christos {
1910 1.1 christos if (d->pspace == current_program_space)
1911 1.1 christos within_current_scope = contained_in (get_selected_block (0), d->block);
1912 1.1 christos else
1913 1.1 christos within_current_scope = 0;
1914 1.7 christos }
1915 1.7 christos else
1916 1.1 christos within_current_scope = 1;
1917 1.1 christos if (!within_current_scope)
1918 1.1 christos return;
1919 1.1 christos
1920 1.1 christos scoped_restore save_display_number
1921 1.1 christos = make_scoped_restore (¤t_display_number, d->number);
1922 1.1 christos
1923 1.1 christos annotate_display_begin ();
1924 1.1 christos printf_filtered ("%d", d->number);
1925 1.1 christos annotate_display_number_end ();
1926 1.1 christos printf_filtered (": ");
1927 1.1 christos if (d->format.size)
1928 1.1 christos {
1929 1.1 christos
1930 1.1 christos annotate_display_format ();
1931 1.1 christos
1932 1.1 christos printf_filtered ("x/");
1933 1.1 christos if (d->format.count != 1)
1934 1.1 christos printf_filtered ("%d", d->format.count);
1935 1.1 christos printf_filtered ("%c", d->format.format);
1936 1.1 christos if (d->format.format != 'i' && d->format.format != 's')
1937 1.1 christos printf_filtered ("%c", d->format.size);
1938 1.1 christos printf_filtered (" ");
1939 1.1 christos
1940 1.1 christos annotate_display_expression ();
1941 1.1 christos
1942 1.1 christos puts_filtered (d->exp_string);
1943 1.1 christos annotate_display_expression_end ();
1944 1.1 christos
1945 1.1 christos if (d->format.count != 1 || d->format.format == 'i')
1946 1.5 christos printf_filtered ("\n");
1947 1.1 christos else
1948 1.1 christos printf_filtered (" ");
1949 1.1 christos
1950 1.1 christos annotate_display_value ();
1951 1.7 christos
1952 1.1 christos TRY
1953 1.1 christos {
1954 1.1 christos struct value *val;
1955 1.1 christos CORE_ADDR addr;
1956 1.1 christos
1957 1.5 christos val = evaluate_expression (d->exp.get ());
1958 1.5 christos addr = value_as_address (val);
1959 1.5 christos if (d->format.format == 'i')
1960 1.5 christos addr = gdbarch_addr_bits_remove (d->exp->gdbarch, addr);
1961 1.5 christos do_examine (d->format, d->exp->gdbarch, addr);
1962 1.1 christos }
1963 1.1 christos CATCH (ex, RETURN_MASK_ERROR)
1964 1.1 christos {
1965 1.1 christos fprintf_filtered (gdb_stdout, _("<error: %s>\n"), ex.message);
1966 1.1 christos }
1967 1.1 christos END_CATCH
1968 1.1 christos }
1969 1.1 christos else
1970 1.1 christos {
1971 1.1 christos struct value_print_options opts;
1972 1.1 christos
1973 1.1 christos annotate_display_format ();
1974 1.1 christos
1975 1.1 christos if (d->format.format)
1976 1.1 christos printf_filtered ("/%c ", d->format.format);
1977 1.1 christos
1978 1.1 christos annotate_display_expression ();
1979 1.1 christos
1980 1.1 christos puts_filtered (d->exp_string);
1981 1.1 christos annotate_display_expression_end ();
1982 1.1 christos
1983 1.1 christos printf_filtered (" = ");
1984 1.5 christos
1985 1.1 christos annotate_display_expression ();
1986 1.1 christos
1987 1.1 christos get_formatted_print_options (&opts, d->format.format);
1988 1.7 christos opts.raw = d->format.raw;
1989 1.1 christos
1990 1.1 christos TRY
1991 1.5 christos {
1992 1.5 christos struct value *val;
1993 1.5 christos
1994 1.5 christos val = evaluate_expression (d->exp.get ());
1995 1.5 christos print_formatted (val, d->format.size, &opts, gdb_stdout);
1996 1.5 christos }
1997 1.1 christos CATCH (ex, RETURN_MASK_ERROR)
1998 1.1 christos {
1999 1.1 christos fprintf_filtered (gdb_stdout, _("<error: %s>"), ex.message);
2000 1.1 christos }
2001 1.1 christos END_CATCH
2002 1.1 christos
2003 1.1 christos printf_filtered ("\n");
2004 1.1 christos }
2005 1.1 christos
2006 1.1 christos annotate_display_end ();
2007 1.1 christos
2008 1.1 christos gdb_flush (gdb_stdout);
2009 1.1 christos }
2010 1.1 christos
2011 1.1 christos /* Display all of the values on the auto-display chain which can be
2012 1.1 christos evaluated in the current scope. */
2013 1.1 christos
2014 1.1 christos void
2015 1.1 christos do_displays (void)
2016 1.1 christos {
2017 1.1 christos struct display *d;
2018 1.1 christos
2019 1.1 christos for (d = display_chain; d; d = d->next)
2020 1.1 christos do_one_display (d);
2021 1.1 christos }
2022 1.1 christos
2023 1.1 christos /* Delete the auto-display which we were in the process of displaying.
2024 1.1 christos This is done when there is an error or a signal. */
2025 1.1 christos
2026 1.1 christos void
2027 1.1 christos disable_display (int num)
2028 1.1 christos {
2029 1.1 christos struct display *d;
2030 1.1 christos
2031 1.1 christos for (d = display_chain; d; d = d->next)
2032 1.1 christos if (d->number == num)
2033 1.1 christos {
2034 1.1 christos d->enabled_p = 0;
2035 1.1 christos return;
2036 1.1 christos }
2037 1.1 christos printf_unfiltered (_("No display number %d.\n"), num);
2038 1.1 christos }
2039 1.1 christos
2040 1.1 christos void
2041 1.1 christos disable_current_display (void)
2042 1.1 christos {
2043 1.1 christos if (current_display_number >= 0)
2044 1.1 christos {
2045 1.1 christos disable_display (current_display_number);
2046 1.1 christos fprintf_unfiltered (gdb_stderr,
2047 1.1 christos _("Disabling display %d to "
2048 1.1 christos "avoid infinite recursion.\n"),
2049 1.8 christos current_display_number);
2050 1.1 christos }
2051 1.1 christos current_display_number = -1;
2052 1.1 christos }
2053 1.1 christos
2054 1.1 christos static void
2055 1.1 christos info_display_command (const char *ignore, int from_tty)
2056 1.1 christos {
2057 1.1 christos struct display *d;
2058 1.1 christos
2059 1.1 christos if (!display_chain)
2060 1.1 christos printf_unfiltered (_("There are no auto-display expressions now.\n"));
2061 1.1 christos else
2062 1.1 christos printf_filtered (_("Auto-display expressions now in effect:\n\
2063 1.1 christos Num Enb Expression\n"));
2064 1.1 christos
2065 1.1 christos for (d = display_chain; d; d = d->next)
2066 1.1 christos {
2067 1.1 christos printf_filtered ("%d: %c ", d->number, "ny"[(int) d->enabled_p]);
2068 1.1 christos if (d->format.size)
2069 1.1 christos printf_filtered ("/%d%c%c ", d->format.count, d->format.size,
2070 1.1 christos d->format.format);
2071 1.1 christos else if (d->format.format)
2072 1.1 christos printf_filtered ("/%c ", d->format.format);
2073 1.1 christos puts_filtered (d->exp_string);
2074 1.1 christos if (d->block && !contained_in (get_selected_block (0), d->block))
2075 1.1 christos printf_filtered (_(" (cannot be evaluated in the current context)"));
2076 1.1 christos printf_filtered ("\n");
2077 1.1 christos gdb_flush (gdb_stdout);
2078 1.1 christos }
2079 1.1 christos }
2080 1.1 christos
2081 1.1 christos /* Callback fo map_display_numbers, that enables or disables the
2082 1.1 christos passed in display D. */
2083 1.1 christos
2084 1.1 christos static void
2085 1.1 christos do_enable_disable_display (struct display *d, void *data)
2086 1.1 christos {
2087 1.1 christos d->enabled_p = *(int *) data;
2088 1.8 christos }
2089 1.1 christos
2090 1.1 christos /* Implamentation of both the "disable display" and "enable display"
2091 1.1 christos commands. ENABLE decides what to do. */
2092 1.1 christos
2093 1.1 christos static void
2094 1.1 christos enable_disable_display_command (const char *args, int from_tty, int enable)
2095 1.1 christos {
2096 1.1 christos if (args == NULL)
2097 1.1 christos {
2098 1.1 christos struct display *d;
2099 1.1 christos
2100 1.1 christos ALL_DISPLAYS (d)
2101 1.1 christos d->enabled_p = enable;
2102 1.1 christos return;
2103 1.1 christos }
2104 1.1 christos
2105 1.8 christos map_display_numbers (args, do_enable_disable_display, &enable);
2106 1.1 christos }
2107 1.1 christos
2108 1.1 christos /* The "enable display" command. */
2109 1.1 christos
2110 1.1 christos static void
2111 1.1 christos enable_display_command (const char *args, int from_tty)
2112 1.1 christos {
2113 1.8 christos enable_disable_display_command (args, from_tty, 1);
2114 1.1 christos }
2115 1.1 christos
2116 1.1 christos /* The "disable display" command. */
2117 1.1 christos
2118 1.1 christos static void
2119 1.1 christos disable_display_command (const char *args, int from_tty)
2120 1.1 christos {
2121 1.1 christos enable_disable_display_command (args, from_tty, 0);
2122 1.1 christos }
2123 1.1 christos
2124 1.1 christos /* display_chain items point to blocks and expressions. Some expressions in
2125 1.1 christos turn may point to symbols.
2126 1.1 christos Both symbols and blocks are obstack_alloc'd on objfile_stack, and are
2127 1.1 christos obstack_free'd when a shared library is unloaded.
2128 1.1 christos Clear pointers that are about to become dangling.
2129 1.1 christos Both .exp and .block fields will be restored next time we need to display
2130 1.1 christos an item by re-parsing .exp_string field in the new execution context. */
2131 1.1 christos
2132 1.1 christos static void
2133 1.1 christos clear_dangling_display_expressions (struct objfile *objfile)
2134 1.1 christos {
2135 1.1 christos struct display *d;
2136 1.1 christos struct program_space *pspace;
2137 1.1 christos
2138 1.1 christos /* With no symbol file we cannot have a block or expression from it. */
2139 1.1 christos if (objfile == NULL)
2140 1.1 christos return;
2141 1.1 christos pspace = objfile->pspace;
2142 1.1 christos if (objfile->separate_debug_objfile_backlink)
2143 1.1 christos {
2144 1.1 christos objfile = objfile->separate_debug_objfile_backlink;
2145 1.1 christos gdb_assert (objfile->pspace == pspace);
2146 1.1 christos }
2147 1.1 christos
2148 1.7 christos for (d = display_chain; d != NULL; d = d->next)
2149 1.1 christos {
2150 1.7 christos if (d->pspace != pspace)
2151 1.1 christos continue;
2152 1.1 christos
2153 1.1 christos if (lookup_objfile_from_block (d->block) == objfile
2154 1.1 christos || (d->exp != NULL && exp_uses_objfile (d->exp.get (), objfile)))
2155 1.1 christos {
2156 1.1 christos d->exp.reset ();
2157 1.1 christos d->block = NULL;
2158 1.1 christos }
2159 1.1 christos }
2160 1.1 christos }
2161 1.1 christos
2162 1.1 christos
2164 1.1 christos /* Print the value in stack frame FRAME of a variable specified by a
2165 1.1 christos struct symbol. NAME is the name to print; if NULL then VAR's print
2166 1.1 christos name will be used. STREAM is the ui_file on which to print the
2167 1.1 christos value. INDENT specifies the number of indent levels to print
2168 1.1 christos before printing the variable name.
2169 1.1 christos
2170 1.1 christos This function invalidates FRAME. */
2171 1.1 christos
2172 1.1 christos void
2173 1.1 christos print_variable_and_value (const char *name, struct symbol *var,
2174 1.8 christos struct frame_info *frame,
2175 1.8 christos struct ui_file *stream, int indent)
2176 1.8 christos {
2177 1.8 christos
2178 1.5 christos if (!name)
2179 1.1 christos name = SYMBOL_PRINT_NAME (var);
2180 1.1 christos
2181 1.1 christos fputs_filtered (n_spaces (2 * indent), stream);
2182 1.1 christos fputs_styled (name, variable_name_style.style (), stream);
2183 1.6 christos fputs_filtered (" = ", stream);
2184 1.6 christos
2185 1.6 christos TRY
2186 1.6 christos {
2187 1.6 christos struct value *val;
2188 1.1 christos struct value_print_options opts;
2189 1.1 christos
2190 1.1 christos /* READ_VAR_VALUE needs a block in order to deal with non-local
2191 1.1 christos references (i.e. to handle nested functions). In this context, we
2192 1.1 christos print variables that are local to this frame, so we can avoid passing
2193 1.1 christos a block to it. */
2194 1.1 christos val = read_var_value (var, NULL, frame);
2195 1.1 christos get_user_print_options (&opts);
2196 1.5 christos opts.deref_ref = 1;
2197 1.5 christos common_val_print (val, stream, indent, &opts, current_language);
2198 1.5 christos
2199 1.5 christos /* common_val_print invalidates FRAME when a pretty printer calls inferior
2200 1.5 christos function. */
2201 1.5 christos frame = NULL;
2202 1.5 christos }
2203 1.1 christos CATCH (except, RETURN_MASK_ERROR)
2204 1.1 christos {
2205 1.1 christos fprintf_filtered(stream, "<error reading variable %s (%s)>", name,
2206 1.1 christos except.message);
2207 1.1 christos }
2208 1.1 christos END_CATCH
2209 1.1 christos
2210 1.1 christos fprintf_filtered (stream, "\n");
2211 1.1 christos }
2212 1.1 christos
2213 1.1 christos /* Subroutine of ui_printf to simplify it.
2214 1.1 christos Print VALUE to STREAM using FORMAT.
2215 1.1 christos VALUE is a C-style string on the target. */
2216 1.1 christos
2217 1.1 christos static void
2218 1.1 christos printf_c_string (struct ui_file *stream, const char *format,
2219 1.8 christos struct value *value)
2220 1.8 christos {
2221 1.8 christos gdb_byte *str;
2222 1.8 christos CORE_ADDR tem;
2223 1.8 christos int j;
2224 1.8 christos
2225 1.8 christos tem = value_as_address (value);
2226 1.8 christos if (tem == 0)
2227 1.1 christos {
2228 1.1 christos DIAGNOSTIC_PUSH
2229 1.1 christos DIAGNOSTIC_IGNORE_FORMAT_NONLITERAL
2230 1.1 christos fprintf_filtered (stream, format, "(null)");
2231 1.1 christos DIAGNOSTIC_POP
2232 1.1 christos return;
2233 1.1 christos }
2234 1.1 christos
2235 1.1 christos /* This is a %s argument. Find the length of the string. */
2236 1.1 christos for (j = 0;; j++)
2237 1.1 christos {
2238 1.1 christos gdb_byte c;
2239 1.1 christos
2240 1.1 christos QUIT;
2241 1.1 christos read_memory (tem + j, &c, 1);
2242 1.1 christos if (c == 0)
2243 1.1 christos break;
2244 1.1 christos }
2245 1.8 christos
2246 1.8 christos /* Copy the string contents into a string inside GDB. */
2247 1.1 christos str = (gdb_byte *) alloca (j + 1);
2248 1.8 christos if (j != 0)
2249 1.1 christos read_memory (tem, str, j);
2250 1.1 christos str[j] = 0;
2251 1.1 christos
2252 1.1 christos DIAGNOSTIC_PUSH
2253 1.1 christos DIAGNOSTIC_IGNORE_FORMAT_NONLITERAL
2254 1.1 christos fprintf_filtered (stream, format, (char *) str);
2255 1.1 christos DIAGNOSTIC_POP
2256 1.1 christos }
2257 1.1 christos
2258 1.1 christos /* Subroutine of ui_printf to simplify it.
2259 1.1 christos Print VALUE to STREAM using FORMAT.
2260 1.1 christos VALUE is a wide C-style string on the target. */
2261 1.1 christos
2262 1.1 christos static void
2263 1.1 christos printf_wide_c_string (struct ui_file *stream, const char *format,
2264 1.1 christos struct value *value)
2265 1.1 christos {
2266 1.1 christos gdb_byte *str;
2267 1.6 christos CORE_ADDR tem;
2268 1.1 christos int j;
2269 1.1 christos struct gdbarch *gdbarch = get_type_arch (value_type (value));
2270 1.8 christos enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
2271 1.8 christos struct type *wctype = lookup_typename (current_language, gdbarch,
2272 1.8 christos "wchar_t", NULL, 0);
2273 1.8 christos int wcwidth = TYPE_LENGTH (wctype);
2274 1.8 christos gdb_byte *buf = (gdb_byte *) alloca (wcwidth);
2275 1.8 christos
2276 1.8 christos tem = value_as_address (value);
2277 1.8 christos if (tem == 0)
2278 1.1 christos {
2279 1.1 christos DIAGNOSTIC_PUSH
2280 1.1 christos DIAGNOSTIC_IGNORE_FORMAT_NONLITERAL
2281 1.1 christos fprintf_filtered (stream, format, "(null)");
2282 1.1 christos DIAGNOSTIC_POP
2283 1.1 christos return;
2284 1.1 christos }
2285 1.1 christos
2286 1.1 christos /* This is a %s argument. Find the length of the string. */
2287 1.1 christos for (j = 0;; j += wcwidth)
2288 1.1 christos {
2289 1.1 christos QUIT;
2290 1.1 christos read_memory (tem + j, buf, wcwidth);
2291 1.1 christos if (extract_unsigned_integer (buf, wcwidth, byte_order) == 0)
2292 1.1 christos break;
2293 1.1 christos }
2294 1.8 christos
2295 1.1 christos /* Copy the string contents into a string inside GDB. */
2296 1.1 christos str = (gdb_byte *) alloca (j + wcwidth);
2297 1.1 christos if (j != 0)
2298 1.1 christos read_memory (tem, str, j);
2299 1.1 christos memset (&str[j], 0, wcwidth);
2300 1.1 christos
2301 1.1 christos auto_obstack output;
2302 1.8 christos
2303 1.8 christos convert_between_encodings (target_wide_charset (gdbarch),
2304 1.1 christos host_charset (),
2305 1.8 christos str, j, wcwidth,
2306 1.1 christos &output, translit_char);
2307 1.1 christos obstack_grow_str0 (&output, "");
2308 1.1 christos
2309 1.8 christos DIAGNOSTIC_PUSH
2310 1.1 christos DIAGNOSTIC_IGNORE_FORMAT_NONLITERAL
2311 1.1 christos fprintf_filtered (stream, format, obstack_base (&output));
2312 1.8 christos DIAGNOSTIC_POP
2313 1.8 christos }
2314 1.1 christos
2315 1.1 christos /* Subroutine of ui_printf to simplify it.
2316 1.1 christos Print VALUE, a floating point value, to STREAM using FORMAT. */
2317 1.1 christos
2318 1.1 christos static void
2319 1.8 christos printf_floating (struct ui_file *stream, const char *format,
2320 1.8 christos struct value *value, enum argclass argclass)
2321 1.8 christos {
2322 1.1 christos /* Parameter data. */
2323 1.8 christos struct type *param_type = value_type (value);
2324 1.8 christos struct gdbarch *gdbarch = get_type_arch (param_type);
2325 1.8 christos
2326 1.8 christos /* Determine target type corresponding to the format string. */
2327 1.8 christos struct type *fmt_type;
2328 1.8 christos switch (argclass)
2329 1.8 christos {
2330 1.8 christos case double_arg:
2331 1.8 christos fmt_type = builtin_type (gdbarch)->builtin_double;
2332 1.8 christos break;
2333 1.8 christos case long_double_arg:
2334 1.8 christos fmt_type = builtin_type (gdbarch)->builtin_long_double;
2335 1.8 christos break;
2336 1.8 christos case dec32float_arg:
2337 1.8 christos fmt_type = builtin_type (gdbarch)->builtin_decfloat;
2338 1.8 christos break;
2339 1.8 christos case dec64float_arg:
2340 1.1 christos fmt_type = builtin_type (gdbarch)->builtin_decdouble;
2341 1.1 christos break;
2342 1.8 christos case dec128float_arg:
2343 1.8 christos fmt_type = builtin_type (gdbarch)->builtin_declong;
2344 1.8 christos break;
2345 1.8 christos default:
2346 1.8 christos gdb_assert_not_reached ("unexpected argument class");
2347 1.8 christos }
2348 1.8 christos
2349 1.8 christos /* To match the traditional GDB behavior, the conversion is
2350 1.8 christos done differently depending on the type of the parameter:
2351 1.8 christos
2352 1.8 christos - if the parameter has floating-point type, it's value
2353 1.8 christos is converted to the target type;
2354 1.8 christos
2355 1.8 christos - otherwise, if the parameter has a type that is of the
2356 1.8 christos same size as a built-in floating-point type, the value
2357 1.8 christos bytes are interpreted as if they were of that type, and
2358 1.1 christos then converted to the target type (this is not done for
2359 1.8 christos decimal floating-point argument classes);
2360 1.8 christos
2361 1.1 christos - otherwise, if the source value has an integer value,
2362 1.8 christos it's value is converted to the target type;
2363 1.8 christos
2364 1.8 christos - otherwise, an error is raised.
2365 1.8 christos
2366 1.8 christos In either case, the result of the conversion is a byte buffer
2367 1.8 christos formatted in the target format for the target type. */
2368 1.1 christos
2369 1.8 christos if (TYPE_CODE (fmt_type) == TYPE_CODE_FLT)
2370 1.1 christos {
2371 1.8 christos param_type = float_type_from_length (param_type);
2372 1.8 christos if (param_type != value_type (value))
2373 1.8 christos value = value_from_contents (param_type, value_contents (value));
2374 1.8 christos }
2375 1.1 christos
2376 1.1 christos value = value_cast (fmt_type, value);
2377 1.1 christos
2378 1.1 christos /* Convert the value to a string and print it. */
2379 1.1 christos std::string str
2380 1.1 christos = target_float_to_string (value_contents (value), fmt_type, format);
2381 1.1 christos fputs_filtered (str.c_str (), stream);
2382 1.1 christos }
2383 1.1 christos
2384 1.1 christos /* Subroutine of ui_printf to simplify it.
2385 1.1 christos Print VALUE, a target pointer, to STREAM using FORMAT. */
2386 1.1 christos
2387 1.1 christos static void
2388 1.1 christos printf_pointer (struct ui_file *stream, const char *format,
2389 1.1 christos struct value *value)
2390 1.1 christos {
2391 1.1 christos /* We avoid the host's %p because pointers are too
2392 1.1 christos likely to be the wrong size. The only interesting
2393 1.1 christos modifier for %p is a width; extract that, and then
2394 1.1 christos handle %p as glibc would: %#x or a literal "(nil)". */
2395 1.1 christos
2396 1.1 christos const char *p;
2397 1.6 christos char *fmt, *fmt_p;
2398 1.1 christos #ifdef PRINTF_HAS_LONG_LONG
2399 1.1 christos long long val = value_as_long (value);
2400 1.1 christos #else
2401 1.1 christos long val = value_as_long (value);
2402 1.1 christos #endif
2403 1.1 christos
2404 1.1 christos fmt = (char *) alloca (strlen (format) + 5);
2405 1.1 christos
2406 1.1 christos /* Copy up to the leading %. */
2407 1.1 christos p = format;
2408 1.1 christos fmt_p = fmt;
2409 1.1 christos while (*p)
2410 1.1 christos {
2411 1.1 christos int is_percent = (*p == '%');
2412 1.1 christos
2413 1.1 christos *fmt_p++ = *p++;
2414 1.1 christos if (is_percent)
2415 1.1 christos {
2416 1.1 christos if (*p == '%')
2417 1.1 christos *fmt_p++ = *p++;
2418 1.1 christos else
2419 1.8 christos break;
2420 1.8 christos }
2421 1.8 christos }
2422 1.1 christos
2423 1.1 christos if (val != 0)
2424 1.1 christos *fmt_p++ = '#';
2425 1.1 christos
2426 1.1 christos /* Copy any width or flags. Only the "-" flag is valid for pointers
2427 1.1 christos -- see the format_pieces constructor. */
2428 1.1 christos while (*p == '-' || (*p >= '0' && *p < '9'))
2429 1.1 christos *fmt_p++ = *p++;
2430 1.1 christos
2431 1.1 christos gdb_assert (*p == 'p' && *(p + 1) == '\0');
2432 1.1 christos if (val != 0)
2433 1.8 christos {
2434 1.8 christos #ifdef PRINTF_HAS_LONG_LONG
2435 1.1 christos *fmt_p++ = 'l';
2436 1.8 christos #endif
2437 1.1 christos *fmt_p++ = 'l';
2438 1.1 christos *fmt_p++ = 'x';
2439 1.1 christos *fmt_p++ = '\0';
2440 1.1 christos DIAGNOSTIC_PUSH
2441 1.1 christos DIAGNOSTIC_IGNORE_FORMAT_NONLITERAL
2442 1.8 christos fprintf_filtered (stream, fmt, val);
2443 1.8 christos DIAGNOSTIC_POP
2444 1.1 christos }
2445 1.8 christos else
2446 1.1 christos {
2447 1.1 christos *fmt_p++ = 's';
2448 1.1 christos *fmt_p++ = '\0';
2449 1.1 christos DIAGNOSTIC_PUSH
2450 1.1 christos DIAGNOSTIC_IGNORE_FORMAT_NONLITERAL
2451 1.1 christos fprintf_filtered (stream, fmt, "(nil)");
2452 1.1 christos DIAGNOSTIC_POP
2453 1.1 christos }
2454 1.1 christos }
2455 1.8 christos
2456 1.1 christos /* printf "printf format string" ARG to STREAM. */
2457 1.1 christos
2458 1.1 christos static void
2459 1.1 christos ui_printf (const char *arg, struct ui_file *stream)
2460 1.8 christos {
2461 1.1 christos const char *s = arg;
2462 1.1 christos std::vector<struct value *> val_args;
2463 1.1 christos
2464 1.1 christos if (s == 0)
2465 1.1 christos error_no_arg (_("format-control string and values to print"));
2466 1.8 christos
2467 1.1 christos s = skip_spaces (s);
2468 1.1 christos
2469 1.1 christos /* A format string should follow, enveloped in double quotes. */
2470 1.1 christos if (*s++ != '"')
2471 1.8 christos error (_("Bad format string, missing '\"'."));
2472 1.1 christos
2473 1.1 christos format_pieces fpieces (&s);
2474 1.1 christos
2475 1.1 christos if (*s++ != '"')
2476 1.1 christos error (_("Bad format string, non-terminated '\"'."));
2477 1.1 christos
2478 1.8 christos s = skip_spaces (s);
2479 1.1 christos
2480 1.1 christos if (*s != ',' && *s != 0)
2481 1.1 christos error (_("Invalid argument syntax"));
2482 1.8 christos
2483 1.8 christos if (*s == ',')
2484 1.1 christos s++;
2485 1.1 christos s = skip_spaces (s);
2486 1.8 christos
2487 1.8 christos {
2488 1.1 christos int nargs_wanted;
2489 1.1 christos int i;
2490 1.1 christos const char *current_substring;
2491 1.1 christos
2492 1.1 christos nargs_wanted = 0;
2493 1.1 christos for (auto &&piece : fpieces)
2494 1.1 christos if (piece.argclass != literal_piece)
2495 1.1 christos ++nargs_wanted;
2496 1.1 christos
2497 1.1 christos /* Now, parse all arguments and evaluate them.
2498 1.8 christos Store the VALUEs in VAL_ARGS. */
2499 1.1 christos
2500 1.1 christos while (*s != '\0')
2501 1.1 christos {
2502 1.1 christos const char *s1;
2503 1.1 christos
2504 1.1 christos s1 = s;
2505 1.8 christos val_args.push_back (parse_to_comma_and_eval (&s1));
2506 1.1 christos
2507 1.1 christos s = s1;
2508 1.1 christos if (*s == ',')
2509 1.1 christos s++;
2510 1.8 christos }
2511 1.1 christos
2512 1.8 christos if (val_args.size () != nargs_wanted)
2513 1.8 christos error (_("Wrong number of arguments for specified format-string"));
2514 1.1 christos
2515 1.1 christos /* Now actually print them. */
2516 1.1 christos i = 0;
2517 1.1 christos for (auto &&piece : fpieces)
2518 1.1 christos {
2519 1.1 christos current_substring = piece.string;
2520 1.1 christos switch (piece.argclass)
2521 1.1 christos {
2522 1.1 christos case string_arg:
2523 1.1 christos printf_c_string (stream, current_substring, val_args[i]);
2524 1.1 christos break;
2525 1.1 christos case wide_string_arg:
2526 1.1 christos printf_wide_c_string (stream, current_substring, val_args[i]);
2527 1.1 christos break;
2528 1.1 christos case wide_char_arg:
2529 1.1 christos {
2530 1.1 christos struct gdbarch *gdbarch
2531 1.1 christos = get_type_arch (value_type (val_args[i]));
2532 1.1 christos struct type *wctype = lookup_typename (current_language, gdbarch,
2533 1.1 christos "wchar_t", NULL, 0);
2534 1.1 christos struct type *valtype;
2535 1.1 christos const gdb_byte *bytes;
2536 1.1 christos
2537 1.8 christos valtype = value_type (val_args[i]);
2538 1.1 christos if (TYPE_LENGTH (valtype) != TYPE_LENGTH (wctype)
2539 1.1 christos || TYPE_CODE (valtype) != TYPE_CODE_INT)
2540 1.1 christos error (_("expected wchar_t argument for %%lc"));
2541 1.1 christos
2542 1.1 christos bytes = value_contents (val_args[i]);
2543 1.1 christos
2544 1.1 christos auto_obstack output;
2545 1.1 christos
2546 1.8 christos convert_between_encodings (target_wide_charset (gdbarch),
2547 1.8 christos host_charset (),
2548 1.1 christos bytes, TYPE_LENGTH (valtype),
2549 1.1 christos TYPE_LENGTH (valtype),
2550 1.8 christos &output, translit_char);
2551 1.1 christos obstack_grow_str0 (&output, "");
2552 1.1 christos
2553 1.1 christos DIAGNOSTIC_PUSH
2554 1.1 christos DIAGNOSTIC_IGNORE_FORMAT_NONLITERAL
2555 1.1 christos fprintf_filtered (stream, current_substring,
2556 1.1 christos obstack_base (&output));
2557 1.1 christos DIAGNOSTIC_POP
2558 1.8 christos }
2559 1.8 christos break;
2560 1.1 christos case long_long_arg:
2561 1.8 christos #ifdef PRINTF_HAS_LONG_LONG
2562 1.1 christos {
2563 1.1 christos long long val = value_as_long (val_args[i]);
2564 1.1 christos
2565 1.1 christos DIAGNOSTIC_PUSH
2566 1.1 christos DIAGNOSTIC_IGNORE_FORMAT_NONLITERAL
2567 1.1 christos fprintf_filtered (stream, current_substring, val);
2568 1.1 christos DIAGNOSTIC_POP
2569 1.1 christos break;
2570 1.1 christos }
2571 1.8 christos #else
2572 1.8 christos error (_("long long not supported in printf"));
2573 1.1 christos #endif
2574 1.8 christos case int_arg:
2575 1.1 christos {
2576 1.1 christos int val = value_as_long (val_args[i]);
2577 1.1 christos
2578 1.1 christos DIAGNOSTIC_PUSH
2579 1.1 christos DIAGNOSTIC_IGNORE_FORMAT_NONLITERAL
2580 1.1 christos fprintf_filtered (stream, current_substring, val);
2581 1.8 christos DIAGNOSTIC_POP
2582 1.8 christos break;
2583 1.1 christos }
2584 1.8 christos case long_arg:
2585 1.1 christos {
2586 1.1 christos long val = value_as_long (val_args[i]);
2587 1.8 christos
2588 1.8 christos DIAGNOSTIC_PUSH
2589 1.8 christos DIAGNOSTIC_IGNORE_FORMAT_NONLITERAL
2590 1.8 christos fprintf_filtered (stream, current_substring, val);
2591 1.8 christos DIAGNOSTIC_POP
2592 1.8 christos break;
2593 1.8 christos }
2594 1.8 christos /* Handles floating-point values. */
2595 1.1 christos case double_arg:
2596 1.1 christos case long_double_arg:
2597 1.1 christos case dec32float_arg:
2598 1.1 christos case dec64float_arg:
2599 1.1 christos case dec128float_arg:
2600 1.1 christos printf_floating (stream, current_substring, val_args[i],
2601 1.1 christos piece.argclass);
2602 1.1 christos break;
2603 1.1 christos case ptr_arg:
2604 1.1 christos printf_pointer (stream, current_substring, val_args[i]);
2605 1.1 christos break;
2606 1.1 christos case literal_piece:
2607 1.1 christos /* Print a portion of the format string that has no
2608 1.8 christos directives. Note that this will not include any
2609 1.8 christos ordinary %-specs, but it might include "%%". That is
2610 1.1 christos why we use printf_filtered and not puts_filtered here.
2611 1.8 christos Also, we pass a dummy argument because some platforms
2612 1.1 christos have modified GCC to include -Wformat-security by
2613 1.1 christos default, which will warn here if there is no
2614 1.1 christos argument. */
2615 1.1 christos DIAGNOSTIC_PUSH
2616 1.1 christos DIAGNOSTIC_IGNORE_FORMAT_NONLITERAL
2617 1.1 christos fprintf_filtered (stream, current_substring, 0);
2618 1.8 christos DIAGNOSTIC_POP
2619 1.1 christos break;
2620 1.1 christos default:
2621 1.1 christos internal_error (__FILE__, __LINE__,
2622 1.1 christos _("failed internal consistency check"));
2623 1.1 christos }
2624 1.1 christos /* Maybe advance to the next argument. */
2625 1.1 christos if (piece.argclass != literal_piece)
2626 1.1 christos ++i;
2627 1.8 christos }
2628 1.1 christos }
2629 1.1 christos }
2630 1.8 christos
2631 1.8 christos /* Implement the "printf" command. */
2632 1.1 christos
2633 1.1 christos static void
2634 1.1 christos printf_command (const char *arg, int from_tty)
2635 1.1 christos {
2636 1.1 christos ui_printf (arg, gdb_stdout);
2637 1.1 christos reset_terminal_style (gdb_stdout);
2638 1.8 christos wrap_here ("");
2639 1.1 christos gdb_flush (gdb_stdout);
2640 1.7 christos }
2641 1.1 christos
2642 1.7 christos /* Implement the "eval" command. */
2643 1.1 christos
2644 1.7 christos static void
2645 1.1 christos eval_command (const char *arg, int from_tty)
2646 1.8 christos {
2647 1.1 christos string_file stb;
2648 1.1 christos
2649 1.1 christos ui_printf (arg, &stb);
2650 1.1 christos
2651 1.1 christos std::string expanded = insert_user_defined_cmd_args (stb.c_str ());
2652 1.1 christos
2653 1.1 christos execute_command (expanded.c_str (), from_tty);
2654 1.1 christos }
2655 1.1 christos
2656 1.8 christos void
2657 1.1 christos _initialize_printcmd (void)
2658 1.8 christos {
2659 1.1 christos struct cmd_list_element *c;
2660 1.1 christos
2661 1.8 christos current_display_number = -1;
2662 1.1 christos
2663 1.1 christos gdb::observers::free_objfile.attach (clear_dangling_display_expressions);
2664 1.1 christos
2665 1.1 christos add_info ("address", info_address_command,
2666 1.1 christos _("Describe where symbol SYM is stored."));
2667 1.1 christos
2668 1.1 christos add_info ("symbol", info_symbol_command, _("\
2669 1.1 christos Describe what symbol is at location ADDR.\n\
2670 1.1 christos Only for symbols with fixed locations (global or static scope)."));
2671 1.1 christos
2672 1.1 christos add_com ("x", class_vars, x_command, _("\
2673 1.1 christos Examine memory: x/FMT ADDRESS.\n\
2674 1.6 christos ADDRESS is an expression for the memory address to examine.\n\
2675 1.6 christos FMT is a repeat count followed by a format letter and a size letter.\n\
2676 1.1 christos Format letters are o(octal), x(hex), d(decimal), u(unsigned decimal),\n\
2677 1.1 christos t(binary), f(float), a(address), i(instruction), c(char), s(string)\n\
2678 1.1 christos and z(hex, zero padded on the left).\n\
2679 1.1 christos Size letters are b(byte), h(halfword), w(word), g(giant, 8 bytes).\n\
2680 1.1 christos The specified number of objects of the specified size are printed\n\
2681 1.1 christos according to the format. If a negative number is specified, memory is\n\
2682 1.1 christos examined backward from the address.\n\n\
2683 1.1 christos Defaults for format and size letters are those previously used.\n\
2684 1.1 christos Default count is 1. Default address is following last thing printed\n\
2685 1.8 christos with this command or \"print\"."));
2686 1.1 christos
2687 1.1 christos #if 0
2688 1.1 christos add_com ("whereis", class_vars, whereis_command,
2689 1.1 christos _("Print line number and file of definition of variable."));
2690 1.1 christos #endif
2691 1.1 christos
2692 1.1 christos add_info ("display", info_display_command, _("\
2693 1.1 christos Expressions to display when program stops, with code numbers."));
2694 1.1 christos
2695 1.1 christos add_cmd ("undisplay", class_vars, undisplay_command, _("\
2696 1.1 christos Cancel some expressions to be displayed when program stops.\n\
2697 1.1 christos Arguments are the code numbers of the expressions to stop displaying.\n\
2698 1.1 christos No argument means cancel all automatic-display expressions.\n\
2699 1.1 christos \"delete display\" has the same effect as this command.\n\
2700 1.1 christos Do \"info display\" to see current list of code numbers."),
2701 1.1 christos &cmdlist);
2702 1.1 christos
2703 1.1 christos add_com ("display", class_vars, display_command, _("\
2704 1.1 christos Print value of expression EXP each time the program stops.\n\
2705 1.1 christos /FMT may be used before EXP as in the \"print\" command.\n\
2706 1.1 christos /FMT \"i\" or \"s\" or including a size-letter is allowed,\n\
2707 1.1 christos as in the \"x\" command, and then EXP is used to get the address to examine\n\
2708 1.1 christos and examining is done as in the \"x\" command.\n\n\
2709 1.1 christos With no argument, display all currently requested auto-display expressions.\n\
2710 1.1 christos Use \"undisplay\" to cancel display requests previously made."));
2711 1.1 christos
2712 1.1 christos add_cmd ("display", class_vars, enable_display_command, _("\
2713 1.1 christos Enable some expressions to be displayed when program stops.\n\
2714 1.1 christos Arguments are the code numbers of the expressions to resume displaying.\n\
2715 1.1 christos No argument means enable all automatic-display expressions.\n\
2716 1.1 christos Do \"info display\" to see current list of code numbers."), &enablelist);
2717 1.1 christos
2718 1.1 christos add_cmd ("display", class_vars, disable_display_command, _("\
2719 1.1 christos Disable some expressions to be displayed when program stops.\n\
2720 1.1 christos Arguments are the code numbers of the expressions to stop displaying.\n\
2721 1.1 christos No argument means disable all automatic-display expressions.\n\
2722 1.1 christos Do \"info display\" to see current list of code numbers."), &disablelist);
2723 1.1 christos
2724 1.8 christos add_cmd ("display", class_vars, undisplay_command, _("\
2725 1.8 christos Cancel some expressions to be displayed when program stops.\n\
2726 1.8 christos Arguments are the code numbers of the expressions to stop displaying.\n\
2727 1.1 christos No argument means cancel all automatic-display expressions.\n\
2728 1.1 christos Do \"info display\" to see current list of code numbers."), &deletelist);
2729 1.1 christos
2730 1.1 christos add_com ("printf", class_vars, printf_command, _("\
2731 1.1 christos Formatted printing, like the C \"printf\" function.\n\
2732 1.1 christos Usage: printf \"format string\", arg1, arg2, arg3, ..., argn\n\
2733 1.1 christos This supports most C printf format specifications, like %s, %d, etc."));
2734 1.1 christos
2735 1.1 christos add_com ("output", class_vars, output_command, _("\
2736 1.1 christos Like \"print\" but don't put in value history and don't print newline.\n\
2737 1.1 christos This is useful in user-defined commands."));
2738 1.1 christos
2739 1.1 christos add_prefix_cmd ("set", class_vars, set_command, _("\
2740 1.1 christos Evaluate expression EXP and assign result to variable VAR, using assignment\n\
2741 1.1 christos syntax appropriate for the current language (VAR = EXP or VAR := EXP for\n\
2742 1.1 christos example). VAR may be a debugger \"convenience\" variable (names starting\n\
2743 1.1 christos with $), a register (a few standard names starting with $), or an actual\n\
2744 1.1 christos variable in the program being debugged. EXP is any valid expression.\n\
2745 1.1 christos Use \"set variable\" for variables with names identical to set subcommands.\n\
2746 1.1 christos \n\
2747 1.1 christos With a subcommand, this command modifies parts of the gdb environment.\n\
2748 1.1 christos You can see these environment settings with the \"show\" command."),
2749 1.1 christos &setlist, "set ", 1, &cmdlist);
2750 1.1 christos if (dbx_commands)
2751 1.1 christos add_com ("assign", class_vars, set_command, _("\
2752 1.1 christos Evaluate expression EXP and assign result to variable VAR, using assignment\n\
2753 1.1 christos syntax appropriate for the current language (VAR = EXP or VAR := EXP for\n\
2754 1.1 christos example). VAR may be a debugger \"convenience\" variable (names starting\n\
2755 1.1 christos with $), a register (a few standard names starting with $), or an actual\n\
2756 1.1 christos variable in the program being debugged. EXP is any valid expression.\n\
2757 1.1 christos Use \"set variable\" for variables with names identical to set subcommands.\n\
2758 1.1 christos \nWith a subcommand, this command modifies parts of the gdb environment.\n\
2759 1.1 christos You can see these environment settings with the \"show\" command."));
2760 1.1 christos
2761 1.1 christos /* "call" is the same as "set", but handy for dbx users to call fns. */
2762 1.1 christos c = add_com ("call", class_vars, call_command, _("\
2763 1.1 christos Call a function in the program.\n\
2764 1.1 christos The argument is the function name and arguments, in the notation of the\n\
2765 1.1 christos current working language. The result is printed and saved in the value\n\
2766 1.1 christos history, if it is not void."));
2767 1.1 christos set_cmd_completer (c, expression_completer);
2768 1.1 christos
2769 1.1 christos add_cmd ("variable", class_vars, set_command, _("\
2770 1.8 christos Evaluate expression EXP and assign result to variable VAR, using assignment\n\
2771 1.1 christos syntax appropriate for the current language (VAR = EXP or VAR := EXP for\n\
2772 1.1 christos example). VAR may be a debugger \"convenience\" variable (names starting\n\
2773 1.1 christos with $), a register (a few standard names starting with $), or an actual\n\
2774 1.1 christos variable in the program being debugged. EXP is any valid expression.\n\
2775 1.1 christos This may usually be abbreviated to simply \"set\"."),
2776 1.1 christos &setlist);
2777 1.1 christos add_alias_cmd ("var", "variable", class_vars, 0, &setlist);
2778 1.1 christos
2779 1.1 christos c = add_com ("print", class_vars, print_command, _("\
2780 1.1 christos Print value of expression EXP.\n\
2781 1.1 christos Variables accessible are those of the lexical environment of the selected\n\
2782 1.1 christos stack frame, plus all those whose scope is global or an entire file.\n\
2783 1.1 christos \n\
2784 1.1 christos $NUM gets previous value number NUM. $ and $$ are the last two values.\n\
2785 1.1 christos $$NUM refers to NUM'th value back from the last one.\n\
2786 1.1 christos Names starting with $ refer to registers (with the values they would have\n\
2787 1.1 christos if the program were to return to the stack frame now selected, restoring\n\
2788 1.1 christos all registers saved by frames farther in) or else to debugger\n\
2789 1.1 christos \"convenience\" variables (any such name not a known register).\n\
2790 1.1 christos Use assignment expressions to give values to convenience variables.\n\
2791 1.1 christos \n\
2792 1.1 christos {TYPE}ADREXP refers to a datum of data type TYPE, located at address ADREXP.\n\
2793 1.1 christos @ is a binary operator for treating consecutive data objects\n\
2794 1.1 christos anywhere in memory as an array. FOO@NUM gives an array whose first\n\
2795 1.1 christos element is FOO, whose second element is stored in the space following\n\
2796 1.1 christos where FOO is stored, etc. FOO must be an expression whose value\n\
2797 1.1 christos resides in memory.\n\
2798 1.1 christos \n\
2799 1.1 christos EXP may be preceded with /FMT, where FMT is a format letter\n\
2800 1.1 christos but no count or size letter (see \"x\" command)."));
2801 1.1 christos set_cmd_completer (c, expression_completer);
2802 1.1 christos add_com_alias ("p", "print", class_vars, 1);
2803 1.1 christos add_com_alias ("inspect", "print", class_vars, 1);
2804 1.1 christos
2805 1.1 christos add_setshow_uinteger_cmd ("max-symbolic-offset", no_class,
2806 1.1 christos &max_symbolic_offset, _("\
2807 1.1 christos Set the largest offset that will be printed in <symbol+1234> form."), _("\
2808 1.1 christos Show the largest offset that will be printed in <symbol+1234> form."), _("\
2809 1.1 christos Tell GDB to only display the symbolic form of an address if the\n\
2810 1.1 christos offset between the closest earlier symbol and the address is less than\n\
2811 1.1 christos the specified maximum offset. The default is \"unlimited\", which tells GDB\n\
2812 1.1 christos to always print the symbolic form of an address if any symbol precedes\n\
2813 1.1 christos it. Zero is equivalent to \"unlimited\"."),
2814 1.1 christos NULL,
2815 1.1 christos show_max_symbolic_offset,
2816 1.1 christos &setprintlist, &showprintlist);
2817 1.1 christos add_setshow_boolean_cmd ("symbol-filename", no_class,
2818 1.1 christos &print_symbol_filename, _("\
2819 1.1 christos Set printing of source filename and line number with <symbol>."), _("\
2820 1.1 christos Show printing of source filename and line number with <symbol>."), NULL,
2821 1.1 christos NULL,
2822 show_print_symbol_filename,
2823 &setprintlist, &showprintlist);
2824
2825 add_com ("eval", no_class, eval_command, _("\
2826 Convert \"printf format string\", arg1, arg2, arg3, ..., argn to\n\
2827 a command line, and call it."));
2828 }
2829