Lab 6 - ECE 421L
Authored
by Michael Villalba
villalb5@unlv.nevada.edu
1008445138,
10/20/2014
Design, Layout, and Simulatation of a CMOS NAND gate, XOR gate, and Full-Adder.
First
thing we are going to do is use the inverter that was created in Lab 5.
Also from Tutorial_4 we drafted a chematic of a NAND gate.
data:image/s3,"s3://crabby-images/f8bf4/f8bf41e6468e401a36f1d1b6cfd979bc187f3751" alt="nand_schm.png"
data:image/s3,"s3://crabby-images/a3194/a31946c72a738f676953aa820477a3a1003bf265" alt="nand_sym.png"
Then we have to ceate a Layout for the NAND gate
data:image/s3,"s3://crabby-images/0aea1/0aea11994b89e9a9efe9e9f5d0c155282ecb065e" alt="nand_layout.png"
Then we have to extract the layout and perform an LVS to make sure they match
data:image/s3,"s3://crabby-images/90a8a/90a8ab64c3f8cdf6de3e3e991cab220d3a31d9dc" alt="nand_extract.png"
data:image/s3,"s3://crabby-images/738eb/738eba6902417062b328b82174efe6ed4b22a3c4" alt="nand_LVS.png"
data:image/s3,"s3://crabby-images/3945d/3945dc3b7a2feb73d664bf770f9fef723defa597" alt="nand_output.png"
Then we have to create a schematic, symbol and layout for a XOR gate with 6u/0.6u MOSFET
data:image/s3,"s3://crabby-images/4ff8d/4ff8da07415b2f73354058f5a6e92ddecbbef5c5" alt="xor_schm.png"
data:image/s3,"s3://crabby-images/bf0ca/bf0caad4ae0da4fb62026119a77d53fee21178d6" alt="xor_sym.png"
Same
as the NAND gate we need to create a layout and extract the layer then
LVS to make sure it matches the schematic. This layout is more complex
than the NAND gate we created previously.
data:image/s3,"s3://crabby-images/9c6b9/9c6b99f61b5fcbaa1e7810aa97e53829126d799b" alt="xor_layout.png"
data:image/s3,"s3://crabby-images/2c772/2c772bcd59a56121d3b0ad11b536e7c19f71ceea" alt="xor_extract.png"
data:image/s3,"s3://crabby-images/d29b8/d29b8064a1ecbefe3ed9d7533b638bc60e545b94" alt="xor_LVS.png"
data:image/s3,"s3://crabby-images/20e91/20e9116d938d5383266dceb606c9270656f1f1b6" alt="xor_output.png"
We
are now going to simulate all the gates we created to make sure they
work. the schematic used to simulate them can be seen below. We use
pulse A and pulse, B whos frequency is twice as fast as A to simulate
inputs 00,01,10,11
data:image/s3,"s3://crabby-images/0db6f/0db6fa31a33e023ee21db8e9f154b5bfea9e2784" alt="sim_gates_schm.png"
data:image/s3,"s3://crabby-images/54edc/54edca0ffedbd1b0a14186f6673c791b928915f6" alt="sim_gates_spec.png"
It
is important to realize there is a rise time and a fall time in this
switching between signals. If we look at around the 200 ns mark we can
see a glitch, that is because the numbers are in transition from 01 to
10 but what in between that time the computer is only reading 00,
so 0 or 0 is zero as seen in this glitch.
First thing to do is to create a schematic of the full-adder and then the symbol.
data:image/s3,"s3://crabby-images/7bcd3/7bcd35e9689498099bde77befe6bcaff24797aec" alt="fa_schm.png"
data:image/s3,"s3://crabby-images/5f1a1/5f1a1b436d16551a3a4e146196654436daf3bffe" alt="fa_sym.2.png"
After
creating the schematic and symbol for the full-adder we then have to
create a layout, extract the layout and then LVS the schematic and
extract to make sure they match.
data:image/s3,"s3://crabby-images/a6167/a6167ea96dc194b5685490c5621505bbd94d54e0" alt="fa_layout.png"
data:image/s3,"s3://crabby-images/8e887/8e887f18aab14a3b1cd839c8a48b6f08bfff459b" alt="fa_extract.png"
data:image/s3,"s3://crabby-images/11c4d/11c4d6301ddcbb0d8fa2a678a18858c55f0a3432" alt="fa_LVS.png"
data:image/s3,"s3://crabby-images/f2c72/f2c72ad4986e1acf1692f26765d5b6b418044285" alt="fa_output.png"
Last thing we have to do is simulate the full adder to make sure its complete.
data:image/s3,"s3://crabby-images/27087/27087b8bd0e58b799733277e513078163f9d525f" alt="sim_fa_schm.png"
data:image/s3,"s3://crabby-images/96f57/96f57bf69fc86c9365107d3ab7971a1cac2318f2" alt="output_sim_fa.png"
Here is proof of me backing up my work
data:image/s3,"s3://crabby-images/29088/2908880ae08082a6e23bfe7ab8655745ebf60041" alt="backup.png"
lab6 can be downloaded here
Return to Michael's Labs