diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/channels.rs | 40 | ||||
-rw-r--r-- | src/conversion.rs | 13 | ||||
-rw-r--r-- | src/devices/features/tier2.rs | 12 | ||||
-rw-r--r-- | src/devices/mod.rs | 4 | ||||
-rw-r--r-- | src/devices/mode/mod.rs | 2 | ||||
-rw-r--r-- | src/devices/mode/oneshot.rs | 10 | ||||
-rw-r--r-- | src/lib.rs | 55 |
7 files changed, 85 insertions, 51 deletions
diff --git a/src/channels.rs b/src/channels.rs index d5ae7bc..90b9b5d 100644 --- a/src/channels.rs +++ b/src/channels.rs @@ -74,14 +74,38 @@ impl Config { pub(crate) fn with_mux_bits(&self, ch: ChannelSelection) -> Self { use self::ChannelSelection as CS; match ch { - CS::DifferentialA0A1 => self.with_low( BF::MUX2).with_low( BF::MUX1).with_low( BF::MUX0), - CS::DifferentialA0A3 => self.with_low( BF::MUX2).with_low( BF::MUX1).with_high(BF::MUX0), - CS::DifferentialA1A3 => self.with_low( BF::MUX2).with_high(BF::MUX1).with_low( BF::MUX0), - CS::DifferentialA2A3 => self.with_low( BF::MUX2).with_high(BF::MUX1).with_high(BF::MUX0), - CS::SingleA0 => self.with_high(BF::MUX2).with_low( BF::MUX1).with_low( BF::MUX0), - CS::SingleA1 => self.with_high(BF::MUX2).with_low( BF::MUX1).with_high(BF::MUX0), - CS::SingleA2 => self.with_high(BF::MUX2).with_high(BF::MUX1).with_low( BF::MUX0), - CS::SingleA3 => self.with_high(BF::MUX2).with_high(BF::MUX1).with_high(BF::MUX0), + CS::DifferentialA0A1 => self + .with_low(BF::MUX2) + .with_low(BF::MUX1) + .with_low(BF::MUX0), + CS::DifferentialA0A3 => self + .with_low(BF::MUX2) + .with_low(BF::MUX1) + .with_high(BF::MUX0), + CS::DifferentialA1A3 => self + .with_low(BF::MUX2) + .with_high(BF::MUX1) + .with_low(BF::MUX0), + CS::DifferentialA2A3 => self + .with_low(BF::MUX2) + .with_high(BF::MUX1) + .with_high(BF::MUX0), + CS::SingleA0 => self + .with_high(BF::MUX2) + .with_low(BF::MUX1) + .with_low(BF::MUX0), + CS::SingleA1 => self + .with_high(BF::MUX2) + .with_low(BF::MUX1) + .with_high(BF::MUX0), + CS::SingleA2 => self + .with_high(BF::MUX2) + .with_high(BF::MUX1) + .with_low(BF::MUX0), + CS::SingleA3 => self + .with_high(BF::MUX2) + .with_high(BF::MUX1) + .with_high(BF::MUX0), } } } diff --git a/src/conversion.rs b/src/conversion.rs index fef80ac..2be9f1e 100644 --- a/src/conversion.rs +++ b/src/conversion.rs @@ -44,25 +44,24 @@ impl ConvertMeasurement for ic::Resolution16Bit { } } - #[cfg(test)] mod tests { use super::*; #[test] fn convert_measurement_12_bits() { - assert_eq!( 0, ic::Resolution12Bit::convert_measurement(0)); - assert_eq!( 2047, ic::Resolution12Bit::convert_measurement(0x7FFF)); + assert_eq!(0, ic::Resolution12Bit::convert_measurement(0)); + assert_eq!(2047, ic::Resolution12Bit::convert_measurement(0x7FFF)); assert_eq!(-2048, ic::Resolution12Bit::convert_measurement(0x8000)); - assert_eq!( -1, ic::Resolution12Bit::convert_measurement(0xFFFF)); + assert_eq!(-1, ic::Resolution12Bit::convert_measurement(0xFFFF)); } #[test] fn convert_measurement_16_bits() { - assert_eq!( 0, ic::Resolution16Bit::convert_measurement(0)); - assert_eq!( 32767, ic::Resolution16Bit::convert_measurement(0x7FFF)); + assert_eq!(0, ic::Resolution16Bit::convert_measurement(0)); + assert_eq!(32767, ic::Resolution16Bit::convert_measurement(0x7FFF)); assert_eq!(-32768, ic::Resolution16Bit::convert_measurement(0x8000)); - assert_eq!( -1, ic::Resolution16Bit::convert_measurement(0xFFFF)); + assert_eq!(-1, ic::Resolution16Bit::convert_measurement(0xFFFF)); } fn assert_invalid_input_data<E>(result: Result<u16, Error<E>>) { diff --git a/src/devices/features/tier2.rs b/src/devices/features/tier2.rs index 48e4eb9..0b0b92c 100644 --- a/src/devices/features/tier2.rs +++ b/src/devices/features/tier2.rs @@ -128,7 +128,10 @@ where /// The comparator can be enabled by setting the comparator queue. /// See [`set_comparator_queue()`](struct.Ads1x1x.html#method.set_comparator_queue) pub fn disable_comparator(&mut self) -> Result<(), Error<E>> { - let config = self.config.with_high(BF::COMP_QUE1).with_high(BF::COMP_QUE0); + let config = self + .config + .with_high(BF::COMP_QUE1) + .with_high(BF::COMP_QUE0); self.iface.write_register(Register::CONFIG, config.bits)?; self.config = config; Ok(()) @@ -142,7 +145,12 @@ where /// /// When calling this the comparator will be disabled and the thresholds will be cleared. pub fn use_alert_rdy_pin_as_ready(&mut self) -> Result<(), Error<E>> { - if self.config != self.config.with_high(BF::COMP_QUE1).with_high(BF::COMP_QUE0) { + if self.config + != self + .config + .with_high(BF::COMP_QUE1) + .with_high(BF::COMP_QUE0) + { self.disable_comparator()?; } self.iface.write_register(Register::HIGH_TH, 0x8000)?; diff --git a/src/devices/mod.rs b/src/devices/mod.rs index 5b87738..01efeba 100644 --- a/src/devices/mod.rs +++ b/src/devices/mod.rs @@ -4,6 +4,6 @@ enum OperatingMode { Continuous, } -mod mode; -mod features; mod common; +mod features; +mod mode; diff --git a/src/devices/mode/mod.rs b/src/devices/mode/mod.rs index 9625465..670ebe9 100644 --- a/src/devices/mode/mod.rs +++ b/src/devices/mode/mod.rs @@ -1,4 +1,4 @@ //! Functions for all devices specific to each operating mode -mod oneshot; mod continuous; +mod oneshot; diff --git a/src/devices/mode/oneshot.rs b/src/devices/mode/oneshot.rs index 612d5a4..5901292 100644 --- a/src/devices/mode/oneshot.rs +++ b/src/devices/mode/oneshot.rs @@ -58,13 +58,19 @@ 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> { - if self.is_measurement_in_progress().map_err(nb::Error::Other)? { + 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()); if self.a_conversion_was_started && same_channel { // result is ready - let value = self.iface.read_register(Register::CONVERSION).map_err(nb::Error::Other)?; + let value = self + .iface + .read_register(Register::CONVERSION) + .map_err(nb::Error::Other)?; self.a_conversion_was_started = false; return Ok(CONV::convert_measurement(value)); } @@ -388,9 +388,7 @@ 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 + SlaveAddr::Alternative(a1, a0) => default | ((a1 as u8) << 1) | a0 as u8, } } } @@ -398,33 +396,32 @@ impl SlaveAddr { struct Register; impl Register { - const CONVERSION : u8 = 0x00; - const CONFIG : u8 = 0x01; - const LOW_TH : u8 = 0x02; - const HIGH_TH : u8 = 0x03; + const CONVERSION: u8 = 0x00; + const CONFIG: u8 = 0x01; + const LOW_TH: u8 = 0x02; + const HIGH_TH: u8 = 0x03; } struct BitFlags; impl BitFlags { - const OS : u16 = 0b1000_0000_0000_0000; - const MUX2 : u16 = 0b0100_0000_0000_0000; - const MUX1 : u16 = 0b0010_0000_0000_0000; - const MUX0 : u16 = 0b0001_0000_0000_0000; - const PGA2 : u16 = 0b0000_1000_0000_0000; - const PGA1 : u16 = 0b0000_0100_0000_0000; - const PGA0 : u16 = 0b0000_0010_0000_0000; - const OP_MODE : u16 = 0b0000_0001_0000_0000; - const DR2 : u16 = 0b0000_0000_1000_0000; - const DR1 : u16 = 0b0000_0000_0100_0000; - const DR0 : u16 = 0b0000_0000_0010_0000; - const COMP_MODE : u16 = 0b0000_0000_0001_0000; - const COMP_POL : u16 = 0b0000_0000_0000_1000; - const COMP_LAT : u16 = 0b0000_0000_0000_0100; - const COMP_QUE1 : u16 = 0b0000_0000_0000_0010; - const COMP_QUE0 : u16 = 0b0000_0000_0000_0001; + const OS: u16 = 0b1000_0000_0000_0000; + const MUX2: u16 = 0b0100_0000_0000_0000; + const MUX1: u16 = 0b0010_0000_0000_0000; + const MUX0: u16 = 0b0001_0000_0000_0000; + const PGA2: u16 = 0b0000_1000_0000_0000; + const PGA1: u16 = 0b0000_0100_0000_0000; + const PGA0: u16 = 0b0000_0010_0000_0000; + const OP_MODE: u16 = 0b0000_0001_0000_0000; + const DR2: u16 = 0b0000_0000_1000_0000; + const DR1: u16 = 0b0000_0000_0100_0000; + const DR0: u16 = 0b0000_0000_0010_0000; + const COMP_MODE: u16 = 0b0000_0000_0001_0000; + const COMP_POL: u16 = 0b0000_0000_0000_1000; + const COMP_LAT: u16 = 0b0000_0000_0000_0100; + const COMP_QUE1: u16 = 0b0000_0000_0000_0010; + const COMP_QUE0: u16 = 0b0000_0000_0000_0001; } - #[derive(Debug, Clone, PartialEq)] struct Config { bits: u16, @@ -471,17 +468,17 @@ pub struct Ads1x1x<DI, IC, CONV, MODE> { _mode: PhantomData<MODE>, } -#[doc(hidden)] -pub mod interface; +mod channels; #[doc(hidden)] pub mod ic; -mod channels; +#[doc(hidden)] +pub mod interface; pub use channels::channel; -mod devices; mod construction; mod conversion; -pub use conversion::ConvertThreshold; +mod devices; pub use conversion::ConvertMeasurement; +pub use conversion::ConvertThreshold; mod private { use super::{ic, interface}; |