

# **Lab Project: Arithmetic Logic Unit**

**MdShahid Bin Emdad**

**April 10th, 2022**

**CSC 34200/34300**

## Table of Contents

|                                                                |           |
|----------------------------------------------------------------|-----------|
| <b>Objective:</b> .....                                        | <b>3</b>  |
| <b>Description of Specifications, and Functionality:</b> ..... | <b>3</b>  |
| 3 32-bit registers: .....                                      | 3         |
| i. 32-bit Register RD:.....                                    | 4         |
| ii. 32-bit Register RS:.....                                   | 5         |
| iii. 32-bit Register RT: .....                                 | 6         |
| 16-bit immediate register: .....                               | 7         |
| 2:1 32-bit multiplexer: .....                                  | 8         |
| N-bit add/sub with flags:.....                                 | 9         |
| 1:2 32-bit demultiplexer: .....                                | 10        |
| Bitwise Operations:.....                                       | 11        |
| Sign Extender:.....                                            | 12        |
| 32-bit MAR:.....                                               | 13        |
| 32-bit MDR:.....                                               | 14        |
| Arithmetic Logic Unit (ALU):.....                              | 15        |
| <b>Simulation:</b> .....                                       | <b>18</b> |
| Add:.....                                                      | 18        |
| ADDU:.....                                                     | 19        |
| SUB:.....                                                      | 19        |
| SUBU:.....                                                     | 20        |
| AND:.....                                                      | 20        |
| NOR: .....                                                     | 21        |
| OR: .....                                                      | 21        |
| SLL: .....                                                     | 22        |
| SRL: .....                                                     | 22        |
| SRA:.....                                                      | 23        |
| I-type Instructions: .....                                     | 23        |

|                                        |                |           |
|----------------------------------------|----------------|-----------|
| i.                                     | ADDI:          | 23        |
| ii.                                    | ADDIU:         | 24        |
| iii.                                   | ANDI:          | 24        |
| iv.                                    | ORI:           | 25        |
| Memory Access Instructions Operations: |                | 25        |
| i.                                     | LW Load Word:  | 25        |
| ii.                                    | SW Store Word: | 26        |
| <b>Conclusion:</b>                     |                | <b>26</b> |

I will neither give nor receive unauthorized assistance on this lab. I will use only one computing device to perform this lab.

A handwritten signature in black ink, appearing to read "Shahid". It is written in a cursive style with a large, sweeping flourish underneath the main name.

## **Objective:**

The objective of this assignment is to learn and understand Arithmetic Logic Unit. We were instructed to implement MIPS arithmetic logic units' instructions by creating and using 3 different 32-bit registers (RD, RS, RT), 16-bit immediate, 32-bit MAR (memory address register), 32-bit MDR (memory data register) and design ALUE with add/sub and bitwise operations. Overall, this lab is to learn how data is written and read from RAM but more complex way.

## **Description of Specifications, and Functionality:**

The digital system I used in this assignment is Quartus Prime 20.1.1 and ModelSimSetup-20.1.1. There two packages needed are cyclonev and cyclonevi (both versions are 20.1.1). In the VHDL editor, I wrote my VHDL code to get the circuit output and then used Modelsim to simulate and run my circuit over time (ps unit).

### **3 32-bit registers:**

In figure 1, we can see the file directory for the ALU project.



Figure 1: ALU project directory

In figure 2, we can see the project summary for the ALU project.



Figure 2: Project summary for ALU

### i. 32-bit Register RD:

In figure 3, we can see the VHDL code for 32-bit register RD. It will store data and perform functions to read and write data on a rising clock edge.

The screenshot shows the Quartus Prime Lite Edition interface with the VHDL code for the 32-bit Register RD. The code is as follows:

```

library IEEE;
use IEEE.std_logic_1164.all;

entity emdad_April10_2022_RD is
generic (emdad_April10_2022_datawidth: integer := 32);
port (
    emdad_April10_2022_clock, emdad_April10_2022_write, emdad_April10_2022_read, emdad_April10_2022_enable: in std_logic;
    emdad_April10_2022_content: in std_logic_vector(emdad_April10_2022_datawidth-1 downto 0);
    emdad_April10_2022_result: out std_logic_vector(emdad_April10_2022_datawidth-1 downto 0));
end emdad_April10_2022_RD;

architecture arch of emdad_April10_2022_RD is
begin
    P1: process(emdad_April10_2022_clock, emdad_April10_2022_write)
    begin
        if(rising_edge(emdad_April10_2022_clock) and emdad_April10_2022_write = '1')
        then emdad_April10_2022_memory <= emdad_April10_2022_content;
        end if;
    end process P1;

    P2: process(emdad_April10_2022_read, emdad_April10_2022_enable, emdad_April10_2022_memory)
    begin
        if(emdad_April10_2022_read = '1' and emdad_April10_2022_enable = '1')
        then emdad_April10_2022_result <= emdad_April10_2022_memory;
        elsif(emdad_April10_2022_enable = '0')
        then emdad_April10_2022_result <= (others => '0');
        end if;
    end process P2;
end arch;

```

On the left, there is a 'Tasks' panel showing the compilation process:

| Task                                   | Time     |
|----------------------------------------|----------|
| Compile Design                         | 00:01:09 |
| Analysis & Synthesis                   | 00:00:10 |
| Fitter (Place & Route)                 | 00:00:58 |
| Assembler (Generate programming files) | 00:00:01 |
| Timing Analysis                        | 00:00:00 |
| EDA Netlist Writer                     |          |
| Edit Settings                          |          |
| Program Device (Open Programmer)       |          |

Figure 3: VHDL code for 32-bit RD

In figure 4, we can see it compiled successfully.



Figure 4: Compilation Report

## ii. 32-bit Register RS:

In figure 5, we can see the VHDL code for 32-bit register RS. It will store data and perform functions to read and write data on a rising clock edge.

```

library IEEE;
use IEEE.std_logic_1164.all;

entity emdad_April10th_2022_RS is
    generic (emdad_April10th_2022_datawidth: integer := 32);
    port (
        emdad_April10th_2022_clock, emdad_April10th_2022_write, emdad_April10th_2022_read, emdad_April10th_2022_enable: in std_logic;
        emdad_April10th_2022_content: in std_logic_vector(emdad_April10th_2022_datawidth-1 downto 0);
        emdad_April10th_2022_result: out std_logic_vector(emdad_April10th_2022_datawidth-1 downto 0));
end emdad_April10th_2022_RS;

architecture arch of emdad_April10th_2022_RS is
begin
    emdad_April10th_2022_memory: std_logic_vector(emdad_April10th_2022_datawidth-1 downto 0);
    begin
        P1: process(emdad_April10th_2022_clock, emdad_April10th_2022_write)
        begin
            if(rising_edge(emdad_April10th_2022_clock) and emdad_April10th_2022_write = '1')
            then emdad_April10th_2022_memory <= emdad_April10th_2022_content;
            end if;
        end process P1;
        P2: process(emdad_April10th_2022_read, emdad_April10th_2022_enable, emdad_April10th_2022_memory)
        begin
            if(emdad_April10th_2022_read = '1' and emdad_April10th_2022_enable = '1')
            then emdad_April10th_2022_result <= emdad_April10th_2022_memory;
            elsif(emdad_April10th_2022_enable = '0')
            then emdad_April10th_2022_result <= (others => '0');
            end if;
        end process P2;
    end arch;

```

Figure 5: VHDL code for 32-bit RS

In figure 6, we can see it compiled successfully.



Figure 6: Compilation Report

### iii. 32-bit Register RT:

In figure 7, we can see the VHDL code for 32-bit register RT. It will store data and perform functions to read and write data on a rising clock edge.



Figure 7: VHDL code for 32-bit RT

In figure 8, we can see it compiled successfully.



Figure 8: Compilation Report

## 16-bit immediate register:

In figure 9, we can see code for 16-bit immediate register. It stores data and perform functions to read and write data on a rising clock edge.

```

library IEEE;
use IEEE.std_logic_1164.all;

entity emdad_April10th_2022_IMM16 is
generic (emdad_April10th_2022_Imm_size: integer := 16);
port
    emdad_April10th_2022_clock, emdad_April10th_2022_write, emdad_April10th_2022_read, emdad_April10th_2022_enable: in std_logic;
    emdad_April10th_2022_In: in std_logic_vector(emdad_April10th_2022_Imm_size-1 downto 0);
    emdad_April10th_2022_out: out std_logic_vector(emdad_April10th_2022_Imm_size-1 downto 0);
end emdad_April10th_2022_IMM16;

architecture arch of emdad_April10th_2022_IMM16 is
begin
    signal emdad_April10th_2022_memory: std_logic_vector(emdad_April10th_2022_Imm_size-1 downto 0);
    begin
        P1: process(emdad_April10th_2022_clock, emdad_April10th_2022_write)
        begin
            if(rising_edge(emdad_April10th_2022_clock) and emdad_April10th_2022_write = '1')
            then emdad_April10th_2022_memory <= emdad_April10th_2022_In;
            end if;
        end process P1;
        P2: process(emdad_April10th_2022_read, emdad_April10th_2022_enable, emdad_April10th_2022_memory)
        begin
            if(emdad_April10th_2022_read = '1' and emdad_April10th_2022_enable = '1')
            then emdad_April10th_2022_out <= emdad_April10th_2022_memory;
            elsif(emdad_April10th_2022_enable = '0')
            then emdad_April10th_2022_out <= (others => '0');
            end if;
        end process P2;
    end arch;

```

Figure 9: VHDL code 16-bit immediate register

In figure 10, we can see it compiled successfully.



Figure 10: Compilation Report

## 2:1 32-bit multiplexer:

In figure 11, we can see code for 2:1 32-bit multiplexer. It chooses one of the inputs.

```

library IEEE;
use IEEE.std_logic_1164.all;

entity emdad_April10th_2022_2to1mux_32 is
  generic (emdad_April10th_2022_k : integer := 32);
  port (emdad_April10th_2022_I0, emdad_April10th_2022_I1: in std_logic_vector(emdad_April10th_2022_k-1 downto 0);
        emdad_April10th_2022_SEL: in std_logic;
        emdad_April10th_2022_Q: out std_logic_vector(emdad_April10th_2022_k-1 downto 0));
end emdad_April10th_2022_2to1mux_32;

architecture arch of emdad_April10th_2022_2to1mux_32 is
begin
  process(emdad_April10th_2022_I0, emdad_April10th_2022_I1, emdad_April10th_2022_SEL)
  begin
    if emdad_April10th_2022_SEL = '0'
    then
      emdad_April10th_2022_Q <= emdad_April10th_2022_I0;
    else
      emdad_April10th_2022_Q <= emdad_April10th_2022_I1;
    end if;
  end process;
end arch;

```

Figure 11: VHDL code for 2:1 32-bit multiplexer

In figure 12, we can see it compiled successfully.



Figure 12: Compilation Report

## N-bit add/sub with flags:

In figure 13, we can see the VHDL code 32-bit add/sub with flags. It is to take care of the arithmetic of MIPS instructions.

