# Lab3

311651055 林柏宇 交大電物碩二

受停電影響原因:實驗室電腦不夠使用,自己在新竹這邊沒有電腦,有用到電腦打程式作業的課,都會到清華的同學那裏用(他沒修這堂課),前陣子停電有點被困擾到,後來臨時找其他同學的電腦先借用一下,才完成作業的

A. 這次主要在用 Veilog 實踐 FIR RTL Code, 並用 Verilog 的 Testbench, 驗證功能的波型是否正常。我將 FIR 電路本身拆為用來控制的部件和用來運算本身的部件。底下簡單介紹一下電路機制。

#### 1. 控制部件(fir.v):

- (1)ap\_idle、ap\_done、ap\_start 控制位元:去看現在是否啟動這筆資料。其中,start 在一筆進來後會立刻切換成 0,準備下一筆進來;idle 會在算完立刻切換回 1; done 會在 last data 也確定被 transfer 過才會切換到 1。
- (2)Adress\_Read、Read、Adress\_Write、Write 狀態機: AXI Stream 的 Protocal 一般有這四組 concurrent 的狀態機,去處理現在寫入讀取的 位置與寫入和讀取。

#### (3) Pointer:

- (a)指派記憶體空間要存取哪一部分的 tap\_count 與 data\_count。
- (b)指派這段要存取甚麼內容到 rdata 的 Read Address。
- (4) data: ss\_tdata 是讀取到的 data、sm\_tdata 是算完輸出的 data。

## 2. 運算部件(Fir\_kernel.v):

用於計算每筆資料 FIR(convolution)的運算部件。



## 3. TestBench(fir\_tb.v):

用於模擬驗證電路波型是否合理,且可用於設計電路時的除錯。



#### B. 設計上遇到的問題:

1. RAM 沒有初始化,讓前幾筆運算的資料讀取到 unknow 的資料出錯。



主要影響在 data\_Do 的部分,也就是要運算的 600 筆資料,從 Memory 讀進來運算時會出錯。解決上,我設定了一塊 register 去在運算前攔截輸入的資料,並透過負緣 data\_WE 開始增加特定延遲,去在該補 0 或該和 data\_Do 同步的地方給予新的 data\_Do (datado\_out)。

不過這樣做會影響到電路原本設計的時序,因此我把 datado\_out 推遲一個 CLK,運算才會是合理的答案。

2. 前面解決 RAM 初始化問題時,有推遲了一格 CLK,會導致我原本對 ap\_start 提早啟動或 arvalid 太晚觸發,影響 rdata,因此我讓 ap\_start 在 rvalid=1 時(確保最開始不受影響),ap\_start 的觸發晚一個 CLK。

```
| PASS| | Pattern | 595 | Golden answer: -1647 | Your answer: -1647 |
| PASS| | Pattern | 596 | Golden answer: -1464 | Your answer: -1464 |
| PASS| | Pattern | 597 | Golden answer: -1281 | Your answer: -1281 |
| PASS| | Pattern | 598 | Golden answer: -1098 | Your answer: -1098 |
| Pass| | Pattern | 599 | Golden answer: -1098 | Your answer: -1098 |
| Pass| | Pattern | 599 | Golden answer: -915 | Your answer: -915 |
| Pass| | Pattern | 599 | Golden answer: -915 | Your answer: -915 |
| Pass| | Pattern | Fass |
| Pass| | Pattern | Fass |
| Pass| | Pattern | 599 | Fass | Fas
```

這是 arvalid 太晚觸發的情況,若 ap\_start 太早觸發,第二次對 rdata 的判斷則會變為 5。

正確情況應該入上圖所示。

3. RTL 合成的語法錯誤:RTL 在推遲時間的語法上只能使用#(數字),數字是時間單位,而我的一個 CLK 設定成 10 個時間單位,因此我要推遲#10,不能用@(posedge axis\_clk);,否則在 simulation 時會出現問題。

### C. 波型結果:



### D. Run Simulation 結果:





時間沒有超過我的設置。

## D. Github 連結:

https://github.com/leolin0501/soclab.github.io/tree/main/Lab3