# HKN ECE 120 Midterm 3 Worksheet

# Serialized Design (Review)

### Problem 1

Consider one bit-slice of a full adder.

- a. How many bits need to be passed between each bit slice? What are they?

  1 bit. We need to pass the carry bit between each bit slice.
- b. If we wanted to serialize this design and add 1 bit at a time, how many D flip-flops would we need to store these signals?
  - 1. We need 1 DFF for each signal we need to store.
- c. Implement a serialized binary adder, adding 1 bit at a time.

figures/serial1c\_solution.png

Note: the CLR (clear) signal is used when we want to clear the carry bit between adding different sets of numbers.

d. Assume we instead wanted to add 4 bits (1 hexadecimal) at a time. Would any signals be different?

No, we still only need to pass one carry bit, the carry bit of the MSB, to the next clock cycle's LSB.

| e. Implement a serialized binary adder, adding 4 bits at a time. |
|------------------------------------------------------------------|
| figures/serial1e_solution.png                                    |

Consider a serialized circuit that takes a sequence of bits, 1 bit at a time, and outputs the same sequence of bits but is delayed by 2 bits and inverted. For example, assuming inputs and outputs are taken at the start of each clock cycle, if the input is 100101101100, then the output is XX0110100100.

- a. How many bits do we need to store between each clock cycle?2 bits.
- b. Implement this circuit using D flip-flops.



c. Can we also implement this circuit using a shift register? Yes:

# Problem 3

In 50 words or less, what are the advantages and disadvantages of serialization over bit-slicing?

For larger sequences, serialized designs take much less area than bitsliced designs. However, serialized designs are much slower, as they depend on the speed of a clock signal, while bit-sliced design is only dependent on gate delay.



# Finite State Machines

#### Problem 1

Suppose we wanted to create a Moore FSM that has two outputs Z and O. Z is 1 if and only if the input contains three or more consecutive zeroes, and O is 1 if and only if the input contains three or more consecutive ones.

- a. How many unique states do we need for this finite state machine? How many bits do we need to represent all states? 6 states. For both 0s and 1s, we want to keep track of how many we have seen consecutively. We have one state for seeing one, two, and three or more for both 0 and 1, so 6 states. We can represent it with 3 bits, allowing for up to 8 states.
- b. Draw a state diagram for this FSM, showing all states used. **This is one possible enumeration.**
- c. Create a truth table for this FSM. For unused states, write X.

figures/fsm1b-solution.png

| S_2 | S_1 | S_0 | A (input) | $S_{-}2^{+}$ | $S_{-1}^{+}$ | $S_{-}0^{+}$ |
|-----|-----|-----|-----------|--------------|--------------|--------------|
| 0   | 0   | 0   | 0         | 0            | 0            | 1            |
| 0   | 0   | 0   | 1         | 1            | 0            | 0            |
| 0   | 0   | 1   | 0         | 0            | 1            | 1            |
| 0   | 0   | 1   | 1         | 1            | 0            | 0            |
| 0   | 1   | 0   | 0         | X            | X            | X            |
| 0   | 1   | 0   | 1         | X            | X            | X            |
| 0   | 1   | 1   | 0         | 0            | 1            | 1            |
| 0   | 1   | 1   | 1         | 1            | 0            | 0            |
| 1   | 0   | 0   | 0         | 0            | 0            | 0            |
| 1   | 0   | 0   | 1         | 1            | 0            | 1            |
| 1   | 0   | 1   | 0         | 0            | 0            | 0            |
| 1   | 0   | 1   | 1         | 1            | 1            | 1            |
| 1   | 1   | 0   | 0         | X            | X            | X            |
| 1   | 1   | 0   | 1         | X            | X            | X            |
| 1   | 1   | 1   | 0         | 0            | 0            | 0            |
| 1   | 1   | 1   | 1         | 1            | 1            | 1            |

d. Use K-maps or another method to derive next-state expressions for this FSM.

$$S_2^+ = A$$

$$S_1^+ = S_2' S_0 A' + S_2 S_0 A$$

$$S_0^+ = S_2' A' + S_2 A$$

