## State Holding and Sequential Circuit Design



Andreas G. Andreou Pedro Julian

Electrical and Computer Engineering Johns Hopkins University

http://andreoulab.net

Lecture Notes adapted from Lecture 05 in MIT 6.004 Computation Structures http://6004.csail.mit.edu/

and from Pedro Julian's VLSI class notes

# Progress so far: all about levels of abstraction and representation



## Something we can't build (yet)

What if you were given the following design specification:



## **Digital machine model**



Plan: Build a Sequential Circuit with stored digital STATE -

- Memory stores CURRENT state, produced at output
- Combinational Logic computes
  - •NEXT state (from input, current state)
  - OUTPUT bit (from input, current state)
- State changes on LOAD control input

## Storage



Combinational logic is *stateless*: valid outputs always reflect current inputs.

- To build devices with state, we need components which *store* information (e.g., state) for subsequent access.
  - *ROMs* (and other combinational logic) store information "wired in" to their truth table
  - *Read/Write* memory elements are required to build devices capable of changing their contents.

#### How can we store – and subsequently access -- a bit?

- Mechanics: holes in cards/tapes
- Optics: Film, CDs, DVDs, ...
- Magnetic materials
- · Delay lines; moonbounce
- Stored charge

## **Dynamic Storage: using capacitors**

"store" a charge on a capacitor!



To write:

Drive bit line, turn on access fet,

force storage cap to new voltage To read:

precharge bit line, turn on access f detect (small) change in bit line vol

## e-DRAM cell

#### Need cell with big capacitance !







**(b)** 



Introduction to VLSI Systems

#### **Dynamic Storage: using capacitors**



Pros:

- compact low cost/bit (on BIG memories)
  Cons:
- complex interface
- stable? (noise, ...)
- it leaks! ⇒ refresh

Suppose we refresh CONTINUOUSLY? Static Storage: using feedback

IDEA: use **positive feedback** to maintain storage indefinitely. Our logic gates are built to restore marginal signal levels, so noise shouldn't be a problem!



#### Settable storage element

It's easy to build a settable storage element (called a latch) using a *lenient* MUX:



#### New device: "transparent" D latch



## Latch: CMOS realization

- Switches implemented using transmission gates
- Switches are complementary
  - L1 passes input to output in transparent mode
  - L2 closes loop and keeps the state







## Let's try it out!



Plan: Build a Sequential Circuit with one bit of STATE -

- Single latch holds CURRENT state
- Combinational Logic computes
  - NEXT state (from input, current state)
  - OUTPUT bit (from input, current state)
- State changes when G = 1 (briefly!)



Introduction to VLSI Systems

### **Combinational cycles**



When G=1, latch is Transparent...

- $\dots$  provides a combinational path from D to Q.
- Can't work without tricky timing constrants on G=1 pulse:
  - Must fit within contamination delay of logic
  - Must accommodate latch setup, hold times

Want to signal an INSTANT, not an INTERVAL...

Looks like a stupid Approach to me...



Introduction to VLSI Systems

## **Edge-triggered Flip-Flop**



## Edge-triggered Flip-Flop



**Observations**:

- only one latch "transparent" at any time:
  - master closed when slave is open
  - slave closed when master is open
  - $\Rightarrow$  no combinational path through flip flop

(the feedback path in one of the master or slave latches is always active)

 ◆ Q only changes shortly after O → 1 transition of CLK, so flip flop appears to be "triggered" by rising edge of CLK

### Flip-Flop waveforms



#### Edge triggered FF

- Positive (rising) edge FF
  - Master negative, slave positive



#### Edge triggered FF

- Falling (negative) edge FF
  - Master positive, slave negative







## Single-clock synchronous circuits



## We'll use Flip Flops and *Registers* – groups of FFs sharing a clock input – in a highly constrained way to build digital systems:

#### Single-clock Synchronous Discipline

- •No combinational cycles
- Single periodic clock signal shared among all clocked devices
- •Only care about value of register data inputs just before rising edge of clock
- Period greater than every combinational delay + setup time
- •Change saved state after noiseinducing logic transitions have stopped!

#### Model: Discrete Time



Active Clock Edges punctuate time ---

- Discrete Clock periods
- Discrete State Variables
- Discrete specifications (simple rules eg tables relating outputs to inputs, state variables)
- ABSTRACTION: Finite State Machines (next lecture!)

## Summary

"Sequential" Circuits (with memory):

#### Basic memory elements:

- Feedback, detailed analysis => basic level-sensitive devices (eg, latch)
- 2 Latches => Flop
- Dynamic Discipline: constraints on input timing

#### Synchronous 1-clock logic:

- Simple rules for sequential circuits
- Yields clocked circuit with  $\rm T_S, T_H$  constraints on input timing

#### Finite State Machines

Next Lecture Topic!



#### Computer Aided Design Tools

