From 309be84594b84dc95f412d968b9f55362b74eccc Mon Sep 17 00:00:00 2001 From: Tomasz Kramkowski Date: Sun, 8 Dec 2024 22:11:08 +0000 Subject: Remove CS handling (handled by SpiDevice implementations) --- src/lib.rs | 95 +++++++++++--------------------------------------------------- 1 file changed, 17 insertions(+), 78 deletions(-) (limited to 'src') diff --git a/src/lib.rs b/src/lib.rs index 2cedba1..c319a1d 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -45,7 +45,6 @@ use bit_field::BitField; use core::{future::Future, ops::RangeInclusive}; -use embedded_hal::digital::OutputPin; use embedded_hal_async::spi::SpiDevice; /// The bits that represent the thermocouple value when reading the first u16 from the sensor @@ -63,11 +62,9 @@ const FAULT_NO_THERMOCOUPLE_BIT: usize = 0; /// Possible errors returned by this crate #[derive(Debug)] -pub enum Error { +pub enum Error { /// An error returned by a call to Transfer::transfer SpiError(SpiE), - /// An error returned by a call to OutputPin::{set_high, set_low} - ChipSelectError(CsE), /// The fault bit (16) was set in the response from the MAX31855 Fault, /// The SCV fault bit (2) was set in the response from the MAX31855 @@ -119,38 +116,11 @@ impl Reading { } } -enum CsState { - High, - Low, -} -use CsState::*; - -fn set_cs(cs: &mut CS, state: CsState) -> Result<(), Error> -where - CS: OutputPin, -{ - let result = match state { - CsState::High => cs.set_high(), - CsState::Low => cs.set_low(), - }; - - result.map_err(|e| Error::ChipSelectError(e)) -} - -async fn transfer( - spi: &mut SPI, - chip_select: &mut CS, - buffer: &mut [u8], -) -> Result<(), Error> +async fn transfer(spi: &mut SPI, buffer: &mut [u8]) -> Result<(), Error> where - CS: OutputPin, SPI: SpiDevice, { - set_cs(chip_select, Low)?; - - spi.read(buffer).await.map_err(|e| Error::SpiError(e))?; - - set_cs(chip_select, High) + spi.read(buffer).await.map_err(|e| Error::SpiError(e)) } fn bits_to_i16(bits: u16, len: usize, divisor: i16, shift: usize) -> i16 { @@ -197,43 +167,25 @@ pub struct FullResult { } /// Trait enabling using the MAX31855 -pub trait Max31855 { +pub trait Max31855 { /// Reads the thermocouple temperature and leave it as a raw ADC count. Checks if there is a fault but doesn't detect what kind of fault it is - fn read_thermocouple_raw( - &mut self, - chip_select: &mut CS, - ) -> impl Future>>; + fn read_thermocouple_raw(&mut self) -> impl Future>>; /// Reads the thermocouple temperature and converts it into degrees in the provided unit. Checks if there is a fault but doesn't detect what kind of fault it is - fn read_thermocouple( - &mut self, - chip_select: &mut CS, - unit: Unit, - ) -> impl Future>>; + fn read_thermocouple(&mut self, unit: Unit) -> impl Future>>; /// Reads both the thermocouple and the internal temperatures, leaving them as raw ADC counts and resolves faults to one of vcc short, ground short or missing thermocouple - fn read_all_raw( - &mut self, - chip_select: &mut CS, - ) -> impl Future>>; + fn read_all_raw(&mut self) -> impl Future>>; /// Reads both the thermocouple and the internal temperatures, converts them into degrees in the provided unit and resolves faults to one of vcc short, ground short or missing thermocouple - fn read_all( - &mut self, - chip_select: &mut CS, - unit: Unit, - ) -> impl Future>>; + fn read_all(&mut self, unit: Unit) -> impl Future>>; } -impl Max31855 for SPI +impl Max31855 for SPI where - CS: OutputPin, SPI: SpiDevice, { /// Reads the thermocouple temperature and leave it as a raw ADC count. Checks if there is a fault but doesn't detect what kind of fault it is - async fn read_thermocouple_raw( - &mut self, - chip_select: &mut CS, - ) -> Result> { + async fn read_thermocouple_raw(&mut self) -> Result> { let mut buffer = [0; 2]; - transfer(self, chip_select, &mut buffer).await?; + transfer(self, &mut buffer).await?; if buffer[1].get_bit(FAULT_BIT) { Err(Error::Fault)? @@ -247,23 +199,16 @@ where } /// Reads the thermocouple temperature and converts it into degrees in the provided unit. Checks if there is a fault but doesn't detect what kind of fault it is - async fn read_thermocouple( - &mut self, - chip_select: &mut CS, - unit: Unit, - ) -> Result> { - self.read_thermocouple_raw(chip_select) + async fn read_thermocouple(&mut self, unit: Unit) -> Result> { + self.read_thermocouple_raw() .await .map(|r| unit.convert(Reading::Thermocouple.convert(r))) } /// Reads both the thermocouple and the internal temperatures, leaving them as raw ADC counts and resolves faults to one of vcc short, ground short or missing thermocouple - async fn read_all_raw( - &mut self, - chip_select: &mut CS, - ) -> Result> { + async fn read_all_raw(&mut self) -> Result> { let mut buffer = [0; 4]; - transfer(self, chip_select, &mut buffer).await?; + transfer(self, &mut buffer).await?; let fault = buffer[1].get_bit(0); @@ -296,13 +241,7 @@ where } /// Reads both the thermocouple and the internal temperatures, converts them into degrees in the provided unit and resolves faults to one of vcc short, ground short or missing thermocouple - async fn read_all( - &mut self, - chip_select: &mut CS, - unit: Unit, - ) -> Result> { - self.read_all_raw(chip_select) - .await - .map(|r| r.convert(unit)) + async fn read_all(&mut self, unit: Unit) -> Result> { + self.read_all_raw().await.map(|r| r.convert(unit)) } } -- cgit v1.2.3-54-g00ecf