Example: Modulo-4 Counter
Example: Modulo-4 Counter
Example: Modulo-4 Counter
Create successful ePaper yourself
Turn your PDF publications into a flip-book with our unique Google optimized e-Paper software.
A-59<br />
<strong>Example</strong>: <strong>Modulo</strong>-4 <strong>Counter</strong><br />
Appendix A: Digital Logic<br />
• <strong>Counter</strong> has a clock input (CLK) and a RESET input.<br />
• <strong>Counter</strong> has two output lines, which take on values of 00, 01, 10,<br />
and 11 on subsequent clock cycles.<br />
Time (t)<br />
4 3 2 1 0 4 3 2 1 0 Time (t)<br />
0 0 0 0 1 RESET q0 0 1 1 0 0<br />
3-bit<br />
Synchronous<br />
<strong>Counter</strong><br />
q1 s0 0 1 0 1 0<br />
D<br />
CLK<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring<br />
s 1<br />
D<br />
s 1<br />
Q<br />
Q<br />
s 0<br />
Q<br />
Q
A-60<br />
State<br />
Transition<br />
Diagram for<br />
Mod-4<br />
<strong>Counter</strong><br />
RESET<br />
Output 00<br />
state<br />
1/00<br />
q1q0 1/00<br />
Output 10<br />
state<br />
A B<br />
Appendix A: Digital Logic<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring<br />
0/10<br />
0/01<br />
1/00<br />
C D<br />
0/11<br />
0/00<br />
1/00<br />
Output 01<br />
state<br />
Output 11<br />
state
A-61<br />
Appendix A: Digital Logic<br />
State Table for Mod-4 <strong>Counter</strong><br />
Present state<br />
Input RESET<br />
0 1<br />
A B/01 A/00<br />
B C/10 A/00<br />
C D/11 A/00<br />
D A/00 A/00<br />
Next state Output<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring
A-62<br />
Appendix A: Digital Logic<br />
State Assignment for Mod-4 <strong>Counter</strong><br />
Present<br />
state (S t)<br />
Input RESET<br />
0 1<br />
A:00 01/01 00/00<br />
B:01 10/10 00/00<br />
C:10 11/11 00/00<br />
D:11 00/00 00/00<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring
A-63<br />
RESET<br />
r(t)<br />
0<br />
0<br />
0<br />
0<br />
1<br />
1<br />
1<br />
1<br />
Appendix A: Digital Logic<br />
Truth Table for Mod-4 <strong>Counter</strong><br />
s 1(t) s 0(t)<br />
0<br />
0<br />
1<br />
1<br />
0<br />
0<br />
1<br />
1<br />
0<br />
1<br />
0<br />
1<br />
0<br />
1<br />
0<br />
1<br />
s 1s 0(t+1)<br />
01<br />
10<br />
11<br />
00<br />
00<br />
00<br />
00<br />
00<br />
q 1q 0(t+1)<br />
01<br />
10<br />
11<br />
00<br />
00<br />
00<br />
00<br />
00<br />
s 0(t+1) = r(t)s 1(t)s 0(t) + r(t)s 1(t)s 0(t)<br />
s 1(t+1) = r(t)s 1(t)s 0(t) + r(t)s 1(t)s 0(t)<br />
q 0(t+1) = r(t)s 1(t)s 0(t) + r(t)s 1(t)s 0(t)<br />
q 1(t+1) = r(t)s 1(t)s 0(t) + r(t)s 1(t)s 0(t)<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring
A-64<br />
RESET<br />
CLK<br />
Appendix A: Digital Logic<br />
Logic Design for Mod-4 <strong>Counter</strong><br />
D<br />
D<br />
s 1<br />
s 0<br />
Q<br />
Q<br />
Q<br />
Q<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring<br />
q 1<br />
q 0
A-65<br />
Appendix A: Digital Logic<br />
<strong>Example</strong>: A Sequence Detector<br />
• <strong>Example</strong>: Design a machine that outputs a 1 when exactly two of<br />
the last three inputs are 1.<br />
• e.g. input sequence of 011011100 produces an output sequence<br />
of 001111010.<br />
• Assume input is a 1-bit serial line.<br />
• Use D flip-flops and 8-to-1 Multiplexers.<br />
• Start by constructing a state transition diagram (next slide).<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring
A-66<br />
Appendix A: Digital Logic<br />
Sequence Detector State Transition<br />
• Design a machine that<br />
outputs a 1 when exactly<br />
two of the last<br />
three inputs are 1.<br />
A<br />
Diagram<br />
0/0<br />
1/0<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring<br />
B<br />
C<br />
0/0<br />
1/0<br />
0/0<br />
1/0<br />
1/1<br />
0/0<br />
D<br />
E<br />
F<br />
G<br />
1/0<br />
1/0<br />
0/0<br />
0/1<br />
0/0<br />
1/1
A-67<br />
Appendix A: Digital Logic<br />
Sequence Detector State Table<br />
Present state<br />
X<br />
0 1<br />
A B/0 C/0<br />
B<br />
C<br />
D<br />
E<br />
Input<br />
D/0 E/0<br />
F/0 G/0<br />
D/0 E/0<br />
F/0 G/1<br />
F D/0 E/1<br />
G F/1 G/0<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring
A-68<br />
Appendix A: Digital Logic<br />
Sequence Detector State Assignment<br />
Present state<br />
Input<br />
X<br />
0 1<br />
S 2 S 1 S 0 S 2 S 1 S 0 Z S 2 S 1 S 0 Z<br />
A: 000 001/0 010/0<br />
B: 001<br />
C: 010<br />
D: 011<br />
E: 100<br />
011/0 100/0<br />
101/0 110/0<br />
011/0 100/0<br />
101/0 110/1<br />
F: 101 011/0 100/1<br />
G: 110 101/1 110/0<br />
(a)<br />
Input and<br />
state at<br />
time t<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring<br />
s 2<br />
0<br />
0<br />
0<br />
0<br />
0<br />
0<br />
0<br />
0<br />
1<br />
1<br />
1<br />
1<br />
1<br />
1<br />
1<br />
1<br />
s 1<br />
0<br />
0<br />
0<br />
0<br />
1<br />
1<br />
1<br />
1<br />
0<br />
0<br />
0<br />
0<br />
1<br />
1<br />
1<br />
1<br />
s 0 x<br />
0<br />
0<br />
1<br />
1<br />
0<br />
0<br />
1<br />
1<br />
0<br />
0<br />
1<br />
1<br />
0<br />
0<br />
1<br />
1<br />
0<br />
1<br />
0<br />
1<br />
0<br />
1<br />
0<br />
1<br />
0<br />
1<br />
0<br />
1<br />
0<br />
1<br />
0<br />
1<br />
Next state<br />
and output at<br />
time t+1<br />
(b)<br />
s 2<br />
0<br />
0<br />
0<br />
1<br />
1<br />
1<br />
0<br />
1<br />
1<br />
1<br />
0<br />
1<br />
1<br />
1<br />
d<br />
d<br />
s 1<br />
0<br />
1<br />
1<br />
0<br />
0<br />
1<br />
1<br />
0<br />
0<br />
1<br />
1<br />
0<br />
0<br />
1<br />
d<br />
d<br />
s 0<br />
1<br />
0<br />
1<br />
0<br />
1<br />
0<br />
1<br />
0<br />
1<br />
0<br />
1<br />
0<br />
1<br />
0<br />
d<br />
d<br />
z<br />
0<br />
0<br />
0<br />
0<br />
0<br />
0<br />
0<br />
0<br />
0<br />
1<br />
0<br />
1<br />
1<br />
0<br />
d<br />
d
A-69<br />
0<br />
x<br />
1<br />
x<br />
1<br />
x<br />
1<br />
0<br />
CLK<br />
Appendix A: Digital Logic<br />
Sequence Detector Logic Diagram<br />
000<br />
001<br />
010<br />
011<br />
100<br />
101<br />
110<br />
111<br />
D<br />
Q<br />
S2<br />
Q<br />
x<br />
x<br />
x<br />
x<br />
x<br />
x<br />
x<br />
0<br />
000<br />
001<br />
010<br />
011<br />
100<br />
101<br />
110<br />
111<br />
D<br />
Q<br />
S1<br />
Q<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring<br />
x<br />
x<br />
x<br />
x<br />
x<br />
x<br />
x<br />
0<br />
000<br />
001<br />
010<br />
011<br />
100<br />
101<br />
110<br />
111<br />
D<br />
Q<br />
S0<br />
Q<br />
0<br />
0<br />
0<br />
0<br />
x<br />
x<br />
x<br />
0<br />
000<br />
001<br />
010<br />
011<br />
100<br />
101<br />
110<br />
111<br />
Z
A-70<br />
<strong>Example</strong>: A Vending Machine<br />
Controller<br />
Appendix A: Digital Logic<br />
• <strong>Example</strong>: Design a finite state machine for a vending machine<br />
controller that accepts nickels (5 cents each), dimes (10 cents<br />
each), and quarters (25 cents each). When the value of the money<br />
inserted equals or exceeds twenty cents, the machine vends the<br />
item and returns change if any, and waits for next transaction.<br />
• Implement with PLA and D flip-flops.<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring
A-71<br />
Appendix A: Digital Logic<br />
Vending Machine State Transition<br />
Q/110<br />
A dime is<br />
inserted<br />
Diagram<br />
N/100 D/110<br />
A<br />
0 ¢<br />
N/000<br />
Q/101<br />
B<br />
5 ¢<br />
D/000<br />
Q/111<br />
D<br />
15 ¢<br />
Q/111<br />
D/100<br />
1/0 = Dispense/Do not<br />
dispense merchandise<br />
D/000 N/000<br />
C<br />
10 ¢<br />
1/0 = Return/Do not return<br />
a nickel in change<br />
1/0 = Return/Do not<br />
return a dime in change<br />
N/000<br />
N = Nickel<br />
D = Dime<br />
Q = Quarter<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring
A-72<br />
Appendix A: Digital Logic<br />
Vending Machine State Table and<br />
P.S.<br />
Input<br />
N D<br />
00 01<br />
A B/000 C/000<br />
B<br />
C<br />
D<br />
C/000 D/000<br />
D/000 A/100<br />
A/100 A/110<br />
(a)<br />
State Assignment<br />
Q<br />
10<br />
A/110<br />
A/101<br />
A/111<br />
B/111<br />
Input<br />
P.S.<br />
N<br />
x1x0 00<br />
D<br />
x1x0 01<br />
Q<br />
x1x0 10<br />
s1s0 s1s0 /<br />
z2z1z0 A:00 01/000 10/000 00/110<br />
B:01 10/000 11/000 00/101<br />
C:10 11/000 00/100 00/111<br />
D:11 00/100 00/110 01/111<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring<br />
(b)
A-73<br />
Appendix A: Digital Logic<br />
PLA Vending Machine Controller<br />
x 1<br />
x 0<br />
(a)<br />
Base 10<br />
equivalent<br />
0<br />
1<br />
2<br />
3<br />
4<br />
5<br />
6<br />
7<br />
8<br />
9<br />
10<br />
11<br />
12<br />
13<br />
14<br />
15<br />
Present<br />
state Coin<br />
s 1 s 0 x 1 x 0<br />
0<br />
0<br />
0<br />
0<br />
0<br />
0<br />
0<br />
0<br />
1<br />
1<br />
1<br />
1<br />
1<br />
1<br />
1<br />
1<br />
0<br />
0<br />
0<br />
0<br />
1<br />
1<br />
1<br />
1<br />
0<br />
0<br />
0<br />
0<br />
1<br />
1<br />
1<br />
1<br />
0<br />
0<br />
1<br />
1<br />
0<br />
0<br />
1<br />
1<br />
0<br />
0<br />
1<br />
1<br />
0<br />
0<br />
1<br />
1<br />
5 × 5<br />
PLA<br />
D<br />
Q s0<br />
D<br />
Q s1<br />
0 0<br />
1 1<br />
0 0<br />
1 d<br />
0 1<br />
1 1<br />
0 0<br />
1 d<br />
0 1<br />
1 0<br />
0 0<br />
1 d<br />
0 0<br />
1 0<br />
0 0<br />
1 d<br />
(b)<br />
Dispense<br />
Next Return nickel<br />
state Return dime<br />
s 1 s 0 z 2 z 1 z 0<br />
1<br />
0<br />
0<br />
d<br />
0<br />
1<br />
0<br />
d<br />
1<br />
0<br />
0<br />
d<br />
0<br />
0<br />
1<br />
d<br />
0<br />
0<br />
1<br />
d<br />
0<br />
0<br />
1<br />
d<br />
0<br />
1<br />
1<br />
d<br />
1<br />
1<br />
1<br />
d<br />
0<br />
0<br />
1<br />
d<br />
0<br />
0<br />
0<br />
d<br />
0<br />
0<br />
1<br />
d<br />
0<br />
1<br />
1<br />
d<br />
0<br />
0<br />
0<br />
d<br />
0<br />
0<br />
1<br />
d<br />
0<br />
0<br />
1<br />
d<br />
0<br />
0<br />
1<br />
d<br />
z 2<br />
z 1<br />
z 0<br />
CLK<br />
s 1 s 0 x 1 x 0<br />
s 1 s 0 z 2 z 1 z 0<br />
Principles of Computer Architecture by M. Murdocca and V. Heuring © 1999 M. Murdocca and V. Heuring<br />
(c)<br />
0<br />
1<br />
2<br />
4<br />
5<br />
6<br />
8<br />
9<br />
10<br />
12<br />
13<br />
14