

6.004 Computation Structures  
Spring 2009

For information about citing these materials or our Terms of Use, visit: <http://ocw.mit.edu/terms>.

Latch / MUX / PIPElined  
Multiplexor | FSM

Reliability  $\rightarrow t_{pp}, t_{cp}$

$p3b$ , ROM, CLK

# Concepts.

## 1. MUX = Multiplexer



Value  $Y$  determined to be a value at  $A, B$  depending on Input  $S$



Muxes are Universal

Can implement XOR, NAND easily.

## 2. ROM



input:  $k \times 1$

output:  $2^k$

one of outputs is high, all others will be low

### Full Adder



N Rows Input

M Rows Output

$\Rightarrow$  M-N matrix

ROM configurations

depending on the matrix structure, signals can be cycled

$\Rightarrow$  may have glitchy operations!

# ROM



## 1. Making a device Using "State"



## 2. Latch, or D Latch

⇒ Using Mux



| G | D | Q' | Q |
|---|---|----|---|
| 0 | 0 | 0  | 0 |
| 0 | 1 | 1  | 1 |
| 1 | 0 | -  | 0 |
| 1 | 1 | -  | 1 |

### 2-1 D-Latch timing Problem



According to principles of  
combinational logic gates,  
this value can't be determined

In this area, not determined

⇒ Not lalent

Wait! What is the definition of a word, "lenient"

Lenient: 모든 입력에 대해 충분한  $t_{pp}$ 가 있을 경우  
행성 유효한 출력을 가질 때

A Timing Condition for Lenient D Latch



Setup latch

D

G

- a

$$t_{\text{setup}} = ① + ②$$
$$t_{\text{hold}} = ③$$



Dynamic Discipline for a Latch

$t_{\text{setup}}$ : Interval prior to G transition, D must be stable, for  $2t_{\text{pp}}$  at least

$t_{\text{hold}}$ : Interval following G transition, D must be stable for  $t_{\text{pp}}$  at least

Why D Latch?  $\Rightarrow$  To make a logic device with "state"

### 3 D- register

why? to prevent positive feedback loop.

⇒ one signal at a time

⇒ CLK, two Latches



⇒ only one signal passes at a time

Diagram:



Master contamination delay  
must be longer than

Slave's hold time

$$\Rightarrow t_{m,c} \geq t_{s,h}$$



$$t_{CD,C} = 0.2 \text{ ns}$$

$$t_{CD,R} = 0.1 \text{ ns}$$

$$t_{PD,C} = 3 \text{ ns}$$

$$t_{PD,R} = 5 \text{ ns}$$

$$t_{\text{setup}} = 2 \text{ ns}$$

$$t_{\text{hold}} = ?$$

$t_{\text{hold}} = \text{shortest path } t_{CD} = 0.2 + 0.1 = 0.3 \text{ ns}$

$t_{CD} \Rightarrow \text{time need to next } \underline{\text{rising edge}}$

$\Rightarrow t_{PP,IR} + t_{PP,C} + \underline{t_{\text{setup}}} = 1 \text{ ns}$

$\leq 0.2 + 0.1 + 2$   
Setup time

MASSACHUSETTS INSTITUTE OF TECHNOLOGY  
DEPARTMENT OF ELECTRICAL ENGINEERING AND COMPUTER SCIENCE

**6.004 Computation Structures**  
Spring 2009

**Quiz #2: March 13, 2009**

| Name | Athena login name | Score |
|------|-------------------|-------|
|      |                   |       |

**Problem 1** (4 points): **Quickies and Trickies**

- (A) A latch is constructed from a 2-input lenient MUX having a propagation delay of 200ps and a contamination delay of 20ps, using the design shown in lecture. Give the minimum appropriate setup time specification for this latch.

**Setup time (ps):** \_\_\_\_\_

- (B) Give the best achievable asymptotic throughput for a pipelined multiplier capable of multiplying two N-bit operands. Enter a number, a formula, or “CAN’T TELL”.

**Asymptotic throughput:**  $\Theta(\text{_____})$

- (C) A complex combinational circuit is constructed entirely from 2-input NAND gates having a propagation delay of 1 ns. If this circuit is pipelined for maximal throughput by adding registers whose setup time and propagation delay are each 1 ns, what is the throughput of the resulting pipeline? Enter a number, a formula, or “CAN’T TELL”.

**Throughput ( $\text{ns}^{-1}$ ):** \_\_\_\_\_

- (D) A “Thingee” is a clocked device built out of 3 interconnected components, each of which is known to be a 4-state FSM. What bound, if any, can you put on the number of states of a Thingee?

**Max # of states, or “Can’t Tell”:** \_\_\_\_\_

### **Problem 2 (6 points): Reliability measures**

Your thesis supervisor has offered you a number of candidate topics, each involving the construction of a gadget from reliable electronic components. To select a project, you decide to evaluate, for each choice, whether it can be made to meet its specification with perfect reliability. Each device takes two digital inputs A and B, each of which start at logical 0 and have a single positive transition at  $t_A$  and  $t_B$ , respectively. The propagation delay  $t_{pd}$  is to be 1 nanosecond.

- (A) The output Q is guaranteed to be a valid 1 or 0  $t_{pd}$  after the second input transition, but there is no constraint on which value is output.

**Can be made reliable? Circle one: YES ... NO ... CAN'T TELL**

