

# MIPS ISA 32 BIT PROCESSOR



PRESENTED TO DR. HOWAIDA ABDEL LATIF

# Project Title: multi cycle processor that implements MIPS ISA 32-bit processor

✓ Course: Hardware Design

✓ Instructor: [DR. Howida Abdellatif]

# √ Submitted by:

| No | Name                   | Academic number | Task completed         |
|----|------------------------|-----------------|------------------------|
| 1  | حمدي عماد              | 20812022100282  | Memory +register       |
|    | حمدي عماد<br>حمدي      |                 | file+A&B&ALUout+MDR&PC |
| 2  | دنيا عصام              | 20812022200264  | ALU+Shift left         |
|    | دنيا عصام<br>فتحي أحمد |                 | +s_extended+MUX        |
| 3  | خلود وليد<br>عطية      | 20812022200595  | Control unit           |
| 4  | مازن یاسر<br>رفعت      | 20812022100417  | Connection             |

## **Table of Contents**

- > Assignment Aim
- > Problem Solution
  - 2.1 Inputs and Outputs
  - 2.2 Design Description
- > Implementation
  - 3.1 Code Overview
  - 3.2 Schematic Diagram
  - 3.3 Simulation Results
- ➤ References

#### 1. Assignment Aim

The aim of this project is to design and implement a simple processor in VHDL, capable of executing basic instructions such as load, store, arithmetic operations, branching, and jump. The design includes all major components of a processor and follows the multicycle approach.

#### 2. Problem Solution

The solution involves building a simplified multi-cycle processor architecture, implementing each component using VHDL, and simulating it in Active-HDL to verify functionality.

## 2.1 Inputs and Outputs

| Component            | Inputs                                                                                                       | Outputs                                                                                                                                                 |
|----------------------|--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| control_unit         | clk, reset, operation<br>(instruction[31:26])                                                                | pc_write, pc_write_condition, IorD, memory_read, memory_write, memorytoregister, IR_write, ALUSrcA, RegWrite, RegDst, ALUSrcB, ALU_operation, pc_source |
| memory               | address (MuxToAddress), writeData (RegBOut), memRead, memWrite, clk, enable                                  | memData                                                                                                                                                 |
| register_file        | clk, reset, read_reg1, read_reg2,<br>write_reg (MuxToWriteReg),<br>write_data (MuxToWriteData),<br>reg_write | read_data1 (srcA), read_data2 (srcB)                                                                                                                    |
| registers (PC)       | clk, reset, enable (OrToPC), input (MuxToPC)                                                                 | output (PC_out)                                                                                                                                         |
| registers<br>(MDR)   | clk, reset, enable = '1', input<br>(memData)                                                                 | output (MDRToMux)                                                                                                                                       |
| registers (IR)       | clk, reset, enable (IR_write), input (memData)                                                               | output (instruction)                                                                                                                                    |
| registers<br>(Reg_A) | clk, reset, enable = '1', input (srcA)                                                                       | output (RegAout)                                                                                                                                        |

| registers<br>(Reg_B) | clk, reset, enable = '1', input (srcB) | output (RegBOut)                 |
|----------------------|----------------------------------------|----------------------------------|
| registers            | clk, reset, enable = '1', input        | output (ALUOut)                  |
| (ALU_OUT)            | (ALUResultTOALUOut)                    |                                  |
| ALUControl           | funct (instruction[5:0]), ALUop        | ALUSel (ALUControltoALU)         |
| ALU                  | A (Mux4ToALU), B (Mux5ToALU),          | Result (ALUResultTOALUOut), Zero |
|                      | ALU_Sel                                |                                  |
| SignExtender         | InData (instruction[15:0])             | OutData (SignExtenderOut)        |
| shift_left32         | input (SignExtenderOut)                | output (shift_left32ToMux)       |
| shift_left26         | input (instruction[25:0])              | output (jumpAddress[27:0])       |
| mux1 (2x1)           | A (PC_out), B (ALUOut), Sel (IorD)     | Y (MuxToAddress)                 |
| mux2 (2x1)           | A (instruction[20:16]), B              | Y (MuxToWriteReg)                |
|                      | (instruction[15:11]), Sel (RegDst)     |                                  |
| mux3 (2x1)           | A (ALUOut), B (MDRToMux), Sel          | Y (MuxToWriteData)               |
|                      | (memorytoregister)                     |                                  |
| mux4 (2x1)           | A (PC_out), B (srcA), Sel (ALUSrcA)    | Y (Mux4ToALU)                    |
| mux5 (4x1)           | A (srcB), B (4), C                     | Y (Mux5ToALU)                    |
|                      | (SignExtenderOut), D                   |                                  |
|                      | (shift_left32ToMux), Sel (ALUSrcB)     |                                  |
| mux6 (3x1)           | A (ALUResultTOALUOut), B               | Y (MuxToPC)                      |
|                      | (ALUOut), C (jumpAddress), Sel         |                                  |
|                      | (pc_source)                            |                                  |

#### 2.2 Design Description

This processor is designed as a multicycle MIPS-like processor and includes the following components:

- Memory: Used for instruction and data storage.
- Register File A & B: Hold source operands and temporary data.
- ALU: Executes arithmetic and logic operations.
- MDR (Memory Data Register): Temporarily stores data read from or to be written to memory.
- . Shift Left Unit: Used in branch instruction to shift address.

- Control Unit: Generates control signals depending on the current state and opcode.
- MUX: Selects between multiple data sources.
- PC (Program Counter): Holds address of next instruction.
- Sign-Extended: Extends 16-bit immediates to 32-bit.

#### 3.Implementation

#### 3.1 Code Overview

https://github.com/HamdiEmad/MIPS-ISA-32-bit-Microprocessor

https://drive.google.com/drive/folders/17P3WBPT8eUuOjN3-iCnyK-3rRcCPDJEx?usp=sharing

#### 3.2 Schematic Diagram



#### 3.3 Simulation Results



#### 4. References

- Course Lecture Slides
- https://github.com/david-palma/mips-32bit/tree/master/MIPS32\_multi\_cycle
- https://www.slideshare.net/slideshow/mipsimplementation-29633476/29633476
- https://claude.ai/public/artifacts/e71731d4-93df-4940-8f78-630e97409063
- https://claude.ai/public/artifacts/af0bbfa2-103e-45e9-8090-7458443d0440
- "Computer Organization and Design" by David A. Patterson and John L. Hennessy
- "Digital Design and Computer Architecture" by David Money Harris and Sarah L. Harris