### MEMORY, LATCHES, + REGISTERS





- Structured
   Logic Arrays
- 2) Memory Arrays
- 3) Transparent Latches
- 4) Saving a few bucks at toll booths
- 5) Edge-triggered Registers

#### GENERAL TABLE LOOKUP SYNTHESIS





Generalizing:

Remember from a few lectures ago that, in theory, we can build any 1-output combinational logic block with multiplexers.

For an N-input function we need a  $-2^{N}$  input multiplexer.

BIG Multiplexers? How about 10-input function? 20-input?

### MUX GUTS







Multiplexers can be partitioned into two sections.

A **DECODER** that identifies the desired input, and

a **SELECTOR** that enables that input onto the output.

Hmmm, by sharing the decoder part of the logic MUXs could be adapted to make lookup tables with any number of outputs

#### A NEW COMBINATIONAL DEVICE





**DECODER:** 

k SELECT inputs, N = 2<sup>k</sup> DATA OUTPUTs.

Selected D, HIGH; all others LOW.

Have I
mentioned
that HIGH
is a synonym
for "1" and
LOW means
the same
as "0"



Now, we are well on our way to building a general purpose table-lookup device.

We can build a 2-dimensional ARRAY of decoders and selectors as follows ...

#### SHARED DECODING LOGIC





We can build a general purpose "table-lookup" device called a Read-Only Memory (ROM), from which we can implement any truth table and, thus, any combinational device

Made from PREWIRED connections  $\bigcirc$ , and CONFIGURABLE connections that can be either connected  $\bigcirc$  or not connected  $\bigcirc$ .

Comp 311 - Fall 2022

### ROM IMPLEMENTATION DETAILS





Hardwired "AND" logic Programmable "OR" logic

#### Advantages:

- Very regular design (can be entirely automated)

#### Problems:

- Active Pull-ups (Static Power)
- Long metal runs (Large Caps)
- Slow

JARGON: Inputs to a ROM are called ADDRESSES. The decoder's outputs are called WORD LINES, and the outputs lines of the selector are called BIT LINES.



### LOGIC ACCORDING TO ROMS



ROMs ignore the structure of combinational functions ...

- Size, layout, and design are independent of function
- Any Truth table can be "programmed" by minor reconfiguration:
  - Metal layer (masked ROMs)
  - Fuses (Field-programmable PROMs)
  - Charge on floating gates (EPROMs)
  - ... etc.

Model: LOOK UP value of function in truth table...

Inputs: "ADDRESS" of a T.T. entry,

ROM SIZE = # TT entries ...

... for an N-input boolean function, size =  $\frac{2^N \times \#outputs}{-----}$ 

#### EXAMPLE: 7-51DED DIE



What nature can't provide... electronics can (and with the same number of LEDs!).

We want to construct a die with the following sides:



An array of LEDs, labeled as follows, can be used to display the outcome of the die:



#### ROM-BASED DESIGN



| Truth T | able | for | a 7 | '-sided | Die |
|---------|------|-----|-----|---------|-----|
|---------|------|-----|-----|---------|-----|

| A | В | C | T | U | V | W           | X | У | Z |
|---|---|---|---|---|---|-------------|---|---|---|
| 0 | 0 | 0 | 0 | 0 | 0 | 0<br>1<br>0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 | 0 | 0 | 1           | 0 | 0 | 0 |
| 0 | 1 | 0 | 0 | 1 | 0 | 0           | 0 | 1 | 0 |
| 0 | 1 | 1 | 0 | 1 | 0 | 1           | 0 | 1 | 0 |
| 1 | 0 | 0 | 1 | 1 | 0 | 0           | 0 | 1 | 1 |
| 1 | 0 | 1 | 1 | 1 | 0 | 1           | 0 | 1 | 1 |
| 1 | 1 | 0 | 1 | 1 | 1 | 0           | 1 | 1 | 1 |
| 1 | 1 | 1 | 1 | 1 | 1 | 1           | 1 | 1 | 1 |

Once we've written out the truth table we've basically finished the design

#### Possible optimizations:

- Eliminate redundant outputs
- Addressing tricks



Comp 311 - Fall 2022

#### A SIMPLE ROM IMPLEMENTATION





| A | В | C | T/Z | U/Y | V/X | W |  |
|---|---|---|-----|-----|-----|---|--|
| 0 | 0 | 0 | 0   | 0   | 0   | 0 |  |
| 0 | 0 | 1 | 0   | 0   | 0   | 1 |  |
| 0 | 1 | 0 | 0   | 1   | 0   | 0 |  |
| 0 | 1 | 1 | 0   | 1   | 0   | 1 |  |
| 1 | 0 | 0 | 1   | 1   | 0   | 0 |  |
| 1 | 0 | 1 | 1   | 1   | 0   | 1 |  |
| 1 | 1 | 0 | 1   | 1   | 1   | 0 |  |
| 1 | 1 | 1 | 1   | 1   | 1   | 1 |  |



#### That was Easy!

ROMs are even more flexible than MUXes, because you can design the H/W first, and figure out the logic later!

This is the essence of programmability: "LATE-BINDING" logic specification.

10/11/2022

Comp 311 - Fall 2022

## "PROGRAMMABLE" LOOK-UP TABLES



Remember, EVERY combinational circuit can be expressed as a lookup table. As a result a ROM is a universal logic device. Unfortunately, the ROMs we've built thus far are "HARDWIRED". That is, the function that they compute is encoded by the pull-down transistors that are built into the OR-plane of the ROM. What we'd really like is a combinational gate that could be reconfigured dynamically. For this we'll need some form of storage.



# Analog Storage: Using Capacitors



We've chosen to encode information using voltages and we know from physics that we can "store" a voltage as "charge" on a capacitor:



Drive bit line, turn on access FET, force storage cap to new voltage To read:

precharge bit line, turn on access FET, detect (small) change in bit line voltage

#### Pros:

compact!

#### Cons:

- it leaks! ⇒ refresh
- complex interface
- reading a bit, destroys it

(you have to rewrite the value after each read)

it's NOT a digital circuit

This storage circuit is the basis for commodity DRAMs

#### DYNAMIC MEMORY



13





### A "DIGITAL" STORAGE ELEMENT



It's also easy to build a settable DIGITAL storage element (called a latch) using a MUX and FEEDBACK:



### A LOOK UNDER THE COVERS



Let's take a quick look at the equivalent circuit for our MUX when the gate is LOW (the feedback path is active)



This storage circuit is the basis for commodity SRAMs

#### Advantages:

- 1) Maintains remembered state for as long as power is applied.
- 2) State is DIGITAL

