Struct kernel::hil::gpio::InterruptValueWrapper
source · pub struct InterruptValueWrapper<'a, IP: InterruptPin<'a>> { /* private fields */ }
Expand description
Standard implementation of InterruptWithValue: handles an
gpio::Client::fired
and passes it up as a
gpio::ClientWithValue::fired
.
Implementations§
source§impl<'a, IP: InterruptPin<'a>> InterruptValueWrapper<'a, IP>
impl<'a, IP: InterruptPin<'a>> InterruptValueWrapper<'a, IP>
Trait Implementations§
source§impl<'a, IP: InterruptPin<'a>> Client for InterruptValueWrapper<'a, IP>
impl<'a, IP: InterruptPin<'a>> Client for InterruptValueWrapper<'a, IP>
source§impl<'a, IP: InterruptPin<'a>> Configure for InterruptValueWrapper<'a, IP>
impl<'a, IP: InterruptPin<'a>> Configure for InterruptValueWrapper<'a, IP>
source§fn configuration(&self) -> Configuration
fn configuration(&self) -> Configuration
Return the current pin configuration.
source§fn make_output(&self) -> Configuration
fn make_output(&self) -> Configuration
Make the pin an output, returning the current configuration,
which should be either
Configuration::Output
or
Configuration::InputOutput
.source§fn disable_output(&self) -> Configuration
fn disable_output(&self) -> Configuration
Disable the pin as an output, returning the current configuration.
source§fn make_input(&self) -> Configuration
fn make_input(&self) -> Configuration
Make the pin an input, returning the current configuration,
which should be ither
Configuration::Input
or
Configuration::InputOutput
.source§fn disable_input(&self) -> Configuration
fn disable_input(&self) -> Configuration
Disable the pin as an input, returning the current configuration.
source§fn deactivate_to_low_power(&self)
fn deactivate_to_low_power(&self)
Put a pin into its lowest power state, with no guarantees on
if it is enabled or not. Implementations are free to use any
state (e.g. input, output, disable, etc.) the hardware pin
supports to ensure the pin is as low power as possible.
Re-enabling the pin requires reconfiguring it (i.e. the state
of its enabled configuration is not stored).
source§fn set_floating_state(&self, state: FloatingState)
fn set_floating_state(&self, state: FloatingState)
Set the floating state of the pin.
source§fn floating_state(&self) -> FloatingState
fn floating_state(&self) -> FloatingState
Return the current floating state of the pin.
source§impl<'a, IP: InterruptPin<'a>> Input for InterruptValueWrapper<'a, IP>
impl<'a, IP: InterruptPin<'a>> Input for InterruptValueWrapper<'a, IP>
source§fn read(&self) -> bool
fn read(&self) -> bool
Get the current state of an input GPIO pin. For an output
pin, return the output; for an input pin, return the input;
for disabled or function pins the value is undefined.
source§fn read_activation(&self, mode: ActivationMode) -> ActivationState
fn read_activation(&self, mode: ActivationMode) -> ActivationState
Get the current state of a GPIO pin, for a given activation mode.
source§impl<'a, IP: InterruptPin<'a>> InterruptWithValue<'a> for InterruptValueWrapper<'a, IP>
impl<'a, IP: InterruptPin<'a>> InterruptWithValue<'a> for InterruptValueWrapper<'a, IP>
source§fn set_client(&self, client: &'a dyn ClientWithValue)
fn set_client(&self, client: &'a dyn ClientWithValue)
Set the client for interrupt events.
source§fn is_pending(&self) -> bool
fn is_pending(&self) -> bool
Return whether this interrupt is pending
source§fn enable_interrupts(&self, edge: InterruptEdge) -> Result<(), ErrorCode>
fn enable_interrupts(&self, edge: InterruptEdge) -> Result<(), ErrorCode>
Enable an interrupt on the GPIO pin. This does not
configure the pin except to enable an interrupt: it
should be separately configured as an input, etc.
Returns:
Ok(()) - the interrupt was set up properly
FAIL - the interrupt was not set up properly; this is due to
not having an underlying interrupt source yet, i.e.
the struct is not yet fully initialized.
source§fn disable_interrupts(&self)
fn disable_interrupts(&self)
Disable interrupts for the GPIO pin.
source§impl<'a, IP: InterruptPin<'a>> Output for InterruptValueWrapper<'a, IP>
impl<'a, IP: InterruptPin<'a>> Output for InterruptValueWrapper<'a, IP>
source§fn set(&self)
fn set(&self)
Set the GPIO pin high. If the pin is not an output or
input/output, this call is ignored.
source§fn clear(&self)
fn clear(&self)
Set the GPIO pin low. If the pin is not an output or
input/output, this call is ignored.
source§fn toggle(&self) -> bool
fn toggle(&self) -> bool
Toggle the GPIO pin. If the pin was high, set it low. If
the pin was low, set it high. If the pin is not an output or
input/output, this call is ignored. Return the new value
of the pin.
source§fn write_activation(&self, state: ActivationState, mode: ActivationMode)
fn write_activation(&self, state: ActivationState, mode: ActivationMode)
Activate or deactivate a GPIO pin, for a given activation mode.
Auto Trait Implementations§
impl<'a, IP> !Freeze for InterruptValueWrapper<'a, IP>
impl<'a, IP> !RefUnwindSafe for InterruptValueWrapper<'a, IP>
impl<'a, IP> !Send for InterruptValueWrapper<'a, IP>
impl<'a, IP> !Sync for InterruptValueWrapper<'a, IP>
impl<'a, IP> Unpin for InterruptValueWrapper<'a, IP>
impl<'a, IP> !UnwindSafe for InterruptValueWrapper<'a, IP>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more