#### Cache Coherence

Sidney Primas and Dinis Cheian

# Progress

| Exercise                    | Passed All | Passed Some                | Passed None                |
|-----------------------------|------------|----------------------------|----------------------------|
| Refined DCache (1.1)        | <b>⊘</b>   |                            |                            |
| Store Queue (1.2)           | <b>⊘</b>   |                            |                            |
| LHUSM (1.3)                 | <b>⊘</b>   |                            |                            |
| Message Fifo (2.1)          | <b>⊘</b>   |                            |                            |
| Message Router (2.2)        | <b>⊘</b>   |                            |                            |
| Coherent DCache (2.3)       | $\bigcirc$ |                            | 1<br>1<br>1<br>1<br>1<br>1 |
| PPP (2.4)                   | $\bigcirc$ |                            | 1<br>1<br>1<br>1<br>1<br>1 |
| RefDMem (2.5)               | $\bigcirc$ | 1<br>1<br>1<br>1<br>1<br>1 | 1<br>1<br>1<br>1<br>1<br>1 |
| Three Cycle Processor (2.6) |            |                            | !<br>!<br>!<br>!<br>!      |
| Six Cycle Processor (2.7)   | $\bigcirc$ |                            |                            |
| Atomic Instructions (2.8)   | $\bigcirc$ |                            |                            |
| Store Queue (2.9)           | <b>⊘</b>   |                            |                            |
| LHUSM (2.10)                |            | <b>Ø</b>                   |                            |

Not Passed on LHUSM:

• On Three: SpinLock

• Six Stage: SpinLock, Multiply2, MdDecker

### Debugging - Sc\_test

- During the Sc-test we passed tb2 but not tb4.
- Error due to possible deadlock.
- Managed to pass by increasing the waiting time.
- Solution: implement round robin in Message Router.

### Debugging - Lr and Sc

- Error while processing a Sc miss. The committed Cache Line did not match the expected Cache Line.
- Narrowed down to the case when Sc Miss and the linkAddr did not match Cache Addr anymore at the moment of Response from the Memory.
- Solution: write to Cache even if linkAddr does not match Cache Line Addr.

## Debugging - Fence

- Issue: With STQ, McDeckker deadlocks with Six Stage Core.
- Symptom: After Fence op, Core 1 deadlocks and we never process the Fence op. Never execute rule mvStoreToCache.
- Techniques: Determine reason for deadlock, investigate instructions before deadlock, investigate/ alter assembly code, etc
- Solution: Empty StoreQ in handleProcReq Rule.

### Debugging - LHUSM

- **Issue**: With LHUSM, Deadlock during spin\_lock with three stage cores.
- Symptom: Deadlock occurs during first Load Hit in Cache during a Store Miss. Load Hit from STQ works.
- Solution: In progress...

#### Improvements for Class

- Develops methods to incrementally compile code.
- Minimize number of tests.
- Spend more time on the hardware side (gates).