



# SACRAMENTO STATE

CPE 151/EEE 234  
Digital IC Design

Project No. 2

Student Name:  
Email ID:  
Date of Submission:

## Table of Contents

|                                                   |    |
|---------------------------------------------------|----|
| <b>D-Type Flip Flop .....</b>                     | 6  |
| <b>D-Type Flip Flop Schematic .....</b>           | 7  |
| <b>D-Type Flip Flop Testbench .....</b>           | 8  |
| <b>D-Type Flip Flop Testbench Waveform .....</b>  | 9  |
| <b>D-Type Flip Flop Layout.....</b>               | 10 |
| <b>D-Type Flip Flop DRC.....</b>                  | 11 |
| <b>D-Type Flip Flop LVS.....</b>                  | 12 |
| <b>D-Type Flip Flop Post-Layout.....</b>          | 14 |
| <b>Inverter .....</b>                             | 16 |
| <b>Inverter Schematic .....</b>                   | 17 |
| <b>Inverter Testbench .....</b>                   | 18 |
| <b>Inverter Testbench Waveform .....</b>          | 19 |
| <b>Inverter Layout.....</b>                       | 20 |
| <b>Inverter DRC.....</b>                          | 21 |
| <b>Inverter LVS.....</b>                          | 22 |
| <b>Inverter Post-Layout.....</b>                  | 24 |
| <b>2-Input AND Gate .....</b>                     | 25 |
| <b>2-Input AND Gate Schematic.....</b>            | 26 |
| <b>2-Input AND Gate Testbench.....</b>            | 27 |
| <b>2-Input AND Gate Testbench Waveform .....</b>  | 28 |
| <b>2-Input AND Gate Layout .....</b>              | 29 |
| <b>2-Input AND Gate DRC .....</b>                 | 30 |
| <b>2-Input AND Gate LVS .....</b>                 | 31 |
| <b>2-Input AND Gate Post Layout .....</b>         | 33 |
| <b>2-Input NAND Gate .....</b>                    | 35 |
| <b>2-Input NAND Gate Schematic .....</b>          | 36 |
| <b>2-Input NAND Gate Testbench .....</b>          | 37 |
| <b>2-Input NAND Gate Testbench Waveform .....</b> | 38 |
| <b>2-Input NAND Gate Layout.....</b>              | 39 |
| <b>2-Input NAND Gate DRC .....</b>                | 40 |

|                                             |    |
|---------------------------------------------|----|
| <b>2-Input NAND Gate LVS</b>                | 41 |
| <b>2-Input NAND Gate Post-Layout</b>        | 43 |
| <b>2-Input NOR Gate</b>                     | 45 |
| <b>2-Input NOR Gate Schematic</b>           | 46 |
| <b>2-Input NOR Gate Testbench</b>           | 47 |
| <b>2-Input NOR Gate Testbench Waveform</b>  | 48 |
| <b>2-Input NOR Gate Layout</b>              | 49 |
| <b>2-Input NOR Gate DRC</b>                 | 50 |
| <b>2-Input NOR Gate LVS</b>                 | 51 |
| <b>2-Input NOR Gate Post-Layout</b>         | 53 |
| <b>ALU</b>                                  | 55 |
| <b>ALU Schematic</b>                        | 56 |
| <b>ALU Testbench</b>                        | 57 |
| <b>ALU Testbench Waveform</b>               | 58 |
| <b>ALU Layout</b>                           | 59 |
| <b>ALU DRC</b>                              | 60 |
| <b>ALU LVS</b>                              | 61 |
| <b>ALU Post-Layout</b>                      | 62 |
| <b>2-Input NAND Gate</b>                    | 63 |
| <b>2-Input NAND Gate Schematic</b>          | 64 |
| <b>2-Input NAND Gate Testbench</b>          | 65 |
| <b>2-Input NAND Gate Testbench Waveform</b> | 66 |
| <b>2-Input NAND Gate Layout</b>             | 67 |
| <b>2-Input NAND Gate DRC</b>                | 68 |
| <b>2-Input NAND Gate LVS</b>                | 69 |
| <b>2-Input NAND Gate Post-Layout</b>        | 71 |
| <b>Full Adder</b>                           | 73 |
| <b>Full Adder Schematic</b>                 | 74 |
| <b>Full Adder Testbench</b>                 | 75 |
| <b>Full Adder Testbench Waveform</b>        | 76 |
| <b>Full Adder Layout</b>                    | 77 |
| <b>Full Adder DRC</b>                       | 78 |
| <b>Full Adder LVS</b>                       | 79 |

|                                                        |     |
|--------------------------------------------------------|-----|
| <b>Full Adder Post-Layout</b> .....                    | 81  |
| <b>2-Input AND Gate</b> .....                          | 83  |
| <b>2-Input AND Gate Schematic</b> .....                | 84  |
| <b>2-Input AND Gate Testbench</b> .....                | 85  |
| <b>2-Input AND Gate Testbench Waveform</b> .....       | 86  |
| <b>2-Input AND Gate Layout</b> .....                   | 87  |
| <b>2-Input AND Gate DRC</b> .....                      | 88  |
| <b>2-Input AND Gate LVS</b> .....                      | 89  |
| <b>2-Input AND Gate Post Layout</b> .....              | 91  |
| <b>Multiplier</b> .....                                | 93  |
| <b>Multiplier Schematic</b> .....                      | 94  |
| <b>Multiplier Testbench</b> .....                      | 95  |
| <b>Multiplier Testbench Waveform</b> .....             | 96  |
| <b>Multiplier Layout</b> .....                         | 97  |
| <b>Multiplier DRC</b> .....                            | 98  |
| <b>Multiplier LVS</b> .....                            | 99  |
| <b>Multiplier Post-Layout</b> .....                    | 100 |
| <b>Bi-Directional Shifter</b> .....                    | 101 |
| <b>Bi-Directional Shifter Schematic</b> .....          | 102 |
| <b>Bi-Directional Shifter Testbench</b> .....          | 103 |
| <b>Bi-Directional Shifter Testbench Waveform</b> ..... | 104 |
| <b>Bi-Directional Shifter Layout</b> .....             | 105 |
| <b>Bi-Directional Shifter DRC</b> .....                | 106 |
| <b>Bi-Directional Shifter LVS</b> .....                | 107 |
| <b>Bi-Directional Shifter Post-Layout</b> .....        | 109 |
| <b>2-Input NAND Gate</b> .....                         | 111 |
| <b>2-Input NAND Gate Schematic</b> .....               | 112 |
| <b>2-Input NAND Gate Testbench</b> .....               | 113 |
| <b>2-Input NAND Gate Testbench Waveform</b> .....      | 114 |
| <b>2-Input NAND Gate Layout</b> .....                  | 115 |
| <b>2-Input NAND Gate DRC</b> .....                     | 116 |
| <b>2-Input NAND Gate LVS</b> .....                     | 117 |
| <b>2-Input NAND Gate Post-Layout</b> .....             | 119 |

