2 ******************************************************************************
3 * @file stm32h7xx_ll_spi.h
4 * @author MCD Application Team
5 * @brief Header file of SPI LL module.
6 ******************************************************************************
9 * <h2><center>© Copyright (c) 2017 STMicroelectronics.
10 * All rights reserved.</center></h2>
12 * This software component is licensed by ST under BSD 3-Clause license,
13 * the "License"; You may not use this file except in compliance with the
14 * License. You may obtain a copy of the License at:
15 * opensource.org/licenses/BSD-3-Clause
17 ******************************************************************************
20 /* Define to prevent recursive inclusion -------------------------------------*/
21 #ifndef STM32H7xx_LL_SPI_H
22 #define STM32H7xx_LL_SPI_H
28 /* Includes ------------------------------------------------------------------*/
29 #include "stm32h7xx.h"
31 /** @addtogroup STM32H7xx_LL_Driver
35 #if defined(SPI1) || defined(SPI2) || defined(SPI3) || defined(SPI4) || defined(SPI5) || defined(SPI6)
37 /** @defgroup SPI_LL SPI
41 /* Private variables ---------------------------------------------------------*/
43 /* Private constants ---------------------------------------------------------*/
45 /* Private macros ------------------------------------------------------------*/
46 #if defined(USE_FULL_LL_DRIVER)
47 /** @defgroup SPI_LL_Private_Macros SPI Private Macros
52 * @brief SPI Init structures definition
56 uint32_t TransferDirection
; /*!< Specifies the SPI unidirectional or bidirectional data mode.
57 This parameter can be a value of @ref SPI_LL_EC_TRANSFER_MODE.
59 This feature can be modified afterwards using unitary function @ref LL_SPI_SetTransferDirection().*/
61 uint32_t Mode
; /*!< Specifies the SPI mode (Master/Slave).
62 This parameter can be a value of @ref SPI_LL_EC_MODE.
64 This feature can be modified afterwards using unitary function @ref LL_SPI_SetMode().*/
66 uint32_t DataWidth
; /*!< Specifies the SPI data width.
67 This parameter can be a value of @ref SPI_LL_EC_DATAWIDTH.
69 This feature can be modified afterwards using unitary function @ref LL_SPI_SetDataWidth().*/
71 uint32_t ClockPolarity
; /*!< Specifies the serial clock steady state.
72 This parameter can be a value of @ref SPI_LL_EC_POLARITY.
74 This feature can be modified afterwards using unitary function @ref LL_SPI_SetClockPolarity().*/
76 uint32_t ClockPhase
; /*!< Specifies the clock active edge for the bit capture.
77 This parameter can be a value of @ref SPI_LL_EC_PHASE.
79 This feature can be modified afterwards using unitary function @ref LL_SPI_SetClockPhase().*/
81 uint32_t NSS
; /*!< Specifies whether the NSS signal is managed by hardware (NSS pin) or by software using the SSI bit.
82 This parameter can be a value of @ref SPI_LL_EC_NSS_MODE.
84 This feature can be modified afterwards using unitary function @ref LL_SPI_SetNSSMode().*/
86 uint32_t BaudRate
; /*!< Specifies the BaudRate prescaler value which will be used to configure the transmit and receive SCK clock.
87 This parameter can be a value of @ref SPI_LL_EC_BAUDRATEPRESCALER.
88 @note The communication clock is derived from the master clock. The slave clock does not need to be set.
90 This feature can be modified afterwards using unitary function @ref LL_SPI_SetBaudRatePrescaler().*/
92 uint32_t BitOrder
; /*!< Specifies whether data transfers start from MSB or LSB bit.
93 This parameter can be a value of @ref SPI_LL_EC_BIT_ORDER.
95 This feature can be modified afterwards using unitary function @ref LL_SPI_SetTransferBitOrder().*/
97 uint32_t CRCCalculation
; /*!< Specifies if the CRC calculation is enabled or not.
98 This parameter can be a value of @ref SPI_LL_EC_CRC_CALCULATION.
100 This feature can be modified afterwards using unitary functions @ref LL_SPI_EnableCRC() and @ref LL_SPI_DisableCRC().*/
102 uint32_t CRCPoly
; /*!< Specifies the polynomial used for the CRC calculation.
103 This parameter must be a number between Min_Data = 0x00 and Max_Data = 0xFFFFFFFF.
105 This feature can be modified afterwards using unitary function @ref LL_SPI_SetCRCPolynomial().*/
107 } LL_SPI_InitTypeDef
;
112 #endif /*USE_FULL_LL_DRIVER*/
114 /* Exported types ------------------------------------------------------------*/
116 /* Exported constants --------------------------------------------------------*/
117 /** @defgroup SPI_LL_Exported_Constants SPI Exported Constants
121 /** @defgroup SPI_LL_EC_GET_FLAG Get Flags Defines
122 * @brief Flags defines which can be used with LL_SPI_ReadReg function
125 #define LL_SPI_SR_RXP (SPI_SR_RXP)
126 #define LL_SPI_SR_TXP (SPI_SR_TXP)
127 #define LL_SPI_SR_DXP (SPI_SR_DXP)
128 #define LL_SPI_SR_EOT (SPI_SR_EOT)
129 #define LL_SPI_SR_TXTF (SPI_SR_TXTF)
130 #define LL_SPI_SR_UDR (SPI_SR_UDR)
131 #define LL_SPI_SR_CRCE (SPI_SR_CRCE)
132 #define LL_SPI_SR_MODF (SPI_SR_MODF)
133 #define LL_SPI_SR_OVR (SPI_SR_OVR)
134 #define LL_SPI_SR_TIFRE (SPI_SR_TIFRE)
135 #define LL_SPI_SR_TSERF (SPI_SR_TSERF)
136 #define LL_SPI_SR_SUSP (SPI_SR_SUSP)
137 #define LL_SPI_SR_TXC (SPI_SR_TXC)
138 #define LL_SPI_SR_RXWNE (SPI_SR_RXWNE)
143 /** @defgroup SPI_LL_EC_IT IT Defines
144 * @brief IT defines which can be used with LL_SPI_ReadReg and LL_SPI_WriteReg functions
147 #define LL_SPI_IER_RXPIE (SPI_IER_RXPIE)
148 #define LL_SPI_IER_TXPIE (SPI_IER_TXPIE)
149 #define LL_SPI_IER_DXPIE (SPI_IER_DXPIE)
150 #define LL_SPI_IER_EOTIE (SPI_IER_EOTIE)
151 #define LL_SPI_IER_TXTFIE (SPI_IER_TXTFIE)
152 #define LL_SPI_IER_UDRIE (SPI_IER_UDRIE)
153 #define LL_SPI_IER_OVRIE (SPI_IER_OVRIE)
154 #define LL_SPI_IER_CRCEIE (SPI_IER_CRCEIE)
155 #define LL_SPI_IER_TIFREIE (SPI_IER_TIFREIE)
156 #define LL_SPI_IER_MODFIE (SPI_IER_MODFIE)
157 #define LL_SPI_IER_TSERFIE (SPI_IER_TSERFIE)
162 /** @defgroup SPI_LL_EC_MODE Mode
165 #define LL_SPI_MODE_MASTER (SPI_CFG2_MASTER)
166 #define LL_SPI_MODE_SLAVE (0x00000000UL)
171 /** @defgroup SPI_LL_EC_SS_LEVEL SS Level
174 #define LL_SPI_SS_LEVEL_HIGH (SPI_CR1_SSI)
175 #define LL_SPI_SS_LEVEL_LOW (0x00000000UL)
180 /** @defgroup SPI_LL_EC_SS_IDLENESS SS Idleness
183 #define LL_SPI_SS_IDLENESS_00CYCLE (0x00000000UL)
184 #define LL_SPI_SS_IDLENESS_01CYCLE (SPI_CFG2_MSSI_0)
185 #define LL_SPI_SS_IDLENESS_02CYCLE (SPI_CFG2_MSSI_1)
186 #define LL_SPI_SS_IDLENESS_03CYCLE (SPI_CFG2_MSSI_0 | SPI_CFG2_MSSI_1)
187 #define LL_SPI_SS_IDLENESS_04CYCLE (SPI_CFG2_MSSI_2)
188 #define LL_SPI_SS_IDLENESS_05CYCLE (SPI_CFG2_MSSI_2 | SPI_CFG2_MSSI_0)
189 #define LL_SPI_SS_IDLENESS_06CYCLE (SPI_CFG2_MSSI_2 | SPI_CFG2_MSSI_1)
190 #define LL_SPI_SS_IDLENESS_07CYCLE (SPI_CFG2_MSSI_2 | SPI_CFG2_MSSI_1 | SPI_CFG2_MSSI_0)
191 #define LL_SPI_SS_IDLENESS_08CYCLE (SPI_CFG2_MSSI_3)
192 #define LL_SPI_SS_IDLENESS_09CYCLE (SPI_CFG2_MSSI_3 | SPI_CFG2_MSSI_0)
193 #define LL_SPI_SS_IDLENESS_10CYCLE (SPI_CFG2_MSSI_3 | SPI_CFG2_MSSI_1)
194 #define LL_SPI_SS_IDLENESS_11CYCLE (SPI_CFG2_MSSI_3 | SPI_CFG2_MSSI_1 | SPI_CFG2_MSSI_0)
195 #define LL_SPI_SS_IDLENESS_12CYCLE (SPI_CFG2_MSSI_3 | SPI_CFG2_MSSI_2)
196 #define LL_SPI_SS_IDLENESS_13CYCLE (SPI_CFG2_MSSI_3 | SPI_CFG2_MSSI_2 | SPI_CFG2_MSSI_0)
197 #define LL_SPI_SS_IDLENESS_14CYCLE (SPI_CFG2_MSSI_3 | SPI_CFG2_MSSI_2 | SPI_CFG2_MSSI_1)
198 #define LL_SPI_SS_IDLENESS_15CYCLE (SPI_CFG2_MSSI_3 | SPI_CFG2_MSSI_2 | SPI_CFG2_MSSI_1 | SPI_CFG2_MSSI_0)
203 /** @defgroup SPI_LL_EC_ID_IDLENESS Master Inter-Data Idleness
206 #define LL_SPI_ID_IDLENESS_00CYCLE (0x00000000UL)
207 #define LL_SPI_ID_IDLENESS_01CYCLE (SPI_CFG2_MIDI_0)
208 #define LL_SPI_ID_IDLENESS_02CYCLE (SPI_CFG2_MIDI_1)
209 #define LL_SPI_ID_IDLENESS_03CYCLE (SPI_CFG2_MIDI_0 | SPI_CFG2_MIDI_1)
210 #define LL_SPI_ID_IDLENESS_04CYCLE (SPI_CFG2_MIDI_2)
211 #define LL_SPI_ID_IDLENESS_05CYCLE (SPI_CFG2_MIDI_2 | SPI_CFG2_MIDI_0)
212 #define LL_SPI_ID_IDLENESS_06CYCLE (SPI_CFG2_MIDI_2 | SPI_CFG2_MIDI_1)
213 #define LL_SPI_ID_IDLENESS_07CYCLE (SPI_CFG2_MIDI_2 | SPI_CFG2_MIDI_1 | SPI_CFG2_MIDI_0)
214 #define LL_SPI_ID_IDLENESS_08CYCLE (SPI_CFG2_MIDI_3)
215 #define LL_SPI_ID_IDLENESS_09CYCLE (SPI_CFG2_MIDI_3 | SPI_CFG2_MIDI_0)
216 #define LL_SPI_ID_IDLENESS_10CYCLE (SPI_CFG2_MIDI_3 | SPI_CFG2_MIDI_1)
217 #define LL_SPI_ID_IDLENESS_11CYCLE (SPI_CFG2_MIDI_3 | SPI_CFG2_MIDI_1 | SPI_CFG2_MIDI_0)
218 #define LL_SPI_ID_IDLENESS_12CYCLE (SPI_CFG2_MIDI_3 | SPI_CFG2_MIDI_2)
219 #define LL_SPI_ID_IDLENESS_13CYCLE (SPI_CFG2_MIDI_3 | SPI_CFG2_MIDI_2 | SPI_CFG2_MIDI_0)
220 #define LL_SPI_ID_IDLENESS_14CYCLE (SPI_CFG2_MIDI_3 | SPI_CFG2_MIDI_2 | SPI_CFG2_MIDI_1)
221 #define LL_SPI_ID_IDLENESS_15CYCLE (SPI_CFG2_MIDI_3 | SPI_CFG2_MIDI_2 | SPI_CFG2_MIDI_1 | SPI_CFG2_MIDI_0)
226 /** @defgroup SPI_LL_EC_TXCRCINIT_ALL TXCRC Init All
229 #define LL_SPI_TXCRCINIT_ALL_ZERO_PATTERN (0x00000000UL)
230 #define LL_SPI_TXCRCINIT_ALL_ONES_PATTERN (SPI_CR1_TCRCINI)
235 /** @defgroup SPI_LL_EC_RXCRCINIT_ALL RXCRC Init All
238 #define LL_SPI_RXCRCINIT_ALL_ZERO_PATTERN (0x00000000UL)
239 #define LL_SPI_RXCRCINIT_ALL_ONES_PATTERN (SPI_CR1_RCRCINI)
244 /** @defgroup SPI_LL_EC_UDR_CONFIG_REGISTER UDR Config Register
247 #define LL_SPI_UDR_CONFIG_REGISTER_PATTERN (0x00000000UL)
248 #define LL_SPI_UDR_CONFIG_LAST_RECEIVED (SPI_CFG1_UDRCFG_0)
249 #define LL_SPI_UDR_CONFIG_LAST_TRANSMITTED (SPI_CFG1_UDRCFG_1)
254 /** @defgroup SPI_LL_EC_UDR_DETECT_BEGIN_DATA UDR Detect Begin Data
257 #define LL_SPI_UDR_DETECT_BEGIN_DATA_FRAME (0x00000000UL)
258 #define LL_SPI_UDR_DETECT_END_DATA_FRAME (SPI_CFG1_UDRDET_0)
259 #define LL_SPI_UDR_DETECT_BEGIN_ACTIVE_NSS (SPI_CFG1_UDRDET_1)
264 /** @defgroup SPI_LL_EC_PROTOCOL Protocol
267 #define LL_SPI_PROTOCOL_MOTOROLA (0x00000000UL)
268 #define LL_SPI_PROTOCOL_TI (SPI_CFG2_SP_0)
273 /** @defgroup SPI_LL_EC_PHASE Phase
276 #define LL_SPI_PHASE_1EDGE (0x00000000UL)
277 #define LL_SPI_PHASE_2EDGE (SPI_CFG2_CPHA)
282 /** @defgroup SPI_LL_EC_POLARITY Polarity
285 #define LL_SPI_POLARITY_LOW (0x00000000UL)
286 #define LL_SPI_POLARITY_HIGH (SPI_CFG2_CPOL)
291 /** @defgroup SPI_LL_EC_NSS_POLARITY NSS Polarity
294 #define LL_SPI_NSS_POLARITY_LOW (0x00000000UL)
295 #define LL_SPI_NSS_POLARITY_HIGH (SPI_CFG2_SSIOP)
300 /** @defgroup SPI_LL_EC_BAUDRATEPRESCALER Baud Rate Prescaler
303 #define LL_SPI_BAUDRATEPRESCALER_DIV2 (0x00000000UL)
304 #define LL_SPI_BAUDRATEPRESCALER_DIV4 (SPI_CFG1_MBR_0)
305 #define LL_SPI_BAUDRATEPRESCALER_DIV8 (SPI_CFG1_MBR_1)
306 #define LL_SPI_BAUDRATEPRESCALER_DIV16 (SPI_CFG1_MBR_1 | SPI_CFG1_MBR_0)
307 #define LL_SPI_BAUDRATEPRESCALER_DIV32 (SPI_CFG1_MBR_2)
308 #define LL_SPI_BAUDRATEPRESCALER_DIV64 (SPI_CFG1_MBR_2 | SPI_CFG1_MBR_0)
309 #define LL_SPI_BAUDRATEPRESCALER_DIV128 (SPI_CFG1_MBR_2 | SPI_CFG1_MBR_1)
310 #define LL_SPI_BAUDRATEPRESCALER_DIV256 (SPI_CFG1_MBR_2 | SPI_CFG1_MBR_1 | SPI_CFG1_MBR_0)
315 /** @defgroup SPI_LL_EC_BIT_ORDER Bit Order
318 #define LL_SPI_LSB_FIRST (SPI_CFG2_LSBFRST)
319 #define LL_SPI_MSB_FIRST (0x00000000UL)
324 /** @defgroup SPI_LL_EC_TRANSFER_MODE Transfer Mode
327 #define LL_SPI_FULL_DUPLEX (0x00000000UL)
328 #define LL_SPI_SIMPLEX_TX (SPI_CFG2_COMM_0)
329 #define LL_SPI_SIMPLEX_RX (SPI_CFG2_COMM_1)
330 #define LL_SPI_HALF_DUPLEX_RX (SPI_CFG2_COMM_0|SPI_CFG2_COMM_1)
331 #define LL_SPI_HALF_DUPLEX_TX (SPI_CFG2_COMM_0|SPI_CFG2_COMM_1|SPI_CR1_HDDIR)
336 /** @defgroup SPI_LL_EC_DATAWIDTH Data Width
339 #define LL_SPI_DATAWIDTH_4BIT (SPI_CFG1_DSIZE_0 | SPI_CFG1_DSIZE_1)
340 #define LL_SPI_DATAWIDTH_5BIT (SPI_CFG1_DSIZE_2)
341 #define LL_SPI_DATAWIDTH_6BIT (SPI_CFG1_DSIZE_2 | SPI_CFG1_DSIZE_0)
342 #define LL_SPI_DATAWIDTH_7BIT (SPI_CFG1_DSIZE_2 | SPI_CFG1_DSIZE_1)
343 #define LL_SPI_DATAWIDTH_8BIT (SPI_CFG1_DSIZE_2 | SPI_CFG1_DSIZE_1 | SPI_CFG1_DSIZE_0)
344 #define LL_SPI_DATAWIDTH_9BIT (SPI_CFG1_DSIZE_3)
345 #define LL_SPI_DATAWIDTH_10BIT (SPI_CFG1_DSIZE_3 | SPI_CFG1_DSIZE_0)
346 #define LL_SPI_DATAWIDTH_11BIT (SPI_CFG1_DSIZE_3 | SPI_CFG1_DSIZE_1)
347 #define LL_SPI_DATAWIDTH_12BIT (SPI_CFG1_DSIZE_3 | SPI_CFG1_DSIZE_1 | SPI_CFG1_DSIZE_0)
348 #define LL_SPI_DATAWIDTH_13BIT (SPI_CFG1_DSIZE_3 | SPI_CFG1_DSIZE_2)
349 #define LL_SPI_DATAWIDTH_14BIT (SPI_CFG1_DSIZE_3 | SPI_CFG1_DSIZE_2 | SPI_CFG1_DSIZE_0)
350 #define LL_SPI_DATAWIDTH_15BIT (SPI_CFG1_DSIZE_3 | SPI_CFG1_DSIZE_2 | SPI_CFG1_DSIZE_1)
351 #define LL_SPI_DATAWIDTH_16BIT (SPI_CFG1_DSIZE_3 | SPI_CFG1_DSIZE_2 | SPI_CFG1_DSIZE_1 | SPI_CFG1_DSIZE_0)
352 #define LL_SPI_DATAWIDTH_17BIT (SPI_CFG1_DSIZE_4)
353 #define LL_SPI_DATAWIDTH_18BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_0)
354 #define LL_SPI_DATAWIDTH_19BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_1)
355 #define LL_SPI_DATAWIDTH_20BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_0 | SPI_CFG1_DSIZE_1)
356 #define LL_SPI_DATAWIDTH_21BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_2)
357 #define LL_SPI_DATAWIDTH_22BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_2 | SPI_CFG1_DSIZE_0)
358 #define LL_SPI_DATAWIDTH_23BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_2 | SPI_CFG1_DSIZE_1)
359 #define LL_SPI_DATAWIDTH_24BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_2 | SPI_CFG1_DSIZE_1 | SPI_CFG1_DSIZE_0)
360 #define LL_SPI_DATAWIDTH_25BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_3)
361 #define LL_SPI_DATAWIDTH_26BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_3 | SPI_CFG1_DSIZE_0)
362 #define LL_SPI_DATAWIDTH_27BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_3 | SPI_CFG1_DSIZE_1)
363 #define LL_SPI_DATAWIDTH_28BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_3 | SPI_CFG1_DSIZE_1 | SPI_CFG1_DSIZE_0)
364 #define LL_SPI_DATAWIDTH_29BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_3 | SPI_CFG1_DSIZE_2)
365 #define LL_SPI_DATAWIDTH_30BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_3 | SPI_CFG1_DSIZE_2 | SPI_CFG1_DSIZE_0)
366 #define LL_SPI_DATAWIDTH_31BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_3 | SPI_CFG1_DSIZE_2 | SPI_CFG1_DSIZE_1)
367 #define LL_SPI_DATAWIDTH_32BIT (SPI_CFG1_DSIZE_4 | SPI_CFG1_DSIZE_3 | SPI_CFG1_DSIZE_2 | SPI_CFG1_DSIZE_1 | SPI_CFG1_DSIZE_0)
372 /** @defgroup SPI_LL_EC_FIFO_TH FIFO Threshold
375 #define LL_SPI_FIFO_TH_01DATA (0x00000000UL)
376 #define LL_SPI_FIFO_TH_02DATA (SPI_CFG1_FTHLV_0)
377 #define LL_SPI_FIFO_TH_03DATA (SPI_CFG1_FTHLV_1)
378 #define LL_SPI_FIFO_TH_04DATA (SPI_CFG1_FTHLV_0 | SPI_CFG1_FTHLV_1)
379 #define LL_SPI_FIFO_TH_05DATA (SPI_CFG1_FTHLV_2)
380 #define LL_SPI_FIFO_TH_06DATA (SPI_CFG1_FTHLV_2 | SPI_CFG1_FTHLV_0)
381 #define LL_SPI_FIFO_TH_07DATA (SPI_CFG1_FTHLV_2 | SPI_CFG1_FTHLV_1)
382 #define LL_SPI_FIFO_TH_08DATA (SPI_CFG1_FTHLV_2 | SPI_CFG1_FTHLV_1 | SPI_CFG1_FTHLV_0)
383 #define LL_SPI_FIFO_TH_09DATA (SPI_CFG1_FTHLV_3)
384 #define LL_SPI_FIFO_TH_10DATA (SPI_CFG1_FTHLV_3 | SPI_CFG1_FTHLV_0)
385 #define LL_SPI_FIFO_TH_11DATA (SPI_CFG1_FTHLV_3 | SPI_CFG1_FTHLV_1)
386 #define LL_SPI_FIFO_TH_12DATA (SPI_CFG1_FTHLV_3 | SPI_CFG1_FTHLV_1 | SPI_CFG1_FTHLV_0)
387 #define LL_SPI_FIFO_TH_13DATA (SPI_CFG1_FTHLV_3 | SPI_CFG1_FTHLV_2)
388 #define LL_SPI_FIFO_TH_14DATA (SPI_CFG1_FTHLV_3 | SPI_CFG1_FTHLV_2 | SPI_CFG1_FTHLV_0)
389 #define LL_SPI_FIFO_TH_15DATA (SPI_CFG1_FTHLV_3 | SPI_CFG1_FTHLV_2 | SPI_CFG1_FTHLV_1)
390 #define LL_SPI_FIFO_TH_16DATA (SPI_CFG1_FTHLV_3 | SPI_CFG1_FTHLV_2 | SPI_CFG1_FTHLV_1 | SPI_CFG1_FTHLV_0)
395 #if defined(USE_FULL_LL_DRIVER)
397 /** @defgroup SPI_LL_EC_CRC_CALCULATION CRC Calculation
400 #define LL_SPI_CRCCALCULATION_DISABLE (0x00000000UL) /*!< CRC calculation disabled */
401 #define LL_SPI_CRCCALCULATION_ENABLE (SPI_CFG1_CRCEN) /*!< CRC calculation enabled */
405 #endif /* USE_FULL_LL_DRIVER */
407 /** @defgroup SPI_LL_EC_CRC CRC
410 #define LL_SPI_CRC_4BIT (SPI_CFG1_CRCSIZE_0 | SPI_CFG1_CRCSIZE_1)
411 #define LL_SPI_CRC_5BIT (SPI_CFG1_CRCSIZE_2)
412 #define LL_SPI_CRC_6BIT (SPI_CFG1_CRCSIZE_2 | SPI_CFG1_CRCSIZE_0)
413 #define LL_SPI_CRC_7BIT (SPI_CFG1_CRCSIZE_2 | SPI_CFG1_CRCSIZE_1)
414 #define LL_SPI_CRC_8BIT (SPI_CFG1_CRCSIZE_2 | SPI_CFG1_CRCSIZE_1 | SPI_CFG1_CRCSIZE_0)
415 #define LL_SPI_CRC_9BIT (SPI_CFG1_CRCSIZE_3)
416 #define LL_SPI_CRC_10BIT (SPI_CFG1_CRCSIZE_3 | SPI_CFG1_CRCSIZE_0)
417 #define LL_SPI_CRC_11BIT (SPI_CFG1_CRCSIZE_3 | SPI_CFG1_CRCSIZE_1)
418 #define LL_SPI_CRC_12BIT (SPI_CFG1_CRCSIZE_3 | SPI_CFG1_CRCSIZE_1 | SPI_CFG1_CRCSIZE_0)
419 #define LL_SPI_CRC_13BIT (SPI_CFG1_CRCSIZE_3 | SPI_CFG1_CRCSIZE_2)
420 #define LL_SPI_CRC_14BIT (SPI_CFG1_CRCSIZE_3 | SPI_CFG1_CRCSIZE_2 | SPI_CFG1_CRCSIZE_0)
421 #define LL_SPI_CRC_15BIT (SPI_CFG1_CRCSIZE_3 | SPI_CFG1_CRCSIZE_2 | SPI_CFG1_CRCSIZE_1)
422 #define LL_SPI_CRC_16BIT (SPI_CFG1_CRCSIZE_3 | SPI_CFG1_CRCSIZE_2 | SPI_CFG1_CRCSIZE_1 | SPI_CFG1_CRCSIZE_0)
423 #define LL_SPI_CRC_17BIT (SPI_CFG1_CRCSIZE_4)
424 #define LL_SPI_CRC_18BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_0)
425 #define LL_SPI_CRC_19BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_1)
426 #define LL_SPI_CRC_20BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_0 | SPI_CFG1_CRCSIZE_1)
427 #define LL_SPI_CRC_21BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_2)
428 #define LL_SPI_CRC_22BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_2 | SPI_CFG1_CRCSIZE_0)
429 #define LL_SPI_CRC_23BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_2 | SPI_CFG1_CRCSIZE_1)
430 #define LL_SPI_CRC_24BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_2 | SPI_CFG1_CRCSIZE_1 | SPI_CFG1_CRCSIZE_0)
431 #define LL_SPI_CRC_25BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_3)
432 #define LL_SPI_CRC_26BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_3 | SPI_CFG1_CRCSIZE_0)
433 #define LL_SPI_CRC_27BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_3 | SPI_CFG1_CRCSIZE_1)
434 #define LL_SPI_CRC_28BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_3 | SPI_CFG1_CRCSIZE_1 | SPI_CFG1_CRCSIZE_0)
435 #define LL_SPI_CRC_29BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_3 | SPI_CFG1_CRCSIZE_2)
436 #define LL_SPI_CRC_30BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_3 | SPI_CFG1_CRCSIZE_2 | SPI_CFG1_CRCSIZE_0)
437 #define LL_SPI_CRC_31BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_3 | SPI_CFG1_CRCSIZE_2 | SPI_CFG1_CRCSIZE_1)
438 #define LL_SPI_CRC_32BIT (SPI_CFG1_CRCSIZE_4 | SPI_CFG1_CRCSIZE_3 | SPI_CFG1_CRCSIZE_2 | SPI_CFG1_CRCSIZE_1 | SPI_CFG1_CRCSIZE_0)
443 /** @defgroup SPI_LL_EC_NSS_MODE NSS Mode
446 #define LL_SPI_NSS_SOFT (SPI_CFG2_SSM)
447 #define LL_SPI_NSS_HARD_INPUT (0x00000000UL)
448 #define LL_SPI_NSS_HARD_OUTPUT (SPI_CFG2_SSOE)
453 /** @defgroup SPI_LL_EC_RX_FIFO RxFIFO Packing LeVel
456 #define LL_SPI_RX_FIFO_0PACKET (0x00000000UL) /* 0 or multiple of 4 packet available is the RxFIFO */
457 #define LL_SPI_RX_FIFO_1PACKET (SPI_SR_RXPLVL_0)
458 #define LL_SPI_RX_FIFO_2PACKET (SPI_SR_RXPLVL_1)
459 #define LL_SPI_RX_FIFO_3PACKET (SPI_SR_RXPLVL_1 | SPI_SR_RXPLVL_0)
468 /* Exported macro ------------------------------------------------------------*/
469 /** @defgroup SPI_LL_Exported_Macros SPI Exported Macros
473 /** @defgroup SPI_LL_EM_WRITE_READ Common Write and read registers Macros
478 * @brief Write a value in SPI register
479 * @param __INSTANCE__ SPI Instance
480 * @param __REG__ Register to be written
481 * @param __VALUE__ Value to be written in the register
484 #define LL_SPI_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__))
487 * @brief Read a value in SPI register
488 * @param __INSTANCE__ SPI Instance
489 * @param __REG__ Register to be read
490 * @retval Register value
492 #define LL_SPI_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__)
502 /* Exported functions --------------------------------------------------------*/
504 /** @defgroup SPI_LL_Exported_Functions SPI Exported Functions
508 /** @defgroup SPI_LL_EF_Configuration Configuration
513 * @brief Enable SPI peripheral
514 * @rmtoll CR1 SPE LL_SPI_Enable
515 * @param SPIx SPI Instance
518 __STATIC_INLINE
void LL_SPI_Enable(SPI_TypeDef
*SPIx
)
520 SET_BIT(SPIx
->CR1
, SPI_CR1_SPE
);
524 * @brief Disable SPI peripheral
525 * @note When disabling the SPI, follow the procedure described in the Reference Manual.
526 * @rmtoll CR1 SPE LL_SPI_Disable
527 * @param SPIx SPI Instance
530 __STATIC_INLINE
void LL_SPI_Disable(SPI_TypeDef
*SPIx
)
532 CLEAR_BIT(SPIx
->CR1
, SPI_CR1_SPE
);
536 * @brief Check if SPI peripheral is enabled
537 * @rmtoll CR1 SPE LL_SPI_IsEnabled
538 * @param SPIx SPI Instance
539 * @retval State of bit (1 or 0)
541 __STATIC_INLINE
uint32_t LL_SPI_IsEnabled(SPI_TypeDef
*SPIx
)
543 return ((READ_BIT(SPIx
->CR1
, SPI_CR1_SPE
) == (SPI_CR1_SPE
)) ? 1UL : 0UL);
547 * @brief Swap the MOSI and MISO pin
548 * @note This configuration can not be changed when SPI is enabled.
549 * @rmtoll CFG2 IOSWP LL_SPI_EnableIOSwap
550 * @param SPIx SPI Instance
553 __STATIC_INLINE
void LL_SPI_EnableIOSwap(SPI_TypeDef
*SPIx
)
555 SET_BIT(SPIx
->CFG2
, SPI_CFG2_IOSWP
);
559 * @brief Restore default function for MOSI and MISO pin
560 * @note This configuration can not be changed when SPI is enabled.
561 * @rmtoll CFG2 IOSWP LL_SPI_DisableIOSwap
562 * @param SPIx SPI Instance
565 __STATIC_INLINE
void LL_SPI_DisableIOSwap(SPI_TypeDef
*SPIx
)
567 CLEAR_BIT(SPIx
->CFG2
, SPI_CFG2_IOSWP
);
571 * @brief Check if MOSI and MISO pin are swapped
572 * @rmtoll CFG2 IOSWP LL_SPI_IsEnabledIOSwap
573 * @param SPIx SPI Instance
574 * @retval State of bit (1 or 0)
576 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledIOSwap(SPI_TypeDef
*SPIx
)
578 return ((READ_BIT(SPIx
->CFG2
, SPI_CFG2_IOSWP
) == (SPI_CFG2_IOSWP
)) ? 1UL : 0UL);
582 * @brief Enable GPIO control
583 * @note This configuration can not be changed when SPI is enabled.
584 * @rmtoll CFG2 AFCNTR LL_SPI_EnableGPIOControl
585 * @param SPIx SPI Instance
588 __STATIC_INLINE
void LL_SPI_EnableGPIOControl(SPI_TypeDef
*SPIx
)
590 SET_BIT(SPIx
->CFG2
, SPI_CFG2_AFCNTR
);
594 * @brief Disable GPIO control
595 * @note This configuration can not be changed when SPI is enabled.
596 * @rmtoll CFG2 AFCNTR LL_SPI_DisableGPIOControl
597 * @param SPIx SPI Instance
600 __STATIC_INLINE
void LL_SPI_DisableGPIOControl(SPI_TypeDef
*SPIx
)
602 CLEAR_BIT(SPIx
->CFG2
, SPI_CFG2_AFCNTR
);
606 * @brief Check if GPIO control is active
607 * @rmtoll CFG2 AFCNTR LL_SPI_IsEnabledGPIOControl
608 * @param SPIx SPI Instance
609 * @retval State of bit (1 or 0)
611 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledGPIOControl(SPI_TypeDef
*SPIx
)
613 return ((READ_BIT(SPIx
->CFG2
, SPI_CFG2_AFCNTR
) == (SPI_CFG2_AFCNTR
)) ? 1UL : 0UL);
617 * @brief Set SPI Mode to Master or Slave
618 * @note This configuration can not be changed when SPI is enabled.
619 * @rmtoll CFG2 MASTER LL_SPI_SetMode
620 * @param SPIx SPI Instance
621 * @param Mode This parameter can be one of the following values:
622 * @arg @ref LL_SPI_MODE_MASTER
623 * @arg @ref LL_SPI_MODE_SLAVE
626 __STATIC_INLINE
void LL_SPI_SetMode(SPI_TypeDef
*SPIx
, uint32_t Mode
)
628 MODIFY_REG(SPIx
->CFG2
, SPI_CFG2_MASTER
, Mode
);
632 * @brief Get SPI Mode (Master or Slave)
633 * @rmtoll CFG2 MASTER LL_SPI_GetMode
634 * @param SPIx SPI Instance
635 * @retval Returned value can be one of the following values:
636 * @arg @ref LL_SPI_MODE_MASTER
637 * @arg @ref LL_SPI_MODE_SLAVE
639 __STATIC_INLINE
uint32_t LL_SPI_GetMode(SPI_TypeDef
*SPIx
)
641 return (uint32_t)(READ_BIT(SPIx
->CFG2
, SPI_CFG2_MASTER
));
645 * @brief Configure the Idleness applied by master between active edge of SS and first send data
646 * @rmtoll CFG2 MSSI LL_SPI_SetMasterSSIdleness
647 * @param SPIx SPI Instance
648 * @param MasterSSIdleness This parameter can be one of the following values:
649 * @arg @ref LL_SPI_SS_IDLENESS_00CYCLE
650 * @arg @ref LL_SPI_SS_IDLENESS_01CYCLE
651 * @arg @ref LL_SPI_SS_IDLENESS_02CYCLE
652 * @arg @ref LL_SPI_SS_IDLENESS_03CYCLE
653 * @arg @ref LL_SPI_SS_IDLENESS_04CYCLE
654 * @arg @ref LL_SPI_SS_IDLENESS_05CYCLE
655 * @arg @ref LL_SPI_SS_IDLENESS_06CYCLE
656 * @arg @ref LL_SPI_SS_IDLENESS_07CYCLE
657 * @arg @ref LL_SPI_SS_IDLENESS_08CYCLE
658 * @arg @ref LL_SPI_SS_IDLENESS_09CYCLE
659 * @arg @ref LL_SPI_SS_IDLENESS_10CYCLE
660 * @arg @ref LL_SPI_SS_IDLENESS_11CYCLE
661 * @arg @ref LL_SPI_SS_IDLENESS_12CYCLE
662 * @arg @ref LL_SPI_SS_IDLENESS_13CYCLE
663 * @arg @ref LL_SPI_SS_IDLENESS_14CYCLE
664 * @arg @ref LL_SPI_SS_IDLENESS_15CYCLE
667 __STATIC_INLINE
void LL_SPI_SetMasterSSIdleness(SPI_TypeDef
*SPIx
, uint32_t MasterSSIdleness
)
669 MODIFY_REG(SPIx
->CFG2
, SPI_CFG2_MSSI
, MasterSSIdleness
);
673 * @brief Get the configured Idleness applied by master
674 * @rmtoll CFG2 MSSI LL_SPI_GetMasterSSIdleness
675 * @param SPIx SPI Instance
676 * @retval Returned value can be one of the following values:
677 * @arg @ref LL_SPI_SS_IDLENESS_00CYCLE
678 * @arg @ref LL_SPI_SS_IDLENESS_01CYCLE
679 * @arg @ref LL_SPI_SS_IDLENESS_02CYCLE
680 * @arg @ref LL_SPI_SS_IDLENESS_03CYCLE
681 * @arg @ref LL_SPI_SS_IDLENESS_04CYCLE
682 * @arg @ref LL_SPI_SS_IDLENESS_05CYCLE
683 * @arg @ref LL_SPI_SS_IDLENESS_06CYCLE
684 * @arg @ref LL_SPI_SS_IDLENESS_07CYCLE
685 * @arg @ref LL_SPI_SS_IDLENESS_08CYCLE
686 * @arg @ref LL_SPI_SS_IDLENESS_09CYCLE
687 * @arg @ref LL_SPI_SS_IDLENESS_10CYCLE
688 * @arg @ref LL_SPI_SS_IDLENESS_11CYCLE
689 * @arg @ref LL_SPI_SS_IDLENESS_12CYCLE
690 * @arg @ref LL_SPI_SS_IDLENESS_13CYCLE
691 * @arg @ref LL_SPI_SS_IDLENESS_14CYCLE
692 * @arg @ref LL_SPI_SS_IDLENESS_15CYCLE
694 __STATIC_INLINE
uint32_t LL_SPI_GetMasterSSIdleness(SPI_TypeDef
*SPIx
)
696 return (uint32_t)(READ_BIT(SPIx
->CFG2
, SPI_CFG2_MSSI
));
700 * @brief Configure the idleness applied by master between data frame
701 * @rmtoll CFG2 MIDI LL_SPI_SetInterDataIdleness
702 * @param SPIx SPI Instance
703 * @param MasterInterDataIdleness This parameter can be one of the following values:
704 * @arg @ref LL_SPI_ID_IDLENESS_00CYCLE
705 * @arg @ref LL_SPI_ID_IDLENESS_01CYCLE
706 * @arg @ref LL_SPI_ID_IDLENESS_02CYCLE
707 * @arg @ref LL_SPI_ID_IDLENESS_03CYCLE
708 * @arg @ref LL_SPI_ID_IDLENESS_04CYCLE
709 * @arg @ref LL_SPI_ID_IDLENESS_05CYCLE
710 * @arg @ref LL_SPI_ID_IDLENESS_06CYCLE
711 * @arg @ref LL_SPI_ID_IDLENESS_07CYCLE
712 * @arg @ref LL_SPI_ID_IDLENESS_08CYCLE
713 * @arg @ref LL_SPI_ID_IDLENESS_09CYCLE
714 * @arg @ref LL_SPI_ID_IDLENESS_10CYCLE
715 * @arg @ref LL_SPI_ID_IDLENESS_11CYCLE
716 * @arg @ref LL_SPI_ID_IDLENESS_12CYCLE
717 * @arg @ref LL_SPI_ID_IDLENESS_13CYCLE
718 * @arg @ref LL_SPI_ID_IDLENESS_14CYCLE
719 * @arg @ref LL_SPI_ID_IDLENESS_15CYCLE
722 __STATIC_INLINE
void LL_SPI_SetInterDataIdleness(SPI_TypeDef
*SPIx
, uint32_t MasterInterDataIdleness
)
724 MODIFY_REG(SPIx
->CFG2
, SPI_CFG2_MIDI
, MasterInterDataIdleness
);
728 * @brief Get the configured inter data idleness
729 * @rmtoll CFG2 MIDI LL_SPI_SetInterDataIdleness
730 * @param SPIx SPI Instance
731 * @retval Returned value can be one of the following values:
732 * @arg @ref LL_SPI_ID_IDLENESS_00CYCLE
733 * @arg @ref LL_SPI_ID_IDLENESS_01CYCLE
734 * @arg @ref LL_SPI_ID_IDLENESS_02CYCLE
735 * @arg @ref LL_SPI_ID_IDLENESS_03CYCLE
736 * @arg @ref LL_SPI_ID_IDLENESS_04CYCLE
737 * @arg @ref LL_SPI_ID_IDLENESS_05CYCLE
738 * @arg @ref LL_SPI_ID_IDLENESS_06CYCLE
739 * @arg @ref LL_SPI_ID_IDLENESS_07CYCLE
740 * @arg @ref LL_SPI_ID_IDLENESS_08CYCLE
741 * @arg @ref LL_SPI_ID_IDLENESS_09CYCLE
742 * @arg @ref LL_SPI_ID_IDLENESS_10CYCLE
743 * @arg @ref LL_SPI_ID_IDLENESS_11CYCLE
744 * @arg @ref LL_SPI_ID_IDLENESS_12CYCLE
745 * @arg @ref LL_SPI_ID_IDLENESS_13CYCLE
746 * @arg @ref LL_SPI_ID_IDLENESS_14CYCLE
747 * @arg @ref LL_SPI_ID_IDLENESS_15CYCLE
749 __STATIC_INLINE
uint32_t LL_SPI_GetInterDataIdleness(SPI_TypeDef
*SPIx
)
751 return (uint32_t)(READ_BIT(SPIx
->CFG2
, SPI_CFG2_MIDI
));
755 * @brief Set transfer size
756 * @note Count is the number of frame to be transferred
757 * @rmtoll CR2 TSIZE LL_SPI_SetTransferSize
758 * @param SPIx SPI Instance
759 * @param Count 0..0xFFFF
762 __STATIC_INLINE
void LL_SPI_SetTransferSize(SPI_TypeDef
*SPIx
, uint32_t Count
)
764 MODIFY_REG(SPIx
->CR2
, SPI_CR2_TSIZE
, Count
);
768 * @brief Get transfer size
769 * @note Count is the number of frame to be transferred
770 * @rmtoll CR2 TSIZE LL_SPI_GetTransferSize
771 * @param SPIx SPI Instance
774 __STATIC_INLINE
uint32_t LL_SPI_GetTransferSize(SPI_TypeDef
*SPIx
)
776 return (uint32_t)(READ_BIT(SPIx
->CR2
, SPI_CR2_TSIZE
));
780 * @brief Set reload transfer size
781 * @note Count is the number of frame to be transferred
782 * @rmtoll CR2 TSER LL_SPI_SetReloadSize
783 * @param SPIx SPI Instance
784 * @param Count 0..0xFFFF
787 __STATIC_INLINE
void LL_SPI_SetReloadSize(SPI_TypeDef
*SPIx
, uint32_t Count
)
789 MODIFY_REG(SPIx
->CR2
, SPI_CR2_TSER
, Count
<< SPI_CR2_TSER_Pos
);
793 * @brief Get reload transfer size
794 * @note Count is the number of frame to be transferred
795 * @rmtoll CR2 TSER LL_SPI_GetReloadSize
796 * @param SPIx SPI Instance
799 __STATIC_INLINE
uint32_t LL_SPI_GetReloadSize(SPI_TypeDef
*SPIx
)
801 return (uint32_t)(READ_BIT(SPIx
->CR2
, SPI_CR2_TSER
) >> SPI_CR2_TSER_Pos
);
805 * @brief Lock the AF configuration of associated IOs
806 * @note Once this bit is set, the AF configuration remains locked until a hardware reset occurs.
807 * the reset of the IOLock bit is done by hardware. for that, LL_SPI_DisableIOLock can not exist.
808 * @rmtoll CR1 IOLOCK LL_SPI_EnableIOLock
809 * @param SPIx SPI Instance
812 __STATIC_INLINE
void LL_SPI_EnableIOLock(SPI_TypeDef
*SPIx
)
814 SET_BIT(SPIx
->CR1
, SPI_CR1_IOLOCK
);
818 * @brief Check if the AF configuration is locked.
819 * @rmtoll CR1 IOLOCK LL_SPI_IsEnabledIOLock
820 * @param SPIx SPI Instance
821 * @retval State of bit (1 or 0)
823 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledIOLock(SPI_TypeDef
*SPIx
)
825 return ((READ_BIT(SPIx
->CR1
, SPI_CR1_IOLOCK
) == (SPI_CR1_IOLOCK
)) ? 1UL : 0UL);
829 * @brief Set Tx CRC Initialization Pattern
830 * @rmtoll CR1 TCRCINI LL_SPI_SetTxCRCInitPattern
831 * @param SPIx SPI Instance
832 * @param TXCRCInitAll This parameter can be one of the following values:
833 * @arg @ref LL_SPI_TXCRCINIT_ALL_ZERO_PATTERN
834 * @arg @ref LL_SPI_TXCRCINIT_ALL_ONES_PATTERN
837 __STATIC_INLINE
void LL_SPI_SetTxCRCInitPattern(SPI_TypeDef
*SPIx
, uint32_t TXCRCInitAll
)
839 MODIFY_REG(SPIx
->CR1
, SPI_CR1_RCRCINI
, TXCRCInitAll
);
843 * @brief Get Tx CRC Initialization Pattern
844 * @rmtoll CR1 TCRCINI LL_SPI_GetTxCRCInitPattern
845 * @param SPIx SPI Instance
846 * @retval Returned value can be one of the following values:
847 * @arg @ref LL_SPI_TXCRCINIT_ALL_ZERO_PATTERN
848 * @arg @ref LL_SPI_TXCRCINIT_ALL_ONES_PATTERN
850 __STATIC_INLINE
uint32_t LL_SPI_GetTxCRCInitPattern(SPI_TypeDef
*SPIx
)
852 return (uint32_t)(READ_BIT(SPIx
->CR1
, SPI_CR1_TCRCINI
));
856 * @brief Set Rx CRC Initialization Pattern
857 * @rmtoll CR1 RCRCINI LL_SPI_SetRxCRCInitPattern
858 * @param SPIx SPI Instance
859 * @param RXCRCInitAll This parameter can be one of the following values:
860 * @arg @ref LL_SPI_RXCRCINIT_ALL_ZERO_PATTERN
861 * @arg @ref LL_SPI_RXCRCINIT_ALL_ONES_PATTERN
864 __STATIC_INLINE
void LL_SPI_SetRxCRCInitPattern(SPI_TypeDef
*SPIx
, uint32_t RXCRCInitAll
)
866 MODIFY_REG(SPIx
->CR1
, SPI_CR1_RCRCINI
, RXCRCInitAll
);
870 * @brief Get Rx CRC Initialization Pattern
871 * @rmtoll CR1 RCRCINI LL_SPI_GetRxCRCInitPattern
872 * @param SPIx SPI Instance
873 * @retval Returned value can be one of the following values:
874 * @arg @ref LL_SPI_RXCRCINIT_ALL_ZERO_PATTERN
875 * @arg @ref LL_SPI_RXCRCINIT_ALL_ONES_PATTERN
877 __STATIC_INLINE
uint32_t LL_SPI_GetRxCRCInitPattern(SPI_TypeDef
*SPIx
)
879 return (uint32_t)(READ_BIT(SPIx
->CR1
, SPI_CR1_RCRCINI
));
883 * @brief Set internal SS input level ignoring what comes from PIN.
884 * @note This configuration has effect only with config LL_SPI_NSS_SOFT
885 * @rmtoll CR1 SSI LL_SPI_SetInternalSSLevel
886 * @param SPIx SPI Instance
887 * @param SSLevel This parameter can be one of the following values:
888 * @arg @ref LL_SPI_SS_LEVEL_HIGH
889 * @arg @ref LL_SPI_SS_LEVEL_LOW
892 __STATIC_INLINE
void LL_SPI_SetInternalSSLevel(SPI_TypeDef
*SPIx
, uint32_t SSLevel
)
894 MODIFY_REG(SPIx
->CR1
, SPI_CR1_SSI
, SSLevel
);
898 * @brief Get internal SS input level
899 * @rmtoll CR1 SSI LL_SPI_GetInternalSSLevel
900 * @param SPIx SPI Instance
901 * @retval Returned value can be one of the following values:
902 * @arg @ref LL_SPI_SS_LEVEL_HIGH
903 * @arg @ref LL_SPI_SS_LEVEL_LOW
905 __STATIC_INLINE
uint32_t LL_SPI_GetInternalSSLevel(SPI_TypeDef
*SPIx
)
907 return (uint32_t)(READ_BIT(SPIx
->CR1
, SPI_CR1_SSI
));
911 * @brief Enable CRC computation on 33/17 bits
912 * @rmtoll CR1 CRC33_17 LL_SPI_EnableFullSizeCRC
913 * @param SPIx SPI Instance
916 __STATIC_INLINE
void LL_SPI_EnableFullSizeCRC(SPI_TypeDef
*SPIx
)
918 SET_BIT(SPIx
->CR1
, SPI_CR1_CRC33_17
);
922 * @brief Disable CRC computation on 33/17 bits
923 * @rmtoll CR1 CRC33_17 LL_SPI_DisableFullSizeCRC
924 * @param SPIx SPI Instance
927 __STATIC_INLINE
void LL_SPI_DisableFullSizeCRC(SPI_TypeDef
*SPIx
)
929 CLEAR_BIT(SPIx
->CR1
, SPI_CR1_CRC33_17
);
933 * @brief Check if Enable CRC computation on 33/17 bits is enabled
934 * @rmtoll CR1 CRC33_17 LL_SPI_IsEnabledFullSizeCRC
935 * @param SPIx SPI Instance
936 * @retval State of bit (1 or 0)
938 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledFullSizeCRC(SPI_TypeDef
*SPIx
)
940 return ((READ_BIT(SPIx
->CR1
, SPI_CR1_CRC33_17
) == (SPI_CR1_CRC33_17
)) ? 1UL : 0UL);
944 * @brief Suspend an ongoing transfer for Master configuration
945 * @rmtoll CR1 CSUSP LL_SPI_SuspendMasterTransfer
946 * @param SPIx SPI Instance
949 __STATIC_INLINE
void LL_SPI_SuspendMasterTransfer(SPI_TypeDef
*SPIx
)
951 SET_BIT(SPIx
->CR1
, SPI_CR1_CSUSP
);
955 * @brief Start effective transfer on wire for Master configuration
956 * @rmtoll CR1 CSTART LL_SPI_StartMasterTransfer
957 * @param SPIx SPI Instance
960 __STATIC_INLINE
void LL_SPI_StartMasterTransfer(SPI_TypeDef
*SPIx
)
962 SET_BIT(SPIx
->CR1
, SPI_CR1_CSTART
);
966 * @brief Check if there is an unfinished master transfer
967 * @rmtoll CR1 CSTART LL_SPI_IsMasterTransferActive
968 * @param SPIx SPI Instance
969 * @retval State of bit (1 or 0)
971 __STATIC_INLINE
uint32_t LL_SPI_IsActiveMasterTransfer(SPI_TypeDef
*SPIx
)
973 return ((READ_BIT(SPIx
->CR1
, SPI_CR1_CSTART
) == (SPI_CR1_CSTART
)) ? 1UL : 0UL);
977 * @brief Enable Master Rx auto suspend in case of overrun
978 * @rmtoll CR1 MASRX LL_SPI_EnableMasterRxAutoSuspend
979 * @param SPIx SPI Instance
982 __STATIC_INLINE
void LL_SPI_EnableMasterRxAutoSuspend(SPI_TypeDef
*SPIx
)
984 SET_BIT(SPIx
->CR1
, SPI_CR1_MASRX
);
988 * @brief Disable Master Rx auto suspend in case of overrun
989 * @rmtoll CR1 MASRX LL_SPI_DisableMasterRxAutoSuspend
990 * @param SPIx SPI Instance
993 __STATIC_INLINE
void LL_SPI_DisableMasterRxAutoSuspend(SPI_TypeDef
*SPIx
)
995 CLEAR_BIT(SPIx
->CR1
, SPI_CR1_MASRX
);
999 * @brief Check if Master Rx auto suspend is activated
1000 * @rmtoll CR1 MASRX LL_SPI_IsEnabledMasterRxAutoSuspend
1001 * @param SPIx SPI Instance
1002 * @retval State of bit (1 or 0)
1004 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledMasterRxAutoSuspend(SPI_TypeDef
*SPIx
)
1006 return ((READ_BIT(SPIx
->CR1
, SPI_CR1_MASRX
) == (SPI_CR1_MASRX
)) ? 1UL : 0UL);
1010 * @brief Set Underrun behavior
1011 * @note This configuration can not be changed when SPI is enabled.
1012 * @rmtoll CFG1 UDRCFG LL_SPI_SetUDRConfiguration
1013 * @param SPIx SPI Instance
1014 * @param UDRConfig This parameter can be one of the following values:
1015 * @arg @ref LL_SPI_UDR_CONFIG_REGISTER_PATTERN
1016 * @arg @ref LL_SPI_UDR_CONFIG_LAST_RECEIVED
1017 * @arg @ref LL_SPI_UDR_CONFIG_LAST_TRANSMITTED
1020 __STATIC_INLINE
void LL_SPI_SetUDRConfiguration(SPI_TypeDef
*SPIx
, uint32_t UDRConfig
)
1022 MODIFY_REG(SPIx
->CFG1
, SPI_CFG1_UDRCFG
, UDRConfig
);
1026 * @brief Get Underrun behavior
1027 * @rmtoll CFG1 UDRCFG LL_SPI_GetUDRConfiguration
1028 * @param SPIx SPI Instance
1029 * @retval Returned value can be one of the following values:
1030 * @arg @ref LL_SPI_UDR_CONFIG_REGISTER_PATTERN
1031 * @arg @ref LL_SPI_UDR_CONFIG_LAST_RECEIVED
1032 * @arg @ref LL_SPI_UDR_CONFIG_LAST_TRANSMITTED
1034 __STATIC_INLINE
uint32_t LL_SPI_GetUDRConfiguration(SPI_TypeDef
*SPIx
)
1036 return (uint32_t)(READ_BIT(SPIx
->CFG1
, SPI_CFG1_UDRCFG
));
1040 * @brief Set Underrun Detection method
1041 * @note This configuration can not be changed when SPI is enabled.
1042 * @rmtoll CFG1 UDRDET LL_SPI_SetUDRDetection
1043 * @param SPIx SPI Instance
1044 * @param UDRDetection This parameter can be one of the following values:
1045 * @arg @ref LL_SPI_UDR_DETECT_BEGIN_DATA_FRAME
1046 * @arg @ref LL_SPI_UDR_DETECT_END_DATA_FRAME
1047 * @arg @ref LL_SPI_UDR_DETECT_BEGIN_ACTIVE_NSS
1050 __STATIC_INLINE
void LL_SPI_SetUDRDetection(SPI_TypeDef
*SPIx
, uint32_t UDRDetection
)
1052 MODIFY_REG(SPIx
->CFG1
, SPI_CFG1_UDRDET
, UDRDetection
);
1056 * @brief Get Underrun Detection method
1057 * @rmtoll CFG1 UDRDET LL_SPI_GetUDRDetection
1058 * @param SPIx SPI Instance
1059 * @retval Returned value can be one of the following values:
1060 * @arg @ref LL_SPI_UDR_DETECT_BEGIN_DATA_FRAME
1061 * @arg @ref LL_SPI_UDR_DETECT_END_DATA_FRAME
1062 * @arg @ref LL_SPI_UDR_DETECT_BEGIN_ACTIVE_NSS
1064 __STATIC_INLINE
uint32_t LL_SPI_GetUDRDetection(SPI_TypeDef
*SPIx
)
1066 return (uint32_t)(READ_BIT(SPIx
->CFG1
, SPI_CFG1_UDRDET
));
1070 * @brief Set Serial protocol used
1071 * @note This configuration can not be changed when SPI is enabled.
1072 * @rmtoll CFG2 SP LL_SPI_SetStandard
1073 * @param SPIx SPI Instance
1074 * @param Standard This parameter can be one of the following values:
1075 * @arg @ref LL_SPI_PROTOCOL_MOTOROLA
1076 * @arg @ref LL_SPI_PROTOCOL_TI
1079 __STATIC_INLINE
void LL_SPI_SetStandard(SPI_TypeDef
*SPIx
, uint32_t Standard
)
1081 MODIFY_REG(SPIx
->CFG2
, SPI_CFG2_SP
, Standard
);
1085 * @brief Get Serial protocol used
1086 * @rmtoll CFG2 SP LL_SPI_GetStandard
1087 * @param SPIx SPI Instance
1088 * @retval Returned value can be one of the following values:
1089 * @arg @ref LL_SPI_PROTOCOL_MOTOROLA
1090 * @arg @ref LL_SPI_PROTOCOL_TI
1092 __STATIC_INLINE
uint32_t LL_SPI_GetStandard(SPI_TypeDef
*SPIx
)
1094 return (uint32_t)(READ_BIT(SPIx
->CFG2
, SPI_CFG2_SP
));
1098 * @brief Set Clock phase
1099 * @note This configuration can not be changed when SPI is enabled.
1100 * This bit is not used in SPI TI mode.
1101 * @rmtoll CFG2 CPHA LL_SPI_SetClockPhase
1102 * @param SPIx SPI Instance
1103 * @param ClockPhase This parameter can be one of the following values:
1104 * @arg @ref LL_SPI_PHASE_1EDGE
1105 * @arg @ref LL_SPI_PHASE_2EDGE
1108 __STATIC_INLINE
void LL_SPI_SetClockPhase(SPI_TypeDef
*SPIx
, uint32_t ClockPhase
)
1110 MODIFY_REG(SPIx
->CFG2
, SPI_CFG2_CPHA
, ClockPhase
);
1114 * @brief Get Clock phase
1115 * @rmtoll CFG2 CPHA LL_SPI_GetClockPhase
1116 * @param SPIx SPI Instance
1117 * @retval Returned value can be one of the following values:
1118 * @arg @ref LL_SPI_PHASE_1EDGE
1119 * @arg @ref LL_SPI_PHASE_2EDGE
1121 __STATIC_INLINE
uint32_t LL_SPI_GetClockPhase(SPI_TypeDef
*SPIx
)
1123 return (uint32_t)(READ_BIT(SPIx
->CFG2
, SPI_CFG2_CPHA
));
1127 * @brief Set Clock polarity
1128 * @note This configuration can not be changed when SPI is enabled.
1129 * This bit is not used in SPI TI mode.
1130 * @rmtoll CFG2 CPOL LL_SPI_SetClockPolarity
1131 * @param SPIx SPI Instance
1132 * @param ClockPolarity This parameter can be one of the following values:
1133 * @arg @ref LL_SPI_POLARITY_LOW
1134 * @arg @ref LL_SPI_POLARITY_HIGH
1137 __STATIC_INLINE
void LL_SPI_SetClockPolarity(SPI_TypeDef
*SPIx
, uint32_t ClockPolarity
)
1139 MODIFY_REG(SPIx
->CFG2
, SPI_CFG2_CPOL
, ClockPolarity
);
1143 * @brief Get Clock polarity
1144 * @rmtoll CFG2 CPOL LL_SPI_GetClockPolarity
1145 * @param SPIx SPI Instance
1146 * @retval Returned value can be one of the following values:
1147 * @arg @ref LL_SPI_POLARITY_LOW
1148 * @arg @ref LL_SPI_POLARITY_HIGH
1150 __STATIC_INLINE
uint32_t LL_SPI_GetClockPolarity(SPI_TypeDef
*SPIx
)
1152 return (uint32_t)(READ_BIT(SPIx
->CFG2
, SPI_CFG2_CPOL
));
1156 * @brief Set NSS polarity
1157 * @note This configuration can not be changed when SPI is enabled.
1158 * This bit is not used in SPI TI mode.
1159 * @rmtoll CFG2 SSIOP LL_SPI_SetNSSPolarity
1160 * @param SPIx SPI Instance
1161 * @param NSSPolarity This parameter can be one of the following values:
1162 * @arg @ref LL_SPI_NSS_POLARITY_LOW
1163 * @arg @ref LL_SPI_NSS_POLARITY_HIGH
1166 __STATIC_INLINE
void LL_SPI_SetNSSPolarity(SPI_TypeDef
*SPIx
, uint32_t NSSPolarity
)
1168 MODIFY_REG(SPIx
->CFG2
, SPI_CFG2_SSIOP
, NSSPolarity
);
1172 * @brief Get NSS polarity
1173 * @rmtoll CFG2 SSIOP LL_SPI_GetNSSPolarity
1174 * @param SPIx SPI Instance
1175 * @retval Returned value can be one of the following values:
1176 * @arg @ref LL_SPI_NSS_POLARITY_LOW
1177 * @arg @ref LL_SPI_NSS_POLARITY_HIGH
1179 __STATIC_INLINE
uint32_t LL_SPI_GetNSSPolarity(SPI_TypeDef
*SPIx
)
1181 return (uint32_t)(READ_BIT(SPIx
->CFG2
, SPI_CFG2_SSIOP
));
1185 * @brief Set Baudrate Prescaler
1186 * @note This configuration can not be changed when SPI is enabled.
1187 * SPI BaudRate = fPCLK/Pescaler.
1188 * @rmtoll CFG1 MBR LL_SPI_SetBaudRatePrescaler
1189 * @param SPIx SPI Instance
1190 * @param Baudrate This parameter can be one of the following values:
1191 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV2
1192 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV4
1193 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV8
1194 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV16
1195 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV32
1196 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV64
1197 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV128
1198 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV256
1201 __STATIC_INLINE
void LL_SPI_SetBaudRatePrescaler(SPI_TypeDef
*SPIx
, uint32_t Baudrate
)
1203 MODIFY_REG(SPIx
->CFG1
, SPI_CFG1_MBR
, Baudrate
);
1207 * @brief Get Baudrate Prescaler
1208 * @rmtoll CFG1 MBR LL_SPI_GetBaudRatePrescaler
1209 * @param SPIx SPI Instance
1210 * @retval Returned value can be one of the following values:
1211 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV2
1212 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV4
1213 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV8
1214 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV16
1215 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV32
1216 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV64
1217 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV128
1218 * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV256
1220 __STATIC_INLINE
uint32_t LL_SPI_GetBaudRatePrescaler(SPI_TypeDef
*SPIx
)
1222 return (uint32_t)(READ_BIT(SPIx
->CFG1
, SPI_CFG1_MBR
));
1226 * @brief Set Transfer Bit Order
1227 * @note This configuration can not be changed when SPI is enabled.
1228 * This bit is not used in SPI TI mode.
1229 * @rmtoll CFG2 LSBFRST LL_SPI_SetTransferBitOrder
1230 * @param SPIx SPI Instance
1231 * @param BitOrder This parameter can be one of the following values:
1232 * @arg @ref LL_SPI_LSB_FIRST
1233 * @arg @ref LL_SPI_MSB_FIRST
1236 __STATIC_INLINE
void LL_SPI_SetTransferBitOrder(SPI_TypeDef
*SPIx
, uint32_t BitOrder
)
1238 MODIFY_REG(SPIx
->CFG2
, SPI_CFG2_LSBFRST
, BitOrder
);
1242 * @brief Get Transfer Bit Order
1243 * @rmtoll CFG2 LSBFRST LL_SPI_GetTransferBitOrder
1244 * @param SPIx SPI Instance
1245 * @retval Returned value can be one of the following values:
1246 * @arg @ref LL_SPI_LSB_FIRST
1247 * @arg @ref LL_SPI_MSB_FIRST
1249 __STATIC_INLINE
uint32_t LL_SPI_GetTransferBitOrder(SPI_TypeDef
*SPIx
)
1251 return (uint32_t)(READ_BIT(SPIx
->CFG2
, SPI_CFG2_LSBFRST
));
1255 * @brief Set Transfer Mode
1256 * @note This configuration can not be changed when SPI is enabled except for half duplex direction using LL_SPI_SetHalfDuplexDirection.
1257 * @rmtoll CR1 HDDIR LL_SPI_SetTransferDirection\n
1258 * CFG2 COMM LL_SPI_SetTransferDirection
1259 * @param SPIx SPI Instance
1260 * @param TransferDirection This parameter can be one of the following values:
1261 * @arg @ref LL_SPI_FULL_DUPLEX
1262 * @arg @ref LL_SPI_SIMPLEX_TX
1263 * @arg @ref LL_SPI_SIMPLEX_RX
1264 * @arg @ref LL_SPI_HALF_DUPLEX_RX
1265 * @arg @ref LL_SPI_HALF_DUPLEX_TX
1268 __STATIC_INLINE
void LL_SPI_SetTransferDirection(SPI_TypeDef
*SPIx
, uint32_t TransferDirection
)
1270 MODIFY_REG(SPIx
->CR1
, SPI_CR1_HDDIR
, TransferDirection
& SPI_CR1_HDDIR
);
1271 MODIFY_REG(SPIx
->CFG2
, SPI_CFG2_COMM
, TransferDirection
& SPI_CFG2_COMM
);
1275 * @brief Get Transfer Mode
1276 * @rmtoll CR1 HDDIR LL_SPI_GetTransferDirection\n
1277 * CFG2 COMM LL_SPI_GetTransferDirection
1278 * @param SPIx SPI Instance
1279 * @retval Returned value can be one of the following values:
1280 * @arg @ref LL_SPI_FULL_DUPLEX
1281 * @arg @ref LL_SPI_SIMPLEX_TX
1282 * @arg @ref LL_SPI_SIMPLEX_RX
1283 * @arg @ref LL_SPI_HALF_DUPLEX_RX
1284 * @arg @ref LL_SPI_HALF_DUPLEX_TX
1286 __STATIC_INLINE
uint32_t LL_SPI_GetTransferDirection(SPI_TypeDef
*SPIx
)
1288 uint32_t Hddir
= READ_BIT(SPIx
->CR1
, SPI_CR1_HDDIR
);
1289 uint32_t Comm
= READ_BIT(SPIx
->CFG2
, SPI_CFG2_COMM
);
1290 return (Hddir
| Comm
);
1294 * @brief Set direction for Half-Duplex Mode
1295 * @note In master mode the MOSI pin is used and in slave mode the MISO pin is used for Half-Duplex.
1296 * @rmtoll CR1 HDDIR LL_SPI_SetHalfDuplexDirection
1297 * @param SPIx SPI Instance
1298 * @param HalfDuplexDirection This parameter can be one of the following values:
1299 * @arg @ref LL_SPI_HALF_DUPLEX_RX
1300 * @arg @ref LL_SPI_HALF_DUPLEX_TX
1303 __STATIC_INLINE
void LL_SPI_SetHalfDuplexDirection(SPI_TypeDef
*SPIx
, uint32_t HalfDuplexDirection
)
1305 MODIFY_REG(SPIx
->CR1
, SPI_CR1_HDDIR
, HalfDuplexDirection
& SPI_CR1_HDDIR
);
1309 * @brief Get direction for Half-Duplex Mode
1310 * @note In master mode the MOSI pin is used and in slave mode the MISO pin is used for Half-Duplex.
1311 * @rmtoll CR1 HDDIR LL_SPI_GetHalfDuplexDirection
1312 * @param SPIx SPI Instance
1313 * @retval Returned value can be one of the following values:
1314 * @arg @ref LL_SPI_HALF_DUPLEX_RX
1315 * @arg @ref LL_SPI_HALF_DUPLEX_TX
1317 __STATIC_INLINE
uint32_t LL_SPI_GetHalfDuplexDirection(SPI_TypeDef
*SPIx
)
1319 return (uint32_t)(READ_BIT(SPIx
->CR1
, SPI_CR1_HDDIR
) | SPI_CFG2_COMM
);
1323 * @brief Set Frame Data Size
1324 * @note This configuration can not be changed when SPI is enabled.
1325 * @rmtoll CFG1 DSIZE LL_SPI_SetDataWidth
1326 * @param SPIx SPI Instance
1327 * @param DataWidth This parameter can be one of the following values:
1328 * @arg @ref LL_SPI_DATAWIDTH_4BIT
1329 * @arg @ref LL_SPI_DATAWIDTH_5BIT
1330 * @arg @ref LL_SPI_DATAWIDTH_6BIT
1331 * @arg @ref LL_SPI_DATAWIDTH_7BIT
1332 * @arg @ref LL_SPI_DATAWIDTH_8BIT
1333 * @arg @ref LL_SPI_DATAWIDTH_9BIT
1334 * @arg @ref LL_SPI_DATAWIDTH_10BIT
1335 * @arg @ref LL_SPI_DATAWIDTH_11BIT
1336 * @arg @ref LL_SPI_DATAWIDTH_12BIT
1337 * @arg @ref LL_SPI_DATAWIDTH_13BIT
1338 * @arg @ref LL_SPI_DATAWIDTH_14BIT
1339 * @arg @ref LL_SPI_DATAWIDTH_15BIT
1340 * @arg @ref LL_SPI_DATAWIDTH_16BIT
1341 * @arg @ref LL_SPI_DATAWIDTH_17BIT
1342 * @arg @ref LL_SPI_DATAWIDTH_18BIT
1343 * @arg @ref LL_SPI_DATAWIDTH_19BIT
1344 * @arg @ref LL_SPI_DATAWIDTH_20BIT
1345 * @arg @ref LL_SPI_DATAWIDTH_21BIT
1346 * @arg @ref LL_SPI_DATAWIDTH_22BIT
1347 * @arg @ref LL_SPI_DATAWIDTH_23BIT
1348 * @arg @ref LL_SPI_DATAWIDTH_24BIT
1349 * @arg @ref LL_SPI_DATAWIDTH_25BIT
1350 * @arg @ref LL_SPI_DATAWIDTH_26BIT
1351 * @arg @ref LL_SPI_DATAWIDTH_27BIT
1352 * @arg @ref LL_SPI_DATAWIDTH_28BIT
1353 * @arg @ref LL_SPI_DATAWIDTH_29BIT
1354 * @arg @ref LL_SPI_DATAWIDTH_30BIT
1355 * @arg @ref LL_SPI_DATAWIDTH_31BIT
1356 * @arg @ref LL_SPI_DATAWIDTH_32BIT
1359 __STATIC_INLINE
void LL_SPI_SetDataWidth(SPI_TypeDef
*SPIx
, uint32_t DataWidth
)
1361 MODIFY_REG(SPIx
->CFG1
, SPI_CFG1_DSIZE
, DataWidth
);
1365 * @brief Get Frame Data Size
1366 * @rmtoll CFG1 DSIZE LL_SPI_GetDataWidth
1367 * @param SPIx SPI Instance
1368 * @retval Returned value can be one of the following values:
1369 * @arg @ref LL_SPI_DATAWIDTH_4BIT
1370 * @arg @ref LL_SPI_DATAWIDTH_5BIT
1371 * @arg @ref LL_SPI_DATAWIDTH_6BIT
1372 * @arg @ref LL_SPI_DATAWIDTH_7BIT
1373 * @arg @ref LL_SPI_DATAWIDTH_8BIT
1374 * @arg @ref LL_SPI_DATAWIDTH_9BIT
1375 * @arg @ref LL_SPI_DATAWIDTH_10BIT
1376 * @arg @ref LL_SPI_DATAWIDTH_11BIT
1377 * @arg @ref LL_SPI_DATAWIDTH_12BIT
1378 * @arg @ref LL_SPI_DATAWIDTH_13BIT
1379 * @arg @ref LL_SPI_DATAWIDTH_14BIT
1380 * @arg @ref LL_SPI_DATAWIDTH_15BIT
1381 * @arg @ref LL_SPI_DATAWIDTH_16BIT
1382 * @arg @ref LL_SPI_DATAWIDTH_17BIT
1383 * @arg @ref LL_SPI_DATAWIDTH_18BIT
1384 * @arg @ref LL_SPI_DATAWIDTH_19BIT
1385 * @arg @ref LL_SPI_DATAWIDTH_20BIT
1386 * @arg @ref LL_SPI_DATAWIDTH_21BIT
1387 * @arg @ref LL_SPI_DATAWIDTH_22BIT
1388 * @arg @ref LL_SPI_DATAWIDTH_23BIT
1389 * @arg @ref LL_SPI_DATAWIDTH_24BIT
1390 * @arg @ref LL_SPI_DATAWIDTH_25BIT
1391 * @arg @ref LL_SPI_DATAWIDTH_26BIT
1392 * @arg @ref LL_SPI_DATAWIDTH_27BIT
1393 * @arg @ref LL_SPI_DATAWIDTH_28BIT
1394 * @arg @ref LL_SPI_DATAWIDTH_29BIT
1395 * @arg @ref LL_SPI_DATAWIDTH_30BIT
1396 * @arg @ref LL_SPI_DATAWIDTH_31BIT
1397 * @arg @ref LL_SPI_DATAWIDTH_32BIT
1399 __STATIC_INLINE
uint32_t LL_SPI_GetDataWidth(SPI_TypeDef
*SPIx
)
1401 return (uint32_t)(READ_BIT(SPIx
->CFG1
, SPI_CFG1_DSIZE
));
1405 * @brief Set threshold of FIFO that triggers a transfer event
1406 * @note This configuration can not be changed when SPI is enabled.
1407 * @rmtoll CFG1 FTHLV LL_SPI_SetFIFOThreshold
1408 * @param SPIx SPI Instance
1409 * @param Threshold This parameter can be one of the following values:
1410 * @arg @ref LL_SPI_FIFO_TH_01DATA
1411 * @arg @ref LL_SPI_FIFO_TH_02DATA
1412 * @arg @ref LL_SPI_FIFO_TH_03DATA
1413 * @arg @ref LL_SPI_FIFO_TH_04DATA
1414 * @arg @ref LL_SPI_FIFO_TH_05DATA
1415 * @arg @ref LL_SPI_FIFO_TH_06DATA
1416 * @arg @ref LL_SPI_FIFO_TH_07DATA
1417 * @arg @ref LL_SPI_FIFO_TH_08DATA
1418 * @arg @ref LL_SPI_FIFO_TH_09DATA
1419 * @arg @ref LL_SPI_FIFO_TH_10DATA
1420 * @arg @ref LL_SPI_FIFO_TH_11DATA
1421 * @arg @ref LL_SPI_FIFO_TH_12DATA
1422 * @arg @ref LL_SPI_FIFO_TH_13DATA
1423 * @arg @ref LL_SPI_FIFO_TH_14DATA
1424 * @arg @ref LL_SPI_FIFO_TH_15DATA
1425 * @arg @ref LL_SPI_FIFO_TH_16DATA
1428 __STATIC_INLINE
void LL_SPI_SetFIFOThreshold(SPI_TypeDef
*SPIx
, uint32_t Threshold
)
1430 MODIFY_REG(SPIx
->CFG1
, SPI_CFG1_FTHLV
, Threshold
);
1434 * @brief Get threshold of FIFO that triggers a transfer event
1435 * @rmtoll CFG1 FTHLV LL_SPI_GetFIFOThreshold
1436 * @param SPIx SPI Instance
1437 * @retval Returned value can be one of the following values:
1438 * @arg @ref LL_SPI_FIFO_TH_01DATA
1439 * @arg @ref LL_SPI_FIFO_TH_02DATA
1440 * @arg @ref LL_SPI_FIFO_TH_03DATA
1441 * @arg @ref LL_SPI_FIFO_TH_04DATA
1442 * @arg @ref LL_SPI_FIFO_TH_05DATA
1443 * @arg @ref LL_SPI_FIFO_TH_06DATA
1444 * @arg @ref LL_SPI_FIFO_TH_07DATA
1445 * @arg @ref LL_SPI_FIFO_TH_08DATA
1446 * @arg @ref LL_SPI_FIFO_TH_09DATA
1447 * @arg @ref LL_SPI_FIFO_TH_10DATA
1448 * @arg @ref LL_SPI_FIFO_TH_11DATA
1449 * @arg @ref LL_SPI_FIFO_TH_12DATA
1450 * @arg @ref LL_SPI_FIFO_TH_13DATA
1451 * @arg @ref LL_SPI_FIFO_TH_14DATA
1452 * @arg @ref LL_SPI_FIFO_TH_15DATA
1453 * @arg @ref LL_SPI_FIFO_TH_16DATA
1455 __STATIC_INLINE
uint32_t LL_SPI_GetFIFOThreshold(SPI_TypeDef
*SPIx
)
1457 return (uint32_t)(READ_BIT(SPIx
->CFG1
, SPI_CFG1_FTHLV
));
1462 * @note This configuration can not be changed when SPI is enabled.
1463 * @rmtoll CFG1 CRCEN LL_SPI_EnableCRC
1464 * @param SPIx SPI Instance
1467 __STATIC_INLINE
void LL_SPI_EnableCRC(SPI_TypeDef
*SPIx
)
1469 SET_BIT(SPIx
->CFG1
, SPI_CFG1_CRCEN
);
1473 * @brief Disable CRC
1474 * @rmtoll CFG1 CRCEN LL_SPI_DisableCRC
1475 * @param SPIx SPI Instance
1478 __STATIC_INLINE
void LL_SPI_DisableCRC(SPI_TypeDef
*SPIx
)
1480 CLEAR_BIT(SPIx
->CFG1
, SPI_CFG1_CRCEN
);
1484 * @brief Check if CRC is enabled
1485 * @rmtoll CFG1 CRCEN LL_SPI_IsEnabledCRC
1486 * @param SPIx SPI Instance
1487 * @retval State of bit (1 or 0).
1489 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledCRC(SPI_TypeDef
*SPIx
)
1491 return ((READ_BIT(SPIx
->CFG1
, SPI_CFG1_CRCEN
) == SPI_CFG1_CRCEN
) ? 1UL : 0UL);
1495 * @brief Set CRC Length
1496 * @note This configuration can not be changed when SPI is enabled.
1497 * @rmtoll CFG1 CRCSIZE LL_SPI_SetCRCWidth
1498 * @param SPIx SPI Instance
1499 * @param CRCLength This parameter can be one of the following values:
1500 * @arg @ref LL_SPI_CRC_4BIT
1501 * @arg @ref LL_SPI_CRC_5BIT
1502 * @arg @ref LL_SPI_CRC_6BIT
1503 * @arg @ref LL_SPI_CRC_7BIT
1504 * @arg @ref LL_SPI_CRC_8BIT
1505 * @arg @ref LL_SPI_CRC_9BIT
1506 * @arg @ref LL_SPI_CRC_10BIT
1507 * @arg @ref LL_SPI_CRC_11BIT
1508 * @arg @ref LL_SPI_CRC_12BIT
1509 * @arg @ref LL_SPI_CRC_13BIT
1510 * @arg @ref LL_SPI_CRC_14BIT
1511 * @arg @ref LL_SPI_CRC_15BIT
1512 * @arg @ref LL_SPI_CRC_16BIT
1513 * @arg @ref LL_SPI_CRC_17BIT
1514 * @arg @ref LL_SPI_CRC_18BIT
1515 * @arg @ref LL_SPI_CRC_19BIT
1516 * @arg @ref LL_SPI_CRC_20BIT
1517 * @arg @ref LL_SPI_CRC_21BIT
1518 * @arg @ref LL_SPI_CRC_22BIT
1519 * @arg @ref LL_SPI_CRC_23BIT
1520 * @arg @ref LL_SPI_CRC_24BIT
1521 * @arg @ref LL_SPI_CRC_25BIT
1522 * @arg @ref LL_SPI_CRC_26BIT
1523 * @arg @ref LL_SPI_CRC_27BIT
1524 * @arg @ref LL_SPI_CRC_28BIT
1525 * @arg @ref LL_SPI_CRC_29BIT
1526 * @arg @ref LL_SPI_CRC_30BIT
1527 * @arg @ref LL_SPI_CRC_31BIT
1528 * @arg @ref LL_SPI_CRC_32BIT
1531 __STATIC_INLINE
void LL_SPI_SetCRCWidth(SPI_TypeDef
*SPIx
, uint32_t CRCLength
)
1533 MODIFY_REG(SPIx
->CFG1
, SPI_CFG1_CRCSIZE
, CRCLength
);
1537 * @brief Get CRC Length
1538 * @rmtoll CFG1 CRCSIZE LL_SPI_GetCRCWidth
1539 * @param SPIx SPI Instance
1540 * @retval Returned value can be one of the following values:
1541 * @arg @ref LL_SPI_CRC_4BIT
1542 * @arg @ref LL_SPI_CRC_5BIT
1543 * @arg @ref LL_SPI_CRC_6BIT
1544 * @arg @ref LL_SPI_CRC_7BIT
1545 * @arg @ref LL_SPI_CRC_8BIT
1546 * @arg @ref LL_SPI_CRC_9BIT
1547 * @arg @ref LL_SPI_CRC_10BIT
1548 * @arg @ref LL_SPI_CRC_11BIT
1549 * @arg @ref LL_SPI_CRC_12BIT
1550 * @arg @ref LL_SPI_CRC_13BIT
1551 * @arg @ref LL_SPI_CRC_14BIT
1552 * @arg @ref LL_SPI_CRC_15BIT
1553 * @arg @ref LL_SPI_CRC_16BIT
1554 * @arg @ref LL_SPI_CRC_17BIT
1555 * @arg @ref LL_SPI_CRC_18BIT
1556 * @arg @ref LL_SPI_CRC_19BIT
1557 * @arg @ref LL_SPI_CRC_20BIT
1558 * @arg @ref LL_SPI_CRC_21BIT
1559 * @arg @ref LL_SPI_CRC_22BIT
1560 * @arg @ref LL_SPI_CRC_23BIT
1561 * @arg @ref LL_SPI_CRC_24BIT
1562 * @arg @ref LL_SPI_CRC_25BIT
1563 * @arg @ref LL_SPI_CRC_26BIT
1564 * @arg @ref LL_SPI_CRC_27BIT
1565 * @arg @ref LL_SPI_CRC_28BIT
1566 * @arg @ref LL_SPI_CRC_29BIT
1567 * @arg @ref LL_SPI_CRC_30BIT
1568 * @arg @ref LL_SPI_CRC_31BIT
1569 * @arg @ref LL_SPI_CRC_32BIT
1571 __STATIC_INLINE
uint32_t LL_SPI_GetCRCWidth(SPI_TypeDef
*SPIx
)
1573 return (uint32_t)(READ_BIT(SPIx
->CFG1
, SPI_CFG1_CRCSIZE
));
1577 * @brief Set NSS Mode
1578 * @note This configuration can not be changed when SPI is enabled.
1579 * This bit is not used in SPI TI mode.
1580 * @rmtoll CFG2 SSM LL_SPI_SetNSSMode\n
1581 * CFG2 SSOE LL_SPI_SetNSSMode
1582 * @param SPIx SPI Instance
1583 * @param NSS This parameter can be one of the following values:
1584 * @arg @ref LL_SPI_NSS_SOFT
1585 * @arg @ref LL_SPI_NSS_HARD_INPUT
1586 * @arg @ref LL_SPI_NSS_HARD_OUTPUT
1589 __STATIC_INLINE
void LL_SPI_SetNSSMode(SPI_TypeDef
*SPIx
, uint32_t NSS
)
1591 MODIFY_REG(SPIx
->CFG2
, SPI_CFG2_SSM
| SPI_CFG2_SSOE
, NSS
);
1595 * @brief Set NSS Mode
1596 * @rmtoll CFG2 SSM LL_SPI_GetNSSMode\n
1597 * CFG2 SSOE LL_SPI_GetNSSMode
1598 * @param SPIx SPI Instance
1599 * @retval Returned value can be one of the following values:
1600 * @arg @ref LL_SPI_NSS_SOFT
1601 * @arg @ref LL_SPI_NSS_HARD_INPUT
1602 * @arg @ref LL_SPI_NSS_HARD_OUTPUT
1604 __STATIC_INLINE
uint32_t LL_SPI_GetNSSMode(SPI_TypeDef
*SPIx
)
1606 return (uint32_t)(READ_BIT(SPIx
->CFG2
, SPI_CFG2_SSM
| SPI_CFG2_SSOE
));
1610 * @brief Enable NSS pulse mgt
1611 * @note This configuration can not be changed when SPI is enabled.
1612 * This bit is not used in SPI TI mode.
1613 * @rmtoll CFG2 SSOM LL_SPI_EnableNSSPulseMgt
1614 * @param SPIx SPI Instance
1617 __STATIC_INLINE
void LL_SPI_EnableNSSPulseMgt(SPI_TypeDef
*SPIx
)
1619 SET_BIT(SPIx
->CFG2
, SPI_CFG2_SSOM
);
1623 * @brief Disable NSS pulse mgt
1624 * @note This configuration can not be changed when SPI is enabled.
1625 * This bit is not used in SPI TI mode.
1626 * @rmtoll CFG2 SSOM LL_SPI_DisableNSSPulseMgt
1627 * @param SPIx SPI Instance
1630 __STATIC_INLINE
void LL_SPI_DisableNSSPulseMgt(SPI_TypeDef
*SPIx
)
1632 CLEAR_BIT(SPIx
->CFG2
, SPI_CFG2_SSOM
);
1636 * @brief Check if NSS pulse is enabled
1637 * @rmtoll CFG2 SSOM LL_SPI_IsEnabledNSSPulse
1638 * @param SPIx SPI Instance
1639 * @retval State of bit (1 or 0)
1641 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledNSSPulse(SPI_TypeDef
*SPIx
)
1643 return ((READ_BIT(SPIx
->CFG2
, SPI_CFG2_SSOM
) == SPI_CFG2_SSOM
) ? 1UL : 0UL);
1650 /** @defgroup SPI_LL_EF_FLAG_Management FLAG_Management
1655 * @brief Check if there is enough data in FIFO to read a full packet
1656 * @rmtoll SR RXP LL_SPI_IsActiveFlag_RXP
1657 * @param SPIx SPI Instance
1658 * @retval State of bit (1 or 0)
1660 __STATIC_INLINE
uint32_t LL_SPI_IsActiveFlag_RXP(SPI_TypeDef
*SPIx
)
1662 return ((READ_BIT(SPIx
->SR
, SPI_SR_RXP
) == (SPI_SR_RXP
)) ? 1UL : 0UL);
1666 * @brief Check if there is enough space in FIFO to hold a full packet
1667 * @rmtoll SR TXP LL_SPI_IsActiveFlag_TXP
1668 * @param SPIx SPI Instance
1669 * @retval State of bit (1 or 0)
1671 __STATIC_INLINE
uint32_t LL_SPI_IsActiveFlag_TXP(SPI_TypeDef
*SPIx
)
1673 return ((READ_BIT(SPIx
->SR
, SPI_SR_TXP
) == (SPI_SR_TXP
)) ? 1UL : 0UL);
1677 * @brief Check if there enough space in FIFO to hold a full packet, AND enough data to read a full packet
1678 * @rmtoll SR DXP LL_SPI_IsActiveFlag_DXP
1679 * @param SPIx SPI Instance
1680 * @retval State of bit (1 or 0)
1682 __STATIC_INLINE
uint32_t LL_SPI_IsActiveFlag_DXP(SPI_TypeDef
*SPIx
)
1684 return ((READ_BIT(SPIx
->SR
, SPI_SR_DXP
) == (SPI_SR_DXP
)) ? 1UL : 0UL);
1688 * @brief Check that end of transfer event occured
1689 * @rmtoll SR EOT LL_SPI_IsActiveFlag_EOT
1690 * @param SPIx SPI Instance
1691 * @retval State of bit (1 or 0).
1693 __STATIC_INLINE
uint32_t LL_SPI_IsActiveFlag_EOT(SPI_TypeDef
*SPIx
)
1695 return ((READ_BIT(SPIx
->SR
, SPI_SR_EOT
) == (SPI_SR_EOT
)) ? 1UL : 0UL);
1699 * @brief Check that all required data has been filled in the fifo according to transfer size
1700 * @rmtoll SR TXTF LL_SPI_IsActiveFlag_TXTF
1701 * @param SPIx SPI Instance
1702 * @retval State of bit (1 or 0).
1704 __STATIC_INLINE
uint32_t LL_SPI_IsActiveFlag_TXTF(SPI_TypeDef
*SPIx
)
1706 return ((READ_BIT(SPIx
->SR
, SPI_SR_TXTF
) == (SPI_SR_TXTF
)) ? 1UL : 0UL);
1710 * @brief Get Underrun error flag
1711 * @rmtoll SR UDR LL_SPI_IsActiveFlag_UDR
1712 * @param SPIx SPI Instance
1713 * @retval State of bit (1 or 0).
1715 __STATIC_INLINE
uint32_t LL_SPI_IsActiveFlag_UDR(SPI_TypeDef
*SPIx
)
1717 return ((READ_BIT(SPIx
->SR
, SPI_SR_UDR
) == (SPI_SR_UDR
)) ? 1UL : 0UL);
1721 * @brief Get CRC error flag
1722 * @rmtoll SR CRCE LL_SPI_IsActiveFlag_CRCERR
1723 * @param SPIx SPI Instance
1724 * @retval State of bit (1 or 0).
1726 __STATIC_INLINE
uint32_t LL_SPI_IsActiveFlag_CRCERR(SPI_TypeDef
*SPIx
)
1728 return ((READ_BIT(SPIx
->SR
, SPI_SR_CRCE
) == (SPI_SR_CRCE
)) ? 1UL : 0UL);
1732 * @brief Get Mode fault error flag
1733 * @rmtoll SR MODF LL_SPI_IsActiveFlag_MODF
1734 * @param SPIx SPI Instance
1735 * @retval State of bit (1 or 0).
1737 __STATIC_INLINE
uint32_t LL_SPI_IsActiveFlag_MODF(SPI_TypeDef
*SPIx
)
1739 return ((READ_BIT(SPIx
->SR
, SPI_SR_MODF
) == (SPI_SR_MODF
)) ? 1UL : 0UL);
1743 * @brief Get Overrun error flag
1744 * @rmtoll SR OVR LL_SPI_IsActiveFlag_OVR
1745 * @param SPIx SPI Instance
1746 * @retval State of bit (1 or 0).
1748 __STATIC_INLINE
uint32_t LL_SPI_IsActiveFlag_OVR(SPI_TypeDef
*SPIx
)
1750 return ((READ_BIT(SPIx
->SR
, SPI_SR_OVR
) == (SPI_SR_OVR
)) ? 1UL : 0UL);
1754 * @brief Get TI Frame format error flag
1755 * @rmtoll SR TIFRE LL_SPI_IsActiveFlag_FRE
1756 * @param SPIx SPI Instance
1757 * @retval State of bit (1 or 0).
1759 __STATIC_INLINE
uint32_t LL_SPI_IsActiveFlag_FRE(SPI_TypeDef
*SPIx
)
1761 return ((READ_BIT(SPIx
->SR
, SPI_SR_TIFRE
) == (SPI_SR_TIFRE
)) ? 1UL : 0UL);
1765 * @brief Check if the additional number of data has been reloaded
1766 * @rmtoll SR TSERF LL_SPI_IsActiveFlag_TSER
1767 * @param SPIx SPI Instance
1768 * @retval State of bit (1 or 0).
1770 __STATIC_INLINE
uint32_t LL_SPI_IsActiveFlag_TSER(SPI_TypeDef
*SPIx
)
1772 return ((READ_BIT(SPIx
->SR
, SPI_SR_TSERF
) == (SPI_SR_TSERF
)) ? 1UL : 0UL);
1776 * @brief Check if a suspend operation is done
1777 * @rmtoll SR SUSP LL_SPI_IsActiveFlag_SUSP
1778 * @param SPIx SPI Instance
1779 * @retval State of bit (1 or 0)
1781 __STATIC_INLINE
uint32_t LL_SPI_IsActiveFlag_SUSP(SPI_TypeDef
*SPIx
)
1783 return ((READ_BIT(SPIx
->SR
, SPI_SR_SUSP
) == (SPI_SR_SUSP
)) ? 1UL : 0UL);
1787 * @brief Check if last TxFIFO or CRC frame transmission is completed
1788 * @rmtoll SR TXC LL_SPI_IsActiveFlag_TXC
1789 * @param SPIx SPI Instance
1790 * @retval State of bit (1 or 0).
1792 __STATIC_INLINE
uint32_t LL_SPI_IsActiveFlag_TXC(SPI_TypeDef
*SPIx
)
1794 return ((READ_BIT(SPIx
->SR
, SPI_SR_TXC
) == (SPI_SR_TXC
)) ? 1UL : 0UL);
1798 * @brief Check if at least one 32-bit data is available in RxFIFO
1799 * @rmtoll SR RXWNE LL_SPI_IsActiveFlag_RXWNE
1800 * @param SPIx SPI Instance
1801 * @retval State of bit (1 or 0)
1803 __STATIC_INLINE
uint32_t LL_SPI_IsActiveFlag_RXWNE(SPI_TypeDef
*SPIx
)
1805 return ((READ_BIT(SPIx
->SR
, SPI_SR_RXWNE
) == (SPI_SR_RXWNE
)) ? 1UL : 0UL);
1809 * @brief Get number of data framed remaining in current TSIZE
1810 * @rmtoll SR CTSIZE LL_SPI_GetRemainingDataFrames
1811 * @param SPIx SPI Instance
1814 __STATIC_INLINE
uint32_t LL_SPI_GetRemainingDataFrames(SPI_TypeDef
*SPIx
)
1816 return (uint32_t)(READ_BIT(SPIx
->SR
, SPI_SR_CTSIZE
) >> SPI_SR_CTSIZE_Pos
);
1820 * @brief Get RxFIFO packing Level
1821 * @rmtoll SR RXPLVL LL_SPI_GetRxFIFOPackingLevel
1822 * @param SPIx SPI Instance
1823 * @retval Returned value can be one of the following values:
1824 * @arg @ref LL_SPI_RX_FIFO_0PACKET
1825 * @arg @ref LL_SPI_RX_FIFO_1PACKET
1826 * @arg @ref LL_SPI_RX_FIFO_2PACKET
1827 * @arg @ref LL_SPI_RX_FIFO_3PACKET
1829 __STATIC_INLINE
uint32_t LL_SPI_GetRxFIFOPackingLevel(SPI_TypeDef
*SPIx
)
1831 return (uint32_t)(READ_BIT(SPIx
->SR
, SPI_SR_RXPLVL
));
1835 * @brief Clear End Of Transfer flag
1836 * @rmtoll IFCR EOTC LL_SPI_ClearFlag_EOT
1837 * @param SPIx SPI Instance
1840 __STATIC_INLINE
void LL_SPI_ClearFlag_EOT(SPI_TypeDef
*SPIx
)
1842 SET_BIT(SPIx
->IFCR
, SPI_IFCR_EOTC
);
1846 * @brief Clear TXTF flag
1847 * @rmtoll IFCR TXTFC LL_SPI_ClearFlag_TXTF
1848 * @param SPIx SPI Instance
1851 __STATIC_INLINE
void LL_SPI_ClearFlag_TXTF(SPI_TypeDef
*SPIx
)
1853 SET_BIT(SPIx
->IFCR
, SPI_IFCR_TXTFC
);
1857 * @brief Clear Underrun error flag
1858 * @rmtoll IFCR UDRC LL_SPI_ClearFlag_UDR
1859 * @param SPIx SPI Instance
1862 __STATIC_INLINE
void LL_SPI_ClearFlag_UDR(SPI_TypeDef
*SPIx
)
1864 SET_BIT(SPIx
->IFCR
, SPI_IFCR_UDRC
);
1868 * @brief Clear Overrun error flag
1869 * @rmtoll IFCR OVRC LL_SPI_ClearFlag_OVR
1870 * @param SPIx SPI Instance
1873 __STATIC_INLINE
void LL_SPI_ClearFlag_OVR(SPI_TypeDef
*SPIx
)
1875 SET_BIT(SPIx
->IFCR
, SPI_IFCR_OVRC
);
1879 * @brief Clear CRC error flag
1880 * @rmtoll IFCR CRCEC LL_SPI_ClearFlag_CRCERR
1881 * @param SPIx SPI Instance
1884 __STATIC_INLINE
void LL_SPI_ClearFlag_CRCERR(SPI_TypeDef
*SPIx
)
1886 SET_BIT(SPIx
->IFCR
, SPI_IFCR_CRCEC
);
1890 * @brief Clear Mode fault error flag
1891 * @rmtoll IFCR MODFC LL_SPI_ClearFlag_MODF
1892 * @param SPIx SPI Instance
1895 __STATIC_INLINE
void LL_SPI_ClearFlag_MODF(SPI_TypeDef
*SPIx
)
1897 SET_BIT(SPIx
->IFCR
, SPI_IFCR_MODFC
);
1901 * @brief Clear Frame format error flag
1902 * @rmtoll IFCR TIFREC LL_SPI_ClearFlag_FRE
1903 * @param SPIx SPI Instance
1906 __STATIC_INLINE
void LL_SPI_ClearFlag_FRE(SPI_TypeDef
*SPIx
)
1908 SET_BIT(SPIx
->IFCR
, SPI_IFCR_TIFREC
);
1912 * @brief Clear TSER flag
1913 * @rmtoll IFCR TSERFC LL_SPI_ClearFlag_TSER
1914 * @param SPIx SPI Instance
1917 __STATIC_INLINE
void LL_SPI_ClearFlag_TSER(SPI_TypeDef
*SPIx
)
1919 SET_BIT(SPIx
->IFCR
, SPI_IFCR_TSERFC
);
1923 * @brief Clear SUSP flag
1924 * @rmtoll IFCR SUSPC LL_SPI_ClearFlag_SUSP
1925 * @param SPIx SPI Instance
1928 __STATIC_INLINE
void LL_SPI_ClearFlag_SUSP(SPI_TypeDef
*SPIx
)
1930 SET_BIT(SPIx
->IFCR
, SPI_IFCR_SUSPC
);
1937 /** @defgroup SPI_LL_EF_IT_Management IT_Management
1942 * @brief Enable Rx Packet available IT
1943 * @rmtoll IER RXPIE LL_SPI_EnableIT_RXP
1944 * @param SPIx SPI Instance
1947 __STATIC_INLINE
void LL_SPI_EnableIT_RXP(SPI_TypeDef
*SPIx
)
1949 SET_BIT(SPIx
->IER
, SPI_IER_RXPIE
);
1953 * @brief Enable Tx Packet space available IT
1954 * @rmtoll IER TXPIE LL_SPI_EnableIT_TXP
1955 * @param SPIx SPI Instance
1958 __STATIC_INLINE
void LL_SPI_EnableIT_TXP(SPI_TypeDef
*SPIx
)
1960 SET_BIT(SPIx
->IER
, SPI_IER_TXPIE
);
1964 * @brief Enable Duplex Packet available IT
1965 * @rmtoll IER DXPIE LL_SPI_EnableIT_DXP
1966 * @param SPIx SPI Instance
1969 __STATIC_INLINE
void LL_SPI_EnableIT_DXP(SPI_TypeDef
*SPIx
)
1971 SET_BIT(SPIx
->IER
, SPI_IER_DXPIE
);
1975 * @brief Enable End Of Transfer IT
1976 * @rmtoll IER EOTIE LL_SPI_EnableIT_EOT
1977 * @param SPIx SPI Instance
1980 __STATIC_INLINE
void LL_SPI_EnableIT_EOT(SPI_TypeDef
*SPIx
)
1982 SET_BIT(SPIx
->IER
, SPI_IER_EOTIE
);
1986 * @brief Enable TXTF IT
1987 * @rmtoll IER TXTFIE LL_SPI_EnableIT_TXTF
1988 * @param SPIx SPI Instance
1991 __STATIC_INLINE
void LL_SPI_EnableIT_TXTF(SPI_TypeDef
*SPIx
)
1993 SET_BIT(SPIx
->IER
, SPI_IER_TXTFIE
);
1997 * @brief Enable Underrun IT
1998 * @rmtoll IER UDRIE LL_SPI_EnableIT_UDR
1999 * @param SPIx SPI Instance
2002 __STATIC_INLINE
void LL_SPI_EnableIT_UDR(SPI_TypeDef
*SPIx
)
2004 SET_BIT(SPIx
->IER
, SPI_IER_UDRIE
);
2008 * @brief Enable Overrun IT
2009 * @rmtoll IER OVRIE LL_SPI_EnableIT_OVR
2010 * @param SPIx SPI Instance
2013 __STATIC_INLINE
void LL_SPI_EnableIT_OVR(SPI_TypeDef
*SPIx
)
2015 SET_BIT(SPIx
->IER
, SPI_IER_OVRIE
);
2019 * @brief Enable CRC Error IT
2020 * @rmtoll IER CRCEIE LL_SPI_EnableIT_CRCERR
2021 * @param SPIx SPI Instance
2024 __STATIC_INLINE
void LL_SPI_EnableIT_CRCERR(SPI_TypeDef
*SPIx
)
2026 SET_BIT(SPIx
->IER
, SPI_IER_CRCEIE
);
2030 * @brief Enable TI Frame Format Error IT
2031 * @rmtoll IER TIFREIE LL_SPI_EnableIT_FRE
2032 * @param SPIx SPI Instance
2035 __STATIC_INLINE
void LL_SPI_EnableIT_FRE(SPI_TypeDef
*SPIx
)
2037 SET_BIT(SPIx
->IER
, SPI_IER_TIFREIE
);
2041 * @brief Enable MODF IT
2042 * @rmtoll IER MODFIE LL_SPI_EnableIT_MODF
2043 * @param SPIx SPI Instance
2046 __STATIC_INLINE
void LL_SPI_EnableIT_MODF(SPI_TypeDef
*SPIx
)
2048 SET_BIT(SPIx
->IER
, SPI_IER_MODFIE
);
2052 * @brief Enable TSER reload IT
2053 * @rmtoll IER TSERFIE LL_SPI_EnableIT_TSER
2054 * @param SPIx SPI Instance
2057 __STATIC_INLINE
void LL_SPI_EnableIT_TSER(SPI_TypeDef
*SPIx
)
2059 SET_BIT(SPIx
->IER
, SPI_IER_TSERFIE
);
2063 * @brief Disable Rx Packet available IT
2064 * @rmtoll IER RXPIE LL_SPI_DisableIT_RXP
2065 * @param SPIx SPI Instance
2068 __STATIC_INLINE
void LL_SPI_DisableIT_RXP(SPI_TypeDef
*SPIx
)
2070 CLEAR_BIT(SPIx
->IER
, SPI_IER_RXPIE
);
2074 * @brief Disable Tx Packet space available IT
2075 * @rmtoll IER TXPIE LL_SPI_DisableIT_TXP
2076 * @param SPIx SPI Instance
2079 __STATIC_INLINE
void LL_SPI_DisableIT_TXP(SPI_TypeDef
*SPIx
)
2081 CLEAR_BIT(SPIx
->IER
, SPI_IER_TXPIE
);
2085 * @brief Disable Duplex Packet available IT
2086 * @rmtoll IER DXPIE LL_SPI_DisableIT_DXP
2087 * @param SPIx SPI Instance
2090 __STATIC_INLINE
void LL_SPI_DisableIT_DXP(SPI_TypeDef
*SPIx
)
2092 CLEAR_BIT(SPIx
->IER
, SPI_IER_DXPIE
);
2096 * @brief Disable End Of Transfer IT
2097 * @rmtoll IER EOTIE LL_SPI_DisableIT_EOT
2098 * @param SPIx SPI Instance
2101 __STATIC_INLINE
void LL_SPI_DisableIT_EOT(SPI_TypeDef
*SPIx
)
2103 CLEAR_BIT(SPIx
->IER
, SPI_IER_EOTIE
);
2107 * @brief Disable TXTF IT
2108 * @rmtoll IER TXTFIE LL_SPI_DisableIT_TXTF
2109 * @param SPIx SPI Instance
2112 __STATIC_INLINE
void LL_SPI_DisableIT_TXTF(SPI_TypeDef
*SPIx
)
2114 CLEAR_BIT(SPIx
->IER
, SPI_IER_TXTFIE
);
2118 * @brief Disable Underrun IT
2119 * @rmtoll IER UDRIE LL_SPI_DisableIT_UDR
2120 * @param SPIx SPI Instance
2123 __STATIC_INLINE
void LL_SPI_DisableIT_UDR(SPI_TypeDef
*SPIx
)
2125 CLEAR_BIT(SPIx
->IER
, SPI_IER_UDRIE
);
2129 * @brief Disable Overrun IT
2130 * @rmtoll IER OVRIE LL_SPI_DisableIT_OVR
2131 * @param SPIx SPI Instance
2134 __STATIC_INLINE
void LL_SPI_DisableIT_OVR(SPI_TypeDef
*SPIx
)
2136 CLEAR_BIT(SPIx
->IER
, SPI_IER_OVRIE
);
2140 * @brief Disable CRC Error IT
2141 * @rmtoll IER CRCEIE LL_SPI_DisableIT_CRCERR
2142 * @param SPIx SPI Instance
2145 __STATIC_INLINE
void LL_SPI_DisableIT_CRCERR(SPI_TypeDef
*SPIx
)
2147 CLEAR_BIT(SPIx
->IER
, SPI_IER_CRCEIE
);
2151 * @brief Disable TI Frame Format Error IT
2152 * @rmtoll IER TIFREIE LL_SPI_DisableIT_FRE
2153 * @param SPIx SPI Instance
2156 __STATIC_INLINE
void LL_SPI_DisableIT_FRE(SPI_TypeDef
*SPIx
)
2158 CLEAR_BIT(SPIx
->IER
, SPI_IER_TIFREIE
);
2162 * @brief Disable MODF IT
2163 * @rmtoll IER MODFIE LL_SPI_DisableIT_MODF
2164 * @param SPIx SPI Instance
2167 __STATIC_INLINE
void LL_SPI_DisableIT_MODF(SPI_TypeDef
*SPIx
)
2169 CLEAR_BIT(SPIx
->IER
, SPI_IER_MODFIE
);
2173 * @brief Disable TSER reload IT
2174 * @rmtoll IER TSERFIE LL_SPI_DisableIT_TSER
2175 * @param SPIx SPI Instance
2178 __STATIC_INLINE
void LL_SPI_DisableIT_TSER(SPI_TypeDef
*SPIx
)
2180 CLEAR_BIT(SPIx
->IER
, SPI_IER_TSERFIE
);
2184 * @brief Check if Rx Packet available IT is enabled
2185 * @rmtoll IER RXPIE LL_SPI_IsEnabledIT_RXP
2186 * @param SPIx SPI Instance
2187 * @retval State of bit (1 or 0)
2189 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledIT_RXP(SPI_TypeDef
*SPIx
)
2191 return ((READ_BIT(SPIx
->IER
, SPI_IER_RXPIE
) == (SPI_IER_RXPIE
)) ? 1UL : 0UL);
2195 * @brief Check if Tx Packet space available IT is enabled
2196 * @rmtoll IER TXPIE LL_SPI_IsEnabledIT_TXP
2197 * @param SPIx SPI Instance
2198 * @retval State of bit (1 or 0)
2200 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledIT_TXP(SPI_TypeDef
*SPIx
)
2202 return ((READ_BIT(SPIx
->IER
, SPI_IER_TXPIE
) == (SPI_IER_TXPIE
)) ? 1UL : 0UL);
2206 * @brief Check if Duplex Packet available IT is enabled
2207 * @rmtoll IER DXPIE LL_SPI_IsEnabledIT_DXP
2208 * @param SPIx SPI Instance
2209 * @retval State of bit (1 or 0)
2211 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledIT_DXP(SPI_TypeDef
*SPIx
)
2213 return ((READ_BIT(SPIx
->IER
, SPI_IER_DXPIE
) == (SPI_IER_DXPIE
)) ? 1UL : 0UL);
2217 * @brief Check if End Of Transfer IT is enabled
2218 * @rmtoll IER EOTIE LL_SPI_IsEnabledIT_EOT
2219 * @param SPIx SPI Instance
2220 * @retval State of bit (1 or 0)
2222 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledIT_EOT(SPI_TypeDef
*SPIx
)
2224 return ((READ_BIT(SPIx
->IER
, SPI_IER_EOTIE
) == (SPI_IER_EOTIE
)) ? 1UL : 0UL);
2228 * @brief Check if TXTF IT is enabled
2229 * @rmtoll IER TXTFIE LL_SPI_IsEnabledIT_TXTF
2230 * @param SPIx SPI Instance
2231 * @retval State of bit (1 or 0)
2233 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledIT_TXTF(SPI_TypeDef
*SPIx
)
2235 return ((READ_BIT(SPIx
->IER
, SPI_IER_TXTFIE
) == (SPI_IER_TXTFIE
)) ? 1UL : 0UL);
2239 * @brief Check if Underrun IT is enabled
2240 * @rmtoll IER UDRIE LL_SPI_IsEnabledIT_UDR
2241 * @param SPIx SPI Instance
2242 * @retval State of bit (1 or 0)
2244 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledIT_UDR(SPI_TypeDef
*SPIx
)
2246 return ((READ_BIT(SPIx
->IER
, SPI_IER_UDRIE
) == (SPI_IER_UDRIE
)) ? 1UL : 0UL);
2250 * @brief Check if Overrun IT is enabled
2251 * @rmtoll IER OVRIE LL_SPI_IsEnabledIT_OVR
2252 * @param SPIx SPI Instance
2253 * @retval State of bit (1 or 0)
2255 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledIT_OVR(SPI_TypeDef
*SPIx
)
2257 return ((READ_BIT(SPIx
->IER
, SPI_IER_OVRIE
) == (SPI_IER_OVRIE
)) ? 1UL : 0UL);
2261 * @brief Check if CRC Error IT is enabled
2262 * @rmtoll IER CRCEIE LL_SPI_IsEnabledIT_CRCERR
2263 * @param SPIx SPI Instance
2264 * @retval State of bit (1 or 0)
2266 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledIT_CRCERR(SPI_TypeDef
*SPIx
)
2268 return ((READ_BIT(SPIx
->IER
, SPI_IER_CRCEIE
) == (SPI_IER_CRCEIE
)) ? 1UL : 0UL);
2272 * @brief Check if TI Frame Format Error IT is enabled
2273 * @rmtoll IER TIFREIE LL_SPI_IsEnabledIT_FRE
2274 * @param SPIx SPI Instance
2275 * @retval State of bit (1 or 0)
2277 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledIT_FRE(SPI_TypeDef
*SPIx
)
2279 return ((READ_BIT(SPIx
->IER
, SPI_IER_TIFREIE
) == (SPI_IER_TIFREIE
)) ? 1UL : 0UL);
2283 * @brief Check if MODF IT is enabled
2284 * @rmtoll IER MODFIE LL_SPI_IsEnabledIT_MODF
2285 * @param SPIx SPI Instance
2286 * @retval State of bit (1 or 0)
2288 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledIT_MODF(SPI_TypeDef
*SPIx
)
2290 return ((READ_BIT(SPIx
->IER
, SPI_IER_MODFIE
) == (SPI_IER_MODFIE
)) ? 1UL : 0UL);
2294 * @brief Check if TSER reload IT is enabled
2295 * @rmtoll IER TSERFIE LL_SPI_IsEnabledIT_TSER
2296 * @param SPIx SPI Instance
2297 * @retval State of bit (1 or 0)
2299 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledIT_TSER(SPI_TypeDef
*SPIx
)
2301 return ((READ_BIT(SPIx
->IER
, SPI_IER_TSERFIE
) == (SPI_IER_TSERFIE
)) ? 1UL : 0UL);
2308 /** @defgroup SPI_LL_EF_DMA_Management DMA Management
2313 * @brief Enable DMA Rx
2314 * @rmtoll CFG1 RXDMAEN LL_SPI_EnableDMAReq_RX
2315 * @param SPIx SPI Instance
2318 __STATIC_INLINE
void LL_SPI_EnableDMAReq_RX(SPI_TypeDef
*SPIx
)
2320 SET_BIT(SPIx
->CFG1
, SPI_CFG1_RXDMAEN
);
2324 * @brief Disable DMA Rx
2325 * @rmtoll CFG1 RXDMAEN LL_SPI_DisableDMAReq_RX
2326 * @param SPIx SPI Instance
2329 __STATIC_INLINE
void LL_SPI_DisableDMAReq_RX(SPI_TypeDef
*SPIx
)
2331 CLEAR_BIT(SPIx
->CFG1
, SPI_CFG1_RXDMAEN
);
2335 * @brief Check if DMA Rx is enabled
2336 * @rmtoll CFG1 RXDMAEN LL_SPI_IsEnabledDMAReq_RX
2337 * @param SPIx SPI Instance
2338 * @retval State of bit (1 or 0)
2340 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledDMAReq_RX(SPI_TypeDef
*SPIx
)
2342 return ((READ_BIT(SPIx
->CFG1
, SPI_CFG1_RXDMAEN
) == (SPI_CFG1_RXDMAEN
)) ? 1UL : 0UL);
2346 * @brief Enable DMA Tx
2347 * @rmtoll CFG1 TXDMAEN LL_SPI_EnableDMAReq_TX
2348 * @param SPIx SPI Instance
2351 __STATIC_INLINE
void LL_SPI_EnableDMAReq_TX(SPI_TypeDef
*SPIx
)
2353 SET_BIT(SPIx
->CFG1
, SPI_CFG1_TXDMAEN
);
2357 * @brief Disable DMA Tx
2358 * @rmtoll CFG1 TXDMAEN LL_SPI_DisableDMAReq_TX
2359 * @param SPIx SPI Instance
2362 __STATIC_INLINE
void LL_SPI_DisableDMAReq_TX(SPI_TypeDef
*SPIx
)
2364 CLEAR_BIT(SPIx
->CFG1
, SPI_CFG1_TXDMAEN
);
2368 * @brief Check if DMA Tx is enabled
2369 * @rmtoll CFG1 TXDMAEN LL_SPI_IsEnabledDMAReq_TX
2370 * @param SPIx SPI Instance
2371 * @retval State of bit (1 or 0)
2373 __STATIC_INLINE
uint32_t LL_SPI_IsEnabledDMAReq_TX(SPI_TypeDef
*SPIx
)
2375 return ((READ_BIT(SPIx
->CFG1
, SPI_CFG1_TXDMAEN
) == (SPI_CFG1_TXDMAEN
)) ? 1UL : 0UL);
2382 /** @defgroup SPI_LL_EF_DATA_Management DATA_Management
2387 * @brief Read Data Register
2388 * @rmtoll RXDR . LL_SPI_ReceiveData8
2389 * @param SPIx SPI Instance
2392 __STATIC_INLINE
uint8_t LL_SPI_ReceiveData8(SPI_TypeDef
*SPIx
)
2394 return (*((__IO
uint8_t *)&SPIx
->RXDR
));
2398 * @brief Read Data Register
2399 * @rmtoll RXDR . LL_SPI_ReceiveData16
2400 * @param SPIx SPI Instance
2403 __STATIC_INLINE
uint16_t LL_SPI_ReceiveData16(SPI_TypeDef
*SPIx
)
2405 return (uint16_t)(READ_REG(SPIx
->RXDR
));
2409 * @brief Read Data Register
2410 * @rmtoll RXDR . LL_SPI_ReceiveData32
2411 * @param SPIx SPI Instance
2412 * @retval 0..0xFFFFFFFF
2414 __STATIC_INLINE
uint32_t LL_SPI_ReceiveData32(SPI_TypeDef
*SPIx
)
2416 return (*((__IO
uint32_t *)&SPIx
->RXDR
));
2420 * @brief Write Data Register
2421 * @rmtoll TXDR . LL_SPI_TransmitData8
2422 * @param SPIx SPI Instance
2423 * @param TxData 0..0xFF
2426 __STATIC_INLINE
void LL_SPI_TransmitData8(SPI_TypeDef
*SPIx
, uint8_t TxData
)
2428 *((__IO
uint8_t *)&SPIx
->TXDR
) = TxData
;
2432 * @brief Write Data Register
2433 * @rmtoll TXDR . LL_SPI_TransmitData16
2434 * @param SPIx SPI Instance
2435 * @param TxData 0..0xFFFF
2438 __STATIC_INLINE
void LL_SPI_TransmitData16(SPI_TypeDef
*SPIx
, uint16_t TxData
)
2440 #if defined (__GNUC__)
2441 __IO
uint16_t *spitxdr
= ((__IO
uint16_t *)&SPIx
->TXDR
);
2444 SPIx
->TXDR
= TxData
;
2449 * @brief Write Data Register
2450 * @rmtoll TXDR . LL_SPI_TransmitData32
2451 * @param SPIx SPI Instance
2452 * @param TxData 0..0xFFFFFFFF
2455 __STATIC_INLINE
void LL_SPI_TransmitData32(SPI_TypeDef
*SPIx
, uint32_t TxData
)
2457 *((__IO
uint32_t *)&SPIx
->TXDR
) = TxData
;
2461 * @brief Set polynomial for CRC calcul
2462 * @rmtoll CRCPOLY CRCPOLY LL_SPI_SetCRCPolynomial
2463 * @param SPIx SPI Instance
2464 * @param CRCPoly 0..0xFFFFFFFF
2467 __STATIC_INLINE
void LL_SPI_SetCRCPolynomial(SPI_TypeDef
*SPIx
, uint32_t CRCPoly
)
2469 WRITE_REG(SPIx
->CRCPOLY
, CRCPoly
);
2473 * @brief Get polynomial for CRC calcul
2474 * @rmtoll CRCPOLY CRCPOLY LL_SPI_GetCRCPolynomial
2475 * @param SPIx SPI Instance
2476 * @retval 0..0xFFFFFFFF
2478 __STATIC_INLINE
uint32_t LL_SPI_GetCRCPolynomial(SPI_TypeDef
*SPIx
)
2480 return (uint32_t)(READ_REG(SPIx
->CRCPOLY
));
2484 * @brief Set the underrun pattern
2485 * @rmtoll UDRDR UDRDR LL_SPI_SetUDRPattern
2486 * @param SPIx SPI Instance
2487 * @param Pattern 0..0xFFFFFFFF
2490 __STATIC_INLINE
void LL_SPI_SetUDRPattern(SPI_TypeDef
*SPIx
, uint32_t Pattern
)
2492 WRITE_REG(SPIx
->UDRDR
, Pattern
);
2496 * @brief Get the underrun pattern
2497 * @rmtoll UDRDR UDRDR LL_SPI_GetUDRPattern
2498 * @param SPIx SPI Instance
2499 * @retval 0..0xFFFFFFFF
2501 __STATIC_INLINE
uint32_t LL_SPI_GetUDRPattern(SPI_TypeDef
*SPIx
)
2503 return (uint32_t)(READ_REG(SPIx
->UDRDR
));
2508 * @rmtoll RXCRCR RXCRC LL_SPI_GetRxCRC
2509 * @param SPIx SPI Instance
2510 * @retval 0..0xFFFFFFFF
2512 __STATIC_INLINE
uint32_t LL_SPI_GetRxCRC(SPI_TypeDef
*SPIx
)
2514 return (uint32_t)(READ_REG(SPIx
->RXCRC
));
2519 * @rmtoll TXCRCR TXCRC LL_SPI_GetTxCRC
2520 * @param SPIx SPI Instance
2521 * @retval 0..0xFFFFFFFF
2523 __STATIC_INLINE
uint32_t LL_SPI_GetTxCRC(SPI_TypeDef
*SPIx
)
2525 return (uint32_t)(READ_REG(SPIx
->TXCRC
));
2532 #if defined(USE_FULL_LL_DRIVER)
2533 /** @defgroup SPI_LL_EF_Init Initialization and de-initialization functions
2537 ErrorStatus
LL_SPI_DeInit(SPI_TypeDef
*SPIx
);
2538 ErrorStatus
LL_SPI_Init(SPI_TypeDef
*SPIx
, LL_SPI_InitTypeDef
*SPI_InitStruct
);
2539 void LL_SPI_StructInit(LL_SPI_InitTypeDef
*SPI_InitStruct
);
2544 #endif /* USE_FULL_LL_DRIVER */
2549 /** @defgroup I2S_LL I2S
2553 /* Private variables ---------------------------------------------------------*/
2554 /* Private constants ---------------------------------------------------------*/
2555 /* Private macros ------------------------------------------------------------*/
2557 /* Exported types ------------------------------------------------------------*/
2558 #if defined(USE_FULL_LL_DRIVER)
2559 /** @defgroup I2S_LL_ES_INIT I2S Exported Init structure
2564 * @brief I2S Init structure definition
2569 uint32_t Mode
; /*!< Specifies the I2S operating mode.
2570 This parameter can be a value of @ref I2S_LL_EC_MODE
2572 This feature can be modified afterwards using unitary function @ref LL_I2S_SetTransferMode().*/
2574 uint32_t Standard
; /*!< Specifies the standard used for the I2S communication.
2575 This parameter can be a value of @ref I2S_LL_EC_STANDARD
2577 This feature can be modified afterwards using unitary function @ref LL_I2S_SetStandard().*/
2580 uint32_t DataFormat
; /*!< Specifies the data format for the I2S communication.
2581 This parameter can be a value of @ref I2S_LL_EC_DATA_FORMAT
2583 This feature can be modified afterwards using unitary function @ref LL_I2S_SetDataFormat().*/
2586 uint32_t MCLKOutput
; /*!< Specifies whether the I2S MCLK output is enabled or not.
2587 This parameter can be a value of @ref I2S_LL_EC_MCLK_OUTPUT
2589 This feature can be modified afterwards using unitary functions @ref LL_I2S_EnableMasterClock() or @ref LL_I2S_DisableMasterClock.*/
2592 uint32_t AudioFreq
; /*!< Specifies the frequency selected for the I2S communication.
2593 This parameter can be a value of @ref I2S_LL_EC_AUDIO_FREQ
2595 Audio Frequency can be modified afterwards using Reference manual formulas to calculate Prescaler Linear, Parity
2596 and unitary functions @ref LL_I2S_SetPrescalerLinear() and @ref LL_I2S_SetPrescalerParity() to set it.*/
2599 uint32_t ClockPolarity
; /*!< Specifies the idle state of the I2S clock.
2600 This parameter can be a value of @ref I2S_LL_EC_POLARITY
2602 This feature can be modified afterwards using unitary function @ref LL_I2S_SetClockPolarity().*/
2604 } LL_I2S_InitTypeDef
;
2609 #endif /*USE_FULL_LL_DRIVER*/
2611 /* Exported constants --------------------------------------------------------*/
2612 /** @defgroup I2S_LL_Exported_Constants I2S Exported Constants
2616 /** @defgroup I2S_LL_EC_DATA_FORMAT Data Format
2619 #define LL_I2S_DATAFORMAT_16B (0x00000000UL)
2620 #define LL_I2S_DATAFORMAT_16B_EXTENDED (SPI_I2SCFGR_CHLEN)
2621 #define LL_I2S_DATAFORMAT_24B (SPI_I2SCFGR_CHLEN | SPI_I2SCFGR_DATLEN_0)
2622 #define LL_I2S_DATAFORMAT_24B_LEFT_ALIGNED (SPI_I2SCFGR_CHLEN | SPI_I2SCFGR_DATLEN_0 | SPI_I2SCFGR_DATFMT)
2623 #define LL_I2S_DATAFORMAT_32B (SPI_I2SCFGR_CHLEN | SPI_I2SCFGR_DATLEN_1)
2628 /** @defgroup I2S_LL_EC_CHANNEL_LENGTH_TYPE Type of Channel Length
2631 #define LL_I2S_SLAVE_VARIABLE_CH_LENGTH (0x00000000UL)
2632 #define LL_I2S_SLAVE_FIXED_CH_LENGTH (SPI_I2SCFGR_FIXCH)
2637 /** @defgroup I2S_LL_EC_POLARITY Clock Polarity
2640 #define LL_I2S_POLARITY_LOW (0x00000000UL)
2641 #define LL_I2S_POLARITY_HIGH (SPI_I2SCFGR_CKPOL)
2646 /** @defgroup I2S_LL_EC_STANDARD I2S Standard
2649 #define LL_I2S_STANDARD_PHILIPS (0x00000000UL)
2650 #define LL_I2S_STANDARD_MSB (SPI_I2SCFGR_I2SSTD_0)
2651 #define LL_I2S_STANDARD_LSB (SPI_I2SCFGR_I2SSTD_1)
2652 #define LL_I2S_STANDARD_PCM_SHORT (SPI_I2SCFGR_I2SSTD_0 | SPI_I2SCFGR_I2SSTD_1)
2653 #define LL_I2S_STANDARD_PCM_LONG (SPI_I2SCFGR_I2SSTD_0 | SPI_I2SCFGR_I2SSTD_1 | SPI_I2SCFGR_PCMSYNC)
2658 /** @defgroup I2S_LL_EC_MODE Operation Mode
2661 #define LL_I2S_MODE_SLAVE_TX (0x00000000UL)
2662 #define LL_I2S_MODE_SLAVE_RX (SPI_I2SCFGR_I2SCFG_0)
2663 #define LL_I2S_MODE_SLAVE_FULL_DUPLEX (SPI_I2SCFGR_I2SCFG_2)
2664 #define LL_I2S_MODE_MASTER_TX (SPI_I2SCFGR_I2SCFG_1)
2665 #define LL_I2S_MODE_MASTER_RX (SPI_I2SCFGR_I2SCFG_1 | SPI_I2SCFGR_I2SCFG_0)
2666 #define LL_I2S_MODE_MASTER_FULL_DUPLEX (SPI_I2SCFGR_I2SCFG_2 | SPI_I2SCFGR_I2SCFG_0)
2671 /** @defgroup I2S_LL_EC_PRESCALER_PARITY Prescaler Factor
2674 #define LL_I2S_PRESCALER_PARITY_EVEN (0x00000000UL) /*!< Odd factor: Real divider value is = I2SDIV * 2 */
2675 #define LL_I2S_PRESCALER_PARITY_ODD (0x00000001UL) /*!< Odd factor: Real divider value is = (I2SDIV * 2)+1 */
2680 /** @defgroup I2S_LL_EC_FIFO_TH FIFO Threshold Level
2683 #define LL_I2S_FIFO_TH_01DATA (LL_SPI_FIFO_TH_01DATA)
2684 #define LL_I2S_FIFO_TH_02DATA (LL_SPI_FIFO_TH_02DATA)
2685 #define LL_I2S_FIFO_TH_03DATA (LL_SPI_FIFO_TH_03DATA)
2686 #define LL_I2S_FIFO_TH_04DATA (LL_SPI_FIFO_TH_04DATA)
2687 #define LL_I2S_FIFO_TH_05DATA (LL_SPI_FIFO_TH_05DATA)
2688 #define LL_I2S_FIFO_TH_06DATA (LL_SPI_FIFO_TH_06DATA)
2689 #define LL_I2S_FIFO_TH_07DATA (LL_SPI_FIFO_TH_07DATA)
2690 #define LL_I2S_FIFO_TH_08DATA (LL_SPI_FIFO_TH_08DATA)
2695 /** @defgroup I2S_LL_EC_BIT_ORDER Transmission Bit Order
2698 #define LL_I2S_LSB_FIRST (LL_SPI_LSB_FIRST)
2699 #define LL_I2S_MSB_FIRST (LL_SPI_MSB_FIRST)
2704 #if defined(USE_FULL_LL_DRIVER)
2706 /** @defgroup I2S_LL_EC_MCLK_OUTPUT MCLK Output
2709 #define LL_I2S_MCLK_OUTPUT_DISABLE (0x00000000UL)
2710 #define LL_I2S_MCLK_OUTPUT_ENABLE (SPI_I2SCFGR_MCKOE)
2715 /** @defgroup I2S_LL_EC_AUDIO_FREQ Audio Frequency
2719 #define LL_I2S_AUDIOFREQ_192K 192000UL /*!< Audio Frequency configuration 192000 Hz */
2720 #define LL_I2S_AUDIOFREQ_96K 96000UL /*!< Audio Frequency configuration 96000 Hz */
2721 #define LL_I2S_AUDIOFREQ_48K 48000UL /*!< Audio Frequency configuration 48000 Hz */
2722 #define LL_I2S_AUDIOFREQ_44K 44100UL /*!< Audio Frequency configuration 44100 Hz */
2723 #define LL_I2S_AUDIOFREQ_32K 32000UL /*!< Audio Frequency configuration 32000 Hz */
2724 #define LL_I2S_AUDIOFREQ_22K 22050UL /*!< Audio Frequency configuration 22050 Hz */
2725 #define LL_I2S_AUDIOFREQ_16K 16000UL /*!< Audio Frequency configuration 16000 Hz */
2726 #define LL_I2S_AUDIOFREQ_11K 11025UL /*!< Audio Frequency configuration 11025 Hz */
2727 #define LL_I2S_AUDIOFREQ_8K 8000UL /*!< Audio Frequency configuration 8000 Hz */
2728 #define LL_I2S_AUDIOFREQ_DEFAULT 0UL /*!< Audio Freq not specified. Register I2SDIV = 0 */
2732 #endif /* USE_FULL_LL_DRIVER */
2738 /* Exported macro ------------------------------------------------------------*/
2739 /** @defgroup I2S_LL_Exported_Macros I2S Exported Macros
2743 /** @defgroup I2S_LL_EM_WRITE_READ Common Write and read registers Macros
2748 * @brief Write a value in I2S register
2749 * @param __INSTANCE__ I2S Instance
2750 * @param __REG__ Register to be written
2751 * @param __VALUE__ Value to be written in the register
2754 #define LL_I2S_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__))
2757 * @brief Read a value in I2S register
2758 * @param __INSTANCE__ I2S Instance
2759 * @param __REG__ Register to be read
2760 * @retval Register value
2762 #define LL_I2S_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__)
2772 /* Exported functions --------------------------------------------------------*/
2774 /** @defgroup I2S_LL_Exported_Functions I2S Exported Functions
2778 /** @defgroup I2S_LL_EF_Configuration Configuration
2783 * @brief Set I2S Data frame format
2784 * @rmtoll I2SCFGR DATLEN LL_I2S_SetDataFormat\n
2785 * I2SCFGR CHLEN LL_I2S_SetDataFormat\n
2786 * I2SCFGR DATFMT LL_I2S_SetDataFormat
2787 * @param SPIx SPI Handle
2788 * @param DataLength This parameter can be one of the following values:
2789 * @arg @ref LL_I2S_DATAFORMAT_16B
2790 * @arg @ref LL_I2S_DATAFORMAT_16B_EXTENDED
2791 * @arg @ref LL_I2S_DATAFORMAT_24B
2792 * @arg @ref LL_I2S_DATAFORMAT_24B_LEFT_ALIGNED
2793 * @arg @ref LL_I2S_DATAFORMAT_32B
2796 __STATIC_INLINE
void LL_I2S_SetDataFormat(SPI_TypeDef
*SPIx
, uint32_t DataLength
)
2798 MODIFY_REG(SPIx
->I2SCFGR
, SPI_I2SCFGR_DATLEN
| SPI_I2SCFGR_CHLEN
| SPI_I2SCFGR_DATFMT
, DataLength
);
2802 * @brief Get I2S Data frame format
2803 * @rmtoll I2SCFGR DATLEN LL_I2S_GetDataFormat\n
2804 * I2SCFGR CHLEN LL_I2S_GetDataFormat\n
2805 * I2SCFGR DATFMT LL_I2S_GetDataFormat
2806 * @param SPIx SPI Handle
2807 * @retval Return value can be one of the following values:
2808 * @arg @ref LL_I2S_DATAFORMAT_16B
2809 * @arg @ref LL_I2S_DATAFORMAT_16B_EXTENDED
2810 * @arg @ref LL_I2S_DATAFORMAT_24B
2811 * @arg @ref LL_I2S_DATAFORMAT_24B_LEFT_ALIGNED
2812 * @arg @ref LL_I2S_DATAFORMAT_32B
2814 __STATIC_INLINE
uint32_t LL_I2S_GetDataFormat(SPI_TypeDef
*SPIx
)
2816 return (uint32_t)(READ_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_DATLEN
| SPI_I2SCFGR_CHLEN
| SPI_I2SCFGR_DATFMT
));
2820 * @brief Set I2S Channel Length Type
2821 * @note This feature is usefull with SLAVE only
2822 * @rmtoll I2SCFGR FIXCH LL_I2S_SetChannelLengthType
2823 * @param SPIx SPI Handle
2824 * @param ChannelLengthType This parameter can be one of the following values:
2825 * @arg @ref LL_I2S_SLAVE_VARIABLE_CH_LENGTH
2826 * @arg @ref LL_I2S_SLAVE_FIXED_CH_LENGTH
2829 __STATIC_INLINE
void LL_I2S_SetChannelLengthType(SPI_TypeDef
*SPIx
, uint32_t ChannelLengthType
)
2831 MODIFY_REG(SPIx
->I2SCFGR
, SPI_I2SCFGR_FIXCH
, ChannelLengthType
);
2835 * @brief Get I2S Channel Length Type
2836 * @note This feature is usefull with SLAVE only
2837 * @rmtoll I2SCFGR FIXCH LL_I2S_GetChannelLengthType
2838 * @param SPIx SPI Handle
2839 * @retval Return value can be one of the following values:
2840 * @arg @ref LL_I2S_SLAVE_VARIABLE_CH_LENGTH
2841 * @arg @ref LL_I2S_SLAVE_FIXED_CH_LENGTH
2843 __STATIC_INLINE
uint32_t LL_I2S_GetChannelLengthType(SPI_TypeDef
*SPIx
)
2845 return (uint32_t)(READ_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_FIXCH
));
2849 * @brief Invert the default polarity of WS signal
2850 * @rmtoll I2SCFGR WSINV LL_I2S_EnableWordSelectInversion
2851 * @param SPIx SPI Handle
2854 __STATIC_INLINE
void LL_I2S_EnableWordSelectInversion(SPI_TypeDef
*SPIx
)
2856 SET_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_WSINV
);
2860 * @brief Use the default polarity of WS signal
2861 * @rmtoll I2SCFGR WSINV LL_I2S_DisableWordSelectInversion
2862 * @param SPIx SPI Handle
2865 __STATIC_INLINE
void LL_I2S_DisableWordSelectInversion(SPI_TypeDef
*SPIx
)
2867 CLEAR_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_WSINV
);
2871 * @brief Check if polarity of WS signal is inverted
2872 * @rmtoll I2SCFGR WSINV LL_I2S_IsEnabledWordSelectInversion
2873 * @param SPIx SPI Handle
2874 * @retval State of bit (1 or 0)
2876 __STATIC_INLINE
uint32_t LL_I2S_IsEnabledWordSelectInversion(SPI_TypeDef
*SPIx
)
2878 return ((READ_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_WSINV
) == (SPI_I2SCFGR_WSINV
)) ? 1UL : 0UL);
2882 * @brief Set 2S Clock Polarity
2883 * @rmtoll I2SCFGR CKPOL LL_I2S_SetClockPolarity
2884 * @param SPIx SPI Handle
2885 * @param ClockPolarity This parameter can be one of the following values:
2886 * @arg @ref LL_I2S_POLARITY_LOW
2887 * @arg @ref LL_I2S_POLARITY_HIGH
2890 __STATIC_INLINE
void LL_I2S_SetClockPolarity(SPI_TypeDef
*SPIx
, uint32_t ClockPolarity
)
2892 MODIFY_REG(SPIx
->I2SCFGR
, SPI_I2SCFGR_CKPOL
, ClockPolarity
);
2896 * @brief Get 2S Clock Polarity
2897 * @rmtoll I2SCFGR CKPOL LL_I2S_GetClockPolarity
2898 * @param SPIx SPI Handle
2899 * @retval Return value can be one of the following values:
2900 * @arg @ref LL_I2S_POLARITY_LOW
2901 * @arg @ref LL_I2S_POLARITY_HIGH
2903 __STATIC_INLINE
uint32_t LL_I2S_GetClockPolarity(SPI_TypeDef
*SPIx
)
2905 return (uint32_t)(READ_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_CKPOL
));
2909 * @brief Set I2S standard
2910 * @rmtoll I2SCFGR I2SSTD LL_I2S_SetStandard\n
2911 * I2SCFGR PCMSYNC LL_I2S_SetStandard
2912 * @param SPIx SPI Handle
2913 * @param Standard This parameter can be one of the following values:
2914 * @arg @ref LL_I2S_STANDARD_PHILIPS
2915 * @arg @ref LL_I2S_STANDARD_MSB
2916 * @arg @ref LL_I2S_STANDARD_LSB
2917 * @arg @ref LL_I2S_STANDARD_PCM_SHORT
2918 * @arg @ref LL_I2S_STANDARD_PCM_LONG
2921 __STATIC_INLINE
void LL_I2S_SetStandard(SPI_TypeDef
*SPIx
, uint32_t Standard
)
2923 MODIFY_REG(SPIx
->I2SCFGR
, SPI_I2SCFGR_I2SSTD
| SPI_I2SCFGR_PCMSYNC
, Standard
);
2927 * @brief Get I2S standard
2928 * @rmtoll I2SCFGR I2SSTD LL_I2S_GetStandard\n
2929 * I2SCFGR PCMSYNC LL_I2S_GetStandard
2930 * @param SPIx SPI Handle
2931 * @retval Return value can be one of the following values:
2932 * @arg @ref LL_I2S_STANDARD_PHILIPS
2933 * @arg @ref LL_I2S_STANDARD_MSB
2934 * @arg @ref LL_I2S_STANDARD_LSB
2935 * @arg @ref LL_I2S_STANDARD_PCM_SHORT
2936 * @arg @ref LL_I2S_STANDARD_PCM_LONG
2938 __STATIC_INLINE
uint32_t LL_I2S_GetStandard(SPI_TypeDef
*SPIx
)
2940 return (uint32_t)(READ_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_I2SSTD
| SPI_I2SCFGR_PCMSYNC
));
2944 * @brief Set I2S config
2945 * @rmtoll I2SCFGR I2SCFG LL_I2S_SetTransferMode
2946 * @param SPIx SPI Handle
2947 * @param Standard This parameter can be one of the following values:
2948 * @arg @ref LL_I2S_MODE_SLAVE_TX
2949 * @arg @ref LL_I2S_MODE_SLAVE_RX
2950 * @arg @ref LL_I2S_MODE_SLAVE_FULL_DUPLEX
2951 * @arg @ref LL_I2S_MODE_MASTER_TX
2952 * @arg @ref LL_I2S_MODE_MASTER_RX
2953 * @arg @ref LL_I2S_MODE_MASTER_FULL_DUPLEX
2956 __STATIC_INLINE
void LL_I2S_SetTransferMode(SPI_TypeDef
*SPIx
, uint32_t Standard
)
2958 MODIFY_REG(SPIx
->I2SCFGR
, SPI_I2SCFGR_I2SCFG
, Standard
);
2962 * @brief Get I2S config
2963 * @rmtoll I2SCFGR I2SCFG LL_I2S_GetTransferMode
2964 * @param SPIx SPI Handle
2965 * @retval Return value can be one of the following values:
2966 * @arg @ref LL_I2S_MODE_SLAVE_TX
2967 * @arg @ref LL_I2S_MODE_SLAVE_RX
2968 * @arg @ref LL_I2S_MODE_SLAVE_FULL_DUPLEX
2969 * @arg @ref LL_I2S_MODE_MASTER_TX
2970 * @arg @ref LL_I2S_MODE_MASTER_RX
2971 * @arg @ref LL_I2S_MODE_MASTER_FULL_DUPLEX
2973 __STATIC_INLINE
uint32_t LL_I2S_GetTransferMode(SPI_TypeDef
*SPIx
)
2975 return (uint32_t)(READ_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_I2SCFG
));
2979 * @brief Select I2S mode and Enable I2S peripheral
2980 * @rmtoll I2SCFGR I2SMOD LL_I2S_Enable\n
2981 * CR1 SPE LL_I2S_Enable
2982 * @param SPIx SPI Handle
2985 __STATIC_INLINE
void LL_I2S_Enable(SPI_TypeDef
*SPIx
)
2987 SET_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_I2SMOD
);
2988 SET_BIT(SPIx
->CR1
, SPI_CR1_SPE
);
2992 * @brief Disable I2S peripheral and disable I2S mode
2993 * @rmtoll CR1 SPE LL_I2S_Disable\n
2994 * I2SCFGR I2SMOD LL_I2S_Disable
2995 * @param SPIx SPI Handle
2998 __STATIC_INLINE
void LL_I2S_Disable(SPI_TypeDef
*SPIx
)
3000 CLEAR_BIT(SPIx
->CR1
, SPI_CR1_SPE
);
3001 CLEAR_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_I2SMOD
);
3005 * @brief Swap the SDO and SDI pin
3006 * @note This configuration can not be changed when I2S is enabled.
3007 * @rmtoll CFG2 IOSWP LL_I2S_EnableIOSwap
3008 * @param SPIx SPI Instance
3011 __STATIC_INLINE
void LL_I2S_EnableIOSwap(SPI_TypeDef
*SPIx
)
3013 LL_SPI_EnableIOSwap(SPIx
);
3017 * @brief Restore default function for SDO and SDI pin
3018 * @note This configuration can not be changed when I2S is enabled.
3019 * @rmtoll CFG2 IOSWP LL_I2S_DisableIOSwap
3020 * @param SPIx SPI Instance
3023 __STATIC_INLINE
void LL_I2S_DisableIOSwap(SPI_TypeDef
*SPIx
)
3025 LL_SPI_DisableIOSwap(SPIx
);
3029 * @brief Check if SDO and SDI pin are swapped
3030 * @rmtoll CFG2 IOSWP LL_I2S_IsEnabledIOSwap
3031 * @param SPIx SPI Instance
3032 * @retval State of bit (1 or 0)
3034 __STATIC_INLINE
uint32_t LL_I2S_IsEnabledIOSwap(SPI_TypeDef
*SPIx
)
3036 return LL_SPI_IsEnabledIOSwap(SPIx
);
3040 * @brief Enable GPIO control
3041 * @note This configuration can not be changed when I2S is enabled.
3042 * @rmtoll CFG2 AFCNTR LL_I2S_EnableGPIOControl
3043 * @param SPIx SPI Instance
3046 __STATIC_INLINE
void LL_I2S_EnableGPIOControl(SPI_TypeDef
*SPIx
)
3048 LL_SPI_EnableGPIOControl(SPIx
);
3052 * @brief Disable GPIO control
3053 * @note This configuration can not be changed when I2S is enabled.
3054 * @rmtoll CFG2 AFCNTR LL_I2S_DisableGPIOControl
3055 * @param SPIx SPI Instance
3058 __STATIC_INLINE
void LL_I2S_DisableGPIOControl(SPI_TypeDef
*SPIx
)
3060 LL_SPI_DisableGPIOControl(SPIx
);
3064 * @brief Check if GPIO control is active
3065 * @rmtoll CFG2 AFCNTR LL_I2S_IsEnabledGPIOControl
3066 * @param SPIx SPI Instance
3067 * @retval State of bit (1 or 0)
3069 __STATIC_INLINE
uint32_t LL_I2S_IsEnabledGPIOControl(SPI_TypeDef
*SPIx
)
3071 return LL_SPI_IsEnabledGPIOControl(SPIx
);
3075 * @brief Lock the AF configuration of associated IOs
3076 * @note Once this bit is set, the SPI_CFG2 register content can not be modified until a hardware reset occurs.
3077 * The reset of the IOLock bit is done by hardware. for that, LL_SPI_DisableIOLock can not exist.
3078 * @rmtoll CR1 IOLOCK LL_SPI_EnableIOLock
3079 * @param SPIx SPI Instance
3082 __STATIC_INLINE
void LL_I2S_EnableIOLock(SPI_TypeDef
*SPIx
)
3084 LL_SPI_EnableIOLock(SPIx
);
3088 * @brief Check if the the SPI_CFG2 register is locked
3089 * @rmtoll CR1 IOLOCK LL_I2S_IsEnabledIOLock
3090 * @param SPIx SPI Instance
3091 * @retval State of bit (1 or 0)
3093 __STATIC_INLINE
uint32_t LL_I2S_IsEnabledIOLock(SPI_TypeDef
*SPIx
)
3095 return LL_SPI_IsEnabledIOLock(SPIx
);
3099 * @brief Set Transfer Bit Order
3100 * @note This configuration can not be changed when I2S is enabled.
3101 * @rmtoll CFG2 LSBFRST LL_I2S_SetTransferBitOrder
3102 * @param SPIx SPI Instance
3103 * @param BitOrder This parameter can be one of the following values:
3104 * @arg @ref LL_I2S_LSB_FIRST
3105 * @arg @ref LL_I2S_MSB_FIRST
3108 __STATIC_INLINE
void LL_I2S_SetTransferBitOrder(SPI_TypeDef
*SPIx
, uint32_t BitOrder
)
3110 LL_SPI_SetTransferBitOrder(SPIx
, BitOrder
);
3113 * @brief Get Transfer Bit Order
3114 * @rmtoll CFG2 LSBFRST LL_I2S_GetTransferBitOrder
3115 * @param SPIx SPI Instance
3116 * @retval Returned value can be one of the following values:
3117 * @arg @ref LL_I2S_LSB_FIRST
3118 * @arg @ref LL_I2S_MSB_FIRST
3120 __STATIC_INLINE
uint32_t LL_I2S_GetTransferBitOrder(SPI_TypeDef
*SPIx
)
3122 return LL_SPI_GetTransferBitOrder(SPIx
);
3126 * @brief Start effective transfer on wire
3127 * @rmtoll CR1 CSTART LL_I2S_StartTransfer
3128 * @param SPIx SPI Instance
3131 __STATIC_INLINE
void LL_I2S_StartTransfer(SPI_TypeDef
*SPIx
)
3133 LL_SPI_StartMasterTransfer(SPIx
);
3137 * @brief Check if there is an unfinished transfer
3138 * @rmtoll CR1 CSTART LL_I2S_IsTransferActive
3139 * @param SPIx SPI Instance
3140 * @retval State of bit (1 or 0)
3142 __STATIC_INLINE
uint32_t LL_I2S_IsActiveTransfer(SPI_TypeDef
*SPIx
)
3144 return LL_SPI_IsActiveMasterTransfer(SPIx
);
3148 * @brief Set threshold of FIFO that triggers a transfer event
3149 * @note This configuration can not be changed when I2S is enabled.
3150 * @rmtoll CFG1 FTHLV LL_I2S_SetFIFOThreshold
3151 * @param SPIx SPI Instance
3152 * @param Threshold This parameter can be one of the following values:
3153 * @arg @ref LL_I2S_FIFO_TH_01DATA
3154 * @arg @ref LL_I2S_FIFO_TH_02DATA
3155 * @arg @ref LL_I2S_FIFO_TH_03DATA
3156 * @arg @ref LL_I2S_FIFO_TH_04DATA
3157 * @arg @ref LL_I2S_FIFO_TH_05DATA
3158 * @arg @ref LL_I2S_FIFO_TH_06DATA
3159 * @arg @ref LL_I2S_FIFO_TH_07DATA
3160 * @arg @ref LL_I2S_FIFO_TH_08DATA
3163 __STATIC_INLINE
void LL_I2S_SetFIFOThreshold(SPI_TypeDef
*SPIx
, uint32_t Threshold
)
3165 LL_SPI_SetFIFOThreshold(SPIx
, Threshold
);
3169 * @brief Get threshold of FIFO that triggers a transfer event
3170 * @rmtoll CFG1 FTHLV LL_I2S_GetFIFOThreshold
3171 * @param SPIx SPI Instance
3172 * @retval Returned value can be one of the following values:
3173 * @arg @ref LL_I2S_FIFO_TH_01DATA
3174 * @arg @ref LL_I2S_FIFO_TH_02DATA
3175 * @arg @ref LL_I2S_FIFO_TH_03DATA
3176 * @arg @ref LL_I2S_FIFO_TH_04DATA
3177 * @arg @ref LL_I2S_FIFO_TH_05DATA
3178 * @arg @ref LL_I2S_FIFO_TH_06DATA
3179 * @arg @ref LL_I2S_FIFO_TH_07DATA
3180 * @arg @ref LL_I2S_FIFO_TH_08DATA
3182 __STATIC_INLINE
uint32_t LL_I2S_GetFIFOThreshold(SPI_TypeDef
*SPIx
)
3184 return LL_SPI_GetFIFOThreshold(SPIx
);
3188 * @brief Set I2S linear prescaler
3189 * @rmtoll I2SCFGR I2SDIV LL_I2S_SetPrescalerLinear
3190 * @param SPIx SPI Instance
3191 * @param PrescalerLinear Value between Min_Data=0x00 and Max_Data=0xFF
3192 * @note PrescalerLinear '1' is not authorized with parity LL_I2S_PRESCALER_PARITY_ODD
3195 __STATIC_INLINE
void LL_I2S_SetPrescalerLinear(SPI_TypeDef
*SPIx
, uint32_t PrescalerLinear
)
3197 MODIFY_REG(SPIx
->I2SCFGR
, SPI_I2SCFGR_I2SDIV
, (PrescalerLinear
<< SPI_I2SCFGR_I2SDIV_Pos
));
3201 * @brief Get I2S linear prescaler
3202 * @rmtoll I2SCFGR I2SDIV LL_I2S_GetPrescalerLinear
3203 * @param SPIx SPI Instance
3204 * @retval PrescalerLinear Value between Min_Data=0x00 and Max_Data=0xFF
3206 __STATIC_INLINE
uint32_t LL_I2S_GetPrescalerLinear(SPI_TypeDef
*SPIx
)
3208 return (uint32_t)(READ_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_I2SDIV
) >> SPI_I2SCFGR_I2SDIV_Pos
);
3212 * @brief Set I2S parity prescaler
3213 * @rmtoll I2SCFGR ODD LL_I2S_SetPrescalerParity
3214 * @param SPIx SPI Instance
3215 * @param PrescalerParity This parameter can be one of the following values:
3216 * @arg @ref LL_I2S_PRESCALER_PARITY_EVEN
3217 * @arg @ref LL_I2S_PRESCALER_PARITY_ODD
3220 __STATIC_INLINE
void LL_I2S_SetPrescalerParity(SPI_TypeDef
*SPIx
, uint32_t PrescalerParity
)
3222 MODIFY_REG(SPIx
->I2SCFGR
, SPI_I2SCFGR_ODD
, PrescalerParity
<< SPI_I2SCFGR_ODD_Pos
);
3226 * @brief Get I2S parity prescaler
3227 * @rmtoll I2SCFGR ODD LL_I2S_GetPrescalerParity
3228 * @param SPIx SPI Instance
3229 * @retval Returned value can be one of the following values:
3230 * @arg @ref LL_I2S_PRESCALER_PARITY_EVEN
3231 * @arg @ref LL_I2S_PRESCALER_PARITY_ODD
3233 __STATIC_INLINE
uint32_t LL_I2S_GetPrescalerParity(SPI_TypeDef
*SPIx
)
3235 return (uint32_t)(READ_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_ODD
) >> SPI_I2SCFGR_ODD_Pos
);
3239 * @brief Enable the Master Clock Output (Pin MCK)
3240 * @rmtoll I2SCFGR MCKOE LL_I2S_EnableMasterClock
3241 * @param SPIx SPI Handle
3244 __STATIC_INLINE
void LL_I2S_EnableMasterClock(SPI_TypeDef
*SPIx
)
3246 SET_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_MCKOE
);
3250 * @brief Disable the Master Clock Ouput (Pin MCK)
3251 * @rmtoll I2SCFGR MCKOE LL_I2S_DisableMasterClock
3252 * @param SPIx SPI Handle
3255 __STATIC_INLINE
void LL_I2S_DisableMasterClock(SPI_TypeDef
*SPIx
)
3257 CLEAR_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_MCKOE
);
3261 * @brief Check if the master clock output (Pin MCK) is enabled
3262 * @rmtoll I2SCFGR MCKOE LL_I2S_IsEnabledMasterClock
3263 * @param SPIx SPI Instance
3264 * @retval State of bit (1 or 0)
3266 __STATIC_INLINE
uint32_t LL_I2S_IsEnabledMasterClock(SPI_TypeDef
*SPIx
)
3268 return ((READ_BIT(SPIx
->I2SCFGR
, SPI_I2SCFGR_MCKOE
) == (SPI_I2SCFGR_MCKOE
)) ? 1UL : 0UL);
3276 /** @defgroup I2S_LL_EF_FLAG_Management FLAG_Management
3281 * @brief Check if there enough data in FIFO to read a full packet
3282 * @rmtoll SR RXP LL_I2S_IsActiveFlag_RXP
3283 * @param SPIx SPI Instance
3284 * @retval State of bit (1 or 0)
3286 __STATIC_INLINE
uint32_t LL_I2S_IsActiveFlag_RXP(SPI_TypeDef
*SPIx
)
3288 return LL_SPI_IsActiveFlag_RXP(SPIx
);
3292 * @brief Check if there enough space in FIFO to hold a full packet
3293 * @rmtoll SR TXP LL_I2S_IsActiveFlag_TXP
3294 * @param SPIx SPI Instance
3295 * @retval State of bit (1 or 0)
3297 __STATIC_INLINE
uint32_t LL_I2S_IsActiveFlag_TXP(SPI_TypeDef
*SPIx
)
3299 return LL_SPI_IsActiveFlag_TXP(SPIx
);
3303 * @brief Get Underrun error flag
3304 * @rmtoll SR UDR LL_I2S_IsActiveFlag_UDR
3305 * @param SPIx SPI Instance
3306 * @retval State of bit (1 or 0)
3308 __STATIC_INLINE
uint32_t LL_I2S_IsActiveFlag_UDR(SPI_TypeDef
*SPIx
)
3310 return LL_SPI_IsActiveFlag_UDR(SPIx
);
3314 * @brief Get Overrun error flag
3315 * @rmtoll SR OVR LL_I2S_IsActiveFlag_OVR
3316 * @param SPIx SPI Instance
3317 * @retval State of bit (1 or 0).
3319 __STATIC_INLINE
uint32_t LL_I2S_IsActiveFlag_OVR(SPI_TypeDef
*SPIx
)
3321 return LL_SPI_IsActiveFlag_OVR(SPIx
);
3325 * @brief Get TI Frame format error flag
3326 * @rmtoll SR TIFRE LL_I2S_IsActiveFlag_FRE
3327 * @param SPIx SPI Instance
3328 * @retval State of bit (1 or 0).
3330 __STATIC_INLINE
uint32_t LL_I2S_IsActiveFlag_FRE(SPI_TypeDef
*SPIx
)
3332 return LL_SPI_IsActiveFlag_FRE(SPIx
);
3336 * @brief Clear Underrun error flag
3337 * @rmtoll IFCR UDRC LL_I2S_ClearFlag_UDR
3338 * @param SPIx SPI Instance
3341 __STATIC_INLINE
void LL_I2S_ClearFlag_UDR(SPI_TypeDef
*SPIx
)
3343 LL_SPI_ClearFlag_UDR(SPIx
);
3347 * @brief Clear Overrun error flag
3348 * @rmtoll IFCR OVRC LL_I2S_ClearFlag_OVR
3349 * @param SPIx SPI Instance
3352 __STATIC_INLINE
void LL_I2S_ClearFlag_OVR(SPI_TypeDef
*SPIx
)
3354 LL_SPI_ClearFlag_OVR(SPIx
);
3358 * @brief Clear Frame format error flag
3359 * @rmtoll IFCR TIFREC LL_I2S_ClearFlag_FRE
3360 * @param SPIx SPI Instance
3363 __STATIC_INLINE
void LL_I2S_ClearFlag_FRE(SPI_TypeDef
*SPIx
)
3365 LL_SPI_ClearFlag_FRE(SPIx
);
3372 /** @defgroup I2S_LL_EF_IT_Management IT_Management
3377 * @brief Enable Rx Packet available IT
3378 * @rmtoll IER RXPIE LL_I2S_EnableIT_RXP
3379 * @param SPIx SPI Instance
3382 __STATIC_INLINE
void LL_I2S_EnableIT_RXP(SPI_TypeDef
*SPIx
)
3384 LL_SPI_EnableIT_RXP(SPIx
);
3388 * @brief Enable Tx Packet space available IT
3389 * @rmtoll IER TXPIE LL_I2S_EnableIT_TXP
3390 * @param SPIx SPI Instance
3393 __STATIC_INLINE
void LL_I2S_EnableIT_TXP(SPI_TypeDef
*SPIx
)
3395 LL_SPI_EnableIT_TXP(SPIx
);
3399 * @brief Enable Underrun IT
3400 * @rmtoll IER UDRIE LL_I2S_EnableIT_UDR
3401 * @param SPIx SPI Instance
3404 __STATIC_INLINE
void LL_I2S_EnableIT_UDR(SPI_TypeDef
*SPIx
)
3406 LL_SPI_EnableIT_UDR(SPIx
);
3410 * @brief Enable Overrun IT
3411 * @rmtoll IER OVRIE LL_I2S_EnableIT_OVR
3412 * @param SPIx SPI Instance
3415 __STATIC_INLINE
void LL_I2S_EnableIT_OVR(SPI_TypeDef
*SPIx
)
3417 LL_SPI_EnableIT_OVR(SPIx
);
3421 * @brief Enable TI Frame Format Error IT
3422 * @rmtoll IER TIFREIE LL_I2S_EnableIT_FRE
3423 * @param SPIx SPI Instance
3426 __STATIC_INLINE
void LL_I2S_EnableIT_FRE(SPI_TypeDef
*SPIx
)
3428 LL_SPI_EnableIT_FRE(SPIx
);
3432 * @brief Disable Rx Packet available IT
3433 * @rmtoll IER RXPIE LL_I2S_DisableIT_RXP
3434 * @param SPIx SPI Instance
3437 __STATIC_INLINE
void LL_I2S_DisableIT_RXP(SPI_TypeDef
*SPIx
)
3439 LL_SPI_DisableIT_RXP(SPIx
);
3443 * @brief Disable Tx Packet space available IT
3444 * @rmtoll IER TXPIE LL_I2S_DisableIT_TXP
3445 * @param SPIx SPI Instance
3448 __STATIC_INLINE
void LL_I2S_DisableIT_TXP(SPI_TypeDef
*SPIx
)
3450 LL_SPI_DisableIT_TXP(SPIx
);
3454 * @brief Disable Underrun IT
3455 * @rmtoll IER UDRIE LL_I2S_DisableIT_UDR
3456 * @param SPIx SPI Instance
3459 __STATIC_INLINE
void LL_I2S_DisableIT_UDR(SPI_TypeDef
*SPIx
)
3461 LL_SPI_DisableIT_UDR(SPIx
);
3465 * @brief Disable Overrun IT
3466 * @rmtoll IER OVRIE LL_I2S_DisableIT_OVR
3467 * @param SPIx SPI Instance
3470 __STATIC_INLINE
void LL_I2S_DisableIT_OVR(SPI_TypeDef
*SPIx
)
3472 LL_SPI_DisableIT_OVR(SPIx
);
3476 * @brief Disable TI Frame Format Error IT
3477 * @rmtoll IER TIFREIE LL_I2S_DisableIT_FRE
3478 * @param SPIx SPI Instance
3481 __STATIC_INLINE
void LL_I2S_DisableIT_FRE(SPI_TypeDef
*SPIx
)
3483 LL_SPI_DisableIT_FRE(SPIx
);
3487 * @brief Check if Rx Packet available IT is enabled
3488 * @rmtoll IER RXPIE LL_I2S_IsEnabledIT_RXP
3489 * @param SPIx SPI Instance
3490 * @retval State of bit (1 or 0)
3492 __STATIC_INLINE
uint32_t LL_I2S_IsEnabledIT_RXP(SPI_TypeDef
*SPIx
)
3494 return LL_SPI_IsEnabledIT_RXP(SPIx
);
3498 * @brief Check if Tx Packet space available IT is enabled
3499 * @rmtoll IER TXPIE LL_I2S_IsEnabledIT_TXP
3500 * @param SPIx SPI Instance
3501 * @retval State of bit (1 or 0)
3503 __STATIC_INLINE
uint32_t LL_I2S_IsEnabledIT_TXP(SPI_TypeDef
*SPIx
)
3505 return LL_SPI_IsEnabledIT_TXP(SPIx
);
3509 * @brief Check if Underrun IT is enabled
3510 * @rmtoll IER UDRIE LL_I2S_IsEnabledIT_UDR
3511 * @param SPIx SPI Instance
3512 * @retval State of bit (1 or 0)
3514 __STATIC_INLINE
uint32_t LL_I2S_IsEnabledIT_UDR(SPI_TypeDef
*SPIx
)
3516 return LL_SPI_IsEnabledIT_UDR(SPIx
);
3520 * @brief Check if Overrun IT is enabled
3521 * @rmtoll IER OVRIE LL_I2S_IsEnabledIT_OVR
3522 * @param SPIx SPI Instance
3523 * @retval State of bit (1 or 0)
3525 __STATIC_INLINE
uint32_t LL_I2S_IsEnabledIT_OVR(SPI_TypeDef
*SPIx
)
3527 return LL_SPI_IsEnabledIT_OVR(SPIx
);
3531 * @brief Check if TI Frame Format Error IT is enabled
3532 * @rmtoll IER TIFREIE LL_I2S_IsEnabledIT_FRE
3533 * @param SPIx SPI Instance
3534 * @retval State of bit (1 or 0)
3536 __STATIC_INLINE
uint32_t LL_I2S_IsEnabledIT_FRE(SPI_TypeDef
*SPIx
)
3538 return LL_SPI_IsEnabledIT_FRE(SPIx
);
3545 /** @defgroup I2S_LL_EF_DMA_Management DMA_Management
3550 * @brief Enable DMA Rx
3551 * @rmtoll CFG1 RXDMAEN LL_I2S_EnableDMAReq_RX
3552 * @param SPIx SPI Instance
3555 __STATIC_INLINE
void LL_I2S_EnableDMAReq_RX(SPI_TypeDef
*SPIx
)
3557 LL_SPI_EnableDMAReq_RX(SPIx
);
3561 * @brief Disable DMA Rx
3562 * @rmtoll CFG1 RXDMAEN LL_I2S_DisableDMAReq_RX
3563 * @param SPIx SPI Instance
3566 __STATIC_INLINE
void LL_I2S_DisableDMAReq_RX(SPI_TypeDef
*SPIx
)
3568 LL_SPI_DisableDMAReq_RX(SPIx
);
3572 * @brief Check if DMA Rx is enabled
3573 * @rmtoll CFG1 RXDMAEN LL_I2S_IsEnabledDMAReq_RX
3574 * @param SPIx SPI Instance
3575 * @retval State of bit (1 or 0)
3577 __STATIC_INLINE
uint32_t LL_I2S_IsEnabledDMAReq_RX(SPI_TypeDef
*SPIx
)
3579 return LL_SPI_IsEnabledDMAReq_RX(SPIx
);
3583 * @brief Enable DMA Tx
3584 * @rmtoll CFG1 TXDMAEN LL_I2S_EnableDMAReq_TX
3585 * @param SPIx SPI Instance
3588 __STATIC_INLINE
void LL_I2S_EnableDMAReq_TX(SPI_TypeDef
*SPIx
)
3590 LL_SPI_EnableDMAReq_TX(SPIx
);
3594 * @brief Disable DMA Tx
3595 * @rmtoll CFG1 TXDMAEN LL_I2S_DisableDMAReq_TX
3596 * @param SPIx SPI Instance
3599 __STATIC_INLINE
void LL_I2S_DisableDMAReq_TX(SPI_TypeDef
*SPIx
)
3601 LL_SPI_DisableDMAReq_TX(SPIx
);
3605 * @brief Check if DMA Tx is enabled
3606 * @rmtoll CFG1 TXDMAEN LL_I2S_IsEnabledDMAReq_TX
3607 * @param SPIx SPI Instance
3608 * @retval State of bit (1 or 0)
3610 __STATIC_INLINE
uint32_t LL_I2S_IsEnabledDMAReq_TX(SPI_TypeDef
*SPIx
)
3612 return LL_SPI_IsEnabledDMAReq_TX(SPIx
);
3619 /** @defgroup I2S_LL_EF_DATA_Management DATA_Management
3624 * @brief Read Data Register
3625 * @rmtoll RXDR . LL_I2S_ReceiveData16
3626 * @param SPIx SPI Instance
3629 __STATIC_INLINE
uint16_t LL_I2S_ReceiveData16(SPI_TypeDef
*SPIx
)
3631 return LL_SPI_ReceiveData16(SPIx
);
3635 * @brief Read Data Register
3636 * @rmtoll RXDR . LL_I2S_ReceiveData32
3637 * @param SPIx SPI Instance
3638 * @retval 0..0xFFFFFFFF
3640 __STATIC_INLINE
uint32_t LL_I2S_ReceiveData32(SPI_TypeDef
*SPIx
)
3642 return LL_SPI_ReceiveData32(SPIx
);
3646 * @brief Write Data Register
3647 * @rmtoll TXDR . LL_I2S_TransmitData16
3648 * @param SPIx SPI Instance
3649 * @param TxData 0..0xFFFF
3652 __STATIC_INLINE
void LL_I2S_TransmitData16(SPI_TypeDef
*SPIx
, uint16_t TxData
)
3654 LL_SPI_TransmitData16(SPIx
, TxData
);
3658 * @brief Write Data Register
3659 * @rmtoll TXDR . LL_I2S_TransmitData32
3660 * @param SPIx SPI Instance
3661 * @param TxData 0..0xFFFFFFFF
3664 __STATIC_INLINE
void LL_I2S_TransmitData32(SPI_TypeDef
*SPIx
, uint32_t TxData
)
3666 LL_SPI_TransmitData32(SPIx
, TxData
);
3674 #if defined(USE_FULL_LL_DRIVER)
3675 /** @defgroup SPI_LL_EF_Init Initialization and de-initialization functions
3679 ErrorStatus
LL_I2S_DeInit(SPI_TypeDef
*SPIx
);
3680 ErrorStatus
LL_I2S_Init(SPI_TypeDef
*SPIx
, LL_I2S_InitTypeDef
*I2S_InitStruct
);
3681 void LL_I2S_StructInit(LL_I2S_InitTypeDef
*I2S_InitStruct
);
3682 void LL_I2S_ConfigPrescaler(SPI_TypeDef
*SPIx
, uint32_t PrescalerLinear
, uint32_t PrescalerParity
);
3687 #endif /* USE_FULL_LL_DRIVER */
3697 #endif /* defined(SPI1) || defined(SPI2) || defined(SPI3) || defined(SPI4) || defined(SPI5) || defined(SPI6) */
3710 #endif /* STM32H7xx_LL_SPI_H */
3712 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/