mirror of
https://github.com/darlinghq/darling-gdb.git
synced 2024-11-29 15:00:34 +00:00
1190271968
2) $Id: tag appears in post-m4 text
927 lines
32 KiB
Plaintext
Executable File
927 lines
32 KiB
Plaintext
Executable File
_dnl__ Copyright (c) 1988 1989 1990 1991 Free Software Foundation, Inc.
|
|
_dnl__ This file is part of the source for the GDB manual.
|
|
@c M4 FRAGMENT: $Id$
|
|
@node Data, Symbols, Source, Top
|
|
@chapter Examining Data
|
|
|
|
@cindex printing data
|
|
@cindex examining data
|
|
@kindex print
|
|
@kindex inspect
|
|
@c "inspect" isn't quite a synonym if you're using Epoch, which we don't
|
|
@c document because it's nonstandard... Under Epoch it displays in a
|
|
@c different window or something like that.
|
|
The usual way to examine data in your program is with the @code{print}
|
|
command (abbreviated @code{p}), or its synonym @code{inspect}. It
|
|
evaluates and prints the value of any valid expression of the language
|
|
the program is written in (for now, C or C++). You type
|
|
|
|
@example
|
|
print @var{exp}
|
|
@end example
|
|
|
|
@noindent
|
|
where @var{exp} is any valid expression (in the source language), and
|
|
the value of @var{exp} is printed in a format appropriate to its data
|
|
type.
|
|
|
|
A more low-level way of examining data is with the @code{x} command.
|
|
It examines data in memory at a specified address and prints it in a
|
|
specified format. @xref{Memory}.
|
|
|
|
@menu
|
|
* Expressions:: Expressions
|
|
* Variables:: Program Variables
|
|
* Arrays:: Artificial Arrays
|
|
* Output formats:: Output formats
|
|
* Memory:: Examining Memory
|
|
* Auto Display:: Automatic Display
|
|
* Print Settings:: Print Settings
|
|
* Value History:: Value History
|
|
* Convenience Vars:: Convenience Variables
|
|
* Registers:: Registers
|
|
* Floating Point Hardware:: Floating Point Hardware
|
|
@end menu
|
|
|
|
@node Expressions, Variables, Data, Data
|
|
@section Expressions
|
|
|
|
@cindex expressions
|
|
@code{print} and many other _GDBN__ commands accept an expression and
|
|
compute its value. Any kind of constant, variable or operator defined
|
|
by the programming language you are using is legal in an expression in
|
|
_GDBN__. This includes conditional expressions, function calls, casts
|
|
and string constants. It unfortunately does not include symbols defined
|
|
by preprocessor @code{#define} commands, or C++ expressions involving
|
|
@samp{::}, the name resolution operator.
|
|
@c FIXME: actually C++ a::b works except in obscure circumstances where it
|
|
@c FIXME...can conflict with GDB's own name scope resolution.
|
|
|
|
Casts are supported in all languages, not just in C, because it is so
|
|
useful to cast a number into a pointer so as to examine a structure
|
|
at that address in memory.
|
|
|
|
_GDBN__ supports three kinds of operator in addition to those of programming
|
|
languages:
|
|
|
|
@table @code
|
|
@item @@
|
|
@samp{@@} is a binary operator for treating parts of memory as arrays.
|
|
@xref{Arrays}, for more information.
|
|
|
|
@item ::
|
|
@samp{::} allows you to specify a variable in terms of the file or
|
|
function where it is defined. @xref{Variables}.
|
|
|
|
@item @{@var{type}@} @var{addr}
|
|
Refers to an object of type @var{type} stored at address @var{addr} in
|
|
memory. @var{addr} may be any expression whose value is an integer or
|
|
pointer (but parentheses are required around binary operators, just as in
|
|
a cast). This construct is allowed regardless of what kind of data is
|
|
normally supposed to reside at @var{addr}.@refill
|
|
@end table
|
|
|
|
@node Variables, Arrays, Expressions, Data
|
|
@section Program Variables
|
|
|
|
The most common kind of expression to use is the name of a variable
|
|
in your program.
|
|
|
|
Variables in expressions are understood in the selected stack frame
|
|
(@pxref{Selection}); they must either be global (or static) or be visible
|
|
according to the scope rules of the programming language from the point of
|
|
execution in that frame. This means that in the function
|
|
|
|
@example
|
|
foo (a)
|
|
int a;
|
|
@{
|
|
bar (a);
|
|
@{
|
|
int b = test ();
|
|
bar (b);
|
|
@}
|
|
@}
|
|
@end example
|
|
|
|
@noindent
|
|
the variable @code{a} is usable whenever the program is executing
|
|
within the function @code{foo}, but the variable @code{b} is visible
|
|
only while the program is executing inside the block in which @code{b}
|
|
is declared.
|
|
|
|
@cindex variable name conflict
|
|
There is an exception: you can refer to a variable or function whose
|
|
scope is a single source file even if the current execution point is not
|
|
in this file. But it is possible to have more than one such variable or
|
|
function with the same name (in different source files). If that happens,
|
|
referring to that name has unpredictable effects. If you wish, you can
|
|
specify a variable in a particular file, using the colon-colon notation:
|
|
|
|
@cindex colon-colon
|
|
@kindex ::
|
|
@example
|
|
@var{file}::@var{variable}
|
|
@end example
|
|
|
|
@noindent
|
|
Here @var{file} is the name of the source file whose variable you want.
|
|
|
|
@cindex C++ name resolution
|
|
This use of @samp{::} is very rarely in conflict with the very similar
|
|
use of the same notation in C++. _GDBN__ also supports use of the C++
|
|
name resolution operator in _GDBN__ expressions.
|
|
|
|
@node Arrays, Output formats, Variables, Data
|
|
@section Artificial Arrays
|
|
|
|
@cindex artificial array
|
|
@kindex @@
|
|
It is often useful to print out several successive objects of the
|
|
same type in memory; a section of an array, or an array of
|
|
dynamically determined size for which only a pointer exists in the
|
|
program.
|
|
|
|
This can be done by constructing an @dfn{artificial array} with the
|
|
binary operator @samp{@@}. The left operand of @samp{@@} should be
|
|
the first element of the desired array, as an individual object.
|
|
The right operand should be the desired length of the array. The result is
|
|
an array value whose elements are all of the type of the left argument.
|
|
The first element is actually the left argument; the second element
|
|
comes from bytes of memory immediately following those that hold the
|
|
first element, and so on. Here is an example. If a program says
|
|
|
|
@example
|
|
int *array = (int *) malloc (len * sizeof (int));
|
|
@end example
|
|
|
|
@noindent
|
|
you can print the contents of @code{array} with
|
|
|
|
@example
|
|
p *array@@len
|
|
@end example
|
|
|
|
The left operand of @samp{@@} must reside in memory. Array values made
|
|
with @samp{@@} in this way behave just like other arrays in terms of
|
|
subscripting, and are coerced to pointers when used in expressions.
|
|
Artificial arrays most often appear in expressions via the value history
|
|
(@pxref{Value History}), after printing one out.)
|
|
|
|
@node Output formats, Memory, Arrays, Data
|
|
@section Output formats
|
|
|
|
@cindex formatted output
|
|
@cindex output formats
|
|
By default, _GDBN__ prints a value according to its data type. Sometimes
|
|
this is not what you want. For example, you might want to print a number
|
|
in hex, or a pointer in decimal. Or you might want to view data in memory
|
|
at a certain address as a character string or as an instruction. To do
|
|
these things, specify an @dfn{output format} when you print a value.
|
|
|
|
The simplest use of output formats is to say how to print a value
|
|
already computed. This is done by starting the arguments of the
|
|
@code{print} command with a slash and a format letter. The format
|
|
letters supported are:
|
|
|
|
@table @code
|
|
@item x
|
|
Regard the bits of the value as an integer, and print the integer in
|
|
hexadecimal.
|
|
|
|
@item d
|
|
Print as integer in signed decimal.
|
|
|
|
@item u
|
|
Print as integer in unsigned decimal.
|
|
|
|
@item o
|
|
Print as integer in octal.
|
|
|
|
@item t
|
|
Print as integer in binary. The letter @samp{t} stands for ``two''.
|
|
|
|
@item a
|
|
Print as an address, both absolute in hex and as an offset from the
|
|
nearest preceding symbol. This format can be used to discover where (in
|
|
what function) an unknown address is located:
|
|
@example
|
|
(_GDBP__) p/a 0x54320
|
|
_0__$3 = 0x54320 <_initialize_vx+396>_1__
|
|
@end example
|
|
|
|
|
|
@item c
|
|
Regard as an integer and print it as a character constant.
|
|
|
|
@item f
|
|
Regard the bits of the value as a floating point number and print
|
|
using typical floating point syntax.
|
|
@end table
|
|
|
|
For example, to print the program counter in hex (@pxref{Registers}), type
|
|
|
|
@example
|
|
p/x $pc
|
|
@end example
|
|
|
|
@noindent
|
|
Note that no space is required before the slash; this is because command
|
|
names in _GDBN__ cannot contain a slash.
|
|
|
|
To reprint the last value in the value history with a different format,
|
|
you can use the @code{print} command with just a format and no
|
|
expression. For example, @samp{p/x} reprints the last value in hex.
|
|
|
|
@node Memory, Auto Display, Output formats, Data
|
|
@section Examining Memory
|
|
|
|
@cindex examining memory
|
|
@table @code
|
|
@kindex x
|
|
@item x/@var{nfu} @var{expr}
|
|
The command @code{x} (for `examine') can be used to examine memory
|
|
without being constrained by your program's data types. You can specify
|
|
the unit size @var{u} of memory to inspect, and a repeat count @var{n} of how
|
|
many of those units to display. @code{x} understands the formats
|
|
@var{f} used by @code{print}; two additional formats, @samp{s} (string)
|
|
and @samp{i} (machine instruction) can be used without specifying a unit
|
|
size.
|
|
@end table
|
|
|
|
For example, @samp{x/3uh 0x54320} is a request to display three halfwords
|
|
(@code{h}) of memory, formatted as unsigned decimal integers (@samp{u}),
|
|
starting at address @code{0x54320}. @samp{x/4xw $sp} prints the four
|
|
words (@samp{w}) of memory above the stack pointer (here, @samp{$sp};
|
|
@pxref{Registers}) in hexadecimal (@samp{x}).
|
|
|
|
Since the letters indicating unit sizes are all distinct from the
|
|
letters specifying output formats, you don't have to remember whether
|
|
unit size or format comes first; either order will work. The output
|
|
specifications @samp{4xw} and @samp{4wx} mean exactly the same thing.
|
|
|
|
After the format specification, you supply an expression for the address
|
|
where _GDBN__ is to begin reading from memory. The expression need not
|
|
have a pointer value (though it may); it is always interpreted as an
|
|
integer address of a byte of memory. @xref{Expressions} for more
|
|
information on expressions.
|
|
|
|
These are the memory units @var{u} you can specify with the @code{x}
|
|
command:
|
|
|
|
@table @code
|
|
@item b
|
|
Examine individual bytes.
|
|
|
|
@item h
|
|
Examine halfwords (two bytes each).
|
|
|
|
@item w
|
|
Examine words (four bytes each).
|
|
|
|
@cindex word
|
|
Many assemblers and cpu designers still use `word' for a 16-bit quantity,
|
|
as a holdover from specific predecessor machines of the 1970's that really
|
|
did use two-byte words. But more generally the term `word' has always
|
|
referred to the size of quantity that a machine normally operates on and
|
|
stores in its registers. This is 32 bits for all the machines that _GDBN__
|
|
runs on.
|
|
|
|
@item g
|
|
Examine giant words (8 bytes).
|
|
@end table
|
|
|
|
You can combine these unit specifications with any of the formats
|
|
described for @code{print}. @xref{Output formats}.
|
|
|
|
@code{x} has two additional output specifications which derive the unit
|
|
size from the data inspected:
|
|
|
|
@table @code
|
|
@item s
|
|
Print a null-terminated string of characters. Any explicitly specified
|
|
unit size is ignored; instead, the unit is however many bytes it takes
|
|
to reach a null character (including the null character).
|
|
|
|
@item i
|
|
Print a machine instruction in assembler syntax (or nearly). Any
|
|
specified unit size is ignored; the number of bytes in an instruction
|
|
varies depending on the type of machine, the opcode and the addressing
|
|
modes used. The command @code{disassemble} gives an alternative way of
|
|
inspecting machine instructions. @xref{Machine Code}.
|
|
@end table
|
|
|
|
If you omit either the format @var{f} or the unit size @var{u}, @code{x}
|
|
will use the same one that was used last. If you don't use any letters
|
|
or digits after the slash, you can omit the slash as well.
|
|
|
|
You can also omit the address to examine. Then the address used is just
|
|
after the last unit examined. This is why string and instruction
|
|
formats actually compute a unit-size based on the data: so that the next
|
|
string or instruction examined will start in the right place.
|
|
|
|
When the @code{print} command shows a value that resides in memory,
|
|
@code{print} also sets the default address for the @code{x} command.
|
|
@code{info line} also sets the default for @code{x}, to the address of
|
|
the start of the machine code for the specified line (@pxref{Machine
|
|
Code}), and @code{info breakpoints} sets it to the address of the last
|
|
breakpoint listed (@pxref{Set Breaks}).
|
|
|
|
When you use @key{RET} to repeat an @code{x} command, the address
|
|
specified previously (if any) is ignored, so that the repeated command
|
|
examines the successive locations in memory rather than the same ones.
|
|
|
|
You can examine several consecutive units of memory with one command by
|
|
writing a repeat-count after the slash (before the format letters, if
|
|
any). Omitting the repeat count @var{n} displays one unit of the
|
|
appropriate size. The repeat count must be a decimal integer. It has
|
|
the same effect as repeating the @code{x} command @var{n} times except
|
|
that the output may be more compact, with several units per line. For
|
|
example,
|
|
|
|
@example
|
|
x/10i $pc
|
|
@end example
|
|
|
|
@noindent
|
|
prints ten instructions starting with the one to be executed next in the
|
|
selected frame. After doing this, you could print a further seven
|
|
instructions with
|
|
|
|
@example
|
|
x/7
|
|
@end example
|
|
|
|
@noindent
|
|
---where the format and address are allowed to default.
|
|
|
|
@kindex $_
|
|
@kindex $__
|
|
The addresses and contents printed by the @code{x} command are not put
|
|
in the value history because there is often too much of them and they
|
|
would get in the way. Instead, _GDBN__ makes these values available for
|
|
subsequent use in expressions as values of the convenience variables
|
|
@code{$_} and @code{$__}. After an @code{x} command, the last address
|
|
examined is available for use in expressions in the convenience variable
|
|
@code{$_}. The contents of that address, as examined, are available in
|
|
the convenience variable @code{$__}.
|
|
|
|
If the @code{x} command has a repeat count, the address and contents saved
|
|
are from the last memory unit printed; this is not the same as the last
|
|
address printed if several units were printed on the last line of output.
|
|
|
|
@node Auto Display, Print Settings, Memory, Data
|
|
@section Automatic Display
|
|
@cindex automatic display
|
|
@cindex display of expressions
|
|
|
|
If you find that you want to print the value of an expression frequently
|
|
(to see how it changes), you might want to add it to the @dfn{automatic
|
|
display list} so that _GDBN__ will print its value each time the program stops.
|
|
Each expression added to the list is given a number to identify it;
|
|
to remove an expression from the list, you specify that number.
|
|
The automatic display looks like this:
|
|
|
|
@example
|
|
2: foo = 38
|
|
3: bar[5] = (struct hack *) 0x3804
|
|
@end example
|
|
|
|
@noindent
|
|
showing item numbers, expressions and their current values. As with
|
|
displays you request manually using @code{x} or @code{print}, you can
|
|
specify the output format you prefer; in fact, @code{display} decides
|
|
whether to use @code{print} or @code{x} depending on how elaborate your
|
|
format specification is---it uses @code{x} if you specify a unit size,
|
|
or one of the two formats (@samp{i} and @samp{s}) that are only
|
|
supported by @code{x}; otherwise it uses @code{print}.
|
|
|
|
@table @code
|
|
@item display @var{exp}
|
|
@kindex display
|
|
Add the expression @var{exp} to the list of expressions to display
|
|
each time the program stops. @xref{Expressions}.
|
|
|
|
@code{display} will not repeat if you press @key{RET} again after using it.
|
|
|
|
@item display/@var{fmt} @var{exp}
|
|
For @var{fmt} specifying only a display format and not a size or
|
|
count, add the expression @var{exp} to the auto-display list but
|
|
arranges to display it each time in the specified format @var{fmt}.
|
|
@xref{Output formats}.
|
|
|
|
@item display/@var{fmt} @var{addr}
|
|
For @var{fmt} @samp{i} or @samp{s}, or including a unit-size or a
|
|
number of units, add the expression @var{addr} as a memory address to
|
|
be examined each time the program stops. Examining means in effect
|
|
doing @samp{x/@var{fmt} @var{addr}}. @xref{Memory}.
|
|
@end table
|
|
|
|
For example, @samp{display/i $pc} can be helpful, to see the machine
|
|
instruction about to be executed each time execution stops (@samp{$pc}
|
|
is a common name for the program counter; @pxref{Registers}).
|
|
|
|
@table @code
|
|
@item undisplay @var{dnums}@dots{}
|
|
@itemx delete display @var{dnums}@dots{}
|
|
@kindex delete display
|
|
@kindex undisplay
|
|
Remove item numbers @var{dnums} from the list of expressions to display.
|
|
|
|
@code{undisplay} will not repeat if you press @key{RET} after using it.
|
|
(Otherwise you would just get the error @samp{No display number @dots{}}.)
|
|
|
|
@item disable display @var{dnums}@dots{}
|
|
@kindex disable display
|
|
Disable the display of item numbers @var{dnums}. A disabled display
|
|
item is not printed automatically, but is not forgotten. It may be
|
|
enabled again later.
|
|
|
|
@item enable display @var{dnums}@dots{}
|
|
@kindex enable display
|
|
Enable display of item numbers @var{dnums}. It becomes effective once
|
|
again in auto display of its expression, until you specify otherwise.
|
|
|
|
@item display
|
|
Display the current values of the expressions on the list, just as is
|
|
done when the program stops.
|
|
|
|
@item info display
|
|
@kindex info display
|
|
Print the list of expressions previously set up to display
|
|
automatically, each one with its item number, but without showing the
|
|
values. This includes disabled expressions, which are marked as such.
|
|
It also includes expressions which would not be displayed right now
|
|
because they refer to automatic variables not currently available.
|
|
@end table
|
|
|
|
If a display expression refers to local variables, then it does not make
|
|
sense outside the lexical context for which it was set up. Such an
|
|
expression is disabled when execution enters a context where one of its
|
|
variables is not defined. For example, if you give the command
|
|
@code{display last_char} while inside a function with an argument
|
|
@code{last_char}, then this argument will be displayed while the program
|
|
continues to stop inside that function. When it stops elsewhere---where
|
|
there is no variable @code{last_char}---display is disabled. The next time
|
|
your program stops where @code{last_char} is meaningful, you can enable the
|
|
display expression once again.
|
|
|
|
@node Print Settings, Value History, Auto Display, Data
|
|
@section Print Settings
|
|
|
|
@cindex format options
|
|
@cindex print settings
|
|
_GDBN__ provides the following ways to control how arrays, structures,
|
|
and symbols are printed.
|
|
|
|
@noindent
|
|
These settings are useful for debugging programs in any language:
|
|
|
|
@table @code
|
|
@item set print address
|
|
@item set print address on
|
|
@kindex set print address
|
|
_GDBN__ will print memory addresses showing the location of stack
|
|
traces, structure values, pointer values, breakpoints, and so forth,
|
|
even when it also displays the contents of those addresses. The default
|
|
is on. For example, this is what a stack frame display looks like, with
|
|
@code{set print address on}:
|
|
@smallexample
|
|
(_GDBP__) f
|
|
#0 set_quotes (lq=0x34c78 "<<", rq=0x34c88 ">>")
|
|
at input.c:530
|
|
530 if (lquote != def_lquote)
|
|
@end smallexample
|
|
|
|
@item set print address off
|
|
Do not print addresses when displaying their contents. For example,
|
|
this is the same stack frame displayed with @code{set print address off}:
|
|
@example
|
|
(_GDBP__) set print addr off
|
|
(_GDBP__) f
|
|
#0 set_quotes (lq="<<", rq=">>") at input.c:530
|
|
530 if (lquote != def_lquote)
|
|
@end example
|
|
|
|
@item show print address
|
|
@kindex show print address
|
|
Show whether or not addresses are to be printed.
|
|
|
|
@item set print array
|
|
@itemx set print array on
|
|
@kindex set print array
|
|
_GDBN__ will pretty print arrays. This format is more convenient to read,
|
|
but uses more space. The default is off.
|
|
|
|
@item set print array off.
|
|
Return to compressed format for arrays.
|
|
|
|
@item show print array
|
|
@kindex show print array
|
|
Show whether compressed or pretty format is selected for displaying
|
|
arrays.
|
|
|
|
@item set print elements @var{number-of-elements}
|
|
@kindex set print elements
|
|
If _GDBN__ is printing a large array, it will stop printing after it has
|
|
printed the number of elements set by the @code{set print elements} command.
|
|
This limit also applies to the display of strings.
|
|
|
|
@item show print elements
|
|
@kindex show print elements
|
|
Display the number of elements of a large array that _GDBN__ will print
|
|
before losing patience.
|
|
|
|
@item set print pretty on
|
|
@kindex set print pretty
|
|
Cause _GDBN__ to print structures in an indented format with one member per
|
|
line, like this:
|
|
|
|
@example
|
|
$1 = @{
|
|
next = 0x0,
|
|
flags = @{
|
|
sweet = 1,
|
|
sour = 1
|
|
@},
|
|
meat = 0x54 "Pork"
|
|
@}
|
|
@end example
|
|
|
|
@item set print pretty off
|
|
Cause _GDBN__ to print structures in a compact format, like this:
|
|
|
|
@smallexample
|
|
$1 = @{next = 0x0, flags = @{sweet = 1, sour = 1@}, meat \
|
|
= 0x54 "Pork"@}
|
|
@end smallexample
|
|
|
|
@noindent
|
|
This is the default format.
|
|
|
|
@item show print pretty
|
|
@kindex show print pretty
|
|
Show which format _GDBN__ will use to print structures.
|
|
|
|
@item set print sevenbit-strings on
|
|
Print using only seven-bit characters; if this option is set,
|
|
_GDBN__ will display any eight-bit characters (in strings or character
|
|
values) using the notation @code{\}@var{nnn}. For example, @kbd{M-a} is
|
|
displayed as @code{\341}.
|
|
|
|
@item set print sevenbit-strings off
|
|
Print using either seven-bit or eight-bit characters, as required. This
|
|
is the default.
|
|
|
|
@item show print sevenbit-strings
|
|
Show whether or not _GDBN__ will print only seven-bit characters.
|
|
|
|
@item set print union on
|
|
@kindex set print union
|
|
Tell _GDBN__ to print unions which are contained in structures. This is the
|
|
default setting.
|
|
|
|
@item set print union off
|
|
Tell _GDBN__ not to print unions which are contained in structures.
|
|
|
|
@item show print union
|
|
@kindex show print union
|
|
Ask _GDBN__ whether or not it will print unions which are contained in
|
|
structures.
|
|
|
|
For example, given the declarations
|
|
|
|
@smallexample
|
|
typedef enum @{Tree, Bug@} Species;
|
|
typedef enum @{Big_tree, Acorn, Seedling@} Tree_forms;
|
|
typedef enum @{Caterpillar, Cocoon, Butterfly@} Bug_forms;
|
|
|
|
struct thing @{
|
|
Species it;
|
|
union @{
|
|
Tree_forms tree;
|
|
Bug_forms bug;
|
|
@} form;
|
|
@};
|
|
|
|
struct thing foo = @{Tree, @{Acorn@}@};
|
|
@end smallexample
|
|
|
|
@noindent
|
|
with @code{set print union on} in effect @samp{p foo} would print
|
|
|
|
@smallexample
|
|
$1 = @{it = Tree, form = @{tree = Acorn, bug = Cocoon@}@}
|
|
@end smallexample
|
|
|
|
@noindent
|
|
and with @code{set print union off} in effect it would print
|
|
|
|
@smallexample
|
|
$1 = @{it = Tree, form = @{...@}@}
|
|
@end smallexample
|
|
@end table
|
|
|
|
@noindent
|
|
These settings are of interest when debugging C++ programs:
|
|
|
|
@table @code
|
|
@item set print demangle
|
|
@itemx set print demangle on
|
|
@kindex set print demangle
|
|
Print C++ names in their source form rather than in the mangled form
|
|
in which they are passed to the assembler and linker for type-safe linkage.
|
|
The default is on.
|
|
|
|
@item show print demangle
|
|
@kindex show print demangle
|
|
Show whether C++ names will be printed in mangled or demangled form.
|
|
|
|
@item set print asm-demangle
|
|
@itemx set print asm-demangle on
|
|
@kindex set print asm-demangle
|
|
Print C++ names in their source form rather than their mangled form, even
|
|
in assembler code printouts such as instruction disassemblies.
|
|
The default is off.
|
|
|
|
@item show print asm-demangle
|
|
@kindex show print asm-demangle
|
|
Show whether C++ names in assembly listings will be printed in mangled
|
|
or demangled form.
|
|
|
|
@item set print object
|
|
@itemx set print object on
|
|
@kindex set print object
|
|
When displaying a pointer to an object, identify the @emph{actual}
|
|
(derived) type of the object rather than the @emph{declared} type, using
|
|
the virtual function table.
|
|
|
|
@item set print object off
|
|
Display only the declared type of objects, without reference to the
|
|
virtual function table. This is the default setting.
|
|
|
|
@item show print object
|
|
@kindex show print object
|
|
Show whether actual, or declared, object types will be displayed.
|
|
|
|
@item set print vtbl
|
|
@itemx set print vtbl on
|
|
@kindex set print vtbl
|
|
Pretty print C++ virtual function tables. The default is off.
|
|
|
|
@item set print vtbl off
|
|
Do not pretty print C++ virtual function tables.
|
|
|
|
@item show print vtbl
|
|
@kindex show print vtbl
|
|
Show whether C++ virtual function tables are pretty printed, or not.
|
|
|
|
@end table
|
|
|
|
@node Value History, Convenience Vars, Print Settings, Data
|
|
@section Value History
|
|
|
|
@cindex value history
|
|
Values printed by the @code{print} command are saved in _GDBN__'s @dfn{value
|
|
history} so that you can refer to them in other expressions. Values are
|
|
kept until the symbol table is re-read or discarded (for example with
|
|
the @code{file} or @code{symbol-file} commands). When the symbol table
|
|
changes, the value history is discarded, since the values may contain
|
|
pointers back to the types defined in the symbol table.
|
|
|
|
@cindex @code{$}
|
|
@cindex @code{$$}
|
|
@cindex history number
|
|
The values printed are given @dfn{history numbers} for you to refer to them
|
|
by. These are successive integers starting with one. @code{print} shows you
|
|
the history number assigned to a value by printing @samp{$@var{num} = }
|
|
before the value; here @var{num} is the history number.
|
|
|
|
To refer to any previous value, use @samp{$} followed by the value's
|
|
history number. The way @code{print} labels its output is designed to
|
|
remind you of this. Just @code{$} refers to the most recent value in
|
|
the history, and @code{$$} refers to the value before that.
|
|
@code{$$@var{n}} refers to the @var{n}th value from the end; @code{$$2}
|
|
is the value just prior to @code{$$}, @code{$$1} is equivalent to
|
|
@code{$$}, and @code{$$0} is equivalent to @code{$}.
|
|
|
|
For example, suppose you have just printed a pointer to a structure and
|
|
want to see the contents of the structure. It suffices to type
|
|
|
|
@example
|
|
p *$
|
|
@end example
|
|
|
|
If you have a chain of structures where the component @code{next} points
|
|
to the next one, you can print the contents of the next one with this:
|
|
|
|
@example
|
|
p *$.next
|
|
@end example
|
|
|
|
@noindent
|
|
You can print successive links in the chain by repeating this
|
|
command---which you can do by just typing @key{RET}.
|
|
|
|
Note that the history records values, not expressions. If the value of
|
|
@code{x} is 4 and you type these commands:
|
|
|
|
@example
|
|
print x
|
|
set x=5
|
|
@end example
|
|
|
|
@noindent
|
|
then the value recorded in the value history by the @code{print} command
|
|
remains 4 even though the value of @code{x} has changed.
|
|
|
|
@table @code
|
|
@kindex show values
|
|
@item show values
|
|
Print the last ten values in the value history, with their item numbers.
|
|
This is like @samp{p@ $$9} repeated ten times, except that @code{show
|
|
values} does not change the history.
|
|
|
|
@item show values @var{n}
|
|
Print ten history values centered on history item number @var{n}.
|
|
|
|
@item show values +
|
|
Print ten history values just after the values last printed. If no more
|
|
values are available, produces no display.
|
|
@end table
|
|
|
|
Pressing @key{RET} to repeat @code{show values @var{n}} has exactly the
|
|
same effect as @samp{show values +}.
|
|
|
|
@node Convenience Vars, Registers, Value History, Data
|
|
@section Convenience Variables
|
|
|
|
@cindex convenience variables
|
|
_GDBN__ provides @dfn{convenience variables} that you can use within
|
|
_GDBN__ to hold on to a value and refer to it later. These variables
|
|
exist entirely within _GDBN__; they are not part of your program, and
|
|
setting a convenience variable has no direct effect on further execution
|
|
of your program. That's why you can use them freely.
|
|
|
|
Convenience variables are prefixed with @samp{$}. Any name preceded by
|
|
@samp{$} can be used for a convenience variable, unless it is one of
|
|
the predefined machine-specific register names (@pxref{Registers}).
|
|
(Value history references, in contrast, are @emph{numbers} preceded
|
|
by @samp{$}. @xref{Value History}.)
|
|
|
|
You can save a value in a convenience variable with an assignment
|
|
expression, just as you would set a variable in your program. Example:
|
|
|
|
@example
|
|
set $foo = *object_ptr
|
|
@end example
|
|
|
|
@noindent
|
|
would save in @code{$foo} the value contained in the object pointed to by
|
|
@code{object_ptr}.
|
|
|
|
Using a convenience variable for the first time creates it; but its value
|
|
is @code{void} until you assign a new value. You can alter the value with
|
|
another assignment at any time.
|
|
|
|
Convenience variables have no fixed types. You can assign a convenience
|
|
variable any type of value, including structures and arrays, even if
|
|
that variable already has a value of a different type. The convenience
|
|
variable, when used as an expression, has the type of its current value.
|
|
|
|
@table @code
|
|
@item show convenience
|
|
@kindex show convenience
|
|
Print a list of convenience variables used so far, and their values.
|
|
Abbreviated @code{show con}.
|
|
@end table
|
|
|
|
One of the ways to use a convenience variable is as a counter to be
|
|
incremented or a pointer to be advanced. For example, to print
|
|
a field from successive elements of an array of structures:
|
|
|
|
_0__@example
|
|
set $i = 0
|
|
print bar[$i++]->contents
|
|
@i{@dots{} repeat that command by typing @key{RET}.}
|
|
_1__@end example
|
|
|
|
Some convenience variables are created automatically by _GDBN__ and given
|
|
values likely to be useful.
|
|
|
|
@table @code
|
|
@item $_
|
|
The variable @code{$_} is automatically set by the @code{x} command to
|
|
the last address examined (@pxref{Memory}). Other commands which
|
|
provide a default address for @code{x} to examine also set @code{$_}
|
|
to that address; these commands include @code{info line} and @code{info
|
|
breakpoint}.
|
|
|
|
@item $__
|
|
The variable @code{$__} is automatically set by the @code{x} command
|
|
to the value found in the last address examined.
|
|
@end table
|
|
|
|
@node Registers, Floating Point Hardware, Convenience Vars, Data
|
|
@section Registers
|
|
|
|
@cindex registers
|
|
Machine register contents can be referred to in expressions as variables
|
|
with names starting with @samp{$}. The names of registers are different
|
|
for each machine; use @code{info registers} to see the names used on
|
|
your machine.
|
|
|
|
@table @code
|
|
@item info registers
|
|
@kindex info registers
|
|
Print the names and values of all registers (in the selected stack frame).
|
|
|
|
@item info registers @var{regname}
|
|
Print the relativized value of register @var{regname}. @var{regname}
|
|
may be any register name valid on the machine you are using, with
|
|
or without the initial @samp{$}.
|
|
@end table
|
|
|
|
The register names @code{$pc} and @code{$sp} are used on most machines
|
|
for the program counter register and the stack pointer. For example,
|
|
you could print the program counter in hex with
|
|
@example
|
|
p/x $pc
|
|
@end example
|
|
|
|
@noindent
|
|
or print the instruction to be executed next with
|
|
@example
|
|
x/i $pc
|
|
@end example
|
|
|
|
@noindent
|
|
or add four to the stack pointer with
|
|
@example
|
|
set $sp += 4
|
|
@end example
|
|
|
|
@noindent
|
|
The last is a way of removing one word from the stack, on machines where
|
|
stacks grow downward in memory (most machines, nowadays). This assumes
|
|
that the innermost stack frame is selected; setting @code{$sp} is
|
|
not allowed when other stack frames are selected. (To pop entire frames
|
|
off the stack, regardless of machine architecture, use @code{return};
|
|
@pxref{Returning}.)
|
|
|
|
Often @code{$fp} is used for a register that contains a pointer to the
|
|
current stack frame, and @code{$ps} is sometimes used for a register
|
|
that contains the processor status. These standard register names may
|
|
be available on your machine even though the @code{info registers}
|
|
command shows other names. For example, on the SPARC, @code{info
|
|
registers} displays the processor status register as @code{$psr} but you
|
|
can also refer to it as @code{$ps}.
|
|
|
|
_GDBN__ always considers the contents of an ordinary register as an
|
|
integer when the register is examined in this way. Some machines have
|
|
special registers which can hold nothing but floating point; these
|
|
registers are considered to have floating point values. There is no way
|
|
to refer to the contents of an ordinary register as floating point value
|
|
(although you can @emph{print} it as a floating point value with
|
|
@samp{print/f $@var{regname}}).
|
|
|
|
Some registers have distinct ``raw'' and ``virtual'' data formats. This
|
|
means that the data format in which the register contents are saved by
|
|
the operating system is not the same one that your program normally
|
|
sees. For example, the registers of the 68881 floating point
|
|
coprocessor are always saved in ``extended'' (raw) format, but all C
|
|
programs expect to work with ``double'' (virtual) format. In such
|
|
cases, _GDBN__ normally works with the virtual format only (the format that
|
|
makes sense for your program), but the @code{info registers} command
|
|
prints the data in both formats.
|
|
|
|
Normally, register values are relative to the selected stack frame
|
|
(@pxref{Selection}). This means that you get the value that the
|
|
register would contain if all stack frames farther in were exited and
|
|
their saved registers restored. In order to see the true contents of
|
|
hardware registers, you must select the innermost frame (with
|
|
@samp{frame 0}).
|
|
|
|
However, _GDBN__ must deduce where registers are saved, from the machine
|
|
code generated by your compiler. If some registers are not saved, or if
|
|
_GDBN__ is unable to locate the saved registers, the selected stack
|
|
frame will make no difference.
|
|
|
|
@node Floating Point Hardware, , Registers, Data
|
|
@section Floating Point Hardware
|
|
@cindex floating point
|
|
Depending on the host machine architecture, _GDBN__ may be able to give
|
|
you more information about the status of the floating point hardware.
|
|
|
|
@table @code
|
|
@item info float
|
|
@kindex info float
|
|
If available, provides hardware-dependent information about the floating
|
|
point unit. The exact contents and layout vary depending on the
|
|
floating point chip.
|
|
@end table
|
|
@c FIXME: this is a cop-out. Try to get examples, explanations. Only
|
|
@c FIXME...supported currently on arm's and 386's. Mark properly with
|
|
@c FIXME... m4 macros to isolate general statements from hardware-dep,
|
|
@c FIXME... at that point.
|