```

File Edit View Project Processing Tools Window Help
1 library IEEE;
2 use IEEE.STD_LOGIC_1164.ALL;
3 use IEEE.STD.TEXT_UNSIGNED;
4 use IEEE.NUMERIC_STD.ALL;
5
6 entity emdad_April10th_2022_NBit_AddSub is
7 generic(n: integer := 32);
8 port(emdad_April10th_2022_a, emdad_April10th_2022_b: in std_logic_vector(n-1 downto 0);
9 emdad_April10th_2022_cout: out std_logic_vector(n-1 downto 0);
10 emdad_April10th_2022_z: out std_logic;
11 emdad_April10th_2022_op: in std_logic;
12 emdad_April10th_2022_out, emdad_April10th_2022_o, emdad_April10th_2022_N, emdad_April10th_2022_Z: out std_logic);
13 end emdad_April10th_2022_NBit_AddSub;
14
15 architecture nbitaddsub_behav of emdad_April10th_2022_NBit_AddSub is
16 signal result: std_logic_vector(n-1 downto 0);
17 begin
18 result <= (emdad_April10th_2022_a + emdad_April10th_2022_b) WHEN (emdad_April10th_2022_op = '0') ELSE (emdad_April10th_2022_a - emdad_April10th_2022_b);
19 emdad_April10th_2022_cout <= '1';
20 WHEN (emdad_April10th_2022_op = '1' AND emdad_April10th_2022_a(n-1) = emdad_April10th_2022_b(n-1) AND result(n-1) /= emdad_April10th_2022_a(n-1)) OR
21 (emdad_April10th_2022_op = '1' AND emdad_April10th_2022_a(n-1) /= emdad_April10th_2022_b(n-1) AND result(n-1) /= emdad_April10th_2022_a(n-1)) ELSE '0';
22 emdad_April10th_2022_o <= '1';
23 WHEN (emdad_April10th_2022_op = '0' AND emdad_April10th_2022_a(n-1) = emdad_April10th_2022_b(n-1) AND result(n-1) /= emdad_April10th_2022_a(n-1)) OR
24 (emdad_April10th_2022_op = '0' AND emdad_April10th_2022_a(n-1) /= emdad_April10th_2022_b(n-1) AND result(n-1) /= emdad_April10th_2022_a(n-1)) ELSE '0';
25 emdad_April10th_2022_sum <= result;
26 emdad_April10th_2022_N <= result(n-1);
27
28 process(result)
29 begin
30 if unsigned(result) = "0" then
31 emdad_April10th_2022_Z <= '1';
32 else
33 emdad_April10th_2022_Z <= '0';
34 end if;
35 end process;
36 end nbitaddsub_behav;

```

Figure 13: VHDL code 32-bit add/sub with flags

In figure 14, we can see it compiled successfully.



Figure 14: Compilation Report

### 1:2 32-bit demultiplexer:

In figure 15, we see the code for 1:2 32-bit demultiplexer. it converts the output based on input.



Figure 15: VHDL code for 1:2 32-bit demultiplexer

In figure 16, we can see it compiled successfully.



Figure 16: Compilation Report

## Bitwise Operations:

In figure 17, we can see the code for the bitwise operation which handles the bitwise for MIPS.

```

1 Library IEEE;
2 use IEEE.std_logic_1164.all;
3 use IEEE.std_logic_signed.all;
4 use IEEE.numeric_std.all;
5
6 entity emdad_April10th_2022_bitwise_op is
7 generic(N: integer := 32);
8 port(
9     emdad_April10th_2022_I0, emdad_April10th_2022_I1, emdad_April10th_2022_ext: in std_logic_vector (N-1 downto 0); --32 bit register inputs
10    emdad_April10th_2022_Imm: in std_logic_vector (15 downto 0); --16 bit immediate
11    emdad_April10th_2022_op: in std_logic_vector(3 downto 0); --Operation Code
12    emdad_April10th_2022_Q: out std_logic_vector (N-1 downto 0); --32 bit register output
13    emdad_April10th_2022_Z: out std_logic := '0'; --Zero flag
14    emdad_April10th_2022_N: out std_logic := '0'; --Negative flag
15    emdad_April10th_2022_O: out std_logic := '0'; --Overflow Flag
16) end emdad_April10th_2022_bitwise_op;
17
18 architecture arch of emdad_April10th_2022_bitwise_op is
19 signal result: std_logic_vector (N-1 downto 0);
20 begin
21 begin
22 P1: process(emdad_April10th_2022_I0, emdad_April10th_2022_I1, emdad_April10th_2022_op, result)
23 begin
24 case emdad_April10th_2022_op is
25 when "0010"=> result <= emdad_April10th_2022_I0 AND emdad_April10th_2022_I1; -- and
26 when "0111"=> result <= emdad_April10th_2022_I0 NOR emdad_April10th_2022_I1; -- nor
27 when "1000"=> result <= emdad_April10th_2022_I0 OR emdad_April10th_2022_I1; -- or
28 when "1010"=> result <= emdad_April10th_2022_I0 OR emdad_April10th_2022_ext; --ori
29 when "1011"=> result <= std_logic_vector(shift_left(unsigned(emdad_April10th_2022_I1), to_integer(unsigned(emdad_April10th_2022_Imm)))); -- sll
30 when "1100"=> result <= std_logic_vector(shift_right(unsigned(emdad_April10th_2022_I1), to_integer(unsigned(emdad_April10th_2022_Imm)))); -- sr
31 when others=> result <= x"00000000";
32 end case;
33 emdad_April10th_2022_Q <= result;
34 end process;
35 end arch;

```

Figure 17: VHDL code for Bitwise Operations

In figure 18, we can see it compiled successfully.



Figure 18: Compilation Report

### Sign Extender:

In figure19, we can see the code for sign extender, to perform operation with 32-bit registers.

```

library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.numeric_std.all;

entity emdad_April10th_2022_Sign_Extend is
    port( emdad_April10th_2022_I: in std_logic_vector(15 downto 0);
          emdad_April10th_2022_Q: out std_logic_vector(31 downto 0));
end emdad_April10th_2022_Sign_Extend;

architecture arch of emdad_April10th_2022_Sign_Extend is
begin
    emdad_April10th_2022_Q <= std_logic_vector(resize(signed(emdad_April10th_2022_I), extended'length));
end arch;

```

