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