

# **COE328 Lab 6 Report**

## **Design Of a Simple General-Purpose Processor**

Nathaniel Recto

501162644

Section - 12

## Table of Contents

|                                 |              |
|---------------------------------|--------------|
| <b>Introduction:</b>            | <b>3</b>     |
| <b>Components:</b>              | <b>3</b>     |
| Latch 1 and Latch 2:            | 3-4          |
| Finite State Machine (FSM):     | 4-5          |
| 4x16 Decoder:                   | 5-7          |
| <b>ALU_1 for Problem Set 1:</b> | <b>7-10</b>  |
| <b>ALU_2 for Problem Set 2:</b> | <b>10-12</b> |
| <b>ALU_3 for Problem Set 3:</b> | <b>12-14</b> |
| <b>Conclusion:</b>              | <b>15</b>    |

## **Introduction:**

The purpose of this lab was to showcase a student number while experimenting with various number tricks using the last 4 digits. To achieve this, Two latches were used for storing data, an ALU for mathematical operations, and a control unit comprising a Moore FSM and a 4x16 decoder.

The latches served as temporary storage for input values before transferring them to the ALU, which performed the desired mathematical operations. The ALU executed these operations based on assigned codes and displayed an 8-bit result on two 7-segment displays.

The control unit, incorporating a Moore FSM and a 4x16 decoder, functioned as a selector for the ALU, determining the actions performed. The FSM acted as an up-counter, cycling through states 0-8 and sending these states to the 4x16 decoder, which subsequently sent a 16-bit message to the ALU.

---

## **Components:**

### **Latch 1 and Latch 2:**

Two of the equivalent latches act as storage units which store input values ("A" and "B") that will be passed on to the ALU and used in the boolean operations. The inputs are 8-bit binary representations of the last 4 digits of my student number in hex form, meaning that input A is  $(26)_{16}$  and converted to (00100110) and input B is  $(44)_{16}$  and converted to (01000100).

| Clock | B Input $(44)_{16}$ | Q (Output) |
|-------|---------------------|------------|
| 0     | 01000100            | 00000000   |
| 1     | 01000100            | 01000100   |
| 0     | 01000100            | 01000100   |
| 1     | 01000100            | 01000100   |

*Table 1: Truth Table for Latch 2*



Figure 1: Waveform of latch 2 with input B ( $44_{16}$  in 8-bit binary representation)



Figure 2: Block diagram of Latch 1 and Latch 2

## Finite State Machine (FSM)

The FSM handles a 4-bit student ID code across nine states using clock and reset inputs. It accurately displays the current state and student ID through systematic Moore logic, in which the current state passes to the decoder.

| Current State | Next State w = 0 | Next State w = 1 | Output (student ID) |
|---------------|------------------|------------------|---------------------|
| 0000          | 0000             | 0001             | 0101                |
| 0001          | 0001             | 0010             | 0000                |
| 0010          | 0010             | 0011             | 0001                |
| 0011          | 0011             | 0100             | 0001                |

|      |      |      |      |
|------|------|------|------|
| 0100 | 0100 | 0101 | 0110 |
| 0101 | 0101 | 0110 | 0010 |
| 0110 | 0110 | 0111 | 0110 |
| 0111 | 0111 | 1000 | 0100 |
| 1000 | 1000 | 0000 | 0100 |

Table 2: Truth Table for FSM



Figure 3: Waveform of FSM with student number



Figure 4: Block diagram of FSM

## 4x16 Decoder

The 4x16 receives the 4-bit current state from the FSM, decodes the value of the current state and produces a 16-bit output signal. This 16-bit output (OP) corresponds to one of nine predefined operations for ALU. The rest of the operations (10 to 16) will produce nothing (“0”) since it is irrelevant. The enable input signal is always “1” so that the decoder produces the 16-bit output signal accordingly from the current state.

Enable = “1”

*Table 3: Truth Table for 4x16 Decoder*



*Figure 5: Waveform of 4x16 Decoder*



*Figure 6: Block diagram of 4x16 Decoder*

---

## ALU\_1 For Problem Set 1

The ALU, a crucial part of the GPU unit, executes the various arithmetic and logical operations. With 8 inputs (A, B, Clock, Data\_in, En, ResetA, ResetB, FSM\_Reset) and 4 outputs (Neg, student\_id, R1, and R2), it aims to perform precise boolean operations between 8-bit values A and B based on its assigned microcode. To achieve this, the ALU leverages the 16-bit “current state” of the FSM as a selector for the specific operation to be executed between A and B.

