

# ECE1388 Tutorial

## Mixed Signal Simulations within Virtuoso AMS Environment

### Contents

|          |                                             |          |
|----------|---------------------------------------------|----------|
| <b>1</b> | <b>IC6</b>                                  | <b>2</b> |
| 1.1      | Environment Setup for UG Machines . . . . . | 2        |
| 1.2      | Design and Testbench Setup . . . . .        | 2        |
| 1.3      | Hierarchy Editor Setup . . . . .            | 2        |
| 1.4      | Netlisting and Simulation . . . . .         | 4        |
| 1.4.1    | Simulator and analysis setup . . . . .      | 4        |
| 1.4.2    | Digital-Analog connection setup . . . . .   | 6        |
| 1.5      | Design and Testbench Setup . . . . .        | 8        |

The intention of this tutorial is to get you familiar with Virtuoso AMS environment and simulator in order to netlist, compile, elaborate, and simulate a system containing analog, digital and mixed-signal components. The AMS simulator provides both the Spectre and the UltraSim solvers and you can switch between the two as your design evolves.

In this tutorial, we will design an inverter using transistors and verilog separately. We will use the following test bench in both cases where some of the inverters are simulated using verilog simulator and some are simulated using spectre simulator at the same time.

# 1 IC6

## 1.1 Environment Setup for UG Machines

1. Change to your local project directory
2. Execute following three lines in the exact order in terminal before starting Cadence session.

```
source /CMC/tools/CSHRCs/Cadence.IC617  
source /CMC/tools/CSHRCs/Cadence.XCELIUM  
setenv LD_PRELOAD /usr/lib/x86_64-linux-gnu/libstdc++.so.6
```

3. Start cadence session using following command.

```
startCds -t ic6-crn65gp
```

**Ignore the following error message in CIW and terminal** "ERROR: ld.so: object '/usr/lib/x86\_64-linux-gnu/libstdc++ so.6' from LD\_PRELOAD cannot be preloaded (wrong ELF class: ELF-CLASS64): ignored."

4. Open cds.lib and following two lines at the end of the file.

```
SOFTINCLUDE $AMSHOME/tools/affirma_ams/etc/connect_lib/cds.lib  
DEFINE sample $CDSHOME/tools/dfII/samples/cdslib/sample
```

5. Refresh library manager from *CIW* → *File* → *Refresh* and make sure you see two new libraries, *connectLib* and *sample*

## 1.2 Design and Testbench Setup

Design the testbench and modules as mentioned in section 1.5 of this tutorial.

## 1.3 Hierarchy Editor Setup

1. Close all windows except *CIW* window.
2. In the library manger, create new view for *tb\_inv* cell as below



3. New configuration window for hierarchy editor will open.

4. Click on *Use Template*.
5. Choose AMS from the drop-down menu.
6. Add *TUT04 analogLib basic* to *Library List* under *Global Bindings*.
7. Make sure *Top Cell Library*, *Cell*, and *View* fields are correctly filled as *TUT04 tb\_inv schematic* respectively.



8. Click OK
9. *Hierarchy editor*(HED) window will be populated.
10. Click on *Tree* in HED window. This will show tree view of all the instances of in your top cell.



11. In this example we will simulate three blocks with verilog model and three blocks with schematic/spectre model as shown below



12. In HED window assign *schematic* as a view to use for the instance highlighted using blue box above. After assigning all the instances HED should look as follows



Save and close all the windows except *CIW* and *Library Manager*

## 1.4 Netlisting and Simulation

We will perform simulation using AMS simulator.

### 1.4.1 Simulator and analysis setup

1. Open *TUT04* → *tb\_inv* → *config*

2. A new window as shown below opens asking to open either of Configuration and Top cell view or both of them. Click yes for both of them.



3. Now you can see the Cadence Hierarchy Editor and the schematic of the design.



4. Open the ADEL from Hierarchy editor by click ADEL button or from virtuoso schematic editor by doing *Launch → ADEL*. Make sure the design view is config. Otherwise correct it in *Setup → Design*.



5. Make sure the simulator is ams from *Setup → Simulator/Directory/Host* in the ADE window.



6. Make the time period of the vpulse to be  $500ps$  with 50% duty cycle. Save and plot all 6 outputs  $OUT[1 : 6]$  and input node  $IN1$ . Set transient analysis for  $5ns$ .



#### 1.4.2 Digital-Analog connection setup

1. Click *Simulation* → *Netlister and Run Options* and make sure settings match as follows.



2. Open *Setup* → *Connect Rules*

The digital 0 and 1s need to be converted to analog levels in order to be able to simulate the design



3. Change *Supply value/Net* from 1.8 to 1.

4. Make sure first row is selected and then click on *Advanced Setup* option.

5. Change rise time, *tr*, to 10p

6. Click OK and close the window.

7. The design is ready for simulation now. Click on *Simulation* → *Netlist and Run* to simulate. A sample output is provided below.



## 1.5 Design and Testbench Setup

Create following library and cellviews.

- Library:** Make new library named *TUT06*. Attach the library to existing technology and choose tsmcN65 from drop-down menu.
  - Cellview → inv → schematic:** Make a unit sized inverter schematic in library *TUT04* as shown as shown in figure 1a with terminals *IN*, *OUT*, and global power connections *DVDD!* and *DVSS!* (No separate pins for power).
- NOTE:** Also create a symbol view from this schematic. This symbol will have only two terminals, *viz.* *IN* and *OUT*.



Figure 1: Inverter testbench

- Cellview → tb\_inv → schematic:** Create a testbench as shown in figure 1b

**NOTE:** Before proceeding to the next step make sure you are able to simulate the *tb\_inv* without any problems.

- Cellview → inv → verilog:** Here we assume that symbol view(It doesn't matter schematic is present or not) is already present in the *inv* cell. Create verilog cellview as shown in figure 2a.
  - Text editor(in this case it is vim) will open with with io ports predefined as per in symbol.
  - Write the code. Save and close the file.
  - if there are errors in the code the pop-up as shown in 2b will appear.



Figure 2: Verilog cellview for inverter(NOT gate)

- (d) Open the file and fix the code. Save and close the file. If you do not see any pop-ups, check *CIW* window and make sure there are no errors.
5. At the end of this section your TUT06 library should look something like as below

