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

Sail Crosscheck Testing with ACT Against Spike #38

Open
13 tasks
jjscheel opened this issue Jan 30, 2024 · 16 comments
Open
13 tasks

Sail Crosscheck Testing with ACT Against Spike #38

jjscheel opened this issue Jan 30, 2024 · 16 comments
Assignees

Comments

@jjscheel
Copy link
Contributor

jjscheel commented Jan 30, 2024

Technical Group

Golden Model SIG

ratification-pkg

Technical Debt

Technical Liaison

Bill McSpadden

Task Category

SAIL model

Task Sub Category

  • gcc
  • binutils
  • gdb
  • intrinsics
  • Java
  • KVM
  • ld
  • llvm
  • Linux kernel
  • QEMU
  • Spike

Ratification Target

3Q2023

Statement of Work (SOW)

Component names:
Sail (infrastructure)

Requirements:
In order to improve functional coverage of the RISC-V Sail model, the RISC-V ACTs need to be run against the model. Since the ACTs are not self-checking tests, another model needs to be checked against. We will use Spike to crosscheck the Sail model.

Configurations of the Sail model should be done with RISCV-Config.

RISCOF should be used for testing.

Deliverables:

  1. github repo that contains documentation as to how to set up and run a Sail/Spike crosschecking environment.
  2. A sandbox containing examples of running the crosscheck for different configurations of the models.

Acceptance Criteria:

  1. Tests run and results are identical between Sail and Spike
  2. Accepted PR into the Sail community and any additional projects identified during work

Projected timeframe: (best guess date)
6 person months of work from start date

SOW Signoffs: (delete those not needed)

  • Development partner sign-off
  • ACT SIG sign-off
  • Golden Model SIG sign-off

Waiver

  • Freeze
  • Ratification

Pull Request Details

@jjscheel
Copy link
Contributor Author

@junambi also expressed interest and/or a willingness to help here. @UmerShahidengr, can you and Nambi see if the work can be divided?

@Abdulwadoodd
Copy link
Member

Abdulwadoodd commented Feb 20, 2024

I have implemented the methodology in CI that runs ACTs on riscv-sail model and test it against spike, using RISCOF. CI runs tests for all configurations of architecture sizes (rv64i_m, rv32i_m, rv32e). After CI completes the test execution, the artifacts containing the test report of all three categories is uploaded on GitHub space
All the extensions supported in sail-riscv are running under the CI and are passing by matching signature with that of spike.

The implementation is currently on my forked repo of sail and (CI results) available here for the initial review for @billmcspadden-riscv. If this looks good to you and does not require major changes, I'm happy to make a PR official sail-riscv repository.

@UmerShahidengr
Copy link

Update ⇾ March 5th, 2024
@Abdulwadoodd is waiting for the initial review, if @billmcspadden-riscv is happy with his implementation, then we can add its PR and complete this SoW.

@jjscheel
Copy link
Contributor Author

jjscheel commented Mar 5, 2024

Thank, @UmerShahidengr.

@Abdulwadoodd, I hear your demo is quite impressive. Now begins the "fun" work of finding an acceptable solution for the community. @billmcspadden-riscv will help you with this. It will take time, so please be patient.

@gsterlin, FYI. This work plays into the broader Compatibility Testing delivery plan we trying to develop.

@Abdulwadoodd
Copy link
Member

Thanks @jjscheel,
The next step is to add a Readme Document for the sandbox, as instructed by @billmcspadden-riscv after the demo. After that, I'll raise a sail PR for the golden model community review.

@UmerShahidengr
Copy link

@Abdulwadoodd can you please give any update on it?

@UmerShahidengr
Copy link

@Abdulwadoodd has been busy in other assignments, he will update on this issue soon

@jjscheel
Copy link
Contributor Author

@Abdulwadoodd, if you get a chance, I'd appreciate an update on Monday or Tuesday. Thanks!

@Abdulwadoodd
Copy link
Member

@jjscheel sorry for the delay.
I have raised a PR (riscv/sail-riscv#481) that runs the ACTs in CI, cross-checks sail and spike, generates reports and uploads the reports to GitHub workspace. suggestions/changes/questions are welcome on this PR.

Currently, CI uses arch-tests release of 3.8.10 while the later releases (including current 3.8.20) is a bit broken for RISCOF. The PR to fix this issue is underway (riscv-non-isa/riscv-arch-test#464)

@jjscheel
Copy link
Contributor Author

Thanks for the update, @Abdulwadoodd!

@UmerShahidengr
Copy link

Update June 11th, 2024:
The PR by @Abdulwadoodd is still in review. Work is completed on our side

@jjscheel
Copy link
Contributor Author

@billmcspadden-riscv, as discussed in yesterday's meeting, please review this SOW and help us understand what's next in the context of Sail CI testing. An update here or in a future DevPartners meeting would be helpful when ready.

@billmcspadden-riscv
Copy link

We will talk about this at the tech-golden-model meeting on 2025-01-18. We will have a general discussion of the testing methodology of the RISC-V model, and this PR will be discussed.

There are numerous comments in the PR about the deficiencies in the RISCOF methodology. Coupling this testing methodology within the RISC-V Sail repo may meet severe pushback. Perhaps creating a separate repo that pulls in all the separate pieces (via git subtree or via git submodules) might be a better tack.

@jjscheel
Copy link
Contributor Author

jjscheel commented Jan 7, 2025

Thanks, @billmcspadden-riscv!

@jjscheel
Copy link
Contributor Author

@billmcspadden-riscv has informed me that the ACT CI environment is performing these checks on a regular basis. This means we can close the PR as complete.

@UmerShahidengr, can you confirm this is indeed correct and that you're comfortable closing this?

@UmerShahidengr
Copy link

@jjscheel Yes it is correct.
@billmcspadden-riscv and I had a meeting and discussed the CI environment in detail, and we have been managing that CI in riscv-arch-tests while verifying the tests by running them on Spike and Sail via riscof

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: As-planned
Development

No branches or pull requests

4 participants