Lab 07 - EE 421L
Authored
by Matthew Parker
parke179@unlv.nevada.edu
October 26th, 2014
Lab
description: The goal of this lab is to create all the components needed to make an 8-bit full adder.
The library for this Lab07 can be downloaded from the zip file located in this directory
http://cmosedu.com/jbaker/courses/ee421L/f14/students/parke179/Lab07/other/
Direct download link
Part I: Using busses to make multi-bit gates
Tutorial
5 covers how to make a ring oscillator using busses. Figure 1 shows the
schematic of a ring oscillator and figure 2 shows the simulation
results.
Figure 1: Ring Oscillator
data:image/s3,"s3://crabby-images/1ea43/1ea4319d490efb57d18e1b7584fd4eaaebb0e377" alt=""
Figure 2: Ring oscillator simulation
data:image/s3,"s3://crabby-images/67e19/67e19db3158a03e9bc5e163f67348868453c80b8" alt=""
Making an 8-bit inverter uses busses in a similar way, except they are in parallel instead of in series like a ring oscillator.
data:image/s3,"s3://crabby-images/edfd4/edfd41e043ef9d059043bfe8003e7757ef7e4cac" alt=""
data:image/s3,"s3://crabby-images/03034/0303477b3c775cd46d625e1ac47128ce9982d9e4" alt=""
The
simulation of the 8-bot inverter will use capacitors to show that the
output has a rise time when attached to a capacitive load.
data:image/s3,"s3://crabby-images/775ce/775cea2b6ea6dfb44a80408db7eb94c26d25171c" alt=""
data:image/s3,"s3://crabby-images/3cdaf/3cdafb237262de3c033f1dacfd91720333443fdc" alt=""
There are two types of delay, Tplh for propagation low to high, and Tphl for high to low.
Tplh = 0.7Rp(Cout + Cload)
Tphl = 0.7Rn(Cout + Cload)
Where:
Rn = R'n L/W = 15k/10 = 1.5k
Rp = R'p L/W = 45k/10 = 4.5k
Cout = C'ox (WnLn + WpLp) = 2.5fF(10+10) = 50f
For large values of Cload (100pF or more), the value of Cout is insignificant and the delay equals:
Tplh = 0.7(1.5k)Cload = 105ns for 100pF
Tphl = 0.7(4.5k)Cload = 315ns for 100pF
At 1pF (output Ai<4>),
Tplh = 0.7(1.5k)(1.05p) = 1.1025ns
Tphl = 0.7(4.5k)(1.05p) = 3.3075ns
At 100fF (output Ai<3>),
Tplh = 0.7(1.5k)(150f) = 0.1575ns
Tphl = 0.7(4.5k)(150f) = 0.4725ns
At 500fF,
Tplh = 0.7(1.5k)(550f) = 0.5775ns
Tphl = 0.7(4.5k)(550f) = 1.7325ns
After
simulating the 8-bit inverters, I repeated the simple steps to make an
8-bit version of a NAND, AND, NOR, OR, and XOR gate.
The AND/OR gates are simply a NAND/NOR gate with an inverter at the end.
data:image/s3,"s3://crabby-images/fcad0/fcad05cfd5c974cab73d19649f6b6a173bc05ac1" alt=""
All
of the inputs will be tied together, so the simulation will only show a
single output for each 8-bit gate, since they are all identical.
data:image/s3,"s3://crabby-images/3fcfd/3fcfd95c8a7ebcab37edb26740b7e7da81a0d2bf" alt=""
Part II: Making an 8-bit 2-to-1 MUX/DEMUX
Figure 10 shows the schematic of a 2-to-1 multiplexer.
data:image/s3,"s3://crabby-images/e5d2c/e5d2caeab8c607909c5d222b87e1277523cd7a4e" alt=""
data:image/s3,"s3://crabby-images/b5891/b589192620794710e9c4dafb31e092754cd0751e" alt=""
The circuit can be used as a MUX or DEMUX. Figure 12 shows the configuration for MUX mode.
A and B are inputs, while Z is the output.
Figure 12: 2-to-1 MUX
data:image/s3,"s3://crabby-images/b1eff/b1effad0da951b76e07f00e08a8e50509f1df5c0" alt=""
data:image/s3,"s3://crabby-images/b4f72/b4f7249dce20bf6393d1bbbb2c346be452344c2a" alt=""
After verifying it works as a 1-bit circuit, I used the same process as earlier to make it an 8-bit MUX.
Figure 14 shows the 8-bit 2-to-1 MUX with A and B as inputs and Z as output.
Figure 14: 8-bit 2-to-1 MUX
data:image/s3,"s3://crabby-images/9717b/9717b385f19df9954be8c812f994c5226719ff90" alt=""
Only a single output is shown since they are all identical when the inputs are equal.
data:image/s3,"s3://crabby-images/9c5ac/9c5ac23e7bbe509f5520b2cce91e66371dec03df" alt=""
Another use of the MUX is as a DEMUX.
Figure 16 shows the DEMUX configuration where Z is the input and A and B are the outputs.
Figure 16: 8-bit 1-to-2 DEMUX
data:image/s3,"s3://crabby-images/87b6a/87b6a4c26a44989444c6a33083895a681be30a79" alt=""
Figure 17 shows the output in DEMUX mode. Z is the input while A and B are outputs.
Figure 17: DEMUX simulation
data:image/s3,"s3://crabby-images/eefbb/eefbbcce80c7eb0ebcd988580e14b06bc122fad1" alt=""
Part III: Making an 8-bit Full Adder
The final component of an ALU is the full adder. A single full adder is cascaded to make an 8-bit full adder.
data:image/s3,"s3://crabby-images/23afa/23afad941d5b12748745e41af436f10b2eb2ee31" alt=""
data:image/s3,"s3://crabby-images/12cdf/12cdf458cff53eeb01b0cf3f45c826981021554c" alt=""
Figure 20 shows the left-most full adder in the layout of the entire 8-bit full adder.
The Cin<0> of the first FA is the only Cin that does not come from a previous FA.
The metal-2 recangles uses for A, B, Cin<1:7>, and Cout are copies along with the FA in an array of 8 collumns.
Figure 20: 8-bit FA left
data:image/s3,"s3://crabby-images/34f6f/34f6fb015eb69c90df321ffd1de388fff0f72c8e" alt=""
The only other special FA is the last FA, which has the final output pin Cout<7>.
Figure 21: 8-bit FA right
data:image/s3,"s3://crabby-images/18d1d/18d1da0bd6b1d64b7edef8079f56f0bd68555da5" alt=""
Figure 22: 9-bit FA layout
data:image/s3,"s3://crabby-images/029a9/029a9709b15193791c6f2a4c2f88e3c7fd54ab37" alt=""
An LVS is ran and succeeds.
data:image/s3,"s3://crabby-images/efb75/efb754d9ec09a3538550a000bcef93c53cb37ab4" alt=""
To test the 8-bit FA, the inputs A<7:0> and B<7:0> vary slightly and Cin<0> is a simple pulse.
data:image/s3,"s3://crabby-images/4d5dc/4d5dc8c4a1ce80b80a6d3399285e3e794f536caa" alt=""
Figure 25: 8-bit FA sim
data:image/s3,"s3://crabby-images/0c507/0c50787c06d1bb62fcc18b38f0df819e0c843686" alt=""
Figure 25 shows the simulation of the 8-bit FA.
Inputs A<0> to A<6> are all the same pulse voltage, and A<7> is a pulse with double the period of the others.
B<0> is a pulse function with the same period as A<7>, and B<7:1> are all a constant 0 volts.
There are glitches in the FA's output whenever A<6:0> transition, but they last less than a nano second.
Table 1 summarizes some of the results from the simulation in figure 25.
Table 1: Results of 8-bit FA sim
|
0-25ns
|
25-50ns
|
50-75ns
|
...
|
250-275ns
|
275-300ns
|
Input A
|
11111111
|
10000000
|
01111111
|
...
|
01111111
|
00000000
|
Input B
|
00000001
|
00000001
|
00000000
|
...
|
00000000
|
00000000
|
Input Cin
|
1
|
1
|
1
|
...
|
0
|
0
|
|
|
|
|
|
|
|
Output S
|
00000001
|
10000010
|
10000000
|
...
|
01111111
|
00000000
|
Output Cout
|
1
|
0
|
0
|
...
|
0
|
0
|
Creating backups
I
use dropbox to backup all screenshots, project files, and html files. I
do so by using the dropbox folder as my active work area to save to,
and then dropbox automatically uploads changes to the files.
data:image/s3,"s3://crabby-images/b99fb/b99fb9bc05840684944704ce06d80e468984cd90" alt=""
The library for this Lab07 can be downloaded from the zip file located in this directory
http://cmosedu.com/jbaker/courses/ee421L/f14/students/parke179/Lab07/other/
Direct download link