pub struct UartRxDriver<'d> { /* private fields */ }
Expand description
Serial receiver
Implementations§
Source§impl<'d> UartRxDriver<'d>
impl<'d> UartRxDriver<'d>
Sourcepub fn new<UART>(
uart: impl Peripheral<P = UART> + 'd,
rx: impl Peripheral<P = impl InputPin> + 'd,
cts: Option<impl Peripheral<P = impl InputPin> + 'd>,
rts: Option<impl Peripheral<P = impl OutputPin> + 'd>,
config: &Config,
) -> Result<UartRxDriver<'d>, EspError>where
UART: Uart,
pub fn new<UART>(
uart: impl Peripheral<P = UART> + 'd,
rx: impl Peripheral<P = impl InputPin> + 'd,
cts: Option<impl Peripheral<P = impl InputPin> + 'd>,
rts: Option<impl Peripheral<P = impl OutputPin> + 'd>,
config: &Config,
) -> Result<UartRxDriver<'d>, EspError>where
UART: Uart,
Create a new serial receiver
Sourcepub fn event_queue(&self) -> Option<&Queue<UartEvent>>
pub fn event_queue(&self) -> Option<&Queue<UartEvent>>
Retrieves the event queue for this UART. Returns None
if
the config specified 0 for queue_size
.
Sourcepub fn change_stop_bits(
&self,
stop_bits: StopBits,
) -> Result<&UartRxDriver<'d>, EspError>
pub fn change_stop_bits( &self, stop_bits: StopBits, ) -> Result<&UartRxDriver<'d>, EspError>
Change the number of stop bits
Sourcepub fn change_data_bits(
&self,
data_bits: DataBits,
) -> Result<&UartRxDriver<'d>, EspError>
pub fn change_data_bits( &self, data_bits: DataBits, ) -> Result<&UartRxDriver<'d>, EspError>
Change the number of data bits
Sourcepub fn change_parity(
&self,
parity: Parity,
) -> Result<&UartRxDriver<'d>, EspError>
pub fn change_parity( &self, parity: Parity, ) -> Result<&UartRxDriver<'d>, EspError>
Change the type of parity checking
Sourcepub fn change_baudrate<T>(
&self,
baudrate: T,
) -> Result<&UartRxDriver<'d>, EspError>where
T: Into<Hertz> + Copy,
pub fn change_baudrate<T>(
&self,
baudrate: T,
) -> Result<&UartRxDriver<'d>, EspError>where
T: Into<Hertz> + Copy,
Change the baudrate.
Will automatically select the clock source. When possible the reference clock (1MHz) will be used, because this is constant when the clock source/frequency changes. However if one of the clock frequencies is below 10MHz or if the baudrate is above the reference clock or if the baudrate cannot be set within 1.5% then use the APB clock.
Sourcepub fn read(&self, buf: &mut [u8], delay: u32) -> Result<usize, EspError>
pub fn read(&self, buf: &mut [u8], delay: u32) -> Result<usize, EspError>
Read multiple bytes into a slice; block until specified timeout Returns:
Ok(0)
if the buffer is of length 0Ok(n)
ifn
bytes were read, where n is > 0Err(EspError::Timeout)
if no bytes were read within the specified timeout
Sourcepub fn flush(&self) -> Result<(), EspError>
👎Deprecated since 0.41.3: Use UartRxDriver::clear
instead
pub fn flush(&self) -> Result<(), EspError>
UartRxDriver::clear
insteadClears the receive buffer.
pub fn clear(&self) -> Result<(), EspError>
pub fn port(&self) -> u32
Trait Implementations§
Source§impl Drop for UartRxDriver<'_>
impl Drop for UartRxDriver<'_>
Source§impl ErrorType for UartRxDriver<'_>
impl ErrorType for UartRxDriver<'_>
Source§type Error = EspIOError
type Error = EspIOError
Error type of all the IO operations on this type.
Source§impl ErrorType for UartRxDriver<'_>
impl ErrorType for UartRxDriver<'_>
Source§type Error = SerialError
type Error = SerialError
Error type
Source§impl Read<u8> for UartRxDriver<'_>
impl Read<u8> for UartRxDriver<'_>
Source§impl Read for UartRxDriver<'_>
impl Read for UartRxDriver<'_>
Source§fn read(
&mut self,
buf: &mut [u8],
) -> Result<usize, <UartRxDriver<'_> as ErrorType>::Error>
fn read( &mut self, buf: &mut [u8], ) -> Result<usize, <UartRxDriver<'_> as ErrorType>::Error>
Read some bytes from this source into the specified buffer, returning how many bytes were read. Read more
Source§fn read_exact(
&mut self,
buf: &mut [u8],
) -> Result<(), ReadExactError<Self::Error>>
fn read_exact( &mut self, buf: &mut [u8], ) -> Result<(), ReadExactError<Self::Error>>
Read the exact number of bytes required to fill
buf
. Read more