#### Exercise 1

Let us consider a memory hierarchy (main memory + cache) given by:

- Memory size 1 Giga words of 16 bit (word addressed);
- Cache size 1 Mega words of 16 bit (word addressed);
- Cache block size 256 words of 16 bit.
- 1. Calculate the number of cache blocks;
- 2. Calculate the structure of the addresses for the following cache structures:
  - direct mapped cache;
  - fully associative cache;
  - 2-way set-associative cache;
  - 4-way set-associative cache;
  - 8-way set-associative cache.
- 3. Calculate the number of sets for the previous set-associative caches.

#### Solution (1):

Number of cache blocks = Cache size / Block size = 1M Word / 256 Word =  $2^{20}$  /  $2^8$  =  $2^{12}$  = 4096

#### Solution (2):

Main memory address: 30 bit Cache memory address: 20 bit

#### **Direct Mapped Cache**

Tag: 10 bit | Index: 12 bit | Word Offset (in the block): 8 bit

#### **Fully Associative Cache**

Tag: 22 bit | Word Offset (in the block): 8 bit

#### 2-way Set-Associative Cache

Tag: 11 bit | Index: 11 bit | Word Offset (in the block): 8 bit

#### 4-way Set-Associative Cache

Tag: 12 bit | Index: 10 bit | Word Offset (in the block): 8 bit

#### 8-way Set-Associative Cache

Tag: 13 bit | Index: 9 bit | Word Offset (in the block): 8 bit

#### Solution (3):

Number of sets in n-way SA cache = Number of blocks / Number of ways = 4096 / n

Number of sets in 2-way SA cache = 4096/2 = 2048

Number of sets in 4-way SA cache = 4096/4 = 1024

Number of sets in 8-way SA cache = 4096 / 8 = 512

#### **Exercise 2**

Let us consider a memory hierarchy (main memory + cache) given by:

- Memory size 2 Giga Byte (Byte addressed);
- Cache size 512 K Byte (Byte addressed);
- Cache block size 512 Byte.
- 1. Calculate the number of cache blocks
- 2. Calculate the structure of the addresses for the following cache structures:
  - direct mapped cache;
  - fully associative cache;
  - 4-way set-associative cache;

# Solution (1)

Number of cache blocks = Cache size / Block size = 512 KB / 512 B = 1 K = 1024

#### Solution (2)

Main memory: 31 bit address Cache memory: 19 bit address

#### **Direct Mapped Cache**

Tag: 12 bit | Index: 10 bit | Byte Offset (in the block): 9 bit

# **Fully Associative Cache**

Tag: 22 bit | Byte Offset (in the block): 9 bit

#### 4-way Set-Associative Cache

Tag: 14 bit | Index: 8 bit | Byte Offset (in the block): 9 bit

#### Exercise 3 - Cache simulation

Let us consider a memory hierarchy composed of the main memory and a **direct mapped cache** with:

- Memory size 4 KByte (Byte addressed);
- Cache size 1 Kbyte (Byte addressed);
- Cache block size 256 Byte.
- 1. Calculate the following parameters:

Number of blocks in memory: **16 blocks** Number of blocks in cache: **4 blocks** 

Structure of the addresses: Memory address: 12 bit Cache address: 10 bit

Byte Offset (in the block): 8 bit

Structure of 12-bit memory address: | 4bit MEM BLOCK INDEX | 8bit BYTE OFFSET|

2bit TAG | 2bit CACHE INDEX | 8bit BYTE OFFSET|

Example: | 11 | 10 | 11100010 | | 2bit TAG | 2bit CACHE INDEX | 8bit BYTE OFFSET|

2. Given the following sequence of memory accesses, please complete the following table by **simulating** the direct mapped cache behavior in terms of:

- 1-bit HIT/MISS
- 1-bit VALID
- 2-bit TAG
- **DATA** to report the number **in base**<sub>10</sub> of the memory block loaded/accessed in cache.
- **ACTION** to report the memory block accessed in the cache block (in case of HIT) or loaded in cache (in case of MISS)

