Skip to main content

RISC-V Model

Project description

This is a python model of the RISC-V ISA. It is intended to be a resource for Python-based automated testing and verification. It is under development and not very useful yet, but can be used to generate random assembler code.

Documentation: https://riscv-python-model.readthedocs.io/en/latest/

Quick Start

First install it:

pip3 install riscv-model

Create random assembler sequences

Create a random assembler sequence:

riscv-random-asm

You can tweak the assembler output:

usage: riscv-random-asm [-h]
                        [-i {add,sub,sll,slt,sltu,xor,srl,sra,or,and,jalr,addi,slti,sltiu,xori,ori,andi,lb,lh,lw,lbu,lhu,slli,srli,srai,sb,sh,sw,beq,bne,blt,bge,bltu,bgeu,lui,auipc,jal}]
                        [--version]
                        [N]

Generate sequence of assembler instructions.

positional arguments:
  N                     Number of assembler instructions

optional arguments:
  -h, --help            show this help message and exit
  -i {add,sub,sll,slt,sltu,xor,srl,sra,or,and,jalr,addi,slti,sltiu,xori,ori,andi,lb,lh,lw,lbu,lhu,slli,srli,srai,sb,sh,sw,beq,bne,blt,bge,bltu,bgeu,lui,auipc,jal}
                        Restrict to instructions
  --version             Display version

For example to generate 100 assembler instructions only with add, or and slti instructions:

riscv-random-asm 100 -i add -i or -i slti

Disassemble machine code

You can disassemble a machine code to the assembly code on instruction level:

riscv-machinsn-decode hexstring 0x007938b3 0xc9650993

You can also directly disassemble object files:

riscv-machinsn-decode objfile file.o

Automatically test random assembler sequences

riscv-random-asm-check generates random assembler sequences, compiles them, reads back the machine codes and matches them. You can use that to test your compiler, but it is also used as sanity check for riscv-model itself.

riscv-random-asm-check

It will by default use riscv32-unknown-elf-gcc and riscv32-unknown-elf-objcopy, but you can configure the tools with --compiler and --objcopy.

The automated tests will test all instructions, you can again restrict the number of instructions and the instructions:

riscv-random-asm-check 1000 -i xor

Finally, you can run the checks for the individual instructions seperately (used in combination with the other options:

riscv-random-asm-check -s

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

riscv-model-0.6.6.tar.gz (28.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

riscv_model-0.6.6-py3-none-any.whl (26.4 kB view details)

Uploaded Python 3

File details

Details for the file riscv-model-0.6.6.tar.gz.

File metadata

  • Download URL: riscv-model-0.6.6.tar.gz
  • Upload date:
  • Size: 28.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.5

File hashes

Hashes for riscv-model-0.6.6.tar.gz
Algorithm Hash digest
SHA256 dfff035b75ed36de33a99f95f1098697be308d4c7161a99407b82df22fd54d69
MD5 5091cebd82d81c0a00a2ccd5ffc39a54
BLAKE2b-256 10c66b3f2b3092681c5d3530455c0b7f737d46c115081df151f4c462ed4bbb7f

See more details on using hashes here.

File details

Details for the file riscv_model-0.6.6-py3-none-any.whl.

File metadata

  • Download URL: riscv_model-0.6.6-py3-none-any.whl
  • Upload date:
  • Size: 26.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.5

File hashes

Hashes for riscv_model-0.6.6-py3-none-any.whl
Algorithm Hash digest
SHA256 94fb3c93ac74fd3fa8c82a600a4c0030fdef020a8c81423aa40e4666687349b6
MD5 04ef08dddd4200b210b920fb73e2d61a
BLAKE2b-256 43eaecec6ebf47fdd9490460d46a9fce02e083274716abbd926c7c3be7b131c9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page