summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/channels.rs9
-rw-r--r--src/devices/mode/oneshot.rs20
-rw-r--r--src/lib.rs8
-rw-r--r--src/types.rs11
4 files changed, 41 insertions, 7 deletions
diff --git a/src/channels.rs b/src/channels.rs
index c0f0ff9..a4c806c 100644
--- a/src/channels.rs
+++ b/src/channels.rs
@@ -23,15 +23,24 @@ pub mod channel {
pub struct DifferentialA2A3;
}
+/// ADC input channel selection
#[derive(Debug, Clone, Copy)]
pub enum ChannelSelection {
+ /// Measure single-ended signal on input channel 0
SingleA0,
+ /// Measure single-ended signal on input channel 1
SingleA1,
+ /// Measure single-ended signal on input channel 2
SingleA2,
+ /// Measure single-ended signal on input channel 3
SingleA3,
+ /// Measure signal on input channel 0 differentially to signal on input channel 1
DifferentialA0A1,
+ /// Measure signal on input channel 0 differentially to signal on input channel 3
DifferentialA0A3,
+ /// Measure signal on input channel 1 differentially to signal on input channel 3
DifferentialA1A3,
+ /// Measure signal on input channel 2 differentially to signal on input channel 3
DifferentialA2A3,
}
diff --git a/src/devices/mode/oneshot.rs b/src/devices/mode/oneshot.rs
index 665ce33..fa4d3b8 100644
--- a/src/devices/mode/oneshot.rs
+++ b/src/devices/mode/oneshot.rs
@@ -1,7 +1,7 @@
//! Common functions
use crate::{
- channels::ChannelSelection, conversion, devices::OperatingMode, interface, mode, Ads1x1x,
- BitFlags, Config, Error, ModeChangeError, Register,
+ conversion, devices::OperatingMode, interface, mode, Ads1x1x, BitFlags, ChannelSelection,
+ Config, DynamicOneShot, Error, ModeChangeError, Register,
};
use core::marker::PhantomData;
use embedded_hal::adc;
@@ -58,13 +58,25 @@ where
/// measurement on a different channel is requested, a new measurement on
/// using the new channel selection is triggered.
fn read(&mut self, _channel: &mut CH) -> nb::Result<i16, Self::Error> {
+ <Self as DynamicOneShot>::read(self, CH::channel())
+ }
+}
+
+impl<DI, IC, CONV, E> DynamicOneShot for Ads1x1x<DI, IC, CONV, mode::OneShot>
+where
+ DI: interface::ReadData<Error = E> + interface::WriteData<Error = E>,
+ CONV: conversion::ConvertMeasurement,
+{
+ type Error = Error<E>;
+
+ fn read(&mut self, channel: ChannelSelection) -> nb::Result<i16, Self::Error> {
if self
.is_measurement_in_progress()
.map_err(nb::Error::Other)?
{
return Err(nb::Error::WouldBlock);
}
- let same_channel = self.config == self.config.with_mux_bits(CH::channel());
+ let same_channel = self.config == self.config.with_mux_bits(channel);
if self.a_conversion_was_started && same_channel {
// result is ready
let value = self
@@ -74,7 +86,7 @@ where
self.a_conversion_was_started = false;
return Ok(CONV::convert_measurement(value));
}
- let config = self.config.with_mux_bits(CH::channel());
+ let config = self.config.with_mux_bits(channel);
self.trigger_measurement(&config)
.map_err(nb::Error::Other)?;
self.config = config;
diff --git a/src/lib.rs b/src/lib.rs
index 418fc46..90a0f62 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -237,7 +237,7 @@ impl BitFlags {
}
mod channels;
-pub use crate::channels::channel;
+pub use crate::channels::{channel, ChannelSelection};
mod construction;
mod conversion;
pub use crate::conversion::{ConvertMeasurement, ConvertThreshold};
@@ -250,14 +250,16 @@ mod types;
use crate::types::Config;
pub use crate::types::{
mode, Ads1x1x, ComparatorLatching, ComparatorMode, ComparatorPolarity, ComparatorQueue,
- DataRate12Bit, DataRate16Bit, Error, FullScaleRange, ModeChangeError, SlaveAddr,
+ DataRate12Bit, DataRate16Bit, DynamicOneShot, Error, FullScaleRange, ModeChangeError,
+ SlaveAddr,
};
mod private {
- use super::{ic, interface};
+ use super::{ic, interface, Ads1x1x};
pub trait Sealed {}
impl<I2C> Sealed for interface::I2cInterface<I2C> {}
+ impl<DI, IC, CONV, MODE> Sealed for Ads1x1x<DI, IC, CONV, MODE> {}
impl Sealed for ic::Resolution12Bit {}
impl Sealed for ic::Resolution16Bit {}
diff --git a/src/types.rs b/src/types.rs
index 2b9fc02..957825e 100644
--- a/src/types.rs
+++ b/src/types.rs
@@ -1,5 +1,6 @@
//! Type definitions.
+use crate::{channels::ChannelSelection, private};
use core::marker::PhantomData;
/// Errors in this crate
@@ -70,6 +71,7 @@ pub enum DataRate16Bit {
/// 860 SPS
Sps860,
}
+
/// Comparator mode (only for ADS1x14, ADS1x15)
#[derive(Debug, Clone, Copy, PartialEq)]
pub enum ComparatorMode {
@@ -257,6 +259,15 @@ pub struct Ads1x1x<DI, 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::DEVICE_BASE_ADDRESS as ADDR;