# EESM518/ ELEC516 Design Automation Tutorial

Teaching Assistant: Michael Ling (EESM518), Toby Qian (ELEC516)

### 23/02/2010

## Objective

After this tutorial, you should gain essential understandings about ASIC design flow. Two popular tools for logic synthesis and auto placement/route would be introduced. A lab material is also supplied to help you understand the flow.

### Background on ASIC design flow

Front End and Back End design are the most popular division between ASIC flows. Front end is more concerned with design logic while Back end is more related to the physical aspect of the design. The whole process is shown in Fig. 1.

#### Front End Design

Each design process begins with a specification. The function of a system is specified and partitioned into submodels or systems to improve the efficiency and robustness. After specification. each module is designed to meet its own function. In digital domain, this design is usually modeled in a hardware description language (i.e., VHDL, verilog). Behavior simulation is devised to check the design function.

After the desired behavior is verified, we move to a stage called logic synthesis. In a fully custom design, this stage may be completed by human beings. Here, we only refer standard-cell based design (a semi-custom design strategy) where this step is accomplished by computer tools. Several key transformations are made here:

- 1. The design logic function is extracted from the HDL for each input and output. The result logic is then presented in basic Boolean equation;
- 2. All the extracted logic function is simplified to achieve better area/ power/ timing;
- 3. All the logic is then mapping into specific cells provided in the standard-cell library. This library is usually provided by foundry;
- 4. The timing/area/power is estimated and optimized to meet certain design constraints;

The output from logic synthesis is a netlist describing the interconnection of library gates. You will see it soon. Then you can utilize this netlist and the library gate model to device a pre-layout simulation which would include the cell delay into consideration and make the result more realistic. If this simulation passes, we hand over the netlist to the back end guys.



Figure 1: ASIC Design Flow

#### **Back End Design**

The back end process focuses on turning the netlist into a physical layout. This involves cell placement and interconnection routing (for signals). Good cell placement and interconnection routing tools would result in a significant better design in terms of area/power/timing. So several iterations of optimization would be performed here to achieve this goal. Usually back end design requires an understanding of tools and real-life experiences.

#### Note on Design Presentations

Probability a better way to see this process is to take a look at your design presentations:

- 1. You write a code in VHDL/Verilog;
- 2. Simulate your design in behavior simulation; We call it behavior simulation in a sense that at this stage, we do not have any information about the physical implementation of your design. Only the logic function is verified. There's no timing information in it.

- 3. Synthesis your design and get your design netlist; This stage your design has been mapped into structure connections with standard-cells. Standard-cell library provides a forest of logic cells for you to implement all possible logic functions (actually, a 2-input nand gate can implement all possible logic); This netlist file is usually in Verilog format;
- 4. With the netlist file, you can do Pre-Layout simulation with a standard library verilog file. The standard library file is only to describe cell functions and their delay information. This time, the simulation result is more realistic in the sense that all the cell/gate delays in your design is included. However, since we still haven't actually layout the cell, we do not know the wire delay (we do not know the distance between to cells, so their connecting wire lengths);
- 5. Placement & Route your design. This time, you get a physical design. You can extract the wire delay information and another netlist (since during this step, some logic might be revised for better timing);
- 6. With the wire delay information and the final netlist, you can redo your simulation (Post-Layout simulation). If it passes, then congratulations! You probability have a functional design (But function is only one concern, power/area are also important).

## **Tutorial Setup**

In this tutorial, we would use a simple 16-bit multiplier design to demonstrate the ASIC flow. A template folder "elec516\_lab" (or eesm518\_lab) contains all the necessary file and setup information for you to practice and use for your project. (See "Before Getting Started" section to download this folder)

The sub-folder "encounter" is used when you to Back-End place and route. There are two files in it.

- The "LEF" file contains the placement information for each standard cell (i.e., size, dimensions, input/output locations);
- The "lib" file is the timing library containing the cell and wire delay information;

You are encouraged to open these two files with a text editor to get a sense.

The "synopsys" folder contains synthesis and simulation setup.

- "db" folder is for you to store your synthesis results. it is short for your design library database;
- "libs" folder contains standard cell library ("db" file) and symbol library ("sdb" file) for synthesis use;
- "sim" folder is for your behavior simulation;
- "syn-sim" folder is for your gate-level (pre-layout/post-layout) simulation. There're verilog files of the standard cell library inside. Since after synthesis, your design is present in standard cells. So this verilog file contains the cell function and delays for you to simulate your design in a more practical situation;
- "syn" folder for you to synthesize your design. You must do it in this folder since it contains a setup file ".synopsys\_dc\_setup" (hidden, use ls -a to see it);
- "verilog" folder for you to put your source code;

## **Before Getting Start**

Download the tempelate folder :

>cp ~qianzl/public/elec516-lab . (copy the folder to your current working directory)

In order to set up the environment for the tools ( so that the system can recognize the licenses and versions for sysnopsys and cadence tools), in "elec516\_lab" (or "eesm518\_lab") folder, we need to source ".cshrc\_user" file first .

> source .cshrc\_user

After this step , you can type commands like

> which design vision

to check the current version of the tools which we'll use.

Note: in many cases , if the system tells you "command not found" , it's most likely you haven't "source .cshrc\_user" yet or the previous source action is no longer valid after reboot. You can source .cshrc\_user file again to fix this problem.

## Behavior Simulation (For VHDL input)

1) Go to the "elec516 lab/synopsys/sim" folder .

2) In "elec516\_lab/synopsys/sim" directory execute the following commands to analyze VHDL source code . If multiple VHDL file need to be analyzed, the bottom level module file is expected to be analyzed before top module file:

> vhdlan -nc ../vhdl/ARITH\_module.vhd

> vhdlan -nc ../vhdl/tb\_multiplier.vhd

>vhdlan -nc ../vhdl/cfg\_array\_mult.vhd

please check and fix any error according to the the information given after execute this command

3) Execute the command below to compile and elaborate the design

>scs -nc cfg\_array\_mult

4) simulate the design

Two kinds of method can be used to simulate the design : File I/O- read stimulus from file and write results into file. (In our example, we generate a vector file named "expect\_vector", each cycle, the testbench read one row of "expector\_vector" and pass the values to the hardware multiplier as input. Then compare the hardware output with the expected value in "expect\_vector", If any mismatch happens, write this cycle simulation information to a file named "error vector" for debugging use).

The second method is through observing the wave form of the simulation (following the commands below):

> scirocco &

Type in 'scsim -debug\_all' to open the simulation in debug mode. (As seen in figure )

| 🗶 Simulator Invocation Dialog |              |
|-------------------------------|--------------|
| Simulator Command Line        |              |
| scsim -debug_all]             |              |
| Type Scirocco Designator II   | ⊥Use Sources |
| OK                            | Help         |

Figure 2: scsim window

In the VirSim window, click window -> Hierarchy

