From d5b88be16b7c81356b2096fef62bb4c38c5e8767 Mon Sep 17 00:00:00 2001 From: Charles-Henri Mousset Date: Thu, 19 Dec 2024 15:53:55 +0100 Subject: [PATCH 1/3] [enh] ported to v1.0.0 of embedded-hal --- Cargo.toml | 15 +++++++++------ src/device_status.rs | 7 ++----- src/i2c_interface.rs | 2 +- src/init.rs | 4 ++-- src/lib.rs | 10 +++++----- src/mode.rs | 14 +++++++------- src/mode/continuous.rs | 8 ++++---- src/mode/dynamic.rs | 7 ++----- src/mode/powered_off.rs | 7 ++----- src/mode/ready.rs | 4 ++-- src/read_measurements.rs | 8 ++++---- src/register.rs | 16 +--------------- src/register/register_tests.rs | 5 +++-- src/start_stop_measurements.rs | 4 ++-- 14 files changed, 46 insertions(+), 65 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 5da4c59..908ca25 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -2,20 +2,23 @@ name = "vl6180x" version = "0.2.0" description = "A rust driver for the VL6180X (Time-of-Flight I2C laser-ranging module)" -authors = ["Luca Zulian ", "Shao Yuan "] +authors = [ + "Luca Zulian ", + "Shao Yuan ", +] categories = ["embedded", "hardware-support", "no-std"] -keywords = ["hal", "IO", "embedded-hal-driver", "vl6180x", "tof"] +keywords = ["hal", "IO", "embedded-hal-driver", "vl6180x", "tof"] license = "MIT" readme = "README.md" repository = "https://github.com/lucazulian/vl6180x" edition = "2018" -exclude = [ "doc", "*.jpg", "*.png", "*.bmp" ] +exclude = ["doc", "*.jpg", "*.png", "*.bmp"] [dependencies] -embedded-hal = {version = "0.2.7", features = ["unproven"]} -int-enum = {version = "0.4.0", default-features = false} +embedded-hal = "1.0.0" +int-enum = { version = "1.1.2", default-features = false } [profile.release] codegen-units = 1 debug = true -lto = true \ No newline at end of file +lto = true diff --git a/src/device_status.rs b/src/device_status.rs index 9f9e599..2940e0d 100644 --- a/src/device_status.rs +++ b/src/device_status.rs @@ -3,14 +3,11 @@ use crate::{ error::{Error, Error2}, register::{Register8Bit::*, SysInterruptClearCode}, }; -use embedded_hal::{ - blocking::i2c::{Write, WriteRead}, - digital::v2::OutputPin, -}; +use embedded_hal::{digital::OutputPin, i2c::I2c}; impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, { pub(crate) fn read_model_id_direct(&mut self) -> Result> { let id = self.read_named_register(IDENTIFICATION__MODEL_ID)?; diff --git a/src/i2c_interface.rs b/src/i2c_interface.rs index 98df993..2d5e7c8 100644 --- a/src/i2c_interface.rs +++ b/src/i2c_interface.rs @@ -3,7 +3,7 @@ use crate::register::{Register16Bit, Register8Bit}; impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, { /// Reads a named 8-bit register pub(crate) fn read_named_register(&mut self, reg: Register8Bit) -> Result { diff --git a/src/init.rs b/src/init.rs index 7a2a9ba..595958f 100644 --- a/src/init.rs +++ b/src/init.rs @@ -3,11 +3,11 @@ use crate::register::{ Register16Bit::*, Register8Bit::*, SysModeGpio1Polarity, SysModeGpio1Select, AMBIENT_ANALOGUE_GAIN_CODE, RANGE_SCALAR_CODE, }; -use embedded_hal::blocking::i2c::{Write, WriteRead}; +use embedded_hal::i2c::I2c; impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, { /// Initialize sensor with settings from ST application note AN4545, /// section "SR03 settings" - "Mandatory : private registers" diff --git a/src/lib.rs b/src/lib.rs index 13e9d5b..a926f33 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -37,7 +37,7 @@ //! .set_open_drain(); //! let i2c = dp.I2C1.i2c((scl, sda), 400.kHz(), &clocks); //! -//! //! To create sensor with default configuration: +//! // To create sensor with default configuration: //! let mut tof = vl6180x::VL6180X::new(i2c).expect("vl"); //! //! loop { @@ -74,8 +74,8 @@ #![allow(dead_code)] pub use crate::register::ResultInterruptStatusGpioCode; pub use config::*; -use embedded_hal::blocking::i2c::{Write, WriteRead}; -use embedded_hal::digital::v2::{InputPin, OutputPin}; +use embedded_hal::digital::{InputPin, OutputPin}; +use embedded_hal::i2c::I2c; pub use error::Error; pub use mode::*; mod config; @@ -90,7 +90,7 @@ mod start_stop_measurements; /// VL6180 interface #[derive(Debug, Clone, Copy)] -pub struct VL6180X { +pub struct VL6180X { mode: MODE, com: I2C, config: Config, @@ -98,7 +98,7 @@ pub struct VL6180X { /// Convenience container for VL6180, x_shutdown_pin and interrupt_pin #[derive(Debug, Clone, Copy)] -pub struct VL6180XwPins { +pub struct VL6180XwPins { /// VL6180 pub vl6180x: VL6180X, /// X Shutdown Pin, output high => powered on, output low => powered off. diff --git a/src/mode.rs b/src/mode.rs index 2ad9d20..e20bc73 100644 --- a/src/mode.rs +++ b/src/mode.rs @@ -5,8 +5,8 @@ mod ready; pub use continuous::*; pub use dynamic::*; -use embedded_hal::blocking::i2c::{Write, WriteRead}; -use embedded_hal::digital::v2::OutputPin; +use embedded_hal::digital::OutputPin; +use embedded_hal::i2c::I2c; pub use powered_off::*; pub use ready::*; @@ -15,7 +15,7 @@ use crate::VL6180X; impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, { fn into_mode(self, mode: MODE2) -> VL6180X { VL6180X { @@ -42,7 +42,7 @@ pub trait AllowStartRangeSingle {} impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, MODE: AllowReadMeasurement, { /// Blocking read of the range mesurement. @@ -87,7 +87,7 @@ where impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, MODE: AllowStartAmbientSingle, { /// Trigger ambient light measurement in a non-blocking way. @@ -108,7 +108,7 @@ where impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, MODE: AllowStartRangeSingle, { /// Trigger range mesurement in a non-blocking way. @@ -127,7 +127,7 @@ where impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, MODE: AllowCommunication, { /// Read the model id of the sensor. Should return 0xB4. diff --git a/src/mode/continuous.rs b/src/mode/continuous.rs index ac24d3e..6dbcf9e 100644 --- a/src/mode/continuous.rs +++ b/src/mode/continuous.rs @@ -1,5 +1,5 @@ use crate::{error::Error, AllowCommunication, VL6180X}; -use embedded_hal::blocking::i2c::{Write, WriteRead}; +use embedded_hal::i2c::I2c; use super::{AllowReadMeasurement, AllowStartAmbientSingle, AllowStartRangeSingle, ReadyMode}; @@ -15,7 +15,7 @@ impl AllowCommunication for RangeContinuousMode {} impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, { /// Stops range continuous mode. pub fn stop_range_continuous_mode(mut self) -> Result, Error> { @@ -36,7 +36,7 @@ impl AllowCommunication for AmbientContinuousMode {} impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, { /// Stops ambient continuous mode. pub fn stop_ambient_continuous_mode(mut self) -> Result, Error> { @@ -58,7 +58,7 @@ impl AllowCommunication for InterleavedContinuousMode {} impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, { /// Stops interleaved continuous mode. pub fn stop_interleaved_continuous_mode(mut self) -> Result, Error> { diff --git a/src/mode/dynamic.rs b/src/mode/dynamic.rs index b6fcdbe..4fc5b2b 100644 --- a/src/mode/dynamic.rs +++ b/src/mode/dynamic.rs @@ -1,9 +1,6 @@ use crate::error::{Error, Error2}; use crate::VL6180X; -use embedded_hal::{ - blocking::i2c::{Write, WriteRead}, - digital::v2::OutputPin, -}; +use embedded_hal::{digital::OutputPin, i2c::I2c}; use OperatingMode::*; /// A mode where the state is kept track of at runtime, instead of being @@ -41,7 +38,7 @@ impl DynamicMode { impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, { /// Same functionality as [`poll_range_mm_single_blocking()`](VL6180X::poll_range_mm_single_blocking) /// but with a check on the current [OperatingMode]. diff --git a/src/mode/powered_off.rs b/src/mode/powered_off.rs index 29393a5..f05b0e7 100644 --- a/src/mode/powered_off.rs +++ b/src/mode/powered_off.rs @@ -1,7 +1,4 @@ -use embedded_hal::{ - blocking::i2c::{Write, WriteRead}, - digital::v2::OutputPin, -}; +use embedded_hal::{digital::OutputPin, i2c::I2c}; use crate::{error::Error2, mode::ReadyMode, VL6180X}; @@ -11,7 +8,7 @@ pub struct PoweredOffMode {} impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, { /// Powers on the sensor by setting the `x_shutdown_pin` high. /// It then busy waits for the device to be booted and initializes the device. diff --git a/src/mode/ready.rs b/src/mode/ready.rs index bb7e758..6ac3649 100644 --- a/src/mode/ready.rs +++ b/src/mode/ready.rs @@ -1,6 +1,6 @@ use crate::{error::Error, Config}; use crate::{AllowCommunication, VL6180X}; -use embedded_hal::blocking::i2c::{Write, WriteRead}; +use embedded_hal::i2c::I2c; use super::{ AllowReadMeasurement, AllowStartAmbientSingle, AllowStartRangeSingle, AmbientContinuousMode, @@ -21,7 +21,7 @@ impl AllowStartAmbientSingle for ReadyMode {} impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, { /// Create a new VL6180X driver pub fn new(i2c: I2C) -> Result> { diff --git a/src/read_measurements.rs b/src/read_measurements.rs index 8f3e9f5..d420791 100644 --- a/src/read_measurements.rs +++ b/src/read_measurements.rs @@ -8,11 +8,11 @@ use crate::{ }, VL6180X, }; -use embedded_hal::blocking::i2c::{Write, WriteRead}; +use embedded_hal::i2c::I2c; impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, { pub(crate) fn read_range_mm_blocking_direct(&mut self) -> Result> { let mut c = 0; @@ -42,7 +42,7 @@ where } fn get_range_val_and_status(&mut self) -> Result> { - let status = self.read_named_register(Register8Bit::RESULT__RANGE_STATUS)?; + let status = self.read_named_register(Register8Bit::RESULT__RANGE_STATUS)? >> 4; self.clear_range_interrupt_direct()?; let error = RangeStatusErrorCode::try_from(status) .map_err(|_| Error::UnknownRegisterCode(status))?; @@ -108,7 +108,7 @@ where } fn get_ambient_val_and_status(&mut self) -> Result> { - let status = self.read_named_register(Register8Bit::RESULT__ALS_STATUS)?; + let status = self.read_named_register(Register8Bit::RESULT__ALS_STATUS)? >> 4; self.clear_ambient_interrupt_direct()?; let error = AmbientStatusErrorCode::try_from(status) .map_err(|_| Error::UnknownRegisterCode(status))?; diff --git a/src/register.rs b/src/register.rs index 36b17eb..69d33bd 100644 --- a/src/register.rs +++ b/src/register.rs @@ -1,5 +1,4 @@ -use core::convert::TryFrom; -use int_enum::{IntEnum, IntEnumError}; +use int_enum::IntEnum; #[cfg(test)] mod register_tests; @@ -246,13 +245,6 @@ impl RangeStatusErrorCode { } } -impl TryFrom for RangeStatusErrorCode { - type Error = IntEnumError; - fn try_from(code: u8) -> Result { - RangeStatusErrorCode::from_int(code >> 4) - } -} - /// Errors from performing an ambient light measurement /// See VL6180X datasheet section 6.2.38 RESULT__ALS_STATUS // Bits 7:4 of what is returned from the register @@ -273,12 +265,6 @@ impl AmbientStatusErrorCode { } } -impl TryFrom for AmbientStatusErrorCode { - type Error = IntEnumError; - fn try_from(code: u8) -> Result { - AmbientStatusErrorCode::from_int(code >> 4) - } -} // RANGE_SCALER values for 1x, 2x, 3x scaling - see STSW-IMG003 core/src/vl6180x_api.c (ScalerLookUP[]) pub const RANGE_SCALAR_CODE: [u16; 4] = [0, 253, 127, 84]; /// See datasheet 2.10.6 for more details diff --git a/src/register/register_tests.rs b/src/register/register_tests.rs index 0c9ed65..8bd5003 100644 --- a/src/register/register_tests.rs +++ b/src/register/register_tests.rs @@ -1,4 +1,5 @@ use super::*; +use core::convert::TryFrom; #[test] fn interupt_has_error() { @@ -88,12 +89,12 @@ fn interupt_has_ambient_low_event() { #[test] fn range_status_error_code_known() { assert_eq!( - RangeStatusErrorCode::try_from(0b0110_0000).unwrap(), + RangeStatusErrorCode::try_from(0b0110_0000 >> 4 as u8).unwrap(), RangeStatusErrorCode::EarlyConvergenceEstimate ) } #[test] fn range_status_error_code_unknown() { - assert!(RangeStatusErrorCode::try_from(0b1001_0000).is_err()) + assert!(RangeStatusErrorCode::try_from(0b1001_0000 >> 4).is_err()) } diff --git a/src/start_stop_measurements.rs b/src/start_stop_measurements.rs index ea1a29e..1f1b395 100644 --- a/src/start_stop_measurements.rs +++ b/src/start_stop_measurements.rs @@ -3,11 +3,11 @@ use crate::{ register::{InterleavedModeEnableCode, Register8Bit, SysAmbientStartCode, SysRangeStartCode}, VL6180X, }; -use embedded_hal::blocking::i2c::{Write, WriteRead}; +use embedded_hal::i2c::I2c; impl VL6180X where - I2C: WriteRead + Write, + I2C: I2c, { pub(crate) fn poll_range_mm_single_blocking_direct(&mut self) -> Result> { self.write_named_register( From 65f5fceb0b4c078b09f1dfee4872f015edc64376 Mon Sep 17 00:00:00 2001 From: Charles-Henri Mousset Date: Thu, 19 Dec 2024 16:16:06 +0100 Subject: [PATCH 2/3] [clnp] bump crate version --- Cargo.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Cargo.toml b/Cargo.toml index 908ca25..889571f 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "vl6180x" -version = "0.2.0" +version = "1.0.0" description = "A rust driver for the VL6180X (Time-of-Flight I2C laser-ranging module)" authors = [ "Luca Zulian ", From 36692b8ae56aa787491e0c9dc347e557f30a9be6 Mon Sep 17 00:00:00 2001 From: Charles-Henri Mousset Date: Thu, 19 Dec 2024 16:24:33 +0100 Subject: [PATCH 3/3] [clnp] updating CI stuff --- .github/workflows/vl6180x-ci.yml | 12 ++++++------ src/config/config_tests.rs | 1 - src/lib.rs | 2 +- src/register/register_tests.rs | 1 + 4 files changed, 8 insertions(+), 8 deletions(-) diff --git a/.github/workflows/vl6180x-ci.yml b/.github/workflows/vl6180x-ci.yml index 2169edd..1ae6673 100644 --- a/.github/workflows/vl6180x-ci.yml +++ b/.github/workflows/vl6180x-ci.yml @@ -4,14 +4,14 @@ name: vl6180x-ci on: push: branches: - - '**' + - "**" tags: - "*.*.*" schedule: - cron: 0 0 * * 0 env: - RUSTFLAGS: '--deny warnings' + RUSTFLAGS: "--deny warnings" jobs: build: @@ -19,7 +19,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - rust: [stable, beta, nightly, 1.52.1, 1.49.0] + rust: [stable, beta, nightly, 1.70.0] TARGET: - x86_64-unknown-linux-gnu - x86_64-unknown-linux-musl @@ -47,9 +47,9 @@ jobs: - name: Checkout CI scripts uses: actions/checkout@v2 with: - repository: 'eldruin/rust-driver-ci-scripts' - ref: 'master' - path: 'ci' + repository: "eldruin/rust-driver-ci-scripts" + ref: "master" + path: "ci" - run: ./ci/patch-no-std.sh if: ${{ ! contains(matrix.TARGET, 'x86_64') }} diff --git a/src/config/config_tests.rs b/src/config/config_tests.rs index 2d00c75..130a0b0 100644 --- a/src/config/config_tests.rs +++ b/src/config/config_tests.rs @@ -29,4 +29,3 @@ fn set_range_max_convergence_time_value_valid() { let mut config = Config::new(); assert_eq!(config.set_range_max_convergence_time(20), Ok(())) } - diff --git a/src/lib.rs b/src/lib.rs index a926f33..43774b1 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -3,7 +3,7 @@ //! //! for more examples please see [vl6180x_stm32f401_examples](https://github.com/shaoyuancc/vl6180x_stm32f401_examples) //! -//! ```rust +//! ```ignore //! #![no_std] //! #![no_main] //! diff --git a/src/register/register_tests.rs b/src/register/register_tests.rs index 8bd5003..ecd2349 100644 --- a/src/register/register_tests.rs +++ b/src/register/register_tests.rs @@ -11,6 +11,7 @@ fn interupt_has_error() { false ) } + #[test] fn interupt_has_no_error() { assert_eq!(