1 /**
2 ******************************************************************************
3 * @file stm32h5xx_ll_bus.h
4 * @author MCD Application Team
5 * @brief Header file of BUS LL module.
6
7 @verbatim
8 ##### RCC Limitations #####
9 ==============================================================================
10 [..]
11 A delay between an RCC peripheral clock enable and the effective peripheral
12 enabling should be taken into account in order to manage the peripheral read/write
13 from/to registers.
14 (+) This delay depends on the peripheral mapping.
15 (++) AHB , APB peripherals, 1 dummy read is necessary
16
17 [..]
18 Workarounds:
19 (#) For AHB , APB peripherals, a dummy read to the peripheral register has been
20 inserted in each LL_{BUS}_GRP{x}_EnableClock() function.
21
22 @endverbatim
23 ******************************************************************************
24 * @attention
25 *
26 * Copyright (c) 2022 STMicroelectronics.
27 * All rights reserved.
28 *
29 * This software is licensed under terms that can be found in the LICENSE file
30 * in the root directory of this software component.
31 * If no LICENSE file comes with this software, it is provided AS-IS.
32 *
33 ******************************************************************************
34 */
35
36 /* Define to prevent recursive inclusion -------------------------------------*/
37 #ifndef __STM32H5xx_LL_BUS_H
38 #define __STM32H5xx_LL_BUS_H
39
40 #ifdef __cplusplus
41 extern "C" {
42 #endif
43
44 /* Includes ------------------------------------------------------------------*/
45 #include "stm32h5xx.h"
46
47 /** @addtogroup STM32H5xx_LL_Driver
48 * @{
49 */
50
51 #if defined(RCC)
52
53 /** @defgroup BUS_LL BUS
54 * @{
55 */
56
57 /* Private types -------------------------------------------------------------*/
58 /* Private variables ---------------------------------------------------------*/
59 /* Private constants ---------------------------------------------------------*/
60 /* Private macros ------------------------------------------------------------*/
61
62 /* Exported types ------------------------------------------------------------*/
63 /* Exported constants --------------------------------------------------------*/
64 /** @defgroup BUS_LL_Exported_Constants BUS Exported Constants
65 * @{
66 */
67
68 /** @defgroup BUS_LL_AHB_BRANCH_CLK_AHBx
69 * @{
70 */
71 #define LL_AHB_BRANCH_CLK_AHB1 RCC_CFGR2_AHB1DIS
72 #define LL_AHB_BRANCH_CLK_AHB2 RCC_CFGR2_AHB2DIS
73 #if defined(AHB4PERIPH_BASE)
74 #define LL_AHB_BRANCH_CLK_AHB4 RCC_CFGR2_AHB4DIS
75 #endif /* AHB4PERIPH_BASE */
76 /**
77 * @}
78 */
79
80 /** @defgroup BUS_LL_APB_BRANCH_CLK_APBx
81 * @{
82 */
83 #define LL_APB_BRANCH_CLK_APB1 RCC_CFGR2_APB1DIS
84 #define LL_APB_BRANCH_CLK_APB2 RCC_CFGR2_APB2DIS
85 #define LL_APB_BRANCH_CLK_APB3 RCC_CFGR2_APB3DIS
86 /**
87 * @}
88 */
89
90 /** @defgroup BUS_LL_EC_AHB1_GRP1_PERIPH AHB1 GRP1 PERIPH
91 * @{
92 */
93 #if defined(CORDIC)
94 #define LL_AHB1_GRP1_PERIPH_ALL 0xF13AD103U
95 #else
96 #define LL_AHB1_GRP1_PERIPH_ALL 0x91021103U
97 #endif /* CORDIC */
98 #define LL_AHB1_GRP1_PERIPH_GPDMA1 RCC_AHB1ENR_GPDMA1EN
99 #define LL_AHB1_GRP1_PERIPH_GPDMA2 RCC_AHB1ENR_GPDMA2EN
100 #if defined(CORDIC)
101 #define LL_AHB1_GRP1_PERIPH_CORDIC RCC_AHB1ENR_CORDICEN
102 #endif /* CORDIC */
103 #if defined(FMAC)
104 #define LL_AHB1_GRP1_PERIPH_FMAC RCC_AHB1ENR_FMACEN
105 #endif /* FMAC */
106 #define LL_AHB1_GRP1_PERIPH_FLASH RCC_AHB1ENR_FLITFEN
107 #if defined(ETH)
108 #define LL_AHB1_GRP1_PERIPH_ETH RCC_AHB1ENR_ETHEN
109 #define LL_AHB1_GRP1_PERIPH_ETHTX RCC_AHB1ENR_ETHTXEN
110 #define LL_AHB1_GRP1_PERIPH_ETHRX RCC_AHB1ENR_ETHRXEN
111 #endif /* ETH */
112 #define LL_AHB1_GRP1_PERIPH_CRC RCC_AHB1ENR_CRCEN
113 #define LL_AHB1_GRP1_PERIPH_RAMCFG RCC_AHB1ENR_RAMCFGEN
114 #define LL_AHB1_GRP1_PERIPH_GTZC1 RCC_AHB1ENR_TZSC1EN
115 #define LL_AHB1_GRP1_PERIPH_BKPSRAM RCC_AHB1ENR_BKPRAMEN
116 #define LL_AHB1_GRP1_PERIPH_ICACHE RCC_AHB1LPENR_ICACHELPEN
117 #if defined(DCACHE1)
118 #define LL_AHB1_GRP1_PERIPH_DCACHE1 RCC_AHB1ENR_DCACHE1EN
119 #endif /* DCACHE1 */
120 #define LL_AHB1_GRP1_PERIPH_SRAM1 RCC_AHB1ENR_SRAM1EN
121 /**
122 * @}
123 */
124
125 /** @defgroup BUS_LL_EC_AHB2_GRP1_PERIPH AHB2 GRP1 PERIPH
126 * @{
127 */
128 #if defined(GPIOE)
129 #define LL_AHB2_GRP1_PERIPH_ALL 0xC01F1DFFU
130 #else
131 #define LL_AHB2_GRP1_PERIPH_ALL 0x40060C8FU
132 #endif /* GPIOE */
133 #define LL_AHB2_GRP1_PERIPH_GPIOA RCC_AHB2ENR_GPIOAEN
134 #define LL_AHB2_GRP1_PERIPH_GPIOB RCC_AHB2ENR_GPIOBEN
135 #define LL_AHB2_GRP1_PERIPH_GPIOC RCC_AHB2ENR_GPIOCEN
136 #define LL_AHB2_GRP1_PERIPH_GPIOD RCC_AHB2ENR_GPIODEN
137 #if defined(GPIOE)
138 #define LL_AHB2_GRP1_PERIPH_GPIOE RCC_AHB2ENR_GPIOEEN
139 #endif /* GPIOE */
140 #if defined(GPIOF)
141 #define LL_AHB2_GRP1_PERIPH_GPIOF RCC_AHB2ENR_GPIOFEN
142 #endif /* GPIOF */
143 #if defined(GPIOG)
144 #define LL_AHB2_GRP1_PERIPH_GPIOG RCC_AHB2ENR_GPIOGEN
145 #endif /* GPIOG */
146 #define LL_AHB2_GRP1_PERIPH_GPIOH RCC_AHB2ENR_GPIOHEN
147 #if defined(GPIOI)
148 #define LL_AHB2_GRP1_PERIPH_GPIOI RCC_AHB2ENR_GPIOIEN
149 #endif /* GPIOI */
150 #define LL_AHB2_GRP1_PERIPH_ADC RCC_AHB2ENR_ADCEN
151 #define LL_AHB2_GRP1_PERIPH_DAC1 RCC_AHB2ENR_DAC1EN
152 #if defined(DCMI)
153 #define LL_AHB2_GRP1_PERIPH_DCMI_PSSI RCC_AHB2ENR_DCMI_PSSIEN
154 #endif /* DCMI */
155 #if defined(AES)
156 #define LL_AHB2_GRP1_PERIPH_AES RCC_AHB2ENR_AESEN
157 #endif /* AES */
158 #if defined(HASH)
159 #define LL_AHB2_GRP1_PERIPH_HASH RCC_AHB2ENR_HASHEN
160 #endif /* HASH */
161 #define LL_AHB2_GRP1_PERIPH_RNG RCC_AHB2ENR_RNGEN
162 #if defined(PKA)
163 #define LL_AHB2_GRP1_PERIPH_PKA RCC_AHB2ENR_PKAEN
164 #endif /* PKA */
165 #if defined(SAES)
166 #define LL_AHB2_GRP1_PERIPH_SAES RCC_AHB2ENR_SAESEN
167 #endif /* SAES */
168 #define LL_AHB2_GRP1_PERIPH_SRAM2 RCC_AHB2ENR_SRAM2EN
169 #if defined(SRAM3_BASE)
170 #define LL_AHB2_GRP1_PERIPH_SRAM3 RCC_AHB2ENR_SRAM3EN
171 #endif /* SRAM3_BASE */
172
173 /**
174 * @}
175 */
176 #if defined(AHB4PERIPH_BASE)
177 /** @defgroup BUS_LL_EC_AHB4_GRP1_PERIPH AHB4 GRP1 PERIPH
178 * @{
179 */
180 #define LL_AHB4_GRP1_PERIPH_ALL 0x00111880U
181 #define LL_AHB4_GRP1_PERIPH_OTFDEC RCC_AHB4ENR_OTFDEC1EN
182 #define LL_AHB4_GRP1_PERIPH_SDMMC1 RCC_AHB4ENR_SDMMC1EN
183 #if defined(SDMMC2)
184 #define LL_AHB4_GRP1_PERIPH_SDMMC2 RCC_AHB4ENR_SDMMC2EN
185 #endif /* SDMMC2*/
186 #define LL_AHB4_GRP1_PERIPH_FMC RCC_AHB4ENR_FMCEN
187 #define LL_AHB4_GRP1_PERIPH_OSPI1 RCC_AHB4ENR_OCTOSPI1EN
188 /**
189 * @}
190 */
191 #endif /* AHB4PERIPH_BASE */
192
193 /** @defgroup BUS_LL_EC_APB1_GRP1_PERIPH APB1 GRP1 PERIPH
194 * @{
195 */
196 #if defined(TIM4)
197 #define LL_APB1_GRP1_PERIPH_ALL 0xDFFEC9FFU
198 #else
199 #define LL_APB1_GRP1_PERIPH_ALL 0x01E7E833U
200 #endif /* TIM4 */
201 #define LL_APB1_GRP1_PERIPH_TIM2 RCC_APB1LENR_TIM2EN
202 #define LL_APB1_GRP1_PERIPH_TIM3 RCC_APB1LENR_TIM3EN
203 #if defined(TIM4)
204 #define LL_APB1_GRP1_PERIPH_TIM4 RCC_APB1LENR_TIM4EN
205 #endif /* TIM4*/
206 #if defined(TIM5)
207 #define LL_APB1_GRP1_PERIPH_TIM5 RCC_APB1LENR_TIM5EN
208 #endif /* TIM5*/
209 #define LL_APB1_GRP1_PERIPH_TIM6 RCC_APB1LENR_TIM6EN
210 #define LL_APB1_GRP1_PERIPH_TIM7 RCC_APB1LENR_TIM7EN
211 #if defined(TIM12)
212 #define LL_APB1_GRP1_PERIPH_TIM12 RCC_APB1LENR_TIM12EN
213 #endif /* TIM12*/
214 #if defined(TIM13)
215 #define LL_APB1_GRP1_PERIPH_TIM13 RCC_APB1LENR_TIM13EN
216 #endif /* TIM13*/
217 #if defined(TIM14)
218 #define LL_APB1_GRP1_PERIPH_TIM14 RCC_APB1LENR_TIM14EN
219 #endif /* TIM14*/
220 #define LL_APB1_GRP1_PERIPH_WWDG RCC_APB1LENR_WWDGEN
221 #if defined(OPAMP1)
222 #define LL_APB1_GRP1_PERIPH_OPAMP RCC_APB1LENR_OPAMPEN
223 #endif /* OPAMP1 */
224 #define LL_APB1_GRP1_PERIPH_SPI2 RCC_APB1LENR_SPI2EN
225 #define LL_APB1_GRP1_PERIPH_SPI3 RCC_APB1LENR_SPI3EN
226 #if defined(COMP1)
227 #define LL_APB1_GRP1_PERIPH_COMP RCC_APB1LENR_COMPEN
228 #endif /* COMP1 */
229 #define LL_APB1_GRP1_PERIPH_USART2 RCC_APB1LENR_USART2EN
230 #define LL_APB1_GRP1_PERIPH_USART3 RCC_APB1LENR_USART3EN
231 #if defined(UART4)
232 #define LL_APB1_GRP1_PERIPH_UART4 RCC_APB1LENR_UART4EN
233 #endif /* UART4*/
234 #if defined(UART5)
235 #define LL_APB1_GRP1_PERIPH_UART5 RCC_APB1LENR_UART5EN
236 #endif /* UART5*/
237 #define LL_APB1_GRP1_PERIPH_I2C1 RCC_APB1LENR_I2C1EN
238 #define LL_APB1_GRP1_PERIPH_I2C2 RCC_APB1LENR_I2C2EN
239 #define LL_APB1_GRP1_PERIPH_I3C1 RCC_APB1LENR_I3C1EN
240 #define LL_APB1_GRP1_PERIPH_CRS RCC_APB1LENR_CRSEN
241 #if defined(USART6)
242 #define LL_APB1_GRP1_PERIPH_USART6 RCC_APB1LENR_USART6EN
243 #endif /* USART6*/
244 #if defined(USART10)
245 #define LL_APB1_GRP1_PERIPH_USART10 RCC_APB1LENR_USART10EN
246 #endif /* USART10*/
247 #if defined(USART11)
248 #define LL_APB1_GRP1_PERIPH_USART11 RCC_APB1LENR_USART11EN
249 #endif /* USART11*/
250 #if defined(CEC)
251 #define LL_APB1_GRP1_PERIPH_CEC RCC_APB1LENR_CECEN
252 #endif /* CEC*/
253 #if defined(UART7)
254 #define LL_APB1_GRP1_PERIPH_UART7 RCC_APB1LENR_UART7EN
255 #endif /* UART7 */
256 #if defined(UART8)
257 #define LL_APB1_GRP1_PERIPH_UART8 RCC_APB1LENR_UART8EN
258 #endif /* UART8 */
259 /**
260 * @}
261 */
262
263
264 /** @defgroup BUS_LL_EC_APB1_GRP2_PERIPH APB1 GRP2 PERIPH
265 * @{
266 */
267 #if defined(UART9)
268 #define LL_APB1_GRP2_PERIPH_ALL 0x0080022BU
269 #else
270 #define LL_APB1_GRP2_PERIPH_ALL 0x00000228U
271 #endif /* UART9 */
272 #if defined(UART9)
273 #define LL_APB1_GRP2_PERIPH_UART9 RCC_APB1HENR_UART9EN
274 #endif /* UART9 */
275 #if defined(UART12)
276 #define LL_APB1_GRP2_PERIPH_UART12 RCC_APB1HENR_UART12EN
277 #endif /* UART12*/
278 #define LL_APB1_GRP2_PERIPH_DTS RCC_APB1HENR_DTSEN
279 #define LL_APB1_GRP2_PERIPH_LPTIM2 RCC_APB1HENR_LPTIM2EN
280 #define LL_APB1_GRP2_PERIPH_FDCAN RCC_APB1HENR_FDCANEN
281 #if defined(UCPD1)
282 #define LL_APB1_GRP2_PERIPH_UCPD1 RCC_APB1HENR_UCPD1EN
283 #endif /* UCPD1 */
284 /**
285 * @}
286 */
287
288 /** @defgroup BUS_LL_EC_APB2_GRP1_PERIPH APB2 GRP1 PERIPH
289 * @{
290 */
291 #if defined(TIM8)
292 #define LL_APB2_GRP1_PERIPH_ALL 0x017F7800U
293 #else
294 #define LL_APB2_GRP1_PERIPH_ALL 0x01005800U
295 #endif /* TIM8 */
296 #define LL_APB2_GRP1_PERIPH_TIM1 RCC_APB2ENR_TIM1EN
297 #define LL_APB2_GRP1_PERIPH_SPI1 RCC_APB2ENR_SPI1EN
298 #if defined(TIM8)
299 #define LL_APB2_GRP1_PERIPH_TIM8 RCC_APB2ENR_TIM8EN
300 #endif /* TIM8 */
301 #define LL_APB2_GRP1_PERIPH_USART1 RCC_APB2ENR_USART1EN
302 #if defined(TIM15)
303 #define LL_APB2_GRP1_PERIPH_TIM15 RCC_APB2ENR_TIM15EN
304 #endif /* TIM15 */
305 #if defined(TIM16)
306 #define LL_APB2_GRP1_PERIPH_TIM16 RCC_APB2ENR_TIM16EN
307 #endif /* TIM16 */
308 #if defined(TIM17)
309 #define LL_APB2_GRP1_PERIPH_TIM17 RCC_APB2ENR_TIM17EN
310 #endif /* TIM17 */
311 #if defined(SPI4)
312 #define LL_APB2_GRP1_PERIPH_SPI4 RCC_APB2ENR_SPI4EN
313 #endif /* SPI4 */
314 #if defined(SPI6)
315 #define LL_APB2_GRP1_PERIPH_SPI6 RCC_APB2ENR_SPI6EN
316 #endif /* SPI6 */
317 #if defined(SAI1)
318 #define LL_APB2_GRP1_PERIPH_SAI1 RCC_APB2ENR_SAI1EN
319 #endif /* SAI1 */
320 #if defined(SAI2)
321 #define LL_APB2_GRP1_PERIPH_SAI2 RCC_APB2ENR_SAI2EN
322 #endif /* SAI2 */
323 #define LL_APB2_GRP1_PERIPH_USB RCC_APB2ENR_USBEN
324 /**
325 * @}
326 */
327
328 /** @defgroup BUS_LL_EC_APB3_GRP1_PERIPH APB3 GRP1 PERIPH
329 * @{
330 */
331 #if defined(SPI5)
332 #define LL_APB3_GRP1_PERIPH_ALL 0x0030F9E2U
333 #else
334 #define LL_APB3_GRP1_PERIPH_ALL 0x00300A42U
335 #endif /* SPI5 */
336 #define LL_APB3_GRP1_PERIPH_SBS RCC_APB3ENR_SBSEN
337 #if defined(SPI5)
338 #define LL_APB3_GRP1_PERIPH_SPI5 RCC_APB3ENR_SPI5EN
339 #endif /* SPI5 */
340 #define LL_APB3_GRP1_PERIPH_LPUART1 RCC_APB3ENR_LPUART1EN
341 #if defined(I2C3)
342 #define LL_APB3_GRP1_PERIPH_I2C3 RCC_APB3ENR_I2C3EN
343 #endif /* I2C3 */
344 #if defined(I2C4)
345 #define LL_APB3_GRP1_PERIPH_I2C4 RCC_APB3ENR_I2C4EN
346 #endif /* I2C4 */
347 #if defined(I3C2)
348 #define LL_APB3_GRP1_PERIPH_I3C2 RCC_APB3ENR_I3C2EN
349 #endif /* I3C2 */
350 #define LL_APB3_GRP1_PERIPH_LPTIM1 RCC_APB3ENR_LPTIM1EN
351 #if defined(LPTIM3)
352 #define LL_APB3_GRP1_PERIPH_LPTIM3 RCC_APB3ENR_LPTIM3EN
353 #endif /* LPTIM3 */
354 #if defined(LPTIM4)
355 #define LL_APB3_GRP1_PERIPH_LPTIM4 RCC_APB3ENR_LPTIM4EN
356 #endif /* LPTIM4 */
357 #if defined(LPTIM5)
358 #define LL_APB3_GRP1_PERIPH_LPTIM5 RCC_APB3ENR_LPTIM5EN
359 #endif /* LPTIM5 */
360 #if defined(LPTIM6)
361 #define LL_APB3_GRP1_PERIPH_LPTIM6 RCC_APB3ENR_LPTIM6EN
362 #endif /* LPTIM6 */
363 #define LL_APB3_GRP1_PERIPH_VREF RCC_APB3ENR_VREFEN
364 #define LL_APB3_GRP1_PERIPH_RTCAPB RCC_APB3ENR_RTCAPBEN
365 /**
366 * @}
367 */
368
369 /**
370 * @}
371 */
372
373 /* Exported macro ------------------------------------------------------------*/
374 /* Exported functions --------------------------------------------------------*/
375 /** @defgroup BUS_LL_Exported_Functions BUS Exported Functions
376 * @{
377 */
378
379 /** @defgroup BUS_LL_EF_AHBx AHBx
380 * @{
381 */
382 /**
383 * @brief Disable of AHBx Clock Branch
384 * @rmtoll CFGR2 AHB1DIS LL_AHB_DisableClock\n
385 * CFGR2 AHB2DIS LL_AHB_DisableClock\n
386 * CFGR2 AHB4DIS LL_AHB_DisableClock
387 * @param AHBx This parameter can be a combination of the following values:
388 * @arg @ref LL_AHB_BRANCH_CLK_AHB1
389 * @arg @ref LL_AHB_BRANCH_CLK_AHB2
390 * @arg @ref LL_AHB_BRANCH_CLK_AHB4 (*)
391 *
392 * (*) : Not available for all stm32h5xxxx family lines.
393 * @retval None
394 */
LL_AHB_DisableClock(uint32_t AHBx)395 __STATIC_INLINE void LL_AHB_DisableClock(uint32_t AHBx)
396 {
397 SET_BIT(RCC->CFGR2, AHBx);
398 }
399
400 /**
401 * @brief Enable of AHBx Clock Branch
402 * @rmtoll CFGR2 AHB1DIS LL_AHB_EnableClock\n
403 * CFGR2 AHB2DIS LL_AHB_EnableClock\n
404 * CFGR2 AHB4DIS LL_AHB_EnableClock
405 * @param AHBx This parameter can be a combination of the following values:
406 * @arg @ref LL_AHB_BRANCH_CLK_AHB1
407 * @arg @ref LL_AHB_BRANCH_CLK_AHB2
408 * @arg @ref LL_AHB_BRANCH_CLK_AHB4 (*)
409 *
410 * (*) : Not available for all stm32h5xxxx family lines.
411 * @retval None
412 */
LL_AHB_EnableClock(uint32_t AHBx)413 __STATIC_INLINE void LL_AHB_EnableClock(uint32_t AHBx)
414 {
415 __IO uint32_t tmpreg;
416 CLEAR_BIT(RCC->CFGR2, AHBx);
417 /* Delay after AHBx clock branch enabling */
418 tmpreg = READ_BIT(RCC->CFGR2, AHBx);
419 (void)tmpreg;
420 }
421
422 /**
423 * @brief Check if AHBx clock branch is disabled or not
424 * @rmtoll CFGR2 AHB1DIS LL_AHB_IsDisabledClock\n
425 * CFGR2 AHB2DIS LL_AHB_IsDisabledClock\n
426 * CFGR2 AHB4DIS LL_AHB_IsDisabledClock
427 * @param AHBx This parameter can be a combination of the following values:
428 * @arg @ref LL_AHB_BRANCH_CLK_AHB1
429 * @arg @ref LL_AHB_BRANCH_CLK_AHB2
430 * @arg @ref LL_AHB_BRANCH_CLK_AHB4 (*)
431 *
432 * (*) : Not available for all stm32h5xxxx family lines.
433 * @retval State of AHBx bus (1 or 0).
434 */
LL_AHB_IsDisabledClock(uint32_t AHBx)435 __STATIC_INLINE uint32_t LL_AHB_IsDisabledClock(uint32_t AHBx)
436 {
437 return ((READ_BIT(RCC->CFGR2, AHBx) == AHBx) ? 1UL : 0UL);
438 }
439
440 /**
441 * @}
442 */
443
444 /** @defgroup BUS_LL_EF_APBx APBx
445 * @{
446 */
447 /**
448 * @brief Disable APBx Clock Branch
449 * @rmtoll CFGR2 APB1DIS LL_APB_DisableClock\n
450 * CFGR2 APB2DIS LL_APB_DisableClock\n
451 * CFGR2 APB3DIS LL_APB_DisableClock
452 * @param APBx This parameter can be a combination of the following values:
453 * @arg @ref LL_APB_BRANCH_CLOCK_APB1
454 * @arg @ref LL_APB_BRANCH_CLOCK_APB2
455 * @arg @ref LL_APB_BRANCH_CLOCK_APB3
456 * @retval None
457 */
LL_APB_DisableClock(uint32_t APBx)458 __STATIC_INLINE void LL_APB_DisableClock(uint32_t APBx)
459 {
460 SET_BIT(RCC->CFGR2, APBx);
461 }
462
463 /**
464 * @brief Enable of APBx Clock Branch
465 * @rmtoll CFGR2 APB1DIS LL_APB_EnableClock\n
466 * CFGR2 APB2DIS LL_APB_EnableClock\n
467 * CFGR2 APB3DIS LL_APB_EnableClock
468 * @param APBx This parameter can be a combination of the following values:
469 * @arg @ref LL_APB_BRANCH_CLOCK_APB1
470 * @arg @ref LL_APB_BRANCH_CLOCK_APB2
471 * @arg @ref LL_APB_BRANCH_CLOCK_APB3
472 * @retval None
473 */
LL_APB_EnableClock(uint32_t APBx)474 __STATIC_INLINE void LL_APB_EnableClock(uint32_t APBx)
475 {
476 __IO uint32_t tmpreg;
477 CLEAR_BIT(RCC->CFGR2, APBx);
478 /* Delay after APBx clock branch enabling */
479 tmpreg = READ_BIT(RCC->CFGR2, APBx);
480 (void)tmpreg;
481 }
482
483 /**
484 * @brief Check if APBx clock branch is disabled or not
485 * @rmtoll CFGR2 APB1DIS LL_APB_IsDisabledClock\n
486 * CFGR2 APB2DIS LL_APB_IsDisabledClock\n
487 * CFGR2 APB3DIS LL_APB_IsDisabledClock
488 * @param APBx This parameter can be a combination of the following values:
489 * @arg @ref LL_APB_BRANCH_CLK_APB1
490 * @arg @ref LL_APB_BRANCH_CLK_APB2
491 * @arg @ref LL_APB_BRANCH_CLK_APB3
492 * @retval State of APBx bus (1 or 0).
493 */
LL_APB_IsDisabledClock(uint32_t APBx)494 __STATIC_INLINE uint32_t LL_APB_IsDisabledClock(uint32_t APBx)
495 {
496 return ((READ_BIT(RCC->CFGR2, APBx) == APBx) ? 1UL : 0UL);
497 }
498
499 /**
500 * @}
501 */
502
503 /** @defgroup BUS_LL_EF_AHB1 AHB1
504 * @{
505 */
506 /**
507 * @brief Enable AHB1 peripherals clock.
508 * @rmtoll AHB1ENR GPDMA1EN LL_AHB1_GRP1_EnableClock\n
509 * AHB1ENR GPDMA2EN LL_AHB1_GRP1_EnableClock\n
510 * AHB1ENR FLITFEN LL_AHB1_GRP1_EnableClock\n
511 * AHB1ENR CRCEN LL_AHB1_GRP1_EnableClock\n
512 * AHB1ENR CORDICEN LL_AHB1_GRP1_EnableClock\n
513 * AHB1ENR FMACEN LL_AHB1_GRP1_EnableClock\n
514 * AHB1ENR RAMCFGEN LL_AHB1_GRP1_EnableClock\n
515 * AHB1ENR ETHEN LL_AHB1_GRP1_EnableClock\n
516 * AHB1ENR ETHTXEN LL_AHB1_GRP1_EnableClock\n
517 * AHB1ENR ETHRXEN LL_AHB1_GRP1_EnableClock\n
518 * AHB1ENR TZSC1EN LL_AHB1_GRP1_EnableClock\n
519 * AHB1ENR BKPRAMEN LL_AHB1_GRP1_EnableClock\n
520 * AHB1ENR DCACHE1EN LL_AHB1_GRP1_EnableClock\n
521 * AHB1ENR SRAM1EN LL_AHB1_GRP1_EnableClock
522 * @param Periphs This parameter can be a combination of the following values:
523 * @arg @ref LL_AHB1_GRP1_PERIPH_ALL
524 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA1
525 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA2
526 * @arg @ref LL_AHB1_GRP1_PERIPH_FLASH
527 * @arg @ref LL_AHB1_GRP1_PERIPH_CRC
528 * @arg @ref LL_AHB1_GRP1_PERIPH_CORDIC (*)
529 * @arg @ref LL_AHB1_GRP1_PERIPH_FMAC
530 * @arg @ref LL_AHB1_GRP1_PERIPH_RAMCFG
531 * @arg @ref LL_AHB1_GRP1_PERIPH_ETH (*)
532 * @arg @ref LL_AHB1_GRP1_PERIPH_ETHTX (*)
533 * @arg @ref LL_AHB1_GRP1_PERIPH_ETHRX (*)
534 * @arg @ref LL_AHB1_GRP1_PERIPH_GTZC1
535 * @arg @ref LL_AHB1_GRP1_PERIPH_BKPSRAM
536 * @arg @ref LL_AHB1_GRP1_PERIPH_DCACHE (*)
537 * @arg @ref LL_AHB1_GRP1_PERIPH_SRAM1
538 *
539 * (*) : Not available for all stm32h5xxxx family lines.
540 * @retval None
541 */
LL_AHB1_GRP1_EnableClock(uint32_t Periphs)542 __STATIC_INLINE void LL_AHB1_GRP1_EnableClock(uint32_t Periphs)
543 {
544 __IO uint32_t tmpreg;
545 SET_BIT(RCC->AHB1ENR, Periphs);
546 /* Delay after an RCC peripheral clock enabling */
547 tmpreg = READ_BIT(RCC->AHB1ENR, Periphs);
548 (void)tmpreg;
549 }
550
551 /**
552 * @brief Check if AHB1 peripheral clock is enabled or not
553 * @rmtoll AHB1ENR GPDMA1EN LL_AHB1_GRP1_IsEnabledClock\n
554 * AHB1ENR GPDMA2EN LL_AHB1_GRP1_IsEnabledClock\n
555 * AHB1ENR FLITFEN LL_AHB1_GRP1_IsEnabledClock\n
556 * AHB1ENR CRCEN LL_AHB1_GRP1_IsEnabledClock\n
557 * AHB1ENR CORDICEN LL_AHB1_GRP1_IsEnabledClock\n
558 * AHB1ENR FMACEN LL_AHB1_GRP1_IsEnabledClock\n
559 * AHB1ENR RAMCFGEN LL_AHB1_GRP1_IsEnabledClock\n
560 * AHB1ENR ETHEN LL_AHB1_GRP1_IsEnabledClock\n
561 * AHB1ENR ETHTXEN LL_AHB1_GRP1_IsEnabledClock\n
562 * AHB1ENR ETHRXEN LL_AHB1_GRP1_IsEnabledClock\n
563 * AHB1ENR TZSC1EN LL_AHB1_GRP1_IsEnabledClock\n
564 * AHB1ENR BKPRAMEN LL_AHB1_GRP1_IsEnabledClock\n
565 * AHB1ENR DCACHE1EN LL_AHB1_GRP1_IsEnabledClock\n
566 * AHB1ENR SRAM1EN LL_AHB1_GRP1_IsEnabledClock
567 * @param Periphs This parameter can be a combination of the following values:
568 * @arg @ref LL_AHB1_GRP1_PERIPH_ALL
569 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA1
570 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA2
571 * @arg @ref LL_AHB1_GRP1_PERIPH_FLASH
572 * @arg @ref LL_AHB1_GRP1_PERIPH_CRC
573 * @arg @ref LL_AHB1_GRP1_PERIPH_CORDIC (*)
574 * @arg @ref LL_AHB1_GRP1_PERIPH_FMAC (*)
575 * @arg @ref LL_AHB1_GRP1_PERIPH_RAMCFG
576 * @arg @ref LL_AHB1_GRP1_PERIPH_ETH (*)
577 * @arg @ref LL_AHB1_GRP1_PERIPH_ETHTX (*)
578 * @arg @ref LL_AHB1_GRP1_PERIPH_ETHRX (*)
579 * @arg @ref LL_AHB1_GRP1_PERIPH_GTZC1
580 * @arg @ref LL_AHB1_GRP1_PERIPH_BKPSRAM
581 * @arg @ref LL_AHB1_GRP1_PERIPH_DCACHE (*)
582 * @arg @ref LL_AHB1_GRP1_PERIPH_SRAM1
583 *
584 * (*) : Not available for all stm32h5xxxx family lines.
585 * @retval State of Periphs (1 or 0).
586 */
LL_AHB1_GRP1_IsEnabledClock(uint32_t Periphs)587 __STATIC_INLINE uint32_t LL_AHB1_GRP1_IsEnabledClock(uint32_t Periphs)
588 {
589 return ((READ_BIT(RCC->AHB1ENR, Periphs) == Periphs) ? 1UL : 0UL);
590 }
591
592 /**
593 * @brief Disable AHB1 peripherals clock.
594 * @rmtoll AHB1ENR GPDMA1EN LL_AHB1_GRP1_DisableClock\n
595 * AHB1ENR GPDMA2EN LL_AHB1_GRP1_DisableClock\n
596 * AHB1ENR FLITFEN LL_AHB1_GRP1_DisableClock\n
597 * AHB1ENR CRCEN LL_AHB1_GRP1_DisableClock\n
598 * AHB1ENR CORDICEN LL_AHB1_GRP1_DisableClock\n
599 * AHB1ENR FMACEN LL_AHB1_GRP1_DisableClock\n
600 * AHB1ENR RAMCFGEN LL_AHB1_GRP1_DisableClock\n
601 * AHB1ENR ETHEN LL_AHB1_GRP1_DisableClock\n
602 * AHB1ENR ETHTXEN LL_AHB1_GRP1_DisableClock\n
603 * AHB1ENR ETHRXEN LL_AHB1_GRP1_DisableClock\n
604 * AHB1ENR TZSC1EN LL_AHB1_GRP1_DisableClock\n
605 * AHB1ENR BKPRAMEN LL_AHB1_GRP1_DisableClock\n
606 * AHB1ENR DCACHE1EN LL_AHB1_GRP1_DisableClock\n
607 * AHB1ENR SRAM1EN LL_AHB1_GRP1_DisableClock
608 * @param Periphs This parameter can be a combination of the following values:
609 * @arg @ref LL_AHB1_GRP1_PERIPH_ALL
610 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA1
611 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA2
612 * @arg @ref LL_AHB1_GRP1_PERIPH_FLASH
613 * @arg @ref LL_AHB1_GRP1_PERIPH_CRC
614 * @arg @ref LL_AHB1_GRP1_PERIPH_CORDIC (*)
615 * @arg @ref LL_AHB1_GRP1_PERIPH_FMAC (*)
616 * @arg @ref LL_AHB1_GRP1_PERIPH_RAMCFG
617 * @arg @ref LL_AHB1_GRP1_PERIPH_ETH (*)
618 * @arg @ref LL_AHB1_GRP1_PERIPH_ETHTX (*)
619 * @arg @ref LL_AHB1_GRP1_PERIPH_ETHRX (*)
620 * @arg @ref LL_AHB1_GRP1_PERIPH_GTZC1
621 * @arg @ref LL_AHB1_GRP1_PERIPH_BKPSRAM
622 * @arg @ref LL_AHB1_GRP1_PERIPH_DCACHE (*)
623 * @arg @ref LL_AHB1_GRP1_PERIPH_SRAM1
624 *
625 * (*) : Not available for all stm32h5xxxx family lines.
626 * @retval None
627 */
LL_AHB1_GRP1_DisableClock(uint32_t Periphs)628 __STATIC_INLINE void LL_AHB1_GRP1_DisableClock(uint32_t Periphs)
629 {
630 CLEAR_BIT(RCC->AHB1ENR, Periphs);
631 }
632
633 /**
634 * @brief Force AHB1 peripherals reset.
635 * @rmtoll AHB1RSTR GPDMA1RST LL_AHB1_GRP1_ForceReset\n
636 * AHB1RSTR GPDMA2RST LL_AHB1_GRP1_ForceReset\n
637 * AHB1RSTR CRCRST LL_AHB1_GRP1_ForceReset\n
638 * AHB1RSTR CORDICRST LL_AHB1_GRP1_ForceReset\n
639 * AHB1RSTR FMACRST LL_AHB1_GRP1_ForceReset\n
640 * AHB1RSTR RAMCFGRST LL_AHB1_GRP1_ForceReset\n
641 * AHB1RSTR ETHRST LL_AHB1_GRP1_ForceReset\n
642 * AHB1RSTR TZSC1RST LL_AHB1_GRP1_ForceReset
643 * @param Periphs This parameter can be a combination of the following values:
644 * @arg @ref LL_AHB1_GRP1_PERIPH_ALL
645 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA1
646 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA2
647 * @arg @ref LL_AHB1_GRP1_PERIPH_CRC
648 * @arg @ref LL_AHB1_GRP1_PERIPH_CORDIC (*)
649 * @arg @ref LL_AHB1_GRP1_PERIPH_FMAC (*)
650 * @arg @ref LL_AHB1_GRP1_PERIPH_RAMCFG
651 * @arg @ref LL_AHB1_GRP1_PERIPH_ETH (*)
652 * @arg @ref LL_AHB1_GRP1_PERIPH_GTZC1
653 *
654 * (*) : Not available for all stm32h5xxxx family lines.
655 * @retval None
656 */
LL_AHB1_GRP1_ForceReset(uint32_t Periphs)657 __STATIC_INLINE void LL_AHB1_GRP1_ForceReset(uint32_t Periphs)
658 {
659 SET_BIT(RCC->AHB1RSTR, Periphs);
660 }
661
662 /**
663 * @brief Release AHB1 peripherals reset.
664 * @rmtoll AHB1RSTR GPDMA1RST LL_AHB1_GRP1_ReleaseReset\n
665 * AHB1RSTR GPDMA2RST LL_AHB1_GRP1_ReleaseReset\n
666 * AHB1RSTR CRCRST LL_AHB1_GRP1_ReleaseReset\n
667 * AHB1RSTR CORDICRST LL_AHB1_GRP1_ReleaseReset\n
668 * AHB1RSTR FMACRST LL_AHB1_GRP1_ReleaseReset\n
669 * AHB1RSTR RAMCFGRST LL_AHB1_GRP1_ReleaseReset\n
670 * AHB1RSTR ETHRST LL_AHB1_GRP1_ReleaseReset\n
671 * AHB1RSTR TZSC1RST LL_AHB1_GRP1_ReleaseReset
672 * @param Periphs This parameter can be a combination of the following values:
673 * @arg @ref LL_AHB1_GRP1_PERIPH_ALL
674 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA1
675 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA2
676 * @arg @ref LL_AHB1_GRP1_PERIPH_CRC
677 * @arg @ref LL_AHB1_GRP1_PERIPH_CORDIC (*)
678 * @arg @ref LL_AHB1_GRP1_PERIPH_FMAC (*)
679 * @arg @ref LL_AHB1_GRP1_PERIPH_RAMCFG
680 * @arg @ref LL_AHB1_GRP1_PERIPH_ETH (*)
681 * @arg @ref LL_AHB1_GRP1_PERIPH_GTZC1
682 *
683 * (*) : Not available for all stm32h5xxxx family lines.
684 * @retval None
685 */
LL_AHB1_GRP1_ReleaseReset(uint32_t Periphs)686 __STATIC_INLINE void LL_AHB1_GRP1_ReleaseReset(uint32_t Periphs)
687 {
688 CLEAR_BIT(RCC->AHB1RSTR, Periphs);
689 }
690
691 /**
692 * @brief Enable AHB1 peripheral clocks in Sleep mode
693 * @rmtoll AHB1LPENR GPDMA1LPEN LL_AHB1_GRP1_EnableClockSleep\n
694 * AHB1LPENR GPDMA2LPEN LL_AHB1_GRP1_EnableClockSleep\n
695 * AHB1LPENR FLITFLPEN LL_AHB1_GRP1_EnableClockSleep\n
696 * AHB1LPENR CRCLPEN LL_AHB1_GRP1_EnableClockSleep\n
697 * AHB1LPENR CORDICLPEN LL_AHB1_GRP1_EnableClockSleep\n
698 * AHB1LPENR FMACLPEN LL_AHB1_GRP1_EnableClockSleep\n
699 * AHB1LPENR RAMCFGLPEN LL_AHB1_GRP1_EnableClockSleep\n
700 * AHB1LPENR ETHLPEN LL_AHB1_GRP1_EnableClockSleep\n
701 * AHB1LPENR ETHTXLPEN LL_AHB1_GRP1_EnableClockSleep\n
702 * AHB1LPENR ETHRXLPEN LL_AHB1_GRP1_EnableClockSleep\n
703 * AHB1LPENR TZSC1LPEN LL_AHB1_GRP1_EnableClockSleep\n
704 * AHB1LPENR BKPRAMLPEN LL_AHB1_GRP1_EnableClockSleep\n
705 * AHB1LPENR DCACHE1LPEN LL_AHB1_GRP1_EnableClockSleep\n
706 * AHB1LPENR SRAM1LPEN LL_AHB1_GRP1_EnableClockSleep
707 * @param Periphs This parameter can be a combination of the following values:
708 * @arg @ref LL_AHB1_GRP1_PERIPH_ALL
709 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA1
710 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA2
711 * @arg @ref LL_AHB1_GRP1_PERIPH_FLASH
712 * @arg @ref LL_AHB1_GRP1_PERIPH_CRC
713 * @arg @ref LL_AHB1_GRP1_PERIPH_CORDIC (*)
714 * @arg @ref LL_AHB1_GRP1_PERIPH_FMAC (*)
715 * @arg @ref LL_AHB1_GRP1_PERIPH_RAMCFG
716 * @arg @ref LL_AHB1_GRP1_PERIPH_ETH (*)
717 * @arg @ref LL_AHB1_GRP1_PERIPH_ETHTX (*)
718 * @arg @ref LL_AHB1_GRP1_PERIPH_ETHRX (*)
719 * @arg @ref LL_AHB1_GRP1_PERIPH_GTZC1
720 * @arg @ref LL_AHB1_GRP1_PERIPH_BKPSRAM
721 * @arg @ref LL_AHB1_GRP1_PERIPH_DCACHE (*)
722 * @arg @ref LL_AHB1_GRP1_PERIPH_SRAM1
723 *
724 * (*) : Not available for all stm32h5xxxx family lines.
725 * @retval None
726 */
LL_AHB1_GRP1_EnableClockSleep(uint32_t Periphs)727 __STATIC_INLINE void LL_AHB1_GRP1_EnableClockSleep(uint32_t Periphs)
728 {
729 __IO uint32_t tmpreg;
730 SET_BIT(RCC->AHB1LPENR, Periphs);
731 /* Delay after an RCC peripheral clock enabling */
732 tmpreg = READ_BIT(RCC->AHB1LPENR, Periphs);
733 (void)tmpreg;
734 }
735
736 /**
737 * @brief Check if AHB1 peripheral clocks in Sleep mode is enabled or not
738 * @rmtoll AHB1LPENR GPDMA1LPEN LL_AHB1_GRP1_IsEnabledClockSleep\n
739 * AHB1LPENR GPDMA2LPEN LL_AHB1_GRP1_IsEnabledClockSleep\n
740 * AHB1LPENR FLITFLPEN LL_AHB1_GRP1_IsEnabledClockSleep\n
741 * AHB1LPENR CRCLPEN LL_AHB1_GRP1_IsEnabledClockSleep\n
742 * AHB1LPENR CORDICLPEN LL_AHB1_GRP1_IsEnabledClockSleep\n
743 * AHB1LPENR FMACLPEN LL_AHB1_GRP1_IsEnabledClockSleep\n
744 * AHB1LPENR RAMCFGLPEN LL_AHB1_GRP1_IsEnabledClockSleep\n
745 * AHB1LPENR ETHLPEN LL_AHB1_GRP1_IsEnabledClockSleep\n
746 * AHB1LPENR ETHTXLPEN LL_AHB1_GRP1_IsEnabledClockSleep\n
747 * AHB1LPENR ETHRXLPEN LL_AHB1_GRP1_IsEnabledClockSleep\n
748 * AHB1LPENR TZSC1LPEN LL_AHB1_GRP1_IsEnabledClockSleep\n
749 * AHB1LPENR BKPRAMLPEN LL_AHB1_GRP1_IsEnabledClockSleep\n
750 * AHB1LPENR DCACHE1LPEN LL_AHB1_GRP1_IsEnabledClockSleep\n
751 * AHB1LPENR SRAM1LPEN LL_AHB1_GRP1_IsEnabledClockSleep
752 * @param Periphs This parameter can be a combination of the following values:
753 * @arg @ref LL_AHB1_GRP1_PERIPH_ALL
754 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA1
755 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA2
756 * @arg @ref LL_AHB1_GRP1_PERIPH_FLASH
757 * @arg @ref LL_AHB1_GRP1_PERIPH_CRC
758 * @arg @ref LL_AHB1_GRP1_PERIPH_CORDIC (*)
759 * @arg @ref LL_AHB1_GRP1_PERIPH_FMAC (*)
760 * @arg @ref LL_AHB1_GRP1_PERIPH_RAMCFG
761 * @arg @ref LL_AHB1_GRP1_PERIPH_ETH (*)
762 * @arg @ref LL_AHB1_GRP1_PERIPH_ETHTX (*)
763 * @arg @ref LL_AHB1_GRP1_PERIPH_ETHRX (*)
764 * @arg @ref LL_AHB1_GRP1_PERIPH_GTZC1
765 * @arg @ref LL_AHB1_GRP1_PERIPH_BKPSRAM
766 * @arg @ref LL_AHB1_GRP1_PERIPH_DCACHE (*)
767 * @arg @ref LL_AHB1_GRP1_PERIPH_SRAM1
768 *
769 * (*) : Not available for all stm32h5xxxx family lines.
770 * @retval State of Periphs (1 or 0).
771 */
LL_AHB1_GRP1_IsEnabledClockSleep(uint32_t Periphs)772 __STATIC_INLINE uint32_t LL_AHB1_GRP1_IsEnabledClockSleep(uint32_t Periphs)
773 {
774 return ((READ_BIT(RCC->AHB1LPENR, Periphs) == Periphs) ? 1UL : 0UL);
775 }
776
777 /**
778 * @brief Disable AHB1 peripheral clocks in Sleep mode
779 * @rmtoll AHB1LPENR GPDMA1LPEN LL_AHB1_GRP1_DisableClockSleep\n
780 * AHB1LPENR GPDMA2LPEN LL_AHB1_GRP1_DisableClockSleep\n
781 * AHB1LPENR FLITFLPEN LL_AHB1_GRP1_DisableClockSleep\n
782 * AHB1LPENR CRCLPEN LL_AHB1_GRP1_DisableClockSleep\n
783 * AHB1LPENR CORDICLPEN LL_AHB1_GRP1_DisableClockSleep\n
784 * AHB1LPENR FMACLPEN LL_AHB1_GRP1_DisableClockSleep\n
785 * AHB1LPENR RAMCFGLPEN LL_AHB1_GRP1_DisableClockSleep\n
786 * AHB1LPENR ETHLPEN LL_AHB1_GRP1_DisableClockSleep\n
787 * AHB1LPENR ETHTXLPEN LL_AHB1_GRP1_DisableClockSleep\n
788 * AHB1LPENR ETHRXLPEN LL_AHB1_GRP1_DisableClockSleep\n
789 * AHB1LPENR TZSC1LPEN LL_AHB1_GRP1_DisableClockSleep\n
790 * AHB1LPENR BKPRAMLPEN LL_AHB1_GRP1_DisableClockSleep\n
791 * AHB1LPENR DCACHE1LPEN LL_AHB1_GRP1_DisableClockSleep\n
792 * AHB1LPENR SRAM1LPEN LL_AHB1_GRP1_DisableClockSleep
793 * @param Periphs This parameter can be a combination of the following values:
794 * @arg @ref LL_AHB1_GRP1_PERIPH_ALL
795 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA1
796 * @arg @ref LL_AHB1_GRP1_PERIPH_GPDMA2
797 * @arg @ref LL_AHB1_GRP1_PERIPH_FLASH
798 * @arg @ref LL_AHB1_GRP1_PERIPH_CRC
799 * @arg @ref LL_AHB1_GRP1_PERIPH_CORDIC (*)
800 * @arg @ref LL_AHB1_GRP1_PERIPH_FMAC (*)
801 * @arg @ref LL_AHB1_GRP1_PERIPH_RAMCFG
802 * @arg @ref LL_AHB1_GRP1_PERIPH_ETH (*)
803 * @arg @ref LL_AHB1_GRP1_PERIPH_ETHTX (*)
804 * @arg @ref LL_AHB1_GRP1_PERIPH_ETHRX (*)
805 * @arg @ref LL_AHB1_GRP1_PERIPH_GTZC1
806 * @arg @ref LL_AHB1_GRP1_PERIPH_BKPSRAM
807 * @arg @ref LL_AHB1_GRP1_PERIPH_DCACHE (*)
808 * @arg @ref LL_AHB1_GRP1_PERIPH_SRAM1
809 *
810 * (*) : Not available for all stm32h5xxxx family lines.
811 * @retval None
812 */
LL_AHB1_GRP1_DisableClockSleep(uint32_t Periphs)813 __STATIC_INLINE void LL_AHB1_GRP1_DisableClockSleep(uint32_t Periphs)
814 {
815 CLEAR_BIT(RCC->AHB1LPENR, Periphs);
816 }
817
818 /**
819 * @}
820 */
821
822 /** @defgroup BUS_LL_EF_AHB2 AHB2
823 * @{
824 */
825 /**
826 * @brief Enable AHB2 peripherals clock.
827 * @rmtoll AHB2ENR GPIOAEN LL_AHB2_GRP1_EnableClock\n
828 * AHB2ENR GPIOBEN LL_AHB2_GRP1_EnableClock\n
829 * AHB2ENR GPIOCEN LL_AHB2_GRP1_EnableClock\n
830 * AHB2ENR GPIODEN LL_AHB2_GRP1_EnableClock\n
831 * AHB2ENR GPIOEEN LL_AHB2_GRP1_EnableClock\n
832 * AHB2ENR GPIOFEN LL_AHB2_GRP1_EnableClock\n
833 * AHB2ENR GPIOGEN LL_AHB2_GRP1_EnableClock\n
834 * AHB2ENR GPIOHEN LL_AHB2_GRP1_EnableClock\n
835 * AHB2ENR GPIOIEN LL_AHB2_GRP1_EnableClock\n
836 * AHB2ENR ADCEN LL_AHB2_GRP1_EnableClock\n
837 * AHB2ENR DAC1EN LL_AHB2_GRP1_EnableClock\n
838 * AHB2ENR DCMI_PSSIEN LL_AHB2_GRP1_EnableClock\n
839 * AHB2ENR AESEN LL_AHB2_GRP1_EnableClock\n
840 * AHB2ENR HASHEN LL_AHB2_GRP1_EnableClock\n
841 * AHB2ENR RNGEN LL_AHB2_GRP1_EnableClock\n
842 * AHB2ENR PKAEN LL_AHB2_GRP1_EnableClock\n
843 * AHB2ENR SAESEN LL_AHB2_GRP1_EnableClock\n
844 * AHB2ENR SRAM2EN LL_AHB2_GRP1_EnableClock\n
845 * AHB2ENR SRAM3EN LL_AHB2_GRP1_EnableClock
846 * @param Periphs This parameter can be a combination of the following values:
847 * @arg @ref LL_AHB2_GRP1_PERIPH_ALL
848 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOA
849 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOB
850 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOC
851 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOD
852 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOE (*)
853 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOF (*)
854 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOG (*)
855 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOH
856 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOI (*)
857 * @arg @ref LL_AHB2_GRP1_PERIPH_ADC
858 * @arg @ref LL_AHB2_GRP1_PERIPH_DAC1
859 * @arg @ref LL_AHB2_GRP1_PERIPH_DCMI_PSSI (*)
860 * @arg @ref LL_AHB2_GRP1_PERIPH_AES (*)
861 * @arg @ref LL_AHB2_GRP1_PERIPH_HASH (*)
862 * @arg @ref LL_AHB2_GRP1_PERIPH_RNG
863 * @arg @ref LL_AHB2_GRP1_PERIPH_PKA (*)
864 * @arg @ref LL_AHB2_GRP1_PERIPH_SAES (*)
865 * @arg @ref LL_AHB2_GRP1_PERIPH_SRAM2 (*)
866 * @arg @ref LL_AHB2_GRP1_PERIPH_SRAM3 (*)
867 *
868 * (*) : Not available for all stm32h5xxxx family lines.
869 * @retval None
870 */
LL_AHB2_GRP1_EnableClock(uint32_t Periphs)871 __STATIC_INLINE void LL_AHB2_GRP1_EnableClock(uint32_t Periphs)
872 {
873 __IO uint32_t tmpreg;
874 SET_BIT(RCC->AHB2ENR, Periphs);
875 /* Delay after an RCC peripheral clock enabling */
876 tmpreg = READ_BIT(RCC->AHB2ENR, Periphs);
877 (void)tmpreg;
878 }
879
880 /**
881 * @brief Check if AHB2 peripheral clock is enabled or not
882 * @rmtoll AHB2ENR GPIOAEN LL_AHB2_GRP1_IsEnabledClock\n
883 * AHB2ENR GPIOBEN LL_AHB2_GRP1_IsEnabledClock\n
884 * AHB2ENR GPIOCEN LL_AHB2_GRP1_IsEnabledClock\n
885 * AHB2ENR GPIODEN LL_AHB2_GRP1_IsEnabledClock\n
886 * AHB2ENR GPIOEEN LL_AHB2_GRP1_IsEnabledClock\n
887 * AHB2ENR GPIOFEN LL_AHB2_GRP1_IsEnabledClock\n
888 * AHB2ENR GPIOGEN LL_AHB2_GRP1_IsEnabledClock\n
889 * AHB2ENR GPIOHEN LL_AHB2_GRP1_IsEnabledClock\n
890 * AHB2ENR GPIOIEN LL_AHB2_GRP1_IsEnabledClock\n
891 * AHB2ENR ADCEN LL_AHB2_GRP1_IsEnabledClock\n
892 * AHB2ENR DAC1EN LL_AHB2_GRP1_IsEnabledClock\n
893 * AHB2ENR DCMI_PSSIEN LL_AHB2_GRP1_IsEnabledClock\n
894 * AHB2ENR AESEN LL_AHB2_GRP1_IsEnabledClock\n
895 * AHB2ENR HASHEN LL_AHB2_GRP1_IsEnabledClock\n
896 * AHB2ENR RNGEN LL_AHB2_GRP1_IsEnabledClock\n
897 * AHB2ENR PKAEN LL_AHB2_GRP1_IsEnabledClock\n
898 * AHB2ENR SAESEN LL_AHB2_GRP1_IsEnabledClock\n
899 * AHB2ENR SRAM2EN LL_AHB2_GRP1_IsEnabledClock\n
900 * AHB2ENR SRAM3EN LL_AHB2_GRP1_IsEnabledClock
901 * @param Periphs This parameter can be a combination of the following values:
902 * @arg @ref LL_AHB2_GRP1_PERIPH_ALL
903 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOA
904 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOB
905 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOC
906 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOD
907 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOE (*)
908 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOF (*)
909 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOG (*)
910 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOH
911 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOI (*)
912 * @arg @ref LL_AHB2_GRP1_PERIPH_ADC
913 * @arg @ref LL_AHB2_GRP1_PERIPH_DAC1
914 * @arg @ref LL_AHB2_GRP1_PERIPH_DCMI_PSSI (*)
915 * @arg @ref LL_AHB2_GRP1_PERIPH_AES (*)
916 * @arg @ref LL_AHB2_GRP1_PERIPH_HASH (*)
917 * @arg @ref LL_AHB2_GRP1_PERIPH_RNG
918 * @arg @ref LL_AHB2_GRP1_PERIPH_PKA (*)
919 * @arg @ref LL_AHB2_GRP1_PERIPH_SAES (*)
920 * @arg @ref LL_AHB2_GRP1_PERIPH_SRAM2 (*)
921 * @arg @ref LL_AHB2_GRP1_PERIPH_SRAM3 (*)
922 *
923 * (*) : Not available for all stm32h5xxxx family lines.
924 * @retval State of Periphs (1 or 0).
925 */
LL_AHB2_GRP1_IsEnabledClock(uint32_t Periphs)926 __STATIC_INLINE uint32_t LL_AHB2_GRP1_IsEnabledClock(uint32_t Periphs)
927 {
928 return ((READ_BIT(RCC->AHB2ENR, Periphs) == Periphs) ? 1UL : 0UL);
929 }
930
931 /**
932 * @brief Disable AHB2 peripherals clock.
933 * @rmtoll AHB2ENR GPIOAEN LL_AHB2_GRP1_DisableClock\n
934 * AHB2ENR GPIOBEN LL_AHB2_GRP1_DisableClock\n
935 * AHB2ENR GPIOCEN LL_AHB2_GRP1_DisableClock\n
936 * AHB2ENR GPIODEN LL_AHB2_GRP1_DisableClock\n
937 * AHB2ENR GPIOEEN LL_AHB2_GRP1_DisableClock\n
938 * AHB2ENR GPIOFEN LL_AHB2_GRP1_DisableClock\n
939 * AHB2ENR GPIOGEN LL_AHB2_GRP1_DisableClock\n
940 * AHB2ENR GPIOHEN LL_AHB2_GRP1_DisableClock\n
941 * AHB2ENR GPIOIEN LL_AHB2_GRP1_DisableClock\n
942 * AHB2ENR ADCEN LL_AHB2_GRP1_DisableClock\n
943 * AHB2ENR DAC1EN LL_AHB2_GRP1_DisableClock\n
944 * AHB2ENR DCMI_PSSIEN LL_AHB2_GRP1_DisableClock\n
945 * AHB2ENR AESEN LL_AHB2_GRP1_DisableClock\n
946 * AHB2ENR HASHEN LL_AHB2_GRP1_DisableClock\n
947 * AHB2ENR RNGEN LL_AHB2_GRP1_DisableClock\n
948 * AHB2ENR PKAEN LL_AHB2_GRP1_DisableClock\n
949 * AHB2ENR SAESEN LL_AHB2_GRP1_DisableClock\n
950 * AHB2ENR SRAM2EN LL_AHB2_GRP1_DisableClock\n
951 * AHB2ENR SRAM3EN LL_AHB2_GRP1_DisableClock
952 * @param Periphs This parameter can be a combination of the following values:
953 * @arg @ref LL_AHB2_GRP1_PERIPH_ALL
954 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOA
955 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOB
956 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOC
957 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOD
958 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOE (*)
959 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOF (*)
960 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOG (*)
961 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOH
962 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOI (*)
963 * @arg @ref LL_AHB2_GRP1_PERIPH_ADC
964 * @arg @ref LL_AHB2_GRP1_PERIPH_DAC1
965 * @arg @ref LL_AHB2_GRP1_PERIPH_DCMI_PSSI (*)
966 * @arg @ref LL_AHB2_GRP1_PERIPH_AES (*)
967 * @arg @ref LL_AHB2_GRP1_PERIPH_HASH (*)
968 * @arg @ref LL_AHB2_GRP1_PERIPH_RNG
969 * @arg @ref LL_AHB2_GRP1_PERIPH_PKA (*)
970 * @arg @ref LL_AHB2_GRP1_PERIPH_SAES (*)
971 * @arg @ref LL_AHB2_GRP1_PERIPH_SRAM2 (*)
972 * @arg @ref LL_AHB2_GRP1_PERIPH_SRAM3 (*)
973 *
974 * (*) : Not available for all stm32h5xxxx family lines.
975 * @retval None
976 */
LL_AHB2_GRP1_DisableClock(uint32_t Periphs)977 __STATIC_INLINE void LL_AHB2_GRP1_DisableClock(uint32_t Periphs)
978 {
979 CLEAR_BIT(RCC->AHB2ENR, Periphs);
980 }
981
982 /**
983 * @brief Force AHB2 peripherals reset.
984 * @rmtoll AHB2RST GPIOARST LL_AHB2_GRP1_ForceReset\n
985 * AHB2RST GPIOBRST LL_AHB2_GRP1_ForceReset\n
986 * AHB2RST GPIOCRST LL_AHB2_GRP1_ForceReset\n
987 * AHB2RST GPIODRST LL_AHB2_GRP1_ForceReset\n
988 * AHB2RST GPIOERST LL_AHB2_GRP1_ForceReset\n
989 * AHB2RST GPIOFRST LL_AHB2_GRP1_ForceReset\n
990 * AHB2RST GPIOGRST LL_AHB2_GRP1_ForceReset\n
991 * AHB2RST GPIOHRST LL_AHB2_GRP1_ForceReset\n
992 * AHB2RST GPIOIRST LL_AHB2_GRP1_ForceReset\n
993 * AHB2RST ADCRST LL_AHB2_GRP1_ForceReset\n
994 * AHB2RST DAC1RST LL_AHB2_GRP1_ForceReset\n
995 * AHB2RST DCMI_PSSIRST LL_AHB2_GRP1_ForceReset\n
996 * AHB2RST AESRST LL_AHB2_GRP1_ForceReset\n
997 * AHB2RST HASHRST LL_AHB2_GRP1_ForceReset\n
998 * AHB2RST RNGRST LL_AHB2_GRP1_ForceReset\n
999 * AHB2RST PKARST LL_AHB2_GRP1_ForceReset\n
1000 * AHB2RST SAESRST LL_AHB2_GRP1_ForceReset
1001 * @param Periphs This parameter can be a combination of the following values:
1002 * @arg @ref LL_AHB2_GRP1_PERIPH_ALL
1003 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOA
1004 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOB
1005 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOC
1006 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOD
1007 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOE (*)
1008 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOF (*)
1009 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOG (*)
1010 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOH
1011 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOI (*)
1012 * @arg @ref LL_AHB2_GRP1_PERIPH_ADC
1013 * @arg @ref LL_AHB2_GRP1_PERIPH_DAC1
1014 * @arg @ref LL_AHB2_GRP1_PERIPH_DCMI_PSSI (*)
1015 * @arg @ref LL_AHB2_GRP1_PERIPH_AES (*)
1016 * @arg @ref LL_AHB2_GRP1_PERIPH_HASH (*)
1017 * @arg @ref LL_AHB2_GRP1_PERIPH_RNG
1018 * @arg @ref LL_AHB2_GRP1_PERIPH_PKA (*)
1019 * @arg @ref LL_AHB2_GRP1_PERIPH_SAES (*)
1020 *
1021 * (*) : Not available for all stm32h5xxxx family lines.
1022 * @retval None
1023 */
LL_AHB2_GRP1_ForceReset(uint32_t Periphs)1024 __STATIC_INLINE void LL_AHB2_GRP1_ForceReset(uint32_t Periphs)
1025 {
1026 SET_BIT(RCC->AHB2RSTR, Periphs);
1027 }
1028
1029 /**
1030 * @brief Release AHB2 peripherals reset.
1031 * @rmtoll AHB2RST GPIOARST LL_AHB2_GRP1_ReleaseReset\n
1032 * AHB2RST GPIOBRST LL_AHB2_GRP1_ReleaseReset\n
1033 * AHB2RST GPIOCRST LL_AHB2_GRP1_ReleaseReset\n
1034 * AHB2RST GPIODRST LL_AHB2_GRP1_ReleaseReset\n
1035 * AHB2RST GPIOERST LL_AHB2_GRP1_ReleaseReset\n
1036 * AHB2RST GPIOFRST LL_AHB2_GRP1_ReleaseReset\n
1037 * AHB2RST GPIOGRST LL_AHB2_GRP1_ReleaseReset\n
1038 * AHB2RST GPIOHRST LL_AHB2_GRP1_ReleaseReset\n
1039 * AHB2RST GPIOIRST LL_AHB2_GRP1_ReleaseReset\n
1040 * AHB2RST ADCRST LL_AHB2_GRP1_ReleaseReset\n
1041 * AHB2RST DAC1RST LL_AHB2_GRP1_ReleaseReset\n
1042 * AHB2RST DCMI_PSSIRST LL_AHB2_GRP1_ReleaseReset\n
1043 * AHB2RST AESRST LL_AHB2_GRP1_ReleaseReset\n
1044 * AHB2RST HASHRST LL_AHB2_GRP1_ReleaseReset\n
1045 * AHB2RST RNGRST LL_AHB2_GRP1_ReleaseReset\n
1046 * AHB2RST PKARST LL_AHB2_GRP1_ReleaseReset\n
1047 * AHB2RST SAESRST LL_AHB2_GRP1_ReleaseReset
1048 * @param Periphs This parameter can be a combination of the following values:
1049 * @arg @ref LL_AHB2_GRP1_PERIPH_ALL
1050 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOA
1051 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOB
1052 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOC
1053 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOD
1054 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOE (*)
1055 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOF (*)
1056 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOG (*)
1057 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOH
1058 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOI (*)
1059 * @arg @ref LL_AHB2_GRP1_PERIPH_ADC
1060 * @arg @ref LL_AHB2_GRP1_PERIPH_DAC1
1061 * @arg @ref LL_AHB2_GRP1_PERIPH_DCMI_PSSI (*)
1062 * @arg @ref LL_AHB2_GRP1_PERIPH_AES (*)
1063 * @arg @ref LL_AHB2_GRP1_PERIPH_HASH (*)
1064 * @arg @ref LL_AHB2_GRP1_PERIPH_RNG
1065 * @arg @ref LL_AHB2_GRP1_PERIPH_PKA (*)
1066 * @arg @ref LL_AHB2_GRP1_PERIPH_SAES (*)
1067 *
1068 * (*) : Not available for all stm32h5xxxx family lines.
1069 * @retval None
1070 */
LL_AHB2_GRP1_ReleaseReset(uint32_t Periphs)1071 __STATIC_INLINE void LL_AHB2_GRP1_ReleaseReset(uint32_t Periphs)
1072 {
1073 CLEAR_BIT(RCC->AHB2RSTR, Periphs);
1074 }
1075
1076 /**
1077 * @brief Enable AHB2 peripheral clocks in Sleep mode
1078 * @rmtoll AHB2LPENR GPIOALPEN LL_AHB2_GRP1_EnableClockSleep\n
1079 * AHB2LPENR GPIOBLPEN LL_AHB2_GRP1_EnableClockSleep\n
1080 * AHB2LPENR GPIOCLPEN LL_AHB2_GRP1_EnableClockSleep\n
1081 * AHB2LPENR GPIODLPEN LL_AHB2_GRP1_EnableClockSleep\n
1082 * AHB2LPENR GPIOELPEN LL_AHB2_GRP1_EnableClockSleep\n
1083 * AHB2LPENR GPIOFLPEN LL_AHB2_GRP1_EnableClockSleep\n
1084 * AHB2LPENR GPIOGLPEN LL_AHB2_GRP1_EnableClockSleep\n
1085 * AHB2LPENR GPIOHLPEN LL_AHB2_GRP1_EnableClockSleep\n
1086 * AHB2LPENR GPIOILPEN LL_AHB2_GRP1_EnableClockSleep\n
1087 * AHB2LPENR ADCLPEN LL_AHB2_GRP1_EnableClockSleep\n
1088 * AHB2LPENR DAC1LPEN LL_AHB2_GRP1_EnableClockSleep\n
1089 * AHB2LPENR DCMI_PSSILPEN LL_AHB2_GRP1_EnableClockSleep\n
1090 * AHB2LPENR AESLPEN LL_AHB2_GRP1_EnableClockSleep\n
1091 * AHB2LPENR HASHLPEN LL_AHB2_GRP1_EnableClockSleep\n
1092 * AHB2LPENR RNGLPEN LL_AHB2_GRP1_EnableClockSleep\n
1093 * AHB2LPENR PKALPEN LL_AHB2_GRP1_EnableClockSleep\n
1094 * AHB2LPENR SAESLPEN LL_AHB2_GRP1_EnableClockSleep\n
1095 * AHB2LPENR SRAM2LPEN LL_AHB2_GRP1_EnableClockSleep\n
1096 * AHB2LPENR SRAM3LPEN LL_AHB2_GRP1_EnableClockSleep
1097 * @param Periphs This parameter can be a combination of the following values:
1098 * @arg @ref LL_AHB2_GRP1_PERIPH_ALL
1099 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOA
1100 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOB
1101 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOC
1102 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOD
1103 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOE (*)
1104 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOF (*)
1105 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOG (*)
1106 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOH
1107 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOI (*)
1108 * @arg @ref LL_AHB2_GRP1_PERIPH_ADC
1109 * @arg @ref LL_AHB2_GRP1_PERIPH_DAC1
1110 * @arg @ref LL_AHB2_GRP1_PERIPH_DCMI_PSSI (*)
1111 * @arg @ref LL_AHB2_GRP1_PERIPH_AES (*)
1112 * @arg @ref LL_AHB2_GRP1_PERIPH_HASH (*)
1113 * @arg @ref LL_AHB2_GRP1_PERIPH_RNG
1114 * @arg @ref LL_AHB2_GRP1_PERIPH_PKA (*)
1115 * @arg @ref LL_AHB2_GRP1_PERIPH_SAES (*)
1116 * @arg @ref LL_AHB2_GRP1_PERIPH_SRAM2 (*)
1117 * @arg @ref LL_AHB2_GRP1_PERIPH_SRAM3 (*)
1118 *
1119 * (*) : Not available for all stm32h5xxxx family lines.
1120 * @retval None
1121 */
LL_AHB2_GRP1_EnableClockSleep(uint32_t Periphs)1122 __STATIC_INLINE void LL_AHB2_GRP1_EnableClockSleep(uint32_t Periphs)
1123 {
1124 __IO uint32_t tmpreg;
1125 SET_BIT(RCC->AHB2LPENR, Periphs);
1126 /* Delay after an RCC peripheral clock enabling */
1127 tmpreg = READ_BIT(RCC->AHB2LPENR, Periphs);
1128 (void)tmpreg;
1129 }
1130
1131 /**
1132 * @brief Check if AHB2 peripheral clocks in Sleep mode is enabled or not
1133 * @rmtoll AHB2LPENR GPIOALPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1134 * AHB2LPENR GPIOBLPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1135 * AHB2LPENR GPIOCLPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1136 * AHB2LPENR GPIODLPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1137 * AHB2LPENR GPIOELPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1138 * AHB2LPENR GPIOFLPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1139 * AHB2LPENR GPIOGLPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1140 * AHB2LPENR GPIOHLPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1141 * AHB2LPENR GPIOILPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1142 * AHB2LPENR ADCLPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1143 * AHB2LPENR DAC1LPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1144 * AHB2LPENR DCMI_PSSILPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1145 * AHB2LPENR AESLPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1146 * AHB2LPENR HASHLPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1147 * AHB2LPENR RNGLPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1148 * AHB2LPENR PKALPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1149 * AHB2LPENR SAESLPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1150 * AHB2LPENR SRAM2LPEN LL_AHB2_GRP1_IsEnabledClockSleep\n
1151 * AHB2LPENR SRAM3LPEN LL_AHB2_GRP1_IsEnabledClockSleep
1152 * @param Periphs This parameter can be a combination of the following values:
1153 * @arg @ref LL_AHB2_GRP1_PERIPH_ALL
1154 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOA
1155 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOB
1156 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOC
1157 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOD
1158 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOE (*)
1159 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOF (*)
1160 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOG (*)
1161 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOH
1162 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOI (*)
1163 * @arg @ref LL_AHB2_GRP1_PERIPH_ADC
1164 * @arg @ref LL_AHB2_GRP1_PERIPH_DAC1
1165 * @arg @ref LL_AHB2_GRP1_PERIPH_DCMI_PSSI (*)
1166 * @arg @ref LL_AHB2_GRP1_PERIPH_AES (*)
1167 * @arg @ref LL_AHB2_GRP1_PERIPH_HASH (*)
1168 * @arg @ref LL_AHB2_GRP1_PERIPH_RNG
1169 * @arg @ref LL_AHB2_GRP1_PERIPH_PKA (*)
1170 * @arg @ref LL_AHB2_GRP1_PERIPH_SAES (*)
1171 * @arg @ref LL_AHB2_GRP1_PERIPH_SRAM2 (*)
1172 * @arg @ref LL_AHB2_GRP1_PERIPH_SRAM3 (*)
1173 *
1174 * (*) : Not available for all stm32h5xxxx family lines.
1175 * @retval State of Periphs (1 or 0).
1176 */
LL_AHB2_GRP1_IsEnabledClockSleep(uint32_t Periphs)1177 __STATIC_INLINE uint32_t LL_AHB2_GRP1_IsEnabledClockSleep(uint32_t Periphs)
1178 {
1179 return ((READ_BIT(RCC->AHB2LPENR, Periphs) == Periphs) ? 1UL : 0UL);
1180 }
1181
1182 /**
1183 * @brief Disable AHB2 peripheral clocks in Sleep mode
1184 * @rmtoll AHB2LPENR GPIOALPEN LL_AHB2_GRP1_DisableClockSleep\n
1185 * AHB2LPENR GPIOBLPEN LL_AHB2_GRP1_DisableClockSleep\n
1186 * AHB2LPENR GPIOCLPEN LL_AHB2_GRP1_DisableClockSleep\n
1187 * AHB2LPENR GPIODLPEN LL_AHB2_GRP1_DisableClockSleep\n
1188 * AHB2LPENR GPIOELPEN LL_AHB2_GRP1_DisableClockSleep\n
1189 * AHB2LPENR GPIOFLPEN LL_AHB2_GRP1_DisableClockSleep\n
1190 * AHB2LPENR GPIOGLPEN LL_AHB2_GRP1_DisableClockSleep\n
1191 * AHB2LPENR GPIOHLPEN LL_AHB2_GRP1_DisableClockSleep\n
1192 * AHB2LPENR GPIOILPEN LL_AHB2_GRP1_DisableClockSleep\n
1193 * AHB2LPENR ADCLPEN LL_AHB2_GRP1_DisableClockSleep\n
1194 * AHB2LPENR DAC1LPEN LL_AHB2_GRP1_DisableClockSleep\n
1195 * AHB2LPENR DCMI_PSSILPEN LL_AHB2_GRP1_DisableClockSleep\n
1196 * AHB2LPENR AESLPEN LL_AHB2_GRP1_DisableClockSleep\n
1197 * AHB2LPENR HASHLPEN LL_AHB2_GRP1_DisableClockSleep\n
1198 * AHB2LPENR RNGLPEN LL_AHB2_GRP1_DisableClockSleep\n
1199 * AHB2LPENR PKALPEN LL_AHB2_GRP1_DisableClockSleep\n
1200 * AHB2LPENR SAESLPEN LL_AHB2_GRP1_DisableClockSleep\n
1201 * AHB2LPENR SRAM2LPEN LL_AHB2_GRP1_DisableClockSleep\n
1202 * AHB2LPENR SRAM3LPEN LL_AHB2_GRP1_DisableClockSleep
1203 * @param Periphs This parameter can be a combination of the following values:
1204 * @arg @ref LL_AHB2_GRP1_PERIPH_ALL
1205 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOA
1206 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOB
1207 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOC
1208 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOD
1209 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOE (*)
1210 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOF (*)
1211 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOG (*)
1212 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOH
1213 * @arg @ref LL_AHB2_GRP1_PERIPH_GPIOI (*)
1214 * @arg @ref LL_AHB2_GRP1_PERIPH_ADC
1215 * @arg @ref LL_AHB2_GRP1_PERIPH_DAC1
1216 * @arg @ref LL_AHB2_GRP1_PERIPH_DCMI_PSSI (*)
1217 * @arg @ref LL_AHB2_GRP1_PERIPH_AES (*)
1218 * @arg @ref LL_AHB2_GRP1_PERIPH_HASH (*)
1219 * @arg @ref LL_AHB2_GRP1_PERIPH_RNG
1220 * @arg @ref LL_AHB2_GRP1_PERIPH_PKA (*)
1221 * @arg @ref LL_AHB2_GRP1_PERIPH_SAES (*)
1222 * @arg @ref LL_AHB2_GRP1_PERIPH_SRAM2 (*)
1223 * @arg @ref LL_AHB2_GRP1_PERIPH_SRAM3 (*)
1224 *
1225 * (*) : Not available for all stm32h5xxxx family lines.
1226 * @retval None
1227 */
LL_AHB2_GRP1_DisableClockSleep(uint32_t Periphs)1228 __STATIC_INLINE void LL_AHB2_GRP1_DisableClockSleep(uint32_t Periphs)
1229 {
1230 CLEAR_BIT(RCC->AHB2LPENR, Periphs);
1231 }
1232
1233 /**
1234 * @}
1235 */
1236
1237 #if defined(AHB4PERIPH_BASE)
1238 /** @defgroup BUS_LL_EF_AHB4 AHB4
1239 * @{
1240 */
1241 /**
1242 * @brief Enable AHB4 peripherals clock.
1243 * @rmtoll AHB4ENR OTFDEC1EN LL_AHB4_GRP1_EnableClock\n
1244 * AHB4ENR SDMMC1EN LL_AHB4_GRP1_EnableClock\n
1245 * AHB4ENR SDMMC2EN LL_AHB4_GRP1_EnableClock\n
1246 * AHB4ENR FMCEN LL_AHB4_GRP1_EnableClock\n
1247 * AHB4ENR OCTOSPI1EN LL_AHB4_GRP1_EnableClock
1248 * @param Periphs This parameter can be a combination of the following values:
1249 * @arg @ref LL_AHB4_GRP1_PERIPH_ALL
1250 * @arg @ref LL_AHB4_GRP1_PERIPH_OTFDEC
1251 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC1
1252 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC2 (*)
1253 * @arg @ref LL_AHB4_GRP1_PERIPH_FMC
1254 * @arg @ref LL_AHB4_GRP1_PERIPH_OSPI1
1255 *
1256 * (*) : Not available for all stm32h5xxxx family lines.
1257 * @retval None
1258 */
LL_AHB4_GRP1_EnableClock(uint32_t Periphs)1259 __STATIC_INLINE void LL_AHB4_GRP1_EnableClock(uint32_t Periphs)
1260 {
1261 __IO uint32_t tmpreg;
1262 SET_BIT(RCC->AHB4ENR, Periphs);
1263 /* Delay after an RCC peripheral clock enabling */
1264 tmpreg = READ_BIT(RCC->AHB4ENR, Periphs);
1265 (void)tmpreg;
1266 }
1267
1268 /**
1269 * @brief Check if AHB4 peripheral clock is enabled or not
1270 * @rmtoll AHB4ENR OTFDEC1EN LL_AHB4_GRP1_IsEnabledClock\n
1271 * AHB4ENR SDMMC1EN LL_AHB4_GRP1_IsEnabledClock\n
1272 * AHB4ENR SDMMC2EN LL_AHB4_GRP1_IsEnabledClock\n
1273 * AHB4ENR FMCEN LL_AHB4_GRP1_IsEnabledClock\n
1274 * AHB4ENR OCTOSPI1EN LL_AHB4_GRP1_IsEnabledClock
1275 * @param Periphs This parameter can be a combination of the following values:
1276 * @arg @ref LL_AHB4_GRP1_PERIPH_ALL
1277 * @arg @ref LL_AHB4_GRP1_PERIPH_OTFDEC
1278 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC1
1279 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC2
1280 * @arg @ref LL_AHB4_GRP1_PERIPH_FMC
1281 * @arg @ref LL_AHB4_GRP1_PERIPH_OSPI1
1282 * @retval State of Periphs (1 or 0).
1283 */
LL_AHB4_GRP1_IsEnabledClock(uint32_t Periphs)1284 __STATIC_INLINE uint32_t LL_AHB4_GRP1_IsEnabledClock(uint32_t Periphs)
1285 {
1286 return ((READ_BIT(RCC->AHB4ENR, Periphs) == Periphs) ? 1UL : 0UL);
1287 }
1288
1289 /**
1290 * @brief Disable AHB4 peripherals clock.
1291 * @rmtoll AHB4ENR OTFDEC1EN LL_AHB4_GRP1_DisableClock\n
1292 * AHB4ENR SDMMC1EN LL_AHB4_GRP1_DisableClock\n
1293 * AHB4ENR SDMMC2EN LL_AHB4_GRP1_DisableClock\n
1294 * AHB4ENR FMCEN LL_AHB4_GRP1_DisableClock\n
1295 * AHB4ENR OCTOSPI1EN LL_AHB4_GRP1_DisableClock
1296 * @param Periphs This parameter can be a combination of the following values:
1297 * @arg @ref LL_AHB4_GRP1_PERIPH_ALL
1298 * @arg @ref LL_AHB4_GRP1_PERIPH_OTFDEC
1299 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC1
1300 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC2
1301 * @arg @ref LL_AHB4_GRP1_PERIPH_FMC
1302 * @arg @ref LL_AHB4_GRP1_PERIPH_OSPI1
1303 * @retval None
1304 */
LL_AHB4_GRP1_DisableClock(uint32_t Periphs)1305 __STATIC_INLINE void LL_AHB4_GRP1_DisableClock(uint32_t Periphs)
1306 {
1307 CLEAR_BIT(RCC->AHB4ENR, Periphs);
1308 }
1309
1310 /**
1311 * @brief Force AHB4 peripherals reset.
1312 * @rmtoll AHB4RSTR OTFDEC1RST LL_AHB4_GRP1_ForceReset\n
1313 * AHB4RSTR SDMMC1RST LL_AHB4_GRP1_ForceReset\n
1314 * AHB4RSTR SDMMC2RST LL_AHB4_GRP1_ForceReset\n
1315 * AHB4RSTR FMCRST LL_AHB4_GRP1_ForceReset\n
1316 * AHB4RSTR OCTOSPI1RST LL_AHB4_GRP1_ForceReset
1317 * @param Periphs This parameter can be a combination of the following values:
1318 * @arg @ref LL_AHB4_GRP1_PERIPH_ALL
1319 * @arg @ref LL_AHB4_GRP1_PERIPH_OTFDEC
1320 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC1
1321 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC2
1322 * @arg @ref LL_AHB4_GRP1_PERIPH_FMC
1323 * @arg @ref LL_AHB4_GRP1_PERIPH_OSPI1
1324 * @retval None
1325 */
LL_AHB4_GRP1_ForceReset(uint32_t Periphs)1326 __STATIC_INLINE void LL_AHB4_GRP1_ForceReset(uint32_t Periphs)
1327 {
1328 SET_BIT(RCC->AHB4RSTR, Periphs);
1329 }
1330
1331 /**
1332 * @brief Release AHB4 peripherals reset.
1333 * @rmtoll AHB4RSTR OTFDEC1RST LL_AHB4_GRP1_ReleaseReset\n
1334 * AHB4RSTR SDMMC1RST LL_AHB4_GRP1_ReleaseReset\n
1335 * AHB4RSTR SDMMC2RST LL_AHB4_GRP1_ReleaseReset\n
1336 * AHB4RSTR FMCRST LL_AHB4_GRP1_ReleaseReset\n
1337 * AHB4RSTR OCTOSPI1RST LL_AHB4_GRP1_ReleaseReset
1338 * @param Periphs This parameter can be a combination of the following values:
1339 * @arg @ref LL_AHB4_GRP1_PERIPH_ALL
1340 * @arg @ref LL_AHB4_GRP1_PERIPH_OTFDEC
1341 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC1
1342 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC2
1343 * @arg @ref LL_AHB4_GRP1_PERIPH_FMC
1344 * @arg @ref LL_AHB4_GRP1_PERIPH_OSPI1
1345 * @retval None
1346 */
LL_AHB4_GRP1_ReleaseReset(uint32_t Periphs)1347 __STATIC_INLINE void LL_AHB4_GRP1_ReleaseReset(uint32_t Periphs)
1348 {
1349 CLEAR_BIT(RCC->AHB4RSTR, Periphs);
1350 }
1351
1352 /**
1353 * @brief Enable AHB4 peripheral clocks in Sleep mode
1354 * @rmtoll AHB4LPENR OTFDEC1LPEN LL_AHB4_GRP1_EnableClockSleep\n
1355 * AHB4LPENR SDMMC1LPEN LL_AHB4_GRP1_EnableClockSleep\n
1356 * AHB4LPENR SDMMC2LPEN LL_AHB4_GRP1_EnableClockSleep\n
1357 * AHB4LPENR FMCLPEN LL_AHB4_GRP1_EnableClockSleep\n
1358 * AHB4LPENR OCTOSPI1LPEN LL_AHB4_GRP1_EnableClockSleep
1359 * @param Periphs This parameter can be a combination of the following values:
1360 * @arg @ref LL_AHB4_GRP1_PERIPH_ALL
1361 * @arg @ref LL_AHB4_GRP1_PERIPH_OTFDEC
1362 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC1
1363 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC2
1364 * @arg @ref LL_AHB4_GRP1_PERIPH_FMC
1365 * @arg @ref LL_AHB4_GRP1_PERIPH_OSPI1
1366 * @retval None
1367 */
LL_AHB4_GRP1_EnableClockSleep(uint32_t Periphs)1368 __STATIC_INLINE void LL_AHB4_GRP1_EnableClockSleep(uint32_t Periphs)
1369 {
1370 __IO uint32_t tmpreg;
1371 SET_BIT(RCC->AHB4LPENR, Periphs);
1372 /* Delay after an RCC peripheral clock enabling */
1373 tmpreg = READ_BIT(RCC->AHB4LPENR, Periphs);
1374 (void)tmpreg;
1375 }
1376
1377 /**
1378 * @brief Check if AHB4 peripheral clocks in Sleep mode is enabled or not
1379 * @rmtoll AHB4LPENR OTFDEC1LPEN LL_AHB4_GRP1_IsEnabledClockSleep\n
1380 * AHB4LPENR SDMMC1LPEN LL_AHB4_GRP1_IsEnabledClockSleep\n
1381 * AHB4LPENR SDMMC2LPEN LL_AHB4_GRP1_IsEnabledClockSleep\n
1382 * AHB4LPENR FMCLPEN LL_AHB4_GRP1_IsEnabledClockSleep\n
1383 * AHB4LPENR OCTOSPI1LPEN LL_AHB4_GRP1_IsEnabledClockSleep
1384 * @param Periphs This parameter can be a combination of the following values:
1385 * @arg @ref LL_AHB4_GRP1_PERIPH_ALL
1386 * @arg @ref LL_AHB4_GRP1_PERIPH_OTFDEC
1387 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC1
1388 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC2
1389 * @arg @ref LL_AHB4_GRP1_PERIPH_FMC
1390 * @arg @ref LL_AHB4_GRP1_PERIPH_OSPI1
1391 * @retval State of Periphs (1 or 0).
1392 */
LL_AHB4_GRP1_IsEnabledClockSleep(uint32_t Periphs)1393 __STATIC_INLINE uint32_t LL_AHB4_GRP1_IsEnabledClockSleep(uint32_t Periphs)
1394 {
1395 return ((READ_BIT(RCC->AHB4LPENR, Periphs) == Periphs) ? 1UL : 0UL);
1396 }
1397
1398 /**
1399 * @brief Disable AHB4 peripheral clocks in Sleep and Stop modes
1400 * @rmtoll AHB4LPENR OTFDEC1LPEN LL_AHB4_GRP1_DisableClockSleep\n
1401 * AHB4LPENR SDMMC1LPEN LL_AHB4_GRP1_DisableClockSleep\n
1402 * AHB4LPENR SDMMC2LPEN LL_AHB4_GRP1_DisableClockSleep\n
1403 * AHB4LPENR FMCLPEN LL_AHB4_GRP1_DisableClockSleep\n
1404 * AHB4LPENR OCTOSPI1LPEN LL_AHB4_GRP1_DisableClockSleep
1405 * @param Periphs This parameter can be a combination of the following values:
1406 * @arg @ref LL_AHB4_GRP1_PERIPH_ALL
1407 * @arg @ref LL_AHB4_GRP1_PERIPH_OTFDEC
1408 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC1
1409 * @arg @ref LL_AHB4_GRP1_PERIPH_SDMMC2
1410 * @arg @ref LL_AHB4_GRP1_PERIPH_FMC
1411 * @arg @ref LL_AHB4_GRP1_PERIPH_OSPI1
1412 * @retval None
1413 */
LL_AHB4_GRP1_DisableClockSleep(uint32_t Periphs)1414 __STATIC_INLINE void LL_AHB4_GRP1_DisableClockSleep(uint32_t Periphs)
1415 {
1416 CLEAR_BIT(RCC->AHB4LPENR, Periphs);
1417 }
1418
1419 /**
1420 * @}
1421 */
1422 #endif /* AHB4PERIPH_BASE */
1423
1424 /** @defgroup BUS_LL_EF_APB1 APB1
1425 * @{
1426 */
1427
1428 /**
1429 * @brief Enable APB1 peripherals clock.
1430 * @rmtoll APB1LENR TIM2EN LL_APB1_GRP1_EnableClock\n
1431 * APB1LENR TIM3EN LL_APB1_GRP1_EnableClock\n
1432 * APB1LENR TIM4EN LL_APB1_GRP1_EnableClock\n
1433 * APB1LENR TIM5EN LL_APB1_GRP1_EnableClock\n
1434 * APB1LENR TIM6EN LL_APB1_GRP1_EnableClock\n
1435 * APB1LENR TIM7EN LL_APB1_GRP1_EnableClock\n
1436 * APB1LENR TIM12EN LL_APB1_GRP1_EnableClock\n
1437 * APB1LENR TIM13EN LL_APB1_GRP1_EnableClock\n
1438 * APB1LENR TIM14EN LL_APB1_GRP1_EnableClock\n
1439 * APB1LENR WWDGEN LL_APB1_GRP1_EnableClock\n
1440 * APB1LENR SPI2EN LL_APB1_GRP1_EnableClock\n
1441 * APB1LENR SPI3EN LL_APB1_GRP1_EnableClock\n
1442 * APB1LENR USART2EN LL_APB1_GRP1_EnableClock\n
1443 * APB1LENR USART3EN LL_APB1_GRP1_EnableClock\n
1444 * APB1LENR UART4EN LL_APB1_GRP1_EnableClock\n
1445 * APB1LENR UART5EN LL_APB1_GRP1_EnableClock\n
1446 * APB1LENR I2C1EN LL_APB1_GRP1_EnableClock\n
1447 * APB1LENR I2C2EN LL_APB1_GRP1_EnableClock\n
1448 * APB1LENR I3C1EN LL_APB1_GRP1_EnableClock\n
1449 * APB1LENR CRSEN LL_APB1_GRP1_EnableClock\n
1450 * APB1LENR USART6EN LL_APB1_GRP1_EnableClock\n
1451 * APB1LENR USART10EN LL_APB1_GRP1_EnableClock\n
1452 * APB1LENR USART11EN LL_APB1_GRP1_EnableClock\n
1453 * APB1LENR CECEN LL_APB1_GRP1_EnableClock\n
1454 * APB1LENR UART7EN LL_APB1_GRP1_EnableClock\n
1455 * APB1LENR UART8EN LL_APB1_GRP1_EnableClock
1456 * @param Periphs This parameter can be a combination of the following values:
1457 * @arg @ref LL_APB1_GRP1_PERIPH_ALL
1458 * @arg @ref LL_APB1_GRP1_PERIPH_TIM2
1459 * @arg @ref LL_APB1_GRP1_PERIPH_TIM3
1460 * @arg @ref LL_APB1_GRP1_PERIPH_TIM4 (*)
1461 * @arg @ref LL_APB1_GRP1_PERIPH_TIM5 (*)
1462 * @arg @ref LL_APB1_GRP1_PERIPH_TIM6
1463 * @arg @ref LL_APB1_GRP1_PERIPH_TIM7
1464 * @arg @ref LL_APB1_GRP1_PERIPH_TIM12 (*)
1465 * @arg @ref LL_APB1_GRP1_PERIPH_TIM13 (*)
1466 * @arg @ref LL_APB1_GRP1_PERIPH_TIM14 (*)
1467 * @arg @ref LL_APB1_GRP1_PERIPH_WWDG
1468 * @arg @ref LL_APB1_GRP1_PERIPH_SPI2
1469 * @arg @ref LL_APB1_GRP1_PERIPH_SPI3
1470 * @arg @ref LL_APB1_GRP1_PERIPH_OPAMP (*)
1471 * @arg @ref LL_APB1_GRP1_PERIPH_COMP (*)
1472 * @arg @ref LL_APB1_GRP1_PERIPH_USART2
1473 * @arg @ref LL_APB1_GRP1_PERIPH_USART3
1474 * @arg @ref LL_APB1_GRP1_PERIPH_UART4 (*)
1475 * @arg @ref LL_APB1_GRP1_PERIPH_UART5 (*)
1476 * @arg @ref LL_APB1_GRP1_PERIPH_I2C1
1477 * @arg @ref LL_APB1_GRP1_PERIPH_I2C2
1478 * @arg @ref LL_APB1_GRP1_PERIPH_I3C1
1479 * @arg @ref LL_APB1_GRP1_PERIPH_CRS
1480 * @arg @ref LL_APB1_GRP1_PERIPH_USART6 (*)
1481 * @arg @ref LL_APB1_GRP1_PERIPH_USART10 (*)
1482 * @arg @ref LL_APB1_GRP1_PERIPH_USART11 (*)
1483 * @arg @ref LL_APB1_GRP1_PERIPH_CEC (*)
1484 * @arg @ref LL_APB1_GRP1_PERIPH_UART7 (*)
1485 * @arg @ref LL_APB1_GRP1_PERIPH_UART8 (*)
1486 *
1487 * (*) : Not available for all stm32h5xxxx family lines.
1488 * @retval None
1489 */
LL_APB1_GRP1_EnableClock(uint32_t Periphs)1490 __STATIC_INLINE void LL_APB1_GRP1_EnableClock(uint32_t Periphs)
1491 {
1492 __IO uint32_t tmpreg;
1493 SET_BIT(RCC->APB1LENR, Periphs);
1494 /* Delay after an RCC peripheral clock enabling */
1495 tmpreg = READ_BIT(RCC->APB1LENR, Periphs);
1496 (void)tmpreg;
1497 }
1498
1499 /**
1500 * @brief Enable APB1 peripherals clock.
1501 * @rmtoll APB1HENR UART9EN LL_APB1_GRP2_EnableClock\n
1502 * APB1HENR UART12EN LL_APB1_GRP2_EnableClock\n
1503 * APB1HENR DTSEN LL_APB1_GRP2_EnableClock\n
1504 * APB1HENR LPTIM2EN LL_APB1_GRP2_EnableClock\n
1505 * APB1HENR FDCANEN LL_APB1_GRP2_EnableClock\n
1506 * APB1HENR FDCANEN LL_APB1_GRP2_EnableClock\n
1507 * APB1HENR UCPD1EN LL_APB1_GRP2_EnableClock
1508 * @param Periphs This parameter can be a combination of the following values:
1509 * @arg @ref LL_APB1_GRP2_PERIPH_ALL
1510 * @arg @ref LL_APB1_GRP2_PERIPH_UART9 (*)
1511 * @arg @ref LL_APB1_GRP2_PERIPH_UART12 (*)
1512 * @arg @ref LL_APB1_GRP2_PERIPH_DTS
1513 * @arg @ref LL_APB1_GRP2_PERIPH_LPTIM2
1514 * @arg @ref LL_APB1_GRP2_PERIPH_FDCAN
1515 * @arg @ref LL_APB1_GRP2_PERIPH_UCPD1
1516 *
1517 * (*) : Not available for all stm32h5xxxx family lines.
1518 * @retval None
1519 */
LL_APB1_GRP2_EnableClock(uint32_t Periphs)1520 __STATIC_INLINE void LL_APB1_GRP2_EnableClock(uint32_t Periphs)
1521 {
1522 __IO uint32_t tmpreg;
1523 SET_BIT(RCC->APB1HENR, Periphs);
1524 /* Delay after an RCC peripheral clock enabling */
1525 tmpreg = READ_BIT(RCC->APB1HENR, Periphs);
1526 (void)tmpreg;
1527 }
1528
1529 /**
1530 * @brief Check if APB1 peripheral clock is enabled or not
1531 * @rmtoll APB1LENR TIM2EN LL_APB1_GRP1_IsEnabledClock\n
1532 * APB1LENR TIM3EN LL_APB1_GRP1_IsEnabledClock\n
1533 * APB1LENR TIM4EN LL_APB1_GRP1_IsEnabledClock\n
1534 * APB1LENR TIM5EN LL_APB1_GRP1_IsEnabledClock\n
1535 * APB1LENR TIM6EN LL_APB1_GRP1_IsEnabledClock\n
1536 * APB1LENR TIM7EN LL_APB1_GRP1_IsEnabledClock\n
1537 * APB1LENR WWDGEN LL_APB1_GRP1_IsEnabledClock\n
1538 * APB1LENR SPI2EN LL_APB1_GRP1_IsEnabledClock\n
1539 * APB1LENR SPI3EN LL_APB1_GRP1_IsEnabledClock\n
1540 * APB1LENR USART2EN LL_APB1_GRP1_IsEnabledClock\n
1541 * APB1LENR USART3EN LL_APB1_GRP1_IsEnabledClock\n
1542 * APB1LENR UART4EN LL_APB1_GRP1_IsEnabledClock\n
1543 * APB1LENR UART5EN LL_APB1_GRP1_IsEnabledClock\n
1544 * APB1LENR I2C1EN LL_APB1_GRP1_IsEnabledClock\n
1545 * APB1LENR I2C2EN LL_APB1_GRP1_IsEnabledClock\n
1546 * APB1LENR I3C1EN LL_APB1_GRP1_IsEnabledClock\n
1547 * APB1LENR CRSEN LL_APB1_GRP1_IsEnabledClock\n
1548 * APB1LENR USART6EN LL_APB1_GRP1_IsEnabledClock\n
1549 * APB1LENR USART10EN LL_APB1_GRP1_IsEnabledClock\n
1550 * APB1LENR USART11EN LL_APB1_GRP1_IsEnabledClock\n
1551 * APB1LENR CECEN LL_APB1_GRP1_IsEnabledClock\n
1552 * APB1LENR UART7EN LL_APB1_GRP1_IsEnabledClock\n
1553 * APB1LENR UART8EN LL_APB1_GRP1_IsEnabledClock
1554 * @param Periphs This parameter can be a combination of the following values:
1555 * @arg @ref LL_APB1_GRP1_PERIPH_ALL
1556 * @arg @ref LL_APB1_GRP1_PERIPH_TIM2
1557 * @arg @ref LL_APB1_GRP1_PERIPH_TIM3
1558 * @arg @ref LL_APB1_GRP1_PERIPH_TIM4 (*)
1559 * @arg @ref LL_APB1_GRP1_PERIPH_TIM5 (*)
1560 * @arg @ref LL_APB1_GRP1_PERIPH_TIM6
1561 * @arg @ref LL_APB1_GRP1_PERIPH_TIM7
1562 * @arg @ref LL_APB1_GRP1_PERIPH_TIM12 (*)
1563 * @arg @ref LL_APB1_GRP1_PERIPH_TIM13 (*)
1564 * @arg @ref LL_APB1_GRP1_PERIPH_TIM14 (*)
1565 * @arg @ref LL_APB1_GRP1_PERIPH_WWDG
1566 * @arg @ref LL_APB1_GRP1_PERIPH_SPI2
1567 * @arg @ref LL_APB1_GRP1_PERIPH_SPI3
1568 * @arg @ref LL_APB1_GRP1_PERIPH_OPAMP (*)
1569 * @arg @ref LL_APB1_GRP1_PERIPH_COMP (*)
1570 * @arg @ref LL_APB1_GRP1_PERIPH_USART2
1571 * @arg @ref LL_APB1_GRP1_PERIPH_USART3
1572 * @arg @ref LL_APB1_GRP1_PERIPH_UART4 (*)
1573 * @arg @ref LL_APB1_GRP1_PERIPH_UART5 (*)
1574 * @arg @ref LL_APB1_GRP1_PERIPH_I2C1
1575 * @arg @ref LL_APB1_GRP1_PERIPH_I2C2
1576 * @arg @ref LL_APB1_GRP1_PERIPH_I3C1
1577 * @arg @ref LL_APB1_GRP1_PERIPH_CRS
1578 * @arg @ref LL_APB1_GRP1_PERIPH_USART6 (*)
1579 * @arg @ref LL_APB1_GRP1_PERIPH_USART10 (*)
1580 * @arg @ref LL_APB1_GRP1_PERIPH_USART11 (*)
1581 * @arg @ref LL_APB1_GRP1_PERIPH_CEC (*)
1582 * @arg @ref LL_APB1_GRP1_PERIPH_UART7 (*)
1583 * @arg @ref LL_APB1_GRP1_PERIPH_UART8 (*)
1584 *
1585 * (*) : Not available for all stm32h5xxxx family lines.
1586 * @retval State of Periphs (1 or 0).
1587 */
LL_APB1_GRP1_IsEnabledClock(uint32_t Periphs)1588 __STATIC_INLINE uint32_t LL_APB1_GRP1_IsEnabledClock(uint32_t Periphs)
1589 {
1590 return ((READ_BIT(RCC->APB1LENR, Periphs) == Periphs) ? 1UL : 0UL);
1591 }
1592
1593 /**
1594 * @brief Check if APB1 peripheral clock is enabled or not
1595 * @rmtoll APB1HENR UART9EN LL_APB1_GRP2_IsEnabledClock\n
1596 * APB1HENR UART12EN LL_APB1_GRP2_IsEnabledClock\n
1597 * APB1HENR DTSEN LL_APB1_GRP2_IsEnabledClock\n
1598 * APB1HENR LPTIM2EN LL_APB1_GRP2_IsEnabledClock\n
1599 * APB1HENR FDCANEN LL_APB1_GRP2_IsEnabledClock\n
1600 * APB1HENR UCPD1EN LL_APB1_GRP2_IsEnabledClock
1601 * @param Periphs This parameter can be a combination of the following values:
1602 * @arg @ref LL_APB1_GRP2_PERIPH_ALL
1603 * @arg @ref LL_APB1_GRP2_PERIPH_UART9 (*)
1604 * @arg @ref LL_APB1_GRP2_PERIPH_UART12 (*)
1605 * @arg @ref LL_APB1_GRP2_PERIPH_DTS
1606 * @arg @ref LL_APB1_GRP2_PERIPH_LPTIM2
1607 * @arg @ref LL_APB1_GRP2_PERIPH_FDCAN
1608 * @arg @ref LL_APB1_GRP2_PERIPH_UCPD1
1609 *
1610 * (*) : Not available for all stm32h5xxxx family lines.
1611 * @retval State of Periphs (1 or 0).
1612 */
LL_APB1_GRP2_IsEnabledClock(uint32_t Periphs)1613 __STATIC_INLINE uint32_t LL_APB1_GRP2_IsEnabledClock(uint32_t Periphs)
1614 {
1615 return ((READ_BIT(RCC->APB1HENR, Periphs) == Periphs) ? 1UL : 0UL);
1616 }
1617
1618 /**
1619 * @brief Disable APB1 peripherals clock.
1620 * @rmtoll APB1LENR TIM2EN LL_APB1_GRP1_DisableClock\n
1621 * APB1LENR TIM3EN LL_APB1_GRP1_DisableClock\n
1622 * APB1LENR TIM4EN LL_APB1_GRP1_DisableClock\n
1623 * APB1LENR TIM5EN LL_APB1_GRP1_DisableClock\n
1624 * APB1LENR TIM6EN LL_APB1_GRP1_DisableClock\n
1625 * APB1LENR TIM7EN LL_APB1_GRP1_DisableClock\n
1626 * APB1LENR WWDGEN LL_APB1_GRP1_DisableClock\n
1627 * APB1LENR SPI2EN LL_APB1_GRP1_DisableClock\n
1628 * APB1LENR SPI3EN LL_APB1_GRP1_DisableClock\n
1629 * APB1LENR USART2EN LL_APB1_GRP1_DisableClock\n
1630 * APB1LENR USART3EN LL_APB1_GRP1_DisableClock\n
1631 * APB1LENR UART4EN LL_APB1_GRP1_DisableClock\n
1632 * APB1LENR UART5EN LL_APB1_GRP1_DisableClock\n
1633 * APB1LENR I2C1EN LL_APB1_GRP1_DisableClock\n
1634 * APB1LENR I2C2EN LL_APB1_GRP1_DisableClock\n
1635 * APB1LENR I3C1EN LL_APB1_GRP1_DisableClock\n
1636 * APB1LENR CRSEN LL_APB1_GRP1_DisableClock\n
1637 * APB1LENR USART6EN LL_APB1_GRP1_DisableClock\n
1638 * APB1LENR USART10EN LL_APB1_GRP1_DisableClock\n
1639 * APB1LENR USART11EN LL_APB1_GRP1_DisableClock\n
1640 * APB1LENR CECEN LL_APB1_GRP1_DisableClock\n
1641 * APB1LENR UART7EN LL_APB1_GRP1_DisableClock\n
1642 * APB1LENR UART8EN LL_APB1_GRP1_DisableClock
1643 * @param Periphs This parameter can be a combination of the following values:
1644 * @arg @ref LL_APB1_GRP1_PERIPH_ALL
1645 * @arg @ref LL_APB1_GRP1_PERIPH_TIM2
1646 * @arg @ref LL_APB1_GRP1_PERIPH_TIM3
1647 * @arg @ref LL_APB1_GRP1_PERIPH_TIM4 (*)
1648 * @arg @ref LL_APB1_GRP1_PERIPH_TIM5 (*)
1649 * @arg @ref LL_APB1_GRP1_PERIPH_TIM6
1650 * @arg @ref LL_APB1_GRP1_PERIPH_TIM7
1651 * @arg @ref LL_APB1_GRP1_PERIPH_TIM12 (*)
1652 * @arg @ref LL_APB1_GRP1_PERIPH_TIM13 (*)
1653 * @arg @ref LL_APB1_GRP1_PERIPH_TIM14 (*)
1654 * @arg @ref LL_APB1_GRP1_PERIPH_WWDG
1655 * @arg @ref LL_APB1_GRP1_PERIPH_SPI2
1656 * @arg @ref LL_APB1_GRP1_PERIPH_SPI3
1657 * @arg @ref LL_APB1_GRP1_PERIPH_OPAMP (*)
1658 * @arg @ref LL_APB1_GRP1_PERIPH_COMP (*)
1659 * @arg @ref LL_APB1_GRP1_PERIPH_USART2
1660 * @arg @ref LL_APB1_GRP1_PERIPH_USART3
1661 * @arg @ref LL_APB1_GRP1_PERIPH_UART4 (*)
1662 * @arg @ref LL_APB1_GRP1_PERIPH_UART5 (*)
1663 * @arg @ref LL_APB1_GRP1_PERIPH_I2C1
1664 * @arg @ref LL_APB1_GRP1_PERIPH_I2C2
1665 * @arg @ref LL_APB1_GRP1_PERIPH_I3C1
1666 * @arg @ref LL_APB1_GRP1_PERIPH_CRS
1667 * @arg @ref LL_APB1_GRP1_PERIPH_USART6 (*)
1668 * @arg @ref LL_APB1_GRP1_PERIPH_USART10 (*)
1669 * @arg @ref LL_APB1_GRP1_PERIPH_USART11 (*)
1670 * @arg @ref LL_APB1_GRP1_PERIPH_CEC (*)
1671 * @arg @ref LL_APB1_GRP1_PERIPH_UART7 (*)
1672 * @arg @ref LL_APB1_GRP1_PERIPH_UART8 (*)
1673 *
1674 * (*) : Not available for all stm32h5xxxx family lines.
1675 * @retval None
1676 */
LL_APB1_GRP1_DisableClock(uint32_t Periphs)1677 __STATIC_INLINE void LL_APB1_GRP1_DisableClock(uint32_t Periphs)
1678 {
1679 CLEAR_BIT(RCC->APB1LENR, Periphs);
1680 }
1681
1682 /**
1683 * @brief Disable APB1 peripherals clock.
1684 * @rmtoll APB1HENR UART9EN LL_APB1_GRP2_DisableClock\n
1685 * APB1HENR UART12EN LL_APB1_GRP2_DisableClock\n
1686 * APB1HENR DTSEN LL_APB1_GRP2_DisableClock\n
1687 * APB1HENR LPTIM2EN LL_APB1_GRP2_DisableClock\n
1688 * APB1HENR FDCANEN LL_APB1_GRP2_DisableClock\n
1689 * APB1HENR UCPD1EN LL_APB1_GRP2_DisableClock
1690 * @param Periphs This parameter can be a combination of the following values:
1691 * @arg @ref LL_APB1_GRP2_PERIPH_ALL
1692 * @arg @ref LL_APB1_GRP2_PERIPH_UART9 (*)
1693 * @arg @ref LL_APB1_GRP2_PERIPH_UART12 (*)
1694 * @arg @ref LL_APB1_GRP2_PERIPH_DTS
1695 * @arg @ref LL_APB1_GRP2_PERIPH_LPTIM2
1696 * @arg @ref LL_APB1_GRP2_PERIPH_FDCAN
1697 * @arg @ref LL_APB1_GRP2_PERIPH_UCPD1
1698 *
1699 * (*) : Not available for all stm32h5xxxx family lines.
1700 * @retval None
1701 */
LL_APB1_GRP2_DisableClock(uint32_t Periphs)1702 __STATIC_INLINE void LL_APB1_GRP2_DisableClock(uint32_t Periphs)
1703 {
1704 CLEAR_BIT(RCC->APB1HENR, Periphs);
1705 }
1706
1707 /**
1708 * @brief Force APB1 peripherals reset.
1709 * @rmtoll APB1LRSTR TIM2RST LL_APB1_GRP1_ForceReset\n
1710 * APB1LRSTR TIM3RST LL_APB1_GRP1_ForceReset\n
1711 * APB1LRSTR TIM4RST LL_APB1_GRP1_ForceReset\n
1712 * APB1LRSTR TIM5RST LL_APB1_GRP1_ForceReset\n
1713 * APB1LRSTR TIM6RST LL_APB1_GRP1_ForceReset\n
1714 * APB1LRSTR TIM7RST LL_APB1_GRP1_ForceReset\n
1715 * APB1LRSTR SPI2RST LL_APB1_GRP1_ForceReset\n
1716 * APB1LRSTR SPI3RST LL_APB1_GRP1_ForceReset\n
1717 * APB1LRSTR USART2RST LL_APB1_GRP1_ForceReset\n
1718 * APB1LRSTR USART3RST LL_APB1_GRP1_ForceReset\n
1719 * APB1LRSTR UART4RST LL_APB1_GRP1_ForceReset\n
1720 * APB1LRSTR UART5RST LL_APB1_GRP1_ForceReset\n
1721 * APB1LRSTR I2C1RST LL_APB1_GRP1_ForceReset\n
1722 * APB1LRSTR I2C2RST LL_APB1_GRP1_ForceReset\n
1723 * APB1LRSTR I3C1RST LL_APB1_GRP1_ForceReset\n
1724 * APB1LRSTR CRSRST LL_APB1_GRP1_ForceReset\n
1725 * APB1LRSTR USART6RST LL_APB1_GRP1_ForceReset\n
1726 * APB1LRSTR USART10RST LL_APB1_GRP1_ForceReset\n
1727 * APB1LRSTR USART11RST LL_APB1_GRP1_ForceReset\n
1728 * APB1LRSTR CECRST LL_APB1_GRP1_ForceReset\n
1729 * APB1LRSTR UART7RST LL_APB1_GRP1_ForceReset\n
1730 * APB1LRSTR UART8RST LL_APB1_GRP1_ForceReset
1731 * @param Periphs This parameter can be a combination of the following values:
1732 * @arg @ref LL_APB1_GRP1_PERIPH_ALL
1733 * @arg @ref LL_APB1_GRP1_PERIPH_TIM2
1734 * @arg @ref LL_APB1_GRP1_PERIPH_TIM3
1735 * @arg @ref LL_APB1_GRP1_PERIPH_TIM4 (*)
1736 * @arg @ref LL_APB1_GRP1_PERIPH_TIM5 (*)
1737 * @arg @ref LL_APB1_GRP1_PERIPH_TIM6
1738 * @arg @ref LL_APB1_GRP1_PERIPH_TIM7
1739 * @arg @ref LL_APB1_GRP1_PERIPH_TIM12 (*)
1740 * @arg @ref LL_APB1_GRP1_PERIPH_TIM13 (*)
1741 * @arg @ref LL_APB1_GRP1_PERIPH_TIM14 (*)
1742 * @arg @ref LL_APB1_GRP1_PERIPH_SPI2
1743 * @arg @ref LL_APB1_GRP1_PERIPH_SPI3
1744 * @arg @ref LL_APB1_GRP1_PERIPH_OPAMP (*)
1745 * @arg @ref LL_APB1_GRP1_PERIPH_COMP (*)
1746 * @arg @ref LL_APB1_GRP1_PERIPH_USART2
1747 * @arg @ref LL_APB1_GRP1_PERIPH_USART3
1748 * @arg @ref LL_APB1_GRP1_PERIPH_UART4 (*)
1749 * @arg @ref LL_APB1_GRP1_PERIPH_UART5 (*)
1750 * @arg @ref LL_APB1_GRP1_PERIPH_I2C1
1751 * @arg @ref LL_APB1_GRP1_PERIPH_I2C2
1752 * @arg @ref LL_APB1_GRP1_PERIPH_I3C1
1753 * @arg @ref LL_APB1_GRP1_PERIPH_CRS
1754 * @arg @ref LL_APB1_GRP1_PERIPH_USART6 (*)
1755 * @arg @ref LL_APB1_GRP1_PERIPH_USART10 (*)
1756 * @arg @ref LL_APB1_GRP1_PERIPH_USART11 (*)
1757 * @arg @ref LL_APB1_GRP1_PERIPH_CEC (*)
1758 * @arg @ref LL_APB1_GRP1_PERIPH_UART7 (*)
1759 * @arg @ref LL_APB1_GRP1_PERIPH_UART8 (*)
1760 *
1761 * (*) : Not available for all stm32h5xxxx family lines.
1762 * @retval None
1763 */
LL_APB1_GRP1_ForceReset(uint32_t Periphs)1764 __STATIC_INLINE void LL_APB1_GRP1_ForceReset(uint32_t Periphs)
1765 {
1766 SET_BIT(RCC->APB1LRSTR, Periphs);
1767 }
1768
1769 /**
1770 * @brief Force APB1 peripherals reset.
1771 * @rmtoll APB1HRSTR UART9RST LL_APB1_GRP2_ForceReset\n
1772 * APB1HRSTR UART12RST LL_APB1_GRP2_ForceReset\n
1773 * APB1HRSTR DTSRST LL_APB1_GRP2_ForceReset\n
1774 * APB1HRSTR LPTIM2RST LL_APB1_GRP2_ForceReset\n
1775 * APB1HRSTR FDCANRST LL_APB1_GRP2_ForceReset\n
1776 * APB1HRSTR UCPD1RST LL_APB1_GRP2_ForceReset
1777 * @param Periphs This parameter can be a combination of the following values:
1778 * @arg @ref LL_APB1_GRP2_PERIPH_ALL
1779 * @arg @ref LL_APB1_GRP2_PERIPH_UART9 (*)
1780 * @arg @ref LL_APB1_GRP2_PERIPH_UART12 (*)
1781 * @arg @ref LL_APB1_GRP2_PERIPH_DTS
1782 * @arg @ref LL_APB1_GRP2_PERIPH_LPTIM2
1783 * @arg @ref LL_APB1_GRP2_PERIPH_FDCAN
1784 * @arg @ref LL_APB1_GRP2_PERIPH_UCPD1
1785 *
1786 * (*) : Not available for all stm32h5xxxx family lines.
1787 * @retval None
1788 */
LL_APB1_GRP2_ForceReset(uint32_t Periphs)1789 __STATIC_INLINE void LL_APB1_GRP2_ForceReset(uint32_t Periphs)
1790 {
1791 SET_BIT(RCC->APB1HRSTR, Periphs);
1792 }
1793
1794 /**
1795 * @brief Release APB1 peripherals reset.
1796 * @rmtoll APB1LRSTR TIM2RST LL_APB1_GRP1_ReleaseReset\n
1797 * APB1LRSTR TIM3RST LL_APB1_GRP1_ReleaseReset\n
1798 * APB1LRSTR TIM4RST LL_APB1_GRP1_ReleaseReset\n
1799 * APB1LRSTR TIM5RST LL_APB1_GRP1_ReleaseReset\n
1800 * APB1LRSTR TIM6RST LL_APB1_GRP1_ReleaseReset\n
1801 * APB1LRSTR TIM7RST LL_APB1_GRP1_ReleaseReset\n
1802 * APB1LRSTR SPI2RST LL_APB1_GRP1_ReleaseReset\n
1803 * APB1LRSTR SPI3RST LL_APB1_GRP1_ReleaseReset\n
1804 * APB1LRSTR USART2RST LL_APB1_GRP1_ReleaseReset\n
1805 * APB1LRSTR USART3RST LL_APB1_GRP1_ReleaseReset\n
1806 * APB1LRSTR UART4RST LL_APB1_GRP1_ReleaseReset\n
1807 * APB1LRSTR UART5RST LL_APB1_GRP1_ReleaseReset\n
1808 * APB1LRSTR I2C1RST LL_APB1_GRP1_ReleaseReset\n
1809 * APB1LRSTR I2C2RST LL_APB1_GRP1_ReleaseReset\n
1810 * APB1LRSTR I3C1RST LL_APB1_GRP1_ReleaseReset\n
1811 * APB1LRSTR CRSRST LL_APB1_GRP1_ReleaseReset\n
1812 * APB1LRSTR USART6RST LL_APB1_GRP1_ReleaseReset\n
1813 * APB1LRSTR USART10RST LL_APB1_GRP1_ReleaseReset\n
1814 * APB1LRSTR USART11RST LL_APB1_GRP1_ReleaseReset\n
1815 * APB1LRSTR CECRST LL_APB1_GRP1_ReleaseReset\n
1816 * APB1LRSTR UART7RST LL_APB1_GRP1_ReleaseReset\n
1817 * APB1LRSTR UART8RST LL_APB1_GRP1_ReleaseReset
1818 * @param Periphs This parameter can be a combination of the following values:
1819 * @arg @ref LL_APB1_GRP1_PERIPH_ALL
1820 * @arg @ref LL_APB1_GRP1_PERIPH_TIM2
1821 * @arg @ref LL_APB1_GRP1_PERIPH_TIM3
1822 * @arg @ref LL_APB1_GRP1_PERIPH_TIM4 (*)
1823 * @arg @ref LL_APB1_GRP1_PERIPH_TIM5 (*)
1824 * @arg @ref LL_APB1_GRP1_PERIPH_TIM6
1825 * @arg @ref LL_APB1_GRP1_PERIPH_TIM7
1826 * @arg @ref LL_APB1_GRP1_PERIPH_TIM12 (*)
1827 * @arg @ref LL_APB1_GRP1_PERIPH_TIM13 (*)
1828 * @arg @ref LL_APB1_GRP1_PERIPH_TIM14 (*)
1829 * @arg @ref LL_APB1_GRP1_PERIPH_SPI2
1830 * @arg @ref LL_APB1_GRP1_PERIPH_SPI3
1831 * @arg @ref LL_APB1_GRP1_PERIPH_OPAMP (*)
1832 * @arg @ref LL_APB1_GRP1_PERIPH_COMP (*)
1833 * @arg @ref LL_APB1_GRP1_PERIPH_USART2
1834 * @arg @ref LL_APB1_GRP1_PERIPH_USART3
1835 * @arg @ref LL_APB1_GRP1_PERIPH_UART4 (*)
1836 * @arg @ref LL_APB1_GRP1_PERIPH_UART5 (*)
1837 * @arg @ref LL_APB1_GRP1_PERIPH_I2C1
1838 * @arg @ref LL_APB1_GRP1_PERIPH_I2C2
1839 * @arg @ref LL_APB1_GRP1_PERIPH_I3C1
1840 * @arg @ref LL_APB1_GRP1_PERIPH_CRS
1841 * @arg @ref LL_APB1_GRP1_PERIPH_USART6 (*)
1842 * @arg @ref LL_APB1_GRP1_PERIPH_USART10 (*)
1843 * @arg @ref LL_APB1_GRP1_PERIPH_USART11 (*)
1844 * @arg @ref LL_APB1_GRP1_PERIPH_CEC (*)
1845 * @arg @ref LL_APB1_GRP1_PERIPH_UART7 (*)
1846 * @arg @ref LL_APB1_GRP1_PERIPH_UART8 (*)
1847 *
1848 * (*) : Not available for all stm32h5xxxx family lines.
1849 * @retval None
1850 */
LL_APB1_GRP1_ReleaseReset(uint32_t Periphs)1851 __STATIC_INLINE void LL_APB1_GRP1_ReleaseReset(uint32_t Periphs)
1852 {
1853 CLEAR_BIT(RCC->APB1LRSTR, Periphs);
1854 }
1855
1856 /**
1857 * @brief Release APB1 peripherals reset.
1858 * @rmtoll APB1HRSTR UART9RST LL_APB1_GRP2_ReleaseReset\n
1859 * APB1HRSTR UART12RST LL_APB1_GRP2_ReleaseReset\n
1860 * APB1HRSTR DTSRST LL_APB1_GRP2_ReleaseReset\n
1861 * APB1HRSTR LPTIM2RST LL_APB1_GRP2_ReleaseReset\n
1862 * APB1HRSTR FDCAN LL_APB1_GRP2_ReleaseReset\n
1863 * APB1HRSTR UCPD1RST LL_APB1_GRP2_ReleaseReset
1864 * @param Periphs This parameter can be a combination of the following values:
1865 * @arg @ref LL_APB1_GRP2_PERIPH_ALL
1866 * @arg @ref LL_APB1_GRP2_PERIPH_UART9 (*)
1867 * @arg @ref LL_APB1_GRP2_PERIPH_UART12 (*)
1868 * @arg @ref LL_APB1_GRP2_PERIPH_DTS
1869 * @arg @ref LL_APB1_GRP2_PERIPH_LPTIM2
1870 * @arg @ref LL_APB1_GRP2_PERIPH_FDCAN
1871 * @arg @ref LL_APB1_GRP2_PERIPH_UCPD1
1872 *
1873 * (*) : Not available for all stm32h5xxxx family lines.
1874 * @retval None
1875 */
LL_APB1_GRP2_ReleaseReset(uint32_t Periphs)1876 __STATIC_INLINE void LL_APB1_GRP2_ReleaseReset(uint32_t Periphs)
1877 {
1878 CLEAR_BIT(RCC->APB1HRSTR, Periphs);
1879 }
1880
1881 /**
1882 * @brief Enable APB1 peripheral clocks in Sleep mode
1883 * @rmtoll APB1LLPENR TIM2LPEN LL_APB1_GRP1_EnableClockSleep\n
1884 * APB1LLPENR TIM3LPEN LL_APB1_GRP1_EnableClockSleep\n
1885 * APB1LLPENR TIM4LPEN LL_APB1_GRP1_EnableClockSleep\n
1886 * APB1LLPENR TIM5LPEN LL_APB1_GRP1_EnableClockSleep\n
1887 * APB1LLPENR TIM6LPEN LL_APB1_GRP1_EnableClockSleep\n
1888 * APB1LLPENR TIM7LPEN LL_APB1_GRP1_EnableClockSleep\n
1889 * APB1LLPENR WWDGLPEN LL_APB1_GRP1_EnableClockSleep\n
1890 * APB1LLPENR SPI2LPEN LL_APB1_GRP1_EnableClockSleep\n
1891 * APB1LLPENR SPI3LPEN LL_APB1_GRP1_EnableClockSleep\n
1892 * APB1LLPENR USART2LPEN LL_APB1_GRP1_EnableClockSleep\n
1893 * APB1LLPENR USART3LPEN LL_APB1_GRP1_EnableClockSleep\n
1894 * APB1LLPENR UART4LPEN LL_APB1_GRP1_EnableClockSleep\n
1895 * APB1LLPENR UART5LPEN LL_APB1_GRP1_EnableClockSleep\n
1896 * APB1LLPENR I2C1LPEN LL_APB1_GRP1_EnableClockSleep\n
1897 * APB1LLPENR I2C2LPEN LL_APB1_GRP1_EnableClockSleep\n
1898 * APB1LLPENR I3C1LPEN LL_APB1_GRP1_EnableClockSleep\n
1899 * APB1LLPENR CRSLPEN LL_APB1_GRP1_EnableClockSleep\n
1900 * APB1LLPENR USART6LPEN LL_APB1_GRP1_EnableClockSleep\n
1901 * APB1LLPENR USART10LPEN LL_APB1_GRP1_EnableClockSleep\n
1902 * APB1LLPENR USART11LPEN LL_APB1_GRP1_EnableClockSleep\n
1903 * APB1LLPENR CECLPEN LL_APB1_GRP1_EnableClockSleep\n
1904 * APB1LLPENR UART7LPEN LL_APB1_GRP1_EnableClockSleep\n
1905 * APB1LLPENR UART8LPEN LL_APB1_GRP1_EnableClockSleep
1906 * @param Periphs This parameter can be a combination of the following values:
1907 * @arg @ref LL_APB1_GRP1_PERIPH_ALL
1908 * @arg @ref LL_APB1_GRP1_PERIPH_TIM2
1909 * @arg @ref LL_APB1_GRP1_PERIPH_TIM3
1910 * @arg @ref LL_APB1_GRP1_PERIPH_TIM4 (*)
1911 * @arg @ref LL_APB1_GRP1_PERIPH_TIM5 (*)
1912 * @arg @ref LL_APB1_GRP1_PERIPH_TIM6
1913 * @arg @ref LL_APB1_GRP1_PERIPH_TIM7
1914 * @arg @ref LL_APB1_GRP1_PERIPH_TIM12 (*)
1915 * @arg @ref LL_APB1_GRP1_PERIPH_TIM13 (*)
1916 * @arg @ref LL_APB1_GRP1_PERIPH_TIM14 (*)
1917 * @arg @ref LL_APB1_GRP1_PERIPH_WWDG
1918 * @arg @ref LL_APB1_GRP1_PERIPH_SPI2
1919 * @arg @ref LL_APB1_GRP1_PERIPH_SPI3
1920 * @arg @ref LL_APB1_GRP1_PERIPH_OPAMP (*)
1921 * @arg @ref LL_APB1_GRP1_PERIPH_COMP (*)
1922 * @arg @ref LL_APB1_GRP1_PERIPH_USART2
1923 * @arg @ref LL_APB1_GRP1_PERIPH_USART3
1924 * @arg @ref LL_APB1_GRP1_PERIPH_UART4 (*)
1925 * @arg @ref LL_APB1_GRP1_PERIPH_UART5 (*)
1926 * @arg @ref LL_APB1_GRP1_PERIPH_I2C1
1927 * @arg @ref LL_APB1_GRP1_PERIPH_I2C2
1928 * @arg @ref LL_APB1_GRP1_PERIPH_I3C1
1929 * @arg @ref LL_APB1_GRP1_PERIPH_CRS
1930 * @arg @ref LL_APB1_GRP1_PERIPH_USART6 (*)
1931 * @arg @ref LL_APB1_GRP1_PERIPH_USART10 (*)
1932 * @arg @ref LL_APB1_GRP1_PERIPH_USART11 (*)
1933 * @arg @ref LL_APB1_GRP1_PERIPH_CEC (*)
1934 * @arg @ref LL_APB1_GRP1_PERIPH_UART7 (*)
1935 * @arg @ref LL_APB1_GRP1_PERIPH_UART8 (*)
1936 *
1937 * (*) : Not available for all stm32h5xxxx family lines.
1938 * @retval None
1939 */
LL_APB1_GRP1_EnableClockSleep(uint32_t Periphs)1940 __STATIC_INLINE void LL_APB1_GRP1_EnableClockSleep(uint32_t Periphs)
1941 {
1942 __IO uint32_t tmpreg;
1943 SET_BIT(RCC->APB1LLPENR, Periphs);
1944 /* Delay after an RCC peripheral clock enabling */
1945 tmpreg = READ_BIT(RCC->APB1LLPENR, Periphs);
1946 (void)tmpreg;
1947 }
1948
1949 /**
1950 * @brief Check if APB1 peripheral clocks in Sleep mode is enabled or not
1951 * @rmtoll APB1LLPENR TIM2LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1952 * APB1LLPENR TIM3LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1953 * APB1LLPENR TIM4LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1954 * APB1LLPENR TIM5LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1955 * APB1LLPENR TIM6LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1956 * APB1LLPENR TIM7LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1957 * APB1LLPENR WWDGLPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1958 * APB1LLPENR SPI2LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1959 * APB1LLPENR SPI3LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1960 * APB1LLPENR USART2LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1961 * APB1LLPENR USART3LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1962 * APB1LLPENR UART4LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1963 * APB1LLPENR UART5LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1964 * APB1LLPENR I2C1LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1965 * APB1LLPENR I2C2LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1966 * APB1LLPENR I3C1LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1967 * APB1LLPENR CRSLPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1968 * APB1LLPENR USART6LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1969 * APB1LLPENR USART10LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1970 * APB1LLPENR USART11LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1971 * APB1LLPENR CECLPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1972 * APB1LLPENR UART7LPEN LL_APB1_GRP1_IsEnabledClockSleep\n
1973 * APB1LLPENR UART8LPEN LL_APB1_GRP1_IsEnabledClockSleep
1974 * @param Periphs This parameter can be a combination of the following values:
1975 * @arg @ref LL_APB1_GRP1_PERIPH_ALL
1976 * @arg @ref LL_APB1_GRP1_PERIPH_TIM2
1977 * @arg @ref LL_APB1_GRP1_PERIPH_TIM3
1978 * @arg @ref LL_APB1_GRP1_PERIPH_TIM4 (*)
1979 * @arg @ref LL_APB1_GRP1_PERIPH_TIM5 (*)
1980 * @arg @ref LL_APB1_GRP1_PERIPH_TIM6
1981 * @arg @ref LL_APB1_GRP1_PERIPH_TIM7
1982 * @arg @ref LL_APB1_GRP1_PERIPH_TIM12 (*)
1983 * @arg @ref LL_APB1_GRP1_PERIPH_TIM13 (*)
1984 * @arg @ref LL_APB1_GRP1_PERIPH_TIM14
1985 * @arg @ref LL_APB1_GRP1_PERIPH_WWDG
1986 * @arg @ref LL_APB1_GRP1_PERIPH_SPI2
1987 * @arg @ref LL_APB1_GRP1_PERIPH_SPI3
1988 * @arg @ref LL_APB1_GRP1_PERIPH_OPAMP (*)
1989 * @arg @ref LL_APB1_GRP1_PERIPH_COMP (*)
1990 * @arg @ref LL_APB1_GRP1_PERIPH_USART2
1991 * @arg @ref LL_APB1_GRP1_PERIPH_USART3
1992 * @arg @ref LL_APB1_GRP1_PERIPH_UART4 (*)
1993 * @arg @ref LL_APB1_GRP1_PERIPH_UART5 (*)
1994 * @arg @ref LL_APB1_GRP1_PERIPH_I2C1
1995 * @arg @ref LL_APB1_GRP1_PERIPH_I2C2
1996 * @arg @ref LL_APB1_GRP1_PERIPH_I3C1
1997 * @arg @ref LL_APB1_GRP1_PERIPH_CRS
1998 * @arg @ref LL_APB1_GRP1_PERIPH_USART6 (*)
1999 * @arg @ref LL_APB1_GRP1_PERIPH_USART10 (*)
2000 * @arg @ref LL_APB1_GRP1_PERIPH_USART11
2001 * @arg @ref LL_APB1_GRP1_PERIPH_CEC (*)
2002 * @arg @ref LL_APB1_GRP1_PERIPH_UART7 (*)
2003 * @arg @ref LL_APB1_GRP1_PERIPH_UART8 (*)
2004 *
2005 * (*) : Not available for all stm32h5xxxx family lines.
2006 * @retval State of Periphs (1 or 0).
2007 */
LL_APB1_GRP1_IsEnabledClockSleep(uint32_t Periphs)2008 __STATIC_INLINE uint32_t LL_APB1_GRP1_IsEnabledClockSleep(uint32_t Periphs)
2009 {
2010 return ((READ_BIT(RCC->APB1LLPENR, Periphs) == Periphs) ? 1UL : 0UL);
2011 }
2012
2013 /**
2014 * @brief Disable APB1 peripheral clocks in Sleep mode
2015 * @rmtoll APB1LLPENR TIM2LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2016 * APB1LLPENR TIM3LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2017 * APB1LLPENR TIM4LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2018 * APB1LLPENR TIM5LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2019 * APB1LLPENR TIM6LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2020 * APB1LLPENR TIM7LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2021 * APB1LLPENR WWDGLPEN LL_APB1_GRP1_DisableClockStopSleep\n
2022 * APB1LLPENR SPI2LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2023 * APB1LLPENR SPI3LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2024 * APB1LLPENR USART2LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2025 * APB1LLPENR USART3LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2026 * APB1LLPENR UART4LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2027 * APB1LLPENR UART5LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2028 * APB1LLPENR I2C1LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2029 * APB1LLPENR I2C2LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2030 * APB1LLPENR I3C1LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2031 * APB1LLPENR CRSLPEN LL_APB1_GRP1_DisableClockStopSleep\n
2032 * APB1LLPENR USART6LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2033 * APB1LLPENR USART10LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2034 * APB1LLPENR USART11LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2035 * APB1LLPENR CECLPEN LL_APB1_GRP1_DisableClockStopSleep\n
2036 * APB1LLPENR UART7LPEN LL_APB1_GRP1_DisableClockStopSleep\n
2037 * APB1LLPENR UART8LPEN LL_APB1_GRP1_DisableClockStopSleep
2038 * @param Periphs This parameter can be a combination of the following values:
2039 * @arg @ref LL_APB1_GRP1_PERIPH_ALL
2040 * @arg @ref LL_APB1_GRP1_PERIPH_TIM2
2041 * @arg @ref LL_APB1_GRP1_PERIPH_TIM3
2042 * @arg @ref LL_APB1_GRP1_PERIPH_TIM4 (*)
2043 * @arg @ref LL_APB1_GRP1_PERIPH_TIM5 (*)
2044 * @arg @ref LL_APB1_GRP1_PERIPH_TIM6
2045 * @arg @ref LL_APB1_GRP1_PERIPH_TIM7
2046 * @arg @ref LL_APB1_GRP1_PERIPH_TIM12 (*)
2047 * @arg @ref LL_APB1_GRP1_PERIPH_TIM13 (*)
2048 * @arg @ref LL_APB1_GRP1_PERIPH_TIM14 (*)
2049 * @arg @ref LL_APB1_GRP1_PERIPH_WWDG
2050 * @arg @ref LL_APB1_GRP1_PERIPH_SPI2
2051 * @arg @ref LL_APB1_GRP1_PERIPH_SPI3
2052 * @arg @ref LL_APB1_GRP1_PERIPH_OPAMP (*)
2053 * @arg @ref LL_APB1_GRP1_PERIPH_COMP (*)
2054 * @arg @ref LL_APB1_GRP1_PERIPH_USART2
2055 * @arg @ref LL_APB1_GRP1_PERIPH_USART3
2056 * @arg @ref LL_APB1_GRP1_PERIPH_UART4 (*)
2057 * @arg @ref LL_APB1_GRP1_PERIPH_UART5 (*)
2058 * @arg @ref LL_APB1_GRP1_PERIPH_I2C1
2059 * @arg @ref LL_APB1_GRP1_PERIPH_I2C2
2060 * @arg @ref LL_APB1_GRP1_PERIPH_I3C1
2061 * @arg @ref LL_APB1_GRP1_PERIPH_CRS
2062 * @arg @ref LL_APB1_GRP1_PERIPH_USART6 (*)
2063 * @arg @ref LL_APB1_GRP1_PERIPH_USART10 (*)
2064 * @arg @ref LL_APB1_GRP1_PERIPH_USART11 (*)
2065 * @arg @ref LL_APB1_GRP1_PERIPH_CEC (*)
2066 * @arg @ref LL_APB1_GRP1_PERIPH_UART7 (*)
2067 * @arg @ref LL_APB1_GRP1_PERIPH_UART8 (*)
2068 *
2069 * (*) : Not available for all stm32h5xxxx family lines.
2070 * @retval None
2071 */
LL_APB1_GRP1_DisableClockSleep(uint32_t Periphs)2072 __STATIC_INLINE void LL_APB1_GRP1_DisableClockSleep(uint32_t Periphs)
2073 {
2074 CLEAR_BIT(RCC->APB1LLPENR, Periphs);
2075 }
2076
2077 /**
2078 * @brief Enable APB1 peripheral clocks in Sleep mode
2079 * @rmtoll APB1HLPENR UART9LPEN LL_APB1_GRP2_EnableClockSleep\n
2080 * APB1HLPENR UART12LPEN LL_APB1_GRP2_EnableClockSleep\n
2081 * APB1HLPENR DTSLPEN LL_APB1_GRP2_EnableClockSleep\n
2082 * APB1HLPENR LPTIM2LPEN LL_APB1_GRP2_EnableClockSleep\n
2083 * APB1HLPENR FDCAN12LPEN LL_APB1_GRP2_EnableClockSleep\n
2084 * APB1HLPENR FDCAN1LPEN LL_APB1_GRP2_EnableClockSleep\n
2085 * APB1HLPENR UCPD1LPEN LL_APB1_GRP2_EnableClockSleep
2086 * @param Periphs This parameter can be a combination of the following values:
2087 * @arg @ref LL_APB1_GRP2_PERIPH_ALL
2088 * @arg @ref LL_APB1_GRP2_PERIPH_UART9 (*)
2089 * @arg @ref LL_APB1_GRP2_PERIPH_UART12 (*)
2090 * @arg @ref LL_APB1_GRP2_PERIPH_DTS
2091 * @arg @ref LL_APB1_GRP2_PERIPH_LPTIM2
2092 * @arg @ref LL_APB1_GRP2_PERIPH_FDCAN12 (*)
2093 * @arg @ref LL_APB1_GRP2_PERIPH_FDCAN1 (*)
2094 * @arg @ref LL_APB1_GRP2_PERIPH_UCPD1
2095 *
2096 * (*) : Not available for all stm32h5xxxx family lines.
2097 * @retval None
2098 */
LL_APB1_GRP2_EnableClockSleep(uint32_t Periphs)2099 __STATIC_INLINE void LL_APB1_GRP2_EnableClockSleep(uint32_t Periphs)
2100 {
2101 __IO uint32_t tmpreg;
2102 SET_BIT(RCC->APB1HLPENR, Periphs);
2103 /* Delay after an RCC peripheral clock enabling */
2104 tmpreg = READ_BIT(RCC->APB1HLPENR, Periphs);
2105 (void)tmpreg;
2106 }
2107
2108 /**
2109 * @brief Check if APB1 peripheral clocks in Sleep mode is enabled or not
2110 * @rmtoll APB1HLPENR UART9LPEN LL_APB1_GRP2_IsEnabledClockSleep\n
2111 * APB1HLPENR UART12LPEN LL_APB1_GRP2_IsEnabledClockSleep\n
2112 * APB1HLPENR DTSLPEN LL_APB1_GRP2_IsEnabledClockSleep\n
2113 * APB1HLPENR LPTIM2LPEN LL_APB1_GRP2_IsEnabledClockSleep\n
2114 * APB1HLPENR FDCAN12LPEN LL_APB1_GRP2_IsEnabledClockSleep\n
2115 * APB1HLPENR FDCAN1LPEN LL_APB1_GRP2_IsEnabledClockSleep\n
2116 * APB1HLPENR UCPD1LPEN LL_APB1_GRP2_IsEnabledClockSleep
2117 * @param Periphs This parameter can be a combination of the following values:
2118 * @arg @ref LL_APB1_GRP2_PERIPH_ALL
2119 * @arg @ref LL_APB1_GRP2_PERIPH_UART9 (*)
2120 * @arg @ref LL_APB1_GRP2_PERIPH_UART12 (*)
2121 * @arg @ref LL_APB1_GRP2_PERIPH_DTS
2122 * @arg @ref LL_APB1_GRP2_PERIPH_LPTIM2
2123 * @arg @ref LL_APB1_GRP2_PERIPH_FDCAN12 (*)
2124 * @arg @ref LL_APB1_GRP2_PERIPH_FDCAN1 (*)
2125 * @arg @ref LL_APB1_GRP2_PERIPH_UCPD1
2126 *
2127 * (*) : Not available for all stm32h5xxxx family lines.
2128 * @retval State of Periphs (1 or 0).
2129 */
LL_APB1_GRP2_IsEnabledClockSleep(uint32_t Periphs)2130 __STATIC_INLINE uint32_t LL_APB1_GRP2_IsEnabledClockSleep(uint32_t Periphs)
2131 {
2132 return ((READ_BIT(RCC->APB1HLPENR, Periphs) == Periphs) ? 1UL : 0UL);
2133 }
2134
2135 /**
2136 * @brief Disable APB1 peripheral clocks in Sleep mode
2137 * @rmtoll APB1HLPENR UART9LPEN LL_APB1_GRP2_DisableClockSleep\n
2138 * APB1HLPENR UART12LPEN LL_APB1_GRP2_DisableClockSleep\n
2139 * APB1HLPENR DTSLPEN LL_APB1_GRP2_DisableClockSleep\n
2140 * APB1HLPENR LPTIM2LPEN LL_APB1_GRP2_DisableClockSleep\n
2141 * APB1HLPENR FDCAN12LPEN LL_APB1_GRP2_DisableClockSleep\n
2142 * APB1HLPENR FDCAN1LPEN LL_APB1_GRP2_DisableClockSleep\n
2143 * APB1HLPENR UCPD1LPEN LL_APB1_GRP2_DisableClockSleep
2144 * @param Periphs This parameter can be a combination of the following values:
2145 * @arg @ref LL_APB1_GRP2_PERIPH_ALL
2146 * @arg @ref LL_APB1_GRP2_PERIPH_UART9 (*)
2147 * @arg @ref LL_APB1_GRP2_PERIPH_UART12 (*)
2148 * @arg @ref LL_APB1_GRP2_PERIPH_DTS
2149 * @arg @ref LL_APB1_GRP2_PERIPH_LPTIM2
2150 * @arg @ref LL_APB1_GRP2_PERIPH_FDCAN12 (*)
2151 * @arg @ref LL_APB1_GRP2_PERIPH_FDCAN1 (*)
2152 * @arg @ref LL_APB1_GRP2_PERIPH_UCPD1
2153 *
2154 * (*) : Not available for all stm32h5xxxx family lines.
2155 * @retval None
2156 */
LL_APB1_GRP2_DisableClockSleep(uint32_t Periphs)2157 __STATIC_INLINE void LL_APB1_GRP2_DisableClockSleep(uint32_t Periphs)
2158 {
2159 CLEAR_BIT(RCC->APB1HLPENR, Periphs);
2160 }
2161
2162 /**
2163 * @}
2164 */
2165
2166 /** @defgroup BUS_LL_EF_APB2 APB2
2167 * @{
2168 */
2169
2170 /**
2171 * @brief Enable APB2 peripherals clock.
2172 * @rmtoll APB2ENR TIM1EN LL_APB2_GRP1_EnableClock\n
2173 * APB2ENR SPI1EN LL_APB2_GRP1_EnableClock\n
2174 * APB2ENR TIM8EN LL_APB2_GRP1_EnableClock\n
2175 * APB2ENR USART1EN LL_APB2_GRP1_EnableClock\n
2176 * APB2ENR TIM15EN LL_APB2_GRP1_EnableClock\n
2177 * APB2ENR TIM16EN LL_APB2_GRP1_EnableClock\n
2178 * APB2ENR TIM17EN LL_APB2_GRP1_EnableClock\n
2179 * APB2ENR SPI4EN LL_APB2_GRP1_EnableClock\n
2180 * APB2ENR SPI6EN LL_APB2_GRP1_EnableClock\n
2181 * APB2ENR SAI1EN LL_APB2_GRP1_EnableClock\n
2182 * APB2ENR SAI2EN LL_APB2_GRP1_EnableClock\n
2183 * APB2ENR USBEN LL_APB2_GRP1_EnableClock
2184 * @param Periphs This parameter can be a combination of the following values:
2185 * @arg @ref LL_APB2_GRP1_PERIPH_ALL
2186 * @arg @ref LL_APB2_GRP1_PERIPH_TIM1
2187 * @arg @ref LL_APB2_GRP1_PERIPH_SPI1
2188 * @arg @ref LL_APB2_GRP1_PERIPH_TIM8 (*)
2189 * @arg @ref LL_APB2_GRP1_PERIPH_USART1
2190 * @arg @ref LL_APB2_GRP1_PERIPH_TIM15 (*)
2191 * @arg @ref LL_APB2_GRP1_PERIPH_TIM16 (*)
2192 * @arg @ref LL_APB2_GRP1_PERIPH_TIM17 (*)
2193 * @arg @ref LL_APB2_GRP1_PERIPH_SPI4 (*)
2194 * @arg @ref LL_APB2_GRP1_PERIPH_SPI6 (*)
2195 * @arg @ref LL_APB2_GRP1_PERIPH_SAI1 (*)
2196 * @arg @ref LL_APB2_GRP1_PERIPH_SAI2 (*)
2197 * @arg @ref LL_APB2_GRP1_PERIPH_USB
2198 *
2199 * (*) : Not available for all stm32h5xxxx family lines.
2200 * @retval None
2201 */
LL_APB2_GRP1_EnableClock(uint32_t Periphs)2202 __STATIC_INLINE void LL_APB2_GRP1_EnableClock(uint32_t Periphs)
2203 {
2204 __IO uint32_t tmpreg;
2205 SET_BIT(RCC->APB2ENR, Periphs);
2206 /* Delay after an RCC peripheral clock enabling */
2207 tmpreg = READ_BIT(RCC->APB2ENR, Periphs);
2208 (void)tmpreg;
2209 }
2210
2211 /**
2212 * @brief Check if APB2 peripheral clock is enabled or not
2213 * @rmtoll APB2ENR TIM1EN LL_APB2_GRP1_IsEnabledClock\n
2214 * APB2ENR SPI1EN LL_APB2_GRP1_IsEnabledClock\n
2215 * APB2ENR TIM8EN LL_APB2_GRP1_IsEnabledClock\n
2216 * APB2ENR USART1EN LL_APB2_GRP1_IsEnabledClock\n
2217 * APB2ENR TIM15EN LL_APB2_GRP1_IsEnabledClock\n
2218 * APB2ENR TIM16EN LL_APB2_GRP1_IsEnabledClock\n
2219 * APB2ENR TIM17EN LL_APB2_GRP1_IsEnabledClock\n
2220 * APB2ENR SPI4EN LL_APB2_GRP1_IsEnabledClock\n
2221 * APB2ENR SPI6EN LL_APB2_GRP1_IsEnabledClock\n
2222 * APB2ENR SAI1EN LL_APB2_GRP1_IsEnabledClock\n
2223 * APB2ENR SAI2EN LL_APB2_GRP1_IsEnabledClock\n
2224 * APB2ENR USBEN LL_APB2_GRP1_IsEnabledClock
2225 * @param Periphs This parameter can be a combination of the following values:
2226 * @arg @ref LL_APB2_GRP1_PERIPH_ALL
2227 * @arg @ref LL_APB2_GRP1_PERIPH_TIM1
2228 * @arg @ref LL_APB2_GRP1_PERIPH_SPI1
2229 * @arg @ref LL_APB2_GRP1_PERIPH_TIM8 (*)
2230 * @arg @ref LL_APB2_GRP1_PERIPH_USART1
2231 * @arg @ref LL_APB2_GRP1_PERIPH_TIM15 (*)
2232 * @arg @ref LL_APB2_GRP1_PERIPH_TIM16 (*)
2233 * @arg @ref LL_APB2_GRP1_PERIPH_TIM17 (*)
2234 * @arg @ref LL_APB2_GRP1_PERIPH_SPI4 (*)
2235 * @arg @ref LL_APB2_GRP1_PERIPH_SPI6 (*)
2236 * @arg @ref LL_APB2_GRP1_PERIPH_SAI1 (*)
2237 * @arg @ref LL_APB2_GRP1_PERIPH_SAI2 (*)
2238 * @arg @ref LL_APB2_GRP1_PERIPH_USB
2239 *
2240 * (*) : Not available for all stm32h5xxxx family lines.
2241 * @retval State of Periphs (1 or 0).
2242 */
LL_APB2_GRP1_IsEnabledClock(uint32_t Periphs)2243 __STATIC_INLINE uint32_t LL_APB2_GRP1_IsEnabledClock(uint32_t Periphs)
2244 {
2245 return ((READ_BIT(RCC->APB2ENR, Periphs) == Periphs) ? 1UL : 0UL);
2246 }
2247
2248 /**
2249 * @brief Disable APB2 peripherals clock.
2250 * @rmtoll APB2ENR TIM1EN LL_APB2_GRP1_DisableClock\n
2251 * APB2ENR SPI1EN LL_APB2_GRP1_DisableClock\n
2252 * APB2ENR TIM8EN LL_APB2_GRP1_DisableClock\n
2253 * APB2ENR USART1EN LL_APB2_GRP1_DisableClock\n
2254 * APB2ENR TIM15EN LL_APB2_GRP1_DisableClock\n
2255 * APB2ENR TIM16EN LL_APB2_GRP1_DisableClock\n
2256 * APB2ENR TIM17EN LL_APB2_GRP1_DisableClock\n
2257 * APB2ENR SPI4EN LL_APB2_GRP1_DisableClock\n
2258 * APB2ENR SPI6EN LL_APB2_GRP1_DisableClock\n
2259 * APB2ENR SAI1EN LL_APB2_GRP1_DisableClock\n
2260 * APB2ENR SAI2EN LL_APB2_GRP1_DisableClock\n
2261 * APB2ENR USBEN LL_APB2_GRP1_DisableClock
2262 * @param Periphs This parameter can be a combination of the following values:
2263 * @arg @ref LL_APB2_GRP1_PERIPH_ALL
2264 * @arg @ref LL_APB2_GRP1_PERIPH_TIM1
2265 * @arg @ref LL_APB2_GRP1_PERIPH_SPI1
2266 * @arg @ref LL_APB2_GRP1_PERIPH_TIM8 (*)
2267 * @arg @ref LL_APB2_GRP1_PERIPH_USART1
2268 * @arg @ref LL_APB2_GRP1_PERIPH_TIM15 (*)
2269 * @arg @ref LL_APB2_GRP1_PERIPH_TIM16 (*)
2270 * @arg @ref LL_APB2_GRP1_PERIPH_TIM17 (*)
2271 * @arg @ref LL_APB2_GRP1_PERIPH_SPI4 (*)
2272 * @arg @ref LL_APB2_GRP1_PERIPH_SPI6 (*)
2273 * @arg @ref LL_APB2_GRP1_PERIPH_SAI1 (*)
2274 * @arg @ref LL_APB2_GRP1_PERIPH_SAI2 (*)
2275 * @arg @ref LL_APB2_GRP1_PERIPH_USB
2276 *
2277 * (*) : Not available for all stm32h5xxxx family lines.
2278 * @retval None
2279 */
LL_APB2_GRP1_DisableClock(uint32_t Periphs)2280 __STATIC_INLINE void LL_APB2_GRP1_DisableClock(uint32_t Periphs)
2281 {
2282 CLEAR_BIT(RCC->APB2ENR, Periphs);
2283 }
2284
2285 /**
2286 * @brief Force APB2 peripherals reset.
2287 * @rmtoll APB2RSTR TIM1RST LL_APB2_GRP1_ForceReset\n
2288 * APB2RSTR SPI1RST LL_APB2_GRP1_ForceReset\n
2289 * APB2RSTR TIM8RST LL_APB2_GRP1_ForceReset\n
2290 * APB2RSTR USART1RST LL_APB2_GRP1_ForceReset\n
2291 * APB2RSTR TIM15RST LL_APB2_GRP1_ForceReset\n
2292 * APB2RSTR TIM16RST LL_APB2_GRP1_ForceReset\n
2293 * APB2RSTR TIM17RST LL_APB2_GRP1_ForceReset\n
2294 * APB2RSTR SPI4RST LL_APB2_GRP1_ForceReset\n
2295 * APB2RSTR SPI6RST LL_APB2_GRP1_ForceReset\n
2296 * APB2RSTR SAI1RST LL_APB2_GRP1_ForceReset\n
2297 * APB2RSTR SAI2RST LL_APB2_GRP1_ForceReset\n
2298 * APB2RSTR USBRST LL_APB2_GRP1_ForceReset
2299 * @param Periphs This parameter can be a combination of the following values:
2300 * @arg @ref LL_APB2_GRP1_PERIPH_ALL
2301 * @arg @ref LL_APB2_GRP1_PERIPH_TIM1
2302 * @arg @ref LL_APB2_GRP1_PERIPH_SPI1
2303 * @arg @ref LL_APB2_GRP1_PERIPH_TIM8 (*)
2304 * @arg @ref LL_APB2_GRP1_PERIPH_USART1
2305 * @arg @ref LL_APB2_GRP1_PERIPH_TIM15 (*)
2306 * @arg @ref LL_APB2_GRP1_PERIPH_TIM16 (*)
2307 * @arg @ref LL_APB2_GRP1_PERIPH_TIM17 (*)
2308 * @arg @ref LL_APB2_GRP1_PERIPH_SPI4 (*)
2309 * @arg @ref LL_APB2_GRP1_PERIPH_SPI6 (*)
2310 * @arg @ref LL_APB2_GRP1_PERIPH_SAI1 (*)
2311 * @arg @ref LL_APB2_GRP1_PERIPH_SAI2 (*)
2312 * @arg @ref LL_APB2_GRP1_PERIPH_USB
2313 *
2314 * (*) : Not available for all stm32h5xxxx family lines.
2315 * @retval None
2316 */
LL_APB2_GRP1_ForceReset(uint32_t Periphs)2317 __STATIC_INLINE void LL_APB2_GRP1_ForceReset(uint32_t Periphs)
2318 {
2319 SET_BIT(RCC->APB2RSTR, Periphs);
2320 }
2321
2322 /**
2323 * @brief Release APB2 peripherals reset.
2324 * @rmtoll APB2RSTR TIM1RST LL_APB2_GRP1_ReleaseReset\n
2325 * APB2RSTR SPI1RST LL_APB2_GRP1_ReleaseReset\n
2326 * APB2RSTR TIM8RST LL_APB2_GRP1_ReleaseReset\n
2327 * APB2RSTR USART1RST LL_APB2_GRP1_ReleaseReset\n
2328 * APB2RSTR TIM15RST LL_APB2_GRP1_ReleaseReset\n
2329 * APB2RSTR TIM16RST LL_APB2_GRP1_ReleaseReset\n
2330 * APB2RSTR TIM17RST LL_APB2_GRP1_ReleaseReset\n
2331 * APB2RSTR SPI4RST LL_APB2_GRP1_ReleaseReset\n
2332 * APB2RSTR SPI6RST LL_APB2_GRP1_ReleaseReset\n
2333 * APB2RSTR SAI1RST LL_APB2_GRP1_ReleaseReset\n
2334 * APB2RSTR SAI2RST LL_APB2_GRP1_ReleaseReset\n
2335 * APB2RSTR USBRST LL_APB2_GRP1_ReleaseReset
2336 * @param Periphs This parameter can be a combination of the following values:
2337 * @arg @ref LL_APB2_GRP1_PERIPH_ALL
2338 * @arg @ref LL_APB2_GRP1_PERIPH_TIM1
2339 * @arg @ref LL_APB2_GRP1_PERIPH_SPI1
2340 * @arg @ref LL_APB2_GRP1_PERIPH_TIM8
2341 * @arg @ref LL_APB2_GRP1_PERIPH_USART1 (*)
2342 * @arg @ref LL_APB2_GRP1_PERIPH_TIM15 (*)
2343 * @arg @ref LL_APB2_GRP1_PERIPH_TIM16 (*)
2344 * @arg @ref LL_APB2_GRP1_PERIPH_TIM17 (*)
2345 * @arg @ref LL_APB2_GRP1_PERIPH_SPI4 (*)
2346 * @arg @ref LL_APB2_GRP1_PERIPH_SPI6 (*)
2347 * @arg @ref LL_APB2_GRP1_PERIPH_SAI1 (*)
2348 * @arg @ref LL_APB2_GRP1_PERIPH_SAI2 (*)
2349 * @arg @ref LL_APB2_GRP1_PERIPH_USB
2350 *
2351 * (*) : Not available for all stm32h5xxxx family lines.
2352 * @retval None
2353 */
LL_APB2_GRP1_ReleaseReset(uint32_t Periphs)2354 __STATIC_INLINE void LL_APB2_GRP1_ReleaseReset(uint32_t Periphs)
2355 {
2356 CLEAR_BIT(RCC->APB2RSTR, Periphs);
2357 }
2358
2359 /**
2360 * @brief Enable APB2 peripheral clocks in Sleep mode
2361 * @rmtoll APB2LPENR TIM1LPEN LL_APB2_GRP1_EnableClockSleep\n
2362 * APB2LPENR SPI1LPEN LL_APB2_GRP1_EnableClockSleep\n
2363 * APB2LPENR TIM8LPEN LL_APB2_GRP1_EnableClockSleep\n
2364 * APB2LPENR USART1LPEN LL_APB2_GRP1_EnableClockSleep\n
2365 * APB2LPENR TIM15LPEN LL_APB2_GRP1_EnableClockSleep\n
2366 * APB2LPENR TIM16LPEN LL_APB2_GRP1_EnableClockSleep\n
2367 * APB2LPENR TIM17LPEN LL_APB2_GRP1_EnableClockSleep\n
2368 * APB2LPENR SPI4LPEN LL_APB2_GRP1_EnableClockSleep\n
2369 * APB2LPENR SPI6LPEN LL_APB2_GRP1_EnableClockSleep\n
2370 * APB2LPENR SAI1LPEN LL_APB2_GRP1_EnableClockSleep\n
2371 * APB2LPENR SAI2LPEN LL_APB2_GRP1_EnableClockSleep\n
2372 * APB2LPENR USBLPEN LL_APB2_GRP1_EnableClockSleep
2373 * @param Periphs This parameter can be a combination of the following values:
2374 * @arg @ref LL_APB2_GRP1_PERIPH_ALL
2375 * @arg @ref LL_APB2_GRP1_PERIPH_TIM1
2376 * @arg @ref LL_APB2_GRP1_PERIPH_SPI1
2377 * @arg @ref LL_APB2_GRP1_PERIPH_TIM8 (*)
2378 * @arg @ref LL_APB2_GRP1_PERIPH_USART1
2379 * @arg @ref LL_APB2_GRP1_PERIPH_TIM15 (*)
2380 * @arg @ref LL_APB2_GRP1_PERIPH_TIM16 (*)
2381 * @arg @ref LL_APB2_GRP1_PERIPH_TIM17 (*)
2382 * @arg @ref LL_APB2_GRP1_PERIPH_SPI4 (*)
2383 * @arg @ref LL_APB2_GRP1_PERIPH_SPI6 (*)
2384 * @arg @ref LL_APB2_GRP1_PERIPH_SAI1 (*)
2385 * @arg @ref LL_APB2_GRP1_PERIPH_SAI2 (*)
2386 * @arg @ref LL_APB2_GRP1_PERIPH_USB
2387 *
2388 * (*) : Not available for all stm32h5xxxx family lines.
2389 * @retval None
2390 */
LL_APB2_GRP1_EnableClockSleep(uint32_t Periphs)2391 __STATIC_INLINE void LL_APB2_GRP1_EnableClockSleep(uint32_t Periphs)
2392 {
2393 __IO uint32_t tmpreg;
2394 SET_BIT(RCC->APB2LPENR, Periphs);
2395 /* Delay after an RCC peripheral clock enabling */
2396 tmpreg = READ_BIT(RCC->APB2LPENR, Periphs);
2397 (void)tmpreg;
2398 }
2399
2400
2401 /**
2402 * @brief Check if APB2 peripheral clocks in Sleep and Stop modes is enabled or not
2403 * @rmtoll APB2LPENR TIM1LPEN LL_APB2_GRP1_IsEnabledClockSleep\n
2404 * APB2LPENR SPI1LPEN LL_APB2_GRP1_IsEnabledClockSleep\n
2405 * APB2LPENR TIM8LPEN LL_APB2_GRP1_IsEnabledClockSleep\n
2406 * APB2LPENR USART1LPEN LL_APB2_GRP1_IsEnabledClockSleep\n
2407 * APB2LPENR TIM15LPEN LL_APB2_GRP1_IsEnabledClockSleep\n
2408 * APB2LPENR TIM16LPEN LL_APB2_GRP1_IsEnabledClockSleep\n
2409 * APB2LPENR TIM17LPEN LL_APB2_GRP1_IsEnabledClockSleep\n
2410 * APB2LPENR SPI4LPEN LL_APB2_GRP1_IsEnabledClockSleep\n
2411 * APB2LPENR SPI6LPEN LL_APB2_GRP1_IsEnabledClockSleep\n
2412 * APB2LPENR SAI1LPEN LL_APB2_GRP1_IsEnabledClockSleep\n
2413 * APB2LPENR SAI2LPEN LL_APB2_GRP1_IsEnabledClockSleep\n
2414 * APB2LPENR USBLPEN LL_APB2_GRP1_IsEnabledClockSleep
2415 * @param Periphs This parameter can be a combination of the following values:
2416 * @arg @ref LL_APB2_GRP1_PERIPH_ALL
2417 * @arg @ref LL_APB2_GRP1_PERIPH_TIM1
2418 * @arg @ref LL_APB2_GRP1_PERIPH_SPI1
2419 * @arg @ref LL_APB2_GRP1_PERIPH_TIM8 (*)
2420 * @arg @ref LL_APB2_GRP1_PERIPH_USART1
2421 * @arg @ref LL_APB2_GRP1_PERIPH_TIM15 (*)
2422 * @arg @ref LL_APB2_GRP1_PERIPH_TIM16 (*)
2423 * @arg @ref LL_APB2_GRP1_PERIPH_TIM17 (*)
2424 * @arg @ref LL_APB2_GRP1_PERIPH_SPI4 (*)
2425 * @arg @ref LL_APB2_GRP1_PERIPH_SPI6 (*)
2426 * @arg @ref LL_APB2_GRP1_PERIPH_SAI1 (*)
2427 * @arg @ref LL_APB2_GRP1_PERIPH_SAI2 (*)
2428 * @arg @ref LL_APB2_GRP1_PERIPH_USB
2429 *
2430 * (*) : Not available for all stm32h5xxxx family lines.
2431 * @retval State of Periphs (1 or 0).
2432 */
LL_APB2_GRP1_IsEnabledClockSleep(uint32_t Periphs)2433 __STATIC_INLINE uint32_t LL_APB2_GRP1_IsEnabledClockSleep(uint32_t Periphs)
2434 {
2435 return ((READ_BIT(RCC->APB2LPENR, Periphs) == Periphs) ? 1UL : 0UL);
2436 }
2437
2438 /**
2439 * @brief Disable APB2 peripheral clocks in Sleep mode
2440 * @rmtoll APB2LPENR TIM1LPEN LL_APB2_GRP1_DisableClockSleep\n
2441 * APB2LPENR SPI1LPEN LL_APB2_GRP1_DisableClockSleep\n
2442 * APB2LPENR TIM8LPEN LL_APB2_GRP1_DisableClockSleep\n
2443 * APB2LPENR USART1LPEN LL_APB2_GRP1_DisableClockSleep\n
2444 * APB2LPENR TIM15LPEN LL_APB2_GRP1_DisableClockSleep\n
2445 * APB2LPENR TIM16LPEN LL_APB2_GRP1_DisableClockSleep\n
2446 * APB2LPENR TIM17LPEN LL_APB2_GRP1_DisableClockSleep\n
2447 * APB2LPENR SPI4LPEN LL_APB2_GRP1_DisableClockSleep\n
2448 * APB2LPENR SPI6LPEN LL_APB2_GRP1_DisableClockSleep\n
2449 * APB2LPENR SAI1LPEN LL_APB2_GRP1_DisableClockSleep\n
2450 * APB2LPENR SAI2LPEN LL_APB2_GRP1_DisableClockSleep\n
2451 * APB2LPENR USBLPEN LL_APB2_GRP1_DisableClockSleep
2452 * @param Periphs This parameter can be a combination of the following values:
2453 * @arg @ref LL_APB2_GRP1_PERIPH_ALL
2454 * @arg @ref LL_APB2_GRP1_PERIPH_TIM1
2455 * @arg @ref LL_APB2_GRP1_PERIPH_SPI1
2456 * @arg @ref LL_APB2_GRP1_PERIPH_TIM8 (*)
2457 * @arg @ref LL_APB2_GRP1_PERIPH_USART1
2458 * @arg @ref LL_APB2_GRP1_PERIPH_TIM15 (*)
2459 * @arg @ref LL_APB2_GRP1_PERIPH_TIM16 (*)
2460 * @arg @ref LL_APB2_GRP1_PERIPH_TIM17 (*)
2461 * @arg @ref LL_APB2_GRP1_PERIPH_SPI4 (*)
2462 * @arg @ref LL_APB2_GRP1_PERIPH_SPI6 (*)
2463 * @arg @ref LL_APB2_GRP1_PERIPH_SAI1 (*)
2464 * @arg @ref LL_APB2_GRP1_PERIPH_SAI2 (*)
2465 * @arg @ref LL_APB2_GRP1_PERIPH_USB
2466 *
2467 * (*) : Not available for all stm32h5xxxx family lines.
2468 * @retval None
2469 */
LL_APB2_GRP1_DisableClockSleep(uint32_t Periphs)2470 __STATIC_INLINE void LL_APB2_GRP1_DisableClockSleep(uint32_t Periphs)
2471 {
2472 CLEAR_BIT(RCC->APB2LPENR, Periphs);
2473 }
2474
2475 /**
2476 * @}
2477 */
2478
2479
2480 /** @defgroup BUS_LL_EF_APB3 APB3
2481 * @{
2482 */
2483
2484 /**
2485 * @brief Enable APB3 peripherals clock.
2486 * @rmtoll APB3ENR SBSEN LL_APB3_GRP1_EnableClock\n
2487 * APB3ENR SPI5EN LL_APB3_GRP1_EnableClock\n
2488 * APB3ENR LPUART1EN LL_APB3_GRP1_EnableClock\n
2489 * APB3ENR I2C3EN LL_APB3_GRP1_EnableClock\n
2490 * APB3ENR I2C4EN LL_APB3_GRP1_EnableClock\n
2491 * APB3ENR LPTIM1EN LL_APB3_GRP1_EnableClock\n
2492 * APB3ENR LPTIM3EN LL_APB3_GRP1_EnableClock\n
2493 * APB3ENR LPTIM4EN LL_APB3_GRP1_EnableClock\n
2494 * APB3ENR LPTIM5EN LL_APB3_GRP1_EnableClock\n
2495 * APB3ENR LPTIM6EN LL_APB3_GRP1_EnableClock\n
2496 * APB3ENR VREFEN LL_APB3_GRP1_EnableClock\n
2497 * APB3ENR RTCAPBEN LL_APB3_GRP1_EnableClock
2498 * @param Periphs This parameter can be a combination of the following values:
2499 * @arg @ref LL_APB3_GRP1_PERIPH_ALL
2500 * @arg @ref LL_APB3_GRP1_PERIPH_SBS
2501 * @arg @ref LL_APB3_GRP1_PERIPH_SPI5 (*)
2502 * @arg @ref LL_APB3_GRP1_PERIPH_LPUART1
2503 * @arg @ref LL_APB3_GRP1_PERIPH_I2C3 (*)
2504 * @arg @ref LL_APB3_GRP1_PERIPH_I2C4 (*)
2505 * @arg @ref LL_APB3_GRP1_PERIPH_I3C2 (*)
2506 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM1
2507 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM3 (*)
2508 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM4 (*)
2509 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM5 (*)
2510 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM6 (*)
2511 * @arg @ref LL_APB3_GRP1_PERIPH_VREF
2512 * @arg @ref LL_APB3_GRP1_PERIPH_RTCAPB
2513 *
2514 * (*) : Not available for all stm32h5xxxx family lines.
2515 * @retval None
2516 */
LL_APB3_GRP1_EnableClock(uint32_t Periphs)2517 __STATIC_INLINE void LL_APB3_GRP1_EnableClock(uint32_t Periphs)
2518 {
2519 __IO uint32_t tmpreg;
2520 SET_BIT(RCC->APB3ENR, Periphs);
2521 /* Delay after an RCC peripheral clock enabling */
2522 tmpreg = READ_BIT(RCC->APB3ENR, Periphs);
2523 (void)tmpreg;
2524 }
2525
2526 /**
2527 * @brief Check if APB3 peripheral clock is enabled or not
2528 * @rmtoll APB3ENR SBSEN LL_APB3_GRP1_IsEnabledClock\n
2529 * APB3ENR SPI5EN LL_APB3_GRP1_IsEnabledClock\n
2530 * APB3ENR LPUART1EN LL_APB3_GRP1_IsEnabledClock\n
2531 * APB3ENR I2C3EN LL_APB3_GRP1_IsEnabledClock\n
2532 * APB3ENR I2C4EN LL_APB3_GRP1_IsEnabledClock\n
2533 * APB3ENR LPTIM1EN LL_APB3_GRP1_IsEnabledClock\n
2534 * APB3ENR LPTIM3EN LL_APB3_GRP1_IsEnabledClock\n
2535 * APB3ENR LPTIM4EN LL_APB3_GRP1_IsEnabledClock\n
2536 * APB3ENR LPTIM5EN LL_APB3_GRP1_IsEnabledClock\n
2537 * APB3ENR LPTIM6EN LL_APB3_GRP1_IsEnabledClock\n
2538 * APB3ENR VREFEN LL_APB3_GRP1_IsEnabledClock\n
2539 * APB3ENR RTCAPBEN LL_APB3_GRP1_IsEnabledClock
2540 * @param Periphs This parameter can be a combination of the following values:
2541 * @arg @ref LL_APB3_GRP1_PERIPH_ALL
2542 * @arg @ref LL_APB3_GRP1_PERIPH_SBS
2543 * @arg @ref LL_APB3_GRP1_PERIPH_SPI5 (*)
2544 * @arg @ref LL_APB3_GRP1_PERIPH_LPUART1
2545 * @arg @ref LL_APB3_GRP1_PERIPH_I2C3 (*)
2546 * @arg @ref LL_APB3_GRP1_PERIPH_I2C4 (*)
2547 * @arg @ref LL_APB3_GRP1_PERIPH_I3C2 (*)
2548 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM1
2549 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM3 (*)
2550 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM4 (*)
2551 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM5 (*)
2552 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM6 (*)
2553 * @arg @ref LL_APB3_GRP1_PERIPH_VREF
2554 * @arg @ref LL_APB3_GRP1_PERIPH_RTCAPB
2555 *
2556 * (*) : Not available for all stm32h5xxxx family lines.
2557 * @retval State of Periphs (1 or 0).
2558 */
LL_APB3_GRP1_IsEnabledClock(uint32_t Periphs)2559 __STATIC_INLINE uint32_t LL_APB3_GRP1_IsEnabledClock(uint32_t Periphs)
2560 {
2561 return ((READ_BIT(RCC->APB3ENR, Periphs) == Periphs) ? 1UL : 0UL);
2562 }
2563
2564 /**
2565 * @brief Disable APB2 peripherals clock.
2566 * @rmtoll APB3ENR SBSEN LL_APB3_GRP1_DisableClock\n
2567 * APB3ENR SPI5EN LL_APB3_GRP1_DisableClock\n
2568 * APB3ENR LPUART1EN LL_APB3_GRP1_DisableClock\n
2569 * APB3ENR I2C3EN LL_APB3_GRP1_DisableClock\n
2570 * APB3ENR I2C4EN LL_APB3_GRP1_DisableClock\n
2571 * APB3ENR LPTIM1EN LL_APB3_GRP1_DisableClock\n
2572 * APB3ENR LPTIM3EN LL_APB3_GRP1_DisableClock\n
2573 * APB3ENR LPTIM4EN LL_APB3_GRP1_DisableClock\n
2574 * APB3ENR LPTIM5EN LL_APB3_GRP1_DisableClock\n
2575 * APB3ENR LPTIM6EN LL_APB3_GRP1_DisableClock\n
2576 * APB3ENR VREFEN LL_APB3_GRP1_DisableClock\n
2577 * APB3ENR RTCAPBEN LL_APB3_GRP1_DisableClock
2578 * @param Periphs This parameter can be a combination of the following values:
2579 * @arg @ref LL_APB3_GRP1_PERIPH_ALL
2580 * @arg @ref LL_APB3_GRP1_PERIPH_SBS
2581 * @arg @ref LL_APB3_GRP1_PERIPH_SPI5 (*)
2582 * @arg @ref LL_APB3_GRP1_PERIPH_LPUART1
2583 * @arg @ref LL_APB3_GRP1_PERIPH_I2C3 (*)
2584 * @arg @ref LL_APB3_GRP1_PERIPH_I2C4 (*)
2585 * @arg @ref LL_APB3_GRP1_PERIPH_I3C2 (*)
2586 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM1
2587 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM3 (*)
2588 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM4 (*)
2589 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM5 (*)
2590 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM6 (*)
2591 * @arg @ref LL_APB3_GRP1_PERIPH_VREF
2592 * @arg @ref LL_APB3_GRP1_PERIPH_RTCAPB
2593 *
2594 * (*) : Not available for all stm32h5xxxx family lines.
2595 * @retval None
2596 */
LL_APB3_GRP1_DisableClock(uint32_t Periphs)2597 __STATIC_INLINE void LL_APB3_GRP1_DisableClock(uint32_t Periphs)
2598 {
2599 CLEAR_BIT(RCC->APB3ENR, Periphs);
2600 }
2601
2602 /**
2603 * @brief Force APB3 peripherals reset.
2604 * @rmtoll APB3RSTR SPI5RST LL_APB3_GRP1_ForceReset\n
2605 * APB3RSTR LPUART1RST LL_APB3_GRP1_ForceReset\n
2606 * APB3RSTR I2C3RST LL_APB3_GRP1_ForceReset\n
2607 * APB3RSTR I2C4RST LL_APB3_GRP1_ForceReset\n
2608 * APB3RSTR LPTIM1RST LL_APB3_GRP1_ForceReset\n
2609 * APB3RSTR LPTIM3RST LL_APB3_GRP1_ForceReset\n
2610 * APB3RSTR LPTIM4RST LL_APB3_GRP1_ForceReset\n
2611 * APB3RSTR LPTIM5RST LL_APB3_GRP1_ForceReset\n
2612 * APB3RSTR LPTIM6RST LL_APB3_GRP1_ForceReset\n
2613 * APB3RSTR VREFRST LL_APB3_GRP1_ForceReset
2614 * @param Periphs This parameter can be a combination of the following values:
2615 * @arg @ref LL_APB3_GRP1_PERIPH_ALL
2616 * @arg @ref LL_APB3_GRP1_PERIPH_SBS
2617 * @arg @ref LL_APB3_GRP1_PERIPH_SPI5 (*)
2618 * @arg @ref LL_APB3_GRP1_PERIPH_LPUART1
2619 * @arg @ref LL_APB3_GRP1_PERIPH_I2C3 (*)
2620 * @arg @ref LL_APB3_GRP1_PERIPH_I2C4 (*)
2621 * @arg @ref LL_APB3_GRP1_PERIPH_I3C2 (*)
2622 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM1
2623 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM3 (*)
2624 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM4 (*)
2625 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM5 (*)
2626 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM6 (*)
2627 * @arg @ref LL_APB3_GRP1_PERIPH_VREF
2628 *
2629 * (*) : Not available for all stm32h5xxxx family lines.
2630 * @retval None
2631 */
LL_APB3_GRP1_ForceReset(uint32_t Periphs)2632 __STATIC_INLINE void LL_APB3_GRP1_ForceReset(uint32_t Periphs)
2633 {
2634 SET_BIT(RCC->APB3RSTR, Periphs);
2635 }
2636
2637 /**
2638 * @brief Release APB3 peripherals reset.
2639 * @rmtoll APB3RSTR SPI5RST LL_APB3_GRP1_ReleaseReset\n
2640 * APB3RSTR LPUART1RST LL_APB3_GRP1_ReleaseReset\n
2641 * APB3RSTR I2C3RST LL_APB3_GRP1_ReleaseReset\n
2642 * APB3RSTR I2C4RST LL_APB3_GRP1_ReleaseReset\n
2643 * APB3RSTR LPTIM1RST LL_APB3_GRP1_ReleaseReset\n
2644 * APB3RSTR LPTIM3RST LL_APB3_GRP1_ReleaseReset\n
2645 * APB3RSTR LPTIM4RST LL_APB3_GRP1_ReleaseReset\n
2646 * APB3RSTR LPTIM5RST LL_APB3_GRP1_ReleaseReset\n
2647 * APB3RSTR LPTIM6RST LL_APB3_GRP1_ReleaseReset\n
2648 * APB3RSTR VREFRST LL_APB3_GRP1_ReleaseReset
2649 * @param Periphs This parameter can be a combination of the following values:
2650 * @arg @ref LL_APB3_GRP1_PERIPH_ALL
2651 * @arg @ref LL_APB3_GRP1_PERIPH_SBS
2652 * @arg @ref LL_APB3_GRP1_PERIPH_SPI5 (*)
2653 * @arg @ref LL_APB3_GRP1_PERIPH_LPUART1
2654 * @arg @ref LL_APB3_GRP1_PERIPH_I2C3 (*)
2655 * @arg @ref LL_APB3_GRP1_PERIPH_I2C4 (*)
2656 * @arg @ref LL_APB3_GRP1_PERIPH_I3C2 (*)
2657 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM1
2658 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM3 (*)
2659 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM4 (*)
2660 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM5 (*)
2661 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM6 (*)
2662 * @arg @ref LL_APB3_GRP1_PERIPH_VREF
2663 *
2664 * (*) : Not available for all stm32h5xxxx family lines.
2665 * @retval None
2666 */
LL_APB3_GRP1_ReleaseReset(uint32_t Periphs)2667 __STATIC_INLINE void LL_APB3_GRP1_ReleaseReset(uint32_t Periphs)
2668 {
2669 CLEAR_BIT(RCC->APB3RSTR, Periphs);
2670 }
2671
2672 /**
2673 * @brief Enable APB3 peripheral clocks in Sleep mode
2674 * @rmtoll APB3LPENR SBSLPEN LL_APB3_GRP1_EnableClockSleep\n
2675 * APB3LPENR SPI5LPEN LL_APB3_GRP1_EnableClockSleep\n
2676 * APB3LPENR LPUART1LPEN LL_APB3_GRP1_EnableClockSleep\n
2677 * APB3LPENR I2C3LPEN LL_APB3_GRP1_EnableClockSleep\n
2678 * APB3LPENR I2C4LPEN LL_APB3_GRP1_EnableClockSleep\n
2679 * APB3LPENR LPTIM1LPEN LL_APB3_GRP1_EnableClockSleep\n
2680 * APB3LPENR LPTIM3LPEN LL_APB3_GRP1_EnableClockSleep\n
2681 * APB3LPENR LPTIM4LPEN LL_APB3_GRP1_EnableClockSleep\n
2682 * APB3LPENR LPTIM5LPEN LL_APB3_GRP1_EnableClockSleep\n
2683 * APB3LPENR LPTIM6LPEN LL_APB3_GRP1_EnableClockSleep\n
2684 * APB3LPENR VREFLPEN LL_APB3_GRP1_EnableClockSleep\n
2685 * APB3LPENR RTCAPBLPEN LL_APB3_GRP1_EnableClockSleep
2686 * @param Periphs This parameter can be a combination of the following values:
2687 * @arg @ref LL_APB3_GRP1_PERIPH_ALL
2688 * @arg @ref LL_APB3_GRP1_PERIPH_SBS
2689 * @arg @ref LL_APB3_GRP1_PERIPH_SPI5 (*)
2690 * @arg @ref LL_APB3_GRP1_PERIPH_LPUART1
2691 * @arg @ref LL_APB3_GRP1_PERIPH_I2C3 (*)
2692 * @arg @ref LL_APB3_GRP1_PERIPH_I2C4 (*)
2693 * @arg @ref LL_APB3_GRP1_PERIPH_I3C2 (*)
2694 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM1
2695 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM3 (*)
2696 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM4 (*)
2697 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM5 (*)
2698 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM6 (*)
2699 * @arg @ref LL_APB3_GRP1_PERIPH_VREF
2700 * @arg @ref LL_APB3_GRP1_PERIPH_RTCAPB
2701 *
2702 * (*) : Not available for all stm32h5xxxx family lines.
2703 * @retval None
2704 */
LL_APB3_GRP1_EnableClockSleep(uint32_t Periphs)2705 __STATIC_INLINE void LL_APB3_GRP1_EnableClockSleep(uint32_t Periphs)
2706 {
2707 __IO uint32_t tmpreg;
2708 SET_BIT(RCC->APB3LPENR, Periphs);
2709 /* Delay after an RCC peripheral clock enabling */
2710 tmpreg = READ_BIT(RCC->APB3LPENR, Periphs);
2711 (void)tmpreg;
2712 }
2713
2714
2715 /**
2716 * @brief Check if APB3 peripheral clocks in Sleep mode is enabled or not
2717 * @rmtoll APB3LPENR SBSLPEN LL_APB3_GRP1_IsEnabledClockSleep\n
2718 * APB3LPENR SPI5LPEN LL_APB3_GRP1_IsEnabledClockSleep\n
2719 * APB3LPENR LPUART1LPEN LL_APB3_GRP1_IsEnabledClockSleep\n
2720 * APB3LPENR I2C3LPEN LL_APB3_GRP1_IsEnabledClockSleep\n
2721 * APB3LPENR I2C4LPEN LL_APB3_GRP1_IsEnabledClockSleep\n
2722 * APB3LPENR LPTIM1LPEN LL_APB3_GRP1_IsEnabledClockSleep\n
2723 * APB3LPENR LPTIM3LPEN LL_APB3_GRP1_IsEnabledClockSleep\n
2724 * APB3LPENR LPTIM4LPEN LL_APB3_GRP1_IsEnabledClockSleep\n
2725 * APB3LPENR LPTIM5LPEN LL_APB3_GRP1_IsEnabledClockSleep\n
2726 * APB3LPENR LPTIM6LPEN LL_APB3_GRP1_IsEnabledClockSleep\n
2727 * APB3LPENR VREFLPEN LL_APB3_GRP1_IsEnabledClockSleep\n
2728 * APB3LPENR RTCAPBLPEN LL_APB3_GRP1_IsEnabledClockSleep
2729 * @param Periphs This parameter can be a combination of the following values:
2730 * @arg @ref LL_APB3_GRP1_PERIPH_ALL
2731 * @arg @ref LL_APB3_GRP1_PERIPH_SBS
2732 * @arg @ref LL_APB3_GRP1_PERIPH_SPI5 (*)
2733 * @arg @ref LL_APB3_GRP1_PERIPH_LPUART1
2734 * @arg @ref LL_APB3_GRP1_PERIPH_I2C3 (*)
2735 * @arg @ref LL_APB3_GRP1_PERIPH_I2C4 (*)
2736 * @arg @ref LL_APB3_GRP1_PERIPH_I3C2 (*)
2737 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM1
2738 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM3 (*)
2739 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM4 (*)
2740 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM5 (*)
2741 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM6 (*)
2742 * @arg @ref LL_APB3_GRP1_PERIPH_VREF
2743 * @arg @ref LL_APB3_GRP1_PERIPH_RTCAPB
2744 *
2745 * (*) : Not available for all stm32h5xxxx family lines.
2746 * @retval State of Periphs (1 or 0).
2747 */
LL_APB3_GRP1_IsEnabledClockSleep(uint32_t Periphs)2748 __STATIC_INLINE uint32_t LL_APB3_GRP1_IsEnabledClockSleep(uint32_t Periphs)
2749 {
2750 return ((READ_BIT(RCC->APB3LPENR, Periphs) == Periphs) ? 1UL : 0UL);
2751 }
2752
2753 /**
2754 * @brief Disable APB3 peripheral clocks in Sleep mode
2755 * @rmtoll APB3LPENR SBSLPEN LL_APB3_GRP1_DisableClockSleep\n
2756 * APB3LPENR SPI5LPEN LL_APB3_GRP1_DisableClockSleep\n
2757 * APB3LPENR LPUART1LPEN LL_APB3_GRP1_DisableClockSleep\n
2758 * APB3LPENR I2C3LPEN LL_APB3_GRP1_DisableClockSleep\n
2759 * APB3LPENR I2C4LPEN LL_APB3_GRP1_DisableClockSleep\n
2760 * APB3LPENR LPTIM1LPEN LL_APB3_GRP1_DisableClockSleep\n
2761 * APB3LPENR LPTIM3LPEN LL_APB3_GRP1_DisableClockSleep\n
2762 * APB3LPENR LPTIM4LPEN LL_APB3_GRP1_DisableClockSleep\n
2763 * APB3LPENR LPTIM5LPEN LL_APB3_GRP1_DisableClockSleep\n
2764 * APB3LPENR LPTIM6LPEN LL_APB3_GRP1_DisableClockSleep\n
2765 * APB3LPENR VREFLPEN LL_APB3_GRP1_DisableClockSleep\n
2766 * APB3LPENR RTCAPBLPEN LL_APB3_GRP1_DisableClockSleep
2767 * @param Periphs This parameter can be a combination of the following values:
2768 * @arg @ref LL_APB3_GRP1_PERIPH_ALL
2769 * @arg @ref LL_APB3_GRP1_PERIPH_SBS
2770 * @arg @ref LL_APB3_GRP1_PERIPH_SPI5 (*)
2771 * @arg @ref LL_APB3_GRP1_PERIPH_LPUART1
2772 * @arg @ref LL_APB3_GRP1_PERIPH_I2C3 (*)
2773 * @arg @ref LL_APB3_GRP1_PERIPH_I2C4 (*)
2774 * @arg @ref LL_APB3_GRP1_PERIPH_I3C2 (*)
2775 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM1
2776 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM3 (*)
2777 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM4 (*)
2778 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM5 (*)
2779 * @arg @ref LL_APB3_GRP1_PERIPH_LPTIM6 (*)
2780 * @arg @ref LL_APB3_GRP1_PERIPH_VREF
2781 * @arg @ref LL_APB3_GRP1_PERIPH_RTCAPB
2782 *
2783 * (*) : Not available for all stm32h5xxxx family lines.
2784 * @retval None
2785 */
LL_APB3_GRP1_DisableClockSleep(uint32_t Periphs)2786 __STATIC_INLINE void LL_APB3_GRP1_DisableClockSleep(uint32_t Periphs)
2787 {
2788 CLEAR_BIT(RCC->APB3LPENR, Periphs);
2789 }
2790
2791 /**
2792 * @}
2793 */
2794
2795 /**
2796 * @}
2797 */
2798 #endif /* defined(RCC) */
2799
2800 /**
2801 * @}
2802 */
2803
2804 #ifdef __cplusplus
2805 }
2806 #endif
2807
2808 #endif /* __STM32H5xx_LL_BUS_H */
2809