| $\mathbf{S_2}^+$ |    |    | $S_0$ | A  |    |
|------------------|----|----|-------|----|----|
|                  |    | 00 | 01    | 11 | 10 |
|                  | 00 | 0  | 1     | 1  | 0  |
| $S_2S_1$         | 01 | X  | X     | 1  | 0  |
|                  | 11 | X  | X     | 1  | 0  |
|                  | 10 | 0  | 1     | 1  | 0  |

| $S_1^+$  |    |    | $S_0$ | $_{0}A$ |    |
|----------|----|----|-------|---------|----|
|          |    | 00 | 01    | 11      | 10 |
|          | 00 | 0  | 0     | 0       | 1  |
| $S_2S_1$ | 01 | X  | X     | 0       | 1  |
|          | 11 | X  | X     | 1       | 0  |
|          | 10 | 0  | 0     | 1       | 0  |

| $S_0^+$  |    |    | $S_0$ | $\mathbf{A}$ |    |
|----------|----|----|-------|--------------|----|
|          |    | 00 | 01    | 11           | 10 |
|          | 00 | 1  | 0     | 0            | 1  |
| 0 0      | 01 | X  | X     | 0            | 1  |
| $S_2S_1$ | 11 | X  | X     | 1            | 0  |
|          | 10 | 0  | 1     | 1            | 0  |

| implement this FSM using D flip-flops. |  |  |  |
|----------------------------------------|--|--|--|
| figures/fsm1e-solution.png             |  |  |  |

e.

Suppose we wanted to create a Mealy FSM that represents an elevator in a building with 6 floors, 1 through 6. It takes two clock cycles for the elevator to move between floors. The input is a 3-bit unsigned integer  $I_2I_1I_0$  and the output is a single bit F that is 1 when the elevator has reached the correct floor and 0 when it has not. You may assume that the input is always between 1 and 6 (inclusive).

a. How many unique states do we need for this finite state machine? How many bits do we need to represent all states? We need a state for each of the floors and another state for moving between floors. Since there are 6 floors, we need 6 floors, plus 5 in-between states, so we need 11 states. We can represent this with 4 bits, allowing for up to 16 states.

| b. | use compariso<br>states in a way | liagram for this FSM, showing all states $(=,<,>)$ . (Hint: it might be helpfully that preserves the 3-bit floor) ably the easiest enumeration, but of | ul to enumerate the |
|----|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
|    |                                  | figures/fsm2b-solution.png                                                                                                                             |                     |

c. Create a truth table for this FSM, defining new intermediate variables for your comparisons. For unused states, write X.

$$E = (I = S_3 S_2 S_1)$$

$$L = (I < S_3 S_2 S_1)$$
  

$$G = (I > S_3 S_2 S_1)$$

$$G = (I > S_3 S_2 S_1)$$

