
305
Chapter 6 Memory Mangement Unit
tion and data address translation. A subsequent section describes the process of tak-
ing a trap.
Two additional traps are assigned to Supervisor and User mode protection
violations. These occur when a TLB entry has a valid entry but the permission fields
do not allow the type of access being attempted. For example unless the UW bit is set
a User mode process can not write to the mapped page, even if all other TLB entry
fields indicate a match with the translation address.
Now examine the bit fields of word 1. The IO bit is little used, it enables a virtual
address to be associated with a physical page in I/O space. The U bit is maintained by
the Am29000 processor. Whenever a TLB set is used in a valid translation the U bit
associated with the set is updated to indicate which of the two TLB entries was used.
In other words, the U bit selects the column within the set. The U bit is used to supply
the most significant bit in the least–recently used (LRU) register. Special register 14
has a 6–bit field which is updated whenever an address translation fails and a TLB
access trap occurs. The lower 5–bits of the LRU register are loaded with the TLB set
number. Thus the LRU register supplies to the trap handler a recommendation for
TLB entry replacement. The trap handler typically builds a new valid TLB entry at
the recommended location before execution of the interrupted program is continued.
The 2–bit PGM field is not assigned a task by the Am29000 processor, these bits
are placed on the PGM[1:0] out put pins when a translation occurs. Developers can
place any information they wish in the PGM bits. These bits are particularly useful
for multiprocessor applications when one processor wishes to signal other processors
about page cache–ability information.
All data accesses have their translated address and corresponding PGM value
presented on the the chip pins in the cycle following the cycle executing the LOAD or
STORE instruction. Pages containing instructions have their corresponding PGM
bits presented to the chip bins when a jump or call to an address within the page first
occurred. However, if the target of the jump or call is found in the on–chip instruction
cache and the address bus is currently in use when jump or call instruction is in
execute, the PGM bits for the target instruction page will not be presented to the chip
PGM[1:0] bins.
In this chapter, the software controlled cache code example shall use the PGM
bits to store page–lock and page–dirty information in bits PGM[0] and PGM[1], re-
spectively.
6.2.1 Dual TLB Processors
Newer microprocessor and microcontroller members of the 29K family do not
have the full complement of 64 address translations cached in their TLB. A smaller
TLB size of 16 entries enables valuable silicon space to be used for on–chip func-
tions; such as peripherals. To support the smaller number of TLB entries, the maxi-
mum page size has been increased from 8k bytes to 16M bytes. This enables a large