Lab
Project
Design
a circuit that takes a serial input and detects
the sequence 101011
Download
project library (labProj.zip) here
Authored
by Tyler Huddleston, huddle10@unlv.nevada.edu
11/30/2016
Part 1: 101011 Sequence Detector
schematic and simulations
Schematic |
data:image/s3,"s3://crabby-images/3982c/3982c2d81b0c085295b6a6398377bece3e61dc00" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/detectorCaptures/detector_schematic.JPG"
|
Topology:
- The sequence
detector has 3 pins:
- in (input) -
sequential logic signal input into detector
- clk (input) -
clock signal
- out (output) -
logic value that outputs HIGH if the sequence has been detected and LOW
otherwise
- It consists of
6 D flip-flops, a 6-input NAND gate, and an inverter:
- D flip-flops:
store and output a bit for one clock cycle
- output Q or
Q_N to NAND gate depending on which bit is required at the D flip-flop
to
detect the sequence
- 6-input NAND
gate outputs LOW if the Q or Q_N values at its inputs are all HIGH, and
out goes HIGH after inverter
- NAND gate and
inverter were chosen over an AND gate, because the AND gate is a NAND
gate with an inverter and if the AND were to be used in a NAND
operation another inverter would have to be added to it - that is, to
achieve an AND operation with a NAND and inverter requires less
components than achieving a NAND operation with an AND and an inverter
|
Operation:
- Sequential
input into 'in' is propagated through the D flip-flops
- To detect
101011, the D flip-flops are arranged in reverse order, such that the
least significant bit of the sequence is at the end of the register -
that is, the least significant bit is detected by the right-most D
flip-flop
- If the D
flip-flop of the register is to detect a 1 in the sequence, its Q
output is sent to the NAND gate
- If the D
flip-flop of the register is to detect a 0 in the sequence, its Q_N
output is sent to the NAND gate
- The NAND and
inverter operate as an AND gate, such that when all of its inputs are
HIGH, the output, 'out', is HIGH, indicating that the sequence has been
detected
|
Simulation
Simulation
Schematic
data:image/s3,"s3://crabby-images/4ba63/4ba63787ea09529259d1b62992cc85b6c8f438a0" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/detectorCaptures/detector_simSchematic.JPG"
- A piecewise
function of various logic levels and a 50ns period clock signal are
input to the detector circuit
|
Simulation
Results
data:image/s3,"s3://crabby-images/afeb9/afeb9f14237992c83f7041abfb01c46b7ff5a1e6" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/detectorCaptures/detector_sim.JPG"
- Operation of
the detector works as expected:
- it is LOW when
101011 has not been input to the register
- it is HIGH
when 101011 has been input to the register
|
Sequence Detector Modules:
D
Flip-Flop
Schematic
data:image/s3,"s3://crabby-images/5d21c/5d21cc875afd142709962c0eeed90f004430d7f1" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/detectorCaptures/D_FF_schematic.JPG" |
Simulation
schematic
data:image/s3,"s3://crabby-images/41391/413918492c080a46640e7cfc7937f6a7f2081826" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/detectorCaptures/D_FF_simSchematic.JPG" |
Simulation
results
data:image/s3,"s3://crabby-images/befb5/befb5477d035eff81dc4d3b398b5597b2737bd07" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/detectorCaptures/D_FF_sim.JPG" |
6
input NAND
Schematic
data:image/s3,"s3://crabby-images/d866e/d866e90d09a34910feaf916b734b57823998f444" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/detectorCaptures/nand6_schematic.JPG" |
Simulation
schematic
data:image/s3,"s3://crabby-images/bf72c/bf72c802b3749ed5942f1b32bbbe2cb5005c2b37" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/detectorCaptures/nand6_simSchematic.JPG" |
Simulation
results
data:image/s3,"s3://crabby-images/b2942/b2942395dbad1451af078510809276b37d742d77" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/detectorCaptures/nand6_sim.JPG" |
Part 2: layout detector circuit
Layout
of detector circuit:
data:image/s3,"s3://crabby-images/107e7/107e72bb968b972b50ca311cd5fb30d7ec5edb3b" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/layoutCaptures/detector_layout.JPG"
- 6 D flip-flops
are arranged in two rows for compact design
- one large
n-well fills the center of the layout with one large ntap vdd rail
shared by all of the PMOSs
- two large ptap
ground rails run along the top and bottom and are shared by the NMOSs
- each D
flip-flop is cascaded with its Q output connected to the D input of the
next D flip-flop
- the Q or Q_N
output connected to the 6-input NAND gate on the bottom right
- the NAND gate
is output to the inverter at the top right
Close up of
first D flip-flop (most significant bit)
data:image/s3,"s3://crabby-images/4fa92/4fa92889ceb200bb90d2d5a6090331892401448c" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/layoutCaptures/detector_layout_cu1.JPG" |
- in and clk are
connected on metal3
- vdd and ground
are connected on metal1
|
Close
up of NAND gate connectins and 3rd D flip-flopdata:image/s3,"s3://crabby-images/8997e/8997e2ac500bbe1466666171afba462d2020681d" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/layoutCaptures/detector_layout_cu2.JPG" |
- the Q and Q_N
outputs of each D flip-flop connec to the input of the 6-input NAND gate
|
Close
up of inverter and 4th D flip-flopdata:image/s3,"s3://crabby-images/df156/df156a5225a2725dcce861a6efdb5665bccce6b1" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/layoutCaptures/detector_layout_cu3.JPG" |
- the output
from the NAND gate is input to the inverter (metal1 route left of the
inverter) with the out pin on metal3
|
DRCs
data:image/s3,"s3://crabby-images/282bd/282bd9d655ecdcf65d4da58911359ba5adfd509b" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/layoutCaptures/detector_DRC.JPG" |
LVSs
data:image/s3,"s3://crabby-images/d9ed5/d9ed5008d061144613f71930edd52b12d83cd74f" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/layoutCaptures/detector_LVS.JPG" |
Verifying
the operation of extracted layout:
Extracted
layout simulation matches schematic simulation
data:image/s3,"s3://crabby-images/68236/68236af0d55c4a67e4e7d2eb4edc737aa4a6a5c8" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/layoutCaptures/detector_ext_sim.JPG"
Connecting
detector to buffer for chip layout
Schematic
data:image/s3,"s3://crabby-images/588e9/588e97fca839e04836aac5c5b4671a1641cd8cc6" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/layoutCaptures/detectorBuffer_schematic.JPG" |
Layout
data:image/s3,"s3://crabby-images/22f7e/22f7e8a5a5be64fc9746fcaad2c9b40738cbb434" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/layoutCaptures/detectorBuffer_layout.JPG"
|
DRCs
data:image/s3,"s3://crabby-images/4e304/4e304428ddf3e3d0f07d40bfaecf76fb60103031" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/layoutCaptures/detectorBuffer_DRC.JPG" |
LVSs
data:image/s3,"s3://crabby-images/eca79/eca7973c12d3b14920a65321a29618776dabc157" alt="http://cmosedu.com/jbaker/courses/ee421L/f16/students/huddle10/proj/layoutCaptures/detectorBuffer_LVS.JPG" |
Return
to EE 421L Labs
Return
to my Labs Index