| L         E         G         S <sub>0</sub> S <sup>+</sup> 0         0         0         0         XXXX           0         0         0         1         XXXX           0         0         1         0         S + 1           0         0         1         1         S + 1           0         1         0         0         S           0         1         0         1         S - 1           0         1         1         1         XXXX           0         1         1         1         XXXX           1         0         0         0         S - 1           1         0         1         0         XXXX           1         0         1         1         XXXXX           1         0         1         1         XXXXX           1         1         0         0         XXXXX           1         1 <th></th> <th></th> <th></th> <th></th> <th></th>                                         |   |   |   |       |       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|-------|-------|
| 0         0         0         1         XXXX           0         0         1         0         S + 1           0         0         1         1         S + 1           0         1         0         0         S           0         1         0         1         S - 1           0         1         1         0         XXXXX           0         1         1         1         XXXXX           1         0         0         0         S - 1           1         0         0         1         S - 1           1         0         1         0         XXXXX           1         0         1         1         XXXXX           1         0         1         XXXXX           1         1         0         0         XXXXX           1         0         1         XXXXX           1         1         0         1         XXXXX           1         1         0         1         XXXXX           1         1         0         0         XXXXX           1         1         1         1 </td <td>L</td> <td>Е</td> <td>G</td> <td><math>S_0</math></td> <td><math>S^+</math></td> | L | Е | G | $S_0$ | $S^+$ |
| 0         0         1         0         S + 1           0         0         1         1         S + 1           0         1         0         0         S           0         1         0         1         S - 1           0         1         1         0         XXXX           0         1         1         1         XXXX           1         0         0         0         S - 1           1         0         0         1         S - 1           1         0         1         0         XXXXX           1         0         1         1         XXXXX           1         1         0         0         XXXXX           1         1         0         1         XXXXX           1         1         0         1         XXXXX           1         1         0         1         XXXXX                                                                                                                                                                                                                                                                                          | 0 | 0 | 0 | 0     | XXXX  |
| 0         0         1         1         S + 1           0         1         0         0         S           0         1         0         1         S - 1           0         1         1         0         XXXX           0         1         1         1         XXXX           1         0         0         0         S - 1           1         0         1         0         XXXX           1         0         1         0         XXXX           1         1         0         0         XXXX           1         1         0         1         XXXX           1         1         0         1         XXXX           1         1         0         0         XXXX                                                                                                                                                                                                                                                                                                                                                                                                                | 0 | 0 | 0 | 1     | XXXX  |
| 0         1         0         0         S           0         1         0         1         S - 1           0         1         1         0         XXXXX           0         1         1         1         XXXXX           1         0         0         0         S - 1           1         0         0         1         S - 1           1         0         1         0         XXXXX           1         0         1         1         XXXXX           1         1         0         1         XXXXX           1         1         0         1         XXXXX           1         1         0         0         XXXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0 | 0 | 1 | 0     | S+1   |
| 0         1         0         1         S - 1           0         1         1         0         XXXXX           0         1         1         1         XXXXX           1         0         0         0         S - 1           1         0         0         1         S - 1           1         0         1         0         XXXXX           1         0         1         1         XXXXX           1         1         0         0         XXXXX           1         1         0         1         XXXXX           1         1         1         0         XXXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0 | 0 | 1 | 1     | S+1   |
| 0         1         1         0         XXXX           0         1         1         1         XXXX           1         0         0         0         S - 1           1         0         0         1         S - 1           1         0         1         0         XXXX           1         0         1         1         XXXX           1         1         0         0         XXXX           1         1         0         1         XXXX           1         1         1         0         XXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0 | 1 | 0 | 0     | S     |
| 0     1     1     1     XXXXX       1     0     0     0     S - 1       1     0     0     1     S - 1       1     0     1     0     XXXXX       1     0     1     1     XXXXX       1     1     0     0     XXXXX       1     1     0     1     XXXXX       1     1     0     1     XXXXX       1     1     1     0     XXXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0 | 1 | 0 | 1     | S - 1 |
| 1         0         0         0         S - 1           1         0         0         1         S - 1           1         0         1         0         XXXX           1         0         1         1         XXXX           1         1         0         0         XXXX           1         1         0         1         XXXX           1         1         1         0         XXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0 | 1 | 1 | 0     | XXXX  |
| 1         0         0         1         S - 1           1         0         1         0         XXXX           1         0         1         1         XXXX           1         1         0         0         XXXX           1         1         0         1         XXXX           1         1         1         0         XXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0 | 1 | 1 | 1     | XXXX  |
| 1     0     1     0     XXXX       1     0     1     1     XXXX       1     0     1     1     XXXX       1     1     0     0     XXXX       1     1     0     1     XXXX       1     1     1     0     XXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1 | 0 | 0 | 0     | S - 1 |
| 1     0     1     1     XXXX       1     1     0     0     XXXX       1     1     0     1     XXXX       1     1     1     0     XXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1 | 0 | 0 | 1     | S - 1 |
| 1         1         0         0         XXXX           1         1         0         1         XXXX           1         1         1         0         XXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1 | 0 | 1 | 0     | XXXX  |
| 1     1     0     1     XXXX       1     1     1     0     XXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1 | 0 | 1 | 1     | XXXX  |
| 1 1 1 0 XXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1 | 1 | 0 | 0     | XXXX  |
| 1 1 1 V 11111111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1 | 1 | 0 | 1     | XXXX  |
| 1 1 1 1 XXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1 | 1 | 1 | 0     | XXXX  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1 | 1 | 1 | 1     | XXXX  |

