## King Fahd University of Petroleum and Minerals College of Computer Science and Engineering Computer Engineering Department

#### COE 202: Digital Logic Design (3-0-3) Term 181 (Fall 2018) Final Exam Saturday, December 15<sup>th</sup>, 2018

#### Time: 150 minutes, Total number of Pages = 9

 Name:
 ID:
 Section:

#### Notes:

- Do not open the exam book until instructed
- **Calculators are not allowed** (*basic, advanced, cell phones, etc.*)
- Answer all questions, show all steps, and clearly state any assumptions you make
- When instructed to use MSI components, only use standard components such as Adders, MUXs, Magnitude Comparators, DeMUXs, Decoders, Encoders (straight or priority). <u>Label each</u> <u>component and its inputs/outputs clearly.</u>

| Question | Maximum Points | Your Points |
|----------|----------------|-------------|
| 1        | 14             |             |
| 2        | 16             |             |
| 3        | 16             |             |
| 4        | 14             |             |
| Total    | 60             |             |

Page 2 of 9

(14 points)

## Question 1.

a) Implement the function G (A,B,C) with the following truth table using a single MUX with minimum size and inverters (as needed): (3 points)

| A | В | С | G |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |
|   |   |   |   |

b) Suppose you have three 4-1 MUXs, but you need an 8-1 MUX. Show one possible implementation of the 8-1 MUX using the three 4-1 MUXs you have. (3 points)

c) Consider the circuit shown below:



Inputs are A and B, and outputs are F0 and F1. Derive the truth table for this circuit. <u>Hint:</u> It helps if you evaluate the internal signals, L1 and L2, before evaluating the outputs. (2 points)

| AB  | L1 L2 | F0 F1 |
|-----|-------|-------|
| 0 0 |       |       |
| 0 1 |       |       |
| 1 0 |       |       |
| 1 1 |       |       |

d) A circuit receives two 4-bit signed numbers in 2's complement representation  $A=A_3A_2A_1A_0$ , and  $B=B_3B_2B_1B_0$ , two selection inputs S1 and S0, and produces a 4-bit output  $C = C_3C_2C_1C_0$ According to the following table:

| <b>S1</b>                                                       | <b>S0</b> | Function                                                         |     |
|-----------------------------------------------------------------|-----------|------------------------------------------------------------------|-----|
| 0                                                               | 0         | $\mathbf{C} = \mathbf{A} + \mathbf{B}$                           |     |
| 0                                                               | 1         | $\mathbf{C} = \mathbf{A} \cdot \mathbf{B}$                       |     |
| 1                                                               | 0         | $\mathbf{C} = \mathbf{B} \cdot \mathbf{A}$                       |     |
| 1                                                               | 1         | $C = \begin{cases} 10XX_2 & , \text{if } A = 0000_2 \end{cases}$ |     |
|                                                                 |           | C = {Position of most-significant 1 in A ,if A≠0000 <sub>2</sub> | _JT |
| This table illustrates the last function (when ({S1,S0}=2'b11): |           |                                                                  |     |

| A3A2A1A0 | $C_3C_2C_1C_0$ |
|----------|----------------|
| 0000     | 1 0 X X        |
| 1 X X X  | 0011           |
| 0 1 X X  | 0010           |
| 001X     | 0001           |
| 0001     | 0000           |
|          |                |

**Design the above circuit using** <u>only one adder</u> and any other MSI components and logic gates as needed. Note that you can freely use Verilog notation in your diagram, e.g. the concatenation operator, replacing  $1000_2$  with  $\{1'b1,3'b0\}$  is acceptable. (6 points)

### **Question 2:**

a) Given the shown Master-Slave configuration of two clocked S-R latches, it is required to complete the Y and Z signals in the following timing diagram. Assume Y and Z are initially equal to zero. Also assume zero propagation delays. (3 points)



b) Derive the state diagram of a synchronous Moore sequential circuit that receives a serial input Y and produces a serial output Z that is set to 1 when the circuit detects the sequence 00X1, where X represents a 0 or 1. (6 points)

c) A sequential circuit has one input X and one output Y. Its state diagram is as shown below. Design the circuit using minimum number of FFs and minimum logic gates. Use the specified state assignment codes. (write the solution on the next page) (6 points)



d) Specify whether the above circuit (in c above) has an unused state and explain why. (1 point)

# **Question 3:**

Part I: Given the synchronous sequential circuit shown below:a) Is it a Mealy or Moore sequential circuit and why?

**b**) Obtain the state diagram of this circuit.

(1 point) (6 points)



**Part II:** The following state diagram is for a sequential circuit with input *x*, output *z*, two state variables *A* and *B*, **positive** edge-triggered flip-flops, and **asynchronous active HI** reset.



a) Complete the timing diagram below for the above state diagram, showing the waveforms of the state variables A and B, and the output z. Initially, the flip-flops are reset to A = B = 0. (4 points)



b) Write a behavioral Verilog description of the circuit with the state diagram shown in **part II above.** 

(5 points)

# **Question 4:**

a) Using D flip-flop(s), MUXs, and logic gates only (i.e. <u>do not use any other MSI components</u>), design a 3-bit register with two mode selection inputs S1 and S0. The register should operate according to the following table: (6 points)

| <b>S1</b> | <b>S0</b> | Function                                                                                                |
|-----------|-----------|---------------------------------------------------------------------------------------------------------|
| 0         | 0         | No change                                                                                               |
| 0         | 1         | Parallel load (load inputs I₂I₁I₀ into register in parallel)                                            |
| 1         | 0         | Rotate Left (i.e., shift register contents to the lest feeding in the shifted bit out from the last bit |
|           |           | location as a serial input to the first location)                                                       |
| 1         | 1         | Synchronous clear (i.e. load with zeros) - the register does not have asynchronous reset                |

| <b>b</b> ) Write a behavioral Verilog description of the register in (a) above. (3 po |
|---------------------------------------------------------------------------------------|
|---------------------------------------------------------------------------------------|

c) The 4-bit shift register shown was initially loaded with ABCD = 0000. List in the table below the contents of the register after receiving each of the clock pulses indicated. (2 points)

|                     | Register Contents | 1     |
|---------------------|-------------------|-------|
|                     | A B C D (Binary)  |       |
| Initial             | 0 0 0 0           |       |
| After Clock Pulse 1 |                   |       |
| After Clock Pulse 2 |                   | Clock |

d) The counter circuit shown below is a modulo \_\_\_\_\_ counter. If the clock frequency is 240 MHz, then the frequency at the *LC* node (output of the 4-IP AND gate) is \_\_\_\_\_ MHz and the frequency of the Q0 output is \_\_\_\_\_ MHz. (3 points)

| LD | EN | Operation of the counter |
|----|----|--------------------------|
| 0  | 0  | Hold count               |
| 0  | 1  | Increment count          |
| 1  | Х  | Parallel load            |



Page 9 of 9