opentitanlib::transport::verilator::gpio

Struct VerilatorGpioPin

Source
pub struct VerilatorGpioPin { /* private fields */ }

Trait Implementations§

Source§

impl GpioPin for VerilatorGpioPin

Source§

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

Atomically sets mode, value, and weak pull.

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

Auto Trait Implementations§

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

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

Source§

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

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

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

Source§

fn into(self) -> U

Calls U::from(self).

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

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

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

Source§

type Error = Infallible

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

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

Performs the conversion.
Source§

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

Source§

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

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

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

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V