Lab 6 -
EE 421L
Authored
by Reiner Dizon,
Email: dizonr1@unlv.nevada.edu
Today's
date is October 18, 2017
Lab
description: This
lab is about designing and laying out CMOS NAND and XOR gates which will be used to create a full adder circuit.
PRELAB
- Back-up all of my work from the lab and the course
Lab Backup:
data:image/s3,"s3://crabby-images/f09d9/f09d99631980bc74b855edabdf1c9abad04a655b" alt="Click for image prelab/prelab_1_backup_lab.PNG" | Course Backup:
data:image/s3,"s3://crabby-images/10b98/10b984a5d70c1c2db0fbc1ad09b91f26169d7e66" alt="Click for image prelab/prelab_2_backup_class.PNG"
|
Tutorial
4 talks about design process of a NAND gate using n and p type MOSFETs.
Here are the schematic and symbol created which will be used for LVS later:
Schematic:
data:image/s3,"s3://crabby-images/ffeb6/ffeb670bd0e932307f5a20b747399bdfcbac65d5" alt="Click for image prelab/prelab_3_sch.PNG"
| Symbol:
data:image/s3,"s3://crabby-images/4e3e5/4e3e5ff689c5c2565d64e55c39eee81fcffb5d79" alt="Click for image prelab/prelab_4_symbol.PNGprelab/prelab_4_symbol.PNG"
|
After creating the NAND gate symbol,
I laid out the logic gate design and DRCed it. Since the
schematic and layout were already created, I performed LVS afterwards to
confirm if the netlists matched.
Finally,
I ran the
simulation on both the schematic and the layout, and the simulations
were identical. For the simulating the NAND gate schematic, I created a
simulation schematic with power and ground.
Simulation Schematic:
data:image/s3,"s3://crabby-images/460c7/460c7443d6523795c8f93b4932fcc30687510ae4" alt="Click for image prelab/prelab_8_sim_sch.PNG"
| Simulation Results:
data:image/s3,"s3://crabby-images/1d0b5/1d0b598dae4f5d0c760a04c6b230d531aafaab3f" alt="Click for image prelab/prelab_9_sim_wave.PNG"
|
- Read through the lab before starting
LAB
REPORT
1) Create schematic, symbol, and layout for 2-input NAND gate using 6u/0.6u (W/L ratio) MOSFETs
The
schematic and symbol for the 2-input NAND gate use those from Tutorial 4
(prelab). Since my design uses the ones from the prelab, I made a copy of that cell
view in order to make changes to them according to the lab
instruction. I added my initials "RD" in the center of the NAND gate to differentiate mine. Here are my schematic and symbol for the NAND gate.
Schematic:
data:image/s3,"s3://crabby-images/97709/977090cf857990df40042a5c1826f5201ab5dda8" alt="Click for image postlab/postlab_nand_1_sch.PNG"
| Symbol:
data:image/s3,"s3://crabby-images/23eac/23eac694bed4400e48e7327255ac622018352622" alt="Click for image postlab/postlab_nand_2_symbol.PNGpostlab/postlab_nand_2_symbol.PNG"
|
Before laying out this schematic, I made a standard cell frame for
all the gates in this lab. This cell allows me to easily wire power and
ground in the same places for all the gates, which helps make my
designs consistent. Since the MOSFETs in this lab have the W/L ratio of
6u/0.6u, I made frame size a bit larger than these dimensions to allow
for more space while wiring up multiple gates.
Since
the prelab used 12u/0.6u PMOS for the NAND gate, this does not match
the schematic given above. Therefore, I modified the layout to match
the ratio of 6u/0.6u for the PMOS transistor. Instead of simply
modifying the layout, I inserted my standard frame cell and moved
everything over to that cell. Since it had more space than the one from
the tutorial, I spread out the components within the frame. Afterwards,
I performed the DRC for the design. Here are my layout and DRC results:
Layout:
data:image/s3,"s3://crabby-images/e381c/e381c39030f85ea7a99306be34e03563cd4689c2" alt="Click for image postlab/postlab_nand_3_layout.PNG"
| DRC Results:
data:image/s3,"s3://crabby-images/aa123/aa123bfd220a872b8122da8090a28c0b4d7465f4" alt="Click for image postlab/postlab_nand_4_drc.PNG"
|
After
checking the layout for errors, I extracted the layout for the LVS tool
which will check it against the NAND gate schematic. Here are the extracted layout and the corresponding LVS results:
Extracted:
data:image/s3,"s3://crabby-images/91872/9187229fc6445d16044a32e56dad109e182ce49c" alt="Click for image postlab/postlab_nand_5_extracted.PNGpostlab/postlab_nand_5_extracted.PNG"
| LVS Results:
data:image/s3,"s3://crabby-images/726f7/726f76910fba7259a80bb3892de50c00d18c47dc" alt="Click for image postlab/postlab_nand_6_lvs.PNG"
|
2) Create schematic, symbol, and layout for 2-input XOR gate using 6u/0.6u (W/L ratio) MOSFETs
For
the 2-input XOR gate, I had to make the schematic almost from scratch.
However, I copied some of my previous circuit onto this schematic (i.e.
inverter and NAND) and modified them according to the schematic given
in the lab instruction. The symbol, on the other hand, was created from
scratch. Just like the NAND gate symbol, I added my initials on it. Here are my schematic and symbol for the XOR gate.
Schematic:
data:image/s3,"s3://crabby-images/95e01/95e016418c553615e9522f6abfee2809e4c4cd37" alt="Click for image postlab/postlab_xor_1_sch.PNG"
| Symbol:
data:image/s3,"s3://crabby-images/cffce/cffce661a26837b336ee789eb64c96d05c68fb22" alt="Click for image postlab/postlab_xor_2_symbol.PNG"
|
As done with the NAND gate layout, I used the standard cell frame as
the foundation of my layout. According to the schematic above, there
are four sets of NMOS/PMOS pairs (some with multipliers) that needs to
be laid out for the XOR gate, so I instantiated four standard frames.
As with these frames, I immediately connected all powers and grounds
accordingly. Moreover, since the are many metal1 connections in the
layout, I had to use metal2 to avoid crossing metal1 connections with other metal1's which would alter the design. Here are my layout and its DRC results:
Layout:
data:image/s3,"s3://crabby-images/f99d0/f99d0a63f08613119497211b3a8abf1e991f5c4e" alt="Click for image postlab/postlab_xor_3_layout.PNG"
DRC Results:
data:image/s3,"s3://crabby-images/1b9ca/1b9ca35828ff7af30c63bc9ce501415be626f987" alt="Click for image postlab/postlab_xor_4_drc.PNG"
After
checking the layout for errors, I extracted the layout for the LVS tool
which will check it against the XOR gate schematic. Here are the extracted layout and the corresponding LVS results:
Extracted:
data:image/s3,"s3://crabby-images/fdfa8/fdfa8c34791fdb0aa1481fced224be59bf1c76fd" alt="Click for image postlab/postlab_xor_5_extracted.PNG"
LVS Results:
data:image/s3,"s3://crabby-images/a1abe/a1abeb3ca8e329992bc6ebb953f974a0140a280f" alt="Click for image postlab/postlab_xor_6_lvs.PNG"
3) Logic gates simulation
Before simulation, I created a simple simulation schematic that contains all of the logic gates that I have created so far. Using
the Spectre tool in ADE, I simulated the logic gate (i.e. 12u/6u
inverter, NAND, XOR) operations for all possible 2-bit inputs on both
the schematics and the layouts. Here are my simulation schematic and results:
Schematic:
data:image/s3,"s3://crabby-images/8cdce/8cdce5831c1f5200c6f5ce9fc71f8a275d71d253" alt="Click for image postlab/postlab_sim_1_sch.PNG"
| Schematic Simulation:
data:image/s3,"s3://crabby-images/30a6b/30a6bd71b8cad92f13c83fc2bffb2e6a8dbb31d7" alt="Click for image postlab/postlab_sim_2_wave_sch.PNG"
|
Layout Simulation:
data:image/s3,"s3://crabby-images/ccb08/ccb08b6777f6aeef3580c4c7f3579028b23698c6" alt="Click for image postlab/postlab_sim_3_wave_ext.PNG"
| Netlist Display (Proof):
data:image/s3,"s3://crabby-images/d432c/d432c65bb0d1279f65d9572530c1538cf5564e1a" alt="Click for imagepostlab/postlab_sim_4_extracted_proof.PNG postlab/postlab_sim_4_extracted_proof.PNG"
|
Comment about glitching:
From
the above simulations, the transition between the input "01" and "10"
causes a glitch at the XOR output. Because both inputs are changing
voltage levels simultaneously, the rise and fall time (or transition
time) when these voltages are changing affects the output at the XOR
gate for that moment until it produces the proper output. Shrinking
this time will reduce or even eliminate this glitch.
4) Draft a full adder schematic and symbol
For
the full adder schematic, I used the NAND and XOR gates symbols from
previous parts of this lab to create my full adder schematic. It has
three inputs: a, b, & cin. Also, it has two outputs: sum &
cout. I also made the corresponding symbol. Here are my schematic and symbol for the full adder.
Schematic:
data:image/s3,"s3://crabby-images/47cfc/47cfc25009f1e4912692d0be19f01cfc1babc602" alt="Click for image postlab/postlab_full_adder_1_sch.PNG"
| Symbol:
data:image/s3,"s3://crabby-images/286b9/286b99a8e7d0e1d6aa1fe1402358cc8288bb1b54" alt="Click for image postlab/postlab_full_adder_2_symbol.PNG"
|
5) Full adder layout
As
done with the full adder schematic, I imported the layouts for each
gate (3 NAND and 2 XOR) and placed them side-by-side, so I can connect
all power and ground connections. I used metal1 pins for inputs and
outputs of the full adder. I mostly used metal2 to connect between gate
pins, along with m2_m1 layouts. Here are my layout and its DRC results:
Layout:
data:image/s3,"s3://crabby-images/883fc/883fcaeb007e374b0d64bc36974240c052723fa0" alt="Click for image postlab/postlab_full_adder_3_layout.PNGpostlab/postlab_full_adder_3_layout.PNG"
DRC Results:
data:image/s3,"s3://crabby-images/14560/145602d102ecfae355452dd50b8d303d255a52d2" alt="Click for image postlab/postlab_full_adder_4_drc.PNG"
After DRCing, I extracted the layout and performed LVS
which will check it against the full adder schematic. Here are the extracted layout and the corresponding LVS results:
Extracted:
data:image/s3,"s3://crabby-images/bb7e2/bb7e2e997ed4125f0fb77d96b103394b49e22a7b" alt="Click for image postlab/postlab_full_adder_5_extracted.PNG"
LVS Results:
data:image/s3,"s3://crabby-images/6fca4/6fca4be9170f6db64a6a1bb65c2529b215e210c6" alt="Click for image postlab/postlab_full_adder_6_lvs.PNG"
6) Full adder simulation
Before simulating the full adder schematic and layouts, I created a simulation schematic. Using
the Spectre tool in ADE, I simulated the full adder operation for all
possible 3-bit inputs on both the schematics and the layouts. Here are
my simulation schematic and results:
Schematic:
data:image/s3,"s3://crabby-images/4b62a/4b62a256a84f43539e973c01bbbe585ed152db1a" alt="Click for image postlab/postlab_full_adder_sim_1_sch.PNG"
Schematic Simulation:
data:image/s3,"s3://crabby-images/95030/950308134ea1f42e337d86b9fa935bfca5e53aea" alt="Click for image postlab/postlab_full_adder_sim_2_wave_sch.PNG"
Layout Simulation:
data:image/s3,"s3://crabby-images/9e404/9e404f3e5db71fbf33ce10b619f9f96c5f5b39d2" alt="Click for image postlab/postlab_full_adder_sim_3_wave_ext.PNG"
Netlist Display (Proof):
data:image/s3,"s3://crabby-images/ddfb2/ddfb2d4ae5a19c401ce6fd5478643fce479f4398" alt="Click for image postlab/postlab_full_adder_sim_4_extracted_proof.PNG"
After finishing the lab, I backed up my lab 6 web directory from CMOSedu and library from the cluster:
data:image/s3,"s3://crabby-images/6590d/6590d5f6b3b1557aac1ec86fa126e18d2b1e9fb0" alt="Click for image postlab/postlab_backup.PNG"
Return
to Reiner's Labs
Return
to EE 421L Labs