MOSIS Counter Report Spring2008 PDF
MOSIS Counter Report Spring2008 PDF
MOSIS Counter Report Spring2008 PDF
Counter design
Report- 1, 2.
Report on D-
Flipflop
Course project for ECE533
REPORT-I
I. Objective:
The objective of this project is to design a 4-bit counter and implement it into a chip with the help of
Cadence (custom IC design tool) following necessary steps and rules dependent on selected process
technology.
The chosen design for the 4-bit counter is a simple 4-bit synchronous counter with synchronous set and
reset option and input and output carry option. The reasons behind choosing this design are
The basic building block of a counter is flip-flop. The choice of flip-flop depends on the logic function of
the circuit. The loguc function of the counter suggests a T flipflop as most appropriate for the design. But
I chose to use a J K Fliflop for the following reasons
i. J K fliflop allows to include both set and reset feature in it which can also be synchronous with
the clock.
ii. A T fliflop can be easily produced from a J K fliflop by applying the same input to both J and K pin.
IV. Design Steps:
Cadence is one of the most popular, efficient and commercial custom IC design tool widely used for
transforming a design idea to fabrication. For fruitful production of an IC from a design concept a
sequence of steps has to followed. The flow chart below describes these steps-
Design Specification
Schematic Capture
Create Symbol
Simulation
Layout
Extraction
Present Next J3 K3 J2 K2 J1 K1 J0 K0
state state
0000 0001 0 X 0 X 0 X 1 X
0001 0010 0 X 0 X 1 X X 1
0010 0011 0 X 0 X X 0 1 X
0011 0100 0 X 1 X X 1 X 1
0100 0101 0 X X 0 0 X 1 X
0101 0110 0 X X 0 1 X X 1
0110 0111 0 X X 0 X 0 1 X
0111 1000 1 X X 1 X 1 X 1
1000 1001 X 0 0 X 0 X 1 X
1001 1010 X 0 0 X 1 X X 1
1010 1011 X 0 0 X X 0 1 X
1011 1100 X 0 1 X X 1 X 1
1100 1101 X 0 X 0 0 X 1 X
1101 1110 X 0 X 0 1 X X 1
1110 1111 X 0 X 0 X 0 1 X
1111 0000 X 1 X 1 X 1 X 1
K-maps:
Q1 Q0 Q1 Q0
00 01 11 10 00 01 11 10
Q3 Q2 Q3 Q2
00 0 0 0 0 00 x x x X
01 0 0 1 0 01 x X x x
11 x x x X 11 0 0 1 0
10 x x x x 10 0 0 0 0
J 3 = Q 2 Q1 Q 0 K 3 = Q 2 Q1 Q 0
Q1 Q0
00 01 11 10
Q3 Q2
00 0 0 1 0 Q1 Q0
00 01 11 10
Q3 Q2
01 X X X X
00 x x x X
11 X X X X 01 0 0 1 0
10 0 0 1 0 11 0 0 1 0
10 x x x X
J2 =Q1Q0 K 2 = Q 1 Q0
Q1 Q0 Q1 Q0
00 01 11 10 00 01 11 10
Q3 Q2 Q3 Q2
00 0 1 x X 00 x x 1 0
01 0 1 x X 01 x x 1 0
11 0 1 x x 11 x x 1 0
10 0 1 x x 10 x x 1 0
J1 =Q0 K1 =Q0
Q1 Q0 Q1 Q0
00 01 11 10 00 01 11 10
Q3 Q2 Q3 Q2
00 1 1 1 1 00 x x x X
01 x x x x 01 1 1 1 1
11 x x x X 11 1 1 1 1
10 1 1 1 1 10 x x x x
J0 = 1 K0 = 1
Logic circuit:
J K Flip-flop: Master slave JK flip flop used in for this circuit for reliable operation and stability. The flip
flop triggers at negative edge of the clock cycle. Truth table for the JK flip flop is given below:
J K Qn+1
0 0 Qn
0 1 1
1 0 0
1 1 Qn’
Schematic of JK flip flop:
Figure 2: Schematic diagram of JK flip flop with set and reset assembly
Description: Master slave cross coupled NAND gate assembly is negative edge triggered. At the negative
edge of the clock cycle the output Qn and Qn’ changes depending upon the input at J and K. the AND OR
gate assembly forces “0-1” or “1=0” input combination to the J-K input to set or reset output. The
changes for set and reset also occur at the negative edge of clock.
Layout:
Layout was drawn in AMI 0.6 micron process. All the building blocks used in the layout has the same
height to maintain symmetry. Since the inverter output for the inverted clock signal was not able to
drive 4 MOSFET gates in the subsequent stage a 3 inverter stage buffer was used, which increased the
area. NAND gate assembly is placed on the upper row while the AND-OR gate assembly for set/ reset is
laid in the bottom row. Minimum spacing rule was utilized to reduce the size of layout.
Figure 4 : Simulation output of J K flip flop with reset enabled during 170ns to220ns
NAND gates:
Figure 5: NAND2 gate size= 35.5umX14um Figure 6: NAND3 gate size= 35.5umX12um
AND- OR- Inverter gates:
AND gate and OR gate require inverted input at the MOSFET gates.
So to create a AND gate NAND gates were complemented with an
inverter to get the inverted AND output. Similarly for OR gate a
NOR gate output was inverted with an inverter to get the OR
output.
Figure 8: Layout of an AND gate size= 35.5uX19u Figure 9: Layout of an OR gate size= 35.5uX19u
VII. Complete Layout of counter design:
Maximum effort was made to minimize the design area on chip. Four J K flip flop was stacked on top of
each other retaining minimum distance from n-well. Layout blocks are rotated to minimize interconnect
requirement. AND gates used at input of each flip flop is placed at closest proximity to the J-K input and
Qn and Qn’ output. Two bus of metal1 is used for supplying set and reset to each block.
Figure 15: Post layout simulation output, clock frequency= 10MHz, C_load= 5 pF
Post layout simulation with set enabled:
Figure 16: Post layout simulation output with set enabled, clock frequency= 10MHz
Figure 17: Post layout simulation output with reset enabled, clock frequency= 10MHz
IX. Measurement of rise time and fall time and propagation delay:
Capacitive loading was varied from 1pF to 15pF and rise time, fall time and propagation delay was
measured. During rise time and fall time measurement time required to change from 30% to 70% of
maximum voltage was measured. To measure propagation delay following equation was used
tdelay= (tPLH+tPHL)/2
Q3
Q2
Q0
40.0000
rise
20.0000 R² = 0.9767 fall
0 2 4 6 8 10 12 14 16 Linear (rise)
60.0000
50.0000 Q2 R² = 0.9964
Time(ns)
40.0000
rise
30.0000
20.0000 R² = 0.9769 fall
10.0000 Linear (fall)
0.0000
Linear (fall)
0 2 4 6 8 10 12 14 16
Capacitive load (pF)
60.0000
50.0000 Q1 R² = 0.9972
Time (ns)
40.0000 rise
30.0000 fall
20.0000 Linear (fall)
R² = 0.9825
10.0000 Linear (fall)
0.0000
0 2 4 6 8 10 12 14 16
Capacitive load (pF)
60.0000
50.0000
Q0 R² = 0.9969
Time(ns)
40.0000
rise
30.0000
20.0000 R² = 0.9922 fall
10.0000
Linear (fall)
0.0000
0 2 4 6 8 10 12 14 16 Linear (fall)
30.0000 Q1 delay
20.0000 Q0 delay
10.0000 Linear (Q3 delay)
0.0000 Linear (Q2 delay)
0 10 20 Linear (Q1 delay)
Capacitive load (pF) Linear (Q0 delay)
Figure 22: Output of 4-bit counter at 10 KHz Clock signal. Trace 1(yellow)- clock, Trace2 (green)- Q0, Trace3 (Purple) -Q1,
Trace4(magenta) -Q2
Figure 23: Output of 4-bit counter at 10 KHz Clock signal. Trace 1(yellow)- clock, Trace2 (green)- Q2, Trace3 (Purple) -Q3,
Trace4(magenta) -Carry_out
-1.00
0.00
1.00
2.00
3.00
4.00
5.00
6.00
7.00
8.00
-2.00
0.00
2.00
4.00
6.00
8.00
10.00
-1.00
0.00
1.00
2.00
3.00
4.00
5.00
6.00
7.00
8.00
9.00
-2.00
-1.00
0.00
1.00
2.00
3.00
4.00
5.00
6.00
7.00
8.00
-1.00
0.00
1.00
2.00
3.00
4.00
5.00
6.00
7.00
8.00
9.00
Time Time
Time
-1.00E+00
0.00E+00
1.00E+00
2.00E+00
3.00E+00
4.00E+00
5.00E+00
6.00E+00
7.00E+00
8.00E+00
-9.50E-04 -9.54E-04
-9.44E-04
Time -8.96E-04 -9.04E-04
-8.84E-04
-9.38E-04 -8.42E-04 -8.54E-04
-8.24E-04 -8.04E-04
-8.72E-04 -7.88E-04
-7.64E-04 -7.54E-04
-8.06E-04 -7.34E-04
-7.04E-04 -7.04E-04
-7.40E-04 -6.80E-04
-6.54E-04
-6.44E-04 -6.26E-04
-6.74E-04 -6.04E-04
-5.84E-04 -5.72E-04
-6.08E-04 -5.54E-04
-5.24E-04 -5.18E-04
-5.42E-04 -5.04E-04
-4.64E-04 -4.64E-04 -4.54E-04
-4.76E-04
-4.04E-04 -4.10E-04 -4.04E-04
-4.10E-04
-3.56E-04 -3.54E-04
-3.44E-04
Plot of measured chip data:
-3.44E-04 -3.04E-04
-3.02E-04
-2.84E-04
-2.78E-04 -2.48E-04 -2.54E-04
-2.24E-04
-2.12E-04 -1.94E-04 -2.04E-04
-1.64E-04 -1.54E-04
-1.46E-04 -1.40E-04
-1.04E-04 -1.04E-04
-8.00E-05 -8.60E-05
-4.40E-05 -5.40E-05
-1.40E-05 -3.20E-05
-4.00E-06
Tim e
1.60E-05 2.20E-05
5.20E-05 4.60E-05
7.60E-05 7.60E-05
1.18E-04 9.60E-05
1.36E-04 1.30E-04
1.84E-04 1.46E-04
1.96E-04 1.84E-04 1.96E-04
2.50E-04
2.56E-04 2.38E-04 2.46E-04
3.16E-04
2.92E-04 2.96E-04
3.16E-04
3.82E-04 3.46E-04
3.46E-04
3.76E-04
4.48E-04 4.00E-04 3.96E-04
4.36E-04 4.46E-04
5.14E-04 4.54E-04
4.96E-04 4.96E-04
5.80E-04 5.08E-04
5.56E-04 5.46E-04
6.46E-04 5.62E-04
6.16E-04 5.96E-04
7.12E-04 6.16E-04
6.46E-04
6.76E-04 6.70E-04
7.78E-04 6.96E-04
7.36E-04 7.24E-04
8.44E-04 7.46E-04
7.96E-04 7.78E-04 7.96E-04
9.10E-04
8.56E-04 8.32E-04 8.46E-04
9.76E-04
9.16E-04 8.86E-04 8.96E-04
9.40E-04 9.46E-04
9.76E-04
9.94E-04
Carry_out Volt
Q3 Volt
Q2 Volt
Q1 Volt
Q0 Volt
Clock Volt
Discussion:
Above plots show that the rise time, fall time and delay linearly varies with the capacitive loading. This
indicates the liner behavior of the designed circuit. It may be noticed that the fall time higher than that
of the fall time. This is because during fall time the capacitive loads discharges through the NMOS to
reach ground potential. In this design a large number of NAND gates are used which has number of
NMOS in series. The series connected NMOS has a larger resistance and has greater RC delay which
leads to the higher value of fall time. Since in NAND gates PMOS are connected in parallel they quickly
charge the load capacitor and give lower rise time.
All rise time and fall time was measured for 10MHz clock frequency. At this frequency capacitive loading
beyond 15pF produces signal that cannot be recognized as ‘1’ or ‘0’. At lower clock frequency higher
capacitive loading is possible.
X. Application:
Counter is used widely in number of digital and analog circuit. There are vast application of counter in
the field of electronics. Some of them are listed below-
I. A counter can be used as frequency divider. This 4-bit counter can be efficiently used to get four
different frequencies up to one sixteenth times of the original clock frequency. Since it is
triggered only at negative edge of the clock, the first cycle gives output at half the frequency of
that of the clock.
II. Counter can be used on building entrances to keep track of number of people entering or
leaving.
III. Counter can be used in digital logic deigns to perform certain operation at certain steps.
IV. Counters are also applicable in timer circuit to turn on/ off a device after certain time with use
of a proper logic function.
REPORT-II
ABSTRACT:
For the final project in ECE-533 we had to design a four bit counter. This project was done with the aid
of Cadence, in the AMI-0.6 micron process. The project involved the design of the schematic as well as
the layout. In both cases, simulations were done. The counter is simulated under no-load condition as
well as with few test loads. The rise time, fall time and delay are measured.
INTRODUCTION:
A Flip-flop is the name given to two-state devices which offer basic memory for sequential logic
operations. Flip-flops are synchronous bistable devices that operate as memory elements. A flip-flop
circuit contains two outputs, one is for the normal value and the other is for the complement value
of the stored bit. Flip-flops are used for digital data storage and transfer and are commonly used in
banks called "registers" for the storage of binary numerical data.
Counters are designed using flip-flops. Counters can be classified as synchronous and asynchronous
counters based on the application of clock to the flip-flops. A synchronous counter is clocked by a
single clock for all the stages and the output for each stage changes at the same time. In an
asynchronous counter the output from the previous stage is given as the clock for the next stage so
that the output ripples across each stage to reach the final count.
T FLIP FLOP:
a) Introduction
The T or "toggle" flip flop changes its output on each clock edge, giving an output which is half the
frequency of the signal to the T input. T flip flop is useful for constructing binary counters, frequency
dividers, and general binary addition devices
A T flip flop can be designed from a J K flip flop by shorting the J and K inputs.
Diagram of a T flip-flop
b) Implementation :
a) Introduction:
The counter was built with the help of T-Flip Flops. The gates used in realizing the design were two
3 Input Nand Gates, three 2 Input Nand gates and an inverter. The outputs of the Flip Flop are Q
and QOb.
In an asynchronous counter the clock pulse is applied only at the first stage. The rest of the stages are
driven by the output of the preceding flip flop. All the output bits do not change at the same time.
An asynchronous counter is also called as a ripple counter because only the first bit changes with the
clock pulse, there exists some delay before the other bits change, so the output ripples across the
counter.
A binary counter can be realized using T-Flip Flops by counting the number of toggles in the previous
stage. The T input of each flip-flop is set to 1 to produce a toggle at each cycle of the clock input. For
each two toggles of the first cell, a toggle is produced in the second cell, and so on down to the fourth
cell. This produces a binary number equal to the number of cycles of the input clock signal.
Using a Master-slave configuration isolates the output from any glitches resulting from any changes
happening in the input signal. The master-slave flip-flop is essentially two back-to-back JK flip-flops, but
the feedback is to both to the master flip flop and the slave flip flop. In this configuration, the master flip
flop sees the input when the clock is high and the output of the first stage holds the input for the next
stage. During the clock ‘low’, the slave circuit is enabled to track the change in the input by using the
output of the master Flip Flop. Thus the master-slave configuration eliminates any sharp change of state
within a clock cycle and the flip flop is free of oscillations.
b) Implementation:
RISE TIME AND FALL TIME FOR VARIOUS OUTPUT BITS AT ZERO LOAD:
FALL
TIME (ns)
RISE TIME (ns)
X0 0.3 0.45
X1 0.25 0.4
X2 0.2 0.43
X3 0.15 0.39
X0
APPLICATIONS OF COUNTERS:
X0 0.3 0.45
X1 0.25 0.4
X2 0.2 0.43
X3 0.15 0.39
Flip-Flop Design
1. Objective
The objective of this project is to design and simulate a J-K Flip-Flop and a D-Flip Flop using Cadence (IC design
software). The design will be in the form of a logic circuit and a layout.
2. Flip Flops
I will be designing a J-K flip flop with a set/reset option. The outputs will only change state on the falling edge of
the CLK signal, and the J and K inputs will control the future output. If both the J and K inputs are held at logic 1
and the CLK signal continues to change, the Q and Q' outputs will simply change state with each falling edge of the
CLK signal.
R J K Qn+
1
0 0 0 Qn
0 0 1 0
0 1 0 1
0 1 1 nQ
1 d d 0
I also will be designing a negative edge triggered D Flip-Flop. The outputs’ states to change only when the clock
signal falls from logic ‘1’ to logic ‘0’.
D Q CLK Qnext
0 X Falling 0
1 X Falling 1
I designed the J-K Flip Flop and the D Flip-Flop using Cadence IC Design Software with an AMI-0.6 micron process.
Ln=Lp=0.6um
Wp=7.5um
Wn=3.0um
The design process began with the schematics of the J-K flip flop (Figure 1) and the D flip flop (Figure 2), which I
utilized nand gates and an inverter that I designed in my previous labs.
After designing the schematics, I simulated using Spectre and the Cadence Analog Environment in order to
generate waveforms that demonstrate the behavior of the J-K flip flop (Figure 3) and the D flip flop (Figure 4). In
order to simulate realistic results, capacitances were added to the outputs in order to generate delays in the
waveforms.
I then designed the layouts for the J-K flip flop (Figure5) and the D flip flop (Figure6) in which I utilized the layouts
of nand gates and an inverter which I designed in my previous labs. After connecting all of the I/O pins, I made
sure that I connected all of the vdd pins from each nand gate and inverter. I did the same for all of the ground
(gnd) pins.
After the design is complete, I used the DRC tool to verify that the layouts of the J-K flip flop and the D flip flop
contained no. The DRC tool confirmed that the spacing between the various components in the layouts was not
too close together and that pins were not duplicated on the same layout.
3.5 Extract
I then utilized the LVS tool to verify that the layouts designs matched that of my schematics in terms of the number
of nets, terminals, and instances (Figure 7 and Figure 8).
The simulation of the layouts is implemented exactly the same way as the schematic simulation. We also add
capacitances to the outputs in the netlist to simulate delays and produce more realistic results. (Figure 9 and
Figure 10)
4. Waveform Analysis
4.1 Results
The rise time/fall time were measured using the 10% - 90% method.
Capacitive Rise Time (ns) Fall Time (ns) Propagation Delay (ns)
Load
(fF)
Table 1: Rise time, fall time, and propagation delay measured from the J-K flip flop waveform
4.4 Capacitive Load Effect Graphs
120
100
Capacitance (fF)
80
60
40
20
0
0 0.5 1 1.5 2 2.5
Time (ns)
120
100
Capacitance (fF)
80
Series1
60
Linear (Series1)
40
20
0
0 0.5 1 1.5 2 2.5 3 3.5
Time (ns)
5. Conclusion from Waveform Analysis
The capacitive load and the rise/fall times and delay correlate in a linear fashion. Based on the analysis of the
rise/fall times and delay we see that if the capacitive load increases, then the rise time, fall time, and delay also
increase.
6. Application
J-K flip flops can be utilized in binary counters, shift registers, and sequence detectors. Because of the behavior of
the D-Flip Flop described in the introduction, it can be utilized in shift registers, which are an essential part of many
electronic devices.
7. Pad Frame
The pad frame schematic and the pad frame layout contained no errors. However, the symbol of the JK flip flop
and contained no vdd or ground pins, therefore my attempts to verify both pad frames using LVS was unsuccessful.
8. Appendix