Skip to content

Conversation

@KushalMeghani1644
Copy link
Contributor

@KushalMeghani1644 KushalMeghani1644 commented Sep 24, 2025

This PR adds support for the mtopi (Machine Top Priority Interrupt) CSR, which is part of the RISC-V Advanced Interrupt Architecture (AIA) extension.

Changes:

  • Add mtopi.rs register implementation at address 0x7C0
  • Export mtopi module in register.rs
  • Read-only CSR with proper bit field definitions:
    • iid (Interrupt ID): bits 16-27
    • iprio (Interrupt Priority ID): bits 0-7
  • Convenience methods for interrupt detection and priority handling

Features:

  • Memory-safe read-only access
  • Comprehensive documentation with usage examples
  • Full test coverage
  • Follows existing CSR implementation patterns

Testing:

  • All existing tests continue to pass
  • New tests cover bit field extraction and edge cases
  • Documentation examples compile successfully

AI Assistance:
Parts of the explanation and understanding of the mtopi CSR were assisted using an AI tool to summarize its behavior in the context of the RISC-V Advanced Interrupt Architecture (AIA). All code and implementation decisions were written and verified manually. NO CODES WERE GENERATED WITH THE HELP OF AI.

Add support for the mtopi CSR (0x7C0) from RISC-V Advanced Interrupt
Architecture (AIA). Provides read-only access to highest-priority
pending interrupt information with IID and IPID fields.
@KushalMeghani1644 KushalMeghani1644 requested a review from a team as a code owner September 24, 2025 11:53
Copy link
Contributor

@rmsyn rmsyn left a comment

Choose a reason for hiding this comment

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

Thanks for your contribution!

AI Assistance:
Parts of the explanation and understanding of the mtopi CSR were assisted using an AI tool to summarize its behavior in the context of the RISC-V Advanced Interrupt Architecture (AIA). All code and implementation decisions were written and verified manually. NO CODES WERE GENERATED WITH THE HELP OF AI.

Thank you for explicitly stating your use of AI tool assistance. AFAIK, we currently do not have a policy on AI contributions. IMO, we should ban AI contributions, even for "just documentation/explanation". Such contributions have deep issues with plagiarism, and we cannot possibly verify the provenance of of the training data.

"Manually" rewriting suggestions from AI is not the same as manually implementing the changes. You're already contradicting yourself by saying that AI only helped by providing explanations/documentation, and that you manually rewrote code suggested by AI.

@romancardenas what are your thoughts on adding a section on AI to our CODE_OF_CONDUCT.md, or creating a CONTRIBUTING.md? After your recent back and forth on @KushalMeghani1644's contributions, how do you feel about their usage of AI?

Replace manual assertions with test_ro_csr_field! macro that follows
the same pattern as test_csr_field! but adapted for read-only CSRs.
@KushalMeghani1644
Copy link
Contributor Author

KushalMeghani1644 commented Sep 24, 2025

Hey @rmsyn thanks for putting time to my PR! I feel there is maybe a little misunderstanding upon the "AI DISCLOSURE" part, I have clearly stated in the PR desc that:

"Parts of the explanation and understanding of the mtopi CSR were assisted using an AI tool to summarize its behavior in the context of the RISC-V Advanced Interrupt Architecture (AIA). All code and implementation decisions were written and verified manually. NO CODES WERE GENERATED WITH THE HELP OF AI."

See the "parts" word! I meant that only a few little queries and all were asked from AI to understand how Mtopi actually works since I haven't studied much on this CSR, and the codes WERE NOT generated by AI, I had indeed went through the official docs of https://tools.cloudbear.ru/docs/riscv-aia-1.0-20230630.pdf to understand mtopi well. And also this line by you, ""Manually" rewriting suggestions from AI is not the same as manually implementing the changes. You're already contradicting yourself by saying that AI only helped by providing explanations/documentation, and that you manually rewrote code suggested by AI." I hadn't not manually rewritter what AI gave me, I stated in the "AI DISCLOSURE" section in capital words that, "NO CODES WERE GENERATED WITH THE HELP OF AI."

Edit: Also just to be transparent, my previous PRs that were merged had 0 use of AI in the codes! Those PRs were purely made by my brain + hands :D

Thank you :)

- Add field boundary testing for both iid and ipid fields
- Improve comments to clarify macro usage and pattern following
- Ensure complete test coverage matching original test_csr_field! scope
@KushalMeghani1644
Copy link
Contributor Author

Hey @rmsynI've updated the mtopi tests to use test helper macros as requested. Created a test_ro_csr_field! macro that follows the same pattern as test_csr_field! from macros.rs but adapted for read-only CSRs. The macro uses identical bit manipulation logic and replaces all the manual assertions. Thanks for the guidance!

@rmsyn
Copy link
Contributor

rmsyn commented Sep 24, 2025

Hey @rmsyn thanks for putting time to my PR! I feel there is maybe a little misunderstanding upon the "AI DISCLOSURE" part, I have clearly stated in the PR desc that:

