### **ECE 341 Midterm Exam**

| Time allowed: 90 minutes | Name: |
|--------------------------|-------|
| Total Points: 75         |       |
| Points Scored:           |       |

#### Problem No. 1 (11 points)

For parts (a) through (d), indicate whether the statement is TRUE or FALSE. For parts (e) and (f) encircle the correct answer(s).

- (a) Asynchronous counters are usually faster than synchronous counters.
- (b) A shift register is capable of reading/writing data in a "serial" fashion.
- (c) CISC instructions typically have a higher average CPI than RISC instructions.
- (d) A sequential multiplier requires more adders than an array multiplier.
- (e) A 16-bit **blocked carry-lookahead adder (CLA)** composed of four 4-bit CLA blocks is used to add two numbers X  $(x_{15}x_{14}x_{13}....x_1x_0)$  and Y  $(y_{15}y_{14}y_{13}....y_1y_0)$ . Under which of the following conditions is the carry-out  $c_{12}$  equal to 0? Encircle all the correct options:
  - a.  $c_0 = 0$ , all the CLA blocks generate a carry, but none of the CLA blocks propagate a carry
  - b.  $c_0 = 0$ , all the CLA blocks propagate a carry, but none of the CLA blocks generates a carry
  - c.  $c_0 = 1$ , all the CLA blocks propagate a carry, but none of the CLA blocks generates a carry
- (f) **(Extra credit problem: 3 points)**: You are required to implement a logic function  $f = z + xy\bar{z}$  in its **minimal** form. You can use any combination of 2-input logic gates. What is the **minimum** number of logic gates required to implement f?
  - i. 1 gate
  - ii. 4 gates
  - iii. 2 gates

### Problem No. 2 (13 points)

(a) **(5 points)** The input waveforms for a **gated SR latch** are shown in the following figure. Plot the Q output as a function of time.



- (b) (8 points) You are required to design a logic function f for comparing two 3-bit numbers A  $(a_2a_1a_0)$  and  $B(b_2b_1b_0)$ , as follows:
  - i. When A is equal to B, the output f should be equal to "0"
  - ii. When A is not equal to B, the output f should be equal to "1".

Derive the logic expression for f and draw the logic circuit implementation.

# Problem No. 3 (15 points)

(a) **(7 points)** Implement the following 3-input function by using a 2-input multiplexer and any number of NOT gates.

$$f = \bar{x} \, \bar{y} \, \bar{z} + x \, \bar{y} \, \bar{z} + x \, y \, \bar{z} + x \, y \, z$$

(b) **(8 points)** You are required to design a <u>3-bit</u> synchronous counter by using a finite state machine. The counter has two external input signals *x* and *y*, which dictate the operation of the counter as follows: (i) If the two inputs have identical values, the counter counts <u>up</u>, (ii) If x = 0, y = 1, the counter <u>holds</u> its value, (ii) If x = 1, y = 0, the counter keeps counting <u>down</u> until it reaches "2" and then stops there. The counter also has an output signal *z*, which is equal to 1 only if the present value of the counter is a non-zero multiple of 3.

Draw the state diagram for this state machine.

### Problem No. 4 (20 points)

(a) **(5 points)** A 4-bit carry-lookahead adder (CLA) is used to add two numbers  $X(x_3x_2x_1x_0) = 0110$  and  $Y(Y_3Y_2Y_1Y_0) = 1001$  with an external carry-in  $c_0 = 1$ . Use the CLA carry-out equation to compute the values of following outputs: (i) carry-out  $c_3$ , (ii) sum  $s_3$ .

(b) **(7 points)** A multiplier circuit employing Booth algorithm is used to multiply two numbers *A* and *B*. Assume that the circuit can choose either of the two operands (A or B) as "multiplicand" and "multiplier", respectively. The choice needs to be made in such a way that the multiplication operation results in the least number of non-zero summands.

If A = +6, B = -15, which of the two operands should be chosen as the "multiplier"? Why?

- (c) **(8 points)** Consider a program running on a processor P1 with a clock period of 0.5 nanoseconds. The instructions in the program can be categorized into two types:
- (i) Type-1: Each of these instructions takes 3 cycles to execute on P1.
- (ii) Type-2: Each of these instructions takes 1 cycle to execute on P1.

Assume that x% of the total instructions in the program are of Type-1, while the remaining instructions are of Type-2. Also assume that processor is required to have an instruction execution rate of at least 1 billion instructions per second. What is the maximum value of "x" (percentage of Type-1 instructions), which will allow the processor to meet the desired execution rate target? Show all the necessary calculations.

## Problem No. 5 (16 points)

The 5-stage RISC processor discussed in class is used to execute the following sequence of instructions, one after the other:

Instruction 1:STORER1, 200(R2)Instruction 2:LOADR1, 100(R2)Instruction 3:SUBTRACT R4, R1, R3

The processor data path with all the control signals is shown in the following figure:



(a) **(5 points)** Write down the register transfer notation (RTN) expression for each of the three instructions.

| 1 | h۱ | (5 noin  | ts) For        | each  | of the three | e instruction    | s in the  | nrogram   | answer th     | e following | aniestions.  |
|---|----|----------|----------------|-------|--------------|------------------|-----------|-----------|---------------|-------------|--------------|
| ١ | υį | וווטק כן | <b>L3</b> 1 OI | Cacii | or the time  | - 111311 4111111 | שווו נווכ | piugiaiii | , aliswei tii |             | z questions. |

(i) Which of the two inputs ("0" or "1") is selected by MuxB?

(ii) Which of the three inputs ("0", "1" or "2") is selected by MuxY?

(c) **(6 points)** The following table shows the initial values of the relevant registers and memory locations. Complete the table by filling in the column corresponding to the final values of each register and memory location, after the above code sequence has been executed by the processor.

| Register/Memory Location | Initial Contents | Final Contents |
|--------------------------|------------------|----------------|
| R1                       | 46               |                |
| R2                       | 30000            |                |
| R3                       | 30               |                |
| R4                       | 10               |                |
| Memory Address 30100     | 64               |                |
| Memory address 30200     | 20               |                |