Introduction to CMOS VLSI Design Lecture 11: Sequential Circuits - PowerPoint PPT Presentation

1 / 51
About This Presentation
Title:

Introduction to CMOS VLSI Design Lecture 11: Sequential Circuits

Description:

output depends on current inputs. Sequential logic. output ... In class, use flip-flop with nonoverlapping clocks. Very slow nonoverlap adds to setup time ... – PowerPoint PPT presentation

Number of Views:282
Avg rating:3.0/5.0
Slides: 52
Provided by: david2963
Category:

less

Transcript and Presenter's Notes

Title: Introduction to CMOS VLSI Design Lecture 11: Sequential Circuits


1
Introduction toCMOS VLSIDesignLecture 11
Sequential Circuits
  • David M. Zar
  • Washington University in St. Louis
  • Based on original work, with permission, by
  • David Harris
  • Harvey Mudd College

2
Outline
  • Sequencing
  • Sequencing Element Design
  • Max and Min-Delay
  • Clock Skew
  • Time Borrowing
  • Two-Phase Clocking

3
Sequencing
  • Combinational logic
  • output depends on current inputs
  • Sequential logic
  • output depends on current and previous inputs
  • Requires separating previous, current, future
  • Called state or tokens
  • Ex FSM, pipeline

4
Sequencing Cont.
  • If tokens moved through pipeline at constant
    speed, no sequencing elements would be necessary
  • Ex fiber-optic cable
  • Light pulses (tokens) are sent down cable
  • Next pulse sent before first reaches end of cable
  • No need for hardware to separate pulses
  • But dispersion sets min time between pulses
  • This is called wave pipelining in circuits
  • In most circuits, dispersion is high
  • Delay fast tokens so they dont catch slow ones.

5
Sequencing Overhead
  • Use flip-flops to delay fast tokens so they move
    through exactly one stage each cycle.
  • Inevitably adds some delay to the slow tokens
  • Makes circuit slower than just the logic delay
  • Called sequencing overhead
  • Some people call this clocking overhead
  • But it applies to asynchronous circuits too
  • Inevitable side effect of maintaining sequence

6
Sequencing Elements
  • Latch Level sensitive
  • a.k.a. transparent latch, D latch
  • Flip-flop edge triggered
  • a.k.a. master-slave flip-flop, D flip-flop, D
    register
  • Timing Diagrams
  • Transparent
  • Opaque
  • Edge-trigger

7
Sequencing Elements
  • Latch Level sensitive
  • a.k.a. transparent latch, D latch
  • Flip-flop edge triggered
  • a.k.a. master-slave flip-flop, D flip-flop, D
    register
  • Timing Diagrams
  • Transparent
  • Opaque
  • Edge-trigger

8
Latch Design
  • Pass Transistor Latch
  • Pros
  • Cons

9
Latch Design
  • Pass Transistor Latch
  • Pros
  • Tiny
  • Low clock load
  • Cons
  • Vt drop
  • Non-restoring
  • Back-driving
  • output noise sensitivity
  • dynamic
  • diffusion input

Used in 1970s
10
Latch Design
  • Transmission gate
  • -

11
Latch Design
  • Transmission gate
  • No Vt drop
  • Requires inverted clock
  • Non-restoring
  • Back-driving
  • output noise sensitivity
  • diffusion input

12
Latch Design
  • Inverting buffer
  • Fixes either

13
Latch Design
  • Inverting buffer
  • Restoring
  • No back-driving
  • Fixes either
  • Output noise sensitivity
  • Or diffusion input
  • Inverted output
  • Still dynamic

14
Latch Design
  • Tristate feedback

15
Latch Design
  • Tristate feedback
  • Static
  • Back-driving risk
  • Static latches are now essential

16
Latch Design
  • Buffered input

17
Latch Design
  • Buffered input
  • Fixes diffusion input
  • Noninverting
  • No back-driving
  • Static
  • Output load affects feedback time

