EE 121 Digital Design Laboratory February 6, 2001 Handout #18

## Midterm Examination #1

Open book, open notes. Time limit: 45 minutes

1. (30 points) *Combinational circuit analysis and timing.* The logic circuit below has three inputs, X, Y, and Z, and two outputs, F and G.



a. Find the minterm list and maxterm list representations for the outputs  $\mathsf{F}$  and  $\mathsf{G}.$ 

| Function | Minterm list     |   | Maxterm list       |   |
|----------|------------------|---|--------------------|---|
| F        | $\Sigma_{XYZ}$ ( | ) | П <sub>ХҮZ</sub> ( | ) |
| G        | $\Sigma_{XYZ}$ ( | ) | П <sub>ХҮZ</sub> ( | ) |

b. The propagation delays for the NAND gates in the above circuit are  $t_{\rm pLH} = 5$  ns and  $t_{\rm pHL} = 3$  ns. What are the worst case propagation delays from X to F? You may assume that wire delays are zero.

 $t_{\rm pLH}({\sf X} \rightarrow {\sf F}) =$  \_\_\_\_\_  $t_{\rm pHL}({\sf X} \rightarrow {\sf F}) =$  \_\_\_\_\_

2. (20 points) *Full adder CMOS logic circuit*. A gate-level circuit diagram for a full adder and a CMOS logic circuit for an XOR gate are shown below. The XOR can be built with only 8 transistors, provided the complements of the inputs are available. (For this problem, it is *not* necessary to understand how the XOR circuit works.)



Since the complements of the inputs are needed for the XOR circuit, it makes sense to use them elsewhere in a CMOS logic circuit for a full adder. Design a CMOS logic circuit using 12 transistors (6 p-channel and 6 n-channel) that computes COUT from the complements X', Y', CIN' of the input signals. Hint: majority(X, Y, Z) = minority(X', Y', Z').

3. (20 points) *Full adders are complete*. Full adders form a *complete* set of logic gates; that is, every Boolean function can be implemented using only full adders.



- a. Wire each of the full adders above to produce the specified logic function (AND2, OR2, or NOT). In each case, only one output of the full adder is used. The full adder inputs may be connected to primary input signals or to constant values 0 or 1.
- b. In each case, the "unused" output of the full adder is a Boolean function. Write next to that output pin the name or formula for this bonus output.