|                                                  |     |
|--------------------------------------------------|-----|
| <b>Inverter</b> .....                            | 121 |
| <b>Inverter Schematic</b> .....                  | 122 |
| <b>Inverter Testbench</b> .....                  | 123 |
| <b>Inverter Testbench Waveform</b> .....         | 124 |
| <b>Inverter Layout</b> .....                     | 125 |
| <b>Inverter DRC</b> .....                        | 126 |
| <b>Inverter LVS</b> .....                        | 127 |
| <b>Inverter Post-Layout</b> .....                | 129 |
| <b>D-Type Flip Flop</b> .....                    | 130 |
| <b>D-Type Flip Flop Schematic</b> .....          | 131 |
| <b>D-Type Flip Flop Testbench</b> .....          | 132 |
| <b>D-Type Flip Flop Testbench Waveform</b> ..... | 133 |
| <b>D-Type Flip Flop Layout</b> .....             | 134 |
| <b>D-Type Flip Flop DRC</b> .....                | 135 |
| <b>D-Type Flip Flop LVS</b> .....                | 136 |
| <b>D-Type Flip Flop Post-Layout</b> .....        | 138 |
| <b>Conclusion</b> .....                          | 140 |

# D-Type Flip Flop

Positive Clock Edge,  
Synchronous Reset

# D-Type Flip Flop Schematic



## D-Type Flip Flop Testbench



# D-Type Flip Flop Testbench Waveform

project2:dff\_tb:1 : project2 dff\_tb schematic

16:22:25 Wed Apr 11 2018



## D-Type Flip Flop Layout



## D-Type Flip Flop DRC

```
Validating hierarchy instantiation for:  
library: project2  
cell:    dff_layout  
view:    layout  
Rules come from library NCSU_TechLib_tsmc02d.  
Rules path is divaDRC.rul.  
Inclusion limit is set to 1000.  
Running layout DRC analysis  
Flat mode  
Full checking.  
DRC started.....Fri May  4 19:44:51 2018  
completed ....Fri May  4 19:44:51 2018  
CPU TIME = 00:00:00  TOTAL TIME = 00:00:00  
***** Summary of rule violations for cell "dff_layout layout" *****  
Total errors found: 0
```

## D-Type Flip Flop LVS

```
@(#) $CDS: LVS version 6.1.7-64b 09/27/2016 19:41 (sjfhw305) $
```

Command line: /software/cadence/install/IC617/tools.lnx86/dfII/bin/64bit/LVS -dir  
/gaia/class/student/ /CPE151/LVS -l -s -t /gaia/class/student/ /CPE151/LVS/layout  
/gaia/class/student/ /CPE151/LVS/schematic

Like matching is enabled.

Net swapping is enabled.

Using terminal names as correspondence points.

Compiling Diva LVS rules...

Net-list summary for /gaia/class/student/ /CPE151/LVS/layout/netlist

count

|    |           |
|----|-----------|
| 18 | nets      |
| 0  | terminals |
| 13 | pmos      |
| 13 | nmos      |

Net-list summary for /gaia/class/student/ /CPE151/LVS/schematic/netlist

count

|    |           |
|----|-----------|
| 18 | nets      |
| 6  | terminals |
| 13 | pmos      |
| 13 | nmos      |

Devices in the rules but not in the netlist:

cap nfet pfet nmos4 pmos4

The net-lists match.

|             | layout    | schematic |
|-------------|-----------|-----------|
|             | instances |           |
| un-matched  | 0         | 0         |
| rewired     | 0         | 0         |
| size errors | 0         | 0         |
| pruned      | 0         | 0         |
| active      | 26        | 26        |
| total       | 26        | 26        |

|            | nets |   |
|------------|------|---|
| un-matched | 0    | 0 |

|        |    |    |
|--------|----|----|
| merged | 0  | 0  |
| pruned | 0  | 0  |
| active | 18 | 18 |
| total  | 18 | 18 |

|                |   |   |
|----------------|---|---|
| terminals      |   |   |
| un-matched     | 0 | 0 |
| matched but    |   |   |
| different type | 0 | 0 |
| total          | 0 | 6 |

Probe files from /gaia/class/student/ /CPE151/LVS/schematic

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

Probe files from /gaia/class/student/ /CPE151/LVS/layout

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

# D-Type Flip Flop Post-Layout

project2:dff\_tb:1 : project2 dff\_tb schematic

16:37:32 Sun May 6 2018



**DC Response****Sun May 6 16:37:13 2018**

Name Vis

/Clk

@

/Reset

@

/D

@

/Q

@



## Inverter

$$(W/L)_n = 1.8/0.18$$

$$(W/L)_p = 3.6/0.18$$

## Inverter Schematic



## Inverter Testbench



# Inverter Testbench Waveform

Project1:Inverter\_testbench:1 : Project1\_Inverter\_testbench schematic

19:20:40 Wed Feb 28 2018

## Transient Response

Wed Feb 28 19:14:42 2018



## Inverter Layout



# Inverter DRC

