summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/devices/features/tier2.rs24
-rw-r--r--src/lib.rs26
-rw-r--r--tests/common/mod.rs3
-rw-r--r--tests/tier2_i2c.rs13
4 files changed, 61 insertions, 5 deletions
diff --git a/src/devices/features/tier2.rs b/src/devices/features/tier2.rs
index 25b618a..067139a 100644
--- a/src/devices/features/tier2.rs
+++ b/src/devices/features/tier2.rs
@@ -2,8 +2,9 @@
//!
//! These are the features included only in ADS1x14, ADS1x15
-use { Ads1x1x, Error, interface, ic, ComparatorMode, ComparatorPolarity,
- ComparatorLatching, ComparatorQueue, Register, BitFlags, conversion };
+use { Ads1x1x, Error, interface, ic, FullScaleRange, ComparatorMode,
+ ComparatorPolarity, ComparatorLatching, ComparatorQueue, Register,
+ BitFlags, conversion };
impl<DI, IC, CONV, MODE, E> Ads1x1x<DI, IC, CONV, MODE>
where
@@ -11,6 +12,25 @@ where
IC: ic::Tier2Features,
CONV: conversion::ConvertThreshold<E>
{
+ /// Set the input voltage measurable range
+ ///
+ /// This configures the programmable gain amplifier and determines the measurable input voltage range.
+ pub fn set_full_scale_range(&mut self, range: FullScaleRange) -> Result<(), Error<E>> {
+ use BitFlags as BF;
+ let config;
+ match range {
+ FullScaleRange::Within6_144V => config = self.config.with_low( BF::PGA2).with_low( BF::PGA1).with_low( BF::PGA0),
+ FullScaleRange::Within4_096V => config = self.config.with_low( BF::PGA2).with_low( BF::PGA1).with_high(BF::PGA0),
+ FullScaleRange::Within2_048V => config = self.config.with_low( BF::PGA2).with_high(BF::PGA1).with_low( BF::PGA0),
+ FullScaleRange::Within1_024V => config = self.config.with_low( BF::PGA2).with_high(BF::PGA1).with_high(BF::PGA0),
+ FullScaleRange::Within0_512V => config = self.config.with_high(BF::PGA2).with_low( BF::PGA1).with_low( BF::PGA0),
+ FullScaleRange::Within0_256V => config = self.config.with_high(BF::PGA2).with_low( BF::PGA1).with_high(BF::PGA0),
+ }
+ self.iface.write_register(Register::CONFIG, config.bits)?;
+ self.config = config;
+ Ok(())
+ }
+
/// Set comparator lower threshold
pub fn set_low_threshold(&mut self, value: i16) -> Result<(), Error<E>> {
let register_value = CONV::convert_threshold(value)?;
diff --git a/src/lib.rs b/src/lib.rs
index 035b0d4..00c7a79 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -292,6 +292,27 @@ pub enum ComparatorQueue {
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)]
+#[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)]
pub enum SlaveAddr {
@@ -330,11 +351,14 @@ impl Register {
struct BitFlags;
impl BitFlags {
- const OP_MODE : u16 = 0b0000_0001_0000_0000;
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;
diff --git a/tests/common/mod.rs b/tests/common/mod.rs
index ee78ffe..8714a36 100644
--- a/tests/common/mod.rs
+++ b/tests/common/mod.rs
@@ -20,6 +20,9 @@ impl BitFlags {
pub const MUX2 : u16 = 0b0100_0000_0000_0000;
pub const MUX1 : u16 = 0b0010_0000_0000_0000;
pub const MUX0 : u16 = 0b0001_0000_0000_0000;
+ pub const PGA2 : u16 = 0b0000_1000_0000_0000;
+ pub const PGA1 : u16 = 0b0000_0100_0000_0000;
+ pub const PGA0 : u16 = 0b0000_0010_0000_0000;
pub const OP_MODE : u16 = 0b0000_0001_0000_0000;
pub const DR2 : u16 = 0b0000_0000_1000_0000;
pub const DR1 : u16 = 0b0000_0000_0100_0000;
diff --git a/tests/tier2_i2c.rs b/tests/tier2_i2c.rs
index a4c4df3..a3e3590 100644
--- a/tests/tier2_i2c.rs
+++ b/tests/tier2_i2c.rs
@@ -1,8 +1,8 @@
extern crate embedded_hal_mock as hal;
use hal::i2c::Transaction as I2cTrans;
extern crate ads1x1x;
-use ads1x1x::{ ComparatorMode, ComparatorPolarity, ComparatorLatching,
- ComparatorQueue };
+use ads1x1x::{ FullScaleRange, ComparatorMode, ComparatorPolarity,
+ ComparatorLatching, ComparatorQueue};
#[macro_use]
mod common;
@@ -67,3 +67,12 @@ mod can_set_comparator_queue {
config_test!(four, set_comparator_queue, ComparatorQueue::Four, Config::default().with_high(BitFlags::COMP_QUE1).with_low( BitFlags::COMP_QUE0));
}
+mod can_set_full_scale_range {
+ use super::*;
+ config_test!(fsr6, set_full_scale_range, FullScaleRange::Within6_144V, Config::default().with_low( BitFlags::PGA2).with_low( BitFlags::PGA1).with_low( BitFlags::PGA0));
+ config_test!(fsr4, set_full_scale_range, FullScaleRange::Within4_096V, Config::default().with_low( BitFlags::PGA2).with_low( BitFlags::PGA1).with_high(BitFlags::PGA0));
+ config_test!(fsr2, set_full_scale_range, FullScaleRange::Within2_048V, Config::default().with_low( BitFlags::PGA2).with_high(BitFlags::PGA1).with_low( BitFlags::PGA0));
+ config_test!(fsr1, set_full_scale_range, FullScaleRange::Within1_024V, Config::default().with_low( BitFlags::PGA2).with_high(BitFlags::PGA1).with_high(BitFlags::PGA0));
+ config_test!(fsr0_5, set_full_scale_range, FullScaleRange::Within0_512V, Config::default().with_high(BitFlags::PGA2).with_low( BitFlags::PGA1).with_low( BitFlags::PGA0));
+ config_test!(fsr0_2, set_full_scale_range, FullScaleRange::Within0_256V, Config::default().with_high(BitFlags::PGA2).with_low( BitFlags::PGA1).with_high(BitFlags::PGA0));
+}