Trait opentitanlib::io::uart::Uart

source ·
pub trait Uart {
    // Required methods
    fn get_baudrate(&self) -> Result<u32>;
    fn set_baudrate(&self, baudrate: u32) -> Result<()>;
    fn read(&self, buf: &mut [u8]) -> Result<usize>;
    fn read_timeout(&self, buf: &mut [u8], timeout: Duration) -> Result<usize>;
    fn write(&self, buf: &[u8]) -> Result<()>;

    // Provided methods
    fn set_flow_control(&self, flow_control: bool) -> Result<()> { ... }
    fn clear_rx_buffer(&self) -> Result<()> { ... }
    fn set_break(&self, _enable: bool) -> Result<()> { ... }
    fn set_parity(&self, _parity: Parity) -> Result<()> { ... }
    fn supports_nonblocking_read(&self) -> Result<bool> { ... }
    fn register_nonblocking_read(
        &self,
        _registry: &Registry,
        _token: Token
    ) -> Result<()> { ... }
    fn nonblocking_help(&self) -> Result<Rc<dyn NonblockingHelp>> { ... }
}
Expand description

A trait which represents a UART.

Required Methods§

source

fn get_baudrate(&self) -> Result<u32>

Returns the UART baudrate. May return zero for virtual UARTs.

source

fn set_baudrate(&self, baudrate: u32) -> Result<()>

Sets the UART baudrate. May do nothing for virtual UARTs.

source

fn read(&self, buf: &mut [u8]) -> Result<usize>

Reads UART receive data into buf, returning the number of bytes read. This function may block.

source

fn read_timeout(&self, buf: &mut [u8], timeout: Duration) -> Result<usize>

Reads UART receive data into buf, returning the number of bytes read. The timeout may be used to specify a duration to wait for data. If timeout expires without any data arriving Ok(0) will be returned, never Err(_).

source

fn write(&self, buf: &[u8]) -> Result<()>

Writes data from buf to the UART.

Provided Methods§

source

fn set_flow_control(&self, flow_control: bool) -> Result<()>

Enables software flow control for writes.

source

fn clear_rx_buffer(&self) -> Result<()>

Clears the UART RX buffer.

source

fn set_break(&self, _enable: bool) -> Result<()>

source

fn set_parity(&self, _parity: Parity) -> Result<()>

source

fn supports_nonblocking_read(&self) -> Result<bool>

Query if nonblocking mio mode is supported.

source

fn register_nonblocking_read( &self, _registry: &Registry, _token: Token ) -> Result<()>

Switch this Uart instance into nonblocking mio mode. Going forward, read() should only be called after mio::poll() has indicated that the given Token is ready.

source

fn nonblocking_help(&self) -> Result<Rc<dyn NonblockingHelp>>

Get the same single NonblockingHelp object as from top level Transport.nonblocking_help().

Trait Implementations§

source§

impl<'a> ConsoleDevice for dyn Uart + 'a

source§

fn console_read(&self, buf: &mut [u8], timeout: Duration) -> Result<usize>

Reads data from the UART to print to the console (used when this UART is the console device).
source§

fn console_write(&self, buf: &[u8]) -> Result<()>

Writes console input data to the UART (used when this UART is the console device).
source§

fn set_break(&self, enable: bool) -> Result<()>

source§

fn supports_nonblocking_read(&self) -> Result<bool>

Query if nonblocking mio mode is supported.
source§

fn register_nonblocking_read( &self, registry: &Registry, token: Token ) -> Result<()>

Switch this Uart instance into nonblocking mio mode. Going forward, read() should only be called after mio::poll() has indicated that the given Token is ready.
source§

fn nonblocking_help(&self) -> Result<Rc<dyn NonblockingHelp>>

Get the same single NonblockingHelp object as from top level Transport.nonblocking_help().
source§

impl Read for &dyn Uart

source§

fn read(&mut self, buf: &mut [u8]) -> Result<usize>

Pull some bytes from this source into the specified buffer, returning how many bytes were read. Read more
1.36.0 · source§

fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>

Like read, except that it reads into a slice of buffers. Read more
source§

fn is_read_vectored(&self) -> bool

🔬This is a nightly-only experimental API. (can_vector)
Determines if this Reader has an efficient read_vectored implementation. Read more
1.0.0 · source§

fn read_to_end(&mut self, buf: &mut Vec<u8, Global>) -> Result<usize, Error>

Read all bytes until EOF in this source, placing them into buf. Read more
1.0.0 · source§

fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>

Read all bytes until EOF in this source, appending them to buf. Read more
1.6.0 · source§

fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>

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

fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Pull some bytes from this source into the specified buffer. Read more
source§

fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Read the exact number of bytes required to fill cursor. Read more
1.0.0 · source§

fn by_ref(&mut self) -> &mut Selfwhere Self: Sized,

Creates a “by reference” adaptor for this instance of Read. Read more
1.0.0 · source§

fn bytes(self) -> Bytes<Self>where Self: Sized,

Transforms this Read instance to an Iterator over its bytes. Read more
1.0.0 · source§

fn chain<R>(self, next: R) -> Chain<Self, R>where R: Read, Self: Sized,

Creates an adapter which will chain this stream with another. Read more
1.0.0 · source§

fn take(self, limit: u64) -> Take<Self>where Self: Sized,

Creates an adapter which will read at most limit bytes from it. Read more

Implementors§