opentitanlib::io::gpio

Trait GpioPin

Source
pub trait GpioPin {
    // Required methods
    fn read(&self) -> Result<bool>;
    fn write(&self, value: bool) -> Result<()>;
    fn set_mode(&self, mode: PinMode) -> Result<()>;
    fn set_pull_mode(&self, mode: PullMode) -> Result<()>;

    // Provided methods
    fn analog_read(&self) -> Result<f32> { ... }
    fn analog_write(&self, _volts: f32) -> Result<()> { ... }
    fn set(
        &self,
        mode: Option<PinMode>,
        value: Option<bool>,
        pull: Option<PullMode>,
        analog_value: Option<f32>,
    ) -> Result<()> { ... }
    fn get_internal_pin_name(&self) -> Option<&str> { ... }
}
Expand description

A trait which represents a single GPIO pin.

Required Methods§

Source

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

Reads the value of the GPIO pin.

Source

fn write(&self, value: bool) -> Result<()>

Sets the value of the GPIO pin to value.

Source

fn set_mode(&self, mode: PinMode) -> Result<()>

Sets the mode of the GPIO pin as input, output, or open drain I/O.

Source

fn set_pull_mode(&self, mode: PullMode) -> Result<()>

Sets the weak pull resistors of the GPIO pin.

Provided Methods§

Source

fn analog_read(&self) -> Result<f32>

Reads the analog value of the GPIO pin in Volts. AnalogInput mode disables digital circuitry for better results, but this method may also work in other modes.

Source

fn analog_write(&self, _volts: f32) -> Result<()>

Sets the analog value of the GPIO pin to value Volts, must be in AnalogOutput mode.

Source

fn set( &self, mode: Option<PinMode>, value: Option<bool>, pull: Option<PullMode>, analog_value: Option<f32>, ) -> Result<()>

Simultaneously sets mode, value, and weak pull, some transports may guarantee atomicity.

Source

fn get_internal_pin_name(&self) -> Option<&str>

Not meant for API clients, this method returns the pin name as it is known to the transport (which may have been through one or more alias mappings from the name provided by the API client.) This method is used by implementations of GpioMonitoring.

Implementors§

Source§

impl GpioPin for DediprogPin

Source§

impl GpioPin for VoltagePin

Source§

impl GpioPin for opentitanlib::transport::ftdi::gpio::Pin

Source§

impl GpioPin for C2d2ResetPin

Source§

impl GpioPin for HyperdebugGpioPin

Source§

impl GpioPin for ServoMicroResetPin

Source§

impl GpioPin for UltradebugGpioPin

Source§

impl GpioPin for VerilatorGpioPin

Source§

impl<B: Board> GpioPin for opentitanlib::transport::chip_whisperer::gpio::Pin<B>