# Homework tips

# Homework / Lab 流程

- HW跟Lab主要分成4個步驟: (可能有幾次Lab會不同)
  - (1) RTL simulation
  - (2) Synthesis
  - (3) Gate-level simulation
  - (4) upload
- 分別對應到每次作業的五個資料夾的其中四個

```
• LabXX/HWXX — 00_TESTBED
- 01_RTL
- 02_SYN
- 03_GATE
- 09_UPLOAD
```

# Directory tree structure



## 00 TESTBED

- 擺放驗證流程與測試資料的資料夾。(TESTBENCH.sv / Pattern.sv / input.txt / output.txt ...)
- 大部分的Lab跟前三次的HW助教會幫你把Pattern寫好, 提供同學驗證自己的Design。
- 如果題目有需求,則助教不會提供Pattern,
   Pattern將會由同學自行完成,以驗證自己的Design。
- 所有HW/Lab中,你的Design都必須通過所有Pattern才會給分, 任何一筆測資錯誤都是0分,不會依照通過比例給分。

# 01\_RTL

- 進行RTL simulation的資料夾,主要包含當次要完成的Design檔案 (XXX.sv)。
- 也包含01\_run與09\_clean\_up兩個Script。
  - 01\_run: 進行電路模擬
  - 09\_clean\_up: 清除波型檔
  - RTL simulation會用pattern去驗證你的Design的functional正確性。
- · 如果通過所有pattern會得到一隻PASS貓貓,有任何一筆pattern錯誤會得到一隻FAIL蠑螈。





script 使用範例:

#### 02 SYN

- 進行電路合成的資料夾,主要包含合成的tcl檔。(syn.tcl)
- 也包含01\_run\_dc與09\_clean\_up兩個Script。
  - 01\_run\_dc: 進行電路合成
  - 09\_clean\_up: 清除合成結果
- 合成結果包含Timing report、Area report、Netlist、Delay format。
- 合成結果不能有Error、不能有Latch、要有Area report、Timing report slack MET。 (slack ≥ 0)
- Synthesis可以<mark>驗證你的timing、是否有使用到不可合成的語法。</mark>

```
Number of ports:
Number of nets:
Number of cells:
                                           161
Number of combinational cells:
                                           161
Number of sequential cells:
Number of macros/black boxes:
                                            Θ
Number of buf/inv:
                                            38
Number of references:
Combinational area:
                                   2864.030431
Buf/Inv area:
                                    379.209614
Noncombinational area:
                                      0.000000
Macro/Black Box area:
                                      0.000000
                            undefined (No wire load specified)
Net Interconnect area:
Total cell area:
```

```
U875/Y (NAND2X4)
                                                      5.05 r
U974/Y (NAND3X4)
                                           0.16
                                                      5.21 f
out n[7] (out)
                                                      5.21 f
data arrival time
                                                      5.21
max delay
                                           5.00
                                                      5.00
output external delay
                                                      5.00
data required time
                                                      5.00
                                                      -5.21
slack (VIOLATED)
```

Startpoint: in num0[1] (input port) Endpoint: out numl[0] (output port) Path Group: default Path Type: max Path input external delay 0.00 r in num0[1] (in) 0.00 0.00 r U250/Y (INVXL) 0.06 0.06 f U166/Y (A0I222XL) 0.58 0.64 r U218/Y (A0I222XL) 0.34 0.98 f U170/Y (INVX2) 0.20 9.28 f U332/Y (A0I22X1) 0.72 10.00 r out num1[0] (out) 0.00 10.00 r data arrival time 10.00 max delay 10.00 10.00 output external delay 10.00 data required time 10.00 10.00 10.00 slack (MET)

Area report

Timing report

## 02\_SYN

- 記得檢查是否合成出Latch
  - 可以在syn.log用ctrl+F尋找關鍵字Latch
- 如果出現Latch → Demo Fail

```
Read RTL Code
read_sverilog {$DESIGN\.sv}
Loading db file '/usr/synthesis/libraries/syn/dw foundation.sldb'
Loading db file '/usr/synthesis/libraries/syn/standard.sldb'
Loading db file '/RAID2/COURSE/iclab/iclabta01/umc018/Synthesis/slow.db'
Loading db file '/usr/synthesis/libraries/syn/gtech.db'
 Loading link library 'slow'
 Loading link library 'gtech'
Loading sverilog file '/home/RAID2/COURSE/dcs/dcsta02/TA/Lab02/01_RTL/Sort.sv'
Detecting input file type automatically (-rtl or -netlist).
Reading with Presto HDL Compiler (equivalent to -rtl option).
Running PRESTO HDLC
Compiling source file /home/RAID2/COURSE/dcs/dcsta02/TA/Lab02/01 RTL/Sort.sv
Inferred memory devices in process
        in routine Sort line 52 in file
                '/home/RAID2/COURSE/dcs/dcsta02/TA/Lab02/01 RTL/Sort.sv'.
                                Width | Bus | MB | AR | AS | SR | SS |
    Register Name
                       Type
     out num2 reg
                       Latch
```

# 03\_GATE

- 進行Gate-level simulation的資料夾。
- 包含01\_run與09\_clean\_up兩個Script。
  - 01\_run: 進行電路模擬
  - 09\_clean\_up: 清除波型
- 與RTL simulation相似,會使用與01\_RTL相同的pattern, 輸入合成出來的電路加上cell delay進行模擬。
- 同時驗證電路functional與timing的正確性。
- 如果在01\_RTL階段的code寫法不當,合成出來的電路就會不正常,在這一步驟高機率翻車。

## 09 UPLAOD

- 上傳你的Design (XXX.sv)到助教帳號底下,
- 包含01\_upload與02\_download兩個Script。
  - 01\_upload: 上傳code
  - 02\_download:下載上傳結果
- 上傳前請確認在01\_RTL的XXX.sv是否為你要繳交的版本
- 會依照當前時間上傳至1de或2de,過了2de的Deadline將無法上傳
- ./02\_download [argument] 可以確認你上傳的檔案
  - [argument] = demo1 or demo2

```
linux01 [Lab02/09_UPLOAD]% ./02_download demo1
Download done!
linux31 [Lab02/09_upload]% ./02_download demo2
Download done!
linux31 [Lab02/09_upload]% ./02_download demo2
You haven't uploaded yet!

Download your code to 09_UPLOAD directory
linux31 [Lab02/09_upload]% ls
01_upload 02_download Counter.sv Counter_dcsta02.sv

02_download 使用方式
```