```
DRC started at Fri May  4 17:02:54 2018

Validating hierarchy instantiation for:
library: project2
cell:    inverter_layout
view:    layout
Rules come from library NCSU_TechLib_tsmc02d.
Rules path is divaDRC.rul.
Inclusion limit is set to 1000.
Running layout DRC analysis
Flat mode
Full checking.

DRC started.....Fri May  4 17:02:54 2018
completed ....Fri May  4 17:02:54 2018
CPU TIME = 00:00:00  TOTAL TIME = 00:00:00
***** Summary of rule violations for cell "inverter_layout layout" *****
Total errors found: 0
```

# Inverter LVS

@(#) \$CDS: LVS version 6.1.7-64b 09/27/2016 19:41 (sjfhw305) \$

Command line: /software/cadence/install/IC617/tools.lnx86/dfII/bin/64bit/LVS -dir /gaia/class/student/ /CPE151/LVS -l -s -t /gaia/class/student/ /CPE151/LVS/layout  
/gaia/class/student/ /CPE151/LVS/schematic

Like matching is enabled.

Net swapping is enabled.

Using terminal names as correspondence points.

Compiling Diva LVS rules...

Net-list summary for /gaia/class/student/ /CPE151/LVS/layout/netlist

count

|   |           |
|---|-----------|
| 4 | nets      |
| 0 | terminals |
| 1 | pmos      |
| 1 | nmos      |

Net-list summary for /gaia/class/student/ /CPE151/LVS/schematic/netlist

count

|   |           |
|---|-----------|
| 4 | nets      |
| 4 | terminals |
| 1 | pmos      |
| 1 | nmos      |

Devices in the rules but not in the netlist:

cap nfet pfet nmos4 pmos4

The net-lists match.

|             | layout    | schematic |
|-------------|-----------|-----------|
|             | instances |           |
| un-matched  | 0         | 0         |
| rewired     | 0         | 0         |
| size errors | 0         | 0         |
| pruned      | 0         | 0         |
| active      | 2         | 2         |
| total       | 2         | 2         |

|            | nets |   |
|------------|------|---|
| un-matched | 0    | 0 |
| merged     | 0    | 0 |

```
pruned      0  0
active      4  4
total       4  4
```

```
          terminals
un-matched   0  0
matched but
different type 0  0
total        0  4
```

Probe files from /gaia/class/student/ /CPE151/LVS/schematic

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

Probe files from /gaia/class/student/ /CPE151/LVS/layout

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

# Inverter Post-Layout



## 2-Input AND Gate

$$(W/L)_n = 5.4/0.18$$

$$(W/L)_p = 3.6/0.18$$

## 2-Input AND Gate Schematic



## 2-Input AND Gate Testbench



# 2-Input AND Gate Testbench Waveform



## 2-Input AND Gate Layout



## 2-Input AND Gate DRC

```
Validating hierarchy instantiation for:  
library: project2  
cell:    2AND_REAL_LAYOUT  
view:    layout  
Rules come from library NCSU_TechLib_tsmc02d.  
Rules path is divaDRC.rul.  
Inclusion limit is set to 1000.  
Running layout DRC analysis  
Flat mode  
Full checking.  
DRC started.....Fri May  4 17:43:36 2018  
completed ....Fri May  4 17:43:36 2018  
CPU TIME = 00:00:00  TOTAL TIME = 00:00:00  
***** Summary of rule violations for cell "2AND_REAL_LAYOUT layout" *****  
Total errors found: 0
```

## 2-Input AND Gate LVS

@(#)\$CDS: LVS version 6.1.7-64b 09/27/2016 19:41 (sjfhw305) \$

Command line: /software/cadence/install/IC617/tools.lnx86/dfII/bin/64bit/LVS -dir /gaia/class/student/ /CPE151/LVS -l -s -t /gaia/class/student/ /CPE151/LVS/layout /gaia/class/student/ /CPE151/LVS/schematic

Like matching is enabled.

Net swapping is enabled.

Using terminal names as correspondence points.

Net-list summary for /gaia/class/student/ /CPE151/LVS/layout/netlist

count

|   |           |
|---|-----------|
| 7 | nets      |
| 0 | terminals |
| 3 | pmos      |
| 3 | nmos      |

Net-list summary for /gaia/class/student/ /CPE151/LVS/schematic/netlist

count

|   |           |
|---|-----------|
| 7 | nets      |
| 5 | terminals |
| 3 | pmos      |
| 3 | nmos      |

Devices in the netlist but not in the rules:

pmos nmos

The net-lists match.

|             | layout    | schematic |
|-------------|-----------|-----------|
|             | instances |           |
| un-matched  | 0         | 0         |
| rewired     | 0         | 0         |
| size errors | 0         | 0         |
| pruned      | 0         | 0         |
| active      | 6         | 6         |
| total       | 6         | 6         |

|            | nets |   |
|------------|------|---|
| un-matched | 0    | 0 |
| merged     | 0    | 0 |
| pruned     | 0    | 0 |
| active     | 7    | 7 |

|                |           |   |
|----------------|-----------|---|
| total          | 7         | 7 |
|                | terminals |   |
| un-matched     | 0         | 0 |
| matched but    |           |   |
| different type | 0         | 0 |
| total          | 0         | 5 |

Probe files from /gaia/class/student/ /CPE151/LVS/schematic

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

Probe files from /gaia/class/student/ /CPE151/LVS/layout

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

# 2-Input AND Gate Post Layout

project2:2AND\_REAL\_tb:1 : project2 2AND\_REAL\_tb schematic

16:32:26 Sun May 6 2018





## 2-Input NAND Gate

$$(W/L)_n = 5.4/0.18$$

$$(W/L)_p = 3.6/0.18$$

## 2-Input NAND Gate Schematic



## 2-Input NAND Gate Testbench



# 2-Input NAND Gate Testbench Waveform

project2:nand2\_tb:1 : project2 nand2\_tb schematic

16:52:05 Wed Apr 11 2018



## 2-Input NAND Gate Layout



## 2-Input NAND Gate DRC

```
Getting layout property bag
DRC started at Fri May  4 17:27:41 2018

Validating hierarchy instantiation for:
library: project2
cell:    nand2_layout
view:   layout
Rules come from library NCSU_TechLib_tsmc02d.
Rules path is divaDRC.rul.
Inclusion limit is set to 1000.
Running layout DRC analysis
Flat mode
Full checking.
DRC started.....Fri May  4 17:27:41 2018
completed ....Fri May  4 17:27:41 2018
CPU TIME = 00:00:00  TOTAL TIME = 00:00:00
*****      Summary of rule violations for cell "nand2_layout layout"      *****
Total errors found: 0
```

## 2-Input NAND Gate LVS

@(#)\$CDS: LVS version 6.1.7-64b 09/27/2016 19:41 (sjfhw305) \$

Command line: /software/cadence/install/IC617/tools.lnx86/dfII/bin/64bit/LVS -dir /gaia/class/student/ /CPE151/LVS -l -s -t /gaia/class/student/ /CPE151/LVS/layout /gaia/class/student/ /CPE151/LVS/schematic

Like matching is enabled.

Net swapping is enabled.

Using terminal names as correspondence points.

Compiling Diva LVS rules...

Net-list summary for /gaia/class/student/ /CPE151/LVS/layout/netlist

|       |           |
|-------|-----------|
| count |           |
| 6     | nets      |
| 0     | terminals |
| 2     | pmos      |
| 2     | nmos      |

Net-list summary for /gaia/class/student/ /CPE151/LVS/schematic/netlist

|       |           |
|-------|-----------|
| count |           |
| 6     | nets      |
| 5     | terminals |
| 2     | pmos      |
| 2     | nmos      |

Devices in the rules but not in the netlist:

cap nfet pfet nmos4 pmos4

1 net-list ambiguity was resolved by random selection.

The net-lists match.

|             |           |
|-------------|-----------|
| layout      | schematic |
| instances   |           |
| un-matched  | 0 0       |
| rewired     | 0 0       |
| size errors | 0 0       |
| pruned      | 0 0       |
| active      | 4 4       |
| total       | 4 4       |

|            |     |
|------------|-----|
| nets       |     |
| un-matched | 0 0 |

|        |   |   |
|--------|---|---|
| merged | 0 | 0 |
| pruned | 0 | 0 |
| active | 6 | 6 |
| total  | 6 | 6 |

|                |   |   |
|----------------|---|---|
| terminals      |   |   |
| un-matched     | 0 | 0 |
| matched but    |   |   |
| different type | 0 | 0 |
| total          | 0 | 5 |

Probe files from /gaia/class/student/ /CPE151/LVS/schematic

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

Probe files from /gaia/class/student/ /CPE151/LVS/layout

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

# 2-Input NAND Gate Post-Layout

project2:nand2\_tb:1 : project2 nand2\_tb schematic

16:42:17 Sun May 6 2018





## 2-Input NOR Gate

$$(W/L)_n = 1.8/0.18$$

$$(W/L)_p = 7.2/0.18$$

## 2-Input NOR Gate Schematic



## 2-Input NOR Gate Testbench



# 2-Input NOR Gate Testbench Waveform

NOR:NOR\_testbench:1 : NOR NOR\_testbench schematic

20:51:44 Thu Mar 1 2018



## 2-Input NOR Gate Layout



## 2-Input NOR Gate DRC

```
Getting layout property bag
DRC started at Fri May  4 17:20:19 2018

Validating hierarchy instantiation for:
library: project2
cell:    nor2_layout
view:    layout
Rules come from library NCSU_TechLib_tsmc02d.
Rules path is divaDRC.rul.
Inclusion limit is set to 1000.
Running layout DRC analysis
Flat mode
Full checking.
DRC started.....Fri May  4 17:20:19 2018
completed ....Fri May  4 17:20:19 2018
CPU TIME = 00:00:00  TOTAL TIME = 00:00:00
*****      Summary of rule violations for cell "nor2_layout layout"      *****
Total errors found: 0
```

## 2-Input NOR Gate LVS

@(#)\$CDS: LVS version 6.1.7-64b 09/27/2016 19:41 (sjfhw305) \$

Command line: /software/cadence/install/IC617/tools.lnx86/dfII/bin/64bit/LVS -dir /gaia/class/student/ /CPE151/LVS -l -s -t /gaia/class/student/ /CPE151/LVS/layout /gaia/class/student/ /CPE151/LVS/schematic

Like matching is enabled.

Net swapping is enabled.

Using terminal names as correspondence points.

Compiling Diva LVS rules...

Net-list summary for /gaia/class/student/ /CPE151/LVS/layout/netlist

| count |           |
|-------|-----------|
| 6     | nets      |
| 0     | terminals |
| 2     | pmos      |
| 2     | nmos      |

Net-list summary for /gaia/class/student/ /CPE151/LVS/schematic/netlist

| count |           |
|-------|-----------|
| 6     | nets      |
| 5     | terminals |
| 2     | pmos      |
| 2     | nmos      |

Devices in the rules but not in the netlist:

cap nfet pfet nmos4 pmos4

1 net-list ambiguity was resolved by random selection.

The net-lists match.

|             | layout | schematic |
|-------------|--------|-----------|
| instances   |        |           |
| un-matched  | 0      | 0         |
| rewired     | 0      | 0         |
| size errors | 0      | 0         |
| pruned      | 0      | 0         |
| active      | 4      | 4         |
| total       | 4      | 4         |

|            | nets |
|------------|------|
| un-matched | 0 0  |

|        |   |   |
|--------|---|---|
| merged | 0 | 0 |
| pruned | 0 | 0 |
| active | 6 | 6 |
| total  | 6 | 6 |

|                |   |   |
|----------------|---|---|
| terminals      |   |   |
| un-matched     | 0 | 0 |
| matched but    |   |   |
| different type | 0 | 0 |
| total          | 0 | 5 |

Probe files from /gaia/class/student/ /CPE151/LVS/schematic

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

Probe files from /gaia/class/student/ /CPE151/LVS/layout

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

# 2-Input NOR Gate Post-Layout

project2:nor2\_tb:1 : project2 nor2\_tb schematic

16:54:10 Sun May 6 2018





# ALU

4-Bit Addition, 2s Complement Subtraction and Multiplier

## ALU Schematic

## ALU Testbench

## ALU Testbench Waveform

## ALU Layout

## ALU DRC

## ALU LVS

## ALU Post-Layout

## 2-Input NAND Gate

$$(W/L)_n = 5.4/0.18$$

$$(W/L)_p = 3.6/0.18$$

## 2-Input NAND Gate Schematic



## 2-Input NAND Gate Testbench



# 2-Input NAND Gate Testbench Waveform

project2:nand2\_tb:1 : project2 nand2\_tb schematic

16:52:05 Wed Apr 11 2018



## 2-Input NAND Gate Layout



## 2-Input NAND Gate DRC

```
Getting layout property bag
DRC started at Fri May  4 17:27:41 2018

Validating hierarchy instantiation for:
library: project2
cell:    nand2_layout
view:   layout
Rules come from library NCSU_TechLib_tsmc02d.
Rules path is divaDRC.rul.
Inclusion limit is set to 1000.
Running layout DRC analysis
Flat mode
Full checking.
DRC started.....Fri May  4 17:27:41 2018
completed ....Fri May  4 17:27:41 2018
CPU TIME = 00:00:00  TOTAL TIME = 00:00:00
*****      Summary of rule violations for cell "nand2_layout layout"      *****
Total errors found: 0
```

## 2-Input NAND Gate LVS

@(#)\$CDS: LVS version 6.1.7-64b 09/27/2016 19:41 (sjfhw305) \$

Command line: /software/cadence/install/IC617/tools.lnx86/dfII/bin/64bit/LVS -dir /gaia/class/student/ /CPE151/LVS -l -s -t /gaia/class/student/ /CPE151/LVS/layout /gaia/class/student/ /CPE151/LVS/schematic

Like matching is enabled.

Net swapping is enabled.

Using terminal names as correspondence points.

Compiling Diva LVS rules...

Net-list summary for /gaia/class/student/ /CPE151/LVS/layout/netlist

|       |           |
|-------|-----------|
| count |           |
| 6     | nets      |
| 0     | terminals |
| 2     | pmos      |
| 2     | nmos      |

Net-list summary for /gaia/class/student/ /CPE151/LVS/schematic/netlist

|       |           |
|-------|-----------|
| count |           |
| 6     | nets      |
| 5     | terminals |
| 2     | pmos      |
| 2     | nmos      |

Devices in the rules but not in the netlist:

cap nfet pfet nmos4 pmos4

1 net-list ambiguity was resolved by random selection.

The net-lists match.

|             |           |
|-------------|-----------|
| layout      | schematic |
| instances   |           |
| un-matched  | 0 0       |
| rewired     | 0 0       |
| size errors | 0 0       |
| pruned      | 0 0       |
| active      | 4 4       |
| total       | 4 4       |

|            |     |
|------------|-----|
| nets       |     |
| un-matched | 0 0 |

```
merged          0  0
pruned          0  0
active          6  6
total           6  6
```

```
terminals
un-matched      0  0
matched but
different type   0  0
total            0  5
```

Probe files from /gaia/class/student/ /CPE151/LVS/schematic

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

Probe files from /gaia/class/student/ /CPE151/LVS/layout

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

# 2-Input NAND Gate Post-Layout

project2:nand2\_tb:1 : project2 nand2\_tb schematic

16:42:17 Sun May 6 2018





# Full Adder

Contains NAND Gate

# Full Adder Schematic



## Full Adder Testbench



# Full Adder Testbench Waveform

project2:fullAdder\_tb:1 : project2 fullAdder\_tb schematic

17:31:52 Wed Apr 11 2018



## Full Adder Layout



# Full Adder DRC

DRC started at Sun May 6 22:17:45 2018

```
Validating hierarchy instantiation for:  
library: project2  
cell: fullAdder_layout  
view: layout  
Rules come from library NCSU_TechLib_tsmc02d.  
Rules path is divaDRC.rul.  
Inclusion limit is set to 1000.  
Running layout DRC analysis  
Flat mode  
Full checking.  
DRC started.....Sun May 6 22:17:45 2018  
completed ....Sun May 6 22:17:45 2018  
CPU TIME = 00:00:00 TOTAL TIME = 00:00:00  
***** Summary of rule violations for cell "fullAdder_layout layout" *****  
Total errors found: 0
```

# Full Adder LVS

@(#)\$CDS: LVS version 6.1.7-64b 09/27/2016 19:41 (sjfhw305) \$

Command line: /software/cadence/install/IC617/tools.lnx86/dfII/bin/64bit/LVS -dir /gaia/class/student/ /CPE151/LVS -l -s -t /gaia/class/student/ /CPE151/LVS/layout /gaia/class/student/ /CPE151/LVS/schematic

Like matching is enabled.

Net swapping is enabled.

Using terminal names as correspondence points.

Compiling Diva LVS rules...

Net-list summary for /gaia/class/student/ /CPE151/LVS/layout/netlist

| count |           |
|-------|-----------|
| 23    | nets      |
| 0     | terminals |
| 18    | pmos      |
| 18    | nmos      |

Net-list summary for /gaia/class/student/ /CPE151/LVS/schematic/netlist

| count |           |
|-------|-----------|
| 23    | nets      |
| 7     | terminals |
| 18    | pmos      |
| 18    | nmos      |

Devices in the netlist but not in the rules:

pcapacitor

Devices in the rules but not in the netlist:

cap nfet pfet nmos4 pmos4

1 net-list ambiguity was resolved by random selection.

The net-lists match.

|             | layout    | schematic |
|-------------|-----------|-----------|
|             | instances |           |
| un-matched  | 0         | 0         |
| rewired     | 0         | 0         |
| size errors | 0         | 0         |
| pruned      | 0         | 0         |
| active      | 36        | 36        |
| total       | 36        | 36        |

|            | nets |    |
|------------|------|----|
| un-matched | 0    | 0  |
| merged     | 0    | 0  |
| pruned     | 0    | 0  |
| active     | 23   | 23 |
| total      | 23   | 23 |

|                               | terminals |   |
|-------------------------------|-----------|---|
| un-matched                    | 0         | 0 |
| matched but<br>different type | 0         | 0 |
| total                         | 0         | 7 |

Probe files from /gaia/class/student/ /CPE151/LVS/schematic

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

Probe files from /gaia/class/student/ /CPE151/LVS/layout

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

# Full Adder Post-Layout

project2:fullAdder\_tb:1 : project2 fullAdder\_tb schematic

22:22:57 Sun May 6 2018





## 2-Input AND Gate

$$(W/L)_n = 5.4/0.18$$

$$(W/L)_p = 3.6/0.18$$

## 2-Input AND Gate Schematic



## 2-Input AND Gate Testbench



# 2-Input AND Gate Testbench Waveform



## 2-Input AND Gate Layout



## 2-Input AND Gate DRC

```
Validating hierarchy instantiation for:  
library: project2  
cell:    2AND_REAL_LAYOUT  
view:    layout  
Rules come from library NCSU_TechLib_tsmc02d.  
Rules path is divaDRC.rul.  
Inclusion limit is set to 1000.  
Running layout DRC analysis  
Flat mode  
Full checking.  
DRC started.....Fri May  4 17:43:36 2018  
completed ....Fri May  4 17:43:36 2018  
CPU TIME = 00:00:00  TOTAL TIME = 00:00:00  
***** Summary of rule violations for cell "2AND_REAL_LAYOUT layout" *****  
Total errors found: 0
```

## 2-Input AND Gate LVS

@(#)\$CDS: LVS version 6.1.7-64b 09/27/2016 19:41 (sjfhw305) \$

Command line: /software/cadence/install/IC617/tools.lnx86/dfII/bin/64bit/LVS -dir /gaia/class/student/ /CPE151/LVS -l -s -t /gaia/class/student/ /CPE151/LVS/layout /gaia/class/student/ /CPE151/LVS/schematic

Like matching is enabled.

Net swapping is enabled.

Using terminal names as correspondence points.

Net-list summary for /gaia/class/student/ /CPE151/LVS/layout/netlist

count

|   |           |
|---|-----------|
| 7 | nets      |
| 0 | terminals |
| 3 | pmos      |
| 3 | nmos      |

Net-list summary for /gaia/class/student/ /CPE151/LVS/schematic/netlist

count

|   |           |
|---|-----------|
| 7 | nets      |
| 5 | terminals |
| 3 | pmos      |
| 3 | nmos      |

Devices in the netlist but not in the rules:

pmos nmos

The net-lists match.

|             | layout    | schematic |
|-------------|-----------|-----------|
|             | instances |           |
| un-matched  | 0         | 0         |
| rewired     | 0         | 0         |
| size errors | 0         | 0         |
| pruned      | 0         | 0         |
| active      | 6         | 6         |
| total       | 6         | 6         |

|            | nets |   |
|------------|------|---|
| un-matched | 0    | 0 |
| merged     | 0    | 0 |
| pruned     | 0    | 0 |
| active     | 7    | 7 |

|                |           |   |
|----------------|-----------|---|
| total          | 7         | 7 |
|                | terminals |   |
| un-matched     | 0         | 0 |
| matched but    |           |   |
| different type | 0         | 0 |
| total          | 0         | 5 |

Probe files from /gaia/class/student/ /CPE151/LVS/schematic

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

Probe files from /gaia/class/student/ /CPE151/LVS/layout

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

# 2-Input AND Gate Post Layout

project2:2AND\_REAL\_tb:1 : project2 2AND\_REAL\_tb schematic

16:32:26 Sun May 6 2018





# Multiplier

Contains AND Gate and Full Adder

## Multiplier Schematic



## Multiplier Testbench



# Multiplier Testbench Waveform



## Multiplier Layout

## Multiplier DRC

## Multiplier LVS

## Multiplier Post-Layout

# Bi-Directional Shifter

2-Input NAND, Inverter, D-Flip Flop

## Bi-Directional Shifter Schematic



## Bi-Directional Shifter Testbench



# Bi-Directional Shifter Testbench Waveform

project2:shifter\_tb:1 : project2 shifter\_tb schematic

18:26:57 Tue Apr 17 2018



## Bi-Directional Shifter Layout



## Bi-Directional Shifter DRC

```
DRC started at Sun May  6 21:08:44 2018

Validating hierarchy instantiation for:
library: project2
cell:    shifter_tb
view:   layout
Rules come from library NCSU_TechLib_tsmc02d.
Rules path is divaDRC.rul.
Inclusion limit is set to 1000.
Running layout DRC analysis
Flat mode
Full checking.
DRC started.....Sun May  6 21:08:44 2018
completed ....Sun May  6 21:08:44 2018
CPU TIME = 00:00:00  TOTAL TIME = 00:00:00
*****      Summary of rule violations for cell "shifter_tb layout"      *****
Total errors found: 0
```

# Bi-Directional Shifter LVS

@(#)\$CDS: LVS version 6.1.7-64b 09/27/2016 19:41 (sjfhw305) \$

Command line: /software/cadence/install/IC617/tools.lnx86/dfl/bin/64bit/LVS -dir /gaia/class/student/ /CPE151/LVS -l -s -t /gaia/class/student/ /CPE151/LVS/layout /gaia/class/student/ /CPE151/LVS/schematic

Like matching is enabled.

Net swapping is enabled.

Using terminal names as correspondence points.

Compiling Diva LVS rules...

Net-list summary for /gaia/class/student/ /CPE151/LVS/layout/netlist

| count |           |
|-------|-----------|
| 83    | nets      |
| 0     | terminals |
| 77    | pmos      |
| 77    | nmos      |

Net-list summary for /gaia/class/student/ /CPE151/LVS/schematic/netlist

| count |           |
|-------|-----------|
| 83    | nets      |
| 10    | terminals |
| 77    | pmos      |
| 77    | nmos      |

Devices in the rules but not in the netlist:

cap nfet pfet nmos4 pmos4

The net-lists match.

|             | layout    | schematic |
|-------------|-----------|-----------|
|             | instances |           |
| un-matched  | 0         | 0         |
| rewired     | 0         | 0         |
| size errors | 0         | 0         |
| pruned      | 0         | 0         |
| active      | 154       | 154       |
| total       | 154       | 154       |

|            | nets |   |
|------------|------|---|
| un-matched | 0    | 0 |
| merged     | 0    | 0 |

|        |    |    |
|--------|----|----|
| pruned | 0  | 0  |
| active | 83 | 83 |
| total  | 83 | 83 |

|                |   |    |
|----------------|---|----|
| terminals      |   |    |
| un-matched     | 0 | 0  |
| matched but    |   |    |
| different type | 0 | 0  |
| total          | 0 | 10 |

Probe files from /gaia/class/student/ /CPE151/LVS/schematic

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

Probe files from /gaia/class/student/ /CPE151/LVS/layout

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

# Bi-Directional Shifter Post-Layout

project2:shifter\_tb:1 : project2 shifter\_tb schematic

21:16:00 Sun May 6 2018





## 2-Input NAND Gate

$$(W/L)_n = 5.4/0.18$$

$$(W/L)_p = 3.6/0.18$$

## 2-Input NAND Gate Schematic



## 2-Input NAND Gate Testbench



# 2-Input NAND Gate Testbench Waveform

project2:nand2\_tb:1 : project2 nand2\_tb schematic

16:52:05 Wed Apr 11 2018



## 2-Input NAND Gate Layout



## 2-Input NAND Gate DRC

```
Getting layout property bag
DRC started at Fri May  4 17:27:41 2018

Validating hierarchy instantiation for:
library: project2
cell:    nand2_layout
view:   layout
Rules come from library NCSU_TechLib_tsmc02d.
Rules path is divaDRC.rul.
Inclusion limit is set to 1000.
Running layout DRC analysis
Flat mode
Full checking.
DRC started.....Fri May  4 17:27:41 2018
completed ....Fri May  4 17:27:41 2018
CPU TIME = 00:00:00  TOTAL TIME = 00:00:00
*****      Summary of rule violations for cell "nand2_layout layout"      *****
Total errors found: 0
```

## 2-Input NAND Gate LVS

@(#)\$CDS: LVS version 6.1.7-64b 09/27/2016 19:41 (sjfhw305) \$

Command line: /software/cadence/install/IC617/tools.lnx86/dfII/bin/64bit/LVS -dir /gaia/class/student/ /CPE151/LVS -l -s -t /gaia/class/student/ /CPE151/LVS/layout /gaia/class/student/ /CPE151/LVS/schematic

Like matching is enabled.

Net swapping is enabled.

Using terminal names as correspondence points.

Compiling Diva LVS rules...

Net-list summary for /gaia/class/student/ /CPE151/LVS/layout/netlist

|       |           |
|-------|-----------|
| count |           |
| 6     | nets      |
| 0     | terminals |
| 2     | pmos      |
| 2     | nmos      |

Net-list summary for /gaia/class/student/ /CPE151/LVS/schematic/netlist

|       |           |
|-------|-----------|
| count |           |
| 6     | nets      |
| 5     | terminals |
| 2     | pmos      |
| 2     | nmos      |

Devices in the rules but not in the netlist:

cap nfet pfet nmos4 pmos4

1 net-list ambiguity was resolved by random selection.

The net-lists match.

|             |           |
|-------------|-----------|
| layout      | schematic |
| instances   |           |
| un-matched  | 0 0       |
| rewired     | 0 0       |
| size errors | 0 0       |
| pruned      | 0 0       |
| active      | 4 4       |
| total       | 4 4       |

|            |     |
|------------|-----|
| nets       |     |
| un-matched | 0 0 |

```
merged          0  0
pruned          0  0
active          6  6
total           6  6
```

```
terminals
un-matched      0  0
matched but
different type   0  0
total            0  5
```

Probe files from /gaia/class/student/ /CPE151/LVS/schematic

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

Probe files from /gaia/class/student/ /CPE151/LVS/layout

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

## 2-Input NAND Gate Post-Layout

project2:nand2\_tb:1 : project2 nand2\_tb schematic

16:42:17 Sun May 6 2018



**DC Response****Sun May 6 16:41:45 2018**

| Name | Vis |
|------|-----|
| /A   | ●   |
| /B   | ●   |
| /Out | ●   |



## Inverter

$$(W/L)_n = 1.8/0.18$$

$$(W/L)_p = 3.6/0.18$$

## Inverter Schematic



## Inverter Testbench



# Inverter Testbench Waveform

Project1:Inverter\_testbench:1 : Project1\_Inverter\_testbench schematic

19:20:40 Wed Feb 28 2018

## Transient Response

Wed Feb 28 19:14:42 2018



## Inverter Layout



## Inverter DRC

```
DRC started at Fri May  4 17:02:54 2018

Validating hierarchy instantiation for:
library: project2
cell:    inverter_layout
view:    layout
Rules come from library NCSU_TechLib_tsmc02d.
Rules path is divaDRC.rul.
Inclusion limit is set to 1000.
Running layout DRC analysis
Flat mode
Full checking.

DRC started.....Fri May  4 17:02:54 2018
completed ....Fri May  4 17:02:54 2018
CPU TIME = 00:00:00  TOTAL TIME = 00:00:00
***** Summary of rule violations for cell "inverter_layout layout" *****
Total errors found: 0
```

# Inverter LVS

@(#) \$CDS: LVS version 6.1.7-64b 09/27/2016 19:41 (sjfhw305) \$

Command line: /software/cadence/install/IC617/tools.lnx86/dfII/bin/64bit/LVS -dir /gaia/class/student/ /CPE151/LVS -l -s -t /gaia/class/student/ /CPE151/LVS/layout  
/gaia/class/student/ /CPE151/LVS/schematic

Like matching is enabled.

Net swapping is enabled.

Using terminal names as correspondence points.

Compiling Diva LVS rules...

Net-list summary for /gaia/class/student/ /CPE151/LVS/layout/netlist

count

|   |           |
|---|-----------|
| 4 | nets      |
| 0 | terminals |
| 1 | pmos      |
| 1 | nmos      |

Net-list summary for /gaia/class/student/ /CPE151/LVS/schematic/netlist

count

|   |           |
|---|-----------|
| 4 | nets      |
| 4 | terminals |
| 1 | pmos      |
| 1 | nmos      |

Devices in the rules but not in the netlist:

cap nfet pfet nmos4 pmos4

The net-lists match.

|             | layout    | schematic |
|-------------|-----------|-----------|
|             | instances |           |
| un-matched  | 0         | 0         |
| rewired     | 0         | 0         |
| size errors | 0         | 0         |
| pruned      | 0         | 0         |
| active      | 2         | 2         |
| total       | 2         | 2         |

|            | nets |   |
|------------|------|---|
| un-matched | 0    | 0 |
| merged     | 0    | 0 |

```
pruned      0  0
active      4  4
total       4  4
```

```
          terminals
un-matched   0  0
matched but
different type 0  0
total        0  4
```

Probe files from /gaia/class/student/ /CPE151/LVS/schematic

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

Probe files from /gaia/class/student/ /CPE151/LVS/layout

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

# Inverter Post-Layout



## D-Type Flip Flop

Positive Clock Edge,  
Synchronous Reset

## D-Type Flip Flop Schematic



## D-Type Flip Flop Testbench



# D-Type Flip Flop Testbench Waveform

project2:dff\_tb:1 : project2 dff\_tb schematic

16:22:25 Wed Apr 11 2018



## D-Type Flip Flop Layout



## D-Type Flip Flop DRC

```
Validating hierarchy instantiation for:  
library: project2  
cell:    dff_layout  
view:    layout  
Rules come from library NCSU_TechLib_tsmc02d.  
Rules path is divaDRC.rul.  
Inclusion limit is set to 1000.  
Running layout DRC analysis  
Flat mode  
Full checking.  
DRC started.....Fri May  4 19:44:51 2018  
      completed ....Fri May  4 19:44:51 2018  
      CPU TIME = 00:00:00  TOTAL TIME = 00:00:00  
***** Summary of rule violations for cell "dff_layout layout" *****  
Total errors found: 0
```

## D-Type Flip Flop LVS

@(#) \$CDS: LVS version 6.1.7-64b 09/27/2016 19:41 (sjfhw305) \$

Command line: /software/cadence/install/IC617/tools.lnx86/dfII/bin/64bit/LVS -dir /gaia/class/student/ /CPE151/LVS -l -s -t /gaia/class/student/ /CPE151/LVS/layout  
/gaia/class/student/ /CPE151/LVS/schematic

Like matching is enabled.

Net swapping is enabled.

Using terminal names as correspondence points.

Compiling Diva LVS rules...

Net-list summary for /gaia/class/student/ /CPE151/LVS/layout/netlist

| count |           |
|-------|-----------|
| 18    | nets      |
| 0     | terminals |
| 13    | pmos      |
| 13    | nmos      |

Net-list summary for /gaia/class/student/ /CPE151/LVS/schematic/netlist

| count |           |
|-------|-----------|
| 18    | nets      |
| 6     | terminals |
| 13    | pmos      |
| 13    | nmos      |

Devices in the rules but not in the netlist:

cap nfet pfet nmos4 pmos4

The net-lists match.

|             | layout    | schematic |
|-------------|-----------|-----------|
|             | instances |           |
| un-matched  | 0         | 0         |
| rewired     | 0         | 0         |
| size errors | 0         | 0         |
| pruned      | 0         | 0         |
| active      | 26        | 26        |
| total       | 26        | 26        |

|            | nets |   |
|------------|------|---|
| un-matched | 0    | 0 |
| merged     | 0    | 0 |

|        |    |    |
|--------|----|----|
| pruned | 0  | 0  |
| active | 18 | 18 |
| total  | 18 | 18 |

|                |   |   |
|----------------|---|---|
| terminals      |   |   |
| un-matched     | 0 | 0 |
| matched but    |   |   |
| different type | 0 | 0 |
| total          | 0 | 6 |

Probe files from /gaia/class/student/ /CPE151/LVS/schematic

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

Probe files from /gaia/class/student/ /CPE151/LVS/layout

devbad.out:

netbad.out:

mergenet.out:

termbad.out:

prunenet.out:

prunedev.out:

audit.out:

# D-Type Flip Flop Post-Layout

project2:dff\_tb:1 : project2 dff\_tb schematic

16:37:32 Sun May 6 2018



**DC Response****Sun May 6 16:37:13 2018**

Name Vis

/Clk

④

/Reset

④

/D

④

/Q

④



## Conclusion

| <b>S. No.</b> | <b>Description</b>     | <b>Rise Time (μs)</b> | <b>Fall Time (μs)</b> | <b>Delay Time (μs)</b> |
|---------------|------------------------|-----------------------|-----------------------|------------------------|
| 1             | Inverter               | 0.000236              | 0.00018               | -0.000056              |
| 2             | 2-Input NAND Gate      | 0.0000681             | 0.00003662            | -0.00003148            |
| 3             | 2-Input NOR Gate       | 0.002172              | 0.000838              | -0.001334              |
| 4             | 2-Input AND            | 0.00004912            | 0.00002901            | -0.00002011            |
| 5             | D-Flip Flop            | 0.0001204             | 0.0001992             | 0.0000788              |
| 6             | Full Adder             | 0.00008112            | 0.0000397             | -0.00004142            |
| 7             | Bi-Directional Shifter | 0.0001178             | 0.0002017             | 0.0000839              |