# **BME328 LAB7** Implementation of Simple Processor

40 Marks (3 weeks) Due Date: Week 13

**Objective:** 

- Design and implementation of simple 8-bit microprocessor
- The processor consists of ALU, Registers to store data, Control unit to execute instructions pointed to by program counter (PC)

\_\_\_\_\_

# **Summary of System Operation:**

An abstract view of system is illustrated in Fig.1.

- 1. 8-bit input data is entered in the simulation phase through the Quartus II waveform editor, and stored in register R1 when instruction LD-R1 is executed
- 2. 8-bit ALU perform operation on input A and input B based on OP code of executed instruction
- 3. ALU input A is connected to R1, input B is connected to Accumulator AC.
- 4. Results of each operation is displayed on two 7 Seg display unit connected to output of AC
- 5. RC register stores 8-bit input data when LD-RC instruction is executed and RC output is used as a conditional register for control flow
- 6. PC is a counter that is used to point to next instruction to be executed and starts from Instruction 0 to Instruction N. Each clock cycle it increments PC to point to next instruction
- 7. Combinational circuit stores the Instructions starting from address 0 to address N. Each instruction has its op code to be used by ALU.



Fig.1 SIMPLE PROCESSOR Organization

# Lab Procedure:

This processor consists of different components that functions in specific sequence to generate the desired output according to the instruction being executed. A processor is usually divided to 4 distinct sub-units Memory Unit, Control Unit, Data storage and ALU core unit. The Memory Unit performs the fetching of instructions. Data storage unit stores data from input switches and results of ALU unit to registers R1, RC and Acc. The ALU Core performs the arithmetic and logical operations on desired inputs and produces the required outputs. The Control unit decode the instruction and activates the control signals to execute it. In this project, we will be implementing distinct tasks by varying logic of control unit.

# Description of system functioning and implementation details:

#### Part 1: Data Storage Unit

Input data is entered in the simulation phase through the Quartus II waveform editor. The input data bus is connected to two 8-bits registers namely R1 (Data register) and RC (Control Register). The data from input bus is loaded into either register R1 or register RC depending on the control signals from the control unit. The control signals associated with storing input data are as follows:

- LD-R1 => 1: Load register R1 from input bus
- LD-RC => 1: Load register RC from input bus
- Dec-RC => 1: Decrement content of register RC by 1.

Suggested implementation for register R1 is as follows:

```
LIBRARY ieee ;
 USE ieee.std_logic_1164.all ;
 use IEEE.numeric_std.all;
ENTITY RC IS
PORT ( D: IN unsigned(7 DOWNTO 0) ;
 LD_RC, Dec_RC : IN STD_LOGIC ;
-Q: OUT unsigned(7 DOWNTO 0) );
 END RC;

    ARCHITECTURE Behavior OF RC IS

Signal D_signal,Q_signal: unsigned(7 DOWNTO 0);
BEGIN
D_signal <= D;
PROCESS (LD_RC, Dec_RC)
 BEGIN
  --- Insert your code here
 END PROCESS ;
Q <= Q_signal;
  END Behavior ;
```

------

\_\_\_\_\_

Suggested implementation for register RC is as follows:

```
LIBRARY ieee ;
 USE ieee.std_logic_1164.all ;
 use IEEE.numeric_std.all;
ENTITY RC IS

PORT ( D: IN unsigned (7 DOWNTO 0) ;
 LD_RC, Dec_RC : IN STD_LOGIC ;
 Q: OUT unsigned(7 DOWNTO 0) );
 END RC;
ARCHITECTURE Behavior OF RC IS
 Signal D_signal,Q_signal: unsigned(7 DOWNTO 0);
BEGIN
 D signal <= D;
PROCESS (LD_RC, Dec_RC)
 BEGIN
  --- Insert your code here
 END PROCESS ;
 Q <= Q_signal;
 END Behavior ;
```

## Part 2: Arithmetic Logic Unit Core

The heart of every processor unit is the ALU core where all arithmetic and logical operations are to be implemented and applied as required. In this part students are required to implement all functionalities and operations using VHDL syntax compatible with Altera FPGA boards. ALU core consists of two components ALU and accumulator (ACC). ACC is a register in which intermediate arithmetic and logic results are stored and fed back to the ALU.

