
October 13 1995, Draft 1
387
Chapter 7 Software Debugging
Using the
swaf
utility described in section 2.6.1, it is possible to display the
ADDR label shown on Figure 7-14 in terms of program address labels. The utility
builds a GPA formatted symbol file from information extracted from a linked COFF
file. The GPA file must be transferred to the analyzer, this is best done using a LAN
connection.
Hewlett–Packard has further extended the ability of their analyzers to support
source level debugging. Their B3740A Software Analyzer tool enables trace in-
formation to be displayed at source level. The tool runs on a Unix workstation or on a
PC running Windows. An HP16500B logic analyzer must be connected to a comput-
er system via an HP16500L LAN card. Once the analyzer is connected to the LAN, it
can be controlled from the workstation or PC. For example, an X–terminal connected
to a computer running Unix can use the Software Analyzer tool to display program
trace information in terms of the original C code. For convenience it is also possible
to display the equivalent assembly level trace normally presented on the dedicated
analyzer display. Analyzer trigger logic can be set from the X–terminal and is pres-
ented in terms of address symbols rather than hexadecimal values. The Software
Analyzer tool currently runs with HP16550A (6–pod, 102 channel) and HP16555A
(4–pod, 68 channel) analyzer cards which can be installed in the HP16500B logic
analyzer system.
Hewlett–Packard’s Software Analyzer tool is very useful, however, it does suf-
fer from displaying trace information corresponding to instruction fetch activity
rather than instruction execution. Not all fetched instructions which are observed on
the system bus, flow through the processor pipeline and are executed. Instructions
can be fetched due to cache block reload or instruction fetch–ahead. The Software
Analyzer indicates that these instructions have been
fetched for execution in the same
way as instructions which really are executed –– they are indistinguishable. This
problem is overcome when the logic analyzer is driven by the MonTIP program. The
UDI conformant MonTIP has been extended to include support for the HP16500B
logic analyzer. Algorithms have been incorporated within MonTIP for processing
trace information. These algorithms, described in more detail later, are able to elimi-
nate
unwanted
trace information and consequently produce trace data which corre-
sponds to the execution path taken by the processor.
Traceable Caching
Traceable Caching is accomplished using two processors in tandem: a main pro-
cessor and a slave processor. The two processors are connected together, pin–to–pin,
except the slave uses its address bus and a few other signal pins to indicate cache hit
activity. The main processor performs all the required operations, and the tracing
processor duplicates the operation of the main processor except that the output pins
connected in parallel are disabled. All processor outputs to the system are driven by
the main processor. The slave processor simply latches the results of the accesses per-
formed by the main processor.