forked from Kirosamurai/RISCV-32I-Implementation
-
Notifications
You must be signed in to change notification settings - Fork 0
ihita2812/RISCV-32I-Implementation
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
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 0
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%