rp/uart: extract fifo draining from blocking_read
this will also be needed for dma operations.
This commit is contained in:
parent
be66e0f7ce
commit
1d5adb8974
1 changed files with 28 additions and 24 deletions
|
@ -238,33 +238,37 @@ impl<'d, T: Instance, M: Mode> UartRx<'d, T, M> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn blocking_read(&mut self, buffer: &mut [u8]) -> Result<(), Error> {
|
pub fn blocking_read(&mut self, mut buffer: &mut [u8]) -> Result<(), Error> {
|
||||||
let r = T::regs();
|
while buffer.len() > 0 {
|
||||||
unsafe {
|
let received = self.drain_fifo(buffer)?;
|
||||||
for b in buffer {
|
buffer = &mut buffer[received..];
|
||||||
*b = loop {
|
|
||||||
if r.uartfr().read().rxfe() {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
let dr = r.uartdr().read();
|
|
||||||
|
|
||||||
if dr.oe() {
|
|
||||||
return Err(Error::Overrun);
|
|
||||||
} else if dr.be() {
|
|
||||||
return Err(Error::Break);
|
|
||||||
} else if dr.pe() {
|
|
||||||
return Err(Error::Parity);
|
|
||||||
} else if dr.fe() {
|
|
||||||
return Err(Error::Framing);
|
|
||||||
} else {
|
|
||||||
break dr.data();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn drain_fifo(&mut self, buffer: &mut [u8]) -> Result<usize, Error> {
|
||||||
|
let r = T::regs();
|
||||||
|
for (i, b) in buffer.iter_mut().enumerate() {
|
||||||
|
if unsafe { r.uartfr().read().rxfe() } {
|
||||||
|
return Ok(i);
|
||||||
|
}
|
||||||
|
|
||||||
|
let dr = unsafe { r.uartdr().read() };
|
||||||
|
|
||||||
|
if dr.oe() {
|
||||||
|
return Err(Error::Overrun);
|
||||||
|
} else if dr.be() {
|
||||||
|
return Err(Error::Break);
|
||||||
|
} else if dr.pe() {
|
||||||
|
return Err(Error::Parity);
|
||||||
|
} else if dr.fe() {
|
||||||
|
return Err(Error::Framing);
|
||||||
|
} else {
|
||||||
|
*b = dr.data();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Ok(buffer.len())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'d, T: Instance> UartRx<'d, T, Blocking> {
|
impl<'d, T: Instance> UartRx<'d, T, Blocking> {
|
||||||
|
|
Loading…
Reference in a new issue