Part3
Part3
Course contents
R.Lauwereins
Imec 2001
Digital
• Digital design
design
• Combinatorial circuits: without status
Combina-
torial
➔Sequential circuits: with status
circuits
• FSMD design: hardwired processors
Sequential
circuits
• Language based HW design: VHDL
FSMD
design
VHDL
3/1
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
• Basic RTL building blocks
FSMD
design
VHDL
3/2
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
➔The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
• Basic RTL building blocks
FSMD
design
VHDL
3/3
©
Digital
• Definitions:
design
❑ Combinatorial circuit: the output is function of
Combina-
the current value of the inputs
torial
circuits
❑ Sequential circuit: the output is function of the
current value of the inputs and of the current
Sequential state (i.e. also function of the sequence of past
circuits
inputs)
FSMD
design
VHDL
3/4
©
Digital
• Definitions
design
❑ Asynchronous sequential circuits: outputs and
Combina-
state change as soon as an input changes
torial
circuits
❑ Synchronous sequential circuits: outputs and
state change only when a special input, the
Sequential clock, gets a certain value
circuits
❑ Clock period: duration between two
FSMD consecutive 1→0 transitions of the clock
design
❑ Clock frequency: 1 / (clock period)
VHDL ❑ Duty cycle: (duration that the clock equals 1) /
(clock period)
❑ Rising edge: 0→1 transition of the clock
❑ Falling edge: 1→0 transition of the clock
3/5
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
❑ SR Latch
Combina- ❑ Gated SR Latch
torial
circuits ❑ Gated D Latch
❑ Flip-flop sensitivity
Sequential
circuits ❑ Flip-flop types
FSMD • Design of synchronous sequential
design
circuits
VHDL • Design of asynchronous sequential
circuits
• Basic RTL building blocks
3/6
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
SR Latch
Combina- ❑ Gated SR Latch
torial
circuits ❑ Gated D Latch
❑ Flip-flop sensitivity
Sequential
circuits ❑ Flip-flop types
FSMD • Design of synchronous sequential
design
circuits
VHDL • Design of asynchronous sequential
circuits
• Basic RTL building blocks
3/7
©
SR Latch
R.Lauwereins
Imec 2001
Digital S R Q(next)
design
Set Q’ 0 0 Q
Combina- 0 1 0
torial
circuits
1 0 1
1 1 NA
Sequential Reset Q
circuits
FSMD
design
S
VHDL
Q’
Undefined
3/8
©
SR Latch
R.Lauwereins
Imec 2001
Digital
• Note that a Boolean signal now already
design
consists of 5 values:
Combina- ❑ 0: the logical signal “0”
torial
circuits ❑ 1: the logical signal “1”
❑ x: don’t care
Sequential
circuits ❑ Z: high impedant
❑ U: undefined
FSMD
design
• The oscillation is called critical race
VHDL • The oscillation only happens when the
delay of both gates is exactly equal
• When the delays are not equal, the fastest
gates determines the end result:
implementation and run-time dependent
undefined
3/9
©
SR Latch
R.Lauwereins
Imec 2001
Digital S R Q(next)
design
Set Q 1 1 Q
Combina- 1 0 0
torial
circuits
0 1 1
0 0 NA
Sequential Reset Q’
circuits Set and Reset active low
FSMD
design
S
VHDL
Q’
3/10
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
❑ SR Latch
Combina- Gated SR Latch
torial
circuits ❑ Gated D Latch
❑ Flip-flop sensitivity
Sequential
circuits ❑ Flip-flop types
FSMD • Design of synchronous sequential
design
circuits
VHDL • Design of asynchronous sequential
circuits
• Basic RTL building blocks
3/11
©
Gated SR Latch
R.Lauwereins
Imec 2001
Digital
design Set C=1: follow inputs
Q’ C=0: latch outputs
Combina-
torial
circuits Clock
Sequential
circuits
Q
Reset
FSMD
design
C S R Q(next)
0 0 0 Q
VHDL
0 0 1 Q
0 1 0 Q
0 1 1 Q
1 0 0 Q
1 0 1 0
1 1 0 1
1 1 1 NA
3/12
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
❑ SR Latch
Combina- ❑ Gated SR Latch
torial
circuits Gated D Latch
❑ Flip-flop sensitivity
Sequential
circuits ❑ Flip-flop types
FSMD • Design of synchronous sequential
design
circuits
VHDL • Design of asynchronous sequential
circuits
• Basic RTL building blocks
3/13
©
Gated D Latch
R.Lauwereins
Imec 2001
3/14
©
Gated D Latch
R.Lauwereins
Imec 2001
D
C
S
D’
R
3/15
©
Gated D Latch
R.Lauwereins
Imec 2001
D
C
S
D’
R
3/16
©
Gated D Latch
R.Lauwereins
Imec 2001
Symbol
Given values:
D Q
5.2=C to QL→H
5.2/3.8 3.8=C to QH→L
C Q’
3/17
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
❑ SR Latch
Combina- ❑ Gated SR Latch
torial
circuits ❑ Gated D Latch
❑ Flip-flop sensitivity
Sequential
circuits Level-sensitive latch
FSMD Master-slave flip-flop
design
Edge-triggered flip-flop
VHDL
❑ Flip-flop types
• Design of synchronous sequential
circuits
• Design of asynchronous sequential
circuits
• Basic RTL building blocks
3/18
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
❑ SR Latch
Combina- ❑ Gated SR Latch
torial
circuits ❑ Gated D Latch
❑ Flip-flop sensitivity
Sequential
circuits ➔Level-sensitive latch
FSMD Master-slave flip-flop
design
Edge-triggered flip-flop
VHDL
❑ Flip-flop types
• Design of synchronous sequential
circuits
• Design of asynchronous sequential
circuits
• Basic RTL building blocks
3/19
©
Digital
• All previous gated latches are level
design
sensitive
Combina- ❑ Transparent when clock is high
torial
circuits ❑ Remembering the last value when clock is low
Sequential
• Level sensitive latches give problems for
circuits shift registers for example
FSMD ❑ The input signal may ripple through multiple
design stages during one clock-high phase
VHDL
❑ making it very hard to meet setup/hold time
requirements
❑ See next slide
3/20
©
X Y
Digital
design
D Q1 D Q2 D Q3
4/3 4/3 4/3
Combina- C C C
torial
circuits Clk
Sequential
circuits
Clk
FSMD
design
X
VHDL Q1
Q2
Q3
Two solutions:
• Master-slave
• Edge-triggered
3/21
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
❑ SR Latch
Combina- ❑ Gated SR Latch
torial
circuits ❑ Gated D Latch
❑ Flip-flop sensitivity
Sequential
circuits Level-sensitive latch
FSMD ➔Master-slave flip-flop
design
Edge-triggered flip-flop
VHDL
❑ Flip-flop types
• Design of synchronous sequential
circuits
• Design of asynchronous sequential
circuits
• Basic RTL building blocks
3/22
©
Master-slave flip-flop
R.Lauwereins
Imec 2001
Sequential
circuits
Clk
FSMD
design X
VHDL Qm1
Q1
Qm2
Y
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
❑ SR Latch
Combina- ❑ Gated SR Latch
torial
circuits ❑ Gated D Latch
❑ Flip-flop sensitivity
Sequential
circuits Level-sensitive latch
FSMD Master-slave flip-flop
design
➔Edge-triggered flip-flop
VHDL
❑ Flip-flop types
• Design of synchronous sequential
circuits
• Design of asynchronous sequential
circuits
• Basic RTL building blocks
3/24
©
Edge-triggered flip-flop
R.Lauwereins
Imec 2001
VHDL Clk
D
B
A
R
S
3/25
Q
©
Sequential Circuits
R.Lauwereins
Imec 2001
Sequential Circuits
R.Lauwereins
Imec 2001
SR flip-flop
R.Lauwereins
Imec 2001
Sequential Circuits
R.Lauwereins
Imec 2001
JK flip-flop
R.Lauwereins
Imec 2001
VHDL
Excitation table
(for design with JK flip-flop)
Q Q(next) J K
Circuits that use 0 0 0 x
JK flip-flops are cheaper 0 1 1 x
than those using SR flip-flops: 1 0 x 1
more don’t cares
1 1 x 0
3/30
©
Sequential Circuits
R.Lauwereins
Imec 2001
D flip-flop
R.Lauwereins
Imec 2001
FSMD
design
VHDL
Excitation table
(for design with D flip-flop)
Q Q(next) D
Designing with D flip-flop 0 0 0
is easy 0 1 1
1 0 0
1 1 1
3/32
©
Sequential Circuits
R.Lauwereins
Imec 2001
T flip-flop
R.Lauwereins
Imec 2001
FSMD
design
VHDL
Excitation table
(for design with T flip-flop)
T D Q Q Q(next) T
Clk 0 0 0
0 1 1
Q’
1 0 1
1 1 0
3/34
©
Sequential Circuits
R.Lauwereins
Imec 2001
Preset
Digital
design A
Combina-
torial Set
circuits Q
Clk
Sequential
circuits Reset
Q’
FSMD
design B
D
VHDL
Clear
PRS
D Q
Asynchronous set and reset are
useful to put the flip-flop Clk Q’
initially in a known state
CLR
(see lab sessions)
3/36
©
Digital
• Why are the asynchronous preset and
design
clear connected to both layers of SR-flip-
Combina- flops?
torial
circuits ❑ The first layer passes input modifications to
the second layer only at the rising clock edge
Sequential
circuits ❑ The second layer reacts immediately, without
waiting for the rising clock edge => needed for
FSMD asynchronous reaction
design
❑ If they were only connected to the second
VHDL layer, the first layer would not know in what
state the second layer was put and could give a
conflicting command to the second layer at the
next rising clock edge, e.g. reset since D=0 and
at the same time an asynchronous preset
3/37
©
Digital
• Why are the asynchronous preset and
design
clear active low?
Combina- ❑ Because ‘wired-or’ of ‘open drain’ circuits is
torial
circuits
used to avoid short circuits when there are
multiple sources driving them:
Sequential
circuits
R
Open
FSMD
design
No No drain
preset preset
VHDL Implements an AND
function (hence
‘wired-or’ ...) with
unlimited number of
inputs:
preset preset The bus is only ‘1’
when all inputs to
the bus are equal to
3/38
‘1’
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
➔Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
• Basic RTL building blocks
FSMD
design
VHDL
3/39
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits ❑ Finite State Machine (FSM)
Sequential
❑ State-based or Moore-type FSM
circuits
❑ Input-based or Mealy-type FSM
FSMD ❑ Step 1: State diagram
design
❑ Step 2: State minimization
VHDL ❑ Step 3: State encoding
❑ Step 4: Choice of the flip-flop type
❑ Step 5: Realization of the combinatorial logic
❑ Step 6: Timing analysis
• Design of asynchronous sequential
circuits
3/40 • Basic RTL building blocks
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits Finite State Machine (FSM)
Sequential
❑ State-based or Moore-type FSM
circuits
❑ Input-based or Mealy-type FSM
FSMD ❑ Step 1: State diagram
design
❑ Step 2: State minimization
VHDL ❑ Step 3: State encoding
❑ Step 4: Choice of the flip-flop type
❑ Step 5: Realization of the combinatorial logic
❑ Step 6: Timing analysis
• Design of asynchronous sequential
circuits
3/41 • Basic RTL building blocks
©
Digital
• Design a modulo 4 “Counter”, that counts
design
when the input “CE” (Count Enable)
Combina- equals 1 and stops counting when the
torial
circuits input “CE” equals 0.
Sequential
• Step 1: translate to a Finite State
circuits Machine (FSM):
CE=0 CE=0
FSMD
design CE=1
Count=0 Count=1
VHDL
CE=1 CE=1
CE=1
3/42
©
Finite State Machine
Transition to the next state happens at each rising clock
R.Lauwereins
Imec 2001
edge (a synchronous FSM is clocked!).
At each rising clock edge, exactly one transition condition
should be true: for each input combination, a transition
Digital
design should be specified in each of the states.
CE=0 CE=0
Combina-
torial CE=1
circuits Count=0 Count=1
Sequential
circuits
CE=1 CE=1
FSMD
design
CE=0 Count=3 Count=2 CE=0
VHDL
CE=1
Digital
• Step 2: Minimise the number of states.
design
It is already the minimum number.
Combina- • Step 3: Encode the states:
torial
circuits
Sequential
circuits
CE=0 CE=0
FSMD CE=1
design
Q1Q0=00 Q1Q0=01
VHDL
CE=1 CE=1
CE=1
3/44
©
Digital
• Step 4: Select the flip-flop type. We select
design
the D type for its simplicity.
Combina- • Step 5: Realise the circuit. See next
torial
circuits slides:
Sequential
circuits
FSMD
design
VHDL
3/45
©
Digital
• Translate the FSM in a next-state table:
design
CE=0 CE=0
Combina-
torial CE=1
circuits
Q1Q0=00 Q1Q0=01
Sequential
circuits CE=1 CE=1
FSMD
design CE=0 Q1Q0=11 Q1Q0=10 CE=0
CE=1
VHDL
Excitation table
VHDL
for D flip-flop Q0 Q0
Q Q(next) D Q1n=D1 Q1 Q0n=D0 Q1
0 0 0
0 1 1 0 0 1 1 0 1 1 0
1 0 0 CE 0 1 0 1 CE 1 0 0 1
1 1 1
D to be applied
3/47 is identical to Qn
©
Digital
• Implement:
design
Q0 Q0
Combina-
torial Q1n=D1 Q1 Q0n=D0 Q1
circuits
0 0 1 1 0 1 1 0
Sequential
circuits CE 0 1 0 1 CE 1 0 0 1
FSMD CE Q1 Q0
design
Q1
VHDL Q1n
D1
Q’
Q0
Q0n
D0
Q’
3/48
©
Digital
• Step 6: Timing analysis
design CE Q1 Q0
Combina-
Q1
torial
Q1n
circuits
D1
Q’
Sequential
circuits
Q0
Q0n
FSMD D0
design
Q’
VHDL
Clk
CE
Q1
Q0
3/49
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits ❑ Finite State Machine (FSM)
Sequential
State-based or Moore-type FSM
circuits
❑ Input-based or Mealy-type FSM
FSMD ❑ Step 1: State diagram
design
❑ Step 2: State minimization
VHDL ❑ Step 3: State encoding
❑ Step 4: Choice of the flip-flop type
❑ Step 5: Realization of the combinatorial logic
❑ Step 6: Timing analysis
• Design of asynchronous sequential
circuits
3/50 • Basic RTL building blocks
©
Digital
• Design a modulo 4 “Counter”, that counts
design
when the “CE” input equals 1 and stops
Combina- counting when “CE” equals 0. The output
torial
circuits “Y” equals 1 when the count value equals
3.
Sequential
circuits • Step 1: translate to FSM:
CE=0 CE=0
FSMD
design
Count=0 CE=1 Count=1
VHDL Y=0 Y=0
CE=1 CE=1
Digital
• Be extremely careful about timing issues!!
design
Assume that the Y output is used as a load-enable
Combina- for a register and as the add/subtract line for an
torial
circuits adder/subtractor: when arriving in state 3, Y
becomes 1, immediately causing the
Sequential
circuits adder/subtractor to switch to “subtract” mode, but
NOT causing the register to load a new value!!!
FSMD
design The loading will only occur at the next state
VHDL
transition (i.e. the next clock edge)
LE Clocked
Register Clk
CE
Counter
Add/Subtract Combinatorial
3/52 A/S’
©
Digital
• State-based:
design
❑ the output is indicated for each state
Combina- ❑ the output is only function of the current state,
torial
circuits
not of the inputs applied
❑ Hence, the output value is indicated in the
Sequential
circuits
circle representing the state
FSMD
design
VHDL
3/53
©
Digital
• Step 2: Minimise the number of states.
design
This is already the minimum number.
Combina- • Step 3: Encode the states:
torial
circuits
Sequential
circuits
CE=0 CE=0
FSMD
design Q1Q0=00 CE=1 Q1Q0=01
Y=0 Y=0
VHDL
CE=1 CE=1
3/54
©
Digital
• Step 4: Select the flip-flop type. We select
design
the D type for its simplicity.
Combina- • Step 5: Realise the circuit. See next
torial
circuits slides:
Sequential
circuits
FSMD
design
VHDL
3/55
©
Digital
• Translate the FSM in a next-state table:
design
CE=0 CE=0
Combina-
torial Q1Q0=00 CE=1 Q1Q0=01
circuits Y=0 Y=0
Sequential
circuits CE=1 CE=1
FSMD
design CE=0 Q1Q0=11 Q1Q0=10 CE=0
Y=1 Y=0
CE=1
VHDL
Digital
• Determine the excitation functions:
design
Present state Next state Outputs
Combina- Q1Q0 Q1nQ0n Y
torial
circuits CE=0 CE=1
00 00 01 0
Sequential
circuits
01 01 10 0
10 10 11 0
FSMD 11 11 00 1
design
Q0 Q0
Excitation table
VHDL
for D flip-flop Q1n=D1 Q1 Q0n=D0 Q1
Q Q(next) D 0 0 1 1 0 1 1 0
0 0 0
CE 0 1 0 1 CE 1 0 0 1
0 1 1
1 0 0
Q0
1 1 1 Y
0 0
D to be applied
3/57 is identical to Qn Q1 0 1
©
Digital
• Implement:
design
Q0 Q0
Combina-
torial Q1n=D1 Q1 Q0n=D0 Q1 Q0
circuits Y
0 0 1 1 0 1 1 0 0 0
Sequential
circuits CE 0 1 0 1 CE 1 0 0 1 Q1 0 1
FSMD CE Q1 Q0
design
Q1 Y
VHDL Q1n
D1
Q’
Q0
Q0n
D0
Q’
3/58
©
Digital
• Step 6: Timing analysis
design CE Q1 Q0
Combina-
Q1 Y
torial
Q1n
circuits
D1
Q’
Sequential
circuits
Q0
Q0n
FSMD D0
design
Q’
VHDL
Clk
CE
Q1 Danger for
Q0 Glitch!
3/59 Y
©
Digital
• Is a glitch harmful?
design
❑ When the output with the glitch is connected to
Combina-
the clock of some clocked circuit:
torial
circuits This clocked circuit will
unintentionally clock: harmful
Sequential
circuits
Hard to debug: glitch may disappear
FSMD when probe is connected due to
design
increased capacitance and hence
VHDL also increased delay
❑ When the output with the glitch is connected to
a combinatorial circuit that eventually is the
input of a register:
Not harmful, since the register looks
at its input only at the clock edge
Dissipates unnecessary power
3/60
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits ❑ Finite State Machine (FSM)
Sequential
❑ State-based or Moore-type FSM
circuits
Input-based or Mealy-type FSM
FSMD ❑ Step 1: State diagram
design
❑ Step 2: State minimization
VHDL ❑ Step 3: State encoding
❑ Step 4: Choice of the flip-flop type
❑ Step 5: Realization of the combinatorial logic
❑ Step 6: Timing analysis
• Design of asynchronous sequential
circuits
3/61 • Basic RTL building blocks
©
Digital
• Design a modulo 4 “Counter”, that counts
design
when the “CE” input equals 1 and stops
Combina- counting when “CE” equals 0. The “Y”
torial
circuits output value equals 1 when the count=3
while the input “CE” equals 1.
Sequential
circuits • Step 1: translate to FSM:
CE=0/Y=0 CE=0/Y=0
FSMD
design
CE=1/Y=0
Count=0 Count=1
VHDL
CE=1/Y=1 CE=1/Y=0
Sequential
circuits
CE=1/Y=1 CE=1/Y=0
FSMD
design
CE=0/Y=0 Count=3 Count=2 CE=0/Y=0
VHDL
CE=1/Y=0
Digital
• Be extremely careful about timing issues!!
design
Assume that the Y output is used as a load-enable
Combina- for a register and as the add/subtract line for an
torial
circuits adder/subtractor: when arriving in state 3 with
CE=1, Y becomes 1 adder/subtractor switches
Sequential
circuits to “subtract”, but register doesn’t load new
value!!! When CE=0, Y becomes 0
FSMD
design adder/subtractor switches to “add”, and LE=0.
VHDL
When the next clock edge comes while CE=0,
register will not load.
LE Clocked
Register Clk
CE
Counter
Add/Subtract Combinatorial
3/64 A/S’
©
Digital
• Input-based:
design
❑ the output is specified for each state and each
Combina-
combination of inputs in that state
torial
circuits
❑ the output is function of the current state, and
of the applied inputs
Sequential
circuits
❑ Hence the output is specified next to each
transition
FSMD
design
VHDL
3/65
©
Digital
• Step 2: Minimise the number of states.
design
This is already the minimum number.
Combina- • Step 3: Encode the states:
torial
circuits
Sequential
circuits
CE=0/Y=0 CE=0/Y=0
FSMD CE=1/Y=0
design
Q1Q0=00 Q1Q0=01
VHDL
CE=1/Y=1 CE=1/Y=0
3/66
©
Digital
• Step 4: Select the flip-flop type. We select
design
the D type for its simplicity.
Combina- • Step 5: Realise the circuit. See next
torial
circuits slides:
Sequential
circuits
FSMD
design
VHDL
3/67
©
Digital
• Translate FSM to next-state table:
design
CE=0/Y=0 CE=0/Y=0
Combina-
torial CE=1/Y=0
circuits
Q1Q0=00 Q1Q0=01
Sequential
circuits CE=1/Y=1 CE=1/Y=0
FSMD
design CE=0/Y=0 Q1Q0=11 Q1Q0=10 CE=0/Y=0
CE=1/Y=0
VHDL
Digital
• Determine the excitation functions:
design
Present state Next state/Outputs
Combina- Q1Q0 Q1nQ0n/Y
torial
circuits CE=0 CE=1
00 00/0 01/0
Sequential
circuits
01 01/0 10/0
10 10/0 11/0
FSMD 11 11/0 00/1
design Q0 Q0
Excitation table Q1n=D1 Q1 Q0n=D0 Q1
VHDL
for D flip-flop
Q Q(next) D 0 0 1 1 0 1 1 0
0 0 0 CE 0 1 0 1 CE 1 0 0 1
0 1 1 Q0
1 0 0 Y Q1
1 1 1
0 0 0 0
D to be applied
3/69 is identical to Qn CE 0 0 1 0
©
Digital
• Implement:
design
Q0 Q0 Q0
Combina-
torial Q1n=D1 Q1 Q0n=D0 Q1 Y Q1
circuits
0 0 1 1 0 1 1 0 0 0 0 0
Sequential
circuits CE 0 1 0 1 CE 1 0 0 1 CE 0 0 1 0
FSMD CE Q1 Q0
design
Q1 Y
VHDL Q1n
D1
Q’
Q0
Q0n
D0
Q’
3/70
©
Digital
• Step 6: Timing analysis
design CE Q1 Q0
Combina- Q1 Y
torial Q1n
circuits D1
Q’
Sequential
circuits
Q0
Q0n
FSMD D0
design Q’
VHDL
Clk
CE
Q1 Danger for
Q0 Glitch!
3/71 Y
©
R.Lauwereins
Imec 2001 State-based model
Next Current
Inputs I Clock
State S* State S
Digital
design
D Q
Combina-
torial Clk
circuits
Outputs
O
Sequential S*=F(S,I)
circuits D Q O=H(S)
Next Clk
FSMD Output
design State
Combi-
Combi-
nato-
VHDL nato-
rial
rial
Logic
Logic
D Q
Clk
3/72
©
R.Lauwereins
Imec 2001 Input-based model
Clock Next State S* Current
Inputs I State S
Digital
design
D Q
Combina-
torial Clk
circuits
Outputs
O
Sequential S*=F(S,I)
circuits D Q O=H(S,I)
Next Clk
FSMD Output
design State
Combi-
Combi-
nato-
VHDL nato-
rial
rial
Logic
Logic
D Q
Clk
3/73
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits ❑ Finite State Machine (FSM)
Sequential
❑ State-based or Moore-type FSM
circuits
❑ Input-based or Mealy-type FSM
FSMD Step 1: State diagram
design
❑ Step 2: State minimization
VHDL ❑ Step 3: State encoding
❑ Step 4: Choice of the flip-flop type
❑ Step 5: Realization of the combinatorial logic
❑ Step 6: Timing analysis
• Design of asynchronous sequential
circuits
3/74 • Basic RTL building blocks
©
Digital
• First step: is this a State-based or an
design
Input-based design?
Combina- ❑ It is Input-based, since the output depends on
torial
circuits
the state and the input
• Second step: construct the FSM starting
Sequential
circuits from the first state, for each combination
FSMD
of inputs from each state
design ❑ See next slide
VHDL
❑ Note: when an output needs to remain high
during several consecutive states, it should be
assigned a ‘high’ value in each of these states!!
Each output should be assigned a value in each
state!
3/76
©
CD=10
Y=1
Digital
design
CD=0X CD=0X CD=0X
Y=0 Y=0 Y=0
Combina-
torial CD=10 CD=10
circuits
u0 Y=0 u1 Y=0 u2
Sequential CD=10
circuits CD=10 Y=0 CD=11
Y=1 Y=0
FSMD
design
CD=10 CD=11
Y=0 Y=1
VHDL
CD=11
Y=0
d0 d1 d2
CD=11 CD=11
Y=0 Y=0
CD=0X CD=0X CD=0X
Y=0 Y=0 Y=0
CD=11
Y=1
3/77
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits ❑ Finite State Machine (FSM)
Sequential
❑ State-based or Moore-type FSM
circuits
❑ Input-based or Mealy-type FSM
FSMD ❑ Step 1: State diagram
design
Step 2: State minimization
VHDL ❑ Step 3: State encoding
❑ Step 4: Choice of the flip-flop type
❑ Step 5: Realization of the combinatorial logic
❑ Step 6: Timing analysis
• Design of asynchronous sequential
circuits
3/78 • Basic RTL building blocks
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• Goal: less states means less flip-flops
design
• Principal: equivalent behavior of two
Combina- FSMs
torial
circuits
• Two FSMs are equivalent when they
Sequential produce the same output sequence for
circuits
the same input sequence
FSMD
design
VHDL
3/79
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• Two states in an FSM may be replaced by
design
1 state when both states produce the
Combina- same outputs for the same inputs and
torial
circuits when both jump to equivalent next states
for the same inputs
Sequential
circuits • Formally: states sj and sk are equivalent
FSMD (sjsk) if and only if
design
❑ iI: h(sj,i)=h(sk,i): both states produce the
VHDL
same output for each combination of inputs
and
❑ iI: f(sj,i)f(sk,i): the next states are equivalent
for each input combination
3/80
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• In practice: build the next state table out
design
of the state diagram first
Combina- PRESENT NEXT STATE / OUTPUT
torial
circuits
STATE CD=0X CD=10 CD=11
u0 u0/0 u1/0 d2/1
Sequential u1 u1/0 u2/0 d0/0
circuits
u2 u2/0 u0/1 d1/0
FSMD d0 d0/0 u1/0 d2/1
design
d1 d1/0 u2/0 d0/0
d2 d2/0 u0/1 d1/0
VHDL
3/81
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• Construct the implication table: 1 square
design
per combination of 2 states
Combina- PRESENT NEXT STATE / OUTPUT
torial
circuits
STATE CD=0X CD=10 CD=11
u0 u0/0 u1/0 d2/1
Sequential u1 u1/0 u2/0 d0/0
circuits
u2 u2/0 u0/1 d1/0
FSMD d0 d0/0 u1/0 d2/1
design
d1 d1/0 u2/0 d0/0
u1 d2 d2/0 u0/1 d1/0
VHDL
u2
d0
d1
d2
u0 u1 u2 d0 d1
3/82
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• Construct the implication table: 1 square
design
per combination of 2 states
Combina-
torial
circuits
Sequential
circuits
s1
FSMD
design
s2
VHDL
s3
s4
s5
s6
s7
s0 s1 s2 s3 s4 s5 s6
3/83
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• Delete all combinations that have
design
different outputs for the same inputs
Combina- PRESENT NEXT STATE / OUTPUT
torial
circuits
STATE CD=0X CD=10 CD=11
u0 u0/0 u1/0 d2/1
Sequential u1 u1/0 u2/0 d0/0
circuits
u2 u2/0 u0/1 d1/0
FSMD d0 d0/0 u1/0 d2/1
design
d1 d1/0 u2/0 d0/0
u1 d2 d2/0 u0/1 d1/0
VHDL
u2
d0
d1
d2
u0 u1 u2 d0 d1
3/84
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• Indicate for the remaining which next
design
states have to be equivalent to make the
Combina- current states equivalent
torial
circuits PRESENT NEXT STATE / OUTPUT
STATE CD=0X CD=10 CD=11
Sequential
circuits u0 u0/0 u1/0 d2/1
u1 u1/0 u2/0 d0/0
FSMD u2 u2/0 u0/1 d1/0
design
d0 d0/0 u1/0 d2/1
u1 d1 d1/0 u2/0 d0/0
VHDL
d0 OK Minimum number
d1 OK of states: 3 ie.
{u0,d0}=s0
d2 OK {u1,d1}=s1
{u2,d2}=s2
u0 u1 u2 d0 d1
3/85
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• Construct the new next state table
design
PRESENT NEXT STATE / OUTPUT
Minimum number
Combina- STATE CD=0X CD=10 CD=11
torial of states: 3 ie.
circuits {u0,d0}=s0 u0 u0/0 u1/0 d2/1
{u1,d1}=s1 u1 u1/0 u2/0 d0/0
Sequential {u2,d2}=s2 u2 u2/0 u0/1 d1/0
circuits
d0 d0/0 u1/0 d2/1
FSMD d1 d1/0 u2/0 d0/0
design
d2 d2/0 u0/1 d1/0
VHDL
3/86
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• FYI: draw new state diagram
design
PRESENT NEXT STATE / OUTPUT
Combina- STATE CD=0X CD=10 CD=11
torial
circuits
s0 s0/0 s1/0 s2/1
s1 s1/0 s2/0 s0/0
Sequential s2 s2/0 s0/1 s1/0
circuits
CD=10
Y=1
FSMD
design
CD=0X CD=0X CD=0X
Y=0 Y=0 Y=0
VHDL CD=10 CD=10
Y=0 Y=0
s0 s1 s2
CD=11 CD=11
Y=0 Y=0
states
Digital
• This example did not show how you
design
should manipulate the implication table
Combina- • Hence an imaginary example showing all
torial
circuits problems:
Sequential
circuits
PRESENT NEXT STATE / OUTPUT
FSMD STATE AB=00 AB=01 AB=10
design
s0 s4/1 s2/0 s1/1
VHDL s1 s2/0 s5/1 s4/1
s2 s1/1 s0/0 s3/1
s3 s2/0 s5/1 s4/1
s4 s0/0 s5/1 s1/1
s5 s2/0 s4/1 s2/1
3/88
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• Construct the implication table: 1 square
design
per combination of 2 states
Combina-
torial PRESENT NEXT STATE / OUTPUT
circuits
STATE AB=00 AB=01 AB=10
Sequential s0 s4/1 s2/0 s1/1
circuits
s1 s2/0 s5/1 s4/1
FSMD
s2 s1/1 s0/0 s3/1
design s3 s2/0 s5/1 s4/1
s1 s4 s0/0 s5/1 s1/1
VHDL
s3
s4
s5
s0 s1 s2 s3 s4
3/89
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• Delete all combinations with different
design
outputs for same inputs
Combina-
torial PRESENT NEXT STATE / OUTPUT
circuits
STATE AB=00 AB=01 AB=10
Sequential s0 s4/1 s2/0 s1/1
circuits
s1 s2/0 s5/1 s4/1
FSMD
s2 s1/1 s0/0 s3/1
design s3 s2/0 s5/1 s4/1
s1 s4 s0/0 s5/1 s1/1
VHDL
s3
s4
s5
s0 s1 s2 s3 s4
3/90
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• Indicate for the remaining which next
design
states have to be equivalent to make the
Combina- current states equivalent
torial
circuits PRESENT NEXT STATE / OUTPUT
STATE AB=00 AB=01 AB=10
Sequential
circuits
s0 s4/1 s2/0 s1/1
s1 s2/0 s5/1 s4/1
FSMD s2 s1/1 s0/0 s3/1
design
s3 s2/0 s5/1 s4/1
VHDL s1 s4 s0/0 s5/1 s1/1
1-4 s5 s2/0 s4/1 s2/1
s2 1-3
s3 OK
0-2
s4 0-2
1-4
4-5 4-5 0-2, 4-5
s5 2-4 2-4 1-2
3/91 s0 s1 s2 s3 s4
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• Delete those states that are equivalent
design
when non-equivalent next states would
Combina- have been equivalent
torial
circuits PRESENT NEXT STATE / OUTPUT
STATE AB=00 AB=01 AB=10
Sequential
circuits
s0 s4/1 s2/0 s1/1
s1 s2/0 s5/1 s4/1
FSMD s2 s1/1 s0/0 s3/1
design
s3 s2/0 s5/1 s4/1
VHDL s1 s4 s0/0 s5/1 s1/1
1-4:
1-4? s5 s2/0 s4/1 s2/1
s2 1-3:OK
1-3
s3 OK
0-2:
0-2?
s4 0-2:
0-2?
1-4:
1-4?
4-5 4-5 0-2, 4-5
s5 2-4 2-4 1-2
3/92 s0 s1 s2 s3 s4
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• Delete again as long as states are deleted
design
during an iteration
Combina-
torial
circuits PRESENT NEXT STATE / OUTPUT
STATE AB=00 AB=01 AB=10
Sequential
circuits
s0 s4/1 s2/0 s1/1
s1 s2/0 s5/1 s4/1
FSMD s2 s1/1 s0/0 s3/1
design
s3 s2/0 s5/1 s4/1
VHDL s1 s4 s0/0 s5/1 s1/1
1-4: ? s5 s2/0 s4/1 s2/1
s2 1-3:OK
s3 OK Minimum number
0-2: ?
of states: 3 ie.
s4 0-2: ? {s0,s2}=u0
1-4: ?
4-5 4-5 0-2, 4-5 {s1,s3,s4}=u1
s5 2-4 2-4 1-2 {s5}=u2
3/93 s0 s1 s2 s3 s4
Step 2: minimise the number of
©
R.Lauwereins
Imec 2001
states
Digital
• Construct the new next state table
design
Minimum number PRESENT NEXT STATE / OUTPUT
Combina- of states: 3 ie. STATE AB=00 AB=01 AB=10
torial
circuits {s0,s2}=u0 s0 s4/1 s2/0 s1/1
{s1,s3,s4}=u1 s1 s2/0 s5/1 s4/1
Sequential {s5}=u2
circuits s2 s1/1 s0/0 s3/1
s3 s2/0 s5/1 s4/1
FSMD
design s4 s0/0 s5/1 s1/1
s5 s2/0 s4/1 s2/1
VHDL
3/94
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits ❑ Finite State Machine (FSM)
Sequential
❑ State-based or Moore-type FSM
circuits
❑ Input-based or Mealy-type FSM
FSMD ❑ Step 1: State diagram
design
❑ Step 2: State minimization
VHDL Step 3: State encoding
❑ Step 4: Choice of the flip-flop type
❑ Step 5: Realization of the combinatorial logic
❑ Step 6: Timing analysis
• Design of asynchronous sequential
circuits
3/95 • Basic RTL building blocks
©
Digital
• n states require at least log2n flip-flops.
• There are n! possible encodings (n
design
Digital
• Does the chosen encoding matters?
design
❑ Yes. Each choice leads to a different
Combina-
combinatorial circuit with different cost and
torial delay.
circuits
• Often chosen encodings:
Sequential
circuits ❑ Straightforward
❑ Minimum-bit-change
FSMD
design ❑ One-hot
VHDL
3/97
Step 3: State encoding:
©
R.Lauwereins
Imec 2001
Straightforward
Digital
• Straightforward encoding uses the binary
design
representation of the state number as
Combina- code (s0→000, s5→101, …)
torial
circuits • Straightforward encoding is mostly used
Sequential
when the state number has a physical
circuits meaning
FSMD ❑ E.g. a counter whose count value is sent to a
design display
VHDL • Straightforward encoding is dangerous for
glitches and leads to non-minimal area
and power consumption: multiple bits
have to change at each state transition
(multiple bit-changes seldomly happen
concurrently; each bit-change requires some logic
to implement it; each bit-change consumes power)
3/98
Step 3: State encoding:
©
R.Lauwereins
Imec 2001
Straightforward
Digital
design PRESENT NEXT STATE / OUTPUT
STATE CD=0X CD=10 CD=11
Combina- s0 s0/0 s1/0 s2/1
torial
circuits s1 s1/0 s2/0 s0/0
s2 s2/0 s0/1 s1/0
Sequential
circuits
FSMD
design
PRESENT NEXT STATE / OUTPUT
VHDL
STATE CD=0X CD=10 CD=11
00 00/0 01/0 10/1
01 01/0 10/0 00/0
10 10/0 00/1 01/0
3/99
Step 3: State encoding:
©
R.Lauwereins
Imec 2001
Minimum-bit-change
Digital
• For minimum-bit-change encoding we
design
assign the codes such that the total
Combina- number of bit-changes for all state
torial
circuits transitions is minimal
Sequential
• Minimum-bit-change encoding is mostly
circuits used when area and power need to be
FSMD minimized (CMOS)
design
VHDL
00 1 01 00 1 01
Gray code
counter
2 2 1 1
1 1
11 10 10 11
Minimum-bit-change
PRESENT NEXT STATE / OUTPUT
Digital
design STATE CD=0X CD=10 CD=11
s0 s0/0 s1/0 s2/1
Combina- s1 s1/0 s2/0 s0/0
torial
circuits s2 s2/0 s0/1 s1/0
Sequential
circuits 0 1
All transitions are equally likely
FSMD Preferrably only 1 bit difference
design
between each pair of transitions
This can only be realised between
VHDL
2 two of the three pairs
One-hot
Digital
• Each state has 1 flip-flop, hence no
design
encoding; Q of 1 FF =1, Q of others=0
Combina- • Flip-flop cost = O(n) i.o. O(logn), hence
torial
circuits only useful for small number of states:
Sequential
controller
circuits
• Very easy to realise: short design time
FSMD (time-to-market, e.g. exam…)
design
• Very small combinatorial circuits to drive
VHDL
the inputs of the flip-flops: cheap
combinatorial part, more expensive flip-
flop part
❑ An FPGA possesses per half CLB a small
combinatorial circuit and 1 flip-flop: one-hot
encoding is ideal for FPGA implementations
(except counters: too many states)
3/102
Step 3: State encoding:
©
R.Lauwereins
Imec 2001
One-hot
PRESENT NEXT STATE / OUTPUT
Digital
design STATE CD=0X CD=10 CD=11
s0 s0/0 s1/0 s2/1
Combina- s1 s1/0 s2/0 s0/0
torial
circuits s2 s2/0 s0/1 s1/0
Sequential
circuits One-hot encoding
s0=001
FSMD
design s1=010
s2=100
VHDL
3/103
Step 3: State encoding:
©
R.Lauwereins
Imec 2001
One-hot
CD=0X CD=0X CD=0X
Digital CD=10 Y=0 Y=0 Y=0
design
Y=1 CD=10 CD=10
Y=0 Y=0
Combina-
torial s0 s1 s2
circuits
CD=11 CD=11 CD=11
Y=1 Y=0 Y=0
Sequential
circuits
FSMD
design
P Q0 Q1 C Q2 C
VHDL D D D Y
C
3/104
D
Step 3: State encoding:
©
R.Lauwereins
Imec 2001
One-hot
Digital
• Implementation rule for One-hot with D
design
flip-flop:
Combina- ❑ Each arriving transition at a state needs an
torial
circuits
AND gate
Sequential
circuits
FSMD
design
VHDL
3/105
Step 3: State encoding:
©
R.Lauwereins
Imec 2001
One-hot
CD=0X CD=0X CD=0X
Digital CD=10 Y=0 Y=0 Y=0
design
Y=1 CD=10 CD=10
Y=0 Y=0
Combina-
torial s0 s1 s2
circuits
CD=11 CD=11 CD=11
Y=1 Y=0 Y=0
Sequential
circuits
FSMD
design
P Q0 Q1 C Q2 C
VHDL S R S R S R Y
C
3/106 D
Step 3: State encoding:
©
R.Lauwereins
Imec 2001
One-hot
Digital
• Implementation rule for One-hot with SR
design
flip-flop:
Combina- ❑ Each arriving transition starting at another
torial
circuits
state requires an AND gate at the S input
❑ Each departing transition to another state
Sequential
circuits
requires an AND gate at the R input
FSMD
design
VHDL
3/107
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits ❑ Finite State Machine (FSM)
Sequential
❑ State-based or Moore-type FSM
circuits
❑ Input-based or Mealy-type FSM
FSMD ❑ Step 1: State diagram
design
❑ Step 2: State minimization
VHDL ❑ Step 3: State encoding
Step 4: Choice of the flip-flop type
❑ Step 5: Realization of the combinatorial logic
❑ Step 6: Timing analysis
• Design of asynchronous sequential
circuits
3/108 • Basic RTL building blocks
©
Digital
• JK flip-flop
design
❑ Most expensive flip-flop
Combina- ❑ Most difficult design
torial
circuits ❑ Largest number of don’t cares: probably
cheapest (and fastest) combinatorial control
Sequential
circuits
logic
❑ Used when a different signal sets resp. resets
FSMD the flip-flop
design
• SR flip-flop
VHDL
❑ Cheap flip-flop
❑ Difficult design
❑ Many don’t cares: probably cheap (and fast)
control logic
❑ Used when a different signal sets resp. resets
the flip-flop
3/109
©
Digital
• D flip-flop
design
❑ Cheap flip-flop
Combina- ❑ Most easy design
torial
circuits ❑ No don’t cares: probably most expensive (and
slowest) combinatorial control logic
Sequential
circuits ❑ Used when the same signal sets resp. resets
the flip-flop, i.e. when the value of a signal has
FSMD to be remembered temporarily
design
• T flip-flop
VHDL
❑ Cheap flip-flop
❑ Easy design
❑ No don’t cares: probably most espensive (and
slowest) combinatorial control logic
❑ Used for counters and frequency dividers: fast
toggling
3/110
©
Digital
• No fixed selection rule exists
design
❑ When we want the cheapest circuit, all variants
Combina-
have to be tried out
torial
circuits
❑ When the fastest design time is needed, D flip-
flops are the best choice
Sequential
circuits
❑ FPGAs only possess D flip-flops
FSMD
design
VHDL
3/111
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits ❑ Finite State Machine (FSM)
Sequential
❑ State-based or Moore-type FSM
circuits
❑ Input-based or Mealy-type FSM
FSMD ❑ Step 1: State diagram
design
❑ Step 2: State minimization
VHDL ❑ Step 3: State encoding
❑ Step 4: Choice of the flip-flop type
Step 5: Realization of the combinatorial logic
❑ Step 6: Timing analysis
• Design of asynchronous sequential
circuits
3/112 • Basic RTL building blocks
Step 5: Realization of the
©
R.Lauwereins
Imec 2001
Excitation table Q0 Q0
VHDL
for D flip-flop Q1n=D1 Q1 Q0n=D0 Q1
Q Q(next) D
0 0 0 0 0 x 1 0 1 x 0
0 1 1 0 0 x 1 0 1 x 0
1 0 0 D D
1 0 x 0 0 0 x 1
1 1 1 C C
0 1 x 0 1 0 x 0
D to be applied
3/113 is identical to Qn
Step 5: Realization of the
©
R.Lauwereins
Imec 2001
Combina-
0 0 x 1 0 1 x 0 0 0 x 0
torial
circuits 0 0 x 1 0 1 x 0 0 0 x 0
D D D
1 0 x 0 0 0 x 1 1 0 x 0
Sequential C C C
circuits 0 1 x 0 1 0 x 0 0 0 x 1
FSMD
design
Q1 Clr Q0 Clr
Cost: 35
VHDL D D Y
1.5 CLB
C
D
3/114
Step 5: Realization of the
©
R.Lauwereins
Imec 2001
Excitation table Q0 Q0
VHDL
for T flip-flop T1 Q1 T0 Q1
Q Q(next) T
0 0 0 0 0 x 0 0 0 x 0
0 1 1 0 0 x 0 0 0 x 0
1 0 1 D D
1 0 x 1 0 1 x 1
1 1 0 C C
0 1 x 1 1 1 x 0
3/115
Step 5: Realization of the
©
R.Lauwereins
Imec 2001
Combina-
0 0 x 0 0 0 x 0 0 0 x 0
torial
circuits 0 0 x 0 0 0 x 0 0 0 x 0
D D D
1 0 x 1 0 1 x 1 1 0 x 0
Sequential C C C
circuits 0 1 x 1 1 1 x 0 0 0 x 1
FSMD
design
Q1 Clr Q0 Clr
Cost: 32
VHDL T T Y
C
D
3/116
Step 5: Realization of the
©
R.Lauwereins
Imec 2001
Excitation table Q0 Q0
VHDL
for SR flip-flop S1 Q1 R1 Q1
Q Q(next) S R
0 0 x x x x x 0
0 0 0 x
0 1 1 0 0 0 x x x x x 0
1 0 0 1
D D
1 0 x 0 0 x x 1
1 1 x 0 C C
0 1 x 0 x 0 x 1
3/117
Step 5: Realization of the
©
R.Lauwereins
Imec 2001
Excitation table Q0 Q0
VHDL
for SR flip-flop S0 Q1 R0 Q1
Q Q(next) S R
0 x x 0 x 0 x x
0 0 0 x
0 1 1 0 0 x x 0 x 0 x x
D D
1 0 0 1 0 0 x 1 x 1 x 0
1 1 x 0 C C
1 0 x 0 0 1 x x
3/118
Step 5: Realization of the
©
R.Lauwereins
Imec 2001
0 0 x x x x x 0
Combina-
torial 0 0 x x x x x 0
circuits
D D
1 0 x 0 0 x x 1
Sequential C C
circuits 0 1 x 0 x 0 x 1
FSMD
design
Q1 C Q0 C
VHDL S R S R
C
3/119 D
Step 5: Realization of the
©
R.Lauwereins
Imec 2001
0 x x 0 x 0 x x
Combina-
torial 0 x x 0 x 0 x x
circuits
D D
0 0 x 1 x 1 x 0
Sequential C C
circuits 1 0 x 0 0 1 x x
FSMD
design
Q1 C Q0 C
VHDL S R S R
C
3/120 D
Step 5: Realization of the
©
R.Lauwereins
Imec 2001
0 x x 0 x 0 x x 0 0 x 0
Combina-
torial 0 x x 0 x 0 x x 0 0 x 0
circuits
D D D
0 0 x 1 x 1 x 0 1 0 x 0
Sequential C C C
circuits 1 0 x 0 0 1 x x 0 0 x 1
FSMD
design
Q1 C Q0 C
Y Cost: 32
VHDL S R S R
C
3/121 D
Step 5: Realization of the
©
R.Lauwereins
Imec 2001
Excitation table Q0 Q0
VHDL
for JK flip-flop J1 Q1 K1 Q1
Q Q(next) J K
0 0 x x x x x 0
0 0 0 x
0 1 1 x 0 0 x x x x x 0
1 0 x 1
D D
1 0 x x x x x 1
1 1 x 0 C C
0 1 x x x x x 1
3/122
Step 5: Realization of the
©
R.Lauwereins
Imec 2001
Excitation table Q0 Q0
VHDL
for JK flip-flop J0 Q1 K0 Q1
Q Q(next) J K
0 x x 0 x 0 x x
0 0 0 x
0 1 1 x 0 x x 0 x 0 x x
1 0 x 1
D D
0 x x 1 x 1 x x
1 1 x 0 C C
1 x x 0 x 1 x x
3/123
Step 5: Realization of the
©
R.Lauwereins
Imec 2001
0 0 x x x x x 0
Combina-
torial 0 0 x x x x x 0
circuits
D D
1 0 x x x x x 1
Sequential C C
circuits 0 1 x x x x x 1
FSMD
design
Q1 C Q0 C
VHDL J K J K
C
3/124 D
Step 5: Realization of the
©
R.Lauwereins
Imec 2001
0 x x 0 x 0 x x 0 0 x 0
Combina-
torial 0 x x 0 x 0 x x 0 0 x 0
circuits
D D D
0 x x 1 x 1 x x 1 0 x 0
Sequential C C C
circuits 1 x x 0 x 1 x x 0 0 x 1
FSMD
design
Q1 C Q0 C
Y Cost: 26
VHDL J K J K
C
3/125 D
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits ❑ Finite State Machine (FSM)
Sequential
❑ State-based or Moore-type FSM
circuits
❑ Input-based or Mealy-type FSM
FSMD ❑ Step 1: State diagram
design
❑ Step 2: State minimization
VHDL ❑ Step 3: State encoding
❑ Step 4: Choice of the flip-flop type
❑ Step 5: Realization of the combinatorial logic
Step 6: Timing analysis
• Design of asynchronous sequential
circuits
3/126 • Basic RTL building blocks
©
Digital
• Determine maximum clock frequency
design
❑ Max. clock frequency = 1/(delay of critical path)
Combina- ❑ Critical path is the path with the longest
torial
circuits
combinatorial delay between two clock edges
❑ Example:
Sequential
circuits
FSMD
design
Q1 Clr Q0 Clr
VHDL D D Y
C
D
3/127
Step 6: Timing analysis
©
R.Lauwereins
Imec 2001
C
D
3/128
©
Digital
• After designing the combinatorial circuits
design
for next state and output, all traditional
Combina- design steps follow:
torial
circuits ❑ Technology mapping
❑ Placement and routing
Sequential
circuits ❑ Timing simulation
FSMD • Timing simulation is even more important
design
for sequential circuits than for
VHDL combinatorial circuits
❑ Determine the maximum clock frequency to
check whether setup and hold times are
satisfied
❑ Avoid, if necessary because of connected
circuits, glitches when a state transition
involves multiple bit-flips
3/129
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
➔Design of asynchronous sequential
Sequential circuits
circuits
• Basic RTL building blocks
FSMD
design
VHDL
3/130
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
❑ Definitions and Fundamental Mode Restriction
FSMD ❑ Design
design
• Basic RTL building blocks
VHDL
3/131
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
Definitions and Fundamental Mode Restriction
FSMD ❑ Design
design
• Basic RTL building blocks
VHDL
3/132
©
Digital
• Definitions:
design
❑ Sequential circuit: the output is function of the
Combina-
current value of the inputs and of the current
torial state (i.e. also function of the sequence of past
circuits
inputs)
Sequential ❑ Asynchronous sequential circuits: outputs and
circuits
state change as soon as an input changes
FSMD
design
• Fundamental mode restriction:
❑ only one input may change at a time; the next
VHDL input change may only occur when all effects
to the previous input change died out
• Goal: design of small asynchronous
circuits, e.g. interfaces between two
synchronous islands with not-correlated
clocks or clocks with unpredictable clock
3/133
skew
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
❑ Definitions and Fundamental Mode Restriction
FSMD Design
design
• Basic RTL building blocks
VHDL
3/134
©
FSMD
design
VHDL
3/135
Design flow
©
R.Lauwereins
Imec 2001
State table
Digital
design
State transition diagram
Combina-
torial
circuits
Primitive flow table
Sequential
circuits
Minimized flow table
FSMD
design
State assignment
VHDL
State table
Digital
design
State transition diagram
Combina-
torial
circuits
Primitive flow table
Sequential
circuits
Minimized flow table
FSMD
design
State assignment
VHDL
State table
R.Lauwereins
Imec 2001
Digital
• List all states: each possible combination
design
of inputs and outputs is a state
Combina-
torial Q I E State
circuits
0 0 0 a
Sequential 0 0 1 b
circuits 0 1 0 c
0 1 1 d
FSMD
design 1 0 0 impossible
1 0 1 e
VHDL 1 1 0 impossible
1 1 1 f
3/138
Design flow
©
R.Lauwereins
Imec 2001
State table
Digital
design
State transition diagram
Combina-
torial
circuits
Primitive flow table
Sequential
circuits
Minimized flow table
FSMD
design
State assignment
VHDL
01 11 11
Digital Q I E State
design
0 0 0 a
e/0 f/0 0 0 1 b
Combina-
torial 0 1 0 c
circuits
01
0 1 1 d
IE 00 11
Sequential 1 0 0 impossible
circuits
01
00 1 0 1 e
01
1 1 0 impossible
FSMD
design a/0 b/0 1 1 1 f
00
VHDL 10
We opted for a
10 00 01
Moore or state
11
10 based design; we
11
could as well have
c/0 d/0 chosen a Mealy
10 approach, with
output per
transition
3/140
Design flow
©
R.Lauwereins
Imec 2001
State table
Digital
design
State transition diagram
Combina-
torial
circuits
Primitive flow table
Sequential
circuits
Minimized flow table
FSMD
design
State assignment
VHDL
Digital
IE Q I E State
design
S 00 01 11 10 Q 0 0 0 a
Combina- a a b x c 0 0 0 1 b
torial 0 1 0 c
circuits b a b f x 0
c a x d c 0 0 1 1 d
Sequential d x b d c 0 1 0 0 impossible
circuits
e a e f x 1 1 0 1 e
f x e f c 1 1 1 0 impossible
FSMD
design 1 1 1 f
VHDL
3/142
Design flow
©
R.Lauwereins
Imec 2001
State table
Digital
design
State transition diagram
Combina-
torial
circuits
Primitive flow table
Sequential
circuits
Minimized flow table
FSMD
design
State assignment
VHDL
Digital
• Rule: merge compatible states: states
design
with same next states and outputs or
Combina- don’t cares
torial
circuits • ‘Compatibility’ is not associative!
Sequential
(a compatible b) AND (a compatible c)
circuits does NOT induce (b compatible c)
FSMD • Note that minimizing the number of states
design
of synchronous circuits requires
VHDL equivalence instead of compatibility.
❑ States with same outputs and equivalent next
states
❑ ‘Equivalence’ is associative!
3/144
©
IE
Digital
S 00 01 11 10 Q Are a and b compatible?
design
a a b x c 0
YES, hence merge them
Combina- b a b f x 0
torial
circuits c a x d c 0
d x b d c 0
Sequential e a e f x 1
circuits
f x e f c 1
FSMD
design
IE
VHDL S 00 01 11 10 Q
f c 0
c x d c 0
d x d c 0
e e f x 1
f x e f c 1
3/145
©
FSMD
design
IE
VHDL S 00 01 11 10 Q
f 0
0
e e f x 1
f x e f 1
3/146
©
FSMD
design
IE
S 00 01 11 10 Q This minimized flow table
VHDL 0 is called the
0 Transition Table
1
3/147
Design flow
©
R.Lauwereins
Imec 2001
State table
Digital
design
State transition diagram
Combina-
torial
circuits
Primitive flow table
Sequential
circuits
Minimized flow table
FSMD
design
State assignment
VHDL
State assignment
R.Lauwereins
Imec 2001
3/149
©
State assignment
R.Lauwereins
Imec 2001
Digital
design
IE
Combina- S 00 01 11 10 Q
torial
circuits 00 00 00 11 01 0
01 00 00 01 01 0
Sequential 11 00 11 11 01 1
circuits
FSMD
design
VHDL
S0 S0
S0n S1 S1n S1
0 0 0 x 0 0 0 x
0 0 1 x 0 0 1 x S0
E E
I 1 1 1 x I 1 0 1 x 0 0
1 1 1 x 0 0 0 x S1 x 1
3/150
©
State assignment
R.Lauwereins
Imec 2001
Digital
design I E S1 S0
Combina-
torial
circuits
Sequential
circuits
Q
FSMD
design
VHDL
S0 S0
S0n S1 S1n S1
0 0 0 x 0 0 0 x
0 0 1 x 0 0 1 x S0
E E
I 1 1 1 x I 1 0 1 x 0 0
1 1 1 x 0 0 0 x S1 x 1
3/151
©
R.Lauwereins
Imec 2001 State assignment
I E S1 S0 IE
Digital
design S 00 01 11 10 Q
00 00 00 11 01 0
Combina- 01 00 00 01 01 0
torial
circuits 11 00 11 11 01 1
Sequential
circuits Q
FSMD
design Let’s animate behav from state S=00 with inputs IE=01->11
Step 1: Stable state S=00 with inputs IE=01
VHDL
Step 2: Inputs change to IE=11
Step 3: after 2-input gate delay, OR-gate switches,
making S0=1
No Step 4: we are stuck in stable state S=01 because
both state bits did not change at the same time
The fact that 2 or more state variables have to change,
when 1 input-bit changes is called a RACE CONDITION
When this leads to the wrong final state,
3/152 it’s called a CRITICAL RACE
Design flow
©
R.Lauwereins
Imec 2001
State table
Digital
design
State transition diagram
Combina-
torial
circuits
Primitive flow table
Sequential
circuits
Minimized flow table
FSMD
design
State assignment
VHDL
Digital
• Solution: make the state assignment such
design
that never 2 or more state variables need
Combina- to change following a single input change
torial
circuits
IE 00 01
Sequential
S 00 01 11 10 Q
circuits
0
FSMD 0
design
1
VHDL 11
3/154
©
Digital
• Do the state assignment as good as you
design
can. Use additional states to solve the
Combina- problems that remain
torial
circuits
IE
S 00 01 11 10 Q Don’t care because both
Sequential
new transitions require
circuits 00 00 00 10
11 01 0
an output change: it
01 00 00 01 01 0
FSMD is not important whether
11 10
00 11 11 01 1
design this already happens in
10 00 x 11 x x the intermediate state
VHDL
3/155
©
Digital IE
design
S 00 01 11 10 Q
00 00 00 10 01 0
Combina-
torial 01 00 00 01 01 0
circuits
11 10 11 11 01 1
10 00 x 11 x x
Sequential
circuits
FSMD
design
VHDL
S0 S0
S0n S1 S1n S1
0 0 0 0 0 0 1 0
0 0 1 x 0 0 1 x S0
E E
I 0 1 1 1 I 1 0 1 1 0 0
1 1 1 x 0 0 0 x S1 x 1
3/156
©
R.Lauwereins Elimination of critical races
Imec 2001
I E S1 S0
Digital
design
Combina-
torial
circuits
Sequential
circuits
FSMD
design
Q
VHDL
S0 S0
S0n S1 S1n S1
0 0 0 0 0 0 1 0
0 0 1 x 0 0 1 x S0
E E
I 0 1 1 1 I 1 0 1 1 0 0
3/157 1 1 1 x 0 0 0 x S1 x 1
©
Digital IE
design
S 00 01 11 10 Q
00 00 00 10 01 0
Combina-
torial 01 00 00 01 01 0
circuits
11 10 11 11 01 1
10 00 00
x 11 01
x x
Sequential
circuits Race, but not critical
State table
Digital
design
State transition diagram
Combina-
torial
circuits
Primitive flow table
Sequential
circuits
Minimized flow table
FSMD
design
State assignment
VHDL
Digital
• The combinatorial circuits of an
design
asynchronous design should be designed
Combina- in a hazard free way
torial
circuits ❑ Static hazard: a status variable that is
supposed not to change, briefly changes; this
Sequential
circuits
could lead to a wrong final state
❑ Dynamic hazard: a status variable that is
FSMD supposed to change just once, changes three
design
times; this could lead to a wrong final state
VHDL
• Synchronous designs do not need to be
hazard free, since state variables are only
taken into account on a clock edge
• Our design was hazard free, and hence
should not be changed
3/160
Design flow
©
R.Lauwereins
Imec 2001
State table
Digital
design
State transition diagram
Combina-
torial
circuits
Primitive flow table
Sequential
circuits
Minimized flow table
FSMD
design
State assignment
VHDL
Digital
• Assume that input I is skewed on the
design
bottom AND gate with respect to the
Combina- other inputs IE
torial S 00 01 11 10 Q
circuits
I E S1 S0 00 00 00 10 01 0
Sequential 01 00 00 01 01 0
circuits
11 10 11 11 01 1
10 00 11 11 01 1
FSMD
design Start in state S=01 with IE=11
VHDL
I becomes 0: S should go to 00
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
➔Basic RTL building blocks
FSMD
design
VHDL
3/163
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
• Basic RTL building blocks
FSMD
design
❑ Registers
❑ Shift registers
VHDL
❑ Counters
Synchronous counters
Asynchronous counters
❑ Register files
❑ LIFO queue (push down stack)
❑ FIFO queue
3/164
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
• Basic RTL building blocks
FSMD
design
Registers
❑ Shift registers
VHDL
❑ Counters
Synchronous counters
Asynchronous counters
❑ Register files
❑ LIFO queue (push down stack)
❑ FIFO queue
3/165
©
Registers
R.Lauwereins
Imec 2001
Digital
• Register
design
I3 I2 I1 I0
Combina-
torial
circuits
D Q D Q D Q D Q
Sequential
circuits
FSMD
design
Clk
VHDL
Q3 Q2 Q1 Q0
I3 I2 I1 I0
Register Symbol
3/166 Q3Q2 Q1 Q0
©
Registers
R.Lauwereins
Imec 2001
Digital
• Asynchronously presettable and clearable
design
Register
Combina- I3 I2 I1 I0
torial
circuits
Preset
Sequential D Q D Q D Q D Q
circuits
FSMD
design Clear
Clk
VHDL Q3 Q2 Q1 Q0
I3 I2 I1 I0
Preset
Register Symbol
Clear
3/167 Q3Q2 Q1 Q0
©
Registers
R.Lauwereins
Imec 2001
Digital
• Loadable register (without gated clock)
design
I3 I2 I1 I0
Combina-
torial
circuits 1 0 1 0 1 0 1 0
S S S S
Sequential
circuits
Load
FSMD D Q D Q D Q D Q
design
VHDL
Clk
Q3 Q2 Q1 Q0
Registers
R.Lauwereins
Imec 2001
Digital
• Loadable register (without gated clock)
design
Combina-
torial
circuits I3 I2 I1 I0
Sequential Load
circuits
Register Symbol
FSMD
design
Q3Q2 Q1 Q0
VHDL
3/169
©
Registers
R.Lauwereins
Imec 2001
Digital
• Loadable register (with gated clock)
design
I3 I2 I1 I0
Combina-
torial
circuits D Q D Q D Q D Q
Sequential
circuits
CE
FSMD
design Clk
Q3 Q2 Q1 Q0
VHDL
Registers
R.Lauwereins
Imec 2001
Digital
• Loadable register (with gated clock)
design
Combina-
torial
circuits I3 I2 I1 I0
Sequential CE
circuits
Register Symbol
FSMD
design
Q3Q2 Q1 Q0
VHDL
3/171
©
Registers
R.Lauwereins
Imec 2001
Registers
R.Lauwereins
Imec 2001
I A Q
Digital
design
D0 Q0 D1 Q1
Combina-
torial
Clk
circuits
CE
Sequential Possible setup or hold
circuits
violation for 2nd flip-flop
FSMD
design
Clk
VHDL I
A
CE
Gated
Clk
Q
3/173
©
Registers
R.Lauwereins
Imec 2001
Digital
• What causes clock skew?
design
❑ Gated clocks
Combina- ❑ Different relative routing delay
torial
circuits On PCB and within chip: different
Sequential
wire length
circuits
In FPGA: different number of routing
FSMD switches
design
• Delay depends on many things:
VHDL
❑ temperature, power supply voltage, fan-out, IC
batch
❑ under no circumstance clock skew may cause
problems!!! worst case analysis (e.g. min-
delay for data path and max-delay for clock
path and vice versa)
3/174
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
• Basic RTL building blocks
FSMD
design
❑ Registers
Shift registers
VHDL
❑ Counters
Synchronous counters
Asynchronous counters
❑ Register files
❑ LIFO queue (push down stack)
❑ FIFO queue
3/175
©
Shift registers
R.Lauwereins
Imec 2001
Digital
• Serial-in/parallel-out shift register (SIPO)
design
IL
Combina-
torial
circuits 1 0 1 0 1 0 1 0
S S S S
Sequential
circuits
SE
FSMD D Q D Q D Q D Q
design
VHDL
Clk
Q3 Q2 Q1 Q0
Example of utilization:
Receive register (Rx) serial port
Delay line for FIR and IIR filters
3/176
©
Shift registers
R.Lauwereins
Imec 2001
Digital
• Serial-in/parallel-out shift register (SIPO)
design
Combina-
torial
circuits
Sequential IL
circuits
Shift Register Symbol
SE
FSMD
design
Q3Q2 Q1 Q0
VHDL
3/177
©
Shift registers
R.Lauwereins
Imec 2001
Digital
• Parallel-in/serial-out shift register (PISO)
design
IL I3 I2 I1 I0
Combina-
torial
circuits 1 0 1 0 1 0 1 0
S S S S
Sequential
circuits
Sh/Ld
FSMD D Q D Q D Q D Q
design
Clk
VHDL
CE
Q0
3/178
©
Shift registers
R.Lauwereins
Imec 2001
Digital
• Parallel-in/serial-out shift register (PISO)
design
Combina-
torial
circuits I3 I2 I1 I0
Sequential IL
circuits
Shift Symbol
FSMD CE Register
design Sh/Ld’
VHDL
Q0
3/179
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
• Basic RTL building blocks
FSMD
design
❑ Registers
❑ Shift registers
VHDL
❑ Counters
➔Synchronous counters
Asynchronous counters
❑ Register files
❑ LIFO queue (push down stack)
❑ FIFO queue
3/180
©
Synchronous counters
R.Lauwereins
Imec 2001
Digital
• Synchronous up-counter
design
Combina-
E
torial
circuits
Sequential HA HA HA
circuits
FSMD D Q D Q D Q
design
VHDL Clear
Clk Output Q2 Q1 Q0
carry
Synchronous counters
R.Lauwereins
Imec 2001 Glitch!
Digital
E
design
Combina-
torial HA HA HA
circuits
Sequential D Q D Q D Q
circuits
FSMD Clear
design
Clk Output
VHDL Q2 Q1 Q0
carry
Clk
Clear
E
Q0
Q1
Q2
3/182
©
Synchronous counters
R.Lauwereins
Imec 2001
Digital
• Synchronous up/down-counter
design
D
Combina-
E
torial Co Ci
circuits HAS HAS HAS
Sequential
circuits
FSMD D Q D Q D Q
design
VHDL Clear
Clk Output Q2 Q1 Q0
carry
Half
adder/subtractor
3/183
©
Synchronous counters
R.Lauwereins
Imec 2001
Digital
• Design of the Half adder/subtractor
design
Behavior:
Combina- D When ci=0 then Di=Qi (no counting)
torial co
circuits HAS ci When ci=1 this section should toggle
Qi C0 has to be 1 when the next section
Sequential has to toggle. When should this happen?
circuits
Di
FSMD
design
Up-count Down-count
VHDL
00 00
01 11
10 10
11 01
00 00
01 11
… …
Next section toggles Next section toggles
at 1→0 of this section at 0→1 of this section
3/184
©
Synchronous counters
R.Lauwereins
Imec 2001
Digital
• Design of the Half adder/subtractor
design
ci Dir Qii D
Dii c
ci+1
i+1 Behavior:
0 0 0 0
0 0
0 When ci=0 then Di=Qi (no counting)
Combina-
torial 0 0 1 1
1 0
0 When ci=1 this section should toggle
circuits
0 1 0 0
0 0
0 C0 has to be 1 when the next section
0 1 1 1
1 0 has to toggle. When should this happen?
0
Sequential
circuits 1 0 0 1
1 0
0
1 0 1 0
0 1
1
FSMD 1 1 0 1
1 1
1
design
1 1 1 0
0 0
0
Up-count Down-count
00 00
VHDL
01 11
10 10
11 01
00 00
01 11
… …
Next section Next section
toggles at 1→0 toggles at 0→1
3/185 of this section of this section
©
Synchronous counters
R.Lauwereins
Imec 2001
Digital
• Design of the Half adder/subtractor
design
ci Dir Qi Di ci+1 Qi Qi
Combina- 0 0 0 0 0 Di Dir ci+1 Dir
torial
circuits 0 0 1 1 0
0 1 0 0 0
0 1 1 0 0 0 0 0
Sequential 0 1 1 1 0 ci 1 0 0 1 ci 0 1 0 1
circuits
1 0 0 1 0
FSMD 1 0 1 0 1
design 1 1 0 1 1
ci
1 1 1 0 0
VHDL Dir
Qi
Di ci+1
3/186
©
Synchronous counters
R.Lauwereins
Imec 2001
Digital
• Parallel loadable up/down-counter
design I2 I1 I0
D
Combina-
torial
circuits E
HAS HAS Co HAS
Sequential Ci
circuits
1 0 1 0 1 0
FSMD
design
Load
VHDL
D Q D Q D Q
Clear
Clk Output Q2 Q1 Q0
carry
3/187
©
Synchronous counters
R.Lauwereins
Imec 2001
Digital
• BCD up-counter
design
Combina-
torial
circuits 0 0 0 0
Sequential I3 I2 I1 I0
circuits
Up-counter
FSMD E
design Load Q3Q2 Q1 Q0
VHDL
Synchronous counters
R.Lauwereins
Imec 2001
Digital
• BCD up/down-counter
design
1 0 0 1 0 0 0 0
Combina-
torial 1 0
circuits
Mux
Sequential
circuits
FSMD
design D I3 I2 I1 I0
Up/down-
VHDL
E counter
Load Q3Q2 Q1 Q0
3/189
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
• Basic RTL building blocks
FSMD
design
❑ Registers
❑ Shift registers
VHDL
❑ Counters
Synchronous counters
➔Asynchronous counters
❑ Register files
❑ LIFO queue (push down stack)
❑ FIFO queue
3/190
©
Asynchronous counters
R.Lauwereins
Imec 2001
Digital
E
design T Q T Q T Q T Q
Combina- Q’ Q’ Q’ Q’
torial
circuits
Clear
Sequential
circuits
FSMD Clk Q3 Q2 Q1 Q0
design
VHDL
Clk
Q0
Q1
Q2
Q3
3/191
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
• Basic RTL building blocks
FSMD
design
❑ Registers
❑ Shift registers
VHDL
❑ Counters
Synchronous counters
Asynchronous counters
Register files
❑ LIFO queue (push down stack)
❑ FIFO queue
3/192
©
Register files
R.Lauwereins
Imec 2001
Digital
design
Dout
WE D Q
Combina-
torial Din
circuits
Clk
Sequential RE
circuits
Register File Cell (RFC)
FSMD This implementation dissipates much power due to the
design
active memorization of data, but does not suffer from
clock skew problems.
VHDL
Register files
R.Lauwereins
Imec 2001
I3 I2 I1 I0
Digital
design
2-to-4
Combina-
0 read
torial dec
circuits RFC RFC RFC RFC
WA1 RA1
0
Sequential
WA0 1 RA0
circuits
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
• Basic RTL building blocks
FSMD
design
❑ Registers
❑ Shift registers
VHDL
❑ Counters
Synchronous counters
Asynchronous counters
❑ Register files
LIFO queue (push down stack)
❑ FIFO queue
3/195
©
Digital
design
Top empty
45
23
12
10 1. Reset
Combina-
2. Push 45
torial
Top-1 empty
45
12
circuits
3. Push 12
Top-2 empty
45 4. Push 23
Sequential
circuits 5. Pop -> 23
Top-3 empty
6. Push 10
FSMD
design
Top-4 empty
Top-5 empty
VHDL
Top-6 empty
Top-7 empty
3/196
©
In0
0
Digital
design
Reset IL IR
L/R’
Enable O7 O0
Combina-
torial
circuits Out0
In7
0
Sequential
circuits
Reset IL IR
L/R’
Enable O7 O0
FSMD
design
Out7
VHDL Reset
Up/down’
Enable Q3..0
Reset’ Empty
Push/pop’
Enable Full
3/198
©
Digital
Alternative implementation: for large stacks
design
Does not At
0=empty 0=full
shift! ‘Push’
Combina-
torial Write Ptr both
circuits ptrs
0 empty
45 1
2
3
0 count
Sequential
1 up
circuits empty
23
Read Ptr
2 empty
12
17 At ‘Pop’
FSMD
design 0
1
2
3 both
3 empty
52
ptrs
VHDL
count
1. Reset down
2. Push 45
3. Push 23
4. Push 12
5. Pop -> 12
6. Push 17
3/199 7. Push 52
©
Note: 10
SET Full/
Digital empty
design
R Up/down
U/D’ counter 1
Combina-
torial E Write ptr 2-to-1
circuits
MUX
S Up/down
Sequential U/D’ counter 0
circuits
E Read ptr S
FSMD Reset’
design
Push/
VHDL Pop’
Enable A 8
1Kx8 Data
CS RAM D in/out
R/W’
Watch timing of the enable: when RAM is not clocked
be careful not to read/write twice since the counters
3/200 count further
©
Sequential Circuits
R.Lauwereins
Imec 2001
Digital
• The flip-flop as building block
design
• Design of synchronous sequential
Combina- circuits
torial
circuits
• Design of asynchronous sequential
Sequential circuits
circuits
• Basic RTL building blocks
FSMD
design
❑ Registers
❑ Shift registers
VHDL
❑ Counters
Synchronous counters
Asynchronous counters
❑ Register files
❑ LIFO queue (push down stack)
FIFO queue
3/201
©
FIFO queue
R.Lauwereins
Imec 2001
Digital
design
1. Reset
Top empty
45
23
12
57
Combina- 2. Write 45
torial
circuits Top-1 empty
45
23
12 3. Write 23
4. Write 12
Top-2 empty
45
23
Sequential 5. Read -> 45
circuits
Top-3 empty 6. Write 57
FSMD
design
Top-4 empty
Top-5 empty
VHDL
Top-6 empty
Top-7 empty
3/202
©
FIFO queue
R.Lauwereins
Imec 2001
In0
Digital
Reset IL
design
Enable O7 O0
Combina- 7
torial
circuits In7 Uit0
0 S2..0
Sequential Reset IL
circuits Read
pointer Enable O7 O0
FSMD 7
design
Uit7
0 S2..0
VHDL
Set
Up/down’
Enable Q3..0
Reset’
Read/ Empty
write’
Enable Full
3/203
©
FIFO queue
R.Lauwereins
Imec 2001
Digital
Alternative implementation: for large FIFO’s
design Only write
Does not Wrap-around pointer
Combina- shift!
torial Write Ptr incr. at
circuits write
0 empty
45
16 2
3
0
1
Sequential
circuits
1 empty
23
Read Ptr
2 empty
12
FSMD
0
1 Only read
design
3 empty
57 pointer
VHDL
incr. at
read
1. Reset
2. Write 45
Read and write
3. Write 23
pointer equal:
4. Write 12 empty or full
5. Read -> 45
6. Write 57
3/204 7. Write 16
©
FIFO queue
R.Lauwereins
Imec 2001
Digital
• Previous implementation indicates
design
empty/full but does not distinguish
Combina- between both
torial
circuits • Solution:
Sequential
❑ assume queue depth equals 2n
circuits
❑ read and write pointer are hence n-bit up-
FSMD
counters
design ❑ select however an (n+1)-bit up-counter:
VHDL n-LSB of read and write equal:
empty/full
MSB equal: empty
MSB different: full
apply only the n-LSB as address for
RAM-queue
3/205
©
FIFO queue
R.Lauwereins
Imec 2001
MSB Full
Digital
design
10-LSB =? Empty
Combina-
torial
circuits R 11-bit Up
E counter 0
Sequential Write ptr 2-to-1
circuits
MUX
R 11-bit Up
FSMD
design
E counter 1
Read ptr S
VHDL
Reset’
Read/ 10
Write’
Enable A 8
1Kx8 Data
CS RAM D in/out
R/W’
3/206