# Cache simulator using SystemC

Sourabh Kulkarni, 532334

Yashas Bedre, 535744

Architecture and Programming Lab

**TUHH** 

## **Requirements:**

Cache size = 32 KB

Cache line size = 32 Bytes

Cache ways = 8

# **Calculations:**

Byte offset bits = log2(Cache line size) = log2(32) = 5 bits

Index bits = log2(Cache size / (Cache line size \* Cache ways))

= log 2(32K / (32 \* 8)) = 7 bits

Tag bits = Address bits – Index bits – Byte offset bits = 32 - 7 - 5 = 20 bits

## **Results:**

| Tracefiles | CPU | Reads | Read  | Read   | Writes | Write | Write  | Hit    | Execution |
|------------|-----|-------|-------|--------|--------|-------|--------|--------|-----------|
|            |     |       | Hits  | Misses |        | Hits  | Misses | Rate   | time (ns) |
| dbg        | 0   | 40    | 19    | 21     | 60     | 29    | 31     | 48.000 | 2259      |
| rnd        | 0   | 33031 | 18662 | 14369  | 32505  | 18308 | 14197  | 56.411 | 1534940   |
| fft        | 0   | 86298 | 7282  | 79016  | 43195  | 10990 | 32205  | 14.110 | 8074286   |

#### **Screenshots:**

1. dbg\_p1

```
Info: /OSCI/SystemC: Simulation stopped by user.
CPU Reads RHit RMiss Writes WHit WMiss Hitrate
0 40 19 21 60 29 31 48.000000
```

2. rnd\_p1

```
Info: /OSCI/SystemC: Simulation stopped by user.
CPU Reads RHit RMiss Writes WHit WMiss Hitrate
0 33031 18662 14369 32505 18308 14197 56.411743
```

3. fft\_p1

| ١ | Info: | /OSCI/Sys | temC: | Simulation | stopped | by user | r.    |           |
|---|-------|-----------|-------|------------|---------|---------|-------|-----------|
| ı | CPU   | Reads     | RHit  | RMiss      | Writes  | WHit    | WMiss | Hitrate   |
| ı | 0     | 86298     | 7282  | 79016      | 43195   | 10990   | 32205 | 14.110415 |