-
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
Changes to the spi
module
#615
Comments
Oh, and one other topic. I've started to think we should make the I think you would need to combine raw reads of the Edit: Actually, wouldn't DMA take ownership of the peripheral, so you could never call the |
That's a good idea, I think either approach works well enough. This one is nice because it removes a type parameter, although I don't actually mind having a capability type parameter, because it's super clear what the peripheral can do. I think the compiler error messages will also help? Maybe it would in this case too. That being said, I don't mind going with an approach or another, and if you choose to use this one, I can update I2C as well. As far as marking
|
@jbeaurivage, I realized something. We could create a safe, |
@jbeaurivage, I updated #613 with two separate interfaces to the |
I'm a little short on time these days, but I might be able to test it over next weekend. I won't have access to my scope or LA so my debugging capabilities will be a little limited |
@jbeaurivage, separate from the discussion in #614, I had another realization about the
spi
module.Right now, I take the same approach as the
uart
module and defineSpi
asI used the
Capability
type parameter in a few cases when implementing theembedded_hal
traits.However, while trying to simplify and consolidate those implementations, I realized that the
Capability
was only ever used to modify the behavior of the implementation. It was never used to change the type signature or API in some way.I realized that changing behavior could be equally-well accomplished by attaching an associated
const
to theCapability
trait. In #613, I added aDynCapability
enum
,and I altered the
Capability
trait to be:Then, within the
embedded_hal
implementations, I can switch based on theDynCapability
const
. This is just as good as using a type parameter, because all the functions are inlined, and constant propagation will ensure only one branch exists in the final code.With this approach, I could remove the
Capability
type parameter fromSpi
. Thus, the new type becomesand the implementations switch on
Capability
by doing something like thisYou can't do the same for the
uart
module, because you rely on theCapability
type parameter to change the API of eachUart
struct. But is it necessary for thei2c
module? Could we make a similar change there, perhaps as part of a broader initiative to achieve uniformity, as discussed in #614?The text was updated successfully, but these errors were encountered: