# MASSACHUSETTS INSTITUTE OF TECHNOLOGY DEPARTMENT OF ELECTRICAL ENGINEERING AND COMPUTER SCIENCE

## 6.111 Introductory Digital Systems Laboratory Fall 2005

#### Midterm Exam: November 2, 2005

| Name | Score        |
|------|--------------|
|      | (out of 100) |
|      |              |

## Problem 1. (25 Points)

Congratulations, you're now a consultant for Hot Logic, Inc., a startup interested in building combinational logic devices that (of course) obey the static discipline. Their chief engineer has given you the following schematic and voltage-transfer curve for their prototype inverter design, the HL-INV:



A. (10 Points) Choose values for V<sub>OL</sub>, V<sub>IL</sub>, V<sub>IH</sub> and V<sub>OH</sub> so that the prototype device obeys the static discipline and has positive, non-zero noise margins. Give your values below or briefly explain why no such values can be found.

Briefly explain why values can't be found or specify voltage levels:  $V_{\rm OL}$ 

V<sub>IL</sub> \_\_\_\_\_

V<sub>IH</sub> \_\_\_\_\_

V<sub>OH</sub> \_\_\_\_\_

Noise margins \_\_\_\_\_

B. (5 Points) Add the appropriate n-channel mosfets to the schematic below to implement a two-input HL-NAND gate with inputs IN1 and IN2 that computes  $\overline{IN1 \bullet IN2}$ .



C. (5 Points) Assume that all mosfets in Hot Logic's gates have the same width and length. If we want the  $V_{OL}$  for the HL-NAND gate to be the same as the  $V_{OL}$  for the HL-INV gate, what value should we choose for RPU?

Value for RPU (in ohms): \_\_\_\_\_

D. (5 Points) Briefly compare the static power dissipation and noise margins of Hot Logic gates with CMOS gates.

## Problem 2. (60 Points)

The diagram below shows the schematic for an electronic lock with a combination consisting of some sequence of 0's and 1's. The user enters the combination by pressing the ZERO and ONE buttons in the correct sequence. If the last N digits that have been entered match the N-digit combination, the UNLOCK signal is asserted and the lock opens. You can assume that the button0 and button1 signals have been properly debounced and synchronized with CLK.



A. (10 Points) The L2P module is a level-to-pulse converter that asserts its output high for 1 clock cycle after a 0-to-1 transition on its input, as shown in the timing diagram below.



Complete the following Verilog implementation for the L2P module:

module L2P(clk,in,out);
 input clk;
 input in;
 output out;

endmodule

| s1 | s0 | one | zero | unlock | next_s1 | next_s0 |
|----|----|-----|------|--------|---------|---------|
| 0  | 0  | 0   | 0    | 0      | 0       | 0       |
| 0  | 0  | 0   | 1    | 0      | 1       | 1       |
| 0  | 0  | 1   | 0    | 0      | 0       | 0       |
| 0  | 0  | 1   | 1    | 0      | 1       | 1       |
| 0  | 1  | 0   | 0    | 0      | 0       | 1       |
| 0  | 1  | 0   | 1    | 0      | 1       | 0       |
| 0  | 1  | 1   | 0    | 0      | 0       | 0       |
| 0  | 1  | 1   | 1    | 0      | 1       | 0       |
| 1  | 0  | 0   | 0    | 1      | 1       | 0       |
| 1  | 0  | 0   | 1    | 1      | 1       | 1       |
| 1  | 0  | 1   | 0    | 1      | 0       | 0       |
| 1  | 0  | 1   | 1    | 1      | 1       | 1       |
| 1  | 1  | 0   | 0    | 0      | 1       | 1       |
| 1  | 1  | 0   | 1    | 0      | 1       | 1       |
| 1  | 1  | 1   | 0    | 0      | 0       | 1       |
| 1  | 1  | 1   | 1    | 0      | 1       | 1       |

Here's the truth table for the lock's Logic module:

B. (10 Points) What's the N-digit combination for the lock, i.e., what sequence of 0's and 1's will leave you with UNLOCK asserted regardless of what state the FSM was in when you started to enter the combination? Hint: use the truth table to draw a state transition diagram. You can use the back of the quiz pages as scratch paper.

# Lock combination: \_\_\_\_\_

C. (5 Points) Briefly describe what happens if both buttons are pressed simultaneously.

D. (8 Points) Here are the timing parameters for the two D-Registers used to hold the current state:  $t_{CD} = 0$ ns,  $t_{PD} = 2$ ns,  $t_{SETUP} = 2$ ns,  $t_{HOLD} = 1$ ns. What are the constraints on  $t_{CD}$  and  $t_{PD}$  of the Logic module if we want the circuit to operate reliably with a 100MHz clock?

# Constraints on Logic module's t<sub>CD</sub>:

#### Constraints on Logic module's t<sub>PD</sub>: \_\_\_\_\_

E. (6 Points) For this question assume the register timing specifications given in part (D) and that the timing specifications of the Logic module are  $t_{CD} = 1$ ns and  $t_{PD} = 5$ ns. Complete the timing diagram below carefully indicating when STATE[0] and NEXT\_STATE[0] are valid and when they are invalid. Each vertical grid line represents 1ns.



F. (6 Points) If the Logic module is implemented using a ROM, what size ROM would we need?

Number of locations in ROM: \_\_\_\_\_

# Number of bits/location in ROM: \_\_\_\_\_

G. (10 Points) Give a minimized sum-of-products expression for next\_s[1] output of the Logic module. Hint: the Karnaugh Map template given below may be useful.

Minimized sum-products expression for next\_s[1]: \_\_\_\_\_



H. (5 Points) Draw a schematic diagram for a circuit that implements next\_s[1]. Your circuit should using only inverters, 2-input NAND gates and 2-input NOR gates.

## Problem 3. (15 Points)

The following Verilog test jig, initially sets a to 1, b to 0 and clk to 0, waits 10 time units, sets clk to 1, waits another 10 time units and the prints out the values of a, b and c.

```
module testjig();
  reg clk,a,b;
  wire c;
  assign c = -a;
  // CODE SNIPPETS ARE INSERTED HERE
  initial begin
    a = 1;
    b = 0;
    clk = 0;
          // wait 10 time units
    #10
    clk = 1;
          // wait 10 time units
    #10
    $display("a=%d b=%d c=%d\n",a,b,c);
    $stop;
  end
endmodule
```

A series of tests is run, each using one of the code snippets below substituted into the testjig module at the indicated location. For each snippet indicate the values printed out for a, b and c. Write ??? for a value if it cannot be determined using standard Verilog semantics.