Lab 6 - EE 421L
Authored
by Henry Chan,
chanh6@unlv.nevada.edu
20 October 2014
This lab is meant to design, layout, and simulate a CMOS NAND gate, XOR gate, and Full-Adder.
We
start by first creating the necessary schematics for the 2-input NAND
gate, and 2-input XOR gate using 6u/0.6u MOSFETs (both NMOS and PMOS).
2-Input NAND Gate
Schematic:
The
schematic was created using nmos4 and pmos4 instances from the
NCSU_Analog_Parts library. The lengths and widths of the mosfets were
adjusted and the connections were made as shown below.
data:image/s3,"s3://crabby-images/dfcc2/dfcc2765e9ff16f9752a45aeccd3999ba6a6a601" alt="images/nand2_schematic.JPG"
Symbol:
A symbol was created using Create->Cellview->From Cellview as shown below.
data:image/s3,"s3://crabby-images/6fadd/6faddc7fabd37d2742984190336d1e4a10cf24cf" alt="images/nand2_symbol.JPG"
Layout:
The
layout was created using nmos and pmos instances from the
NCSU_TechLib_ami06 library. Ntap and ptap cells were included to tie
Vdd and ground sources. Pins were then assigned to the appropriate
areas for a successful LVS.
data:image/s3,"s3://crabby-images/3a4f3/3a4f3ae25b06e247e43f9efd85f2e65f07adddf0" alt="images/nand2_layout.JPG"
data:image/s3,"s3://crabby-images/7e757/7e75724e3054b9cc971b4e5957b8313daabec452" alt="images/nand2_LVS.JPG"
2-Input XOR Gate
Schematic:
Again, instances of nmos4 and pmos4 from the NCSU_Analog_Parts library were used to create the xor schematic.
data:image/s3,"s3://crabby-images/e185e/e185e6f7588a9347657adb4d9a560958a77975f6" alt="images/xor_schematic.JPG"
Symbol:
The symbol for the xor gate was made using the same method for the nand gate.
data:image/s3,"s3://crabby-images/790c1/790c1febb36afea4dc206fbda04c0ffb3a2b5ac9" alt="images/xor_symbol.JPG"
Layout:
The layout used nmos and pmos instances from the NCSU_TechLib_ami06 library.
data:image/s3,"s3://crabby-images/2196c/2196cce706254063dd7316fd134217a42c4426e3" alt="images/xor_layout.JPG"
LVS shows net lists match with no errors.
data:image/s3,"s3://crabby-images/8c7b2/8c7b21f9c43d27844a80e2a894b98a9b399a3b96" alt="images/xor_LVS.JPG"
Simulating the Gates
Spectre was used to simulate the logical operation of the gates for all four possible inputs (00,01,10,11).
data:image/s3,"s3://crabby-images/9898a/9898a12d2e0376fffea89bc712478ae604ab4314" alt="images/sim_gates_schematic.JPG"
The plot below shows the correct output logic.
A | B | AND | XOR | NOT A |
0 | 0 | 0 | 0 | 1 |
0 | 1 | 0 | 1 | 1 |
1 | 0 | 0 | 1 | 0 |
1 | 1 | 1 | 0 | 0 |
data:image/s3,"s3://crabby-images/a399b/a399b3e22f4c51b6432d4d8b7d0b133d166e2c6e" alt="images/sim_gates_simulation.JPG"
It
is important to note that any delays from one input of the circuit can
drastically affect the output results due to unsynchronized operation
of the inputs. For example, if input A must traverse through a greater
length mosfet than input B, input A may experience more delay, thus the
output may incorrectly evaluate the state of input B versus an
unarrived input A.
Full-Adder
Schematic:
Using the symbols from the nand and xor gates, the full-adder schematic is created.
data:image/s3,"s3://crabby-images/ea5f6/ea5f672897d7401d3c3d9e2f3bb3b2fd2316bce6" alt="images/full_adder_schematic.JPG"
Symbol:
The symbol view was created similar to the other symbols in this lab.
data:image/s3,"s3://crabby-images/47e32/47e323548ca04c3d6e5722abfc66d01ac88dd1a6" alt="images/full_adder_symbol.JPG"
Simulation:
A
simulation schematic was created using the full-adder symbol above.
Three voltage pulse sources were used as inputs a,b, and cin. Each
pulse source has a different frequency in order to demonstrate all
input possibilities.
data:image/s3,"s3://crabby-images/f82b8/f82b8e9ead6ea4c77ca1e27f682cd0da4481110f" alt="images/sim_full_adder_schematic.JPG"
a | b | cin | s | cout |
0 | 0 | 0 | 0 | 0 |
1 | 0 | 0 | 1 | 0 |
0 | 1 | 0 | 1 | 0 |
1 | 1 | 0 | 0 | 1 |
0 | 0 | 1 | 1 | 0 |
1 | 0 | 1 | 0 | 1 |
0 | 1 | 1 | 0 | 1 |
1 | 1 | 1 | 1 | 1 |
The simulation output shows the correct operation.
data:image/s3,"s3://crabby-images/705d3/705d37c77feb785e896d889973a0eb3b720643de" alt="images/sim_full_adder_plot.JPG"
Layout:
The layout of the full-adder was created using instances of the nand and xor layouts made previously in this lab.
data:image/s3,"s3://crabby-images/c702d/c702db3ea91365d851d522020995117350c283fe" alt="images/full_adder_layout.JPG"
LVS shows matching netlists and no errors.
data:image/s3,"s3://crabby-images/1cff5/1cff526bdeca8432fe86b697f2eacc8ea085a51d" alt="images/full_adder_LVS.JPG"
This concludes the lab, all files from this lab can be found here.
Backups of this lab were stored in a cloud service.
data:image/s3,"s3://crabby-images/d51a2/d51a2239a64bd973e018ef43c36919ae75bfaee8" alt="images/backup1.JPG"
data:image/s3,"s3://crabby-images/3b019/3b0192bb0c1c0d749caa0f5e7f00f2863542cce5" alt="images/backup2.JPG"
Return to EE 421 Labs