18
Latch Design
  • Buffered output

19
Latch Design
  • Buffered output
  • No back-driving
  • Load doesnt slow down feedback path
  • Widely used in standard cells
  • Very robust (most important)
  • Rather large
  • Rather slow (1.5 2 FO4 delays)
  • High clock loading

20
Latch Design
  • Datapath latch
  • -

21
Latch Design
  • Datapath latch
  • Smaller, faster
  • unbuffered input
  • (back-driving when switching)

22
Flip-Flop Design
  • Flip-flop is built as pair of back-to-back latches

23
Enable
  • Enable ignore clock when en 0
  • Mux increase latch D-Q delay
  • Clock Gating increase en setup time, skew

24
Reset
  • Force output low when reset asserted
  • Synchronous vs. asynchronous

25
Set / Reset
  • Set forces output high when enabled
  • Flip-flop with asynchronous set and reset

26
Sequencing Methods
  • Flip-flops
  • 2-Phase Latches
  • Pulsed Latches

27
Timing Diagrams
Contamination and Propagation Delays
28
Max-Delay Flip-Flops
29
Max-Delay Flip-Flops
30
Max Delay 2-Phase Latches
31
Max Delay 2-Phase Latches
32
Max Delay Pulsed Latches
33
Max Delay Pulsed Latches
34
Min-Delay Flip-Flops
35
Min-Delay Flip-Flops
36
Min-Delay 2-Phase Latches
Hold time reduced by nonoverlap Paradox hold
applies twice each cycle, vs. only once for
flops. But a flop is made of two latches!
37
Min-Delay 2-Phase Latches
Hold time reduced by nonoverlap Paradox hold
applies twice each cycle, vs. only once for
flops. But a flop is made of two latches!
38
Min-Delay Pulsed Latches
Hold time increased by pulse width
39
Min-Delay Pulsed Latches
Hold time increased by pulse width
40
Time Borrowing
  • In a flop-based system
  • Data launches on one rising edge
  • Must setup before next rising edge
  • If it arrives late, system fails
  • If it arrives early, time is wasted
  • Flops have hard edges
  • In a latch-based system
  • Data can pass through latch while transparent
  • Long cycle of logic can borrow time into next
  • As long as each loop completes in one cycle

41
Time Borrowing Example
42
How Much Borrowing?
2-Phase Latches
Pulsed Latches
43
Clock Skew
  • We have assumed zero clock skew
  • Clocks really have uncertainty in arrival time
  • Decreases maximum propagation delay
  • Increases minimum contamination delay
  • Decreases time borrowing

44
Skew Flip-Flops
45
Skew Latches
2-Phase Latches
Pulsed Latches
46
Two-Phase Clocking
  • If setup times are violated, reduce clock speed
  • If hold times are violated, chip fails at any
    speed
  • In this class, working chips are most important
  • No tools to analyze clock skew
  • An easy way to guarantee hold times is to use
    2-phase latches with big nonoverlap times
  • Call these clocks f1, f2 (ph1, ph2)

47
Safe Flip-Flop
  • In class, use flip-flop with nonoverlapping
    clocks
  • Very slow nonoverlap adds to setup time
  • But no hold times
  • In industry, use a better timing analyzer
  • Add buffers to slow signals if hold time is at
    risk

48
Summary
  • Flip-Flops
  • Very easy to use, supported by all tools
  • 2-Phase Transparent Latches
  • Lots of skew tolerance and time borrowing
  • Pulsed Latches
  • Fast, some skew tol borrow, hold time risk

49
Metastability
  • Latches (flops) are bistable devices.
  • Depending on inputs, output is 0 or 1 and is
    stable.
  • If inputs are just right, the output can be at
    ½.
  • METASTABILITY
  • Resolution time is unknown due to noise, not due
    to metastability being random.
  • Metastability will always occur with these inputs.

50
Metastable State
51
Metastable State in Dynamic Latch
Write a Comment
User Comments (0)
About PowerShow.com