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/e0e0e/e0e0ef3eac5bbf748cb7e06fba8a44f4c909a4f0" alt=""
Figure 2: Ring oscillator simulation
data:image/s3,"s3://crabby-images/d752e/d752e23e83fc24dc06d9c1f1c4212286ba3a305e" 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/97ace/97ace5151922cd98d24982f5d03db811009aaabf" alt=""
data:image/s3,"s3://crabby-images/636db/636db7c5eccd3f6eb6e9790a2659b5939220a258" 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/22764/227644adaca193da5f903c30768348fc24e5422a" alt=""
data:image/s3,"s3://crabby-images/76850/7685022c3a517837dbb0c51958548778ec8257db" 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/e7a3d/e7a3d1747b7068f2fc521bdb310e83be72516e2d" 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/9f265/9f2651154f28e70679819d0c6ea3494dd9e28cb9" 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/c3877/c3877c5df615a4a0fd560e592d437fab18d83e04" alt=""
data:image/s3,"s3://crabby-images/26069/260694f4c6df9e811c47c934605025a41497be21" 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/fe25f/fe25fea8b7b86d1f7766e788c72ede89c26f0905" alt=""
data:image/s3,"s3://crabby-images/d8013/d80135749a560881f8f97653e204ac613f245f5d" 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/73459/73459b24623c18bc3fa1e23a54e19a40e356e6b3" alt=""
Only a single output is shown since they are all identical when the inputs are equal.
data:image/s3,"s3://crabby-images/02df3/02df3605a10071bda85a4d77594e0a16d9929b56" 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/82ec8/82ec8339635cdcc4ed722f63c2f5993d6f429fe0" 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/3c7a4/3c7a4bcb605dd16dd79652a7d2151a4f35da3cb0" 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/ff5bb/ff5bbfcf0cae010bffb0d327557351b24d76b849" alt=""
data:image/s3,"s3://crabby-images/c57dd/c57dd27f4cd6a103e16275f135608da9732abbed" 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/9501f/9501fbad45e3c2c68c4382dd6743ceb46c7e98e4" 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/c9ceb/c9ceb075eda926d1307bc8aa1a9e42af901bacc2" alt=""
Figure 22: 9-bit FA layout
data:image/s3,"s3://crabby-images/44c36/44c3652e831bda2169ddf1315136fda44b628c64" alt=""
An LVS is ran and succeeds.
data:image/s3,"s3://crabby-images/dc01f/dc01f04a20f75fe734be5950e118f18f3f349a9f" 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/30e33/30e33e11bcd9a1926d9085af6a8c31683e84cc88" alt=""
Figure 25: 8-bit FA sim
data:image/s3,"s3://crabby-images/15be2/15be28ad240b56396a4391a1dba24e3a4996c582" 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/72823/728236c4c69558071d6edd84f687e1aa814215a6" 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