aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--embassy-stm32/src/dma/ringbuffer/mod.rs6
1 files changed, 5 insertions, 1 deletions
diff --git a/embassy-stm32/src/dma/ringbuffer/mod.rs b/embassy-stm32/src/dma/ringbuffer/mod.rs
index 25bdc7522..4dc1b51a9 100644
--- a/embassy-stm32/src/dma/ringbuffer/mod.rs
+++ b/embassy-stm32/src/dma/ringbuffer/mod.rs
@@ -252,9 +252,13 @@ impl<'a, W: Word> WritableDmaRingBuffer<'a, W> {
252 } 252 }
253 253
254 /// Write elements directly to the buffer. 254 /// Write elements directly to the buffer.
255 ///
256 /// Data is aligned towards the end of the buffer.
255 pub fn write_immediate(&mut self, buf: &[W]) -> Result<(usize, usize), Error> { 257 pub fn write_immediate(&mut self, buf: &[W]) -> Result<(usize, usize), Error> {
258 let start = self.cap() - buf.len();
259
256 for (i, data) in buf.iter().enumerate() { 260 for (i, data) in buf.iter().enumerate() {
257 self.write_buf(i, *data) 261 self.write_buf(start + i, *data)
258 } 262 }
259 let written = buf.len().min(self.cap()); 263 let written = buf.len().min(self.cap());
260 Ok((written, self.cap() - written)) 264 Ok((written, self.cap() - written))