From f6ac6188a652bd7ccff772648d57cff9a0963e84 Mon Sep 17 00:00:00 2001 From: Diego Barrios Romero Date: Sat, 10 Nov 2018 10:01:27 +0100 Subject: Add support for setting the comparator latching --- src/devices/ads1x1x/features/tier2.rs | 14 +++++++++++++- src/lib.rs | 21 +++++++++++++++++++++ 2 files changed, 34 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/devices/ads1x1x/features/tier2.rs b/src/devices/ads1x1x/features/tier2.rs index 7d22796..43dce5c 100644 --- a/src/devices/ads1x1x/features/tier2.rs +++ b/src/devices/ads1x1x/features/tier2.rs @@ -3,7 +3,7 @@ //! These are the features included only in ADS1x14, ADS1x15 use { Ads1x1x, Error, interface, ic, ComparatorMode, ComparatorPolarity, - Register, BitFlags }; + ComparatorLatching, Register, BitFlags }; impl Ads1x1x where @@ -33,4 +33,16 @@ where self.config = config; Ok(()) } + + /// Set comparator latching + pub fn set_comparator_latching(&mut self, latching: ComparatorLatching) -> Result<(), Error> { + let config; + match latching { + ComparatorLatching::Nonlatching => config = self.config.with_low( BitFlags::COMP_LAT), + ComparatorLatching::Latching => config = self.config.with_high(BitFlags::COMP_LAT) + } + self.iface.write_register(Register::CONFIG, config.bits)?; + self.config = config; + Ok(()) + } } diff --git a/src/lib.rs b/src/lib.rs index ee37a1d..f144b01 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -175,6 +175,26 @@ pub enum ComparatorPolarity { 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, 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 +} + /// Possible slave addresses #[derive(Debug, Clone)] pub enum SlaveAddr { @@ -220,6 +240,7 @@ impl BitFlags { 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; } -- cgit v1.2.3-54-g00ecf