The ALU will take two 8-bit inputs (A and B) and a 4-bit opcode from Control unit. The opcode input from controller unit is the operation-selector signal, deciding the operation that is to be applied on the inputs A and B based on the instruction being executed.

#### Suggested implementation for ALU is as follows:

```
vs IEEE.som_tCoTd.alty

use IEEE.som_tCoTd_UNSIGNED.ALL;

ENTITY AUD IS

Port {

A. B. inde 'in STD_UGIC_UNSIGNED.ALL;

ENTITY AUD IS

inde 'in STD_UGIC_UNSIGNED', ALL;

entitety and 'inde', and', and 'inde', and 'inde', and', an
```

#### Suggested implementation for ACC is as follows:

\_\_\_\_\_

```
LIBRARY ieee ;
   USE ieee.std_logic_1164.all ;
   use ieee.numeric_std.all ;
 ENTITY ACC IS
PORT (D: IN unsigned(7 downto 0);
SHL_ACC,SHR_ACC,Clock,Reset : IN STD_LOGIC;
Q: OUT unsigned(7 DOWNTO 0));
   END ACC ;
ARCHITECTURE Behavior OF ACC IS
L signal store_signal : unsigned(7 downto 0) := (others => '0');
BEGIN
PROCESS (SHL_ACC, Clock, Reset, SHR_ACC, D)
 BEGIN
□ IF Reset = '0' then

↓ store_signal <= "00000000";

□ ELSIF((Reset = '1') and (falling_edge(Clock)))then --raising edge of clock
| store_signal<= D;

 IF SHL_ACC = '1' THEN
store_signal <= store_signal sll 1 ;
END IF;</pre>
      IF SHR_ACC = '1' THEN
       store_signal <= store_signal srl 1 ;
END IF ;</pre>
END IF;
END IF;
END PROCESS ;
Q <= store_signal;
ND Behavior ;
```

# Part 3: Control Unit

The Control unit decides the microcode that is to be delivered to the ALU core and will act as the operations-selector for the ALU core. The Control Unit produces an output OP, which is passed to ALU core as the operations selector. This component consists of program counter (PC) and combinational circuit. The control unit uses Finite State Machine (FSM) to implement PC and combinational circuit is an instruction memory. The details of instruction set to be implemented by control unit are given in following table.

| Mnemonics              | Description                           | Opcode |
|------------------------|---------------------------------------|--------|
| Register Transfer      |                                       |        |
| LDR1                   | Load R1 from input; R1=INPUT          | 0      |
| LDRC                   | Load RC from input; RC= INPUT         | 1      |
| Arithmetic Operations: |                                       |        |
| ADDA                   | Add R1 to Acc; $Acc = Acc + R1$       | 2      |
| SUBA                   | Sub R1 from Acc; Acc= ACC-R1          | 3      |
| INCA                   | Increment Acc; Acc=Acc + 1            | 4      |
| DECA                   | Dec Acc; Acc= Acc -1                  | 5      |
| DEC-RC                 | Dec RC; $RC = RC - 1$                 | 6      |
| Logic Operations       |                                       |        |
| ANDA                   | And Acc with R1; Acc=Acc&R1           | 7      |
| ORA                    | Or Acc with R1; $Acc = Acc   R1$      | 8      |
| XORA                   | XOR Acc with R1; Acc =Acc XOR R1      | 9      |
| NAND                   | Invert Acc; $Acc = Acc NAND R1$       | А      |
| SLA                    | Shift Left Acc; Acc=Acc*2             | В      |
| SRA                    | Shift Right Acc; $Acc = Acc/2$        | С      |
| Control flow           |                                       |        |
| BNEQZ                  | branch to start if RC !=0; goto state | D      |

### **Instruction Set**

| <b>Task-1:</b> Calculate average of 4 numbers entered from input x1, x2, x3, x4 |  |
|---------------------------------------------------------------------------------|--|
|                                                                                 |  |

| 1   | Instruction | Result from execution of the instruction |
|-----|-------------|------------------------------------------|
| No. |             |                                          |
| 1   | LDR1 0      | R1 =0;                                   |
| 2   | ANDA        | Acc=0                                    |
| 3   | LDR1 X1     | R1=X1                                    |
| 4   | ADD         | Acc=X1                                   |
| 5   | LDR1 X2     | R1=X2                                    |
| 6   | ADD         | Acc= X1+X2                               |
| 7   | LDR1 X3     | R1=X3                                    |
| 8   | ADD         | Acc=X1+X2+X3                             |
| 9   | LDR1 X4     | R1=X4                                    |
| 10  | ADD         | ACC=X1+X2+X3+X4                          |
| 11  | SR          | Acc= (X1+X2+X3+X4)/2                     |
| 12  | SR          | Acc= (X1+X2+X3+X4)/4                     |
|     |             |                                          |

Instruction Sequence to execute the task-1

FSM implementation of PC for task-1



Suggested implementation of PC and instruction memory for task-1 is as follows: *Please note that next two figures are part of a single vhdl code file. Please focus on bottom of first figure and top of second figure to find continuation between them.* 

\_\_\_\_\_

```
LIBRARY ieee;
USE ieee.std logic 1164.all;
ENTITY PC_comb_ckt_example1 IS
PORT (Clock, Reset : IN STD_logic;
z : OUT STD_LOGIC_VECTOR (3 DOWNTO 0);
RC : IN STD_LOGIC_VECTOR (7 DOWNTO 0); -- used for branch instruction
LD_R1, LD_RC, Dec_RC, SHL_Acc, SHR_Acc, ACC_output_bus_select : out std_logic);
-- RC_select = 1 --> input connected to RC
-- RC_select = 0 --> input connected to R1
-- A_select = 1 --> ACC connected to input A of ALU
-- A_select = 0 --> ACC connected to output bus connected to 7-segment signal
END PC_comb_ckt_example1;
ARCHITECTURE Behavior OF PC_comb_ckt_example1 IS
TYPE State_type IS (S0, S1, S2, S3, S4, S5, S6, S7, S8, S9, S10);
SIGNAL y: State_type;
SIGNAL control_signal: STD_LOGIC_VECTOR(9 DOWNTO 0);
BEGIN
PROCESS (Reset, Clock)
BEGIN
IF Reset='0' THEN
y<=S0;
ELSIF (Clock 'EVENT AND Clock='1') THEN
CASE y IS
WHEN SO=> y <= S1;
WHEN S1=> y <=S2;
WHEN S2=> y <=S3;
WHEN S3=> y <=S4;
WHEN S4=> y <=S5;
WHEN $5=> y<=$6;
WHEN S0=> y<=S0;
WHEN S6=> y<=S7;
WHEN S7=> y<=S8;
WHEN S8=> y<=S9;
WHEN S9=> y<=S10;
WHEN S10=> y<=S0;
WHEN S10=> y<=S0;
END CASE;
END IF;
END PROCESS;
PROCESS (Y)
BEGIN
CASE y IS
WHEN SO=>
control signal <= "0000010000"; --Load R1 from input X1
```

```
WHEN S9=> y<=S10;
WHEN S10=> y<=S0;
 END CASE;
- END IF;
- END PROCESS;
PROCESS (Y)
BEGIN
CASE y IS
 control_signal <= "0000010000"; --Load R1 from input X1</pre>
 WHEN S1=>
 control_signal <= "0000000010"; -- Acc = Acc + R1
 WHEN S2=>
 control_signal <= "0000010000"; --Load R1 from input X2, set input to X2
 WHEN S3=>
 control_signal <= "0000000010"; -- Acc = Acc + R1</pre>
 WHEN S4=>
 control_signal <= "0000010000"; --Load R1 from input X3
 WHEN S5=>
 control_signal <= "0000000010"; -- Acc = Acc + R1
 WHEN S6=>
 control_signal <= "0000010000"; --Load R1 from input X4</pre>
 WHEN S7=>
 control_signal <= "0000000010"; -- Acc = Acc + R1
 WHEN S8=>
 control_signal <= "0100000000"; --SRA
 WHEN S9=>
 control_signal <= "0100000000"; --SRA
 WHEN S10=>
                                   -- Connect output of ACC to 7 segment display
 control_signal <= "1000000000";
 END CASE;
 END PROCESS;
 z <= control_signal(3 DOWNTO 0);</pre>
 LD_R1 <= control_signal();
LD_RC <= control_signal(4);
 Dec_RC <= control_signal(6);</pre>
 SHL_Acc <= control_signal(7);
 SHR_Acc <= control_signal(8);
 ACC_output_bus_select <= control_signal(9);
END Behavior;
```

#### Task- 2:

Executing a Loop for number of times. For example

for 
$$(i = 5; i \ge 0; i - -)$$
 {result = result + x}

\_\_\_\_\_

Instruction Sequence to execute the task-2

| Sequence<br>No. | Instruction | Result from execution of the instruction |
|-----------------|-------------|------------------------------------------|
| 1               | LDRC 5      | RC =5;                                   |
| 2               | LDR10       | R1=0                                     |
| 3               | ANDA        | ACC=ACC and 0; ACC = 0;                  |
| 4               | LDR1 X      | R1= X                                    |
| 5               | LOOP: ADD   | ACC = ACC+R1                             |
| 6               | DECRC       | RC = RC-1;                               |
| 7               | BNEQZ LOOP  | PC = address of "LOOP"                   |

| Reset   |           |         |     |
|---------|-----------|---------|-----|
| SO LDRO |           |         |     |
| IDR1    |           | ST<br>E | ind |
| 52      | 2         | RC!=0   |     |
| S3      |           |         |     |
| IDR1    | S4<br>ADD | DECRO   | :   |
|         |           |         |     |
|         |           |         |     |

FSM implementation of PC for task-2

Suggested implementation of PC and instruction memory for task-2 is as follows: *Please note that next two figures are part of a single vhdl code file. Please focus on bottom of first figure and top of second figure to find continuation between them.* 

\_\_\_\_\_

BME-328

