Download presentation
Presentation is loading. Please wait.
Published byCoral Stephens Modified over 9 years ago
1
Unit 5 Synchronous And Asynchronous Sequential Circuits
2
Algorithmic State Machine
2
3
ASM Block Timing 3
4
An Algorithmic Binary Multiplier
Either adding the multiplier or 0000 4
5
5
6
Shifting partial product right is the same as shifting the
multiplier to the left 6
7
7
8
Synchronous Moore Machine
Inputs Combinational logic circuit {Input decoder} Memory Elements Output decoder Outputs Next state Present state State signals Clock 8 8
9
Asynchronous Moore Machine
Inputs Combinational logic circuit {Input decoder} Output decoder Outputs State signals 9 9
10
Synchronous Mealy Machine
Inputs Combinational logic circuit {Input decoder} Memory Elements Output decoder Next state Present state State signals Clock 10 10
11
Asynchronous Mealy Machine
Inputs Combinational logic circuit {Input decoder} Output decoder Outputs State signals 11 11
12
Asynchronous Sequential Circuits
In steady-state condition, the y's and the Y's are the same, but during transition they are not. 12 12
13
According to how input variables are to be considered, there are 2 types of asynchronous circuits: Fundamental mode circuits Pulse mode circuits FUNDAMENTAL MODE CIRCUITS: It assumes that: Input changes should be spaced by at least t, the time needed for the circuit to settle into a stable state following an input change. That is, the input variables should change only when the circuit is stable. Only 1 input variable can change at a given instant of time. 13 13
14
Inputs are levels and not pulses
Inputs are levels and not pulses. Delay lines are used as memory elements. PULSE MODE CIRCUIT: It assumes that The input variables are pulses instead of levels. The width of the pulse is long enough for the circuit to respond to the input. The pulse width must not be so long that it is still present after the new state is reached. pulses should not occur simultaneously on 2 or more input lines. 14 14
15
Derivation of primitive flow table: The flow table in asynchronous sequential circuit is same as that of state table in the synchronous sequential circuit. In asynchronous sequential circuits stable state table is known as flow table because of the behaviour of the asynchronous sequential circuits. The state changes occur independent of a clock, based on the logic propagation delay, and cause the states to ‘flow’ from one to another. A primitive flow table is a special case of flow table which has exactly 1 stable state for each row in the table. The design process begins with the construction of primitive flow table 15 15
16
fundamental mode fundamental mode :Only one input variable can change at any one time and the time between two input changes must be longer than the time it takes the circuit to reach a stable state. 16 16
17
TRANSITION TABLE This diagram clearly shows 2 feedback loops from the OR gate outputs back to the AND gate inputs. The circuit consists of 1 input variable x and 2 internal states. The 2 internal states have 2 excitation variables, Y1 and Y2, and 2 secondary variables, y1 and y2. Each logic gate in the path introduces a propagation delay of about 2 to 10 ns. We can derive the Boolean expressions for the excitation variables as a function of the input and secondary variables. 17 17
18
Transition Table Y1 = xy1 + x'y2 Y2 = xy'1 + x'y2 18 18
19
The encoded binary values of the y variables are used for the labeling the rows, and the input variable x is used to designate the columns. The following table provides the same information as the transition table. There is 1 restriction that applies to the asynchronous case, but not the synchronous case. In the asynchronous transition table, there usually is at least 1 next state entry that is the same as the present state value in each row. Otherwise, all the total states in that row will be unstable. 19 19
20
Transition Table Y1 = xy1 + x'y2 Y2 = xy'1 + x'y2 20 20
21
Transition Table For a state to be stable, the value of Y must be the same as that of y = y1y2 21 21
22
Transition Table The Unstable states, Y ≠ y 22 22
23
Transition Table Consider the square for x = 0 and y = 00. It is stable. x changes from 0 to 1. The circuit changes the value of Y to 01. The state is unstable. The feedback causes a change in y to 01. The circuit reaches stable. 23 23
24
Transition Table In general, if a change in the input takes the circuit to an unstable state, y will change until it reaches a stable state. 24 24
25
Flow Table Flow Table Transition table whose states are named by letter symbol instead of binary values. 25 25
26
FLOW TABLE During the design of asynchronous sequential circuits, it is more convenient to name the states by letter symbols without making specific reference to their binary values. Such table is called a flow table. 26 26
27
It is called primitive flow table because it has only one stable state in each row.
It is a flow table with more than one stable state in the same row. 27 27
28
Flow Table 28 28
29
29 29
30
Prob 2: Design a circuit with inputs A and B to give an output Z=1 when AB=11 but only if A=1 before B, by drawing total state diagram, primitive flow table and output map in which transient state is included 30 30
31
31 31
32
32 32
33
33 33
34
34 34
35
Initially both inputs and outputs are equal to 0.
prob 3: Develop the state diagram and primitive flow table for a logic system that has two inputs X and Y and a single output Z, which is to behave in the following manner. Initially both inputs and outputs are equal to 0. Whenever X=1 and Y=0, the Z becomes 1. Whenever X=0 and Y=1, the Z becomes 0. When X=Y=0 or X=Y=1, the output Z does not change; it remains in the previous state. The logic system has edge triggered inputs and the system change state on the rising edges of the two inputs. 35 35
36
State diagram Inputs A State Output B C D E 1 F 1 36 36
37
Next state, output Z for XY inputs
Primitive Flow Table Present state Next state, output Z for XY inputs 00 A A , 0 B , 0 _ , _ C , _ B A , _ D , _ C E , _ F , _ C , 1 D B , _ D,0 E E, _ F F,1 37 37
38
Next state , output Z for XY inputs
Reduction of Primitive Flow Table Set of maximal compatibilities (A ,B,D) S0 (C ,E,F) S1 Reduced flow diagram Present State Next state , output Z for XY inputs 00 01 11 10 S0 S0 , 0 S1 , _ S1 S1 , 1 S0 , _ S1 , 1 38 38
39
Next state , output Z for XY inputs
Transition table S S Present State Next state , output Z for XY inputs 00 01 11 10 0 , 0 1 , _ 1 1 , 1 0 , _ 1 , 1 Implementation using K-map 1 F+ = XY’ + FX + FY’ 39 39
40
X 1 Z = FX + FX’ + XY’ X Y Z F+ = Z 40 40
41
State Diagram S0 S1 S2 S3 S4 S5 S6 X=1 X=0 X=1 X=0 X=1 X=0 X=1 X=0 X=1
41 41
42
State Table Present State Next State X=0 X=1 S0 S2 Output O=0 S1 S4 S3
42 42
43
Reduced State Table Present State Next State X=0 X=1 S0 S2 Output O=0
43 43
44
Minimal State Table Present State Next State X=0 X=1 S0 S12 Output O=0
44 44
45
Reduced State Diagram O=0 O=0 O=1 O=0 S0 X=0 X=0 X=0 X=1 X=1 X=1 S12
AB 00 S0 O=0 X=0 X=0 X=0 X=1 X=1 X=1 S12 O=0 X=1 X=0 AB 01 S35 O=1 S46 O=0 AB 11 AB 10 45 45
46
Revised State Table of State Diagram
Present State Next State Flip-Flop State Outputs O X=0 X=1 AB D1 D0 00 01 1 10 11 46 46
47
3 Variable K-Map D1 = A’B AB A’B’ (00) A’B (01) AB (11) AB’ (10)
X’ (0) 1 X (1) X 47 47
48
3 Variable K-Map D0 = A’B’ + XA’
1 X (1) X 48 48
49
Implementation of sequential circuit using logic gates and D flip-flops
B X D0 Q0 D Q D1 Q1 D Q Q’ Q’ Q = AB Clock 49 49
50
Problem: Analyze the given fundamental mode asynchronous sequential circuit given.
50 50
51
Step 1: Determine next-secondary state and output equations.
Solution: The given circuit has 2 input variables I1 and I0 and 1 output variable Z. The circuit has 2 feedback paths which provide inputs to the gates, creating latching operation necessary to produce a sequential circuit. The feedback path also generates the state variables X0 and X1. The next state for the circuit is determined by both, the state of the input variables and the state variables. Step 1: Determine next-secondary state and output equations. Step 2: Construct state table. 51 51
52
52 52
53
OUTPUT MAP: I1 I0 X1 X0 00 01 11 10 - 1 00 01 11 10 53 53
54
Design Example Problem: Design a gated latch circuit with two inputs G (gate) and D (data), and one output Q. Binary information present at the D input is transferred to the Q output when G is equal to 1. The Q output will follow the D input as long as G=1. When G goes to 0, the information that was present at the D input at the time the transition occurred is retained at the Q output. The gated latch is a memory element that accepts the value after G goes to 0. Once G=0, a change the value of the output Q. 54 54
55
Primitive flow table A primitive flow table is a flow table with only one stable state in each row.
Inputs Output comments D G Q a b c d e f 1 D =Q because G = 1 After state a or d After state c After state b or f After state e 55 55
56
The primitive flow table shown has one row for each state and one column for each input combination. For eg, state a is stable and the output is 0 when the input is 01. This information is entered in the flow table in the first row and second column. Similarly, the other 5 stable states together with their output are entered in the corresponding input columns. Since both the inputs are not allowed to change simultaneously, we can enter dash marks in each row that differs in 2 or more variables from the input variables associated with the stable state. Next it is necessary to find the values for 2 or more squares in each row. The unstable state values for the other squares are determined in a similar manner. All the outputs associated with unstable states are marked with dash to indicate don’t care conditions. 56 56
57
Design Example State Inputs Output D G Q a b c d e f 0 1 1 1 0 0 1 0 1
1 57 57
58
Reduction of the Primitive Flow Table
Two of more rows in the primitive flow table can be merged into one row if there are non-conflicting states and outputs in each of the columns. Reduction of the Primitive Flow Table 58 58
59
Reduction of the Primitive Flow Table
59 59
60
Transition Table and Logic Diagram
60 60
61
Circuit With SR Latch 61 61
62
Assigning Output to Unstable States
Assign a 0 to an output variable associated with an unstable state that is a transient state between two stable states that have a 0 in the corresponding output variable. Assign a 1 to an output variable associated with an unstable state that is a transient state between two stable states that have a 1 in the corresponding output variable. Assign a don't-care condition to an output variable associated with an unstable state that is a transient state between two stable states that have different values in the corresponding output variable. 62 62
63
Equivalent States Two states are equivalent if for each possible input, they give exactly the same output and go to the same next states or to equivalent next states. The characteristic of equivalent states is that if (a,b) imply (c,d) and (c,d) imply (a,b), then both pairs of states are equivalent. 63 63
64
Implication table The state reduction procedure for completely specified state table can be combined into one if they can be shown to be equivalent if for each possible input, they can give exactly the same output and go to the next states or equivalent states. 64 64
65
Implication Table Two states are equivalent if for each possible input, they give exactly the same output and go to the same next states or to equivalent next states. The characteristic of equivalent states is that if (a,b) imply (c,d) and (c,d) imply (a,b), then both pairs of states are equivalent. 65 65
66
Implication Table Without the first X1X2 Sn A 00 01 11 10 B C D E F G
S n+1/Zn Example B C D E F G H AF DF BC BD BG DG Without the last BD AF DG AF A B C D E F G 66 66
67
Implied Pairs A B C D E F G H X1X2 Sn 00 01 11 10 D/0 F/0 A/0 C/1
BD AF DG DF BC BG X1X2 Sn 00 01 11 10 D/0 F/0 A/0 C/1 E/1 B/0 G/0 B/1 S n+1/Zn example 67 67
68
The equivalent states:[A,F]、[B,H]、[B,C]、[C,H]。
Denoted by A Denoted by B The largest group of equivalent states A B C D E F G H BD AF DG DF BC BG Combined into [B,C,H] [A,F], [B,C,H], [D], [E], [G] S n+1/Zn X1X2 Sn A 00 01 11 10 B D E G D/0 A/0 C/1 E/1 B/0 B/1 G/0 68 68
69
Reduction of Primitive Flow Table
Reduction of the Flow Table to a Minimum Number of Rows Reduce the number of state variables Reduce the amount of logic required Reduction Method : 1.Equivalent states can be combined by using implication table method for completely specified state tables 2.Compatible rows can be merged for incompletely specified tables 69 69
70
If c and d are equivalent, then a and b are equivalent
Equivalent States If c and d are equivalent, then a and b are equivalent (a,b) -> (c,d) 70 70
71
State Table To Be Reduced
71 71
72
Reduced State Table 72 72
73
Problem: Obtain the primitive flow table for an asynchronous circuit that has 2 inputs x, y and 1 output z. An output z=1 occur only during the input state xy=01 and then if the input state xy=01 is preceded by the input sequence xy=01, 00, 10, 00, 10, 00. State diagram: 73 73
74
Primitive flow table: 74 74
75
States Machine Design Other topics on state machine design
Equivalent sequential machines Incompletely specified machines One Hot State Machines 75
76
Equivalent State Machines
So far have seen that equivalent states in the state table of a sequential machine are equivalent and can be removed. How about the equivalence between two sequential circuits? Two sequential circuits are equivalent is they are capable of doing the same work. 76
77
Formally An implication table can be used to prove this.
Sequential circuit N1 is equivalent to sequential circuit N2 if for each state p in N1, there is a state q in N2 such that p º q, and conversely, for each state s in N2 there is a state t in N1 such that s º t. Simply said they have the same states which can be seen if the circuit is small enough. An implication table can be used to prove this. 77
78
An example State tables and state graphs of two sequential machines. Figure 15-6 from the text. Equivalent? 78
79
Proving equivalence Again will use an implication table.
Only this time it is the full square. Along bottom are the state of one machine Along the side are the states of the second. Start by removing output incompatible states. 79
80
Copyright 2012 - Joanne DeGroat, ECE, OSU
Step 2 Go back through and remove the implied equivalence pairs that were Xed on the first pass. Continue until no further Xs are entered. If there is one square not Xed in each row and each column, the state machines are equivalent. Consider problem 15-17 9/2/2012 – ECE 3561 Lect 10 Copyright Joanne DeGroat, ECE, OSU 80 80
81
The equivalence implication table
X squares where the outputs are incompatible Enter implied equivalence pairs for remaining states. 81
82
Incompletely Specified
Incompletely Specified State Tables State tables that contain don’t cares. Results in reduced logic Determining the best way to fill in the don’t cares is another of the n-p complete problems. For this course do the most logical approach. 82
83
RACES AND CYCLES When two or more binary state variables change their value in response to a change in an input variable, race condition occurs in an asynchronous sequential circuit. In case of unequal delays, a race condition may cause the state variables to change in an unpredictable manner. For example, if there is a change in two state variables due to change in input variable such that both change from 00 to 11. In this situation, the difference in delays may cause the first variable to change faster than the second resulting the state variables to change in sequence 83
84
from 00 to 11 and then to 11. On the other hand, if the second variable changes faster than first, the state variables change from 00 to 01 and then to 11. If the final stable state that the circuit reaches does not depend on the order in which the state variable changes, the race condition is not harmful and it is called a non critical race. But if the final stable state depends on the order in which the state variable changes, the race condition is harmful and it is called a critical race. Such critical races must be avoided for proper operation. 84
85
NON CRITICAL RACES The following diagram illustrates non critical races. It shows transition tables in which X is a input variable and y1 y2 are the state variables. Consider a circuit is in a stable state y1 y2 x=000 and there is change in the input there are three possibilities that the state variables may change. They can either change simultaneously from 00 to 11, or they may change in sequence from 00 to 01 and then to 11, or they may change in sequence from 00 to 10 and then to 11. In all cases, the final stable state is 11, which results in a non critical race condition. 85
86
Two or more binary state variables change value in response to a change in an input variable
Race Conditions Noncritical Race: State variables change from 00 to 11. The possible transition could be 86 It is a noncritical race. The final stable state that the circuit reaches does not depend on the order in which the state variables change.
87
CRITICAL RACES The following diagram illustrates critical race
CRITICAL RACES The following diagram illustrates critical race. Consider a circuit is in a stable state y1 y2 x=000 and there is a change in input from 0 to 1. If state variable change simultaneously, the final stable state is y1 y2 x=111. If Y2 changes to 1 before Y1 because of unequal propagation delay, the circuit goes to stable state 011 and remain there. On the other hand, if Y1 changes faster than Y2, then the circuit goes to the stable state 101 and remain there. Hence the race is critical because the circuit goes to different stable states depending on the order in which the state variables change. 87
88
Race Conditions Critical Race:
State variables change from 00 to 11. The possible transition could be It is a critical race. The final stable state depends on the order in which the state variables change. 88
89
CYCLES A cycle occurs when an asynchronous circuit makes a transition through a series of unstable states. When a state assignment is made so that it introduces cycles, care must be taken to ensure that each cycle terminates on a stable state. If a cycle does not contain a stable state, the circuit will go from one unstable state to another, until the inputs are changed. Obviously, such a situation must always be avoided when designing asynchronous circuits. 89
90
When a circuit goes through a unique sequence of unstable states, it is said to have a cycle.
Race Conditions Cycle It starts with y1 y2 =00, then input changes from 0 to 1. The sequence is as follows, 90 90
91
The primary objective in choosing a proper binary state assignment is the prevention of critical races. Critical races can be avoided by making a binary state assignment in such a way that only one variable changes at any given time when a state transition occurs in the flow table. 91
92
SHARED ROW METHOD The assignment of a single binary variable to a flow table with two rows does not impose critical race problems. A flow table with three rows requires an assignment of two binary variables. The assignment of binary values to the stable states may cause critical races if not done properly. consider the following flow table. Inspection of row a reveals that there is a transition from state a to state b in column 01 and from state a to c in column 11. To avoid critical races, we must find a binary state assignment such that only one binary variable changes 92
93
during each state transition
during each state transition. An attempt to find such assignment is that, state a is assigned binary 00 and state c is assigned 11. 93
94
Three-Row Flow-Table Example
00 01 11 This assignment will cause a critical race during the transition from a to c. 94
95
A race free state assignment can be obtained if we add an extra row to the flow table. The use of fourth row does not increase the number of binary state variables, but it allows the formation of cycles between two state tables. The first 3 rows represent the same conditions as the original 3-row table. The fourth row, labeled d, is assigned the binary value 10, adjacent to both a and c. The transition from a to c must now go through d, with the result that the binary variables change from a to d to c, this avoiding a critical race. This is accomplished by changing row a, column 11 to d and row d, column 11 to c. similarly, the transition from c to a should go through unstable state d even though column 00 constitutes a non critical race. 95 95
96
Three-Row Flow-Table Example
00 01 11 10 The transition from a to c must now go through d, thus avoiding a critical race. 96 96
97
MULTIPLE-ROW METHOD In multiple row assignment, each state in the original flow table is replaced by two or more combinations of state variables. There are 2 binary state variables for each stable state, each being the logical complement of each other. For example, the original state a is replaced with 2 equivalent states a1=000 and a2=111. Note that a1 is adjacent to b1, c2 and d1 and a2 is adjacent to c1, b2 and d2, and similarly each state is adjacent to 3 states of different letter designation. 97 97
98
Multiple-Row Method In the multiple-row assignment, each state in the original flow table is replaced by two or more combinations of state variables. Note that a2 is adjacent to d2, c1, b2. 98 98
99
The expanded table is formed by replacing each row of the original table with 2 rows. For eg, row b is replaced by rows b1 and b2 and stable state b is entered in columns 00 and 11 in both the rows b1 and b2. After all the stable states have been entered, the unstable states are filled in by reference to the assignment specified in the map. When choosing the next state for a given present state, a state that is adjacent to the present state is selected from the map. In the original table, the next states of b are a and d for the inputs 10 and 01, respectively. In the expanded table, the next states for b2 are a2 and d1 because they are adjacent to b2. 99 99
100
The original flow table
Multiple-Row Method The original flow table 100 100
101
ONE HOT STATE ASSIGNMENT The one hot state assignment is an another method for finding a race free state assignment In this method, only one variable is active or ‘hot’ for each row in the original flow table, i.e. it requires one state variable changes between internal state transitions. Consider a flow table. 101 101
102
4 state variables are used to represent the 4 rows in the table.
Flow table: State variables State Inputs X1 X2 F4 F3 F2 F1 00 01 11 10 1 A B C D 4 state variables are used to represent the 4 rows in the table. Each row is represented by a case where only one of the 4 state variables is a 1. A transition from state A to state B requires 2 state variable changes; F1 from 1 to 0 and F2 from 0 to 1. By directing the transition from A to B through a new row E which contains 1s where both states A and B have 1s. 102 102
103
We require only one state variable change from transition A to E and then from transition E to B. This permits the race free transition between A and B. In general, we can say that, in row I of the table, state variable Fi is 1 and all other state variables are 0. When a transition between row i and j is required, first state variable Fj is set to 1 and Fi is set to 0. Thus each transition between 2 rows in the flow table goes through one intermediate row. This permits the race free transition but requires 2 state transitions. The following table is the complete one hot state assignment flow table. 103 103
104
State variables State Inputs X1 X2 F4 F3 F2 F1 00 01 11 10 1 A B C D 1 E A B - C G H D I F When X1 X2=01 the transition from A to B is passing through the dummy state E. Similarly, when X1X2=00 the transition from C to A is passing through the dummy state F and so on. 104 104
105
Guidelines for State Assignment
To try all equivalent state assignments, i.e., and exhaustive exploration of all possible state assignments is a n-p complete problem. Do not panic!!! (where does this come from?) There are guidelines that help 1. States which have the same next state for a given input should be given adjacent assignments. 2. States which are the next states of the same state should be given adjacent assignments. And third 3. States which have the same output for a given input should be given adjacent assignments. 105 105
106
Hazards Hazards definition. Hazards in combinational circuit
Hazards Hazards definition. Hazards in combinational circuit static hazard dynamic hazard Hazard free circuit. Hazards in sequential circuit Essential hazards 106 106
107
Hazards Hazards are unwanted switching transients that may appear at the output of a circuit because different paths exhibit different propagation delays. Hazards occur in combinational circuits, where they may cause a temporary false-output value. When hazards occur in sequential circuits, it may result in a transition to a wrong stable state. 107
108
Hazards in Combinational Circuits
F1 F2 108
109
-> Assume that all the three inputs are initially equal to 1
-> Assume that all the three inputs are initially equal to 1. This causes the output of the gate 1 to be 1, that of gate 2 to be 0, and the output of the circuit to be equal to 1. -> Now consider a change of x2 from 1 to 0. The output of gate 1 changes to 0 and that of gate 2 changes to 1, leaving the output at > However, the output may momentarily go to 0 if the propagation delay through the inverter is taken into consideration. -> The delay in the inverter may cause the output of gate 1 to change to 0 before the output of gate 2 changes to 1. 109
110
-> In that case, both inputs of gate 3 are momentarily equal to 0, causing the output to go to 0 for short interval of time that the input signal from x2 is delayed while it is propagating through the inverter circuit. -> If the circuit is implemented in SOP, Y=x1 x2+x2’ x3 This type of implementation may cause the output to go to 0 when it should remain at 1. This type is called as static 1-hazard. -> If the circuit is Implemented in POS, Y=(x1+x2’) (x2+x3) Then the output may momentarily go to 1 when it should remain 0. This type is called as static 0- hazard. -> A third type of hazard, known as dynamic hazard, causes the output to change three or more times when it should change from 1 to 0 or from 0 to 1. 110
111
Hazards in Combinational Circuits
111
112
Hazards in Combinational Circuits
The hazard exists because the change of input results in a different product term covering the two minterms. 112
113
In the above K-map, the change in x2 from 1 to 0 moves the circuit from minterm 111 to minterm 101. The hazard exists because the change of input results in a different product term covering the two min terms. Min term 111 is covered by the product term implemented in gate whenever the circuit must move from one product term to another, there is a possibility of a momentary interval when neither term is equal to 1, giving rise to an undesirable 0 output. 113
114
Eliminating hazards The remedy for eliminating hazard is to enclose the two minterms in question with another product term the overlap both the groupings. This is shown in the following K-map, where two min terms that cause the hazard are combined into one product term. 114
115
Hazards in Combinational Circuits
The remedy for eliminating a hazard is to enclose the two minterms in question with another product term that overlap both grouping. 115
116
HAZARD FREE CIRCUIT The following circuit is the hazard free circuit
HAZARD FREE CIRCUIT The following circuit is the hazard free circuit. The extra gate in the circuit generates the product term x1 x3. In general hazards in combinational circuits can be eliminated covering any two minterms that may produce a hazard with a product term common to both. The removal of hazard requires the addition of redundant gates to the circuit. 116
117
Hazards in Combinational Circuits
117
118
Prob: Give hazard-free realization for the following Boolean function
Prob: Give hazard-free realization for the following Boolean function. f(A,B,C,D)=m(0,2,6,7,8,10,12) Soln: The given function can be implemented using K-map. 00 01 11 10 00 01 11 10 00 1 00 1 01 01 11 11 10 10 f= B’D’+A’BC+AC’D’+A’CD’ f= B’D’+A’BC+AC’D’ 118
119
A A’ B B’ C C’ D D’ f 119
120
HAZARDS IN SEQUENTIAL CIRCUITS
120
121
ESSENTIAL HAZARDS There is another type of hazard that may occur in asynchronous sequential circuits, called essential hazard. An essential hazard is caused by unequal delays along two or more paths that originate from the same input. An excessive delay through an inverter circuit in comparison to the delay associated with the feedback path may cause such a hazard. Essential hazards cannot be corrected by adding redundant gated as in static hazards. The problem that they impose can be corrected by adjusting the amount of delay in the affected path. 121
122
To avoid essential hazards, each feedback loop must be handled with individual care to ensure that the delay in feedback path is long enough compared to delays of other signals that originate from the input terminals. This problem tends to be specialized, as it depends on the particular circuit used and the amount of delays that atr encountered in its various paths. 122
123
Essential hazards A critical race between an input signal change and a feedback signal change – may cause an incorrect state transition Incorrect behaviour depends upon specific delays in gates/interconnections “If from any stable state, the final state reached after one change in an input is different to that reached after three changes in that input, then an essential hazard exists” 123 123
124
Essential hazards Starting from PRY1Y2 = 1010
The final state can be 00 or 01 for one or three changes in P But, depending upon circuit delays, a single change in P may cause an incorrect transition to state 01 What circuit delays? We must ensure that input signal delays are smaller than feedback signal delays. 124 124
125
Essential hazards Buffer delay increased here
Essential hazards are inherent in the original flow table - they cannot be ‘designed out’ except at the circuit/physical level. 125 125 125
126
ELIMINATING ESSENTIAL HAZARDS We can avoid essential hazards in asynchronous circuits by implementing them using SR latches. A momentary 0 signal applied to the S or R inputs of a NOR latch will have no effect on the state of the circuit. Similarly, a momentary 1 signal is applied to the S and R inputs of a NAND latch will have no effect on the state of the latch. Let us consider a NAND SR latch with the following Boolean function: S= AB+CD R= A’C 126 126
127
A B Q C D A’ C Q’ The first level consists of NAND gates that implement each product term in the original Boolean expression of S and R. The second level forms the cross coupled connection of the SR latch with the inputs that come from the outputs of each NAND gate in the first level. 127 127
128
Essential hazard elimination
x Y1 y1 D1 y1’ Y2 D2 y2 x Essential hazard elimination 128 128
129
Flow table: Present state Next state (Y1 Y2) y1 y2 x=0 x=1 00 01 11
129 129
130
Hardware Description Language - Introduction
HDL is a language that describes the hardware of digital systems in a textual form. It resembles a programming language, but is specifically oriented to describing hardware structures and behaviors. The main difference with the traditional programming languages is HDL’s representation of extensive parallel operations whereas traditional ones represents mostly serial operations. The most common use of a HDL is to provide an alternative to schematics. 130
131
HDL – Introduction (2) When a language is used for the above purpose (i.e. to provide an alternative to schematics), it is referred to as a structural description in which the language describes an interconnection of components. Such a structural description can be used as input to logic simulation just as a schematic is used. Models for each of the primitive components are required. If an HDL is used, then these models can also be written in the HDL providing a more uniform, portable representation for simulation input. 131
132
Logic Simulation A simulator interprets the HDL description and produces a readable output, such as a timing diagram, that predicts how the hardware will behave before its is actually fabricated. Simulation allows the detection of functional errors in a design without having to physically create the circuit. 132
133
Verilog - Module A module is the building block in Verilog.
It is declared by the keyword module and is always terminated by the keyword endmodule. Each statement is terminated with a semicolon, but there is no semi-colon after endmodule. 133
134
Verilog – Module (2) HDL Example module smpl_circuit(A,B,C,x,y);
input A,B,C; output x,y; wire e; and g1(e,A,B); not g2(y,C); or g3(x,e,y); endmodule 134
135
Verilog – Module (4) //Description of circuit with delay
module circuit_with_delay (A,B,C,x,y); input A,B,C; output x,y; wire e; and #(30) g1(e,A,B); or #(20) g3(x,e,y); not #(10) g2(y,C); endmodule 135
136
Verilog – Module (5) In order to simulate a circuit with HDL, it is necessary to apply inputs to the circuit for the simulator to generate an output response. An HDL description that provides the stimulus to a design is called a test bench. The initial statement specifies inputs between the keyword begin and end. Initially ABC=000 (A,B and C are each set to 1’b0 (one binary digit with a value 0). $finish is a system task. 136
137
Verilog – Module (7) Bitwise operators Bitwise NOT : ~ Bitwise AND: &
Bitwise OR: | Bitwise XOR: ^ Bitwise XNOR: ~^ or ^~ 137
138
Verilog – Module (8) Boolean Expressions:
These are specified in Verilog HDL with a continuous assignment statement consisting of the keyword assign followed by a Boolean Expression. The earlier circuit can be specified using the statement: assign x = (A&B)|~C) E.g. x = A + BC + B’D y = B’C + BC’D’ 138
139
Verilog – Module (9) //Circuit specified with Boolean equations
module circuit_bln (x,y,A,B,C,D); input A,B,C,D; output x,y; assign x = A | (B & C) | (~B & C); assign y = (~B & C) | (B & ~C & ~D); endmodule 139
140
Verilog – Module (10) User Defined Primitives (UDP):
The logic gates used in HDL descriptions with keywords and, or,etc., are defined by the system and are referred to as system primitives. The user can create additional primitives by defining them in tabular form. These type of circuits are referred to as user-defined primitives. 140
141
Verilog – Module (14) A module can be described in any one (or a combination) of the following modeling techniques. Gate-level modeling using instantiation of primitive gates and user defined modules. This describes the circuit by specifying the gates and how they are connected with each other. Dataflow modeling using continuous assignment statements with the keyword assign. This is mostly used for describing combinational circuits. Behavioral modeling using procedural assignment statements with keyword always. This is used to describe digital systems at a higher level of abstraction. 141
142
4-bit Half Adder 142
143
4-bit Full Adder 143
144
4-bit Full Adder //Gate-level hierarchical description of 4-bit adder
module halfadder (S,C,x,y); input x,y; output S,C; //Instantiate primitive gates xor (S,x,y); and (C,x,y); endmodule module fulladder (S,C,x,y,z); input x,y,z; wire S1,D1,D2; //Outputs of first XOR and two AND gates //Instantiate the half adders halfadder HA1(S1,D1,x,y), HA2(S,D2,S1,z); or g1(C,D2,D1); 144
145
4-bit Full Adder module _4bit_adder (S,C4,A,B,C0); input [3:0] A,B;
input C0; output [3:0] S; output C4; wire C1,C2,C3; //Intermediate carries //Instantiate the full adder fulladder FA0 (S[0],C1,A[0],B[0],C0), FA1 (S[1],C2,A[1],B[1],C1), FA2 (S[2],C3,A[2],B[2],C2), FA3 (S[3],C4,A[3],B[3],C3); endmodule 145
146
2 to 4 Decoder 146
147
2 to 4 Decoder //Gate-level description of a 2-to-4-line decoder
module decoder_gl (A,B,E,D); input A,B,E; output[0:3]D; wire Anot,Bnot,Enot; not n1 (Anot,A), n2 (Bnot,B), n3 (Enot,E); nand n4 (D[0],Anot,Bnot,Enot), n5 (D[1],Anot,B,Enot), n6 (D[2],A,Bnot,Enot), n7 (D[3],A,B,Enot); endmodule 147
148
2-to-4 Line Decoder 148
149
2-to-4 Line Decoder //2 to 4 line decoder
module decoder_2_to_4_st_v(E_n, A0, A1, D0_n, D1_n, D2_n, D3_n); input E_n, A0, A1; output D0_n, D1_n, D2_n, D3_n; wire A0_n, A1_n, E; not g0(A0_n, A0), g1(A1_n, A1), g2(E,E_n); nand g3(D0_n,A0_n,A1_n,E), g4(D1_n,A0,A1_n,E), g5(D2_n,A0_n,A1,E), g6(D3_n,A0,A1,E); endmodule 149
150
Three-State Gates 150
151
Three-State Gates Three-state gates have a control input that can place the gate into a high-impedance state. (symbolized by z in HDL). The bufif1 gate behaves like a normal buffer if control=1. The output goes to a high-impedance state z when control=0. bufif0 gate behaves in a similar way except that the high-impedance state occurs when control=1 Two not gates operate in a similar manner except that the o/p is the complement of the input when the gate is not in a high impedance state. The gates are instantiated with the statement gate name (output, input, control); 151
152
Three-State Gates The output of 3-state gates can be connected together to form a common output line. To identify such connections, HDL uses the keyword tri (for tri-state) to indicate that the output has multiple drivers. module muxtri(A,B,sel,out); input A,B,sel; output OUT; tri OUT; bufif1 (OUT,A,sel); bufif0 (OUT,B,sel); endmodule 152
153
Three-State Gates Keywords wire and tri are examples of net data type.
Nets represent connections between hardware elements. Their value is continuously driven by the output of the device that they represent. The word net is not a keyword, but represents a class of data types such as wire, wor, wand, tri, supply1 and supply0. The wire declaration is used most frequently. The net wor models the hardware implementation of the wired-OR configuration. The wand models the wired-AND configuration. The nets supply1 and supply0 represent power supply and ground. 153
154
Writing a Test Bench (2) initial begin A=0; B=0; #10 A=1; #20 A=0; B=1; end The block is enclosed between begin and end. At time=0, A and B are set to time units later, A is changed to time units later (at t=30) a is changed to 0 and B to 1. 154
155
Writing a Test Bench (2) Inputs to a 3-bit truth table can be generated with the initial block initial begin D = 3’b000; repeat (7); #10 D = D + 3’b001; end The 3-bit vector D is initialized to 000 at time=0. The keyword repeat specifies looping statement: one is added to D seven times, once every 10 time units. 155
156
2-to-4 Line Decoder – Data flow description
module dec_2_to_4_df(E_n,A0,A1,D0_n,D1_n,D2_n,D3_n); input E_n, A0, A1; output D0_n,D1_n,D2_n,D3_n; assign D0_n=~(~E_n&~A1&~A0); assign D1_n=~(~E_n&~A1& A0); assign D2_n=~(~E_n& A1&~A0); assign D3_n=~(~E_n& A1& A0); endmodule 156
157
4-to-1 Multiplexer 157
158
4-to-1 Multiplexer //4-to-1 Mux: Structural Verilog
module mux_4_to_1_st_v(S,D,Y); input [1:0]S; input [3:0]D; output Y; wire [1:0]not_s; wire [0:3]N; not g0(not_s[0],S[0]),g1(not_s[1],S[1]); and g2(N[0],not_s[0],not_s[1],D[0]), g3(N[1],S[0],not_s[1],D[0]), g4(N[2],not_s[0],S[1],D[0]), g5(N[3],S[0],S[1],D[0]); or g5(Y,N[0],N[1],N[2],N[3]); endmodule 158
159
4-to-1 Multiplexer – Data Flow
//4-to-1 Mux: Dataflow description module mux_4_to_1(S,D,Y); input [1:0]S; input [3:0]D; output Y; assign Y = (~S[1]&~S[0]&D[0])|(~S[1]&S[0]&D[1]) |(S[1]&~S[0]&D[2])|(S[1]&S[0]&D[3]); endmodule //4-to-1 Mux: Conditional Dataflow description module mux_4_to_1(S,D,Y); input [1:0]S; input [3:0]D; output Y; assign Y = (S==2’b00)?D[0] : (S==2’b01)?D[1] : (S==2’b10)?D[2] : (S==2’b11)?D[3]:1’bx;; endmodule 159
160
4-to-1 Multiplexer //4-to-1 Mux: Dataflow Verilog Description
module mux_4_to_1(S,D,Y); input [1:0]S; input [3:0]D; output Y; assign Y=S[1]?(S[0]?D[3]:D[2]):(S[0]?D[1]:D[0]); endmodule 160
161
HDL for Sequential Circuits
161
162
Lecture Outline Latches and Flip-flops Counters and Registers 162
163
Gated D Latch module D_latch (Q,D,control); output Q; input D,control;
reg Q; (control or D) if (control) Q = D; //Same as: if (control = 1) endmodule 163
164
D Flip-flop module D_FF (Q,D,CLK); output Q; input D,CLK; reg Q;
(posedge CLK) Q = D; endmodule 164
165
Testing Flip-flops Need to have flip-flop in known state at start of test Add reset input module DFF (Q,D,CLK,RST); output Q; input D,CLK,RST; reg Q; CLK or negedge RST) if (~RST) Q = 1'b0; // Same as: if (RST = 0) else Q = D; endmodule 165
166
T Flip-flop from D type Characteristic Equation
module TFF (Q,T,CLK,RST); output Q; input T,CLK,RST; wire DT; assign DT = Q ^ T ; //Instantiate the D flip-flop DFF TF1 (Q,DT,CLK,RST); endmodule 166
167
JK Flip-flop from D type
Characteristic Equation module JKFF (Q,J,K,CLK,RST); output Q; input J,K,CLK,RST; wire JK; assign JK = (J & ~Q) | (~K & Q); //Instantiate D flipflop DFF JK1 (Q,JK,CLK,RST); endmodule 167
168
Ripple Counter module ripplecounter(count, reset, A0, A1, A2, A3);
input count; input reset; output A0, A1, A2, A3; TFF T0(count, reset, A0); TFF T1(A0, reset, A1); TFF T2(A1, reset, A2); TFF T3(A2, reset, A3); endmodule 168
169
T Flip-flop module TFF (T,RST,Q); input T, RST; output Q; reg Q;
T or posedge RST) begin if (RST) begin Q = 1'b0; end else begin #2 Q = ~Q; endmodule 169
170
Binary Counter module counter (Count,Load,IN,CLK,Clr,A,CO);
input Count,Load,CLK,Clr; input [3:0] IN; //Data input output CO; //Output carry output [3:0] A; //Data output reg [3:0] A; assign CO = Count & ~Load & (A == 4'b1111); (posedge CLK or negedge Clr) if (~Clr) A = 4'b0000; else if (Load) A = IN; else if (Count) A = A + 1'b1; else A = A; // no change endmodule 170
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.