
13
Chapter 1 Architectural Overview
load instruction. This happens when, fortunately, the RB field of the load instruction
matches with the destination register of the previous address computation instruc-
tions.
Software debugging is better supported on the Am29050 processor than on any
other current 29K family member. All 29K processors have a trace facility which en-
ables single stepping of processor instructions. However, prior to the Am29050 pro-
cessor, tracing did not apply to the processor operation while the DA bit (disable all
traps and interrupts) was set in the current processor status (CPS) register. The DA bit
is typically set while the processor is operating in Freeze mode (FZ bit set in the CPS
register). Freeze mode code is used during the entry and exit of interrupt and trap
handlers, as well as other critical system support code. The introduction of Monitor
mode operation with the Am29050 enables tracing to be extended to Freeze mode
code debugging. The processor enters Monitor mode when a synchronous trap oc-
curs while the DA bit is set. The processor is equipped with a second set of PC buffer
registers, known as the shadow PC registers, which record the PC–bus activity while
the processor is operating in Monitor mode. The first set of PC buffer registers have
their values frozen when Freeze mode is entered.
The addition of two hardware breakpoint registers aids the Am29050 debug
support. As instructions move into the execute stage of the processor pipeline, the
instruction address is compared with the break address values. The processor takes a
trap when a match occurs. Software debug tools, such as monitors like Mini-
MON29K, used with other 29K family members, typically use illegal instructions to
implement breakpoints. The use of breakpoint registers has a number of advantages
over this technique. Breakpoints can be placed in read–only memories, and break ad-
dresses need not be physical but virtual, tagged with the per–process identifier.
1.5
THE Am29030 2–BUS MICROPROCESSOR
The Am29030
processor is pin compatible with other 2–bus members of the
family (see Table 1-2) [AMD 1991b]. It was the first member of the 2–bus family
introduced in 1991. Higher device construction densities enable it to offer high per-
formance with a simplified system interface design. From a software point of view
the main differences between it and the Am29000 processor occur as a result of re-
placing the Branch Target Cache (BTC) memory with 8k bytes of instruction cache,
and connecting the instruction and data busses together on–chip. However, the sys-
tem interface busses have gained a number of important new capabilities.
The inclusion of an instruction cache memory reduces off–chip instruction
memory access bandwidth requirements. This enables instructions to be fetched via
the same device pins used by the data bus. Only when instructions can not be supplied
by the cache is there contention for access to external memory. Research [Hill 1987]
has shown that with cache sizes above 4k bytes, a conventional instruction cache is