|   | Requested<br>Memory | H<br>/ |   | Block_0_<br>index | _                         | E | Block_1<br>index | _                         | E | Block_2_<br>index | -                         | ВІ | ock_3_<br>index | _cache<br>11              | ACTION                       |
|---|---------------------|--------|---|-------------------|---------------------------|---|------------------|---------------------------|---|-------------------|---------------------------|----|-----------------|---------------------------|------------------------------|
|   | Address             | М      | V | TAG               | DATA<br>bl. <sub>10</sub> | V | TAG              | DATA<br>bl. <sub>10</sub> | V | TAG               | DATA<br>bl. <sub>10</sub> | V  | TA<br>G         | DATA<br>bl. <sub>10</sub> |                              |
|   |                     |        | 1 | 00                | 0                         | 0 | 11               | 2                         | 1 | 01                | 6                         | 0  | 10              | 7                         | Initial situation            |
| 1 | 11 10 1110 0010     | М      | 1 | 00                | 0                         | 0 | 11               | 2                         | 1 | 11                | 14                        | 0  | 10              | 7                         | Load bl.14 in block_2_cache  |
| 2 | 00 01 1110 0101     | М      | 1 | 00                | 0                         | 1 | 00               | 1                         | 1 | 11                | 14                        | 0  | 10              | 7                         | Load bl.1 in block_1_cache   |
| 3 | 00 01 0011 1001     | Н      | 1 | 00                | 0                         | 1 | 00               | 1                         | 1 | 11                | 14                        | 0  | 10              | 7                         | Access bl.1 in block_1_cache |
| 4 | 11 00 0000 0010     | М      | 1 | 11                | 12                        | 1 | 00               | 1                         | 1 | 11                | 14                        | 0  | 10              | 7                         | Load bl.12 in block_0_cache  |
| 5 | 00 11 1111 1110     | М      | 1 | 11                | 12                        | 1 | 00               | 1                         | 1 | 11                | 14                        | 1  | 00              | 3                         | Load bl.3 in block_3_cache   |
| 6 | 10 01 0100 0111     | М      | 1 | 11                | 12                        | 1 | 10               | 9                         | 1 | 11                | 14                        | 1  | 00              | 3                         | Load bl.9 in block_1_cache   |

#### Exercise 4 - Cache simulation

Let us consider a memory hierarchy composed of the main memory and a **2-way set associative cache** with:

- Memory size 4 KByte (Byte addressed)
- Cache size 512 byte (Byte addressed)
- Cache block size 128 Byte
- 1. Calculate the following parameters:

Number of blocks in memory: 32 blocks

Number of blocks in cache: 4 blocks (marked as block\_a, block\_b, block\_c and block\_d)

Number of sets = 2 sets (marked as Set\_0 and Set\_1)

Structure of the addresses: Memory address: 12 bit Cache address: 9 bit

Byte Offset (in the block): 7 bit

Structure of 12-bit memory address: | 5bit MEM BLOCK INDEX | 7-bit BYTE OFFSET|

4-bit TAG | 1-bit cache INDEX | 7-bit BYTE OFFSET|

Example: | 1110 | 1 | 1100010 | | 4-bit TAG | 1-bit cache INDEX | 7bit BYTE OFFSET |

Given the following sequence of memory accesses, please complete the following table describing the behavior of the:

- 2. Given the following sequence of memory accesses, please complete the following table by **simulating** the 2-way set associative cache assuming the **LRU** (**Least Recently Used**) substitution policy:
  - 1-bit HIT/MISS
  - 1-bit VALID
  - 4-bit TAG
  - **DATA** to report the number **in base**<sub>10</sub> of the memory block loaded/accessed in cache.
  - ACTION to report the memory block accessed in the cache block (in case of HIT) or loaded in cache (in case of MISS)

