



|                |                 |
|----------------|-----------------|
| Course Number: | COE328          |
| Course Title:  | Digital Systems |
| Semester/Year: |                 |
| Instructor:    |                 |
| TA:            |                 |

|                         |                                            |
|-------------------------|--------------------------------------------|
| Lab/Tutorial Report No. | 6                                          |
| Report Title:           | Design of a Simple Central Processing Unit |

|                  |  |
|------------------|--|
| Section No.      |  |
| Submission Date: |  |
| Due Date:        |  |

| Student Name | Student ID | Signature |
|--------------|------------|-----------|
| Ganojan      |            |           |

## Table of Contents

|                                                    |           |
|----------------------------------------------------|-----------|
| <b>Table of Contents.....</b>                      | <b>1</b>  |
| <b>Introduction.....</b>                           | <b>3</b>  |
| <b>Components.....</b>                             | <b>3</b>  |
| Description of Four Important Components.....      | 3         |
| Latch1 and Latch2.....                             | 4         |
| Screenshot of Latch Block Diagram.....             | 4         |
| Latch Truth Table.....                             | 4         |
| Latch Waveforms.....                               | 5         |
| Latch VHDL Code.....                               | 5         |
| Moore FSM.....                                     | 6         |
| Screenshot of FSM Block Diagram.....               | 6         |
| FSM Truth Table.....                               | 6         |
| FSM Waveform (data_in = 1).....                    | 7         |
| FSM VHDL Code.....                                 | 7         |
| 4-to-16 Decoder.....                               | 9         |
| Screenshot of Decoder Block Diagram.....           | 9         |
| Decoder Truth Table.....                           | 10        |
| 4-to-16 Decoder Waveform.....                      | 11        |
| 4-to-16 Decoder VHDL Code.....                     | 12        |
| SSEG (for the Result).....                         | 13        |
| Screenshot of SSEG (Result) Block Diagram.....     | 13        |
| SSEG (Result) Truth Table.....                     | 14        |
| SSEG (Result) Waveform.....                        | 15        |
| SSEG (Result) VHDL Code.....                       | 16        |
| SSEG (Student ID).....                             | 17        |
| Screenshot of SSEG (Student ID) Block Diagram..... | 17        |
| SSEG (Student ID) Truth Table.....                 | 18        |
| SSEG (Student ID) Waveform.....                    | 18        |
| SSEG (Student ID) VHDL Code.....                   | 19        |
| SSEG (Answer) (for ALU 3 only).....                | 20        |
| Screenshot of SSEG (Answer) Block Diagram.....     | 20        |
| SSEG (Answer) Truth Table.....                     | 20        |
| SSEG (Answer) Waveform.....                        | 20        |
| SSEG (Answer) VHDL Code.....                       | 21        |
| <b>ALU1 Problem Set 1.....</b>                     | <b>22</b> |
| Description.....                                   | 22        |

|                                                                  |           |
|------------------------------------------------------------------|-----------|
| Screenshot of ALU1 Block Schematic File (BDF).....               | 22        |
| Purpose of Inputs and Outputs for ALU1.....                      | 23        |
| Table of Microcodes Generated by the Decoder for ALU1.....       | 23        |
| ALU1 Complete Truth Table for the Various Operations.....        | 24        |
| Handwritten Work for ALU1 Operations.....                        | 25        |
| Screenshot of Complete Waveform for ALU1.....                    | 26        |
| ALU1 VHDL Code.....                                              | 27        |
| <b>ALU2 Problem Set 2.....</b>                                   | <b>28</b> |
| Description.....                                                 | 28        |
| Screenshot of ALU2 Block Schematic File (BDF).....               | 28        |
| Purpose of Inputs and Outputs for ALU2.....                      | 29        |
| Table of Microcodes Generated by the Decoder for ALU2.....       | 29        |
| ALU2 Complete Truth Table for the Various Operations.....        | 30        |
| Handwritten Work for ALU2 Operations.....                        | 31        |
| Screenshot of Complete Waveform for ALU2.....                    | 33        |
| ALU2 VHDL Code.....                                              | 33        |
| <b>ALU3 Problem Set 3.....</b>                                   | <b>35</b> |
| Description.....                                                 | 35        |
| Screenshot of ALU3 Block Schematic File (BDF).....               | 35        |
| Purpose of Inputs and Outputs for ALU3.....                      | 36        |
| Table of Microcodes Generated by the Decoder for ALU3.....       | 36        |
| ALU3 Complete Truth Table for the Various Operations.....        | 37        |
| Handwritten Work for ALU3 Operations.....                        | 37        |
| Screenshot of Complete Waveform for ALU3.....                    | 38        |
| ALU3 VHDL Code.....                                              | 38        |
| <b>ALU1 Operation Pictures (One Full Sequence In Order).....</b> | <b>40</b> |
| <b>ALU2 Operation Pictures (One Full Sequence In Order).....</b> | <b>44</b> |
| <b>ALU3 Operation Pictures (One Full Sequence In Order).....</b> | <b>48</b> |
| <b>Conclusion.....</b>                                           | <b>52</b> |

## **Introduction**

The objective of this lab is to design a simple CPU (central processing unit). This is done by implementing an ALU (arithmetic logic unit) and using VHDL code to create a network of different components that work together to perform various simple calculations and operations on the FPGA board. The important aspects of the operation of the CPU is the input data, the storage units, the control unit and the ALU core. The input data consists of two 8-bit inputs, A and B, corresponding to the last 4 digits of the student's ID. This data will be inputted to the storage units, where they will temporarily store the data so they can be used by the ALU core to perform the necessary calculations. The control unit supplies the “opcode”, or the instruction to the ALU, stating which calculation to perform. It is composed of an FSM and 4x16 decoder, and when working together, the decoder outputs the current calculation operation to the ALU depending on the current state of the FSM. All the components are connected to the same clock source so that every time the system is clocked on, the components work synchronously to almost instantaneously produce the correct and desired output to the FPGA board.

## **Components**

### **Description of Four Important Components**

The storage units will consist of 2 latches with each one storing an 8-bit input determined by the last 4 digits of the student's ID. Of the 4 digits, the first 2 digits will be converted to two 4-bit binary numbers (for an 8-bit input A at Latch 1) and the last 2 digits will be converted to two 4-bit binary numbers (for an 8-bit input B at Latch 2). The FSM will act as an up-counter to cycle through the 8 states, in accordance with the last 8 digits of the student's ID. As the FSM moves through each state, it will output the current state information which will be received by the 4-to-16 decoder. The decoder can then use this information to tell the ALU which action to perform depending on the current state of the system.

## Latch1 and Latch2

### Screenshot of Latch Block Diagram



### Latch Truth Table

| Latch 1 and Latch 2 Truth Table |       |   |         |              |           |           |
|---------------------------------|-------|---|---------|--------------|-----------|-----------|
| Input                           | Reset |   | Input   |              | Output    |           |
|                                 |       |   | Decimal | 8-Bit Binary | Reset = 0 | Reset = 1 |
| A                               | 1     | 0 | 28      | 00101000     | 00101000  | 00000000  |
| B                               | 1     | 0 | 65      | 01100101     | 01100101  | 00000000  |

## Latch Waveforms

**Reset = 0**



**Reset = 1**



From the above waveforms, it can be seen that the output of the latch is whatever the input was when the system is clocked while Reset = 0. When Reset is set to 1, only 00000000 goes to the output.

## Latch VHDL Code

```

1  LIBRARY ieee;
2  USE ieee.std_logic_1164.all;
3
4  ENTITY registerlatch IS
5  PORT(   D      : IN    STD_LOGIC_VECTOR (7 DOWNTO 0); -- 8 bit input
6        reset, clk   : IN    STD_LOGIC;
7        Q      : OUT   STD_LOGIC_VECTOR (7 DOWNTO 0)); -- 8 bit output
8  END registerlatch;
9
10 ARCHITECTURE Behavior OF registerlatch IS
11 BEGIN
12   PROCESS(reset,clk)
13   BEGIN
14     IF reset = '1' THEN
15       Q <= "00000000";
16     ELSIF(clk'EVENT AND clk = '1') THEN
17       Q <= D;
18     END IF;
19   END PROCESS;
20 END Behavior;

```

## Moore FSM

### Screenshot of FSM Block Diagram



### FSM Truth Table

| Moore FSM Truth Table |                   |            |          |                     |                   |
|-----------------------|-------------------|------------|----------|---------------------|-------------------|
| Current State         |                   | Next State |          | Output (Student ID) |                   |
| Decimal               | Binary<br>(4-bit) | Data = 0   | Data = 1 | Decimal             | Binary<br>(4-bit) |
| 0                     | 0000              | 0000       | 0001     | 0                   | 0000              |
| 1                     | 0001              | 0001       | 0010     | 1                   | 0001              |
| 2                     | 0010              | 0010       | 0011     | 2                   | 0010              |
| 3                     | 0011              | 0011       | 0100     | 4                   | 0100              |
| 4                     | 0100              | 0100       | 0101     | 2                   | 0010              |
| 5                     | 0101              | 0101       | 0110     | 8                   | 1000              |
| 6                     | 0110              | 0110       | 0111     | 6                   | 0110              |
| 7                     | 0111              | 0111       | 0000     | 5                   | 0101              |

## FSM Waveform (data\_in = 1)



In the above waveform, it can be seen that the FSM outputs the correct student ID digit in 4-bit binary as the state goes up one by one. It is important to note that the data\_in = 0 and reset = 1 waveform possibilities are not included as they are not of any use to us.

## FSM VHDL Code

```

1  LIBRARY ieee;
2  USE ieee.std_logic_1164.all;
3
4  entity FSM IS
5  port (data_in, clk, reset      : in  std_logic;
6        current_state : out std_logic_vector(3 DOWNTO 0);
7        student_id   : out std_logic_vector(3 DOWNTO 0));
8  end FSM;
9
10 architecture fsm of FSM is
11 type state_type is (s0,s1,s2,s3,s4,s5,s6,s7);
12 signal yfsm : state_type;
13 begin
14 process (clk,reset)
15 begin
16 if reset = '1' then
17     yfsm <= s0;
18 elsif (clk'EVENT AND clk = '1') then --POSITIVE EDGE TRIGGER
19     case yfsm is
20         when s0 =>
21             if data_in = '1' then
22                 yfsm <= s1;
23             end if;
24         when s1 =>
25             if data_in = '1' then
26                 yfsm <= s2;
27             end if;
28         when s2 =>
29             if data_in = '1' then
30                 yfsm <= s3;
31             end if;
32         when s3 =>
33             if data_in = '1' then
34                 yfsm <= s4;
35             end if;

```

```
36         when s4 =>
37             if data_in = '1' then
38                 yfsm <= s5;
39             end if;
40         when s5 =>
41             if data_in = '1' then
42                 yfsm <= s6;
43             end if;
44         when s6 =>
45             if data_in = '1' then
46                 yfsm <= s7;
47             end if;
48         when s7 =>
49             if data_in = '1' then
50                 yfsm <= s0;
51             end if;
52         end case;
53     end if;
54 end process;
55
56 process (yfsm)
57 begin
58     case yfsm is
59         when s0 => current_state <= "0000";
60             student_id <= "0000"; --d2
61         when s1 => current_state <= "0001";
62             student_id <= "0001"; --d3
63         when s2 => current_state <= "0010";
64             student_id <= "0010"; --d4
65         when s3 => current_state <= "0011";
66             student_id <= "0100"; --d5
67         when s4 => current_state <= "0100";
68             student_id <= "0010"; --d6
69         when s5 => current_state <= "0101";
70             student_id <= "1000"; --d7
71         when s6 => current_state <= "0110";
72             student_id <= "0110"; --d8
73         when s7 => current_state <= "0111";
74             student_id <= "0101"; --d9
75     end case;
76 end process;
77 end fsm;
```

## 4-to-16 Decoder

### Screenshot of Decoder Block Diagram



### Decoder Truth Table

