1 /** 2 ****************************************************************************** 3 * @file stm32f1xx_hal_rcc.h 4 * @author MCD Application Team 5 * @brief Header file of RCC HAL module. 6 ****************************************************************************** 7 * @attention 8 * 9 * Copyright (c) 2016 STMicroelectronics. 10 * All rights reserved. 11 * 12 * This software is licensed under terms that can be found in the LICENSE file in 13 * the root directory of this software component. 14 * If no LICENSE file comes with this software, it is provided AS-IS. 15 ****************************************************************************** 16 */ 17 18 /* Define to prevent recursive inclusion -------------------------------------*/ 19 #ifndef __STM32F1xx_HAL_RCC_H 20 #define __STM32F1xx_HAL_RCC_H 21 22 #ifdef __cplusplus 23 extern "C" { 24 #endif 25 26 /* Includes ------------------------------------------------------------------*/ 27 #include "stm32f1xx_hal_def.h" 28 29 30 /** @addtogroup STM32F1xx_HAL_Driver 31 * @{ 32 */ 33 34 /** @addtogroup RCC 35 * @{ 36 */ 37 38 /* Exported types ------------------------------------------------------------*/ 39 40 /** @defgroup RCC_Exported_Types RCC Exported Types 41 * @{ 42 */ 43 44 /** 45 * @brief RCC PLL configuration structure definition 46 */ 47 typedef struct 48 { 49 uint32_t PLLState; /*!< PLLState: The new state of the PLL. 50 This parameter can be a value of @ref RCC_PLL_Config */ 51 52 uint32_t PLLSource; /*!< PLLSource: PLL entry clock source. 53 This parameter must be a value of @ref RCC_PLL_Clock_Source */ 54 55 uint32_t PLLMUL; /*!< PLLMUL: Multiplication factor for PLL VCO input clock 56 This parameter must be a value of @ref RCCEx_PLL_Multiplication_Factor */ 57 } RCC_PLLInitTypeDef; 58 59 /** 60 * @brief RCC System, AHB and APB busses clock configuration structure definition 61 */ 62 typedef struct 63 { 64 uint32_t ClockType; /*!< The clock to be configured. 65 This parameter can be a value of @ref RCC_System_Clock_Type */ 66 67 uint32_t SYSCLKSource; /*!< The clock source (SYSCLKS) used as system clock. 68 This parameter can be a value of @ref RCC_System_Clock_Source */ 69 70 uint32_t AHBCLKDivider; /*!< The AHB clock (HCLK) divider. This clock is derived from the system clock (SYSCLK). 71 This parameter can be a value of @ref RCC_AHB_Clock_Source */ 72 73 uint32_t APB1CLKDivider; /*!< The APB1 clock (PCLK1) divider. This clock is derived from the AHB clock (HCLK). 74 This parameter can be a value of @ref RCC_APB1_APB2_Clock_Source */ 75 76 uint32_t APB2CLKDivider; /*!< The APB2 clock (PCLK2) divider. This clock is derived from the AHB clock (HCLK). 77 This parameter can be a value of @ref RCC_APB1_APB2_Clock_Source */ 78 } RCC_ClkInitTypeDef; 79 80 /** 81 * @} 82 */ 83 84 /* Exported constants --------------------------------------------------------*/ 85 /** @defgroup RCC_Exported_Constants RCC Exported Constants 86 * @{ 87 */ 88 89 /** @defgroup RCC_PLL_Clock_Source PLL Clock Source 90 * @{ 91 */ 92 93 #define RCC_PLLSOURCE_HSI_DIV2 0x00000000U /*!< HSI clock divided by 2 selected as PLL entry clock source */ 94 #define RCC_PLLSOURCE_HSE RCC_CFGR_PLLSRC /*!< HSE clock selected as PLL entry clock source */ 95 96 /** 97 * @} 98 */ 99 100 /** @defgroup RCC_Oscillator_Type Oscillator Type 101 * @{ 102 */ 103 #define RCC_OSCILLATORTYPE_NONE 0x00000000U 104 #define RCC_OSCILLATORTYPE_HSE 0x00000001U 105 #define RCC_OSCILLATORTYPE_HSI 0x00000002U 106 #define RCC_OSCILLATORTYPE_LSE 0x00000004U 107 #define RCC_OSCILLATORTYPE_LSI 0x00000008U 108 /** 109 * @} 110 */ 111 112 /** @defgroup RCC_HSE_Config HSE Config 113 * @{ 114 */ 115 #define RCC_HSE_OFF 0x00000000U /*!< HSE clock deactivation */ 116 #define RCC_HSE_ON RCC_CR_HSEON /*!< HSE clock activation */ 117 #define RCC_HSE_BYPASS ((uint32_t)(RCC_CR_HSEBYP | RCC_CR_HSEON)) /*!< External clock source for HSE clock */ 118 /** 119 * @} 120 */ 121 122 /** @defgroup RCC_LSE_Config LSE Config 123 * @{ 124 */ 125 #define RCC_LSE_OFF 0x00000000U /*!< LSE clock deactivation */ 126 #define RCC_LSE_ON RCC_BDCR_LSEON /*!< LSE clock activation */ 127 #define RCC_LSE_BYPASS ((uint32_t)(RCC_BDCR_LSEBYP | RCC_BDCR_LSEON)) /*!< External clock source for LSE clock */ 128 129 /** 130 * @} 131 */ 132 133 /** @defgroup RCC_HSI_Config HSI Config 134 * @{ 135 */ 136 #define RCC_HSI_OFF 0x00000000U /*!< HSI clock deactivation */ 137 #define RCC_HSI_ON RCC_CR_HSION /*!< HSI clock activation */ 138 139 #define RCC_HSICALIBRATION_DEFAULT 0x10U /* Default HSI calibration trimming value */ 140 141 /** 142 * @} 143 */ 144 145 /** @defgroup RCC_LSI_Config LSI Config 146 * @{ 147 */ 148 #define RCC_LSI_OFF 0x00000000U /*!< LSI clock deactivation */ 149 #define RCC_LSI_ON RCC_CSR_LSION /*!< LSI clock activation */ 150 151 /** 152 * @} 153 */ 154 155 /** @defgroup RCC_PLL_Config PLL Config 156 * @{ 157 */ 158 #define RCC_PLL_NONE 0x00000000U /*!< PLL is not configured */ 159 #define RCC_PLL_OFF 0x00000001U /*!< PLL deactivation */ 160 #define RCC_PLL_ON 0x00000002U /*!< PLL activation */ 161 162 /** 163 * @} 164 */ 165 166 /** @defgroup RCC_System_Clock_Type System Clock Type 167 * @{ 168 */ 169 #define RCC_CLOCKTYPE_SYSCLK 0x00000001U /*!< SYSCLK to configure */ 170 #define RCC_CLOCKTYPE_HCLK 0x00000002U /*!< HCLK to configure */ 171 #define RCC_CLOCKTYPE_PCLK1 0x00000004U /*!< PCLK1 to configure */ 172 #define RCC_CLOCKTYPE_PCLK2 0x00000008U /*!< PCLK2 to configure */ 173 174 /** 175 * @} 176 */ 177 178 /** @defgroup RCC_System_Clock_Source System Clock Source 179 * @{ 180 */ 181 #define RCC_SYSCLKSOURCE_HSI RCC_CFGR_SW_HSI /*!< HSI selected as system clock */ 182 #define RCC_SYSCLKSOURCE_HSE RCC_CFGR_SW_HSE /*!< HSE selected as system clock */ 183 #define RCC_SYSCLKSOURCE_PLLCLK RCC_CFGR_SW_PLL /*!< PLL selected as system clock */ 184 185 /** 186 * @} 187 */ 188 189 /** @defgroup RCC_System_Clock_Source_Status System Clock Source Status 190 * @{ 191 */ 192 #define RCC_SYSCLKSOURCE_STATUS_HSI RCC_CFGR_SWS_HSI /*!< HSI used as system clock */ 193 #define RCC_SYSCLKSOURCE_STATUS_HSE RCC_CFGR_SWS_HSE /*!< HSE used as system clock */ 194 #define RCC_SYSCLKSOURCE_STATUS_PLLCLK RCC_CFGR_SWS_PLL /*!< PLL used as system clock */ 195 196 /** 197 * @} 198 */ 199 200 /** @defgroup RCC_AHB_Clock_Source AHB Clock Source 201 * @{ 202 */ 203 #define RCC_SYSCLK_DIV1 RCC_CFGR_HPRE_DIV1 /*!< SYSCLK not divided */ 204 #define RCC_SYSCLK_DIV2 RCC_CFGR_HPRE_DIV2 /*!< SYSCLK divided by 2 */ 205 #define RCC_SYSCLK_DIV4 RCC_CFGR_HPRE_DIV4 /*!< SYSCLK divided by 4 */ 206 #define RCC_SYSCLK_DIV8 RCC_CFGR_HPRE_DIV8 /*!< SYSCLK divided by 8 */ 207 #define RCC_SYSCLK_DIV16 RCC_CFGR_HPRE_DIV16 /*!< SYSCLK divided by 16 */ 208 #define RCC_SYSCLK_DIV64 RCC_CFGR_HPRE_DIV64 /*!< SYSCLK divided by 64 */ 209 #define RCC_SYSCLK_DIV128 RCC_CFGR_HPRE_DIV128 /*!< SYSCLK divided by 128 */ 210 #define RCC_SYSCLK_DIV256 RCC_CFGR_HPRE_DIV256 /*!< SYSCLK divided by 256 */ 211 #define RCC_SYSCLK_DIV512 RCC_CFGR_HPRE_DIV512 /*!< SYSCLK divided by 512 */ 212 213 /** 214 * @} 215 */ 216 217 /** @defgroup RCC_APB1_APB2_Clock_Source APB1 APB2 Clock Source 218 * @{ 219 */ 220 #define RCC_HCLK_DIV1 RCC_CFGR_PPRE1_DIV1 /*!< HCLK not divided */ 221 #define RCC_HCLK_DIV2 RCC_CFGR_PPRE1_DIV2 /*!< HCLK divided by 2 */ 222 #define RCC_HCLK_DIV4 RCC_CFGR_PPRE1_DIV4 /*!< HCLK divided by 4 */ 223 #define RCC_HCLK_DIV8 RCC_CFGR_PPRE1_DIV8 /*!< HCLK divided by 8 */ 224 #define RCC_HCLK_DIV16 RCC_CFGR_PPRE1_DIV16 /*!< HCLK divided by 16 */ 225 226 /** 227 * @} 228 */ 229 230 /** @defgroup RCC_RTC_Clock_Source RTC Clock Source 231 * @{ 232 */ 233 #define RCC_RTCCLKSOURCE_NO_CLK 0x00000000U /*!< No clock */ 234 #define RCC_RTCCLKSOURCE_LSE RCC_BDCR_RTCSEL_LSE /*!< LSE oscillator clock used as RTC clock */ 235 #define RCC_RTCCLKSOURCE_LSI RCC_BDCR_RTCSEL_LSI /*!< LSI oscillator clock used as RTC clock */ 236 #define RCC_RTCCLKSOURCE_HSE_DIV128 RCC_BDCR_RTCSEL_HSE /*!< HSE oscillator clock divided by 128 used as RTC clock */ 237 /** 238 * @} 239 */ 240 241 242 /** @defgroup RCC_MCO_Index MCO Index 243 * @{ 244 */ 245 #define RCC_MCO1 0x00000000U 246 #define RCC_MCO RCC_MCO1 /*!< MCO1 to be compliant with other families with 2 MCOs*/ 247 248 /** 249 * @} 250 */ 251 252 /** @defgroup RCC_MCOx_Clock_Prescaler MCO Clock Prescaler 253 * @{ 254 */ 255 #define RCC_MCODIV_1 0x00000000U 256 257 /** 258 * @} 259 */ 260 261 /** @defgroup RCC_Interrupt Interrupts 262 * @{ 263 */ 264 #define RCC_IT_LSIRDY ((uint8_t)RCC_CIR_LSIRDYF) /*!< LSI Ready Interrupt flag */ 265 #define RCC_IT_LSERDY ((uint8_t)RCC_CIR_LSERDYF) /*!< LSE Ready Interrupt flag */ 266 #define RCC_IT_HSIRDY ((uint8_t)RCC_CIR_HSIRDYF) /*!< HSI Ready Interrupt flag */ 267 #define RCC_IT_HSERDY ((uint8_t)RCC_CIR_HSERDYF) /*!< HSE Ready Interrupt flag */ 268 #define RCC_IT_PLLRDY ((uint8_t)RCC_CIR_PLLRDYF) /*!< PLL Ready Interrupt flag */ 269 #define RCC_IT_CSS ((uint8_t)RCC_CIR_CSSF) /*!< Clock Security System Interrupt flag */ 270 /** 271 * @} 272 */ 273 274 /** @defgroup RCC_Flag Flags 275 * Elements values convention: XXXYYYYYb 276 * - YYYYY : Flag position in the register 277 * - XXX : Register index 278 * - 001: CR register 279 * - 010: BDCR register 280 * - 011: CSR register 281 * @{ 282 */ 283 /* Flags in the CR register */ 284 #define RCC_FLAG_HSIRDY ((uint8_t)((CR_REG_INDEX << 5U) | RCC_CR_HSIRDY_Pos)) /*!< Internal High Speed clock ready flag */ 285 #define RCC_FLAG_HSERDY ((uint8_t)((CR_REG_INDEX << 5U) | RCC_CR_HSERDY_Pos)) /*!< External High Speed clock ready flag */ 286 #define RCC_FLAG_PLLRDY ((uint8_t)((CR_REG_INDEX << 5U) | RCC_CR_PLLRDY_Pos)) /*!< PLL clock ready flag */ 287 288 /* Flags in the CSR register */ 289 #define RCC_FLAG_LSIRDY ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_LSIRDY_Pos)) /*!< Internal Low Speed oscillator Ready */ 290 #define RCC_FLAG_PINRST ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_PINRSTF_Pos)) /*!< PIN reset flag */ 291 #define RCC_FLAG_PORRST ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_PORRSTF_Pos)) /*!< POR/PDR reset flag */ 292 #define RCC_FLAG_SFTRST ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_SFTRSTF_Pos)) /*!< Software Reset flag */ 293 #define RCC_FLAG_IWDGRST ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_IWDGRSTF_Pos)) /*!< Independent Watchdog reset flag */ 294 #define RCC_FLAG_WWDGRST ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_WWDGRSTF_Pos)) /*!< Window watchdog reset flag */ 295 #define RCC_FLAG_LPWRRST ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_LPWRRSTF_Pos)) /*!< Low-Power reset flag */ 296 297 /* Flags in the BDCR register */ 298 #define RCC_FLAG_LSERDY ((uint8_t)((BDCR_REG_INDEX << 5U) | RCC_BDCR_LSERDY_Pos)) /*!< External Low Speed oscillator Ready */ 299 300 /** 301 * @} 302 */ 303 304 /** 305 * @} 306 */ 307 308 /* Exported macro ------------------------------------------------------------*/ 309 310 /** @defgroup RCC_Exported_Macros RCC Exported Macros 311 * @{ 312 */ 313 314 /** @defgroup RCC_Peripheral_Clock_Enable_Disable Peripheral Clock Enable Disable 315 * @brief Enable or disable the AHB1 peripheral clock. 316 * @note After reset, the peripheral clock (used for registers read/write access) 317 * is disabled and the application software has to enable this clock before 318 * using it. 319 * @{ 320 */ 321 #define __HAL_RCC_DMA1_CLK_ENABLE() do { \ 322 __IO uint32_t tmpreg; \ 323 SET_BIT(RCC->AHBENR, RCC_AHBENR_DMA1EN);\ 324 /* Delay after an RCC peripheral clock enabling */\ 325 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_DMA1EN);\ 326 UNUSED(tmpreg); \ 327 } while(0U) 328 329 #define __HAL_RCC_SRAM_CLK_ENABLE() do { \ 330 __IO uint32_t tmpreg; \ 331 SET_BIT(RCC->AHBENR, RCC_AHBENR_SRAMEN);\ 332 /* Delay after an RCC peripheral clock enabling */\ 333 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_SRAMEN);\ 334 UNUSED(tmpreg); \ 335 } while(0U) 336 337 #define __HAL_RCC_FLITF_CLK_ENABLE() do { \ 338 __IO uint32_t tmpreg; \ 339 SET_BIT(RCC->AHBENR, RCC_AHBENR_FLITFEN);\ 340 /* Delay after an RCC peripheral clock enabling */\ 341 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_FLITFEN);\ 342 UNUSED(tmpreg); \ 343 } while(0U) 344 345 #define __HAL_RCC_CRC_CLK_ENABLE() do { \ 346 __IO uint32_t tmpreg; \ 347 SET_BIT(RCC->AHBENR, RCC_AHBENR_CRCEN);\ 348 /* Delay after an RCC peripheral clock enabling */\ 349 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_CRCEN);\ 350 UNUSED(tmpreg); \ 351 } while(0U) 352 353 #define __HAL_RCC_DMA1_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_DMA1EN)) 354 #define __HAL_RCC_SRAM_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_SRAMEN)) 355 #define __HAL_RCC_FLITF_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_FLITFEN)) 356 #define __HAL_RCC_CRC_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_CRCEN)) 357 358 /** 359 * @} 360 */ 361 362 /** @defgroup RCC_AHB_Peripheral_Clock_Enable_Disable_Status AHB Peripheral Clock Enable Disable Status 363 * @brief Get the enable or disable status of the AHB peripheral clock. 364 * @note After reset, the peripheral clock (used for registers read/write access) 365 * is disabled and the application software has to enable this clock before 366 * using it. 367 * @{ 368 */ 369 370 #define __HAL_RCC_DMA1_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_DMA1EN)) != RESET) 371 #define __HAL_RCC_DMA1_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_DMA1EN)) == RESET) 372 #define __HAL_RCC_SRAM_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_SRAMEN)) != RESET) 373 #define __HAL_RCC_SRAM_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_SRAMEN)) == RESET) 374 #define __HAL_RCC_FLITF_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_FLITFEN)) != RESET) 375 #define __HAL_RCC_FLITF_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_FLITFEN)) == RESET) 376 #define __HAL_RCC_CRC_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_CRCEN)) != RESET) 377 #define __HAL_RCC_CRC_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_CRCEN)) == RESET) 378 379 /** 380 * @} 381 */ 382 383 /** @defgroup RCC_APB1_Clock_Enable_Disable APB1 Clock Enable Disable 384 * @brief Enable or disable the Low Speed APB (APB1) peripheral clock. 385 * @note After reset, the peripheral clock (used for registers read/write access) 386 * is disabled and the application software has to enable this clock before 387 * using it. 388 * @{ 389 */ 390 #define __HAL_RCC_TIM2_CLK_ENABLE() do { \ 391 __IO uint32_t tmpreg; \ 392 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM2EN);\ 393 /* Delay after an RCC peripheral clock enabling */\ 394 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM2EN);\ 395 UNUSED(tmpreg); \ 396 } while(0U) 397 398 #define __HAL_RCC_TIM3_CLK_ENABLE() do { \ 399 __IO uint32_t tmpreg; \ 400 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM3EN);\ 401 /* Delay after an RCC peripheral clock enabling */\ 402 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM3EN);\ 403 UNUSED(tmpreg); \ 404 } while(0U) 405 406 #define __HAL_RCC_WWDG_CLK_ENABLE() do { \ 407 __IO uint32_t tmpreg; \ 408 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_WWDGEN);\ 409 /* Delay after an RCC peripheral clock enabling */\ 410 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_WWDGEN);\ 411 UNUSED(tmpreg); \ 412 } while(0U) 413 414 #define __HAL_RCC_USART2_CLK_ENABLE() do { \ 415 __IO uint32_t tmpreg; \ 416 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_USART2EN);\ 417 /* Delay after an RCC peripheral clock enabling */\ 418 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_USART2EN);\ 419 UNUSED(tmpreg); \ 420 } while(0U) 421 422 #define __HAL_RCC_I2C1_CLK_ENABLE() do { \ 423 __IO uint32_t tmpreg; \ 424 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C1EN);\ 425 /* Delay after an RCC peripheral clock enabling */\ 426 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C1EN);\ 427 UNUSED(tmpreg); \ 428 } while(0U) 429 430 #define __HAL_RCC_BKP_CLK_ENABLE() do { \ 431 __IO uint32_t tmpreg; \ 432 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_BKPEN);\ 433 /* Delay after an RCC peripheral clock enabling */\ 434 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_BKPEN);\ 435 UNUSED(tmpreg); \ 436 } while(0U) 437 438 #define __HAL_RCC_PWR_CLK_ENABLE() do { \ 439 __IO uint32_t tmpreg; \ 440 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_PWREN);\ 441 /* Delay after an RCC peripheral clock enabling */\ 442 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_PWREN);\ 443 UNUSED(tmpreg); \ 444 } while(0U) 445 446 #define __HAL_RCC_TIM2_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM2EN)) 447 #define __HAL_RCC_TIM3_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM3EN)) 448 #define __HAL_RCC_WWDG_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_WWDGEN)) 449 #define __HAL_RCC_USART2_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_USART2EN)) 450 #define __HAL_RCC_I2C1_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_I2C1EN)) 451 452 #define __HAL_RCC_BKP_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_BKPEN)) 453 #define __HAL_RCC_PWR_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_PWREN)) 454 455 /** 456 * @} 457 */ 458 459 /** @defgroup RCC_APB1_Peripheral_Clock_Enable_Disable_Status APB1 Peripheral Clock Enable Disable Status 460 * @brief Get the enable or disable status of the APB1 peripheral clock. 461 * @note After reset, the peripheral clock (used for registers read/write access) 462 * is disabled and the application software has to enable this clock before 463 * using it. 464 * @{ 465 */ 466 467 #define __HAL_RCC_TIM2_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM2EN)) != RESET) 468 #define __HAL_RCC_TIM2_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM2EN)) == RESET) 469 #define __HAL_RCC_TIM3_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM3EN)) != RESET) 470 #define __HAL_RCC_TIM3_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM3EN)) == RESET) 471 #define __HAL_RCC_WWDG_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_WWDGEN)) != RESET) 472 #define __HAL_RCC_WWDG_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_WWDGEN)) == RESET) 473 #define __HAL_RCC_USART2_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_USART2EN)) != RESET) 474 #define __HAL_RCC_USART2_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_USART2EN)) == RESET) 475 #define __HAL_RCC_I2C1_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C1EN)) != RESET) 476 #define __HAL_RCC_I2C1_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C1EN)) == RESET) 477 #define __HAL_RCC_BKP_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_BKPEN)) != RESET) 478 #define __HAL_RCC_BKP_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_BKPEN)) == RESET) 479 #define __HAL_RCC_PWR_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_PWREN)) != RESET) 480 #define __HAL_RCC_PWR_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_PWREN)) == RESET) 481 482 /** 483 * @} 484 */ 485 486 /** @defgroup RCC_APB2_Clock_Enable_Disable APB2 Clock Enable Disable 487 * @brief Enable or disable the High Speed APB (APB2) peripheral clock. 488 * @note After reset, the peripheral clock (used for registers read/write access) 489 * is disabled and the application software has to enable this clock before 490 * using it. 491 * @{ 492 */ 493 #define __HAL_RCC_AFIO_CLK_ENABLE() do { \ 494 __IO uint32_t tmpreg; \ 495 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_AFIOEN);\ 496 /* Delay after an RCC peripheral clock enabling */\ 497 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_AFIOEN);\ 498 UNUSED(tmpreg); \ 499 } while(0U) 500 501 #define __HAL_RCC_GPIOA_CLK_ENABLE() do { \ 502 __IO uint32_t tmpreg; \ 503 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_IOPAEN);\ 504 /* Delay after an RCC peripheral clock enabling */\ 505 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_IOPAEN);\ 506 UNUSED(tmpreg); \ 507 } while(0U) 508 509 #define __HAL_RCC_GPIOB_CLK_ENABLE() do { \ 510 __IO uint32_t tmpreg; \ 511 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_IOPBEN);\ 512 /* Delay after an RCC peripheral clock enabling */\ 513 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_IOPBEN);\ 514 UNUSED(tmpreg); \ 515 } while(0U) 516 517 #define __HAL_RCC_GPIOC_CLK_ENABLE() do { \ 518 __IO uint32_t tmpreg; \ 519 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_IOPCEN);\ 520 /* Delay after an RCC peripheral clock enabling */\ 521 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_IOPCEN);\ 522 UNUSED(tmpreg); \ 523 } while(0U) 524 525 #define __HAL_RCC_GPIOD_CLK_ENABLE() do { \ 526 __IO uint32_t tmpreg; \ 527 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_IOPDEN);\ 528 /* Delay after an RCC peripheral clock enabling */\ 529 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_IOPDEN);\ 530 UNUSED(tmpreg); \ 531 } while(0U) 532 533 #define __HAL_RCC_ADC1_CLK_ENABLE() do { \ 534 __IO uint32_t tmpreg; \ 535 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_ADC1EN);\ 536 /* Delay after an RCC peripheral clock enabling */\ 537 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_ADC1EN);\ 538 UNUSED(tmpreg); \ 539 } while(0U) 540 541 #define __HAL_RCC_TIM1_CLK_ENABLE() do { \ 542 __IO uint32_t tmpreg; \ 543 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM1EN);\ 544 /* Delay after an RCC peripheral clock enabling */\ 545 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM1EN);\ 546 UNUSED(tmpreg); \ 547 } while(0U) 548 549 #define __HAL_RCC_SPI1_CLK_ENABLE() do { \ 550 __IO uint32_t tmpreg; \ 551 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN);\ 552 /* Delay after an RCC peripheral clock enabling */\ 553 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN);\ 554 UNUSED(tmpreg); \ 555 } while(0U) 556 557 #define __HAL_RCC_USART1_CLK_ENABLE() do { \ 558 __IO uint32_t tmpreg; \ 559 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_USART1EN);\ 560 /* Delay after an RCC peripheral clock enabling */\ 561 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_USART1EN);\ 562 UNUSED(tmpreg); \ 563 } while(0U) 564 565 #define __HAL_RCC_AFIO_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_AFIOEN)) 566 #define __HAL_RCC_GPIOA_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_IOPAEN)) 567 #define __HAL_RCC_GPIOB_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_IOPBEN)) 568 #define __HAL_RCC_GPIOC_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_IOPCEN)) 569 #define __HAL_RCC_GPIOD_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_IOPDEN)) 570 #define __HAL_RCC_ADC1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_ADC1EN)) 571 572 #define __HAL_RCC_TIM1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_TIM1EN)) 573 #define __HAL_RCC_SPI1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_SPI1EN)) 574 #define __HAL_RCC_USART1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_USART1EN)) 575 576 /** 577 * @} 578 */ 579 580 /** @defgroup RCC_APB2_Peripheral_Clock_Enable_Disable_Status APB2 Peripheral Clock Enable Disable Status 581 * @brief Get the enable or disable status of the APB2 peripheral clock. 582 * @note After reset, the peripheral clock (used for registers read/write access) 583 * is disabled and the application software has to enable this clock before 584 * using it. 585 * @{ 586 */ 587 588 #define __HAL_RCC_AFIO_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_AFIOEN)) != RESET) 589 #define __HAL_RCC_AFIO_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_AFIOEN)) == RESET) 590 #define __HAL_RCC_GPIOA_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_IOPAEN)) != RESET) 591 #define __HAL_RCC_GPIOA_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_IOPAEN)) == RESET) 592 #define __HAL_RCC_GPIOB_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_IOPBEN)) != RESET) 593 #define __HAL_RCC_GPIOB_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_IOPBEN)) == RESET) 594 #define __HAL_RCC_GPIOC_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_IOPCEN)) != RESET) 595 #define __HAL_RCC_GPIOC_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_IOPCEN)) == RESET) 596 #define __HAL_RCC_GPIOD_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_IOPDEN)) != RESET) 597 #define __HAL_RCC_GPIOD_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_IOPDEN)) == RESET) 598 #define __HAL_RCC_ADC1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_ADC1EN)) != RESET) 599 #define __HAL_RCC_ADC1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_ADC1EN)) == RESET) 600 #define __HAL_RCC_TIM1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM1EN)) != RESET) 601 #define __HAL_RCC_TIM1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM1EN)) == RESET) 602 #define __HAL_RCC_SPI1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SPI1EN)) != RESET) 603 #define __HAL_RCC_SPI1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SPI1EN)) == RESET) 604 #define __HAL_RCC_USART1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_USART1EN)) != RESET) 605 #define __HAL_RCC_USART1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_USART1EN)) == RESET) 606 607 /** 608 * @} 609 */ 610 611 /** @defgroup RCC_APB1_Force_Release_Reset APB1 Force Release Reset 612 * @brief Force or release APB1 peripheral reset. 613 * @{ 614 */ 615 #define __HAL_RCC_APB1_FORCE_RESET() (RCC->APB1RSTR = 0xFFFFFFFFU) 616 #define __HAL_RCC_TIM2_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM2RST)) 617 #define __HAL_RCC_TIM3_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM3RST)) 618 #define __HAL_RCC_WWDG_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_WWDGRST)) 619 #define __HAL_RCC_USART2_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_USART2RST)) 620 #define __HAL_RCC_I2C1_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_I2C1RST)) 621 622 #define __HAL_RCC_BKP_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_BKPRST)) 623 #define __HAL_RCC_PWR_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_PWRRST)) 624 625 #define __HAL_RCC_APB1_RELEASE_RESET() (RCC->APB1RSTR = 0x00) 626 #define __HAL_RCC_TIM2_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM2RST)) 627 #define __HAL_RCC_TIM3_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM3RST)) 628 #define __HAL_RCC_WWDG_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_WWDGRST)) 629 #define __HAL_RCC_USART2_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_USART2RST)) 630 #define __HAL_RCC_I2C1_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_I2C1RST)) 631 632 #define __HAL_RCC_BKP_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_BKPRST)) 633 #define __HAL_RCC_PWR_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_PWRRST)) 634 635 /** 636 * @} 637 */ 638 639 /** @defgroup RCC_APB2_Force_Release_Reset APB2 Force Release Reset 640 * @brief Force or release APB2 peripheral reset. 641 * @{ 642 */ 643 #define __HAL_RCC_APB2_FORCE_RESET() (RCC->APB2RSTR = 0xFFFFFFFFU) 644 #define __HAL_RCC_AFIO_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_AFIORST)) 645 #define __HAL_RCC_GPIOA_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_IOPARST)) 646 #define __HAL_RCC_GPIOB_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_IOPBRST)) 647 #define __HAL_RCC_GPIOC_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_IOPCRST)) 648 #define __HAL_RCC_GPIOD_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_IOPDRST)) 649 #define __HAL_RCC_ADC1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_ADC1RST)) 650 651 #define __HAL_RCC_TIM1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_TIM1RST)) 652 #define __HAL_RCC_SPI1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_SPI1RST)) 653 #define __HAL_RCC_USART1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_USART1RST)) 654 655 #define __HAL_RCC_APB2_RELEASE_RESET() (RCC->APB2RSTR = 0x00) 656 #define __HAL_RCC_AFIO_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_AFIORST)) 657 #define __HAL_RCC_GPIOA_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_IOPARST)) 658 #define __HAL_RCC_GPIOB_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_IOPBRST)) 659 #define __HAL_RCC_GPIOC_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_IOPCRST)) 660 #define __HAL_RCC_GPIOD_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_IOPDRST)) 661 #define __HAL_RCC_ADC1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_ADC1RST)) 662 663 #define __HAL_RCC_TIM1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_TIM1RST)) 664 #define __HAL_RCC_SPI1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_SPI1RST)) 665 #define __HAL_RCC_USART1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_USART1RST)) 666 667 /** 668 * @} 669 */ 670 671 /** @defgroup RCC_HSI_Configuration HSI Configuration 672 * @{ 673 */ 674 675 /** @brief Macros to enable or disable the Internal High Speed oscillator (HSI). 676 * @note The HSI is stopped by hardware when entering STOP and STANDBY modes. 677 * @note HSI can not be stopped if it is used as system clock source. In this case, 678 * you have to select another source of the system clock then stop the HSI. 679 * @note After enabling the HSI, the application software should wait on HSIRDY 680 * flag to be set indicating that HSI clock is stable and can be used as 681 * system clock source. 682 * @note When the HSI is stopped, HSIRDY flag goes low after 6 HSI oscillator 683 * clock cycles. 684 */ 685 #define __HAL_RCC_HSI_ENABLE() (*(__IO uint32_t *) RCC_CR_HSION_BB = ENABLE) 686 #define __HAL_RCC_HSI_DISABLE() (*(__IO uint32_t *) RCC_CR_HSION_BB = DISABLE) 687 688 /** @brief Macro to adjust the Internal High Speed oscillator (HSI) calibration value. 689 * @note The calibration is used to compensate for the variations in voltage 690 * and temperature that influence the frequency of the internal HSI RC. 691 * @param _HSICALIBRATIONVALUE_ specifies the calibration trimming value. 692 * (default is RCC_HSICALIBRATION_DEFAULT). 693 * This parameter must be a number between 0 and 0x1F. 694 */ 695 #define __HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST(_HSICALIBRATIONVALUE_) \ 696 (MODIFY_REG(RCC->CR, RCC_CR_HSITRIM, (uint32_t)(_HSICALIBRATIONVALUE_) << RCC_CR_HSITRIM_Pos)) 697 698 /** 699 * @} 700 */ 701 702 /** @defgroup RCC_LSI_Configuration LSI Configuration 703 * @{ 704 */ 705 706 /** @brief Macro to enable the Internal Low Speed oscillator (LSI). 707 * @note After enabling the LSI, the application software should wait on 708 * LSIRDY flag to be set indicating that LSI clock is stable and can 709 * be used to clock the IWDG and/or the RTC. 710 */ 711 #define __HAL_RCC_LSI_ENABLE() (*(__IO uint32_t *) RCC_CSR_LSION_BB = ENABLE) 712 713 /** @brief Macro to disable the Internal Low Speed oscillator (LSI). 714 * @note LSI can not be disabled if the IWDG is running. 715 * @note When the LSI is stopped, LSIRDY flag goes low after 6 LSI oscillator 716 * clock cycles. 717 */ 718 #define __HAL_RCC_LSI_DISABLE() (*(__IO uint32_t *) RCC_CSR_LSION_BB = DISABLE) 719 720 /** 721 * @} 722 */ 723 724 /** @defgroup RCC_HSE_Configuration HSE Configuration 725 * @{ 726 */ 727 728 /** 729 * @brief Macro to configure the External High Speed oscillator (HSE). 730 * @note Transition HSE Bypass to HSE On and HSE On to HSE Bypass are not 731 * supported by this macro. User should request a transition to HSE Off 732 * first and then HSE On or HSE Bypass. 733 * @note After enabling the HSE (RCC_HSE_ON or RCC_HSE_Bypass), the application 734 * software should wait on HSERDY flag to be set indicating that HSE clock 735 * is stable and can be used to clock the PLL and/or system clock. 736 * @note HSE state can not be changed if it is used directly or through the 737 * PLL as system clock. In this case, you have to select another source 738 * of the system clock then change the HSE state (ex. disable it). 739 * @note The HSE is stopped by hardware when entering STOP and STANDBY modes. 740 * @note This function reset the CSSON bit, so if the clock security system(CSS) 741 * was previously enabled you have to enable it again after calling this 742 * function. 743 * @param __STATE__ specifies the new state of the HSE. 744 * This parameter can be one of the following values: 745 * @arg @ref RCC_HSE_OFF turn OFF the HSE oscillator, HSERDY flag goes low after 746 * 6 HSE oscillator clock cycles. 747 * @arg @ref RCC_HSE_ON turn ON the HSE oscillator 748 * @arg @ref RCC_HSE_BYPASS HSE oscillator bypassed with external clock 749 */ 750 #define __HAL_RCC_HSE_CONFIG(__STATE__) \ 751 do{ \ 752 if ((__STATE__) == RCC_HSE_ON) \ 753 { \ 754 SET_BIT(RCC->CR, RCC_CR_HSEON); \ 755 } \ 756 else if ((__STATE__) == RCC_HSE_OFF) \ 757 { \ 758 CLEAR_BIT(RCC->CR, RCC_CR_HSEON); \ 759 CLEAR_BIT(RCC->CR, RCC_CR_HSEBYP); \ 760 } \ 761 else if ((__STATE__) == RCC_HSE_BYPASS) \ 762 { \ 763 SET_BIT(RCC->CR, RCC_CR_HSEBYP); \ 764 SET_BIT(RCC->CR, RCC_CR_HSEON); \ 765 } \ 766 else \ 767 { \ 768 CLEAR_BIT(RCC->CR, RCC_CR_HSEON); \ 769 CLEAR_BIT(RCC->CR, RCC_CR_HSEBYP); \ 770 } \ 771 }while(0U) 772 773 /** 774 * @} 775 */ 776 777 /** @defgroup RCC_LSE_Configuration LSE Configuration 778 * @{ 779 */ 780 781 /** 782 * @brief Macro to configure the External Low Speed oscillator (LSE). 783 * @note Transitions LSE Bypass to LSE On and LSE On to LSE Bypass are not supported by this macro. 784 * @note As the LSE is in the Backup domain and write access is denied to 785 * this domain after reset, you have to enable write access using 786 * @ref HAL_PWR_EnableBkUpAccess() function before to configure the LSE 787 * (to be done once after reset). 788 * @note After enabling the LSE (RCC_LSE_ON or RCC_LSE_BYPASS), the application 789 * software should wait on LSERDY flag to be set indicating that LSE clock 790 * is stable and can be used to clock the RTC. 791 * @param __STATE__ specifies the new state of the LSE. 792 * This parameter can be one of the following values: 793 * @arg @ref RCC_LSE_OFF turn OFF the LSE oscillator, LSERDY flag goes low after 794 * 6 LSE oscillator clock cycles. 795 * @arg @ref RCC_LSE_ON turn ON the LSE oscillator. 796 * @arg @ref RCC_LSE_BYPASS LSE oscillator bypassed with external clock. 797 */ 798 #define __HAL_RCC_LSE_CONFIG(__STATE__) \ 799 do{ \ 800 if ((__STATE__) == RCC_LSE_ON) \ 801 { \ 802 SET_BIT(RCC->BDCR, RCC_BDCR_LSEON); \ 803 } \ 804 else if ((__STATE__) == RCC_LSE_OFF) \ 805 { \ 806 CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSEON); \ 807 CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSEBYP); \ 808 } \ 809 else if ((__STATE__) == RCC_LSE_BYPASS) \ 810 { \ 811 SET_BIT(RCC->BDCR, RCC_BDCR_LSEBYP); \ 812 SET_BIT(RCC->BDCR, RCC_BDCR_LSEON); \ 813 } \ 814 else \ 815 { \ 816 CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSEON); \ 817 CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSEBYP); \ 818 } \ 819 }while(0U) 820 821 /** 822 * @} 823 */ 824 825 /** @defgroup RCC_PLL_Configuration PLL Configuration 826 * @{ 827 */ 828 829 /** @brief Macro to enable the main PLL. 830 * @note After enabling the main PLL, the application software should wait on 831 * PLLRDY flag to be set indicating that PLL clock is stable and can 832 * be used as system clock source. 833 * @note The main PLL is disabled by hardware when entering STOP and STANDBY modes. 834 */ 835 #define __HAL_RCC_PLL_ENABLE() (*(__IO uint32_t *) RCC_CR_PLLON_BB = ENABLE) 836 837 /** @brief Macro to disable the main PLL. 838 * @note The main PLL can not be disabled if it is used as system clock source 839 */ 840 #define __HAL_RCC_PLL_DISABLE() (*(__IO uint32_t *) RCC_CR_PLLON_BB = DISABLE) 841 842 /** @brief Macro to configure the main PLL clock source and multiplication factors. 843 * @note This function must be used only when the main PLL is disabled. 844 * 845 * @param __RCC_PLLSOURCE__ specifies the PLL entry clock source. 846 * This parameter can be one of the following values: 847 * @arg @ref RCC_PLLSOURCE_HSI_DIV2 HSI oscillator clock selected as PLL clock entry 848 * @arg @ref RCC_PLLSOURCE_HSE HSE oscillator clock selected as PLL clock entry 849 * @param __PLLMUL__ specifies the multiplication factor for PLL VCO output clock 850 * This parameter can be one of the following values: 851 * @arg @ref RCC_PLL_MUL4 PLLVCO = PLL clock entry x 4 852 * @arg @ref RCC_PLL_MUL6 PLLVCO = PLL clock entry x 6 853 @if STM32F105xC 854 * @arg @ref RCC_PLL_MUL6_5 PLLVCO = PLL clock entry x 6.5 855 @elseif STM32F107xC 856 * @arg @ref RCC_PLL_MUL6_5 PLLVCO = PLL clock entry x 6.5 857 @else 858 * @arg @ref RCC_PLL_MUL2 PLLVCO = PLL clock entry x 2 859 * @arg @ref RCC_PLL_MUL3 PLLVCO = PLL clock entry x 3 860 * @arg @ref RCC_PLL_MUL10 PLLVCO = PLL clock entry x 10 861 * @arg @ref RCC_PLL_MUL11 PLLVCO = PLL clock entry x 11 862 * @arg @ref RCC_PLL_MUL12 PLLVCO = PLL clock entry x 12 863 * @arg @ref RCC_PLL_MUL13 PLLVCO = PLL clock entry x 13 864 * @arg @ref RCC_PLL_MUL14 PLLVCO = PLL clock entry x 14 865 * @arg @ref RCC_PLL_MUL15 PLLVCO = PLL clock entry x 15 866 * @arg @ref RCC_PLL_MUL16 PLLVCO = PLL clock entry x 16 867 @endif 868 * @arg @ref RCC_PLL_MUL8 PLLVCO = PLL clock entry x 8 869 * @arg @ref RCC_PLL_MUL9 PLLVCO = PLL clock entry x 9 870 * 871 */ 872 #define __HAL_RCC_PLL_CONFIG(__RCC_PLLSOURCE__, __PLLMUL__)\ 873 MODIFY_REG(RCC->CFGR, (RCC_CFGR_PLLSRC | RCC_CFGR_PLLMULL),((__RCC_PLLSOURCE__) | (__PLLMUL__) )) 874 875 /** @brief Get oscillator clock selected as PLL input clock 876 * @retval The clock source used for PLL entry. The returned value can be one 877 * of the following: 878 * @arg @ref RCC_PLLSOURCE_HSI_DIV2 HSI oscillator clock selected as PLL input clock 879 * @arg @ref RCC_PLLSOURCE_HSE HSE oscillator clock selected as PLL input clock 880 */ 881 #define __HAL_RCC_GET_PLL_OSCSOURCE() ((uint32_t)(READ_BIT(RCC->CFGR, RCC_CFGR_PLLSRC))) 882 883 /** 884 * @} 885 */ 886 887 /** @defgroup RCC_Get_Clock_source Get Clock source 888 * @{ 889 */ 890 891 /** 892 * @brief Macro to configure the system clock source. 893 * @param __SYSCLKSOURCE__ specifies the system clock source. 894 * This parameter can be one of the following values: 895 * @arg @ref RCC_SYSCLKSOURCE_HSI HSI oscillator is used as system clock source. 896 * @arg @ref RCC_SYSCLKSOURCE_HSE HSE oscillator is used as system clock source. 897 * @arg @ref RCC_SYSCLKSOURCE_PLLCLK PLL output is used as system clock source. 898 */ 899 #define __HAL_RCC_SYSCLK_CONFIG(__SYSCLKSOURCE__) \ 900 MODIFY_REG(RCC->CFGR, RCC_CFGR_SW, (__SYSCLKSOURCE__)) 901 902 /** @brief Macro to get the clock source used as system clock. 903 * @retval The clock source used as system clock. The returned value can be one 904 * of the following: 905 * @arg @ref RCC_SYSCLKSOURCE_STATUS_HSI HSI used as system clock 906 * @arg @ref RCC_SYSCLKSOURCE_STATUS_HSE HSE used as system clock 907 * @arg @ref RCC_SYSCLKSOURCE_STATUS_PLLCLK PLL used as system clock 908 */ 909 #define __HAL_RCC_GET_SYSCLK_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR,RCC_CFGR_SWS))) 910 911 /** 912 * @} 913 */ 914 915 /** @defgroup RCCEx_MCOx_Clock_Config RCC Extended MCOx Clock Config 916 * @{ 917 */ 918 919 #if defined(RCC_CFGR_MCO_3) 920 /** @brief Macro to configure the MCO clock. 921 * @param __MCOCLKSOURCE__ specifies the MCO clock source. 922 * This parameter can be one of the following values: 923 * @arg @ref RCC_MCO1SOURCE_NOCLOCK No clock selected as MCO clock 924 * @arg @ref RCC_MCO1SOURCE_SYSCLK System clock (SYSCLK) selected as MCO clock 925 * @arg @ref RCC_MCO1SOURCE_HSI HSI selected as MCO clock 926 * @arg @ref RCC_MCO1SOURCE_HSE HSE selected as MCO clock 927 * @arg @ref RCC_MCO1SOURCE_PLLCLK PLL clock divided by 2 selected as MCO clock 928 * @arg @ref RCC_MCO1SOURCE_PLL2CLK PLL2 clock selected by 2 selected as MCO clock 929 * @arg @ref RCC_MCO1SOURCE_PLL3CLK_DIV2 PLL3 clock divided by 2 selected as MCO clock 930 * @arg @ref RCC_MCO1SOURCE_EXT_HSE XT1 external 3-25 MHz oscillator clock selected (for Ethernet) as MCO clock 931 * @arg @ref RCC_MCO1SOURCE_PLL3CLK PLL3 clock selected (for Ethernet) as MCO clock 932 * @param __MCODIV__ specifies the MCO clock prescaler. 933 * This parameter can be one of the following values: 934 * @arg @ref RCC_MCODIV_1 No division applied on MCO clock source 935 */ 936 #else 937 /** @brief Macro to configure the MCO clock. 938 * @param __MCOCLKSOURCE__ specifies the MCO clock source. 939 * This parameter can be one of the following values: 940 * @arg @ref RCC_MCO1SOURCE_NOCLOCK No clock selected as MCO clock 941 * @arg @ref RCC_MCO1SOURCE_SYSCLK System clock (SYSCLK) selected as MCO clock 942 * @arg @ref RCC_MCO1SOURCE_HSI HSI selected as MCO clock 943 * @arg @ref RCC_MCO1SOURCE_HSE HSE selected as MCO clock 944 * @arg @ref RCC_MCO1SOURCE_PLLCLK PLL clock divided by 2 selected as MCO clock 945 * @param __MCODIV__ specifies the MCO clock prescaler. 946 * This parameter can be one of the following values: 947 * @arg @ref RCC_MCODIV_1 No division applied on MCO clock source 948 */ 949 #endif 950 951 #define __HAL_RCC_MCO1_CONFIG(__MCOCLKSOURCE__, __MCODIV__) \ 952 MODIFY_REG(RCC->CFGR, RCC_CFGR_MCO, (__MCOCLKSOURCE__)) 953 954 955 /** 956 * @} 957 */ 958 959 /** @defgroup RCC_RTC_Clock_Configuration RCC RTC Clock Configuration 960 * @{ 961 */ 962 963 /** @brief Macro to configure the RTC clock (RTCCLK). 964 * @note As the RTC clock configuration bits are in the Backup domain and write 965 * access is denied to this domain after reset, you have to enable write 966 * access using the Power Backup Access macro before to configure 967 * the RTC clock source (to be done once after reset). 968 * @note Once the RTC clock is configured it can't be changed unless the 969 * Backup domain is reset using @ref __HAL_RCC_BACKUPRESET_FORCE() macro, or by 970 * a Power On Reset (POR). 971 * 972 * @param __RTC_CLKSOURCE__ specifies the RTC clock source. 973 * This parameter can be one of the following values: 974 * @arg @ref RCC_RTCCLKSOURCE_NO_CLK No clock selected as RTC clock 975 * @arg @ref RCC_RTCCLKSOURCE_LSE LSE selected as RTC clock 976 * @arg @ref RCC_RTCCLKSOURCE_LSI LSI selected as RTC clock 977 * @arg @ref RCC_RTCCLKSOURCE_HSE_DIV128 HSE divided by 128 selected as RTC clock 978 * @note If the LSE or LSI is used as RTC clock source, the RTC continues to 979 * work in STOP and STANDBY modes, and can be used as wakeup source. 980 * However, when the HSE clock is used as RTC clock source, the RTC 981 * cannot be used in STOP and STANDBY modes. 982 * @note The maximum input clock frequency for RTC is 1MHz (when using HSE as 983 * RTC clock source). 984 */ 985 #define __HAL_RCC_RTC_CONFIG(__RTC_CLKSOURCE__) MODIFY_REG(RCC->BDCR, RCC_BDCR_RTCSEL, (__RTC_CLKSOURCE__)) 986 987 /** @brief Macro to get the RTC clock source. 988 * @retval The clock source can be one of the following values: 989 * @arg @ref RCC_RTCCLKSOURCE_NO_CLK No clock selected as RTC clock 990 * @arg @ref RCC_RTCCLKSOURCE_LSE LSE selected as RTC clock 991 * @arg @ref RCC_RTCCLKSOURCE_LSI LSI selected as RTC clock 992 * @arg @ref RCC_RTCCLKSOURCE_HSE_DIV128 HSE divided by 128 selected as RTC clock 993 */ 994 #define __HAL_RCC_GET_RTC_SOURCE() (READ_BIT(RCC->BDCR, RCC_BDCR_RTCSEL)) 995 996 /** @brief Macro to enable the the RTC clock. 997 * @note These macros must be used only after the RTC clock source was selected. 998 */ 999 #define __HAL_RCC_RTC_ENABLE() (*(__IO uint32_t *) RCC_BDCR_RTCEN_BB = ENABLE) 1000 1001 /** @brief Macro to disable the the RTC clock. 1002 * @note These macros must be used only after the RTC clock source was selected. 1003 */ 1004 #define __HAL_RCC_RTC_DISABLE() (*(__IO uint32_t *) RCC_BDCR_RTCEN_BB = DISABLE) 1005 1006 /** @brief Macro to force the Backup domain reset. 1007 * @note This function resets the RTC peripheral (including the backup registers) 1008 * and the RTC clock source selection in RCC_BDCR register. 1009 */ 1010 #define __HAL_RCC_BACKUPRESET_FORCE() (*(__IO uint32_t *) RCC_BDCR_BDRST_BB = ENABLE) 1011 1012 /** @brief Macros to release the Backup domain reset. 1013 */ 1014 #define __HAL_RCC_BACKUPRESET_RELEASE() (*(__IO uint32_t *) RCC_BDCR_BDRST_BB = DISABLE) 1015 1016 /** 1017 * @} 1018 */ 1019 1020 /** @defgroup RCC_Flags_Interrupts_Management Flags Interrupts Management 1021 * @brief macros to manage the specified RCC Flags and interrupts. 1022 * @{ 1023 */ 1024 1025 /** @brief Enable RCC interrupt. 1026 * @param __INTERRUPT__ specifies the RCC interrupt sources to be enabled. 1027 * This parameter can be any combination of the following values: 1028 * @arg @ref RCC_IT_LSIRDY LSI ready interrupt 1029 * @arg @ref RCC_IT_LSERDY LSE ready interrupt 1030 * @arg @ref RCC_IT_HSIRDY HSI ready interrupt 1031 * @arg @ref RCC_IT_HSERDY HSE ready interrupt 1032 * @arg @ref RCC_IT_PLLRDY main PLL ready interrupt 1033 @if STM32F105xx 1034 * @arg @ref RCC_IT_PLL2RDY Main PLL2 ready interrupt. 1035 * @arg @ref RCC_IT_PLLI2S2RDY Main PLLI2S ready interrupt. 1036 @elsif STM32F107xx 1037 * @arg @ref RCC_IT_PLL2RDY Main PLL2 ready interrupt. 1038 * @arg @ref RCC_IT_PLLI2S2RDY Main PLLI2S ready interrupt. 1039 @endif 1040 */ 1041 #define __HAL_RCC_ENABLE_IT(__INTERRUPT__) (*(__IO uint8_t *) RCC_CIR_BYTE1_ADDRESS |= (__INTERRUPT__)) 1042 1043 /** @brief Disable RCC interrupt. 1044 * @param __INTERRUPT__ specifies the RCC interrupt sources to be disabled. 1045 * This parameter can be any combination of the following values: 1046 * @arg @ref RCC_IT_LSIRDY LSI ready interrupt 1047 * @arg @ref RCC_IT_LSERDY LSE ready interrupt 1048 * @arg @ref RCC_IT_HSIRDY HSI ready interrupt 1049 * @arg @ref RCC_IT_HSERDY HSE ready interrupt 1050 * @arg @ref RCC_IT_PLLRDY main PLL ready interrupt 1051 @if STM32F105xx 1052 * @arg @ref RCC_IT_PLL2RDY Main PLL2 ready interrupt. 1053 * @arg @ref RCC_IT_PLLI2S2RDY Main PLLI2S ready interrupt. 1054 @elsif STM32F107xx 1055 * @arg @ref RCC_IT_PLL2RDY Main PLL2 ready interrupt. 1056 * @arg @ref RCC_IT_PLLI2S2RDY Main PLLI2S ready interrupt. 1057 @endif 1058 */ 1059 #define __HAL_RCC_DISABLE_IT(__INTERRUPT__) (*(__IO uint8_t *) RCC_CIR_BYTE1_ADDRESS &= (uint8_t)(~(__INTERRUPT__))) 1060 1061 /** @brief Clear the RCC's interrupt pending bits. 1062 * @param __INTERRUPT__ specifies the interrupt pending bit to clear. 1063 * This parameter can be any combination of the following values: 1064 * @arg @ref RCC_IT_LSIRDY LSI ready interrupt. 1065 * @arg @ref RCC_IT_LSERDY LSE ready interrupt. 1066 * @arg @ref RCC_IT_HSIRDY HSI ready interrupt. 1067 * @arg @ref RCC_IT_HSERDY HSE ready interrupt. 1068 * @arg @ref RCC_IT_PLLRDY Main PLL ready interrupt. 1069 @if STM32F105xx 1070 * @arg @ref RCC_IT_PLL2RDY Main PLL2 ready interrupt. 1071 * @arg @ref RCC_IT_PLLI2S2RDY Main PLLI2S ready interrupt. 1072 @elsif STM32F107xx 1073 * @arg @ref RCC_IT_PLL2RDY Main PLL2 ready interrupt. 1074 * @arg @ref RCC_IT_PLLI2S2RDY Main PLLI2S ready interrupt. 1075 @endif 1076 * @arg @ref RCC_IT_CSS Clock Security System interrupt 1077 */ 1078 #define __HAL_RCC_CLEAR_IT(__INTERRUPT__) (*(__IO uint8_t *) RCC_CIR_BYTE2_ADDRESS = (__INTERRUPT__)) 1079 1080 /** @brief Check the RCC's interrupt has occurred or not. 1081 * @param __INTERRUPT__ specifies the RCC interrupt source to check. 1082 * This parameter can be one of the following values: 1083 * @arg @ref RCC_IT_LSIRDY LSI ready interrupt. 1084 * @arg @ref RCC_IT_LSERDY LSE ready interrupt. 1085 * @arg @ref RCC_IT_HSIRDY HSI ready interrupt. 1086 * @arg @ref RCC_IT_HSERDY HSE ready interrupt. 1087 * @arg @ref RCC_IT_PLLRDY Main PLL ready interrupt. 1088 @if STM32F105xx 1089 * @arg @ref RCC_IT_PLL2RDY Main PLL2 ready interrupt. 1090 * @arg @ref RCC_IT_PLLI2S2RDY Main PLLI2S ready interrupt. 1091 @elsif STM32F107xx 1092 * @arg @ref RCC_IT_PLL2RDY Main PLL2 ready interrupt. 1093 * @arg @ref RCC_IT_PLLI2S2RDY Main PLLI2S ready interrupt. 1094 @endif 1095 * @arg @ref RCC_IT_CSS Clock Security System interrupt 1096 * @retval The new state of __INTERRUPT__ (TRUE or FALSE). 1097 */ 1098 #define __HAL_RCC_GET_IT(__INTERRUPT__) ((RCC->CIR & (__INTERRUPT__)) == (__INTERRUPT__)) 1099 1100 /** @brief Set RMVF bit to clear the reset flags. 1101 * The reset flags are RCC_FLAG_PINRST, RCC_FLAG_PORRST, RCC_FLAG_SFTRST, 1102 * RCC_FLAG_IWDGRST, RCC_FLAG_WWDGRST, RCC_FLAG_LPWRRST 1103 */ 1104 #define __HAL_RCC_CLEAR_RESET_FLAGS() (*(__IO uint32_t *)RCC_CSR_RMVF_BB = ENABLE) 1105 1106 /** @brief Check RCC flag is set or not. 1107 * @param __FLAG__ specifies the flag to check. 1108 * This parameter can be one of the following values: 1109 * @arg @ref RCC_FLAG_HSIRDY HSI oscillator clock ready. 1110 * @arg @ref RCC_FLAG_HSERDY HSE oscillator clock ready. 1111 * @arg @ref RCC_FLAG_PLLRDY Main PLL clock ready. 1112 @if STM32F105xx 1113 * @arg @ref RCC_FLAG_PLL2RDY Main PLL2 clock ready. 1114 * @arg @ref RCC_FLAG_PLLI2SRDY Main PLLI2S clock ready. 1115 @elsif STM32F107xx 1116 * @arg @ref RCC_FLAG_PLL2RDY Main PLL2 clock ready. 1117 * @arg @ref RCC_FLAG_PLLI2SRDY Main PLLI2S clock ready. 1118 @endif 1119 * @arg @ref RCC_FLAG_LSERDY LSE oscillator clock ready. 1120 * @arg @ref RCC_FLAG_LSIRDY LSI oscillator clock ready. 1121 * @arg @ref RCC_FLAG_PINRST Pin reset. 1122 * @arg @ref RCC_FLAG_PORRST POR/PDR reset. 1123 * @arg @ref RCC_FLAG_SFTRST Software reset. 1124 * @arg @ref RCC_FLAG_IWDGRST Independent Watchdog reset. 1125 * @arg @ref RCC_FLAG_WWDGRST Window Watchdog reset. 1126 * @arg @ref RCC_FLAG_LPWRRST Low Power reset. 1127 * @retval The new state of __FLAG__ (TRUE or FALSE). 1128 */ 1129 #define __HAL_RCC_GET_FLAG(__FLAG__) (((((__FLAG__) >> 5U) == CR_REG_INDEX)? RCC->CR : \ 1130 ((((__FLAG__) >> 5U) == BDCR_REG_INDEX)? RCC->BDCR : \ 1131 RCC->CSR)) & (1U << ((__FLAG__) & RCC_FLAG_MASK))) 1132 1133 /** 1134 * @} 1135 */ 1136 1137 /** 1138 * @} 1139 */ 1140 1141 /* Include RCC HAL Extension module */ 1142 #include "stm32f1xx_hal_rcc_ex.h" 1143 1144 /* Exported functions --------------------------------------------------------*/ 1145 /** @addtogroup RCC_Exported_Functions 1146 * @{ 1147 */ 1148 1149 /** @addtogroup RCC_Exported_Functions_Group1 1150 * @{ 1151 */ 1152 1153 /* Initialization and de-initialization functions ******************************/ 1154 HAL_StatusTypeDef HAL_RCC_DeInit(void); 1155 HAL_StatusTypeDef HAL_RCC_OscConfig(RCC_OscInitTypeDef *RCC_OscInitStruct); 1156 HAL_StatusTypeDef HAL_RCC_ClockConfig(RCC_ClkInitTypeDef *RCC_ClkInitStruct, uint32_t FLatency); 1157 1158 /** 1159 * @} 1160 */ 1161 1162 /** @addtogroup RCC_Exported_Functions_Group2 1163 * @{ 1164 */ 1165 1166 /* Peripheral Control functions ************************************************/ 1167 void HAL_RCC_MCOConfig(uint32_t RCC_MCOx, uint32_t RCC_MCOSource, uint32_t RCC_MCODiv); 1168 void HAL_RCC_EnableCSS(void); 1169 void HAL_RCC_DisableCSS(void); 1170 uint32_t HAL_RCC_GetSysClockFreq(void); 1171 uint32_t HAL_RCC_GetHCLKFreq(void); 1172 uint32_t HAL_RCC_GetPCLK1Freq(void); 1173 uint32_t HAL_RCC_GetPCLK2Freq(void); 1174 void HAL_RCC_GetOscConfig(RCC_OscInitTypeDef *RCC_OscInitStruct); 1175 void HAL_RCC_GetClockConfig(RCC_ClkInitTypeDef *RCC_ClkInitStruct, uint32_t *pFLatency); 1176 1177 /* CSS NMI IRQ handler */ 1178 void HAL_RCC_NMI_IRQHandler(void); 1179 1180 /* User Callbacks in non blocking mode (IT mode) */ 1181 void HAL_RCC_CSSCallback(void); 1182 1183 /** 1184 * @} 1185 */ 1186 1187 /** 1188 * @} 1189 */ 1190 1191 /** @addtogroup RCC_Private_Constants 1192 * @{ 1193 */ 1194 1195 /** @defgroup RCC_Timeout RCC Timeout 1196 * @{ 1197 */ 1198 1199 /* Disable Backup domain write protection state change timeout */ 1200 #define RCC_DBP_TIMEOUT_VALUE 100U /* 100 ms */ 1201 /* LSE state change timeout */ 1202 #define RCC_LSE_TIMEOUT_VALUE LSE_STARTUP_TIMEOUT 1203 #define CLOCKSWITCH_TIMEOUT_VALUE 5000 /* 5 s */ 1204 #define HSE_TIMEOUT_VALUE HSE_STARTUP_TIMEOUT 1205 #define HSI_TIMEOUT_VALUE 2U /* 2 ms (minimum Tick + 1) */ 1206 #define LSI_TIMEOUT_VALUE 2U /* 2 ms (minimum Tick + 1) */ 1207 #define PLL_TIMEOUT_VALUE 2U /* 2 ms (minimum Tick + 1) */ 1208 1209 /** 1210 * @} 1211 */ 1212 1213 /** @defgroup RCC_Register_Offset Register offsets 1214 * @{ 1215 */ 1216 #define RCC_OFFSET (RCC_BASE - PERIPH_BASE) 1217 #define RCC_CR_OFFSET 0x00U 1218 #define RCC_CFGR_OFFSET 0x04U 1219 #define RCC_CIR_OFFSET 0x08U 1220 #define RCC_BDCR_OFFSET 0x20U 1221 #define RCC_CSR_OFFSET 0x24U 1222 1223 /** 1224 * @} 1225 */ 1226 1227 /** @defgroup RCC_BitAddress_AliasRegion BitAddress AliasRegion 1228 * @brief RCC registers bit address in the alias region 1229 * @{ 1230 */ 1231 #define RCC_CR_OFFSET_BB (RCC_OFFSET + RCC_CR_OFFSET) 1232 #define RCC_CFGR_OFFSET_BB (RCC_OFFSET + RCC_CFGR_OFFSET) 1233 #define RCC_CIR_OFFSET_BB (RCC_OFFSET + RCC_CIR_OFFSET) 1234 #define RCC_BDCR_OFFSET_BB (RCC_OFFSET + RCC_BDCR_OFFSET) 1235 #define RCC_CSR_OFFSET_BB (RCC_OFFSET + RCC_CSR_OFFSET) 1236 1237 /* --- CR Register ---*/ 1238 /* Alias word address of HSION bit */ 1239 #define RCC_HSION_BIT_NUMBER RCC_CR_HSION_Pos 1240 #define RCC_CR_HSION_BB ((uint32_t)(PERIPH_BB_BASE + (RCC_CR_OFFSET_BB * 32U) + (RCC_HSION_BIT_NUMBER * 4U))) 1241 /* Alias word address of HSEON bit */ 1242 #define RCC_HSEON_BIT_NUMBER RCC_CR_HSEON_Pos 1243 #define RCC_CR_HSEON_BB ((uint32_t)(PERIPH_BB_BASE + (RCC_CR_OFFSET_BB * 32U) + (RCC_HSEON_BIT_NUMBER * 4U))) 1244 /* Alias word address of CSSON bit */ 1245 #define RCC_CSSON_BIT_NUMBER RCC_CR_CSSON_Pos 1246 #define RCC_CR_CSSON_BB ((uint32_t)(PERIPH_BB_BASE + (RCC_CR_OFFSET_BB * 32U) + (RCC_CSSON_BIT_NUMBER * 4U))) 1247 /* Alias word address of PLLON bit */ 1248 #define RCC_PLLON_BIT_NUMBER RCC_CR_PLLON_Pos 1249 #define RCC_CR_PLLON_BB ((uint32_t)(PERIPH_BB_BASE + (RCC_CR_OFFSET_BB * 32U) + (RCC_PLLON_BIT_NUMBER * 4U))) 1250 1251 /* --- CSR Register ---*/ 1252 /* Alias word address of LSION bit */ 1253 #define RCC_LSION_BIT_NUMBER RCC_CSR_LSION_Pos 1254 #define RCC_CSR_LSION_BB ((uint32_t)(PERIPH_BB_BASE + (RCC_CSR_OFFSET_BB * 32U) + (RCC_LSION_BIT_NUMBER * 4U))) 1255 1256 /* Alias word address of RMVF bit */ 1257 #define RCC_RMVF_BIT_NUMBER RCC_CSR_RMVF_Pos 1258 #define RCC_CSR_RMVF_BB ((uint32_t)(PERIPH_BB_BASE + (RCC_CSR_OFFSET_BB * 32U) + (RCC_RMVF_BIT_NUMBER * 4U))) 1259 1260 /* --- BDCR Registers ---*/ 1261 /* Alias word address of LSEON bit */ 1262 #define RCC_LSEON_BIT_NUMBER RCC_BDCR_LSEON_Pos 1263 #define RCC_BDCR_LSEON_BB ((uint32_t)(PERIPH_BB_BASE + (RCC_BDCR_OFFSET_BB * 32U) + (RCC_LSEON_BIT_NUMBER * 4U))) 1264 1265 /* Alias word address of LSEON bit */ 1266 #define RCC_LSEBYP_BIT_NUMBER RCC_BDCR_LSEBYP_Pos 1267 #define RCC_BDCR_LSEBYP_BB ((uint32_t)(PERIPH_BB_BASE + (RCC_BDCR_OFFSET_BB * 32U) + (RCC_LSEBYP_BIT_NUMBER * 4U))) 1268 1269 /* Alias word address of RTCEN bit */ 1270 #define RCC_RTCEN_BIT_NUMBER RCC_BDCR_RTCEN_Pos 1271 #define RCC_BDCR_RTCEN_BB ((uint32_t)(PERIPH_BB_BASE + (RCC_BDCR_OFFSET_BB * 32U) + (RCC_RTCEN_BIT_NUMBER * 4U))) 1272 1273 /* Alias word address of BDRST bit */ 1274 #define RCC_BDRST_BIT_NUMBER RCC_BDCR_BDRST_Pos 1275 #define RCC_BDCR_BDRST_BB ((uint32_t)(PERIPH_BB_BASE + (RCC_BDCR_OFFSET_BB * 32U) + (RCC_BDRST_BIT_NUMBER * 4U))) 1276 1277 /** 1278 * @} 1279 */ 1280 1281 /* CR register byte 2 (Bits[23:16]) base address */ 1282 #define RCC_CR_BYTE2_ADDRESS ((uint32_t)(RCC_BASE + RCC_CR_OFFSET + 0x02U)) 1283 1284 /* CIR register byte 1 (Bits[15:8]) base address */ 1285 #define RCC_CIR_BYTE1_ADDRESS ((uint32_t)(RCC_BASE + RCC_CIR_OFFSET + 0x01U)) 1286 1287 /* CIR register byte 2 (Bits[23:16]) base address */ 1288 #define RCC_CIR_BYTE2_ADDRESS ((uint32_t)(RCC_BASE + RCC_CIR_OFFSET + 0x02U)) 1289 1290 /* Defines used for Flags */ 1291 #define CR_REG_INDEX ((uint8_t)1) 1292 #define BDCR_REG_INDEX ((uint8_t)2) 1293 #define CSR_REG_INDEX ((uint8_t)3) 1294 1295 #define RCC_FLAG_MASK ((uint8_t)0x1F) 1296 1297 /** 1298 * @} 1299 */ 1300 1301 /** @addtogroup RCC_Private_Macros 1302 * @{ 1303 */ 1304 /** @defgroup RCC_Alias_For_Legacy Alias define maintained for legacy 1305 * @{ 1306 */ 1307 #define __HAL_RCC_SYSCFG_CLK_DISABLE __HAL_RCC_AFIO_CLK_DISABLE 1308 #define __HAL_RCC_SYSCFG_CLK_ENABLE __HAL_RCC_AFIO_CLK_ENABLE 1309 #define __HAL_RCC_SYSCFG_FORCE_RESET __HAL_RCC_AFIO_FORCE_RESET 1310 #define __HAL_RCC_SYSCFG_RELEASE_RESET __HAL_RCC_AFIO_RELEASE_RESET 1311 /** 1312 * @} 1313 */ 1314 1315 #define IS_RCC_PLLSOURCE(__SOURCE__) (((__SOURCE__) == RCC_PLLSOURCE_HSI_DIV2) || \ 1316 ((__SOURCE__) == RCC_PLLSOURCE_HSE)) 1317 #define IS_RCC_OSCILLATORTYPE(__OSCILLATOR__) (((__OSCILLATOR__) == RCC_OSCILLATORTYPE_NONE) || \ 1318 (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_HSE) == RCC_OSCILLATORTYPE_HSE) || \ 1319 (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_HSI) == RCC_OSCILLATORTYPE_HSI) || \ 1320 (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_LSI) == RCC_OSCILLATORTYPE_LSI) || \ 1321 (((__OSCILLATOR__) & RCC_OSCILLATORTYPE_LSE) == RCC_OSCILLATORTYPE_LSE)) 1322 #define IS_RCC_HSE(__HSE__) (((__HSE__) == RCC_HSE_OFF) || ((__HSE__) == RCC_HSE_ON) || \ 1323 ((__HSE__) == RCC_HSE_BYPASS)) 1324 #define IS_RCC_LSE(__LSE__) (((__LSE__) == RCC_LSE_OFF) || ((__LSE__) == RCC_LSE_ON) || \ 1325 ((__LSE__) == RCC_LSE_BYPASS)) 1326 #define IS_RCC_HSI(__HSI__) (((__HSI__) == RCC_HSI_OFF) || ((__HSI__) == RCC_HSI_ON)) 1327 #define IS_RCC_CALIBRATION_VALUE(__VALUE__) ((__VALUE__) <= 0x1FU) 1328 #define IS_RCC_LSI(__LSI__) (((__LSI__) == RCC_LSI_OFF) || ((__LSI__) == RCC_LSI_ON)) 1329 #define IS_RCC_PLL(__PLL__) (((__PLL__) == RCC_PLL_NONE) || ((__PLL__) == RCC_PLL_OFF) || \ 1330 ((__PLL__) == RCC_PLL_ON)) 1331 1332 #define IS_RCC_CLOCKTYPE(CLK) ((((CLK) & RCC_CLOCKTYPE_SYSCLK) == RCC_CLOCKTYPE_SYSCLK) || \ 1333 (((CLK) & RCC_CLOCKTYPE_HCLK) == RCC_CLOCKTYPE_HCLK) || \ 1334 (((CLK) & RCC_CLOCKTYPE_PCLK1) == RCC_CLOCKTYPE_PCLK1) || \ 1335 (((CLK) & RCC_CLOCKTYPE_PCLK2) == RCC_CLOCKTYPE_PCLK2)) 1336 #define IS_RCC_SYSCLKSOURCE(__SOURCE__) (((__SOURCE__) == RCC_SYSCLKSOURCE_HSI) || \ 1337 ((__SOURCE__) == RCC_SYSCLKSOURCE_HSE) || \ 1338 ((__SOURCE__) == RCC_SYSCLKSOURCE_PLLCLK)) 1339 #define IS_RCC_SYSCLKSOURCE_STATUS(__SOURCE__) (((__SOURCE__) == RCC_SYSCLKSOURCE_STATUS_HSI) || \ 1340 ((__SOURCE__) == RCC_SYSCLKSOURCE_STATUS_HSE) || \ 1341 ((__SOURCE__) == RCC_SYSCLKSOURCE_STATUS_PLLCLK)) 1342 #define IS_RCC_HCLK(__HCLK__) (((__HCLK__) == RCC_SYSCLK_DIV1) || ((__HCLK__) == RCC_SYSCLK_DIV2) || \ 1343 ((__HCLK__) == RCC_SYSCLK_DIV4) || ((__HCLK__) == RCC_SYSCLK_DIV8) || \ 1344 ((__HCLK__) == RCC_SYSCLK_DIV16) || ((__HCLK__) == RCC_SYSCLK_DIV64) || \ 1345 ((__HCLK__) == RCC_SYSCLK_DIV128) || ((__HCLK__) == RCC_SYSCLK_DIV256) || \ 1346 ((__HCLK__) == RCC_SYSCLK_DIV512)) 1347 #define IS_RCC_PCLK(__PCLK__) (((__PCLK__) == RCC_HCLK_DIV1) || ((__PCLK__) == RCC_HCLK_DIV2) || \ 1348 ((__PCLK__) == RCC_HCLK_DIV4) || ((__PCLK__) == RCC_HCLK_DIV8) || \ 1349 ((__PCLK__) == RCC_HCLK_DIV16)) 1350 #define IS_RCC_MCO(__MCO__) ((__MCO__) == RCC_MCO) 1351 #define IS_RCC_MCODIV(__DIV__) (((__DIV__) == RCC_MCODIV_1)) 1352 #define IS_RCC_RTCCLKSOURCE(__SOURCE__) (((__SOURCE__) == RCC_RTCCLKSOURCE_NO_CLK) || \ 1353 ((__SOURCE__) == RCC_RTCCLKSOURCE_LSE) || \ 1354 ((__SOURCE__) == RCC_RTCCLKSOURCE_LSI) || \ 1355 ((__SOURCE__) == RCC_RTCCLKSOURCE_HSE_DIV128)) 1356 1357 /** 1358 * @} 1359 */ 1360 1361 /** 1362 * @} 1363 */ 1364 1365 /** 1366 * @} 1367 */ 1368 1369 #ifdef __cplusplus 1370 } 1371 #endif 1372 1373 #endif /* __STM32F1xx_HAL_RCC_H */ 1374 1375 1376