esp_idf_svc::hal::uart

Struct UartRxDriver

Source
pub struct UartRxDriver<'d> { /* private fields */ }
Expand description

Serial receiver

Implementations§

Source§

impl<'d> UartRxDriver<'d>

Source

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

Source

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.

Source

pub fn change_stop_bits( &self, stop_bits: StopBits, ) -> Result<&UartRxDriver<'d>, EspError>

Change the number of stop bits

Source

pub fn stop_bits(&self) -> Result<StopBits, EspError>

Returns the current number of stop bits

Source

pub fn change_data_bits( &self, data_bits: DataBits, ) -> Result<&UartRxDriver<'d>, EspError>

Change the number of data bits

Source

pub fn data_bits(&self) -> Result<DataBits, EspError>

Return the current number of data bits

Source

pub fn change_parity( &self, parity: Parity, ) -> Result<&UartRxDriver<'d>, EspError>

Change the type of parity checking

Source

pub fn parity(&self) -> Result<Parity, EspError>

Returns the current type of parity checking

Source

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.

Source

pub fn baudrate(&self) -> Result<Hertz, EspError>

Returns the current baudrate

Source

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 0
  • Ok(n) if n bytes were read, where n is > 0
  • Err(EspError::Timeout) if no bytes were read within the specified timeout
Source

pub fn flush(&self) -> Result<(), EspError>

👎Deprecated since 0.41.3: Use UartRxDriver::clear instead

Clears the receive buffer.

Source

pub fn clear(&self) -> Result<(), EspError>

Source

pub fn port(&self) -> u32

Source

pub fn count(&self) -> Result<usize, EspError>

Get count of remaining bytes in the receive ring buffer

Trait Implementations§

Source§

impl Drop for UartRxDriver<'_>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl ErrorType for UartRxDriver<'_>

Source§

type Error = EspIOError

Error type of all the IO operations on this type.
Source§

impl ErrorType for UartRxDriver<'_>

Source§

type Error = SerialError

Error type
Source§

impl Read<u8> for UartRxDriver<'_>

Source§

type Error = SerialError

Read error
Source§

fn read(&mut self) -> Result<u8, Error<<UartRxDriver<'_> as Read<u8>>::Error>>

Reads a single word from the serial interface
Source§

impl Read for UartRxDriver<'_>

Source§

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>>

Read the exact number of bytes required to fill buf. Read more
Source§

impl Read for UartRxDriver<'_>

Source§

fn read(&mut self) -> Result<u8, Error<<UartRxDriver<'_> as ErrorType>::Error>>

Reads a single word from the serial interface

Auto Trait Implementations§

§

impl<'d> Freeze for UartRxDriver<'d>

§

impl<'d> RefUnwindSafe for UartRxDriver<'d>

§

impl<'d> Send for UartRxDriver<'d>

§

impl<'d> Sync for UartRxDriver<'d>

§

impl<'d> Unpin for UartRxDriver<'d>

§

impl<'d> !UnwindSafe for UartRxDriver<'d>

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, U> Into<U> for T
where U: From<T>,

§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of [From]<T> for U chooses to do.

§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.