Cache Data Size: 32 Kib Cache Block Size: 2 Words Cache Access Time: 1 Cycle

Download as pdf or txt
Download as pdf or txt
You are on page 1of 2

1.

Caches are important to providing a high-performance memory


hierarchy to processors. Below is a list of 32-bit memory address references,
given as word addresses: 3, 180, 43, 2, 191, 88, 190, 14, 181, 44, 186, 253
a. For each of these references, identify the binary address, the tag, and
the index given a direct-mapped cache with 16 one-word blocks. Also
list if each reference is a hit or a miss, assuming the cache is initially
empty.
b. For each of these references, identify the binary address, the tag, and
the index given a direct-mapped cache with two-word blocks and a
total size of 8 blocks. Also list if each reference is a hit or a miss,
assuming the cache is initially empty.
c. You are asked to optimize a cache design for the given references.
There are three direct-mapped cache designs possible, all with a total
of 8 words of data: C1 has 1-word blocks, C2 has 2-word blocks, and
C3 has 4-word blocks. In terms of miss rate, which cache design is the
best? If the miss stall time is 25 cycles, and C1 has an access time of
2 cycles, C2 takes 3 cycles, and C3 takes 5 cycles, which is the best
cache design?
There are many different design parameters that are important to a
cache’s overall performance. Below are listed parameters for different
direct-mapped cache designs.
Cache Data Size: 32 KiB
Cache Block Size: 2 words
Cache Access Time: 1 cycle
d. Calculate the total number of bits required for the cache listed above,
assuming a 32-bit address. Given that total size, find the total size of
the closest direct-mapped cache with 16-word blocks of equal size or
greater. Explain why the second cache, despite its larger data size,
might provide slower performance than the first cache.
e. Generate a series of read requests that have a lower miss rate on a 2
KiB 2-way set associative cache than the cache listed above. Identify
one possible solution that would make the cache listed have an equal
or lower miss rate than the 2 KiB cache. Discuss the advantages and
disadvantages of such a solution.
f. The formula shows the typical method to index a direct-mapped cache,
specifically (Block address) modulo (Number of blocks in the cache).
Assuming a 32-bit address and 1024 blocks in the cache, consider a
different indexing function, specifically (Block address[31:27] XOR
Block address[26:22]). Is it possible to use this to index a direct-
mapped cache? If so, explain why and discuss any changes that might
need to be made to the cache. If it is not possible, explain why.

2. For a direct-mapped cache design with a 32-bit address, the following


bits of the address are used to access the cache.
Tag Index Offset
31–10 9–5 4–0
a. What is the cache block size (in words)?
b. How many entries does the cache have?
c. What is the ratio between total bits required for such a cache
implementation over the data storage bits?
Starting from power on, the following byte-addressed cache references
are recorded.
Address
0 4 16 132 232 160 1024 30 140 3100 180 2180
d. How many blocks are replaced?
e. What is the hit ratio?
f. List the final state of the cache, with each valid entry represented as a
record of <index, tag, data>.

You might also like