|   | Requested<br>Memory | H<br>/ |   | Set_0<br>block_a |                           |   | Set_0<br>block_b |                           |   | Set_1<br>block_ |                           |   | Set_1<br>block_ |                           | ACTION                       |
|---|---------------------|--------|---|------------------|---------------------------|---|------------------|---------------------------|---|-----------------|---------------------------|---|-----------------|---------------------------|------------------------------|
|   | Address             | M      | V | TAG              | DATA<br>bl. <sub>10</sub> | V | TAG              | DATA<br>bl. <sub>10</sub> | V | TAG             | DATA<br>bl. <sub>10</sub> | V | TAG             | DATA<br>bl. <sub>10</sub> | -                            |
|   |                     |        | 1 | 0001             | 2                         | 0 | 0001             | 2                         | 1 | 0001            | 3                         | 0 | 0010            | 7                         | Initial<br>situation         |
| 1 | 0010 1 1010010      | М      | 1 | 0001             | 2                         | 0 | 0001             | 2                         | 1 | 0001            | 3                         | 1 | 0010            | 5                         | Load bl. 5 in block_d_cache  |
| 2 | 0001 1 1010100      | Н      | 1 | 0001             | 2                         | 0 | 0001             | 2                         | 1 | 0001            | 3                         | 1 | 0010            | 5                         | Access bl.3 in block_c_cache |
| 3 | 0001 0 0111111      | Н      | 1 | 0001             | 2                         | 0 | 0001             | 2                         | 1 | 0001            | 3                         | 1 | 0010            | 5                         | Access bl.2 in block_a_cache |
| 4 | 1100 0 0001010      | М      | 1 | 0001             | 2                         | 1 | 1100             | 24                        | 1 | 0001            | 3                         | 1 | 0010            | 5                         | Load bl.24 in block_b_cache  |
| 5 | 0111 1 1010010      | М      | 1 | 0001             | 2                         | 1 | 1100             | 24                        | 1 | 0001            | 3                         | 1 | 0111            | 15                        | Load bl.15 in block_d_cache  |
| 6 | 1011 0 1000110      | М      | 1 | 1011             | 22                        | 1 | 1100             | 24                        | 1 | 0001            | 3                         | 1 | 0111            | 15                        | Load bl.22 in block_a_cache  |

# Question 1 (format Multiple Choice - Single answer) - 10 Jan. 2022 - PART1

Please indicate the structure of the 32-bit memory address of a 4-way set-associative cache with 1 MB cache size and a block size of 256 B.

# (SINGLE ANSWER)

1 point

Answer 1: | 24-bit tag | 8-bit offset |

Answer 2: |14-bit tag | 10-bit index | 8-bit offset | (TRUE)

Answer 3: |13-bit tag | 11-bit index | 8-bit offset |

Answer 4: |12-bit tag | 12-bit index | 8-bit offset |

# Solution:

Answer 2: |14-bit tag | 10-bit index | 8-bit offset | (TRUE)

# Question 5 (format true/false) - 10 Jan. 2022 - PART1

In a write-back cache, the most updated value of a dirty cache block is always in the cache.

Answer: T/F

1 point

**SOLUTION:** True

#### Feedback:

In a write-back cache, a modified (dirty) cache block is not coherent with the main memory but the most updated value is always in the cache. The modified block will be written in the main memory only when it will be replaced due to a miss. See slides on L08: Memory Hierarchy.

# Question 12 (format SINGLE ANSWER) - 10 Jan. 2022 - PART1

For a **direct-mapped cache**, which strategy can be used for the block replacement?

# (SINGLE ANSWER)

1 point

Answer 1: LRU (Least Recently Used).
Answer 2: FIFO (First In First Out).
Answer 3: None of them (TRUE)

#### **Solution**

Answer 3: None of them (TRUE)

Feedback:

For a direct mapped cache, there is no need of any block replacement strategy, because there is only one block to be replaced by direct mapping.

#### Question 3 (format Multiple Choice - Single answer) - 25 Aug. 2021 - PART2

Let's consider a fully associative write-back cache with many cache entries that at cold start is empty and receives the following sequence of memory accesses:

Read Mem[AAAA]

Write Mem[AAAA]

Read Mem[BBBB]

Write Mem[BBBB]

Read Mem[AAAA]

Read Mem[BBBB]

What are the number of cache hits and misses when using a "write allocate" versus a "no-write allocate" policy?

(SINGLE ANSWER)

2 points

Answer 1: Write allocate has 2 hits & 4 misses | No-write allocate has 4 hits & 2 misses

Answer 2: Write allocate has 4 hits & 2 misses | No-write allocate has 4 hits & 2 misses

Answer 3: Write allocate has 4 hits & 2 misses | No-write allocate has 2 hits & 4 misses

Answer 4: Write allocate has 5 hits & 1 miss | No-write allocate has 5 hits & 1 miss

