

#### Lab01 Binary-Coded Decimal(BCD)

### Inputs

• There is only 1 input, and the value is from 0 to 511.

### Outputs

Three outputs out\_hundred [2:0], out\_ten[3:0], out\_unit[3:0]
represent hundreds, tens, and units digit of input signal

When input signal is given, outputs should change at the same cycle

# Specifications

| Top module name | BCD (File name : BCD.sv) |  |
|-----------------|--------------------------|--|
| Input pins      | in_bin [8:0]             |  |
| Output pins     | out_hundred [2:0]        |  |
|                 | out_ten [3:0]            |  |
|                 | out_unit [3:0]           |  |

# Block Diagram



## Directory

- 00\_TESTBED
  - TESTBED.sv
  - PATTERN.sv
- 01 RTL
  - 01\_run
  - 09\_clean\_up
  - BCD.sv
- 02\_SYN
  - 01\_run\_dc
  - 09\_clean\_up
- 03\_GATE
  - 01\_run
  - 09\_clean\_up
- 09\_UPLOAD
  - 01\_upload
  - 02\_download

#### MobaXterm

Create New Session



## Change Password

- Default password: dcs
- Change password: passwd

```
CAD tools available on this machine (2022.03.13 updated)
  Cell-Based Design
  Simulation
                       VCS 2020.12(vcs)
                                                   XCELIUM 20.09(xrun)
                      VERDI_2020.12(nWave)
                                                  INCISIV_15.20(irun)
                      DC 2020.09(dc_shell)
  Synthesis
                                                   GENUS_20.10(genus)
                      ICC2_2020.09(icc2_shell)
                                                  INNOVUS_20.15(innovus)
  Physical Design
  STA / Power
                      PT_2019.03(pt_shell)
  Formal
                                                  JG_2021.03(jg)
  Full-Custom Design |
  Simulation
                      HSP_2020.03(hspice)
                      CEX_2020.12(cx,wv)
                      LAKER_2021.03(laker)
                                                  IC_06.17(virtuoso)
  Layout
                       Siemens Calibre
                      Synopsys MetaWare Development Toolkit
                      Synopsys Tetra Max
                      Python3.6
                      1717@lshc:5280@lshc:26585@lshc
  Useful Command:
  1. quota -us [username] --> check out your quota
                         --> change your password
  htop
                         --> check out server usage
                          --> check available server usage
linux01 [dcs/dcs240]% passwd
Changing NIS account information for dcs240 on raid.
Please enter old password:
```

://mobaxterm.mobatek.net

#### Command

- tar -xvf ~dcsta01/Lab01.tar
- cd Lab01/01\_RTL/
- vim BCD.sv (text editor)
  - i (輸入模式)
  - [Esc] (退回普通模式)
  - :w (儲存)
  - :q (結束)
- gedit BCD.sv (text editor)
  - view → Highlight Mode → Sources → Verilog
  - If you use Windows/MacOS, you can use Notepad++, or any editors you are used to using.

## gedit



#### RTL simulation

- cd Lab01/01\_RTL/
- ./01\_run (電路模擬)
- ./09\_clean\_up (清除波型檔)
- nWave & (看波型)
  - 範例波型

#### nWave



#### nWave



## nWave (change radix)



## Synthesis

- cd ../02\_SYN/
- ./01\_run\_dc (合成電路)
- ./09\_clean\_up (清除合成結果)
  - 合成結果: (不能有Error、要有Area report、Timing report slack met、不能有Latch)

```
Number of ports:
                                            20
Number of nets:
                                           103
Number of cells:
                                            94
Number of combinational cells:
                                            94
Number of sequential cells:
Number of macros/black boxes:
                                             Θ
Number of buf/inv:
                                            22
Number of references:
Combinational area:
                                   1333.886419
Buf/Inv area:
                                    222.868808
Noncombinational area:
                                      0.000000
                                      0.000000
Macro/Black Box area:
                            undefined (No wire load specified)
Net Interconnect area:
                                   1333.886419
Total cell area:
Total area:
                             undefined
```

## Synthesis

- 合成的timing report中的 slack必須≥0 (MET)
- 如果出現timing violation → Demo Fail!(slack < 0)

| Point                 | Incr  | Path   |
|-----------------------|-------|--------|
| input external delay  | 0.00  | 0.00 f |
| in bin[6] (in)        | 0.00  | 0.00 f |
| U36/Y (A0I2BB1XL)     | 0.29  | 0.29 f |
| U53/Y (INVXL)         | 0.21  | 0.50 r |
| U37/Y (A0I22XL)       | 0.23  | 0.73 f |
| U76/Y (A0I221XL)      | 0.51  | 1.24 r |
| U73/Y (INVXL)         | 0.15  | 1.39 f |
| U28/Y (NAND2XL)       | 0.14  | 1.53 r |
| U27/Y (OAI2BB1XL)     | 0.10  | 1.63 f |
| U8/Y (NOR2XL)         | 0.17  | 1.80 r |
| U18/Y (NOR2X1)        | 0.07  | 1.87 f |
| U17/Y (NOR2X1)        | 0.21  | 2.08 r |
| U40/Y (INVXL)         | 0.12  | 2.20 f |
| U26/Y (MXI2XL)        | 0.25  | 2.45 r |
| U39/Y (NAND2XL)       | 0.10  | 2.55 f |
| U38/Y (A0I21XL)       | 0.52  | 3.07 r |
| U51/Y (MXI2XL)        | 0.39  | 3.45 f |
| U11/Y (NOR2XL)        | 0.24  | 3.69 r |
| U15/Y (NOR2X1)        | 0.11  | 3.80 f |
| U52/Y (OR2XL)         | 0.32  | 4.12 f |
| U49/Y (NAND2XL)       | 0.14  | 4.27 r |
| U67/Y (OAI2BB1XL)     | 0.20  | 4.47 r |
| U66/Y (OAI2BB2XL)     | 0.20  | 4.68 r |
| U48/Y (INVXL)         | 0.13  | 4.81 f |
| U46/Y (OR2XL)         | 0.28  | 5.09 f |
| U96/Y (OAI2BB2XL)     | 0.19  | 5.28 f |
| out_unit[2] (out)     | 0.00  | 5.28 f |
| data arrival time     |       | 5.28   |
| max delay             | 12.00 | 12.00  |
| output external delay | 0.00  | 12.00  |
| data required time    |       | 12.00  |
| data required time    |       | 12.00  |
| data arrival time     |       | -5.28  |
| slack (MET)           |       | 6.72   |
|                       |       |        |

## Synthesis

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



#### Gate-level simulation

- cd Lab01/03\_GATE/
- ./01\_run (電路模擬)
- ./09\_clean\_up (清除波型檔)
- nWave & (看波型)
  - 範例波型



## Grading policy

- Pass the RTL & Synthesis & Gate-level simulation: 100%
  - 合成結果: (不能有Error、 Timing report slack met、 不能有Latch)
- Demo2 打7折

### Upload

- cd ../09\_UPLOAD/
- ./01\_upload (上傳code)
- ./02\_download [argument] (下載上傳結果)
  - [argument] = demo1 or demo2
  - 檢查是否上傳成功&正確
- Demo1: 3/3, 23:59:59 , Demo2: 3/10, 23:59:59

#### Facebook社團

- We establish a discussion club for all students
- You can join this club to ask questions and discuss with classmates

• The following is the link of FB club: www.facebook.com/groups/641166254678986/