Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mrLSD/riscv-fs
F# RISC-V Instruction Set formal specification
https://github.com/mrLSD/riscv-fs
cpu fs fsharp isa library risc-processor risc-v riscv riscv-emulator riscv-simulator riscv32 riscv64
Last synced: 2 months ago
JSON representation
F# RISC-V Instruction Set formal specification
- Host: GitHub
- URL: https://github.com/mrLSD/riscv-fs
- Owner: mrLSD
- License: mit
- Created: 2019-08-28T23:36:00.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-09-11T07:43:01.000Z (4 months ago)
- Last Synced: 2024-10-30T01:37:43.347Z (3 months ago)
- Topics: cpu, fs, fsharp, isa, library, risc-processor, risc-v, riscv, riscv-emulator, riscv-simulator, riscv32, riscv64
- Language: F#
- Homepage:
- Size: 148 KB
- Stars: 281
- Watchers: 12
- Forks: 14
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# RISC-V formal ISA Specification
[![Build Status](https://travis-ci.org/mrLSD/riscv-fs.svg?branch=master)](https://travis-ci.org/mrLSD/riscv-fs)**Copyright © Evgeny Ukhanov**
This is a formal (and executable) specification for the
RISC-V ISA (Instruction Set Architecture), written in
**F# purely functional style**. We deliberately choose
an "_extremely elementary_" implementation of F# to make it
readable and usable by wide audience who do not know F# and who
do not plan to learn F#.![F# RISC-V ISA Formal Specification](https://miro.medium.com/max/2474/1*88Zj-QJq48IZTiCGUo5mSQ.png)
This is a work-in-progress, one of several similar concurrent
efforts within the **ISA Formal Specification**
Technical Group constituted by The RISC-V Foundation
(https://riscv.org). We welcome your feedback, comments and suggestions.## Content
* [Features & Current status](#features--current-status)
* [Reading the code](#reading-the-code)
* [How to build and run it on RISC-V binaries](#how-to-build-and-run-it-on-risc-v-binaries)
* [Install .NET SDK](#install-.net-sdk)
* [Make the application executable](#make-the-application-executable)
* [Run the application executable](#run-the-application-executable)
* [How to Contribute](#how-to-contribute)
* [References](#references)
* [Licence](#licence)
## Features & Current status
* Supports the following features (or _in active development state_)
- [x] Base instruction set: RV32I
- [x] Tests RV32I
- [x] Base instruction set: RV64I
- [x] Tests RV64I
- [x] Standard extension M (integer multiply/divide)
- [x] Tests for Standard extension M RV32/RV64
- [x] Standard extension A (atomic memory ops)
- [ ] Tests for Standard extension A RV32/RV64
* Features under development
* Standard extension C (Compressed 16-bit instructions)
* Standard extension F (Single-precision floating point)
* Standard extension D (Double-precision floating point)
* Privilege Level M (Machine)
* Privilege Level U (User)
* Privilege Level S (Supervisor)
* Virtual Memory schemes SV32, SV39 and SV48
* Application can be executed as a F# program flexible with
CLI (_command line interface_) support, which in
turn executes RISC-V ELF binaries. This is a sequential
interpretation: one-instruction-at-a-time, sequential
memory model.
* Tests passing for RISC-V **under development**:
* Basic instruction flow
* `rv32ui-p-*, rv64ui-p-*` (Base instruction set)
* `rv32um-p-*, rv64um-p-*` (M extension)
* `rv32ua-p-*, rv64ua-p-*` (A extension)
* `rv32uc-p-*, rv64uc-p-*` (C extension)## Reading the code
We expect that many people might use this as a reading
reference (whether or not they build and execute it) to
clarify their understanding of RISC-V ISA semantics.Main part for reading Specification:
* **Decode\*.fs**
Decodes contain decoders for specific instructions set
and notified with instruction/extension set symbol. For example `DecodeI.fs`
* **Execute\*.fs**Executes contain executions for specific instructions set
and notified with instruction/extension set symbol. For example `ExecuteI.fs`
* Utilities:
* `CLI.fs`
Contain helper function and types for
building effective CLI commands and options.
* `Bits.fs`
Basic type specific functions for
manipulations with `bits`.
* `Run.fs`
Basic Run flow - fetch, decode, execute,
logging execution flow.* Architecture
* `Arch.fs`Basic architecture types for RISC-V specification.
* `MachineState.fs`
Basic type and functions described
RISC-V machine state.* Main app
* `Program.fs`
Main application to execute **RISC-V simulator/emulator**.
* Test
* `Test/*.fs`
Contain unit-tests for instructions set
and extensions
* Test/asm/
Contain Assembler test programs for
manual testing RISC-V CPI implementation.
It depend on **risc-v toolchain** and
it has special auto-build `Makefile`.## How to build and run it on RISC-V binaries
Application can be executed as a _sequential RISC-V simulator_
(sequential, one-instruction-at-a-time semantics), by
building and executing it as a standard F# program.Supported OS:
* Linux
* Windows
* MacOSSupported **.NET SDK**:
* .NET SDK 2.2
* .NET SDK 3.0### Install .NET SDK
For Windows preferred way to use Visual Studio.
Other examples will be for Linux.
Please follow to instruction https://dotnet.microsoft.com/downloadFor Ubuntu:
```
$ wget -q https://packages.microsoft.com/config/ubuntu/16.04/packages-microsoft-prod.deb -O packages-microsoft-prod.deb
$ sudo dpkg -i packages-microsoft-prod.deb
$ sudo apt-get update
$ sudo apt-get install apt-transport-https
$ sudo apt-get update
$ sudo apt-get install dotnet-sdk-3.0
```
To check installation:`$ dotnet --version`
will tell you what version of `dotnet` you have.
### Make the application executable
You can build the application executable with:`$ dotnet build`
### Run the application executable
Most simple way to run immediately `run` (without
additional `build` command) to see command-line
options on the executable:`$ dotnet run -- --help`
If you run the application without option:
`$ dotnet run`
you'll receive error message:
> Wrong parameters put --help to get more information
**Example** to run specific ISA with extensions, verbosity
output and ELF file for execution in RISC-V CPI simulator:`$ dotnet run -- -A rv32i -v myapp.elf`
## How to Contribute
Please read file [CONTRIBUTING.md](CONTRIBUTING.md)
## References
* github ISA manual: https://github.com/riscv/riscv-isa-manual
* RISC-V specification: https://riscv.org/specifications/
* RISC-V Formal Verification Framework: https://github.com/SymbioticEDA/riscv-formal## Licence
**MIT License**