summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/channel.rs24
-rw-r--r--src/devices/mode/oneshot.rs52
-rw-r--r--src/lib.rs5
-rw-r--r--src/types.rs11
4 files changed, 31 insertions, 61 deletions
diff --git a/src/channel.rs b/src/channel.rs
index 27262d4..4b7555e 100644
--- a/src/channel.rs
+++ b/src/channel.rs
@@ -1,33 +1,31 @@
//! ADC input channels
use crate::{ic, Ads1x1x, BitFlags as BF, Config};
-mod private {
- pub trait Sealed {}
-}
+use private::ChannelSelection;
/// Marker type for an ADC input channel.
-pub trait ChannelId<T>: private::Sealed {
+pub trait ChannelId<T> {
/// Get the channel.
fn channel_id() -> ChannelSelection;
}
macro_rules! impl_channels {
($(#[doc = $doc:expr] $CH:ident => [$($IC:ident),+]),+ $(,)?) => {
- #[derive(Debug, Clone, Copy)]
- /// ADC input channel selection.
- pub enum ChannelSelection {
- $(
- #[doc = $doc]
- $CH,
- )+
+ mod private {
+ #[derive(Debug, Clone, Copy)]
+ /// ADC input channel selection.
+ pub enum ChannelSelection {
+ $(
+ #[doc = $doc]
+ $CH,
+ )+
+ }
}
$(
#[doc = $doc]
pub struct $CH;
- impl private::Sealed for $CH {}
-
$(
impl<I2C, CONV, MODE> ChannelId<Ads1x1x<I2C, ic::$IC, CONV, MODE>> for $CH {
fn channel_id() -> ChannelSelection {
diff --git a/src/devices/mode/oneshot.rs b/src/devices/mode/oneshot.rs
index 957eba5..10cdadb 100644
--- a/src/devices/mode/oneshot.rs
+++ b/src/devices/mode/oneshot.rs
@@ -1,7 +1,7 @@
//! Common functions
use crate::{
- conversion, devices::OperatingMode, mode, Ads1x1x, BitFlags, ChannelId, ChannelSelection,
- Config, DynamicOneShot, Error, ModeChangeError, Register,
+ conversion, devices::OperatingMode, mode, Ads1x1x, BitFlags, ChannelId, Config, Error,
+ ModeChangeError, Register,
};
use core::marker::PhantomData;
@@ -40,14 +40,28 @@ where
I2C: embedded_hal::i2c::I2c<Error = E>,
CONV: conversion::ConvertMeasurement,
{
- fn read_inner(&mut self, channel: ChannelSelection) -> nb::Result<i16, Error<E>> {
+ /// Request that the ADC begin a conversion on the specified channel.
+ ///
+ /// The output value will be within `[2047..-2048]` for 12-bit devices
+ /// (`ADS101x`) and within `[32767..-32768]` for 16-bit devices (`ADS111x`).
+ /// The voltage that these values correspond to must be calculated using
+ /// the full-scale range selected.
+ /// See [`FullScaleRange`](enum.FullScaleRange.html).
+ ///
+ /// Returns `nb::Error::WouldBlock` while a measurement is in progress.
+ ///
+ /// In case a measurement was requested and after is it is finished a
+ /// 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>> {
if self
.is_measurement_in_progress()
.map_err(nb::Error::Other)?
{
return Err(nb::Error::WouldBlock);
}
- let config = self.config.with_mux_bits(channel);
+ let config = self.config.with_mux_bits(CH::channel_id());
let same_channel = self.config == config;
if self.a_conversion_was_started && same_channel {
// result is ready
@@ -63,34 +77,4 @@ where
self.a_conversion_was_started = true;
Err(nb::Error::WouldBlock)
}
-
- /// Request that the ADC begin a conversion on the specified channel.
- ///
- /// The output value will be within `[2047..-2048]` for 12-bit devices
- /// (`ADS101x`) and within `[32767..-32768]` for 16-bit devices (`ADS111x`).
- /// The voltage that these values correspond to must be calculated using
- /// the full-scale range selected.
- /// See [`FullScaleRange`](enum.FullScaleRange.html).
- ///
- /// Returns `nb::Error::WouldBlock` while a measurement is in progress.
- ///
- /// In case a measurement was requested and after is it is finished a
- /// 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>> {
- self.read_inner(CH::channel_id())
- }
-}
-
-impl<I2C, IC, CONV, E> DynamicOneShot for Ads1x1x<I2C, IC, CONV, mode::OneShot>
-where
- I2C: embedded_hal::i2c::I2c<Error = E>,
- CONV: conversion::ConvertMeasurement,
-{
- type Error = Error<E>;
-
- fn read(&mut self, channel: ChannelSelection) -> nb::Result<i16, Self::Error> {
- self.read_inner(channel)
- }
}
diff --git a/src/lib.rs b/src/lib.rs
index 277b2ad..cd63c4b 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -213,7 +213,7 @@ impl BitFlags {
}
pub mod channel;
-pub use channel::{ChannelId, ChannelSelection};
+pub use channel::ChannelId;
mod construction;
mod conversion;
pub use crate::conversion::{ConvertMeasurement, ConvertThreshold};
@@ -224,8 +224,7 @@ mod types;
use crate::types::Config;
pub use crate::types::{
mode, Ads1x1x, ComparatorLatching, ComparatorMode, ComparatorPolarity, ComparatorQueue,
- DataRate12Bit, DataRate16Bit, DynamicOneShot, Error, FullScaleRange, ModeChangeError,
- SlaveAddr,
+ DataRate12Bit, DataRate16Bit, Error, FullScaleRange, ModeChangeError, SlaveAddr,
};
mod private {
diff --git a/src/types.rs b/src/types.rs
index 31b4cdb..bcda430 100644
--- a/src/types.rs
+++ b/src/types.rs
@@ -2,8 +2,6 @@
use core::marker::PhantomData;
-use crate::{private, ChannelSelection};
-
/// Errors in this crate
#[derive(Debug)]
pub enum Error<E> {
@@ -235,15 +233,6 @@ pub struct Ads1x1x<I2C, IC, CONV, MODE> {
pub(crate) _mode: PhantomData<MODE>,
}
-/// Multi channel One-shot ADC
-pub trait DynamicOneShot: private::Sealed {
- /// Error type
- type Error;
-
- /// Read a measurement
- fn read(&mut self, channel: ChannelSelection) -> nb::Result<i16, Self::Error>;
-}
-
#[cfg(test)]
mod tests {
use crate::{FullScaleRange, SlaveAddr};