]> git.sur5r.net Git - freertos/blob
5111e73fe1c9537179bb7417209b38f69ddae8f4
[freertos] /
1 /**\r
2   ******************************************************************************\r
3   * @file    stm32l4xx_hal_rcc.h\r
4   * @author  MCD Application Team\r
5   * @brief   Header file of RCC HAL module.\r
6   ******************************************************************************\r
7   * @attention\r
8   *\r
9   * <h2><center>&copy; Copyright (c) 2017 STMicroelectronics.\r
10   * All rights reserved.</center></h2>\r
11   *\r
12   * This software component is licensed by ST under BSD 3-Clause license,\r
13   * the "License"; You may not use this file except in compliance with the\r
14   * License. You may obtain a copy of the License at:\r
15   *                        opensource.org/licenses/BSD-3-Clause\r
16   *\r
17   ******************************************************************************\r
18   */\r
19 \r
20 /* Define to prevent recursive inclusion -------------------------------------*/\r
21 #ifndef __STM32L4xx_HAL_RCC_H\r
22 #define __STM32L4xx_HAL_RCC_H\r
23 \r
24 #ifdef __cplusplus\r
25  extern "C" {\r
26 #endif\r
27 \r
28 /* Includes ------------------------------------------------------------------*/\r
29 #include "stm32l4xx_hal_def.h"\r
30 \r
31 /** @addtogroup STM32L4xx_HAL_Driver\r
32   * @{\r
33   */\r
34 \r
35 /** @addtogroup RCC\r
36   * @{\r
37   */\r
38 \r
39 /* Exported types ------------------------------------------------------------*/\r
40 /** @defgroup RCC_Exported_Types RCC Exported Types\r
41   * @{\r
42   */\r
43 \r
44 /**\r
45   * @brief  RCC PLL configuration structure definition\r
46   */\r
47 typedef struct\r
48 {\r
49   uint32_t PLLState;   /*!< The new state of the PLL.\r
50                             This parameter can be a value of @ref RCC_PLL_Config                      */\r
51 \r
52   uint32_t PLLSource;  /*!< RCC_PLLSource: PLL entry clock source.\r
53                             This parameter must be a value of @ref RCC_PLL_Clock_Source               */\r
54 \r
55   uint32_t PLLM;       /*!< PLLM: Division factor for PLL VCO input clock.\r
56                             This parameter must be a number between Min_Data = 1 and Max_Data = 16 on STM32L4Rx/STM32L4Sx devices.\r
57                             This parameter must be a number between Min_Data = 1 and Max_Data = 8 on the other devices */\r
58 \r
59   uint32_t PLLN;       /*!< PLLN: Multiplication factor for PLL VCO output clock.\r
60                             This parameter must be a number between Min_Data = 8 and Max_Data = 86    */\r
61 \r
62 #if defined(RCC_PLLP_SUPPORT)\r
63   uint32_t PLLP;       /*!< PLLP: Division factor for SAI clock.\r
64                             This parameter must be a value of @ref RCC_PLLP_Clock_Divider             */\r
65 #endif /* RCC_PLLP_SUPPORT */\r
66 \r
67   uint32_t PLLQ;       /*!< PLLQ: Division factor for SDMMC1, RNG and USB clocks.\r
68                             This parameter must be a value of @ref RCC_PLLQ_Clock_Divider             */\r
69 \r
70   uint32_t PLLR;       /*!< PLLR: Division for the main system clock.\r
71                             User have to set the PLLR parameter correctly to not exceed max frequency 120MHZ\r
72                             on STM32L4Rx/STM32L4Sx devices else 80MHz on the other devices.\r
73                             This parameter must be a value of @ref RCC_PLLR_Clock_Divider             */\r
74 \r
75 }RCC_PLLInitTypeDef;\r
76 \r
77 /**\r
78   * @brief  RCC Internal/External Oscillator (HSE, HSI, MSI, LSE and LSI) configuration structure definition\r
79   */\r
80 typedef struct\r
81 {\r
82   uint32_t OscillatorType;       /*!< The oscillators to be configured.\r
83                                       This parameter can be a value of @ref RCC_Oscillator_Type                   */\r
84 \r
85   uint32_t HSEState;             /*!< The new state of the HSE.\r
86                                       This parameter can be a value of @ref RCC_HSE_Config                        */\r
87 \r
88   uint32_t LSEState;             /*!< The new state of the LSE.\r
89                                       This parameter can be a value of @ref RCC_LSE_Config                        */\r
90 \r
91   uint32_t HSIState;             /*!< The new state of the HSI.\r
92                                       This parameter can be a value of @ref RCC_HSI_Config                        */\r
93 \r
94   uint32_t HSICalibrationValue;  /*!< The calibration trimming value (default is RCC_HSICALIBRATION_DEFAULT).\r
95                                       This parameter must be a number between Min_Data = 0x00 and Max_Data = 0x1F on STM32L43x/STM32L44x/STM32L47x/STM32L48x devices.\r
96                                       This parameter must be a number between Min_Data = 0x00 and Max_Data = 0x7F on the other devices */\r
97 \r
98   uint32_t LSIState;             /*!< The new state of the LSI.\r
99                                       This parameter can be a value of @ref RCC_LSI_Config                        */\r
100 #if defined(RCC_CSR_LSIPREDIV)\r
101 \r
102   uint32_t LSIDiv;               /*!< The division factor of the LSI.\r
103                                       This parameter can be a value of @ref RCC_LSI_Div                           */\r
104 #endif /* RCC_CSR_LSIPREDIV */\r
105 \r
106   uint32_t MSIState;             /*!< The new state of the MSI.\r
107                                       This parameter can be a value of @ref RCC_MSI_Config */\r
108 \r
109   uint32_t MSICalibrationValue;  /*!< The calibration trimming value (default is RCC_MSICALIBRATION_DEFAULT).\r
110                                       This parameter must be a number between Min_Data = 0x00 and Max_Data = 0xFF */\r
111 \r
112   uint32_t MSIClockRange;        /*!< The MSI frequency range.\r
113                                       This parameter can be a value of @ref RCC_MSI_Clock_Range  */\r
114 \r
115   uint32_t HSI48State;             /*!< The new state of the HSI48 (only applicable to STM32L43x/STM32L44x/STM32L49x/STM32L4Ax devices).\r
116                                         This parameter can be a value of @ref RCC_HSI48_Config */\r
117 \r
118   RCC_PLLInitTypeDef PLL;        /*!< Main PLL structure parameters                                               */\r
119 \r
120 }RCC_OscInitTypeDef;\r
121 \r
122 /**\r
123   * @brief  RCC System, AHB and APB busses clock configuration structure definition\r
124   */\r
125 typedef struct\r
126 {\r
127   uint32_t ClockType;             /*!< The clock to be configured.\r
128                                        This parameter can be a value of @ref RCC_System_Clock_Type      */\r
129 \r
130   uint32_t SYSCLKSource;          /*!< The clock source used as system clock (SYSCLK).\r
131                                        This parameter can be a value of @ref RCC_System_Clock_Source    */\r
132 \r
133   uint32_t AHBCLKDivider;         /*!< The AHB clock (HCLK) divider. This clock is derived from the system clock (SYSCLK).\r
134                                        This parameter can be a value of @ref RCC_AHB_Clock_Source       */\r
135 \r
136   uint32_t APB1CLKDivider;        /*!< The APB1 clock (PCLK1) divider. This clock is derived from the AHB clock (HCLK).\r
137                                        This parameter can be a value of @ref RCC_APB1_APB2_Clock_Source */\r
138 \r
139   uint32_t APB2CLKDivider;        /*!< The APB2 clock (PCLK2) divider. This clock is derived from the AHB clock (HCLK).\r
140                                        This parameter can be a value of @ref RCC_APB1_APB2_Clock_Source */\r
141 \r
142 }RCC_ClkInitTypeDef;\r
143 \r
144 /**\r
145   * @}\r
146   */\r
147 \r
148 /* Exported constants --------------------------------------------------------*/\r
149 /** @defgroup RCC_Exported_Constants RCC Exported Constants\r
150   * @{\r
151   */\r
152 \r
153 /** @defgroup RCC_Timeout_Value Timeout Values\r
154   * @{\r
155   */\r
156 #define RCC_DBP_TIMEOUT_VALUE          2U            /* 2 ms (minimum Tick + 1) */\r
157 #define RCC_LSE_TIMEOUT_VALUE          LSE_STARTUP_TIMEOUT\r
158 /**\r
159   * @}\r
160   */\r
161 \r
162 /** @defgroup RCC_Oscillator_Type Oscillator Type\r
163   * @{\r
164   */\r
165 #define RCC_OSCILLATORTYPE_NONE        0x00000000U   /*!< Oscillator configuration unchanged */\r
166 #define RCC_OSCILLATORTYPE_HSE         0x00000001U   /*!< HSE to configure */\r
167 #define RCC_OSCILLATORTYPE_HSI         0x00000002U   /*!< HSI to configure */\r
168 #define RCC_OSCILLATORTYPE_LSE         0x00000004U   /*!< LSE to configure */\r
169 #define RCC_OSCILLATORTYPE_LSI         0x00000008U   /*!< LSI to configure */\r
170 #define RCC_OSCILLATORTYPE_MSI         0x00000010U   /*!< MSI to configure */\r
171 #if defined(RCC_HSI48_SUPPORT)\r
172 #define RCC_OSCILLATORTYPE_HSI48       0x00000020U   /*!< HSI48 to configure */\r
173 #endif /* RCC_HSI48_SUPPORT */\r
174 /**\r
175   * @}\r
176   */\r
177 \r
178 /** @defgroup RCC_HSE_Config HSE Config\r
179   * @{\r
180   */\r
181 #define RCC_HSE_OFF                    0x00000000U                    /*!< HSE clock deactivation */\r
182 #define RCC_HSE_ON                     RCC_CR_HSEON                   /*!< HSE clock activation */\r
183 #define RCC_HSE_BYPASS                 (RCC_CR_HSEBYP | RCC_CR_HSEON) /*!< External clock source for HSE clock */\r
184 /**\r
185   * @}\r
186   */\r
187 \r
188 /** @defgroup RCC_LSE_Config LSE Config\r
189   * @{\r
190   */\r
191 #define RCC_LSE_OFF                    0x00000000U                           /*!< LSE clock deactivation */\r
192 #define RCC_LSE_ON                     RCC_BDCR_LSEON                        /*!< LSE clock activation */\r
193 #define RCC_LSE_BYPASS                 (RCC_BDCR_LSEBYP | RCC_BDCR_LSEON)    /*!< External clock source for LSE clock */\r
194 #if defined(RCC_BDCR_LSESYSDIS)\r
195 #define RCC_LSE_ON_RTC_ONLY            (RCC_BDCR_LSESYSDIS | RCC_BDCR_LSEON) /*!< LSE clock activation without propagation to system */\r
196 #define RCC_LSE_BYPASS_RTC_ONLY        (RCC_BDCR_LSEBYP | RCC_BDCR_LSESYSDIS | RCC_BDCR_LSEON) /*!< External clock source for LSE clock without propagation to system */\r
197 #endif /* RCC_BDCR_LSESYSDIS */\r
198 /**\r
199   * @}\r
200   */\r
201 \r
202 /** @defgroup RCC_HSI_Config HSI Config\r
203   * @{\r
204   */\r
205 #define RCC_HSI_OFF                    0x00000000U   /*!< HSI clock deactivation */\r
206 #define RCC_HSI_ON                     RCC_CR_HSION  /*!< HSI clock activation */\r
207 \r
208 #if defined(STM32L431xx) || defined(STM32L432xx) || defined(STM32L433xx) || defined(STM32L442xx) || defined(STM32L443xx) || \\r
209     defined(STM32L471xx) || defined(STM32L475xx) || defined(STM32L476xx) || defined(STM32L485xx) || defined(STM32L486xx)\r
210 #define RCC_HSICALIBRATION_DEFAULT     0x10U         /* Default HSI calibration trimming value */\r
211 #else\r
212 #define RCC_HSICALIBRATION_DEFAULT     0x40U         /* Default HSI calibration trimming value */\r
213 #endif /* STM32L431xx || STM32L432xx || STM32L433xx || STM32L442xx || STM32L443xx || */\r
214        /* STM32L471xx || STM32L475xx || STM32L476xx || STM32L485xx || STM32L486xx    */\r
215 /**\r
216   * @}\r
217   */\r
218 \r
219 /** @defgroup RCC_LSI_Config LSI Config\r
220   * @{\r
221   */\r
222 #define RCC_LSI_OFF                    0x00000000U   /*!< LSI clock deactivation */\r
223 #define RCC_LSI_ON                     RCC_CSR_LSION /*!< LSI clock activation */\r
224 /**\r
225   * @}\r
226   */\r
227 #if defined(RCC_CSR_LSIPREDIV)\r
228 \r
229 /** @defgroup RCC_LSI_Div LSI Div\r
230   * @{\r
231   */\r
232 #define RCC_LSI_DIV1                   0x00000000U       /*!< LSI clock not divided    */\r
233 #define RCC_LSI_DIV128                 RCC_CSR_LSIPREDIV /*!< LSI clock divided by 128 */\r
234 /**\r
235   * @}\r
236   */\r
237 #endif /* RCC_CSR_LSIPREDIV */\r
238 \r
239 /** @defgroup RCC_MSI_Config MSI Config\r
240   * @{\r
241   */\r
242 #define RCC_MSI_OFF                    0x00000000U   /*!< MSI clock deactivation */\r
243 #define RCC_MSI_ON                     RCC_CR_MSION  /*!< MSI clock activation */\r
244 \r
245 #define RCC_MSICALIBRATION_DEFAULT     0U            /*!< Default MSI calibration trimming value */\r
246 /**\r
247   * @}\r
248   */\r
249 \r
250 #if defined(RCC_HSI48_SUPPORT)\r
251 /** @defgroup RCC_HSI48_Config HSI48 Config\r
252   * @{\r
253   */\r
254 #define RCC_HSI48_OFF                  0x00000000U       /*!< HSI48 clock deactivation */\r
255 #define RCC_HSI48_ON                   RCC_CRRCR_HSI48ON /*!< HSI48 clock activation */\r
256 /**\r
257   * @}\r
258   */\r
259 #else\r
260 /** @defgroup RCC_HSI48_Config HSI48 Config\r
261   * @{\r
262   */\r
263 #define RCC_HSI48_OFF                  0x00000000U   /*!< HSI48 clock deactivation */\r
264 /**\r
265   * @}\r
266   */\r
267 #endif /* RCC_HSI48_SUPPORT */\r
268 \r
269 /** @defgroup RCC_PLL_Config PLL Config\r
270   * @{\r
271   */\r
272 #define RCC_PLL_NONE                   0x00000000U   /*!< PLL configuration unchanged */\r
273 #define RCC_PLL_OFF                    0x00000001U   /*!< PLL deactivation */\r
274 #define RCC_PLL_ON                     0x00000002U   /*!< PLL activation */\r
275 /**\r
276   * @}\r
277   */\r
278 \r
279 #if defined(RCC_PLLP_SUPPORT)\r
280 /** @defgroup RCC_PLLP_Clock_Divider PLLP Clock Divider\r
281   * @{\r
282   */\r
283 #if defined(RCC_PLLP_DIV_2_31_SUPPORT)\r
284 #define RCC_PLLP_DIV2                  0x00000002U   /*!< PLLP division factor = 2  */\r
285 #define RCC_PLLP_DIV3                  0x00000003U   /*!< PLLP division factor = 3  */\r
286 #define RCC_PLLP_DIV4                  0x00000004U   /*!< PLLP division factor = 4  */\r
287 #define RCC_PLLP_DIV5                  0x00000005U   /*!< PLLP division factor = 5  */\r
288 #define RCC_PLLP_DIV6                  0x00000006U   /*!< PLLP division factor = 6  */\r
289 #define RCC_PLLP_DIV7                  0x00000007U   /*!< PLLP division factor = 7  */\r
290 #define RCC_PLLP_DIV8                  0x00000008U   /*!< PLLP division factor = 8  */\r
291 #define RCC_PLLP_DIV9                  0x00000009U   /*!< PLLP division factor = 9  */\r
292 #define RCC_PLLP_DIV10                 0x0000000AU   /*!< PLLP division factor = 10 */\r
293 #define RCC_PLLP_DIV11                 0x0000000BU   /*!< PLLP division factor = 11 */\r
294 #define RCC_PLLP_DIV12                 0x0000000CU   /*!< PLLP division factor = 12 */\r
295 #define RCC_PLLP_DIV13                 0x0000000DU   /*!< PLLP division factor = 13 */\r
296 #define RCC_PLLP_DIV14                 0x0000000EU   /*!< PLLP division factor = 14 */\r
297 #define RCC_PLLP_DIV15                 0x0000000FU   /*!< PLLP division factor = 15 */\r
298 #define RCC_PLLP_DIV16                 0x00000010U   /*!< PLLP division factor = 16 */\r
299 #define RCC_PLLP_DIV17                 0x00000011U   /*!< PLLP division factor = 17 */\r
300 #define RCC_PLLP_DIV18                 0x00000012U   /*!< PLLP division factor = 18 */\r
301 #define RCC_PLLP_DIV19                 0x00000013U   /*!< PLLP division factor = 19 */\r
302 #define RCC_PLLP_DIV20                 0x00000014U   /*!< PLLP division factor = 20 */\r
303 #define RCC_PLLP_DIV21                 0x00000015U   /*!< PLLP division factor = 21 */\r
304 #define RCC_PLLP_DIV22                 0x00000016U   /*!< PLLP division factor = 22 */\r
305 #define RCC_PLLP_DIV23                 0x00000017U   /*!< PLLP division factor = 23 */\r
306 #define RCC_PLLP_DIV24                 0x00000018U   /*!< PLLP division factor = 24 */\r
307 #define RCC_PLLP_DIV25                 0x00000019U   /*!< PLLP division factor = 25 */\r
308 #define RCC_PLLP_DIV26                 0x0000001AU   /*!< PLLP division factor = 26 */\r
309 #define RCC_PLLP_DIV27                 0x0000001BU   /*!< PLLP division factor = 27 */\r
310 #define RCC_PLLP_DIV28                 0x0000001CU   /*!< PLLP division factor = 28 */\r
311 #define RCC_PLLP_DIV29                 0x0000001DU   /*!< PLLP division factor = 29 */\r
312 #define RCC_PLLP_DIV30                 0x0000001EU   /*!< PLLP division factor = 30 */\r
313 #define RCC_PLLP_DIV31                 0x0000001FU   /*!< PLLP division factor = 31 */\r
314 #else\r
315 #define RCC_PLLP_DIV7                  0x00000007U   /*!< PLLP division factor = 7  */\r
316 #define RCC_PLLP_DIV17                 0x00000011U   /*!< PLLP division factor = 17 */\r
317 #endif /* RCC_PLLP_DIV_2_31_SUPPORT */\r
318 /**\r
319   * @}\r
320   */\r
321 #endif /* RCC_PLLP_SUPPORT */\r
322 \r
323 /** @defgroup RCC_PLLQ_Clock_Divider PLLQ Clock Divider\r
324   * @{\r
325   */\r
326 #define RCC_PLLQ_DIV2                  0x00000002U   /*!< PLLQ division factor = 2 */\r
327 #define RCC_PLLQ_DIV4                  0x00000004U   /*!< PLLQ division factor = 4 */\r
328 #define RCC_PLLQ_DIV6                  0x00000006U   /*!< PLLQ division factor = 6 */\r
329 #define RCC_PLLQ_DIV8                  0x00000008U   /*!< PLLQ division factor = 8 */\r
330 /**\r
331   * @}\r
332   */\r
333 \r
334 /** @defgroup RCC_PLLR_Clock_Divider PLLR Clock Divider\r
335   * @{\r
336   */\r
337 #define RCC_PLLR_DIV2                  0x00000002U   /*!< PLLR division factor = 2 */\r
338 #define RCC_PLLR_DIV4                  0x00000004U   /*!< PLLR division factor = 4 */\r
339 #define RCC_PLLR_DIV6                  0x00000006U   /*!< PLLR division factor = 6 */\r
340 #define RCC_PLLR_DIV8                  0x00000008U   /*!< PLLR division factor = 8 */\r
341 /**\r
342   * @}\r
343   */\r
344 \r
345 /** @defgroup RCC_PLL_Clock_Source PLL Clock Source\r
346   * @{\r
347   */\r
348 #define RCC_PLLSOURCE_NONE             0x00000000U             /*!< No clock selected as PLL entry clock source  */\r
349 #define RCC_PLLSOURCE_MSI              RCC_PLLCFGR_PLLSRC_MSI  /*!< MSI clock selected as PLL entry clock source */\r
350 #define RCC_PLLSOURCE_HSI              RCC_PLLCFGR_PLLSRC_HSI  /*!< HSI clock selected as PLL entry clock source */\r
351 #define RCC_PLLSOURCE_HSE              RCC_PLLCFGR_PLLSRC_HSE  /*!< HSE clock selected as PLL entry clock source */\r
352 /**\r
353   * @}\r
354   */\r
355 \r
356 /** @defgroup RCC_PLL_Clock_Output PLL Clock Output\r
357   * @{\r
358   */\r
359 #if defined(RCC_PLLSAI2_SUPPORT)\r
360 #define RCC_PLL_SAI3CLK                RCC_PLLCFGR_PLLPEN      /*!< PLLSAI3CLK selection from main PLL (for devices with PLLSAI2) */\r
361 #elif defined(RCC_PLLSAI1_SUPPORT)\r
362 #define RCC_PLL_SAI2CLK                RCC_PLLCFGR_PLLPEN      /*!< PLLSAI2CLK selection from main PLL (for devices without PLLSAI2) */\r
363 #endif /* RCC_PLLSAI2_SUPPORT */\r
364 #define RCC_PLL_48M1CLK                RCC_PLLCFGR_PLLQEN      /*!< PLL48M1CLK selection from main PLL */\r
365 #define RCC_PLL_SYSCLK                 RCC_PLLCFGR_PLLREN      /*!< PLLCLK selection from main PLL */\r
366 /**\r
367   * @}\r
368   */\r
369 #if defined(RCC_PLLSAI1_SUPPORT)\r
370 \r
371 /** @defgroup RCC_PLLSAI1_Clock_Output PLLSAI1 Clock Output\r
372   * @{\r
373   */\r
374 #define RCC_PLLSAI1_SAI1CLK            RCC_PLLSAI1CFGR_PLLSAI1PEN /*!< PLLSAI1CLK selection from PLLSAI1 */\r
375 #define RCC_PLLSAI1_48M2CLK            RCC_PLLSAI1CFGR_PLLSAI1QEN /*!< PLL48M2CLK selection from PLLSAI1 */\r
376 #define RCC_PLLSAI1_ADC1CLK            RCC_PLLSAI1CFGR_PLLSAI1REN /*!< PLLADC1CLK selection from PLLSAI1 */\r
377 /**\r
378   * @}\r
379   */\r
380 #endif /* RCC_PLLSAI1_SUPPORT */\r
381 \r
382 #if defined(RCC_PLLSAI2_SUPPORT)\r
383 \r
384 /** @defgroup RCC_PLLSAI2_Clock_Output PLLSAI2 Clock Output\r
385   * @{\r
386   */\r
387 #define RCC_PLLSAI2_SAI2CLK            RCC_PLLSAI2CFGR_PLLSAI2PEN /*!< PLLSAI2CLK selection from PLLSAI2 */\r
388 #if defined(RCC_PLLSAI2Q_DIV_SUPPORT)\r
389 #define RCC_PLLSAI2_DSICLK             RCC_PLLSAI2CFGR_PLLSAI2QEN /*!< PLLDSICLK selection from PLLSAI2  */\r
390 #endif /* RCC_PLLSAI2Q_DIV_SUPPORT */\r
391 #if defined(STM32L471xx) || defined(STM32L475xx) || defined(STM32L476xx) || defined(STM32L485xx) || defined(STM32L486xx) || defined(STM32L496xx) || defined(STM32L4A6xx)\r
392 #define RCC_PLLSAI2_ADC2CLK            RCC_PLLSAI2CFGR_PLLSAI2REN /*!< PLLADC2CLK selection from PLLSAI2 */\r
393 #else\r
394 #define RCC_PLLSAI2_LTDCCLK            RCC_PLLSAI2CFGR_PLLSAI2REN /*!< PLLLTDCCLK selection from PLLSAI2 */\r
395 #endif /* STM32L471xx || STM32L475xx || STM32L476xx || STM32L485xx || STM32L486xx || STM32L496xx || STM32L4A6xx */\r
396 /**\r
397   * @}\r
398   */\r
399 \r
400 #endif /* RCC_PLLSAI2_SUPPORT */\r
401 \r
402 /** @defgroup RCC_MSI_Clock_Range MSI Clock Range\r
403   * @{\r
404   */\r
405 #define RCC_MSIRANGE_0                 RCC_CR_MSIRANGE_0  /*!< MSI = 100 KHz  */\r
406 #define RCC_MSIRANGE_1                 RCC_CR_MSIRANGE_1  /*!< MSI = 200 KHz  */\r
407 #define RCC_MSIRANGE_2                 RCC_CR_MSIRANGE_2  /*!< MSI = 400 KHz  */\r
408 #define RCC_MSIRANGE_3                 RCC_CR_MSIRANGE_3  /*!< MSI = 800 KHz  */\r
409 #define RCC_MSIRANGE_4                 RCC_CR_MSIRANGE_4  /*!< MSI = 1 MHz    */\r
410 #define RCC_MSIRANGE_5                 RCC_CR_MSIRANGE_5  /*!< MSI = 2 MHz    */\r
411 #define RCC_MSIRANGE_6                 RCC_CR_MSIRANGE_6  /*!< MSI = 4 MHz    */\r
412 #define RCC_MSIRANGE_7                 RCC_CR_MSIRANGE_7  /*!< MSI = 8 MHz    */\r
413 #define RCC_MSIRANGE_8                 RCC_CR_MSIRANGE_8  /*!< MSI = 16 MHz   */\r
414 #define RCC_MSIRANGE_9                 RCC_CR_MSIRANGE_9  /*!< MSI = 24 MHz   */\r
415 #define RCC_MSIRANGE_10                RCC_CR_MSIRANGE_10 /*!< MSI = 32 MHz   */\r
416 #define RCC_MSIRANGE_11                RCC_CR_MSIRANGE_11 /*!< MSI = 48 MHz   */\r
417 /**\r
418   * @}\r
419   */\r
420 \r
421 /** @defgroup RCC_System_Clock_Type System Clock Type\r
422   * @{\r
423   */\r
424 #define RCC_CLOCKTYPE_SYSCLK           0x00000001U   /*!< SYSCLK to configure */\r
425 #define RCC_CLOCKTYPE_HCLK             0x00000002U   /*!< HCLK to configure */\r
426 #define RCC_CLOCKTYPE_PCLK1            0x00000004U   /*!< PCLK1 to configure */\r
427 #define RCC_CLOCKTYPE_PCLK2            0x00000008U   /*!< PCLK2 to configure */\r
428 /**\r
429   * @}\r
430   */\r
431 \r
432 /** @defgroup RCC_System_Clock_Source System Clock Source\r
433   * @{\r
434   */\r
435 #define RCC_SYSCLKSOURCE_MSI           RCC_CFGR_SW_MSI    /*!< MSI selection as system clock */\r
436 #define RCC_SYSCLKSOURCE_HSI           RCC_CFGR_SW_HSI    /*!< HSI selection as system clock */\r
437 #define RCC_SYSCLKSOURCE_HSE           RCC_CFGR_SW_HSE    /*!< HSE selection as system clock */\r
438 #define RCC_SYSCLKSOURCE_PLLCLK        RCC_CFGR_SW_PLL    /*!< PLL selection as system clock */\r
439 /**\r
440   * @}\r
441   */\r
442 \r
443 /** @defgroup RCC_System_Clock_Source_Status System Clock Source Status\r
444   * @{\r
445   */\r
446 #define RCC_SYSCLKSOURCE_STATUS_MSI    RCC_CFGR_SWS_MSI   /*!< MSI used as system clock */\r
447 #define RCC_SYSCLKSOURCE_STATUS_HSI    RCC_CFGR_SWS_HSI   /*!< HSI used as system clock */\r
448 #define RCC_SYSCLKSOURCE_STATUS_HSE    RCC_CFGR_SWS_HSE   /*!< HSE used as system clock */\r
449 #define RCC_SYSCLKSOURCE_STATUS_PLLCLK RCC_CFGR_SWS_PLL   /*!< PLL used as system clock */\r
450 /**\r
451   * @}\r
452   */\r
453 \r
454 /** @defgroup RCC_AHB_Clock_Source AHB Clock Source\r
455   * @{\r
456   */\r
457 #define RCC_SYSCLK_DIV1                RCC_CFGR_HPRE_DIV1   /*!< SYSCLK not divided */\r
458 #define RCC_SYSCLK_DIV2                RCC_CFGR_HPRE_DIV2   /*!< SYSCLK divided by 2 */\r
459 #define RCC_SYSCLK_DIV4                RCC_CFGR_HPRE_DIV4   /*!< SYSCLK divided by 4 */\r
460 #define RCC_SYSCLK_DIV8                RCC_CFGR_HPRE_DIV8   /*!< SYSCLK divided by 8 */\r
461 #define RCC_SYSCLK_DIV16               RCC_CFGR_HPRE_DIV16  /*!< SYSCLK divided by 16 */\r
462 #define RCC_SYSCLK_DIV64               RCC_CFGR_HPRE_DIV64  /*!< SYSCLK divided by 64 */\r
463 #define RCC_SYSCLK_DIV128              RCC_CFGR_HPRE_DIV128 /*!< SYSCLK divided by 128 */\r
464 #define RCC_SYSCLK_DIV256              RCC_CFGR_HPRE_DIV256 /*!< SYSCLK divided by 256 */\r
465 #define RCC_SYSCLK_DIV512              RCC_CFGR_HPRE_DIV512 /*!< SYSCLK divided by 512 */\r
466 /**\r
467   * @}\r
468   */\r
469 \r
470 /** @defgroup RCC_APB1_APB2_Clock_Source APB1 APB2 Clock Source\r
471   * @{\r
472   */\r
473 #define RCC_HCLK_DIV1                  RCC_CFGR_PPRE1_DIV1  /*!< HCLK not divided */\r
474 #define RCC_HCLK_DIV2                  RCC_CFGR_PPRE1_DIV2  /*!< HCLK divided by 2 */\r
475 #define RCC_HCLK_DIV4                  RCC_CFGR_PPRE1_DIV4  /*!< HCLK divided by 4 */\r
476 #define RCC_HCLK_DIV8                  RCC_CFGR_PPRE1_DIV8  /*!< HCLK divided by 8 */\r
477 #define RCC_HCLK_DIV16                 RCC_CFGR_PPRE1_DIV16 /*!< HCLK divided by 16 */\r
478 /**\r
479   * @}\r
480   */\r
481 \r
482 /** @defgroup RCC_RTC_Clock_Source RTC Clock Source\r
483   * @{\r
484   */\r
485 #define RCC_RTCCLKSOURCE_NONE          0x00000000U          /*!< No clock used as RTC clock */\r
486 #define RCC_RTCCLKSOURCE_LSE           RCC_BDCR_RTCSEL_0    /*!< LSE oscillator clock used as RTC clock */\r
487 #define RCC_RTCCLKSOURCE_LSI           RCC_BDCR_RTCSEL_1    /*!< LSI oscillator clock used as RTC clock */\r
488 #define RCC_RTCCLKSOURCE_HSE_DIV32     RCC_BDCR_RTCSEL      /*!< HSE oscillator clock divided by 32 used as RTC clock */\r
489 /**\r
490   * @}\r
491   */\r
492 \r
493 /** @defgroup RCC_MCO_Index MCO Index\r
494   * @{\r
495   */\r
496 #define RCC_MCO1                       0x00000000U\r
497 #define RCC_MCO                        RCC_MCO1      /*!< MCO1 to be compliant with other families with 2 MCOs*/\r
498 /**\r
499   * @}\r
500   */\r
501 \r
502 /** @defgroup RCC_MCO1_Clock_Source MCO1 Clock Source\r
503   * @{\r
504   */\r
505 #define RCC_MCO1SOURCE_NOCLOCK         0x00000000U                            /*!< MCO1 output disabled, no clock on MCO1 */\r
506 #define RCC_MCO1SOURCE_SYSCLK          RCC_CFGR_MCOSEL_0                      /*!< SYSCLK selection as MCO1 source */\r
507 #define RCC_MCO1SOURCE_MSI             RCC_CFGR_MCOSEL_1                      /*!< MSI selection as MCO1 source */\r
508 #define RCC_MCO1SOURCE_HSI             (RCC_CFGR_MCOSEL_0| RCC_CFGR_MCOSEL_1) /*!< HSI selection as MCO1 source */\r
509 #define RCC_MCO1SOURCE_HSE             RCC_CFGR_MCOSEL_2                      /*!< HSE selection as MCO1 source */\r
510 #define RCC_MCO1SOURCE_PLLCLK          (RCC_CFGR_MCOSEL_0|RCC_CFGR_MCOSEL_2)  /*!< PLLCLK selection as MCO1 source */\r
511 #define RCC_MCO1SOURCE_LSI             (RCC_CFGR_MCOSEL_1|RCC_CFGR_MCOSEL_2)  /*!< LSI selection as MCO1 source */\r
512 #define RCC_MCO1SOURCE_LSE             (RCC_CFGR_MCOSEL_0|RCC_CFGR_MCOSEL_1|RCC_CFGR_MCOSEL_2) /*!< LSE selection as MCO1 source */\r
513 #if defined(RCC_HSI48_SUPPORT)\r
514 #define RCC_MCO1SOURCE_HSI48           RCC_CFGR_MCOSEL_3                      /*!< HSI48 selection as MCO1 source (STM32L43x/STM32L44x devices) */\r
515 #endif /* RCC_HSI48_SUPPORT */\r
516 /**\r
517   * @}\r
518   */\r
519 \r
520 /** @defgroup RCC_MCOx_Clock_Prescaler MCO1 Clock Prescaler\r
521   * @{\r
522   */\r
523 #define RCC_MCODIV_1                   RCC_CFGR_MCOPRE_DIV1     /*!< MCO not divided  */\r
524 #define RCC_MCODIV_2                   RCC_CFGR_MCOPRE_DIV2     /*!< MCO divided by 2 */\r
525 #define RCC_MCODIV_4                   RCC_CFGR_MCOPRE_DIV4     /*!< MCO divided by 4 */\r
526 #define RCC_MCODIV_8                   RCC_CFGR_MCOPRE_DIV8     /*!< MCO divided by 8 */\r
527 #define RCC_MCODIV_16                  RCC_CFGR_MCOPRE_DIV16    /*!< MCO divided by 16 */\r
528 /**\r
529   * @}\r
530   */\r
531 \r
532 /** @defgroup RCC_Interrupt Interrupts\r
533   * @{\r
534   */\r
535 #define RCC_IT_LSIRDY                  RCC_CIFR_LSIRDYF      /*!< LSI Ready Interrupt flag */\r
536 #define RCC_IT_LSERDY                  RCC_CIFR_LSERDYF      /*!< LSE Ready Interrupt flag */\r
537 #define RCC_IT_MSIRDY                  RCC_CIFR_MSIRDYF      /*!< MSI Ready Interrupt flag */\r
538 #define RCC_IT_HSIRDY                  RCC_CIFR_HSIRDYF      /*!< HSI16 Ready Interrupt flag */\r
539 #define RCC_IT_HSERDY                  RCC_CIFR_HSERDYF      /*!< HSE Ready Interrupt flag */\r
540 #define RCC_IT_PLLRDY                  RCC_CIFR_PLLRDYF      /*!< PLL Ready Interrupt flag */\r
541 #if defined(RCC_PLLSAI1_SUPPORT)\r
542 #define RCC_IT_PLLSAI1RDY              RCC_CIFR_PLLSAI1RDYF  /*!< PLLSAI1 Ready Interrupt flag */\r
543 #endif /* RCC_PLLSAI1_SUPPORT */\r
544 #if defined(RCC_PLLSAI2_SUPPORT)\r
545 #define RCC_IT_PLLSAI2RDY              RCC_CIFR_PLLSAI2RDYF  /*!< PLLSAI2 Ready Interrupt flag */\r
546 #endif /* RCC_PLLSAI2_SUPPORT */\r
547 #define RCC_IT_CSS                     RCC_CIFR_CSSF        /*!< Clock Security System Interrupt flag */\r
548 #define RCC_IT_LSECSS                  RCC_CIFR_LSECSSF     /*!< LSE Clock Security System Interrupt flag */\r
549 #if defined(RCC_HSI48_SUPPORT)\r
550 #define RCC_IT_HSI48RDY                RCC_CIFR_HSI48RDYF   /*!< HSI48 Ready Interrupt flag */\r
551 #endif /* RCC_HSI48_SUPPORT */\r
552 /**\r
553   * @}\r
554   */\r
555 \r
556 /** @defgroup RCC_Flag Flags\r
557   *        Elements values convention: XXXYYYYYb\r
558   *           - YYYYY  : Flag position in the register\r
559   *           - XXX  : Register index\r
560   *                 - 001: CR register\r
561   *                 - 010: BDCR register\r
562   *                 - 011: CSR register\r
563   *                 - 100: CRRCR register\r
564   * @{\r
565   */\r
566 /* Flags in the CR register */\r
567 #define RCC_FLAG_MSIRDY                ((CR_REG_INDEX << 5U) | RCC_CR_MSIRDY_Pos) /*!< MSI Ready flag */\r
568 #define RCC_FLAG_HSIRDY                ((CR_REG_INDEX << 5U) | RCC_CR_HSIRDY_Pos) /*!< HSI Ready flag */\r
569 #define RCC_FLAG_HSERDY                ((CR_REG_INDEX << 5U) | RCC_CR_HSERDY_Pos) /*!< HSE Ready flag */\r
570 #define RCC_FLAG_PLLRDY                ((CR_REG_INDEX << 5U) | RCC_CR_PLLRDY_Pos) /*!< PLL Ready flag */\r
571 #if defined(RCC_PLLSAI1_SUPPORT)\r
572 #define RCC_FLAG_PLLSAI1RDY            ((CR_REG_INDEX << 5U) | RCC_CR_PLLSAI1RDY_Pos) /*!< PLLSAI1 Ready flag */\r
573 #endif /* RCC_PLLSAI1_SUPPORT */\r
574 #if defined(RCC_PLLSAI2_SUPPORT)\r
575 #define RCC_FLAG_PLLSAI2RDY            ((CR_REG_INDEX << 5U) | RCC_CR_PLLSAI2RDY_Pos) /*!< PLLSAI2 Ready flag */\r
576 #endif /* RCC_PLLSAI2_SUPPORT */\r
577 \r
578 /* Flags in the BDCR register */\r
579 #define RCC_FLAG_LSERDY                ((BDCR_REG_INDEX << 5U) | RCC_BDCR_LSERDY_Pos)  /*!< LSE Ready flag */\r
580 #define RCC_FLAG_LSECSSD               ((BDCR_REG_INDEX << 5U) | RCC_BDCR_LSECSSD_Pos) /*!< LSE Clock Security System Interrupt flag */\r
581 \r
582 /* Flags in the CSR register */\r
583 #define RCC_FLAG_LSIRDY                ((CSR_REG_INDEX << 5U) | RCC_CSR_LSIRDY_Pos)    /*!< LSI Ready flag */\r
584 #define RCC_FLAG_FWRST                 ((CSR_REG_INDEX << 5U) | RCC_CSR_FWRSTF_Pos)    /*!< Firewall reset flag */\r
585 #define RCC_FLAG_OBLRST                ((CSR_REG_INDEX << 5U) | RCC_CSR_OBLRSTF_Pos)   /*!< Option Byte Loader reset flag */\r
586 #define RCC_FLAG_PINRST                ((CSR_REG_INDEX << 5U) | RCC_CSR_PINRSTF_Pos)   /*!< PIN reset flag */\r
587 #define RCC_FLAG_BORRST                ((CSR_REG_INDEX << 5U) | RCC_CSR_BORRSTF_Pos)   /*!< BOR reset flag */\r
588 #define RCC_FLAG_SFTRST                ((CSR_REG_INDEX << 5U) | RCC_CSR_SFTRSTF_Pos)   /*!< Software Reset flag */\r
589 #define RCC_FLAG_IWDGRST               ((CSR_REG_INDEX << 5U) | RCC_CSR_IWDGRSTF_Pos)  /*!< Independent Watchdog reset flag */\r
590 #define RCC_FLAG_WWDGRST               ((CSR_REG_INDEX << 5U) | RCC_CSR_WWDGRSTF_Pos)  /*!< Window watchdog reset flag */\r
591 #define RCC_FLAG_LPWRRST               ((CSR_REG_INDEX << 5U) | RCC_CSR_LPWRRSTF_Pos)  /*!< Low-Power reset flag */\r
592 \r
593 #if defined(RCC_HSI48_SUPPORT)\r
594 /* Flags in the CRRCR register */\r
595 #define RCC_FLAG_HSI48RDY              ((CRRCR_REG_INDEX << 5U) | RCC_CRRCR_HSI48RDY_Pos) /*!< HSI48 Ready flag */\r
596 #endif /* RCC_HSI48_SUPPORT */\r
597 /**\r
598   * @}\r
599   */\r
600 \r
601 /** @defgroup RCC_LSEDrive_Config LSE Drive Config\r
602   * @{\r
603   */\r
604 #define RCC_LSEDRIVE_LOW                 0x00000000U         /*!< LSE low drive capability */\r
605 #define RCC_LSEDRIVE_MEDIUMLOW           RCC_BDCR_LSEDRV_0   /*!< LSE medium low drive capability */\r
606 #define RCC_LSEDRIVE_MEDIUMHIGH          RCC_BDCR_LSEDRV_1   /*!< LSE medium high drive capability */\r
607 #define RCC_LSEDRIVE_HIGH                RCC_BDCR_LSEDRV     /*!< LSE high drive capability */\r
608 /**\r
609   * @}\r
610   */\r
611 \r
612 /** @defgroup RCC_Stop_WakeUpClock Wake-Up from STOP Clock\r
613   * @{\r
614   */\r
615 #define RCC_STOP_WAKEUPCLOCK_MSI       0x00000000U           /*!< MSI selection after wake-up from STOP */\r
616 #define RCC_STOP_WAKEUPCLOCK_HSI       RCC_CFGR_STOPWUCK     /*!< HSI selection after wake-up from STOP */\r
617 /**\r
618   * @}\r
619   */\r
620 \r
621 /**\r
622   * @}\r
623   */\r
624 \r
625 /* Exported macros -----------------------------------------------------------*/\r
626 \r
627 /** @defgroup RCC_Exported_Macros RCC Exported Macros\r
628   * @{\r
629   */\r
630 \r
631 /** @defgroup RCC_AHB1_Peripheral_Clock_Enable_Disable AHB1 Peripheral Clock Enable Disable\r
632   * @brief  Enable or disable the AHB1 peripheral clock.\r
633   * @note   After reset, the peripheral clock (used for registers read/write access)\r
634   *         is disabled and the application software has to enable this clock before\r
635   *         using it.\r
636   * @{\r
637   */\r
638 \r
639 #define __HAL_RCC_DMA1_CLK_ENABLE()            do { \\r
640                                                  __IO uint32_t tmpreg; \\r
641                                                  SET_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA1EN); \\r
642                                                  /* Delay after an RCC peripheral clock enabling */ \\r
643                                                  tmpreg = READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA1EN); \\r
644                                                  UNUSED(tmpreg); \\r
645                                                } while(0)\r
646 \r
647 #define __HAL_RCC_DMA2_CLK_ENABLE()            do { \\r
648                                                  __IO uint32_t tmpreg; \\r
649                                                  SET_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA2EN); \\r
650                                                  /* Delay after an RCC peripheral clock enabling */ \\r
651                                                  tmpreg = READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA2EN); \\r
652                                                  UNUSED(tmpreg); \\r
653                                                } while(0)\r
654 \r
655 #if defined(DMAMUX1)\r
656 #define __HAL_RCC_DMAMUX1_CLK_ENABLE()         do { \\r
657                                                  __IO uint32_t tmpreg; \\r
658                                                  SET_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMAMUX1EN); \\r
659                                                  /* Delay after an RCC peripheral clock enabling */ \\r
660                                                  tmpreg = READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMAMUX1EN); \\r
661                                                  UNUSED(tmpreg); \\r
662                                                } while(0)\r
663 #endif /* DMAMUX1 */\r
664 \r
665 #define __HAL_RCC_FLASH_CLK_ENABLE()           do { \\r
666                                                  __IO uint32_t tmpreg; \\r
667                                                  SET_BIT(RCC->AHB1ENR, RCC_AHB1ENR_FLASHEN); \\r
668                                                  /* Delay after an RCC peripheral clock enabling */ \\r
669                                                  tmpreg = READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_FLASHEN); \\r
670                                                  UNUSED(tmpreg); \\r
671                                                } while(0)\r
672 \r
673 #define __HAL_RCC_CRC_CLK_ENABLE()             do { \\r
674                                                  __IO uint32_t tmpreg; \\r
675                                                  SET_BIT(RCC->AHB1ENR, RCC_AHB1ENR_CRCEN); \\r
676                                                  /* Delay after an RCC peripheral clock enabling */ \\r
677                                                  tmpreg = READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_CRCEN); \\r
678                                                  UNUSED(tmpreg); \\r
679                                                } while(0)\r
680 \r
681 #define __HAL_RCC_TSC_CLK_ENABLE()             do { \\r
682                                                  __IO uint32_t tmpreg; \\r
683                                                  SET_BIT(RCC->AHB1ENR, RCC_AHB1ENR_TSCEN); \\r
684                                                  /* Delay after an RCC peripheral clock enabling */ \\r
685                                                  tmpreg = READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_TSCEN); \\r
686                                                  UNUSED(tmpreg); \\r
687                                                } while(0)\r
688 \r
689 #if defined(DMA2D)\r
690 #define __HAL_RCC_DMA2D_CLK_ENABLE()           do { \\r
691                                                  __IO uint32_t tmpreg; \\r
692                                                  SET_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA2DEN); \\r
693                                                  /* Delay after an RCC peripheral clock enabling */ \\r
694                                                  tmpreg = READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA2DEN); \\r
695                                                  UNUSED(tmpreg); \\r
696                                                } while(0)\r
697 #endif /* DMA2D */\r
698 \r
699 #if defined(GFXMMU)\r
700 #define __HAL_RCC_GFXMMU_CLK_ENABLE()          do { \\r
701                                                  __IO uint32_t tmpreg; \\r
702                                                  SET_BIT(RCC->AHB1ENR, RCC_AHB1ENR_GFXMMUEN); \\r
703                                                  /* Delay after an RCC peripheral clock enabling */ \\r
704                                                  tmpreg = READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_GFXMMUEN); \\r
705                                                  UNUSED(tmpreg); \\r
706                                                } while(0)\r
707 #endif /* GFXMMU */\r
708 \r
709 \r
710 #define __HAL_RCC_DMA1_CLK_DISABLE()           CLEAR_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA1EN)\r
711 \r
712 #define __HAL_RCC_DMA2_CLK_DISABLE()           CLEAR_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA2EN)\r
713 \r
714 #if defined(DMAMUX1)\r
715 #define __HAL_RCC_DMAMUX1_CLK_DISABLE()        CLEAR_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMAMUX1EN)\r
716 #endif /* DMAMUX1 */\r
717 \r
718 #define __HAL_RCC_FLASH_CLK_DISABLE()          CLEAR_BIT(RCC->AHB1ENR, RCC_AHB1ENR_FLASHEN)\r
719 \r
720 #define __HAL_RCC_CRC_CLK_DISABLE()            CLEAR_BIT(RCC->AHB1ENR, RCC_AHB1ENR_CRCEN)\r
721 \r
722 #define __HAL_RCC_TSC_CLK_DISABLE()            CLEAR_BIT(RCC->AHB1ENR, RCC_AHB1ENR_TSCEN)\r
723 \r
724 #if defined(DMA2D)\r
725 #define __HAL_RCC_DMA2D_CLK_DISABLE()          CLEAR_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA2DEN)\r
726 #endif /* DMA2D */\r
727 \r
728 #if defined(GFXMMU)\r
729 #define __HAL_RCC_GFXMMU_CLK_DISABLE()         CLEAR_BIT(RCC->AHB1ENR, RCC_AHB1ENR_GFXMMUEN)\r
730 #endif /* GFXMMU */\r
731 \r
732 /**\r
733   * @}\r
734   */\r
735 \r
736 /** @defgroup RCC_AHB2_Peripheral_Clock_Enable_Disable AHB2 Peripheral Clock Enable Disable\r
737   * @brief  Enable or disable the AHB2 peripheral clock.\r
738   * @note   After reset, the peripheral clock (used for registers read/write access)\r
739   *         is disabled and the application software has to enable this clock before\r
740   *         using it.\r
741   * @{\r
742   */\r
743 \r
744 #define __HAL_RCC_GPIOA_CLK_ENABLE()           do { \\r
745                                                  __IO uint32_t tmpreg; \\r
746                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOAEN); \\r
747                                                  /* Delay after an RCC peripheral clock enabling */ \\r
748                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOAEN); \\r
749                                                  UNUSED(tmpreg); \\r
750                                                } while(0)\r
751 \r
752 #define __HAL_RCC_GPIOB_CLK_ENABLE()           do { \\r
753                                                  __IO uint32_t tmpreg; \\r
754                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOBEN); \\r
755                                                  /* Delay after an RCC peripheral clock enabling */ \\r
756                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOBEN); \\r
757                                                  UNUSED(tmpreg); \\r
758                                                } while(0)\r
759 \r
760 #define __HAL_RCC_GPIOC_CLK_ENABLE()           do { \\r
761                                                  __IO uint32_t tmpreg; \\r
762                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOCEN); \\r
763                                                  /* Delay after an RCC peripheral clock enabling */ \\r
764                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOCEN); \\r
765                                                  UNUSED(tmpreg); \\r
766                                                } while(0)\r
767 \r
768 #if defined(GPIOD)\r
769 #define __HAL_RCC_GPIOD_CLK_ENABLE()           do { \\r
770                                                  __IO uint32_t tmpreg; \\r
771                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIODEN); \\r
772                                                  /* Delay after an RCC peripheral clock enabling */ \\r
773                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIODEN); \\r
774                                                  UNUSED(tmpreg); \\r
775                                                } while(0)\r
776 #endif /* GPIOD */\r
777 \r
778 #if defined(GPIOE)\r
779 #define __HAL_RCC_GPIOE_CLK_ENABLE()           do { \\r
780                                                  __IO uint32_t tmpreg; \\r
781                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOEEN); \\r
782                                                  /* Delay after an RCC peripheral clock enabling */ \\r
783                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOEEN); \\r
784                                                  UNUSED(tmpreg); \\r
785                                                } while(0)\r
786 #endif /* GPIOE */\r
787 \r
788 #if defined(GPIOF)\r
789 #define __HAL_RCC_GPIOF_CLK_ENABLE()           do { \\r
790                                                  __IO uint32_t tmpreg; \\r
791                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOFEN); \\r
792                                                  /* Delay after an RCC peripheral clock enabling */ \\r
793                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOFEN); \\r
794                                                  UNUSED(tmpreg); \\r
795                                                } while(0)\r
796 #endif /* GPIOF */\r
797 \r
798 #if defined(GPIOG)\r
799 #define __HAL_RCC_GPIOG_CLK_ENABLE()           do { \\r
800                                                  __IO uint32_t tmpreg; \\r
801                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOGEN); \\r
802                                                  /* Delay after an RCC peripheral clock enabling */ \\r
803                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOGEN); \\r
804                                                  UNUSED(tmpreg); \\r
805                                                } while(0)\r
806 #endif /* GPIOG */\r
807 \r
808 #define __HAL_RCC_GPIOH_CLK_ENABLE()           do { \\r
809                                                  __IO uint32_t tmpreg; \\r
810                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOHEN); \\r
811                                                  /* Delay after an RCC peripheral clock enabling */ \\r
812                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOHEN); \\r
813                                                  UNUSED(tmpreg); \\r
814                                                } while(0)\r
815 \r
816 #if defined(GPIOI)\r
817 #define __HAL_RCC_GPIOI_CLK_ENABLE()           do { \\r
818                                                  __IO uint32_t tmpreg; \\r
819                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOIEN); \\r
820                                                  /* Delay after an RCC peripheral clock enabling */ \\r
821                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOIEN); \\r
822                                                  UNUSED(tmpreg); \\r
823                                                } while(0)\r
824 #endif /* GPIOI */\r
825 \r
826 #if defined(USB_OTG_FS)\r
827 #define __HAL_RCC_USB_OTG_FS_CLK_ENABLE()      do { \\r
828                                                  __IO uint32_t tmpreg; \\r
829                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_OTGFSEN); \\r
830                                                  /* Delay after an RCC peripheral clock enabling */ \\r
831                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_OTGFSEN); \\r
832                                                  UNUSED(tmpreg); \\r
833                                                } while(0)\r
834 #endif /* USB_OTG_FS */\r
835 \r
836 #define __HAL_RCC_ADC_CLK_ENABLE()             do { \\r
837                                                  __IO uint32_t tmpreg; \\r
838                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_ADCEN); \\r
839                                                  /* Delay after an RCC peripheral clock enabling */ \\r
840                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_ADCEN); \\r
841                                                  UNUSED(tmpreg); \\r
842                                                } while(0)\r
843 \r
844 #if defined(DCMI)\r
845 #define __HAL_RCC_DCMI_CLK_ENABLE()             do { \\r
846                                                  __IO uint32_t tmpreg; \\r
847                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_DCMIEN); \\r
848                                                  /* Delay after an RCC peripheral clock enabling */ \\r
849                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_DCMIEN); \\r
850                                                  UNUSED(tmpreg); \\r
851                                                } while(0)\r
852 #endif /* DCMI */\r
853 \r
854 #if defined(AES)\r
855 #define __HAL_RCC_AES_CLK_ENABLE()             do { \\r
856                                                  __IO uint32_t tmpreg; \\r
857                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_AESEN); \\r
858                                                  /* Delay after an RCC peripheral clock enabling */ \\r
859                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_AESEN); \\r
860                                                  UNUSED(tmpreg); \\r
861                                                } while(0)\r
862 #endif /* AES */\r
863 \r
864 #if defined(HASH)\r
865 #define __HAL_RCC_HASH_CLK_ENABLE()             do { \\r
866                                                  __IO uint32_t tmpreg; \\r
867                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_HASHEN); \\r
868                                                  /* Delay after an RCC peripheral clock enabling */ \\r
869                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_HASHEN); \\r
870                                                  UNUSED(tmpreg); \\r
871                                                } while(0)\r
872 #endif /* HASH */\r
873 \r
874 #define __HAL_RCC_RNG_CLK_ENABLE()             do { \\r
875                                                  __IO uint32_t tmpreg; \\r
876                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_RNGEN); \\r
877                                                  /* Delay after an RCC peripheral clock enabling */ \\r
878                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_RNGEN); \\r
879                                                  UNUSED(tmpreg); \\r
880                                                } while(0)\r
881 \r
882 #if defined(OCTOSPIM)\r
883 #define __HAL_RCC_OSPIM_CLK_ENABLE()           do { \\r
884                                                  __IO uint32_t tmpreg; \\r
885                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_OSPIMEN); \\r
886                                                  /* Delay after an RCC peripheral clock enabling */ \\r
887                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_OSPIMEN); \\r
888                                                  UNUSED(tmpreg); \\r
889                                                } while(0)\r
890 #endif /* OCTOSPIM */\r
891 \r
892 #if defined(SDMMC1) && defined(RCC_AHB2ENR_SDMMC1EN)\r
893 #define __HAL_RCC_SDMMC1_CLK_ENABLE()          do { \\r
894                                                  __IO uint32_t tmpreg; \\r
895                                                  SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_SDMMC1EN); \\r
896                                                  /* Delay after an RCC peripheral clock enabling */ \\r
897                                                  tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_SDMMC1EN); \\r
898                                                  UNUSED(tmpreg); \\r
899                                                } while(0)\r
900 #endif /* SDMMC1 && RCC_AHB2ENR_SDMMC1EN */\r
901 \r
902 \r
903 #define __HAL_RCC_GPIOA_CLK_DISABLE()          CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOAEN)\r
904 \r
905 #define __HAL_RCC_GPIOB_CLK_DISABLE()          CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOBEN)\r
906 \r
907 #define __HAL_RCC_GPIOC_CLK_DISABLE()          CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOCEN)\r
908 \r
909 #if defined(GPIOD)\r
910 #define __HAL_RCC_GPIOD_CLK_DISABLE()          CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIODEN)\r
911 #endif /* GPIOD */\r
912 \r
913 #if defined(GPIOE)\r
914 #define __HAL_RCC_GPIOE_CLK_DISABLE()          CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOEEN)\r
915 #endif /* GPIOE */\r
916 \r
917 #if defined(GPIOF)\r
918 #define __HAL_RCC_GPIOF_CLK_DISABLE()          CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOFEN)\r
919 #endif /* GPIOF */\r
920 \r
921 #if defined(GPIOG)\r
922 #define __HAL_RCC_GPIOG_CLK_DISABLE()          CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOGEN)\r
923 #endif /* GPIOG */\r
924 \r
925 #define __HAL_RCC_GPIOH_CLK_DISABLE()          CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOHEN)\r
926 \r
927 #if defined(GPIOI)\r
928 #define __HAL_RCC_GPIOI_CLK_DISABLE()          CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOIEN)\r
929 #endif /* GPIOI */\r
930 \r
931 #if defined(USB_OTG_FS)\r
932 #define __HAL_RCC_USB_OTG_FS_CLK_DISABLE()     CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_OTGFSEN);\r
933 #endif /* USB_OTG_FS */\r
934 \r
935 #define __HAL_RCC_ADC_CLK_DISABLE()            CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_ADCEN)\r
936 \r
937 #if defined(DCMI)\r
938 #define __HAL_RCC_DCMI_CLK_DISABLE()           CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_DCMIEN)\r
939 #endif /* DCMI */\r
940 \r
941 #if defined(AES)\r
942 #define __HAL_RCC_AES_CLK_DISABLE()            CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_AESEN);\r
943 #endif /* AES */\r
944 \r
945 #if defined(HASH)\r
946 #define __HAL_RCC_HASH_CLK_DISABLE()           CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_HASHEN)\r
947 #endif /* HASH */\r
948 \r
949 #define __HAL_RCC_RNG_CLK_DISABLE()            CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_RNGEN)\r
950 \r
951 #if defined(OCTOSPIM)\r
952 #define __HAL_RCC_OSPIM_CLK_DISABLE()          CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_OSPIMEN)\r
953 #endif /* OCTOSPIM */\r
954 \r
955 #if defined(SDMMC1) && defined(RCC_AHB2ENR_SDMMC1EN)\r
956 #define __HAL_RCC_SDMMC1_CLK_DISABLE()         CLEAR_BIT(RCC->AHB2ENR, RCC_AHB2ENR_SDMMC1EN)\r
957 #endif /* SDMMC1 && RCC_AHB2ENR_SDMMC1EN */\r
958 \r
959 /**\r
960   * @}\r
961   */\r
962 \r
963 /** @defgroup RCC_AHB3_Clock_Enable_Disable AHB3 Peripheral Clock Enable Disable\r
964   * @brief  Enable or disable the AHB3 peripheral clock.\r
965   * @note   After reset, the peripheral clock (used for registers read/write access)\r
966   *         is disabled and the application software has to enable this clock before\r
967   *         using it.\r
968   * @{\r
969   */\r
970 \r
971 #if defined(FMC_BANK1)\r
972 #define __HAL_RCC_FMC_CLK_ENABLE()             do { \\r
973                                                  __IO uint32_t tmpreg; \\r
974                                                  SET_BIT(RCC->AHB3ENR, RCC_AHB3ENR_FMCEN); \\r
975                                                  /* Delay after an RCC peripheral clock enabling */ \\r
976                                                  tmpreg = READ_BIT(RCC->AHB3ENR, RCC_AHB3ENR_FMCEN); \\r
977                                                  UNUSED(tmpreg); \\r
978                                                } while(0)\r
979 #endif /* FMC_BANK1 */\r
980 \r
981 #if defined(QUADSPI)\r
982 #define __HAL_RCC_QSPI_CLK_ENABLE()            do { \\r
983                                                  __IO uint32_t tmpreg; \\r
984                                                  SET_BIT(RCC->AHB3ENR, RCC_AHB3ENR_QSPIEN); \\r
985                                                  /* Delay after an RCC peripheral clock enabling */ \\r
986                                                  tmpreg = READ_BIT(RCC->AHB3ENR, RCC_AHB3ENR_QSPIEN); \\r
987                                                  UNUSED(tmpreg); \\r
988                                                } while(0)\r
989 #endif /* QUADSPI */\r
990 \r
991 #if defined(OCTOSPI1)\r
992 #define __HAL_RCC_OSPI1_CLK_ENABLE()           do { \\r
993                                                  __IO uint32_t tmpreg; \\r
994                                                  SET_BIT(RCC->AHB3ENR, RCC_AHB3ENR_OSPI1EN); \\r
995                                                  /* Delay after an RCC peripheral clock enabling */ \\r
996                                                  tmpreg = READ_BIT(RCC->AHB3ENR, RCC_AHB3ENR_OSPI1EN); \\r
997                                                  UNUSED(tmpreg); \\r
998                                                } while(0)\r
999 #endif /* OCTOSPI1 */\r
1000 \r
1001 #if defined(OCTOSPI2)\r
1002 #define __HAL_RCC_OSPI2_CLK_ENABLE()           do { \\r
1003                                                  __IO uint32_t tmpreg; \\r
1004                                                  SET_BIT(RCC->AHB3ENR, RCC_AHB3ENR_OSPI2EN); \\r
1005                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1006                                                  tmpreg = READ_BIT(RCC->AHB3ENR, RCC_AHB3ENR_OSPI2EN); \\r
1007                                                  UNUSED(tmpreg); \\r
1008                                                } while(0)\r
1009 #endif /* OCTOSPI2 */\r
1010 \r
1011 #if defined(FMC_BANK1)\r
1012 #define __HAL_RCC_FMC_CLK_DISABLE()            CLEAR_BIT(RCC->AHB3ENR, RCC_AHB3ENR_FMCEN)\r
1013 #endif /* FMC_BANK1 */\r
1014 \r
1015 #if defined(QUADSPI)\r
1016 #define __HAL_RCC_QSPI_CLK_DISABLE()           CLEAR_BIT(RCC->AHB3ENR, RCC_AHB3ENR_QSPIEN)\r
1017 #endif /* QUADSPI */\r
1018 \r
1019 #if defined(OCTOSPI1)\r
1020 #define __HAL_RCC_OSPI1_CLK_DISABLE()          CLEAR_BIT(RCC->AHB3ENR, RCC_AHB3ENR_OSPI1EN)\r
1021 #endif /* OCTOSPI1 */\r
1022 \r
1023 #if defined(OCTOSPI2)\r
1024 #define __HAL_RCC_OSPI2_CLK_DISABLE()          CLEAR_BIT(RCC->AHB3ENR, RCC_AHB3ENR_OSPI2EN)\r
1025 #endif /* OCTOSPI2 */\r
1026 \r
1027 /**\r
1028   * @}\r
1029   */\r
1030 \r
1031 /** @defgroup RCC_APB1_Clock_Enable_Disable APB1 Peripheral Clock Enable Disable\r
1032   * @brief  Enable or disable the APB1 peripheral clock.\r
1033   * @note   After reset, the peripheral clock (used for registers read/write access)\r
1034   *         is disabled and the application software has to enable this clock before\r
1035   *         using it.\r
1036   * @{\r
1037   */\r
1038 \r
1039 #define __HAL_RCC_TIM2_CLK_ENABLE()            do { \\r
1040                                                  __IO uint32_t tmpreg; \\r
1041                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM2EN); \\r
1042                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1043                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM2EN); \\r
1044                                                  UNUSED(tmpreg); \\r
1045                                                } while(0)\r
1046 \r
1047 #if defined(TIM3)\r
1048 #define __HAL_RCC_TIM3_CLK_ENABLE()            do { \\r
1049                                                  __IO uint32_t tmpreg; \\r
1050                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM3EN); \\r
1051                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1052                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM3EN); \\r
1053                                                  UNUSED(tmpreg); \\r
1054                                                } while(0)\r
1055 #endif /* TIM3 */\r
1056 \r
1057 #if defined(TIM4)\r
1058 #define __HAL_RCC_TIM4_CLK_ENABLE()            do { \\r
1059                                                  __IO uint32_t tmpreg; \\r
1060                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM4EN); \\r
1061                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1062                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM4EN); \\r
1063                                                  UNUSED(tmpreg); \\r
1064                                                } while(0)\r
1065 #endif /* TIM4 */\r
1066 \r
1067 #if defined(TIM5)\r
1068 #define __HAL_RCC_TIM5_CLK_ENABLE()            do { \\r
1069                                                  __IO uint32_t tmpreg; \\r
1070                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM5EN); \\r
1071                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1072                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM5EN); \\r
1073                                                  UNUSED(tmpreg); \\r
1074                                                } while(0)\r
1075 #endif /* TIM5 */\r
1076 \r
1077 #define __HAL_RCC_TIM6_CLK_ENABLE()            do { \\r
1078                                                  __IO uint32_t tmpreg; \\r
1079                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM6EN); \\r
1080                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1081                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM6EN); \\r
1082                                                  UNUSED(tmpreg); \\r
1083                                                } while(0)\r
1084 \r
1085 #if defined(TIM7)\r
1086 #define __HAL_RCC_TIM7_CLK_ENABLE()            do { \\r
1087                                                  __IO uint32_t tmpreg; \\r
1088                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM7EN); \\r
1089                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1090                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM7EN); \\r
1091                                                  UNUSED(tmpreg); \\r
1092                                                } while(0)\r
1093 #endif /* TIM7 */\r
1094 \r
1095 #if defined(LCD)\r
1096 #define __HAL_RCC_LCD_CLK_ENABLE()             do { \\r
1097                                                  __IO uint32_t tmpreg; \\r
1098                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_LCDEN); \\r
1099                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1100                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_LCDEN); \\r
1101                                                  UNUSED(tmpreg); \\r
1102                                                } while(0)\r
1103 #endif /* LCD */\r
1104 \r
1105 #if defined(RCC_APB1ENR1_RTCAPBEN)\r
1106 #define __HAL_RCC_RTCAPB_CLK_ENABLE()          do { \\r
1107                                                  __IO uint32_t tmpreg; \\r
1108                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_RTCAPBEN); \\r
1109                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1110                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_RTCAPBEN); \\r
1111                                                  UNUSED(tmpreg); \\r
1112                                                } while(0)\r
1113 #endif /* RCC_APB1ENR1_RTCAPBEN */\r
1114 \r
1115 #define __HAL_RCC_WWDG_CLK_ENABLE()            do { \\r
1116                                                  __IO uint32_t tmpreg; \\r
1117                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_WWDGEN); \\r
1118                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1119                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_WWDGEN); \\r
1120                                                  UNUSED(tmpreg); \\r
1121                                                } while(0)\r
1122 \r
1123 #if defined(SPI2)\r
1124 #define __HAL_RCC_SPI2_CLK_ENABLE()            do { \\r
1125                                                  __IO uint32_t tmpreg; \\r
1126                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_SPI2EN); \\r
1127                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1128                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_SPI2EN); \\r
1129                                                  UNUSED(tmpreg); \\r
1130                                                } while(0)\r
1131 #endif /* SPI2 */\r
1132 \r
1133 #if defined(SPI3)\r
1134 #define __HAL_RCC_SPI3_CLK_ENABLE()            do { \\r
1135                                                  __IO uint32_t tmpreg; \\r
1136                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_SPI3EN); \\r
1137                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1138                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_SPI3EN); \\r
1139                                                  UNUSED(tmpreg); \\r
1140                                                } while(0)\r
1141 #endif /* SPI3 */\r
1142 \r
1143 #define __HAL_RCC_USART2_CLK_ENABLE()          do { \\r
1144                                                  __IO uint32_t tmpreg; \\r
1145                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USART2EN); \\r
1146                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1147                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USART2EN); \\r
1148                                                  UNUSED(tmpreg); \\r
1149                                                } while(0)\r
1150 \r
1151 #if defined(USART3)\r
1152 #define __HAL_RCC_USART3_CLK_ENABLE()          do { \\r
1153                                                  __IO uint32_t tmpreg; \\r
1154                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USART3EN); \\r
1155                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1156                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USART3EN); \\r
1157                                                  UNUSED(tmpreg); \\r
1158                                                } while(0)\r
1159 #endif /* USART3 */\r
1160 \r
1161 #if defined(UART4)\r
1162 #define __HAL_RCC_UART4_CLK_ENABLE()           do { \\r
1163                                                  __IO uint32_t tmpreg; \\r
1164                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_UART4EN); \\r
1165                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1166                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_UART4EN); \\r
1167                                                  UNUSED(tmpreg); \\r
1168                                                } while(0)\r
1169 #endif /* UART4 */\r
1170 \r
1171 #if defined(UART5)\r
1172 #define __HAL_RCC_UART5_CLK_ENABLE()           do { \\r
1173                                                  __IO uint32_t tmpreg; \\r
1174                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_UART5EN); \\r
1175                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1176                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_UART5EN); \\r
1177                                                  UNUSED(tmpreg); \\r
1178                                                } while(0)\r
1179 #endif /* UART5 */\r
1180 \r
1181 #define __HAL_RCC_I2C1_CLK_ENABLE()            do { \\r
1182                                                  __IO uint32_t tmpreg; \\r
1183                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C1EN); \\r
1184                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1185                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C1EN); \\r
1186                                                  UNUSED(tmpreg); \\r
1187                                                } while(0)\r
1188 \r
1189 #if defined(I2C2)\r
1190 #define __HAL_RCC_I2C2_CLK_ENABLE()            do { \\r
1191                                                  __IO uint32_t tmpreg; \\r
1192                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C2EN); \\r
1193                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1194                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C2EN); \\r
1195                                                  UNUSED(tmpreg); \\r
1196                                                } while(0)\r
1197 #endif /* I2C2 */\r
1198 \r
1199 #define __HAL_RCC_I2C3_CLK_ENABLE()            do { \\r
1200                                                  __IO uint32_t tmpreg; \\r
1201                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C3EN); \\r
1202                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1203                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C3EN); \\r
1204                                                  UNUSED(tmpreg); \\r
1205                                                } while(0)\r
1206 \r
1207 #if defined(I2C4)\r
1208 #define __HAL_RCC_I2C4_CLK_ENABLE()            do { \\r
1209                                                  __IO uint32_t tmpreg; \\r
1210                                                  SET_BIT(RCC->APB1ENR2, RCC_APB1ENR2_I2C4EN); \\r
1211                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1212                                                  tmpreg = READ_BIT(RCC->APB1ENR2, RCC_APB1ENR2_I2C4EN); \\r
1213                                                  UNUSED(tmpreg); \\r
1214                                                } while(0)\r
1215 #endif /* I2C4 */\r
1216 \r
1217 #if defined(CRS)\r
1218 #define __HAL_RCC_CRS_CLK_ENABLE()             do { \\r
1219                                                  __IO uint32_t tmpreg; \\r
1220                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CRSEN); \\r
1221                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1222                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CRSEN); \\r
1223                                                  UNUSED(tmpreg); \\r
1224                                                } while(0)\r
1225 #endif /* CRS */\r
1226 \r
1227 #if defined(CAN1)\r
1228 #define __HAL_RCC_CAN1_CLK_ENABLE()            do { \\r
1229                                                  __IO uint32_t tmpreg; \\r
1230                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CAN1EN); \\r
1231                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1232                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CAN1EN); \\r
1233                                                  UNUSED(tmpreg); \\r
1234                                                } while(0)\r
1235 #endif /* CAN1 */\r
1236 \r
1237 #if defined(CAN2)\r
1238 #define __HAL_RCC_CAN2_CLK_ENABLE()            do { \\r
1239                                                  __IO uint32_t tmpreg; \\r
1240                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CAN2EN); \\r
1241                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1242                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CAN2EN); \\r
1243                                                  UNUSED(tmpreg); \\r
1244                                                } while(0)\r
1245 #endif /* CAN2 */\r
1246 \r
1247 #if defined(USB)\r
1248 #define __HAL_RCC_USB_CLK_ENABLE()             do { \\r
1249                                                  __IO uint32_t tmpreg; \\r
1250                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USBFSEN); \\r
1251                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1252                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USBFSEN); \\r
1253                                                  UNUSED(tmpreg); \\r
1254                                                } while(0)\r
1255 #endif /* USB */\r
1256 \r
1257 #define __HAL_RCC_PWR_CLK_ENABLE()             do { \\r
1258                                                  __IO uint32_t tmpreg; \\r
1259                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_PWREN); \\r
1260                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1261                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_PWREN); \\r
1262                                                  UNUSED(tmpreg); \\r
1263                                                } while(0)\r
1264 \r
1265 #if defined(DAC1)\r
1266 #define __HAL_RCC_DAC1_CLK_ENABLE()            do { \\r
1267                                                  __IO uint32_t tmpreg; \\r
1268                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_DAC1EN); \\r
1269                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1270                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_DAC1EN); \\r
1271                                                  UNUSED(tmpreg); \\r
1272                                                } while(0)\r
1273 #endif /* DAC1 */\r
1274 \r
1275 #define __HAL_RCC_OPAMP_CLK_ENABLE()           do { \\r
1276                                                  __IO uint32_t tmpreg; \\r
1277                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_OPAMPEN); \\r
1278                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1279                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_OPAMPEN); \\r
1280                                                  UNUSED(tmpreg); \\r
1281                                                } while(0)\r
1282 \r
1283 #define __HAL_RCC_LPTIM1_CLK_ENABLE()          do { \\r
1284                                                  __IO uint32_t tmpreg; \\r
1285                                                  SET_BIT(RCC->APB1ENR1, RCC_APB1ENR1_LPTIM1EN); \\r
1286                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1287                                                  tmpreg = READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_LPTIM1EN); \\r
1288                                                  UNUSED(tmpreg); \\r
1289                                                } while(0)\r
1290 \r
1291 #define __HAL_RCC_LPUART1_CLK_ENABLE()         do { \\r
1292                                                  __IO uint32_t tmpreg; \\r
1293                                                  SET_BIT(RCC->APB1ENR2, RCC_APB1ENR2_LPUART1EN); \\r
1294                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1295                                                  tmpreg = READ_BIT(RCC->APB1ENR2, RCC_APB1ENR2_LPUART1EN); \\r
1296                                                  UNUSED(tmpreg); \\r
1297                                                } while(0)\r
1298 \r
1299 #if defined(SWPMI1)\r
1300 #define __HAL_RCC_SWPMI1_CLK_ENABLE()          do { \\r
1301                                                  __IO uint32_t tmpreg; \\r
1302                                                  SET_BIT(RCC->APB1ENR2, RCC_APB1ENR2_SWPMI1EN); \\r
1303                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1304                                                  tmpreg = READ_BIT(RCC->APB1ENR2, RCC_APB1ENR2_SWPMI1EN); \\r
1305                                                  UNUSED(tmpreg); \\r
1306                                                } while(0)\r
1307 #endif /* SWPMI1 */\r
1308 \r
1309 #define __HAL_RCC_LPTIM2_CLK_ENABLE()          do { \\r
1310                                                  __IO uint32_t tmpreg; \\r
1311                                                  SET_BIT(RCC->APB1ENR2, RCC_APB1ENR2_LPTIM2EN); \\r
1312                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1313                                                  tmpreg = READ_BIT(RCC->APB1ENR2, RCC_APB1ENR2_LPTIM2EN); \\r
1314                                                  UNUSED(tmpreg); \\r
1315                                                } while(0)\r
1316 \r
1317 \r
1318 #define __HAL_RCC_TIM2_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM2EN)\r
1319 \r
1320 #if defined(TIM3)\r
1321 #define __HAL_RCC_TIM3_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM3EN)\r
1322 #endif /* TIM3 */\r
1323 \r
1324 #if defined(TIM4)\r
1325 #define __HAL_RCC_TIM4_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM4EN)\r
1326 #endif /* TIM4 */\r
1327 \r
1328 #if defined(TIM5)\r
1329 #define __HAL_RCC_TIM5_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM5EN)\r
1330 #endif /* TIM5 */\r
1331 \r
1332 #define __HAL_RCC_TIM6_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM6EN)\r
1333 \r
1334 #if defined(TIM7)\r
1335 #define __HAL_RCC_TIM7_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM7EN)\r
1336 #endif /* TIM7 */\r
1337 \r
1338 #if defined(LCD)\r
1339 #define __HAL_RCC_LCD_CLK_DISABLE()            CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_LCDEN);\r
1340 #endif /* LCD */\r
1341 \r
1342 #if defined(RCC_APB1ENR1_RTCAPBEN)\r
1343 #define __HAL_RCC_RTCAPB_CLK_DISABLE()         CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_RTCAPBEN);\r
1344 #endif /* RCC_APB1ENR1_RTCAPBEN */\r
1345 \r
1346 #if defined(SPI2)\r
1347 #define __HAL_RCC_SPI2_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_SPI2EN)\r
1348 #endif /* SPI2 */\r
1349 \r
1350 #if defined(SPI3)\r
1351 #define __HAL_RCC_SPI3_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_SPI3EN)\r
1352 #endif /* SPI3 */\r
1353 \r
1354 #define __HAL_RCC_USART2_CLK_DISABLE()         CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USART2EN)\r
1355 \r
1356 #if defined(USART3)\r
1357 #define __HAL_RCC_USART3_CLK_DISABLE()         CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USART3EN)\r
1358 #endif /* USART3 */\r
1359 \r
1360 #if defined(UART4)\r
1361 #define __HAL_RCC_UART4_CLK_DISABLE()          CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_UART4EN)\r
1362 #endif /* UART4 */\r
1363 \r
1364 #if defined(UART5)\r
1365 #define __HAL_RCC_UART5_CLK_DISABLE()          CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_UART5EN)\r
1366 #endif /* UART5 */\r
1367 \r
1368 #define __HAL_RCC_I2C1_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C1EN)\r
1369 \r
1370 #if defined(I2C2)\r
1371 #define __HAL_RCC_I2C2_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C2EN)\r
1372 #endif /* I2C2 */\r
1373 \r
1374 #define __HAL_RCC_I2C3_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C3EN)\r
1375 \r
1376 #if defined(I2C4)\r
1377 #define __HAL_RCC_I2C4_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR2, RCC_APB1ENR2_I2C4EN)\r
1378 #endif /* I2C4 */\r
1379 \r
1380 #if defined(CRS)\r
1381 #define __HAL_RCC_CRS_CLK_DISABLE()            CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CRSEN);\r
1382 #endif /* CRS */\r
1383 \r
1384 #if defined(CAN1)\r
1385 #define __HAL_RCC_CAN1_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CAN1EN)\r
1386 #endif /* CAN1 */\r
1387 \r
1388 #if defined(CAN2)\r
1389 #define __HAL_RCC_CAN2_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CAN2EN)\r
1390 #endif /* CAN2 */\r
1391 \r
1392 #if defined(USB)\r
1393 #define __HAL_RCC_USB_CLK_DISABLE()            CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USBFSEN);\r
1394 #endif /* USB */\r
1395 \r
1396 #define __HAL_RCC_PWR_CLK_DISABLE()            CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_PWREN)\r
1397 \r
1398 #if defined(DAC1)\r
1399 #define __HAL_RCC_DAC1_CLK_DISABLE()           CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_DAC1EN)\r
1400 #endif /* DAC1 */\r
1401 \r
1402 #define __HAL_RCC_OPAMP_CLK_DISABLE()          CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_OPAMPEN)\r
1403 \r
1404 #define __HAL_RCC_LPTIM1_CLK_DISABLE()         CLEAR_BIT(RCC->APB1ENR1, RCC_APB1ENR1_LPTIM1EN)\r
1405 \r
1406 #define __HAL_RCC_LPUART1_CLK_DISABLE()        CLEAR_BIT(RCC->APB1ENR2, RCC_APB1ENR2_LPUART1EN)\r
1407 \r
1408 #if defined(SWPMI1)\r
1409 #define __HAL_RCC_SWPMI1_CLK_DISABLE()         CLEAR_BIT(RCC->APB1ENR2, RCC_APB1ENR2_SWPMI1EN)\r
1410 #endif /* SWPMI1 */\r
1411 \r
1412 #define __HAL_RCC_LPTIM2_CLK_DISABLE()         CLEAR_BIT(RCC->APB1ENR2, RCC_APB1ENR2_LPTIM2EN)\r
1413 \r
1414 /**\r
1415   * @}\r
1416   */\r
1417 \r
1418 /** @defgroup RCC_APB2_Clock_Enable_Disable APB2 Peripheral Clock Enable Disable\r
1419   * @brief  Enable or disable the APB2 peripheral clock.\r
1420   * @note   After reset, the peripheral clock (used for registers read/write access)\r
1421   *         is disabled and the application software has to enable this clock before\r
1422   *         using it.\r
1423   * @{\r
1424   */\r
1425 \r
1426 #define __HAL_RCC_SYSCFG_CLK_ENABLE()          do { \\r
1427                                                  __IO uint32_t tmpreg; \\r
1428                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SYSCFGEN); \\r
1429                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1430                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SYSCFGEN); \\r
1431                                                  UNUSED(tmpreg); \\r
1432                                                } while(0)\r
1433 \r
1434 #define __HAL_RCC_FIREWALL_CLK_ENABLE()        do { \\r
1435                                                  __IO uint32_t tmpreg; \\r
1436                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_FWEN); \\r
1437                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1438                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_FWEN); \\r
1439                                                  UNUSED(tmpreg); \\r
1440                                                } while(0)\r
1441 \r
1442 #if defined(SDMMC1) && defined(RCC_APB2ENR_SDMMC1EN)\r
1443 #define __HAL_RCC_SDMMC1_CLK_ENABLE()          do { \\r
1444                                                  __IO uint32_t tmpreg; \\r
1445                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SDMMC1EN); \\r
1446                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1447                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SDMMC1EN); \\r
1448                                                  UNUSED(tmpreg); \\r
1449                                                } while(0)\r
1450 #endif /* SDMMC1 && RCC_APB2ENR_SDMMC1EN */\r
1451 \r
1452 #define __HAL_RCC_TIM1_CLK_ENABLE()            do { \\r
1453                                                  __IO uint32_t tmpreg; \\r
1454                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM1EN); \\r
1455                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1456                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM1EN); \\r
1457                                                  UNUSED(tmpreg); \\r
1458                                                } while(0)\r
1459 \r
1460 #define __HAL_RCC_SPI1_CLK_ENABLE()            do { \\r
1461                                                  __IO uint32_t tmpreg; \\r
1462                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN); \\r
1463                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1464                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN); \\r
1465                                                  UNUSED(tmpreg); \\r
1466                                                } while(0)\r
1467 \r
1468 #if defined(TIM8)\r
1469 #define __HAL_RCC_TIM8_CLK_ENABLE()            do { \\r
1470                                                  __IO uint32_t tmpreg; \\r
1471                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM8EN); \\r
1472                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1473                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM8EN); \\r
1474                                                  UNUSED(tmpreg); \\r
1475                                                } while(0)\r
1476 #endif /* TIM8 */\r
1477 \r
1478 #define __HAL_RCC_USART1_CLK_ENABLE()          do { \\r
1479                                                  __IO uint32_t tmpreg; \\r
1480                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_USART1EN); \\r
1481                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1482                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_USART1EN); \\r
1483                                                  UNUSED(tmpreg); \\r
1484                                                } while(0)\r
1485 \r
1486 \r
1487 #define __HAL_RCC_TIM15_CLK_ENABLE()           do { \\r
1488                                                  __IO uint32_t tmpreg; \\r
1489                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM15EN); \\r
1490                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1491                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM15EN); \\r
1492                                                  UNUSED(tmpreg); \\r
1493                                                } while(0)\r
1494 \r
1495 #define __HAL_RCC_TIM16_CLK_ENABLE()           do { \\r
1496                                                  __IO uint32_t tmpreg; \\r
1497                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM16EN); \\r
1498                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1499                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM16EN); \\r
1500                                                  UNUSED(tmpreg); \\r
1501                                                } while(0)\r
1502 \r
1503 #if defined(TIM17)\r
1504 #define __HAL_RCC_TIM17_CLK_ENABLE()           do { \\r
1505                                                  __IO uint32_t tmpreg; \\r
1506                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM17EN); \\r
1507                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1508                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM17EN); \\r
1509                                                  UNUSED(tmpreg); \\r
1510                                                } while(0)\r
1511 #endif /* TIM17 */\r
1512 \r
1513 #if defined(SAI1)\r
1514 #define __HAL_RCC_SAI1_CLK_ENABLE()            do { \\r
1515                                                  __IO uint32_t tmpreg; \\r
1516                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SAI1EN); \\r
1517                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1518                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SAI1EN); \\r
1519                                                  UNUSED(tmpreg); \\r
1520                                                } while(0)\r
1521 #endif /* SAI1 */\r
1522 \r
1523 #if defined(SAI2)\r
1524 #define __HAL_RCC_SAI2_CLK_ENABLE()            do { \\r
1525                                                  __IO uint32_t tmpreg; \\r
1526                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SAI2EN); \\r
1527                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1528                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SAI2EN); \\r
1529                                                  UNUSED(tmpreg); \\r
1530                                                } while(0)\r
1531 #endif /* SAI2 */\r
1532 \r
1533 #if defined(DFSDM1_Filter0)\r
1534 #define __HAL_RCC_DFSDM1_CLK_ENABLE()          do { \\r
1535                                                  __IO uint32_t tmpreg; \\r
1536                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_DFSDM1EN); \\r
1537                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1538                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_DFSDM1EN); \\r
1539                                                  UNUSED(tmpreg); \\r
1540                                                } while(0)\r
1541 #endif /* DFSDM1_Filter0 */\r
1542 \r
1543 #if defined(LTDC)\r
1544 #define __HAL_RCC_LTDC_CLK_ENABLE()            do { \\r
1545                                                  __IO uint32_t tmpreg; \\r
1546                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_LTDCEN); \\r
1547                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1548                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_LTDCEN); \\r
1549                                                  UNUSED(tmpreg); \\r
1550                                                } while(0)\r
1551 #endif /* LTDC */\r
1552 \r
1553 #if defined(DSI)\r
1554 #define __HAL_RCC_DSI_CLK_ENABLE()             do { \\r
1555                                                  __IO uint32_t tmpreg; \\r
1556                                                  SET_BIT(RCC->APB2ENR, RCC_APB2ENR_DSIEN); \\r
1557                                                  /* Delay after an RCC peripheral clock enabling */ \\r
1558                                                  tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_DSIEN); \\r
1559                                                  UNUSED(tmpreg); \\r
1560                                                } while(0)\r
1561 #endif /* DSI */\r
1562 \r
1563 \r
1564 #define __HAL_RCC_SYSCFG_CLK_DISABLE()         CLEAR_BIT(RCC->APB2ENR, RCC_APB2ENR_SYSCFGEN)\r
1565 \r
1566 #if defined(SDMMC1) && defined(RCC_APB2ENR_SDMMC1EN)\r
1567 #define __HAL_RCC_SDMMC1_CLK_DISABLE()         CLEAR_BIT(RCC->APB2ENR, RCC_APB2ENR_SDMMC1EN)\r
1568 #endif /* SDMMC1 && RCC_APB2ENR_SDMMC1EN */\r
1569 \r
1570 #define __HAL_RCC_TIM1_CLK_DISABLE()           CLEAR_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM1EN)\r
1571 \r
1572 #define __HAL_RCC_SPI1_CLK_DISABLE()           CLEAR_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN)\r
1573 \r
1574 #if defined(TIM8)\r
1575 #define __HAL_RCC_TIM8_CLK_DISABLE()           CLEAR_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM8EN)\r
1576 #endif /* TIM8 */\r
1577 \r
1578 #define __HAL_RCC_USART1_CLK_DISABLE()         CLEAR_BIT(RCC->APB2ENR, RCC_APB2ENR_USART1EN)\r
1579 \r
1580 #define __HAL_RCC_TIM15_CLK_DISABLE()          CLEAR_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM15EN)\r
1581 \r
1582 #define __HAL_RCC_TIM16_CLK_DISABLE()          CLEAR_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM16EN)\r
1583 \r
1584 #if defined(TIM17)\r
1585 #define __HAL_RCC_TIM17_CLK_DISABLE()          CLEAR_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM17EN)\r
1586 #endif /* TIM17 */\r
1587 \r
1588 #if defined(SAI1)\r
1589 #define __HAL_RCC_SAI1_CLK_DISABLE()           CLEAR_BIT(RCC->APB2ENR, RCC_APB2ENR_SAI1EN)\r
1590 #endif /* SAI1 */\r
1591 \r
1592 #if defined(SAI2)\r
1593 #define __HAL_RCC_SAI2_CLK_DISABLE()           CLEAR_BIT(RCC->APB2ENR, RCC_APB2ENR_SAI2EN)\r
1594 #endif /* SAI2 */\r
1595 \r
1596 #if defined(DFSDM1_Filter0)\r
1597 #define __HAL_RCC_DFSDM1_CLK_DISABLE()         CLEAR_BIT(RCC->APB2ENR, RCC_APB2ENR_DFSDM1EN)\r
1598 #endif /* DFSDM1_Filter0 */\r
1599 \r
1600 #if defined(LTDC)\r
1601 #define __HAL_RCC_LTDC_CLK_DISABLE()           CLEAR_BIT(RCC->APB2ENR, RCC_APB2ENR_LTDCEN)\r
1602 #endif /* LTDC */\r
1603 \r
1604 #if defined(DSI)\r
1605 #define __HAL_RCC_DSI_CLK_DISABLE()            CLEAR_BIT(RCC->APB2ENR, RCC_APB2ENR_DSIEN)\r
1606 #endif /* DSI */\r
1607 \r
1608 /**\r
1609   * @}\r
1610   */\r
1611 \r
1612 /** @defgroup RCC_AHB1_Peripheral_Clock_Enable_Disable_Status AHB1 Peripheral Clock Enabled or Disabled Status\r
1613   * @brief  Check whether the AHB1 peripheral clock is enabled or not.\r
1614   * @note   After reset, the peripheral clock (used for registers read/write access)\r
1615   *         is disabled and the application software has to enable this clock before\r
1616   *         using it.\r
1617   * @{\r
1618   */\r
1619 \r
1620 #define __HAL_RCC_DMA1_IS_CLK_ENABLED()        (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA1EN) != 0U)\r
1621 \r
1622 #define __HAL_RCC_DMA2_IS_CLK_ENABLED()        (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA2EN) != 0U)\r
1623 \r
1624 #if defined(DMAMUX1)\r
1625 #define __HAL_RCC_DMAMUX1_IS_CLK_ENABLED()     (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMAMUX1EN) != 0U)\r
1626 #endif /* DMAMUX1 */\r
1627 \r
1628 #define __HAL_RCC_FLASH_IS_CLK_ENABLED()       (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_FLASHEN) != 0U)\r
1629 \r
1630 #define __HAL_RCC_CRC_IS_CLK_ENABLED()         (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_CRCEN) != 0U)\r
1631 \r
1632 #define __HAL_RCC_TSC_IS_CLK_ENABLED()         (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_TSCEN) != 0U)\r
1633 \r
1634 #if defined(DMA2D)\r
1635 #define __HAL_RCC_DMA2D_IS_CLK_ENABLED()       (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA2DEN) != 0U)\r
1636 #endif /* DMA2D */\r
1637 \r
1638 #if defined(GFXMMU)\r
1639 #define __HAL_RCC_GFXMMU_IS_CLK_ENABLED()      (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_GFXMMUEN) != 0U)\r
1640 #endif /* GFXMMU */\r
1641 \r
1642 \r
1643 #define __HAL_RCC_DMA1_IS_CLK_DISABLED()       (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA1EN) == 0U)\r
1644 \r
1645 #define __HAL_RCC_DMA2_IS_CLK_DISABLED()       (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA2EN) == 0U)\r
1646 \r
1647 #if defined(DMAMUX1)\r
1648 #define __HAL_RCC_DMAMUX1_IS_CLK_DISABLED()    (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMAMUX1EN) == 0U)\r
1649 #endif /* DMAMUX1 */\r
1650 \r
1651 #define __HAL_RCC_FLASH_IS_CLK_DISABLED()      (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_FLASHEN) == 0U)\r
1652 \r
1653 #define __HAL_RCC_CRC_IS_CLK_DISABLED()        (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_CRCEN) == 0U)\r
1654 \r
1655 #define __HAL_RCC_TSC_IS_CLK_DISABLED()        (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_TSCEN) == 0U)\r
1656 \r
1657 #if defined(DMA2D)\r
1658 #define __HAL_RCC_DMA2D_IS_CLK_DISABLED()      (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_DMA2DEN) == 0U)\r
1659 #endif /* DMA2D */\r
1660 \r
1661 #if defined(GFXMMU)\r
1662 #define __HAL_RCC_GFXMMU_IS_CLK_DISABLED()     (READ_BIT(RCC->AHB1ENR, RCC_AHB1ENR_GFXMMUEN) == 0U)\r
1663 #endif /* GFXMMU */\r
1664 \r
1665 /**\r
1666   * @}\r
1667   */\r
1668 \r
1669 /** @defgroup RCC_AHB2_Clock_Enable_Disable_Status AHB2 Peripheral Clock Enabled or Disabled Status\r
1670   * @brief  Check whether the AHB2 peripheral clock is enabled or not.\r
1671   * @note   After reset, the peripheral clock (used for registers read/write access)\r
1672   *         is disabled and the application software has to enable this clock before\r
1673   *         using it.\r
1674   * @{\r
1675   */\r
1676 \r
1677 #define __HAL_RCC_GPIOA_IS_CLK_ENABLED()       (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOAEN) != 0U)\r
1678 \r
1679 #define __HAL_RCC_GPIOB_IS_CLK_ENABLED()       (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOBEN) != 0U)\r
1680 \r
1681 #define __HAL_RCC_GPIOC_IS_CLK_ENABLED()       (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOCEN) != 0U)\r
1682 \r
1683 #if defined(GPIOD)\r
1684 #define __HAL_RCC_GPIOD_IS_CLK_ENABLED()       (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIODEN) != 0U)\r
1685 #endif /* GPIOD */\r
1686 \r
1687 #if defined(GPIOE)\r
1688 #define __HAL_RCC_GPIOE_IS_CLK_ENABLED()       (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOEEN) != 0U)\r
1689 #endif /* GPIOE */\r
1690 \r
1691 #if defined(GPIOF)\r
1692 #define __HAL_RCC_GPIOF_IS_CLK_ENABLED()       (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOFEN) != 0U)\r
1693 #endif /* GPIOF */\r
1694 \r
1695 #if defined(GPIOG)\r
1696 #define __HAL_RCC_GPIOG_IS_CLK_ENABLED()       (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOGEN) != 0U)\r
1697 #endif /* GPIOG */\r
1698 \r
1699 #define __HAL_RCC_GPIOH_IS_CLK_ENABLED()       (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOHEN) != 0U)\r
1700 \r
1701 #if defined(GPIOI)\r
1702 #define __HAL_RCC_GPIOI_IS_CLK_ENABLED()       (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOIEN) != 0U)\r
1703 #endif /* GPIOI */\r
1704 \r
1705 #if defined(USB_OTG_FS)\r
1706 #define __HAL_RCC_USB_OTG_FS_IS_CLK_ENABLED()  (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_OTGFSEN) != 0U)\r
1707 #endif /* USB_OTG_FS */\r
1708 \r
1709 #define __HAL_RCC_ADC_IS_CLK_ENABLED()         (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_ADCEN) != 0U)\r
1710 \r
1711 #if defined(DCMI)\r
1712 #define __HAL_RCC_DCMI_IS_CLK_ENABLED()        (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_DCMIEN) != 0U)\r
1713 #endif /* DCMI */\r
1714 \r
1715 #if defined(AES)\r
1716 #define __HAL_RCC_AES_IS_CLK_ENABLED()         (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_AESEN) != 0U)\r
1717 #endif /* AES */\r
1718 \r
1719 #if defined(HASH)\r
1720 #define __HAL_RCC_HASH_IS_CLK_ENABLED()        (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_HASHEN) != 0U)\r
1721 #endif /* HASH */\r
1722 \r
1723 #define __HAL_RCC_RNG_IS_CLK_ENABLED()         (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_RNGEN) != 0U)\r
1724 \r
1725 \r
1726 #define __HAL_RCC_GPIOA_IS_CLK_DISABLED()      (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOAEN) == 0U)\r
1727 \r
1728 #define __HAL_RCC_GPIOB_IS_CLK_DISABLED()      (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOBEN) == 0U)\r
1729 \r
1730 #define __HAL_RCC_GPIOC_IS_CLK_DISABLED()      (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOCEN) == 0U)\r
1731 \r
1732 #if defined(GPIOD)\r
1733 #define __HAL_RCC_GPIOD_IS_CLK_DISABLED()      (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIODEN) == 0U)\r
1734 #endif /* GPIOD */\r
1735 \r
1736 #if defined(GPIOE)\r
1737 #define __HAL_RCC_GPIOE_IS_CLK_DISABLED()      (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOEEN) == 0U)\r
1738 #endif /* GPIOE */\r
1739 \r
1740 #if defined(GPIOF)\r
1741 #define __HAL_RCC_GPIOF_IS_CLK_DISABLED()      (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOFEN) == 0U)\r
1742 #endif /* GPIOF */\r
1743 \r
1744 #if defined(GPIOG)\r
1745 #define __HAL_RCC_GPIOG_IS_CLK_DISABLED()      (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOGEN) == 0U)\r
1746 #endif /* GPIOG */\r
1747 \r
1748 #define __HAL_RCC_GPIOH_IS_CLK_DISABLED()      (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOHEN) == 0U)\r
1749 \r
1750 #if defined(GPIOI)\r
1751 #define __HAL_RCC_GPIOI_IS_CLK_DISABLED()      (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_GPIOIEN) == 0U)\r
1752 #endif /* GPIOI */\r
1753 \r
1754 #if defined(USB_OTG_FS)\r
1755 #define __HAL_RCC_USB_OTG_FS_IS_CLK_DISABLED() (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_OTGFSEN) == 0U)\r
1756 #endif /* USB_OTG_FS */\r
1757 \r
1758 #define __HAL_RCC_ADC_IS_CLK_DISABLED()        (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_ADCEN) == 0U)\r
1759 \r
1760 #if defined(DCMI)\r
1761 #define __HAL_RCC_DCMI_IS_CLK_DISABLED()       (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_DCMIEN) == 0U)\r
1762 #endif /* DCMI */\r
1763 \r
1764 #if defined(AES)\r
1765 #define __HAL_RCC_AES_IS_CLK_DISABLED()        (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_AESEN) == 0U)\r
1766 #endif /* AES */\r
1767 \r
1768 #if defined(HASH)\r
1769 #define __HAL_RCC_HASH_IS_CLK_DISABLED()       (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_HASHEN) == 0U)\r
1770 #endif /* HASH */\r
1771 \r
1772 #define __HAL_RCC_RNG_IS_CLK_DISABLED()        (READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_RNGEN) == 0U)\r
1773 \r
1774 /**\r
1775   * @}\r
1776   */\r
1777 \r
1778 /** @defgroup RCC_AHB3_Clock_Enable_Disable_Status AHB3 Peripheral Clock Enabled or Disabled Status\r
1779   * @brief  Check whether the AHB3 peripheral clock is enabled or not.\r
1780   * @note   After reset, the peripheral clock (used for registers read/write access)\r
1781   *         is disabled and the application software has to enable this clock before\r
1782   *         using it.\r
1783   * @{\r
1784   */\r
1785 \r
1786 #if defined(FMC_BANK1)\r
1787 #define __HAL_RCC_FMC_IS_CLK_ENABLED()         (READ_BIT(RCC->AHB3ENR, RCC_AHB3ENR_FMCEN) != 0U)\r
1788 #endif /* FMC_BANK1 */\r
1789 \r
1790 #if defined(QUADSPI)\r
1791 #define __HAL_RCC_QSPI_IS_CLK_ENABLED()        (READ_BIT(RCC->AHB3ENR, RCC_AHB3ENR_QSPIEN) != 0U)\r
1792 #endif /* QUADSPI */\r
1793 \r
1794 #if defined(FMC_BANK1)\r
1795 #define __HAL_RCC_FMC_IS_CLK_DISABLED()        (READ_BIT(RCC->AHB3ENR, RCC_AHB3ENR_FMCEN) == 0U)\r
1796 #endif /* FMC_BANK1 */\r
1797 \r
1798 #if defined(QUADSPI)\r
1799 #define __HAL_RCC_QSPI_IS_CLK_DISABLED()       (READ_BIT(RCC->AHB3ENR, RCC_AHB3ENR_QSPIEN) == 0U)\r
1800 #endif /* QUADSPI */\r
1801 \r
1802 /**\r
1803   * @}\r
1804   */\r
1805 \r
1806 /** @defgroup RCC_APB1_Clock_Enable_Disable_Status APB1 Peripheral Clock Enabled or Disabled Status\r
1807   * @brief  Check whether the APB1 peripheral clock is enabled or not.\r
1808   * @note   After reset, the peripheral clock (used for registers read/write access)\r
1809   *         is disabled and the application software has to enable this clock before\r
1810   *         using it.\r
1811   * @{\r
1812   */\r
1813 \r
1814 #define __HAL_RCC_TIM2_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM2EN) != 0U)\r
1815 \r
1816 #if defined(TIM3)\r
1817 #define __HAL_RCC_TIM3_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM3EN) != 0U)\r
1818 #endif /* TIM3 */\r
1819 \r
1820 #if defined(TIM4)\r
1821 #define __HAL_RCC_TIM4_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM4EN) != 0U)\r
1822 #endif /* TIM4 */\r
1823 \r
1824 #if defined(TIM5)\r
1825 #define __HAL_RCC_TIM5_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM5EN) != 0U)\r
1826 #endif /* TIM5 */\r
1827 \r
1828 #define __HAL_RCC_TIM6_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM6EN) != 0U)\r
1829 \r
1830 #if defined(TIM7)\r
1831 #define __HAL_RCC_TIM7_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM7EN) != 0U)\r
1832 #endif /* TIM7 */\r
1833 \r
1834 #if defined(LCD)\r
1835 #define __HAL_RCC_LCD_IS_CLK_ENABLED()         (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_LCDEN) != 0U)\r
1836 #endif /* LCD */\r
1837 \r
1838 #if defined(RCC_APB1ENR1_RTCAPBEN)\r
1839 #define __HAL_RCC_RTCAPB_IS_CLK_ENABLED()      (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_RTCAPBEN) != 0U)\r
1840 #endif /* RCC_APB1ENR1_RTCAPBEN */\r
1841 \r
1842 #define __HAL_RCC_WWDG_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_WWDGEN) != 0U)\r
1843 \r
1844 #if defined(SPI2)\r
1845 #define __HAL_RCC_SPI2_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_SPI2EN) != 0U)\r
1846 #endif /* SPI2 */\r
1847 \r
1848 #if defined(SPI3)\r
1849 #define __HAL_RCC_SPI3_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_SPI3EN) != 0U)\r
1850 #endif /* SPI3 */\r
1851 \r
1852 #define __HAL_RCC_USART2_IS_CLK_ENABLED()      (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USART2EN) != 0U)\r
1853 \r
1854 #if defined(USART3)\r
1855 #define __HAL_RCC_USART3_IS_CLK_ENABLED()      (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USART3EN) != 0U)\r
1856 #endif /* USART3 */\r
1857 \r
1858 #if defined(UART4)\r
1859 #define __HAL_RCC_UART4_IS_CLK_ENABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_UART4EN) != 0U)\r
1860 #endif /* UART4 */\r
1861 \r
1862 #if defined(UART5)\r
1863 #define __HAL_RCC_UART5_IS_CLK_ENABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_UART5EN) != 0U)\r
1864 #endif /* UART5 */\r
1865 \r
1866 #define __HAL_RCC_I2C1_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C1EN) != 0U)\r
1867 \r
1868 #if defined(I2C2)\r
1869 #define __HAL_RCC_I2C2_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C2EN) != 0U)\r
1870 #endif /* I2C2 */\r
1871 \r
1872 #define __HAL_RCC_I2C3_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C3EN) != 0U)\r
1873 \r
1874 #if defined(I2C4)\r
1875 #define __HAL_RCC_I2C4_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR2, RCC_APB1ENR2_I2C4EN) != 0U)\r
1876 #endif /* I2C4 */\r
1877 \r
1878 #if defined(CRS)\r
1879 #define __HAL_RCC_CRS_IS_CLK_ENABLED()         (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CRSEN) != 0U)\r
1880 #endif /* CRS */\r
1881 \r
1882 #if defined(CAN1)\r
1883 #define __HAL_RCC_CAN1_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CAN1EN) != 0U)\r
1884 #endif /* CAN1 */\r
1885 \r
1886 #if defined(CAN2)\r
1887 #define __HAL_RCC_CAN2_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CAN2EN) != 0U)\r
1888 #endif /* CAN2 */\r
1889 \r
1890 #if defined(USB)\r
1891 #define __HAL_RCC_USB_IS_CLK_ENABLED()         (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USBFSEN) != 0U)\r
1892 #endif /* USB */\r
1893 \r
1894 #define __HAL_RCC_PWR_IS_CLK_ENABLED()         (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_PWREN) != 0U)\r
1895 \r
1896 #if defined(DAC1)\r
1897 #define __HAL_RCC_DAC1_IS_CLK_ENABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_DAC1EN) != 0U)\r
1898 #endif /* DAC1 */\r
1899 \r
1900 #define __HAL_RCC_OPAMP_IS_CLK_ENABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_OPAMPEN) != 0U)\r
1901 \r
1902 #define __HAL_RCC_LPTIM1_IS_CLK_ENABLED()      (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_LPTIM1EN) != 0U)\r
1903 \r
1904 #define __HAL_RCC_LPUART1_IS_CLK_ENABLED()     (READ_BIT(RCC->APB1ENR2, RCC_APB1ENR2_LPUART1EN) != 0U)\r
1905 \r
1906 #if defined(SWPMI1)\r
1907 #define __HAL_RCC_SWPMI1_IS_CLK_ENABLED()      (READ_BIT(RCC->APB1ENR2, RCC_APB1ENR2_SWPMI1EN) != 0U)\r
1908 #endif /* SWPMI1 */\r
1909 \r
1910 #define __HAL_RCC_LPTIM2_IS_CLK_ENABLED()      (READ_BIT(RCC->APB1ENR2, RCC_APB1ENR2_LPTIM2EN) != 0U)\r
1911 \r
1912 \r
1913 #define __HAL_RCC_TIM2_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM2EN) == 0U)\r
1914 \r
1915 #if defined(TIM3)\r
1916 #define __HAL_RCC_TIM3_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM3EN) == 0U)\r
1917 #endif /* TIM3 */\r
1918 \r
1919 #if defined(TIM4)\r
1920 #define __HAL_RCC_TIM4_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM4EN) == 0U)\r
1921 #endif /* TIM4 */\r
1922 \r
1923 #if defined(TIM5)\r
1924 #define __HAL_RCC_TIM5_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM5EN) == 0U)\r
1925 #endif /* TIM5 */\r
1926 \r
1927 #define __HAL_RCC_TIM6_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM6EN) == 0U)\r
1928 \r
1929 #if defined(TIM7)\r
1930 #define __HAL_RCC_TIM7_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_TIM7EN) == 0U)\r
1931 #endif /* TIM7 */\r
1932 \r
1933 #if defined(LCD)\r
1934 #define __HAL_RCC_LCD_IS_CLK_DISABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_LCDEN) == 0U)\r
1935 #endif /* LCD */\r
1936 \r
1937 #if defined(RCC_APB1ENR1_RTCAPBEN)\r
1938 #define __HAL_RCC_RTCAPB_IS_CLK_DISABLED()     (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_RTCAPBEN) == 0U)\r
1939 #endif /* RCC_APB1ENR1_RTCAPBEN */\r
1940 \r
1941 #define __HAL_RCC_WWDG_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_WWDGEN) == 0U)\r
1942 \r
1943 #if defined(SPI2)\r
1944 #define __HAL_RCC_SPI2_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_SPI2EN) == 0U)\r
1945 #endif /* SPI2 */\r
1946 \r
1947 #if defined(SPI3)\r
1948 #define __HAL_RCC_SPI3_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_SPI3EN) == 0U)\r
1949 #endif /* SPI3 */\r
1950 \r
1951 #define __HAL_RCC_USART2_IS_CLK_DISABLED()     (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USART2EN) == 0U)\r
1952 \r
1953 #if defined(USART3)\r
1954 #define __HAL_RCC_USART3_IS_CLK_DISABLED()     (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USART3EN) == 0U)\r
1955 #endif /* USART3 */\r
1956 \r
1957 #if defined(UART4)\r
1958 #define __HAL_RCC_UART4_IS_CLK_DISABLED()      (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_UART4EN) == 0U)\r
1959 #endif /* UART4 */\r
1960 \r
1961 #if defined(UART5)\r
1962 #define __HAL_RCC_UART5_IS_CLK_DISABLED()      (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_UART5EN) == 0U)\r
1963 #endif /* UART5 */\r
1964 \r
1965 #define __HAL_RCC_I2C1_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C1EN) == 0U)\r
1966 \r
1967 #if defined(I2C2)\r
1968 #define __HAL_RCC_I2C2_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C2EN) == 0U)\r
1969 #endif /* I2C2 */\r
1970 \r
1971 #define __HAL_RCC_I2C3_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_I2C3EN) == 0U)\r
1972 \r
1973 #if defined(I2C4)\r
1974 #define __HAL_RCC_I2C4_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR2, RCC_APB1ENR2_I2C4EN) == 0U)\r
1975 #endif /* I2C4 */\r
1976 \r
1977 #if defined(CRS)\r
1978 #define __HAL_RCC_CRS_IS_CLK_DISABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CRSEN) == 0U)\r
1979 #endif /* CRS */\r
1980 \r
1981 #if defined(CAN1)\r
1982 #define __HAL_RCC_CAN1_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CAN1EN) == 0U)\r
1983 #endif /* CAN1 */\r
1984 \r
1985 #if defined(CAN2)\r
1986 #define __HAL_RCC_CAN2_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_CAN2EN) == 0U)\r
1987 #endif /* CAN2 */\r
1988 \r
1989 #if defined(USB)\r
1990 #define __HAL_RCC_USB_IS_CLK_DISABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_USBFSEN) == 0U)\r
1991 #endif /* USB */\r
1992 \r
1993 #define __HAL_RCC_PWR_IS_CLK_DISABLED()        (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_PWREN) == 0U)\r
1994 \r
1995 #if defined(DAC1)\r
1996 #define __HAL_RCC_DAC1_IS_CLK_DISABLED()       (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_DAC1EN) == 0U)\r
1997 #endif /* DAC1 */\r
1998 \r
1999 #define __HAL_RCC_OPAMP_IS_CLK_DISABLED()      (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_OPAMPEN) == 0U)\r
2000 \r
2001 #define __HAL_RCC_LPTIM1_IS_CLK_DISABLED()     (READ_BIT(RCC->APB1ENR1, RCC_APB1ENR1_LPTIM1EN) == 0U)\r
2002 \r
2003 #define __HAL_RCC_LPUART1_IS_CLK_DISABLED()    (READ_BIT(RCC->APB1ENR2, RCC_APB1ENR2_LPUART1EN) == 0U)\r
2004 \r
2005 #if defined(SWPMI1)\r
2006 #define __HAL_RCC_SWPMI1_IS_CLK_DISABLED()     (READ_BIT(RCC->APB1ENR2, RCC_APB1ENR2_SWPMI1EN) == 0U)\r
2007 #endif /* SWPMI1 */\r
2008 \r
2009 #define __HAL_RCC_LPTIM2_IS_CLK_DISABLED()     (READ_BIT(RCC->APB1ENR2, RCC_APB1ENR2_LPTIM2EN) == 0U)\r
2010 \r
2011 /**\r
2012   * @}\r
2013   */\r
2014 \r
2015 /** @defgroup RCC_APB2_Clock_Enable_Disable_Status APB2 Peripheral Clock Enabled or Disabled Status\r
2016   * @brief  Check whether the APB2 peripheral clock is enabled or not.\r
2017   * @note   After reset, the peripheral clock (used for registers read/write access)\r
2018   *         is disabled and the application software has to enable this clock before\r
2019   *         using it.\r
2020   * @{\r
2021   */\r
2022 \r
2023 #define __HAL_RCC_SYSCFG_IS_CLK_ENABLED()      (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SYSCFGEN) != 0U)\r
2024 \r
2025 #define __HAL_RCC_FIREWALL_IS_CLK_ENABLED()    (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_FWEN) != 0U)\r
2026 \r
2027 #if defined(SDMMC1) && defined(RCC_APB2ENR_SDMMC1EN)\r
2028 #define __HAL_RCC_SDMMC1_IS_CLK_ENABLED()      (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SDMMC1EN) != 0U)\r
2029 #endif /* SDMMC1 && RCC_APB2ENR_SDMMC1EN */\r
2030 \r
2031 #define __HAL_RCC_TIM1_IS_CLK_ENABLED()        (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM1EN) != 0U)\r
2032 \r
2033 #define __HAL_RCC_SPI1_IS_CLK_ENABLED()        (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN) != 0U)\r
2034 \r
2035 #if defined(TIM8)\r
2036 #define __HAL_RCC_TIM8_IS_CLK_ENABLED()        (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM8EN) != 0U)\r
2037 #endif /* TIM8 */\r
2038 \r
2039 #define __HAL_RCC_USART1_IS_CLK_ENABLED()      (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_USART1EN) != 0U)\r
2040 \r
2041 #define __HAL_RCC_TIM15_IS_CLK_ENABLED()       (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM15EN) != 0U)\r
2042 \r
2043 #define __HAL_RCC_TIM16_IS_CLK_ENABLED()       (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM16EN) != 0U)\r
2044 \r
2045 #if defined(TIM17)\r
2046 #define __HAL_RCC_TIM17_IS_CLK_ENABLED()       (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM17EN) != 0U)\r
2047 #endif /* TIM17 */\r
2048 \r
2049 #if defined(SAI1)\r
2050 #define __HAL_RCC_SAI1_IS_CLK_ENABLED()        (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SAI1EN) != 0U)\r
2051 #endif /* SAI1 */\r
2052 \r
2053 #if defined(SAI2)\r
2054 #define __HAL_RCC_SAI2_IS_CLK_ENABLED()        (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SAI2EN) != 0U)\r
2055 #endif /* SAI2 */\r
2056 \r
2057 #if defined(DFSDM1_Filter0)\r
2058 #define __HAL_RCC_DFSDM1_IS_CLK_ENABLED()      (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_DFSDM1EN) != 0U)\r
2059 #endif /* DFSDM1_Filter0 */\r
2060 \r
2061 #if defined(LTDC)\r
2062 #define __HAL_RCC_LTDC_IS_CLK_ENABLED()        (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_LTDCEN) != 0U)\r
2063 #endif /* LTDC */\r
2064 \r
2065 #if defined(DSI)\r
2066 #define __HAL_RCC_DSI_IS_CLK_ENABLED()         (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_DSIEN) != 0U)\r
2067 #endif /* DSI */\r
2068 \r
2069 \r
2070 #define __HAL_RCC_SYSCFG_IS_CLK_DISABLED()     (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SYSCFGEN) == 0U)\r
2071 \r
2072 #if defined(SDMMC1) && defined(RCC_APB2ENR_SDMMC1EN)\r
2073 #define __HAL_RCC_SDMMC1_IS_CLK_DISABLED()     (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SDMMC1EN) == 0U)\r
2074 #endif /* SDMMC1 && RCC_APB2ENR_SDMMC1EN */\r
2075 \r
2076 #define __HAL_RCC_TIM1_IS_CLK_DISABLED()       (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM1EN) == 0U)\r
2077 \r
2078 #define __HAL_RCC_SPI1_IS_CLK_DISABLED()       (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN) == 0U)\r
2079 \r
2080 #if defined(TIM8)\r
2081 #define __HAL_RCC_TIM8_IS_CLK_DISABLED()       (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM8EN) == 0U)\r
2082 #endif /* TIM8 */\r
2083 \r
2084 #define __HAL_RCC_USART1_IS_CLK_DISABLED()     (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_USART1EN) == 0U)\r
2085 \r
2086 #define __HAL_RCC_TIM15_IS_CLK_DISABLED()      (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM15EN) == 0U)\r
2087 \r
2088 #define __HAL_RCC_TIM16_IS_CLK_DISABLED()      (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM16EN) == 0U)\r
2089 \r
2090 #if defined(TIM17)\r
2091 #define __HAL_RCC_TIM17_IS_CLK_DISABLED()      (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM17EN) == 0U)\r
2092 #endif /* TIM17 */\r
2093 \r
2094 #if defined(SAI1)\r
2095 #define __HAL_RCC_SAI1_IS_CLK_DISABLED()       (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SAI1EN) == 0U)\r
2096 #endif /* SAI1 */\r
2097 \r
2098 #if defined(SAI2)\r
2099 #define __HAL_RCC_SAI2_IS_CLK_DISABLED()       (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SAI2EN) == 0U)\r
2100 #endif /* SAI2 */\r
2101 \r
2102 #if defined(DFSDM1_Filter0)\r
2103 #define __HAL_RCC_DFSDM1_IS_CLK_DISABLED()     (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_DFSDM1EN) == 0U)\r
2104 #endif /* DFSDM1_Filter0 */\r
2105 \r
2106 #if defined(LTDC)\r
2107 #define __HAL_RCC_LTDC_IS_CLK_DISABLED()       (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_LTDCEN) == 0U)\r
2108 #endif /* LTDC */\r
2109 \r
2110 #if defined(DSI)\r
2111 #define __HAL_RCC_DSI_IS_CLK_DISABLED()        (READ_BIT(RCC->APB2ENR, RCC_APB2ENR_DSIEN) == 0U)\r
2112 #endif /* DSI */\r
2113 \r
2114 /**\r
2115   * @}\r
2116   */\r
2117 \r
2118 /** @defgroup RCC_AHB1_Force_Release_Reset AHB1 Peripheral Force Release Reset\r
2119   * @brief  Force or release AHB1 peripheral reset.\r
2120   * @{\r
2121   */\r
2122 #define __HAL_RCC_AHB1_FORCE_RESET()           WRITE_REG(RCC->AHB1RSTR, 0xFFFFFFFFU)\r
2123 \r
2124 #define __HAL_RCC_DMA1_FORCE_RESET()           SET_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_DMA1RST)\r
2125 \r
2126 #define __HAL_RCC_DMA2_FORCE_RESET()           SET_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_DMA2RST)\r
2127 \r
2128 #if defined(DMAMUX1)\r
2129 #define __HAL_RCC_DMAMUX1_FORCE_RESET()        SET_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_DMAMUX1RST)\r
2130 #endif /* DMAMUX1 */\r
2131 \r
2132 #define __HAL_RCC_FLASH_FORCE_RESET()          SET_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_FLASHRST)\r
2133 \r
2134 #define __HAL_RCC_CRC_FORCE_RESET()            SET_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_CRCRST)\r
2135 \r
2136 #define __HAL_RCC_TSC_FORCE_RESET()            SET_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_TSCRST)\r
2137 \r
2138 #if defined(DMA2D)\r
2139 #define __HAL_RCC_DMA2D_FORCE_RESET()          SET_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_DMA2DRST)\r
2140 #endif /* DMA2D */\r
2141 \r
2142 #if defined(GFXMMU)\r
2143 #define __HAL_RCC_GFXMMU_FORCE_RESET()         SET_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_GFXMMURST)\r
2144 #endif /* GFXMMU */\r
2145 \r
2146 \r
2147 #define __HAL_RCC_AHB1_RELEASE_RESET()         WRITE_REG(RCC->AHB1RSTR, 0x00000000U)\r
2148 \r
2149 #define __HAL_RCC_DMA1_RELEASE_RESET()         CLEAR_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_DMA1RST)\r
2150 \r
2151 #define __HAL_RCC_DMA2_RELEASE_RESET()         CLEAR_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_DMA2RST)\r
2152 \r
2153 #if defined(DMAMUX1)\r
2154 #define __HAL_RCC_DMAMUX1_RELEASE_RESET()      CLEAR_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_DMAMUX1RST)\r
2155 #endif /* DMAMUX1 */\r
2156 \r
2157 #define __HAL_RCC_FLASH_RELEASE_RESET()        CLEAR_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_FLASHRST)\r
2158 \r
2159 #define __HAL_RCC_CRC_RELEASE_RESET()          CLEAR_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_CRCRST)\r
2160 \r
2161 #define __HAL_RCC_TSC_RELEASE_RESET()          CLEAR_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_TSCRST)\r
2162 \r
2163 #if defined(DMA2D)\r
2164 #define __HAL_RCC_DMA2D_RELEASE_RESET()        CLEAR_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_DMA2DRST)\r
2165 #endif /* DMA2D */\r
2166 \r
2167 #if defined(GFXMMU)\r
2168 #define __HAL_RCC_GFXMMU_RELEASE_RESET()       CLEAR_BIT(RCC->AHB1RSTR, RCC_AHB1RSTR_GFXMMURST)\r
2169 #endif /* GFXMMU */\r
2170 \r
2171 /**\r
2172   * @}\r
2173   */\r
2174 \r
2175 /** @defgroup RCC_AHB2_Force_Release_Reset AHB2 Peripheral Force Release Reset\r
2176   * @brief  Force or release AHB2 peripheral reset.\r
2177   * @{\r
2178   */\r
2179 #define __HAL_RCC_AHB2_FORCE_RESET()           WRITE_REG(RCC->AHB2RSTR, 0xFFFFFFFFU)\r
2180 \r
2181 #define __HAL_RCC_GPIOA_FORCE_RESET()          SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOARST)\r
2182 \r
2183 #define __HAL_RCC_GPIOB_FORCE_RESET()          SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOBRST)\r
2184 \r
2185 #define __HAL_RCC_GPIOC_FORCE_RESET()          SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOCRST)\r
2186 \r
2187 #if defined(GPIOD)\r
2188 #define __HAL_RCC_GPIOD_FORCE_RESET()          SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIODRST)\r
2189 #endif /* GPIOD */\r
2190 \r
2191 #if defined(GPIOE)\r
2192 #define __HAL_RCC_GPIOE_FORCE_RESET()          SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOERST)\r
2193 #endif /* GPIOE */\r
2194 \r
2195 #if defined(GPIOF)\r
2196 #define __HAL_RCC_GPIOF_FORCE_RESET()          SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOFRST)\r
2197 #endif /* GPIOF */\r
2198 \r
2199 #if defined(GPIOG)\r
2200 #define __HAL_RCC_GPIOG_FORCE_RESET()          SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOGRST)\r
2201 #endif /* GPIOG */\r
2202 \r
2203 #define __HAL_RCC_GPIOH_FORCE_RESET()          SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOHRST)\r
2204 \r
2205 #if defined(GPIOI)\r
2206 #define __HAL_RCC_GPIOI_FORCE_RESET()          SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOIRST)\r
2207 #endif /* GPIOI */\r
2208 \r
2209 #if defined(USB_OTG_FS)\r
2210 #define __HAL_RCC_USB_OTG_FS_FORCE_RESET()     SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_OTGFSRST)\r
2211 #endif /* USB_OTG_FS */\r
2212 \r
2213 #define __HAL_RCC_ADC_FORCE_RESET()            SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_ADCRST)\r
2214 \r
2215 #if defined(DCMI)\r
2216 #define __HAL_RCC_DCMI_FORCE_RESET()           SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_DCMIRST)\r
2217 #endif /* DCMI */\r
2218 \r
2219 #if defined(AES)\r
2220 #define __HAL_RCC_AES_FORCE_RESET()            SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_AESRST)\r
2221 #endif /* AES */\r
2222 \r
2223 #if defined(HASH)\r
2224 #define __HAL_RCC_HASH_FORCE_RESET()           SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_HASHRST)\r
2225 #endif /* HASH */\r
2226 \r
2227 #define __HAL_RCC_RNG_FORCE_RESET()            SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_RNGRST)\r
2228 \r
2229 #if defined(OCTOSPIM)\r
2230 #define __HAL_RCC_OSPIM_FORCE_RESET()          SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_OSPIMRST)\r
2231 #endif /* OCTOSPIM */\r
2232 \r
2233 #if defined(SDMMC1) && defined(RCC_AHB2RSTR_SDMMC1RST)\r
2234 #define __HAL_RCC_SDMMC1_FORCE_RESET()         SET_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_SDMMC1RST)\r
2235 #endif /* SDMMC1 && RCC_AHB2RSTR_SDMMC1RST */\r
2236 \r
2237 \r
2238 #define __HAL_RCC_AHB2_RELEASE_RESET()         WRITE_REG(RCC->AHB2RSTR, 0x00000000U)\r
2239 \r
2240 #define __HAL_RCC_GPIOA_RELEASE_RESET()        CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOARST)\r
2241 \r
2242 #define __HAL_RCC_GPIOB_RELEASE_RESET()        CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOBRST)\r
2243 \r
2244 #define __HAL_RCC_GPIOC_RELEASE_RESET()        CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOCRST)\r
2245 \r
2246 #if defined(GPIOD)\r
2247 #define __HAL_RCC_GPIOD_RELEASE_RESET()        CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIODRST)\r
2248 #endif /* GPIOD */\r
2249 \r
2250 #if defined(GPIOE)\r
2251 #define __HAL_RCC_GPIOE_RELEASE_RESET()        CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOERST)\r
2252 #endif /* GPIOE */\r
2253 \r
2254 #if defined(GPIOF)\r
2255 #define __HAL_RCC_GPIOF_RELEASE_RESET()        CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOFRST)\r
2256 #endif /* GPIOF */\r
2257 \r
2258 #if defined(GPIOG)\r
2259 #define __HAL_RCC_GPIOG_RELEASE_RESET()        CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOGRST)\r
2260 #endif /* GPIOG */\r
2261 \r
2262 #define __HAL_RCC_GPIOH_RELEASE_RESET()        CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOHRST)\r
2263 \r
2264 #if defined(GPIOI)\r
2265 #define __HAL_RCC_GPIOI_RELEASE_RESET()        CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_GPIOIRST)\r
2266 #endif /* GPIOI */\r
2267 \r
2268 #if defined(USB_OTG_FS)\r
2269 #define __HAL_RCC_USB_OTG_FS_RELEASE_RESET()   CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_OTGFSRST)\r
2270 #endif /* USB_OTG_FS */\r
2271 \r
2272 #define __HAL_RCC_ADC_RELEASE_RESET()          CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_ADCRST)\r
2273 \r
2274 #if defined(DCMI)\r
2275 #define __HAL_RCC_DCMI_RELEASE_RESET()         CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_DCMIRST)\r
2276 #endif /* DCMI */\r
2277 \r
2278 #if defined(AES)\r
2279 #define __HAL_RCC_AES_RELEASE_RESET()          CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_AESRST)\r
2280 #endif /* AES */\r
2281 \r
2282 #if defined(HASH)\r
2283 #define __HAL_RCC_HASH_RELEASE_RESET()         CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_HASHRST)\r
2284 #endif /* HASH */\r
2285 \r
2286 #define __HAL_RCC_RNG_RELEASE_RESET()          CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_RNGRST)\r
2287 \r
2288 #if defined(OCTOSPIM)\r
2289 #define __HAL_RCC_OSPIM_RELEASE_RESET()        CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_OSPIMRST)\r
2290 #endif /* OCTOSPIM */\r
2291 \r
2292 #if defined(SDMMC1) && defined(RCC_AHB2RSTR_SDMMC1RST)\r
2293 #define __HAL_RCC_SDMMC1_RELEASE_RESET()       CLEAR_BIT(RCC->AHB2RSTR, RCC_AHB2RSTR_SDMMC1RST)\r
2294 #endif /* SDMMC1 && RCC_AHB2RSTR_SDMMC1RST */\r
2295 \r
2296 /**\r
2297   * @}\r
2298   */\r
2299 \r
2300 /** @defgroup RCC_AHB3_Force_Release_Reset AHB3 Peripheral Force Release Reset\r
2301   * @brief  Force or release AHB3 peripheral reset.\r
2302   * @{\r
2303   */\r
2304 #define __HAL_RCC_AHB3_FORCE_RESET()           WRITE_REG(RCC->AHB3RSTR, 0xFFFFFFFFU)\r
2305 \r
2306 #if defined(FMC_BANK1)\r
2307 #define __HAL_RCC_FMC_FORCE_RESET()            SET_BIT(RCC->AHB3RSTR, RCC_AHB3RSTR_FMCRST)\r
2308 #endif /* FMC_BANK1 */\r
2309 \r
2310 #if defined(QUADSPI)\r
2311 #define __HAL_RCC_QSPI_FORCE_RESET()           SET_BIT(RCC->AHB3RSTR, RCC_AHB3RSTR_QSPIRST)\r
2312 #endif /* QUADSPI */\r
2313 \r
2314 #if defined(OCTOSPI1)\r
2315 #define __HAL_RCC_OSPI1_FORCE_RESET()          SET_BIT(RCC->AHB3RSTR, RCC_AHB3RSTR_OSPI1RST)\r
2316 #endif /* OCTOSPI1 */\r
2317 \r
2318 #if defined(OCTOSPI2)\r
2319 #define __HAL_RCC_OSPI2_FORCE_RESET()          SET_BIT(RCC->AHB3RSTR, RCC_AHB3RSTR_OSPI2RST)\r
2320 #endif /* OCTOSPI2 */\r
2321 \r
2322 #define __HAL_RCC_AHB3_RELEASE_RESET()         WRITE_REG(RCC->AHB3RSTR, 0x00000000U)\r
2323 \r
2324 #if defined(FMC_BANK1)\r
2325 #define __HAL_RCC_FMC_RELEASE_RESET()          CLEAR_BIT(RCC->AHB3RSTR, RCC_AHB3RSTR_FMCRST)\r
2326 #endif /* FMC_BANK1 */\r
2327 \r
2328 #if defined(QUADSPI)\r
2329 #define __HAL_RCC_QSPI_RELEASE_RESET()         CLEAR_BIT(RCC->AHB3RSTR, RCC_AHB3RSTR_QSPIRST)\r
2330 #endif /* QUADSPI */\r
2331 \r
2332 #if defined(OCTOSPI1)\r
2333 #define __HAL_RCC_OSPI1_RELEASE_RESET()        CLEAR_BIT(RCC->AHB3RSTR, RCC_AHB3RSTR_OSPI1RST)\r
2334 #endif /* OCTOSPI1 */\r
2335 \r
2336 #if defined(OCTOSPI2)\r
2337 #define __HAL_RCC_OSPI2_RELEASE_RESET()        CLEAR_BIT(RCC->AHB3RSTR, RCC_AHB3RSTR_OSPI2RST)\r
2338 #endif /* OCTOSPI2 */\r
2339 \r
2340 /**\r
2341   * @}\r
2342   */\r
2343 \r
2344 /** @defgroup RCC_APB1_Force_Release_Reset APB1 Peripheral Force Release Reset\r
2345   * @brief  Force or release APB1 peripheral reset.\r
2346   * @{\r
2347   */\r
2348 #define __HAL_RCC_APB1_FORCE_RESET()           WRITE_REG(RCC->APB1RSTR1, 0xFFFFFFFFU)\r
2349 \r
2350 #define __HAL_RCC_TIM2_FORCE_RESET()           SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_TIM2RST)\r
2351 \r
2352 #if defined(TIM3)\r
2353 #define __HAL_RCC_TIM3_FORCE_RESET()           SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_TIM3RST)\r
2354 #endif /* TIM3 */\r
2355 \r
2356 #if defined(TIM4)\r
2357 #define __HAL_RCC_TIM4_FORCE_RESET()           SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_TIM4RST)\r
2358 #endif /* TIM4 */\r
2359 \r
2360 #if defined(TIM5)\r
2361 #define __HAL_RCC_TIM5_FORCE_RESET()           SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_TIM5RST)\r
2362 #endif /* TIM5 */\r
2363 \r
2364 #define __HAL_RCC_TIM6_FORCE_RESET()           SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_TIM6RST)\r
2365 \r
2366 #if defined(TIM7)\r
2367 #define __HAL_RCC_TIM7_FORCE_RESET()           SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_TIM7RST)\r
2368 #endif /* TIM7 */\r
2369 \r
2370 #if defined(LCD)\r
2371 #define __HAL_RCC_LCD_FORCE_RESET()            SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_LCDRST)\r
2372 #endif /* LCD */\r
2373 \r
2374 #if defined(SPI2)\r
2375 #define __HAL_RCC_SPI2_FORCE_RESET()           SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_SPI2RST)\r
2376 #endif /* SPI2 */\r
2377 \r
2378 #if defined(SPI3)\r
2379 #define __HAL_RCC_SPI3_FORCE_RESET()           SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_SPI3RST)\r
2380 #endif /* SPI3 */\r
2381 \r
2382 #define __HAL_RCC_USART2_FORCE_RESET()         SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_USART2RST)\r
2383 \r
2384 #if defined(USART3)\r
2385 #define __HAL_RCC_USART3_FORCE_RESET()         SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_USART3RST)\r
2386 #endif /* USART3 */\r
2387 \r
2388 #if defined(UART4)\r
2389 #define __HAL_RCC_UART4_FORCE_RESET()          SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_UART4RST)\r
2390 #endif /* UART4 */\r
2391 \r
2392 #if defined(UART5)\r
2393 #define __HAL_RCC_UART5_FORCE_RESET()          SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_UART5RST)\r
2394 #endif /* UART5 */\r
2395 \r
2396 #define __HAL_RCC_I2C1_FORCE_RESET()           SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_I2C1RST)\r
2397 \r
2398 #if defined(I2C2)\r
2399 #define __HAL_RCC_I2C2_FORCE_RESET()           SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_I2C2RST)\r
2400 #endif /* I2C2 */\r
2401 \r
2402 #define __HAL_RCC_I2C3_FORCE_RESET()           SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_I2C3RST)\r
2403 \r
2404 #if defined(I2C4)\r
2405 #define __HAL_RCC_I2C4_FORCE_RESET()           SET_BIT(RCC->APB1RSTR2, RCC_APB1RSTR2_I2C4RST)\r
2406 #endif /* I2C4 */\r
2407 \r
2408 #if defined(CRS)\r
2409 #define __HAL_RCC_CRS_FORCE_RESET()            SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_CRSRST)\r
2410 #endif /* CRS */\r
2411 \r
2412 #if defined(CAN1)\r
2413 #define __HAL_RCC_CAN1_FORCE_RESET()           SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_CAN1RST)\r
2414 #endif /* CAN1 */\r
2415 \r
2416 #if defined(CAN2)\r
2417 #define __HAL_RCC_CAN2_FORCE_RESET()           SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_CAN2RST)\r
2418 #endif /* CAN2 */\r
2419 \r
2420 #if defined(USB)\r
2421 #define __HAL_RCC_USB_FORCE_RESET()            SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_USBFSRST)\r
2422 #endif /* USB */\r
2423 \r
2424 #define __HAL_RCC_PWR_FORCE_RESET()            SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_PWRRST)\r
2425 \r
2426 #if defined(DAC1)\r
2427 #define __HAL_RCC_DAC1_FORCE_RESET()           SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_DAC1RST)\r
2428 #endif /* DAC1 */\r
2429 \r
2430 #define __HAL_RCC_OPAMP_FORCE_RESET()          SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_OPAMPRST)\r
2431 \r
2432 #define __HAL_RCC_LPTIM1_FORCE_RESET()         SET_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_LPTIM1RST)\r
2433 \r
2434 #define __HAL_RCC_LPUART1_FORCE_RESET()        SET_BIT(RCC->APB1RSTR2, RCC_APB1RSTR2_LPUART1RST)\r
2435 \r
2436 #if defined(SWPMI1)\r
2437 #define __HAL_RCC_SWPMI1_FORCE_RESET()         SET_BIT(RCC->APB1RSTR2, RCC_APB1RSTR2_SWPMI1RST)\r
2438 #endif /* SWPMI1 */\r
2439 \r
2440 #define __HAL_RCC_LPTIM2_FORCE_RESET()         SET_BIT(RCC->APB1RSTR2, RCC_APB1RSTR2_LPTIM2RST)\r
2441 \r
2442 \r
2443 #define __HAL_RCC_APB1_RELEASE_RESET()         WRITE_REG(RCC->APB1RSTR1, 0x00000000U)\r
2444 \r
2445 #define __HAL_RCC_TIM2_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_TIM2RST)\r
2446 \r
2447 #if defined(TIM3)\r
2448 #define __HAL_RCC_TIM3_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_TIM3RST)\r
2449 #endif /* TIM3 */\r
2450 \r
2451 #if defined(TIM4)\r
2452 #define __HAL_RCC_TIM4_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_TIM4RST)\r
2453 #endif /* TIM4 */\r
2454 \r
2455 #if defined(TIM5)\r
2456 #define __HAL_RCC_TIM5_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_TIM5RST)\r
2457 #endif /* TIM5 */\r
2458 \r
2459 #define __HAL_RCC_TIM6_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_TIM6RST)\r
2460 \r
2461 #if defined(TIM7)\r
2462 #define __HAL_RCC_TIM7_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_TIM7RST)\r
2463 #endif /* TIM7 */\r
2464 \r
2465 #if defined(LCD)\r
2466 #define __HAL_RCC_LCD_RELEASE_RESET()          CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_LCDRST)\r
2467 #endif /* LCD */\r
2468 \r
2469 #if defined(SPI2)\r
2470 #define __HAL_RCC_SPI2_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_SPI2RST)\r
2471 #endif /* SPI2 */\r
2472 \r
2473 #if defined(SPI3)\r
2474 #define __HAL_RCC_SPI3_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_SPI3RST)\r
2475 #endif /* SPI3 */\r
2476 \r
2477 #define __HAL_RCC_USART2_RELEASE_RESET()       CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_USART2RST)\r
2478 \r
2479 #if defined(USART3)\r
2480 #define __HAL_RCC_USART3_RELEASE_RESET()       CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_USART3RST)\r
2481 #endif /* USART3 */\r
2482 \r
2483 #if defined(UART4)\r
2484 #define __HAL_RCC_UART4_RELEASE_RESET()        CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_UART4RST)\r
2485 #endif /* UART4 */\r
2486 \r
2487 #if defined(UART5)\r
2488 #define __HAL_RCC_UART5_RELEASE_RESET()        CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_UART5RST)\r
2489 #endif /* UART5 */\r
2490 \r
2491 #define __HAL_RCC_I2C1_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_I2C1RST)\r
2492 \r
2493 #if defined(I2C2)\r
2494 #define __HAL_RCC_I2C2_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_I2C2RST)\r
2495 #endif /* I2C2 */\r
2496 \r
2497 #define __HAL_RCC_I2C3_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_I2C3RST)\r
2498 \r
2499 #if defined(I2C4)\r
2500 #define __HAL_RCC_I2C4_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR2, RCC_APB1RSTR2_I2C4RST)\r
2501 #endif /* I2C4 */\r
2502 \r
2503 #if defined(CRS)\r
2504 #define __HAL_RCC_CRS_RELEASE_RESET()          CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_CRSRST)\r
2505 #endif /* CRS */\r
2506 \r
2507 #if defined(CAN1)\r
2508 #define __HAL_RCC_CAN1_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_CAN1RST)\r
2509 #endif /* CAN1 */\r
2510 \r
2511 #if defined(CAN2)\r
2512 #define __HAL_RCC_CAN2_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_CAN2RST)\r
2513 #endif /* CAN2 */\r
2514 \r
2515 #if defined(USB)\r
2516 #define __HAL_RCC_USB_RELEASE_RESET()          CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_USBFSRST)\r
2517 #endif /* USB */\r
2518 \r
2519 #define __HAL_RCC_PWR_RELEASE_RESET()          CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_PWRRST)\r
2520 \r
2521 #if defined(DAC1)\r
2522 #define __HAL_RCC_DAC1_RELEASE_RESET()         CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_DAC1RST)\r
2523 #endif /* DAC1 */\r
2524 \r
2525 #define __HAL_RCC_OPAMP_RELEASE_RESET()        CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_OPAMPRST)\r
2526 \r
2527 #define __HAL_RCC_LPTIM1_RELEASE_RESET()       CLEAR_BIT(RCC->APB1RSTR1, RCC_APB1RSTR1_LPTIM1RST)\r
2528 \r
2529 #define __HAL_RCC_LPUART1_RELEASE_RESET()      CLEAR_BIT(RCC->APB1RSTR2, RCC_APB1RSTR2_LPUART1RST)\r
2530 \r
2531 #if defined(SWPMI1)\r
2532 #define __HAL_RCC_SWPMI1_RELEASE_RESET()       CLEAR_BIT(RCC->APB1RSTR2, RCC_APB1RSTR2_SWPMI1RST)\r
2533 #endif /* SWPMI1 */\r
2534 \r
2535 #define __HAL_RCC_LPTIM2_RELEASE_RESET()       CLEAR_BIT(RCC->APB1RSTR2, RCC_APB1RSTR2_LPTIM2RST)\r
2536 \r
2537 /**\r
2538   * @}\r
2539   */\r
2540 \r
2541 /** @defgroup RCC_APB2_Force_Release_Reset APB2 Peripheral Force Release Reset\r
2542   * @brief  Force or release APB2 peripheral reset.\r
2543   * @{\r
2544   */\r
2545 #define __HAL_RCC_APB2_FORCE_RESET()           WRITE_REG(RCC->APB2RSTR, 0xFFFFFFFFU)\r
2546 \r
2547 #define __HAL_RCC_SYSCFG_FORCE_RESET()         SET_BIT(RCC->APB2RSTR, RCC_APB2RSTR_SYSCFGRST)\r
2548 \r
2549 #if defined(SDMMC1) && defined(RCC_APB2RSTR_SDMMC1RST)\r
2550 #define __HAL_RCC_SDMMC1_FORCE_RESET()         SET_BIT(RCC->APB2RSTR, RCC_APB2RSTR_SDMMC1RST)\r
2551 #endif /* SDMMC1 && RCC_APB2RSTR_SDMMC1RST */\r
2552 \r
2553 #define __HAL_RCC_TIM1_FORCE_RESET()           SET_BIT(RCC->APB2RSTR, RCC_APB2RSTR_TIM1RST)\r
2554 \r
2555 #define __HAL_RCC_SPI1_FORCE_RESET()           SET_BIT(RCC->APB2RSTR, RCC_APB2RSTR_SPI1RST)\r
2556 \r
2557 #if defined(TIM8)\r
2558 #define __HAL_RCC_TIM8_FORCE_RESET()           SET_BIT(RCC->APB2RSTR, RCC_APB2RSTR_TIM8RST)\r
2559 #endif /* TIM8 */\r
2560 \r
2561 #define __HAL_RCC_USART1_FORCE_RESET()         SET_BIT(RCC->APB2RSTR, RCC_APB2RSTR_USART1RST)\r
2562 \r
2563 #define __HAL_RCC_TIM15_FORCE_RESET()          SET_BIT(RCC->APB2RSTR, RCC_APB2RSTR_TIM15RST)\r
2564 \r
2565 #define __HAL_RCC_TIM16_FORCE_RESET()          SET_BIT(RCC->APB2RSTR, RCC_APB2RSTR_TIM16RST)\r
2566 \r
2567 #if defined(TIM17)\r
2568 #define __HAL_RCC_TIM17_FORCE_RESET()          SET_BIT(RCC->APB2RSTR, RCC_APB2RSTR_TIM17RST)\r
2569 #endif /* TIM17 */\r
2570 \r
2571 #if defined(SAI1)\r
2572 #define __HAL_RCC_SAI1_FORCE_RESET()           SET_BIT(RCC->APB2RSTR, RCC_APB2RSTR_SAI1RST)\r
2573 #endif /* SAI1 */\r
2574 \r
2575 #if defined(SAI2)\r
2576 #define __HAL_RCC_SAI2_FORCE_RESET()           SET_BIT(RCC->APB2RSTR, RCC_APB2RSTR_SAI2RST)\r
2577 #endif /* SAI2 */\r
2578 \r
2579 #if defined(DFSDM1_Filter0)\r
2580 #define __HAL_RCC_DFSDM1_FORCE_RESET()         SET_BIT(RCC->APB2RSTR, RCC_APB2RSTR_DFSDM1RST)\r
2581 #endif /* DFSDM1_Filter0 */\r
2582 \r
2583 #if defined(LTDC)\r
2584 #define __HAL_RCC_LTDC_FORCE_RESET()           SET_BIT(RCC->APB2RSTR, RCC_APB2RSTR_LTDCRST)\r
2585 #endif /* LTDC */\r
2586 \r
2587 #if defined(DSI)\r
2588 #define __HAL_RCC_DSI_FORCE_RESET()            SET_BIT(RCC->APB2RSTR, RCC_APB2RSTR_DSIRST)\r
2589 #endif /* DSI */\r
2590 \r
2591 \r
2592 #define __HAL_RCC_APB2_RELEASE_RESET()         WRITE_REG(RCC->APB2RSTR, 0x00000000U)\r
2593 \r
2594 #define __HAL_RCC_SYSCFG_RELEASE_RESET()       CLEAR_BIT(RCC->APB2RSTR, RCC_APB2RSTR_SYSCFGRST)\r
2595 \r
2596 #if defined(SDMMC1) && defined(RCC_APB2RSTR_SDMMC1RST)\r
2597 #define __HAL_RCC_SDMMC1_RELEASE_RESET()       CLEAR_BIT(RCC->APB2RSTR, RCC_APB2RSTR_SDMMC1RST)\r
2598 #endif /* SDMMC1 && RCC_APB2RSTR_SDMMC1RST */\r
2599 \r
2600 #define __HAL_RCC_TIM1_RELEASE_RESET()         CLEAR_BIT(RCC->APB2RSTR, RCC_APB2RSTR_TIM1RST)\r
2601 \r
2602 #define __HAL_RCC_SPI1_RELEASE_RESET()         CLEAR_BIT(RCC->APB2RSTR, RCC_APB2RSTR_SPI1RST)\r
2603 \r
2604 #if defined(TIM8)\r
2605 #define __HAL_RCC_TIM8_RELEASE_RESET()         CLEAR_BIT(RCC->APB2RSTR, RCC_APB2RSTR_TIM8RST)\r
2606 #endif /* TIM8 */\r
2607 \r
2608 #define __HAL_RCC_USART1_RELEASE_RESET()       CLEAR_BIT(RCC->APB2RSTR, RCC_APB2RSTR_USART1RST)\r
2609 \r
2610 #define __HAL_RCC_TIM15_RELEASE_RESET()        CLEAR_BIT(RCC->APB2RSTR, RCC_APB2RSTR_TIM15RST)\r
2611 \r
2612 #define __HAL_RCC_TIM16_RELEASE_RESET()        CLEAR_BIT(RCC->APB2RSTR, RCC_APB2RSTR_TIM16RST)\r
2613 \r
2614 #if defined(TIM17)\r
2615 #define __HAL_RCC_TIM17_RELEASE_RESET()        CLEAR_BIT(RCC->APB2RSTR, RCC_APB2RSTR_TIM17RST)\r
2616 #endif /* TIM17 */\r
2617 \r
2618 #if defined(SAI1)\r
2619 #define __HAL_RCC_SAI1_RELEASE_RESET()         CLEAR_BIT(RCC->APB2RSTR, RCC_APB2RSTR_SAI1RST)\r
2620 #endif /* SAI1 */\r
2621 \r
2622 #if defined(SAI2)\r
2623 #define __HAL_RCC_SAI2_RELEASE_RESET()         CLEAR_BIT(RCC->APB2RSTR, RCC_APB2RSTR_SAI2RST)\r
2624 #endif /* SAI2 */\r
2625 \r
2626 #if defined(DFSDM1_Filter0)\r
2627 #define __HAL_RCC_DFSDM1_RELEASE_RESET()       CLEAR_BIT(RCC->APB2RSTR, RCC_APB2RSTR_DFSDM1RST)\r
2628 #endif /* DFSDM1_Filter0 */\r
2629 \r
2630 #if defined(LTDC)\r
2631 #define __HAL_RCC_LTDC_RELEASE_RESET()         CLEAR_BIT(RCC->APB2RSTR, RCC_APB2RSTR_LTDCRST)\r
2632 #endif /* LTDC */\r
2633 \r
2634 #if defined(DSI)\r
2635 #define __HAL_RCC_DSI_RELEASE_RESET()          CLEAR_BIT(RCC->APB2RSTR, RCC_APB2RSTR_DSIRST)\r
2636 #endif /* DSI */\r
2637 \r
2638 /**\r
2639   * @}\r
2640   */\r
2641 \r
2642 /** @defgroup RCC_AHB1_Clock_Sleep_Enable_Disable AHB1 Peripheral Clock Sleep Enable Disable\r
2643   * @brief  Enable or disable the AHB1 peripheral clock during Low Power (Sleep) mode.\r
2644   * @note   Peripheral clock gating in SLEEP mode can be used to further reduce\r
2645   *         power consumption.\r
2646   * @note   After wakeup from SLEEP mode, the peripheral clock is enabled again.\r
2647   * @note   By default, all peripheral clocks are enabled during SLEEP mode.\r
2648   * @{\r
2649   */\r
2650 \r
2651 #define __HAL_RCC_DMA1_CLK_SLEEP_ENABLE()      SET_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMA1SMEN)\r
2652 \r
2653 #define __HAL_RCC_DMA2_CLK_SLEEP_ENABLE()      SET_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMA2SMEN)\r
2654 \r
2655 #if defined(DMAMUX1)\r
2656 #define __HAL_RCC_DMAMUX1_CLK_SLEEP_ENABLE()   SET_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMAMUX1SMEN)\r
2657 #endif /* DMAMUX1 */\r
2658 \r
2659 #define __HAL_RCC_FLASH_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_FLASHSMEN)\r
2660 \r
2661 #define __HAL_RCC_SRAM1_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_SRAM1SMEN)\r
2662 \r
2663 #define __HAL_RCC_CRC_CLK_SLEEP_ENABLE()       SET_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_CRCSMEN)\r
2664 \r
2665 #define __HAL_RCC_TSC_CLK_SLEEP_ENABLE()       SET_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_TSCSMEN)\r
2666 \r
2667 #if defined(DMA2D)\r
2668 #define __HAL_RCC_DMA2D_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMA2DSMEN)\r
2669 #endif /* DMA2D */\r
2670 \r
2671 #if defined(GFXMMU)\r
2672 #define __HAL_RCC_GFXMMU_CLK_SLEEP_ENABLE()    SET_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_GFXMMUSMEN)\r
2673 #endif /* GFXMMU */\r
2674 \r
2675 \r
2676 #define __HAL_RCC_DMA1_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMA1SMEN)\r
2677 \r
2678 #define __HAL_RCC_DMA2_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMA2SMEN)\r
2679 \r
2680 #if defined(DMAMUX1)\r
2681 #define __HAL_RCC_DMAMUX1_CLK_SLEEP_DISABLE()  CLEAR_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMAMUX1SMEN)\r
2682 #endif /* DMAMUX1 */\r
2683 \r
2684 #define __HAL_RCC_FLASH_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_FLASHSMEN)\r
2685 \r
2686 #define __HAL_RCC_SRAM1_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_SRAM1SMEN)\r
2687 \r
2688 #define __HAL_RCC_CRC_CLK_SLEEP_DISABLE()      CLEAR_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_CRCSMEN)\r
2689 \r
2690 #define __HAL_RCC_TSC_CLK_SLEEP_DISABLE()      CLEAR_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_TSCSMEN)\r
2691 \r
2692 #if defined(DMA2D)\r
2693 #define __HAL_RCC_DMA2D_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMA2DSMEN)\r
2694 #endif /* DMA2D */\r
2695 \r
2696 #if defined(GFXMMU)\r
2697 #define __HAL_RCC_GFXMMU_CLK_SLEEP_DISABLE()   CLEAR_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_GFXMMUSMEN)\r
2698 #endif /* GFXMMU */\r
2699 \r
2700 /**\r
2701   * @}\r
2702   */\r
2703 \r
2704 /** @defgroup RCC_AHB2_Clock_Sleep_Enable_Disable AHB2 Peripheral Clock Sleep Enable Disable\r
2705   * @brief  Enable or disable the AHB2 peripheral clock during Low Power (Sleep) mode.\r
2706   * @note   Peripheral clock gating in SLEEP mode can be used to further reduce\r
2707   *         power consumption.\r
2708   * @note   After wakeup from SLEEP mode, the peripheral clock is enabled again.\r
2709   * @note   By default, all peripheral clocks are enabled during SLEEP mode.\r
2710   * @{\r
2711   */\r
2712 \r
2713 #define __HAL_RCC_GPIOA_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOASMEN)\r
2714 \r
2715 #define __HAL_RCC_GPIOB_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOBSMEN)\r
2716 \r
2717 #define __HAL_RCC_GPIOC_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOCSMEN)\r
2718 \r
2719 #if defined(GPIOD)\r
2720 #define __HAL_RCC_GPIOD_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIODSMEN)\r
2721 #endif /* GPIOD */\r
2722 \r
2723 #if defined(GPIOE)\r
2724 #define __HAL_RCC_GPIOE_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOESMEN)\r
2725 #endif /* GPIOE */\r
2726 \r
2727 #if defined(GPIOF)\r
2728 #define __HAL_RCC_GPIOF_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOFSMEN)\r
2729 #endif /* GPIOF */\r
2730 \r
2731 #if defined(GPIOG)\r
2732 #define __HAL_RCC_GPIOG_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOGSMEN)\r
2733 #endif /* GPIOG */\r
2734 \r
2735 #define __HAL_RCC_GPIOH_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOHSMEN)\r
2736 \r
2737 #if defined(GPIOI)\r
2738 #define __HAL_RCC_GPIOI_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOISMEN)\r
2739 #endif /* GPIOI */\r
2740 \r
2741 #define __HAL_RCC_SRAM2_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_SRAM2SMEN)\r
2742 \r
2743 #if defined(SRAM3)\r
2744 #define __HAL_RCC_SRAM3_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_SRAM3SMEN)\r
2745 #endif /* SRAM3 */\r
2746 \r
2747 #if defined(USB_OTG_FS)\r
2748 #define __HAL_RCC_USB_OTG_FS_CLK_SLEEP_ENABLE()  SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_OTGFSSMEN)\r
2749 #endif /* USB_OTG_FS */\r
2750 \r
2751 #define __HAL_RCC_ADC_CLK_SLEEP_ENABLE()       SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_ADCSMEN)\r
2752 \r
2753 #if defined(DCMI)\r
2754 #define __HAL_RCC_DCMI_CLK_SLEEP_ENABLE()      SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_DCMISMEN)\r
2755 #endif /* DCMI */\r
2756 \r
2757 #if defined(AES)\r
2758 #define __HAL_RCC_AES_CLK_SLEEP_ENABLE()       SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_AESSMEN)\r
2759 #endif /* AES */\r
2760 \r
2761 #if defined(HASH)\r
2762 #define __HAL_RCC_HASH_CLK_SLEEP_ENABLE()      SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_HASHSMEN)\r
2763 #endif /* HASH */\r
2764 \r
2765 #define __HAL_RCC_RNG_CLK_SLEEP_ENABLE()       SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_RNGSMEN)\r
2766 \r
2767 #if defined(OCTOSPIM)\r
2768 #define __HAL_RCC_OSPIM_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_OSPIMSMEN)\r
2769 #endif /* OCTOSPIM */\r
2770 \r
2771 #if defined(SDMMC1) && defined(RCC_AHB2SMENR_SDMMC1SMEN)\r
2772 #define __HAL_RCC_SDMMC1_CLK_SLEEP_ENABLE()    SET_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_SDMMC1SMEN)\r
2773 #endif /* SDMMC1 && RCC_AHB2SMENR_SDMMC1SMEN */\r
2774 \r
2775 \r
2776 #define __HAL_RCC_GPIOA_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOASMEN)\r
2777 \r
2778 #define __HAL_RCC_GPIOB_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOBSMEN)\r
2779 \r
2780 #define __HAL_RCC_GPIOC_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOCSMEN)\r
2781 \r
2782 #if defined(GPIOD)\r
2783 #define __HAL_RCC_GPIOD_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIODSMEN)\r
2784 #endif /* GPIOD */\r
2785 \r
2786 #if defined(GPIOE)\r
2787 #define __HAL_RCC_GPIOE_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOESMEN)\r
2788 #endif /* GPIOE */\r
2789 \r
2790 #if defined(GPIOF)\r
2791 #define __HAL_RCC_GPIOF_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOFSMEN)\r
2792 #endif /* GPIOF */\r
2793 \r
2794 #if defined(GPIOG)\r
2795 #define __HAL_RCC_GPIOG_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOGSMEN)\r
2796 #endif /* GPIOG */\r
2797 \r
2798 #define __HAL_RCC_GPIOH_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOHSMEN)\r
2799 \r
2800 #if defined(GPIOI)\r
2801 #define __HAL_RCC_GPIOI_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOISMEN)\r
2802 #endif /* GPIOI */\r
2803 \r
2804 #define __HAL_RCC_SRAM2_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_SRAM2SMEN)\r
2805 \r
2806 #if defined(SRAM3)\r
2807 #define __HAL_RCC_SRAM3_IS_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_SRAM3SMEN)\r
2808 #endif /* SRAM3 */\r
2809 \r
2810 #if defined(USB_OTG_FS)\r
2811 #define __HAL_RCC_USB_OTG_FS_CLK_SLEEP_DISABLE() CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_OTGFSSMEN)\r
2812 #endif /* USB_OTG_FS */\r
2813 \r
2814 #define __HAL_RCC_ADC_CLK_SLEEP_DISABLE()      CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_ADCSMEN)\r
2815 \r
2816 #if defined(DCMI)\r
2817 #define __HAL_RCC_DCMI_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_DCMISMEN)\r
2818 #endif /* DCMI */\r
2819 \r
2820 #if defined(AES)\r
2821 #define __HAL_RCC_AES_CLK_SLEEP_DISABLE()      CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_AESSMEN)\r
2822 #endif /* AES */\r
2823 \r
2824 #if defined(HASH)\r
2825 #define __HAL_RCC_HASH_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_HASHSMEN)\r
2826 #endif /* HASH */\r
2827 \r
2828 #define __HAL_RCC_RNG_CLK_SLEEP_DISABLE()      CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_RNGSMEN)\r
2829 \r
2830 #if defined(OCTOSPIM)\r
2831 #define __HAL_RCC_OSPIM_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_OSPIMSMEN)\r
2832 #endif /* OCTOSPIM */\r
2833 \r
2834 #if defined(SDMMC1) && defined(RCC_AHB2SMENR_SDMMC1SMEN)\r
2835 #define __HAL_RCC_SDMMC1_CLK_SLEEP_DISABLE()   CLEAR_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_SDMMC1SMEN)\r
2836 #endif /* SDMMC1 && RCC_AHB2SMENR_SDMMC1SMEN */\r
2837 \r
2838 /**\r
2839   * @}\r
2840   */\r
2841 \r
2842 /** @defgroup RCC_AHB3_Clock_Sleep_Enable_Disable AHB3 Peripheral Clock Sleep Enable Disable\r
2843   * @brief  Enable or disable the AHB3 peripheral clock during Low Power (Sleep) mode.\r
2844   * @note   Peripheral clock gating in SLEEP mode can be used to further reduce\r
2845   *         power consumption.\r
2846   * @note   After wakeup from SLEEP mode, the peripheral clock is enabled again.\r
2847   * @note   By default, all peripheral clocks are enabled during SLEEP mode.\r
2848   * @{\r
2849   */\r
2850 \r
2851 #if defined(QUADSPI)\r
2852 #define __HAL_RCC_QSPI_CLK_SLEEP_ENABLE()      SET_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_QSPISMEN)\r
2853 #endif /* QUADSPI */\r
2854 \r
2855 #if defined(OCTOSPI1)\r
2856 #define __HAL_RCC_OSPI1_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_OSPI1SMEN)\r
2857 #endif /* OCTOSPI1 */\r
2858 \r
2859 #if defined(OCTOSPI2)\r
2860 #define __HAL_RCC_OSPI2_CLK_SLEEP_ENABLE()     SET_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_OSPI2SMEN)\r
2861 #endif /* OCTOSPI2 */\r
2862 \r
2863 #if defined(FMC_BANK1)\r
2864 #define __HAL_RCC_FMC_CLK_SLEEP_ENABLE()       SET_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_FMCSMEN)\r
2865 #endif /* FMC_BANK1 */\r
2866 \r
2867 #if defined(QUADSPI)\r
2868 #define __HAL_RCC_QSPI_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_QSPISMEN)\r
2869 #endif /* QUADSPI */\r
2870 \r
2871 #if defined(OCTOSPI1)\r
2872 #define __HAL_RCC_OSPI1_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_OSPI1SMEN)\r
2873 #endif /* OCTOSPI1 */\r
2874 \r
2875 #if defined(OCTOSPI2)\r
2876 #define __HAL_RCC_OSPI2_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_OSPI2SMEN)\r
2877 #endif /* OCTOSPI2 */\r
2878 \r
2879 #if defined(FMC_BANK1)\r
2880 #define __HAL_RCC_FMC_CLK_SLEEP_DISABLE()      CLEAR_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_FMCSMEN)\r
2881 #endif /* FMC_BANK1 */\r
2882 \r
2883 /**\r
2884   * @}\r
2885   */\r
2886 \r
2887 /** @defgroup RCC_APB1_Clock_Sleep_Enable_Disable APB1 Peripheral Clock Sleep Enable Disable\r
2888   * @brief  Enable or disable the APB1 peripheral clock during Low Power (Sleep) mode.\r
2889   * @note   Peripheral clock gating in SLEEP mode can be used to further reduce\r
2890   *         power consumption.\r
2891   * @note   After wakeup from SLEEP mode, the peripheral clock is enabled again.\r
2892   * @note   By default, all peripheral clocks are enabled during SLEEP mode.\r
2893   * @{\r
2894   */\r
2895 \r
2896 #define __HAL_RCC_TIM2_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM2SMEN)\r
2897 \r
2898 #if defined(TIM3)\r
2899 #define __HAL_RCC_TIM3_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM3SMEN)\r
2900 #endif /* TIM3 */\r
2901 \r
2902 #if defined(TIM4)\r
2903 #define __HAL_RCC_TIM4_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM4SMEN)\r
2904 #endif /* TIM4 */\r
2905 \r
2906 #if defined(TIM5)\r
2907 #define __HAL_RCC_TIM5_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM5SMEN)\r
2908 #endif /* TIM5 */\r
2909 \r
2910 #define __HAL_RCC_TIM6_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM6SMEN)\r
2911 \r
2912 #if defined(TIM7)\r
2913 #define __HAL_RCC_TIM7_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM7SMEN)\r
2914 #endif /* TIM7 */\r
2915 \r
2916 #if defined(LCD)\r
2917 #define __HAL_RCC_LCD_CLK_SLEEP_ENABLE()       SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_LCDSMEN)\r
2918 #endif /* LCD */\r
2919 \r
2920 #if defined(RCC_APB1SMENR1_RTCAPBSMEN)\r
2921 #define __HAL_RCC_RTCAPB_CLK_SLEEP_ENABLE()    SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_RTCAPBSMEN)\r
2922 #endif /* RCC_APB1SMENR1_RTCAPBSMEN */\r
2923 \r
2924 #define __HAL_RCC_WWDG_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_WWDGSMEN)\r
2925 \r
2926 #if defined(SPI2)\r
2927 #define __HAL_RCC_SPI2_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_SPI2SMEN)\r
2928 #endif /* SPI2 */\r
2929 \r
2930 #if defined(SPI3)\r
2931 #define __HAL_RCC_SPI3_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_SPI3SMEN)\r
2932 #endif /* SPI3 */\r
2933 \r
2934 #define __HAL_RCC_USART2_CLK_SLEEP_ENABLE()    SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_USART2SMEN)\r
2935 \r
2936 #if defined(USART3)\r
2937 #define __HAL_RCC_USART3_CLK_SLEEP_ENABLE()    SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_USART3SMEN)\r
2938 #endif /* USART3 */\r
2939 \r
2940 #if defined(UART4)\r
2941 #define __HAL_RCC_UART4_CLK_SLEEP_ENABLE()     SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_UART4SMEN)\r
2942 #endif /* UART4 */\r
2943 \r
2944 #if defined(UART5)\r
2945 #define __HAL_RCC_UART5_CLK_SLEEP_ENABLE()     SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_UART5SMEN)\r
2946 #endif /* UART5 */\r
2947 \r
2948 #define __HAL_RCC_I2C1_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_I2C1SMEN)\r
2949 \r
2950 #if defined(I2C2)\r
2951 #define __HAL_RCC_I2C2_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_I2C2SMEN)\r
2952 #endif /* I2C2 */\r
2953 \r
2954 #define __HAL_RCC_I2C3_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_I2C3SMEN)\r
2955 \r
2956 #if defined(I2C4)\r
2957 #define __HAL_RCC_I2C4_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_I2C4SMEN)\r
2958 #endif /* I2C4 */\r
2959 \r
2960 #if defined(CRS)\r
2961 #define __HAL_RCC_CRS_CLK_SLEEP_ENABLE()       SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_CRSSMEN)\r
2962 #endif /* CRS */\r
2963 \r
2964 #if defined(CAN1)\r
2965 #define __HAL_RCC_CAN1_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_CAN1SMEN)\r
2966 #endif /* CAN1 */\r
2967 \r
2968 #if defined(CAN2)\r
2969 #define __HAL_RCC_CAN2_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_CAN2SMEN)\r
2970 #endif /* CAN2 */\r
2971 \r
2972 #if defined(USB)\r
2973 #define __HAL_RCC_USB_CLK_SLEEP_ENABLE()       SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_USBFSSMEN)\r
2974 #endif /* USB */\r
2975 \r
2976 #define __HAL_RCC_PWR_CLK_SLEEP_ENABLE()       SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_PWRSMEN)\r
2977 \r
2978 #if defined(DAC1)\r
2979 #define __HAL_RCC_DAC1_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_DAC1SMEN)\r
2980 #endif /* DAC1 */\r
2981 \r
2982 #define __HAL_RCC_OPAMP_CLK_SLEEP_ENABLE()     SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_OPAMPSMEN)\r
2983 \r
2984 #define __HAL_RCC_LPTIM1_CLK_SLEEP_ENABLE()    SET_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_LPTIM1SMEN)\r
2985 \r
2986 #define __HAL_RCC_LPUART1_CLK_SLEEP_ENABLE()   SET_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_LPUART1SMEN)\r
2987 \r
2988 #if defined(SWPMI1)\r
2989 #define __HAL_RCC_SWPMI1_CLK_SLEEP_ENABLE()    SET_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_SWPMI1SMEN)\r
2990 #endif /* SWPMI1 */\r
2991 \r
2992 #define __HAL_RCC_LPTIM2_CLK_SLEEP_ENABLE()    SET_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_LPTIM2SMEN)\r
2993 \r
2994 \r
2995 #define __HAL_RCC_TIM2_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM2SMEN)\r
2996 \r
2997 #if defined(TIM3)\r
2998 #define __HAL_RCC_TIM3_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM3SMEN)\r
2999 #endif /* TIM3 */\r
3000 \r
3001 #if defined(TIM4)\r
3002 #define __HAL_RCC_TIM4_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM4SMEN)\r
3003 #endif /* TIM4 */\r
3004 \r
3005 #if defined(TIM5)\r
3006 #define __HAL_RCC_TIM5_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM5SMEN)\r
3007 #endif /* TIM5 */\r
3008 \r
3009 #define __HAL_RCC_TIM6_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM6SMEN)\r
3010 \r
3011 #if defined(TIM7)\r
3012 #define __HAL_RCC_TIM7_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM7SMEN)\r
3013 #endif /* TIM7 */\r
3014 \r
3015 #if defined(LCD)\r
3016 #define __HAL_RCC_LCD_CLK_SLEEP_DISABLE()      CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_LCDSMEN)\r
3017 #endif /* LCD */\r
3018 \r
3019 #if defined(RCC_APB1SMENR1_RTCAPBSMEN)\r
3020 #define __HAL_RCC_RTCAPB_CLK_SLEEP_DISABLE()   CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_RTCAPBSMEN)\r
3021 #endif /* RCC_APB1SMENR1_RTCAPBSMEN */\r
3022 \r
3023 #define __HAL_RCC_WWDG_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_WWDGSMEN)\r
3024 \r
3025 #if defined(SPI2)\r
3026 #define __HAL_RCC_SPI2_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_SPI2SMEN)\r
3027 #endif /* SPI2 */\r
3028 \r
3029 #if defined(SPI3)\r
3030 #define __HAL_RCC_SPI3_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_SPI3SMEN)\r
3031 #endif /* SPI3 */\r
3032 \r
3033 #define __HAL_RCC_USART2_CLK_SLEEP_DISABLE()   CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_USART2SMEN)\r
3034 \r
3035 #if defined(USART3)\r
3036 #define __HAL_RCC_USART3_CLK_SLEEP_DISABLE()   CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_USART3SMEN)\r
3037 #endif /* USART3 */\r
3038 \r
3039 #if defined(UART4)\r
3040 #define __HAL_RCC_UART4_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_UART4SMEN)\r
3041 #endif /* UART4 */\r
3042 \r
3043 #if defined(UART5)\r
3044 #define __HAL_RCC_UART5_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_UART5SMEN)\r
3045 #endif /* UART5 */\r
3046 \r
3047 #define __HAL_RCC_I2C1_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_I2C1SMEN)\r
3048 \r
3049 #if defined(I2C2)\r
3050 #define __HAL_RCC_I2C2_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_I2C2SMEN)\r
3051 #endif /* I2C2 */\r
3052 \r
3053 #define __HAL_RCC_I2C3_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_I2C3SMEN)\r
3054 \r
3055 #if defined(I2C4)\r
3056 #define __HAL_RCC_I2C4_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_I2C4SMEN)\r
3057 #endif /* I2C4 */\r
3058 \r
3059 #if defined(CRS)\r
3060 #define __HAL_RCC_CRS_CLK_SLEEP_DISABLE()      CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_CRSSMEN)\r
3061 #endif /* CRS */\r
3062 \r
3063 #if defined(CAN1)\r
3064 #define __HAL_RCC_CAN1_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_CAN1SMEN)\r
3065 #endif /* CAN1 */\r
3066 \r
3067 #if defined(CAN2)\r
3068 #define __HAL_RCC_CAN2_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_CAN2SMEN)\r
3069 #endif /* CAN2 */\r
3070 \r
3071 #if defined(USB)\r
3072 #define __HAL_RCC_USB_CLK_SLEEP_DISABLE()      CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_USBFSSMEN)\r
3073 #endif /* USB */\r
3074 \r
3075 #define __HAL_RCC_PWR_CLK_SLEEP_DISABLE()      CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_PWRSMEN)\r
3076 \r
3077 #if defined(DAC1)\r
3078 #define __HAL_RCC_DAC1_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_DAC1SMEN)\r
3079 #endif /* DAC1 */\r
3080 \r
3081 #define __HAL_RCC_OPAMP_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_OPAMPSMEN)\r
3082 \r
3083 #define __HAL_RCC_LPTIM1_CLK_SLEEP_DISABLE()   CLEAR_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_LPTIM1SMEN)\r
3084 \r
3085 #define __HAL_RCC_LPUART1_CLK_SLEEP_DISABLE()  CLEAR_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_LPUART1SMEN)\r
3086 \r
3087 #if defined(SWPMI1)\r
3088 #define __HAL_RCC_SWPMI1_CLK_SLEEP_DISABLE()   CLEAR_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_SWPMI1SMEN)\r
3089 #endif /* SWPMI1 */\r
3090 \r
3091 #define __HAL_RCC_LPTIM2_CLK_SLEEP_DISABLE()   CLEAR_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_LPTIM2SMEN)\r
3092 \r
3093 /**\r
3094   * @}\r
3095   */\r
3096 \r
3097 /** @defgroup RCC_APB2_Clock_Sleep_Enable_Disable APB2 Peripheral Clock Sleep Enable Disable\r
3098   * @brief  Enable or disable the APB2 peripheral clock during Low Power (Sleep) mode.\r
3099   * @note   Peripheral clock gating in SLEEP mode can be used to further reduce\r
3100   *         power consumption.\r
3101   * @note   After wakeup from SLEEP mode, the peripheral clock is enabled again.\r
3102   * @note   By default, all peripheral clocks are enabled during SLEEP mode.\r
3103   * @{\r
3104   */\r
3105 \r
3106 #define __HAL_RCC_SYSCFG_CLK_SLEEP_ENABLE()    SET_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SYSCFGSMEN)\r
3107 \r
3108 #if defined(SDMMC1) && defined(RCC_APB2SMENR_SDMMC1SMEN)\r
3109 #define __HAL_RCC_SDMMC1_CLK_SLEEP_ENABLE()    SET_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SDMMC1SMEN)\r
3110 #endif /* SDMMC1 && RCC_APB2SMENR_SDMMC1SMEN */\r
3111 \r
3112 #define __HAL_RCC_TIM1_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM1SMEN)\r
3113 \r
3114 #define __HAL_RCC_SPI1_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SPI1SMEN)\r
3115 \r
3116 #if defined(TIM8)\r
3117 #define __HAL_RCC_TIM8_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM8SMEN)\r
3118 #endif /* TIM8 */\r
3119 \r
3120 #define __HAL_RCC_USART1_CLK_SLEEP_ENABLE()    SET_BIT(RCC->APB2SMENR, RCC_APB2SMENR_USART1SMEN)\r
3121 \r
3122 #define __HAL_RCC_TIM15_CLK_SLEEP_ENABLE()     SET_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM15SMEN)\r
3123 \r
3124 #define __HAL_RCC_TIM16_CLK_SLEEP_ENABLE()     SET_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM16SMEN)\r
3125 \r
3126 #if defined(TIM17)\r
3127 #define __HAL_RCC_TIM17_CLK_SLEEP_ENABLE()     SET_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM17SMEN)\r
3128 #endif /* TIM17 */\r
3129 \r
3130 #if defined(SAI1)\r
3131 #define __HAL_RCC_SAI1_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SAI1SMEN)\r
3132 #endif /* SAI1 */\r
3133 \r
3134 #if defined(SAI2)\r
3135 #define __HAL_RCC_SAI2_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SAI2SMEN)\r
3136 #endif /* SAI2 */\r
3137 \r
3138 #if defined(DFSDM1_Filter0)\r
3139 #define __HAL_RCC_DFSDM1_CLK_SLEEP_ENABLE()    SET_BIT(RCC->APB2SMENR, RCC_APB2SMENR_DFSDM1SMEN)\r
3140 #endif /* DFSDM1_Filter0 */\r
3141 \r
3142 #if defined(LTDC)\r
3143 #define __HAL_RCC_LTDC_CLK_SLEEP_ENABLE()      SET_BIT(RCC->APB2SMENR, RCC_APB2SMENR_LTDCSMEN)\r
3144 #endif /* LTDC */\r
3145 \r
3146 #if defined(DSI)\r
3147 #define __HAL_RCC_DSI_CLK_SLEEP_ENABLE()       SET_BIT(RCC->APB2SMENR, RCC_APB2SMENR_DSISMEN)\r
3148 #endif /* DSI */\r
3149 \r
3150 \r
3151 #define __HAL_RCC_SYSCFG_CLK_SLEEP_DISABLE()   CLEAR_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SYSCFGSMEN)\r
3152 \r
3153 #if defined(SDMMC1) && defined(RCC_APB2SMENR_SDMMC1SMEN)\r
3154 #define __HAL_RCC_SDMMC1_CLK_SLEEP_DISABLE()   CLEAR_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SDMMC1SMEN)\r
3155 #endif /* SDMMC1 && RCC_APB2SMENR_SDMMC1SMEN */\r
3156 \r
3157 #define __HAL_RCC_TIM1_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM1SMEN)\r
3158 \r
3159 #define __HAL_RCC_SPI1_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SPI1SMEN)\r
3160 \r
3161 #if defined(TIM8)\r
3162 #define __HAL_RCC_TIM8_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM8SMEN)\r
3163 #endif /* TIM8 */\r
3164 \r
3165 #define __HAL_RCC_USART1_CLK_SLEEP_DISABLE()   CLEAR_BIT(RCC->APB2SMENR, RCC_APB2SMENR_USART1SMEN)\r
3166 \r
3167 #define __HAL_RCC_TIM15_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM15SMEN)\r
3168 \r
3169 #define __HAL_RCC_TIM16_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM16SMEN)\r
3170 \r
3171 #if defined(TIM17)\r
3172 #define __HAL_RCC_TIM17_CLK_SLEEP_DISABLE()    CLEAR_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM17SMEN)\r
3173 #endif /* TIM17 */\r
3174 \r
3175 #if defined(SAI1)\r
3176 #define __HAL_RCC_SAI1_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SAI1SMEN)\r
3177 #endif /* SAI1 */\r
3178 \r
3179 #if defined(SAI2)\r
3180 #define __HAL_RCC_SAI2_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SAI2SMEN)\r
3181 #endif /* SAI2 */\r
3182 \r
3183 #if defined(DFSDM1_Filter0)\r
3184 #define __HAL_RCC_DFSDM1_CLK_SLEEP_DISABLE()   CLEAR_BIT(RCC->APB2SMENR, RCC_APB2SMENR_DFSDM1SMEN)\r
3185 #endif /* DFSDM1_Filter0 */\r
3186 \r
3187 #if defined(LTDC)\r
3188 #define __HAL_RCC_LTDC_CLK_SLEEP_DISABLE()     CLEAR_BIT(RCC->APB2SMENR, RCC_APB2SMENR_LTDCSMEN)\r
3189 #endif /* LTDC */\r
3190 \r
3191 #if defined(DSI)\r
3192 #define __HAL_RCC_DSI_CLK_SLEEP_DISABLE()      CLEAR_BIT(RCC->APB2SMENR, RCC_APB2SMENR_DSISMEN)\r
3193 #endif /* DSI */\r
3194 \r
3195 /**\r
3196   * @}\r
3197   */\r
3198 \r
3199 /** @defgroup RCC_AHB1_Clock_Sleep_Enable_Disable_Status AHB1 Peripheral Clock Sleep Enabled or Disabled Status\r
3200   * @brief  Check whether the AHB1 peripheral clock during Low Power (Sleep) mode is enabled or not.\r
3201   * @note   Peripheral clock gating in SLEEP mode can be used to further reduce\r
3202   *         power consumption.\r
3203   * @note   After wakeup from SLEEP mode, the peripheral clock is enabled again.\r
3204   * @note   By default, all peripheral clocks are enabled during SLEEP mode.\r
3205   * @{\r
3206   */\r
3207 \r
3208 #define __HAL_RCC_DMA1_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMA1SMEN) != 0U)\r
3209 \r
3210 #define __HAL_RCC_DMA2_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMA2SMEN) != 0U)\r
3211 \r
3212 #if defined(DMAMUX1)\r
3213 #define __HAL_RCC_DMAMUX1_IS_CLK_SLEEP_ENABLED() (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMAMUX1SMEN) != 0U)\r
3214 #endif /* DMAMUX1 */\r
3215 \r
3216 #define __HAL_RCC_FLASH_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_FLASHSMEN) != 0U)\r
3217 \r
3218 #define __HAL_RCC_SRAM1_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_SRAM1SMEN) != 0U)\r
3219 \r
3220 #define __HAL_RCC_CRC_IS_CLK_SLEEP_ENABLED()     (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_CRCSMEN) != 0U)\r
3221 \r
3222 #define __HAL_RCC_TSC_IS_CLK_SLEEP_ENABLED()     (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_TSCSMEN) != 0U)\r
3223 \r
3224 #if defined(DMA2D)\r
3225 #define __HAL_RCC_DMA2D_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMA2DSMEN) != 0U)\r
3226 #endif /* DMA2D */\r
3227 \r
3228 #if defined(GFXMMU)\r
3229 #define __HAL_RCC_GFXMMU_IS_CLK_SLEEP_ENABLED()  (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_GFXMMUSMEN) != 0U)\r
3230 #endif /* GFXMMU */\r
3231 \r
3232 \r
3233 #define __HAL_RCC_DMA1_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMA1SMEN) == 0U)\r
3234 \r
3235 #define __HAL_RCC_DMA2_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMA2SMEN) == 0U)\r
3236 \r
3237 #if defined(DMAMUX1)\r
3238 #define __HAL_RCC_DMAMUX1_IS_CLK_SLEEP_DISABLED() (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMAMUX1SMEN) == 0U)\r
3239 #endif /* DMAMUX1 */\r
3240 \r
3241 #define __HAL_RCC_FLASH_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_FLASHSMEN) == 0U)\r
3242 \r
3243 #define __HAL_RCC_SRAM1_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_SRAM1SMEN) == 0U)\r
3244 \r
3245 #define __HAL_RCC_CRC_IS_CLK_SLEEP_DISABLED()    (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_CRCSMEN) == 0U)\r
3246 \r
3247 #define __HAL_RCC_TSC_IS_CLK_SLEEP_DISABLED()    (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_TSCSMEN) == 0U)\r
3248 \r
3249 #if defined(DMA2D)\r
3250 #define __HAL_RCC_DMA2D_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_DMA2DSMEN) == 0U)\r
3251 #endif /* DMA2D */\r
3252 \r
3253 #if defined(GFXMMU)\r
3254 #define __HAL_RCC_GFXMMU_IS_CLK_SLEEP_DISABLED() (READ_BIT(RCC->AHB1SMENR, RCC_AHB1SMENR_GFXMMUSMEN) == 0U)\r
3255 #endif /* GFXMMU */\r
3256 \r
3257 /**\r
3258   * @}\r
3259   */\r
3260 \r
3261 /** @defgroup RCC_AHB2_Clock_Sleep_Enable_Disable_Status AHB2 Peripheral Clock Sleep Enabled or Disabled Status\r
3262   * @brief  Check whether the AHB2 peripheral clock during Low Power (Sleep) mode is enabled or not.\r
3263   * @note   Peripheral clock gating in SLEEP mode can be used to further reduce\r
3264   *         power consumption.\r
3265   * @note   After wakeup from SLEEP mode, the peripheral clock is enabled again.\r
3266   * @note   By default, all peripheral clocks are enabled during SLEEP mode.\r
3267   * @{\r
3268   */\r
3269 \r
3270 #define __HAL_RCC_GPIOA_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOASMEN) != 0U)\r
3271 \r
3272 #define __HAL_RCC_GPIOB_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOBSMEN) != 0U)\r
3273 \r
3274 #define __HAL_RCC_GPIOC_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOCSMEN) != 0U)\r
3275 \r
3276 #if defined(GPIOD)\r
3277 #define __HAL_RCC_GPIOD_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIODSMEN) != 0U)\r
3278 #endif /* GPIOD */\r
3279 \r
3280 #if defined(GPIOE)\r
3281 #define __HAL_RCC_GPIOE_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOESMEN) != 0U)\r
3282 #endif /* GPIOE */\r
3283 \r
3284 #if defined(GPIOF)\r
3285 #define __HAL_RCC_GPIOF_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOFSMEN) != 0U)\r
3286 #endif /* GPIOF */\r
3287 \r
3288 #if defined(GPIOG)\r
3289 #define __HAL_RCC_GPIOG_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOGSMEN) != 0U)\r
3290 #endif /* GPIOG */\r
3291 \r
3292 #define __HAL_RCC_GPIOH_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOHSMEN) != 0U)\r
3293 \r
3294 #if defined(GPIOI)\r
3295 #define __HAL_RCC_GPIOI_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOISMEN) != 0U)\r
3296 #endif /* GPIOI */\r
3297 \r
3298 #define __HAL_RCC_SRAM2_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_SRAM2SMEN) != 0U)\r
3299 \r
3300 #if defined(SRAM3)\r
3301 #define __HAL_RCC_SRAM3_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_SRAM3SMEN) != 0U)\r
3302 #endif /* SRAM3 */\r
3303 \r
3304 #if defined(USB_OTG_FS)\r
3305 #define __HAL_RCC_USB_OTG_FS_IS_CLK_SLEEP_ENABLED()  (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_OTGFSSMEN) != 0U)\r
3306 #endif /* USB_OTG_FS */\r
3307 \r
3308 #define __HAL_RCC_ADC_IS_CLK_SLEEP_ENABLED()     (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_ADCSMEN) != 0U)\r
3309 \r
3310 #if defined(DCMI)\r
3311 #define __HAL_RCC_DCMI_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_DCMISMEN) != 0U)\r
3312 #endif /* DCMI */\r
3313 \r
3314 #if defined(AES)\r
3315 #define __HAL_RCC_AES_IS_CLK_SLEEP_ENABLED()     (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_AESSMEN) != 0U)\r
3316 #endif /* AES */\r
3317 \r
3318 #if defined(HASH)\r
3319 #define __HAL_RCC_HASH_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_HASHSMEN) != 0U)\r
3320 #endif /* HASH */\r
3321 \r
3322 #define __HAL_RCC_RNG_IS_CLK_SLEEP_ENABLED()     (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_RNGSMEN) != 0U)\r
3323 \r
3324 #if defined(OCTOSPIM)\r
3325 #define __HAL_RCC_OSPIM_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_OSPIMSMEN) != 0U)\r
3326 #endif /* OCTOSPIM */\r
3327 \r
3328 #if defined(SDMMC1) && defined(RCC_AHB2SMENR_SDMMC1SMEN)\r
3329 #define __HAL_RCC_SDMMC1_IS_CLK_SLEEP_ENABLED()  (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_SDMMC1SMEN) != 0U)\r
3330 #endif /* SDMMC1 && RCC_AHB2SMENR_SDMMC1SMEN */\r
3331 \r
3332 \r
3333 #define __HAL_RCC_GPIOA_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOASMEN) == 0U)\r
3334 \r
3335 #define __HAL_RCC_GPIOB_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOBSMEN) == 0U)\r
3336 \r
3337 #define __HAL_RCC_GPIOC_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOCSMEN) == 0U)\r
3338 \r
3339 #if defined(GPIOD)\r
3340 #define __HAL_RCC_GPIOD_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIODSMEN) == 0U)\r
3341 #endif /* GPIOD */\r
3342 \r
3343 #if defined(GPIOE)\r
3344 #define __HAL_RCC_GPIOE_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOESMEN) == 0U)\r
3345 #endif /* GPIOE */\r
3346 \r
3347 #if defined(GPIOF)\r
3348 #define __HAL_RCC_GPIOF_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOFSMEN) == 0U)\r
3349 #endif /* GPIOF */\r
3350 \r
3351 #if defined(GPIOG)\r
3352 #define __HAL_RCC_GPIOG_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOGSMEN) == 0U)\r
3353 #endif /* GPIOG */\r
3354 \r
3355 #define __HAL_RCC_GPIOH_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOHSMEN) == 0U)\r
3356 \r
3357 #if defined(GPIOI)\r
3358 #define __HAL_RCC_GPIOI_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_GPIOISMEN) == 0U)\r
3359 #endif /* GPIOI */\r
3360 \r
3361 #define __HAL_RCC_SRAM2_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_SRAM2SMEN) == 0U)\r
3362 \r
3363 #if defined(SRAM3)\r
3364 #define __HAL_RCC_SRAM3_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_SRAM3SMEN) == 0U)\r
3365 #endif /* SRAM3 */\r
3366 \r
3367 #if defined(USB_OTG_FS)\r
3368 #define __HAL_RCC_USB_OTG_FS_IS_CLK_SLEEP_DISABLED() (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_OTGFSSMEN) == 0U)\r
3369 #endif /* USB_OTG_FS */\r
3370 \r
3371 #define __HAL_RCC_ADC_IS_CLK_SLEEP_DISABLED()    (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_ADCSMEN) == 0U)\r
3372 \r
3373 #if defined(DCMI)\r
3374 #define __HAL_RCC_DCMI_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_DCMISMEN) == 0U)\r
3375 #endif /* DCMI */\r
3376 \r
3377 #if defined(AES)\r
3378 #define __HAL_RCC_AES_IS_CLK_SLEEP_DISABLED()    (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_AESSMEN) == 0U)\r
3379 #endif /* AES */\r
3380 \r
3381 #if defined(HASH)\r
3382 #define __HAL_RCC_HASH_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_HASHSMEN) == 0U)\r
3383 #endif /* HASH */\r
3384 \r
3385 #define __HAL_RCC_RNG_IS_CLK_SLEEP_DISABLED()    (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_RNGSMEN) == 0U)\r
3386 \r
3387 #if defined(OCTOSPIM)\r
3388 #define __HAL_RCC_OSPIM_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_OSPIMSMEN) == 0U)\r
3389 #endif /* OCTOSPIM */\r
3390 \r
3391 #if defined(SDMMC1) && defined(RCC_AHB2SMENR_SDMMC1SMEN)\r
3392 #define __HAL_RCC_SDMMC1_IS_CLK_SLEEP_DISABLED() (READ_BIT(RCC->AHB2SMENR, RCC_AHB2SMENR_SDMMC1SMEN) == 0U)\r
3393 #endif /* SDMMC1 && RCC_AHB2SMENR_SDMMC1SMEN */\r
3394 \r
3395 /**\r
3396   * @}\r
3397   */\r
3398 \r
3399 /** @defgroup RCC_AHB3_Clock_Sleep_Enable_Disable_Status AHB3 Peripheral Clock Sleep Enabled or Disabled Status\r
3400   * @brief  Check whether the AHB3 peripheral clock during Low Power (Sleep) mode is enabled or not.\r
3401   * @note   Peripheral clock gating in SLEEP mode can be used to further reduce\r
3402   *         power consumption.\r
3403   * @note   After wakeup from SLEEP mode, the peripheral clock is enabled again.\r
3404   * @note   By default, all peripheral clocks are enabled during SLEEP mode.\r
3405   * @{\r
3406   */\r
3407 \r
3408 #if defined(QUADSPI)\r
3409 #define __HAL_RCC_QSPI_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_QSPISMEN) != 0U)\r
3410 #endif /* QUADSPI */\r
3411 \r
3412 #if defined(OCTOSPI1)\r
3413 #define __HAL_RCC_OSPI1_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_OSPI1SMEN) != 0U)\r
3414 #endif /* OCTOSPI1 */\r
3415 \r
3416 #if defined(OCTOSPI2)\r
3417 #define __HAL_RCC_OSPI2_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_OSPI2SMEN) != 0U)\r
3418 #endif /* OCTOSPI2 */\r
3419 \r
3420 #if defined(FMC_BANK1)\r
3421 #define __HAL_RCC_FMC_IS_CLK_SLEEP_ENABLED()     (READ_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_FMCSMEN) != 0U)\r
3422 #endif /* FMC_BANK1 */\r
3423 \r
3424 \r
3425 #if defined(QUADSPI)\r
3426 #define __HAL_RCC_QSPI_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_QSPISMEN) == 0U)\r
3427 #endif /* QUADSPI */\r
3428 \r
3429 #if defined(OCTOSPI1)\r
3430 #define __HAL_RCC_OSPI1_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_OSPI1SMEN) == 0U)\r
3431 #endif /* OCTOSPI1 */\r
3432 \r
3433 #if defined(OCTOSPI2)\r
3434 #define __HAL_RCC_OSPI2_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_OSPI2SMEN) == 0U)\r
3435 #endif /* OCTOSPI2 */\r
3436 \r
3437 #if defined(FMC_BANK1)\r
3438 #define __HAL_RCC_FMC_IS_CLK_SLEEP_DISABLED()    (READ_BIT(RCC->AHB3SMENR, RCC_AHB3SMENR_FMCSMEN) == 0U)\r
3439 #endif /* FMC_BANK1 */\r
3440 \r
3441 /**\r
3442   * @}\r
3443   */\r
3444 \r
3445 /** @defgroup RCC_APB1_Clock_Sleep_Enable_Disable_Status APB1 Peripheral Clock Sleep Enabled or Disabled Status\r
3446   * @brief  Check whether the APB1 peripheral clock during Low Power (Sleep) mode is enabled or not.\r
3447   * @note   Peripheral clock gating in SLEEP mode can be used to further reduce\r
3448   *         power consumption.\r
3449   * @note   After wakeup from SLEEP mode, the peripheral clock is enabled again.\r
3450   * @note   By default, all peripheral clocks are enabled during SLEEP mode.\r
3451   * @{\r
3452   */\r
3453 \r
3454 #define __HAL_RCC_TIM2_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM2SMEN) != 0U)\r
3455 \r
3456 #if defined(TIM3)\r
3457 #define __HAL_RCC_TIM3_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM3SMEN) != 0U)\r
3458 #endif /* TIM3 */\r
3459 \r
3460 #if defined(TIM4)\r
3461 #define __HAL_RCC_TIM4_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM4SMEN) != 0U)\r
3462 #endif /* TIM4 */\r
3463 \r
3464 #if defined(TIM5)\r
3465 #define __HAL_RCC_TIM5_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM5SMEN) != 0U)\r
3466 #endif /* TIM5 */\r
3467 \r
3468 #define __HAL_RCC_TIM6_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM6SMEN) != 0U)\r
3469 \r
3470 #if defined(TIM7)\r
3471 #define __HAL_RCC_TIM7_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM7SMEN) != 0U)\r
3472 #endif /* TIM7 */\r
3473 \r
3474 #if defined(LCD)\r
3475 #define __HAL_RCC_LCD_IS_CLK_SLEEP_ENABLED()       (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_LCDSMEN) != 0U)\r
3476 #endif /* LCD */\r
3477 \r
3478 #if defined(RCC_APB1SMENR1_RTCAPBSMEN)\r
3479 #define __HAL_RCC_RTCAPB_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_RTCAPBSMEN) != 0U)\r
3480 #endif /* RCC_APB1SMENR1_RTCAPBSMEN */\r
3481 \r
3482 #define __HAL_RCC_WWDG_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_WWDGSMEN) != 0U)\r
3483 \r
3484 #if defined(SPI2)\r
3485 #define __HAL_RCC_SPI2_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_SPI2SMEN) != 0U)\r
3486 #endif /* SPI2 */\r
3487 \r
3488 #if defined(SPI3)\r
3489 #define __HAL_RCC_SPI3_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_SPI3SMEN) != 0U)\r
3490 #endif /* SPI3 */\r
3491 \r
3492 #define __HAL_RCC_USART2_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_USART2SMEN) != 0U)\r
3493 \r
3494 #if defined(USART3)\r
3495 #define __HAL_RCC_USART3_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_USART3SMEN) != 0U)\r
3496 #endif /* USART3 */\r
3497 \r
3498 #if defined(UART4)\r
3499 #define __HAL_RCC_UART4_IS_CLK_SLEEP_ENABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_UART4SMEN) != 0U)\r
3500 #endif /* UART4 */\r
3501 \r
3502 #if defined(UART5)\r
3503 #define __HAL_RCC_UART5_IS_CLK_SLEEP_ENABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_UART5SMEN) != 0U)\r
3504 #endif /* UART5 */\r
3505 \r
3506 #define __HAL_RCC_I2C1_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_I2C1SMEN) != 0U)\r
3507 \r
3508 #if defined(I2C2)\r
3509 #define __HAL_RCC_I2C2_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_I2C2SMEN) != 0U)\r
3510 #endif /* I2C2 */\r
3511 \r
3512 #define __HAL_RCC_I2C3_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_I2C3SMEN) != 0U)\r
3513 \r
3514 #if defined(I2C4)\r
3515 #define __HAL_RCC_I2C4_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_I2C4SMEN) != 0U)\r
3516 #endif /* I2C4 */\r
3517 \r
3518 #if defined(CRS)\r
3519 #define __HAL_RCC_CRS_IS_CLK_SLEEP_ENABLED()       (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_CRSSMEN) != 0U)\r
3520 #endif /* CRS */\r
3521 \r
3522 #if defined(CAN1)\r
3523 #define __HAL_RCC_CAN1_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_CAN1SMEN) != 0U)\r
3524 #endif /* CAN1 */\r
3525 \r
3526 #if defined(CAN2)\r
3527 #define __HAL_RCC_CAN2_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_CAN2SMEN) != 0U)\r
3528 #endif /* CAN2 */\r
3529 \r
3530 #if defined(USB)\r
3531 #define __HAL_RCC_USB_IS_CLK_SLEEP_ENABLED()       (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_USBFSSMEN) != 0U)\r
3532 #endif /* USB */\r
3533 \r
3534 #define __HAL_RCC_PWR_IS_CLK_SLEEP_ENABLED()       (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_PWRSMEN) != 0U)\r
3535 \r
3536 #if defined(DAC1)\r
3537 #define __HAL_RCC_DAC1_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_DAC1SMEN) != 0U)\r
3538 #endif /* DAC1 */\r
3539 \r
3540 #define __HAL_RCC_OPAMP_IS_CLK_SLEEP_ENABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_OPAMPSMEN) != 0U)\r
3541 \r
3542 #define __HAL_RCC_LPTIM1_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_LPTIM1SMEN) != 0U)\r
3543 \r
3544 #define __HAL_RCC_LPUART1_IS_CLK_SLEEP_ENABLED()   (READ_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_LPUART1SMEN) != 0U)\r
3545 \r
3546 #if defined(SWPMI1)\r
3547 #define __HAL_RCC_SWPMI1_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_SWPMI1SMEN) != 0U)\r
3548 #endif /* SWPMI1 */\r
3549 \r
3550 #define __HAL_RCC_LPTIM2_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_LPTIM2SMEN) != 0U)\r
3551 \r
3552 \r
3553 #define __HAL_RCC_TIM2_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM2SMEN) == 0U)\r
3554 \r
3555 #if defined(TIM3)\r
3556 #define __HAL_RCC_TIM3_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM3SMEN) == 0U)\r
3557 #endif /* TIM3 */\r
3558 \r
3559 #if defined(TIM4)\r
3560 #define __HAL_RCC_TIM4_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM4SMEN) == 0U)\r
3561 #endif /* TIM4 */\r
3562 \r
3563 #if defined(TIM5)\r
3564 #define __HAL_RCC_TIM5_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM5SMEN) == 0U)\r
3565 #endif /* TIM5 */\r
3566 \r
3567 #define __HAL_RCC_TIM6_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM6SMEN) == 0U)\r
3568 \r
3569 #if defined(TIM7)\r
3570 #define __HAL_RCC_TIM7_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_TIM7SMEN) == 0U)\r
3571 #endif /* TIM7 */\r
3572 \r
3573 #if defined(LCD)\r
3574 #define __HAL_RCC_LCD_IS_CLK_SLEEP_DISABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_LCDSMEN) == 0U)\r
3575 #endif /* LCD */\r
3576 \r
3577 #if defined(RCC_APB1SMENR1_RTCAPBSMEN)\r
3578 #define __HAL_RCC_RTCAPB_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_RTCAPBSMEN) == 0U)\r
3579 #endif /* RCC_APB1SMENR1_RTCAPBSMEN */\r
3580 \r
3581 #define __HAL_RCC_WWDG_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_WWDGSMEN) == 0U)\r
3582 \r
3583 #if defined(SPI2)\r
3584 #define __HAL_RCC_SPI2_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_SPI2SMEN) == 0U)\r
3585 #endif /* SPI2 */\r
3586 \r
3587 #if defined(SPI3)\r
3588 #define __HAL_RCC_SPI3_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_SPI3SMEN) == 0U)\r
3589 #endif /* SPI3 */\r
3590 \r
3591 #define __HAL_RCC_USART2_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_USART2SMEN) == 0U)\r
3592 \r
3593 #if defined(USART3)\r
3594 #define __HAL_RCC_USART3_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_USART3SMEN) == 0U)\r
3595 #endif /* USART3 */\r
3596 \r
3597 #if defined(UART4)\r
3598 #define __HAL_RCC_UART4_IS_CLK_SLEEP_DISABLED()    (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_UART4SMEN) == 0U)\r
3599 #endif /* UART4 */\r
3600 \r
3601 #if defined(UART5)\r
3602 #define __HAL_RCC_UART5_IS_CLK_SLEEP_DISABLED()    (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_UART5SMEN) == 0U)\r
3603 #endif /* UART5 */\r
3604 \r
3605 #define __HAL_RCC_I2C1_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_I2C1SMEN) == 0U)\r
3606 \r
3607 #if defined(I2C2)\r
3608 #define __HAL_RCC_I2C2_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_I2C2SMEN) == 0U)\r
3609 #endif /* I2C2 */\r
3610 \r
3611 #define __HAL_RCC_I2C3_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_I2C3SMEN) == 0U)\r
3612 \r
3613 #if defined(I2C4)\r
3614 #define __HAL_RCC_I2C4_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_I2C4SMEN) == 0U)\r
3615 #endif /* I2C4 */\r
3616 \r
3617 #if defined(CRS)\r
3618 #define __HAL_RCC_CRS_IS_CLK_SLEEP_DISABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_CRSSMEN) == 0U)\r
3619 #endif /* CRS */\r
3620 \r
3621 #if defined(CAN1)\r
3622 #define __HAL_RCC_CAN1_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_CAN1SMEN) == 0U)\r
3623 #endif /* CAN1 */\r
3624 \r
3625 #if defined(CAN2)\r
3626 #define __HAL_RCC_CAN2_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_CAN2SMEN) == 0U)\r
3627 #endif /* CAN2 */\r
3628 \r
3629 #if defined(USB)\r
3630 #define __HAL_RCC_USB_IS_CLK_SLEEP_DISABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_USBFSSMEN) == 0U)\r
3631 #endif /* USB */\r
3632 \r
3633 #define __HAL_RCC_PWR_IS_CLK_SLEEP_DISABLED()      (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_PWRSMEN) == 0U)\r
3634 \r
3635 #if defined(DAC1)\r
3636 #define __HAL_RCC_DAC1_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_DAC1SMEN) == 0U)\r
3637 #endif /* DAC1 */\r
3638 \r
3639 #define __HAL_RCC_OPAMP_IS_CLK_SLEEP_DISABLED()    (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_OPAMPSMEN) == 0U)\r
3640 \r
3641 #define __HAL_RCC_LPTIM1_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->APB1SMENR1, RCC_APB1SMENR1_LPTIM1SMEN) == 0U)\r
3642 \r
3643 #define __HAL_RCC_LPUART1_IS_CLK_SLEEP_DISABLED()  (READ_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_LPUART1SMEN) == 0U)\r
3644 \r
3645 #if defined(SWPMI1)\r
3646 #define __HAL_RCC_SWPMI1_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_SWPMI1SMEN) == 0U)\r
3647 #endif /* SWPMI1 */\r
3648 \r
3649 #define __HAL_RCC_LPTIM2_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->APB1SMENR2, RCC_APB1SMENR2_LPTIM2SMEN) == 0U)\r
3650 \r
3651 /**\r
3652   * @}\r
3653   */\r
3654 \r
3655 /** @defgroup RCC_APB2_Clock_Sleep_Enable_Disable_Status APB2 Peripheral Clock Sleep Enabled or Disabled Status\r
3656   * @brief  Check whether the APB2 peripheral clock during Low Power (Sleep) mode is enabled or not.\r
3657   * @note   Peripheral clock gating in SLEEP mode can be used to further reduce\r
3658   *         power consumption.\r
3659   * @note   After wakeup from SLEEP mode, the peripheral clock is enabled again.\r
3660   * @note   By default, all peripheral clocks are enabled during SLEEP mode.\r
3661   * @{\r
3662   */\r
3663 \r
3664 #define __HAL_RCC_SYSCFG_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SYSCFGSMEN) != 0U)\r
3665 \r
3666 #if defined(SDMMC1) && defined(RCC_APB2SMENR_SDMMC1SMEN)\r
3667 #define __HAL_RCC_SDMMC1_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SDMMC1SMEN) != 0U)\r
3668 #endif /* SDMMC1 && RCC_APB2SMENR_SDMMC1SMEN */\r
3669 \r
3670 #define __HAL_RCC_TIM1_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM1SMEN) != 0U)\r
3671 \r
3672 #define __HAL_RCC_SPI1_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SPI1SMEN) != 0U)\r
3673 \r
3674 #if defined(TIM8)\r
3675 #define __HAL_RCC_TIM8_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM8SMEN) != 0U)\r
3676 #endif /* TIM8 */\r
3677 \r
3678 #define __HAL_RCC_USART1_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_USART1SMEN) != 0U)\r
3679 \r
3680 #define __HAL_RCC_TIM15_IS_CLK_SLEEP_ENABLED()     (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM15SMEN) != 0U)\r
3681 \r
3682 #define __HAL_RCC_TIM16_IS_CLK_SLEEP_ENABLED()     (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM16SMEN) != 0U)\r
3683 \r
3684 #if defined(TIM17)\r
3685 #define __HAL_RCC_TIM17_IS_CLK_SLEEP_ENABLED()     (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM17SMEN) != 0U)\r
3686 #endif /* TIM17 */\r
3687 \r
3688 #if defined(SAI1)\r
3689 #define __HAL_RCC_SAI1_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SAI1SMEN) != 0U)\r
3690 #endif /* SAI1 */\r
3691 \r
3692 #if defined(SAI2)\r
3693 #define __HAL_RCC_SAI2_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SAI2SMEN) != 0U)\r
3694 #endif /* SAI2 */\r
3695 \r
3696 #if defined(DFSDM1_Filter0)\r
3697 #define __HAL_RCC_DFSDM1_IS_CLK_SLEEP_ENABLED()    (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_DFSDM1SMEN) != 0U)\r
3698 #endif /* DFSDM1_Filter0 */\r
3699 \r
3700 #if defined(LTDC)\r
3701 #define __HAL_RCC_LTDC_IS_CLK_SLEEP_ENABLED()      (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_LTDCSMEN) != 0U)\r
3702 #endif /* LTDC */\r
3703 \r
3704 #if defined(DSI)\r
3705 #define __HAL_RCC_DSI_IS_CLK_SLEEP_ENABLED()       (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_DSISMEN) != 0U)\r
3706 #endif /* DSI */\r
3707 \r
3708 \r
3709 #define __HAL_RCC_SYSCFG_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SYSCFGSMEN) == 0U)\r
3710 \r
3711 #if defined(SDMMC1) && defined(RCC_APB2SMENR_SDMMC1SMEN)\r
3712 #define __HAL_RCC_SDMMC1_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SDMMC1SMEN) == 0U)\r
3713 #endif /* SDMMC1 && RCC_APB2SMENR_SDMMC1SMEN */\r
3714 \r
3715 #define __HAL_RCC_TIM1_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM1SMEN) == 0U)\r
3716 \r
3717 #define __HAL_RCC_SPI1_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SPI1SMEN) == 0U)\r
3718 \r
3719 #if defined(TIM8)\r
3720 #define __HAL_RCC_TIM8_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM8SMEN) == 0U)\r
3721 #endif /* TIM8 */\r
3722 \r
3723 #define __HAL_RCC_USART1_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_USART1SMEN) == 0U)\r
3724 \r
3725 #define __HAL_RCC_TIM15_IS_CLK_SLEEP_DISABLED()    (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM15SMEN) == 0U)\r
3726 \r
3727 #define __HAL_RCC_TIM16_IS_CLK_SLEEP_DISABLED()    (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM16SMEN) == 0U)\r
3728 \r
3729 #if defined(TIM17)\r
3730 #define __HAL_RCC_TIM17_IS_CLK_SLEEP_DISABLED()    (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_TIM17SMEN) == 0U)\r
3731 #endif /* TIM17 */\r
3732 \r
3733 #if defined(SAI1)\r
3734 #define __HAL_RCC_SAI1_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SAI1SMEN) == 0U)\r
3735 #endif /* SAI1 */\r
3736 \r
3737 #if defined(SAI2)\r
3738 #define __HAL_RCC_SAI2_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_SAI2SMEN) == 0U)\r
3739 #endif /* SAI2 */\r
3740 \r
3741 #if defined(DFSDM1_Filter0)\r
3742 #define __HAL_RCC_DFSDM1_IS_CLK_SLEEP_DISABLED()   (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_DFSDM1SMEN) == 0U)\r
3743 #endif /* DFSDM1_Filter0 */\r
3744 \r
3745 #if defined(LTDC)\r
3746 #define __HAL_RCC_LTDC_IS_CLK_SLEEP_DISABLED()     (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_LTDCSMEN) == 0U)\r
3747 #endif /* LTDC */\r
3748 \r
3749 #if defined(DSI)\r
3750 #define __HAL_RCC_DSI_IS_CLK_SLEEP_DISABLED()      (READ_BIT(RCC->APB2SMENR, RCC_APB2SMENR_DSISMEN) == 0U)\r
3751 #endif /* DSI */\r
3752 \r
3753 /**\r
3754   * @}\r
3755   */\r
3756 \r
3757 /** @defgroup RCC_Backup_Domain_Reset RCC Backup Domain Reset\r
3758   * @{\r
3759   */\r
3760 \r
3761 /** @brief  Macros to force or release the Backup domain reset.\r
3762   * @note   This function resets the RTC peripheral (including the backup registers)\r
3763   *         and the RTC clock source selection in RCC_CSR register.\r
3764   * @note   The BKPSRAM is not affected by this reset.\r
3765   * @retval None\r
3766   */\r
3767 #define __HAL_RCC_BACKUPRESET_FORCE()   SET_BIT(RCC->BDCR, RCC_BDCR_BDRST)\r
3768 \r
3769 #define __HAL_RCC_BACKUPRESET_RELEASE() CLEAR_BIT(RCC->BDCR, RCC_BDCR_BDRST)\r
3770 \r
3771 /**\r
3772   * @}\r
3773   */\r
3774 \r
3775 /** @defgroup RCC_RTC_Clock_Configuration RCC RTC Clock Configuration\r
3776   * @{\r
3777   */\r
3778 \r
3779 /** @brief  Macros to enable or disable the RTC clock.\r
3780   * @note   As the RTC is in the Backup domain and write access is denied to\r
3781   *         this domain after reset, you have to enable write access using\r
3782   *         HAL_PWR_EnableBkUpAccess() function before to configure the RTC\r
3783   *         (to be done once after reset).\r
3784   * @note   These macros must be used after the RTC clock source was selected.\r
3785   * @retval None\r
3786   */\r
3787 #define __HAL_RCC_RTC_ENABLE()         SET_BIT(RCC->BDCR, RCC_BDCR_RTCEN)\r
3788 \r
3789 #define __HAL_RCC_RTC_DISABLE()        CLEAR_BIT(RCC->BDCR, RCC_BDCR_RTCEN)\r
3790 \r
3791 /**\r
3792   * @}\r
3793   */\r
3794 \r
3795 /** @brief  Macros to enable or disable the Internal High Speed 16MHz oscillator (HSI).\r
3796   * @note   The HSI is stopped by hardware when entering STOP and STANDBY modes.\r
3797   *         It is used (enabled by hardware) as system clock source after startup\r
3798   *         from Reset, wakeup from STOP and STANDBY mode, or in case of failure\r
3799   *         of the HSE used directly or indirectly as system clock (if the Clock\r
3800   *         Security System CSS is enabled).\r
3801   * @note   HSI can not be stopped if it is used as system clock source. In this case,\r
3802   *         you have to select another source of the system clock then stop the HSI.\r
3803   * @note   After enabling the HSI, the application software should wait on HSIRDY\r
3804   *         flag to be set indicating that HSI clock is stable and can be used as\r
3805   *         system clock source.\r
3806   *         This parameter can be: ENABLE or DISABLE.\r
3807   * @note   When the HSI is stopped, HSIRDY flag goes low after 6 HSI oscillator\r
3808   *         clock cycles.\r
3809   * @retval None\r
3810   */\r
3811 #define __HAL_RCC_HSI_ENABLE()  SET_BIT(RCC->CR, RCC_CR_HSION)\r
3812 \r
3813 #define __HAL_RCC_HSI_DISABLE() CLEAR_BIT(RCC->CR, RCC_CR_HSION)\r
3814 \r
3815 /** @brief  Macro to adjust the Internal High Speed 16MHz oscillator (HSI) calibration value.\r
3816   * @note   The calibration is used to compensate for the variations in voltage\r
3817   *         and temperature that influence the frequency of the internal HSI RC.\r
3818   * @param  __HSICALIBRATIONVALUE__ specifies the calibration trimming value\r
3819   *         (default is RCC_HSICALIBRATION_DEFAULT).\r
3820   *         This parameter must be a number between 0 and 0x1F (STM32L43x/STM32L44x/STM32L47x/STM32L48x) or 0x7F (for other devices).\r
3821   * @retval None\r
3822   */\r
3823 #define __HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST(__HSICALIBRATIONVALUE__) \\r
3824                   MODIFY_REG(RCC->ICSCR, RCC_ICSCR_HSITRIM, (__HSICALIBRATIONVALUE__) << RCC_ICSCR_HSITRIM_Pos)\r
3825 \r
3826 /**\r
3827   * @brief    Macros to enable or disable the wakeup the Internal High Speed oscillator (HSI)\r
3828   *           in parallel to the Internal Multi Speed oscillator (MSI) used at system wakeup.\r
3829   * @note     The enable of this function has not effect on the HSION bit.\r
3830   *           This parameter can be: ENABLE or DISABLE.\r
3831   * @retval None\r
3832   */\r
3833 #define __HAL_RCC_HSIAUTOMATIC_START_ENABLE()   SET_BIT(RCC->CR, RCC_CR_HSIASFS)\r
3834 \r
3835 #define __HAL_RCC_HSIAUTOMATIC_START_DISABLE()  CLEAR_BIT(RCC->CR, RCC_CR_HSIASFS)\r
3836 \r
3837 /**\r
3838   * @brief    Macros to enable or disable the force of the Internal High Speed oscillator (HSI)\r
3839   *           in STOP mode to be quickly available as kernel clock for USARTs and I2Cs.\r
3840   * @note     Keeping the HSI ON in STOP mode allows to avoid slowing down the communication\r
3841   *           speed because of the HSI startup time.\r
3842   * @note     The enable of this function has not effect on the HSION bit.\r
3843   *           This parameter can be: ENABLE or DISABLE.\r
3844   * @retval None\r
3845   */\r
3846 #define __HAL_RCC_HSISTOP_ENABLE()     SET_BIT(RCC->CR, RCC_CR_HSIKERON)\r
3847 \r
3848 #define __HAL_RCC_HSISTOP_DISABLE()    CLEAR_BIT(RCC->CR, RCC_CR_HSIKERON)\r
3849 \r
3850 /**\r
3851   * @brief  Macros to enable or disable the Internal Multi Speed oscillator (MSI).\r
3852   * @note     The MSI is stopped by hardware when entering STOP and STANDBY modes.\r
3853   *           It is used (enabled by hardware) as system clock source after\r
3854   *           startup from Reset, wakeup from STOP and STANDBY mode, or in case\r
3855   *           of failure of the HSE used directly or indirectly as system clock\r
3856   *           (if the Clock Security System CSS is enabled).\r
3857   * @note     MSI can not be stopped if it is used as system clock source.\r
3858   *           In this case, you have to select another source of the system\r
3859   *           clock then stop the MSI.\r
3860   * @note     After enabling the MSI, the application software should wait on\r
3861   *           MSIRDY flag to be set indicating that MSI clock is stable and can\r
3862   *           be used as system clock source.\r
3863   * @note   When the MSI is stopped, MSIRDY flag goes low after 6 MSI oscillator\r
3864   *         clock cycles.\r
3865   * @retval None\r
3866   */\r
3867 #define __HAL_RCC_MSI_ENABLE()  SET_BIT(RCC->CR, RCC_CR_MSION)\r
3868 \r
3869 #define __HAL_RCC_MSI_DISABLE() CLEAR_BIT(RCC->CR, RCC_CR_MSION)\r
3870 \r
3871 /** @brief  Macro Adjusts the Internal Multi Speed oscillator (MSI) calibration value.\r
3872   * @note   The calibration is used to compensate for the variations in voltage\r
3873   *         and temperature that influence the frequency of the internal MSI RC.\r
3874   *         Refer to the Application Note AN3300 for more details on how to\r
3875   *         calibrate the MSI.\r
3876   * @param  __MSICALIBRATIONVALUE__ specifies the calibration trimming value\r
3877   *         (default is RCC_MSICALIBRATION_DEFAULT).\r
3878   *         This parameter must be a number between 0 and 255.\r
3879   * @retval None\r
3880   */\r
3881 #define __HAL_RCC_MSI_CALIBRATIONVALUE_ADJUST(__MSICALIBRATIONVALUE__) \\r
3882                   MODIFY_REG(RCC->ICSCR, RCC_ICSCR_MSITRIM, (__MSICALIBRATIONVALUE__) << RCC_ICSCR_MSITRIM_Pos)\r
3883 \r
3884 /**\r
3885   * @brief  Macro configures the Internal Multi Speed oscillator (MSI) clock range in run mode\r
3886   * @note     After restart from Reset , the MSI clock is around 4 MHz.\r
3887   *           After stop the startup clock can be MSI (at any of its possible\r
3888   *           frequencies, the one that was used before entering stop mode) or HSI.\r
3889   *          After Standby its frequency can be selected between 4 possible values\r
3890   *          (1, 2, 4 or 8 MHz).\r
3891   * @note     MSIRANGE can be modified when MSI is OFF (MSION=0) or when MSI is ready\r
3892   *          (MSIRDY=1).\r
3893   * @note    The MSI clock range after reset can be modified on the fly.\r
3894   * @param  __MSIRANGEVALUE__ specifies the MSI clock range.\r
3895   *         This parameter must be one of the following values:\r
3896   *            @arg @ref RCC_MSIRANGE_0  MSI clock is around 100 KHz\r
3897   *            @arg @ref RCC_MSIRANGE_1  MSI clock is around 200 KHz\r
3898   *            @arg @ref RCC_MSIRANGE_2  MSI clock is around 400 KHz\r
3899   *            @arg @ref RCC_MSIRANGE_3  MSI clock is around 800 KHz\r
3900   *            @arg @ref RCC_MSIRANGE_4  MSI clock is around 1 MHz\r
3901   *            @arg @ref RCC_MSIRANGE_5  MSI clock is around 2 MHz\r
3902   *            @arg @ref RCC_MSIRANGE_6  MSI clock is around 4 MHz (default after Reset)\r
3903   *            @arg @ref RCC_MSIRANGE_7  MSI clock is around 8 MHz\r
3904   *            @arg @ref RCC_MSIRANGE_8  MSI clock is around 16 MHz\r
3905   *            @arg @ref RCC_MSIRANGE_9  MSI clock is around 24 MHz\r
3906   *            @arg @ref RCC_MSIRANGE_10  MSI clock is around 32 MHz\r
3907   *            @arg @ref RCC_MSIRANGE_11  MSI clock is around 48 MHz\r
3908   * @retval None\r
3909   */\r
3910 #define __HAL_RCC_MSI_RANGE_CONFIG(__MSIRANGEVALUE__) \\r
3911                   do {                                                         \\r
3912                     SET_BIT(RCC->CR, RCC_CR_MSIRGSEL);                         \\r
3913                     MODIFY_REG(RCC->CR, RCC_CR_MSIRANGE, (__MSIRANGEVALUE__)); \\r
3914                   } while(0)\r
3915 \r
3916 /**\r
3917   * @brief  Macro configures the Internal Multi Speed oscillator (MSI) clock range after Standby mode\r
3918   *         After Standby its frequency can be selected between 4 possible values (1, 2, 4 or 8 MHz).\r
3919   * @param  __MSIRANGEVALUE__ specifies the MSI clock range.\r
3920   *         This parameter must be one of the following values:\r
3921   *            @arg @ref RCC_MSIRANGE_4  MSI clock is around 1 MHz\r
3922   *            @arg @ref RCC_MSIRANGE_5  MSI clock is around 2 MHz\r
3923   *            @arg @ref RCC_MSIRANGE_6  MSI clock is around 4 MHz (default after Reset)\r
3924   *            @arg @ref RCC_MSIRANGE_7  MSI clock is around 8 MHz\r
3925   * @retval None\r
3926   */\r
3927 #define __HAL_RCC_MSI_STANDBY_RANGE_CONFIG(__MSIRANGEVALUE__) \\r
3928                   MODIFY_REG(RCC->CSR, RCC_CSR_MSISRANGE, (__MSIRANGEVALUE__) << 4U)\r
3929 \r
3930 /** @brief  Macro to get the Internal Multi Speed oscillator (MSI) clock range in run mode\r
3931   * @retval MSI clock range.\r
3932   *         This parameter must be one of the following values:\r
3933   *            @arg @ref RCC_MSIRANGE_0  MSI clock is around 100 KHz\r
3934   *            @arg @ref RCC_MSIRANGE_1  MSI clock is around 200 KHz\r
3935   *            @arg @ref RCC_MSIRANGE_2  MSI clock is around 400 KHz\r
3936   *            @arg @ref RCC_MSIRANGE_3  MSI clock is around 800 KHz\r
3937   *            @arg @ref RCC_MSIRANGE_4  MSI clock is around 1 MHz\r
3938   *            @arg @ref RCC_MSIRANGE_5  MSI clock is around 2 MHz\r
3939   *            @arg @ref RCC_MSIRANGE_6  MSI clock is around 4 MHz (default after Reset)\r
3940   *            @arg @ref RCC_MSIRANGE_7  MSI clock is around 8 MHz\r
3941   *            @arg @ref RCC_MSIRANGE_8  MSI clock is around 16 MHz\r
3942   *            @arg @ref RCC_MSIRANGE_9  MSI clock is around 24 MHz\r
3943   *            @arg @ref RCC_MSIRANGE_10  MSI clock is around 32 MHz\r
3944   *            @arg @ref RCC_MSIRANGE_11  MSI clock is around 48 MHz\r
3945   */\r
3946 #define __HAL_RCC_GET_MSI_RANGE()                                              \\r
3947                   ((READ_BIT(RCC->CR, RCC_CR_MSIRGSEL) != 0U) ?             \\r
3948                    READ_BIT(RCC->CR, RCC_CR_MSIRANGE) :                        \\r
3949                    (READ_BIT(RCC->CSR, RCC_CSR_MSISRANGE) >> 4U))\r
3950 \r
3951 /** @brief  Macros to enable or disable the Internal Low Speed oscillator (LSI).\r
3952   * @note   After enabling the LSI, the application software should wait on\r
3953   *         LSIRDY flag to be set indicating that LSI clock is stable and can\r
3954   *         be used to clock the IWDG and/or the RTC.\r
3955   * @note   LSI can not be disabled if the IWDG is running.\r
3956   * @note   When the LSI is stopped, LSIRDY flag goes low after 6 LSI oscillator\r
3957   *         clock cycles.\r
3958   * @retval None\r
3959   */\r
3960 #define __HAL_RCC_LSI_ENABLE()         SET_BIT(RCC->CSR, RCC_CSR_LSION)\r
3961 \r
3962 #define __HAL_RCC_LSI_DISABLE()        CLEAR_BIT(RCC->CSR, RCC_CSR_LSION)\r
3963 \r
3964 /**\r
3965   * @brief  Macro to configure the External High Speed oscillator (HSE).\r
3966   * @note   Transition HSE Bypass to HSE On and HSE On to HSE Bypass are not\r
3967   *         supported by this macro. User should request a transition to HSE Off\r
3968   *         first and then HSE On or HSE Bypass.\r
3969   * @note   After enabling the HSE (RCC_HSE_ON or RCC_HSE_Bypass), the application\r
3970   *         software should wait on HSERDY flag to be set indicating that HSE clock\r
3971   *         is stable and can be used to clock the PLL and/or system clock.\r
3972   * @note   HSE state can not be changed if it is used directly or through the\r
3973   *         PLL as system clock. In this case, you have to select another source\r
3974   *         of the system clock then change the HSE state (ex. disable it).\r
3975   * @note   The HSE is stopped by hardware when entering STOP and STANDBY modes.\r
3976   * @note   This function reset the CSSON bit, so if the clock security system(CSS)\r
3977   *         was previously enabled you have to enable it again after calling this\r
3978   *         function.\r
3979   * @param  __STATE__ specifies the new state of the HSE.\r
3980   *         This parameter can be one of the following values:\r
3981   *            @arg @ref RCC_HSE_OFF  Turn OFF the HSE oscillator, HSERDY flag goes low after\r
3982   *                              6 HSE oscillator clock cycles.\r
3983   *            @arg @ref RCC_HSE_ON  Turn ON the HSE oscillator.\r
3984   *            @arg @ref RCC_HSE_BYPASS  HSE oscillator bypassed with external clock.\r
3985   * @retval None\r
3986   */\r
3987 #define __HAL_RCC_HSE_CONFIG(__STATE__)                      \\r
3988                     do {                                     \\r
3989                       if((__STATE__) == RCC_HSE_ON)          \\r
3990                       {                                      \\r
3991                         SET_BIT(RCC->CR, RCC_CR_HSEON);      \\r
3992                       }                                      \\r
3993                       else if((__STATE__) == RCC_HSE_BYPASS) \\r
3994                       {                                      \\r
3995                         SET_BIT(RCC->CR, RCC_CR_HSEBYP);     \\r
3996                         SET_BIT(RCC->CR, RCC_CR_HSEON);      \\r
3997                       }                                      \\r
3998                       else                                   \\r
3999                       {                                      \\r
4000                         CLEAR_BIT(RCC->CR, RCC_CR_HSEON);    \\r
4001                         CLEAR_BIT(RCC->CR, RCC_CR_HSEBYP);   \\r
4002                       }                                      \\r
4003                     } while(0)\r
4004 \r
4005 /**\r
4006   * @brief  Macro to configure the External Low Speed oscillator (LSE).\r
4007   * @note   Transitions LSE Bypass to LSE On and LSE On to LSE Bypass are not\r
4008   *         supported by this macro. User should request a transition to LSE Off\r
4009   *         first and then LSE On or LSE Bypass.\r
4010   * @note   As the LSE is in the Backup domain and write access is denied to\r
4011   *         this domain after reset, you have to enable write access using\r
4012   *         HAL_PWR_EnableBkUpAccess() function before to configure the LSE\r
4013   *         (to be done once after reset).\r
4014   * @note   After enabling the LSE (RCC_LSE_ON or RCC_LSE_BYPASS), the application\r
4015   *         software should wait on LSERDY flag to be set indicating that LSE clock\r
4016   *         is stable and can be used to clock the RTC.\r
4017   * @param  __STATE__ specifies the new state of the LSE.\r
4018   *         This parameter can be one of the following values:\r
4019   *            @arg @ref RCC_LSE_OFF  Turn OFF the LSE oscillator, LSERDY flag goes low after\r
4020   *                              6 LSE oscillator clock cycles.\r
4021   *            @arg @ref RCC_LSE_ON  Turn ON the LSE oscillator.\r
4022   *            @arg @ref RCC_LSE_BYPASS  LSE oscillator bypassed with external clock.\r
4023   * @retval None\r
4024   */\r
4025 #define __HAL_RCC_LSE_CONFIG(__STATE__)                        \\r
4026                     do {                                       \\r
4027                       if((__STATE__) == RCC_LSE_ON)            \\r
4028                       {                                        \\r
4029                         SET_BIT(RCC->BDCR, RCC_BDCR_LSEON);    \\r
4030                       }                                        \\r
4031                       else if((__STATE__) == RCC_LSE_BYPASS)   \\r
4032                       {                                        \\r
4033                         SET_BIT(RCC->BDCR, RCC_BDCR_LSEBYP);   \\r
4034                         SET_BIT(RCC->BDCR, RCC_BDCR_LSEON);    \\r
4035                       }                                        \\r
4036                       else                                     \\r
4037                       {                                        \\r
4038                         CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSEON);  \\r
4039                         CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSEBYP); \\r
4040                       }                                        \\r
4041                     } while(0)\r
4042 \r
4043 #if defined(RCC_HSI48_SUPPORT)\r
4044 \r
4045 /** @brief  Macros to enable or disable the Internal High Speed 48MHz oscillator (HSI48).\r
4046   * @note   The HSI48 is stopped by hardware when entering STOP and STANDBY modes.\r
4047   * @note   After enabling the HSI48, the application software should wait on HSI48RDY\r
4048   *         flag to be set indicating that HSI48 clock is stable.\r
4049   *         This parameter can be: ENABLE or DISABLE.\r
4050   * @retval None\r
4051   */\r
4052 #define __HAL_RCC_HSI48_ENABLE()  SET_BIT(RCC->CRRCR, RCC_CRRCR_HSI48ON)\r
4053 \r
4054 #define __HAL_RCC_HSI48_DISABLE() CLEAR_BIT(RCC->CRRCR, RCC_CRRCR_HSI48ON)\r
4055 \r
4056 #endif /* RCC_HSI48_SUPPORT */\r
4057 \r
4058 /** @brief  Macros to configure the RTC clock (RTCCLK).\r
4059   * @note   As the RTC clock configuration bits are in the Backup domain and write\r
4060   *         access is denied to this domain after reset, you have to enable write\r
4061   *         access using the Power Backup Access macro before to configure\r
4062   *         the RTC clock source (to be done once after reset).\r
4063   * @note   Once the RTC clock is configured it cannot be changed unless the\r
4064   *         Backup domain is reset using __HAL_RCC_BACKUPRESET_FORCE() macro, or by\r
4065   *         a Power On Reset (POR).\r
4066   *\r
4067   * @param  __RTC_CLKSOURCE__ specifies the RTC clock source.\r
4068   *         This parameter can be one of the following values:\r
4069   *            @arg @ref RCC_RTCCLKSOURCE_NONE  No clock selected as RTC clock.\r
4070   *            @arg @ref RCC_RTCCLKSOURCE_LSE  LSE selected as RTC clock.\r
4071   *            @arg @ref RCC_RTCCLKSOURCE_LSI  LSI selected as RTC clock.\r
4072   *            @arg @ref RCC_RTCCLKSOURCE_HSE_DIV32  HSE clock divided by 32 selected\r
4073   *\r
4074   * @note   If the LSE or LSI is used as RTC clock source, the RTC continues to\r
4075   *         work in STOP and STANDBY modes, and can be used as wakeup source.\r
4076   *         However, when the HSE clock is used as RTC clock source, the RTC\r
4077   *         cannot be used in STOP and STANDBY modes.\r
4078   * @note   The maximum input clock frequency for RTC is 1MHz (when using HSE as\r
4079   *         RTC clock source).\r
4080   * @retval None\r
4081   */\r
4082 #define __HAL_RCC_RTC_CONFIG(__RTC_CLKSOURCE__)  \\r
4083                   MODIFY_REG( RCC->BDCR, RCC_BDCR_RTCSEL, (__RTC_CLKSOURCE__))\r
4084 \r
4085 \r
4086 /** @brief  Macro to get the RTC clock source.\r
4087   * @retval The returned value can be one of the following:\r
4088   *            @arg @ref RCC_RTCCLKSOURCE_NONE  No clock selected as RTC clock.\r
4089   *            @arg @ref RCC_RTCCLKSOURCE_LSE  LSE selected as RTC clock.\r
4090   *            @arg @ref RCC_RTCCLKSOURCE_LSI  LSI selected as RTC clock.\r
4091   *            @arg @ref RCC_RTCCLKSOURCE_HSE_DIV32  HSE clock divided by 32 selected\r
4092   */\r
4093 #define  __HAL_RCC_GET_RTC_SOURCE() (READ_BIT(RCC->BDCR, RCC_BDCR_RTCSEL))\r
4094 \r
4095 /** @brief  Macros to enable or disable the main PLL.\r
4096   * @note   After enabling the main PLL, the application software should wait on\r
4097   *         PLLRDY flag to be set indicating that PLL clock is stable and can\r
4098   *         be used as system clock source.\r
4099   * @note   The main PLL can not be disabled if it is used as system clock source\r
4100   * @note   The main PLL is disabled by hardware when entering STOP and STANDBY modes.\r
4101   * @retval None\r
4102   */\r
4103 #define __HAL_RCC_PLL_ENABLE()         SET_BIT(RCC->CR, RCC_CR_PLLON)\r
4104 \r
4105 #define __HAL_RCC_PLL_DISABLE()        CLEAR_BIT(RCC->CR, RCC_CR_PLLON)\r
4106 \r
4107 /** @brief  Macro to configure the PLL clock source.\r
4108   * @note   This function must be used only when the main PLL is disabled.\r
4109   * @param  __PLLSOURCE__ specifies the PLL entry clock source.\r
4110   *         This parameter can be one of the following values:\r
4111   *            @arg @ref RCC_PLLSOURCE_NONE  No clock selected as PLL clock entry\r
4112   *            @arg @ref RCC_PLLSOURCE_MSI  MSI oscillator clock selected as PLL clock entry\r
4113   *            @arg @ref RCC_PLLSOURCE_HSI  HSI oscillator clock selected as PLL clock entry\r
4114   *            @arg @ref RCC_PLLSOURCE_HSE  HSE oscillator clock selected as PLL clock entry\r
4115   * @note   This clock source is common for the main PLL and audio PLL (PLLSAI1 and PLLSAI2).\r
4116   * @retval None\r
4117   *\r
4118   */\r
4119 #define __HAL_RCC_PLL_PLLSOURCE_CONFIG(__PLLSOURCE__) \\r
4120                   MODIFY_REG(RCC->PLLCFGR, RCC_PLLCFGR_PLLSRC, (__PLLSOURCE__))\r
4121 \r
4122 /** @brief  Macro to configure the PLL source division factor M.\r
4123   * @note   This function must be used only when the main PLL is disabled.\r
4124   * @param  __PLLM__ specifies the division factor for PLL VCO input clock\r
4125   *         This parameter must be a number between Min_Data = 1 and Max_Data = 16 on STM32L4Rx/STM32L4Sx devices.\r
4126   *         This parameter must be a number between Min_Data = 1 and Max_Data = 8 on other devices.\r
4127   * @note   You have to set the PLLM parameter correctly to ensure that the VCO input\r
4128   *         frequency ranges from 4 to 16 MHz. It is recommended to select a frequency\r
4129   *         of 16 MHz to limit PLL jitter.\r
4130   * @retval None\r
4131   *\r
4132   */\r
4133 #define __HAL_RCC_PLL_PLLM_CONFIG(__PLLM__) \\r
4134                   MODIFY_REG(RCC->PLLCFGR, RCC_PLLCFGR_PLLM, ((__PLLM__) - 1) << 4U)\r
4135 \r
4136 /**\r
4137   * @brief  Macro to configure the main PLL clock source, multiplication and division factors.\r
4138   * @note   This function must be used only when the main PLL is disabled.\r
4139   *\r
4140   * @param  __PLLSOURCE__ specifies the PLL entry clock source.\r
4141   *          This parameter can be one of the following values:\r
4142   *            @arg @ref RCC_PLLSOURCE_NONE  No clock selected as PLL clock entry\r
4143   *            @arg @ref RCC_PLLSOURCE_MSI  MSI oscillator clock selected as PLL clock entry\r
4144   *            @arg @ref RCC_PLLSOURCE_HSI  HSI oscillator clock selected as PLL clock entry\r
4145   *            @arg @ref RCC_PLLSOURCE_HSE  HSE oscillator clock selected as PLL clock entry\r
4146   * @note   This clock source is common for the main PLL and audio PLL (PLLSAI1 and PLLSAI2).\r
4147   *\r
4148   * @param  __PLLM__ specifies the division factor for PLL VCO input clock.\r
4149   *          This parameter must be a number between Min_Data = 1 and Max_Data = 16 on STM32L4Rx/STM32L4Sx devices.\r
4150   *          This parameter must be a number between Min_Data = 1 and Max_Data = 8 on other devices.\r
4151   * @note   You have to set the PLLM parameter correctly to ensure that the VCO input\r
4152   *         frequency ranges from 4 to 16 MHz. It is recommended to select a frequency\r
4153   *         of 16 MHz to limit PLL jitter.\r
4154   *\r
4155   * @param  __PLLN__ specifies the multiplication factor for PLL VCO output clock.\r
4156   *          This parameter must be a number between 8 and 86.\r
4157   * @note   You have to set the PLLN parameter correctly to ensure that the VCO\r
4158   *         output frequency is between 64 and 344 MHz.\r
4159   *\r
4160   * @param  __PLLP__ specifies the division factor for SAI clock when SAI available on device.\r
4161   *          This parameter must be a number in the range (7 or 17) for STM32L47x/STM32L48x\r
4162   *          else (2 to 31).\r
4163   *\r
4164   * @param  __PLLQ__ specifies the division factor for OTG FS, SDMMC1 and RNG clocks.\r
4165   *          This parameter must be in the range (2, 4, 6 or 8).\r
4166   * @note   If the USB OTG FS is used in your application, you have to set the\r
4167   *         PLLQ parameter correctly to have 48 MHz clock for the USB. However,\r
4168   *         the SDMMC1 and RNG need a frequency lower than or equal to 48 MHz to work\r
4169   *         correctly.\r
4170   * @param  __PLLR__ specifies the division factor for the main system clock.\r
4171   * @note   You have to set the PLLR parameter correctly to not exceed 80MHZ.\r
4172   *          This parameter must be in the range (2, 4, 6 or 8).\r
4173   * @retval None\r
4174   */\r
4175 #if defined(RCC_PLLP_DIV_2_31_SUPPORT)\r
4176 \r
4177 #define __HAL_RCC_PLL_CONFIG(__PLLSOURCE__, __PLLM__, __PLLN__, __PLLP__, __PLLQ__,__PLLR__ ) \\r
4178                   MODIFY_REG(RCC->PLLCFGR, \\r
4179                              (RCC_PLLCFGR_PLLSRC | RCC_PLLCFGR_PLLM | RCC_PLLCFGR_PLLN | \\r
4180                               RCC_PLLCFGR_PLLQ | RCC_PLLCFGR_PLLR | RCC_PLLCFGR_PLLP | RCC_PLLCFGR_PLLPDIV), \\r
4181                              ((__PLLSOURCE__) | \\r
4182                               (((__PLLM__) - 1U) << RCC_PLLCFGR_PLLM_Pos) | \\r
4183                               ((__PLLN__) << RCC_PLLCFGR_PLLN_Pos) | \\r
4184                               ((((__PLLQ__) >> 1U) - 1U) << RCC_PLLCFGR_PLLQ_Pos) | \\r
4185                               ((((__PLLR__) >> 1U) - 1U) << RCC_PLLCFGR_PLLR_Pos) | \\r
4186                               ((uint32_t)(__PLLP__) << RCC_PLLCFGR_PLLPDIV_Pos)))\r
4187 \r
4188 #elif defined(RCC_PLLP_SUPPORT)\r
4189 \r
4190 #define __HAL_RCC_PLL_CONFIG(__PLLSOURCE__, __PLLM__, __PLLN__, __PLLP__, __PLLQ__,__PLLR__ ) \\r
4191                   MODIFY_REG(RCC->PLLCFGR, \\r
4192                              (RCC_PLLCFGR_PLLSRC | RCC_PLLCFGR_PLLM | RCC_PLLCFGR_PLLN | \\r
4193                               RCC_PLLCFGR_PLLQ | RCC_PLLCFGR_PLLR | RCC_PLLCFGR_PLLP), \\r
4194                              ((__PLLSOURCE__) | \\r
4195                               (((__PLLM__) - 1U) << RCC_PLLCFGR_PLLM_Pos) | \\r
4196                               ((__PLLN__) << RCC_PLLCFGR_PLLN_Pos) | \\r
4197                               ((((__PLLQ__) >> 1U) - 1U) << RCC_PLLCFGR_PLLQ_Pos) | \\r
4198                               ((((__PLLR__) >> 1U) - 1U) << RCC_PLLCFGR_PLLR_Pos) | \\r
4199                               (((__PLLP__) >> 4U) << RCC_PLLCFGR_PLLP_Pos)))\r
4200 \r
4201 #else\r
4202 \r
4203 #define __HAL_RCC_PLL_CONFIG(__PLLSOURCE__, __PLLM__, __PLLN__, __PLLQ__,__PLLR__ ) \\r
4204                   MODIFY_REG(RCC->PLLCFGR, \\r
4205                              (RCC_PLLCFGR_PLLSRC | RCC_PLLCFGR_PLLM | RCC_PLLCFGR_PLLN | \\r
4206                               RCC_PLLCFGR_PLLQ | RCC_PLLCFGR_PLLR), \\r
4207                              ((__PLLSOURCE__) | \\r
4208                               (((__PLLM__) - 1U) << RCC_PLLCFGR_PLLM_Pos) | \\r
4209                               ((__PLLN__) << RCC_PLLCFGR_PLLN_Pos) | \\r
4210                               ((((__PLLQ__) >> 1U) - 1U) << RCC_PLLCFGR_PLLQ_Pos) | \\r
4211                               ((((__PLLR__) >> 1U) - 1U) << RCC_PLLCFGR_PLLR_Pos)))\r
4212 \r
4213 #endif /* RCC_PLLP_DIV_2_31_SUPPORT */\r
4214 \r
4215 /** @brief  Macro to get the oscillator used as PLL clock source.\r
4216   * @retval The oscillator used as PLL clock source. The returned value can be one\r
4217   *         of the following:\r
4218   *              - RCC_PLLSOURCE_NONE: No oscillator is used as PLL clock source.\r
4219   *              - RCC_PLLSOURCE_MSI: MSI oscillator is used as PLL clock source.\r
4220   *              - RCC_PLLSOURCE_HSI: HSI oscillator is used as PLL clock source.\r
4221   *              - RCC_PLLSOURCE_HSE: HSE oscillator is used as PLL clock source.\r
4222   */\r
4223 #define __HAL_RCC_GET_PLL_OSCSOURCE() (READ_BIT(RCC->PLLCFGR, RCC_PLLCFGR_PLLSRC))\r
4224 \r
4225 /**\r
4226   * @brief  Enable or disable each clock output (RCC_PLL_SYSCLK, RCC_PLL_48M1CLK, RCC_PLL_SAI3CLK)\r
4227   * @note   Enabling/disabling clock outputs RCC_PLL_SAI3CLK and RCC_PLL_48M1CLK can be done at anytime\r
4228   *         without the need to stop the PLL in order to save power. But RCC_PLL_SYSCLK cannot\r
4229   *         be stopped if used as System Clock.\r
4230   * @param  __PLLCLOCKOUT__ specifies the PLL clock to be output.\r
4231   *          This parameter can be one or a combination of the following values:\r
4232   *            @arg @ref RCC_PLL_SAI3CLK  This clock is used to generate an accurate clock to achieve\r
4233   *                                   high-quality audio performance on SAI interface in case.\r
4234   *            @arg @ref RCC_PLL_48M1CLK  This Clock is used to generate the clock for the USB OTG FS (48 MHz),\r
4235   *                                   the random analog generator (<=48 MHz) and the SDMMC1 (<= 48 MHz).\r
4236   *            @arg @ref RCC_PLL_SYSCLK  This Clock is used to generate the high speed system clock (up to 80MHz)\r
4237   * @retval None\r
4238   */\r
4239 #define __HAL_RCC_PLLCLKOUT_ENABLE(__PLLCLOCKOUT__)   SET_BIT(RCC->PLLCFGR, (__PLLCLOCKOUT__))\r
4240 \r
4241 #define __HAL_RCC_PLLCLKOUT_DISABLE(__PLLCLOCKOUT__)  CLEAR_BIT(RCC->PLLCFGR, (__PLLCLOCKOUT__))\r
4242 \r
4243 /**\r
4244   * @brief  Get clock output enable status (RCC_PLL_SYSCLK, RCC_PLL_48M1CLK, RCC_PLL_SAI3CLK)\r
4245   * @param  __PLLCLOCKOUT__ specifies the output PLL clock to be checked.\r
4246   *          This parameter can be one of the following values:\r
4247   *            @arg @ref RCC_PLL_SAI3CLK  This clock is used to generate an accurate clock to achieve\r
4248   *                                   high-quality audio performance on SAI interface in case.\r
4249   *            @arg @ref RCC_PLL_48M1CLK  This Clock is used to generate the clock for the USB OTG FS (48 MHz),\r
4250   *                                   the random analog generator (<=48 MHz) and the SDMMC1 (<= 48 MHz).\r
4251   *            @arg @ref RCC_PLL_SYSCLK  This Clock is used to generate the high speed system clock (up to 80MHz)\r
4252   * @retval SET / RESET\r
4253   */\r
4254 #define __HAL_RCC_GET_PLLCLKOUT_CONFIG(__PLLCLOCKOUT__)  READ_BIT(RCC->PLLCFGR, (__PLLCLOCKOUT__))\r
4255 \r
4256 /**\r
4257   * @brief  Macro to configure the system clock source.\r
4258   * @param  __SYSCLKSOURCE__ specifies the system clock source.\r
4259   *          This parameter can be one of the following values:\r
4260   *              - RCC_SYSCLKSOURCE_MSI: MSI oscillator is used as system clock source.\r
4261   *              - RCC_SYSCLKSOURCE_HSI: HSI oscillator is used as system clock source.\r
4262   *              - RCC_SYSCLKSOURCE_HSE: HSE oscillator is used as system clock source.\r
4263   *              - RCC_SYSCLKSOURCE_PLLCLK: PLL output is used as system clock source.\r
4264   * @retval None\r
4265   */\r
4266 #define __HAL_RCC_SYSCLK_CONFIG(__SYSCLKSOURCE__) \\r
4267                   MODIFY_REG(RCC->CFGR, RCC_CFGR_SW, (__SYSCLKSOURCE__))\r
4268 \r
4269 /** @brief  Macro to get the clock source used as system clock.\r
4270   * @retval The clock source used as system clock. The returned value can be one\r
4271   *         of the following:\r
4272   *              - RCC_SYSCLKSOURCE_STATUS_MSI: MSI used as system clock.\r
4273   *              - RCC_SYSCLKSOURCE_STATUS_HSI: HSI used as system clock.\r
4274   *              - RCC_SYSCLKSOURCE_STATUS_HSE: HSE used as system clock.\r
4275   *              - RCC_SYSCLKSOURCE_STATUS_PLLCLK: PLL used as system clock.\r
4276   */\r
4277 #define __HAL_RCC_GET_SYSCLK_SOURCE() (READ_BIT(RCC->CFGR, RCC_CFGR_SWS))\r
4278 \r
4279 /**\r
4280   * @brief  Macro to configure the External Low Speed oscillator (LSE) drive capability.\r
4281   * @note   As the LSE is in the Backup domain and write access is denied to\r
4282   *         this domain after reset, you have to enable write access using\r
4283   *         HAL_PWR_EnableBkUpAccess() function before to configure the LSE\r
4284   *         (to be done once after reset).\r
4285   * @param  __LSEDRIVE__ specifies the new state of the LSE drive capability.\r
4286   *          This parameter can be one of the following values:\r
4287   *            @arg @ref RCC_LSEDRIVE_LOW  LSE oscillator low drive capability.\r
4288   *            @arg @ref RCC_LSEDRIVE_MEDIUMLOW  LSE oscillator medium low drive capability.\r
4289   *            @arg @ref RCC_LSEDRIVE_MEDIUMHIGH  LSE oscillator medium high drive capability.\r
4290   *            @arg @ref RCC_LSEDRIVE_HIGH  LSE oscillator high drive capability.\r
4291   * @retval None\r
4292   */\r
4293 #define __HAL_RCC_LSEDRIVE_CONFIG(__LSEDRIVE__) \\r
4294                   MODIFY_REG(RCC->BDCR, RCC_BDCR_LSEDRV, (__LSEDRIVE__))\r
4295 \r
4296 /**\r
4297   * @brief  Macro to configure the wake up from stop clock.\r
4298   * @param  __STOPWUCLK__ specifies the clock source used after wake up from stop.\r
4299   *         This parameter can be one of the following values:\r
4300   *            @arg @ref RCC_STOP_WAKEUPCLOCK_MSI  MSI selected as system clock source\r
4301   *            @arg @ref RCC_STOP_WAKEUPCLOCK_HSI  HSI selected as system clock source\r
4302   * @retval None\r
4303   */\r
4304 #define __HAL_RCC_WAKEUPSTOP_CLK_CONFIG(__STOPWUCLK__) \\r
4305                   MODIFY_REG(RCC->CFGR, RCC_CFGR_STOPWUCK, (__STOPWUCLK__))\r
4306 \r
4307 \r
4308 /** @brief  Macro to configure the MCO clock.\r
4309   * @param  __MCOCLKSOURCE__ specifies the MCO clock source.\r
4310   *          This parameter can be one of the following values:\r
4311   *            @arg @ref RCC_MCO1SOURCE_NOCLOCK  MCO output disabled\r
4312   *            @arg @ref RCC_MCO1SOURCE_SYSCLK  System  clock selected as MCO source\r
4313   *            @arg @ref RCC_MCO1SOURCE_MSI  MSI clock selected as MCO source\r
4314   *            @arg @ref RCC_MCO1SOURCE_HSI  HSI clock selected as MCO source\r
4315   *            @arg @ref RCC_MCO1SOURCE_HSE  HSE clock selected as MCO sourcee\r
4316   *            @arg @ref RCC_MCO1SOURCE_PLLCLK  Main PLL clock selected as MCO source\r
4317   *            @arg @ref RCC_MCO1SOURCE_LSI  LSI clock selected as MCO source\r
4318   *            @arg @ref RCC_MCO1SOURCE_LSE  LSE clock selected as MCO source\r
4319   @if STM32L443xx\r
4320   *            @arg @ref RCC_MCO1SOURCE_HSI48  HSI48 clock selected as MCO source for devices with HSI48\r
4321   @endif\r
4322   @if STM32L4A6xx\r
4323   *            @arg @ref RCC_MCO1SOURCE_HSI48  HSI48 clock selected as MCO source for devices with HSI48\r
4324   @endif\r
4325   * @param  __MCODIV__ specifies the MCO clock prescaler.\r
4326   *          This parameter can be one of the following values:\r
4327   *            @arg @ref RCC_MCODIV_1   MCO clock source is divided by 1\r
4328   *            @arg @ref RCC_MCODIV_2   MCO clock source is divided by 2\r
4329   *            @arg @ref RCC_MCODIV_4   MCO clock source is divided by 4\r
4330   *            @arg @ref RCC_MCODIV_8   MCO clock source is divided by 8\r
4331   *            @arg @ref RCC_MCODIV_16  MCO clock source is divided by 16\r
4332   */\r
4333 #define __HAL_RCC_MCO1_CONFIG(__MCOCLKSOURCE__, __MCODIV__) \\r
4334                  MODIFY_REG(RCC->CFGR, (RCC_CFGR_MCOSEL | RCC_CFGR_MCOPRE), ((__MCOCLKSOURCE__) | (__MCODIV__)))\r
4335 \r
4336 /** @defgroup RCC_Flags_Interrupts_Management Flags Interrupts Management\r
4337   * @brief macros to manage the specified RCC Flags and interrupts.\r
4338   * @{\r
4339   */\r
4340 \r
4341 /** @brief  Enable RCC interrupt(s).\r
4342   * @param  __INTERRUPT__ specifies the RCC interrupt source(s) to be enabled.\r
4343   *         This parameter can be any combination of the following values:\r
4344   *            @arg @ref RCC_IT_LSIRDY  LSI ready interrupt\r
4345   *            @arg @ref RCC_IT_LSERDY  LSE ready interrupt\r
4346   *            @arg @ref RCC_IT_MSIRDY  HSI ready interrupt\r
4347   *            @arg @ref RCC_IT_HSIRDY  HSI ready interrupt\r
4348   *            @arg @ref RCC_IT_HSERDY  HSE ready interrupt\r
4349   *            @arg @ref RCC_IT_PLLRDY  Main PLL ready interrupt\r
4350   *            @arg @ref RCC_IT_PLLSAI1RDY  PLLSAI1 ready interrupt for devices with PLLSAI1\r
4351   *            @arg @ref RCC_IT_PLLSAI2RDY  PLLSAI2 ready interrupt for devices with PLLSAI2\r
4352   *            @arg @ref RCC_IT_LSECSS  LSE Clock security system interrupt\r
4353   @if STM32L443xx\r
4354   *            @arg @ref RCC_IT_HSI48RDY  HSI48 ready interrupt for devices with HSI48\r
4355   @endif\r
4356   @if STM32L4A6xx\r
4357   *            @arg @ref RCC_IT_HSI48RDY  HSI48 ready interrupt for devices with HSI48\r
4358   @endif\r
4359   * @retval None\r
4360   */\r
4361 #define __HAL_RCC_ENABLE_IT(__INTERRUPT__) SET_BIT(RCC->CIER, (__INTERRUPT__))\r
4362 \r
4363 /** @brief Disable RCC interrupt(s).\r
4364   * @param  __INTERRUPT__ specifies the RCC interrupt source(s) to be disabled.\r
4365   *         This parameter can be any combination of the following values:\r
4366   *            @arg @ref RCC_IT_LSIRDY  LSI ready interrupt\r
4367   *            @arg @ref RCC_IT_LSERDY  LSE ready interrupt\r
4368   *            @arg @ref RCC_IT_MSIRDY  HSI ready interrupt\r
4369   *            @arg @ref RCC_IT_HSIRDY  HSI ready interrupt\r
4370   *            @arg @ref RCC_IT_HSERDY  HSE ready interrupt\r
4371   *            @arg @ref RCC_IT_PLLRDY  Main PLL ready interrupt\r
4372   *            @arg @ref RCC_IT_PLLSAI1RDY  PLLSAI1 ready interrupt for devices with PLLSAI1\r
4373   *            @arg @ref RCC_IT_PLLSAI2RDY  PLLSAI2 ready interrupt for devices with PLLSAI2\r
4374   *            @arg @ref RCC_IT_LSECSS  LSE Clock security system interrupt\r
4375   @if STM32L443xx\r
4376   *            @arg @ref RCC_IT_HSI48RDY  HSI48 ready interrupt for devices with HSI48\r
4377   @endif\r
4378   @if STM32L4A6xx\r
4379   *            @arg @ref RCC_IT_HSI48RDY  HSI48 ready interrupt for devices with HSI48\r
4380   @endif\r
4381   * @retval None\r
4382   */\r
4383 #define __HAL_RCC_DISABLE_IT(__INTERRUPT__) CLEAR_BIT(RCC->CIER, (__INTERRUPT__))\r
4384 \r
4385 /** @brief  Clear the RCC's interrupt pending bits.\r
4386   * @param  __INTERRUPT__ specifies the interrupt pending bit to clear.\r
4387   *         This parameter can be any combination of the following values:\r
4388   *            @arg @ref RCC_IT_LSIRDY  LSI ready interrupt\r
4389   *            @arg @ref RCC_IT_LSERDY  LSE ready interrupt\r
4390   *            @arg @ref RCC_IT_MSIRDY  MSI ready interrupt\r
4391   *            @arg @ref RCC_IT_HSIRDY  HSI ready interrupt\r
4392   *            @arg @ref RCC_IT_HSERDY  HSE ready interrupt\r
4393   *            @arg @ref RCC_IT_PLLRDY  Main PLL ready interrupt\r
4394   *            @arg @ref RCC_IT_PLLSAI1RDY  PLLSAI1 ready interrupt for devices with PLLSAI1\r
4395   *            @arg @ref RCC_IT_PLLSAI2RDY  PLLSAI2 ready interrupt for devices with PLLSAI2\r
4396   *            @arg @ref RCC_IT_CSS  HSE Clock security system interrupt\r
4397   *            @arg @ref RCC_IT_LSECSS  LSE Clock security system interrupt\r
4398   @if STM32L443xx\r
4399   *            @arg @ref RCC_IT_HSI48RDY  HSI48 ready interrupt for devices with HSI48\r
4400   @endif\r
4401   @if STM32L4A6xx\r
4402   *            @arg @ref RCC_IT_HSI48RDY  HSI48 ready interrupt for devices with HSI48\r
4403   @endif\r
4404   * @retval None\r
4405   */\r
4406 #define __HAL_RCC_CLEAR_IT(__INTERRUPT__) WRITE_REG(RCC->CICR, (__INTERRUPT__))\r
4407 \r
4408 /** @brief  Check whether the RCC interrupt has occurred or not.\r
4409   * @param  __INTERRUPT__ specifies the RCC interrupt source to check.\r
4410   *         This parameter can be one of the following values:\r
4411   *            @arg @ref RCC_IT_LSIRDY  LSI ready interrupt\r
4412   *            @arg @ref RCC_IT_LSERDY  LSE ready interrupt\r
4413   *            @arg @ref RCC_IT_MSIRDY  MSI ready interrupt\r
4414   *            @arg @ref RCC_IT_HSIRDY  HSI ready interrupt\r
4415   *            @arg @ref RCC_IT_HSERDY  HSE ready interrupt\r
4416   *            @arg @ref RCC_IT_PLLRDY  Main PLL ready interrupt\r
4417   *            @arg @ref RCC_IT_PLLSAI1RDY  PLLSAI1 ready interrupt for devices with PLLSAI1\r
4418   *            @arg @ref RCC_IT_PLLSAI2RDY  PLLSAI2 ready interrupt for devices with PLLSAI2\r
4419   *            @arg @ref RCC_IT_CSS  HSE Clock security system interrupt\r
4420   *            @arg @ref RCC_IT_LSECSS  LSE Clock security system interrupt\r
4421   @if STM32L443xx\r
4422   *            @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt for devices with HSI48\r
4423   @endif\r
4424   @if STM32L4A6xx\r
4425   *            @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt for devices with HSI48\r
4426   @endif\r
4427   * @retval The new state of __INTERRUPT__ (TRUE or FALSE).\r
4428   */\r
4429 #define __HAL_RCC_GET_IT(__INTERRUPT__) (READ_BIT(RCC->CIFR, (__INTERRUPT__)) == (__INTERRUPT__))\r
4430 \r
4431 /** @brief Set RMVF bit to clear the reset flags.\r
4432   *        The reset flags are: RCC_FLAG_FWRRST, RCC_FLAG_OBLRST, RCC_FLAG_PINRST, RCC_FLAG_BORRST,\r
4433   *        RCC_FLAG_SFTRST, RCC_FLAG_IWDGRST, RCC_FLAG_WWDGRST and RCC_FLAG_LPWRRST.\r
4434   * @retval None\r
4435  */\r
4436 #define __HAL_RCC_CLEAR_RESET_FLAGS() SET_BIT(RCC->CSR, RCC_CSR_RMVF)\r
4437 \r
4438 /** @brief  Check whether the selected RCC flag is set or not.\r
4439   * @param  __FLAG__ specifies the flag to check.\r
4440   *         This parameter can be one of the following values:\r
4441   *            @arg @ref RCC_FLAG_MSIRDY  MSI oscillator clock ready\r
4442   *            @arg @ref RCC_FLAG_HSIRDY  HSI oscillator clock ready\r
4443   *            @arg @ref RCC_FLAG_HSERDY  HSE oscillator clock ready\r
4444   *            @arg @ref RCC_FLAG_PLLRDY  Main PLL clock ready\r
4445   *            @arg @ref RCC_FLAG_PLLSAI1RDY  PLLSAI1 clock ready for devices with PLLSAI1\r
4446   *            @arg @ref RCC_FLAG_PLLSAI2RDY  PLLSAI2 clock ready for devices with PLLSAI2\r
4447   @if STM32L443xx\r
4448   *            @arg @ref RCC_FLAG_HSI48RDY  HSI48 clock ready for devices with HSI48\r
4449   @endif\r
4450   @if STM32L4A6xx\r
4451   *            @arg @ref RCC_FLAG_HSI48RDY  HSI48 clock ready for devices with HSI48\r
4452   @endif\r
4453   *            @arg @ref RCC_FLAG_LSERDY  LSE oscillator clock ready\r
4454   *            @arg @ref RCC_FLAG_LSECSSD  Clock security system failure on LSE oscillator detection\r
4455   *            @arg @ref RCC_FLAG_LSIRDY  LSI oscillator clock ready\r
4456   *            @arg @ref RCC_FLAG_BORRST  BOR reset\r
4457   *            @arg @ref RCC_FLAG_OBLRST  OBLRST reset\r
4458   *            @arg @ref RCC_FLAG_PINRST  Pin reset\r
4459   *            @arg @ref RCC_FLAG_FWRST  FIREWALL reset\r
4460   *            @arg @ref RCC_FLAG_SFTRST  Software reset\r
4461   *            @arg @ref RCC_FLAG_IWDGRST  Independent Watchdog reset\r
4462   *            @arg @ref RCC_FLAG_WWDGRST  Window Watchdog reset\r
4463   *            @arg @ref RCC_FLAG_LPWRRST  Low Power reset\r
4464   * @retval The new state of __FLAG__ (TRUE or FALSE).\r
4465   */\r
4466 #if defined(RCC_HSI48_SUPPORT)\r
4467 #define __HAL_RCC_GET_FLAG(__FLAG__) (((((((__FLAG__) >> 5U) == 1U) ? RCC->CR :                    \\r
4468                                         ((((__FLAG__) >> 5U) == 4U) ? RCC->CRRCR :                 \\r
4469                                         ((((__FLAG__) >> 5U) == 2U) ? RCC->BDCR :                  \\r
4470                                         ((((__FLAG__) >> 5U) == 3U) ? RCC->CSR : RCC->CIFR)))) &   \\r
4471                                           (1U << ((__FLAG__) & RCC_FLAG_MASK))) != 0U) ? 1U : 0U)\r
4472 #else\r
4473 #define __HAL_RCC_GET_FLAG(__FLAG__) (((((((__FLAG__) >> 5U) == 1U) ? RCC->CR :                    \\r
4474                                         ((((__FLAG__) >> 5U) == 2U) ? RCC->BDCR :                  \\r
4475                                         ((((__FLAG__) >> 5U) == 3U) ? RCC->CSR : RCC->CIFR))) &    \\r
4476                                           (1U << ((__FLAG__) & RCC_FLAG_MASK))) != 0U) ? 1U : 0U)\r
4477 #endif /* RCC_HSI48_SUPPORT */\r
4478 \r
4479 /**\r
4480   * @}\r
4481   */\r
4482 \r
4483 /**\r
4484   * @}\r
4485   */\r
4486 \r
4487 /* Private constants ---------------------------------------------------------*/\r
4488 /** @defgroup RCC_Private_Constants RCC Private Constants\r
4489   * @{\r
4490   */\r
4491 /* Defines used for Flags */\r
4492 #define CR_REG_INDEX              1U\r
4493 #define BDCR_REG_INDEX            2U\r
4494 #define CSR_REG_INDEX             3U\r
4495 #if defined(RCC_HSI48_SUPPORT)\r
4496 #define CRRCR_REG_INDEX           4U\r
4497 #endif /* RCC_HSI48_SUPPORT */\r
4498 \r
4499 #define RCC_FLAG_MASK             0x1FU\r
4500 /**\r
4501   * @}\r
4502   */\r
4503 \r
4504 /* Private macros ------------------------------------------------------------*/\r
4505 /** @addtogroup RCC_Private_Macros\r
4506   * @{\r
4507   */\r
4508 \r
4509 #if defined(RCC_HSI48_SUPPORT)\r
4510 #define IS_RCC_OSCILLATORTYPE(__OSCILLATOR__) (((__OSCILLATOR__) == RCC_OSCILLATORTYPE_NONE)                               || \\r
4511                                                (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_HSE)   == RCC_OSCILLATORTYPE_HSE)   || \\r
4512                                                (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_HSI)   == RCC_OSCILLATORTYPE_HSI)   || \\r
4513                                                (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_HSI48) == RCC_OSCILLATORTYPE_HSI48) || \\r
4514                                                (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_MSI)   == RCC_OSCILLATORTYPE_MSI)   || \\r
4515                                                (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_LSI)   == RCC_OSCILLATORTYPE_LSI)   || \\r
4516                                                (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_LSE)   == RCC_OSCILLATORTYPE_LSE))\r
4517 #else\r
4518 #define IS_RCC_OSCILLATORTYPE(__OSCILLATOR__) (((__OSCILLATOR__) == RCC_OSCILLATORTYPE_NONE)                           || \\r
4519                                                (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_HSE) == RCC_OSCILLATORTYPE_HSE) || \\r
4520                                                (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_HSI) == RCC_OSCILLATORTYPE_HSI) || \\r
4521                                                (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_MSI) == RCC_OSCILLATORTYPE_MSI) || \\r
4522                                                (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_LSI) == RCC_OSCILLATORTYPE_LSI) || \\r
4523                                                (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_LSE) == RCC_OSCILLATORTYPE_LSE))\r
4524 #endif /* RCC_HSI48_SUPPORT */\r
4525 \r
4526 #define IS_RCC_HSE(__HSE__)  (((__HSE__) == RCC_HSE_OFF) || ((__HSE__) == RCC_HSE_ON) || \\r
4527                               ((__HSE__) == RCC_HSE_BYPASS))\r
4528 \r
4529 #if defined(RCC_BDCR_LSESYSDIS)\r
4530 #define IS_RCC_LSE(__LSE__)  (((__LSE__) == RCC_LSE_OFF) || ((__LSE__) == RCC_LSE_ON) || ((__LSE__) == RCC_LSE_BYPASS_RTC_ONLY) || \\r
4531                               ((__LSE__) == RCC_LSE_ON_RTC_ONLY) || ((__LSE__) == RCC_LSE_BYPASS))\r
4532 #else\r
4533 #define IS_RCC_LSE(__LSE__)  (((__LSE__) == RCC_LSE_OFF) || ((__LSE__) == RCC_LSE_ON) || \\r
4534                               ((__LSE__) == RCC_LSE_BYPASS))\r
4535 #endif /* RCC_BDCR_LSESYSDIS */\r
4536 \r
4537 #define IS_RCC_HSI(__HSI__)  (((__HSI__) == RCC_HSI_OFF) || ((__HSI__) == RCC_HSI_ON))\r
4538 \r
4539 #define IS_RCC_HSI_CALIBRATION_VALUE(__VALUE__) ((__VALUE__) <= (RCC_ICSCR_HSITRIM >> RCC_ICSCR_HSITRIM_Pos))\r
4540 \r
4541 #define IS_RCC_LSI(__LSI__)  (((__LSI__) == RCC_LSI_OFF) || ((__LSI__) == RCC_LSI_ON))\r
4542 \r
4543 #if defined(RCC_CSR_LSIPREDIV)\r
4544 #define IS_RCC_LSIDIV(__LSIDIV__)  (((__LSIDIV__) == RCC_LSI_DIV1) || ((__LSIDIV__) == RCC_LSI_DIV128))\r
4545 #endif /* RCC_CSR_LSIPREDIV */\r
4546 \r
4547 #define IS_RCC_MSI(__MSI__)  (((__MSI__) == RCC_MSI_OFF) || ((__MSI__) == RCC_MSI_ON))\r
4548 \r
4549 #define IS_RCC_MSICALIBRATION_VALUE(__VALUE__) ((__VALUE__) <= 255U)\r
4550 \r
4551 #if defined(RCC_HSI48_SUPPORT)\r
4552 #define IS_RCC_HSI48(__HSI48__)  (((__HSI48__) == RCC_HSI48_OFF) || ((__HSI48__) == RCC_HSI48_ON))\r
4553 #endif /* RCC_HSI48_SUPPORT */\r
4554 \r
4555 #define IS_RCC_PLL(__PLL__) (((__PLL__) == RCC_PLL_NONE) ||((__PLL__) == RCC_PLL_OFF) || \\r
4556                              ((__PLL__) == RCC_PLL_ON))\r
4557 \r
4558 #define IS_RCC_PLLSOURCE(__SOURCE__) (((__SOURCE__) == RCC_PLLSOURCE_NONE) || \\r
4559                                       ((__SOURCE__) == RCC_PLLSOURCE_MSI)  || \\r
4560                                       ((__SOURCE__) == RCC_PLLSOURCE_HSI)  || \\r
4561                                       ((__SOURCE__) == RCC_PLLSOURCE_HSE))\r
4562 \r
4563 #if defined(RCC_PLLM_DIV_1_16_SUPPORT)\r
4564 #define IS_RCC_PLLM_VALUE(__VALUE__) ((1U <= (__VALUE__)) && ((__VALUE__) <= 16U))\r
4565 #else\r
4566 #define IS_RCC_PLLM_VALUE(__VALUE__) ((1U <= (__VALUE__)) && ((__VALUE__) <= 8U))\r
4567 #endif /*RCC_PLLM_DIV_1_16_SUPPORT */\r
4568 \r
4569 #define IS_RCC_PLLN_VALUE(__VALUE__) ((8U <= (__VALUE__)) && ((__VALUE__) <= 86U))\r
4570 \r
4571 #if defined(RCC_PLLP_DIV_2_31_SUPPORT)\r
4572 #define IS_RCC_PLLP_VALUE(__VALUE__) (((__VALUE__) >= 2U) && ((__VALUE__) <= 31U))\r
4573 #else\r
4574 #define IS_RCC_PLLP_VALUE(__VALUE__) (((__VALUE__) == 7U) || ((__VALUE__) == 17U))\r
4575 #endif /*RCC_PLLP_DIV_2_31_SUPPORT */\r
4576 \r
4577 #define IS_RCC_PLLQ_VALUE(__VALUE__) (((__VALUE__) == 2U) || ((__VALUE__) == 4U) || \\r
4578                                       ((__VALUE__) == 6U) || ((__VALUE__) == 8U))\r
4579 \r
4580 #define IS_RCC_PLLR_VALUE(__VALUE__) (((__VALUE__) == 2U) || ((__VALUE__) == 4U) || \\r
4581                                       ((__VALUE__) == 6U) || ((__VALUE__) == 8U))\r
4582 \r
4583 #if defined(RCC_PLLSAI1_SUPPORT)\r
4584 #define IS_RCC_PLLSAI1CLOCKOUT_VALUE(__VALUE__) (((((__VALUE__) & RCC_PLLSAI1_SAI1CLK) == RCC_PLLSAI1_SAI1CLK)  || \\r
4585                                                   (((__VALUE__) & RCC_PLLSAI1_48M2CLK) == RCC_PLLSAI1_48M2CLK)  || \\r
4586                                                   (((__VALUE__) & RCC_PLLSAI1_ADC1CLK) == RCC_PLLSAI1_ADC1CLK)) && \\r
4587                                                  (((__VALUE__) & ~(RCC_PLLSAI1_SAI1CLK|RCC_PLLSAI1_48M2CLK|RCC_PLLSAI1_ADC1CLK)) == 0U))\r
4588 #endif /* RCC_PLLSAI1_SUPPORT */\r
4589 \r
4590 #if defined(RCC_PLLSAI2_SUPPORT)\r
4591 #if defined(STM32L471xx) || defined(STM32L475xx) || defined(STM32L476xx) || defined(STM32L485xx) || defined(STM32L486xx) || defined(STM32L496xx) || defined(STM32L4A6xx)\r
4592 #define IS_RCC_PLLSAI2CLOCKOUT_VALUE(__VALUE__) (((((__VALUE__) & RCC_PLLSAI2_SAI2CLK) == RCC_PLLSAI2_SAI2CLK)  || \\r
4593                                                   (((__VALUE__) & RCC_PLLSAI2_ADC2CLK) == RCC_PLLSAI2_ADC2CLK)) && \\r
4594                                                  (((__VALUE__) & ~(RCC_PLLSAI2_SAI2CLK|RCC_PLLSAI2_ADC2CLK)) == 0U))\r
4595 #elif defined(STM32L4R5xx) || defined(STM32L4R7xx) || defined(STM32L4R9xx) || defined(STM32L4S5xx) || defined(STM32L4S7xx) || defined(STM32L4S9xx)\r
4596 #define IS_RCC_PLLSAI2CLOCKOUT_VALUE(__VALUE__) (((((__VALUE__) & RCC_PLLSAI2_SAI2CLK) == RCC_PLLSAI2_SAI2CLK)  || \\r
4597                                                   (((__VALUE__) & RCC_PLLSAI2_DSICLK)  == RCC_PLLSAI2_DSICLK)   || \\r
4598                                                   (((__VALUE__) & RCC_PLLSAI2_LTDCCLK) == RCC_PLLSAI2_LTDCCLK)) && \\r
4599                                                  (((__VALUE__) & ~(RCC_PLLSAI2_SAI2CLK|RCC_PLLSAI2_DSICLK|RCC_PLLSAI2_LTDCCLK)) == 0U))\r
4600 #endif /* STM32L471xx || STM32L475xx || STM32L476xx || STM32L485xx || STM32L486xx || STM32L496xx || STM32L4A6xx */\r
4601 #endif /* RCC_PLLSAI2_SUPPORT */\r
4602 \r
4603 #define IS_RCC_MSI_CLOCK_RANGE(__RANGE__) (((__RANGE__) == RCC_MSIRANGE_0)  || \\r
4604                                            ((__RANGE__) == RCC_MSIRANGE_1)  || \\r
4605                                            ((__RANGE__) == RCC_MSIRANGE_2)  || \\r
4606                                            ((__RANGE__) == RCC_MSIRANGE_3)  || \\r
4607                                            ((__RANGE__) == RCC_MSIRANGE_4)  || \\r
4608                                            ((__RANGE__) == RCC_MSIRANGE_5)  || \\r
4609                                            ((__RANGE__) == RCC_MSIRANGE_6)  || \\r
4610                                            ((__RANGE__) == RCC_MSIRANGE_7)  || \\r
4611                                            ((__RANGE__) == RCC_MSIRANGE_8)  || \\r
4612                                            ((__RANGE__) == RCC_MSIRANGE_9)  || \\r
4613                                            ((__RANGE__) == RCC_MSIRANGE_10) || \\r
4614                                            ((__RANGE__) == RCC_MSIRANGE_11))\r
4615 \r
4616 #define IS_RCC_MSI_STANDBY_CLOCK_RANGE(__RANGE__) (((__RANGE__) == RCC_MSIRANGE_4)  || \\r
4617                                                    ((__RANGE__) == RCC_MSIRANGE_5)  || \\r
4618                                                    ((__RANGE__) == RCC_MSIRANGE_6)  || \\r
4619                                                    ((__RANGE__) == RCC_MSIRANGE_7))\r
4620 \r
4621 #define IS_RCC_CLOCKTYPE(__CLK__)  ((1U <= (__CLK__)) && ((__CLK__) <= 15U))\r
4622 \r
4623 #define IS_RCC_SYSCLKSOURCE(__SOURCE__) (((__SOURCE__) == RCC_SYSCLKSOURCE_MSI) || \\r
4624                                          ((__SOURCE__) == RCC_SYSCLKSOURCE_HSI) || \\r
4625                                          ((__SOURCE__) == RCC_SYSCLKSOURCE_HSE) || \\r
4626                                          ((__SOURCE__) == RCC_SYSCLKSOURCE_PLLCLK))\r
4627 \r
4628 #define IS_RCC_HCLK(__HCLK__) (((__HCLK__) == RCC_SYSCLK_DIV1)   || ((__HCLK__) == RCC_SYSCLK_DIV2)   || \\r
4629                                ((__HCLK__) == RCC_SYSCLK_DIV4)   || ((__HCLK__) == RCC_SYSCLK_DIV8)   || \\r
4630                                ((__HCLK__) == RCC_SYSCLK_DIV16)  || ((__HCLK__) == RCC_SYSCLK_DIV64)  || \\r
4631                                ((__HCLK__) == RCC_SYSCLK_DIV128) || ((__HCLK__) == RCC_SYSCLK_DIV256) || \\r
4632                                ((__HCLK__) == RCC_SYSCLK_DIV512))\r
4633 \r
4634 #define IS_RCC_PCLK(__PCLK__) (((__PCLK__) == RCC_HCLK_DIV1) || ((__PCLK__) == RCC_HCLK_DIV2) || \\r
4635                                ((__PCLK__) == RCC_HCLK_DIV4) || ((__PCLK__) == RCC_HCLK_DIV8) || \\r
4636                                ((__PCLK__) == RCC_HCLK_DIV16))\r
4637 \r
4638 #define IS_RCC_RTCCLKSOURCE(__SOURCE__) (((__SOURCE__) == RCC_RTCCLKSOURCE_NONE)   || \\r
4639                                          ((__SOURCE__) == RCC_RTCCLKSOURCE_LSE)    || \\r
4640                                          ((__SOURCE__) == RCC_RTCCLKSOURCE_LSI)    || \\r
4641                                          ((__SOURCE__) == RCC_RTCCLKSOURCE_HSE_DIV32))\r
4642 \r
4643 #define IS_RCC_MCO(__MCOX__) ((__MCOX__) == RCC_MCO1)\r
4644 \r
4645 #if defined(RCC_HSI48_SUPPORT)\r
4646 #define IS_RCC_MCO1SOURCE(__SOURCE__) (((__SOURCE__) == RCC_MCO1SOURCE_NOCLOCK) || \\r
4647                                        ((__SOURCE__) == RCC_MCO1SOURCE_SYSCLK) || \\r
4648                                        ((__SOURCE__) == RCC_MCO1SOURCE_MSI) || \\r
4649                                        ((__SOURCE__) == RCC_MCO1SOURCE_HSI) || \\r
4650                                        ((__SOURCE__) == RCC_MCO1SOURCE_HSE) || \\r
4651                                        ((__SOURCE__) == RCC_MCO1SOURCE_PLLCLK) || \\r
4652                                        ((__SOURCE__) == RCC_MCO1SOURCE_LSI) || \\r
4653                                        ((__SOURCE__) == RCC_MCO1SOURCE_LSE) || \\r
4654                                        ((__SOURCE__) == RCC_MCO1SOURCE_HSI48))\r
4655 #else\r
4656 #define IS_RCC_MCO1SOURCE(__SOURCE__) (((__SOURCE__) == RCC_MCO1SOURCE_NOCLOCK) || \\r
4657                                        ((__SOURCE__) == RCC_MCO1SOURCE_SYSCLK) || \\r
4658                                        ((__SOURCE__) == RCC_MCO1SOURCE_MSI) || \\r
4659                                        ((__SOURCE__) == RCC_MCO1SOURCE_HSI) || \\r
4660                                        ((__SOURCE__) == RCC_MCO1SOURCE_HSE) || \\r
4661                                        ((__SOURCE__) == RCC_MCO1SOURCE_PLLCLK) || \\r
4662                                        ((__SOURCE__) == RCC_MCO1SOURCE_LSI) || \\r
4663                                        ((__SOURCE__) == RCC_MCO1SOURCE_LSE))\r
4664 #endif /* RCC_HSI48_SUPPORT */\r
4665 \r
4666 #define IS_RCC_MCODIV(__DIV__) (((__DIV__) == RCC_MCODIV_1) || ((__DIV__) == RCC_MCODIV_2) || \\r
4667                                 ((__DIV__) == RCC_MCODIV_4) || ((__DIV__) == RCC_MCODIV_8) || \\r
4668                                 ((__DIV__) == RCC_MCODIV_16))\r
4669 \r
4670 #define IS_RCC_LSE_DRIVE(__DRIVE__) (((__DRIVE__) == RCC_LSEDRIVE_LOW)        || \\r
4671                                      ((__DRIVE__) == RCC_LSEDRIVE_MEDIUMLOW)  || \\r
4672                                      ((__DRIVE__) == RCC_LSEDRIVE_MEDIUMHIGH) || \\r
4673                                      ((__DRIVE__) == RCC_LSEDRIVE_HIGH))\r
4674 \r
4675 #define IS_RCC_STOP_WAKEUPCLOCK(__SOURCE__) (((__SOURCE__) == RCC_STOP_WAKEUPCLOCK_MSI) || \\r
4676                                              ((__SOURCE__) == RCC_STOP_WAKEUPCLOCK_HSI))\r
4677 /**\r
4678   * @}\r
4679   */\r
4680 \r
4681 /* Include RCC HAL Extended module */\r
4682 #include "stm32l4xx_hal_rcc_ex.h"\r
4683 \r
4684 /* Exported functions --------------------------------------------------------*/\r
4685 /** @addtogroup RCC_Exported_Functions\r
4686   * @{\r
4687   */\r
4688 \r
4689 \r
4690 /** @addtogroup RCC_Exported_Functions_Group1\r
4691   * @{\r
4692   */\r
4693 \r
4694 /* Initialization and de-initialization functions  ******************************/\r
4695 HAL_StatusTypeDef HAL_RCC_DeInit(void);\r
4696 HAL_StatusTypeDef HAL_RCC_OscConfig(RCC_OscInitTypeDef *RCC_OscInitStruct);\r
4697 HAL_StatusTypeDef HAL_RCC_ClockConfig(RCC_ClkInitTypeDef *RCC_ClkInitStruct, uint32_t FLatency);\r
4698 \r
4699 /**\r
4700   * @}\r
4701   */\r
4702 \r
4703 /** @addtogroup RCC_Exported_Functions_Group2\r
4704   * @{\r
4705   */\r
4706 \r
4707 /* Peripheral Control functions  ************************************************/\r
4708 void              HAL_RCC_MCOConfig(uint32_t RCC_MCOx, uint32_t RCC_MCOSource, uint32_t RCC_MCODiv);\r
4709 void              HAL_RCC_EnableCSS(void);\r
4710 uint32_t          HAL_RCC_GetSysClockFreq(void);\r
4711 uint32_t          HAL_RCC_GetHCLKFreq(void);\r
4712 uint32_t          HAL_RCC_GetPCLK1Freq(void);\r
4713 uint32_t          HAL_RCC_GetPCLK2Freq(void);\r
4714 void              HAL_RCC_GetOscConfig(RCC_OscInitTypeDef *RCC_OscInitStruct);\r
4715 void              HAL_RCC_GetClockConfig(RCC_ClkInitTypeDef *RCC_ClkInitStruct, uint32_t *pFLatency);\r
4716 /* CSS NMI IRQ handler */\r
4717 void              HAL_RCC_NMI_IRQHandler(void);\r
4718 /* User Callbacks in non blocking mode (IT mode) */\r
4719 void              HAL_RCC_CSSCallback(void);\r
4720 \r
4721 /**\r
4722   * @}\r
4723   */\r
4724 \r
4725 /**\r
4726   * @}\r
4727   */\r
4728 \r
4729 /**\r
4730   * @}\r
4731   */\r
4732 \r
4733 /**\r
4734   * @}\r
4735   */\r
4736 \r
4737 #ifdef __cplusplus\r
4738 }\r
4739 #endif\r
4740 \r
4741 #endif /* __STM32L4xx_HAL_RCC_H */\r
4742 \r
4743 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/\r