Compaq Ladebug for Compaq Tru64 UNIX Systems is a fully symbolic debugger
with graphical user interface (GUI) for the Compaq Tru64 UNIX platform.
Key features of Ladebug allow you to:
- Perform source-level debugging
- Attach to a running process
- Debug programs with shared libraries
- Debug multithreaded applications
- Debug multiprocess applications, including programs that fork/exec
- Perform remote client/server debugging
- Perform kernel debugging
- Provide I18N support for local language characters
Ladebug supports the debugging of programs written in C, C++, Fortran,
Fortran 90, Ada and COBOL. Ladebug features expression evaluation using
the syntax of the source programming language.
For full information about the Ladebug debugger, please refer to
the following manual:
Compaq Tru64 UNIX: Ladebug Debugger Manual
These release notes are broken down into the following subsections:
2 New Features
Problems fixed in this and previous releases of the Ladebug Debugger are
discussed in detail in Problems Fixed
(section 5).
2.1 Internationalization
The "internationalized" version of the debugger is now available in all
kits of the Version 4.0-24 and later debuggers. It is no longer necessary
to install the special IOSLDBxxx subsets of the debugger software to achieve
localization to other language locales.
The IOSLDBxxx subsets are no longer shipped with Digital UNIX V4.0C
and later releases.
Background and Cautions
This release of Ladebug comes at a time when the project
is well on its way through a significant re-engineering of much of
the internal structure of the product. The project has a long range
goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieving this.
This release is primarily being made to include a number of fixes
to bugs reported since -64. See the
V65 Problems Fixed section for details
Note that starting with this release, the Ladebug debugger version number
no longer carries "4.0"
The "4.0" part of the number had been used to distinguish versions
which supported Tru64 Unix 4.0 or greater from those supporting
3.2 or earlier, and is no longer needed.
V65 is an immediate descendent of 4.0-64.
The Ladebug debugger now provides the if
command whose behavior depends on the value of an expression, with the following syntax:
if expression braced_command_list [ else braced_command_list ]
In this command, the first braced_command_list
is executed if
expression
evaluates to a non-zero value, otherwise the
braced_command_list
in the else_clause
is executed, if specified.
For example:
(ladebug) set $c = 1
(ladebug) assign pid = 0
(ladebug) if (pid < $c) { print "Greater" } else { print "Lesser" }
Greater
In V65, the Ladebug debugger provides three new print commands: printi
, printt
, and printb
.
printi
takes one or more comma-separated
instruction expressions and outputs each one in assembly format. See the
following example for more detail:
(ladebug) $curpc/5i
int main(int, char**): probe.C
*[line 17, 0x120002780] ldl r1, 48(sp)
[line 17, 0x120002784] xor r1, 0x2, r1
[line 17, 0x120002788] beq r1, 0x1200027b0
[line 19, 0x12000278c] ldq r16, -32728(gp)
[line 19, 0x120002790] lda r16, -2808(r16)
(ladebug) $curpc/5xx
0x120002780: 0xa03e0030 0x44205801 0xe4200009 0xa61d8028
0x120002790: 0x2210f508
(ladebug) printi 0xa03e0030, 0x44205801, 0xe4200009
ldl r1, 48(sp)
xor r1, 0x2, r1
beq r1, .+0x28
Note in the branch instruction that the _offset_ is given, rather than
the destination PC. This is expected, since the address of the instruction
argument is unknown to the printi command.
Also note that we have switched the built-in alias pi
from "playback input
" to "printi
".
printt
(built-in alias pt
) takes
one or more integer arguments and processes each one as a time value,
in seconds, from the Epoch (7pm, Dec. 31, 1969).
(ladebug) printt 0
Wed Dec 31 19:00:00 1969
(ladebug) printt 0xfaceface
Wed Mar 29 16:55:26 1967
printb
(built-in alias pb
) takes one or more
numerical arguments and outputs them in binary format.
(ladebug) printb 1234567
0b100101101011010000111
Note: Ladebug does not yet accept input in the form output by
the printb
command.
Two new debugger variables are added to support dbx compatibility:
$readtextfile
, primarily used for
Tru64 Unix kernel debugging.
$regstyle
, which controls
the format of the register names during disassembly. Note that
this only occurs with the memory display commands in "i" mode.
There are only three valid settings:
0 = Compiler names (e.g. zero, t3)
1 = Hardware names (e.g. r31, r4) (the default)
2 = Assembly names (e.g. $31, $4)
In V65, the Ladebug debugger implements the next
,
step
and stepi
operations several
times faster than before, equalling the performance of the
dbx
debugger.
Background and Cautions
This release of Ladebug comes at a time when the project
is well on its way through a significant re-engineering of much of
the internal structure of the product. The project has a long range
goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieving this.
This release is primarily being made to include a number of fixes
to bugs reported since -63. See the
4.0-64 Problems Fixed section for details.
As of 4.0-64, The Ladebug debugger no longer supports Alpha Linux
kernels prior to 2.2. In particular, the 2.0 kernels (e.g. as
distributed in the RedHat 5.2 distribution) are not supported.
Floating point numbers are represented inside the computer in
binary floating point. They are converted to decimal floating
point when printed. The two formats are not the same, and
some numbers are easily represented in decimal but not in
binary (such as 1.1). The internal binary form for such
numbers is an approximation, the closest that can be made
given the number of bits available.
It is often the case that a given binary floating point number
represents several "nearby" decimal floating point numbers, as
each of them would be converted into the same binary bit pattern.
Normally, when a floating point number is printed out, the shortest
such decimal number is used, as it is a legal representation of
the internal binary number.
Users who require the most exact conversion, so that they see
the decimal number which is the closest representation in the
number of decimal digits available can now see those digits,
using the new debugger control variable $floatshrinking
.
The default value is one, which preserves the old behaviour of
Ladebug. Users may set it to zero to see the unshrunk numbers.
Here's an example, showing the result of converting 1.1 to the
closest long double binary floating point number when the command
is read by Ladebug, and then the converting of that value back to
decimal floating point when printed for the user.
The shrunk number is 1.1, but the unshrunk number is the closest
decimal number to the actual binary approximation to 1.1:
(ladebug) p $floatshrinking
1
(ladebug) p 1.1
1.1
(ladebug) set $floatshrinking = 0
(ladebug) p 1.1
1.10000000000000000000000000000000008
At the moment, the unshrunk forms are only available for long
double variables and expressions (which includes literals from
the command line as above).
For more detail on floating point representation, see
ANSI IEEE standard 754-1985.
You can now use the print
and whatis
commands with Fortran arrays, which were distributed using NUMA directives.
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieving this.
This release is primarily being made to include a number of fixes
to bugs reported since -62. See the
4.0-63 Problems Fixed section for details.
Ladebug now requires the '#
' character which starts a
non-leading comment to be preceded by whitespace and followed by
whitespace or newlines. Leading comments (lines which start with
'#
') do not have to have preceeding whitespace, and
a '#
' at the end of a line does not have to have
trailing whitespace.
This is an incompatible change, but is needed because the
tmpnam
standard library function
generates file and directory names containing '#
' characters.
Ladebug will now see "right#file
" as a name, not as
"right
" followed by a comment.
This work was done based on QAR 81040.
When debugging BLISS code, the debugger variable
$statusargs
can be set to -1
to display anonymous structures in abbreviated form
(e.g. struct {...}
rather than as a list of data member names).
This feature works only when debugging BLISS code.
Ladebug now has better external symbol support on Linux, as it
will read the external symbol table as well as the debug information.
New features for Version
4.0-62
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieving this.
This release is primarily being made to provide a fix
for a libc error that affects debugging programs optimized with "Spike".
New support
for Fortran 90 Intrinsic Procedures
Ladebug now supports the kind type category of Fortran 90 intrinsic procedures
in addition to those in the mathematical category (as described in the
Compaq
Fortran Language Reference Manual, which discusses categories of intrinsic
functions).
New Debugger Variable
$cursrcpc
This new variable contains the most recently listed PC address.
New command line
option -interactive
This option makes Ladebug act as though stdin is tied to a tty
device regardless of whether it really is or not. This is sometimes
useful when using rsh to run Ladebug. Currently, the only effect
is to cause Ladebug to output a prompt to stdout when it is ready
for the next line of input.
New features for Version
4.0-61
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieving this.
This release is primarily being made due to demand for bug fixes. See
the 4.0-61 Problems Fixed section for details.
Version 61 follows directly on version 59; there was no formal version
60, though a patch kit with that number was sent to some customers.
New meaning for px alias
The aliases px, pd and po used to expand to
a printf of the first longword of the referenced value; this meant
that px of a structure would not show the fields of the structure.
We have changed these aliases so that they now refer to new commands
(printx, printd and printo), which will not
only change the display radix, but will also show the fields of structures.
The example below shows the new result, as well as a
printf command
to simulate the old result:
(ladebug) print a
struct S {
i = 12;
c = '\211';
}
(ladebug) printf "0x%lx", a
0x890000000c
(ladebug) px a
struct S {
i = 0xc;
c = 0xffffffffffffff89;
}
Display of bitfields in registers
Bitfields in registers can now be printed.
New command unrecord
A new command unrecord has been added; it will turn off the specified
recording (input, output or io).
Previously, to turn off recording, users had to set recording to /dev/null.
Improved handling of C++ interludes
When there are derived classes with virtual methods, and multiple inheritance,
the compiler sometimes generates 'interludes' - small functions that adjust
the 'this' pointer as part of a virtual call.
Setting a breakpoint in such an interlude, such as by either of the
two commands below
(ladebug) stop in __INTER__Top_f_Base_Xv
(ladebug) stop in b->f
now results in the breakpoint actually being set in the virtually called
method - much closer to what the user probably intended.
This makes the interlude be just part of the set-up sequence of instructions
for the virtual method - even though physically separate from it.
To actually break on the interlude itself, use the "stopi" command and
the actual address of the interlude in the machine code:
(ladebug) stopi at &__INTER__Top_f_Base_Xv
Improved handling of C++ downcasts
Given arbitrary multiple inheritence including virtual inheritence...
class Base1 { ... }; class Base2 { ... };
class Middle : public Base1, public virtual Base2 { ... }
class Top : public Middle { ... }
Top top;
Ladebug now does the right things when you
() cast objects (ladebug) print (Base2)top
() cast pointers (ladebug) print (Base2*)&top
() call methods (ladebug) print top->virtFunc()
(ladebug) print (Base2*)&top->virtFunc()
(ladebug) print ((Base2)top).virtFunc()
Pick-lists for multiple files
Where there is more than one file which might have been specified, the
user is given a pick-list to select from:
(ladebug) file a_multi_unit.ada
Select from
----------------------------------------------------
1 a_multi_unit.ada containing int YI
2 a_multi_unit.ada containing void Z_foo(void)
3 a_multi_unit.ada containing void Y_foo(void)
4 a_multi_unit.ada containing int ZI
The debugBreak function
debugBreak is a function that can be added to any program. When
the
debugBreak function is called, it creates a Ladebug debugger
process with the initialization needed to connect the debugger (via attach)
to the program. This process invokes the debugger, positioned at the prompt,
with control over the program just after the debugBreak call.
The id of the process calling debugBreak is stored in the new
debugger variable $exitonterminationofprocesswithpid. The debugger
will exit after debugBreak if the process runs to completion under
the debugger.
For a detailed discussion on how to use debugBreak, please
refer to the Ladebug Debugger Manual.
Improvements to GUI
GUI improvements:
-
Support for selection panels and wizards being in thier own "plane" window
(without a menu bar).
-
Breakpoint editor wizard.
-
Use x,y coordinates if specified.
-
runArgs made temporary.
-
Debugger output window always appears on startup.
-
Better support for attach.
-
Better performance.
-
Better "interrupt" support.
-
dxladebug will now be executing a script that calls ladebug
-gui, supporting compatibility with old Ladebug command line.
Improvements to performance
Performance improvements:
-
Performance improvement to "step" for lines with lots of instructions.
-
Performance improvement to trace.
-
Performance improvements to symbol lookup.
Miscellaneous improvements
-
Better echoing of escaped characters in aliases.
-
Command call is enabled on Linux.
-
Better handling of namespaces.
Please also see New features
for Version 4.0-59 for a list of recently introduced features,
including a new graphical user interface.
New features for Version
4.0-59
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieving this.
This release is primarily being made due to demand for bug fixes. See
the 4.0-59 Problems Fixed section for details.
Please also see New features
for Version 4.0-57 for a list of recently introduced features,
including a new graphical user interface.
New debugger control variable $lasteventmade
A new debugger control variable $lasteventmade has been created.
It contains the number of the most recently-created event (breakpoint,
watchpoint, catch, etc.). The intended use is the support of complex
debugger command scripts in which the user wishes to enable (or disable
or delete, etc.) events created in the script.
New command option -V
A new option to the ladebug command has been added. The -V
option will cause the Ladebug debugger to print its version number and
terminate.
New features for Version
4.0-58
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieving this.
This release is primarily being made due to demand for bug fixes. See
the 4.0-58 Problems Fixed section for details.
Please also see New features
for Version 4.0-57 for a list of recently introduced features,
including a new graphical user interface.
Logical Data Type Support in Fortran
Ladebug now supports tracing of logical variables and comparison of logical
values with other logical values and with integer values.
New features for Version
4.0-57
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieving this.
This release is primarily being made due to demand for bug fixes. See
the 4.0-57 Problems Fixed section for details.
New Graphical User Interface
This version of Ladebug includes the new Graphical User Interface (GUI).
This interface presents a source-code centered view of the application
being debugged. Although it does not yet support all of the Ladebug command
line functionality, it does provide the core commands needed for most debugging
sessions. The commands not supported may still be entered at the terminal
window in which the debugger and gui are running.
To start the GUI, use the -gui switch on the Ladebug command line when
starting it up, or enter the "gui" command anytime during a command line
debugging session. We are eager to hear feedback on the new GUI. It will
be used to guide development of future releases.
Note that the new GUI does not work with FUSE.
New Command-- edit
Use the edit command without an argument to bring up an editor
on the current source. Specify a file to bring up an editor on the specified
file.
Ladebug evaluates the EDITOR environment variable to pick an editor.
It will default to 'vi'.
New Predefined Aliases-- printd,
printo,
and printx
Three predefined aliases are added in this release:
-
printd is the alias for printf "%ld",
-
printo is the alias for printf "0%lo",
-
printx is the alias for printf "0x%lx",
They are added for dbx friendliness. Meanwhile, two unsupported aliases,
sb
and sj, have been removed.
New Debugger Variable-- $curfilepath
$curfilepath has the value of the access path used to find the
current file (relative if relative, absolute if absolute). It can help
users debug their map source directory and use commands.
Better Fortran Support
Ladebug now supports invocation of generic and specific Fortran 90 intrinsic
procedures in the Mathematical category as described in the Compaq Fortran
Language Reference Manual. Ladebug also supports the exponentiation operator
for non-complex operands.
Shell-like Treatment on run/rerun
Arguments
Ladebug now treats arguments to run/rerun commands in
a shell-like manner, supporting tilde(~) and environment variable expansion,
wildcard substitution, single quote('), double quote("), and single character
quote(\).
Comprehensive Diagnostic Message when Ladebug
Cannot Find a Source File
In this release, Ladebug emits a more comprehensive diagnostic message
when it is unable to locate a source file-- it prints out the pathnames
that it tried and failed.
New features for Version
4.0-56
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieving this.
This release is primarily being made due to demand for bug fixes. See
the 4.0-56 Problems Fixed section for details.
More dbx Friendly Features
When the debugging variable $dbxoutputformat is set to a non-zero
value,
-
the command assign echoes the assigned value, and
-
the command process displays information about the process that
is being switched to.
For example,
(ladebug> set $dbxoutputformat = 1
(ladebug) run
[1] stopped at [int main(void):18 0x120001104]
18 x.op = 6;
(ladebug) assign x.op = 9
9
(ladebug) show process *
>localhost:25965 (qq) paused.
localhost:26133 (www) loaded.
(ladebug) process www
Current Process: localhost:26133 (www) loaded.
New features for Version
4.0-55
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieving this.
This release is primarily being made due to demand for bug fixes. See
the 4.0-55 Problems Fixed section for details.
Support for Reflexes
We introduce the concept of reflexes in this release. Reflexes are
a generalization of various detector-reaction operations in Ladebug, such
as breakpoints, watchpoints, and signal and unaligned catching. The syntax
for reflex creation is designed in such a way that it is backward compatible
with the syntax for breakpoint creation, except in the case of "stop <
exp > ", which in the old days meant "stop when the value of < exp >
changes", and now means "stop in < exp > if < exp > is a function
name; otherwise, stop at line < exp > ." Therefore, the user should
notice minimal differences when creating breakpoints. Enter 'help stop'
at the prompt to learn more about reflexes.
Support for Source Directory
Mappings
Source directory mappings enable Ladebug to look for source files in directories
other than the ones provided in the debug info. To learn more about this
feature, enter 'help map source directory' at the prompt.
More Debugger Variables for customizing
the Look of Ladebug
For users who prefer the look of dbx
,
this release provides three new debugger
variables for customizing Ladebug to look more like dbx
. These variables
are $showlineonstartup
, $showwelcomemsg
,
and $giveladebughints
.
Enter 'help
$variable
' to see their usage.
The Old GUI dxladebug Is Dropped
from the Kit
We no longer support dxladebug.
New features for Version
4.0-54
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieving this.
This release is primarily being made due to demand for bug fixes. See
the 4.0-54 Problems Fixed section for details.
New debugger variable $funcsig
A new debug variable, $funcsig, has been added which controls the display
of function signatures when the debuggee program is stopped.
Additional support for Fortran dynamic
arrays
This release of Ladebug contains symbolic info parsing support for the
fortran array descriptor format produced when "-ladebug" is not specified
on the compile line
New Graphical User Interface incorporated
into Ladebug image
This release incorporates the Beta release of the new GUI into the Ladebug
image. This GUI shows the style and direction of the Ladebug GUI effort.
It is provided for comment and review. Future releases will continue to
refine and develop this GUI.
Support for Extended Source Line Information
This release of Ladebug contains symbolic info parsing support for Extended
Source Line Information.
New features for Version
4.0-52 & 4.0-52gui
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieving this.
This release is primarily being made due to demand for bug fixes in
the debugging support for multi-threaded processes. See the 4.0-52
Problems Fixed section for details.
New Graphical User Interface
This release of Ladebug includes the Beta release of the new GUI for comment
and review. This GUI shows the style and direction of the Ladebug GUI effort
. Future releases will continue to refine and develop this GUI.
For this release the GUI focuses on the operations needed to perform
basic source code level debugging. More features will be added in future
releases. Any feature not directly supported through the GUI can still
be entered in the terminal window from where Ladebug was originally invoked,
the GUI will stay in sync with the engine, in this case. A web-based help
system is provided with the new GUI to aid in using and understanding it.
To invoke the new GUI:
-
<unix prompt>ladebug -gui <other engine command line options
and arguments>........or
-
-
<unix prompt>ladebug <engine command line options and arguments>
and enter the gui
command at the ladebug prompt whenever you wish to see the GUI (See
Caveat 3.)
Caveats and Tips
-
A lot of functionality is still not implemented
-
The HELP text is slightly out of synch with the implementation, due to
changes made as a result of internal reviews. The gist of the help text
is still valid
-
To exit the GUI select the X in the upper left corner of the topmost panel.
Note that this leaves the engine running. Currently, if you exit the GUI
then restart it in the same session, you will lose the current state of
your debug session, and the application will be restarted.
Attaching to a process without
specifying an image name
Ladebug now allows the user to attach to a process without specifying an
image name. The attach command has been changed to have the following syntax:
attach <pid> [image-name-optional]
If the image name is not given, the image name of the current process is
assumed.
New dbx-compatible commands
<number.exp> cont <signal>
Continues the program execution and ignores the next (<number.exp>+1)
breakpoints.
conti to <address.exp>
Continues the execution of the process until the instruction at <address-exp>
is about to be executed.
New debugger variables
-
$dbxuse, defaults to 0
Ladebug's "use" command (use [a sequence of dir names])
appends the [dir names] to the existing use list. This is different
from the "use" command in dbx, which replaces the existing list
with [dir names]. By setting $dbxuse the user can select
between the two flavors of "use": When $dbxuse is set
to a non-zero value, the "use" command replaces the existing use
list, otherwise "use" appends to the existing use list.
-
$curprocess
Contains the pid of the current process.
-
$dbxoutputformat, defaults
to 0
When this variable is set to a non-zero integer, Ladebug will print
values of structs and arrays using dbx's formats.
-
$statusargs, defaults to 1
If it is set to zero, the call stack will be printed in a non-verbose
fashion (no parameters).
-
$doverbosehelp, defaults
to 1
When $doverbosehelp is non-zero, a help request on
an unrecognized command invokes the intro to help system; when $doverbosehelp
is zero, the intro to help system is suppressed.
Improved behavior of the record command
When the file name is not specified in a "record" command, we
create a new file as the recording file in /tmp whose name is
suffixed by a running number. A number is skipped if the file ended in
that number already exists (as you can see here, my /tmp is filled
with ladebug-record-io-00[01-13]). The file name is echoed so
the user knows which it is.
For example:
% ladebug
Welcome to the Ladebug Debugger Version 4.0-52
(ladebug) record io
I/O recorded in file /tmp/ladebug-record-io-0014
(ladebug) record input
Input recorded in file /tmp/ladebug-record-input-0015
(ladebug) record output
Output recorded in file /tmp/ladebug-record-output-0016
Support for debugging optimized code that
has discontiguous scopes
Added support for debugging optimized code that has discontiguous scopes.
New features for Version
4.0-51
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieving this.
This release is primarily being made due to demand for bug fixes in
the debugging support for multi-threaded processes and core files. See
the 4.0-51 Problems Fixed section for details.
New features for Version
4.0-50
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieving this.
This release is primarily being made due to demand for bug fixes in
the debugging support for hard partitioned systems. See the 4.0-50
Problems Fixed section for details.
New features for Version
4.0-49
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieve this.
This release is primarily being made due to demand for bug fixes in
the debugging support for hard partitioned systems. See the 4.0-49
Problems Fixed section for details.
New features for Version
4.0-48
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieve this.
This release is primarily being made due to demand for support of Fortran
static links, support for compressed files, performance improvements and
as a vehicle for fixing bugs.
snapshot functionality
You can save the current state of the debuggee process in a snapshot, and
later "return" to that state and try a different set of steps.
Conceptually speaking, this feature is similar to the "undo" function
in text editors, except that with snapshots you have the control of the
granularity of each undo.
Limitations: Snapshots are actually implemented by causing the process
to fork.
-
The state saved in a snapshot doesn't cover I/O and forks. In other words,
when you clone a snapshot, the I/O that has been done since the snapshot
was saved is not undone; likewise, the child processes that have been spawned
since the snapshot was saved are not killed.
-
'save snapshot' saves the state of the current process only. If you are
doing multiprocess debugging, you might want to save a snapshot for each
process.
-
Snapshots on a multithread process are not supported.
For more information, type "help snapshot"
Support for debugging compressed files
Ladebug will now automatically decompress compressed executables rather
than depending on the user to decompress them.
Ladebug looks first in the current directory for any file that is reported
as coming from "/subsys" - these are usually a loadable driver. This means
that
-
users don't have to leave buggy drivers in "/subsys" to debug them,
-
users can copy kernel dumps and associated loadable drivers to another
platform for debugging.
Support for split lifetime local variables
This is a new capability in 4.0-48, but is latent until the compilers produce
the necessary information. It enables the debugger to more accurately locate
and evaluate variables in optimized code.
Support for static links
Ladebug now correctly examines variables that are up-level accessed using
static links. This mainly is an issue for optimized Fortran programs that
have had loops decomposed into threads. The debugger, when debugging these
threads, can now examine the variables outside the loop but inside the
function containing the loop.
Ladebug now linked against libcxx.a
Ladebug is linked against libcxx.a rather than libcxx.so, so it is not
dependent on the version of C++ or the C++ RTL installed on your system.
Better handling of recursive functions
Recursive functions are dealt with more cleanly by the 'next',
'nexti',
'step',
and 'return' commands. Prior to 4.0-48, Ladebug would break in
a called function that happened to execute the next line or the address
being returned to. Ladebug now checks either the $sp ('return')
or the $vfp ('next', 'nexti',
'step') to see
if is the expected stack frame. We expect to only test the $vfp in
a future release.
thread command now accepts an expression
The thread command nows takes an expression, not just an integer
literal, as its argument.
Modified output for listobj command
The listobj command output has changed to show the mapping of
the .text, .data, and .bss sections of each of the loaded files.
Modified name lookup
We are changing Ladebug's identifier lookup to more closely follow the
language model. In this version, Ladebug does a language-model-based lexical
scope lookup for symbols. Occassionally this means it no longers finds
symbols that it used to find - especially when it should not have found
them.
More information from where command
Ladebug no longer filters out __start from the where command call-stack
output - thus providing a more truthful picture of the real state of the
program's execution.
Optionally mmap a loaded file
It is possible for very large applications to save some amount of swap
space by having Ladebug mmap the loaded file's, rather than reading portions
of them into heap-allocated storage. Defining the LADEBUG_CAN_MMAP_THE_FILE
environment
variable turns this latent capability on. We have not turned it on by default
because
-
it doesn't make much difference for smaller applications,
-
we have not given it sufficient testing,
-
we are not sure how it will behave when you keep the same Ladebug session
going, but replace the loaded file on disk.
2.47 What's new at Version
4.0-47
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieve this.
This release is primarily being made due to demand for Namespace support
by C++ developers and as a vehicle for fixing bugs.
Support for C++ "using" declarations
Support has been added for C++ "using" declarations.
Better symbolization
When printing a stack trace, Ladebug now prints the name of the .so
file which contains a function, if it cannot find out the actual source
filename due to missing debug information.
This situation arises for compilations using the -g0 qualifier.
More information from which command
The which command was modified to provide more extensive information.
2.46 What's new at Version
4.0-46
Background and Cautions
This release of Ladebug comes at a time when the project is only part of
the way through a significant re-engineering of much of the internal structure
of the product. The project has a long range goal of fixing many of the
performance and reliability issues it has had, and has chosen the restructuring
as the best approach to achieve this.
This release is primarily being made due to demand for Namespace and
Template support by C++ developers.
Requirements
This version of Ladebug requires that users have C++ version 6.0 installed
on their Digital Unix 4.0 (or later) systems, due to a shared library dependency.
Limited support for C++ Namespaces
This release adds limited support for C++ namespaces. The usual C++ qualified
name syntax for namespace components is now supported:
NamespaceId {::namespecId}::id
The anonymous namespace is not yet properly supported.
Using namespace declarations or definitions is not yet supported.
Implicit visibility into namespaces is not supported.
More support for C++ Templates
The use of templates can cause a source file to be compiled into several
.o
files. Limited support has been added for this situation (which can also
arise due to code in .h files).
Output pagination support
Two new debugger variables provide user control of output pagination.
-
$page turns pagination on (when set
to 1) and off (when set to 0)
-
$pagewindow can be set to the maximum
number of contiguous lines which will be considered to be in a page. When
set to 0 it is ignored.
If during the output from Ladebug for a single command, more lines remain
when the first page has been displayed, the user is asked
More (n if no)?
A response of n is equivalent to typing Ctrl-C: the current
command is abandoned as soon as possible, and control returns to the (ladebug)
prompt level. Any other response causes the next page to be displayed.
2.44 What's new at Version
4.0-44
Dynamic Type Member Access
This change allows the user to circumvent C++ visibilities rules regarding
base class pointers referencing derived class objects by directly accessing
(print, whatis) derived class members through a base class pointer when
$usedynamictypes
is set to 1.
watch variable
functionality
This command allows to watch the current storage assigned to the variable.
Using line numbers in expressions
Line numbers can now be used as a part of an expression. In particular,
expressions like
and
now work.
Remote debugging on
DIGITAL UNIX v3.2
This feature is working again, but the user must now use the SECURE_SERVER
for it.
2.43 What's new at Version
4.0-43
Command line interface support for editing lines
which are longer than the screen width
Ladebug now provides an interface for editing long command lines similar
to that provided by the kshell. (DECL 519)
When the length of a command exceeds the width of the screen, part
of a command line is now scrolled out of view and a special status character
is displayed in the rightmost column. There are four possible status characters:
-
the status charcter is blank when the command fits fully on the screen
-
'>' is displayed when there are more characters beyond the right edge of
the screen
-
'<' is displayed when there are more characters beyond the left edge
of the screen
-
'*' is displayed when there are more characters beyond both the right and
the left edges of the screen
You can scroll along the command line using the arrow keys. You can press
<Ctrl-a>
to jump to the beginning of the command line and <Ctrl-e>
to jump to the end of the command line.
Remote
debugging is available on DIGITAL UNIX v4.0
This was accidently broken in the previous release. This version fixes
it.
3. Known problems and restrictions
Each subsection below documents known problems and restrictions related
to one of the following topics:
3.1 Known general problems and restrictions
with the Ladebug Debugger
The following are known general problems and restrictions with the Ladebug
Debugger:
The Ladebug debugger may crash due to running out of memory when
used to debug analysis-phase routines inserted by the ATOM tool.
This is due to the ATOM tool's not following the calling standard
when it inserts its "trampoline" routines. This causes Ladebug to
become confused about the state of the execution stack and crash.
There is no work-around.
The Ladebug debugger may not be able to see some routine parameters
when used to debug optimizied code. This is because the compiler
back end is not producing debug information which correctly describes
the parameters.
There is no work-around.
DECthreads debugging on V3.2
This release of the Ladebug debugger does not support DECthreads debugging
on the DIGITAL UNIX V3.2 platform. Kernel threads debugging, however, is
supported on this platform and both kernel threads and DECthreads debugging
are fully supported on the DIGITAL UNIX V4.0 platform. DECthreads debugging
on the V3.2 platform was most recently supported in Ladebug versions 4.0-14
and V4.0-14A.
Running the debugger hangs or halts V4.0B
There is a problem with using any version of ladebug (or dbx) on certain
systems that are running DIGITAL UNIX 4.0B. The problem is that some systems
will hang or crash when the debugger is used.
The machines affected are the newer machines, such as the AlphaStation
500 and 600 series machines. This is not a problem for other machines such
as DEC 3000s and DEC 4000s.
A kernel patch is required to fix this problem. From the 4.0B patch
kit, install the following patch:
NEW PatchID: 91.00 PATCH ID: OSF410-053 SUBSET(s):
OSFBIN410
When using setld to install the 4.0B patch kit, look for the new PatchID
in the subset menu display to select the correct patch. The patch description
is: "Patch: Kernel Debugger Corrections".
Restrictions due to
C++ compiler bugs
-
There is a known bug with the C++ compiler introduced between v5.1-1 and
v5.3 that will prevent Ladebug from displaying the correct value for a
derived class that inherits virtually from more than one of its base classes.
-
There is a known bug with the C++ compiler introduced in v5.4 that may
prevent Ladebug from printing the correct return value of a virtual function.
When incorrect, the return value is printed as being 'void' instead of
its actual value.
Reducing the Size of Debuggable Binaries
It is often the case that when a bug is reported to the
Compaq Ladebug team, and we have looked over the .o
files and .so
files,
etc.
that were sent to us that we find that Ladebug
is just being swamped by the size of the .so
debugging information.
The basic reason your .o
and .so
files may be so large is the duplication
of information in them, caused by the many interrelationships amongst the
classes in your application.
Using the C++ -g
rather than -gall
switch can radically reduce the size
of your binary files. Further reduction can be attempted using an undocumented
feature of the V5.6 C++ compiler. The compiler can be directed to put out
each class once, and only once, into a set of .o
files. The debugger will
then find this single occurrence when debugging the application containing
all these .o
files.
This is done by defining the environment variable
CXX_DEBUG_INFORMATION_CACHE
to be the full file-name of an empty file before invoking your make
script:
setenv CXX_DEBUG_INFORMATION_CACHE
$TMPDIR/136132834732823953.txt
rm -f $CXX_DEBUG_INFORMATION_CACHE
touch $CXX_DEBUG_INFORMATION_CACHE
make -f your_make_script
rm -f $CXX_DEBUG_INFORMATION_CACHE
unsetenv CXX_DEBUG_INFORMATION_CACHE
We would be interested in seeing how much this capability reduces the size
of the .o
and .so
files in your application. It may well reduce them to
the point where Ladebug can swallow the lot...
We also recommend keeping both stripped and non-stripped executables,
and using the stripped ones when you are debugging a different binary file
that needs the presence but not debuggability of a some shared libraries.
This will also improve Ladebug startup times.
Apart from these approachs, the only other approach we can suggest is
compiling most of your sources -g0
, and compiling just a small subset
-gall
.
System Patches that Ladebug Users should Install
The following Compaq Tru64 Unix patches clear up various Ladebug problems
that have been reported to us. Customers can get these from
http://www.service.digital.com/html/patch_main.html
The following patches are strongly recommended.
***in all cases***
NEW PatchID: 91.00 PATCH ID: OSF410-053 SUBSET(s): OSFBIN410
New PatchID: 136.00 PATCH ID: OSF410-400239 SUBSET(s): OSFBASE410OSFCMPLRS410
***if you are using AdvFS***
New PatchID: 128.00
PATCH ID: OSF410-400231 SUBSET(s): OSFADVFSBIN410 OSFADVFSBINOBJECT410
System Crashes
Ladebug has no special privileges or hooks into the system, and as such
can not cause any crashes that another debugger or other program could
not also cause, hence such crashes are fundamental system problems, not
Ladebug problems.
However Ladebug does exercise parts of the system (especially procfs
,
ptrace
, and pthreads
)
more than other programs, and hence crashes caused
by these components are seen as 'Ladebug crashed my system', and so the
Ladebug team gets such reports regularly.
The single biggest problem occurs on V4.0B and V4.0C running on some
machines, where using the debugger hangs or halts the system.
The machines affected are the newer machines, such as the AlphaStation
500 and 600 series machines. This is not a problem for other machines such
as DEC 3000s and DEC 4000s.
The problem can be worked around by patching the kernel as follows...
If Ladebug causes a problem even doing this, the user can use dbx to perform
the patch.
% ladebug -k /vmunix
(ladebug) patch db_enable=0
(ladebug) quit
A kernel patch is required to fix this problem.
Ladebug and/or Application
Hangs
Ladebug relies on both the DECThreads and procfs components of the base
system to work. However there have been a series of problems in these components
that cause Ladebug to hang, or incorrectly step, etc. while debugging applications.
Using a 4.0-40 (or later) Ladebug, and installing the latest patches for DECThreads
and the Unix kernel will cause many of these problems to go away. Any further
problems should be reported to the Ladebug team, who will then work with
the appropriate other teams to get the problems resolved.
Here are the relevant patches.
Examining Fortran Arrays
Ladebug's understanding of Fortran expressions is weak, and is an area
where future improvement is being considered.
In particular, arrays of strings are incorrectly understood as though
the array had an extra left-most dimension indexing the individual characters,
rather as though it were an array-of-array-of-character.
For this reason, Ladebug emits the following error message when you
try to use correct Fortran syntax...
(ladebug) print a(1)(:1) print a(1)(:1) ^ Unable
to parse input as legal command or Fortran expression.
Also for this reason, Ladebug accepts expressions that Fortran would not...
(ladebug) print a(1:2,2:3) (2) "ef" (3) "ij"
For the time being, you should use this second form to deal with arrays
of strings.
Dxladebug GUI Problems
Please note that the original GUI (dxladebug) is no longer supported and
has been removed from the Ladebug kits as of version 4.0-55. To obtain
the final version of dxladebug, install the 4.0-52 Ladebug kit.
Hang On Application Input
When the application being debugged waits for input, dxladebug 'hangs'
with none of the controls doing what they are supposed to.
The biggest frustration here seems to be the result of the user simply
not knowing why the GUI has hung - often they are not aware that their
application has stalled waiting for input.
Once the application receives the input it is waiting for, dxladebug
comes to life again.
The problem is still present in the Ladebug 4.0-40 release.
We are investigating why the problem occurs, and will fix it within
the current GUI if the fix is simple and does not endanger the rest of
the GUI.
Workaround: Either use the command-line interface, or provide the input
to the application.
Scrolling Performance
The source display had scroll bars, but terrible scrolling performance.
This was largely fixed in Ladebug 4.0-40 and later releases.
The actual performance of the scrolling was dramatically improved, and
a FIND capability was added.
When using the GUI, if you have more than one Source Viewer up on
different threads, printing variables may not yield the expected
results. This is because the engine's notion of the current thread
and frame may be different from what is viewed in the Source Viewer
where the user is issuing the print
command. The debugger
output window and the DO
button don't send their context
to the engine when sending command requests to the engine.
The current work-around is to click the mouse on the selected frame in
the Source Viewer where you want to print. Then issue the command.
For a list of additional known problems with version 65, see the
known problems with Version 4.0-64.
For a list of known problems with version 4.0-64, see the
known problems with Version 4.0-63.
For a list of known problems with version 4.0-63, see the
known problems with Version 4.0-62.
For a list of known problems with version 4.0-62, see the
known problems with Version 4.0-61.
Problems in Version 4.0-61
For a list of known problems with version 4.0-61, see the
known problems with Version 4.0-59.
Problems in Version 4.0-59
For a list of known problems with version 4.0-59, see the
known problems with Version 4.0-58.
Problems in Version 4.0-58
For a list of known problems with version 4.0-58, see the
known problems with Version 4.0-57.
Problems in Version 4.0-57
For a list of known problems with version 4.0-57, see the
known problems with Version 4.0-56.
Problems in Version 4.0-56
For a list of known problems with version 4.0-56, see the known
problems with Version 4.0-55.
Problems in Version 4.0-55
For a list of known problems with version 4.0-55, see the known
problems with Version 4.0-54.
Problems in Version 4.0-54
The following are known problems and restrictions with the Ladebug Debugger
Version 4.0-54 release:
-
The dxladebug GUI has become non-functional with this release and is no
longer supported.
For a list of additional known problems, see the known
problems with Version 4.0-52.
Problems in Version 4.0-52
For a list of known problems with version 4.0-52, see the list of known
problems with Version 4.0-51.
Problems in Version 4.0-51
For a list of known problems with version 4.0-51, see the list of known
problems with Version 4.0-50.
Problems in Version 4.0-50
For a list of known problems with version 4.0-50, see the list of known
problems with Version 4.0-49.
Problems in Version 4.0-49
For a list of known problems with version 4.0-49, see the list of known
problems with Version 4.0-48.
Problems in Version 4.0-48
For a list of known problems with version 4.0-48, see the list of known
problems with Version 4.0-47.
Problems in Version 4.0-47
For a list of known problems with version 4.0-47, see the list of known
problems with Version 4.0-46.
Problems in Version 4.0-46
The following are known problems and restrictions with the Ladebug Debugger
Version 4.0-46 release:
Problems with very large applications
Very large C++ applications (>50Mb debuggable binaries) may have trouble
with the debugger running out of memory. The internals of this version
of Ladebug contain both the new and the old versions of data structures
that we are re-engineering. For this reason, it can use more memory than
previous versions. This will be fixed in the next version, but for now,
be aware that you may have to increase your datasize limit:
% limit datasize 500000
Very large C++ applications (>50Mb debuggable binaries) seem to have this
problem the most. You should make sure you are using the latest C++ 6.0
compiler, and that you are not using the -gall qualifier too heavily,
since earlier compilers and the -gall qualifier both cause large
debuggable binaries.
Problems with per-routine entry tracing
A Unix kernel bug results in the debugger being unable to insert tracing
breakpoints in some applications. Users will see messages like this:
Warning: Unable to insert breakpoint at 0x3ff80173398.
If the address can be read then you have run into a known operating system
problem which has been reported, but for which a fix is not yet available.
The following shows a way to see if the memory is readable...
(ladebug) 0x3ff80173398/X
0x3ff80173398: 6bfa800147ff0400
Writes to the process using either the procfs
or ptrace
facility are consuming
"mapentries", objects used to map VM space for re-writing the memory.
When all the available mapentries are consumed, further writes can only
happen to pages that have already been written to.
A workaround outside of Ladebug is to bump the maxentries from the default
of 200 to something like 20000 with dbx:
dbx -k /vmunix
assign vm_tune.vt_mapentries=20000
quit
You can also put this in /etc/sysconfigtab as:
vm:
vm-mapentries = 20000
When a patch to the Unix kernel is available, it will be released through
the normal channels.
Within Ladebug, this problem most often arises due to the use of the
stop
<variable> command. Delete any such commands and use
watch
instead; the problem may go away and you will be able to continue debugging.
Note that there will be warnings when the 'stop' is deleted.
Known problems with
handling interrupts
The following are known to be problems with the debugger's handling of
interrupts (Ctrl/C):
-
After pressing the dxladebug GUI "Interrupt" button multiple times
in rapid succession (in an attempt, for example, to halt the display of
a program variable that contains a large amount of data), the dxladebug
GUI will fail with an assertion failure. (LB 2227.1)
-
An interrupt entered when the debugger is loading a program will not halt
the load process.
-
Occasionally, assigning a value to a variable will not work after entering
an interrupt.
-
Occasionally, after an interrupt is entered, the debugger will stop indefinitely
in the routine "__exc_virtual_unwind" after displaying one or
the other of these two messages:
bad
PC (0x5083200000000010) - stack trace not available. PC
is zero - stack trace not available.
Several other problems related to interrupt handling have been fixed in
Version 4.0-43. See the Problems Fixed section
of 4.0-43 for details.
step fails to step into routine
Under certain circumstances the debugger will not step into a called function
when instructed to do so by the debugger "step" command. If the calling
function, function A, is built into a shared library and the called function,
function B, is not built into that shared library, attempts to step into
function B from its call site in function A may not be honored by the debugger,
and program execution will proceed right through function B without stopping.
To work around this problem, set a breakpoint inside function B before
it is called.
Core files produced by cont command
may not be readable
Under certain conditions, the debugger cannot read a core file produced
by the debugger's "cont <signal>" command. When debugging a DECthreads
multithreaded application, and if the "cont <signal>" command is given
with a signal that produces a core file, that core file cannot be read
back in by the debugger.
Release notes under CDE may cause
broken link message
There is a problem with the integration of the release notes into the Common
Desktop Environment. If the Ladebug release notes are not installed on
the system (subsets OSFLDBDOC or IOSLDBDOC), then clicking on the README
icon in the Ladebug application group in the CDE Application Manager will
result in a "broken link" error message.
kdbx hangs on whatis command
A problem with the kdbx debugger, when Ladebug is used as the underlying
debugger engine, causes kdbx to hang when the Ladebug command "whatis"
is issued.
Line numbers may
be wrong after illegal multibyte characters
If a line in a debugger command input file contains multiple illegal multi-byte
characters, then the line numbers displayed in the debugger error messages
will be incorrect.
Register View may hang dxladebug GUI
Manipulating the Register View can hang the dxladebug GUI under the following
conditions: 1) open the Register View 2) click on (select) a value in the
Value/Deposit field in the lefthand side of the register display 3) select
a value in the Value/Deposit field in the righthand side of the register
display. The GUI will then hang, consuming as much CPU as it can get. (LB
2046)
Cannot modify registers
from Register View in dxladebug GUI
Because of the Register View problem that
may hang the dxladebug GUI and other problems with the view, the ability
to modify register values has been disabled.
Memory consumed when using dxladebug GUI
There is a large memory leak in the "ladebug" process when the dxladebug
GUI is used. This is especially true when manually expanding and collapsing
pointers and structure elements in the Locals and Monitor views, or when
the C++ dynamic type feature is used. Memory usage by the "ladebug" process
can quickly grow to 50MB and more. (LB 2053)
This memory leak has been greatly reduced in the 4.0-36 version of the
debugger.
Source view in dxladebug
GUI displays incorrect line after program completion
When program execution completes, the dxladebug GUI Source View will still
display the "execution paused at" arrow at the point where the last breakpoint
was encountered. (LB 2054)
Instruction view in dxladebug
GUI causes error after "detach"
If the Instruction View is open when you detach from the program being
debugged and that program completes, the following error will be displayed,
once for each active breakpoint: (LB 2049)
Internal Error : dbg$search_for_rout : No valid routine at PC =
X
Some buttons may
be incorrectly active in the Source Browser of the dxladebug GUI
In the Source Browser, the "Display Source" and "Set Breakpoint" buttons
are sometimes enabled when they should be disabled (greyed out). (LB 1211)
Using an alias for quit may confuse
the debugger
If you have defined an alias for the "quit" command and issue that alias
in the dxladebug GUI command message view, dxladebug will not exit properly.
(LB 1190)
The dxladebug GUI Source
Browser cannot be iconized
The dxladebug GUI Source Browser cannot be iconized. (LB 1153)
Ladebug may cause a "no
pseudo-terminals available" message
"Error: No pseudo-terminals available - can't start debugger
engine"
This diagnostic means that a communication channel could not be opened
between the dxladebug GUI and the Ladebug engine. If you see this diagnostic,
you need to add more pseudo-terminals to your kernel.
3.2 Known problems and
restrictions with the Ladebug Debugger and Fortran
The following are known problems and restrictions with the Ladebug Debugger
Version 4.0-41 and Fortran:
Debugging information problems
with V3.5 compiler
Problems with the V3.5 Fortran compiler will result in unreliable debugging
information in Ladebug. These problems are corrected in the V3.6 Fortran
compiler.
3.3 Known problems and
restrictions with the Ladebug Debugger and threads
The following are known problems and restrictions with the Ladebug Debugger
Version 4.0-40 and threads:
Thread context may change
after "step[i]" or "next[i]"
The step and next commands execute lines of source code based on the current
thread context. The thread context may change after the operation is performed.
Similarly, the stepi and nexti commands execute machine instructions
based on the current thread context.
Some commands need a running
thread
When debugging a DECthreads application, the step, stepi, next, nexti,
and call commands can only be performed on running threads.
3.4 Known problems and restrictions
with the Ladebug Debugger and FUSE
From 4.0-54 on, the new GUI no longer works with FUSE.
3.5 Known problems
and restrictions with the Ladebug Remote Debug Server
The following are known problems and restrictions with the Ladebug Remote
Debug Server:
Commands using signals are not supported
For remote debugging, no commands are supported that make use of signals;
in particular:
cont <signal> catch <signal> ignore <signal>
Cannot set breakpoints in shared
libraries
In remote debugging, you cannot set breakpoints on functions in shared
libraries (although you can now debug programs using shared libraries).
Process exit code may be wrong
When a remote process exits, the exit code is always returned to the debugger
as 0, whatever the real exit status.
Processes may be left after run
When the server is run, processes may be left over afterward if the system
is heavily loaded. The leftover processes must be killed manually.
Multithreaded applications
are not supported
Multithreaded application debugging support is not available in the Remote
Debug Server.
Attach and detach commands are
not supported
The "attach" and "detach" commands are not supported.
The -pid option not supported
The "-pid" option is not supported.
4 Reporting problems
If you have any problems with the Ladebug debugger, please let us know.
When reporting problems, include as much information as possible to help
with diagnosis and resolution of the problem. Useful information would
include (but is not limited to):
-
The Ladebug version number as reported in the "Welcome" banner.
-
The source code of a sample program or an executable binary that demonstrates
the problem.
-
The steps necessary to rebuild the sample program or executable binary
that demonstrates the problem.
-
The version(s) of the compiler(s) used to build the sample program or executable
binary that demonstrates the problem.
-
The exact steps used to reproduce the problem.
-
If the executable program is compiled with a compiler that supports the
"-P" option, please include a .i or .ixx file.
-
The system configuration:
-
the type of hardware (e.g. AlphaStation 600)
-
the version of the operating system (e.g. output of uname -a)
5 Problems fixed
When two breakpoints were triggered at the same time,
and one of them was marked as quiet
, Ladebug sometimes reported
the quiet breakpoint as the reason for the stop rather
than the non-quiet one. V65 fixes this anomaly (The original problem report
is in DECLADEBUG 2059).
This problem was reported in DECLADEBUG 2144. A BLISS language symbol should
be searched for in a case-insensitive way. V65 fixes this problem.
The Ladebug debugger no longer displays duplicate native thread
entries in the output of show thread
.
- Fixed
DECLADEBUG 2131
- Ladebug would crash while reading Coff Symbol tables where procedure signature entries are encountered within the description of a class.
- Fixed
DECLADEBUG 2113
- GUI preference window was too small.
- Fixed
DECLADEBUG 2139
- Assertion failure when reading unnamed symbols in debug info.
- Fixed
DECLADEBUG 2148
- Ladebug would crash when $threadlevel
is set.
- Fixed
DECLADEBUG 2149
- Assert on some executables processed
by the spike
tool.
-
Fixed
DECLADEBUG 2153
- Ladebug would SEGV when doing a
next
on an attached threaded application.
-
Fixed
DECLADEBUG 2163
- Ladebug would crash due to a dangling reference within Ladebug.
Some libraries and the objects produced by some compilers produce
debug information in records called "stabs". If an application is
built using the COFF file format, the stabs will be encapsulated in
COFF records which can sometimes have incorrect fields (for example,
specifying a routine which didn't exist in the procedure descriptor
table).
Ladebug does not understand the stabs format, and would raise an
assertion failure when
it saw a COFF record with an incorrect field, ending the debugging
session.
Ladebug now checks for the existence of the symbol @stabs
in a
file; if it sees that symbol, it assumes that the file contains
stabs encapsulated in COFF and will stop processing the debug information
from that file. This means that the file's symbolic information will
not be known, and that users will have to debug inside it at the
machine-language level.
The patch
command modifies the running program and the on-disk
executable file as well. To allow users to revert back to the old
file, Ladebug tried to save the original executable file by changing
its name and copying it.
Two patch
commands in a row would defeat this: the original file
would be replaced by the result from the first patch. This bug has
been fixed.
More recent versions of the operating system will prevent Ladebug
from modifying the on-disk file when a process made from it is running.
This can be worked around by moving the file to another name and then
copying it back to the original name. This work-around is now part of
the patch
command's action.
In an effort to be more comprehensible, the files have been given
clearer names. If your original executable was named prog
,
the saved original is now named prog~backup
. A temporary
intermediate patched file resulting from the use of the work-around will
be named prog~temp
. The current patched file being
debugged will be named prog
.
Ladebug now shows the user all the decimal digits required to correctly
represent the actual bit pattern in a float, double, or long double.
Though the default presentation Ladebug used to use often leads to
more "natural" looking numbers, correct presentation can be important.
The default presentation of float is 6 digits, of
double is 16, and of a long double is 33 digits; truthful presentation
requires 9, 17 anbd 36, respectively.
Before this fix, if the user had printed a value and used
the result as an input to Ladebug, the resulting bit pattern might not be the
same as that in the value printed. Here's a short example from
Ladebug Debugger Version 4.0-63:
(ladebug) p f
3.14159
(ladebug) assign f2 = 3.14159 # Cut-and-paste value from above
(ladebug) p f2
3.14159
(ladebug) p f == f2 # They are unequal!
0x0
(ladebug) px f, f2 # And the actual bit patterns differ
0x40490fdb 0x40490fd0
and the correct result in Ladebug Debugger Version 4.0-64:
(ladebug) p f # Show correct number of digits
3.14159274
(ladebug) assign f2 = 3.14159274
(ladebug) p f2
3.14159274
(ladebug) p f == f2 # They are equal, as they should be
0x1
(ladebug) px f,f2 # And the bits are equal
0x40490fdb 0x40490fdb
For another example, if Ladebug were to use the default representation, some
miscompares in user code might not be obvious.
If the application's code had a compare using only
the default six digits of precision, such as
if (f == 3.14159)
and the user used Ladebug to print the value of "f", then if "f" were printed with the
default precsion, it might well be the case that "f"'s value would also be printed as
3.14159. But those two values might actually be different and the control expression
would evaluate as false. Some actual possible values near 3.14159 are printed
correctly as:
3.14159226
3.1415925
3.14159274
3.14159298
3.14159346
and yet each would be printed as 3.14159 using the default precision.
This bug was reported by Steve Hobbs in DECLADEBUG 2024. The correct number
of digits to present taken from ANSI IEEE standard 754-1985.
- Fixed
DECLADEBUG 2000
- A bug in the calculation of octal values.
- Fixed
DECLADEBUG 1204
- Ladebug had problems printing union members.
- Fixed
DECLADEBUG 1947
- Ladebug would crash when switched to native
thread mode while debugging a pthreads core file.
-
Ladebug on Alpha Linux can now identify the dynamic type of a pointer or
reference.
-
Improved the Fortran common block support for Linux. Ladebug now knows the names
of common blocks, and how to print both the whole block and its individual members.
-
We have fixed various problems with Ladebug's ability to call both C and Fortran
functions. You can now call many Fortran functions. Ladebug doesn't support calls
that require descriptors.
-
Fixed
DECLADEBUG 2042
- Ladebug couldn't properly edit screen lines
longer than 100 characters (approx).
-
Fixed
DECLADEBUG 2043
- $i++
didn't change $i
.
Ladebug expressions
involving setting debugger variables did not actually change their value. To
change the value of a debugger variable, you had to use a set
command.
Now you can use expressions like $i++
, although string
assignment is not implemented (nor is it implemented for program variables).
-
Ladebug now supports the representation of addresses in the kseg segment,
for use in kernel debugging, by the use of a
0k
prefix followed
by hexadecimal digits for the segment offset of the
address. E.g., 0k123abc
represents the address at offset
0x123abc
in the kseg
segment.
-
Fixed
DECLADEBUG 2036
- Ladebug would throw an assertion failure when
reading the symbol table of an atomized program.
-
Fixed
DECLADEBUG 2068
- Ladebug used to print long double NaNs
(Not a Number) as
"NaNNaN.0" and long double Infinities as "InfinityI.nfinityE+07". This has been fixed.
-
Fixed
DECLADEBUG 2074
- A fatal error which occured when $lang
was set to "java".
-
Fortran array slicing and bounds checking now have better behavior. Work in
this area fixed
DECLADEBUG 2007
(an assertion failure while
printing an array slice with member selection) and eliminated a crash described in
DECLADEBUG 1671
, although setting watchpoints on whole Fortran arrays
or sections of Fortran arrays is still not supported.
The -I
qualifier no longer needs a space between it and
the directory entry, so users may cut and paste Ladebug command arguments
from their compiler command line to the Ladebug command line.
This was reported in DECLADEBUG 305
.
Setting $threadlevel
now expresses a preference (which is sticky) rather
than forcing the actual threadlevel to a level not currently supported by the
application or the debugger.
Reading $threadlevel
shows the current thread level, which may not match
your preference.
For whatis Foo::u
, where the type of u
is an anonymous
union declared within class Foo
:
Old Form New Form
union Foo:: { union {
int x; int x;
char c; char c;
} Foo::u; } Foo::u;
This was reported in DECLADEBUG
note 888.
-
Fixed
DECLADEBUG 1893
-
C language struct
members whose names
began with "__"
were being hidden from the user.
-
Fixed
QAR 50164
-
Ladebug could crash when debugging a target
application which had a very deep stack (usually due to recursion).
The crash was fixed, and some performance improvements for dealing with
deep recursive call stacks were made.
-
Fixed selection from a namespace alias using the syntax
aliasOfANamespace::member
.
-
Fixed
DECLADEBUG 1716
- Ladebug was
not finding members of anonymous unions inside C++ classes.
-
Fixed
QAR 33160
- Improve the way Ladebug outputs Cobol types and groups.
-
Fixed
QAR 35734
- Ladebug didn't always correctly interpret
the C++ global scoping operator (::
).
-
Fixed
QAR 49914
and QAR 49915
-
Ladebug now adds symbols from the external symbol table
to its internal tables when the symbols are not already there.
This makes symbols like __istart
visible.
-
Fixed
QAR 52599
- Ladebug didn't deal with
weak procedure symbols properly.
-
Ladebug required a running process before
it would let users "call" a function, but it did not require one before
attempting to print an expression including a function call. Such a
call could lead to incorrect results and unexpected signals. Ladebug
now checks for a runnable process when evaluating a call in an
expression.
-
Fixed
DECLADEBUG 1949
-
Better handling of incomplete symbol table struct
descriptions
for the C language.
-
Fixed
DECLADEBUG 1966
-
The quiet
specifier didn't make a breakpoint actually be quiet.
-
Fixed
DECLADEBUG 1543
-
Ladebug would SEGV
when trying to run a process loaded as
a core file.
-
Fixed
DECLADEBUG 754
-
whatis
of a variable declared as being of a typedef type
should report the typedef name, rather than the meaning of the typedef
name.
-
Fixed
DECLADEBUG 1839
-
Several problems where Ladebug misunderstood the size of pointers
and references in sources compiled with -xtaso_short
.
Problems fixed in the Ladebug Debugger Version
4.0-62
Debugging programs
optimized with "Spike"
If your application has been optimized by the "Spike" tool using performance
feedback, and you debug the application, in certain cases the call stack
will not be displayed fully by Ladebug. It will terminate too soon
and may be incorrect.
This is a libc error introduced in Tru64 UNIX V4.0D. This error
will be fixed in a future Tru64 UNIX patch release and in the base kit
for a future release of the OS.
In the mean time Ladebug has been modified to work around this problem
if it detects that the version of libc it is using is one with the problem.
Problems fixed in the Ladebug Debugger Version
4.0-61
Miscellaneous
-
Overload pick-lists are now alphabetized.
-
The manual has been improved.
-
Ladebug now looks up C++ constructors and destructors are more correctly.
-
Ladebug now more correctly follows C++ rules about the visibility struct
S {...} S; implies for struct S and S.
-
Ladebug handles C++ pointers and reference types more correctly.
-
Ladebug handles C++ rules about virtual and nonvirtual methods in derivation
hierachies more correctly.
-
Ladebug now gets the correct result (4) for sizeof('a').
-
A number of debugger internal errors leading to SIGSEGVs have
been fixed.
-
Ladebug now does better echoing of strings with escaped characters, such
as "ab\t\007cd".
-
Ladebug handles the C++ use of interludes more correctly.
-
Ladebug now does virtual dispatching calls correctly.
class C { ... virtual int f() ... };
class D : public C { virtual int f() ... };
D d;
C* p = &d;
(ladebug) print p->f() will call D::f
(ladebug) print p->C::f() will call C::f
Ladebug has more support for Fortran 90 optional arguments.
A bizarre consequence of the expression *&array ==- *&array[0]
has been fixed.
A bug in which Ladebug acted as if $stopparentonfork were set
when it was not has been fixed.
Ladebug handles use lists better.
Ladebug now issues a supplementary information line to distinguish variables
that have no value because they were optimized away versus no value at
the current PC (due to splitting).
The bug (LADEBUGBUGS 2641) which could consume all of memory when
unloading or quitting from programs with lots of symbols has been fixed.
The obscure problem caused by the const qualifier being removed
from a virtual function of a base class has been fixed.
Remote kernel debugging works again.
Support for a Zulu kernel trap frame change has been added.
An assertion failure posted in DECLADEBUG 1814 (due to incorrect
information from the compiler for a C++ using directive that references
an incomplete type) has been fixed.
The bug (DECLADEBUG 1752) of not recognizing nested classes as
being the same when they were described by debugging information in different
.o
files has been fixed.
Problems fixed in the Ladebug Debugger Version
4.0-59
Miscellaneous
-
Fixed many bugs in the echoing of commands when $pimode is set
and record io is in effect (More work will be done in this
area in the future).
-
Help text and man page text have been improved.
-
The continue command is accepted as meaning cont.
-
The syntax every procedure entry is accepted as meaning every
proc entry.
-
Nested aliases now expand correctly.
-
Fixed DECLADEBUG 1624, SEGV when attempting to print a debugger
variable.
-
Paging now works with the output of the printenv, setenv
and export commands.
-
Fixed DECLADEBUG 1613, Ladebug can now cope with binaries joined
via the shell command ostrip -j.
-
Fixed DECLADEBUG 1629, made namespace using declarations
visible again
-
Fixed DECLADEBUG 1628, better handling of ignored signals under
linux/ptrace.
-
Fixed DECLADEBUG 1625, C++ interlude functions are now less visible.
-
Fixed DECLADEBUG 1633, Ladebug now allows rerun when there are
breakpoints in dlopen-ed code.
-
The "String is too long to display" error message now includes the name
of the debugger variable.
-
Underscore ("_") is now a legal character in naming an environment variable.
-
Fixed DECLADEBUG 1619, the user is now warned that Ladebug does
not support snapshotting threaded applications.
-
Fixed DECLADEBUG 1654, added detection of Symbol Table format
error (incorrect procedure count).
-
Bugs which prevented remote kernel debugging capabilities have been fixed.
-
Bugs which prevented the patch command from working have been
fixed.
-
Ladebug now allows the whereis ~destructor syntax.
-
Ladebug now allows patching a location not backed by a loadable file.
-
Fixed dropping of a comma when echoing printf commands.
-
Fixed DECLADEBUG 1675, a problem with breakpoints on class member
functions when the application was compiled -g3.
-
Fixed a Ladebug SEGV with file command when no binary is loaded.
-
Ladebug now disallows startup if given an incorrect qualifier.
-
Ladebug now has better handling of unsupported startup qualifiers.
-
Fixed DECLADEBUG 1695, an interaction bug when the same instruction
triggered both a breakpoint and a watchpoint.
-
Better handling for reinstating signal handlers after backtraces.
-
Better representation of C++ unnamed structs/unions.
-
Fixed DECLADEBUG 1695, watchpoints now work properly after a rerun.
-
Added class/struct/union label when displaying C++ nested types
as members.
-
Better handling for debugging of core files with mismatched pthreads libraries.
-
Ladebug now warns users about debugger variables not starting with "$",
and about overlaps between debugger variable names and user program names.
-
Added exit as an alias of the command quit.
Problems fixed in the Ladebug Debugger Version
4.0-58
Miscellaneous
-
Fixed a bug in processing the output pagination control character.
Problems fixed in the Ladebug Debugger Version
4.0-57
Miscellaneous
-
Fixed a bug in looking up a class member class which has opaque base classes.
-
Fixed DECLADEBUG 1603 - Allow evaluating a C++ struct member in
a C context.
-
Fixed DECLADEBUG 1607 - In some situations, debug info entries
for some alternate entry points actually preceed the debug info for the
main entry point. This is a formatting error. Ladebug will report the error
and work around the problematic entries, allowing the users to debug their
program.
-
Fixed DECLADEBUG 1614 - Expand aliases in an alias definition
correctly.
-
Allowed commands in the form of <n> c, which are a shorthand
for <n> cont.
-
Initialized an uninitialed data field.
Problems fixed in the Ladebug Debugger Version
4.0-56
Miscellaneous
Version 4.0-55 segmentation faults if the binary given at the command line
does not exist. 4.0-56 fixed this bug.
Problems fixed in the Ladebug Debugger Version
4.0-55
Miscellaneous
-
Fixed QAR 71758 - Provide better local kernel debugging support.
-
Fixed DECLADEBUG 1076, 1249, 1591 (partial)- Support writing registers
and memory when debugging core files.
-
Fixed DECLADEBUG 1486 - Fix a symbol table parsing bug.
-
Fixed DECLADEBUG 1566 - Expand leading tilde, include ~ and ~,
and environment variables in file names.
-
Fixed DECLADEBUG 1569 - Add a preference for any symbol over a
file name when they have the same name
-
Fixed DECLADEBUG 1582 - Fix a bug in looking up global variables.
-
Fixed DECLADEBUG 1584 - Allow the caller's stack to be in the
"wrong direction" by large amounts.
-
Fixed DECLADEBUG 1590 - Handle long command string.
-
Fixed LADEBUGBUG 2321 - 'whereis' and 'stop in' can take a signature
in C and C++ mode.
-
Fixed handling of 64-bit array indices as part of tqArray_64 support.
-
Made the command 'record output' switch a single tee, so that each overrides
the earlier rather than the previous behavior where each was done as well
as the earlier.
Problems fixed in the Ladebug Debugger Version
4.0-54
Miscellaneous
-
Fixed QAR 70617 - Display SIGABRT instead of SIGIOT when they
are the same.
-
Fixed DECLADEBUG 1521 - Provide better representation for array
pointers
-
Fixed DECLADEBUG 1522 - Allow pointer arithmetics on an array
reference
-
Fixed DECLADEBUG 1528 - Provide better tracing thru _OtsMove
-
Fixed DECLADEBUG 1529 - Fix crash while parsing external symbolic
info
-
Fixed DECLADEBUG 1531 - Add control for printing of function arguments
-
Detaching a snapshot process is no longer allowed.
Problems fixed in the Ladebug Debugger Version
4.0-52
Multi-Threaded Debugging on Multi-CPU
Systems
Fixed numerous issues involving using breakpoints or watchpoints when debugging
pthreads processes on Multi-CPU Systems. These often resulted in the process
being debugged hanging, or receiving spurious signals, or dying upon detach.
Attach and Detach
Make attaching to a process be a lot more innocuous - no longer cause the
process to make further progress, making it easier to debug hangs.
Fixed BCGM113LM, TURRIS::DECLADEBUG note 1353.0:
Detaching from a hung process also hung Ladebug.
Language Understanding
Fix the assertions and other problems associated with Fortran alternate
entry point parameters and dynamic arrays.
Fix some problems with the visibility of global identifiers.
If we can't find main, set the initial scope to the universal scope.
Fix an incorrect handling of -g3 level of debugging. This results
in a more correct representation of fortran procedures compiled under -g3,
going from
<opaque> function other2(integer*4, integer*8)
to
subroutine other2(integer*4, integer*8)
If a procedure contains a static link, but the debugger is unable to
find the ancestor frame referenced by that static link during a lookup,
then warn the user.
Miscellaneous
-
Fixed DECladebug 1443.0 - crashes caused by the show process
command when the process changes.
-
Fixed some obscure problems with function calls that were corrupting Ladebug's
stack occassionally, causing crashes.
-
When the user issues a SIGQUIT, exit quietly instead of
printing a stack trace. This puts SIGQUIT inline with how
Ladebug treats SIGTERM.
-
Don't crash when presented with a bad core file.
-
Fixes assertion failures, etc. when attempting to debug the kernel with
insufficient privileges.
-
Fixed QAR 66003 - some crashes in the old GUI.
-
Fix some of the old GUI's problems with core files.
-
Fixed Assertion failed: !isTerminated() src/appl/procs/process.C 739
-
Fix a memory leak.
-
Fix the SEGVs when "watch", which isn't available under ptrace,
is used with ptrace.
Problems fixed in the Ladebug Debugger Version
4.0-51
Multi-threaded debugging
Release 4.0-50 has problems with debugging an attached multi-threaded processes
and the setting of Ladebug variable $threadlevel. These problems
are resolved in this release.
Core file debugging
Release 4.0-50 has problems similar to the aforementioned ones in debugging
multi-threaded core files. They have been fixed in 4.0-51.
Problems fixed in the Ladebug Debugger Version
4.0-50
Core file debugging
-
Users who are debugging core files on a system different from the one on
which the core file was created are "transporting" core files from an original
system to a user system.
For Ladebug to debug a transported core file, it needs access to the
libraries used by the core file. A new environment variable is now used
by Ladebug to support debugging transported core files.
Before invoking Ladebug, copy the shared libraries used by the failing
application on the original system into a directory on the user system.
Set the environment variable
LADEBUG_COREFILE_LIBRARY_PATH
to that directory. You can now run Ladebug on the core file in a normal
manner on the user system.
This is necessary because core files do not include the contents of
the libraries. They refer to them by pathname in a loader database inside
the core file. Usually the pathnames are absolute pathnames for the original
system's filesystem, such as "/usr/shlib/libc.so".
On the user system, there may be not files with the specified pathname,
or the file with that pathname may be a different version. If the file
is different or absent, Ladebug will not be able to present the user with
the correct view of the core file.
All the relevant shared objects associated with the core file (those
that would show up in the output of the listobj command if the
user were debugging on the original system) must be in the local directory.
Example:
% setenv LADEBUG_COREFILE_LIBRARY_PATH applibs
% ladebug a.out core
At this point, the listobj command would show the shared libraries
as being located in the "applibs" directory, rather than from the user
system's directories. < End of example >
For debugging transported corefiles of multi-threaded applications,
it is prudent to put the shared objects used by the application in one
subdirectory (e.g. "applibs", as shown in the previous example) and the
pthread debug library (libpthreaddebug.so) in a separate directory (e.g.
"dbglibs"). DO NOT PUT APPLICATION SHARED OBJECTS IN THE SECOND/DEBUG
DIRECTORY!
Then, to get Ladebug to use the correct libpthreaddebug.so library,
point the LD_LIBRARY_PATH environment variable at its directory,
% setenv LD_LIBRARY_PATH dbglibs
before you run Ladebug.
Many problems with processing core files generated by processes that have
been doing dlOpens have been fixed, and there is ongoing work
in this area.
Problems with classes and/or
structs having the same identifier as variables
This release fixes the problems related to classes and/or structs having
the same identifier as variables, as shown in the following transcript:
% ladebug a.out
(ladebug) p s
struct s {
i = 0;
}
(ladebug) stop in main
(ladebug) run
(ladebug) W
1
2 struct s { int i; } s;
3
4 int main()
5 {
> 6 return s.i;
7 }
(ladebug) p s
struct s {
i = 0;
}
(ladebug) p s.i
0
(ladebug) p struct s
struct s {
int i;
}
Problems with local variables
and class data members having the same identifier
Ladebug no longer has problems when local variables and class data members
have the same identifier, as demonstrated in the following transcript:
(ladebug) W
1 class S {
2 public:
3 S():i(0){}
4 int i;
5 };
6
7 void main()
8 {
9 int i = 10;
10 S* s = new S();
> 11 i++;
12 }
(ladebug) p i
10
Limitation in print
This release is able to print Bar::Foo where both Bar
and Foo are types; it also accepts the command print <type
name >, which has exactly the same behavior as whatis <type
name >.
Support for base classes
We have been overhauling the support for both virtual and non-virtual base
classes, and now many more of the fringe cases work properly. Meanwhile,
Ladebug now correctly supports printing of dereferences of pointers to
virtual base classes.
Breakpoint/Watchpoint handling
-
Under obscure circumstances, previous versions of Ladebug would not actually
remove the Breakpoints and Watchpoints when they were no longer needed,
although they would be hidden from both the user and the process by the
debugger. This merely slowed the process down. They are now fully removed.
-
As soon as the running process dies, Ladebug now returns the context back
to before the program was run, so that breakpoints etc. can be specified
for the next run.
-
Watchpoints now work even when the user has specified "ignore SEGV".
Assertion failures
This release fixes the following assertion failures:
-
src/st/file/parsesymscoff.C 3613
-
The "isComplete()" assertion failure when dealing with classes generated
by older C++ compilers without the beginning stTag entry.
Also, we have replaced an assert with a warning message to allow users
to continue debugging after encountering an unexpected TIR format (continued
flag being set). This was caused by bad compilers/linkers but was showing
up as a Ladebug problem.
Miscellaneous
-
In this release, the message "Process has exited" is now put out more often,
to remind you that run, rerun, and other commands can cause the current
process to terminate.
-
Ladebug would crash under some circumstances if the environment variable
LD_LIBRARY_PATH
was set. This has been fixed.
-
The performance has been improved dramatically when printing deep call
stacks.
-
Stack tracing now works through JIT'ed code, provided the JIT'ed procedures
have been correctly registered with the exception system.
-
Variables whose lifetimes have been split by the optimizer are now more
likely to be correctly evaluated.
Problems fixed in the Ladebug Debugger Version
4.0-49
Emacs Support File
The emacs support file, ladebug.el, was missing from the 4.0-48
kit. It is now once again included in the Ladebug kits.
Ladebug Man Pages
The Ladebug man pages are normally installed as part of the OS installation
and were not included in Ladebug kits. The current version of the Ladebug
man pages are now included as part of the Ladebug kits in the LDBMAN subset.
Hard Partitioning
Ladebug better supports debugging in the presence of hard partitioning,
which essentially partitions a single machine into what appears to software
as multiple separate machines (each partition running its own copy of the
OS).
The issue was that physical memory doesn't start at address zero for
secondary partitions, so debuggers were unable to find the Restart Parameter
Block (RPB) for mapped kernels.
A modified libdpi.a was supplied to the Ladebug project which
allows debuggers to work on partitions transparently.
Problems fixed in the Ladebug Debugger Version
4.0-48
Performance improvements
As part of our continuing work on Ladebug's memory usage and cpu usage,
we have started delaying the loading of information about local variables
until an explicit reference to the containing scope is made. Typically
this happens automatically as part of the scope lookup.
-
In the case of the whereis command, local symbols may not be found.
-
A where command will load the local symbols of all the displayed
scopes.
-
The performance of the stop, when and trace
commands has been improved.
Many memory leaks within these commands, and also within the watch
command, have also been eliminated.
C++
-
Clear up Ladebug's confusion when a namespace and a class have the same
name.
-
Fixed some problems in reading namespace related information from the a.out
file. DECLADEBUG 1301.
-
Don't print C++ base classes inherited virtually more than once. Do print
base classes once for each non-virtual base class.
-
Some C++ member-function-related crashes were fixed.
Fortran
-
A common block that was defined in a shared library, but referenced from
a different shared library, sometimes could not have its members examined.
This has been fixed.
-
Fixed some problems with arrays passed-by-reference in the Fortran support
Miscellaneous
-
Control-C now interrupts the debugger output and returns control to the
user in the where comand, and many other cases.
-
Large character arrays are now handled better
-
We've put a control-C handler in the read loop(s) for strings.
-
Ladebug already has $maxstrlen, which limits the size of string that gets
printed; however, it used to fetch to a null byte and then apply the limit.
It will now check the limit in the loop, so that we don't waste time fetch
bytes we're not going to print.
-
Fixed a problem resulting in a breakpoint being set on a wildly different
line if the user-specified line did not exist.
-
Correctly handle "vfork" calls.
-
Some internal problems that corrupted the debugger's memory were fixed.
-
Some threads-related crashes were fixed.
Problems fixed in the Ladebug Debugger Version
4.0-47
Shared library handling
-
Fixed various problems when shared libraries (.so's) were not
loaded at their preferred (or quick-start) addresses. This release
fixes the known problems.
C++
-
Ladebug now prints the proper scope delimiter for function declarations.
-
Ladebug now prints the 'ellipsis' parameter notation more often.
FORTRAN
A number of problems in handling alternate entry points and COMMON blocks
which lead to assertions were fixed:
-
Assertion failed: !thisCalculatedProcedureInformationTable
-
Assertion failed: !_symbolPtrTree.lookup(index, sh)
Miscellaneous
Compilers are now putting out debugger symbol table information for procedures
that have been optimized out of existence. Ladebug now supports this information--previously
it crashed.
We have reduced the amount of memory leaked during the execution of
the command 'stop <variable-name>'. We still strongly
recommend using the command 'watch variable <variable-name>'
instead.
Problems fixed in the Ladebug Debugger Version
4.0-46
C++
-
Fixed a bug where use of the dot operator prevented dynamic type evaluation
for references (e.g. print a.b where b is a reference).
-
Change the way static data members are dealt with to make them be both
a symbol in the class, and also a global variable with a mangled name.
This gets mixed C/C++ correct, and also results in the GOT being used for
such symbols.
-
Cope with the same localSymbol being used for both a variable and a struct
data member when dealing with FORTRAN common
-
Fixed parsing of p (class C*)0.
-
Fix the processing of struct/class/enum/union Id so that the result
must be of the correct flavor.
-
Fix a crash caused by expressions like print `sub`i `sub`j.
FORTRAN
-
Fixed some of the problems with calling procedures, although more work
remains in this area. Scalar parameters by reference are now supported,
which helps many Fortran programs.
-
Fix the Fortran support so that ladebug can debug code produced with the
-assume
nounderscore f77 switch.
-
Taught Ladebug that alternate-entry-points are not subroutines in their
own right, so the symbolization and knowlege of what variables are in scope
is closer to the truth.
-
Fixed a bug where whatis of an out-of-bound array reference used
to show the index number of the out-of-bound dimension one too low.
-
Now display the Bounds error in Fortran with the right index value.
GUI
-
The dxladebug ladebug GUI often failed to show bpt toggles. Several instances
of this were fixed.
Miscellaneous
-
Step and next command semantics were improved for optimized
code.
-
Fixed a bug where calling a function that results in the debuggee terminating
execution caused ladebug to get a segment violation (SEGV).
-
When the process terminates during a call, Ladebug now returns control
to the user right away.
-
Passing many parameters in calls, either with the call command
or part of an expression, has had several fixes.
-
Fixed various obscure memory corruptions within Ladebug that would lead
to ladebug crashing.
-
Ladebug will no longer crash when attempting to debug a core file for an
executable which can't be loaded.
-
Fixed most of the problems Ladebug had with managing multi-process debugging
sessions. Most importantly, fix the way run/rerun is done in these cases.
Run/rerun now removes the whole process tree and restarts from a "clean
sheat".
-
When detaching from a process created by Ladebug (loaded by the user rather
than attached to) then the debugger will detach from its children also,
rather than killing them as it used to.
-
Improved the functionality of the history recall (UP/DOWN arrow keys).
Now only unique history entries are recalled that way. The "history" command
will still display everything.
-
The when and trace commands previously took incredible
amounts of time and memory to process. This has been drastically reduced.
Unfortunately, this fix exposed a bug in per-routine entry tracing. See
Problems
with per-routine entry tracing
-
Fixed several places where expression evaluation required, but didn't really
need, a thread to be running.
-
Allowed ^C interruption of memory examination commands such as
(ladebug) $pc/1000i
-
Changed the output format for function names to show the return result
and parameter types.
Old: [1] stopped at [main:12
0xXXXXXXXX] New: [1] stopped
at [int main(void):12 0xXXXXXXXX]
Changed the machine code examination to look nicer in the presence of long
function names.
(ladebug) wi int
operator <(const D&, const D&): tmp.cxx [line
5, 0x120001bd4] ret r31, (r26), 1 int
main(void): tmp.cxx [line 8, 0x120001bd8] ldah gp,
8192(r27) [line 8, 0x120001bdc] lda gp,
25912(gp) [line 8, 0x120001be0] lda sp,
-48(sp) [line 8, 0x120001be4] stq r26,
0(sp) *[line 10, 0x120001be8] bis r31,
0x1, r0 [line 10, 0x120001bec] stl r0,
16(sp) [line 11, 0x120001bf0] bis r31,
0x2, r2 [line 11, 0x120001bf4] stl r2,
8(sp) [line 12, 0x120001bf8] bis r31,
0x1, r4
Fixed a bug where strange characters appearanced at the end of a LongDouble
string.
Fixed a crash on quit after an incomplete startup.
Make ladebug terminate silently when kill(ed) (SIGTERM) instead of printing
a stack trace
Fixed a parsing bug where the '>' or '<' characters got included in
the preceding filename if no separating space was present.
Problems fixed in the Ladebug Debugger Version
4.0-44
Fortran
-
Fixed some problems with examining Fortran arrays whose bounds were provided
as parameters. (DECL 1009)
-
Fixed the Ladebug Fortran grammar to correctly accept many more Fortran
expressionssuch as "a%b(c)%d".
(DECL 343)
-
Fixed crashes when blank-common was declared differently in separate .o
files. (DECL 2303)
C and C++
-
Added support for pointers to functions in general so they can now be used
for calls, breakpoints, etc. (DECL 23)
-
Added informational messages for the user about the existance of opaque
base classes in a couple of places where an opaque base class may limit
the user's acess to class members. (DECL 1040)
-
Fixed some problems with typedfs of classes
getting error messages about unfinished aspects of Ladebug.
-
Better handling of C++ RTTI information in .o files.
-
Ladebug now uses a much more recent version of the demangler which fixes
some crashes.
Threads and Timers
Added a workaround for a kernel bug which affects debugging a program with
timers. (DECL 852)
Miscellaneous
-
Allow many more flavors of exprs where addresses are expected by the Ladebug
grammar - especially in the examine/watch commands. (DECL 1039) For instance,
the following now works
(ladebug) $pc+4*4/x
-
Long-line-editting support added to Version 4.0-42 had the short-coming
of spacing out to col 79 even for short lines, printing the ' ' status
character, and backspacing to the correct place subsequently. We no longer
do this.
-
Removed several memory leaks, and unnecessary uses of storage.
-
Fixed ladebug erratically crashing some time after the user repeated a
USE by hitting the ENTER. It resulted in a dangling pointer being used,
resulting in a heap corruption inside Ladebug.
-
Stop ladebug from crashing when there is no matching symbol. (DECL 2303)
-
Fixed a crash when trying to load a bad executable.
-
Fixed crashes when the user tries to get and address of source line when
nothing is being debugged. (LB 1850)
Performance
Drastically improved the performance of Ladebug when a trace or stop command
requires a breakpoint on hundreds or more of procedures. We are continuing
work in this area, especially for the initial execution of the command.
Problems fixed in the Ladebug Debugger Version
4.0-43
C++ Class support
-
Fixed assertion failure when printing a class that has an opaque base class
somewhere in its inheritance heirarchy.
-
Virtual member functions are now identified correctly when a class is printed.
-
Fix some 5.6 problems with overloaded member functions.
-
Added a small enhancement to the dynamic type support where Ladebug will
now attempt to use the __bptr member if the __vptr member does not exist.
Using either pointer works properly, but the __bptr has the disadvantage
of not being a member of the class at the top of the hierarchy (it has
no parents).
-
Cope better with some printing of uninitialized objects
-
Fix some reference casting problems, especially for multiple-inheritance
(LB 2020, 2352, 2354)
Watchpoints
-
Fixed a memory leak
-
User commands on watchpoints
FORTRAN
-
Further fixes to multi-dimensional arrays
COBOL
-
Fix indexing into interleaved arrays
GUI
-
Fix the GUI hanging when application does I/O (DECL 901)
-
Fix "newline in middle of UseList" message (DECL 1015)
Interrupt Handling
-
Fix the <Ctrl-c> sometimes being acknowledged
as "Interrupt (for ladebug)".
-
Fix <Ctrl-c> sometimes being sent to application
as a SIGTRAP.
-
<Ctrl-c> now stops a process without the
extra "Stopping process..." messages.
Unsigned Arithmetic
-
Fix a problem when ladebug incorrectly believes that the result of an unsigned-literal
is
signed.
Single-stepping on v3.2 Systems
-
Fix problems which occured when interrupt was received during single step
instruction