1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70
// Licensed under the Apache License, Version 2.0 or the MIT License.
// SPDX-License-Identifier: Apache-2.0 OR MIT
// Copyright Tock Contributors 2022.
//! Interface for GPIO pins that require split-phase operation to control.
use crate::hil;
use crate::ErrorCode;
/// Interface for banks of asynchronous GPIO pins. GPIO pins are asynchronous
/// when there is an asynchronous interface used to control them. The most
/// common example is when using a GPIO extender on an I2C or SPI bus. With
/// asynchronous GPIO functions, every config action results in an eventual
/// callback function that indicates that the configuration has finished
/// (unless the initial function call returns an error code, then no callback
/// will be generated).
///
/// Asynchronous GPIO pins are grouped into ports because it is assumed that
/// the remote entity that is controlling the pins can control multiple pins.
/// Typically, a port will be provided by a particular driver.
///
/// The API for the Port mirrors the synchronous GPIO interface.
pub trait Port {
/// Try to disable a GPIO pin. This cannot be supported for all devices.
fn disable(&self, pin: usize) -> Result<(), ErrorCode>;
/// Configure a pin as an ouput GPIO.
fn make_output(&self, pin: usize) -> Result<(), ErrorCode>;
/// Configure a pin as an input GPIO. Not all FloatingMode settings may
/// be supported by a given device.
fn make_input(&self, pin: usize, mode: hil::gpio::FloatingState) -> Result<(), ErrorCode>;
/// Get the state (0 or 1) of an input pin. The value will be returned
/// via a callback.
fn read(&self, pin: usize) -> Result<(), ErrorCode>;
/// Toggle an output GPIO pin.
fn toggle(&self, pin: usize) -> Result<(), ErrorCode>;
/// Assert a GPIO pin high.
fn set(&self, pin: usize) -> Result<(), ErrorCode>;
/// Clear a GPIO pin low.
fn clear(&self, pin: usize) -> Result<(), ErrorCode>;
/// Setup an interrupt on a GPIO input pin. The identifier should be
/// the port number and will be returned when the interrupt callback
/// fires.
fn enable_interrupt(&self, pin: usize, mode: hil::gpio::InterruptEdge)
-> Result<(), ErrorCode>;
/// Disable an interrupt on a GPIO input pin.
fn disable_interrupt(&self, pin: usize) -> Result<(), ErrorCode>;
fn is_pending(&self, pin: usize) -> bool;
}
/// The gpio_async Client interface is used to both receive callbacks
/// when a configuration command finishes and to handle interrupt events
/// from pins with interrupts enabled.
pub trait Client {
/// Called when an interrupt occurs. The pin that interrupted is included,
/// and the identifier that was passed with the call to `enable_interrupt`
/// is also returned.
fn fired(&self, pin: usize, identifier: usize);
/// Done is called when a configuration command finishes.
fn done(&self, value: usize);
}