From 06132ec9bcf9b7a2e9c8f9c74bb540ec249a03b5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?D=C3=A1niel=20Buga?= Date: Fri, 20 Dec 2024 13:49:28 +0100 Subject: [PATCH] Mark SPI slave as unstable --- esp-hal/src/lib.rs | 6 ++++-- esp-hal/src/spi/mod.rs | 5 ++++- esp-hal/src/spi/slave.rs | 21 ++++++++++++++++++++- 3 files changed, 28 insertions(+), 4 deletions(-) diff --git a/esp-hal/src/lib.rs b/esp-hal/src/lib.rs index 09c64b853a..53beb9cac4 100644 --- a/esp-hal/src/lib.rs +++ b/esp-hal/src/lib.rs @@ -196,7 +196,7 @@ pub mod time; // can't use instability on inline module definitions, see https://github.com/rust-lang/rust/issues/54727 #[doc(hidden)] -macro_rules! unstable { +macro_rules! unstable_module { ($( $(#[$meta:meta])* pub mod $module:ident; @@ -216,7 +216,9 @@ macro_rules! unstable { }; } -unstable! { +pub(crate) use unstable_module; + +unstable_module! { #[cfg(aes)] pub mod aes; #[cfg(any(adc, dac))] diff --git a/esp-hal/src/spi/mod.rs b/esp-hal/src/spi/mod.rs index 8d6afac706..ea54cf1ddb 100644 --- a/esp-hal/src/spi/mod.rs +++ b/esp-hal/src/spi/mod.rs @@ -12,7 +12,10 @@ use crate::dma::{DmaEligible, DmaError}; pub mod master; -pub mod slave; + +crate::unstable_module! { + pub mod slave; +} /// SPI errors #[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)] diff --git a/esp-hal/src/spi/slave.rs b/esp-hal/src/spi/slave.rs index 5b4b7db336..95453eeb76 100644 --- a/esp-hal/src/spi/slave.rs +++ b/esp-hal/src/spi/slave.rs @@ -54,6 +54,8 @@ //! //! ## Implementation State //! +//! This driver is currently **unstable**. +//! //! There are several options for working with the SPI peripheral in slave mode, //! but the code currently only supports: //! - Single transfers (not segmented transfers) @@ -91,6 +93,7 @@ const MAX_DMA_SIZE: usize = 32768 - 32; /// SPI peripheral driver. /// /// See the [module-level documentation][self] for more details. +#[instability::unstable] pub struct Spi<'d, Dm, T = AnySpi> { spi: PeripheralRef<'d, T>, #[allow(dead_code)] @@ -98,9 +101,9 @@ pub struct Spi<'d, Dm, T = AnySpi> { _mode: PhantomData, _guard: PeripheralGuard, } - impl<'d> Spi<'d, Blocking> { /// Constructs an SPI instance in 8bit dataframe mode. + #[instability::unstable] pub fn new(spi: impl Peripheral

+ 'd, mode: Mode) -> Spi<'d, Blocking> { Self::new_typed(spi.map_into(), mode) } @@ -111,6 +114,7 @@ where T: Instance, { /// Constructs an SPI instance in 8bit dataframe mode. + #[instability::unstable] pub fn new_typed(spi: impl Peripheral

+ 'd, mode: Mode) -> Spi<'d, Dm, T> { crate::into_ref!(spi); @@ -133,6 +137,7 @@ where } /// Assign the SCK (Serial Clock) pin for the SPI instance. + #[instability::unstable] pub fn with_sck(self, sclk: impl Peripheral

+ 'd) -> Self { crate::into_mapped_ref!(sclk); sclk.enable_input(true, private::Internal); @@ -141,6 +146,7 @@ where } /// Assign the MOSI (Master Out Slave In) pin for the SPI instance. + #[instability::unstable] pub fn with_mosi(self, mosi: impl Peripheral

+ 'd) -> Self { crate::into_mapped_ref!(mosi); mosi.enable_input(true, private::Internal); @@ -149,6 +155,7 @@ where } /// Assign the MISO (Master In Slave Out) pin for the SPI instance. + #[instability::unstable] pub fn with_miso(self, miso: impl Peripheral

+ 'd) -> Self { crate::into_mapped_ref!(miso); miso.set_to_push_pull_output(private::Internal); @@ -157,6 +164,7 @@ where } /// Assign the CS (Chip Select) pin for the SPI instance. + #[instability::unstable] pub fn with_cs(self, cs: impl Peripheral

+ 'd) -> Self { crate::into_mapped_ref!(cs); cs.enable_input(true, private::Internal); @@ -166,6 +174,7 @@ where } /// DMA (Direct Memory Access) functionality (Slave). +#[instability::unstable] pub mod dma { use super::*; use crate::{ @@ -198,6 +207,7 @@ pub mod dma { /// Configures the SPI peripheral with the provided DMA channel and /// descriptors. #[cfg_attr(esp32, doc = "\n\n**Note**: ESP32 only supports Mode 1 and 3.")] + #[instability::unstable] pub fn with_dma( self, channel: impl Peripheral

+ 'd, @@ -218,6 +228,7 @@ pub mod dma { } /// A DMA capable SPI instance. + #[instability::unstable] pub struct SpiDma<'d, Dm, T = AnySpi> where T: InstanceDma, @@ -320,6 +331,7 @@ pub mod dma { Dm: DriverMode, T: InstanceDma, { + #[instability::unstable] fn driver(&self) -> DmaDriver { DmaDriver { info: self.spi.info(), @@ -333,6 +345,7 @@ pub mod dma { /// sent is 32736 bytes. /// /// The write is driven by the SPI master's sclk signal and cs line. + #[instability::unstable] pub fn write<'t, TXBUF>( &'t mut self, words: &'t TXBUF, @@ -368,6 +381,7 @@ pub mod dma { /// received is 32736 bytes. /// /// The read is driven by the SPI master's sclk signal and cs line. + #[instability::unstable] pub fn read<'t, RXBUF>( &'t mut self, words: &'t mut RXBUF, @@ -404,6 +418,7 @@ pub mod dma { /// /// The data transfer is driven by the SPI master's sclk signal and cs /// line. + #[instability::unstable] pub fn transfer<'t, RXBUF, TXBUF>( &'t mut self, read_buffer: &'t mut RXBUF, @@ -573,12 +588,14 @@ pub mod dma { } /// SPI peripheral instance. +#[doc(hidden)] pub trait Instance: Peripheral

+ Into + 'static { /// Returns the peripheral data describing this SPI instance. fn info(&self) -> &'static Info; } /// A marker for DMA-capable SPI peripheral instances. +#[doc(hidden)] pub trait InstanceDma: Instance + DmaEligible {} impl InstanceDma for crate::peripherals::SPI2 {} @@ -587,6 +604,7 @@ impl InstanceDma for crate::peripherals::SPI3 {} /// Peripheral data describing a particular SPI instance. #[non_exhaustive] +#[doc(hidden)] pub struct Info { /// Pointer to the register block for this SPI instance. /// @@ -611,6 +629,7 @@ pub struct Info { impl Info { /// Returns the register block for this SPI instance. + #[instability::unstable] pub fn register_block(&self) -> &RegisterBlock { unsafe { &*self.register_block } }