summaryrefslogtreecommitdiffstats
path: root/src/devices/mode/oneshot.rs
diff options
context:
space:
mode:
authorTomasz Kramkowski <tomasz@kramkow.ski>2024-12-08 12:01:31 +0000
committerTomasz Kramkowski <tomasz@kramkow.ski>2024-12-08 12:01:31 +0000
commitcd403a91e6078956445aeb21d6509e863b0592ae (patch)
treeb1bb59ed526081be31494544f8920c39f0588711 /src/devices/mode/oneshot.rs
parent0edd5527161809dfbc0c76e39c462e3a4f00beb7 (diff)
downloadads1x1x-async-cd403a91e6078956445aeb21d6509e863b0592ae.tar.gz
ads1x1x-async-cd403a91e6078956445aeb21d6509e863b0592ae.tar.xz
ads1x1x-async-cd403a91e6078956445aeb21d6509e863b0592ae.zip
Modify to use asyncasync
A changeover from embedded_hal::i2c::I2c to embedded_hal_async::i2c::I2c including changes to all the relevant functions into async functions. Tests have been updated to work using futures-test and embedded-hal-mock with the embedded-hal-async feature. Examples have been kept the same meaning they no longer compile. Currently it doesn't _seem_ like the linux embedded hal can do async i2c so maybe these should be re-written to use embassy?
Diffstat (limited to 'src/devices/mode/oneshot.rs')
-rw-r--r--src/devices/mode/oneshot.rs17
1 files changed, 10 insertions, 7 deletions
diff --git a/src/devices/mode/oneshot.rs b/src/devices/mode/oneshot.rs
index 22b6d51..ba78c84 100644
--- a/src/devices/mode/oneshot.rs
+++ b/src/devices/mode/oneshot.rs
@@ -9,14 +9,14 @@ use crate::{
impl<I2C, IC, CONV, E> Ads1x1x<I2C, IC, CONV, mode::OneShot>
where
- I2C: embedded_hal::i2c::I2c<Error = E>,
+ I2C: embedded_hal_async::i2c::I2c<Error = E>,
CONV: conversion::ConvertMeasurement,
{
/// Changes to continuous operating mode.
- pub fn into_continuous(
+ pub async fn into_continuous(
mut self,
) -> Result<Ads1x1x<I2C, IC, CONV, mode::Continuous>, ModeChangeError<E, Self>> {
- if let Err(Error::I2C(e)) = self.set_operating_mode(OperatingMode::Continuous) {
+ if let Err(Error::I2C(e)) = self.set_operating_mode(OperatingMode::Continuous).await {
return Err(ModeChangeError::I2C(e, self));
}
Ok(Ads1x1x {
@@ -31,15 +31,15 @@ where
})
}
- fn trigger_measurement(&mut self, config: &Config) -> Result<(), Error<E>> {
+ async fn trigger_measurement(&mut self, config: &Config) -> Result<(), Error<E>> {
let config = config.with_high(BitFlags::OS);
- self.write_register(Register::CONFIG, config.bits)
+ self.write_register(Register::CONFIG, config.bits).await
}
}
impl<I2C, IC, CONV, E> Ads1x1x<I2C, IC, CONV, mode::OneShot>
where
- I2C: embedded_hal::i2c::I2c<Error = E>,
+ I2C: embedded_hal_async::i2c::I2c<Error = E>,
CONV: conversion::ConvertMeasurement,
{
/// Requests that the ADC begins a conversion on the specified channel.
@@ -55,9 +55,10 @@ where
/// measurement on a different channel is requested, a new measurement on
/// using the new channel selection is triggered.
#[allow(unused_variables)]
- pub fn read<CH: ChannelId<Self>>(&mut self, channel: CH) -> nb::Result<i16, Error<E>> {
+ pub async fn read<CH: ChannelId<Self>>(&mut self, channel: CH) -> nb::Result<i16, Error<E>> {
if self
.is_measurement_in_progress()
+ .await
.map_err(nb::Error::Other)?
{
return Err(nb::Error::WouldBlock);
@@ -68,11 +69,13 @@ where
// result is ready
let value = self
.read_register(Register::CONVERSION)
+ .await
.map_err(nb::Error::Other)?;
self.a_conversion_was_started = false;
return Ok(CONV::convert_measurement(value));
}
self.trigger_measurement(&config)
+ .await
.map_err(nb::Error::Other)?;
self.config = config;
self.a_conversion_was_started = true;