- (B) The output Q is guaranteed to be a valid 1 or 0  $t_{pd}$  after the second input transition, must be 1 if  $t_A$  is 10ns or more *earlier* than  $t_B$ , must be 0 if  $t_A$  is 10ns or more *later* than  $t_B$ , or otherwise can be either valid logic level.

**Can be made reliable? Circle one: YES ... NO ... CAN'T TELL**

- (C) At  $t_{pd}$  after the second input transition, the output Q must be a valid 1 if  $t_A$  is 10ns or more *earlier* than  $t_B$ , must be a valid 0 if  $t_A$  is 10ns or more *later* than  $t_B$ , and is otherwise unspecified (may be invalid) if  $t_A$  and  $t_B$  are within 10 ns of each other.

**Can be made reliable? Circle one: YES ... NO ... CAN'T TELL**

- (D) Prior to  $t_A$  and  $t_B$  the output Q must be a valid 0, but it must become a valid 1 within  $t_{pd}$  of the first input transition.

**Can be made reliable? Circle one: YES ... NO ... CAN'T TELL**

- (E) The output Q is guaranteed to be a valid 1 or 0  $t_{pd}$  after the second input transition, must be 1 if the transitions are within 10ns of each other, and must be 0 if the transitions are separated by more than 20ns.

**Can be made reliable? Circle one: YES ... NO ... CAN'T TELL**

- (F) Two outputs, Q and R, where R is guaranteed to become a valid 1 sometime after the first input transition. When R=1, the Q output must be a valid 1 if  $t_A$  is 10ns or more *earlier* than  $t_B$ , must be a valid 0 if  $t_A$  is 10ns or more *later* than  $t_B$ , or otherwise may be either valid logic level.

**Can be made reliable? Circle one: YES ... NO ... CAN'T TELL**

### Problem 3. (9 Points) Picking Locks, 6.004 style

Perfectly Perplexing Padlocks makes an entry-level electronic lock, the P3b, built from an FSM with two bits of state. The P3b has two buttons (“0” and “1”) that when pressed cause the FSM controlling the lock to advance to a new state. In addition to advancing the FSM, each button press is encoded on the B signal (B=0 for button “0”, B=1 for button “1”). The padlock unlocks when the FSM sets the UNLOCK output signal to 1, which it does **whenever—and only whenever—the last 3 button presses correspond to the 3-digit combination**. The combination is unique, and will open the lock independently of the starting state. Unfortunately the design notes for the P3b are incomplete.



| $S_1$ | $S_0$ | B | $S'_1$ | $S'_0$ | U |
|-------|-------|---|--------|--------|---|
| 0     | 0     | 0 | 1      | 1      | 0 |
| 0     | 0     | 1 | 0      | 0      | 0 |
| 0     | 1     | 0 |        |        | 1 |
| 0     | 1     | 1 | 1      | 0      | 1 |
| 1     | 0     | 0 | 0      | 1      | 0 |
| 1     | 0     | 1 |        |        | 0 |
| 1     | 1     | 0 |        |        | 0 |
| 1     | 1     | 1 |        |        | 0 |

(A) (1 Point) What is the 3-bit combination for the lock?

lock combination: \_\_\_\_\_

(B) (4 Points) Using the specification and clues from the partially completed diagrams above fill in the information that is missing from the state transition diagram and its accompanying truth table. When done:

- each state in the transition diagram should be assigned a 2-bit state name  $S_1 S_0$  (note that in this design the state name is *not* derived from the combination that opens the lock),
- the arcs leaving each state should be mutually exclusive and collectively exhaustive,
- the value for U should be specified for each state, and
- the truth table should be completed.

(complete above transition diagram and table)

The circuit diagram for the P3b is shown below. You may assume that the B input has been appropriately synchronized with CLK.



(C) (1 Point) How many bits are stored in the ROM?

**Total size of ROM, in bits:** \_\_\_\_\_

(D) (1 Point) What is the smallest value for the ROM's contamination delay that ensures the necessary timing specifications are met?

**smallest valid value for  $t_{CD,ROM}$  (ns):** \_\_\_\_\_

(E) (1 Point) What is the smallest value for the period of CLK that will meet the timing specifications?

**smallest value for  $t_{CLK}$  (ns):** \_\_\_\_\_

(F) (1 Point) What is the smallest setup time for the B input with respect to the active edge of CLK that ensures the necessary timing specifications are met?

**smallest setup time for B input (ns):** \_\_\_\_\_

#### Problem 4 (6 Points) The Mysterious XYZ Machine

An unidentified government agency has a design for a combinational device depicted below:



Although you don't know the function of each of the component modules, they are each combinational and marked with their respective propagation delays. You have been hired to analyze and improve the performance of this device.

*NOTE: Scratch copies of the above diagram appear on the back of the previous page.*

- (A) (1 Point) What are the best throughput and latency that can be achieved with the combinational device?

Latency: \_\_\_\_\_ ns; Throughput: \_\_\_\_\_  $\text{ns}^{-1}$

- (B) (4 Points) Show how to pipeline the above circuit for maximum throughput, by marking locations in the diagram where registers are to be inserted. Use a minimum number of registers, but be sure to include one on the output.

**(mark register locations in diagram above)**

- (C) (1 Point) What are the latency and throughput of your pipelined circuit?

Latency: \_\_\_\_\_ ns; Throughput: \_\_\_\_\_  $\text{ns}^{-1}$

**END OF QUIZ!**