## Computer Architecture Project 2 Report

楊傑森 Jason Yeo B07902101

OS 作業系統: Windows

Implementation of new modules & changes (比對 Project 1: Pipelined CPU without cache):

1) Dcache\_controller (include dcache\_sram)

(参考下面 dcache\_sram): If hit = 1, r\_hit\_data is from cache.

Check offset to read from 256-bit data to 32-bit data.

Check offset to read from 32-bit data to 256-bit data.

Deal with cache miss. Details + Diagram provided as below



- i) STATE\_ IDLE is the initial state. It will go to State MISS when it receives a read/write request and cache miss.
- ii) In STATE\_MISS, if sram\_dirty is set to 1, cache data block needs to write back to data memory. mem\_write, mem\_enable, write\_back are all set to 1. Then go to STATE WRITEBACK.
- iii) If sram\_dirty is set to 0, mem\_write is set to 0, mem\_enable is set to 1.
- iv) In STATE\_WRITEBACK, it waits until the data memory ack is set to 1. If ack = 1, mem\_write is set to 0, mem\_enable is set to 1, write\_back is set to 0. Go to STATE\_READMISS.
- v) In STATE\_READMISS, it waits until the data memory ack is set to 1. If ack = 1, mem\_write is set to 0, mem\_enable is set to 0, cache\_write is set to 1. Go to STATE\_READMISSOK.
- vi) STATE\_READMISSOK will go back to STATE\_IDLE and cache\_write is set to 0.
- 2) Dcache\_sram

Handles tag & data together.

Reset signal = 1, lru, tag, data initialized to 0.

LRU 記錄上個使用的 sram,交替使用兩塊不同

因為考慮 2-way associative cache, hit 的 signal 由以下操作決定:

2個 input 分為 hit0 和 hit1, 至少其中一個 input signal 是 1, hit 的 signal 就是 1。

hit0 和 hit1 由以下操作決定:

2個 tag bits 都一樣 && valid bit 的值是 1, hit0/hit1的 signal 就是 1。

不满足其中一個條件則 0。

data\_o 和 tag\_o 的值由 hit0 決定,

hit0 是 1, 選擇第一個 tag&data, 否則選第二個

3) Other modules (PC + 4 個 pipeline registers)

Stall when a new stall signal (MemStall) is received because of cache miss.

Difficulties while debugging & solutions 除錯時出現的問題和解決方案:

## 疑:

- 1) output.txt 在第2個測資&第2s個測資部分 registers 的值前面2個值應該是ff,不是00。
- 2) 所有的測資建立的 output.txt 的 Data Memory (x200 和 x220)的值沒有更新。

## 解:

- 1) 修改 ALU 的 syntax, shift right arithmetic 的問題
- 2) 在 testbench 自行初始化