-
Notifications
You must be signed in to change notification settings - Fork 844
Adding Support for Sdtrig Extension in CVA6 #3097
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
Adding Support for Sdtrig Extension in CVA6 #3097
Conversation
|
❌ failed run, report available here. |
05ab967 to
0f58810
Compare
|
❌ failed run, report available here. |
@JeanRochCoulon Hi, I see that the GitHub CI is passing on my latest commit but the Thales CI is reported as failing. However, I can not see the latest Thales report/logs. It still shows the old commit reports. Can you please look into this? |
|
❌ failed run, report available here. |
|
Hello @munailwaqar The Thales CI passes (only one test is always failed, it is normal...) ! I will review the PR in the coming days. Can you rebase ? |
|
❌ failed run, report available here. |
0f58810 to
ae39f4d
Compare
@JeanRochCoulon Thanks! I've rebased the branch -- ready for your review whenever you can. |
|
Congratulations @munailwaqar. Thanks to 10x team ! |
Introduction
This PR adds support for the Sdtrig Extension in CVA6, which primarily adds the Trigger Module. The core can now support four types of triggers i.e. icount, mcontrol6, etrigger and itrigger.
Implementation
The number of triggers supported by the core is parameterized and can be set at compile time.
The trigger module supports 2 types of action on trigger match i.e. breakpoint exception generation and debug mode
Modifications
The entire Trigger Module has been added under a SDTRIG bit for configuration. Additionally, all trigger types can be individually enabled and disabled using their own dedicated bits Icount, Mcontrol6, Etrigger, Itrigger.
The new trigger_module (trigger_module.sv) was added inside the CSR Register File (csr_regfile.sv). Additionally, the csr_regfile, commit stage and decode modules were updated to handle trigger fire logic.
Modifications Diagram

Documentation and Reference
The official The RISC-V Debug Specification Version 1.0.0 was followed to ensure alignment with ratification.
Verification
These changes have been tested with self-written tests to ensure proper functionality.