-
Notifications
You must be signed in to change notification settings - Fork 205
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
Update PAC's to svd2rust 0.30.2 #683
Conversation
The Parts changed where adding SELECT to a few Registers ending with _A, as they were renamed frm *_A to *SELECT_A
@Tremoneck, thank you for this PR! I've had something similar but half finished for a while. Nice to see someone else step up to take it on. To answer your questions:
I think logically the register should be renamed. Looks like an oversight on Atmel's part, as most registers are suffixed with *CTRL. That being said, I don't particularly like that the PACs now diverge from the datasheet.
That depends. Do you expect rust-embedded/svd2rust#713 to end up generating the same code as your manual patch? Ie, will we have breaking changes when a fix lands and we re-generate the PACs in the future?, |
I don't like the divergent from the Datasheet either. In the Datasheet (p. 792) the register is titled Channel n Control but the name is given as the value in the SVD of CHANNEL. The alternative is calling the struct something along the lines of CHANNEL_REGISTERS. I expect the register to end up generating to the value I fixed them to. It's the same type name as the 0.27 would generate. So even if a fix changes the typename, we would still have the same breaking change. |
What about calling the struct In any case, I'm on board with the manual patch while awaiting the |
This change keeps the register names in sync with the datasheet.
Where should the breaking changes be documented? Should that be in the changelog on how to migrate to the next version. I've added a new feature to the hal, which is only needed if you want to use the take for Peripherals. Where should this be documented? I really would like to add an example for when you need it and what else you need so you don't get compiler errors. When everything is ready, should I rebase and squash the commits and add a longer explanation into the commit message with the required things to do to migrate. |
The changelog, and maybe a short note in the readme as well?
What exactly does that feature entail? Is is something that's mandated by the new svd2rust version?
Yep, that sounds good! |
pac/atsamd11c/src/lib.rs
Outdated
@@ -914,18 +913,22 @@ pub struct Peripherals { | |||
pub WDT: WDT, | |||
} | |||
impl Peripherals { | |||
#[doc = r"Returns all the peripherals *once*"] | |||
#[doc = r" Returns all the peripherals *once*."] | |||
#[cfg(feature = "critical-section")] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The optional dependency is forced by this new addition to the generated pac. To access the peripherals one has to call take. But only one thread may get the struct. To avoid a datarace synchronization is required. This used to be achieved with a cortex specific call to disable interrupts, but was replaced with a critical section. One can still use steal if one wants to avoid the dependency's, but has to use unsafe code.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah fair enough. Though I don't really see a case where someone wouldn't want to use the critical section feature - I would suggest enabling it in the HAL for all PACs. That way users and libraries can use thecritical-section
lib without having to worry about cargo features. After all, it's not like there should be another critical section provider in the dependency tree anyways - what do you think?
@Tremoneck, svd2rust 0.29.0 is out. I don't know if you want to adapt to the new version, or stick to 0.28.0? |
I've been thinking longg about the critical-section part. I believe you are right with providing always. However, we will need documentation in that case that you will require another crate, that provides the bindings, as otherwise you will get strange linker errors. Might as well switch the script to 0.29, if I'm already updating it. |
What if the PACs depended directly on |
@Tremoneck, have you had the time to think about my last comment? I'm going to have a bit more bandwidth in the following weeks, I could assist in getting this ready for merge. |
The critical section crate strongly encourages gating the implementation of critical sections behind a feature flag, so that it can be disabled, as linking two creates implementing it leads to two definitions and then linker errors. It would also make this crate incompatible with any crate that wants to implement it's own definition like a RTOS or an async runtime. For reference the STM32 crates https://github.com/stm32-rs/stm32-rs-nightlies/blob/3767c5e39a9c15e321c0230e53742f14b882be06/stm32f4/src/stm32f405/mod.rs#L4375 implement it as an optional feature as well. It is also designed in a way, where a user doesn't have to depent on an Implementor of a critical-section, as long as a critical section provider is linked in, it works. |
@Tremoneck that's fair. I suggest we follow stm32-rs' lead and expose a |
@Tremoneck, take a look at #1. If you agree and merge it, we could land this promptly. |
I thought some more about the
In our case, since |
Merge jbeaurivage updates into Branch
Yeah, thats a good point. Maybe I miss understood what the critical-section crate meant. Anyway, should there ever arise a need to remove this direct dependency on the cortex-m-rt crate it should still be possible to break it out as a default feature flag without breaking SemVer I think. I've merged your commits into my feature branch. |
Yeah sorry about that, I messed up the branch on top of which my PR was based. Thanks for catching it. |
Remove "critical-section" feature of PAC libs
I've noticed some new warnings for |
@ianrrees I usually use nightly compilers when working on async stuff (especially my HAL's async branch. However even that is going to change with AFIT around the corner. Otherwise I try to stick with stable. It's true that svd2rust seems to regularly try using some weird lints, perhaps too aggressively. I'm not too sure how to fix that on our end though. |
I see, thanks! Will aim to follow up with svd2rust and see if we can arrive at a solution that works with both stable and unstable. |
Aha, svd2rust is already on it: rust-embedded/svd2rust#760 In the meantime, I'll PR an addition of |
Disregard - Rust 1.74.0 has these new lints |
* Update svd2rust and form version * CreatePatch file for the EVSYS channel * Regenerate PAC's with svd2rut 0.30.2 * Apply manual patch for wrong generation of svd2rust See rust-embedded/svd2rust#713 * Update Cargo.toml to the new Versions of the pacs * Update hal to the new pacs The Parts changed where adding SELECT to a few Registers ending with _A, as they were renamed frm *_A to *SELECT_A * Make the tier one examples compileable * Update the changelog * Change the rename in EVSYS to the Channel struct. This change keeps the register names in sync with the datasheet. --------- Co-authored-by: Adrian Geipert <adrian.git@geipert.eu> Co-authored-by: Justin Beaurivage <justin@wearableavionics.com>
* Update svd2rust and form version * CreatePatch file for the EVSYS channel * Regenerate PAC's with svd2rut 0.30.2 * Apply manual patch for wrong generation of svd2rust See rust-embedded/svd2rust#713 * Update Cargo.toml to the new Versions of the pacs * Update hal to the new pacs The Parts changed where adding SELECT to a few Registers ending with _A, as they were renamed frm *_A to *SELECT_A * Make the tier one examples compileable * Update the changelog * Change the rename in EVSYS to the Channel struct. This change keeps the register names in sync with the datasheet. --------- Co-authored-by: Adrian Geipert <adrian.git@geipert.eu> Co-authored-by: Justin Beaurivage <justin@wearableavionics.com>
Summary
Update the PAC to use svd2rust 0.28.0 and form 0.10.0, while fixing up all the renamed registers.
svd2rust renamed severall registers from *_A to *SELECT_A, these were fixed up. This is a breaking change for dependent crates accessing registers, structs or enums directly.
Two patches were neccessary to make the generated code correct.
This pull request isn't finished as is, but requires some feedback:
For the SAM_5 should the register be renamed or the struct representing a channel?
Should we wait for a fix to land for rust-embedded/svd2rust#713, go back to 0.27.0 or go with this manual patch?
The new generated code relies on a feature on critical-section. Should this be default and always available, or should it, like it is in this PR be a optional feature which can be enabled over the hal?
Fixes #648
Obsoletes #650
Checklist
CHANGELOG.md
for the BSP or HAL updatedIf Adding a new cargo
feature
to the HALcrates.json