Answer 5: Write allocate has 3 hits & 3 misses | No-write allocate has 2 hits & 4 misses

#### **Solution:**

**Answer 2**: Write allocate has 4 hits & 2 misses | No-write allocate has 4 hits & 2 misses **(TRUE) Feedback** 

For the write allocate policy, the first read accesses to Mem[AAAA] and Mem[BBBB] are misses, and the 2 blocks corresponding to [AAAA] and [BBBB] are allocated in cache. The next four accesses are all hits, since the blocks corresponding to [AAAA] and [BBBB] are found in cache. Globally, the write allocate has 2 misses & 4 hits.

For the no-write allocate policy there is the same behavior as in the write allocate policy because the first accesses to Mem[AAAA] and Mem[BBBB] are done on read and the corresponding blocks are allocated in cache. Therefore, also the no-write allocate policy has 2 misses & 4 hits.

# Question 4 (complete table format) from PART2 – Exam 21 July, 2022 2 points

Let's consider 32-block main memory with a **direct-mapped** 8-block cache based on a **write allocate** with **write-through** protocol.

The addresses are expressed as decimal numbers:

Memory Address: [0, 1, 2, ...... 31] 10

Cache Address: [0, 1, 2, ...7] 10

and Cache Tags are expressed as binary numbers.

At cold start the cache is empty, then there is the following sequence of memory accesses. Please complete the following table:

|    | Type of | Memory             | HIT/MISS   | Cache             | Cache   | Write                |
|----|---------|--------------------|------------|-------------------|---------|----------------------|
|    | memory  | Address            | Type       | Tag               | Address | in memory            |
|    | access  |                    |            |                   |         |                      |
| 1  | Read    | [24] <sub>10</sub> | Cold-start | [11] <sub>2</sub> | [0] 10  | No                   |
|    |         |                    | Miss       |                   |         |                      |
| 2  | Write   | [24] 10            | Hit        | [11] <sub>2</sub> | [0] 10  | Yes, Wr. in M[24] 10 |
| 3  | Read    | [24] 10            | Hit        | [11] <sub>2</sub> | [0] 10  | No                   |
| 4  | Read    | [10] 10            |            |                   |         |                      |
| 5  | Read    | [16] 10            |            |                   |         |                      |
| 6  | Write   | [10] 10            |            |                   |         |                      |
| 7  | Write   | [24] 10            |            |                   |         |                      |
| 8  | Read    | [12] 10            |            |                   |         |                      |
| 9  | Read    | [21] 10            |            |                   |         |                      |
| 10 | Write   | [18] 10            |            |                   |         |                      |

# **Solution:**

|    | Type of memory access | Memory<br>Address  | HIT/MISS<br>Type | Cache<br>Tag      | Cache<br>Address         | Write<br>in memory   |
|----|-----------------------|--------------------|------------------|-------------------|--------------------------|----------------------|
| 1  | Read                  | [24] 10            | Cold-start Miss  | [11] 2            | [0] 10                   | No                   |
| 2  | Write                 | [24] 10            | Hit              | [11] <sub>2</sub> | [0] 10                   | Yes, Wr. in M[24] 10 |
| 3  | Read                  | [24] 10            | Hit              | [11] <sub>2</sub> | [0] 10                   | No                   |
| 4  | Read                  | [10] 10            | Cold-start Miss  | [01] 2            | [2] 10                   | No                   |
| 5  | Read                  | [16] <sub>10</sub> | Conflict Miss    | [10] <sub>2</sub> | [0] 10                   | No                   |
| 6  | Write                 | [10] 10            | Hit              | [01] 2            | [2] 10                   | Yes, Wr. in M[10] 10 |
| 7  | Write                 | [24] 10            | Conflict Miss    | [11] <sub>2</sub> | [0] 10                   | Yes, Wr. in M[24] 10 |
| 8  | Read                  | [12] 10            | Cold-start Miss  | [01] 2            | [4] 10                   | No                   |
| 9  | Read                  | [21] 10            | Cold-start Miss  | [10] <sub>2</sub> | <b>[5]</b> <sub>10</sub> | No                   |
| 10 | Write                 | [18] 10            | Conflict Miss    | [10] <sub>2</sub> | [2] 10                   | Yes, W in M[18] 10   |