|                            | Window -> Hierarchy                                                                                                         | -        | • —      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------|----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| 👯 VirSim - Interactive -   | SIM - 11 - Scirocco                                                                                                         |          |          | 🚰 VirSim - Hierarchy - 11 - inter.vpd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                       |
|                            | Window                                                                                                                      |          | Help     | File Edit Display View Window                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Help                                  |
|                            |                                                                                                                             |          |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |
|                            | 🗄 📓 🔄 🛛 🦿 EG                                                                                                                | roupO    | Nim 🗞    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Signals Search<br>■ C ■ G ■ V ■ S ■ P |
| History                    |                                                                                                                             |          |          | E TB_MULTIPLIER_15_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | P                                     |
| This program<br>of Synopsy | ALL RIGHTS RESERVED<br>n is proprietary and confident<br>s, Inc. and may be used and c<br>a license agreement contro<br>re. | lisclose | d only 📊 | <sup>2</sup> <sup>3</sup> <sup>1</sup> <sup>3</sup> <sup>3</sup> <sup>1</sup> <sup>1</sup> <sup>3</sup> <sup>3</sup> <sup>1</sup> <sup>1</sup> <sup>3</sup> <sup>3</sup> <sup>1</sup> <sup>1</sup> <sup>3</sup> <sup>1</sup> <sup></sup> | Fiter MutoGroupD Add                  |
| User Defined Buttons       |                                                                                                                             |          |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |
| Interactive                | Debug                                                                                                                       |          | A        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |
| pwd Is                     | Step                                                                                                                        | Next     | t        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |
| cd cd freq                 | ion1 Bin                                                                                                                    | Hex      |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |
|                            |                                                                                                                             | пех      | [        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |
| ls -v ls -                 | t brkpnt [sig] I                                                                                                            | nonitor  | [sig]    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |
| list size   list u         | an List Dumma                                                                                                               | int Hon  | itaun 🕅  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |
| M                          |                                                                                                                             |          |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |
| Simulator Control          |                                                                                                                             |          |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |
| Step Time 💷 🛛 🛛            |                                                                                                                             | ОК       | Cancel   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |
| Scope 👔                    |                                                                                                                             | ОК       | Cancel   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |
| Time 0 (1 ns)              |                                                                                                                             |          |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |
|                            |                                                                                                                             | St       | opped    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       |

Figure 3: Hierarchy Window of Scsim

In the VirSim-Interactive window, click Window -> Waveform , in order to add signals into the waveform , you need to select these signals in the Hierarchy window. For our tutorial design, in Hierarchy window, choose "PT(31 downto 0)" and press the middle button of your mouse, drag this signal to the waveform region. Similarly, add signals "XT(15 downto 0)" and "YT(15 downto 0)" to the waveform window.



Figure 4: Choose signals to be observed

In the VirSim-Interactive window, in "Simulator Control" area, you can set the Step Time (we leave 20ns as default), and click "OK". The Simulation begins, and you can observe the resulting waveform for your debugging.

For behavior simulation, the major purpose is to verify the correctness of function. And from the wave form below, we indeed observe that  $PT = XT \times YT$ ; thus verify the behavioral design.

Also, we can check the generated output file "error vector" for behavioral verification.



Figure 5: Simulation results

# Behavior Simulation (For Verilog input)

You are encouraged to use a third-party simulator during your code implementation stage. It is more convenient. Modelsim, ActiveHDL for examples. Also you can try it on the workstation with synopsys tools – VCS.

| + +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++< | 1022    | 994 <b>Ŭ</b> 10 | 01   | 1008   | X1015  | 1022   | ĬO    | Ĭ7     | 14    | 21     |
|----------------------------------------------------------------------------------------------------------------|---------|-----------------|------|--------|--------|--------|-------|--------|-------|--------|
|                                                                                                                | -606    | 263 41          |      | 109    | (110   | (449   | )-169 | (-529  | -183  | (-456  |
|                                                                                                                | -619332 | 261 41          | 7417 | 109872 | 111650 | 458878 | )0    | (-3703 | -2562 | (-9576 |
| 💽 🔷 /Tb_Multiplier_15_0/pt                                                                                     | -619332 | 261 41          | 7417 | 109872 | 111650 | 458878 | )0    | (-3703 | -2562 | (-9576 |
|                                                                                                                |         |                 |      |        |        |        |       |        |       |        |
|                                                                                                                |         |                 |      |        |        |        |       |        |       |        |
|                                                                                                                |         |                 |      |        |        |        |       |        |       |        |
|                                                                                                                |         |                 |      |        |        |        |       |        |       |        |
|                                                                                                                |         |                 |      |        |        |        |       |        |       |        |
|                                                                                                                |         |                 |      |        |        |        |       |        |       |        |
|                                                                                                                |         |                 |      |        |        |        |       |        |       |        |
|                                                                                                                |         |                 |      |        |        |        |       |        |       |        |
|                                                                                                                |         |                 |      |        |        |        |       |        |       |        |
|                                                                                                                |         |                 |      |        |        |        |       |        |       |        |

Figure 6: A behavioral simulation by Modelsim

In "synopsys/sim" directory, following the commands as follows.

1) analyze the verilog file and testbench

> vlogan .../verilog/ARITH\_module.v

>vlogan +v2k ../verilog/Tb\_multiplier.v

(note: our test bench is written in verilog IEEE2000 syntax, without "+v2k" , vlogan command may fail due to compatible issue)

2) compile/simulate the design

- vcs +v2k .../verilog/Tb\_multiplier.v .../verilog/ARITH\_module.v (this compiles a simv file)
- vcs +v2k -RI ../verilog/Tb\_multiplier.v ../verilog/ARITH\_module.v (this opens a GUI interface)
- In VirSim-Interactive window ; choose Window -> Hierarchy to get a hierarchy view of our design. Choose Window -> Waveform to generate the waveform window.

|                                                                                                                                                                                                                                                                                                                                                                                                                       | Signals in testbench                       |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                       | testbenon                                  |
| 🛱 VirSim - Interactive - SIM - 11 - VCS                                                                                                                                                                                                                                                                                                                                                                               | 🗱 VirSim - Hierarchy - 11 - vcdplus.vpd    |
| File Edit Sim View Window Help                                                                                                                                                                                                                                                                                                                                                                                        | <u>File Edit Display View Window H</u> elp |
| → → ↑ → 🖬 🖪 🖪 🐷 🛛 🤻 EGroup0 🔖 SIM                                                                                                                                                                                                                                                                                                                                                                                     |                                            |
| History                                                                                                                                                                                                                                                                                                                                                                                                               | Hierarchy Signals Search                   |
| Chronologic VCS simulator copyright 1991-2005         Contains Synopsys proprietary information.         Compiler version Y-2006.06-SP1; Runtime version Y-2006.06-S         \$stop at time 0         cli_OVCD+ Writer Y-2006.06-SP1 Copyright 2005 Synopsys Inc.         Command         cli_1 >         User Defined Buttons         Control       Show         Scope       Breakpoints         Continue       Show | 10                                         |
| Next         Loads         Upscope         Break Change                                                                                                                                                                                                                                                                                                                                                               | Filter F AutoGroup0 Adit                   |
| Step 0 Ports Scopes Local Break Opposedge                                                                                                                                                                                                                                                                                                                                                                             |                                            |
|                                                                                                                                                                                                                                                                                                                                                                                                                       |                                            |
| Simulator Control                                                                                                                                                                                                                                                                                                                                                                                                     |                                            |
| Step Time 20 OK Cancel                                                                                                                                                                                                                                                                                                                                                                                                |                                            |
| Scope Tb_Multiplier_15_0 OK Cancel                                                                                                                                                                                                                                                                                                                                                                                    |                                            |
| Time 0 (1 ps)                                                                                                                                                                                                                                                                                                                                                                                                         |                                            |
| Stopped                                                                                                                                                                                                                                                                                                                                                                                                               |                                            |

Figure 7: VirSim hierarchy window

- Choose the signals we want to observe in the Hierarchy window ( pt[31:0], xt[15:0], yt[15:0] etc), hold the middle button of the mouse, drag them into the waveform window
- In "VirSim- Interactive window", in "Simulation Control" area, type in your desired step time, and press OK. Then, you can observe the output waveforms

| Signals i<br>testbenc                                                      | h .                   |
|----------------------------------------------------------------------------|-----------------------|
| VirSim - Waveform - A - AutoGroupO 📰 💽 🖬 VirSim - Hierarchy - 11 - vcdplus | s.vpd · 📃 🗖 🔀         |
| File Edit Zoom Display View Window Help File Edit Display View Window      | ow <u>H</u> elp       |
|                                                                            | 1                     |
| CI 0 (1 ps)<br>C2 NA                                                       | Signals Search        |
| Detta NA 0 2 4 6 8 10                                                      |                       |
| 11 pt[31:0] 32'hxxxxxxxx 3 1 [] testbench                                  | line_num[31:0]        |
| 11 xt[15:0] 16'hxxxx                                                       | MESS1_STR[304:0]      |
| 11 yt[15:0] 16'hxxxx                                                       | MESS2_STR[144:0]      |
|                                                                            | MESS3_STR[144:0]      |
|                                                                            | MESS4_STR[24:0]       |
|                                                                            | MESS5_STR[16:0]       |
|                                                                            | MESS6_STR[64:0]       |
|                                                                            | p_expected[31:0]      |
|                                                                            | 🖬 pt[31:0]            |
|                                                                            | 🖬 q[31:0]             |
|                                                                            | r[31:0]               |
|                                                                            | tmp_in[31:0]          |
|                                                                            | xt[15:0]              |
|                                                                            | 🖬 yt[15:0]            |
|                                                                            | Ľ                     |
|                                                                            | Filter AutoGroup0 Adu |
|                                                                            |                       |

Figure 8: Waveform window to be observed

|                       |                                 |           | I       | Check this :<br>Multiplier: 812<br>Multiplicand : -80<br>Product : -6504 | 01;     |         |           |              |
|-----------------------|---------------------------------|-----------|---------|--------------------------------------------------------------------------|---------|---------|-----------|--------------|
| VirSim - Waveform     | n - A - AutoGroup0              |           |         |                                                                          |         |         |           |              |
| <u>File Edit Zoom</u> | <u>D</u> isplay ⊻iew <u>₩</u> i | ndow      |         |                                                                          |         |         |           | <u>H</u> elp |
| 🗮 🍠 🍇 🕆 🛛 🗷           | 2 [2] 22 🔹 🕨                    |           |         |                                                                          |         |         | €         | None 🍇 A     |
|                       | 0 (1 ps)                        |           |         |                                                                          |         |         |           |              |
| C2                    | NA                              |           |         |                                                                          |         |         |           |              |
| Delta                 | NA                              | 1,570,000 |         | 1,580,000                                                                | 1,590,0 | 000     | 1,600,000 |              |
| 11 pt[31:0]           | x                               | 51292     | -299460 | -650412                                                                  | -612612 | -194936 | -714714   | -39480 🛆     |
| I1 xt[15:0]           | x                               | 798       | 805     | 812                                                                      | 819     | 826     | 833       | 840          |
| I1 yt[15:0]           | ×                               | 954       | -372    | -801                                                                     | -748    | -236    | -858      | -47          |
|                       |                                 |           |         |                                                                          |         |         |           |              |
|                       |                                 |           |         |                                                                          |         |         |           |              |
|                       |                                 |           |         | •                                                                        |         |         |           |              |
|                       |                                 |           |         | L                                                                        |         |         |           |              |
|                       |                                 |           |         |                                                                          |         |         |           |              |
|                       |                                 |           |         |                                                                          |         |         |           |              |
|                       | <hr/>                           | 4         |         |                                                                          |         |         |           |              |
|                       |                                 |           |         |                                                                          |         |         |           |              |

Figure 9: Out put Waveforms

# Synthesis with Synopsys Design Vision

## Input Your Design

This section would guide you step by step to synthesize a 16-bit multiplier example. We would use Synopsys Design Vision for this purpose.

- go to the syn library: cd  $\sim$ /elec516-lab/synopsys/syn
- check out the there is a setup file ".synopsys\_dc\_setup" : ls -a

- In terminal : source ../../.cshrc user (source the design vision)
- start design vision: design\_vision &

For Linux workstations, the design\_vision can be loaded correctly without any error or warning as figure below:



Figure 10: Design Vision Main Window

For UNIX SUN workstations, there may display some error messages of X-display as figures below, normally, it won't affect our synthesis process, we can ignore this compatible issue.

We may look at the main window of Design Vision to see a few of the program's features. In the top panel, there are two panes. The left pane is a full Hierarchy pane; it will show the entire hierarchy of the current design (as selected from the drop-down box in the upper control panel). The right panel is a context based panel which will display contents based upon the selection in the drop down box at the top of the panel.

The bottom panel has three different tabs: log, history and errors/warnings. The important thing to note about this panel is that every command you perform will appear in this panel, allowing you to learn the commands and create scripts of commands for future use. It is also the panel that you must monitor to determine the source of errors and warnings, allowing you to fix the code or correctly determine if a warning is expected.

• analyze the file. Select File->Analyze and add the file you want to analyze, in our design , choose "elec516-lab/synopsys/vhdl/ARITH module.vhd".

After analyzing the file, please check whether the compilation is sucessful.

|          | <mark>sion - TopLevel.1</mark><br><u>/</u> iew <u>S</u> elect <u>H</u> igh | light List Ligear                 | thu Dasian | Attributes | C sharpatis | Tirain a Tast | Dowar Mind                        | our Hala |          |
|----------|----------------------------------------------------------------------------|-----------------------------------|------------|------------|-------------|---------------|-----------------------------------|----------|----------|
|          | 12   0 0 0 4                                                               | ngnic u <u>s</u> c <u>n</u> ieran |            |            |             | Linning Tesi  | • <u>-</u> 000001 <u>000</u> 1110 |          |          |
| D High   |                                                                            | - a m li                          |            |            |             |               |                                   |          | _        |
|          | al Hie Cells (Hierar                                                       | chical)                           |            | •          |             |               |                                   |          |          |
|          | Cell Name                                                                  | Ref Name                          | Cell Path  | D          |             |               |                                   |          |          |
| 2        |                                                                            |                                   |            | -          |             |               |                                   |          |          |
| 2        |                                                                            |                                   |            |            |             |               |                                   |          |          |
| 2        |                                                                            |                                   |            |            |             |               |                                   |          |          |
|          |                                                                            |                                   |            |            |             |               |                                   |          |          |
|          |                                                                            |                                   |            |            |             |               |                                   |          |          |
|          |                                                                            |                                   |            |            |             |               |                                   |          |          |
|          |                                                                            |                                   |            |            |             |               |                                   |          |          |
|          |                                                                            |                                   |            |            |             |               |                                   |          |          |
|          |                                                                            |                                   |            |            |             |               |                                   |          |          |
|          |                                                                            |                                   |            |            |             |               |                                   |          |          |
|          |                                                                            |                                   |            |            |             |               |                                   |          |          |
| <u> </u> |                                                                            |                                   |            | _          |             |               |                                   |          |          |
|          | ror: unknown con                                                           |                                   |            |            |             |               |                                   |          |          |
|          | ror: unknown com<br>ror: unknown com                                       |                                   |            |            | Ignore      | these errors  | ,                                 |          |          |
|          | ror: unknown con                                                           |                                   |            | L -        |             |               |                                   |          |          |
|          | _shell> gui_stan<br>sign_vision>                                           | it.                               |            | •          |             |               |                                   |          |          |
|          |                                                                            |                                   |            |            |             |               |                                   |          | 0        |
| Log      |                                                                            |                                   |            |            |             |               |                                   |          | Options: |
| desi     | gn_vision>                                                                 |                                   |            |            |             |               |                                   |          |          |
| eady     |                                                                            |                                   |            |            |             |               |                                   |          |          |

Figure 11: Errors due to compatible issue in Sun(eesu) workstation

| 2                |                 |                               |                                   | n Vision - To       |            |                    |             |        |          |        | (     | _ 🗆 🗙 Ì |
|------------------|-----------------|-------------------------------|-----------------------------------|---------------------|------------|--------------------|-------------|--------|----------|--------|-------|---------|
| °a, <u>F</u> ile | Edit View       | / <u>S</u> elect <u>H</u> igh | light L <u>i</u> st <u>H</u> iera | rchy <u>D</u> esign | Attributes | S <u>c</u> hematic | Timing      | Test   | Power    | Window | Help  | _8×     |
| ] 🗳 🖫            | 1 <b>8</b>   12 | 0 2 8 4                       | 0. 🖸 🛛 🛎 🛔                        |                     | 3 HE 🛛     |                    |             |        |          | •      | ۱ 🕘 🖲 | 2       |
| Lo               | gical Hier      | Cells (Hierarch               | nical)                            |                     |            |                    |             |        |          |        |       | -       |
| 1                |                 | Cell Name                     | Ref Name                          | Cell Path           | Dont Tou   | ich                |             |        |          |        |       |         |
| 1                |                 |                               | 1                                 |                     |            |                    |             |        |          |        |       |         |
| ⊛                |                 |                               |                                   |                     |            |                    |             |        |          |        |       |         |
| 0                |                 |                               |                                   |                     |            |                    |             |        |          |        |       |         |
|                  |                 |                               |                                   |                     |            |                    |             |        |          |        |       |         |
|                  |                 |                               |                                   |                     |            |                    |             |        |          |        |       |         |
|                  |                 |                               |                                   |                     |            |                    |             |        |          |        |       |         |
|                  |                 |                               |                                   |                     |            |                    |             |        |          |        |       |         |
|                  |                 |                               |                                   |                     |            |                    |             |        |          |        |       |         |
| - 1              | Compili         | ng Entity D                   | eclaration UB                     | DIDERY 20 1         |            |                    |             |        |          |        |       |         |
|                  |                 |                               | ture UBPUREBK                     |                     |            | 30_15              |             |        |          |        |       | ᅴ       |
|                  |                 |                               | eclaration UB                     |                     |            | A                  | After Anal  | vze, m | ake sure | e the  |       |         |
|                  |                 |                               | completed su                      |                     | STCCONV3   | 1 0                | ompilation  |        | leted    |        |       |         |
|                  |                 | vision>                       | compreted su                      | ccessidily.         |            | s                  | uccessfully | у      |          |        |       | - I     |
|                  | •               |                               |                                   |                     |            |                    |             |        |          |        |       |         |
|                  | Log His         | story                         |                                   |                     |            |                    |             |        |          |        | Opti  | ons: 💌  |
|                  | design vis      | ion>                          |                                   |                     |            |                    |             |        |          |        |       |         |
|                  | uesign_vis      |                               |                                   |                     |            |                    |             |        |          |        |       |         |
| Ready            |                 |                               |                                   |                     |            |                    |             |        |          |        |       |         |

Figure 13: After Analyze

Analyze is similar to compilation. It will check the syntax of each of the files to verify correct use of the language and that all code used is synthesizable.Note that for VHDL code, you must analyze in a specific order because of some of the ordering requirements of VHDL. No particular order will be required when using Verilog code with Design Vision. I recommend for the first time analyze your code, analyze one by one to see the messages, after that, you can add it together<sup>1</sup>.

<sup>&</sup>lt;sup>1</sup>Be careful not to include the testbench file , this is not part of the design and can not be synthesized

|                        | Analyze Designs               | ×                |
|------------------------|-------------------------------|------------------|
| Fi <u>l</u> e names in | analysis order:               |                  |
| /local/staff/ee        | e/qianzl/elec516-lab/synopsys | /vh A <u>d</u> d |
|                        |                               | Delete           |
|                        |                               |                  |
| •                      |                               | <u> </u>         |
| <u>F</u> ormat:        | VHDL (vhdl)                   | •                |
| <u>W</u> ork library:  | WORK                          | •                |
|                        | Create new library if it doe  | s not exist      |
|                        | ОК                            | Cancel           |

Figure 12: Analyze VHDL Code

|                     | Elab               | orate Designs 🔹 🕨            | ]  |
|---------------------|--------------------|------------------------------|----|
| <u>L</u> ibrary:    | WORK               | •                            | ]  |
| <u>D</u> esign:     | MULTIPLIER_15      | 0_1000(MULTIPLIER_15_0_1000) | ]  |
| <u>P</u> arameters: | Name               | Value                        | ]  |
|                     |                    |                              |    |
|                     | e out-of-date libr |                              |    |
|                     |                    | OK Cancel                    | // |