| <b>4-to-16 Decoder Truth Table</b> |                               |                        |
|------------------------------------|-------------------------------|------------------------|
| Enable = 1                         |                               |                        |
| FSM Current State                  | Input From FSM (4-bit Binary) | Output (16-bit Binary) |
| 0                                  | 0000                          | 00000000000000001      |
| 1                                  | 0001                          | 000000000000000010     |
| 2                                  | 0010                          | 0000000000000000100    |
| 3                                  | 0011                          | 00000000000000001000   |
| 4                                  | 0100                          | 00000000000010000      |
| 5                                  | 0101                          | 00000000000100000      |
| 6                                  | 0110                          | 0000000001000000       |
| 7                                  | 0111                          | 0000000010000000       |
| 8                                  | dddd                          | ddddddddddddd          |
| 9                                  | dddd                          | ddddddddddddd          |
| ...                                | ...                           | ...                    |
| 15                                 | dddd                          | ddddddddddddd          |

## 4-to-16 Decoder Waveform

**Enable = 1**



**Enable = 0**



As can be seen from the waveforms above, the correct opcode is output to the ALU when the Enable = 1. When Enable = 0, the output '0000000000000000' is output, which means nothing happens in our system.

## 4-to-16 Decoder VHDL Code

```

1  LIBRARY ieee ;
2  USE ieee.std_logic_1164.all ;
3
4  ENTITY decoder IS
5    PORT ( w : IN STD_LOGIC_VECTOR(3 DOWNTO 0);
6           En : IN STD_LOGIC ;
7           y : OUT STD_LOGIC_VECTOR(15 DOWNTO 0));
8  END decoder;
9
10 ARCHITECTURE Behavior OF decoder IS
11 BEGIN
12   PROCESS (w)
13   BEGIN
14     if (En = '0') then
15       y <= "0000000000000000";
16     else
17       case w is
18         WHEN "0000" => y <= "0000000000000001";
19         WHEN "0001" => y <= "00000000000000010";
20         WHEN "0010" => y <= "000000000000000100";
21         WHEN "0011" => y <= "0000000000000001000";
22         WHEN "0100" => y <= "00000000000000010000";
23         WHEN "0101" => y <= "000000000000000100000";
24         WHEN "0110" => y <= "0000000000000001000000";
25         WHEN "0111" => y <= "00000000000000010000000";
26         WHEN "1000" => y <= "000000000000000100000000";
27         WHEN "1001" => y <= "0000000000000001000000000";
28         WHEN "1010" => y <= "0000000000000001000000000";
29         WHEN "1011" => y <= "0000000000000001000000000";
30         WHEN "1100" => y <= "00010000000000000000";
31         WHEN "1101" => y <= "00100000000000000000";
32         WHEN "1110" => y <= "01000000000000000000";
33         WHEN "1111" => y <= "10000000000000000000";
34         WHEN OTHERS => y <= "00000000000000000000";
35       END CASE;
36     END IF;
37   END PROCESS;
38 END Behavior;

```

## SSEG (for the Result)

### Screenshot of SSEG (Result) Block Diagram



**SSEG (Result) Truth Table**

| <b>SSEG (Result) Truth Table</b> |                                |                                 |
|----------------------------------|--------------------------------|---------------------------------|
| <b>Neg = 0</b>                   |                                | <b>Neg = 1</b>                  |
| Negative SSEG Display = 1111111  |                                | Negative SSEG Display = 1111110 |
| <b>BCD Input (4-bit Binary)</b>  | <b>BCD Input (Hexadecimal)</b> | <b>SSEG</b>                     |
| 0000                             | 0                              | 0000001                         |
| 0001                             | 1                              | 1001111                         |
| 0010                             | 2                              | 0010010                         |
| 0011                             | 3                              | 0000110                         |
| 0100                             | 4                              | 1001100                         |
| 0101                             | 5                              | 0100100                         |
| 0110                             | 6                              | 0100000                         |
| 0111                             | 7                              | 0001111                         |
| 1000                             | 8                              | 0000000                         |
| 1001                             | 9                              | 0000100                         |
| 1010                             | A                              | 0001000                         |
| 1011                             | B                              | 1100000                         |
| 1100                             | C                              | 0110001                         |
| 1101                             | D                              | 1000010                         |
| 1110                             | E                              | 0110000                         |
| 1111                             | F                              | 0111000                         |

## SSEG (Result) Waveform



From the waveform, it's seen that the SSEG outputs the correct hexadecimal number for each of the 4-bit binary inputs. It can also be seen that when the 'Neg' signal is 0, the SSEG outputs nothing on the display (represented by all 1s) and when 'Neg' is 1, the SSEG outputs a negative sign to the SSEG.

## SSEG (Result) VHDL Code

```

1  LIBRARY ieee ;
2  USE ieee.std_logic_1164.all ;
3
4  ENTITY bcdtosseg_result IS
5    PORT (      bcd : IN STD_LOGIC_VECTOR(3 DOWNTO 0);
6              neg : IN STD_LOGIC;
7              leds, ledn : OUT STD_LOGIC_VECTOR(0 TO 6) );
8  END bcdtosseg_result;
9
10 END ENTITY bcdtosseg_result;
11
12 ARCHITECTURE Behavior OF bcdtosseg_result IS
13 BEGIN
14   PROCESS (bcd, neg)
15   BEGIN
16     IF (neg = '1') then
17       ledn <= ("1111110");
18     ELSE
19       ledn <= ("1111111");
20     END IF;
21
22     CASE bcd IS          --abcdefg
23     WHEN "0000" => leds <= ("0000001");
24     WHEN "0001" => leds <= ("1001111");
25     WHEN "0010" => leds <= ("0010010");
26     WHEN "0011" => leds <= ("0000110");
27     WHEN "0100" => leds <= ("1001100");
28     WHEN "0101" => leds <= ("0100100");
29     WHEN "0110" => leds <= ("0100000");
30     WHEN "0111" => leds <= ("0001111");
31     WHEN "1000" => leds <= ("0000000");
32     WHEN "1001" => leds <= ("0000100");
33     WHEN "1010" => leds <= ("0001000");
34     WHEN "1011" => leds <= ("1100000");
35     WHEN "1100" => leds <= ("0110001");
36     WHEN "1101" => leds <= ("1000010");
37     WHEN "1110" => leds <= ("0110000");
38     WHEN "1111" => leds <= ("0111000");
39     WHEN OTHERS => leds <= ("-----");
40   END CASE;
41
42   END PROCESS;
43
44 END Behavior;

```

## SSEG (Student ID)

This SSEG is almost identical to the Result SSEG; the difference is that there is no ‘Neg’ input and negative led output due to not needing a negative sign for displaying student ID digits. Also the BCD decimal inputs beyond 9 is not included due to student ID digits not going over that.