# EXERCISE 3 - CACHE MEMORIES (3 points) - exam 22/1/2024

Let's consider a **fully associative** cache with 4 blocks [a, b, c, d] that at cold start is empty and receives the following sequence of memory accesses:

Read Mem[AAAA]
Write Mem[ABBB]
Read Mem[BBBB]
Read Mem[AAAA]
Write Mem[CCCC]
Read Mem[CCCC]
Read Mem[BBBB]

Part A) Assuming Write Allocate and Write Back cache policies, complete the following table:

|   | Type of memory access | Memory<br>Address | HIT /<br>MISS<br>Type | Cache<br>Tag | Cache<br>Block | Dirty<br>bit | Write-back<br>in memory |
|---|-----------------------|-------------------|-----------------------|--------------|----------------|--------------|-------------------------|
| 1 | read                  | [AAAA] ex         | Cold start<br>MISS    | [AAAA] ex    | а              | 0            | no                      |
| 2 | write                 | [AAAA] ex         | HIT                   | [AAAA] ex    | а              | 1            | no                      |
| 3 | read                  | [BBBB] ex         |                       |              |                |              |                         |
| 4 | write                 | [BBBB] ex         |                       |              |                |              |                         |
| 5 | read                  | [AAAA] ex         |                       |              |                |              |                         |
| 6 | write                 | [CCCC] ex         |                       |              |                |              |                         |
| 7 | read                  | [CCCC] ex         |                       |              |                |              |                         |
| 8 | write                 | [BBBB] ex         |                       |              |                |              |                         |

| How many cache misses?   |          |
|--------------------------|----------|
| How many cache hits?     | <u> </u> |
| Calculate the Miss Rate: |          |

**Part b)** Assuming **No-write Allocate** and **Write Through** cache policies, complete the following table:

|   | Type of memory access | Memory<br>Address    | HIT /<br>MISS Type | Cache<br>Tag         | Cache<br>Block | Write<br>in memory |
|---|-----------------------|----------------------|--------------------|----------------------|----------------|--------------------|
| 1 | read                  | [AAAA] <sub>ex</sub> | Cold start<br>MISS | [AAAA] <sub>ex</sub> | а              | no                 |
| 2 | write                 | [AAAA] ex            | HIT                | [AAAA] ex            | а              | yes                |
| 3 | read                  | [BBBB] ex            |                    |                      |                |                    |
| 4 | write                 | [BBBB] ex            |                    |                      |                |                    |
| 5 | read                  | [AAAA] ex            |                    |                      |                |                    |
| 6 | write                 | [CCCC] ex            |                    |                      |                |                    |
| 7 | read                  | [CCCC] ex            |                    |                      |                |                    |
| 8 | write                 | [BBBB] ex            |                    |                      |                |                    |

| How many cache misses?   |  |
|--------------------------|--|
| How many cache hits?     |  |
| Calculate the Miss Rate: |  |

# Solution

Part A) Assuming the Write Allocate and Write Back cache policies, complete the following table:

|   | Type of memory access | Memory<br>Address    | HIT /<br>MISS<br>Type | Cache<br>Tag         | Cache<br>Block | Dirty<br>bit | Write-back<br>in memory |
|---|-----------------------|----------------------|-----------------------|----------------------|----------------|--------------|-------------------------|
| 1 | read                  | [AAAA] <sub>ex</sub> | Cold start<br>MISS    | [AAAA] <sub>ex</sub> | а              | 0            | no                      |
| 2 | write                 | [AAAA] <sub>ex</sub> | HIT                   | [AAAA] <sub>ex</sub> | а              | 1            | no                      |
| 3 | read                  | [BBBB] ex            | Cold start<br>MISS    | [BBBB] ex            | b              | 0            | no                      |
| 4 | write                 | [BBBB] ex            | HIT                   | [BBBB] ex            | b              | 1            | no                      |
| 5 | read                  | [AAAA] ex            | HIT                   | [AAAA] ex            | а              | 1            | no                      |
| 6 | write                 | [CCCC] ex            | Cold start<br>MISS    | [CCCC] ex            | С              | 1            | no                      |
| 7 | read                  | [CCCC] ex            | HIT                   | [CCCC] ex            | С              | 1            | no                      |
| 8 | write                 | [BBBB] ex            | HIT                   | [BBBB] ex            | b              | 1            | no                      |