Figure 14: Elaborate Design

- elaborate the analyzed code:
  - File-> Elaborate;
  - Change Library to "Work"; This is where you defined to store your intermediate results;
  - Change Design to "Multiplier\_15\_0\_1000". This is your top module;
  - Click "OK";

The elaboration step may take several minutes. This step is similar to loading the design in Modelsim. The design is checked to make sure that the code is synthesizable, the subdesigns connect correctly and that there are no major errors in the implied circuit. (At the end of this step you may need to fix your code to remove them by checking the output message: THIS IS A MUST). Alternatively, you can use File-> Read to perform the function of analyze and elaborate.

|                                                |                                                                               |                                                            | opLevel.1 (M                               |                   |              |       |          |         |    |        |                  |
|------------------------------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------|--------------------------------------------|-------------------|--------------|-------|----------|---------|----|--------|------------------|
|                                                |                                                                               | nlight L <u>i</u> st <u>H</u> iera                         |                                            |                   |              |       |          |         |    |        |                  |
|                                                | 1                                                                             | ) Q 🖸 🛛 🕹 🕯                                                | 2 🖸 🖿                                      | 🐻 👪 🗍 🖀           | i 📰 📰 🖾      | Mult  | iplier_1 | L5_0_10 | 00 | • ] @. | ۵.               |
| Logical Hier                                   | Cells (Hierarch                                                               | hical)                                                     |                                            |                   |              |       |          |         |    |        |                  |
| , = D==                                        | Cell Name                                                                     | Ref Name                                                   | Cell Path                                  | Dont Tou          | ich          |       |          |         |    |        |                  |
|                                                | :D-∪0                                                                         | MultTC_STD                                                 | . U0                                       | undefined         | d            |       |          |         |    |        |                  |
| 2                                              |                                                                               |                                                            |                                            |                   |              |       |          |         |    |        |                  |
|                                                |                                                                               |                                                            |                                            |                   |              |       |          |         |    |        |                  |
| 9                                              |                                                                               |                                                            |                                            |                   |              |       |          |         |    |        |                  |
|                                                |                                                                               |                                                            |                                            |                   |              |       |          |         |    |        |                  |
|                                                |                                                                               |                                                            |                                            |                   |              |       |          |         |    |        |                  |
|                                                |                                                                               |                                                            |                                            |                   |              |       |          |         |    |        |                  |
|                                                |                                                                               |                                                            |                                            |                   |              |       |          |         |    |        |                  |
|                                                |                                                                               |                                                            |                                            |                   |              |       |          |         |    |        |                  |
|                                                |                                                                               | an ang an a catalog an ang ang ang ang ang ang ang ang ang |                                            |                   |              |       |          |         |    |        |                  |
| - Inform                                       | tion. Build                                                                   | ling the desig                                             | m 'GPGenerat                               | or! (HDI          | 193)         |       |          |         |    |        |                  |
|                                                |                                                                               | ling the desig                                             |                                            | cor'. <u>(HDI</u> | <u> 193)</u> | Check | t wheth  | her the |    |        |                  |
| Presto                                         | compilation                                                                   |                                                            | ccessfully.                                |                   |              | elabo | ration   | her the | ed |        |                  |
| Presto<br>Inform<br>Presto                     | compilation<br>ation: Build<br>compilation                                    | completed su                                               | nccessfully.<br>n 'CarryOpen               |                   |              |       | ration   |         | ed |        |                  |
| Presto<br>Inform<br>Presto<br>design           | compilation<br>ation: Build<br>compilation<br>_vision>                        | completed su<br>ling the desig<br>completed su             | ccessfully.<br>m 'CarryOpen<br>ccessfully. |                   |              | elabo | ration   |         | ed |        |                  |
| Presto<br>Inform<br>Presto<br>design           | compilation<br>ation: Build<br>compilation<br>_vision>                        | completed su<br>ling the desig                             | ccessfully.<br>m 'CarryOpen<br>ccessfully. |                   |              | elabo | ration   |         | ed |        |                  |
| Presto<br>Inform<br>Presto<br>Curren           | compilation<br>ation: Build<br>compilation<br>_vision><br>t design is         | completed su<br>ling the desig<br>completed su             | ccessfully.<br>m 'CarryOpen<br>ccessfully. |                   |              | elabo | ration   |         | ed |        | •                |
| Presto<br>Inform<br>Presto<br>Lesign<br>Curren | compilation<br>ation: Build<br>compilation<br>_vision>                        | completed su<br>ling the desig<br>completed su             | ccessfully.<br>m 'CarryOpen<br>ccessfully. |                   |              | elabo | ration   |         | ed | Option | ▶<br>15: <u></u> |
| Presto<br>Inform<br>Presto<br>Lesign<br>Curren | compilation<br>ation: Build<br>compilation<br>vision><br>t design is<br>story | completed su<br>ling the desig<br>completed su             | ccessfully.<br>m 'CarryOpen<br>ccessfully. |                   |              | elabo | ration   |         | ed | Optior | )<br>15: [       |
| Presto<br>Inform<br>Presto<br>Lesign<br>Curren | compilation<br>ation: Build<br>compilation<br>vision><br>t design is<br>story | completed su<br>ling the desig<br>completed su             | ccessfully.<br>m 'CarryOpen<br>ccessfully. |                   |              | elabo | ration   |         | ed | Optior | 15:              |

