## Genus Tutorial



**McCormick** 

Northwestern Engineering

## **Genus Tutorial**

Before going to next steps, please note that those lines that start with '#' are explanation, lines that follow with '\$' are commands and you need to copy and then paste in your terminal and press enter.

1) # Type following command to source the cadence environment.

\$ source /vol/ece303/genus\_tutorial/cadence.env

```
[qcb2982@ras ~]$ source /vol/ece303/genus_tutor1al/cadence.env
[qcb2982@ras ~]$ ■
```

2) # Create working directory, for example "Lab2". Then go into the directory "Lab2" and copy files to this folder. 'mkdir' means make directory; 'cd' means change directory; 'cp' means copy.

```
$ mkdir Lab2
```

\$ cd./Lab2

\$ cp /vol/ece303/genus\_tutorial/alu\_conv.v .

\$ cp /vol/ece303/genus\_tutorial/alu\_conv.sdc .

\$ mkdir Synthesis

Lab2 folder should contain: alu\_conv.sdc, alu\_conv.v, Synthesis. You could type "ls" to see files in the directory.

3) # Go to **Synthesis** folder and then type "genus" and press enter to run the cadence tool.

\$ cd Synthesis

\$ genus

```
[qcb2982@ras Synthesis]$ genus

IMPDIR is being set to /tmp/genus_temp_19276_ras.ece.northwestern.edu_qcb2982_pvUhwk

Cadence Genus(ITM) Synthesis Solution.

Copyright 2018 Cadence Design Systems, Inc. All rights reserved worldwide.

Cadence and the Cadence logo are registered trademarks and Genus is a trademark

of Cadence Design Systems, Inc. in the United States and other countries.

Version: 18.14-s037_1, built Wed Mar 27 10:19:21 PDT 2019

Options:

Date: Wed Sep 18 16:31:15 2019

Host: ras.ece.northwestern.edu (x86_64 w/Linux 2.6.32-754.22.1.el6.x86_64) (4cores*8cpus*1physical cpu*In tel(R) Xeon(R) CPU E5-1620 0 @ 3.60GHz 10240KB) (16252572KB)

OS: Red Hat Enterprise Linux Server release 6.10 (Santiago)

Checking out license: Genus_Synthesis

Loading tool scripts...

Finished loading tool scripts (11 seconds elapsed).

@genus:root: 1> ■
```

Important: Everything will be command based. There is no GUI interface.

4) # read RTL file, '...' refers to files in the upper level folder

\$ read\_hdl ../alu\_conv.v

```
@genus:root: 1> read_hdl ../alu_conv.v
@genus:root: 2>
```

5) # set lib and lef files. This provides information of gates.

\$ set\_db library /vol/ece303/genus\_tutorial/NangateOpenCellLibrary\_typical.lib

\$ set\_db lef\_library /vol/ece303/genus\_tutorial/NangateOpenCellLibrary.lef

Important: It's fine to have Warning, but ERROR needs to be fixed.

@genus:root: 2> set\_db library /vol/ece303/genus\_tutorial/NangateOpenCellLibrary\_typical.lib
@genus:root: 3> set db lef library /vol/ece303/genus tutorial/NangateOpenCellLibrary.lef

6) #Elaborating design

\$ elaborate

\$ current\_design alu\_conv

```
@genus:root: 4> elaborate
@genus:root: 5> current_design alu_conv
design:alu_conv
```

- 7) #Read sdc file, which is for timing constraints. It defines max delay, load, max capacitance and max transition of the circuit.
  - "../" refers to files in the upper level folder

\$ read\_sdc ../alu\_conv.sdc

Important: read\_sdc should have 0 failed

```
genus:design:alu_conv 6> read_sdc alu_conv.sdc
Statistics for commands executed by read sdc:
 "all_inputs"

    successful

                                                                   Θ
                                                                    (runtime
                                                                                0.00)
                                                 2
 "all_outputs"
                                successful
                                                                   Θ
                                                                                0.00
                                                                                0.00)
 "current design"
                                successful
                                                                   0
                                                                      runtime
                                                      tail
 "set load"
                                successful
                                                      failed
                                                                   Θ
                                                                     (runtime
                                                                                0.00
 "set_max_capacitance"
                                                                   Θ
                                                                     (runtime
                                                                                0.00)
                                successful
                                                      failed
                                                                                0.00)
 "set max delay"
                                                                   Θ
                                                                     (runtime
                                successful
                                                                    (runtime
                                                                                0.00)
 "set_max_transition"
                                successful
Total runtime 0.0
@genus:design:alu conv 7>
```

8) # The setting below are all default. Syn\_generic is for synthesis into generic gates with some RTL optimization. Syn\_map is for mapping the design to cells from provided library with some logic optimization. Syn\_opt is for gate level optimization. Then starts to Synthesize.

```
$ syn_generic
```

\$ syn\_map

\$ syn\_opt

```
@genus:design:alu_conv 7> syn_generic
@genus:design:alu_conv 8> syn_map
@genus:design:alu_conv 9> syn_opt
```

9) # Report timing, and it will return longest logic path, and the timing slack of the design.

\$ report\_timing > timing.rpt

```
@genus:design:alu_conv 10> report_timing > timing.rpt
Path 1: MET (377 ps) Path Delay Check
     Startpoint: (F) a_sel
       Endpoint: (F) out[7]
                    Capture
                               Launch
      Path Delay:+
                       1000
      Drv Adjust:+
                                    Θ
                          Θ
         Arrival:=
                       1000
   Required Time:=
                       1000
       Data Path:-
                        623
           Slack:=
                        377
```

After timing report, you can open timing.rpt file using a text editor, e.g. vim or emacs, to see the report above. You can open another terminal to do this if you do not want to quit the current Genus session.

NOTE THAT THE ACTUAL DELAY AND AREA VALUES YOU OBSERVE WHEN YOU RUN GENUS MAY DIFFER FROM THOSE IN THESE SCREENSHOTS AS THE LIBRARIES AND SOFTWARE GET UPDATES OVER TIME.

10) # Report area, and it will return the design name, design area, and gate numbers.

\$ report\_area > area.rpt

@genus:design:alu\_conv 11> report\_area > area.rpt

| Instance Module | Cell Count | Cell Area | Net Area | Total Area |
|-----------------|------------|-----------|----------|------------|
| alu_conv        | 220        | 225.834   | 322.806  | 548.640    |

Note: After area report, you can open area.rpt file using a text editor to see report above.

11) # Write gate level netlist file. This is finally generated gate level netlist from synthesis.

\$ write\_hdl > alu\_conv\_syn.v

12) # Quit from tool

\$ quit

@genus:design:alu\_conv 13> quit

Note in this design example, the design is fully combinational without sequential circuits and clocks. For a design with clock, the sdc file needs to be modified to define clock period. Examples can be found in the commented-out lines in the sdc file, i.e. alu\_conv.sdc.