How many cache misses?

3

How many cache hits?

5

Calculate the Miss Rate:

Miss Rate = Number of misses / Number of memory access = 3 / 8= 0.375

#### Solution

**Part b)** Assuming the **No-write Allocate** and **Write Through** cache policies, complete the following table:

|   | Type of memory access | Memory<br>Address    | HIT /<br>MISS Type                | Cache<br>Tag | Cache<br>Block | Write<br>in memory |
|---|-----------------------|----------------------|-----------------------------------|--------------|----------------|--------------------|
| 1 | read                  | [AAAA] <sub>ex</sub> | Cold start<br>MISS                | [AAAA] ex    | а              | no                 |
| 2 | write                 | [AAAA] ex            | HIT                               | [AAAA] ex    | а              | yes                |
| 3 | read                  | [BBBB] ex            | Cold start<br>MISS                | [BBBB] ex    | b              | no                 |
| 4 | write                 | [BBBB] ex            | HIT                               | [BBBB] ex    | b              | yes                |
| 5 | read                  | [AAAA] ex            | HIT                               | [AAAA] ex    | а              | no                 |
| 6 | write                 | [CCCC] ex            | Miss with no-<br>write allocation |              | 1              | Yes (*)            |
| 7 | read                  | [CCCC] ex            | Cold start<br>MISS                | [CCCC] ex    | С              | no                 |
| 8 | write                 | [BBBB] ex            | HIT                               | [BBBB] ex    | b              | yes                |

(\*) Write done directly in memory with no-write allocation in cache

| How many cache misses' | w illaliy | y cacii <del>c</del> | 11113353: |
|------------------------|-----------|----------------------|-----------|
|------------------------|-----------|----------------------|-----------|

4

How many cache hits?

4

Calculate the Miss Rate:

Miss Rate = Number of misses / Number of memory access = 4 / 8 = 0.5

# EXERCISE 4 – CACHE MEMORIES (3 points) – exam 22/1/2024

Let's consider 32-block main memory with a **direct-mapped** 8-block cache based on a **write allocate** with **write-back** protocol.

The addresses are expressed as decimal numbers:

Cache Block Addresses: [0, 1, 2, ...7] 10

At cold start the cache is empty, then there is the following sequence of memory accesses.

# 1. Please complete the following table:

|    | Type of memory access | Memory<br>Address | HIT /<br>MISS<br>Type | Cache<br>Tag | Cache<br>Index     | Dirty<br>bit | Write-back<br>in memory       |
|----|-----------------------|-------------------|-----------------------|--------------|--------------------|--------------|-------------------------------|
| 1  | write                 | [12] 10           | Cold start<br>MISS    | [01] 2       | [100] <sub>2</sub> | 1            | no                            |
| 2  | read                  | [12] 10           | HIT                   | [01] 2       | [100] <sub>2</sub> | 1            | no                            |
| 3  | read                  | [10] 10           | Cold start<br>MISS    | [01] 2       | [010] 2            | 0            | no                            |
| 4  | write                 | [10] 10           | HIT                   | [01] 2       | [010] 2            | 1            | no                            |
| 5  | write                 | [26] 10           | Conflict<br>MISS      | [11] 2       | [010] 2            | 1            | WB in M[10] <sub>10</sub>     |
| 6  | read                  | [20] 10           | Conflict<br>MISS      | [10] 2       | [100] 2            | 0            | WB in M[12] <sub>10</sub>     |
| 7  | read                  | [30] 10           | Cold start<br>MISS    | [11] 2       | [110] 2            | 0            | no                            |
| 8  | write                 | [16] 10           | Cold start<br>MISS    | [10] 2       | [000] 2            | 1            | no                            |
| 9  | write                 | [6] 10            | Conflict<br>MISS      | [00] 2       | [110] 2            | 1            | no (block 30<br>not modified) |
| 10 | read                  | [18] 10           | Conflict<br>MISS      | [10] 2       | [010] 2            | 0            | WB in M[26] 10                |

#### 2. Calculate the Miss Rate:

