From c49770ec3656b97a098b6f6ea348d4d6c43cb327 Mon Sep 17 00:00:00 2001 From: Diego Barrios Romero Date: Sun, 21 Jun 2020 23:06:36 +0200 Subject: Extract type definitions into separate module --- src/lib.rs | 252 ++--------------------------------------------------------- src/types.rs | 245 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 252 insertions(+), 245 deletions(-) create mode 100644 src/types.rs (limited to 'src') diff --git a/src/lib.rs b/src/lib.rs index 34ef219..4444c68 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -191,185 +191,8 @@ #![deny(missing_docs)] #![no_std] -use core::marker::PhantomData; - -/// Errors in this crate -#[derive(Debug)] -pub enum Error { - /// I²C bus error - I2C(E), - /// Invalid input data provided - InvalidInputData, -} - -/// Error type for mode changes. -/// -/// This allows to retrieve the unchanged device in case of an error. -pub enum ModeChangeError { - /// I²C bus error while changing mode. - /// - /// `E` is the error that happened. - /// `DEV` is the device with the mode unchanged. - I2C(E, DEV), -} - const DEVICE_BASE_ADDRESS: u8 = 0b100_1000; -/// Mode marker types -pub mod mode { - /// One-shot operating mode / power-down state (default) - pub struct OneShot(()); - - /// Continuous conversion mode - pub struct Continuous(()); -} - -/// Data rate for ADS1013, ADS1014, ADS1015 -#[derive(Debug, Clone, Copy, PartialEq)] -pub enum DataRate12Bit { - /// 128 SPS - Sps128, - /// 250 SPS - Sps250, - /// 490 SPS - Sps490, - /// 920 SPS - Sps920, - /// 1600 SPS (default) - Sps1600, - /// 2400 SPS - Sps2400, - /// 3300 SPS - Sps3300, -} - -/// Data rate for ADS1113, ADS1114, ADS1115 -#[derive(Debug, Clone, Copy, PartialEq)] -pub enum DataRate16Bit { - /// 8 SPS - Sps8, - /// 16 SPS - Sps16, - /// 32 SPS - Sps32, - /// 64 SPS - Sps64, - /// 128 SPS (default) - Sps128, - /// 250 SPS - Sps250, - /// 475 SPS - Sps475, - /// 860 SPS - Sps860, -} -/// Comparator mode (only for ADS1x14, ADS1x15) -#[derive(Debug, Clone, Copy, PartialEq)] -pub enum ComparatorMode { - /// Traditional comparator (default) - /// - /// In this mode the ALERT/RDY pin asserts (according to selected active - /// polarity) when the conversion data exceeds the limit set as *high* - /// threshold and remains active until the conversion data falls below the - /// value set as *low* threshold. - Traditional, - /// Window comparator - /// - /// In this mode the ALERT/RDY pin asserts (according to selected active - /// polarity) when the conversion data exceeds the value set as *high* - /// threshold or goes below the value set as *low* temperature threshold. - Window, -} - -/// Comparator polarity (only for ADS1x14, ADS1x15) -#[derive(Debug, Clone, Copy, PartialEq)] -pub enum ComparatorPolarity { - /// Active low (default) - ActiveLow, - /// Active high - ActiveHigh, -} - -/// Comparator polarity (only for ADS1x14, ADS1x15) -/// -/// Select whether the ALERT/RDY pin latches after being asserted or clears -/// after conversions are within the margin of the upper and lower -/// threshold values. -#[derive(Debug, Clone, Copy, PartialEq)] -pub enum ComparatorLatching { - /// Nonlatching (default) - /// - /// The ALERT/RDY pin does not latch when asserted. - Nonlatching, - /// Latching - /// - /// The asserted ALERT/RDY pin remains latched until conversion data are - /// read by the master or an appropriate SMBus alert response is sent by - /// the master. The device responds with its address, and it is the lowest - /// address currently asserting the ALERT/RDY bus line. - Latching, -} - -/// Comparator alert queue (only for ADS1x14, ADS1x15) -/// -/// The default state of the comparator is deactivated. It can be activated by setting -/// the comparator queue. -#[derive(Debug, Clone, Copy, PartialEq)] -pub enum ComparatorQueue { - /// Activate comparator and assert after one conversion exceeding thresholds - One, - /// Activate comparator and assert after two consecutive conversions exceeding thresholds - Two, - /// Activate comparator and assert after four consecutive conversions exceeding thresholds - Four, -} - -/// Full-scale range configuration for the programmable gain amplifier (PGA) (only for ADS1x14, ADS1x15) -/// -/// This sets the input voltage measurable range. -/// The FSR is fixed at ±2.048 V in the ADS1x13. -#[derive(Clone, Copy, Debug, PartialEq)] -#[allow(non_camel_case_types)] -pub enum FullScaleRange { - /// The measurable range is ±6.144V. - Within6_144V, - /// The measurable range is ±4.096V. - Within4_096V, - /// The measurable range is ±2.048V. (default) - Within2_048V, - /// The measurable range is ±1.024V. - Within1_024V, - /// The measurable range is ±0.512V. - Within0_512V, - /// The measurable range is ±0.256V. - Within0_256V, -} - -/// Possible slave addresses -#[derive(Debug, Clone, Copy, PartialEq)] -pub enum SlaveAddr { - /// Default slave address - Default, - /// Alternative slave address providing bit values for A1 and A0 - Alternative(bool, bool), -} - -impl Default for SlaveAddr { - /// Default slave address - fn default() -> Self { - SlaveAddr::Default - } -} - -impl SlaveAddr { - fn addr(self, default: u8) -> u8 { - match self { - SlaveAddr::Default => default, - SlaveAddr::Alternative(a1, a0) => default | ((a1 as u8) << 1) | a0 as u8, - } - } -} - struct Register; impl Register { @@ -399,52 +222,12 @@ impl BitFlags { const COMP_QUE0: u16 = 0b0000_0000_0000_0001; } -#[derive(Debug, Clone, PartialEq)] -struct Config { - bits: u16, -} - -impl Config { - fn is_high(&self, mask: u16) -> bool { - (self.bits & mask) != 0 - } - - fn with_high(&self, mask: u16) -> Self { - Config { - bits: self.bits | mask, - } - } - fn with_low(&self, mask: u16) -> Self { - Config { - bits: self.bits & !mask, - } - } -} - -impl Default for Config { - fn default() -> Self { - Config { bits: 0x8583 } - } -} - -impl Default for FullScaleRange { - fn default() -> Self { - FullScaleRange::Within2_048V - } -} - -/// ADS1x1x ADC driver -#[derive(Debug, Default)] -pub struct Ads1x1x { - iface: DI, - config: Config, - fsr: FullScaleRange, - a_conversion_was_started: bool, - _conv: PhantomData, - _ic: PhantomData, - _mode: PhantomData, -} - +mod types; +use crate::types::Config; +pub use crate::types::{ + mode, Ads1x1x, ComparatorLatching, ComparatorMode, ComparatorPolarity, ComparatorQueue, + DataRate12Bit, DataRate16Bit, Error, FullScaleRange, ModeChangeError, SlaveAddr, +}; mod channels; #[doc(hidden)] pub mod ic; @@ -454,8 +237,7 @@ pub use crate::channels::channel; mod construction; mod conversion; mod devices; -pub use crate::conversion::ConvertMeasurement; -pub use crate::conversion::ConvertThreshold; +pub use crate::conversion::{ConvertMeasurement, ConvertThreshold}; mod private { use super::{ic, interface}; @@ -473,23 +255,3 @@ mod private { impl Sealed for ic::Ads1015 {} impl Sealed for ic::Ads1115 {} } - -#[cfg(test)] -mod tests { - use super::DEVICE_BASE_ADDRESS as ADDR; - use super::*; - - #[test] - fn can_get_default_address() { - let addr = SlaveAddr::default(); - assert_eq!(ADDR, addr.addr(ADDR)); - } - - #[test] - fn can_generate_alternative_addresses() { - assert_eq!(0b100_1000, SlaveAddr::Alternative(false, false).addr(ADDR)); - assert_eq!(0b100_1001, SlaveAddr::Alternative(false, true).addr(ADDR)); - assert_eq!(0b100_1010, SlaveAddr::Alternative(true, false).addr(ADDR)); - assert_eq!(0b100_1011, SlaveAddr::Alternative(true, true).addr(ADDR)); - } -} diff --git a/src/types.rs b/src/types.rs new file mode 100644 index 0000000..67994d6 --- /dev/null +++ b/src/types.rs @@ -0,0 +1,245 @@ +//! Type definitions. + +use core::marker::PhantomData; + +/// Errors in this crate +#[derive(Debug)] +pub enum Error { + /// I²C bus error + I2C(E), + /// Invalid input data provided + InvalidInputData, +} + +/// Error type for mode changes. +/// +/// This allows to retrieve the unchanged device in case of an error. +pub enum ModeChangeError { + /// I²C bus error while changing mode. + /// + /// `E` is the error that happened. + /// `DEV` is the device with the mode unchanged. + I2C(E, DEV), +} + +/// Mode marker types +pub mod mode { + /// One-shot operating mode / power-down state (default) + pub struct OneShot(()); + + /// Continuous conversion mode + pub struct Continuous(()); +} + +/// Data rate for ADS1013, ADS1014, ADS1015 +#[derive(Debug, Clone, Copy, PartialEq)] +pub enum DataRate12Bit { + /// 128 SPS + Sps128, + /// 250 SPS + Sps250, + /// 490 SPS + Sps490, + /// 920 SPS + Sps920, + /// 1600 SPS (default) + Sps1600, + /// 2400 SPS + Sps2400, + /// 3300 SPS + Sps3300, +} + +/// Data rate for ADS1113, ADS1114, ADS1115 +#[derive(Debug, Clone, Copy, PartialEq)] +pub enum DataRate16Bit { + /// 8 SPS + Sps8, + /// 16 SPS + Sps16, + /// 32 SPS + Sps32, + /// 64 SPS + Sps64, + /// 128 SPS (default) + Sps128, + /// 250 SPS + Sps250, + /// 475 SPS + Sps475, + /// 860 SPS + Sps860, +} +/// Comparator mode (only for ADS1x14, ADS1x15) +#[derive(Debug, Clone, Copy, PartialEq)] +pub enum ComparatorMode { + /// Traditional comparator (default) + /// + /// In this mode the ALERT/RDY pin asserts (according to selected active + /// polarity) when the conversion data exceeds the limit set as *high* + /// threshold and remains active until the conversion data falls below the + /// value set as *low* threshold. + Traditional, + /// Window comparator + /// + /// In this mode the ALERT/RDY pin asserts (according to selected active + /// polarity) when the conversion data exceeds the value set as *high* + /// threshold or goes below the value set as *low* temperature threshold. + Window, +} + +/// Comparator polarity (only for ADS1x14, ADS1x15) +#[derive(Debug, Clone, Copy, PartialEq)] +pub enum ComparatorPolarity { + /// Active low (default) + ActiveLow, + /// Active high + ActiveHigh, +} + +/// Comparator polarity (only for ADS1x14, ADS1x15) +/// +/// Select whether the ALERT/RDY pin latches after being asserted or clears +/// after conversions are within the margin of the upper and lower +/// threshold values. +#[derive(Debug, Clone, Copy, PartialEq)] +pub enum ComparatorLatching { + /// Nonlatching (default) + /// + /// The ALERT/RDY pin does not latch when asserted. + Nonlatching, + /// Latching + /// + /// The asserted ALERT/RDY pin remains latched until conversion data are + /// read by the master or an appropriate SMBus alert response is sent by + /// the master. The device responds with its address, and it is the lowest + /// address currently asserting the ALERT/RDY bus line. + Latching, +} + +/// Comparator alert queue (only for ADS1x14, ADS1x15) +/// +/// The default state of the comparator is deactivated. It can be activated by setting +/// the comparator queue. +#[derive(Debug, Clone, Copy, PartialEq)] +pub enum ComparatorQueue { + /// Activate comparator and assert after one conversion exceeding thresholds + One, + /// Activate comparator and assert after two consecutive conversions exceeding thresholds + Two, + /// Activate comparator and assert after four consecutive conversions exceeding thresholds + Four, +} + +/// Full-scale range configuration for the programmable gain amplifier (PGA) (only for ADS1x14, ADS1x15) +/// +/// This sets the input voltage measurable range. +/// The FSR is fixed at ±2.048 V in the ADS1x13. +#[derive(Clone, Copy, Debug, PartialEq)] +#[allow(non_camel_case_types)] +pub enum FullScaleRange { + /// The measurable range is ±6.144V. + Within6_144V, + /// The measurable range is ±4.096V. + Within4_096V, + /// The measurable range is ±2.048V. (default) + Within2_048V, + /// The measurable range is ±1.024V. + Within1_024V, + /// The measurable range is ±0.512V. + Within0_512V, + /// The measurable range is ±0.256V. + Within0_256V, +} + +/// Possible slave addresses +#[derive(Debug, Clone, Copy, PartialEq)] +pub enum SlaveAddr { + /// Default slave address + Default, + /// Alternative slave address providing bit values for A1 and A0 + Alternative(bool, bool), +} + +impl Default for SlaveAddr { + /// Default slave address + fn default() -> Self { + SlaveAddr::Default + } +} + +impl SlaveAddr { + pub(crate) fn addr(self, default: u8) -> u8 { + match self { + SlaveAddr::Default => default, + SlaveAddr::Alternative(a1, a0) => default | ((a1 as u8) << 1) | a0 as u8, + } + } +} + +#[derive(Debug, Clone, PartialEq)] +pub(crate) struct Config { + pub(crate) bits: u16, +} + +impl Config { + pub(crate) fn is_high(&self, mask: u16) -> bool { + (self.bits & mask) != 0 + } + + pub(crate) fn with_high(&self, mask: u16) -> Self { + Config { + bits: self.bits | mask, + } + } + + pub(crate) fn with_low(&self, mask: u16) -> Self { + Config { + bits: self.bits & !mask, + } + } +} + +impl Default for Config { + fn default() -> Self { + Config { bits: 0x8583 } + } +} + +impl Default for FullScaleRange { + fn default() -> Self { + FullScaleRange::Within2_048V + } +} + +/// ADS1x1x ADC driver +#[derive(Debug, Default)] +pub struct Ads1x1x { + pub(crate) iface: DI, + pub(crate) config: Config, + pub(crate) fsr: FullScaleRange, + pub(crate) a_conversion_was_started: bool, + pub(crate) _conv: PhantomData, + pub(crate) _ic: PhantomData, + pub(crate) _mode: PhantomData, +} + +#[cfg(test)] +mod tests { + use crate::SlaveAddr; + use crate::DEVICE_BASE_ADDRESS as ADDR; + + #[test] + fn can_get_default_address() { + let addr = SlaveAddr::default(); + assert_eq!(ADDR, addr.addr(ADDR)); + } + + #[test] + fn can_generate_alternative_addresses() { + assert_eq!(0b100_1000, SlaveAddr::Alternative(false, false).addr(ADDR)); + assert_eq!(0b100_1001, SlaveAddr::Alternative(false, true).addr(ADDR)); + assert_eq!(0b100_1010, SlaveAddr::Alternative(true, false).addr(ADDR)); + assert_eq!(0b100_1011, SlaveAddr::Alternative(true, true).addr(ADDR)); + } +} -- cgit v1.2.3-54-g00ecf