





# THE UNIVERSITY OF KANSAS

# **SCHOOL OF ENGINEERING**

# DEPARTMENT OF ELECTRICAL ENGINEERING AND COMPUTER SCIENCE

EECS 645 – Computer Architecture

Spring 2021

Homework 05 (MIPS Data Memory and Instruction Memory)

Student Name: Student ID:

# **MIPS Data Memory and Instruction Memory**

Describe in behavioral VHDL (using processes) both MIPS data memory (using 2 concurrent processes) and MIPS instruction memory (using 1 process) as shown in Figures 1 and 2 with the following interface:

- I. Data Memory (Single-Ported Read/Write memory)
  - Generics
    - O Data memory size/depth (*data\_mem\_depth* with default value of <u>117</u> locations)
    - O Data memory width (data\_mem\_width with default value of 32 bits)
  - Inputs
    - Clock (clk  $\rightarrow$  1 bit)
    - o Asynchronous reset (rst  $\rightarrow$  1 bit)
    - Memory write enable (MemWrite  $\rightarrow$  1 bit)
      - 1  $\rightarrow$  enable writing to data memory,
      - 0 → disable writing to data memory
    - Address for read/write operand (A  $\rightarrow n\_bits\_address$  bits = 32 bits)
    - Write Data for write operand (WD → data\_mem\_width bits)
  - Outputs
    - Read Data for read operand (RD  $\rightarrow$  data\_mem\_width bits)



Figure 1. MIPS Data Memory

# II. Instruction Memory (Single-Ported Read-Only Memory)

- Generics
  - o Instruction memory size/depth (*instr\_mem\_depth* with default value of <u>39</u> locations)
  - o Instruction memory width (instr\_mem\_width with default value of 32 bits)
- Inputs
  - o Asynchronous reset for mimicking program load (rst  $\rightarrow$  1 bit)
  - O Address for instruction read (A  $\rightarrow n_bits_address$  bits = 32 bits)
- Outputs
  - Instruction fetched (Instr → instr\_mem\_width bits)



Figure 2. MIPS Instruction Memory

# In your design:

• Guard against address-spilling (address-overflow) where addresses could go out of range, e.g., exceeding the data/instruction memory size/depth.

#### In Vivado

- Create a blank project
- Add design and simulation source files
- o Run behavioral simulation
- O Your waveform configuration should be identical to the provided waveform snapshot, see Figure 2.

## • Steps:

- 1) Download the file "HW05\_MIPS\_MEM.zip" from blackboard and extract its contents.
- 2) Rename the folder "HW05\_MIPS\_MEM" to "HW05\_MIPS\_MEM\_<your last name>", for example "HW05\_MIPS\_MEM\_El-Araby".
- 3) Data memory
  - a. Launch Vivado and create a new project, for example "vivado\_project", with the default settings under the following directory "\HW05\_MIPS\_MEM\_<your last name>\DataMem" resulting in the following project directory "\HW05\_MIPS\_MEM\_<your last name>\DataMem\vivado\_project\"
  - Add to the project the VHDL design and simulation source files from the folders;
     "\HW05\_MIPS\_MEM\_<your last name>\DataMem\design\_sources" and "\HW05\_MIPS\_MEM\_<your last name>\DataMem\simulation sources" respectively.
  - c. Edit the VHDL file in the folder "\HW05\_MIPS\_MEM\_<your last name>\DataMem\design\_sources\" according to your design such that it describes the required MIPS data memory.

## 4) Instruction memory

- a. Launch Vivado and create a new project, for example "vivado\_project", with the default settings under the following directory "\HW05\_MIPS\_MEM\_<your last name>\InstrMem" resulting in the following project directory "\HW05\_MIPS\_MEM\_<your last name>\InstrMem\vivado\_project\"
- Add to the project the VHDL design and simulation source files from the folders;
   "\HW05\_MIPS\_MEM\_<your last name>\InstrMem\design\_sources" and "\HW05\_MIPS\_MEM\_<your last name>\InstrMem\simulation sources" respectively.
- c. Edit the VHDL file in the folder "\HW05\_MIPS\_MEM\_<your last name>\InstrMem\design\_sources\" according to your design such that it describes the required MIPS instruction memory.
- 5) Set the simulation time to the proper time, e.g., 300 ns, and then launch Vivado Simulator.
- 6) Verify the correctness of your design. Your waveform configuration should be identical to the waveform snapshot shown in Figures 3 and 4. You may go back to step 3 and/or 4 to correct your code until your design works properly as required.
- 7) After you are done, compress the folder "\HW05\_MIPS\_MEM\_<your last name>" to "HW05\_MIPS\_MEM\_<your last name>.zip", for example "HW05\_MIPS\_MEM\_El-Araby.zip" and upload it to blackboard before the due date and time.

### **Grade Distribution:**

- Functional Correctness, i.e. correct source code  $\rightarrow$  75 / 100
- Proper Setup of Vivado Project → 25 / 100

## **NOTE:**

Homework submission is a "Single Attempt", i.e., carefully review everything that you want to submit before hitting the "submit" button and make sure that you have uploaded all documents you want to submit and have not missed anything.



Figure 3. Snapshot of Correct Waveform Configuration for MIPS Data Memory



Figure 4. Snapshot of Correct Waveform Configuration for MIPS Instruction Memory