In this problem set, only 5 out of 8 inputs were utilized. “A” and “B” stand for the values of the last 4 digits of my student number, while “OP” selects the desired boolean operation. “Clock” dictates the timeframe for output activation. The input Data\_in and En (enabled) are always “1” to produce constant inputs, and operations, and maintain a specific state during certain clock cycles. I decided not to use the reset inputs due to propagation delays as the reset inputs cause it to not display any results. The outputs “R1” and “R2” divide the 8-bit boolean operation result into two 4-bit numbers in order to display the 7-segment component on the FPGA board. Meanwhile, “Neg” indicates the negative sign if the boolean operation yields a negative result on the FPGA board. The output “student\_id” displays my student number from the FSM at each current state. Every output is displayed as 7 segments in order to show on the FPGA board.

| Function # | Microcode         | Boolean Operation / Function |
|------------|-------------------|------------------------------|
| 1          | 0000000000000001  | sum(A, B) = 6A               |
| 2          | 0000000000000010  | diff(A, B) = -1E             |
| 3          | 00000000000000100 | $\bar{A}$ = d9               |
| 4          | 0000000000001000  | $\overline{A \cdot B}$ = Fb  |
| 5          | 00000000000010000 | $\overline{A + B}$ = 99      |
| 6          | 0000000000100000  | $A \cdot B$ = 04             |
| 7          | 0000000001000000  | $A \oplus B$ = 62            |
| 8          | 0000000010000000  | $A + B$ = 6A                 |
| 9          | 0000000100000000  | $\overline{A \oplus B}$ = 9d |

Table 3: Microcode Table of ALU\_1

(1) sum (A, B)  $\begin{array}{r} 0010 & 0110 \\ + 0100 & 0100 \\ \hline 0110 & 1010 \end{array} = 6A$

(2) diff (A, B)  $\begin{array}{r} 0010 & 0110 \\ 1011 & 1100 \\ \hline 1110 & 0010 \\ \downarrow & \\ 0001 & 1101 \\ + & 1 \\ \hline 0001 & 1110 \end{array} \Rightarrow -1E$  (B)  $\begin{array}{r} 1011 & 1011 \\ + & 1 \\ \hline 1011 & 1100 \end{array}$  z's complement

(3)  $\bar{A} = (1101 \ 1001) = d9$

(4)  $\overline{A \cdot B} = \begin{array}{r} 0010 & 0110 \\ + 0100 & 0100 \\ \hline 0000 & 0100 \end{array} \Rightarrow 1111 \ 1011 = Fb$

(5)  $\overline{A+B} = \begin{array}{r} 0010 & 0110 \\ 0100 & 0100 \\ \hline 0001 & 1001 \end{array} = 99$

(6)  $A \cdot B = \begin{array}{r} 0010 & 0110 \\ . 0100 & 0100 \\ \hline 0000 & 0100 \end{array} = 04$

(7)  $A \oplus B = \begin{array}{r} 0010 & 0110 \\ 0100 & 0100 \\ \hline 0110 & 0010 \end{array} = 62$

(8)  $A+B = \begin{array}{r} 0010 & 0110 \\ + 0100 & 0100 \\ \hline 0110 & 1010 \end{array} = 6A$

(9)  $\overline{A \oplus B} = \begin{array}{r} 0010 & 0110 \\ 0100 & 0100 \\ \hline 1001 & 1101 \end{array} = 9d$

Figure 7: Handwritten results of each function



Figure 8: Block diagram of Problem Set 1



Figure 9: Waveform of Problem Set 1

It is shown that input “data\_in” and “En” are always “1”, the highlighted blue is the clock input where it clocks high and low, highlighted pink are the “A” and “B” inputs, highlighted yellow are the “R1” and “R2” outputs and the highlighted green is my student id. All outputs are in 7-segments. The pink line in the middle is the clock recycle where it now shows the results from operation 1 to 9.

To understand the ALU operation, I added an output “DEBUG\_OPCODE” (turquoise highlighted) that displays which operation the ALU is in. According to the waveform, the operation is delayed by a microcode, making the first operation start at

the second student number. This was caused due to both FSM and ALU clocking at the same time and the result of the ALU lags behind the FSM/Decoder output. This happens because the opcode does not have time to get to the ALU before the ALU updates its function since they both update at the same time in the same clock cycle.

Note that my 7-segment is inverted because the LED lights were inverted in the FPGA board.



Figure 10: First two Results of ALU\_1 Problem Set 1

On Hex[3], my student number is displayed, Hex[2] shows the sign, Hex[1] shows R2 output, and Hex[0] shows R1 output.

---

## ALU\_2 For Problem Set 2

The ALU design in this problem set is the same as the design from the previous problem set. Its aim is to execute distinct boolean functions on inputs A and B according to the designated microcode. The only difference is that all operations/functions are operated differently in the ALU for the A and B input values. This means that the same 5 out of 8 inputs were used, and 4 same outputs are being displayed and served the same purpose as ALU\_1. The modified 9 operations I chose were part a).

a)

| Function # | Operation / Function                                                   |    |
|------------|------------------------------------------------------------------------|----|
| 1          | Increment A by 2                                                       | 28 |
| 2          | Shift B to right by two bits, input bit = 0 (SHR)                      | 11 |
| 3          | Shift A to right by four bits, input bit = 1 (SHR)                     | F2 |
| 4          | Find the smaller value of A and B and produce the results ( Min(A,B) ) | 26 |
| 5          | Rotate A to right by two bits (ROR)                                    | 89 |
| 6          | Invert the bit-significance order of B                                 | 22 |
| 7          | Produce the result of XORing A and B                                   | 62 |
| 8          | Produce the summation of A and B, then decrease it by 4                | 76 |
| 9          | Produce all high bits on the output                                    | FF |

Table 4: Microcode Table of ALU\_2

①  $A + "0010" \rightarrow \begin{array}{r} 0010 \\ + 0000 \\ \hline 0010 \end{array} = 28$       ⑥  $0100 \ 0100 \Rightarrow 0010 \ 0010 = 22$   
 ②  $B$   
 ②  $0100 \ 0100 = 0001 \ 0001 = 11$       ⑦  $A \oplus B \Rightarrow \begin{array}{r} 0010 \ 0110 \\ \oplus 0100 \ 0100 \\ \hline 0110 \ 0010 \end{array} = 62$   
 ③  $A$   
 ③  $0010 \ 0110 = 1111 \ 0010 = F2$       ⑧  $A+B - "0100" \Rightarrow \begin{array}{r} 0010 \ 0110 \\ - 0100 \ 0100 \\ \hline 0110 \ 1010 \end{array} \Rightarrow \begin{array}{r} 0110 \ 1010 \\ + 1100 \\ \hline 0111 \ 0110 \end{array} = 76$   
 ④  $A < B \Rightarrow 26$   
 ⑤  $0010 \ 0110 \Rightarrow 1000 \ 1001 = 89$       ⑨ FF

Figure 11: Handwritten results of each function



Figure 12: Block diagram of ALU\_2 Problem Set 2



Figure 13: Waveform of ALU\_2 Problem Set 2

Similarly, with the previous waveform, it is shown that input “data\_in” and “En” are always “1”, the highlighted blue is the clock input where it clocks high and low, highlighted pink are the “A” and “B” inputs, highlighted yellow are the “R1” and “R2” outputs and the highlighted green is my student id. All outputs are in 7-segments. The pink line in the middle is the clock recycle where it now shows the results from operation 1 to 9.



Figure 14: First two Results of ALU\_2 Problem Set 2 (same Hex order from ALU\_1)

## ALU\_3 For Problem Set 3

In problem set 3, the ALU and the 7-segment were modified so that a 4-bit student ID input is introduced in the ALU, taken from the FSM. The output “leds” will display “y” if a digit of my student number is odd, and “n” otherwise. This means that there will be only two outputs, the student number and the “leds”. The inputs are the same as the previous problem sets and do the same purpose. This is for part a).

- a) For each microcode instruction, display 'y' if the FSM output (**student\_id**) is odd and 'n' otherwise

| Function # | Microcode             | Student_ID | “y” or “n” |
|------------|-----------------------|------------|------------|
| 1          | 00000000000000000001  | 5          | y          |
| 2          | 00000000000000000010  | 0          | n          |
| 3          | 0000000000000000100   | 1          | y          |
| 4          | 00000000000000001000  | 1          | y          |
| 5          | 000000000000000010000 | 6          | n          |
| 6          | 000000000000100000    | 2          | n          |
| 7          | 000000000010000000    | 6          | n          |
| 8          | 000000000100000000    | 4          | n          |
| 9          | 000000001000000000    | 4          | n          |

Table 5: Microcode Table for ALU\_3



Figure 15: Block diagram of ALU\_3 Problem Set 3

I decided to connect “Enable” to data\_in since both inputs will always be “1”.



Figure 16: Waveform of ALU\_3 Problem Set 3

Similarly, for the previous waveforms of the problem sets, the highlighted pink are input “A” and “B”, data\_in with enable connected is always “1”, the highlighted yellow is the “leds” display showing “y” (1000100) or “n” (1101010), and the highlighted green is the student\_id. The pink line is the recycle that goes back to the beginning of my student ID.



Figure 1: First two Results of ALU\_3 Problem Set 3

On Hex[3], my student number is displayed and Hex[0] shows the “leds” output displaying either “y” or “n”.

## Conclusion

In conclusion, this laboratory experiment demonstrates the design and utilization of an ALU on an FPGA board, offering flexibility by allowing easy circuit alteration through ALU modifications. The ALU's versatility enables diverse functions, while in conjunction with the latch and FSM, it stores values and transitions to the next state. Following the function execution and result retrieval on the FPGA board, the output is showcased using a 7-segment display.