# **CS6135 VLSI Physical Design Automation**

# Homework 1: P&R Tool

Due: 23:59, October 13, 2022

#### 1. Goal

In this homework, you are asked to use Cadence Innovus to complete the P&R (Place and Route) flow for a given synthesized standard-cell design. The goal is to acquaint you with Innovus and the P&R flow. Besides, you are encouraged to try to optimize timing, total area, and total wirelength without violating any timing or DRC constraints.

In a clear way, we want you to utilize a P&R tool (Cadence Innovus) to do APR to generate a layout.



# 2. Working Items

- Follow the procedures described in Section 6 step by step to get familiar with Innovus.
- Try your best to use Innovus for optimizing the timing (clock period in the SDC file) and the area (try to adjust the core utilization in Design Planning stage) of the circuit. (Hint: You need to adjust the value of the clock period (2x and x) in the .sdc file to optimize the timing.)
  - create\_clock [get\_ports {clk}] -name VCLK -period 2x -waveform {0 x}
- Try to switch the timing-driven option on and off and change congestion-driven effort setting, respectively, when placing standard cells to see how they affect the result. Please also try to explain the difference(s) between the timing-driven placement and congestion-driven placement in your submitted report.
- Please explain why we need to insert filler cells into the design.

- Show the information of clock period (design.sdc), slack (timing.rpt), total area (area.rpt), total wirelength (route.rpt), and DRC (drc.rpt) in the report.
- Make sure that the slack must be non-negative and the number of DRC violations must be zero for your physical implementation to be successful.

# 3. Report

Your report should contain the following contents, and you can add as more as you wish.

- (1) Your name and student ID
- (2) A comparison table like the following one, and an explanation of the result (The table should be built under a fixed core utilization and clock period and you should specify them in the report.)

|                  | (congestion-driven, timing-driven) |         |          |         |          |         |
|------------------|------------------------------------|---------|----------|---------|----------|---------|
|                  | (L, off)                           | (L, on) | (M, off) | (M, on) | (H, off) | (H, on) |
| slack            | ???                                | ???     | ???      | ???     | ???      | ???     |
| total wirelength | ???                                | ???     | ???      | ???     | ???      | ???     |

- (3) The difference(s) between the congestion-driven placement and timingdriven placement
- (4) An explanation of why we insert filler cells
- (5) Show your best result (including clock period, total area, total wirelength, slack, congestion-driven effort and timing-driven on/off settings, and their snapshots) to maintain a non-negative slack and no DRC violation.

## 4. The File to be Handed in

Please package all the following items in one file named CS6135\_HW1\_{STUDENT\_ID}.zip and submit it to eeclass.

- (1) CS6135 HW1 {STUDENT ID}.tar.gz
  - An archive containing your post P&R design
    - \$ tar -zcvf CS6135\_HW1\_{STUDENT\_ID}.tar.gz HW1/
      For example:
    - \$ tar -zcvf CS6135\_HW1\_111062500.tar.gz HW1/
- (2) CS6135 HW1 {STUDENT ID} report.pdf
  - Your report

## (3) CS6135 HW1\_{STUDENT\_ID}\_chip.jpg (or .png)

The final chip layout of your best result generated by Innovus (use print-screen)

# 5. Grading

- ✓ The completeness of your submitted report
- ✓ The quality (clock period, total area, and total wirelength) of your physical implementation

### 6. Procedures

Please follow the steps below to complete your physical implementation of the given design. Note that each figure shown below is just an example, so your result may not be the same as it.

To follow the procedures, you'd better have a basic understanding of CLI (command-line interface). If you are not familiar with how to operate shell and vim, please study the "Shell Tutorial.pdf" that has been uploaded to eeclass.

# A. Design Preparation

#### Step 1. Log in to the workstation (using MobaXterm for ease)

Please download HW1.tar.gz from eeclass. Then, upload the file to the server nthucad.cs.nthu.edu.tw.

\$ scp HW1.tar.gz {YOUR ACCOUNT}@nthucad.cs.nthu.edu.tw:.

(\$ is a prompt, not a command, so don't type it. scp stands for secure copy.)

Next, login to the server nthucad.cs.nthu.edu.tw (by using the command ssh in some sort of command windows such as putty, Cygwin, MobaXterm, terminal.app, etc), and then change your password by entering the command yppasswd.

(ssh stands for secure shell. -XY means to enable X11 forwarding to see GUI on Linux.)

\$ ssh -XY {YOUR ACCOUNT}@nthucad.cs.nthu.edu.tw

#### \$ yppasswd

The server nthucad.cs.nthu.edu.tw is just a proxy server (or a so-called relay server), which is used to connect other servers on a private network. That means it only contains some basic services, so you need to log in to another workstation with Linux system (ic51) to run Innovus, e.g.,

#### \$ ssh -XY ic51

Also, you could enter lab\_uptime to see the loading information of each available server. You could choose the server which has fewer active users to log in.

### Step 2. Invoke Innovus

Before invoking Innovus with GUI, you might need to set the environment variable "DISPLAY" to your IP address and also make sure that you have already installed X server such as Xming or X-win32 in your computer. (Hint: Use MobaXterm in Windows or XQuartz in OS X at the beginning, and then you won't worry about it.)

\$ innovus # invoke Innovus

(If you didn't set up a X server on your PC and forward X11 to the workstation properly, you will get the following error.)

# **B.** Design Setup

First, we need to import the given design and read in all required files. Each time you enter a command, it's very important for you to check whether the error messages show in the console.

#### **Step 1. Set CPU Usage and Process Node**

Window > Tools > Set Multiple CPU Usage ...

#### **Local Machine**

| Number of Local CPU(s) 8 | Number of Local CPU(s) | 8 |
|--------------------------|------------------------|---|
|--------------------------|------------------------|---|

Then click **OK** 

innovus> setDesignMode -process 45

## Step 2. Import Design

Window > File > Import Design...

### Netlist

| Verilog  | Selected             |
|----------|----------------------|
| Files    | AES_1.v              |
| Top Cell | Select "Auto Assign" |

## Technology/Physical Libraries

| LEF Files | Selected                   |
|-----------|----------------------------|
| LEF Files | NangateOpenCellLibrary.lef |

#### Power

| Power Nets  | VDD |
|-------------|-----|
| Ground Nets | VSS |

# **Analysis Configuration**

| MMMC View Definition File | mmmc.view |
|---------------------------|-----------|
|---------------------------|-----------|

Then click **OK** 

Then it will open a layout window like the following figure. (You can click on the marked bottom first to fit the design to the window size.)



# Step 3. Save design

Window > File > Save Design...

| Data Type | Select "Innovus" |
|-----------|------------------|
| Path Name | setup            |

Then click **OK** 

#### P.S. Any time you want to restore a design

Window > File > Restore Design...

| Data Type           | Select "Innovus"          |
|---------------------|---------------------------|
| Restore Design File | setup (Your saved design) |

Then click **OK** 

# C. Floorplan and Placement

Next, we specify a region and put our design in it.

## Step 1. Initialize floorplan

Window > Floorplan > Specify Floorplan... > Basic

| Specify By           | Select "Size"                             |
|----------------------|-------------------------------------------|
| Core Size by         | Select "Aspect Ratio"                     |
| Ratio (H/W)          | 1.0                                       |
| Core Utilization     | 0.7 (Depends on you, 0 < utilization < 1) |
| Core Margins by      | Select "Core to Die Boundary"             |
| Core to Die Boundary | Core to Left: 4.0                         |
|                      | Core to Right: 4.0                        |
|                      | Core to Top: 4.0                          |
|                      | Core to Bottom: 4.0                       |

Then click **OK** 

The initial floorplan should be like the following figure. The gray solid rectangle is the core area in which you will put all your standard cells.



#### **Step 2. Full Placement**

Window > Place > Place Standard Cell...

| Run Full Placement | Selected |
|--------------------|----------|
|--------------------|----------|

Window > Place > Place Standard Cell... > Mode...

#### **Placement**

| Congestion Effort           | Depends on you |
|-----------------------------|----------------|
| Run Timing Driven Placement | Depends on you |
| Place IO Pins               | Checked        |

Then click **OK** 

And click **OK** again in the previous pop-up window

In order to see the placed standard cell, please remember to uncheck the marked checkbox to hide the routing net. You can use the zooming utility to observe the layout.



# D. Clock Tree Synthesis (CTS)

You can see the clock tree by doing the following instruction:

1. Make sure "Route" checkbox is checked and uncheck the "Net" checkbox.



2. Double click on the "Net" and then check the "Clock" checkbox.



After these steps you can see picture like this (the clock tree is showed):



# E. Power Planning

## **Step 1. Connect Global Net**

Window > Power > Connect Global Net...

### **Power Ground Connection > Connect**

| Pin         | Selected |
|-------------|----------|
| Pin Name(s) | VDD      |

## **Power Ground Connection > Scope**

### **Power Ground Connection**

| To Global Net | VDD |
|---------------|-----|
|---------------|-----|

Then click Add to List

### **Power Ground Connection > Connect**

| Pin         | Selected |
|-------------|----------|
| Pin Name(s) | VSS      |

### **Power Ground Connection > Scope**

| Apply All | Selected |
|-----------|----------|
|-----------|----------|

#### **Power Ground Connection**

| To Global Net | VSS |
|---------------|-----|
|---------------|-----|

Then click Add to List, click Apply and close the pop-up window

# **Step 2. Construct Power Network**

Window > Power > Power Planning > Add Ring...

#### Rasic

| Net(s)             | VDD VSS (please select by yourself) |
|--------------------|-------------------------------------|
| Ring Configuration |                                     |
| Layer (T/B/L/R)    | 7/7/6/6                             |
| Width (T/B/L/R)    | 0.6/0.6/0.6/0.6                     |
| Spacing (T/B/L/R)  | 0.5/0.5/0.5/0.5                     |

Selected

Then click **OK** 

Offset: Center in channel

Window > Power > Power Planning > Add Stripe...

#### **Basic**

# **Set Configuration**

| Net(s)  | VDD VSS (please select by yourself) |
|---------|-------------------------------------|
| Layer   | metal6(6)                           |
| Width   | 0.4                                 |
| Spacing | 0.5                                 |

#### **Set Pattern**

| Set-to-set distance | 5 |
|---------------------|---|

# First/Last Stripe

| Relative from core or selected area | Start: 0.5 |
|-------------------------------------|------------|
|-------------------------------------|------------|

Then click **Apply** 

## **Set Configuration**

| Net(s)  | VDD VSS (please select by yourself) |
|---------|-------------------------------------|
| Layer   | metal7(7)                           |
| Width   | 0.4                                 |
| Spacing | 0.5                                 |

### **Set Pattern**

| Set-to-set distance | 5 |
|---------------------|---|
|---------------------|---|

## First/Last Stripe

| Relative from core or selected area | Start: 0.5 |
|-------------------------------------|------------|
| Relative from core or selected area | Start: 0.5 |

Then click **OK** 

Window > Route > Special Route...

| Net(s) | VDD VSS (please select by yourself) |
|--------|-------------------------------------|
| (- )   | · = = · · · · · (F)                 |

Then click **OK** 

After these steps you can see the power planning result like this (remember to check the "Net" checkbox)



# F. Route (Clock Nets and Signal Nets)

### Step 1. Route Design

Window > Route > NanoRoute > Route...

Then click OK

### Step 2. Analyze timing (setup and hold) and check routability

innovus> report\_timing

Is there any timing violation (slack < 0)?

(slack = required time - arrival time. If slack < 0, it is failed.)

## Step 3. Optimize routing results

If there is any timing violation, you can fix timing violation by following command: innovus> setAnalysisMode -analysisType onChipVariation innovus> optDesign -postRoute

You can see the routing results as follows.



## G. Insert Filler Cells

(Why do we insert filler cells? Please google it and write a reasonable explanation in your report.)

## Step 1. Insert standard cell filler and connect P/G nets of cells

```
innovus> getCTSMode -engine -quiet
innovus> getFillerMode -quiet
innovus> addFiller -cell {FILLCELL_X1 FILLCELL_X2 FILLCELL_X4
FILLCELL_X8 FILLCELL_X16 FILLCELL_X32} -prefix FILL
```

#### Step 2. Save design

Window > File > Save Design...

| Data Type | Select "Innovus" |
|-----------|------------------|
| Path Name | final            |

Then click **OK** 

#### Step 3. Dump report

```
innovus> report_timing > timing.rpt
innovus> report_area > area.rpt
innovus> report_route -summary > route.rpt
innovus> verify drc > drc.rpt
```

### Step 4. Take a snapshot of your final layout

Save it as a graphic file "CS6135 HW1 {STUDENT ID} chip.jpg"

## Step 5. Exit

innovus> exit

## P.S. Using TCL

When the last time you exit the innovus, all your GUI operations are translated as commands and are stored in the file "innovus.cmd." You could copy it into "apr.tcl" and modify it as you wish. Next time you can just enter source apr.tcl in innovus to complete the whole process.

innovus> source apr.tcl