d. Use K-maps or another method to derive next-state expressions for this

$$S^{+} = (S+1)G + (S-1)(L + ES_0) + (S)(ES_0')$$



| e. Implement this FSM using D flip-flops and a 3-bit digital comparator, with outputs for $A > B$ , $A = B$ , and $A < B$ . Feel free to use adders MUXes, buses, or any other component covered earlier in the course. |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| figures/fsm2e-solution.png                                                                                                                                                                                              |

| Taken from HDLBits "Design a Moore FSM" |  |  |  |  |
|-----------------------------------------|--|--|--|--|
| figures/fsm_q3.png                      |  |  |  |  |



# Memory

#### Problem 1

- a. What is memory addressability? What is the difference between memory addressability and a memory address?
  - The number of addresses, or address space, is the number of memory locations in a memory module. The addressibility is the number of bits of memory that can be accessed at once at a memory location, corresponding to a memory address.
- b. What is the purpose of the chip select signal in a RAM block? The chip select signal allows for our control logic to control which memory modules are enabled, allowing us to share connections between memory modules.
- c. What is the purpose of the write enable signal in a RAM block?

The write enable signal allows us to select between reading and writing on a memory module.

- d. Describe the process to read from a RAM block. Detail the signal values: Chip select should be set to high (active), and write enable should be set to low (inactive). Note that some modules show  $\overline{WE}$ , which indicate active low, so write enable should be set to high in that case.
- e. Describe the process to write to a RAM block. Detail the signal values: Chip select should be set to high (active), and write enable should be set to high (active). Again, if write enable is active low, it should be set to low.



a. What should we apply to Select, B and B' in order to read the value Q to C?

$$SELECT = 1, B = High-Z, B' = High-Z$$

- b. What should we apply to Select, B and B' in order to hold a value Q? SELECT = 0, B = High-Z, B' = High-Z
- c. What should we apply to Select, B and B' in order to write a 0 to Q? SELECT = 1, B = 0, B' = 1
- d. What should we apply to Select, B and B' in order to write a 1 to Q? SELECT = 1, B = 1, B' = 0



For each of the combinations below, select and draw those that can be used to build a  $2048 \times 12$  RAM using only the parts given. If not possible, explain why. Assume that logic 0 and 1 signals are available and that the chip select and write enable are active-high.

- a. Two 1024 x 6 RAMs and one 4:1 multiplexer Not possible. The largest we can build is a 2048 x 6 or 1024 x 12 RAM.
- b. Four 512 x 12 RAMs and a 2:4 priority encoder



c. Two  $2048 \times 6$  RAMs



d. Four 512 x 3 RAMs and two 4:1 multiplexers Not possible. The largest we can build is a 2048 x 3 or 512 x 12 RAM.

### LC-3 ISA

#### Problem 1

Review Questions. Answer for the LC-3 ISA.

- a. How many bits are used to address memory? What is the memory address space?
  - The LC-3 has 16 bit memory addresses. Its address space is  $2^{16}$ , or 65536 locations.
- b. How many bits of data are stored at each memory space/what is the memory addressibility?
  - The LC-3 has a 16 bit memory bus. Its memory addressibility is 16 bits.
- c. What is the bus width?
  - The LC-3 has a system bus that is also 16 bits wide. By making all bus sizes be the same, we don't have to do conversions between different sized buses.
- d. How many registers are in the register file? How wide are they?8 registers, R0 through R7. They are each 16 bits wide.
- e. How many other registers are there? How wide are they?
  At least 5. We have the Program Counter (PC), the Instruction Register (IR), the Memory Address Register (MAR), the Memory Data Register (MDR), control codes (NZP), and more registers for I/O (not taught in ECE 120).
- f. How do we control which signals are sent to the system bus?

  Tri-state buffers are added wherever there is a connection into the system bus, allowing for control logic to ensure only one is enabled at any one time.

#### Problem 2

Consider the Von Neumann Architecture.

- a In 50 words or less, explain the role of the control unit.
  - The control unit tells all other units what to do depending on the current state in control logic, which is determined by the current instruction. It holds the program counter and instruction register.
- b In 50 words or less, explain the role of the ALU.
  - The ALU performs all of the actual computation in a von Neumann machine. Data is loaded to and from memory, and processed through the ALU.



- c For the LC-3 ISA, what does the control unit correspond to? The PC, IR, and control logic.
- d For the LC-3 ISA, what are the inputs and outputs?

  Keyboard input and display (character display) output.

# LC-3 Assembly

| Problem 1          |
|--------------------|
| figures/lc3_q1.png |



Write an LC-3 Assembly program that compares two numbers in R2 and R3 and puts the larger number into R1. If the numbers are equal, then R1 is set equal to 0. Use as many lines as necessary.



| Location | Assembly       | Comments                          |
|----------|----------------|-----------------------------------|
| x3000    | NOT R2, R2     | Set R2 to -R2 (step one)          |
| x3001    | ADD R2, R2, #1 | Set R2 to -R2 (step two)          |
| x3002    | ADD R2, R3, R2 | Set R2 to R3 - R2                 |
| x3003    | BRn #3         | If the result is negative, R2 >R3 |
| x3004    | BRp #4         | If the result is positive, R3 >R2 |
| x3005    | AND R1, R1, #0 | Else, set R1 to 0                 |
| x3006    | HALT           |                                   |
| x3007    | ADD R1, R2, #0 | If R2 >R3, Set R1 to R2           |
| x3008    | HALT           |                                   |
| x3009    | ADD R1, R3, #0 | If R3 >R2, Set R1 to R3           |
| x300A    | HALT           |                                   |

Write two LC-3 Assembly programs that executes a bitwise OR operation and a bitwise XOR operation respectively on R4 and R5 and puts the result in R1.

How might you extend these to support NOR and XNOR?  $\mathbf{OR}$ 

| Location | Assembly       | Comments                     |
|----------|----------------|------------------------------|
| x3000    | NOT R4, R4     | $R4 \le R4$                  |
| x3001    | NOT R5, R5     | $R5 \le R5$                  |
| x3002    | AND R1, R4, R5 | R1 <= R4'R5'                 |
| x3003    | NOT R1, R1     | $R1 \le (R4'R5')' = R4 + R5$ |

**XOR** Remember that  $p \bigoplus q = (p+q)(pq)'$ 

| Location | Assembly       | Comments                     |
|----------|----------------|------------------------------|
| x3000    | AND R3, R4, R5 | $R3 \le R4R5$                |
| x3001    | NOT R4, R4     | R4 <= R4'                    |
| x3002    | NOT R5, R5     | $R5 \ll R5$                  |
| x3003    | AND R2, R4, R5 | $R2 \ll R4'R5'$              |
| x3004    | NOT R2, R2     | $R2 \le (R4'R5')' = R4 + R5$ |
| x3005    | NOT R3, R3     | R3 <= (R4R5)'                |
| x3006    | AND R1, R2, R3 | $R1 \le (R4 + R5)(R4R5)$     |

NOR and XNOR would be adding an additional instruction NOT R1, R1 to negate the result.

- a. Assuming LC-3 now has 32 registers, we want to increase the number of registers that we can specify in the LC-3 ADD instruction to 32. Is there a problem with this? Explain.
  - Yes, specifying 32 registers would require 5 bits per field, meaning 5 bits for SR1, 5 for SR2 and 5 for DR in the case of the 2 source version. This leaves only 1 bit for the opcode, which is not possible. If we were to extend the immediate version instead, we can fit the opcode, SR and DR into 14 bits, but this leaves only 2 bits for the immediate, which is extremely inconvenient at best.
- b. A memory's addressibility is 64 bits. What does that tell you about the size of the MAR and MDR, given a 64-bit ISA and 2<sup>20</sup> memory locations? 64-bit addressibility means MDR must be 64 bits, as one address stores 64 bits of data. MAR can stay 20 bits as that is all that is needed to access one location.
- c. Say we have a memory consisting of 256 locations, and each location contains 16 bits. How many bits are required for the address for a byte-addressable system? Explain.

 $256 = 2^8$ , so 8 bits for the address.

1 byte is 8 bits, 16/8 = 2 bits to offset into one location.

So 8+2=10 bits are needed in total.