## CSE140L Final Exam, 3-4:30PM, Friday June 12, Name Sample 1. Use CMOS complementary logic to implement the following functions. Draw the circuit to show your design. a) $$f(a) = a$$ . b) $$f(a,b) = (a+b)$$ . c) $$f(a,b,c) = [a(b+c)]$$ . $$\begin{array}{c} b \rightarrow 0 \\ \hline c c \rightarrow 0 \\ \hline c \rightarrow 0 \\ \hline c \rightarrow 0 \\ \hline c \rightarrow 0 \\ \hline c \rightarrow 0 \\ \hline c \rightarrow 0 \\ \hline c \rightarrow 0 \\ \hline c$$ d) $$f(a,b,c)=[ab+(a+b)c]'$$ $$a \xrightarrow{A} b \xrightarrow{b} b \xrightarrow{b} f(a,b,c)$$ $$a \xrightarrow{b} b \xrightarrow{b} b \xrightarrow{b} f(a,b,c)$$ 2. The logic diagram below shows a 3-bit counter. Derive the function behavior of the counter. a) Suppose the flip-flops are reset initially, enumerate the states (A,B,C) according to the clock sequence. Fill the following table. | Time | 0 | 1 | 2 | 3 | 4 | 5 | 6 | |------|---|---|-----|---|---|---|-----------| | A | 0 | | | 0 | O | 0 | | | В | 0 | 0 | *** | | 0 | 0 | <u> </u> | | С | 0 | 0 | 0 | | | | $\perp O$ | b) Suppose the flip-flops are not reset initially. Instead, the initial state is (A,B,C) = (0,1,0). Fill the following table. | Time | 0 | T 1 | 2 | 3 | 4 | 5 | 6 | |------|---|-----|---|---|---|------|----------| | A | 0 | | 1 | 0 | 0 | 0 | | | В | 1 | Ö | 1 | 1 | 0 | 0 | 0 | | С | 0 | | Ö | | | L-0- | $LO_{-}$ | 3. Given a Mealy machine as described by the following state table. Transform the Mealy machine to a Moore machine. Write the state table. | PS | x=0 | X:-=1 | |----|-------|-------| | Λ | F, 1 | В, 0 | | В | C, 0 | D, 1 | | С | A, 0 | E, 0 | | D | В, 0 | E, 1 | | E | В, 1 | D, 1 | | F | C,0 | F,1 | | | NS, z | | 4. Assume a computer system has a simple instruction set described as follows: | Command | 2-bit<br>Instruction | 4-bit<br>Data | Description | | |---------|----------------------|----------------|---------------------------------------------------------------------------------------|--| | Movel | 00 | $d_3d_2d_1d_0$ | Move data d <sub>3</sub> d <sub>2</sub> d <sub>1</sub> d <sub>0</sub> to register R1. | | | Move2 | 01 | $d_3d_2d_1d_0$ | Move data d <sub>3</sub> d <sub>2</sub> d <sub>1</sub> d <sub>0</sub> to register R2. | | | Add | 10 | XXXX | Add R1 and R2, store the result back to R1, and output the overflow flag. | | | Branch | 11 | $d_3d_2d_1d_0$ | Branch to instruction at address $d_3d_2d_1d_0$ , if overflow flag is true. | | a) Implement a datapath system to carry out the instructions. Assuming that you have two four-bit registers R1 and R2, one flip-flop for overflow\_flag, one 4-bit adder with overflow output, one counter for program branching, and one memory module which stores the instruction. Draw the logic diagram to illustrate your data path design. Label the signals of all the modules. b) Implement the control subsystem. Use the truth table to describe the control subsystem design.