Set blackbox file handler to NULL after closing file
[inav.git] / lib / main / STM32H7 / Drivers / STM32H7xx_HAL_Driver / Inc / stm32h7xx_ll_bdma.h
blob0748b35d4dcf79ae0eeba27dca6dd9d1122647f6
1 /**
2 ******************************************************************************
3 * @file stm32h7xx_ll_bdma.h
4 * @author MCD Application Team
5 * @brief Header file of BDMA LL module.
6 ******************************************************************************
7 * @attention
9 * <h2><center>&copy; 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_BDMA_H
22 #define STM32H7xx_LL_BDMA_H
24 #ifdef __cplusplus
25 extern "C" {
26 #endif
28 /* Includes ------------------------------------------------------------------*/
29 #include "stm32h7xx.h"
30 #include "stm32h7xx_ll_dmamux.h"
32 /** @addtogroup STM32H7xx_LL_Driver
33 * @{
36 #if defined (BDMA) || defined (BDMA1) || defined (BDMA2)
38 /** @defgroup BDMA_LL BDMA
39 * @{
42 /* Private types -------------------------------------------------------------*/
43 /* Private variables ---------------------------------------------------------*/
44 /** @defgroup BDMA_LL_Private_Variables BDMA Private Variables
45 * @{
47 /* Array used to get the BDMA channel register offset versus channel index LL_BDMA_CHANNEL_x */
48 static const uint8_t LL_BDMA_CH_OFFSET_TAB[] =
50 (uint8_t)(BDMA_Channel0_BASE - BDMA_BASE),
51 (uint8_t)(BDMA_Channel1_BASE - BDMA_BASE),
52 (uint8_t)(BDMA_Channel2_BASE - BDMA_BASE),
53 (uint8_t)(BDMA_Channel3_BASE - BDMA_BASE),
54 (uint8_t)(BDMA_Channel4_BASE - BDMA_BASE),
55 (uint8_t)(BDMA_Channel5_BASE - BDMA_BASE),
56 (uint8_t)(BDMA_Channel6_BASE - BDMA_BASE),
57 (uint8_t)(BDMA_Channel7_BASE - BDMA_BASE)
59 /**
60 * @}
63 /* Private constants ---------------------------------------------------------*/
64 /* Private macros ------------------------------------------------------------*/
65 #if !defined(UNUSED)
66 #define UNUSED(x) ((void)(x))
67 #endif
69 /* Exported types ------------------------------------------------------------*/
70 #if defined(USE_FULL_LL_DRIVER)
71 /** @defgroup BDMA_LL_ES_INIT BDMA Exported Init structure
72 * @{
74 typedef struct
76 uint32_t PeriphOrM2MSrcAddress; /*!< Specifies the peripheral base address for BDMA transfer
77 or as Source base address in case of memory to memory transfer direction.
79 This parameter must be a value between Min_Data = 0 and Max_Data = 0xFFFFFFFF. */
81 uint32_t MemoryOrM2MDstAddress; /*!< Specifies the memory base address for DMA transfer
82 or as Destination base address in case of memory to memory transfer direction.
84 This parameter must be a value between Min_Data = 0 and Max_Data = 0xFFFFFFFF. */
86 uint32_t Direction; /*!< Specifies if the data will be transferred from memory to peripheral,
87 from memory to memory or from peripheral to memory.
88 This parameter can be a value of @ref BDMA_LL_EC_DIRECTION
90 This feature can be modified afterwards using unitary function @ref LL_BDMA_SetDataTransferDirection(). */
92 uint32_t Mode; /*!< Specifies the normal or circular operation mode.
93 This parameter can be a value of @ref BDMA_LL_EC_MODE
94 @note: The circular buffer mode cannot be used if the memory to memory
95 data transfer direction is configured on the selected Channel
97 This feature can be modified afterwards using unitary function @ref LL_BDMA_SetMode(). */
99 uint32_t PeriphOrM2MSrcIncMode; /*!< Specifies whether the Peripheral address or Source address in case of memory to memory transfer direction
100 is incremented or not.
101 This parameter can be a value of @ref BDMA_LL_EC_PERIPH
103 This feature can be modified afterwards using unitary function @ref LL_BDMA_SetPeriphIncMode(). */
105 uint32_t MemoryOrM2MDstIncMode; /*!< Specifies whether the Memory address or Destination address in case of memory to memory transfer direction
106 is incremented or not.
107 This parameter can be a value of @ref BDMA_LL_EC_MEMORY
109 This feature can be modified afterwards using unitary function @ref LL_BDMA_SetMemoryIncMode(). */
111 uint32_t PeriphOrM2MSrcDataSize; /*!< Specifies the Peripheral data size alignment or Source data size alignment (byte, half word, word)
112 in case of memory to memory transfer direction.
113 This parameter can be a value of @ref BDMA_LL_EC_PDATAALIGN
115 This feature can be modified afterwards using unitary function @ref LL_BDMA_SetPeriphSize(). */
117 uint32_t MemoryOrM2MDstDataSize; /*!< Specifies the Memory data size alignment or Destination data size alignment (byte, half word, word)
118 in case of memory to memory transfer direction.
119 This parameter can be a value of @ref BDMA_LL_EC_MDATAALIGN
121 This feature can be modified afterwards using unitary function @ref LL_BDMA_SetMemorySize(). */
123 uint32_t NbData; /*!< Specifies the number of data to transfer, in data unit.
124 The data unit is equal to the source buffer configuration set in PeripheralSize
125 or MemorySize parameters depending in the transfer direction.
126 This parameter must be a value between Min_Data = 0 and Max_Data = 0x0000FFFF
128 This feature can be modified afterwards using unitary function @ref LL_BDMA_SetDataLength(). */
130 uint32_t PeriphRequest; /*!< Specifies the peripheral request.
131 This parameter can be a value of @ref DMAMUX_LL_EC_REQUEST
133 This feature can be modified afterwards using unitary function @ref LL_BDMA_SetPeriphRequest(). */
135 uint32_t Priority; /*!< Specifies the channel priority level.
136 This parameter can be a value of @ref BDMA_LL_EC_PRIORITY
138 This feature can be modified afterwards using unitary function @ref LL_BDMA_SetChannelPriorityLevel(). */
140 } LL_BDMA_InitTypeDef;
142 * @}
144 #endif /* USE_FULL_LL_DRIVER */
146 /* Exported constants --------------------------------------------------------*/
147 /** @defgroup BDMA_LL_Exported_Constants BDMA Exported Constants
148 * @{
150 /** @defgroup BDMA_LL_EC_CLEAR_FLAG Clear Flags Defines
151 * @brief Flags defines which can be used with LL_BDMA_WriteReg function
152 * @{
154 #define LL_BDMA_IFCR_CGIF1 BDMA_IFCR_CGIF1 /*!< Channel 1 global flag */
155 #define LL_BDMA_IFCR_CTCIF1 BDMA_IFCR_CTCIF1 /*!< Channel 1 transfer complete flag */
156 #define LL_BDMA_IFCR_CHTIF1 BDMA_IFCR_CHTIF1 /*!< Channel 1 half transfer flag */
157 #define LL_BDMA_IFCR_CTEIF1 BDMA_IFCR_CTEIF1 /*!< Channel 1 transfer error flag */
158 #define LL_BDMA_IFCR_CGIF2 BDMA_IFCR_CGIF2 /*!< Channel 2 global flag */
159 #define LL_BDMA_IFCR_CTCIF2 BDMA_IFCR_CTCIF2 /*!< Channel 2 transfer complete flag */
160 #define LL_BDMA_IFCR_CHTIF2 BDMA_IFCR_CHTIF2 /*!< Channel 2 half transfer flag */
161 #define LL_BDMA_IFCR_CTEIF2 BDMA_IFCR_CTEIF2 /*!< Channel 2 transfer error flag */
162 #define LL_BDMA_IFCR_CGIF3 BDMA_IFCR_CGIF3 /*!< Channel 3 global flag */
163 #define LL_BDMA_IFCR_CTCIF3 BDMA_IFCR_CTCIF3 /*!< Channel 3 transfer complete flag */
164 #define LL_BDMA_IFCR_CHTIF3 BDMA_IFCR_CHTIF3 /*!< Channel 3 half transfer flag */
165 #define LL_BDMA_IFCR_CTEIF3 BDMA_IFCR_CTEIF3 /*!< Channel 3 transfer error flag */
166 #define LL_BDMA_IFCR_CGIF4 BDMA_IFCR_CGIF4 /*!< Channel 4 global flag */
167 #define LL_BDMA_IFCR_CTCIF4 BDMA_IFCR_CTCIF4 /*!< Channel 4 transfer complete flag */
168 #define LL_BDMA_IFCR_CHTIF4 BDMA_IFCR_CHTIF4 /*!< Channel 4 half transfer flag */
169 #define LL_BDMA_IFCR_CTEIF4 BDMA_IFCR_CTEIF4 /*!< Channel 4 transfer error flag */
170 #define LL_BDMA_IFCR_CGIF5 BDMA_IFCR_CGIF5 /*!< Channel 5 global flag */
171 #define LL_BDMA_IFCR_CTCIF5 BDMA_IFCR_CTCIF5 /*!< Channel 5 transfer complete flag */
172 #define LL_BDMA_IFCR_CHTIF5 BDMA_IFCR_CHTIF5 /*!< Channel 5 half transfer flag */
173 #define LL_BDMA_IFCR_CTEIF5 BDMA_IFCR_CTEIF5 /*!< Channel 5 transfer error flag */
174 #define LL_BDMA_IFCR_CGIF6 BDMA_IFCR_CGIF6 /*!< Channel 6 global flag */
175 #define LL_BDMA_IFCR_CTCIF6 BDMA_IFCR_CTCIF6 /*!< Channel 6 transfer complete flag */
176 #define LL_BDMA_IFCR_CHTIF6 BDMA_IFCR_CHTIF6 /*!< Channel 6 half transfer flag */
177 #define LL_BDMA_IFCR_CTEIF6 BDMA_IFCR_CTEIF6 /*!< Channel 6 transfer error flag */
178 #define LL_BDMA_IFCR_CGIF7 BDMA_IFCR_CGIF7 /*!< Channel 7 global flag */
179 #define LL_BDMA_IFCR_CTCIF7 BDMA_IFCR_CTCIF7 /*!< Channel 7 transfer complete flag */
180 #define LL_BDMA_IFCR_CHTIF7 BDMA_IFCR_CHTIF7 /*!< Channel 7 half transfer flag */
181 #define LL_BDMA_IFCR_CTEIF7 BDMA_IFCR_CTEIF7 /*!< Channel 7 transfer error flag */
183 * @}
186 /** @defgroup BDMA_LL_EC_GET_FLAG Get Flags Defines
187 * @brief Flags defines which can be used with LL_BDMA_ReadReg function
188 * @{
190 #define LL_BDMA_ISR_GIF0 BDMA_ISR_GIF0 /*!< Channel 1 global flag */
191 #define LL_BDMA_ISR_TCIF0 BDMA_ISR_TCIF0 /*!< Channel 1 transfer complete flag */
192 #define LL_BDMA_ISR_HTIF0 BDMA_ISR_HTIF0 /*!< Channel 1 half transfer flag */
193 #define LL_BDMA_ISR_TEIF0 BDMA_ISR_TEIF0 /*!< Channel 1 transfer error flag */
194 #define LL_BDMA_ISR_GIF1 BDMA_ISR_GIF1 /*!< Channel 1 global flag */
195 #define LL_BDMA_ISR_TCIF1 BDMA_ISR_TCIF1 /*!< Channel 1 transfer complete flag */
196 #define LL_BDMA_ISR_HTIF1 BDMA_ISR_HTIF1 /*!< Channel 1 half transfer flag */
197 #define LL_BDMA_ISR_TEIF1 BDMA_ISR_TEIF1 /*!< Channel 1 transfer error flag */
198 #define LL_BDMA_ISR_GIF2 BDMA_ISR_GIF2 /*!< Channel 2 global flag */
199 #define LL_BDMA_ISR_TCIF2 BDMA_ISR_TCIF2 /*!< Channel 2 transfer complete flag */
200 #define LL_BDMA_ISR_HTIF2 BDMA_ISR_HTIF2 /*!< Channel 2 half transfer flag */
201 #define LL_BDMA_ISR_TEIF2 BDMA_ISR_TEIF2 /*!< Channel 2 transfer error flag */
202 #define LL_BDMA_ISR_GIF3 BDMA_ISR_GIF3 /*!< Channel 3 global flag */
203 #define LL_BDMA_ISR_TCIF3 BDMA_ISR_TCIF3 /*!< Channel 3 transfer complete flag */
204 #define LL_BDMA_ISR_HTIF3 BDMA_ISR_HTIF3 /*!< Channel 3 half transfer flag */
205 #define LL_BDMA_ISR_TEIF3 BDMA_ISR_TEIF3 /*!< Channel 3 transfer error flag */
206 #define LL_BDMA_ISR_GIF4 BDMA_ISR_GIF4 /*!< Channel 4 global flag */
207 #define LL_BDMA_ISR_TCIF4 BDMA_ISR_TCIF4 /*!< Channel 4 transfer complete flag */
208 #define LL_BDMA_ISR_HTIF4 BDMA_ISR_HTIF4 /*!< Channel 4 half transfer flag */
209 #define LL_BDMA_ISR_TEIF4 BDMA_ISR_TEIF4 /*!< Channel 4 transfer error flag */
210 #define LL_BDMA_ISR_GIF5 BDMA_ISR_GIF5 /*!< Channel 5 global flag */
211 #define LL_BDMA_ISR_TCIF5 BDMA_ISR_TCIF5 /*!< Channel 5 transfer complete flag */
212 #define LL_BDMA_ISR_HTIF5 BDMA_ISR_HTIF5 /*!< Channel 5 half transfer flag */
213 #define LL_BDMA_ISR_TEIF5 BDMA_ISR_TEIF5 /*!< Channel 5 transfer error flag */
214 #define LL_BDMA_ISR_GIF6 BDMA_ISR_GIF6 /*!< Channel 6 global flag */
215 #define LL_BDMA_ISR_TCIF6 BDMA_ISR_TCIF6 /*!< Channel 6 transfer complete flag */
216 #define LL_BDMA_ISR_HTIF6 BDMA_ISR_HTIF6 /*!< Channel 6 half transfer flag */
217 #define LL_BDMA_ISR_TEIF6 BDMA_ISR_TEIF6 /*!< Channel 6 transfer error flag */
218 #define LL_BDMA_ISR_GIF7 BDMA_ISR_GIF7 /*!< Channel 7 global flag */
219 #define LL_BDMA_ISR_TCIF7 BDMA_ISR_TCIF7 /*!< Channel 7 transfer complete flag */
220 #define LL_BDMA_ISR_HTIF7 BDMA_ISR_HTIF7 /*!< Channel 7 half transfer flag */
221 #define LL_BDMA_ISR_TEIF7 BDMA_ISR_TEIF7 /*!< Channel 7 transfer error flag */
223 * @}
226 /** @defgroup BDMA_LL_EC_IT IT Defines
227 * @brief IT defines which can be used with LL_BDMA_ReadReg and LL_BDMA_WriteReg functions
228 * @{
230 #define LL_BDMA_CCR_TCIE BDMA_CCR_TCIE /*!< Transfer complete interrupt */
231 #define LL_BDMA_CCR_HTIE BDMA_CCR_HTIE /*!< Half Transfer interrupt */
232 #define LL_BDMA_CCR_TEIE BDMA_CCR_TEIE /*!< Transfer error interrupt */
234 * @}
237 /** @defgroup BDMA_LL_EC_CHANNEL CHANNEL
238 * @{
240 #define LL_BDMA_CHANNEL_0 0x00000000U /*!< DMA Channel 0 */
241 #define LL_BDMA_CHANNEL_1 0x00000001U /*!< BDMA Channel 1 */
242 #define LL_BDMA_CHANNEL_2 0x00000002U /*!< BDMA Channel 2 */
243 #define LL_BDMA_CHANNEL_3 0x00000003U /*!< BDMA Channel 3 */
244 #define LL_BDMA_CHANNEL_4 0x00000004U /*!< BDMA Channel 4 */
245 #define LL_BDMA_CHANNEL_5 0x00000005U /*!< BDMA Channel 5 */
246 #define LL_BDMA_CHANNEL_6 0x00000006U /*!< BDMA Channel 6 */
247 #define LL_BDMA_CHANNEL_7 0x00000007U /*!< BDMA Channel 7 */
248 #if defined(USE_FULL_LL_DRIVER)
249 #define LL_BDMA_CHANNEL_ALL 0xFFFF0000U /*!< BDMA Channel all (used only for function @ref LL_BDMA_DeInit(). */
250 #endif /*USE_FULL_LL_DRIVER*/
252 * @}
255 /** @defgroup BDMA_LL_EC_DIRECTION Transfer Direction
256 * @{
258 #define LL_BDMA_DIRECTION_PERIPH_TO_MEMORY 0x00000000U /*!< Peripheral to memory direction */
259 #define LL_BDMA_DIRECTION_MEMORY_TO_PERIPH BDMA_CCR_DIR /*!< Memory to peripheral direction */
260 #define LL_BDMA_DIRECTION_MEMORY_TO_MEMORY BDMA_CCR_MEM2MEM /*!< Memory to memory direction */
262 * @}
265 /** @defgroup BDMA_LL_EC_MODE Transfer mode
266 * @{
268 #define LL_BDMA_MODE_NORMAL 0x00000000U /*!< Normal Mode */
269 #define LL_BDMA_MODE_CIRCULAR BDMA_CCR_CIRC /*!< Circular Mode */
271 * @}
274 /** @defgroup DMA_LL_EC_DOUBLEBUFFER_MODE DOUBLE BUFFER MODE
275 * @{
277 #define LL_BDMA_DOUBLEBUFFER_MODE_DISABLE 0x00000000U /*!< Disable double buffering mode */
278 #define LL_BDMA_DOUBLEBUFFER_MODE_ENABLE BDMA_CCR_DBM /*!< Enable double buffering mode */
280 * @}
283 /** @defgroup BDMA_LL_EC_PERIPH Peripheral increment mode
284 * @{
286 #define LL_BDMA_PERIPH_INCREMENT BDMA_CCR_PINC /*!< Peripheral increment mode Enable */
287 #define LL_BDMA_PERIPH_NOINCREMENT 0x00000000U /*!< Peripheral increment mode Disable */
289 * @}
292 /** @defgroup BDMA_LL_EC_MEMORY Memory increment mode
293 * @{
295 #define LL_BDMA_MEMORY_INCREMENT BDMA_CCR_MINC /*!< Memory increment mode Enable */
296 #define LL_BDMA_MEMORY_NOINCREMENT 0x00000000U /*!< Memory increment mode Disable */
298 * @}
301 /** @defgroup BDMA_LL_EC_PDATAALIGN Peripheral data alignment
302 * @{
304 #define LL_BDMA_PDATAALIGN_BYTE 0x00000000U /*!< Peripheral data alignment : Byte */
305 #define LL_BDMA_PDATAALIGN_HALFWORD BDMA_CCR_PSIZE_0 /*!< Peripheral data alignment : HalfWord */
306 #define LL_BDMA_PDATAALIGN_WORD BDMA_CCR_PSIZE_1 /*!< Peripheral data alignment : Word */
308 * @}
311 /** @defgroup BDMA_LL_EC_MDATAALIGN Memory data alignment
312 * @{
314 #define LL_BDMA_MDATAALIGN_BYTE 0x00000000U /*!< Memory data alignment : Byte */
315 #define LL_BDMA_MDATAALIGN_HALFWORD BDMA_CCR_MSIZE_0 /*!< Memory data alignment : HalfWord */
316 #define LL_BDMA_MDATAALIGN_WORD BDMA_CCR_MSIZE_1 /*!< Memory data alignment : Word */
318 * @}
321 /** @defgroup BDMA_LL_EC_PRIORITY Transfer Priority level
322 * @{
324 #define LL_BDMA_PRIORITY_LOW 0x00000000U /*!< Priority level : Low */
325 #define LL_BDMA_PRIORITY_MEDIUM BDMA_CCR_PL_0 /*!< Priority level : Medium */
326 #define LL_BDMA_PRIORITY_HIGH BDMA_CCR_PL_1 /*!< Priority level : High */
327 #define LL_BDMA_PRIORITY_VERYHIGH BDMA_CCR_PL /*!< Priority level : Very_High */
329 * @}
332 /** @defgroup DMA_LL_EC_CURRENTTARGETMEM CURRENTTARGETMEM
333 * @{
335 #define LL_BDMA_CURRENTTARGETMEM0 0x00000000U /*!< Set CurrentTarget Memory to Memory 0 */
336 #define LL_BDMA_CURRENTTARGETMEM1 BDMA_CCR_CT /*!< Set CurrentTarget Memory to Memory 1 */
338 * @}
341 /* Exported macro ------------------------------------------------------------*/
342 /** @defgroup BDMA_LL_Exported_Macros BDMA Exported Macros
343 * @{
346 /** @defgroup BDMA_LL_EM_WRITE_READ Common Write and read registers macros
347 * @{
350 * @brief Write a value in BDMA register
351 * @param __INSTANCE__ BDMA Instance
352 * @param __REG__ Register to be written
353 * @param __VALUE__ Value to be written in the register
354 * @retval None
356 #define LL_BDMA_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG((__INSTANCE__)->__REG__, (__VALUE__))
359 * @brief Read a value in BDMA register
360 * @param __INSTANCE__ BDMA Instance
361 * @param __REG__ Register to be read
362 * @retval Register value
364 #define LL_BDMA_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__)
366 * @}
369 /** @defgroup BDMA_LL_EM_CONVERT_DMAxCHANNELy Convert BDMAxChannely
370 * @{
373 * @brief Convert BDMAx_Channely into BDMAx
374 * @param __CHANNEL_INSTANCE__ BDMAx_Channely
375 * @retval BDMAx
377 #if defined (BDMA1)
378 #define __LL_BDMA_GET_INSTANCE(__CHANNEL_INSTANCE__) \
379 (((uint32_t)(__CHANNEL_INSTANCE__) < LL_BDMA_CHANNEL_0) ? BDMA1 : BDMA)
380 #else
381 #define __LL_BDMA_GET_INSTANCE(__CHANNEL_INSTANCE__) (BDMA)
382 #endif /* BDMA1 */
385 * @brief Convert BDMAx_Channely into LL_BDMA_CHANNEL_y
386 * @param __CHANNEL_INSTANCE__ BDMAx_Channely
387 * @retval LL_BDMA_CHANNEL_y
389 #if defined (BDMA1)
390 #define __LL_BDMA_GET_CHANNEL(__CHANNEL_INSTANCE__) \
391 (((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel0)) ? LL_BDMA_CHANNEL_0 : \
392 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA1_Channel0)) ? LL_BDMA_CHANNEL_0 : \
393 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel1)) ? LL_BDMA_CHANNEL_1 : \
394 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA1_Channel1)) ? LL_BDMA_CHANNEL_1 : \
395 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel2)) ? LL_BDMA_CHANNEL_2 : \
396 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA1_Channel2)) ? LL_BDMA_CHANNEL_2 : \
397 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel3)) ? LL_BDMA_CHANNEL_3 : \
398 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA1_Channel3)) ? LL_BDMA_CHANNEL_3 : \
399 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel4)) ? LL_BDMA_CHANNEL_4 : \
400 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA1_Channel4)) ? LL_BDMA_CHANNEL_4 : \
401 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel5)) ? LL_BDMA_CHANNEL_5 : \
402 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA1_Channel5)) ? LL_BDMA_CHANNEL_5 : \
403 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel6)) ? LL_BDMA_CHANNEL_6 : \
404 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA1_Channel6)) ? LL_BDMA_CHANNEL_6 : \
405 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel7)) ? LL_BDMA_CHANNEL_7 : \
406 LL_BDMA_CHANNEL_7)
407 #else
408 #define __LL_BDMA_GET_CHANNEL(__CHANNEL_INSTANCE__) \
409 (((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel0)) ? LL_BDMA_CHANNEL_0 : \
410 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel1)) ? LL_BDMA_CHANNEL_1 : \
411 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel2)) ? LL_BDMA_CHANNEL_2 : \
412 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel3)) ? LL_BDMA_CHANNEL_3 : \
413 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel4)) ? LL_BDMA_CHANNEL_4 : \
414 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel5)) ? LL_BDMA_CHANNEL_5 : \
415 ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)BDMA_Channel6)) ? LL_BDMA_CHANNEL_6 : \
416 LL_BDMA_CHANNEL_7)
417 #endif /* BDMA1 */
420 * @brief Convert BDMA Instance BDMAx and LL_BDMA_CHANNEL_y into BDMAx_Channely
421 * @param __BDMA_INSTANCE__ BDMAx
422 * @param __CHANNEL__ LL_BDMA_CHANNEL_y
423 * @retval BDMAx_Channely
425 #if defined (BDMA1)
426 #define __LL_BDMA_GET_CHANNEL_INSTANCE(__BDMA_INSTANCE__, __CHANNEL__) \
427 ((((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_0))) ? BDMA_Channel0 : \
428 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_0))) ? BDMA1_Channel0 : \
429 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_1))) ? BDMA_Channel1 : \
430 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_1))) ? BDMA1_Channel1 : \
431 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_2))) ? BDMA_Channel2 : \
432 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_2))) ? BDMA1_Channel2 : \
433 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_3))) ? BDMA_Channel3 : \
434 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_3))) ? BDMA1_Channel3 : \
435 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_4))) ? BDMA_Channel4 : \
436 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_4))) ? BDMA1_Channel4 : \
437 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_5))) ? BDMA_Channel5 : \
438 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_5))) ? BDMA1_Channel5 : \
439 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_6))) ? BDMA_Channel6 : \
440 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_6))) ? BDMA1_Channel6 : \
441 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_7))) ? BDMA_Channel7 : \
442 BDMA1_Channel7)
443 #else
444 #define __LL_BDMA_GET_CHANNEL_INSTANCE(__BDMA_INSTANCE__, __CHANNEL__) \
445 ((((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_0))) ? BDMA_Channel0 : \
446 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_1))) ? BDMA_Channel1 : \
447 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_2))) ? BDMA_Channel2 : \
448 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_3))) ? BDMA_Channel3 : \
449 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_4))) ? BDMA_Channel4 : \
450 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_5))) ? BDMA_Channel5 : \
451 (((uint32_t)(__BDMA_INSTANCE__) == ((uint32_t)BDMA)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_BDMA_CHANNEL_6))) ? BDMA_Channel6 : \
452 BDMA_Channel7)
453 #endif /* BDMA1 */
455 * @}
459 * @}
462 /* Exported functions --------------------------------------------------------*/
463 /** @defgroup BDMA_LL_Exported_Functions BDMA Exported Functions
464 * @{
467 /** @defgroup BDMA_LL_EF_Configuration Configuration
468 * @{
471 * @brief Enable BDMA channel.
472 * @rmtoll CCR EN LL_BDMA_EnableChannel
473 * @param BDMAx BDMA Instance
474 * @param Channel This parameter can be one of the following values:
475 * @arg @ref LL_BDMA_CHANNEL_0
476 * @arg @ref LL_BDMA_CHANNEL_1
477 * @arg @ref LL_BDMA_CHANNEL_2
478 * @arg @ref LL_BDMA_CHANNEL_3
479 * @arg @ref LL_BDMA_CHANNEL_4
480 * @arg @ref LL_BDMA_CHANNEL_5
481 * @arg @ref LL_BDMA_CHANNEL_6
482 * @arg @ref LL_BDMA_CHANNEL_7
483 * @retval None
485 __STATIC_INLINE void LL_BDMA_EnableChannel(BDMA_TypeDef *BDMAx, uint32_t Channel)
487 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
489 SET_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_EN);
493 * @brief Disable BDMA channel.
494 * @rmtoll CCR EN LL_BDMA_DisableChannel
495 * @param BDMAx BDMA Instance
496 * @param Channel This parameter can be one of the following values:
497 * @arg @ref LL_BDMA_CHANNEL_0
498 * @arg @ref LL_BDMA_CHANNEL_1
499 * @arg @ref LL_BDMA_CHANNEL_2
500 * @arg @ref LL_BDMA_CHANNEL_3
501 * @arg @ref LL_BDMA_CHANNEL_4
502 * @arg @ref LL_BDMA_CHANNEL_5
503 * @arg @ref LL_BDMA_CHANNEL_6
504 * @arg @ref LL_BDMA_CHANNEL_7
505 * @retval None
507 __STATIC_INLINE void LL_BDMA_DisableChannel(BDMA_TypeDef *BDMAx, uint32_t Channel)
509 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
511 CLEAR_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_EN);
515 * @brief Check if BDMA channel is enabled or disabled.
516 * @rmtoll CCR EN LL_BDMA_IsEnabledChannel
517 * @param BDMAx BDMA Instance
518 * @param Channel This parameter can be one of the following values:
519 * @arg @ref LL_BDMA_CHANNEL_0
520 * @arg @ref LL_BDMA_CHANNEL_1
521 * @arg @ref LL_BDMA_CHANNEL_2
522 * @arg @ref LL_BDMA_CHANNEL_3
523 * @arg @ref LL_BDMA_CHANNEL_4
524 * @arg @ref LL_BDMA_CHANNEL_5
525 * @arg @ref LL_BDMA_CHANNEL_6
526 * @arg @ref LL_BDMA_CHANNEL_7
527 * @retval State of bit (1 or 0).
529 __STATIC_INLINE uint32_t LL_BDMA_IsEnabledChannel(BDMA_TypeDef *BDMAx, uint32_t Channel)
531 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
533 return ((READ_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_EN) == (BDMA_CCR_EN)) ? 1UL : 0UL);
537 * @brief Configure all parameters link to BDMA transfer.
538 * @rmtoll CCR DIR LL_BDMA_ConfigTransfer\n
539 * CCR MEM2MEM LL_BDMA_ConfigTransfer\n
540 * CCR CIRC LL_BDMA_ConfigTransfer\n
541 * CCR PINC LL_BDMA_ConfigTransfer\n
542 * CCR MINC LL_BDMA_ConfigTransfer\n
543 * CCR PSIZE LL_BDMA_ConfigTransfer\n
544 * CCR MSIZE LL_BDMA_ConfigTransfer\n
545 * CCR PL LL_BDMA_ConfigTransfer
546 * @param BDMAx BDMA Instance
547 * @param Channel This parameter can be one of the following values:
548 * @arg @ref LL_BDMA_CHANNEL_0
549 * @arg @ref LL_BDMA_CHANNEL_1
550 * @arg @ref LL_BDMA_CHANNEL_2
551 * @arg @ref LL_BDMA_CHANNEL_3
552 * @arg @ref LL_BDMA_CHANNEL_4
553 * @arg @ref LL_BDMA_CHANNEL_5
554 * @arg @ref LL_BDMA_CHANNEL_6
555 * @arg @ref LL_BDMA_CHANNEL_7
556 * @param Configuration This parameter must be a combination of all the following values:
557 * @arg @ref LL_BDMA_DIRECTION_PERIPH_TO_MEMORY or @ref LL_BDMA_DIRECTION_MEMORY_TO_PERIPH or @ref LL_BDMA_DIRECTION_MEMORY_TO_MEMORY
558 * @arg @ref LL_BDMA_MODE_NORMAL or @ref LL_BDMA_MODE_CIRCULAR
559 * @arg @ref LL_BDMA_PERIPH_INCREMENT or @ref LL_BDMA_PERIPH_NOINCREMENT
560 * @arg @ref LL_BDMA_MEMORY_INCREMENT or @ref LL_BDMA_MEMORY_NOINCREMENT
561 * @arg @ref LL_BDMA_PDATAALIGN_BYTE or @ref LL_BDMA_PDATAALIGN_HALFWORD or @ref LL_BDMA_PDATAALIGN_WORD
562 * @arg @ref LL_BDMA_MDATAALIGN_BYTE or @ref LL_BDMA_MDATAALIGN_HALFWORD or @ref LL_BDMA_MDATAALIGN_WORD
563 * @arg @ref LL_BDMA_PRIORITY_LOW or @ref LL_BDMA_PRIORITY_MEDIUM or @ref LL_BDMA_PRIORITY_HIGH or @ref LL_BDMA_PRIORITY_VERYHIGH
564 * @retval None
566 __STATIC_INLINE void LL_BDMA_ConfigTransfer(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t Configuration)
568 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
570 MODIFY_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR,
571 BDMA_CCR_DIR | BDMA_CCR_MEM2MEM | BDMA_CCR_CIRC | BDMA_CCR_PINC | BDMA_CCR_MINC | BDMA_CCR_PSIZE | BDMA_CCR_MSIZE | BDMA_CCR_PL,
572 Configuration);
576 * @brief Set Data transfer direction (read from peripheral or from memory).
577 * @rmtoll CCR DIR LL_BDMA_SetDataTransferDirection\n
578 * CCR MEM2MEM LL_BDMA_SetDataTransferDirection
579 * @param BDMAx BDMA Instance
580 * @param Channel This parameter can be one of the following values:
581 * @arg @ref LL_BDMA_CHANNEL_0
582 * @arg @ref LL_BDMA_CHANNEL_1
583 * @arg @ref LL_BDMA_CHANNEL_2
584 * @arg @ref LL_BDMA_CHANNEL_3
585 * @arg @ref LL_BDMA_CHANNEL_4
586 * @arg @ref LL_BDMA_CHANNEL_5
587 * @arg @ref LL_BDMA_CHANNEL_6
588 * @arg @ref LL_BDMA_CHANNEL_7
589 * @param Direction This parameter can be one of the following values:
590 * @arg @ref LL_BDMA_DIRECTION_PERIPH_TO_MEMORY
591 * @arg @ref LL_BDMA_DIRECTION_MEMORY_TO_PERIPH
592 * @arg @ref LL_BDMA_DIRECTION_MEMORY_TO_MEMORY
593 * @retval None
595 __STATIC_INLINE void LL_BDMA_SetDataTransferDirection(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t Direction)
597 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
599 MODIFY_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR,
600 BDMA_CCR_DIR | BDMA_CCR_MEM2MEM, Direction);
604 * @brief Get Data transfer direction (read from peripheral or from memory).
605 * @rmtoll CCR DIR LL_BDMA_GetDataTransferDirection\n
606 * CCR MEM2MEM LL_BDMA_GetDataTransferDirection
607 * @param BDMAx BDMA Instance
608 * @param Channel This parameter can be one of the following values:
609 * @arg @ref LL_BDMA_CHANNEL_0
610 * @arg @ref LL_BDMA_CHANNEL_1
611 * @arg @ref LL_BDMA_CHANNEL_2
612 * @arg @ref LL_BDMA_CHANNEL_3
613 * @arg @ref LL_BDMA_CHANNEL_4
614 * @arg @ref LL_BDMA_CHANNEL_5
615 * @arg @ref LL_BDMA_CHANNEL_6
616 * @arg @ref LL_BDMA_CHANNEL_7
617 * @retval Returned value can be one of the following values:
618 * @arg @ref LL_BDMA_DIRECTION_PERIPH_TO_MEMORY
619 * @arg @ref LL_BDMA_DIRECTION_MEMORY_TO_PERIPH
620 * @arg @ref LL_BDMA_DIRECTION_MEMORY_TO_MEMORY
622 __STATIC_INLINE uint32_t LL_BDMA_GetDataTransferDirection(BDMA_TypeDef *BDMAx, uint32_t Channel)
624 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
626 return (READ_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR,
627 BDMA_CCR_DIR | BDMA_CCR_MEM2MEM));
631 * @brief Set BDMA mode circular or normal.
632 * @note The circular buffer mode cannot be used if the memory-to-memory
633 * data transfer is configured on the selected Channel.
634 * @rmtoll CCR CIRC LL_BDMA_SetMode
635 * @param BDMAx BDMA Instance
636 * @param Channel This parameter can be one of the following values:
637 * @arg @ref LL_BDMA_CHANNEL_0
638 * @arg @ref LL_BDMA_CHANNEL_1
639 * @arg @ref LL_BDMA_CHANNEL_2
640 * @arg @ref LL_BDMA_CHANNEL_3
641 * @arg @ref LL_BDMA_CHANNEL_4
642 * @arg @ref LL_BDMA_CHANNEL_5
643 * @arg @ref LL_BDMA_CHANNEL_6
644 * @arg @ref LL_BDMA_CHANNEL_7
645 * @param Mode This parameter can be one of the following values:
646 * @arg @ref LL_BDMA_MODE_NORMAL
647 * @arg @ref LL_BDMA_MODE_CIRCULAR
648 * @retval None
650 __STATIC_INLINE void LL_BDMA_SetMode(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t Mode)
652 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
654 MODIFY_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_CIRC,
655 Mode);
659 * @brief Get BDMA mode circular or normal.
660 * @rmtoll CCR CIRC LL_BDMA_GetMode
661 * @param BDMAx BDMA Instance
662 * @param Channel This parameter can be one of the following values:
663 * @arg @ref LL_BDMA_CHANNEL_0
664 * @arg @ref LL_BDMA_CHANNEL_1
665 * @arg @ref LL_BDMA_CHANNEL_2
666 * @arg @ref LL_BDMA_CHANNEL_3
667 * @arg @ref LL_BDMA_CHANNEL_4
668 * @arg @ref LL_BDMA_CHANNEL_5
669 * @arg @ref LL_BDMA_CHANNEL_6
670 * @arg @ref LL_BDMA_CHANNEL_7
671 * @retval Returned value can be one of the following values:
672 * @arg @ref LL_BDMA_MODE_NORMAL
673 * @arg @ref LL_BDMA_MODE_CIRCULAR
675 __STATIC_INLINE uint32_t LL_BDMA_GetMode(BDMA_TypeDef *BDMAx, uint32_t Channel)
677 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
679 return (READ_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR,
680 BDMA_CCR_CIRC));
684 * @brief Set Peripheral increment mode.
685 * @rmtoll CCR PINC LL_BDMA_SetPeriphIncMode
686 * @param BDMAx BDMA Instance
687 * @param Channel This parameter can be one of the following values:
688 * @arg @ref LL_BDMA_CHANNEL_0
689 * @arg @ref LL_BDMA_CHANNEL_1
690 * @arg @ref LL_BDMA_CHANNEL_2
691 * @arg @ref LL_BDMA_CHANNEL_3
692 * @arg @ref LL_BDMA_CHANNEL_4
693 * @arg @ref LL_BDMA_CHANNEL_5
694 * @arg @ref LL_BDMA_CHANNEL_6
695 * @arg @ref LL_BDMA_CHANNEL_7
696 * @param PeriphOrM2MSrcIncMode This parameter can be one of the following values:
697 * @arg @ref LL_BDMA_PERIPH_INCREMENT
698 * @arg @ref LL_BDMA_PERIPH_NOINCREMENT
699 * @retval None
701 __STATIC_INLINE void LL_BDMA_SetPeriphIncMode(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t PeriphOrM2MSrcIncMode)
703 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
705 MODIFY_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_PINC,
706 PeriphOrM2MSrcIncMode);
710 * @brief Get Peripheral increment mode.
711 * @rmtoll CCR PINC LL_BDMA_GetPeriphIncMode
712 * @param BDMAx BDMA Instance
713 * @param Channel This parameter can be one of the following values:
714 * @arg @ref LL_BDMA_CHANNEL_0
715 * @arg @ref LL_BDMA_CHANNEL_1
716 * @arg @ref LL_BDMA_CHANNEL_2
717 * @arg @ref LL_BDMA_CHANNEL_3
718 * @arg @ref LL_BDMA_CHANNEL_4
719 * @arg @ref LL_BDMA_CHANNEL_5
720 * @arg @ref LL_BDMA_CHANNEL_6
721 * @arg @ref LL_BDMA_CHANNEL_7
722 * @retval Returned value can be one of the following values:
723 * @arg @ref LL_BDMA_PERIPH_INCREMENT
724 * @arg @ref LL_BDMA_PERIPH_NOINCREMENT
726 __STATIC_INLINE uint32_t LL_BDMA_GetPeriphIncMode(BDMA_TypeDef *BDMAx, uint32_t Channel)
728 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
730 return (READ_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR,
731 BDMA_CCR_PINC));
735 * @brief Set Memory increment mode.
736 * @rmtoll CCR MINC LL_BDMA_SetMemoryIncMode
737 * @param BDMAx BDMA Instance
738 * @param Channel This parameter can be one of the following values:
739 * @arg @ref LL_BDMA_CHANNEL_0
740 * @arg @ref LL_BDMA_CHANNEL_1
741 * @arg @ref LL_BDMA_CHANNEL_2
742 * @arg @ref LL_BDMA_CHANNEL_3
743 * @arg @ref LL_BDMA_CHANNEL_4
744 * @arg @ref LL_BDMA_CHANNEL_5
745 * @arg @ref LL_BDMA_CHANNEL_6
746 * @arg @ref LL_BDMA_CHANNEL_7
747 * @param MemoryOrM2MDstIncMode This parameter can be one of the following values:
748 * @arg @ref LL_BDMA_MEMORY_INCREMENT
749 * @arg @ref LL_BDMA_MEMORY_NOINCREMENT
750 * @retval None
752 __STATIC_INLINE void LL_BDMA_SetMemoryIncMode(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t MemoryOrM2MDstIncMode)
754 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
756 MODIFY_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_MINC,
757 MemoryOrM2MDstIncMode);
761 * @brief Get Memory increment mode.
762 * @rmtoll CCR MINC LL_BDMA_GetMemoryIncMode
763 * @param BDMAx BDMA Instance
764 * @param Channel This parameter can be one of the following values:
765 * @arg @ref LL_BDMA_CHANNEL_0
766 * @arg @ref LL_BDMA_CHANNEL_1
767 * @arg @ref LL_BDMA_CHANNEL_2
768 * @arg @ref LL_BDMA_CHANNEL_3
769 * @arg @ref LL_BDMA_CHANNEL_4
770 * @arg @ref LL_BDMA_CHANNEL_5
771 * @arg @ref LL_BDMA_CHANNEL_6
772 * @arg @ref LL_BDMA_CHANNEL_7
773 * @retval Returned value can be one of the following values:
774 * @arg @ref LL_BDMA_MEMORY_INCREMENT
775 * @arg @ref LL_BDMA_MEMORY_NOINCREMENT
777 __STATIC_INLINE uint32_t LL_BDMA_GetMemoryIncMode(BDMA_TypeDef *BDMAx, uint32_t Channel)
779 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
781 return (READ_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR,
782 BDMA_CCR_MINC));
786 * @brief Set Peripheral size.
787 * @rmtoll CCR PSIZE LL_BDMA_SetPeriphSize
788 * @param BDMAx BDMA Instance
789 * @param Channel This parameter can be one of the following values:
790 * @arg @ref LL_BDMA_CHANNEL_0
791 * @arg @ref LL_BDMA_CHANNEL_1
792 * @arg @ref LL_BDMA_CHANNEL_2
793 * @arg @ref LL_BDMA_CHANNEL_3
794 * @arg @ref LL_BDMA_CHANNEL_4
795 * @arg @ref LL_BDMA_CHANNEL_5
796 * @arg @ref LL_BDMA_CHANNEL_6
797 * @arg @ref LL_BDMA_CHANNEL_7
798 * @param PeriphOrM2MSrcDataSize This parameter can be one of the following values:
799 * @arg @ref LL_BDMA_PDATAALIGN_BYTE
800 * @arg @ref LL_BDMA_PDATAALIGN_HALFWORD
801 * @arg @ref LL_BDMA_PDATAALIGN_WORD
802 * @retval None
804 __STATIC_INLINE void LL_BDMA_SetPeriphSize(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t PeriphOrM2MSrcDataSize)
806 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
808 MODIFY_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_PSIZE,
809 PeriphOrM2MSrcDataSize);
813 * @brief Get Peripheral size.
814 * @rmtoll CCR PSIZE LL_BDMA_GetPeriphSize
815 * @param BDMAx BDMA Instance
816 * @param Channel This parameter can be one of the following values:
817 * @arg @ref LL_BDMA_CHANNEL_0
818 * @arg @ref LL_BDMA_CHANNEL_1
819 * @arg @ref LL_BDMA_CHANNEL_2
820 * @arg @ref LL_BDMA_CHANNEL_3
821 * @arg @ref LL_BDMA_CHANNEL_4
822 * @arg @ref LL_BDMA_CHANNEL_5
823 * @arg @ref LL_BDMA_CHANNEL_6
824 * @arg @ref LL_BDMA_CHANNEL_7
825 * @retval Returned value can be one of the following values:
826 * @arg @ref LL_BDMA_PDATAALIGN_BYTE
827 * @arg @ref LL_BDMA_PDATAALIGN_HALFWORD
828 * @arg @ref LL_BDMA_PDATAALIGN_WORD
830 __STATIC_INLINE uint32_t LL_BDMA_GetPeriphSize(BDMA_TypeDef *BDMAx, uint32_t Channel)
832 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
834 return (READ_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR,
835 BDMA_CCR_PSIZE));
839 * @brief Set Memory size.
840 * @rmtoll CCR MSIZE LL_BDMA_SetMemorySize
841 * @param BDMAx BDMA Instance
842 * @param Channel This parameter can be one of the following values:
843 * @arg @ref LL_BDMA_CHANNEL_0
844 * @arg @ref LL_BDMA_CHANNEL_1
845 * @arg @ref LL_BDMA_CHANNEL_2
846 * @arg @ref LL_BDMA_CHANNEL_3
847 * @arg @ref LL_BDMA_CHANNEL_4
848 * @arg @ref LL_BDMA_CHANNEL_5
849 * @arg @ref LL_BDMA_CHANNEL_6
850 * @arg @ref LL_BDMA_CHANNEL_7
851 * @param MemoryOrM2MDstDataSize This parameter can be one of the following values:
852 * @arg @ref LL_BDMA_MDATAALIGN_BYTE
853 * @arg @ref LL_BDMA_MDATAALIGN_HALFWORD
854 * @arg @ref LL_BDMA_MDATAALIGN_WORD
855 * @retval None
857 __STATIC_INLINE void LL_BDMA_SetMemorySize(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t MemoryOrM2MDstDataSize)
859 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
861 MODIFY_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_MSIZE,
862 MemoryOrM2MDstDataSize);
866 * @brief Get Memory size.
867 * @rmtoll CCR MSIZE LL_BDMA_GetMemorySize
868 * @param BDMAx BDMA Instance
869 * @param Channel This parameter can be one of the following values:
870 * @arg @ref LL_BDMA_CHANNEL_0
871 * @arg @ref LL_BDMA_CHANNEL_1
872 * @arg @ref LL_BDMA_CHANNEL_2
873 * @arg @ref LL_BDMA_CHANNEL_3
874 * @arg @ref LL_BDMA_CHANNEL_4
875 * @arg @ref LL_BDMA_CHANNEL_5
876 * @arg @ref LL_BDMA_CHANNEL_6
877 * @arg @ref LL_BDMA_CHANNEL_7
878 * @retval Returned value can be one of the following values:
879 * @arg @ref LL_BDMA_MDATAALIGN_BYTE
880 * @arg @ref LL_BDMA_MDATAALIGN_HALFWORD
881 * @arg @ref LL_BDMA_MDATAALIGN_WORD
883 __STATIC_INLINE uint32_t LL_BDMA_GetMemorySize(BDMA_TypeDef *BDMAx, uint32_t Channel)
885 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
887 return (READ_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR,
888 BDMA_CCR_MSIZE));
892 * @brief Set Channel priority level.
893 * @rmtoll CCR PL LL_BDMA_SetChannelPriorityLevel
894 * @param BDMAx BDMA Instance
895 * @param Channel This parameter can be one of the following values:
896 * @arg @ref LL_BDMA_CHANNEL_0
897 * @arg @ref LL_BDMA_CHANNEL_1
898 * @arg @ref LL_BDMA_CHANNEL_2
899 * @arg @ref LL_BDMA_CHANNEL_3
900 * @arg @ref LL_BDMA_CHANNEL_4
901 * @arg @ref LL_BDMA_CHANNEL_5
902 * @arg @ref LL_BDMA_CHANNEL_6
903 * @arg @ref LL_BDMA_CHANNEL_7
904 * @param Priority This parameter can be one of the following values:
905 * @arg @ref LL_BDMA_PRIORITY_LOW
906 * @arg @ref LL_BDMA_PRIORITY_MEDIUM
907 * @arg @ref LL_BDMA_PRIORITY_HIGH
908 * @arg @ref LL_BDMA_PRIORITY_VERYHIGH
909 * @retval None
911 __STATIC_INLINE void LL_BDMA_SetChannelPriorityLevel(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t Priority)
913 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
915 MODIFY_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_PL,
916 Priority);
920 * @brief Get Channel priority level.
921 * @rmtoll CCR PL LL_BDMA_GetChannelPriorityLevel
922 * @param BDMAx BDMA Instance
923 * @param Channel This parameter can be one of the following values:
924 * @arg @ref LL_BDMA_CHANNEL_0
925 * @arg @ref LL_BDMA_CHANNEL_1
926 * @arg @ref LL_BDMA_CHANNEL_2
927 * @arg @ref LL_BDMA_CHANNEL_3
928 * @arg @ref LL_BDMA_CHANNEL_4
929 * @arg @ref LL_BDMA_CHANNEL_5
930 * @arg @ref LL_BDMA_CHANNEL_6
931 * @arg @ref LL_BDMA_CHANNEL_7
932 * @retval Returned value can be one of the following values:
933 * @arg @ref LL_BDMA_PRIORITY_LOW
934 * @arg @ref LL_BDMA_PRIORITY_MEDIUM
935 * @arg @ref LL_BDMA_PRIORITY_HIGH
936 * @arg @ref LL_BDMA_PRIORITY_VERYHIGH
938 __STATIC_INLINE uint32_t LL_BDMA_GetChannelPriorityLevel(BDMA_TypeDef *BDMAx, uint32_t Channel)
940 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
942 return (READ_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR,
943 BDMA_CCR_PL));
947 * @brief Set Number of data to transfer.
948 * @note This action has no effect if
949 * channel is enabled.
950 * @rmtoll CNDTR NDT LL_BDMA_SetDataLength
951 * @param BDMAx BDMA Instance
952 * @param Channel This parameter can be one of the following values:
953 * @arg @ref LL_BDMA_CHANNEL_0
954 * @arg @ref LL_BDMA_CHANNEL_1
955 * @arg @ref LL_BDMA_CHANNEL_2
956 * @arg @ref LL_BDMA_CHANNEL_3
957 * @arg @ref LL_BDMA_CHANNEL_4
958 * @arg @ref LL_BDMA_CHANNEL_5
959 * @arg @ref LL_BDMA_CHANNEL_6
960 * @arg @ref LL_BDMA_CHANNEL_7
961 * @param NbData Between Min_Data = 0 and Max_Data = 0x0000FFFF
962 * @retval None
964 __STATIC_INLINE void LL_BDMA_SetDataLength(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t NbData)
966 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
968 MODIFY_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CNDTR,
969 BDMA_CNDTR_NDT, NbData);
973 * @brief Get Number of data to transfer.
974 * @note Once the channel is enabled, the return value indicate the
975 * remaining bytes to be transmitted.
976 * @rmtoll CNDTR NDT LL_BDMA_GetDataLength
977 * @param BDMAx BDMA Instance
978 * @param Channel This parameter can be one of the following values:
979 * @arg @ref LL_BDMA_CHANNEL_0
980 * @arg @ref LL_BDMA_CHANNEL_1
981 * @arg @ref LL_BDMA_CHANNEL_2
982 * @arg @ref LL_BDMA_CHANNEL_3
983 * @arg @ref LL_BDMA_CHANNEL_4
984 * @arg @ref LL_BDMA_CHANNEL_5
985 * @arg @ref LL_BDMA_CHANNEL_6
986 * @arg @ref LL_BDMA_CHANNEL_7
987 * @retval Between Min_Data = 0 and Max_Data = 0xFFFFFFFF
989 __STATIC_INLINE uint32_t LL_BDMA_GetDataLength(BDMA_TypeDef *BDMAx, uint32_t Channel)
991 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
993 return (READ_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CNDTR,
994 BDMA_CNDTR_NDT));
998 * @brief Set Current target (only in double buffer mode) to Memory 1 or Memory 0.
999 * @rmtoll CR CT LL_BDMA_SetCurrentTargetMem
1000 * @param BDMAx BDMAx Instance
1001 * @param Channel This parameter can be one of the following values:
1002 * @arg @ref LL_BDMA_CHANNEL_0
1003 * @arg @ref LL_BDMA_CHANNEL_1
1004 * @arg @ref LL_BDMA_CHANNEL_2
1005 * @arg @ref LL_BDMA_CHANNEL_3
1006 * @arg @ref LL_BDMA_CHANNEL_4
1007 * @arg @ref LL_BDMA_CHANNEL_5
1008 * @arg @ref LL_BDMA_CHANNEL_6
1009 * @arg @ref LL_BDMA_CHANNEL_7
1010 * @param CurrentMemory This parameter can be one of the following values:
1011 * @arg @ref LL_BDMA_CURRENTTARGETMEM0
1012 * @arg @ref LL_BDMA_CURRENTTARGETMEM1
1013 * @retval None
1015 __STATIC_INLINE void LL_BDMA_SetCurrentTargetMem(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t CurrentMemory)
1017 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1019 MODIFY_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_CT, CurrentMemory);
1023 * @brief Set Current target (only in double buffer mode) to Memory 1 or Memory 0.
1024 * @rmtoll CR CT LL_BDMA_GetCurrentTargetMem
1025 * @param BDMAx BDMAx Instance
1026 * @param Channel This parameter can be one of the following values:
1027 * @arg @ref LL_BDMA_CHANNEL_0
1028 * @arg @ref LL_BDMA_CHANNEL_1
1029 * @arg @ref LL_BDMA_CHANNEL_2
1030 * @arg @ref LL_BDMA_CHANNEL_3
1031 * @arg @ref LL_BDMA_CHANNEL_4
1032 * @arg @ref LL_BDMA_CHANNEL_5
1033 * @arg @ref LL_BDMA_CHANNEL_6
1034 * @arg @ref LL_BDMA_CHANNEL_7
1035 * @retval Returned value can be one of the following values:
1036 * @arg @ref LL_BDMA_CURRENTTARGETMEM0
1037 * @arg @ref LL_BDMA_CURRENTTARGETMEM1
1039 __STATIC_INLINE uint32_t LL_BDMA_GetCurrentTargetMem(BDMA_TypeDef *BDMAx, uint32_t Channel)
1041 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1043 return (READ_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_CT));
1047 * @brief Enable the double buffer mode.
1048 * @rmtoll CR DBM LL_BDMA_EnableDoubleBufferMode
1049 * @param BDMAx BDMAx Instance
1050 * @param Channel This parameter can be one of the following values:
1051 * @arg @ref LL_BDMA_CHANNEL_0
1052 * @arg @ref LL_BDMA_CHANNEL_1
1053 * @arg @ref LL_BDMA_CHANNEL_2
1054 * @arg @ref LL_BDMA_CHANNEL_3
1055 * @arg @ref LL_BDMA_CHANNEL_4
1056 * @arg @ref LL_BDMA_CHANNEL_5
1057 * @arg @ref LL_BDMA_CHANNEL_6
1058 * @arg @ref LL_BDMA_CHANNEL_7
1059 * @retval None
1061 __STATIC_INLINE void LL_BDMA_EnableDoubleBufferMode(BDMA_TypeDef *BDMAx, uint32_t Channel)
1063 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1065 SET_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_DBM);
1069 * @brief Disable the double buffer mode.
1070 * @rmtoll CR DBM LL_BDMA_DisableDoubleBufferMode
1071 * @param BDMAx BDMAx Instance
1072 * @param Channel This parameter can be one of the following values:
1073 * @arg @ref LL_BDMA_CHANNEL_0
1074 * @arg @ref LL_BDMA_CHANNEL_1
1075 * @arg @ref LL_BDMA_CHANNEL_2
1076 * @arg @ref LL_BDMA_CHANNEL_3
1077 * @arg @ref LL_BDMA_CHANNEL_4
1078 * @arg @ref LL_BDMA_CHANNEL_5
1079 * @arg @ref LL_BDMA_CHANNEL_6
1080 * @arg @ref LL_BDMA_CHANNEL_7
1081 * @retval None
1083 __STATIC_INLINE void LL_BDMA_DisableDoubleBufferMode(BDMA_TypeDef *BDMAx, uint32_t Channel)
1085 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1087 CLEAR_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_DBM);
1091 * @brief Configure the Source and Destination addresses.
1092 * @note This API must not be called when the BDMA channel is enabled.
1093 * @note Each IP using BDMA provides an API to get directly the register adress (LL_PPP_BDMA_GetRegAddr).
1094 * @rmtoll CPAR PA LL_BDMA_ConfigAddresses\n
1095 * CMAR MA LL_BDMA_ConfigAddresses
1096 * @param BDMAx BDMA Instance
1097 * @param Channel This parameter can be one of the following values:
1098 * @arg @ref LL_BDMA_CHANNEL_0
1099 * @arg @ref LL_BDMA_CHANNEL_1
1100 * @arg @ref LL_BDMA_CHANNEL_2
1101 * @arg @ref LL_BDMA_CHANNEL_3
1102 * @arg @ref LL_BDMA_CHANNEL_4
1103 * @arg @ref LL_BDMA_CHANNEL_5
1104 * @arg @ref LL_BDMA_CHANNEL_6
1105 * @arg @ref LL_BDMA_CHANNEL_7
1106 * @param SrcAddress Between Min_Data = 0 and Max_Data = 0xFFFFFFFF
1107 * @param DstAddress Between Min_Data = 0 and Max_Data = 0xFFFFFFFF
1108 * @param Direction This parameter can be one of the following values:
1109 * @arg @ref LL_BDMA_DIRECTION_PERIPH_TO_MEMORY
1110 * @arg @ref LL_BDMA_DIRECTION_MEMORY_TO_PERIPH
1111 * @arg @ref LL_BDMA_DIRECTION_MEMORY_TO_MEMORY
1112 * @retval None
1114 __STATIC_INLINE void LL_BDMA_ConfigAddresses(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t SrcAddress,
1115 uint32_t DstAddress, uint32_t Direction)
1117 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1119 /* Direction Memory to Periph */
1120 if (Direction == LL_BDMA_DIRECTION_MEMORY_TO_PERIPH)
1122 WRITE_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CM0AR, SrcAddress);
1123 WRITE_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CPAR, DstAddress);
1125 /* Direction Periph to Memory and Memory to Memory */
1126 else
1128 WRITE_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CPAR, SrcAddress);
1129 WRITE_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CM0AR, DstAddress);
1134 * @brief Set the Memory address.
1135 * @note Interface used for direction LL_BDMA_DIRECTION_PERIPH_TO_MEMORY or LL_BDMA_DIRECTION_MEMORY_TO_PERIPH only.
1136 * @note This API must not be called when the BDMA channel is enabled.
1137 * @rmtoll CMAR MA LL_BDMA_SetMemoryAddress
1138 * @param BDMAx BDMA Instance
1139 * @param Channel This parameter can be one of the following values:
1140 * @arg @ref LL_BDMA_CHANNEL_0
1141 * @arg @ref LL_BDMA_CHANNEL_1
1142 * @arg @ref LL_BDMA_CHANNEL_2
1143 * @arg @ref LL_BDMA_CHANNEL_3
1144 * @arg @ref LL_BDMA_CHANNEL_4
1145 * @arg @ref LL_BDMA_CHANNEL_5
1146 * @arg @ref LL_BDMA_CHANNEL_6
1147 * @arg @ref LL_BDMA_CHANNEL_7
1148 * @param MemoryAddress Between Min_Data = 0 and Max_Data = 0xFFFFFFFF
1149 * @retval None
1151 __STATIC_INLINE void LL_BDMA_SetMemoryAddress(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t MemoryAddress)
1153 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1155 WRITE_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CM0AR, MemoryAddress);
1159 * @brief Set the Peripheral address.
1160 * @note Interface used for direction LL_BDMA_DIRECTION_PERIPH_TO_MEMORY or LL_BDMA_DIRECTION_MEMORY_TO_PERIPH only.
1161 * @note This API must not be called when the BDMA channel is enabled.
1162 * @rmtoll CPAR PA LL_BDMA_SetPeriphAddress
1163 * @param BDMAx BDMA Instance
1164 * @param Channel This parameter can be one of the following values:
1165 * @arg @ref LL_BDMA_CHANNEL_0
1166 * @arg @ref LL_BDMA_CHANNEL_1
1167 * @arg @ref LL_BDMA_CHANNEL_2
1168 * @arg @ref LL_BDMA_CHANNEL_3
1169 * @arg @ref LL_BDMA_CHANNEL_4
1170 * @arg @ref LL_BDMA_CHANNEL_5
1171 * @arg @ref LL_BDMA_CHANNEL_6
1172 * @arg @ref LL_BDMA_CHANNEL_7
1173 * @param PeriphAddress Between Min_Data = 0 and Max_Data = 0xFFFFFFFF
1174 * @retval None
1176 __STATIC_INLINE void LL_BDMA_SetPeriphAddress(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t PeriphAddress)
1178 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1180 WRITE_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CPAR, PeriphAddress);
1184 * @brief Get Memory address.
1185 * @note Interface used for direction LL_BDMA_DIRECTION_PERIPH_TO_MEMORY or LL_BDMA_DIRECTION_MEMORY_TO_PERIPH only.
1186 * @rmtoll CMAR MA LL_BDMA_GetMemoryAddress
1187 * @param BDMAx BDMA Instance
1188 * @param Channel This parameter can be one of the following values:
1189 * @arg @ref LL_BDMA_CHANNEL_0
1190 * @arg @ref LL_BDMA_CHANNEL_1
1191 * @arg @ref LL_BDMA_CHANNEL_2
1192 * @arg @ref LL_BDMA_CHANNEL_3
1193 * @arg @ref LL_BDMA_CHANNEL_4
1194 * @arg @ref LL_BDMA_CHANNEL_5
1195 * @arg @ref LL_BDMA_CHANNEL_6
1196 * @arg @ref LL_BDMA_CHANNEL_7
1197 * @retval Between Min_Data = 0 and Max_Data = 0xFFFFFFFF
1199 __STATIC_INLINE uint32_t LL_BDMA_GetMemoryAddress(BDMA_TypeDef *BDMAx, uint32_t Channel)
1201 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1203 return (READ_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CM0AR));
1207 * @brief Get Peripheral address.
1208 * @note Interface used for direction LL_BDMA_DIRECTION_PERIPH_TO_MEMORY or LL_BDMA_DIRECTION_MEMORY_TO_PERIPH only.
1209 * @rmtoll CPAR PA LL_BDMA_GetPeriphAddress
1210 * @param BDMAx BDMA Instance
1211 * @param Channel This parameter can be one of the following values:
1212 * @arg @ref LL_BDMA_CHANNEL_0
1213 * @arg @ref LL_BDMA_CHANNEL_1
1214 * @arg @ref LL_BDMA_CHANNEL_2
1215 * @arg @ref LL_BDMA_CHANNEL_3
1216 * @arg @ref LL_BDMA_CHANNEL_4
1217 * @arg @ref LL_BDMA_CHANNEL_5
1218 * @arg @ref LL_BDMA_CHANNEL_6
1219 * @arg @ref LL_BDMA_CHANNEL_7
1220 * @retval Between Min_Data = 0 and Max_Data = 0xFFFFFFFF
1222 __STATIC_INLINE uint32_t LL_BDMA_GetPeriphAddress(BDMA_TypeDef *BDMAx, uint32_t Channel)
1224 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1226 return (READ_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CPAR));
1230 * @brief Set the Memory to Memory Source address.
1231 * @note Interface used for direction LL_BDMA_DIRECTION_MEMORY_TO_MEMORY only.
1232 * @note This API must not be called when the BDMA channel is enabled.
1233 * @rmtoll CPAR PA LL_BDMA_SetM2MSrcAddress
1234 * @param BDMAx BDMA Instance
1235 * @param Channel This parameter can be one of the following values:
1236 * @arg @ref LL_BDMA_CHANNEL_0
1237 * @arg @ref LL_BDMA_CHANNEL_1
1238 * @arg @ref LL_BDMA_CHANNEL_2
1239 * @arg @ref LL_BDMA_CHANNEL_3
1240 * @arg @ref LL_BDMA_CHANNEL_4
1241 * @arg @ref LL_BDMA_CHANNEL_5
1242 * @arg @ref LL_BDMA_CHANNEL_6
1243 * @arg @ref LL_BDMA_CHANNEL_7
1244 * @param MemoryAddress Between Min_Data = 0 and Max_Data = 0xFFFFFFFF
1245 * @retval None
1247 __STATIC_INLINE void LL_BDMA_SetM2MSrcAddress(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t MemoryAddress)
1249 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1251 WRITE_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CPAR, MemoryAddress);
1255 * @brief Set the Memory to Memory Destination address.
1256 * @note Interface used for direction LL_BDMA_DIRECTION_MEMORY_TO_MEMORY only.
1257 * @note This API must not be called when the BDMA channel is enabled.
1258 * @rmtoll CMAR MA LL_BDMA_SetM2MDstAddress
1259 * @param BDMAx BDMA Instance
1260 * @param Channel This parameter can be one of the following values:
1261 * @arg @ref LL_BDMA_CHANNEL_0
1262 * @arg @ref LL_BDMA_CHANNEL_1
1263 * @arg @ref LL_BDMA_CHANNEL_2
1264 * @arg @ref LL_BDMA_CHANNEL_3
1265 * @arg @ref LL_BDMA_CHANNEL_4
1266 * @arg @ref LL_BDMA_CHANNEL_5
1267 * @arg @ref LL_BDMA_CHANNEL_6
1268 * @arg @ref LL_BDMA_CHANNEL_7
1269 * @param MemoryAddress Between Min_Data = 0 and Max_Data = 0xFFFFFFFF
1270 * @retval None
1272 __STATIC_INLINE void LL_BDMA_SetM2MDstAddress(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t MemoryAddress)
1274 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1276 WRITE_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CM0AR, MemoryAddress);
1280 * @brief Get the Memory to Memory Source address.
1281 * @note Interface used for direction LL_BDMA_DIRECTION_MEMORY_TO_MEMORY only.
1282 * @rmtoll CPAR PA LL_BDMA_GetM2MSrcAddress
1283 * @param BDMAx BDMA Instance
1284 * @param Channel This parameter can be one of the following values:
1285 * @arg @ref LL_BDMA_CHANNEL_0
1286 * @arg @ref LL_BDMA_CHANNEL_1
1287 * @arg @ref LL_BDMA_CHANNEL_2
1288 * @arg @ref LL_BDMA_CHANNEL_3
1289 * @arg @ref LL_BDMA_CHANNEL_4
1290 * @arg @ref LL_BDMA_CHANNEL_5
1291 * @arg @ref LL_BDMA_CHANNEL_6
1292 * @arg @ref LL_BDMA_CHANNEL_7
1293 * @retval Between Min_Data = 0 and Max_Data = 0xFFFFFFFF
1295 __STATIC_INLINE uint32_t LL_BDMA_GetM2MSrcAddress(BDMA_TypeDef *BDMAx, uint32_t Channel)
1297 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1299 return (READ_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CPAR));
1303 * @brief Get the Memory to Memory Destination address.
1304 * @note Interface used for direction LL_BDMA_DIRECTION_MEMORY_TO_MEMORY only.
1305 * @rmtoll CMAR MA LL_BDMA_GetM2MDstAddress
1306 * @param BDMAx BDMA Instance
1307 * @param Channel This parameter can be one of the following values:
1308 * @arg @ref LL_BDMA_CHANNEL_0
1309 * @arg @ref LL_BDMA_CHANNEL_1
1310 * @arg @ref LL_BDMA_CHANNEL_2
1311 * @arg @ref LL_BDMA_CHANNEL_3
1312 * @arg @ref LL_BDMA_CHANNEL_4
1313 * @arg @ref LL_BDMA_CHANNEL_5
1314 * @arg @ref LL_BDMA_CHANNEL_6
1315 * @arg @ref LL_BDMA_CHANNEL_7
1316 * @retval Between Min_Data = 0 and Max_Data = 0xFFFFFFFF
1318 __STATIC_INLINE uint32_t LL_BDMA_GetM2MDstAddress(BDMA_TypeDef *BDMAx, uint32_t Channel)
1320 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1322 return (READ_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CM0AR));
1326 * @brief Set Memory 1 address (used in case of Double buffer mode).
1327 * @rmtoll M1AR M1A LL_BDMA_SetMemory1Address
1328 * @param BDMAx BDMAx Instance
1329 * @param Channel This parameter can be one of the following values:
1330 * @arg @ref LL_BDMA_CHANNEL_0
1331 * @arg @ref LL_BDMA_CHANNEL_1
1332 * @arg @ref LL_BDMA_CHANNEL_2
1333 * @arg @ref LL_BDMA_CHANNEL_3
1334 * @arg @ref LL_BDMA_CHANNEL_4
1335 * @arg @ref LL_BDMA_CHANNEL_5
1336 * @arg @ref LL_BDMA_CHANNEL_6
1337 * @arg @ref LL_BDMA_CHANNEL_7
1338 * @param Address Between 0 to 0xFFFFFFFF
1339 * @retval None
1341 __STATIC_INLINE void LL_BDMA_SetMemory1Address(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t Address)
1343 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1345 MODIFY_REG(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CM1AR, BDMA_CM1AR_MA, Address);
1349 * @brief Get Memory 1 address (used in case of Double buffer mode).
1350 * @rmtoll M1AR M1A LL_BDMA_GetMemory1Address
1351 * @param BDMAx BDMAx Instance
1352 * @param Channel This parameter can be one of the following values:
1353 * @arg @ref LL_BDMA_CHANNEL_0
1354 * @arg @ref LL_BDMA_CHANNEL_1
1355 * @arg @ref LL_BDMA_CHANNEL_2
1356 * @arg @ref LL_BDMA_CHANNEL_3
1357 * @arg @ref LL_BDMA_CHANNEL_4
1358 * @arg @ref LL_BDMA_CHANNEL_5
1359 * @arg @ref LL_BDMA_CHANNEL_6
1360 * @arg @ref LL_BDMA_CHANNEL_7
1361 * @retval Between 0 to 0xFFFFFFFF
1363 __STATIC_INLINE uint32_t LL_BDMA_GetMemory1Address(BDMA_TypeDef *BDMAx, uint32_t Channel)
1365 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
1367 return (((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CM1AR);
1371 * @brief Set BDMA request for BDMA Channels on DMAMUX Channel x.
1372 * @note DMAMUX2 channel 0 to 7 are mapped to BDMA channel 0 to 7.
1373 * @rmtoll CxCR DMAREQ_ID LL_BDMA_SetPeriphRequest
1374 * @param BDMAx BDMAx Instance
1375 * @param Channel This parameter can be one of the following values:
1376 * @arg @ref LL_BDMA_CHANNEL_0
1377 * @arg @ref LL_BDMA_CHANNEL_1
1378 * @arg @ref LL_BDMA_CHANNEL_2
1379 * @arg @ref LL_BDMA_CHANNEL_3
1380 * @arg @ref LL_BDMA_CHANNEL_4
1381 * @arg @ref LL_BDMA_CHANNEL_5
1382 * @arg @ref LL_BDMA_CHANNEL_6
1383 * @arg @ref LL_BDMA_CHANNEL_7
1384 * @param Request This parameter can be one of the following values:
1385 * @arg @ref LL_DMAMUX2_REQ_MEM2MEM
1386 * @arg @ref LL_DMAMUX2_REQ_GENERATOR0
1387 * @arg @ref LL_DMAMUX2_REQ_GENERATOR1
1388 * @arg @ref LL_DMAMUX2_REQ_GENERATOR2
1389 * @arg @ref LL_DMAMUX2_REQ_GENERATOR3
1390 * @arg @ref LL_DMAMUX2_REQ_GENERATOR4
1391 * @arg @ref LL_DMAMUX2_REQ_GENERATOR5
1392 * @arg @ref LL_DMAMUX2_REQ_GENERATOR6
1393 * @arg @ref LL_DMAMUX2_REQ_GENERATOR7
1394 * @arg @ref LL_DMAMUX2_REQ_LPUART1_RX
1395 * @arg @ref LL_DMAMUX2_REQ_LPUART1_TX
1396 * @arg @ref LL_DMAMUX2_REQ_SPI6_RX
1397 * @arg @ref LL_DMAMUX2_REQ_SPI6_TX
1398 * @arg @ref LL_DMAMUX2_REQ_I2C4_RX
1399 * @arg @ref LL_DMAMUX2_REQ_I2C4_TX
1400 * @arg @ref LL_DMAMUX2_REQ_SAI4_A (*)
1401 * @arg @ref LL_DMAMUX2_REQ_SAI4_B (*)
1402 * @arg @ref LL_DMAMUX2_REQ_ADC3 (*)
1403 * @arg @ref LL_DMAMUX2_REQ_DAC3 (*)
1404 * @arg @ref LL_DMAMUX2_REQ_DFSDM2_FLT0 (*)
1405 * @note (*) Availability depends on devices.
1406 * @retval None
1408 __STATIC_INLINE void LL_BDMA_SetPeriphRequest(BDMA_TypeDef *BDMAx, uint32_t Channel, uint32_t Request)
1410 UNUSED(BDMAx);
1411 MODIFY_REG(((DMAMUX_Channel_TypeDef *)(uint32_t)((uint32_t)DMAMUX2_Channel0 + (DMAMUX_CCR_SIZE * (Channel))))->CCR, DMAMUX_CxCR_DMAREQ_ID, Request);
1415 * @brief Get BDMA request for BDMA Channels on DMAMUX Channel x.
1416 * @note DMAMUX channel 0 to 7 are mapped to BDMA channel 0 to 7.
1417 * @rmtoll CxCR DMAREQ_ID LL_BDMA_GetPeriphRequest
1418 * @param BDMAx BDMAx Instance
1419 * @param Channel This parameter can be one of the following values:
1420 * @arg @ref LL_BDMA_CHANNEL_0
1421 * @arg @ref LL_BDMA_CHANNEL_1
1422 * @arg @ref LL_BDMA_CHANNEL_2
1423 * @arg @ref LL_BDMA_CHANNEL_3
1424 * @arg @ref LL_BDMA_CHANNEL_4
1425 * @arg @ref LL_BDMA_CHANNEL_5
1426 * @arg @ref LL_BDMA_CHANNEL_6
1427 * @arg @ref LL_BDMA_CHANNEL_7
1428 * @retval Returned value can be one of the following values:
1429 * @arg @ref LL_DMAMUX2_REQ_MEM2MEM
1430 * @arg @ref LL_DMAMUX2_REQ_GENERATOR0
1431 * @arg @ref LL_DMAMUX2_REQ_GENERATOR1
1432 * @arg @ref LL_DMAMUX2_REQ_GENERATOR2
1433 * @arg @ref LL_DMAMUX2_REQ_GENERATOR3
1434 * @arg @ref LL_DMAMUX2_REQ_GENERATOR4
1435 * @arg @ref LL_DMAMUX2_REQ_GENERATOR5
1436 * @arg @ref LL_DMAMUX2_REQ_GENERATOR6
1437 * @arg @ref LL_DMAMUX2_REQ_GENERATOR7
1438 * @arg @ref LL_DMAMUX2_REQ_LPUART1_RX
1439 * @arg @ref LL_DMAMUX2_REQ_LPUART1_TX
1440 * @arg @ref LL_DMAMUX2_REQ_SPI6_RX
1441 * @arg @ref LL_DMAMUX2_REQ_SPI6_TX
1442 * @arg @ref LL_DMAMUX2_REQ_I2C4_RX
1443 * @arg @ref LL_DMAMUX2_REQ_I2C4_TX
1444 * @arg @ref LL_DMAMUX2_REQ_SAI4_A (*)
1445 * @arg @ref LL_DMAMUX2_REQ_SAI4_B (*)
1446 * @arg @ref LL_DMAMUX2_REQ_ADC3 (*)
1447 * @arg @ref LL_DMAMUX2_REQ_DAC3 (*)
1448 * @arg @ref LL_DMAMUX2_REQ_DFSDM2_FLT0 (*)
1449 * @note (*) Availability depends on devices.
1451 __STATIC_INLINE uint32_t LL_BDMA_GetPeriphRequest(BDMA_TypeDef *BDMAx, uint32_t Channel)
1453 UNUSED(BDMAx);
1454 return (READ_BIT(((DMAMUX_Channel_TypeDef *)((uint32_t)((uint32_t)DMAMUX2_Channel0 + (DMAMUX_CCR_SIZE * (Channel)))))->CCR, DMAMUX_CxCR_DMAREQ_ID));
1458 * @}
1462 /** @defgroup BDMA_LL_EF_FLAG_Management FLAG_Management
1463 * @{
1466 * @brief Get Channel 0 global interrupt flag.
1467 * @rmtoll ISR GIF0 LL_BDMA_IsActiveFlag_GI0
1468 * @param BDMAx BDMA Instance
1469 * @retval State of bit (1 or 0).
1471 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_GI0(BDMA_TypeDef *BDMAx)
1473 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_GIF0) == (BDMA_ISR_GIF0)) ? 1UL : 0UL);
1477 * @brief Get Channel 1 global interrupt flag.
1478 * @rmtoll ISR GIF1 LL_BDMA_IsActiveFlag_GI1
1479 * @param BDMAx BDMA Instance
1480 * @retval State of bit (1 or 0).
1482 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_GI1(BDMA_TypeDef *BDMAx)
1484 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_GIF1) == (BDMA_ISR_GIF1)) ? 1UL : 0UL);
1488 * @brief Get Channel 2 global interrupt flag.
1489 * @rmtoll ISR GIF2 LL_BDMA_IsActiveFlag_GI2
1490 * @param BDMAx BDMA Instance
1491 * @retval State of bit (1 or 0).
1493 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_GI2(BDMA_TypeDef *BDMAx)
1495 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_GIF2) == (BDMA_ISR_GIF2)) ? 1UL : 0UL);
1499 * @brief Get Channel 3 global interrupt flag.
1500 * @rmtoll ISR GIF3 LL_BDMA_IsActiveFlag_GI3
1501 * @param BDMAx BDMA Instance
1502 * @retval State of bit (1 or 0).
1504 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_GI3(BDMA_TypeDef *BDMAx)
1506 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_GIF3) == (BDMA_ISR_GIF3)) ? 1UL : 0UL);
1510 * @brief Get Channel 4 global interrupt flag.
1511 * @rmtoll ISR GIF4 LL_BDMA_IsActiveFlag_GI4
1512 * @param BDMAx BDMA Instance
1513 * @retval State of bit (1 or 0).
1515 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_GI4(BDMA_TypeDef *BDMAx)
1517 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_GIF4) == (BDMA_ISR_GIF4)) ? 1UL : 0UL);
1521 * @brief Get Channel 5 global interrupt flag.
1522 * @rmtoll ISR GIF5 LL_BDMA_IsActiveFlag_GI5
1523 * @param BDMAx BDMA Instance
1524 * @retval State of bit (1 or 0).
1526 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_GI5(BDMA_TypeDef *BDMAx)
1528 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_GIF5) == (BDMA_ISR_GIF5)) ? 1UL : 0UL);
1532 * @brief Get Channel 6 global interrupt flag.
1533 * @rmtoll ISR GIF6 LL_BDMA_IsActiveFlag_GI6
1534 * @param BDMAx BDMA Instance
1535 * @retval State of bit (1 or 0).
1537 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_GI6(BDMA_TypeDef *BDMAx)
1539 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_GIF6) == (BDMA_ISR_GIF6)) ? 1UL : 0UL);
1543 * @brief Get Channel 7 global interrupt flag.
1544 * @rmtoll ISR GIF7 LL_BDMA_IsActiveFlag_GI7
1545 * @param BDMAx BDMA Instance
1546 * @retval State of bit (1 or 0).
1548 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_GI7(BDMA_TypeDef *BDMAx)
1550 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_GIF7) == (BDMA_ISR_GIF7)) ? 1UL : 0UL);
1554 * @brief Get Channel 0 transfer complete flag.
1555 * @rmtoll ISR TCIF0 LL_BDMA_IsActiveFlag_TC0
1556 * @param BDMAx BDMA Instance
1557 * @retval State of bit (1 or 0).
1559 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TC0(BDMA_TypeDef *BDMAx)
1561 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TCIF0) == (BDMA_ISR_TCIF0)) ? 1UL : 0UL);
1564 * @brief Get Channel 1 transfer complete flag.
1565 * @rmtoll ISR TCIF1 LL_BDMA_IsActiveFlag_TC1
1566 * @param BDMAx BDMA Instance
1567 * @retval State of bit (1 or 0).
1569 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TC1(BDMA_TypeDef *BDMAx)
1571 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TCIF1) == (BDMA_ISR_TCIF1)) ? 1UL : 0UL);
1575 * @brief Get Channel 2 transfer complete flag.
1576 * @rmtoll ISR TCIF2 LL_BDMA_IsActiveFlag_TC2
1577 * @param BDMAx BDMA Instance
1578 * @retval State of bit (1 or 0).
1580 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TC2(BDMA_TypeDef *BDMAx)
1582 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TCIF2) == (BDMA_ISR_TCIF2)) ? 1UL : 0UL);
1586 * @brief Get Channel 3 transfer complete flag.
1587 * @rmtoll ISR TCIF3 LL_BDMA_IsActiveFlag_TC3
1588 * @param BDMAx BDMA Instance
1589 * @retval State of bit (1 or 0).
1591 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TC3(BDMA_TypeDef *BDMAx)
1593 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TCIF3) == (BDMA_ISR_TCIF3)) ? 1UL : 0UL);
1597 * @brief Get Channel 4 transfer complete flag.
1598 * @rmtoll ISR TCIF4 LL_BDMA_IsActiveFlag_TC4
1599 * @param BDMAx BDMA Instance
1600 * @retval State of bit (1 or 0).
1602 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TC4(BDMA_TypeDef *BDMAx)
1604 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TCIF4) == (BDMA_ISR_TCIF4)) ? 1UL : 0UL);
1608 * @brief Get Channel 5 transfer complete flag.
1609 * @rmtoll ISR TCIF5 LL_BDMA_IsActiveFlag_TC5
1610 * @param BDMAx BDMA Instance
1611 * @retval State of bit (1 or 0).
1613 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TC5(BDMA_TypeDef *BDMAx)
1615 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TCIF5) == (BDMA_ISR_TCIF5)) ? 1UL : 0UL);
1619 * @brief Get Channel 6 transfer complete flag.
1620 * @rmtoll ISR TCIF6 LL_BDMA_IsActiveFlag_TC6
1621 * @param BDMAx BDMA Instance
1622 * @retval State of bit (1 or 0).
1624 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TC6(BDMA_TypeDef *BDMAx)
1626 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TCIF6) == (BDMA_ISR_TCIF6)) ? 1UL : 0UL);
1630 * @brief Get Channel 7 transfer complete flag.
1631 * @rmtoll ISR TCIF7 LL_BDMA_IsActiveFlag_TC7
1632 * @param BDMAx BDMA Instance
1633 * @retval State of bit (1 or 0).
1635 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TC7(BDMA_TypeDef *BDMAx)
1637 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TCIF7) == (BDMA_ISR_TCIF7)) ? 1UL : 0UL);
1641 * @brief Get Channel 0 half transfer flag.
1642 * @rmtoll ISR HTIF0 LL_BDMA_IsActiveFlag_HT0
1643 * @param BDMAx BDMA Instance
1644 * @retval State of bit (1 or 0).
1646 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_HT0(BDMA_TypeDef *BDMAx)
1648 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_HTIF0) == (BDMA_ISR_HTIF0)) ? 1UL : 0UL);
1652 * @brief Get Channel 1 half transfer flag.
1653 * @rmtoll ISR HTIF1 LL_BDMA_IsActiveFlag_HT1
1654 * @param BDMAx BDMA Instance
1655 * @retval State of bit (1 or 0).
1657 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_HT1(BDMA_TypeDef *BDMAx)
1659 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_HTIF1) == (BDMA_ISR_HTIF1)) ? 1UL : 0UL);
1663 * @brief Get Channel 2 half transfer flag.
1664 * @rmtoll ISR HTIF2 LL_BDMA_IsActiveFlag_HT2
1665 * @param BDMAx BDMA Instance
1666 * @retval State of bit (1 or 0).
1668 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_HT2(BDMA_TypeDef *BDMAx)
1670 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_HTIF2) == (BDMA_ISR_HTIF2)) ? 1UL : 0UL);
1674 * @brief Get Channel 3 half transfer flag.
1675 * @rmtoll ISR HTIF3 LL_BDMA_IsActiveFlag_HT3
1676 * @param BDMAx BDMA Instance
1677 * @retval State of bit (1 or 0).
1679 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_HT3(BDMA_TypeDef *BDMAx)
1681 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_HTIF3) == (BDMA_ISR_HTIF3)) ? 1UL : 0UL);
1685 * @brief Get Channel 4 half transfer flag.
1686 * @rmtoll ISR HTIF4 LL_BDMA_IsActiveFlag_HT4
1687 * @param BDMAx BDMA Instance
1688 * @retval State of bit (1 or 0).
1690 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_HT4(BDMA_TypeDef *BDMAx)
1692 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_HTIF4) == (BDMA_ISR_HTIF4)) ? 1UL : 0UL);
1696 * @brief Get Channel 5 half transfer flag.
1697 * @rmtoll ISR HTIF5 LL_BDMA_IsActiveFlag_HT5
1698 * @param BDMAx BDMA Instance
1699 * @retval State of bit (1 or 0).
1701 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_HT5(BDMA_TypeDef *BDMAx)
1703 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_HTIF5) == (BDMA_ISR_HTIF5)) ? 1UL : 0UL);
1707 * @brief Get Channel 6 half transfer flag.
1708 * @rmtoll ISR HTIF6 LL_BDMA_IsActiveFlag_HT6
1709 * @param BDMAx BDMA Instance
1710 * @retval State of bit (1 or 0).
1712 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_HT6(BDMA_TypeDef *BDMAx)
1714 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_HTIF6) == (BDMA_ISR_HTIF6)) ? 1UL : 0UL);
1718 * @brief Get Channel 7 half transfer flag.
1719 * @rmtoll ISR HTIF7 LL_BDMA_IsActiveFlag_HT7
1720 * @param BDMAx BDMA Instance
1721 * @retval State of bit (1 or 0).
1723 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_HT7(BDMA_TypeDef *BDMAx)
1725 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_HTIF7) == (BDMA_ISR_HTIF7)) ? 1UL : 0UL);
1729 * @brief Get Channel 0 transfer error flag.
1730 * @rmtoll ISR TEIF0 LL_BDMA_IsActiveFlag_TE0
1731 * @param BDMAx BDMA Instance
1732 * @retval State of bit (1 or 0).
1734 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TE0(BDMA_TypeDef *BDMAx)
1736 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TEIF0) == (BDMA_ISR_TEIF0)) ? 1UL : 0UL);
1740 * @brief Get Channel 1 transfer error flag.
1741 * @rmtoll ISR TEIF1 LL_BDMA_IsActiveFlag_TE1
1742 * @param BDMAx BDMA Instance
1743 * @retval State of bit (1 or 0).
1745 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TE1(BDMA_TypeDef *BDMAx)
1747 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TEIF1) == (BDMA_ISR_TEIF1)) ? 1UL : 0UL);
1751 * @brief Get Channel 2 transfer error flag.
1752 * @rmtoll ISR TEIF2 LL_BDMA_IsActiveFlag_TE2
1753 * @param BDMAx BDMA Instance
1754 * @retval State of bit (1 or 0).
1756 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TE2(BDMA_TypeDef *BDMAx)
1758 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TEIF2) == (BDMA_ISR_TEIF2)) ? 1UL : 0UL);
1762 * @brief Get Channel 3 transfer error flag.
1763 * @rmtoll ISR TEIF3 LL_BDMA_IsActiveFlag_TE3
1764 * @param BDMAx BDMA Instance
1765 * @retval State of bit (1 or 0).
1767 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TE3(BDMA_TypeDef *BDMAx)
1769 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TEIF3) == (BDMA_ISR_TEIF3)) ? 1UL : 0UL);
1773 * @brief Get Channel 4 transfer error flag.
1774 * @rmtoll ISR TEIF4 LL_BDMA_IsActiveFlag_TE4
1775 * @param BDMAx BDMA Instance
1776 * @retval State of bit (1 or 0).
1778 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TE4(BDMA_TypeDef *BDMAx)
1780 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TEIF4) == (BDMA_ISR_TEIF4)) ? 1UL : 0UL);
1784 * @brief Get Channel 5 transfer error flag.
1785 * @rmtoll ISR TEIF5 LL_BDMA_IsActiveFlag_TE5
1786 * @param BDMAx BDMA Instance
1787 * @retval State of bit (1 or 0).
1789 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TE5(BDMA_TypeDef *BDMAx)
1791 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TEIF5) == (BDMA_ISR_TEIF5)) ? 1UL : 0UL);
1795 * @brief Get Channel 6 transfer error flag.
1796 * @rmtoll ISR TEIF6 LL_BDMA_IsActiveFlag_TE6
1797 * @param BDMAx BDMA Instance
1798 * @retval State of bit (1 or 0).
1800 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TE6(BDMA_TypeDef *BDMAx)
1802 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TEIF6) == (BDMA_ISR_TEIF6)) ? 1UL : 0UL);
1806 * @brief Get Channel 7 transfer error flag.
1807 * @rmtoll ISR TEIF7 LL_BDMA_IsActiveFlag_TE7
1808 * @param BDMAx BDMA Instance
1809 * @retval State of bit (1 or 0).
1811 __STATIC_INLINE uint32_t LL_BDMA_IsActiveFlag_TE7(BDMA_TypeDef *BDMAx)
1813 return ((READ_BIT(BDMAx->ISR, BDMA_ISR_TEIF7) == (BDMA_ISR_TEIF7)) ? 1UL : 0UL);
1817 * @brief Clear Channel 0 global interrupt flag.
1818 * @rmtoll IFCR CGIF0 LL_BDMA_ClearFlag_GI0
1819 * @param BDMAx BDMA Instance
1820 * @retval None
1822 __STATIC_INLINE void LL_BDMA_ClearFlag_GI0(BDMA_TypeDef *BDMAx)
1824 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CGIF0);
1828 * @brief Clear Channel 1 global interrupt flag.
1829 * @rmtoll IFCR CGIF1 LL_BDMA_ClearFlag_GI1
1830 * @param BDMAx BDMA Instance
1831 * @retval None
1833 __STATIC_INLINE void LL_BDMA_ClearFlag_GI1(BDMA_TypeDef *BDMAx)
1835 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CGIF1);
1839 * @brief Clear Channel 2 global interrupt flag.
1840 * @rmtoll IFCR CGIF2 LL_BDMA_ClearFlag_GI2
1841 * @param BDMAx BDMA Instance
1842 * @retval None
1844 __STATIC_INLINE void LL_BDMA_ClearFlag_GI2(BDMA_TypeDef *BDMAx)
1846 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CGIF2);
1850 * @brief Clear Channel 3 global interrupt flag.
1851 * @rmtoll IFCR CGIF3 LL_BDMA_ClearFlag_GI3
1852 * @param BDMAx BDMA Instance
1853 * @retval None
1855 __STATIC_INLINE void LL_BDMA_ClearFlag_GI3(BDMA_TypeDef *BDMAx)
1857 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CGIF3);
1861 * @brief Clear Channel 4 global interrupt flag.
1862 * @rmtoll IFCR CGIF4 LL_BDMA_ClearFlag_GI4
1863 * @param BDMAx BDMA Instance
1864 * @retval None
1866 __STATIC_INLINE void LL_BDMA_ClearFlag_GI4(BDMA_TypeDef *BDMAx)
1868 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CGIF4);
1872 * @brief Clear Channel 5 global interrupt flag.
1873 * @rmtoll IFCR CGIF5 LL_BDMA_ClearFlag_GI5
1874 * @param BDMAx BDMA Instance
1875 * @retval None
1877 __STATIC_INLINE void LL_BDMA_ClearFlag_GI5(BDMA_TypeDef *BDMAx)
1879 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CGIF5);
1883 * @brief Clear Channel 6 global interrupt flag.
1884 * @rmtoll IFCR CGIF6 LL_BDMA_ClearFlag_GI6
1885 * @param BDMAx BDMA Instance
1886 * @retval None
1888 __STATIC_INLINE void LL_BDMA_ClearFlag_GI6(BDMA_TypeDef *BDMAx)
1890 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CGIF6);
1894 * @brief Clear Channel 7 global interrupt flag.
1895 * @rmtoll IFCR CGIF7 LL_BDMA_ClearFlag_GI7
1896 * @param BDMAx BDMA Instance
1897 * @retval None
1899 __STATIC_INLINE void LL_BDMA_ClearFlag_GI7(BDMA_TypeDef *BDMAx)
1901 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CGIF7);
1905 * @brief Clear Channel 0 transfer complete flag.
1906 * @rmtoll IFCR CTCIF0 LL_BDMA_ClearFlag_TC0
1907 * @param BDMAx BDMA Instance
1908 * @retval None
1910 __STATIC_INLINE void LL_BDMA_ClearFlag_TC0(BDMA_TypeDef *BDMAx)
1912 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTCIF0);
1916 * @brief Clear Channel 1 transfer complete flag.
1917 * @rmtoll IFCR CTCIF1 LL_BDMA_ClearFlag_TC1
1918 * @param BDMAx BDMA Instance
1919 * @retval None
1921 __STATIC_INLINE void LL_BDMA_ClearFlag_TC1(BDMA_TypeDef *BDMAx)
1923 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTCIF1);
1927 * @brief Clear Channel 2 transfer complete flag.
1928 * @rmtoll IFCR CTCIF2 LL_BDMA_ClearFlag_TC2
1929 * @param BDMAx BDMA Instance
1930 * @retval None
1932 __STATIC_INLINE void LL_BDMA_ClearFlag_TC2(BDMA_TypeDef *BDMAx)
1934 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTCIF2);
1938 * @brief Clear Channel 3 transfer complete flag.
1939 * @rmtoll IFCR CTCIF3 LL_BDMA_ClearFlag_TC3
1940 * @param BDMAx BDMA Instance
1941 * @retval None
1943 __STATIC_INLINE void LL_BDMA_ClearFlag_TC3(BDMA_TypeDef *BDMAx)
1945 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTCIF3);
1949 * @brief Clear Channel 4 transfer complete flag.
1950 * @rmtoll IFCR CTCIF4 LL_BDMA_ClearFlag_TC4
1951 * @param BDMAx BDMA Instance
1952 * @retval None
1954 __STATIC_INLINE void LL_BDMA_ClearFlag_TC4(BDMA_TypeDef *BDMAx)
1956 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTCIF4);
1960 * @brief Clear Channel 5 transfer complete flag.
1961 * @rmtoll IFCR CTCIF5 LL_BDMA_ClearFlag_TC5
1962 * @param BDMAx BDMA Instance
1963 * @retval None
1965 __STATIC_INLINE void LL_BDMA_ClearFlag_TC5(BDMA_TypeDef *BDMAx)
1967 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTCIF5);
1971 * @brief Clear Channel 6 transfer complete flag.
1972 * @rmtoll IFCR CTCIF6 LL_BDMA_ClearFlag_TC6
1973 * @param BDMAx BDMA Instance
1974 * @retval None
1976 __STATIC_INLINE void LL_BDMA_ClearFlag_TC6(BDMA_TypeDef *BDMAx)
1978 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTCIF6);
1982 * @brief Clear Channel 7 transfer complete flag.
1983 * @rmtoll IFCR CTCIF7 LL_BDMA_ClearFlag_TC7
1984 * @param BDMAx BDMA Instance
1985 * @retval None
1987 __STATIC_INLINE void LL_BDMA_ClearFlag_TC7(BDMA_TypeDef *BDMAx)
1989 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTCIF7);
1993 * @brief Clear Channel 0 half transfer flag.
1994 * @rmtoll IFCR CHTIF0 LL_BDMA_ClearFlag_HT0
1995 * @param BDMAx BDMA Instance
1996 * @retval None
1998 __STATIC_INLINE void LL_BDMA_ClearFlag_HT0(BDMA_TypeDef *BDMAx)
2000 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CHTIF0);
2004 * @brief Clear Channel 1 half transfer flag.
2005 * @rmtoll IFCR CHTIF1 LL_BDMA_ClearFlag_HT1
2006 * @param BDMAx BDMA Instance
2007 * @retval None
2009 __STATIC_INLINE void LL_BDMA_ClearFlag_HT1(BDMA_TypeDef *BDMAx)
2011 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CHTIF1);
2015 * @brief Clear Channel 2 half transfer flag.
2016 * @rmtoll IFCR CHTIF2 LL_BDMA_ClearFlag_HT2
2017 * @param BDMAx BDMA Instance
2018 * @retval None
2020 __STATIC_INLINE void LL_BDMA_ClearFlag_HT2(BDMA_TypeDef *BDMAx)
2022 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CHTIF2);
2026 * @brief Clear Channel 3 half transfer flag.
2027 * @rmtoll IFCR CHTIF3 LL_BDMA_ClearFlag_HT3
2028 * @param BDMAx BDMA Instance
2029 * @retval None
2031 __STATIC_INLINE void LL_BDMA_ClearFlag_HT3(BDMA_TypeDef *BDMAx)
2033 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CHTIF3);
2037 * @brief Clear Channel 4 half transfer flag.
2038 * @rmtoll IFCR CHTIF4 LL_BDMA_ClearFlag_HT4
2039 * @param BDMAx BDMA Instance
2040 * @retval None
2042 __STATIC_INLINE void LL_BDMA_ClearFlag_HT4(BDMA_TypeDef *BDMAx)
2044 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CHTIF4);
2048 * @brief Clear Channel 5 half transfer flag.
2049 * @rmtoll IFCR CHTIF5 LL_BDMA_ClearFlag_HT5
2050 * @param BDMAx BDMA Instance
2051 * @retval None
2053 __STATIC_INLINE void LL_BDMA_ClearFlag_HT5(BDMA_TypeDef *BDMAx)
2055 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CHTIF5);
2059 * @brief Clear Channel 6 half transfer flag.
2060 * @rmtoll IFCR CHTIF6 LL_BDMA_ClearFlag_HT6
2061 * @param BDMAx BDMA Instance
2062 * @retval None
2064 __STATIC_INLINE void LL_BDMA_ClearFlag_HT6(BDMA_TypeDef *BDMAx)
2066 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CHTIF6);
2070 * @brief Clear Channel 7 half transfer flag.
2071 * @rmtoll IFCR CHTIF7 LL_BDMA_ClearFlag_HT7
2072 * @param BDMAx BDMA Instance
2073 * @retval None
2075 __STATIC_INLINE void LL_BDMA_ClearFlag_HT7(BDMA_TypeDef *BDMAx)
2077 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CHTIF7);
2081 * @brief Clear Channel 0 transfer error flag.
2082 * @rmtoll IFCR CTEIF0 LL_BDMA_ClearFlag_TE0
2083 * @param BDMAx BDMA Instance
2084 * @retval None
2086 __STATIC_INLINE void LL_BDMA_ClearFlag_TE0(BDMA_TypeDef *BDMAx)
2088 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTEIF0);
2092 * @brief Clear Channel 1 transfer error flag.
2093 * @rmtoll IFCR CTEIF1 LL_BDMA_ClearFlag_TE1
2094 * @param BDMAx BDMA Instance
2095 * @retval None
2097 __STATIC_INLINE void LL_BDMA_ClearFlag_TE1(BDMA_TypeDef *BDMAx)
2099 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTEIF1);
2103 * @brief Clear Channel 2 transfer error flag.
2104 * @rmtoll IFCR CTEIF2 LL_BDMA_ClearFlag_TE2
2105 * @param BDMAx BDMA Instance
2106 * @retval None
2108 __STATIC_INLINE void LL_BDMA_ClearFlag_TE2(BDMA_TypeDef *BDMAx)
2110 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTEIF2);
2114 * @brief Clear Channel 3 transfer error flag.
2115 * @rmtoll IFCR CTEIF3 LL_BDMA_ClearFlag_TE3
2116 * @param BDMAx BDMA Instance
2117 * @retval None
2119 __STATIC_INLINE void LL_BDMA_ClearFlag_TE3(BDMA_TypeDef *BDMAx)
2121 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTEIF3);
2125 * @brief Clear Channel 4 transfer error flag.
2126 * @rmtoll IFCR CTEIF4 LL_BDMA_ClearFlag_TE4
2127 * @param BDMAx BDMA Instance
2128 * @retval None
2130 __STATIC_INLINE void LL_BDMA_ClearFlag_TE4(BDMA_TypeDef *BDMAx)
2132 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTEIF4);
2136 * @brief Clear Channel 5 transfer error flag.
2137 * @rmtoll IFCR CTEIF5 LL_BDMA_ClearFlag_TE5
2138 * @param BDMAx BDMA Instance
2139 * @retval None
2141 __STATIC_INLINE void LL_BDMA_ClearFlag_TE5(BDMA_TypeDef *BDMAx)
2143 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTEIF5);
2147 * @brief Clear Channel 6 transfer error flag.
2148 * @rmtoll IFCR CTEIF6 LL_BDMA_ClearFlag_TE6
2149 * @param BDMAx BDMA Instance
2150 * @retval None
2152 __STATIC_INLINE void LL_BDMA_ClearFlag_TE6(BDMA_TypeDef *BDMAx)
2154 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTEIF6);
2158 * @brief Clear Channel 7 transfer error flag.
2159 * @rmtoll IFCR CTEIF7 LL_BDMA_ClearFlag_TE7
2160 * @param BDMAx BDMA Instance
2161 * @retval None
2163 __STATIC_INLINE void LL_BDMA_ClearFlag_TE7(BDMA_TypeDef *BDMAx)
2165 WRITE_REG(BDMAx->IFCR, BDMA_IFCR_CTEIF7);
2169 * @}
2172 /** @defgroup BDMA_LL_EF_IT_Management IT_Management
2173 * @{
2176 * @brief Enable Transfer complete interrupt.
2177 * @rmtoll CCR TCIE LL_BDMA_EnableIT_TC
2178 * @param BDMAx BDMA Instance
2179 * @param Channel This parameter can be one of the following values:
2180 * @arg @ref LL_BDMA_CHANNEL_0
2181 * @arg @ref LL_BDMA_CHANNEL_1
2182 * @arg @ref LL_BDMA_CHANNEL_2
2183 * @arg @ref LL_BDMA_CHANNEL_3
2184 * @arg @ref LL_BDMA_CHANNEL_4
2185 * @arg @ref LL_BDMA_CHANNEL_5
2186 * @arg @ref LL_BDMA_CHANNEL_6
2187 * @arg @ref LL_BDMA_CHANNEL_7
2188 * @retval None
2190 __STATIC_INLINE void LL_BDMA_EnableIT_TC(BDMA_TypeDef *BDMAx, uint32_t Channel)
2192 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
2194 SET_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_TCIE);
2198 * @brief Enable Half transfer interrupt.
2199 * @rmtoll CCR HTIE LL_BDMA_EnableIT_HT
2200 * @param BDMAx BDMA Instance
2201 * @param Channel This parameter can be one of the following values:
2202 * @arg @ref LL_BDMA_CHANNEL_0
2203 * @arg @ref LL_BDMA_CHANNEL_1
2204 * @arg @ref LL_BDMA_CHANNEL_2
2205 * @arg @ref LL_BDMA_CHANNEL_3
2206 * @arg @ref LL_BDMA_CHANNEL_4
2207 * @arg @ref LL_BDMA_CHANNEL_5
2208 * @arg @ref LL_BDMA_CHANNEL_6
2209 * @arg @ref LL_BDMA_CHANNEL_7
2210 * @retval None
2212 __STATIC_INLINE void LL_BDMA_EnableIT_HT(BDMA_TypeDef *BDMAx, uint32_t Channel)
2214 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
2216 SET_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_HTIE);
2220 * @brief Enable Transfer error interrupt.
2221 * @rmtoll CCR TEIE LL_BDMA_EnableIT_TE
2222 * @param BDMAx BDMA Instance
2223 * @param Channel This parameter can be one of the following values:
2224 * @arg @ref LL_BDMA_CHANNEL_0
2225 * @arg @ref LL_BDMA_CHANNEL_1
2226 * @arg @ref LL_BDMA_CHANNEL_2
2227 * @arg @ref LL_BDMA_CHANNEL_3
2228 * @arg @ref LL_BDMA_CHANNEL_4
2229 * @arg @ref LL_BDMA_CHANNEL_5
2230 * @arg @ref LL_BDMA_CHANNEL_6
2231 * @arg @ref LL_BDMA_CHANNEL_7
2232 * @retval None
2234 __STATIC_INLINE void LL_BDMA_EnableIT_TE(BDMA_TypeDef *BDMAx, uint32_t Channel)
2236 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
2238 SET_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_TEIE);
2242 * @brief Disable Transfer complete interrupt.
2243 * @rmtoll CCR TCIE LL_BDMA_DisableIT_TC
2244 * @param BDMAx BDMA Instance
2245 * @param Channel This parameter can be one of the following values:
2246 * @arg @ref LL_BDMA_CHANNEL_0
2247 * @arg @ref LL_BDMA_CHANNEL_1
2248 * @arg @ref LL_BDMA_CHANNEL_2
2249 * @arg @ref LL_BDMA_CHANNEL_3
2250 * @arg @ref LL_BDMA_CHANNEL_4
2251 * @arg @ref LL_BDMA_CHANNEL_5
2252 * @arg @ref LL_BDMA_CHANNEL_6
2253 * @arg @ref LL_BDMA_CHANNEL_7
2254 * @retval None
2256 __STATIC_INLINE void LL_BDMA_DisableIT_TC(BDMA_TypeDef *BDMAx, uint32_t Channel)
2258 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
2260 CLEAR_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_TCIE);
2264 * @brief Disable Half transfer interrupt.
2265 * @rmtoll CCR HTIE LL_BDMA_DisableIT_HT
2266 * @param BDMAx BDMA Instance
2267 * @param Channel This parameter can be one of the following values:
2268 * @arg @ref LL_BDMA_CHANNEL_0
2269 * @arg @ref LL_BDMA_CHANNEL_1
2270 * @arg @ref LL_BDMA_CHANNEL_2
2271 * @arg @ref LL_BDMA_CHANNEL_3
2272 * @arg @ref LL_BDMA_CHANNEL_4
2273 * @arg @ref LL_BDMA_CHANNEL_5
2274 * @arg @ref LL_BDMA_CHANNEL_6
2275 * @arg @ref LL_BDMA_CHANNEL_7
2276 * @retval None
2278 __STATIC_INLINE void LL_BDMA_DisableIT_HT(BDMA_TypeDef *BDMAx, uint32_t Channel)
2280 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
2282 CLEAR_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_HTIE);
2286 * @brief Disable Transfer error interrupt.
2287 * @rmtoll CCR TEIE LL_BDMA_DisableIT_TE
2288 * @param BDMAx BDMA Instance
2289 * @param Channel This parameter can be one of the following values:
2290 * @arg @ref LL_BDMA_CHANNEL_0
2291 * @arg @ref LL_BDMA_CHANNEL_1
2292 * @arg @ref LL_BDMA_CHANNEL_2
2293 * @arg @ref LL_BDMA_CHANNEL_3
2294 * @arg @ref LL_BDMA_CHANNEL_4
2295 * @arg @ref LL_BDMA_CHANNEL_5
2296 * @arg @ref LL_BDMA_CHANNEL_6
2297 * @arg @ref LL_BDMA_CHANNEL_7
2298 * @retval None
2300 __STATIC_INLINE void LL_BDMA_DisableIT_TE(BDMA_TypeDef *BDMAx, uint32_t Channel)
2302 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
2304 CLEAR_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_TEIE);
2308 * @brief Check if Transfer complete Interrupt is enabled.
2309 * @rmtoll CCR TCIE LL_BDMA_IsEnabledIT_TC
2310 * @param BDMAx BDMA Instance
2311 * @param Channel This parameter can be one of the following values:
2312 * @arg @ref LL_BDMA_CHANNEL_0
2313 * @arg @ref LL_BDMA_CHANNEL_1
2314 * @arg @ref LL_BDMA_CHANNEL_2
2315 * @arg @ref LL_BDMA_CHANNEL_3
2316 * @arg @ref LL_BDMA_CHANNEL_4
2317 * @arg @ref LL_BDMA_CHANNEL_5
2318 * @arg @ref LL_BDMA_CHANNEL_6
2319 * @arg @ref LL_BDMA_CHANNEL_7
2320 * @retval State of bit (1 or 0).
2322 __STATIC_INLINE uint32_t LL_BDMA_IsEnabledIT_TC(BDMA_TypeDef *BDMAx, uint32_t Channel)
2324 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
2326 return ((READ_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_TCIE) == (BDMA_CCR_TCIE)) ? 1UL : 0UL);
2330 * @brief Check if Half transfer Interrupt is enabled.
2331 * @rmtoll CCR HTIE LL_BDMA_IsEnabledIT_HT
2332 * @param BDMAx BDMA Instance
2333 * @param Channel This parameter can be one of the following values:
2334 * @arg @ref LL_BDMA_CHANNEL_0
2335 * @arg @ref LL_BDMA_CHANNEL_1
2336 * @arg @ref LL_BDMA_CHANNEL_2
2337 * @arg @ref LL_BDMA_CHANNEL_3
2338 * @arg @ref LL_BDMA_CHANNEL_4
2339 * @arg @ref LL_BDMA_CHANNEL_5
2340 * @arg @ref LL_BDMA_CHANNEL_6
2341 * @arg @ref LL_BDMA_CHANNEL_7
2342 * @retval State of bit (1 or 0).
2344 __STATIC_INLINE uint32_t LL_BDMA_IsEnabledIT_HT(BDMA_TypeDef *BDMAx, uint32_t Channel)
2346 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
2348 return ((READ_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_HTIE) == (BDMA_CCR_HTIE)) ? 1UL : 0UL);
2352 * @brief Check if Transfer error Interrupt is enabled.
2353 * @rmtoll CCR TEIE LL_BDMA_IsEnabledIT_TE
2354 * @param BDMAx BDMA Instance
2355 * @param Channel This parameter can be one of the following values:
2356 * @arg @ref LL_BDMA_CHANNEL_0
2357 * @arg @ref LL_BDMA_CHANNEL_1
2358 * @arg @ref LL_BDMA_CHANNEL_2
2359 * @arg @ref LL_BDMA_CHANNEL_3
2360 * @arg @ref LL_BDMA_CHANNEL_4
2361 * @arg @ref LL_BDMA_CHANNEL_5
2362 * @arg @ref LL_BDMA_CHANNEL_6
2363 * @arg @ref LL_BDMA_CHANNEL_7
2364 * @retval State of bit (1 or 0).
2366 __STATIC_INLINE uint32_t LL_BDMA_IsEnabledIT_TE(BDMA_TypeDef *BDMAx, uint32_t Channel)
2368 register uint32_t bdma_base_addr = (uint32_t)BDMAx;
2370 return ((READ_BIT(((BDMA_Channel_TypeDef *)(bdma_base_addr + LL_BDMA_CH_OFFSET_TAB[Channel]))->CCR, BDMA_CCR_TEIE) == (BDMA_CCR_TEIE)) ? 1UL : 0UL);
2374 * @}
2377 #if defined(USE_FULL_LL_DRIVER)
2378 /** @defgroup BDMA_LL_EF_Init Initialization and de-initialization functions
2379 * @{
2382 uint32_t LL_BDMA_Init(BDMA_TypeDef *BDMAx, uint32_t Channel, LL_BDMA_InitTypeDef *BDMA_InitStruct);
2383 uint32_t LL_BDMA_DeInit(BDMA_TypeDef *BDMAx, uint32_t Channel);
2384 void LL_BDMA_StructInit(LL_BDMA_InitTypeDef *BDMA_InitStruct);
2387 * @}
2389 #endif /* USE_FULL_LL_DRIVER */
2392 * @}
2396 * @}
2399 #endif /* BDMA || BDMA1 || BDMA2 */
2402 * @}
2406 * @}
2409 #ifdef __cplusplus
2411 #endif
2413 #endif /* STM32H7xx_LL_BDMA_H */
2415 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/