| LIBRARY iece;<br>USE iece.std_logic_1164.all;<br>ENVTIY PC_comb_ckt_example1 IS                                                                                                                                                                                                                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PORT (Clock, Reset : IN STD_logic;                                                                                                                                                                                                                                                                      |
| <pre>z : OUT STD_LOGIC_VECTOR(3 DOWNTO 0);<br/>RC : IN STD_LOGIC_VECTOR(7 DOWNTO 0); used for branch instruction</pre>                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                         |
| LD_R1, LD_RC, Dec_RC, SHL_Acc, SHR_Acc, ACC_output_bus_select : out std_logic);<br>END PC_comb_ckt_example1;                                                                                                                                                                                            |
| ARCHITECTURE Behavior OF PC_comb_ckt_example1 IS<br>TYPE State_type IS (S0, S1, S2, S3, S4, S5, S6, S7, S8, S9, S10);                                                                                                                                                                                   |
| SIGNAL y: State_type;<br>SIGNAL control_signal: STD_LOGIC_VECTOR (9 DOWNTO 0);                                                                                                                                                                                                                          |
| LSIGNAL control_signal: STD_LOGIC_VECTOR (9 DOWNTO 0); BEGIN                                                                                                                                                                                                                                            |
| PROCESS (Reset, Clock)                                                                                                                                                                                                                                                                                  |
| BEGIN                                                                                                                                                                                                                                                                                                   |
| IF Reset='0' THEN<br>y<=S0;                                                                                                                                                                                                                                                                             |
| ELSIF (Clock 'EVENT AND Clock='1') THEN                                                                                                                                                                                                                                                                 |
| CASE y IS                                                                                                                                                                                                                                                                                               |
| WHEN S0=> y <= S1;<br>WHEN S1=> y <=S2;                                                                                                                                                                                                                                                                 |
| WHEN S2=> y <=S3;                                                                                                                                                                                                                                                                                       |
| WHEN \$3=> y <=\$4;<br>WHEN \$4=> y <=\$5;                                                                                                                                                                                                                                                              |
| WHEN \$5=> v<=\$6;                                                                                                                                                                                                                                                                                      |
| WHEN S6=> y<=S7;<br>WUEN S7=> v<=S8.                                                                                                                                                                                                                                                                    |
| WHEN S7=> y <= 58;<br>WHEN S8=> y <= 59;<br>WHEN S9=> y <= 510;<br>WHEN S10=> y <= 50;                                                                                                                                                                                                                  |
| WHEN S9=> y<=S10;                                                                                                                                                                                                                                                                                       |
| -END CASE;                                                                                                                                                                                                                                                                                              |
| - END IF;<br>- END PROCESS;                                                                                                                                                                                                                                                                             |
| PROCESS;                                                                                                                                                                                                                                                                                                |
| BEGIN                                                                                                                                                                                                                                                                                                   |
| CASE Y IS<br>WHEN SO=>                                                                                                                                                                                                                                                                                  |
| control_signal <= "0000010000";Load R1 from input X1                                                                                                                                                                                                                                                    |
| WHEN S1=><br>control_signal <= "0000000010"; Acc = Acc + R1<br>WHEN S2=>                                                                                                                                                                                                                                |
| <pre>control_signal &lt;= "0000010000";Load R1 from input X2, set input to X2 WHEN S3=&gt;</pre>                                                                                                                                                                                                        |
| anntys] signal of #00000000000000000000000000000000000                                                                                                                                                                                                                                                  |
| END PROCESS;<br>PROCESS(y)                                                                                                                                                                                                                                                                              |
| BEGIN                                                                                                                                                                                                                                                                                                   |
| CASE y IS<br>WHEN SO=>                                                                                                                                                                                                                                                                                  |
| <pre>control_signal &lt;= "0000010000";Load R1 from input X1</pre>                                                                                                                                                                                                                                      |
| WHEN S1=><br>control_signal <= "0000000010"; Acc = Acc + R1                                                                                                                                                                                                                                             |
| WHEN S2=><br>control_signal <= "0000010000";Load R1 from input X2, set input to X2                                                                                                                                                                                                                      |
| WHEN \$3=><br>control_signal <= "0000000010"; Acc = Acc + R1                                                                                                                                                                                                                                            |
| WHEN S4=><br>control_signal <= "0000010000";Load R1 from input X3                                                                                                                                                                                                                                       |
| WHEN S5=><br>control_signal <= "0000000010"; Acc = Acc + R1                                                                                                                                                                                                                                             |
| WHEN S6=><br>control_signal <= "0000010000";Load R1 from input X4                                                                                                                                                                                                                                       |
| WHEN S7=><br>control_signal <= "0000000010"; Acc = Acc + R1                                                                                                                                                                                                                                             |
| <pre>WHEN S8=&gt; control_signal &lt;= "0100000000";SRA WHEN S9=&gt;</pre>                                                                                                                                                                                                                              |
| control_signal <= "0100000000";SRA                                                                                                                                                                                                                                                                      |
| WHEN S10=> Connect output of ACC to 7 segment display<br>control_signal <= "1000000000";                                                                                                                                                                                                                |
| END CASE;<br>END PROCESS;                                                                                                                                                                                                                                                                               |
| <pre>z &lt;= control_signal(3 DONNTO 0);<br/>LD_R1 &lt;= control_signal(4);<br/>LD_RC &lt;= control_signal(5);<br/>Dec_RC &lt;= control_signal(7);<br/>SHL_Acc &lt;= control_signal(7);<br/>SHL_Acc &lt;= control_signal(8);<br/>ACC output_bus_select &lt;= control_signal(9);<br/>END Behavior;</pre> |

## **Displaying Output**

The final result of the task which corresponds to the content of ACC during final state of task sequence should be clearly displayed in the simulation waveforms. Please refer to the final schematic on the following page.



Logic Operations: -

- 1-Enter X1, X2, X3, X4 from switches then perform the following: -Result= (X1 AND X2) OR X3; Sum of products function
- 2-Enter X1, X2, X3, X4 from switches then perform the following: -Result= (X1 OR X2) AND X3; Product of sums function
- 3-Enter X, Y from switches then perform the following: -Result= (X XNOR Y); A comparator if(X=Y) Result=1;

Arithmetic Operations: -

1-Enter X1, X2, X3, X4 from switches then perform the following: -Result= 2\*(X1+X2+X3+X4); ADD then SHL

2-Enter X1, X2, Y1, Y2 from switches then perform the following: -Result= (X1-Y1) + (X2-Y2); Difference between two sets of numbers

- 3-Enter X1, X2, X3, X4 from switches then perform the following: -
- Result= (X1+1) + (X2+1) + (X3+1) + (X4+1); Inc each number and find total
- 4-Enter X1, Y1, X2, Y2 from switches then perform the following: -Result= 2\*(X1-Y1) +2\*(X2-Y2); Calculate double the difference between two sets