BRISC-V Explorer is a web application which allows for design space exploration for an open source RISC-V implementation written in Verilog 2001. The aim is allow both students and researchers to quickly configure a starting point for hardware design to avoid the work of starting from scratch.
The theme for these stories is researchers and students
- As a user I want to choose the number of stages in my processor pipeline
- As a user I want to choose if my processor pipeline is stalled or bypassed
- As a user I want to select the number of cores included in the final design
- As a user I want to select the width of my address bus
- As a user I want to select the width of my data bus
- As a user I want to load configuration parameters saved in a file
- As a user I want to set the associativity of L1 and L2 caches
- As a user I want to set the number indices for L1 and L2 caches
- As a user I want set the number of cache lines for L1 and L2 caches
- As a user I want to select the number of cache levels
- As a user I want to set the size of available main memory
- As a user I want to see the block diagram reflecting my chosen parameters
BRISC-V is a one page web application with a backend component handling the Verilog source generation.
- npm: package manager for node.js runtime
- flask: threaded server library for python
- GitPython: interact with repositories programmatically
golden layout: multi-window management for javascript
Meet with stakeholders to discuss requirementsIdentify any additional features that could be addedCreate requirements document and get approval from stakeholdersIdentify needed technology to support user stories
Define needed window panesRefactor project directory structure- Refactor old code base
- Create verilog configuration abstraction layer (VCAL)
- Create local verilog configuration module (VCM)
- Create remote verilog configuration module (VCM)
- Implement needed endpoints on flask server to support remote VCM
- Implement git repository functions on backend (might use GitPython for this)
- fetching metadata
- issues
- latest versions
- clone and pull
- Design module configuration logic
- Implement communication logic between front end and backend
TODO: Add goals here
