

# Lab06 code review

#### Pattern

- 檢查design的錯誤
  - Spec1 : reset後所有的output signal要歸零
  - Spec2:計算完吐完值後4 cycles, out\_valid要歸零 (out\_valid只維持4 cycles)
  - Spec3 : outvalid 不能跟 invalid重疊
  - Spec4: 100cycle內要計算完成(out\_valid為high之前)
  - Spec5: function要對(前一頁的公式會有錯要檢查出來)
  - Spec6:當out\_valid是0時,out\_result要歸零

#### 產生clock

· Clock 要記得給初始值

```
integer CYCLE = 10;
always #(CYCLE/2.0) clk = ~clk;
initial clk = 0;
```

# 如何產生signed的測資

- urandom\_range要怎麼給signed的數
- test = \$urandom\_range(15,0);
- 他會回傳0000~1111
- 所以只要你前面的變數宣告為4bits signed, 他就會自動識別為-8~7

# Pattern 給值與檢查值的時間

- Pattern 給值與檢查的時機都是在 negedge clk,目的是為了讓 design在posedge clk取值時機與給值時間相隔半個cycle,檢查 時機也會等到output穩定半個cycle後才會檢查output值。
- 使用@(negedge clk);等到下一個negedge clk才繼續執行後面的 code,否則會直接執行下去



#### Sample code

- Initial 裡面的code是依序執行的,因此 task的順序很重要
- Spec3(invalid和outvalid不能重疊)在 input\_task裡面檢查,邊給input邊檢查 outvalid是否為1

```
initial begin
    reset task;
    in_valid = 0;
    in number = 4'dx;
    mode = 2'dx;
    total_latency = 0;
    for (i=0;i<=PATNUM;i=i+1)begin
        input task;
        gen_ans;
        wait outvalid;
        check_ans;
        outvalid rst;
        @(negedge clk);
    end
    #(1000)
    YOU PASS task;
    $finish;
end
```

### Sample code

- Spec5 check answer只能檢查4個cycle
- 第5個cycle如果outvalid仍為1算 spec2(outvalid沒有歸零)

```
task check_ans; begin
   for(cnt = 0;cnt<4;cnt=cnt+1 ) begin</pre>
       if(d_mode == 0) begin
           golden = d_number[cnt];
       end
       else if(d mode == 1) case (cnt) ···
       else if(d mode == 2) begin ···
       end
       else if(d_mode == 3)begin ···
       if(out_result!== golden)begin
           //fail;
           $display ("-----
           $display ("
          $display ("
          $display ("
           $display ("-----
           #(100);
           $finish;
       end
       @(negedge clk);
    end
```