



ELEN 153: Digital Integrated Circuit Desb 59114

### Lab 3: CMOS Inverter Layout

Yutong Li

Wednesday 2:15-5:00pm 2017/10/11

## **I. OBJECTIVE**

- To develop skills for CMOS layout using Synopsys Custom Compiler.
- To create an inverter layout and verify it using DRC and LVS.
- To perform parasitic extraction and post-layout simulation.

## **II. LAB PROCEDURE**

### **1. Inverter Layout**

Before beginning to draw out the layout, we need to turn on DRD since it can visually indicate any design rule violation live as we draw the layout. However, the instruction in the Tutorial doesn't give the drop-down menu of DRD, instead of doing **Window→Toolbars→DRD** directly, we need to do **Tools→SDL**, press ok on the pop up, then go back to do **Window→Toolbars→DRD**. Next, open **Options->Display**, and turn on Dynamic and DX/DY so we can see X and Y measurement on the cursor as we draw.

Now we begin the layout. Note that the magnitude of every component needs to be exactly the same as told. When placing the Diffusion Contacts on PMOS, remember to enter “4” for the number of rows or there will be error if you try to add one by one.



Figure 1. Final design of CMOS inverter layout

Table 1. Layout layers and their corresponding name in Synopsys tools

| Layout layers   | Corresponding name in Synopsys tools |
|-----------------|--------------------------------------|
| N-Well          | NWELL                                |
| N+ Implantation | NIMP                                 |
| P+ Implantation | PIMP                                 |
| Diffusion       | DIFF                                 |
| Poly Silicon    | PO                                   |

|             |       |
|-------------|-------|
| Metal 1     | M1    |
| Metal 2     | M2    |
| Metal 1 Pin | M1PIN |

## 2. DRC and LVS

### Design Rule Check(DRC)

Select **Verification→DRC→Run**. The text view will pop-up to show the progress of the DRC. If the layout is correct in terms of rules, the screen should match Figure 3.



Figure 2. Console indicating no errors

The screenshot shows a software interface with multiple tabs at the top: 'run\_icv.sh', 'rules.drc.9m\_saed90\_icv.drc.rs', 'inverter.drc.custom\_compiler.rc', 'inverter.RESULTS', 'inverter.LAYOUT\_ERRORS', and 'stdout.drc.log'. The 'inverter.LAYOUT\_ERRORS' tab is selected. The content of the tab is as follows:

```

LAYOUT ERRORS RESULTS: CLEAN

#####
#   #####
#   #   #
#   #   #####
#   #   #   #
##### #####
#   #   #   #

=====

Library name: lab3
Structure name: inverter
Generated by: IC Validator RHEL64 M-2017.06-1.3706802 2017/06/19
Runset name: /DCNFS/users/student/yli1/ELEN153/lab3/synopsys_custom/pvjob_lab3.inverter.icv.drc/rules.drc.9m_saed90_icv.drc.rs
User name: yli1
Time started: 2017/10/11 03:52:29PM
Time ended: 2017/10/11 03:52:33PM

Called as: icv -f openaccess -i lab3 -c inverter -oa_view layout -oa_lib_defs /DCNFS/users/student/yli1/ELEN153/lab3/lib.defs -oa_layer_map /DCNFS/applications/synopsys/2017/app/SAED/SAED_PDK90nm/techfiles/saed_pdk90_layer.map -rc /DCNFS/users/student/yli1/ELEN153/lab3/synopsys_custom/pvjob_lab3.inverter.icv.drc/inverter.drc.custom_compiler.rc -oa_dm5 -vue /DCNFS/users/student/yli1/ELEN153/lab3/synopsys_custom/pvjob_lab3.inverter.icv.drc/rules.drc.9m_saed90_icv.drc.rs

```

Figure 3. inverter.LAYOUT\_ERRORS

### Layout Vs. Schematic (LVS)

Select **Verification→LVS→Run**. At first, on the pop-up VUE window I got FAIL, as shown in Figure 4.



Figure 4. VUE indicating failing LVS

Then, I learn that it fails because I didn't have this layout in the same folder that holds the schematic and symbol for CMOS inverter. In order to solve this, the TA suggests and helps me build another schematic and symbol in the current file. After this modification, I got PASS.



Figure 5. VUE indicating passing LVS

### 3. LPE and Post-Layout Simulation

Select **Verification→LPE→Setup and Run**. In the **Extraction Options** bar, include Tutorial\_final\_2017/synopsys\_custom/pvjob\_Tutorial.inverter.icv.lvs/pex\_runset\_report to the Runset report file.

When LPE is completed successfully, the inverter starrc view will pop-up to show the Layout parasitics on the layout as shown in Figure 6. Zoom-in so we can see there are many resistors and capacitances.



Figure 6. Inverter starrc view



Figure 7. Detail of Figure 6

In order to do the Post-Layout Simulations, we need to create a new cellview for the testbench\_inverter cell named config. Type **schematic hspice** in View Search List. Then click on the empty space under the Selected Column corresponding to the inverter, and select the **starrc** view. Then load the config state on SAE, perform a transient simulation, and select **append** in the Plotting Mode drop-down menu, in order to superimpose pre- and post-layout simulations.

Keep the WaveView of pre-layout simulation in order to compare with that of post-layout simulation. Change the design from config view back to schematic view to run post-layout simulation. The input and output waveforms for the pre-layout simulation will be appended to the WaveView window as shown in Figure 9.



Figure 8. Pre-layout simulation waveform



Figure 9.Post-layout simulation waveform

First, ungroup the waveforms to have 4 waveforms. Then group them so we have 2 groups: Vout and Vin, as shown in Figure 10.



Figure 10. Waveform after ungrouping and grouping

We can see that the two waveforms of Vout are not identical, because of the resistors and capacitances. In our case, the number of capacitances is not huge, so the difference is small and neglectable.

### **III. CONCLUSION**

In this lab, I learn how to create CMOS layout, verify it using DRC and LVS, and perform parasitic extraction and pre- and post-layout simulations, and notice the difference through waveform. I also learn that when creating the layout, we should be very strict about the magnitude so that we can have the layout function. During the lab, because I didn't build the layout in the same folder that holds the symbol and schematic for the CMOS inverter, I had to either rebuild the schematic and symbol in the current file, or rebuild the layout in the former folder. The TA suggested the first option, and helped me a lot with it. Also, I learnt that I forgot to add the model files again. After including the path, \$SAED90\_PDK/hspice, and select TT\_12, I was able to run and get the desired waveform and results.