"Parts of the explanation and understanding of the mtopi CSR were assisted using an AI tool to summarize its behavior in the context of the RISC-V Advanced Interrupt Architecture (AIA). All code and implementation decisions were written and verified manually. NO CODES WERE GENERATED WITH THE HELP OF AI."

See the "parts" word! I meant that only a few little queries and all were asked from AI to understand how Mtopi actually works since I haven't studied much on this CSR, and the codes WERE NOT generated by AI, I had indeed went through the official docs of https://tools.cloudbear.ru/docs/riscv-aia-1.0-20230630.pdf to understand mtopi well. And also this line by you, ""Manually" rewriting suggestions from AI is not the same as manually implementing the changes. You're already contradicting yourself by saying that AI only helped by providing explanations/documentation, and that you manually rewrote code suggested by AI." I hadn't not manually rewritter what AI gave me, I stated in the "AI DISCLOSURE" section in capital words that, "NO CODES WERE GENERATED WITH THE HELP OF AI."

Edit: Also just to be transparent, my previous PRs that were merged had 0 use of AI in the codes! Those PRs were purely made by my brain + hands :D

Thank you :)

The official link to the AIA specification (from the RISC-V Atlassian repo) is a Google Docs link RISC-V AIA], maybe the cloudbear.ru link you posted is a mirror of that document?

Regarding your previous contributions, that's fine if you indeed contributed all those changes yourself. I was asking for @romancardenas to give feedback on allowing your AI contirbutions after the experience of reviewing your previous contribution.

@KushalMeghani1644
Copy link
Contributor Author

The official link to the AIA specification (from the RISC-V Atlassian repo) is a Google Docs link RISC-V AIA], maybe the cloudbear.ru link you posted is a mirror of that document?

Regarding your previous contributions, that's fine if you indeed contributed all those changes yourself. I was asking for @romancardenas to give feedback on allowing your AI contirbutions after the experience of reviewing your previous contribution.

Hey! sorry if I was too harsh in my previous comments. I was just trying to be as transparent as I can! cause I always find it fun to contribute to OSS projects, especially bare metal codes like RISCV. Apologize for the inconveniences caused by me here. I hope that I have cleared out that everything is fine now :) And yes the cloudbear.ru link is a mirror, I for some reason wasn't able to find the official docs from RISCV, thanks for providing the links though.

Extend test_csr_field! macro with new arm for read-only multi-bit fields.
Update mtopi tests to use standard macro instead of custom implementation.
@KushalMeghani1644
Copy link
Contributor Author

Hey! @rmsyn (sorry for pinging if you were busy) I've added a new arm to the existing test_csr_field! macro instead of creating a separate one. The macro now supports read-only CSR fields with the pattern [start:literal, end:literal] and mtopi tests now use the standard macro. Thanks for the clarification!

Copy link
Contributor

@rmsyn rmsyn left a comment

Choose a reason for hiding this comment

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

Hey! @rmsyn (sorry for pinging if you were busy) I've added a new arm to the existing test_csr_field! macro instead of creating a separate one. The macro now supports read-only CSR fields with the pattern [start:literal, end:literal] and mtopi tests now use the standard macro. Thanks for the clarification!

No worries, and thanks for making the changes. I have a couple other suggestions, otherwise LGTM outside the question of AI contributions.

These methods were simple aliases for ipid() and iid() respectively,
which doesn't follow the crate's pattern of only adding convenience
methods that provide semantic value or logical operations.
@KushalMeghani1644
Copy link
Contributor Author

Hi @rmsyn I have removed the helper functiosn as requested! I hope the changes are fine :) if there are more improvements remaining, I'd be happy to fix them :D

@KushalMeghani1644
Copy link
Contributor Author

Hey @rmsyn and @romancardenas sorry for disturbing but can I please get any updates on what do I have to do with this PR next?

@KushalMeghani1644
Copy link
Contributor Author

A unrelated change @romancardenas (maybe) but I have fixed the spelling in aclint.rs, I hope you are fine with that :) if you think its unrelated to this PR I can also remove the commits.

@KushalMeghani1644
Copy link
Contributor Author

KushalMeghani1644 commented Oct 20, 2025

I am sorry, but seems like most the things @romancardenas has asked are fixed, if there are more changes required, I would definitely make them but I'll be slow to respond just for 2 or so days. Either way I am sorry for the other hurdles that were caused... I would wait for a response :) thanks

@romancardenas
Copy link
Contributor

@KushalMeghani1644 please add a reference value to the test macro branch, so the macro actually checks against an expected value

@KushalMeghani1644
Copy link
Contributor Author

I am quiet unsure if the CI failing is my fault... I would like some guidance here, but it doesn't seem like my changes broke anything here... I didn't even touch the riscv-rt crate?

@romancardenas
Copy link
Contributor

Looks like the new version of syn bumped the MSRV to 1.68...

I was thinking on bumping MSRV to 1.81 with riscv-types, so it shouldn't be a big deal. Let put this PR in standby until I do all the required work.

@KushalMeghani1644
Copy link
Contributor Author

OK then, I'll wait :)

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.

3 participants