2021-03-01 23:32:23 +00:00
|
|
|
#![cfg_attr(not(feature = "std"), no_std)]
|
2022-07-09 22:58:05 +00:00
|
|
|
#![cfg_attr(feature = "nightly", feature(generic_associated_types, type_alias_impl_trait))]
|
2022-07-19 05:57:39 +00:00
|
|
|
#![warn(missing_docs)]
|
|
|
|
|
|
|
|
//! Utilities to use `embedded-hal` traits with Embassy.
|
2021-03-01 23:32:23 +00:00
|
|
|
|
2022-07-09 22:05:57 +00:00
|
|
|
#[cfg(feature = "nightly")]
|
2021-12-17 11:50:48 +00:00
|
|
|
pub mod adapter;
|
2022-07-09 22:05:57 +00:00
|
|
|
|
2022-05-26 16:54:58 +00:00
|
|
|
pub mod shared_bus;
|
2022-07-08 13:47:47 +00:00
|
|
|
|
2022-07-19 05:57:39 +00:00
|
|
|
/// Set the configuration of a peripheral driver.
|
|
|
|
///
|
|
|
|
/// This trait is intended to be implemented by peripheral drivers such as SPI
|
|
|
|
/// and I2C. It allows changing the configuration at runtime.
|
|
|
|
///
|
|
|
|
/// The exact type of the "configuration" is defined by each individual driver, since different
|
|
|
|
/// drivers support different options. Therefore it is defined as an associated type.
|
|
|
|
///
|
|
|
|
/// For example, it is used by [`SpiDeviceWithConfig`](crate::shared_bus::asynch::spi::SpiDeviceWithConfig) and
|
|
|
|
/// [`I2cDeviceWithConfig`](crate::shared_bus::asynch::i2c::I2cDeviceWithConfig) to allow different
|
|
|
|
/// devices on the same bus to use different communication settings.
|
2022-07-08 22:00:55 +00:00
|
|
|
pub trait SetConfig {
|
2022-07-19 05:57:39 +00:00
|
|
|
/// The configuration type used by this driver.
|
2022-07-08 22:00:55 +00:00
|
|
|
type Config;
|
2022-07-19 05:57:39 +00:00
|
|
|
|
|
|
|
/// Set the configuration of the driver.
|
2022-07-08 22:00:55 +00:00
|
|
|
fn set_config(&mut self, config: &Self::Config);
|
2022-07-08 13:47:47 +00:00
|
|
|
}
|