

# Lab11 Exercise

Advisor: Prof. Chen-Yi Lee

TA: Yu-Hsiang Wang

Date: 2025/05/15



#### Outline

- 00\_TESTBED
- 01\_RTL
- 02\_SYN
- 03\_GATE
- 04\_MEM
- 05 APR
- 06\_POST
- Avoid DRC violation after nanoRoute

## 00\_TESTBED

- Put the pattern you use in 00\_TESTBED
- Include all memory.v in filelist.f

```
TESTBED.v
../04_MEM/MEM_IMAGE.v
```

Modify this part like this if you use TA's code



### 01\_RTL

- Use TA's RTL code
  - Prepare MEM\_IMAGE.v in 04\_MEM
  - Execute ./01\_run\_rtl
- Use your own RTL code
  - Remove the soft link named MVDM.v
  - Upload your code named MVDM.v
  - Prepare all memory.v in 04\_MEM
  - Execute ./01\_run\_rtl



#### 02\_SYN

- Modify target\_library and link\_library in .synopsys\_dc.setup
- Modify the synthesis cycle time in syn.tcl
- Execute 01\_run\_dc\_shell

```
set desinger "Student"
set search path
                        ../01_RTL
                        ../04 MEM
                        ~iclabTA01/UMC018 CBDK/CIC/SynopsysDC/db/
                        ~iclabTA01/UMC018 CBDK/CIC/Sdb/
                        /usr/cad/synopsys/synthesis/cur/libraries/syn/ \
                        /usr/cad/synopsys/synthesis/cur/dw "
set target library
                        " fsa0m_a_generic_core_ss1p62v125c.db \
                          fsa0m a generic core ff1p98vm40c.db \
                          fsa0m_a_t33_generic_io_ss1p62v125c.db \
                          fsa0m a t33 generic io tt1p8v25c.db \
                          L1 WC.db \
                          L0 WC.db"
                        " * $target library dw foundation.sldb standard.sldb L0 WC.db L1 WC.db"
set link library
set symbol library
                        " *.sdb "
set synthetic library
                        " dw foundation.sldb "
set verilogout no tri true
set hdlin enable presto for vhdl "TRUE"
set sh enable line editing true
history keep 100
alias h historv
```



# 03\_GATE

Execute ./01\_run\_gate



### 04\_MEM

- Use TA's RTL code
  - Memory used has been generated in Memory/ftclib\_200901.2.1/EXE
  - Memory name: L0 L1
  - Copy L0 L1 .v / .db / .lef / .lib to 04\_MEM
- Use your own RTL code
  - Prepare all\_your\_memory.v / .db / .lef / .lib in 04\_MEM



#### 05\_APR

- Put all Memory.lef in 05\_APR/LEF
- Put all Memory\_WC.lib & Memory\_BC.lib in 05\_APR/LIB
- Follow APR steps in APR\_flow\_2025S.pdf
  - You can execute ./01\_setenv to set OA\_HOME
  - You can source apr\_setting.cmd after you activate Innovus

```
05_APR]$ ./01_setenv
```

```
#!/bin/csh
setenv OA HOME /RAID2/cad/cadence/INNOVUS/INNOVUS 20.15.000/share/oa
```

[INFO] Loading Pegasus 21.21 fill procedures innovus 1> source ./cmd/apr\_setting.cmd ■



## 06\_POST

Execute ./01\_run\_post



#### Avoid DRC violation after nanoRoute

- End Iteration: more than once!
- Post Route Optimization
  - Turn on Optimize Via & Optimize Wire
- Routing Control
  - Turn on ECO Route

If you still have some DRC violation after nanoRoute with these settings, TA will suggest you should redo APR flow





# Thanks