Figure 19: VHDL code for Sign Extender

In figure 20, we can see it compiled successfully.

The screenshot shows the Quartus Prime Lite Edition interface with the following details:

- File Menu:** File, Edit, View, Project, Assignments, Processing, Tools, Window, Help.
- Project Navigator:** Shows files: emdad\_April10th\_2022\_RD.vhd, emdad\_April10th\_2022\_RS.vhd, emdad\_April10th\_2022\_RT.vhd, emdad\_April10th\_2022\_IMM16.vhd, emdad\_April10th\_2022\_2to1mux\_32.vhd, emdad\_April10th\_2022\_NBIt\_AddSub.vhd, emdad\_April10th\_2022\_1to2demux\_32.vhd, emdad\_April10th\_2022\_bitwise\_op.vhd, emdad\_April10th\_2022\_Sign\_Extend.vhd.
- Tasks:**

| Task                              | Time     |
|-----------------------------------|----------|
| Compile Design                    | 00:01:15 |
| > Analysis & Synthesis            | 00:00:11 |
| > Fitter (Place & Route)          | 00:00:50 |
| > Assembler (Generate programm... | 00:00:08 |
| > Timing Analysis                 | 00:00:06 |
| > EDA Netlist Writer              |          |
- Code Editor:** Displays VHDL code for emdad\_April10th\_2022\_Sign\_Extend.vhd.
- Compilation Report:**
  - 267 warnings
  - 268 errors
  - 15 lines of code

```

1 Library IEEE;
2 use IEEE.std_logic_1164.all;
3 use IEEE.numeric_std.all;
4
5 Entity emdad_April10th_2022_Sign_Extend is
6   port( emdad_April10th_2022_I: in std_logic_vector(15 downto 0);
7        emdad_April10th_2022_Q: out std_logic_vector(31 downto 0));
8 end emdad_April10th_2022_Sign_Extend;
9
10 Architecture arch of emdad_April10th_2022_Sign_Extend is
11   signal extended: std_logic_vector(31 downto 0);
12
13   begin
14     emdad_April10th_2022_Q <= std_logic_vector(resize(signed(emdad_April10th_2022_I), extended'length));
15   end arch;

```
- Messages:**
  - Type ID Message
  - 332146 Worst-case setup slack is -2.274
  - 332146 Worst-case hold slack is 0.264
  - 332140 No Recovery paths to report
  - 332140 No Removal paths to report
  - 332146 Design use minimum pulse width slack is -0.083
  - 332102 Design is not fully constrained for setup requirements
  - 332102 Design is not fully constrained for hold requirements
  - Quartus Prime Timing Analyzer was successful. 0 errors, 7 warnings
  - 293000 Quartus Prime Full Compilation was successful. 0 errors, 80 warnings

Figure 20: Compilation Report

## 32-bit MAR:

In figure 21, we can see the VHDL code 32-bit MAR to store and read and write data.

The screenshot shows the Quartus Prime Lite Edition interface with the following details:

- File Menu:** File, Edit, View, Project, Assignments, Processing, Tools, Window, Help.
- Project Navigator:** Shows files: emdad\_April10th\_2022\_RD.vhd, emdad\_April10th\_2022\_RS.vhd, emdad\_April10th\_2022\_RT.vhd, emdad\_April10th\_2022\_IMM16.vhd, emdad\_April10th\_2022\_2to1mux\_32.vhd, emdad\_April10th\_2022\_NBIt\_AddSub.vhd, emdad\_April10th\_2022\_1to2demux\_32.vhd, emdad\_April10th\_2022\_bitwise\_op.vhd, emdad\_April10th\_2022\_Sign\_Extend.vhd, emdad\_April10th\_2022\_MAR.vhd.
- Tasks:**

| Task                                 | Time     |
|--------------------------------------|----------|
| 8% ▶ Compile Design                  | 00:00:16 |
| > Analysis & Synthesis               | 00:00:10 |
| > Fitter (Place & Route)             | 00:00:06 |
| 0% ▶ Assembler (Generate programm... | 00:00:00 |
| > Timing Analysis                    | 00:00:00 |
| > EDA Netlist Writer                 |          |
| Edit Settings                        |          |
| Program Device (Open Programmer)     |          |
- Code Editor:** Displays VHDL code for emdad\_April10th\_2022\_MAR.vhd.
- Compilation Report:**
  - 267 warnings
  - 268 errors
  - 35 lines of 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 emdad_April10th_2022_MAR is
7   generic (emdad_April10th_2022_datawidth: integer := 32);
8   port(
9     emdad_April10th_2022_clock, emdad_April10th_2022_write, emdad_April10th_2022_read, emdad_April10th_2022_enable: in std_logic;
10    emdad_April10th_2022_content: in std_logic_vector(emdad_April10th_2022_datawidth-1 downto 0);
11    emdad_April10th_2022_ext: in std_logic_vector(emdad_April10th_2022_datawidth-1 downto 0);
12    emdad_April10th_2022_result: out std_logic_vector(emdad_April10th_2022_datawidth-1 downto 0));
13 end emdad_April10th_2022_MAR;
14
15 Architecture arch of emdad_April10th_2022_MAR is
16   signal emdad_April10th_2022_memory: std_logic_vector(emdad_April10th_2022_datawidth-1 downto 0);
17
18   begin
19     P1: process(emdad_April10th_2022_clock, emdad_April10th_2022_write)
20     begin
21       if(rising_edge(emdad_April10th_2022_clock) and emdad_April10th_2022_write = '1')
22         then emdad_April10th_2022_memory <= emdad_April10th_2022_content + emdad_April10th_2022_ext;
23       end if;
24     end process P1;
25
26     P2: process(emdad_April10th_2022_read, emdad_April10th_2022_enable, emdad_April10th_2022_memory)
27     begin
28       if(emdad_April10th_2022_read = '1' and emdad_April10th_2022_enable = '1')
29         then emdad_April10th_2022_result <= emdad_April10th_2022_memory;
30       elsif(emdad_April10th_2022_enable = '0')
31         then emdad_April10th_2022_result <= (others => '0');
32       end if;
33     end process P2;
34   end arch;
35

```
- Messages:**
  - Type ID Message
  - 10041 Inferred latch for "emdad\_April10\_2022\_result[16]" at emdad\_April10\_2022\_RD.vhd(24)
  - 10041 Inferred latch for "emdad\_April10\_2022\_result[17]" at emdad\_April10\_2022\_RD.vhd(24)
  - 10041 Inferred latch for "emdad\_April10\_2022\_result[18]" at emdad\_April10\_2022\_RD.vhd(24)
  - 10041 Inferred latch for "emdad\_April10\_2022\_result[19]" at emdad\_April10\_2022\_RD.vhd(24)

Figure 21: VHDL code 32-bit MAR

In figure 22, we can see it compiled successfully.



Figure 22: Compilation Report

## 32-bit MDR:

In figure 23, we can see the VHDL code for 32-bit MDR to store data, read and write.

```

use IEEE.STD_LOGIC_UNSIGNED.ALL;
use IEEE.numeric_std.ALL;

entity emdad_April10th_2022_MDR is
    generic(cemdad_April10th_2022_datawidth: integer := 32);
    port (
        emdad_April10th_2022_clock, emdad_April10th_2022_write, emdad_April10th_2022_read, emdad_April10th_2022_enable: in std_logic;
        emdad_April10th_2022_content: in std_logic_vector(cemdad_April10th_2022_datawidth-1 downto 0);
        emdad_April10th_2022_result: out std_logic_vector(cemdad_April10th_2022_datawidth-1 downto 0));
end entity emdad_April10th_2022_MDR;

architecture arch of emdad_April10th_2022_MDR is
    signal emdad_April10th_2022_memory: std_logic_vector(cemdad_April10th_2022_datawidth-1 downto 0);
begin
    P1: process(emdad_April10th_2022_clock, emdad_April10th_2022_write)
    begin
        if(rising_edge(emdad_April10th_2022_clock) and emdad_April10th_2022_write = '1')
        then emdad_April10th_2022_memory <= emdad_April10th_2022_content;
        end if;
    end process P1;
    P2: process(emdad_April10th_2022_read, emdad_April10th_2022_enable, emdad_April10th_2022_memory)
    begin
        if(emdad_April10th_2022_read = '1' and emdad_April10th_2022_enable = '1')
        then emdad_April10th_2022_result <= emdad_April10th_2022_memory;
        elsif(emdad_April10th_2022_enable = '0')
        then emdad_April10th_2022_result <= (others => '0');
        end if;
    end process P2;
end arch;

```

The screenshot shows the Quartus Prime Lite Edition interface with the following details:

- Project Navigator:** Shows files like emdad\_April10\_2022\_RD.vhd, emdad\_April10th\_2022\_RS.vhd, etc.
- Tasks:** A table showing the status of various compilation steps: Compile Design (00:00:14), Analysis & Synthesis (00:00:10), Fitter (Place & Route) (00:00:04), Assembler (Generate program...) (00:00:00), Timing Analysis (00:00:00), and EDA Netlist Writer.
- Code Editor:** Displays the VHDL code for the emdad\_April10th\_2022\_MDR entity, defining its generic, ports, and architecture.

Figure 23: VHDL code for 32-bit MDR

In figure 24, we can see it compiled successfully.



Figure 24: Compilation Report

### Arithmetic Logic Unit (ALU):

In figure 25, we can see the VHDL code for the ALU. The inputs are 32-bit registers (RS, RT) to compute operations, 16-bit immediate to compute immediate operations, 32-bit MDR, clock and operation. The outputs are 32-bit register RD and 3 flags: zero, negative, overflow. I also used the other codes as a component to get the waveform.

```

1 Library IEEE;
2 use IEEE.std_logic_1164.all;
3 use IEEE.std_logic_signed.all;
4 use IEEE.numeric_std.all;
5
6 entity emdad_April10th_2022_ALU is
7   generic(N: integer := 32);
8   port(
9     emdad_April10th_2022_clk: in std_logic;
10    emdad_April10th_2022_RS_i, emdad_April10th_2022_RT_i, emdad_April10th_2022_MDR_i: in std_logic_vector (N-1 downto 0);
11    emdad_April10th_2022_Imm: in std_logic_vector (15 downto 0);
12    emdad_April10th_2022_op: in std_logic_vector (3 downto 0);
13    emdad_April10th_2022_RD_i: out std_logic_vector (N-1 downto 0);
14    emdad_April10th_2022_RD_out: out std_logic_vector (N-1 downto 0);
15    emdad_April10th_2022_Z: out std_logic := '0';
16    emdad_April10th_2022_N: out std_logic := '0';
17    emdad_April10th_2022_O: out std_logic := '0');
18 end emdad_April10th_2022_ALU;
19
20 architecture arch of emdad_April10th_2022_ALU is
21   signal cout, z_temp0, n_temp0, o_temp0, z_temp1, n_temp1, o_temp1, z_temp2, n_temp2, o_temp2, z_temp3, n_temp3, o_temp3,
22   z_temp4, n_temp4, o_temp4, z_temp5, n_temp5, o_temp5, z_temp6, n_temp6, o_temp6, mar_wren, mdr_wren: std_logic := '0';
23   signal temp0, temp1, temp2, temp3, temp4, temp5: std_logic_vector (N-1 downto 0);
24   signal RS_o, RT_o, RD_out, RD_i, ext_o, MAR_o, MDR_o: std_logic_vector (N-1 downto 0);
25   signal Imm_o: std_logic_vector (15 downto 0);
26
27   component emdad_April10th_2022_RD is
28     generic (emdad_April10th_2022_datewidth: integer := 32);
29     port (
30       emdad_April10th_2022_clock, emdad_April10th_2022_write, emdad_April10th_2022_read, emdad_April10th_2022_enable: in std_logic;
31       emdad_April10th_2022_content: in std_logic_vector(emdad_April10th_2022_datewidth-1 downto 0);
32       emdad_April10th_2022_result: out std_logic_vector(emdad_April10th_2022_datewidth-1 downto 0));
33   end component;
34
35   component emdad_April10th_2022_RT is
36     generic (emdad_April10th_2022_datewidth: integer := 32);
37     port (
38       emdad_April10th_2022_clock, emdad_April10th_2022_write, emdad_April10th_2022_read, emdad_April10th_2022_enable: in std_logic;
39       emdad_April10th_2022_content: in std_logic_vector(emdad_April10th_2022_datewidth-1 downto 0);
40       emdad_April10th_2022_result: out std_logic_vector(emdad_April10th_2022_datewidth-1 downto 0));
41   end component;
42
43   component emdad_April10th_2022_RS is
44     generic (emdad_April10th_2022_datewidth: integer := 32);
45     port (
46       emdad_April10th_2022_clock, emdad_April10th_2022_write, emdad_April10th_2022_read, emdad_April10th_2022_enable: in std_logic;
47       emdad_April10th_2022_content: in std_logic_vector(emdad_April10th_2022_datewidth-1 downto 0);
48       emdad_April10th_2022_result: out std_logic_vector(emdad_April10th_2022_datewidth-1 downto 0));
49   end component;

```

Figure 25: VHDL code for the ALU (Part 1)

```

50
51 component emdad_April10th_2022_IMM16 is
52   generic Cemdad_April10th_2022_Imm_size: integer := 16;
53   port (
54     emdad_April10th_2022_clock, emdad_April10th_2022_write, emdad_April10th_2022_read, emdad_April10th_2022_enable: in std_logic;
55     emdad_April10th_2022_in: in std_logic_vector(emdad_April10th_2022_Imm_size-1 downto 0);
56     emdad_April10th_2022_out: out std_logic_vector(emdad_April10th_2022_Imm_size-1 downto 0));
57 end component;
58
59 component emdad_April10th_2022_Sign_Extend is
60   port( emdad_April10th_2022_I: in std_logic_vector(15 downto 0);
61         emdad_April10th_2022_Q: out std_logic_vector(31 downto 0));
62 end component;
63
64 component emdad_April10th_2022_MAR is
65   generic Cemdad_April10th_2022_datawidth: integer := 32;
66   port (
67     emdad_April10th_2022_clock, emdad_April10th_2022_write, emdad_April10th_2022_read, emdad_April10th_2022_enable: in std_logic;
68     emdad_April10th_2022_content: in std_logic_vector(emdad_April10th_2022_datawidth-1 downto 0);
69     emdad_April10th_2022_ext: in std_logic_vector(emdad_April10th_2022_datawidth-1 downto 0);
70     emdad_April10th_2022_result: out std_logic_vector(emdad_April10th_2022_datawidth-1 downto 0));
71 end component;
72
73 component emdad_April10th_2022_MDR is
74   generic Cemdad_April10th_2022_datawidth: integer := 32;
75   port (
76     emdad_April10th_2022_clock, emdad_April10th_2022_write, emdad_April10th_2022_read, emdad_April10th_2022_enable: in std_logic;
77     emdad_April10th_2022_content: in std_logic_vector(emdad_April10th_2022_datawidth-1 downto 0);
78     emdad_April10th_2022_result: out std_logic_vector(emdad_April10th_2022_datawidth-1 downto 0));
79 end component;
80
81 component emdad_April10th_2022_NBit_AddSub is
82   generic(n: integer := 32);
83   port(emdad_April10th_2022_RS: in std_logic_vector(n-1 downto 0);
84         emdad_April10th_2022_Sign_Extend: in std_logic_vector(n-1 downto 0);
85         emdad_April10th_2022_cin: in std_logic;
86         emdad_April10th_2022_OP: in std_logic;
87         emdad_April10th_2022_out, emdad_April10th_2022_O, emdad_April10th_2022_N, emdad_April10th_2022_Z: out std_logic);
88 end component;
89
90 component emdad_April10th_2022_bitwise_op is
91   generic(N: integer := 32);
92   port(
93     emdad_April10th_2022_I0, emdad_April10th_2022_I1, emdad_April10th_2022_ext: in std_logic_vector(N-1 downto 0);
94     emdad_April10th_2022_In: in std_logic_vector(31 downto 0);
95     emdad_April10th_2022_Op: out std_logic_vector(N-1 downto 0);
96     emdad_April10th_2022_Z: out std_logic := '0';
97     emdad_April10th_2022_N: out std_logic := '0';
98     emdad_April10th_2022_O: out std_logic := '0');
99 end component;
100

```

Figure 26: VHDL code for the ALU (Part 2)

```

101 begin
102
103
104   RD: emdad_April10th_2022_RD generic map (emdad_April10th_2022_datawidth => 32)
105   port map (emdad_April10th_2022_clk, '1', '1', '1', RD_i, emdad_April10th_2022_RD_i);
106   RS: emdad_April10th_2022_RS generic map (emdad_April10th_2022_datawidth => 32)
107   port map (emdad_April10th_2022_RS, '1', '1', '1', '1', emdad_April10th_2022_RS_i, RS_o);
108   RT: emdad_April10th_2022_RT generic map (emdad_April10th_2022_datawidth => 32)
109   port map (emdad_April10th_2022_clk, '1', '1', '1', '1', emdad_April10th_2022_RT_i, RT_o);
110   IMM: emdad_April10th_2022_IMM16 generic map (emdad_April10th_2022_Imm_size => 16)
111   port map (emdad_April10th_2022_clk, '1', '1', '1', '1', emdad_April10th_2022_Imm, imm_o);
112   EXT: emdad_April10th_2022_Sign_Extend generic map (emdad_April10th_2022_Imm, ext_o);
113   MAR: emdad_April10th_2022_MAR generic map (emdad_April10th_2022_datawidth => 32)
114   port map (emdad_April10th_2022_clk, '1', '1', '1', '1', RS_o, ext_o, MAR_o);
115   MDR: emdad_April10th_2022_MDR generic map (emdad_April10th_2022_datawidth => 32)
116   port map (emdad_April10th_2022_clk, '1', '1', '1', emdad_April10th_2022_MDR_i, MDR_o);
117
118   add: emdad_April10th_2022_NBit_AddSub generic map (n => 32) port map (RS_o, RT_o, temp0, '0', '0', cout, o_temp0, n_temp0, z_temp0);
119   addi: emdad_April10th_2022_NBit_AddSub generic map (n => 32) port map (RS_o, ext_o, temp1, '0', '0', cout, o_temp1, n_temp1, z_temp1);
120   addiu: emdad_April10th_2022_NBit_AddSub generic map (n => 32) port map (RS_o, ext_o, temp2, '0', '0', cout, o_temp2, n_temp2, z_temp2);
121   addu: emdad_April10th_2022_NBit_AddSub generic map (n => 32) port map (RS_o, RT_o, temp3, '0', '0', cout, o_temp3, n_temp3, z_temp3);
122   sub: emdad_April10th_2022_NBit_AddSub generic map (n => 32) port map (RS_o, RT_o, temp4, '0', '1', cout, o_temp4, n_temp4, z_temp4);
123   subu: emdad_April10th_2022_NBit_AddSub generic map (n => 32) port map (RS_o, RT_o, temp5, '0', '1', cout, o_temp5, n_temp5, z_temp5);
124   bit_op: emdad_April10th_2022_bitwise_op generic map (N => 32) port map (RS_o, RT_o, ext_o, imm_o, emdad_April10th_2022_OP, temp6, z_temp6, n_temp6, o_temp6);
125
126
127 P1: process(temp0, temp1, temp2, temp3, temp4, temp5, temp6)
128 begin
129   case emdad_April10th_2022_Op is
130     when "0000" => emdad_April10th_2022_RD_out <= temp0; emdad_April10th_2022_O <= o_temp0;
131     when "0001" => emdad_April10th_2022_Z <= n_temp0; emdad_April10th_2022_N <= n_temp1; emdad_April10th_2022_Z <= z_temp0;
132     when "0010" => RT_out <= temp1; emdad_April10th_2022_O <= o_temp1; emdad_April10th_2022_N <= n_temp2; emdad_April10th_2022_Z <= n_temp2;
133     when "0011" => emdad_April10th_2022_Z <= z_temp2; emdad_April10th_2022_O <= '0'; emdad_April10th_2022_N <= n_temp2;
134     when "0100" => emdad_April10th_2022_Z <= z_temp3; emdad_April10th_2022_O <= '0'; emdad_April10th_2022_N <= n_temp3;
135     when "0101" => emdad_April10th_2022_Z <= z_temp3; emdad_April10th_2022_O <= temp2; emdad_April10th_2022_N <= n_temp3;
136     when "0110" => emdad_April10th_2022_Z <= z_temp3; emdad_April10th_2022_O <= temp3; emdad_April10th_2022_N <= n_temp3;
137     when "0111" => emdad_April10th_2022_Z <= z_temp3; emdad_April10th_2022_O <= temp3; emdad_April10th_2022_N <= n_temp3;
138     when "1000" => emdad_April10th_2022_Z <= z_temp4; emdad_April10th_2022_O <= temp4; emdad_April10th_2022_N <= n_temp4;
139     when "1001" => emdad_April10th_2022_Z <= z_temp4; emdad_April10th_2022_O <= temp5; emdad_April10th_2022_N <= n_temp5;
140     when "1010" => emdad_April10th_2022_Z <= z_temp5; emdad_April10th_2022_O <= temp6; emdad_April10th_2022_N <= n_temp5;
141     when "1011" => emdad_April10th_2022_Z <= z_temp5; emdad_April10th_2022_O <= temp6; emdad_April10th_2022_N <= n_temp6;
142     when "1100" => emdad_April10th_2022_Z <= z_temp6; emdad_April10th_2022_O <= temp7; emdad_April10th_2022_N <= n_temp6;
143     when "1101" => emdad_April10th_2022_Z <= z_temp6; emdad_April10th_2022_O <= temp7; emdad_April10th_2022_N <= n_temp6;
144     when "1110" => emdad_April10th_2022_Z <= z_temp6; emdad_April10th_2022_O <= temp7; emdad_April10th_2022_N <= n_temp6;
145     when "1111" => RT_out <= MAR_o;
146     when others => emdad_April10th_2022_RD_out <= x"00000000";
147   end case;
148 end process;
149
150 end arch;

```

Figure 27: VHDL code for the ALU (Part 3)

100% 00:01:17

In figure 28, we can see it compiled successfully.



Figure 28: Compilation Report

## Simulation:

In figure 29, we can see the directory for the ALU project for ModelSim.



Figure 29: ALU project Modelsim directory

## Add:



Figure 30: MIPS Instructions ADD simulation

In figure 30, we can see the simulation for the add operation. I used the addition operation where  $R[rd] = R[rs] + R[rt]$ . I kept changing the clock signal and forced the value for RS and RT. We can see the negative flag got to 1 because we need two positive numbers.

## ADDU:



Figure 31: MIPS Instructions ADDU simulation

In figure 31, we can see the simulation for ADDU. Following the equation,  $R[rd] = R[rs] + R[rt]$ , the VHDL code computes unsigned addition. While changing the clock signal, I forced values into RS and RT. The zero flag and negative flag is 0 because the result is not 0 and positive and there is no overflow occurred as the operation was unsigned.

## SUB:



Figure 32: MIPS Instructions Sub simulation

In figure 32, we can see the simulation for SUB of MIPS instructions followed the equation,  $R[rd] = R[rs] - R[rt]$ . I forced values into RS and RT while keep changing the clock signal. The

operation code is 4 in hexadecimal (0100 in binary). The zero flag and negative flag is 0 because the result is not 0 and positive and there is no overflow occurred as the operation was unsigned.

## **SUBU:**



Figure 33: MIPS Instructions SUBU simulation

In figure 33, we can see the simulation for SUBU of MIPS instructions followed the equation,  $R[rd] = R[rs] - R[rt]$ . I forced values into RS and RT while keep changing the clock signal. The operation code is 5 in hexadecimal (0101 in binary). The zero flag is not 0 because the result is 0 and there is no overflow occurred as the operation was unsigned. But the negative flag is 1 because the result is negative (F in hexadecimal, 1111 in binary).

## **AND:**



Figure 34: MIPS Instructions AND simulation

In figure 34, we can see the simulation for AND of MIPS instructions followed the equation,  $R[rd] = R[rs] \& R[rt]$ . I forced values into RS and RT while keep changing the clock signal. As this is a logical operation, all the flags are 0.

## NOR:



Figure 35: MIPS Instructions NOR simulation

In figure 35, we can see the simulation for NOR of MIPS instructions followed the equation,  $R[rd] = \sim(R[rs] | R[rt])$ . I forced values into RS and RT while keep changing the clock signal. As this is a logical operation, all the flags are 0.

## OR:



Figure 36: MIPS Instructions OR simulation

In figure 36, we can see the simulation for OR of MIPS instructions followed the equation,  $R[rd] = R[rs] | R[rt]$ . I forced values into RS and RT while keep changing the clock signal. As this is a logical operation, all the flags are 0.

### SLL:



Figure 37: MIPS Instructions SLL simulation

In figure 37, we can see the simulation for SLL of MIPS instructions followed the equation  $R[rd] = R[rt] \ll \text{shamt}$ . I forced values into RS and RT while keep changing the clock signal. As this is a logical operation, all the flags are 0.

### SRL:



Figure 38: MIPS Instructions SRL simulation

In figure 38, we can see the simulation for SRL of MIPS instructions followed the equation  $R[rd] = R[rt] \gg \text{shamt}$ . I forced values into RS and RT while keep changing the clock signal. As this is a logical operation, all the flags are 0.

### SRA:



Figure 39: MIPS Instructions SRA simulation

In figure 38, we can see the simulation for SRA of MIPS instructions followed the equation  $R[rd] = R[rt] \gg \text{shamt}$ . I forced values into RS and RT while keep changing the clock signal. As this is a logical operation, all the flags are 0.

### I-type Instructions:

#### i. ADDI:



Figure 40: MIPS Instructions ADDI simulation

In figure 40, we can see the simulation for ADDI of MIPS instructions followed by the equation  $R[rt] = R[rs] + \text{SignExtImm}$ . The simulation shows that sign extender is working correctly as it extended 16-bit register into 32-bit. The zero flag is 0 because the result is not 0. The negative and overflow is 1 because the result is negative.

### ii. ADDIU:



Figure 41: MIPS Instructions ADDIU simulation

In figure 41, we can see the simulation for ADDIU of MIPS instructions. The simulation shows that sign extender is working correctly as it extended 16-bit register into 32-bit. The zero flag is 0 because the result is not 0. The negative is 1 because the result is negative, and the overflow flag is 0.

### iii. ANDI:



Figure 42: MIPS Instructions ANDI simulation

In figure 42, we can see the simulation for ANDI of MIPS instructions following by the equation  $R[rt] = R[rs] \& \text{ZeroExtImm}$ . The simulation shows that sign extender is working correctly as it extended 16-bit register into 32-bit. As this is a logical operation, all the flags are 0.

#### iv. ORI:



Figure 43: MIPS Instructions ORI simulation

In figure 42, we can see the simulation for ORI of MIPS instructions following by the equation  $R[rt] = R[rs] | ZeroExtImm$ . The simulation shows that sign extender is working correctly as it extended 16-bit register into 32-bit. As this is a logical operation, all the flags are 0.

#### Memory Access Instructions Operations:

##### i. LW Load Word:



Figure 44: MIPS Instructions LW Load Word Simulation

In figure 44, we can see the simulation for LW Load Word of MIPS instructions following by the equation  $R[rt] = M[R[rs]] + SignExtImm$ . While changing the clock signal, I forced values into RS, MDR and IMM.

## ii. SW Store Word:



Figure 45: MIPS Instructions SW Store Word Simulation

In figure 45, we can see the simulation for SW Store Word of MIPS instructions following by the equation  $M[R[rs] + SignExtImm] = R[rt]$ . While changing the clock signal, I forced values into RS, MDR and IMM.

## Conclusion:

In this assignment, I learned how to design and understand the specifications of VHDL extender using Quartus and Modelsim. It was a good practice on Modelsim for circuit simulation. The experiment taught me how to implement MIPS instructions in VHDL and different parts of ALU. The operations logics were helpful to learn easily. I relearned and reviewed the concept again and which will help me in the course further.