opentitanlib::transport

Trait Transport

Source
pub trait Transport {
Show 14 methods // Required method fn capabilities(&self) -> Result<Capabilities>; // Provided methods fn apply_default_configuration(&self) -> Result<()> { ... } fn jtag(&self, _opts: &JtagParams) -> Result<Box<dyn JtagChain + '_>> { ... } fn spi(&self, _instance: &str) -> Result<Rc<dyn Target>> { ... } fn i2c(&self, _instance: &str) -> Result<Rc<dyn Bus>> { ... } fn uart(&self, _instance: &str) -> Result<Rc<dyn Uart>> { ... } fn gpio_pin(&self, _instance: &str) -> Result<Rc<dyn GpioPin>> { ... } fn gpio_monitoring(&self) -> Result<Rc<dyn GpioMonitoring>> { ... } fn gpio_bitbanging(&self) -> Result<Rc<dyn GpioBitbanging>> { ... } fn emulator(&self) -> Result<Rc<dyn Emulator>> { ... } fn proxy_ops(&self) -> Result<Rc<dyn ProxyOps>> { ... } fn dispatch(&self, _action: &dyn Any) -> Result<Option<Box<dyn Annotate>>> { ... } fn maintain_connection(&self) -> Result<Rc<dyn MaintainConnection>> { ... } fn nonblocking_help(&self) -> Result<Rc<dyn NonblockingHelp>> { ... }
}
Expand description

A transport object is a factory for the low-level interfaces provided by a given communications backend.

Required Methods§

Source

fn capabilities(&self) -> Result<Capabilities>

Returns a Capabilities object to check the capabilities of this transport object.

Provided Methods§

Source

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

Resets the transport to power-on condition. That is, pin/uart/spi configuration reverts to default, ongoing operations are cancelled, etc.

Source

fn jtag(&self, _opts: &JtagParams) -> Result<Box<dyn JtagChain + '_>>

Returns a JtagChain implementation.

Source

fn spi(&self, _instance: &str) -> Result<Rc<dyn Target>>

Returns a SPI Target implementation.

Source

fn i2c(&self, _instance: &str) -> Result<Rc<dyn Bus>>

Returns a I2C Bus implementation.

Source

fn uart(&self, _instance: &str) -> Result<Rc<dyn Uart>>

Returns a Uart implementation.

Source

fn gpio_pin(&self, _instance: &str) -> Result<Rc<dyn GpioPin>>

Returns a GpioPin implementation.

Source

fn gpio_monitoring(&self) -> Result<Rc<dyn GpioMonitoring>>

Returns a GpioMonitoring implementation, for logic analyzer functionality.

Source

fn gpio_bitbanging(&self) -> Result<Rc<dyn GpioBitbanging>>

Returns a GpioBitbanging implementation, for timed and synchronized manipulation of multiple GPIO pins.

Source

fn emulator(&self) -> Result<Rc<dyn Emulator>>

Returns a Emulator implementation.

Source

fn proxy_ops(&self) -> Result<Rc<dyn ProxyOps>>

Methods available only on Proxy implementation.

Source

fn dispatch(&self, _action: &dyn Any) -> Result<Option<Box<dyn Annotate>>>

Invoke non-standard functionality of some Transport implementations.

Source

fn maintain_connection(&self) -> Result<Rc<dyn MaintainConnection>>

As long as the returned MaintainConnection object is kept by the caller, this driver may assume that no other opentitantool processes attempt to access the same debugger device. This allows for optimzations such as keeping USB handles open across function invocations.

Source

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

Before nonblocking operations can be used on Uart or other traits, this NonblockingHelp object must be invoked, in order to get the Transport implementation a chance to register its internal event sources with the main event loop.

Implementors§

Source§

impl Transport for Dediprog

Source§

impl Transport for HyperdebugDfu

The device does not support any part of the Transport trait, except the UpdateFirmware action.

Source§

impl Transport for Proxy

Source§

impl Transport for EmptyTransport

Source§

impl Transport for Ti50Emulator

Implementation of the Transport trait backed based on TockOS HostEmulation port.

Source§

impl Transport for Ultradebug

Source§

impl Transport for Verilator

Source§

impl<B: Board + 'static> Transport for ChipWhisperer<B>

Source§

impl<C: Chip> Transport for Ftdi<C>

Source§

impl<T: Flavor> Transport for Hyperdebug<T>