### Screenshot of SSEG (Student ID) Block Diagram



### SSEG (Student ID) Truth Table

| SSEG (Student ID) Truth Table |                     |         |
|-------------------------------|---------------------|---------|
| BCD Input (4-bit Binary)      | BCD Input (Decimal) | SSEG    |
| 0000                          | 0                   | 0000001 |
| 0001                          | 1                   | 1001111 |
| 0010                          | 2                   | 0010010 |
| 0011                          | 3                   | 0000110 |
| 0100                          | 4                   | 1001100 |
| 0101                          | 5                   | 0100100 |
| 0110                          | 6                   | 0100000 |
| 0111                          | 7                   | 0001111 |
| 1000                          | 8                   | 0000000 |
| 1001                          | 9                   | 0000100 |
| 1010                          | d                   | ddddddd |
| 1011                          | d                   | ddddddd |
| 1100                          | d                   | ddddddd |
| 1101                          | d                   | ddddddd |
| 1110                          | d                   | ddddddd |
| 1111                          | d                   | ddddddd |

### SSEG (Student ID) Waveform



## SSEG (Student ID) VHDL Code

```
1  LIBRARY ieee ;
2  USE ieee.std_logic_1164.all ;
3
4  ENTITY bcdtosseg_studentID IS
5  PORT ( bcd : IN STD_LOGIC_VECTOR(3 DOWNTO 0);
6         led : OUT STD_LOGIC_VECTOR(0 TO 6) );
7  END bcdtosseg_studentID;
8
9  ARCHITECTURE Behavior OF bcdtosseg_studentID IS
10 BEGIN
11  PROCESS (bcd)
12  BEGIN
13  BEGIN
14
15  CASE bcd IS          --abcdefg
16    WHEN "0000" => led <= ("0000001");
17    WHEN "0001" => led <= ("1001111");
18    WHEN "0010" => led <= ("0010010");
19    WHEN "0011" => led <= ("0000110");
20    WHEN "0100" => led <= ("1001100");
21    WHEN "0101" => led <= ("0100100");
22    WHEN "0110" => led <= ("0100000");
23    WHEN "0111" => led <= ("0001111");
24    WHEN "1000" => led <= ("0000000");
25    WHEN "1001" => led <= ("0000100");
26    WHEN OTHERS => led <= ("-----");
27  END CASE;
28
29  END PROCESS;
30
31 END Behavior;
```

## SSEG (Answer) (for ALU 3 only)

### Screenshot of SSEG (Answer) Block Diagram



### SSEG (Answer) Truth Table

| SSEG (for ALU3) Truth Table |                     |           |
|-----------------------------|---------------------|-----------|
| Input                       | SSEG ('0' means ON) | Yes or No |
| 0000                        | 0001001             | n         |
| 0001                        | 1000100             | y         |

### SSEG (Answer) Waveform



From the waveform, it is observed that the display outputs 'n' when 0000 is read by the SSEG and 'y' is output when 0001 is read by the SSEG.

### SSEG (Answer) VHDL Code

```
1  LIBRARY ieee ;
2  USE ieee.std_logic_1164.all ;
3
4  ENTITY bcdtosseg_answer IS
5  PORT ( bcd : IN STD_LOGIC_VECTOR(3 DOWNTO 0);
6        led : OUT STD_LOGIC_VECTOR(0 TO 6) );
7  END bcdtosseg_answer;
8
9  ARCHITECTURE Behavior OF bcdtosseg_answer IS
10 BEGIN
11   PROCESS (bcd)
12   BEGIN
13
14   CASE bcd IS          --abcdefg
15     WHEN "0000" => led <= ("0001001"); -- no
16     WHEN "0001" => led <= ("1000100"); -- yes
17     WHEN OTHERS => led <= ("-----"); -- do nothing
18   END CASE;
19
20   END PROCESS;
21
22
23 END Behavior;
```

## ALU1 Problem Set 1

### Description

The purpose of ALU1 is to perform basic arithmetic and Boolean operations given 8-bit inputs A and B from the two storage latches. The ALU1 core will receive the opcode instruction of what operation to do at each rising edge of the clock signal. Once received, the action will be performed using both inputs or either input, depending on the operation at hand. The result of the operation will be an 8-bit output. Since the seven segment displays can only take a 4-bit binary input, the result will be split into two 4-bit results (R2 and R1) which will be split across two seven segment displays. For this ALU, there will be a total of 3 SSEGs. One SSEG will display the result R1 which is the first four MSBs (Most Significant Bits) of the result. Another SSEG will display the result R2 which is the four LSBs (Least Significant Bits) of the result. The final SSEG will display a negative sign if the computation of an operation results in a negative result (namely function 2). Each of the 8 microcodes gives instructions to the ALU to perform a different function. This information is located in the table below. As mentioned previously every component of the CPU is connected to the same clock. As the FSM up-counts through the different states and corresponding student ID digits, the ALU1 will cycle through performing the different functions supplied by the opcode. Once all the functions have been performed and the FSM cycles back to loop the sequence, the ALU will also loop from the beginning to do the operations again.

### Screenshot of ALU1 Block Schematic File (BDF)



### **Purpose of Inputs and Outputs for ALU1**

The ALU1 takes the inputs A and B as they are what will be used to perform the operations. The clock's purpose is to let the FSM know when to perform the given operation. The opcode input will inform the ALU of the current operation to be completed. Regarding the outputs of the ALU, R2 and R1 are the split outputs of the 8-bit result from the computation. The negative sign output sends data to the negative sign SSEG regarding whether a negative sign is required for the computation that was done.

### **Table of Microcodes Generated by the Decoder for ALU1**

| Function # | Microcode (from 4-to-16 Decoder) | Operation              |
|------------|----------------------------------|------------------------|
| 1          | 0000000000000001                 | Sum(A,B)               |
| 2          | 0000000000000010                 | Diff(A,B)              |
| 3          | 000000000000100                  | $\bar{A}$              |
| 4          | 0000000000001010                 | $\overline{A \cdot B}$ |
| 5          | 0000000000010000                 | $\overline{A + B}$     |
| 6          | 0000000000100000                 | $A \cdot B$            |
| 7          | 0000000001000000                 | $A \oplus B$           |
| 8          | 0000000010000000                 | $A + B$                |