Miss Rate = Number of misses / Number of memory access = 8/10 = 0.8

# EXERCISE 3 - CACHE MEMORIES (3 points) - exam 15/2/2024

| Let's consider 32-block main memory with a fully-associative 4-block cache and LRU cache | ne |
|------------------------------------------------------------------------------------------|----|
| replacement policy. The addresses are expressed as:                                      |    |

| Memory Block Addresses | s: [0, | 1, 2, | <br>31] 10 |
|------------------------|--------|-------|------------|
|                        |        |       |            |

Cache Block Addresses: [a, b, c, d]

At cold start the cache is empty, then there is the following sequence of memory accesses.

Assuming the Write Allocate and Write Back cache policies, complete the following table:

|    | Type of memory access | Memory<br>Address | HIT /<br>MISS<br>Type | Cache<br>Tag | Cache<br>Block<br>Addres<br>s | Dirty<br>bit | Write-back<br>in memory |
|----|-----------------------|-------------------|-----------------------|--------------|-------------------------------|--------------|-------------------------|
| 1  | read                  | [12] 10           | Cold start<br>MISS    | [01100] 2    | а                             | 0            | no                      |
| 2  | write                 | [12] 10           | HIT                   | [01100] 2    | а                             | 1            | no                      |
| 3  | write                 | [10] 10           |                       |              |                               |              |                         |
| 4  | read                  | [10] 10           |                       |              |                               |              |                         |
| 5  | read                  | [26] 10           |                       |              |                               |              |                         |
| 6  | write                 | [7] 10            |                       |              |                               |              |                         |
| 7  | read                  | [12] 10           |                       |              |                               |              |                         |
| 8  | read                  | <b>[4]</b> 10     |                       |              |                               |              |                         |
| 9  | write                 | [26] 10           |                       |              |                               |              |                         |
| 10 | write                 | [18] 10           |                       |              |                               |              |                         |
| 11 | read                  | [5] 10            |                       |              |                               |              |                         |
| 12 | write                 | [24] 10           |                       |              |                               |              |                         |

| Calculate the Miss Rate: |  |
|--------------------------|--|
| Miss Rate =              |  |

# **Solution:**

|    | Type of memory access | Memory<br>Address | HIT /<br>MISS<br>Type | Cache<br>Tag         | Cache<br>Block<br>Addres<br>s | Dirty<br>bit | Write-back<br>in memory          |
|----|-----------------------|-------------------|-----------------------|----------------------|-------------------------------|--------------|----------------------------------|
| 1  | read                  | [12] 10           | Cold start<br>MISS    | [01100] 2            | а                             | 0            | no                               |
| 2  | write                 | [12] 10           | HIT                   | [01100] 2            | а                             | 1            | no                               |
| 3  | write                 | [10] 10           | Cold start<br>MISS    | [01010] 2            | b                             | 1            | no                               |
| 4  | read                  | [10] 10           | HIT                   | [01010] 2            | b                             | 1            | no                               |
| 5  | read                  | [26] 10           | Cold start<br>MISS    | [11010] <sub>2</sub> | С                             | 0            | no                               |
| 6  | write                 | [7] 10            | Cold start<br>MISS    | [00111] <sub>2</sub> | d                             | 1            | no                               |
| 7  | read                  | [12] 10           | HIT                   | [01100] <sub>2</sub> | а                             | 1            | no                               |
| 8  | read                  | [4] 10            | Conflict<br>MISS      | [00100] 2            | b                             | 0            | Yes:<br>WB in [10] <sub>10</sub> |
| 9  | write                 | [26] 10           | HIT                   | [11010] 2            | С                             | 1            | no                               |
| 10 | write                 | [18] 10           | Conflict<br>MISS      | [10010] 2            | d                             | 1            | Yes:<br>WB in [7] 10             |
| 11 | read                  | [5] 10            | Conflict<br>MISS      | [00101]2             | а                             | 0            | Yes:<br>WB in [12] <sub>10</sub> |
| 12 | write                 | [24] 10           | Conflict<br>MISS      | [11000] 2            | b                             | 1            | No                               |

Calculate the Miss Rate:

Miss Rate = Number of misses / Number of memory access = 8 / 12= 0,67