Skip to content

A C++ implementation of RISCV-32I Single cycle processor

Notifications You must be signed in to change notification settings

ihita2812/RISCV-32I-Implementation

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

# RISCV-32I-Implementation

--------------------------------------------------------
A C++ implementation of RISCV-32I Processor
--------------------------------------------------------

README

Table of contents:
1. Developer Details
2. Directory Structure
3. How to build
4. How to execute
5. How to view output/GUI

Developer Details
-----------------

Developer's Name: Rhitvik Anand
Developer's Entry Number: 2021csb1127
Developer's Mail: [email protected] / [email protected]

Developer's Name: Niti Shyamsukha
Developer's Entry Number: 2021csb1118
Developer's Mail: [email protected]

Developer's Name: Ihita Sinha
Developer's Entry Number: 2021csb1095
Developer's Mail: [email protected]

Directory Structure
-------------------

RISCV-32I-Implementation
  |
  |- bin
    |- RISCV
    |- Data Memory.mc
  |- doc
    |- Design Doc.docx
  |- include
    |- Core.h
    |- CacheFile.h
    |- GUI.h
    |- Pipeline.h
    |- RISCV.h
  |- src
    |- Core.cpp
    |- CacheFile.cpp
    |- GUI.cpp
    |- Pipeline.cpp
    |- main.cpp
    |- Makefile
    |- RISCV.cpp
  |- test
    |- array_sum.s
    |- array_sum.mc
    |- bubblesort.s
    |- bubblesort.mc
    |- fibonacci.s
    |- fibonacci.mc
    |- LFU.s
    |- LFU.mc
  |- gui
    |- public
      |- index.html
      |- styles.css
    |- src
      |- App.jsx
      |- index.js
      |- components
        |- filedata.json

How to build
------------

For compiling:
  $cd src
  $make

For cleaning the project:
  $cd src
  $make clean

How to execute
--------------

Command to execute program:
../bin/RISCV <knobs>

<knobs> --
          | -test <filename.mc>
          | -n <value of N>
          | -pipeline
          | -forward
          | -trace [<instruction number>]
          | -registers
          | -h (or) -help

(compulsory knob: -test <filename.mc>)
(all other knobs are optional:
          | -h (or) -help will show how to execute
          | default value of N is 5
          | default setting of pipelining, forwarding, tracing, and showing register values is off
          | if forward/trace is called without calling pipeline, it doesn't do anything
          | providing instruction number after -trace knob will activate tracing for that particular instruction only, otherwise for all instructions
          | -registers knob will show values in register file after every cycle)

How to view output/GUI
----------------------

All data memory is stored in file ../bin/Data Memory.mc

Run the following commands to view GUI:
$cd ../gui
$npm i react-scripts
$npm start

About

A C++ implementation of RISCV-32I Single cycle processor

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 74.3%
  • JavaScript 14.3%
  • CSS 7.2%
  • Assembly 1.9%
  • M4 1.8%
  • HTML 0.3%
  • Makefile 0.2%