
October 13 1995, Draft 1
369
Chapter 7 Software Debugging
tional
osboot_file.
Thus, the
–r
option must be used to enable Freeze mode debug-
ging. Additionally, to enable debugging of Freeze mode timer interrupts the
–tm
op-
tion must also be selected to enable timer interrupt simulation. The simulator normal-
ly intercepts floating–point traps and performs the necessary calculation directly.
Simulation speeds are reduced if floating–point trapware is simulated. However, if
the trapware is to be debugged the
–t
option must be used to enable trapware simula-
tion.
When the
isstip
process is started it
advertises
its readiness to service UDI re-
quests. A DFE process will typically connect to the TIP process and a debug session
will commence. However, it is more typical to get the DFE to start the TIP. The
mondfe
process starts the TIP during the DFE start–up process. The
gdb
DFE starts
the TIP after the
target
gdb
command is used. The start–up
isstip
parameters are tak-
en from the “UDI Configuration File”. The format of this file is explained in the pre-
vious section discussing
mondfe
.
7.5.8 UDI Benefits
A number of debug tool developers are currently, or will be shortly, offering
tools which are UDI compliant. Typically the DFEs are C source level debuggers.
This is not surprising, as the increased use of RISC processor designs has resulted in a
corresponding increase in software complexity. The use of a high level language,
such as C, is more productive than developing code at machine instruction level. And
further, the use of C enables much greater portability of code among current and
future projects. The low cost of GDB makes it an attractive choice for developers.
Target processors and their control mechanisms are much more varied than
Debugger Front Ends (DFEs). I have briefly described the MiniMON29K TIP, which
is a process which controls the execution of a 29K processor. A small amount of code
known as the DebugCore is placed in processor ROM memory and enables
examination of the processor state. The MiniMON29K TIP communicates with the
DebugCore via a hardware link which is specific to the embedded application
hardware.
Other TIPs already exist and more are under development. There is a 29K
simulator (ISS) which runs on UNIX and DOS hosts. The DFE communicating with
the simulator TIP is unaware that the 29K processor is not present, but being
simulated by a process, executing on, say, a UNIX workstation. There are also tool
developers constructing TIP programs to control processor emulators. This will
make possible a top–of–the–line debug environment.
UDI makes possible a wider tool choice for application code developers.
Debugger front end tools are supplied separately from target control programs. The
user can consider cost, availability and functionality when selecting the debug
environment. This level of debug tool configurability has not been available to the
embedded application development community in the past.