Skip to content

Harshiitrpr/RISCV-Simulator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Functional Simulator for RISC-V Processor

This project is developed as part of Computer Architecture class and is build in 3 phases.

Table of Contents

  1. Contributors
  2. Directory Structure of each phase
  3. Requirements
  4. Phase 1 (Single Cycle Execution)
  5. Phase 2 (Pipelined Implementation)
  6. Phase 3 (Cache Implementation)
  7. How to run ?

Contributors

-------------------------------------------------
| Developer's Name   | Developer's Email ID     |
|-----------------------------------------------|
| Akhil Arya         | [email protected] |
| Harshwardhan Kumar | [email protected] |
| Krithika Goyal     | [email protected] |
| Rhythm Jain        | [email protected] |
| Tarun Singla       | [email protected] |
-------------------------------------------------

Directory Structure of each phase

RISCV-Simulator
  |
  |- doc
      |
      |- design-doc.docx
  |- src
      |
      |- Gui.py
      |- Instruction_Set_List.csv
      |- main.py
      |- memory.py(Phase 3 only)
      |- myRISCVSim.py
  |- test
      |
      |- bubble_sort.mc
      |- factorial.mc
      |- fibonacci.mc
      |- TC_1_Fibonacci_Assembly.s
      |- TC_2_Factorial_Assembly.s
      |- TC_1_BubbleSort_Assembly.s
      |- Test.md
  |
  |- Project-statement.txt
  |- README

Requirements

This simulator is built using Python. The user must install python3 and all libraries stated in requirements.txt.

Run the following command in the terminal in the main directory to install all the requirements of the project after installing python.

pip install -r requirements.txt

PHASE 1 (Single Cycle Execution)

myRISCVSim.py file will take .mc file as its argument and is executed as per the functional behaviour of the instructions. Each instruction will go through the following steps:

  1. Fetch
  2. Decode
  3. Execute
  4. Memory access
  5. Register update or Writeback

The simulator supports below 29 instructions:

  • R Format: add, and, or, sll, slt, sra, srl, sub, xor, mul, div, rem.
  • I Format: andi, addi, ori, lb, lh, lw, jalr.
  • S Format: sb, sw, sh.
  • SB Format: beq, bne, bge, blt.
  • U Format: auipc, lui.
  • UJ Format: jal.

As an output, the simulator writes the updated memory contents in a "data_out.mc" file. A "reg_out.mc" file is also produced containing the contents of the registers. Additionally, the simulator also prints messages for each stage about what it is doing in that stage and the number of clock cycles after each cycle.

PHASE 2 (Pipelined Implementation)

The simulator now supports pipelined implementation also. Various knobs can be set by the user to enable/disable pipelining, forwarding, printing register file, and printing pipeline registers for all or a specific instruction.

At the end of the execution, the simulator prints various insightful statistics in a stats.txt file.

PHASE 3 (Cache Implementation)

The simulator now supports both data and instruction caches. Various input parameters like cache size, cache block size, type of cache and number of ways can be set by the user.

At the end of the execution, the simulator prints various insightful statistics in a stats.txt file.

How to run ?

For any phase,

  1. Place your input .mc file(new ones if any) in the test directory.
  2. Run the following command on the terminal in the src directory:
$ python main.py

A GUI window opens. Select the input file, knobs(if present), cache parameters(if present) in the GUI and press the "run" button(if present). The program runs and the GUI window opens again to show various data corresponding to the input program execution.