### ALU1 Complete Truth Table for the Various Operations

| ALU1 Truth Table |                        |      |                       |         |                      |           |               |         |
|------------------|------------------------|------|-----------------------|---------|----------------------|-----------|---------------|---------|
| Input A          |                        |      |                       | Input B |                      |           |               |         |
| Decimal          | Binary (8-bit)         |      |                       | Decimal | Binary (8-bit)       |           |               |         |
| 28               | 00101000               |      |                       | 65      | 01100101             |           |               |         |
| ALU Process      | Results (4-bit Binary) |      | Results (Hexadecimal) |         | Results SSEG Display |           | Negative Sign |         |
| Function #       | R2                     | R1   | R2                    | R1      | SSEG (R2)            | SSEG (R1) | Yes or No?    | SSEG    |
| 1                | 0110                   | 1101 | 6                     | D       | 0100000              | 1000010   | No            | 1111111 |
| 2                | 0011                   | 1101 | 3                     | D       | 0000110              | 1000010   | Yes           | 1111110 |
| 3                | 1101                   | 0111 | D                     | 7       | 1000010              | 0001111   | No            | 1111111 |
| 4                | 1101                   | 1111 | D                     | F       | 1000010              | 0111000   | No            | 1111111 |
| 5                | 1001                   | 0010 | 9                     | 2       | 0000100              | 0010010   | No            | 1111111 |
| 6                | 0010                   | 0000 | 2                     | 0       | 0010010              | 0000001   | No            | 1111111 |
| 7                | 0100                   | 1101 | 4                     | D       | 1001100              | 1000010   | No            | 1111111 |
| 8                | 0110                   | 1101 | 6                     | D       | 0100000              | 1000010   | No            | 1111111 |

### Handwritten Work for ALU1 Operations

$$\underline{\text{ALU1}} \quad A = 00101000 \quad B = 01100101$$

Function 1:  $\text{Sum}(A, B) \Rightarrow$

|                                               |                                             |
|-----------------------------------------------|---------------------------------------------|
| $+ \begin{array}{r} 0010 \\ 0110 \end{array}$ | $\begin{array}{r} 1000 \\ 0191 \end{array}$ |
| $\hline 0110$                                 | $\hline 1101$                               |
| $\underbrace{6}$                              | $\underbrace{D}$                            |

Function 2:  $\text{Diff}(A, B) \Rightarrow$

|                                                       |                                               |                                                 |
|-------------------------------------------------------|-----------------------------------------------|-------------------------------------------------|
| $- \begin{array}{r} 0010 \\ 0110 \\ 0011 \end{array}$ | $\begin{array}{r} 0101 \\ - 1000 \end{array}$ | $= + \begin{array}{r} 0101 \\ 1000 \end{array}$ |
| $\underbrace{-3}$                                     | $\hline 1000$                                 | $\hline 1101$                                   |
|                                                       |                                               | $\underbrace{D}$                                |

negative sign appears when subtracting

Function 3:  $\bar{A} \Rightarrow \overline{00101000} = \underbrace{1101}_{\text{D}} \underbrace{0111}_{\text{7}}$

Function 4:  $\overline{A \cdot B} \Rightarrow \overline{00101000 \cdot 01100101} = \overline{00100000} = \underbrace{1101}_{\text{D}} \underbrace{1111}_{\text{F}}$

Function 5:  $\overline{A+B} \Rightarrow \overline{00101000 + 01100101} = \overline{01101101} = \underbrace{1001}_{\text{9}} \underbrace{0010}_{\text{2}}$

Function 6:  $A \cdot B \Rightarrow 00101000 \cdot 01100101 = \underbrace{00100000}_{\text{2 } 0}$

Function 7:  $A \oplus B \Rightarrow 00101000 \oplus 01100101 = \underbrace{01001101}_{\text{4 } D}$

Function 8:  $A+B \Rightarrow 00101000 + 01100101 = \underbrace{01101101}_{\text{6 } D} = 10010010$

### Screenshot of Complete Waveform for ALU1



## ALU1 VHDL Code

```

1  LIBRARY ieee;
2  USE ieee.std_logic_1164.all;
3  USE ieee.std_logic_unsigned.all;
4  USE ieee.numeric_std.all;
5
6  ENTITY ALU IS
7  PORT(
8      clk : in STD_LOGIC;
9      A,B : in STD_LOGIC_VECTOR(7 DOWNTO 0); -- 8-bit inputs A & B from Reg. 1 & Reg. 2
10     opcode : in STD_LOGIC_VECTOR(3 DOWNTO 0); -- 8-bit opcode from Decoder
11     R1, R2 : out STD_LOGIC_VECTOR(3 DOWNTO 0); -- two 4-bit results
12     negative : out STD_LOGIC);
13 END ALU;
14
15 ARCHITECTURE calculation OF ALU IS
16 SIGNAL Reg1, Reg2, Result : STD_LOGIC_VECTOR(7 DOWNTO 0) := (OTHERS => '0');
17
18 BEGIN
19     Reg1 <= A;
20     Reg2 <= B;
21
22     PROCESS(clk,opcode)
23     BEGIN
24         if(rising_edge(clk)) then
25             case opcode is
26                 WHEN "0000000000000001" => -- Addition of both numbers
27                     Result <= Reg1 + Reg2;
28                     negative <= '0';
29
30                 WHEN "0000000000000010" => -- Subtraction of both numbers
31                     if (Reg2 > Reg1) then -- Accounting for a negative result with a negative sign
32                         Result <= Reg2 - Reg1;
33                         negative <= '1';
34                     else -- Accounting for non-negative result with no negative sign
35                         Result <= Reg1 - Reg2;
36                         negative <= '0';
37
38             end if;
39
40             WHEN "0000000000001000" => -- Inverting A operation
41                 Result <= NOT(Reg1);
42                 negative <= '0';
43
44             WHEN "0000000000001000" => -- A NAND B operation
45                 Result <= Reg1 NAND Reg2;
46                 negative <= '0';
47
48             WHEN "0000000000001000" => -- A NOR B operation
49                 Result <= Reg1 NOR Reg2;
50                 negative <= '0';
51
52             WHEN "0000000000100000" => -- A AND B operation
53                 Result <= Reg1 AND Reg2;
54                 negative <= '0';
55
56             WHEN "0000000001000000" => -- A XOR B operation
57                 Result <= Reg1 XOR Reg2;
58                 negative <= '0';
59
60             WHEN "0000000010000000" => -- A OR B operation
61                 Result <= Reg1 OR Reg2;
62                 negative <= '0';
63
64             WHEN OTHERS => --don't care, do nothing
65
66             end case;
67         end if;
68     END PROCESS;
69     R1 <= Result(3 DOWNTO 0); --Result split into two 4-bit outputs and displayed on 2 pairs of seven segment displays
70     R2 <= Result(7 DOWNTO 4);
71     END calculation;

```

