PNX1300/01/02/11 Data Book
Philips Semiconductors
5-10
PRELIMINARY SPECIFICATION
Reading the LRU bits produces a 32-bit result with the
format shown at the bottom of
Figure 5-11
. The least-sig-
nificant ten bits contain the state of the LRU bits when the
ld32 was executed. See
Section 5.6.7,
“
LRU Bit Defini-
tions,
”
for a description of the LRU bits.
Note that the tag_i_mux and set fields in the address for-
mats of
Figure 5-10
are larger than necessary for the in-
struction cache in PNX1300. These fields will allow fu-
ture implementations with larger instruction caches to
use a compatible mechanism for reading instruction
cache information. The tag_i_mux field can accommo-
date a cache of up to 16-way set-associativity, and the
set field can accommodate a cache with up to 512 sets.
For PNX1300, the following constraints of the values of
these fields must be observed:
1. 0
≤
tag_i_mux
≤
7
2. 0
≤
set
≤
63
5.4.9
Cache Locking
Like the data cache, the instruction cache allows up to
one-half of its blocks to be locked. A locked block is nev-
er chosen as a victim by the replacement algorithm; its
contents remain undisturbed until the locked status is
changed explicitly by software. Thus, on PNX1300, up to
16 KB of the cache can be used as a high-speed instruc-
tion
‘
ROM.
’
Only four out of eight blocks in any set can be
locked.
The MMIO registers IC_LOCK_ADDR, IC_LOCK_SIZE,
and IC_LOCK_CTL
—
shown in
Figure 5-12
—
are used to
define and enable instruction locking in the same way
that the similarly named data-cache locking registers are
used.
Section 5.3.7,
“
Cache Locking,
”
describes the de-
tails of cache locking; they are not repeated here.
Setting the IC_LOCK_ENABLE bit (in IC_LOCK_CTL) to
‘
1
’
causes the following sequence of events:
1. The instruction cache invalidates all blocks in the
cache.
2. The instruction cache fetches all blocks in the lock
range (defined by IC_LOCK_ADDR and
IC_LOCK_SIZE) from main memory into the cache.
3. Cache locking is activated so that the locked blocks
cannot be victims of the replacement algorithm.
The only difference between this sequence and the ini-
tialization sequence for data-cache locking is that dirty
blocks (which cannot exist in the instruction cache) are
not written back first.
Programmer’s note:
Programmers (or compilers) must
combine all instructions that need to be locked into the
single linear instruction-locking address range.
The special iclr operation also removes locked blocks
from the cache. If blocks are locked in the instruction
cache, then instruction cache locking should be disabled
in software (by writing
‘
0
’
to IC_LOCK_CTL) before an
iclr operation is issued.
Locking should not be enabled by PCI accesses to the
MMIO register.
5.4.10
Instruction Cache Initialization and
Boot Sequence
When PNX1300 is reset, the instruction cache executes
an initialization and processor boot sequence. While re-
set is asserted, the instruction cache forces NOP opera-
tion to the DSPCPU, and the program counter is set to
the default value reset_vector. When reset is deassert-
ed, the initialization and boot sequence is as follows.
31
0
3
7
11
15
0
19
23
27
To Read Tag & Valid Bit
To Read LRU Bits
SET
MMIO_BASE
1 0 0 0 0
MMIO_BASE
TAG_I_MUX
SET
0 0
0 0
Figure 5-10. Required address format for reading instruction-cache tags and status.
31
0 0 0 0 0 0 0 0 0 0
0
3
7
11
15
19
23
27
VALID
I-Cache Tag-Read Result Format
I-Cache Status-Read Result Format
LRU
0 0 0 0 0 0 0 0 0 0 0
0 0 0
0
0 0 0 0 0 0 0 0
TAG
Figure 5-11. Result formats for reads from the instruction-cache region of the MMIO aperture.
IC_LOCK_ADDR (r/w)
0x10 0214
IC_LOCK_ADDRESS
IC_LOCK_SIZE (r/w)
0x10 0218
IC_LOCK_SIZE
0 0 0 0 0 0
0 0 0 0 0 0
31
0 0 0 0 0 0
0
3
7
11
0 0 0 0 0 0
15
19
23
0 0 0 0 0 0
27
IC_LOCK_CTL (r/w)
0x10 0210
0
0 0 0 0 0 0
0 0
IC_LOCK_ENABLE
MMIO_BASE
offset:
0 0 0 0 0 0
0 0
0
0 0
0 0 0 0 0 0
0 0
0 0 0 0 0 0
0 0
reserved
Figure 5-12. Formats of the registers that control instruction-cache locking.