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