-
Notifications
You must be signed in to change notification settings - Fork 27
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
Review DMA implementation for Undefined Behavior (UB) #906
Comments
@ryan-summers if you can point me to the driver impl(s) I can give a review, or at least my opinions. |
The implementations are specifically in:
Note that there's a few single-byte transfers in there that are not concerning - the memory is static and entirely owned by the DMA module and is never modified. It's worth noting that this is a double-buffered DMA implementation using the STM32H7xx-Hal. This is implemented here for swapping the DMA double-buffer for the next transfer |
Possibly related: nightly now emits warnings like this (same for other DMA/Ethernet description ring buffers), and it seems like this is going to turn into
I am not sure I understand the documentation here – is |
c.f. #84 and stm32-rs/stm32h7xx-hal#518 |
It was noted by James Munns that we may need to use an
UnsafeCell
internal wrapper on the DMA reception buffers to prevent invoking undefined behavior by the Rust compiler (i.e. two owners of the memory cell)The text was updated successfully, but these errors were encountered: