-
Notifications
You must be signed in to change notification settings - Fork 240
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
Erase DMA type params #2261
Erase DMA type params #2261
Conversation
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.
A problem I forsee is, what happens when users call .degrade()
on a PDMA channel before creating the driver with it?
EDIT: I suppose this would easily happen on multi chip libraries/applications.
Yes please. I'd like to be able to get my channel back from the driver, ideally in the same condition (type) that I gave to it. This is particularly important on chips with a very limited number of channels. |
I think full erasure of the type is the correct path. I don't think having DMA register access as a ZST vs a runtime access makes any real difference. Most of the time spent on DMA setup is with descriptors and or the buffer preparation. It being fully erased means we can apply this to any driver without having to rely on DMA being the last generic param on a driver to avoid inference issues. |
I was hoping to be able to statically tell if a DMA channel supported EDMA or not. I'm guessing you envision this sort of thing to be a runtime check now? |
dab86f9
to
2fcf862
Compare
This reverts commit 415e45e.
Latest push is just a rebase. |
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.
Very pleased to see these type removed!
I'm quite happy with the legibility of the compiler errors too:
error[E0277]: the trait bound `I2s1DmaChannel: DmaChannelConvert<Spi2DmaChannel>` is not satisfied
--> src/bin/embassy_spi.rs:63:19
|
63 | .with_dma(dma_channel.configure_for_async(false, DmaPriority::Priority0))
| -------- ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `DmaChannelConvert<Spi2DmaChannel>` is not implemented for `I2s1DmaChannel`
| |
| required by a bound introduced by this call
|
It's fairly good, which is not always the case :D.
Could we improve it with rust-lang/rust#119888 ? We are already on MSRV 1.79 and I think it was introduced in 1.78 |
Thank you for your contribution!
We appreciate the time and effort you've put into this pull request.
To help us review it efficiently, please ensure you've gone through the following checklist:
Submission Checklist 📝
cargo xtask fmt-packages
command to ensure that all changed code is formatted correctly.CHANGELOG.md
in the proper section.Extra:
Pull Request Details 📖
Description
This PR implements DMA type erasure. In the current system, the peripherals prescribe the erased DMA channel type. This allows erase-using-ZST-types on PDMA devices, and will allow handling P4's different DMAs without a ton of peripheral-specific
#[cfg]
gates. Pretty good idea, thanks @Dominaezzz even if this was terribly tricky to implement 😅There is no
AnyDmaChannel
type. The goal of this exercise was not to introduce one, but to remove the type parameter from peripherals, and the current implementation is a bit more information-rich with (barringfn degrade
) the same user-facing API.Fixes #2248