# **Computer-Aided VLSI System Design**

Synthesis Lab 1-1: Design Vision / Design Compiler Synthesis Lab 1-2: Synopsys Memory Library Generation

# **Objectives:**

In this lab, you will learn:

- 1. Basic concept about synthesis
- 2. How to use Synopsys Design Vision (GUI) / Design Compiler (text mode)
- 3. How to use Synopsys Design Compiler to generate the memory library file for Synopsys Design Compiler

# **Environment Setup:**

1. Make sure you can run design compiler:

```
dc_shell -h
```

IF it returned:

```
dc shell: Command not found.
```

Go to edit ~/.cshrc, comment out line 90-92 like this:

```
#if (-f /usr/spring_soft/CIC/debussy.cshrc ) then
# source /usr/spring_soft/CIC/debussy.cshrc
#endif
```

Then login again, or:

```
source ~/.cshrc
```

2. Make a working directory:

```
mkdir synthesis_lab
cd synthesis_lab
```

3. Copy synopsys\_dc.setup to .synopsys\_dc.setup into your working directory: cp ~cvsd/CUR/Synthesis/Lab1/synopsys\_dc.setup ./.synopsys\_dc.setup

**Note:** If you already have a .synopsys\_dc.setup file and you do not want to overwrite it, you can add only the Library and tools related lines that you miss into your own .synopsys\_dc.setup file.

## **Copy Files from CVSD Directory**

1. Copy all the files into your work directory,

```
cp -r ~cvsd/CUR/Synthesis/Lab1/* .
```

2. Check if you have these files

| Filename                     | Description                                |
|------------------------------|--------------------------------------------|
| .synopsys_dc.setup           | Design compiler setting                    |
| Lab1_alu.v                   | The source ALU file                        |
| HSs13n_512x8_fast_syn.lib    | The memory library under fast condition    |
| HSs13n_512x8_slow_syn.lib    | The memory library under slow condition    |
| HSs13n_512x8_typical_syn.lib | The memory library under typical condition |

# Lab1-1: Synopsys Design Vision Read files

- 1. The function of *Lab1\_alu.v* is from your previous Lab. We will try to use this sample and practice Synopsys synthesis tool step by step. We will show the GUI example with figures and text-mode with the strings in the text blocks.
- 2. Build your working directory by yourself, copy all files and start up design\_vision at working directory by using the **dv &** command. Also, you could invoke text mode by using **dc\_shell** command or **Command line** at the bottom of the window.



3. Check the GUI environment setting "File -> Setup". If the "Line library" or "Target library" or "Symbol library" is empty, you have to check the .synopsys\_dc.setup or use the GUI to choose the library files.



4.

5. read *Lab1\_alu.v* 



5. Check the log information. If any error or warning message, you have to fix it! After that, checking all the registers are filp-flop type. You have to modify your verilog code, if there is the **latch** in your circuit!



6. Synopsys Design analyzer will translate verilog code into G-tech model. Double click the icon "ALU", and click the right button then choose Schematic view. We can get the G-tech MAP.



7. Or you can create a symbol view by click on the following symbol view button. The symbol view is as the right window.



#### Set clock

8. Back to the symbol view window. **Select the CLK**(at Symbol View) port and click "<u>Attributes</u>"-"<u>Specify Clock</u>".



9. Specify the clock as period 10ns. (100 MHz). Don't forget to select "don't touch network" and "fix hold".



And then type in following command to change the wire load model:

```
set_operating_conditions "typical" -library "typical" set_wire_load_model -name "ForQA" -library "typical" set_wire_load_mode "segmented"
```

# **Set operating environment**

10. Select "inputA" in the Symbol View and click "Attribute"-"operating environment"-"input delay". Set 2.5ns input delay.



- 11. Set "input B" as 3.8ns input delay; "instruction" as 4.5ns input delay; "reset" as 5.2ns input delay.
- 12. By the same way, setup output delay 8ns on "alu\_out".
- 13. Click "Attribute"-"optimization Constraints"-"Design constraints". Set max area is 0. Max fan-out is 8. max transition is 1. The error message in GUI mode could be ignored. And input following command:

set\_boundary\_optimization "\*" set\_fix\_multiple\_port\_nets -all -buffer\_constant



## **Check Design**

**14.** Click "**Design**"-"**Check Design**". Click "OK". If any error message, there may be error at above steps. Redo these steps!

# **Design Optimization**

15. Click "Design"-"Compile Design". Click "OK", start to optimize ALU.



# Report

16. Few seconds later, We will get our gate level circuit. We must to check our circuit met our conditions or not at first.



17. Try to select different report item and check the report. For example: Check timing, use "Timing"=>"Report Timing Paths"; check power, use "Design" => "Report Power"; check area, use "Design"=> "Report Area"

# \_\_\_\_\_ == The following is timing report. Report : timing -path full -delay max -max\_paths 1 -sort\_by group Design : ALU Version: B-2008.09-SP2 Date : Fri Oct 14 19:19:41 2011 Operating Conditions: typical Library: typical Wire Load Model Mode: segmented Startpoint: alu\_out\_reg[0] (rising edge-triggered flip-flop clocked by clk) Endpoint: alu\_out[0] (output port clocked by clk) Path Group: clk Path Type: max Des/Clust/Port Wire Load Model Library -----ForQA typical ALU Point Incr Path \_\_\_\_\_ clock clk (rise edge) 0.00 0.00 clock network delay (ideal) 0.00 0.00 alu\_out\_reg[0]/CK (DFFRX1) 0.00 0.00 r alu\_out\_reg[0]/Q (DFFRX1) 0.28 0.28 f alu\_out[0] (out) 0.00 0.28 f data arrival time 0.28 data arrival time 0.28 clock clk (rise edge) 10.00 10.00 clock network delay (ideal) 0.00 10.00 output external delay -8.00 2.00 -8.00 data required time 2.00 .\_\_\_\_\_ data required time data arrival time

# \_\_\_\_\_ == The following is power report. \_\_\_\_\_

Report : power

slack (MET)

-analysis\_effort low

Design : ALU Version: B-2008.09-SP2

Date : Fri Oct 14 19:19:45 2011

\*\*\*\*\*\*\*\*\*\*

Slack is Positive!!

```
Library(s) Used:
   typical (File:
/home/raid2_2/course/cvsd/CBDK_IC_Contest/CIC/SynopsysDC/db/ty
pical.db)
Operating Conditions: typical Library: typical
Wire Load Model Mode: segmented
Design
         Wire Load Model
                                   Library
______
ALU
                  ForQA typical
Global Operating Voltage = 1.2
Power-specific unit information :
   Voltage Units = 1V
   Capacitance Units = 1.000000pf
   Time Units = 1ns
   Dynamic Power Units = 1mW
                             (derived from V,C,T units)
   Leakage Power Units = 1pW
 Cell Internal Power = 81.9936 uW (94%)
Net Switching Power = 5.3187 uW (6%)
Total Dynamic Power = 87.3122 uW (100%)
Cell Leakage Power = 448.0108 nW
 _____
 == The following is area report.
 ***********
Report : area
Design : ALU
Version: B-2008.09-SP2
Date : Fri Oct 14 19:19:45 2011
***********
Library(s) Used:
   typical (File:
/home/raid2_2/course/cvsd/CBDK_IC_Contest/CIC/SynopsysDC/db/ty
pical.db)
Number of ports:
Number of nets:
Number of cells:
                           3.0
                         140
                          83
Number of references:
Combinational area: 1033.716617
Noncombinational area: 903.016769
Net Interconnect area: 18.000000
Total cell area: 1936.733387
Total area: 1954.733387
```

Notice at the last line "Slack". We know this circuit is safe at timing.

18. Repeat Step1. ~ Step 15. Try to change different settings and modify the constraints.

- 19. If the result is met your requirement, Synthesis is ending. Then, we must export the design to a file. Select "File"-"Save" (it will save the all the settings and results in ALU.ddc). You can also select "File"-"Save As" and choose "DDC" formate to save this design.
- 20. Save the gate level netlist in verilog formate. Select "File"-"Save As", choose "VERILOG" formate with the File name "ALU\_syn", and click "Save".



21. Finally, to save the timing information, you have to type the following commend in the command line: "write\_sdf -version 2.1 ALU.sdf". That will generate the timing information of this design.



22. You might use "write\_script > script\_file" command or save the comment history "History"-"Save Contents As..." to generate a script with the constraints you have made. After that, you could use "include script\_file" command or "File"-"Execute Script" button to re-run all steps automatically.



23. For verilog gate-level simulation, you may add "\$sdf\_annotate(sdf\_file, testbench\_module.ALU\_instance);" in initial block in your test bench to use timing information for simulation.

# Lab1-2: Synopsys Memory Library Generation Environment Setup:

- 1. Synopsys<sup>TM</sup> Design Compiler is not able to read the library file directly generated from the Memory Compiler. Please follow the below instructions to convert the .lib files to .db files that the Design Compiler can use.
- 2. We have gotten the TSMC 0.13µm 512 words \* 8bit memory library files "HSs13n 512x8 fast syn.lib",
  - "HSs13n 512x8 slow syn.lib",
  - "HSs13n\_512x8\_typical\_syn.lib" in the Verilog Lab2. Please check them whether they are in your working directory or not.

# **Compile the Memory Library:**

- 3. Now we are going to compile the .lib files to .db files. Firstly, check your Synopsys environments are correctly setup.
- 4. Run **dc\_shell -xg** under UNIX. And execute the following command in dc shell:

```
dc_shell> read_lib NAME.lib
dc_shell> write_lib USER_LIB -output OUTPUT_FILE_NAME
```

You should fill the name of one of the three memory files onto "NAME.lib" here. "USER\_LAB" is the Library Name you defined while generating the "Synopsys library model(.lib)" in Memory Compiler.

As for HSs13n\_512x8\_fast\_syn.lib, just type in following instructions:

```
dc_shell> read_lib HSs13n_512x8_fast_syn.lib
dc_shell> write_lib HSs13n_512x8 -output
HSs13n_512x8_fast_syn.db
```

The produced .db files are the synthesis models that Synospys Design Compiler can use. Remember to add where you put the .db files in the "search\_path" and add the .db file names in the "link\_library" and "target\_library" in your .synopsys\_dc.setup before further synthesis of the RAM.

### **Checkpoints:**

Please check with TAs before leaving this lab to make sure the following goals are accomplished and to get credits.

- 1. Show your synthesis result. Including synthesized gate level codes, sdf file, timing and area reports.
- 2. You have generated the memory db file. Please add them in to your .synopsys dc.setup.

#### **END of LAB**

### NTUEE GIEE

Creator:

1<sup>st</sup> Edition: Jazz Yang, 2002 2<sup>nd</sup> Edition: Lin Houng-mao, 2003 3<sup>rd</sup> Edition: Yu-Lin Chang, 2004, 2005 4<sup>th</sup> Edition: Yu-Lin Chang, 2006 5<sup>th</sup> Edition: Jui-Hsin Lai(Larry), 2008 6<sup>th</sup> Edition: Chih-Fan Lai, 2009 7<sup>th</sup> Edition: Chia-Wei Chang, 2010 8<sup>th</sup> Edition: Tung-Chien Chen, 2011