Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add decoder for RVV instructions #501

Draft
wants to merge 3 commits into
base: master
Choose a base branch
from
Draft

Conversation

howjmay
Copy link
Collaborator

@howjmay howjmay commented Oct 17, 2024

relate to #504

Copy link
Contributor

@jserv jserv left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Benchmarks

Benchmark suite Current: 7554c3b Previous: 584625f Ratio
Dhrystone 1336 Average DMIPS over 10 runs 1336 Average DMIPS over 10 runs 1
Coremark 948.638 Average iterations/sec over 10 runs 957.189 Average iterations/sec over 10 runs 1.01

This comment was automatically generated by workflow using github-action-benchmark.

@howjmay howjmay force-pushed the rvv branch 2 times, most recently from 7de4a2a to 11ea214 Compare October 18, 2024 00:35
@howjmay howjmay changed the title Support RVV instructions Add decoder for RVV instructions Oct 18, 2024
@howjmay howjmay force-pushed the rvv branch 5 times, most recently from 2dcaaf6 to 73db290 Compare October 20, 2024 14:52
@jserv
Copy link
Contributor

jserv commented Oct 20, 2024

How can you test the RVV instructions?

@howjmay
Copy link
Collaborator Author

howjmay commented Oct 20, 2024

A test set own by chipsalliance is here. https://github.com/chipsalliance/riscv-vector-tests/tree/main

I think we can test instructions' behavior with this repo. However, testing decoder is harder. I think I will Spike the verify the behavior, or generating the test cases

@howjmay howjmay force-pushed the rvv branch 2 times, most recently from 9225e3b to f092a89 Compare November 30, 2024 23:46
src/emulate.c Outdated
@@ -370,6 +370,9 @@ static bool has_loops = false;
}

#include "rv32_template.c"
#if RV32_HAS(EXT_RVV)
#include "rv32_rvv_template.c"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Rename it to rv32_vector.c

Comment on lines +5 to +9
/*
* This file is auto-generated by running 'make' in
* https://github.com/riscv/riscv-opcodes (9226b0d)
* and it is temporarily used by RVV only
*/
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Related: #103

Do you think it makes sense to replace the existing hand-written RISC-V instruction decoder with the generated one?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think the current one is good for education, especially the comments are valuable.
However I think having a table to clearly store the instructions in human-readable form is good for the future development.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

But this encoding.h is only a temporary header file for me to decode rvv instructions.

@howjmay howjmay force-pushed the rvv branch 3 times, most recently from 1f4ad39 to 584625f Compare December 30, 2024 01:40
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants