# **NCTU-EE IC Design LAB – Fall2023**

## Final Project: Innovus - From RTL to GDSII

Due to the main goal of this course is to teach students on the front-end design methodology, the APR of final project will be modified to pin design rather than pad design so it's easier.

# 1. Data Preparation

- 1. Complete rtl simulation, synthesis, and gate level simulation.
- 2. cd./05 APR/ write and check your CHIP.sdc file.

(Hint: you may modify the file generated during synthesize in ../02\_SYN/Netlist folder, and carefully check the constraints following the check list.pdf document.)

3. cp CPU\_SYN.v CHIP\_SYN.v and change the module name to CHIP.

(Because the design does not require any pad connection, you won't need to write your own shell file, nor do you need to execute ./00 combine.)

4. You don't need to write the CHIP.io file when you run Innovus at the first time. (The import design step should use CHIP\_SYN.v and leave the CHIP.io part empty.)

Notice that TA has provided 05\_APR/mmmc.view for you, please do not create mmmc.view by yourself, or you may fail in demo.

#### Please modify the mmmc.view file to include memory lib file:

You should include all your memory you used if you have multiple memory. create\_library\_set -name lib\_max -timing "XX ../04\_MEM/SRAM\_XXX\_WC.lib" ... create library set-name lib min -timing "XX ../04 MEM/SRAM XXX BC.lib" ...

```
# Version1.0 PMPC Vite Definition File
# Do Not Remove Above Line
# File: mmc.tcl
# File: mmc.
```

5. Open file: 05 APR/cmd/run apr.cmd

This file sets up the initial design environment. You can use these commands as an alternative to performing actions step-by-step via the GUI. However, the GUI option remains available if you find it more convenient.

```
# source cmd/floorPlan.cmd
# source cmd/powerRing.cmd
# source cmd/powerStripe.cmd
# source cmd/place.cmd
# source cmd/place.cmd
# source cmd/place.cmd
# source cmd/ploostCTSTiming.cmd
# source cmd/postCTSTiming.cmd
# source cmd/postRouteTiming.cmd
# source cmd/postRouteVerify.cmd
# source cmd/dofiller.cmd
# source cmd/sdfiller.cmd
# source cmd/sdfiller.cmd
# source cmd/sdfiller.cmd
```

Notice that please add your memory LEF file PATH at the end of lefFile variable.

For example:

add ../04\_MEM/XXXX.lef beyond the \$ProcessRoot/lef/BONDPAD.lef

```
# Project: iclab APR Flow
# File: run_apr.cmd
# Author: Lai, Lin-Hung @ Si2 Lab
# Date:
            2023.07.25
######### Paremeter setting #########
set NUM_OF_CPU 48
 set mmmcFile "mmmc.view"
 set lefFile '
   $ProcessRoot/lef/header6_V55_20ka_cic.lef
    $ProcessRoot/lef/fsa0m_a_generic_core.lef
    $ProcessRoot/lef/FSA0M_A_GENERIC_CORE_ANT_V55.lef
   $ProcessRoot/lef/fsa0m_a_t33_generic_io.lef
$ProcessRoot/lef/FSA0M_A_T33_GENERIC_IO_ANT_V55.lef
$ProcessRoot/lef/BONDPAD.lef
set topDesign "CHIP"
set verilogFile "./CHIP_SYN.v"
set ioFile "./CHIP.io"
set pwrNet "VCC"
set gndNet "GND"
```

Comment this line for the first time without CHIP.io file: set init io file \$ioFile

6. Launch innovus by the following command:

innovus -cpus 8 -init ./cmd/run\_apr.cmd -log ./log/run\_apr.log -cmd ./log/run apr.cmdlog

or make apr\_init

you may find pin are gathering together due to no CHIP.io provided, thus you can do step 7 to auto generate this io file.

7. Upper left corner: FILE -> SAVE -> IO FILE -> sequence check & generate template IO file check change the file name to CHIP.io and click OK.



Then exit

Uncomment this line for the first time without CHIP.io file:

### set init\_io\_file \$ioFile

Restart innovus again. You may see the pin shape below.



8. You may change the orders in CHIP.io file if you wish to modify your pin orders.

```
# Generated by: Cadence Innovus 20.15-s105_1
                                    Linux x86 64(Host ID ee31)
# OS:
# Generated on:
                               Mon Dec 25 21:08:16 2023
CHIP
# Design:
                                    saveIoFile -byOrder -temp CHIP.save.io
 # Command:
io_order = default
       (top
(pin name="clk" layer=2 width=0.2800 depth=0.7000 place_status=placed )
(pin name="rst_n" layer=2 width=0.2800 depth=0.7000 place_status=placed )
(pin name="10_stall" layer=2 width=0.2800 depth=0.7000 place_status=placed )
(pin name="awid_m_inf[3]" layer=2 width=0.2800 depth=0.7000 place_status=placed )
(pin name="awid_m_inf[2]" layer=2 width=0.2800 depth=0.7000 place_status=placed )
(pin name="awid_m_inf[1]" layer=2 width=0.2800 depth=0.7000 place_status=placed )
(pin name="awid_m_inf[0]" layer=2 width=0.2800 depth=0.7000 place_status=placed )
(pin name="awid_m_inf[31]" layer=2 width=0.2800 depth=0.7000 place_status=placed )
(pin name="awaddr_m_inf[31]" layer=2 width=0.2800 depth=0.7000 place_status=placed )
       (pin name="awaddr_m_inf[30]"
(pin name="awaddr_m_inf[29]"
                                                               layer=2 width=0.2800 depth=0.7000 place_status=placed layer=2 width=0.2800 depth=0.7000 place_status=placed
                                                               layer=2 width=0.2800 depth=0.7000 place_status=placed
        (pin name="awaddr m inf[28]"
       (pin name="awaddr_m_inf[27]"
                                                               layer=2 width=0.2800 depth=0.7000 place_status=placed
       (pin name="awaddr_m_inf[26]"
(pin name="awaddr_m_inf[25]"
                                                               layer=2 width=0.2800 depth=0.7000 place_status=placed
                                                               layer=2 width=0.2800 depth=0.7000 place_status=placed
          pin_name="awaddr_m_inf[24]"
                                                               layer=2 width=0.2800 depth=0.7000 place status=placed
```

9. After that, most of the steps are the same as Lab11 and Lab12. The only

difference is that there are no pads, so you should skip the step (Add PAD Filler).

#### 2. SDC FILE

#### SDC file CHIP.sdc

This file is generated from 02\_SYN.

You may change this to your target cycle time by yourself.

Normally, this may be equal or larger than 02 SYN due to wiring delay.

```
create_clock [get_ports clk] -period 20 -waveform {0 10}
set_clock_uncertainty 0.1 [get_clocks clk]
set_input_delay -clock clk 0 [get_ports clk]
```

Before CTS stage, you may no need to comment out the set\_clock\_uncertainty & set\_clock\_transition instruction.

### SDC file CHIP\_cts.sdc

The only difference of CHIP\_cts.sdc is that you need to comment out the set\_clock\_uncertainty & set\_clock\_transition instruction.

Then do the CTS stage.

#### 3. Short issue

Delete the short metal line, then use area nano route (Area Route--> Select Area and Route) to re-route that path. (sometimes may need to delete a longer metal line so the new routed result won't have short again)





#### 4. Check Area

type > summaryReport -noHtml -outfile summaryReport.rpt then you will see the CORE area.