Struct Io

Source
pub struct Io<'d> { /* private fields */ }
Available on crate feature unstable only.
Expand description

General Purpose Input/Output driver

§Stability

This API is marked as unstable and is only available when the unstable crate feature is enabled. This comes with no stability guarantees, and could be changed or removed at any time.

Implementations§

Source§

impl<'d> Io<'d>

Source

pub fn new(_io_mux: IO_MUX<'d>) -> Self

Initialize the I/O driver.

§Stability

This API is marked as unstable and is only available when the unstable crate feature is enabled. This comes with no stability guarantees, and could be changed or removed at any time.

Source

pub fn set_interrupt_priority(&self, prio: Priority)

Set the interrupt priority for GPIO interrupts.

§Panics

Panics if passed interrupt handler is invalid (e.g. has priority None)

§Stability

This API is marked as unstable and is only available when the unstable crate feature is enabled. This comes with no stability guarantees, and could be changed or removed at any time.

Source

pub fn set_interrupt_handler(&mut self, handler: InterruptHandler)

Registers an interrupt handler for all GPIO pins.

Note that when using interrupt handlers registered by this function, or by defining a #[no_mangle] unsafe extern "C" fn GPIO() function, we do not clear the interrupt status register or the interrupt enable setting for you. Based on your use case, you need to do one of this yourself:

  • Disabling the interrupt enable setting for the GPIO pin allows you to handle an event once per call to listen(). Using this method, the is_interrupt_set() method will return true if the interrupt is set even after your handler has finished running.
  • Clearing the interrupt status register allows you to handle an event repeatedly after listen() is called. Using this method, is_interrupt_set() will return false after your handler has finished running.
§Panics

Panics if passed interrupt handler is invalid (e.g. has priority None)

§Stability

This API is marked as unstable and is only available when the unstable crate feature is enabled. This comes with no stability guarantees, and could be changed or removed at any time.

Trait Implementations§

Source§

impl<'d> Debug for Io<'d>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl InterruptConfigurable for Io<'_>

§Stability

This API is marked as unstable and is only available when the unstable crate feature is enabled. This comes with no stability guarantees, and could be changed or removed at any time.

Source§

fn set_interrupt_handler(&mut self, handler: InterruptHandler)

Registers an interrupt handler for the peripheral. Read more

Auto Trait Implementations§

§

impl<'d> Freeze for Io<'d>

§

impl<'d> RefUnwindSafe for Io<'d>

§

impl<'d> Send for Io<'d>

§

impl<'d> Sync for Io<'d>

§

impl<'d> Unpin for Io<'d>

§

impl<'d> !UnwindSafe for Io<'d>

Blanket Implementations§

§

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

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

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

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

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

§

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

Mutably borrows from an owned value. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

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

§

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
§

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

§

type Error = Infallible

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

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

Performs the conversion.
§

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

§

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

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

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

Performs the conversion.