#### Disadvantage:

1) Requires more transistors

### WHY DOES FEEDBACK = STORAGE?



BIG 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!



Result: a bistable storage element

Not affected

by noise



Three solutions:

- · two end-points are stable
- · middle point is unstable

We'll get back to this!

#### STATIC D LATCH





**Positive latch** 







"static" means latch will hold data (i.e., value of Q) while G is inactive, however long that may be.

#### A DYNAMIC DISCIPLINE



Design of sequential circuits MUST quarantee that inputs to sequential devices are valid and stable during periods when they may influence state changes.



#### STORAGE ALONE IS NOT ENOUGH!





10/11/2022

Comp 311 - Fall 2022

#### FLAKEY CONTROL SYSTEMS





10/11/2022

### FLAKEY CONTROL SYSTEMS





### FLAKEY CONTROL SYSTEMS



Here's a strategy for saving 2 bucks the next time you find yourself toll booth



Professional Drivers Used! Don't try this At home!



Comp 311 - Fall 2022





10/11/2022









10/11/2022





10/11/2022



















The Solution: Add two gates and only open one at a time.









The Solution:
Add two gates
and only open
one at a time.
(Psst... Don't
tell the toll
folks)





The Solution:
Add two gates
and only open
one at a time.
(Psst... Don't
tell the toll
folks)



The Solution:
Add two gates
and only open
one at a time.



The Solution:
Add two gates
and only open
one at a time.





The Solution:
Add two gates
and only open
one at a time.
(Psst... Don't
tell the toll
folks)



KEY: At no time is there an open path through both gates...

#### EDGE-TRIGGERED FLIP FLOP



#### LOGICAL "ESCAPEMENT"



#### Observations:



- primary closed when replica is open (CLK is high)
- replica closed when primary is open (CLK is low)
- no combinational path through flip flop
- Q only changes shortly after 0→1 transition of CLK, so Flip flop appears to be "triggered" by rising edge of CLK





### FLIP-FLOP TIMING





TWO ISSUES





- · Must allow time for the input's value to propagate to the Primary's output while CLK is LOW.
  - · This is called "SET-UP" time (How long a D input must valid before the clock rises)
- · Must keep the input stable, just after CLK transitions to HIGH.

  This is insurance in case the Replica's gate opens just before the Primary's gate closes.
  - · This is called "HOLD-TIME" (How long a D input must 'remain' valid after the clock rises)
  - · Can be zero (or even negative!)
- · Assuring "set-up" and "hold" times is what limits a computer's performance

### FLIP-FLOP TIMING SPECS







 $t_{PD}$ : maximum propagation delay, CLK  $\rightarrow$ Q

t<sub>SETUP</sub>: setup time guarantee that D has propagated through feedback path before primary closes

t<sub>HOLD</sub>: hold time guarantee primary is closed and data is stable before allowing D to change

#### **SUMMARY**



- Regular Arrays can be used to implement arbitrary logic functions
- ROMs decode every input combination (fixed-AND array)
   and compute the output for it (customized-OR array)
- Memories
  - ROMs are HARDWIRED memories
  - RAMs include storage elements at each WORD-line and BIT-line intersection
    - dynamic memory: compact, only reliable short-term
    - static memory: controlled use of positive feedback
- Level-sensitive D-latches for static storage
- Dynamic discipline (setup and hold times)