Figure 15: Message After Elaboration

Now that we have elaborated the design, we see some basic structure of the design in the main window of Design Vision. See Figure 15. The left pane of the main window shows the full hierarchy of the design starting from the design that is specified as the top-level (from the drop-down box in the top tool panel). In the right pane we can select what we see to help perform later tasks. By right clicking on a module, we may also choose to see a schematic view from the right click menu. The schematic view may be useful, but requires a good understanding of synthesis, as the module names may seem cryptic at first.

#### Design Check & Set Constraints

After you input all the design files, it is sometimes necessary for you to link the design (In File->Link Design). For sometime tools might no be able to correctly establish the interconnection between your different modules. When you finish all these, you check your design for possible errors (Design->Check Design). Example check results have warnings due to output connected to input ports directly (We can ignore this kind of warnings since we dedicately connect them in our design).

- Select Multiplier\_15\_0\_1000 as your current design (this is the top design module) in the module selection in the selection box right upper corner;
- Select Design->Check Design, and set the choice as shown in Figure 16;
- Check out the output messages;

You should perform frequency design check after each major operations which would affect the design logic.

Now you are going to set your design constraints to guide the mapping process. Common constraints are: clock periods, timing/area/power constraints, input delay, output delay, false path, wire load, operating conditions, fanout, etc.. (It's highly depends on the specification of the design system)

| Check Design X                                                                |
|-------------------------------------------------------------------------------|
| Check for                                                                     |
| Current design: Multiplier_15_0_1000                                          |
| Check options                                                                 |
| Warning messages                                                              |
| C Suppress C Display a summary C Display in detail                            |
| Hierarchy                                                                     |
| C Only current level of hierarchy C Current level and all sub-designs         |
| <b>Check for correct back annotation D</b> Do <u>n</u> ot check design itself |
| OK Cancel Apply                                                               |

Figure 16: Check Design Box

#### Set Clock

Specify clock tells design vision the clock rate at which the design should be able to operate. This goal will tell design vision to make sure to organize the modules such that calculations can all be performed within the clock period. Various techniques such as logic duplication are used to achieve the goals. It is important to set realistic goals for the clock rate so that design vision does not perform too much logic duplication to attempt to reach the goal.

- Set Clock: If you have the clock pin in your design, then select this pin in port view, since in our multiplier design, we don't have any clock pins, we need't select any pin ;
- Select Attributes->Specify Clock (see. Figure. 17);
- We create a clock name : vclk which means this is a virtual clock; Period is 0.5 here; feel free to try out different values to see how fast the system can run;

|                          | Specify Clo | ock 🛛                     |
|--------------------------|-------------|---------------------------|
| <u>C</u> lock name: vcl  | k           |                           |
| Port name:               |             |                           |
| ☐ <u>R</u> emove clock   |             |                           |
| Clock creation –         |             |                           |
| Perio <u>d</u> : 0.5     |             | I                         |
| Edge                     | Value       | Add <u>e</u> dge pair     |
| Rising                   | 0.25        | Remove edge pair          |
| Falling                  | 0.5         | Kem <u>o</u> ve edge pair |
|                          |             | Invert <u>w</u> ave form  |
|                          |             |                           |
| 0.00                     | 0.25        | 0.5                       |
| 🔽 Don't <u>t</u> ouch ne | twork       | Fix <u>h</u> old          |
|                          | ОК          | Cancel <u>A</u> pply      |

Figure 17: Specify Clock

You will know if you have correctly selected Clk based upon if Clk shows up in the grayed out Port name box. If that box is empty, be sure to close this dialog and make sure Clk is selected before opening this dialog. Since a clock is a signal we don't want to optimize (prevents errors of the synthesizer disconnecting the signal), we want to set the clock as a "don't touch" network. Select Don't touch network before clicking OK.

#### Set Input/Output Delay

Input delay tells design vision that a signal will always arrive at a certain time relative to the clock (after the rising edge of the clock). When specifying delay, the delay should always be specified relative to a clock so that design vision may calculate delays correctly.

- Change the drop down box to Pins/Ports.
- Select->Ports/Pins->Input Ports to select all input pins
- Attributes->Operating Environment->Input Delay (If you did not select any signals, either the Input Delay option in the menu would be grayed out, or there would be no entries in the Name field).
- Select vclk in the Relative to clock dropdown Specify 0.1 as the Minimum and Maximum delay This means that input signals should be modeled so that they arrive 0.1nS after the edge of clk. Click OK
- Do the same for the output delay (This specifies how long a signal takes to reach the chips output after leaving your modules output after the clock edge.)

| Input Delay                                                                |
|----------------------------------------------------------------------------|
| Name: <pre><multiple selected=""></multiple></pre> Relative to clock: vclk |
| © Rising edge C Falling edge                                               |
| ✓ Same rise and fall                                                       |
| Max rise: 0.1 Max fall: 0.1                                                |
| Min ris <u>e</u> : 0.1 Min fall: 0.1                                       |
|                                                                            |
| OK Cancel <u>A</u> pply                                                    |

Figure 18: Set Input Delay

#### Wire Load

We must specify a wire load model so that design vision can estimate the delay that wires in the design have. Each model is based upon a different amount of resistance and capacitance for a certain amount of wire. Design vision will use that amount to estimate how much delay is added to the circuit based on the length of the wires and distance between the wires.

- Attributes->Operating Environment->Wire Load;
- Select-> 5K\_hvratio\_1\_1;

|                  | Wire Load                               | × |
|------------------|-----------------------------------------|---|
| Current design:  | Multiplier_15_0_1000                    |   |
| Wire load model: | 5K_hvratio_1_1 ( NangateOpenCellLibrary | ) |
| 5K_hvratio_1_1   | ( NangateOpenCellLibrary )              | - |
| 5K_hvratio_1_2   | ( NangateOpenCellLibrary )              |   |
| 5K_hvratio_1_4   | ( NangateOpenCellLibrary )              |   |
| 3K_hvratio_1_1   | ( NangateOpenCellLibrary )              |   |
| 3K_hvratio_1_2   | ( NangateOpenCellLibrary )              | - |
|                  | OK Cancel <u>A</u> ppl                  | у |

Figure 19: Wire Load

#### **Design Constraints**

This level of constraints allows us to set overall objectives of the design for design vision to attempt to reach. We can set maximum values for area, power, fanout, and transition. Normally for this course we will only set values for area and fanout, allowing power and transition to vary as design vision likes. This will speed our synthesis time and will allow us to concentrate on the operation of the circuit rather than worrying about power and other effects that require attention after full correctness is guaranteed.

In "Attributes > Optimization Constraints > Design constraints" we can set the optimization goal

| Design Constraints                   |
|--------------------------------------|
| Current design: Multiplier_15_0_1000 |
| Optimization constraints             |
| Constraint value: Unit:              |
| Max ar <u>e</u> a : 2900             |
| Max dynamic power:                   |
| Max <u>l</u> eakage power:           |
| Max t <u>o</u> tal power:            |
| Design rules                         |
| Max <u>f</u> anout: 8                |
| Max <u>t</u> ransition:              |
| OK Cancel <u>A</u> pply              |

Figure 20: Design Constraints

| Co                                   | mpile 🗙                                      |
|--------------------------------------|----------------------------------------------|
| Mapping options                      | Compile options                              |
| ☑ <u>M</u> ap design                 | <u>T</u> op level <u>Incremental mapping</u> |
| F Exact map                          | 「 Ungroup 「 Allo <u>w</u> boundary conditic  |
| Map effort: medium                   | 「 <u>S</u> can 「Auto <u>u</u> ngroup         |
| Ar <u>e</u> a effort: medium         | Carea                                        |
| Design rule options                  |                                              |
| • Fix design rules and optimize mapp | bing                                         |
| C Optimize mapping only              |                                              |
| C Fix design rules only              |                                              |
| C Fix hold time only                 |                                              |
|                                      | OK Cancel <u>A</u> pply                      |

Figure 21: Compile Design

#### Start Compile

Now we've setup all the constraints. We will start to compile the design (logic simplification and technology mapping) and hope that Design Vision would get a satisfactory design for all our constraints.

- Design->Compile Design
- Uncheck the exact map option (this would leads no logic optimization). See Figure. 21

After finish, check out the output message. There're each optimization step output to tell you the current trade-offs between area and timings. Check if the design is satisfactory. Perform check design if necessary.

| 8      | 🖀 🛛 🕲 🌀        | 1 2 0 0   | 🖾 📋 🏝 🌨    | ۰ 🗈        | - 📷 🔠 📋  | 🔛 🔜 🔛 🔜 📗 Multiplier_15_0 | _1000 🗾 💽 | ۹ 🕑 🕘 |
|--------|----------------|-----------|------------|------------|----------|---------------------------|-----------|-------|
| Logica | Hierarchy      |           | Cells (Hie | rarchical) |          |                           |           |       |
| å-⊅=   | => Multiplier_ | 15_0_1000 | Cell Nam   | e Ref      | Name     | Cell Path Dont Touch      |           |       |
| ÷-1    | 000            |           | D U0       | Mult       | TC_STD   | U0 undefined              |           |       |
|        |                |           |            |            |          |                           |           |       |
|        | TIME           | AREA      | SLACK      | SLACK      | RULE COS | T KNDPOINT                | COST      |       |
|        |                |           |            |            |          |                           |           |       |
|        | 0:00:15        | 3492.3    | 1.96       | 42.2       | 256.     | 0 Optimization Tradeoff   | 0.00      |       |
|        | 0:00:16        | 2785.9    | 2.16       | 46.4       | 256.     | o during compilation      | 0.00      |       |
|        | 0:00:16        | 2789.7    | 2.10       | 45.2       | 256.     | 0                         | 0.00      |       |
|        | 0:00:16        | 2788.5    | 2.09       | 44.9       | 256.     | 0                         | 0.00      |       |
|        | 0.00.16        | 2790.0    | 2.07       | 11.0       | 256.     | 0                         | 0.00      |       |
|        | 0:00:16        | 2792.3    | 2.09       | 44.9       | 256.     | 0                         | 0.00      |       |
|        | 0:00:16        | 2794.3    | 2.09       | 44.9       | 256.     | 0                         | 0.00      |       |
|        | 0:00:17        | 2797.7    | 2.08       | 44.7       | 256.     | 0                         | 0.00      |       |
|        | 0:00:17        | 2796.6    | 2.08       | 44.8       | 256.     | 0                         | 0.00      |       |
|        | 0:00:17        | 2796.6    | 2.08       | 44.8       | 256.     | 0                         | 0.00      |       |
|        | 0:00:17        | 2796.6    | 2.08       | 44.8       | 256.     | 0                         | 0.00      |       |
|        | 0:00:17        | 2796.6    | 2.08       | 44.8       | 256.     | 0                         | 0.00      |       |
|        | 0:00:17        | 2796.6    | 2.08       | 44.8       | 256.     | 0                         | 0.00      |       |
|        | 0:00:17        | 2796.6    | 2.08       | 44.8       | 256.     | 0                         | 0.00      |       |
|        | 0:00:17        | 2796.6    | 2.08       | 44.8       | 256.     | 0                         | 0.00      |       |
| 4      |                |           |            |            |          |                           |           |       |

Figure 22: After compilation of the design

Then, you can save the mapped design. All the designs would be saved in ddc format. Later you can read in the design where you left off. Here, i want emphasis two things you need to save for use in back-end design.

• A verilog netlist for place & route and pre-layout simulation: In the hierarchical window, select the top module, and then File->Save as, choose verilog format, name it as syn netlist.v



Figure 23: pre-layout simulation results

• A constraint file for the constraints you set for synthesis. it would be used for back-end too. we name it syn\_netlist.sdc .

#### **Report File**

There're various report method you can use to check your design. The most important one is timing report (like "Design > Report Design").

## **Pre-Layout Simulation**

Till now, you are required to perform Pre-Layout simulation to verify your function. The file you needed is syn\_netlist.v and a library verilog file called typical.v under "syn\_sim" folder.

Using the similar method introduced in the "behavioral simulation for verilog" to do the pre-layout simulation

> cd elec516-lab/synopsys/syn sim (where library file typical.v and syn netlist.v locates in)

>cp ../verilog/Tb\_multiplier.v . (copy testbench to syn\_sim folder)

>source /usr/eelocal/synopsys/vcs\_mx-vy2006.06-sp1/.cshrc

- >vlogan syn\_netlist.v
- >vlogan +v2k Tb\_multiplier.v

>vcs -RI Tb\_multiplier.v +v2k syn\_netlist.v -v typical.v

Then, we enter into the GUI of the simulator. For how to choose signals for observation and the explanations of the interface, you may refer to previous " behavioral simulation for verilog " section.

## Place & Route with Cadence Encounter

## setup and start encounter

copy your generated netlist file and constraint file into encounter for back end use:

- cp syn\_netlist.v ../../encounter
- source ../.cshrc\_user
- check there're library files under the "encounter" folder: ".lib" and ".lef" respectively
- start encounter: encounter (Make sure DO NOT type "& " after encounter )

| - |                          | Design Import                      | • [ |
|---|--------------------------|------------------------------------|-----|
| ſ | Basic Advanced           |                                    |     |
|   |                          |                                    |     |
|   | Verilog Netlist:         |                                    |     |
|   | Files:                   | ./synopsys/syn/syn_netlist.v       |     |
|   | To                       | p Cell: 🔶 Auto Assign 💠 By User:   |     |
|   | - Timing Libraries:      |                                    |     |
|   | Max Timing Libraries:    |                                    |     |
|   | Min Timing Libraries:    |                                    |     |
|   | Common Timing Libraries: | typical.lib                        |     |
|   | LEF Files:               | ananlih laf                        |     |
|   |                          |                                    |     |
|   | Timing Constraint File:  |                                    | 2   |
|   | IO Assignment File:      |                                    | 2   |
|   |                          |                                    |     |
|   |                          |                                    |     |
|   |                          |                                    |     |
| Ŀ |                          |                                    |     |
|   | <u>O</u> K <u>S</u> ave  | . Load <u>C</u> ancel <u>H</u> elp |     |

(a) Basic Setting

| - Design Import                                                                                                                                                                                                                                                                  | 🗌 🦳 Design Import 👘 🗌                                                                                                                                                                                                                                                                   |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Basic     Advanced       Delay Calculation<br>GDS     Power Nets:     VDD       GDS     Ground Nets:     VSS       ILM     IPO/CTS     DenAccess       Power     RC     1.0       Power     RC     1.0       Power     RT     1.0       SI Analysis     Timing       Yield     J | Basic     Advanced       Delay Calculation     Buffer Name/Footprint: buf       DLW     Delay Name/Footprint: inv       OpenAccess     Power       POwer     RC Extraction       RT.     SI Analysis       Timing     Cell Footprint: Based on Functional Equivalence       QK     Save |

(b) Power Setting & IPO Setting

Figure 24: Design Import

#### Load Design

 $\bullet\,$  Design-> Design Import, set the Basic and Advanced Option as Figure. 24

• For future use, after you set up all the required field, you can save a config file and next time directly load it is ok

#### **Connect Global Nets**

- Click Floorplan->Connect Global Nets
- Following the setting listed in the table below and add the connects to the list
- Click Apply, and then Check. The Check command check for unconnected pins in your design. Verify and fix if any warnings or errors appear in the encounter console.

| Setting        | Setting1  | Setting2  | Setting3  | Setting4  |
|----------------|-----------|-----------|-----------|-----------|
| Connect Region | Pins: VDD | Tie High  | Pins: VSS | Tie Low   |
| Scope Region   | Apply All | Apply All | Apply All | Apply All |
| To Global Net  | VDD       | VDD       | VSS       | VSS       |



Table 1: Global Nets Connections

Figure 25: Connect Global Nets

#### Floorplan

- Floorplan-> Specify Floorplan. See Figure.26 for the setting;
- Figure 27 shows the result floorplan;

| —                                            | Specif        | y Floor   | plan        |                              | · [          |
|----------------------------------------------|---------------|-----------|-------------|------------------------------|--------------|
| C Design Dimensions -                        |               |           |             |                              |              |
| Specify Dimensions by                        | :             |           |             |                              |              |
| Size by:                                     |               |           |             |                              |              |
| 🔶 Core Size by: 🤇                            | Aspect Ra     | atio:     |             | Ratio (H/W):                 | 1            |
|                                              |               |           | 🔶 Co        | re Utilization               | 0.7          |
|                                              |               |           | ♦ Str       | I. Utilization:              | 0.699995     |
|                                              | > Width and   | Height:   |             |                              | 55.17        |
|                                              |               |           |             |                              | 54.6         |
| ♦ Die Size by: W                             | idth and Heig | ght       |             |                              | 55.17        |
|                                              |               |           |             |                              | 54.6         |
| Core Margins by:                             |               |           | ·           |                              |              |
|                                              |               |           |             | · · - 1                      |              |
| Core to                                      |               | 5.0       |             | Core to Top:                 | 5.0          |
| Core to<br>Die Size Calculatio               |               | 5.0       |             | re to Bottom:<br>ght 🔶 Min I | 510          |
| Floorplan Origin at                          |               |           |             | comer 🔶 Cer                  |              |
| ♦ Die/IO/Core Coordina                       |               |           |             | ····· • ···                  |              |
| Die LL:                                      | 0.0           | 0.0       | UR:         | 55.17                        | 54.6         |
| IO LL:                                       | 0.0           | 0.0       | UR:         | 55.17                        | 54.6         |
| Core LL:                                     | 0.0           | 0.0       | UR:         | 55.17                        | 54.6         |
|                                              |               |           |             |                              | unit: micron |
| - Standard Cell Rows -                       |               |           |             |                              |              |
| Double-back rows:                            |               | Bot       | tom ro      | w orient: 📋                  | _            |
| Row Spacing: 0.0                             | um F          | or Every  | 2 =         | Row                          |              |
| Site: NCSU_FreePDK_4                         | 15nm - F      | Row heigh | t: 1.4      |                              |              |
| Allow overlapping                            | same site r   | ows       | ,           |                              |              |
| - IO Specifications<br>Bottom IO Pad Orienta | tion: 🔲 RO    | -         |             |                              |              |
| <u>o</u> k                                   | Apply         | [         | <u>C</u> an | cel                          | Help         |

Figure 26: Floorplan Setting

| Encounter – /lo                               |     |                   |                |               |       |               |          |            |        |            | 15_0   |              |
|-----------------------------------------------|-----|-------------------|----------------|---------------|-------|---------------|----------|------------|--------|------------|--------|--------------|
| <u>D</u> esign <u>E</u> dit S <u>y</u> nthesi |     | <u>F</u> loorplan | Po <u>w</u> er | <u>P</u> lace | Clock | <u>R</u> oute | Timing   | <u>S</u> I | Verify | Tools      |        | <u>H</u> elp |
|                                               | 日の間 |                   | > 🔀 🛚          | 周日            |       | Ô             | 0        |            | Desi   | gn is:     | n Mem  | ory          |
| 🔨 👙 🕮 🖉 🧱                                     |     |                   | <b>■ </b>      | " 🛄           | Ծ∎    | 5             |          |            |        | All        | Colors |              |
|                                               |     |                   |                |               |       |               |          |            | Ē      |            |        | S            |
|                                               |     |                   |                |               |       |               |          |            | ĪN     | √lodule    |        |              |
|                                               |     |                   |                |               |       |               |          |            |        | Black Box  | 66     | Ηſ           |
|                                               |     |                   |                |               |       |               |          |            | F      | ence       |        | ΞL           |
|                                               |     |                   |                |               |       |               |          |            | 0      | Guide      |        |              |
|                                               |     |                   |                |               |       |               |          |            | 0      | Obstruct   |        |              |
|                                               |     |                   |                |               |       |               |          |            | F      | Region     |        |              |
| TU= 70.1%                                     |     |                   |                |               |       |               |          |            | 2      | Screen     |        |              |
|                                               |     |                   |                |               |       |               |          |            |        | nstance    |        |              |
|                                               |     |                   |                |               |       |               |          |            |        | Vet        |        |              |
|                                               |     |                   |                |               |       |               |          |            |        | SNet       |        |              |
|                                               |     |                   |                |               |       |               |          |            |        | P/G        |        |              |
| Uo                                            |     |                   |                |               |       |               |          |            |        | Pin        |        |              |
| C-O                                           |     |                   |                |               |       |               |          |            |        | Ruler      |        |              |
|                                               |     |                   |                |               |       |               |          |            |        | /Congest   |        |              |
|                                               |     |                   |                |               |       |               |          |            |        | HCongest   |        |              |
|                                               |     |                   |                |               |       |               |          |            |        | Fext       | 님님     |              |
|                                               |     |                   |                |               |       |               |          |            |        | Rel. FPlan |        | JY           |
|                                               |     |                   |                |               |       |               |          |            |        |            |        |              |
|                                               |     |                   |                |               | Q     | ( -           | -107.729 | , 122      | 2.911) | $\frown$   |        |              |

Figure 27: View After Floorplan

## Add Power Ring and Stripe

• Power->Power Planning->Add Rings (Figure. 28)

|              |                                    | Add Rir      | igs         |              |                |
|--------------|------------------------------------|--------------|-------------|--------------|----------------|
| Basic Adv    | anced   Via Ger                    | eration      |             |              |                |
|              |                                    |              |             |              |                |
|              | 001100                             |              |             | _            |                |
| Net(s): V    | SS VDD                             |              |             |              |                |
| Ring Type    |                                    |              |             |              |                |
|              | (s) contouring:<br>d core boundary |              | /O boundary |              |                |
|              | de selected obje                   |              | /O boundary |              |                |
| Block ring   |                                    | 263          |             |              |                |
| 🔶 Each I     |                                    |              |             |              |                |
| 🔷 Each i     |                                    |              |             |              |                |
| 🔷 💠 Selec    |                                    |              |             |              |                |
|              |                                    |              |             |              |                |
|              |                                    |              |             |              |                |
|              |                                    | dges         |             |              |                |
|              | ned coordinates                    |              |             |              | Mouse Click    |
| 🔶 Core ri    | ng 🔷 Ə Block                       |              |             |              |                |
| Ring Config  | juration                           |              |             |              |                |
|              | Top:                               | Bottom:      | Left:       | Right:       |                |
| Layer:       | metal1 H 💻                         | metal1 H 😐   | metal2 V 🗕  | metal2 V 💻   | 1              |
| Width:       | 0.8                                | 0.8          | 0.8         | 0.8          |                |
| Spacing:     | 0.8                                | 0.8          | 0.8         | 0.8          | <u>U</u> pdate |
| Offset: <    | Center in channe                   | el 🔶 Specify |             |              |                |
|              | 0.095                              | 0.095        | 0.095       | 0.095        |                |
| - Option Set |                                    |              |             |              |                |
|              |                                    |              |             | Update Basic | 1              |
| 💷 Use opti   | on set:                            |              | <b>₹</b>    | Update Basic |                |
|              |                                    |              |             |              |                |
|              |                                    |              |             |              |                |
|              |                                    |              |             |              |                |
| ок           | Variables                          | Apply        | Defaults    | Cancel       | <u>H</u> elp   |

Figure 28: Add Ring Config

• Power->Power Planning->Add Stripe (Figure. 29)

| Add Stripes                                                                       |
|-----------------------------------------------------------------------------------|
| Basic Advanced Via Generation                                                     |
| Basic Advanced Via Generation                                                     |
| Set Configuration                                                                 |
| Net(s): VSS VDD                                                                   |
| Layer: metal2 -                                                                   |
| Direction: 🔷 Vertical 🗇 Horizontal                                                |
| Width: 0.8                                                                        |
| Spacing: 0.5 Update                                                               |
| Set Pattern                                                                       |
| ♦ Set-to-set distance: 15                                                         |
| ♦ Number of sets: 1                                                               |
| ♦ Bumps ♦ Over ♦ Between                                                          |
| Over P/G pins Pin layer: Top pin layer → Max pin width: 0                         |
| ♦ Master name:                                                                    |
| Stripe Boundary                                                                   |
| ♦ Core ring                                                                       |
| ♦ Pad ring ♦ Inner ♦ Outer                                                        |
| Design boundary     Create pins     Each selected block/domain/fence              |
| ↓ Zuch solected more domain renee                                                 |
| ♦ Specify area                                                                    |
| First / Last Stripe                                                               |
| Start from: 🔶 left 🐟 right                                                        |
| Relative from core or selected area                                               |
| X from left: 12 X from right: 0                                                   |
|                                                                                   |
| Option Set                                                                        |
| Update Basic                                                                      |
|                                                                                   |
|                                                                                   |
| <u>QK</u> <u>Variables</u> <u>Apply</u> <u>Defaults</u> <u>Cancel</u> <u>Help</u> |

Figure 29: Add Stripe Config

After you add power ring and stripes, you can see now we have a primitive view in Figure.30.



Figure 30: View after add power ring and stripes

## **Special Routing**

- Route->Special Route; leave everything in default and ok
- $\bullet\,$  Special Route would help you do the VDD/VSS connection.

| Jesign | Edit | er – /loca<br>Synthesis | Partition | Doorplan | Power | Place          | glock | <u>B</u> oute | Timing | <u>S</u> I | Verify | Tools             | He           | elp |
|--------|------|-------------------------|-----------|----------|-------|----------------|-------|---------------|--------|------------|--------|-------------------|--------------|-----|
| DŒ     | Q    | 9.0.0                   | い間        | <u>a</u> |       | <del>4</del> 🛛 | 6     | 0 E           | כ      |            | Desi   | gn is:            | In Memory    |     |
| •      | 11 7 |                         | 7 🖬 🗅     | 33       |       | e" 🖬           | , ⇒   | 54            |        |            |        | All               | Colors       |     |
|        |      |                         |           |          |       |                |       |               |        |            | ŕ      |                   |              | -   |
|        |      |                         |           |          |       |                |       |               |        |            |        | Adule             |              | Ī   |
|        |      |                         |           |          |       |                |       |               |        |            | E      | Black Box         |              |     |
|        |      |                         |           |          |       |                |       |               |        |            |        | ence              |              |     |
|        |      |                         |           |          |       |                |       |               |        |            |        | Guide             |              |     |
|        |      |                         |           |          |       |                |       |               |        |            |        | Obstruct          |              |     |
|        | î    | U=70.1%                 |           |          |       |                |       |               |        |            |        | Region<br>Screen  | 222          |     |
|        |      |                         |           |          |       |                |       |               |        |            |        | nstance           | <b>1</b> 222 |     |
|        | - 1  |                         |           |          |       |                |       |               |        |            | r      | Vet               |              |     |
|        | - 1  |                         |           |          |       |                |       |               |        |            |        | SNet              |              |     |
|        | - 1  |                         |           |          |       |                |       |               |        |            |        | P/G               |              |     |
|        | - 1  |                         |           |          |       |                |       |               |        |            |        | Pin               |              |     |
|        |      |                         |           |          |       |                |       |               |        |            |        | Ruler<br>/Congest |              |     |
|        |      |                         |           |          |       |                |       |               |        |            |        | Congest           |              | ł   |
|        |      |                         |           |          |       |                |       |               |        |            |        | Fext              |              | ł   |
|        |      |                         |           |          |       |                |       |               |        |            |        | Rel. FPlan        | <b>1</b> 7   | k   |
|        |      |                         |           |          |       |                |       |               |        |            |        |                   | 2            |     |
|        |      |                         |           |          |       |                |       |               |        |            |        | $\times$          |              |     |
|        |      |                         |           |          |       |                | 9     | (             | 98.627 | 5          | 1.093) |                   |              |     |

Figure 31: View after Special Routing

#### Place the Standard Cell

This step is to place the cell in your design into the floorplan. The quality of placement would affect your timing a lot.

- Place->Standard Cell and Blocks
- Un-check the Reorder Scan Connection

| -          | Place                                                                           | · 🗆               |
|------------|---------------------------------------------------------------------------------|-------------------|
| Basic      | Advanced                                                                        |                   |
| -Mode      | -                                                                               | Prototyping       |
|            | ons<br>un Timing Driven Placement<br>eorder Scan Connection                     |                   |
| 🗖 Ind      | nization Options<br>clude Pre-Place Optimization<br>clude In-Place Optimization |                   |
| <u>0</u> K | <u>Apply D</u> efaults <u>C</u> a                                               | ncel <u>H</u> elp |

Figure 32: Placement Setting

After placement, switch your view into physical view. You can see how your cell is placed.

| ∑esign <u>E</u> dit | Synthesis    | Partition     | Boorplan    | Power       | Place    | glock                     | Route | Timing | SI Verit |                  | Help   |
|---------------------|--------------|---------------|-------------|-------------|----------|---------------------------|-------|--------|----------|------------------|--------|
| DDD                 | QQ&          |               |             |             | # 関      |                           | Ô     |        |          | esign is:        | Placed |
| 🔪 🚸 🔛 🤉             | { <b>\</b> ≓ | ⊒ 🎗 ⊐•        | 54          |             |          |                           |       |        | == 🕺 📰   | All              | Colors |
|                     |              |               |             |             |          |                           |       |        |          | ;                |        |
|                     |              |               |             |             |          |                           |       |        |          | Module           |        |
|                     |              |               |             |             |          |                           |       |        |          | Black Box        |        |
|                     |              |               |             | 1011111110  | 1920-020 |                           |       |        |          | Fence            |        |
|                     |              | ALC: UNK      |             |             |          |                           |       |        |          | Guide            | 566 B  |
|                     |              | distantin .   |             |             |          | 34 <b>1</b> 47            |       |        |          | Obstruct         |        |
|                     |              | CONTRACTOR OF |             |             |          |                           |       |        |          | Region           |        |
|                     |              |               | A N DO      |             |          |                           |       |        |          | Screen           |        |
|                     |              |               |             | All Control |          | 10 C                      |       |        |          | Instance         |        |
|                     |              | STREET, ST    | 11 I.I.     | 111111      | and a    | 6 <b>1</b> 6 6            |       |        |          | Net              |        |
|                     |              |               | 4.05.01     |             |          |                           |       |        |          | SNet             |        |
|                     |              |               |             |             |          |                           |       |        |          | P/G              |        |
|                     |              |               |             |             |          |                           | 8 i   |        |          | Pin              |        |
|                     |              | ****          | 10/10/00    | 1.14.81     | 1.1.10   | 11. <mark>1</mark> . 1. 1 |       |        |          | Ruler            |        |
|                     |              |               | and the set |             |          |                           |       |        |          | VCongest         |        |
|                     |              |               |             |             |          |                           | 2     |        |          | HCongest<br>Text |        |
|                     |              |               |             |             |          |                           |       |        |          | Rel. FPlan       |        |
|                     |              |               |             |             |          |                           |       |        |          | These PP Idi     |        |
|                     |              |               |             |             |          |                           |       |        |          |                  |        |

Figure 33: Physical View after placement

#### Route the connection

• Route-> Nano Route-> Route, leave everything is default

Here is what you get after routing:

| ലില   | Edit | Synthesis    | Partition     | Floorplan             | Po <u>w</u> er                           | Place       | Clock       | Route  | Timing | <u>S</u> I | Verify | Toots             | Routed | Help |
|-------|------|--------------|---------------|-----------------------|------------------------------------------|-------------|-------------|--------|--------|------------|--------|-------------------|--------|------|
| ene   |      |              |               | 1 V V                 | * <u>(</u>                               | 66 130      |             |        | J      |            |        | -                 |        |      |
| 🗙 🔶 L | 1 2  | V #°         | ⊒ 👗 ⊐         | • • • •               |                                          |             |             |        |        |            |        | All               | Colors |      |
|       |      |              |               |                       |                                          |             |             |        |        |            |        |                   | V S    |      |
|       |      |              |               |                       |                                          |             |             |        |        |            |        | Module            |        | 1    |
|       |      | - 世紀         | 能能量為          | 總加朝                   | 10.05                                    |             | 114         | TEN!   | ΠE     |            |        | Black Box         |        | 41   |
|       |      | 146          | Column -      |                       |                                          | 18 A 1      |             |        |        |            |        | Fence             |        | 41   |
|       |      | 125          | 33 88.15      | Status                | THE R.                                   |             | 明清          | 12     |        |            |        | Guide             | i na   | 81   |
|       |      |              | 1.1           |                       | 111                                      |             | 10.1        | 2014   |        |            |        | Obstruct          |        | 5    |
|       |      |              | 1.0           | and the second second | 1 200                                    |             | 16          |        |        |            |        | Region            |        |      |
|       |      |              |               | 10.0                  | 1010                                     |             |             |        |        |            |        | Screen            |        |      |
|       |      | 一相後          | 8 8 R.C       |                       |                                          | 1217        | <b>8</b> 91 |        | 8      |            |        | Instance          |        |      |
|       |      |              |               |                       | TO ADD INT                               | <b>e</b> 10 |             | 日間     |        |            |        | Net               |        | 1    |
|       |      | - <b>6</b> 4 | 19.6          |                       |                                          | <b>a</b> 2  | 910         |        |        |            |        | SNet              |        |      |
|       |      |              | <b>新社 1</b> 4 |                       | 1811                                     |             |             |        |        |            |        | P/G               |        |      |
|       |      | 1 - 5 1      | 10000         |                       | C. C |             | 1111        | 合理日    |        |            |        | Pin<br>Ruler      |        |      |
|       |      | 「勝手          |               |                       |                                          |             |             |        |        |            |        | Kuler<br>VCongest |        |      |
|       |      |              | 2237          |                       |                                          | - 12        |             | n of t |        |            |        | HCongest          |        |      |
|       |      | 186          | C Internation | e-ter Ram             | 100                                      |             | 福井          |        |        |            |        | Text              |        |      |
|       |      | - 26         |               | 100 to 100            |                                          | 100         | が行          | 12.0   |        |            |        | Rel. FPlan        | 66     |      |
|       |      | 2 Summer     |               |                       |                                          |             | -           |        |        |            |        |                   |        |      |

Figure 34: View After Routing

### Add Filler Cell

Filler Cell has no function and is added to fill all the blank area without cells. The aim is to increase physical stress.

- Place->Filler->Add...
- Select Filler Name and Add all available fillers (shown in Figure. )
- OK

| - Add Filler                       | • □    | - Selec                     | t Filler Cells             | · [ |
|------------------------------------|--------|-----------------------------|----------------------------|-----|
| Cell Name(s) FILLCELL_X8 FILLCELL_ | Select | Selectable Cells List       | Cells List                 |     |
| Prefix FILLER                      |        | FILLCELL_X8                 | FILLCELL_X8<br>FILLCELL_X4 | Â   |
| Power Domain                       | Select | FILLCELL_X32                | FILLCELL_X32               |     |
| I No DRC                           |        | FILLCELL_X2<br>FILLCELL_X16 | Add FILLCELL_X2            |     |
| Mark Fixed                         |        | FILLCELL_X16                | Delete FILLCELL_X16        |     |
| Fill Boundary                      |        | _                           | Delete                     |     |
| 🗇 Fill Area Draw                   |        |                             |                            |     |
| lb: lb:                            |        | 7                           |                            | 7   |
| unx ury                            |        | A                           | M                          |     |
| <u>O</u> K <u>Cancel</u>           | leip   |                             | Qose                       |     |

Figure 35: Add Filler

### Calculate Delay:

- > Timing -> Extract RC... (leave everything as default and click OK)
- > Timing -> Calculate Delay

The delay is extracted from the wire loading and save into an delay file called "sdf " file. We can use it to do the Post-Layout simulation

| — Calc                                                     | ulate Delay 👘 🗌                 |
|------------------------------------------------------------|---------------------------------|
| <ul> <li>Delay Calculation</li> <li>Ideal Clock</li> </ul> | n Option                        |
| SDF Output File                                            | : Multiplier_15_0_1000.sdf      |
| <u>о</u> к <u>А</u> р                                      | ply <u>C</u> ancel <u>H</u> elp |

Figure 36: Calculate Delay

#### Save the Final Netlist and layout file

This netlist might be different from the one you saved after synthesis. During P&R, some logic might be optimized again for better timing. So you should use this netlist and sdf from last step to perform your Post-Layout Simulation.

- Design->Save->Netlist, name the file as your wish
- Design->Save Design to save the layout in enc file format (the actual file for fabrication is in gds format you can also save it)

### **Post-simulation**

The simulation can be done with the netlist from P&R, sdf file from P&R which we have saved in the previous step and standard cell library verilog file (the same typical.v file in pre-layout simulation). The sdf file is annotated to take account for the interconnection delay. you can refer to the appendix. for a reference to add it in the testbench. ("\$sdf\_annotate" in the testbench); after adding sdf annotation in test bench, the post layout simulation is similar to pre-layout simulation. (Note : Because we use the testbench which contains sdf (timing information of layout), the results are more accurate).

# Appendix A

```
_____
// sample verilog testbench
'timescale 1ns / 1ps
module MyDesign_tb;
reg clk;
MyDesign uut ( // design ports );
always #50
   clk = !clk;
initial begin
   $sdf_annotate("./MyDesign.sdf", uut);
   // uut is the name you instantiate your design in the testbench
   // assume sdf in within the same folder of your simulation folder
end
initial begin
   # 0 // Have your test bench here
   # 1000000000
   $finish;
end
endmodule
_____
```