Merge pull request #3915 from embedded-rust-iml/fix/BufferedUartRx-nb-read
fix: BufferedUartRx embedded_hal_nb::serial::Read impl
This commit is contained in:
commit
00ef474b94
@ -908,29 +908,20 @@ impl<'d> embedded_hal_02::serial::Read<u8> for BufferedUartRx<'d> {
|
|||||||
type Error = Error;
|
type Error = Error;
|
||||||
|
|
||||||
fn read(&mut self) -> Result<u8, nb::Error<Self::Error>> {
|
fn read(&mut self) -> Result<u8, nb::Error<Self::Error>> {
|
||||||
let r = self.info.regs;
|
let state = self.state;
|
||||||
unsafe {
|
let mut rx_reader = unsafe { state.rx_buf.reader() };
|
||||||
let sr = sr(r).read();
|
|
||||||
if sr.pe() {
|
let do_pend = state.rx_buf.is_full();
|
||||||
rdr(r).read_volatile();
|
if let Some(data) = rx_reader.pop_one() {
|
||||||
Err(nb::Error::Other(Error::Parity))
|
if do_pend {
|
||||||
} else if sr.fe() {
|
self.info.interrupt.pend();
|
||||||
rdr(r).read_volatile();
|
}
|
||||||
Err(nb::Error::Other(Error::Framing))
|
Ok(data)
|
||||||
} else if sr.ne() {
|
|
||||||
rdr(r).read_volatile();
|
|
||||||
Err(nb::Error::Other(Error::Noise))
|
|
||||||
} else if sr.ore() {
|
|
||||||
rdr(r).read_volatile();
|
|
||||||
Err(nb::Error::Other(Error::Overrun))
|
|
||||||
} else if sr.rxne() {
|
|
||||||
Ok(rdr(r).read_volatile())
|
|
||||||
} else {
|
} else {
|
||||||
Err(nb::Error::WouldBlock)
|
Err(nb::Error::WouldBlock)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
impl<'d> embedded_hal_02::blocking::serial::Write<u8> for BufferedUartTx<'d> {
|
impl<'d> embedded_hal_02::blocking::serial::Write<u8> for BufferedUartTx<'d> {
|
||||||
type Error = Error;
|
type Error = Error;
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user