## ALU2 Problem Set 2

### Description

ALU2 will work very similarly to ALU1. ALU1 was used to perform basic arithmetic and Boolean operations given 8-bit inputs A and B from the two storage latches. The ALU2 core, just like ALU1, will receive the opcode instruction of what operation to do at each rising edge of the clock signal. Once received, the action will be performed using both inputs or either input, depending on the operation at hand. The result of the operation will be an 8-bit output. Since the seven segment displays can only take a 4-bit binary input, the result will be split into two 4-bit results (R2 and R1) which will be split across two seven segment displays. For this ALU, there will be a total of 2 SSEGs. One SSEG will display the result R1 which is the first four MSBs (Most Significant Bits) of the result. Another SSEG will display the result R2 which is the four LSBs (Least Significant Bits) of the result. Each of the 8 microcodes gives instructions to the ALU to perform a different function. The set of microcodes is from Problem (d). This information is located in the table below. Every component of the CPU is connected to the same clock. As the FSM up-counts through the different states and corresponding student ID digits, the ALU2 will cycle through performing the different functions supplied by the opcode. Once all the functions have been performed and the FSM cycles back to loop the sequence, the ALU will also loop from the beginning to do the operations again.

### Screenshot of ALU2 Block Schematic File (BDF)



### Purpose of Inputs and Outputs for ALU2

The ALU2 takes the inputs A and B as they are what will be used to perform the operations. The clock's purpose is to let the FSM know when to perform the given operation. The opcode input will inform the ALU of the current operation to be completed. Regarding the outputs of the ALU, R2 and R1 are the split outputs of the 8-bit result from the computation.

### Table of Microcodes Generated by the Decoder for ALU2

*Problem Set: d)*

| Function # | Microcode (from 4-to-16 Decoder) | Operation                                                                                   |
|------------|----------------------------------|---------------------------------------------------------------------------------------------|
| 1          | 0000000000000001                 | Shift <b>A</b> to right by two bits, input bit = 1 (SHR)                                    |
| 2          | 0000000000000010                 | Produce the difference of <b>A</b> and <b>B</b> and then increment by 3                     |
| 3          | 000000000000100                  | Find the greater value of <b>A</b> and <b>B</b> and produce the results (Max( <b>A,B</b> )) |
| 4          | 0000000000001010                 | Swap the upper 4 bits of <b>A</b> by the lower 4 bits of <b>B</b>                           |
| 5          | 0000000000010000                 | Increment <b>A</b> by 1                                                                     |
| 6          | 0000000000100000                 | Produce the result of ANDing <b>A</b> and <b>B</b>                                          |
| 7          | 000000001000000                  | Invert the upper four bits of <b>A</b>                                                      |
| 8          | 000000010000000                  | Rotate <b>B</b> to left by 3 bits (ROL)                                                     |

### ALU2 Complete Truth Table for the Various Operations

| ALU2 Truth Table |                        |      |                       |                |              |           |
|------------------|------------------------|------|-----------------------|----------------|--------------|-----------|
| Input A          |                        |      | Input B               |                |              |           |
| Decimal          | Binary (8-bit)         |      | Decimal               | Binary (8-bit) |              |           |
| 28               | 00101000               |      | 65                    | 01100101       |              |           |
|                  |                        |      |                       |                |              |           |
| ALU Operation    | Results (4-bit Binary) |      | Results (Hexadecimal) |                | SSEG Display |           |
| Function #       | R2                     | R1   | R2                    | R1             | SSEG (R2)    | SSEG (R1) |
| 1                | 1100                   | 1010 | C                     | A              | 0110001      | 0001000   |
| 2                | 1100                   | 0110 | C                     | 6              | 0110001      | 0100000   |
| 3                | 0110                   | 0101 | 6                     | 5              | 0100000      | 0100100   |
| 4                | 0101                   | 1000 | 5                     | 8              | 0100100      | 0000000   |
| 5                | 0010                   | 1001 | 2                     | 9              | 0010010      | 0000100   |
| 6                | 0010                   | 0000 | 2                     | 0              | 0010010      | 0000001   |
| 7                | 1101                   | 1000 | D                     | 8              | 1000010      | 0000000   |
| 8                | 0010                   | 1011 | 2                     | B              | 0010010      | 1100000   |

### Handwritten Work for ALU2 Operations

$$\text{ALU 2} \quad A = 00101000 \quad B = 01100101$$

Function 1 : A SHR 2 bits  
Input bit = 1



Function 2:  $(A - B) + 3$

$$\begin{array}{r} 0010 \\ - 0110 \\ \hline 0010 \end{array} \Rightarrow \begin{array}{r} 0010 \\ + 1010 \\ \hline 1100 \\ + 0011 \\ \hline 1100 \end{array}$$

C

$$\begin{array}{r} 1000 \\ - 0101 \\ \hline 0011 \\ + 0011 \\ \hline 0110 \end{array}$$

6

Function 3:  $\text{Max}(A, B)$      $\text{Max}(A, B) = B = \underbrace{01100101}_{6 \ 5}$

Function 4: Swap upper 4 bits of A with lower 4 bits of B

$$\begin{aligned} A &= \underline{\underline{0010}}1000 \quad B = 0110\underline{\underline{0101}} \\ &= \underline{\underline{0101}}1000 \\ &\quad \text{5} \quad \text{8} \end{aligned}$$

Function 5: Increment A by 1 :

$$\begin{array}{r} 00101000 \\ + 00000001 \\ \hline 00101001 \end{array}$$

2      9

Function 6:  $A \cdot B \Rightarrow 00101000 \cdot 01100101 = \underline{\underline{00100000}}$

2      0

Function 7: Invert upper 4 bits of A :  $\overline{00101000} = \underline{\underline{11011000}}$

D      8

Function 8: Rotate B left 3 bits:  $01100101 \xrightarrow{2 \text{ rotation}} 11001010$

$$\begin{array}{r} 11001010 \\ 10010101 \\ 00101011 \\ \hline \end{array}$$

2      B

## Screenshot of Complete Waveform for ALU2



## ALU2 VHDL Code

```

1 LIBRARY ieee;
2 USE ieee.std_logic_1164.all;
3 USE ieee.std_logic_unsigned.all;
4 USE ieee.numeric_std.all;
5
6 ENTITY ALU2 IS
7 PORT(
8     clk : in STD_LOGIC;
9     A,B : in UNSIGNED(7 DOWNTO 0); -- 8-bit inputs A & B from Reg. 1 & Reg. 2
10    opcode : in UNSIGNED(3 DOWNTO 0); -- 8-bit opcode from Decoder
11    R1, R2 : out UNSIGNED(3 DOWNTO 0); -- two 4-bit results
12    negative : out STD_LOGIC);
13 END ALU2;
14
15 ARCHITECTURE calculation OF ALU2 IS
16 SIGNAL Reg1, Reg2, Result : UNSIGNED(7 DOWNTO 0) := (OTHERS => '0');
17
18 BEGIN
19     Reg1 <= A;
20     Reg2 <= B;
21
22 PROCESS(clk,opcode)
23 BEGIN
24     case opcode is
25
26 WHEN "0000000000000001" =>
27     Result <= Reg1 srl 2; -- Shift A right 2 bits
28     Result(6) <= '1'; --Input bit 1
29     Result(7) <= '1';
30
31 WHEN "0000000000000010" => -- Subtraction of both numbers and increment by 3
32     Result <= (Reg1 - Reg2) + "00000011";
33
34 WHEN "00000000000000100" => -- Output the maximum of the 2 numbers;

```

```

35      if(Reg1 > Reg2) then
36          Result <= Reg1;
37      else
38          Result <= Reg2;
39      end if;
40
41      WHEN "0000000000001000" => -- Swap upper 4 bits of A with lower 4 bits of B
42          Result(0) <= Reg1(0);
43          Result(1) <= Reg1(1);
44          Result(2) <= Reg1(2);
45          Result(3) <= Reg1(3);
46          Result(4) <= Reg2(0);
47          Result(5) <= Reg2(1);
48          Result(6) <= Reg2(2);
49          Result(7) <= Reg2(3);
50
51      WHEN "0000000000010000" => -- Increment A by 1
52          Result <= Reg1 + "00000001";
53
54      WHEN "0000000000100000" => -- A AND B operation
55          Result <= Reg1 AND Reg2;
56          negative <= '0';
57
58      WHEN "0000000001000000" => -- Invert upper four bits of A
59          Result(0) <= Reg1(0);
60          Result(1) <= Reg1(1);
61
61      Result(2) <= Reg1(2);
62      Result(3) <= Reg1(3);
63      Result(4) <= NOT Reg1(4);
64      Result(5) <= NOT Reg1(5);
65      Result(6) <= NOT Reg1(6);
66      Result(7) <= NOT Reg1(7);
67
68      WHEN "0000000010000000" => -- Rotate B left 3 bits
69          Result <= Reg2 ROL 3;
70
71      WHEN OTHERS => --don't care, do nothing
72
73          end case;
74      END PROCESS;
75      R1 <= Result(3 DOWNTO 0); --Result split into two 4-bit outputs and displayed on 2 pairs of seven segment displays
76      LR2 <= Result(7 DOWNTO 4);
77      END calculation;

```

## ALU3 Problem Set 3

### Description

ALU3 will work slightly differently to the other ALUs. In this case, the only useful inputs to the ALU3 is the opcode from the control unit and the student ID digits from the FSM. The ALU3 core will receive the opcode instruction of what operation to do at each rising edge of the clock signal. According to Problem Set (c), the ALU will check the current student ID digit for the current state. If the digit has odd parity in 4-bit binary, the SSEG will display the letter 'y' for yes. If the digit has even parity, the SSEG will display the letter 'n' for no. Since there is just the need for one letter output at a time, there will only be one SSEG for ALU3 which will be modified appropriately to display 'y' or 'n'. Every component of the CPU is connected to the same clock. As the FSM up-counts through the different states and corresponding student ID digits, the ALU3 will cycle through performing the different functions supplied by the opcode. Once all the functions have been performed and the FSM cycles back to loop the sequence, the ALU will also loop from the beginning to do the operations again.

### Screenshot of ALU3 Block Schematic File (BDF)



### Purpose of Inputs and Outputs for ALU3

The ALU3 takes the student ID input from the FSM. The clock's purpose is to let the FSM know when to perform the given operation. The opcode input will inform the ALU of the current operation to be completed. Regarding the output, a binary code will be sent to the SSEG and depending on the ALU's operation, the letter 'y' or the letter 'n' will be displayed by the SSEG.

### Table of Microcodes Generated by the Decoder for ALU3

**Problem Set: c):** For each opcode submitted to the ALU, display 'y' if the student\_id signal has an odd parity and 'n' otherwise.

| Function # | Microcode (from 4-to-16 Decoder) | Operation                                            |
|------------|----------------------------------|------------------------------------------------------|
| 1          | 0000000000000001                 | Checks if the student ID's 2nd digit has odd parity. |
| 2          | 00000000000000010                | Checks if the student ID's 3rd digit has odd parity. |
| 3          | 00000000000000100                | Checks if the student ID's 4th digit has odd parity. |
| 4          | 0000000000001010                 | Checks if the student ID's 5th digit has odd parity. |
| 5          | 0000000000010000                 | Checks if the student ID's 6th digit has odd parity. |
| 6          | 0000000000100000                 | Checks if the student ID's 7th digit has odd parity. |
| 7          | 0000000001000000                 | Checks if the student ID's 8th digit has odd parity. |
| 8          | 0000000010000000                 | Checks if the student ID's 9th digit has odd parity. |

### ALU3 Complete Truth Table for the Various Operations

| ALU3 Truth Table           |            |                           |                                |             |         |
|----------------------------|------------|---------------------------|--------------------------------|-------------|---------|
| Student ID<br>(BCD Format) | Function # | Student ID #<br>(Decimal) | Student ID #<br>(4-bit Binary) | Odd Parity  |         |
|                            |            |                           |                                | (Yes or No) | SSEG    |
| 0000001                    | 1          | 0                         | 0000                           | No          | 0001001 |
| 1001111                    | 2          | 1                         | 0001                           | Yes         | 1000100 |
| 0010010                    | 3          | 2                         | 0010                           | Yes         | 1000100 |
| 1001100                    | 4          | 4                         | 0100                           | Yes         | 1000100 |
| 0010010                    | 5          | 2                         | 0010                           | Yes         | 1000100 |
| 0000000                    | 6          | 8                         | 1000                           | Yes         | 1000100 |
| 0100000                    | 7          | 6                         | 0110                           | No          | 0001001 |
| 0100100                    | 8          | 5                         | 0101                           | No          | 0001001 |

### Handwritten Work for ALU3 Operations

| <u>ALU3</u> |                         |               |                         |                                            |
|-------------|-------------------------|---------------|-------------------------|--------------------------------------------|
|             | <u>Student ID Digit</u> | <u>Binary</u> | <u>Number of 1 Bits</u> | <u>Odd Parity (odd number of 1 bits) ?</u> |
| Function 1: | 0                       | 0000          | 0                       | No                                         |
| Function 2: | 1                       | 0001          | 1                       | Yes                                        |
| Function 3: | 2                       | 0010          | 1                       | Yes                                        |
| Function 4: | 4                       | 0100          | 1                       | Yes                                        |
| Function 5: | 2                       | 0010          | 1                       | Yes                                        |
| Function 6: | 8                       | 1000          | 1                       | Yes                                        |
| Function 7: | 6                       | 0110          | 2                       | No                                         |
| Function 8: | 5                       | 0101          | 2                       | No                                         |

## Screenshot of Complete Waveform for ALU3



## ALU3 VHDL Code

```

1  LIBRARY ieee;
2  USE ieee.std_logic_1164.all;
3  USE ieee.numeric_std.all;
4  USE ieee.std_logic_unsigned.all;
5
6  ENTITY ALU3 IS
7  PORT(
8      clk : in STD_LOGIC;
9      A,B : in STD_LOGIC_VECTOR(7 DOWNTO 0);
10     opcode : in STD_LOGIC_VECTOR(15 DOWNTO 0); -- 8-bit opcode from Decoder
11     student_ID : in STD_LOGIC_VECTOR(3 DOWNTO 0);
12     Answer : out STD_LOGIC_VECTOR(3 DOWNTO 0));
13 END ALU3;
14
15 ARCHITECTURE calculation OF ALU3 IS
16
17 BEGIN
18
19 PROCESS(opcode)
20 BEGIN
21     case opcode is
22         -- Checking for odd parity; if odd parity, output 'y'; if even parity, output 'n'
23         WHEN "0000000000000001" =>
24             if (NOT(student_ID(3) XOR student_ID(2) XOR student_ID(1) XOR student_ID(0)) = '0') then
25                 Answer <= "0001";
26             else
27                 Answer <= "0000";
28             end if;
29
30         WHEN "0000000000000010" =>
31             if (NOT(student_ID(3) XOR student_ID(2) XOR student_ID(1) XOR student_ID(0)) = '0') then
32                 Answer <= "0001";

```

```

32      else
33          Answer <= "0000";
34      end if;
35
36      WHEN "0000000000000100" =>
37          if (NOT(student_ID(3) XOR student_ID(2) XOR student_ID(1) XOR student_ID(0)) = '0') then
38              Answer <= "0001";
39          else
40              Answer <= "0000";
41          end if;
42
43      WHEN "0000000000001000" =>
44          if (NOT(student_ID(3) XOR student_ID(2) XOR student_ID(1) XOR student_ID(0)) = '0') then
45              Answer <= "0001";
46          else
47              Answer <= "0000";
48          end if;
49
50      WHEN "0000000000010000" =>
51          if (NOT(student_ID(3) XOR student_ID(2) XOR student_ID(1) XOR student_ID(0)) = '0') then
52              Answer <= "0001";
53          else
54              Answer <= "0000";
55          end if;
56
57      WHEN "0000000000100000" =>
58          if (NOT(student_ID(3) XOR student_ID(2) XOR student_ID(1) XOR student_ID(0)) = '0') then
59              Answer <= "0001";
60          else
61              Answer <= "0000";
62          end if;
63
64      WHEN "0000000001000000" =>
65          if (NOT(student_ID(3) XOR student_ID(2) XOR student_ID(1) XOR student_ID(0)) = '0') then
66              Answer <= "0001";
67          else
68              Answer <= "0000";
69          end if;
70
71      WHEN "0000000010000000" =>
72          if (NOT(student_ID(3) XOR student_ID(2) XOR student_ID(1) XOR student_ID(0)) = '0') then
73              Answer <= "0001";
74          else
75              Answer <= "0000";
76          end if;
77
78      WHEN OTHERS => --don't care, do nothing
79          Answer <= "----";
80
81      end case;
82  END PROCESS;
83  END calculation;

```

## ALU1 Operation Pictures (One Full Sequence In Order)









## ALU2 Operation Pictures (One Full Sequence In Order)









## ALU3 Operation Pictures (One Full Sequence In Order)









## **Conclusion**

In Lab 6, I was able to successfully design and implement a simple working CPU that could perform basic arithmetic and logical operations. Throughout the semester, I learned about various components and how their logic worked. Through working on the labs prior to Lab 6, I was able to gain a deeper understanding on how various digital circuits work. Things like storage units are crucial to keep memory of the input data passed on to the system. Without a decoder, it would be difficult to pass on instructions in a concise and neat manner to the ALU. Most importantly, the clock signal is an extremely important aspect. Without a clock to time everything synchronously, no calculation would occur properly; matter of fact, the system would be completely dysfunctional. Using all of this knowledge I gained through my time studying the course, I was able to strive really hard to achieve the accomplishment of successfully completing Lab 6. It was definitely challenging to get the entire system to work and there were several hurdles along the way. But with each obstacle, I was patient and analysed the situation to be able to move past it and finish the project. The knowledge I gained from this course, its content and all of the labs will most definitely help me in my future endeavours and I am grateful for that!