mbed official / mbed

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

Committer:
Kojto
Date:
Fri Aug 12 13:04:35 2016 +0200
Revision:
123:b0220dba8be7
Parent:
122:f9eeca106725
Release 123 of the mbed library

Changes:
- new targets: nucleo_f207zg, beetle, nrf51_dk, hexiwear,
nuvoton nuc472, vk rz a1h
- ST - fix timer interrupt handler, sleep api fix
- NXP - lpc15xx us ticker fix
- Nordic - analogin fixes, LF clock init addition, enable i2c async

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Kojto 90:cb3d968589d8 1 /**
Kojto 90:cb3d968589d8 2 ******************************************************************************
Kojto 90:cb3d968589d8 3 * @file stm32f3xx_hal_rcc_ex.h
Kojto 90:cb3d968589d8 4 * @author MCD Application Team
Kojto 123:b0220dba8be7 5 * @version V1.3.0
Kojto 123:b0220dba8be7 6 * @date 01-July-2016
Kojto 122:f9eeca106725 7 * @brief Header file of RCC HAL Extension module.
Kojto 90:cb3d968589d8 8 ******************************************************************************
Kojto 90:cb3d968589d8 9 * @attention
Kojto 90:cb3d968589d8 10 *
Kojto 122:f9eeca106725 11 * <h2><center>&copy; COPYRIGHT(c) 2016 STMicroelectronics</center></h2>
Kojto 90:cb3d968589d8 12 *
Kojto 90:cb3d968589d8 13 * Redistribution and use in source and binary forms, with or without modification,
Kojto 90:cb3d968589d8 14 * are permitted provided that the following conditions are met:
Kojto 90:cb3d968589d8 15 * 1. Redistributions of source code must retain the above copyright notice,
Kojto 90:cb3d968589d8 16 * this list of conditions and the following disclaimer.
Kojto 90:cb3d968589d8 17 * 2. Redistributions in binary form must reproduce the above copyright notice,
Kojto 90:cb3d968589d8 18 * this list of conditions and the following disclaimer in the documentation
Kojto 90:cb3d968589d8 19 * and/or other materials provided with the distribution.
Kojto 90:cb3d968589d8 20 * 3. Neither the name of STMicroelectronics nor the names of its contributors
Kojto 90:cb3d968589d8 21 * may be used to endorse or promote products derived from this software
Kojto 90:cb3d968589d8 22 * without specific prior written permission.
Kojto 90:cb3d968589d8 23 *
Kojto 90:cb3d968589d8 24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
Kojto 90:cb3d968589d8 25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
Kojto 90:cb3d968589d8 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
Kojto 90:cb3d968589d8 27 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
Kojto 90:cb3d968589d8 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
Kojto 90:cb3d968589d8 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
Kojto 90:cb3d968589d8 30 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
Kojto 90:cb3d968589d8 31 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
Kojto 90:cb3d968589d8 32 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Kojto 90:cb3d968589d8 33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Kojto 90:cb3d968589d8 34 *
Kojto 90:cb3d968589d8 35 ******************************************************************************
Kojto 90:cb3d968589d8 36 */
Kojto 90:cb3d968589d8 37
Kojto 90:cb3d968589d8 38 /* Define to prevent recursive inclusion -------------------------------------*/
Kojto 90:cb3d968589d8 39 #ifndef __STM32F3xx_HAL_RCC_EX_H
Kojto 90:cb3d968589d8 40 #define __STM32F3xx_HAL_RCC_EX_H
Kojto 90:cb3d968589d8 41
Kojto 90:cb3d968589d8 42 #ifdef __cplusplus
Kojto 90:cb3d968589d8 43 extern "C" {
Kojto 90:cb3d968589d8 44 #endif
Kojto 90:cb3d968589d8 45
Kojto 90:cb3d968589d8 46 /* Includes ------------------------------------------------------------------*/
Kojto 90:cb3d968589d8 47 #include "stm32f3xx_hal_def.h"
Kojto 90:cb3d968589d8 48
Kojto 90:cb3d968589d8 49 /** @addtogroup STM32F3xx_HAL_Driver
Kojto 90:cb3d968589d8 50 * @{
Kojto 90:cb3d968589d8 51 */
Kojto 90:cb3d968589d8 52
Kojto 90:cb3d968589d8 53 /** @addtogroup RCCEx
Kojto 90:cb3d968589d8 54 * @{
Kojto 90:cb3d968589d8 55 */
Kojto 90:cb3d968589d8 56
Kojto 122:f9eeca106725 57 /** @addtogroup RCCEx_Private_Macros
Kojto 122:f9eeca106725 58 * @{
Kojto 122:f9eeca106725 59 */
Kojto 122:f9eeca106725 60
Kojto 122:f9eeca106725 61 #if defined(RCC_CFGR_PLLNODIV)
Kojto 122:f9eeca106725 62 #define IS_RCC_MCO1SOURCE(SOURCE) (((SOURCE) == RCC_MCO1SOURCE_NOCLOCK) || \
Kojto 122:f9eeca106725 63 ((SOURCE) == RCC_MCO1SOURCE_LSI) || \
Kojto 122:f9eeca106725 64 ((SOURCE) == RCC_MCO1SOURCE_LSE) || \
Kojto 122:f9eeca106725 65 ((SOURCE) == RCC_MCO1SOURCE_SYSCLK) || \
Kojto 122:f9eeca106725 66 ((SOURCE) == RCC_MCO1SOURCE_HSI) || \
Kojto 122:f9eeca106725 67 ((SOURCE) == RCC_MCO1SOURCE_HSE) || \
Kojto 122:f9eeca106725 68 ((SOURCE) == RCC_MCO1SOURCE_PLLCLK) || \
Kojto 122:f9eeca106725 69 ((SOURCE) == RCC_MCO1SOURCE_PLLCLK_DIV2))
Kojto 122:f9eeca106725 70 #else
Kojto 122:f9eeca106725 71 #define IS_RCC_MCO1SOURCE(SOURCE) (((SOURCE) == RCC_MCO1SOURCE_NOCLOCK) || \
Kojto 122:f9eeca106725 72 ((SOURCE) == RCC_MCO1SOURCE_LSI) || \
Kojto 122:f9eeca106725 73 ((SOURCE) == RCC_MCO1SOURCE_LSE) || \
Kojto 122:f9eeca106725 74 ((SOURCE) == RCC_MCO1SOURCE_SYSCLK) || \
Kojto 122:f9eeca106725 75 ((SOURCE) == RCC_MCO1SOURCE_HSI) || \
Kojto 122:f9eeca106725 76 ((SOURCE) == RCC_MCO1SOURCE_HSE) || \
Kojto 122:f9eeca106725 77 ((SOURCE) == RCC_MCO1SOURCE_PLLCLK_DIV2))
Kojto 122:f9eeca106725 78 #endif /* RCC_CFGR_PLLNODIV */
Kojto 122:f9eeca106725 79
Kojto 122:f9eeca106725 80 #if defined(STM32F301x8) || defined(STM32F318xx)
Kojto 122:f9eeca106725 81 #define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | \
Kojto 122:f9eeca106725 82 RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_I2C2 | \
Kojto 122:f9eeca106725 83 RCC_PERIPHCLK_ADC1 | RCC_PERIPHCLK_I2S | \
Kojto 122:f9eeca106725 84 RCC_PERIPHCLK_I2C3 | RCC_PERIPHCLK_TIM1 | \
Kojto 122:f9eeca106725 85 RCC_PERIPHCLK_TIM15 | RCC_PERIPHCLK_TIM16 | \
Kojto 122:f9eeca106725 86 RCC_PERIPHCLK_TIM17 | RCC_PERIPHCLK_RTC))
Kojto 122:f9eeca106725 87 #endif /* STM32F301x8 || STM32F318xx */
Kojto 122:f9eeca106725 88 #if defined(STM32F302x8)
Kojto 122:f9eeca106725 89 #define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | \
Kojto 122:f9eeca106725 90 RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_I2C2 | \
Kojto 122:f9eeca106725 91 RCC_PERIPHCLK_ADC1 | RCC_PERIPHCLK_I2S | \
Kojto 122:f9eeca106725 92 RCC_PERIPHCLK_I2C3 | RCC_PERIPHCLK_TIM1 | \
Kojto 122:f9eeca106725 93 RCC_PERIPHCLK_RTC | RCC_PERIPHCLK_USB | \
Kojto 122:f9eeca106725 94 RCC_PERIPHCLK_TIM15 | RCC_PERIPHCLK_TIM16 | \
Kojto 122:f9eeca106725 95 RCC_PERIPHCLK_TIM17))
Kojto 122:f9eeca106725 96 #endif /* STM32F302x8 */
Kojto 122:f9eeca106725 97 #if defined(STM32F302xC)
Kojto 122:f9eeca106725 98 #define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_USART2 | RCC_PERIPHCLK_USART3 | \
Kojto 122:f9eeca106725 99 RCC_PERIPHCLK_UART4 | RCC_PERIPHCLK_UART5 | \
Kojto 122:f9eeca106725 100 RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_I2C2 | \
Kojto 122:f9eeca106725 101 RCC_PERIPHCLK_ADC12 | RCC_PERIPHCLK_I2S | \
Kojto 122:f9eeca106725 102 RCC_PERIPHCLK_TIM1 | RCC_PERIPHCLK_RTC | \
Kojto 122:f9eeca106725 103 RCC_PERIPHCLK_USB))
Kojto 122:f9eeca106725 104 #endif /* STM32F302xC */
Kojto 122:f9eeca106725 105 #if defined(STM32F303xC)
Kojto 122:f9eeca106725 106 #define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_USART2 | RCC_PERIPHCLK_USART3 | \
Kojto 122:f9eeca106725 107 RCC_PERIPHCLK_UART4 | RCC_PERIPHCLK_UART5 | \
Kojto 122:f9eeca106725 108 RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_I2C2 | \
Kojto 122:f9eeca106725 109 RCC_PERIPHCLK_ADC12 | RCC_PERIPHCLK_ADC34 | \
Kojto 122:f9eeca106725 110 RCC_PERIPHCLK_I2S | RCC_PERIPHCLK_TIM1 | \
Kojto 122:f9eeca106725 111 RCC_PERIPHCLK_TIM8 | RCC_PERIPHCLK_RTC | \
Kojto 122:f9eeca106725 112 RCC_PERIPHCLK_USB))
Kojto 122:f9eeca106725 113 #endif /* STM32F303xC */
Kojto 122:f9eeca106725 114 #if defined(STM32F302xE)
Kojto 122:f9eeca106725 115 #define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_USART2 | RCC_PERIPHCLK_USART3 | \
Kojto 122:f9eeca106725 116 RCC_PERIPHCLK_UART4 | RCC_PERIPHCLK_UART5 | \
Kojto 122:f9eeca106725 117 RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_I2C2 | \
Kojto 122:f9eeca106725 118 RCC_PERIPHCLK_ADC12 | RCC_PERIPHCLK_I2S | \
Kojto 122:f9eeca106725 119 RCC_PERIPHCLK_TIM1 | RCC_PERIPHCLK_RTC | \
Kojto 122:f9eeca106725 120 RCC_PERIPHCLK_USB | RCC_PERIPHCLK_I2C3 | \
Kojto 122:f9eeca106725 121 RCC_PERIPHCLK_TIM2 | RCC_PERIPHCLK_TIM34 | \
Kojto 122:f9eeca106725 122 RCC_PERIPHCLK_TIM15 | RCC_PERIPHCLK_TIM16 | \
Kojto 122:f9eeca106725 123 RCC_PERIPHCLK_TIM17))
Kojto 122:f9eeca106725 124 #endif /* STM32F302xE */
Kojto 122:f9eeca106725 125 #if defined(STM32F303xE)
Kojto 122:f9eeca106725 126 #define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_USART2 | RCC_PERIPHCLK_USART3 | \
Kojto 122:f9eeca106725 127 RCC_PERIPHCLK_UART4 | RCC_PERIPHCLK_UART5 | \
Kojto 122:f9eeca106725 128 RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_I2C2 | \
Kojto 122:f9eeca106725 129 RCC_PERIPHCLK_ADC12 | RCC_PERIPHCLK_ADC34 | \
Kojto 122:f9eeca106725 130 RCC_PERIPHCLK_I2S | RCC_PERIPHCLK_TIM1 | \
Kojto 122:f9eeca106725 131 RCC_PERIPHCLK_TIM8 | RCC_PERIPHCLK_RTC | \
Kojto 122:f9eeca106725 132 RCC_PERIPHCLK_USB | RCC_PERIPHCLK_I2C3 | \
Kojto 122:f9eeca106725 133 RCC_PERIPHCLK_TIM2 | RCC_PERIPHCLK_TIM34 | \
Kojto 122:f9eeca106725 134 RCC_PERIPHCLK_TIM15 | RCC_PERIPHCLK_TIM16 | \
Kojto 122:f9eeca106725 135 RCC_PERIPHCLK_TIM17 | RCC_PERIPHCLK_TIM20))
Kojto 122:f9eeca106725 136 #endif /* STM32F303xE */
Kojto 122:f9eeca106725 137 #if defined(STM32F398xx)
Kojto 122:f9eeca106725 138 #define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_USART2 | RCC_PERIPHCLK_USART3 | \
Kojto 122:f9eeca106725 139 RCC_PERIPHCLK_UART4 | RCC_PERIPHCLK_UART5 | \
Kojto 122:f9eeca106725 140 RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_I2C2 | \
Kojto 122:f9eeca106725 141 RCC_PERIPHCLK_ADC12 | RCC_PERIPHCLK_ADC34 | \
Kojto 122:f9eeca106725 142 RCC_PERIPHCLK_I2S | RCC_PERIPHCLK_TIM1 | \
Kojto 122:f9eeca106725 143 RCC_PERIPHCLK_TIM8 | RCC_PERIPHCLK_RTC | \
Kojto 122:f9eeca106725 144 RCC_PERIPHCLK_I2C3 | RCC_PERIPHCLK_TIM2 | \
Kojto 122:f9eeca106725 145 RCC_PERIPHCLK_TIM34 | RCC_PERIPHCLK_TIM15 | \
Kojto 122:f9eeca106725 146 RCC_PERIPHCLK_TIM16 | RCC_PERIPHCLK_TIM17 | \
Kojto 122:f9eeca106725 147 RCC_PERIPHCLK_TIM20))
Kojto 122:f9eeca106725 148 #endif /* STM32F398xx */
Kojto 122:f9eeca106725 149 #if defined(STM32F358xx)
Kojto 122:f9eeca106725 150 #define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_USART2 | RCC_PERIPHCLK_USART3 | \
Kojto 122:f9eeca106725 151 RCC_PERIPHCLK_UART4 | RCC_PERIPHCLK_UART5 | \
Kojto 122:f9eeca106725 152 RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_I2C2 | \
Kojto 122:f9eeca106725 153 RCC_PERIPHCLK_ADC12 | RCC_PERIPHCLK_ADC34 | \
Kojto 122:f9eeca106725 154 RCC_PERIPHCLK_I2S | RCC_PERIPHCLK_TIM1 | \
Kojto 122:f9eeca106725 155 RCC_PERIPHCLK_TIM8 | RCC_PERIPHCLK_RTC))
Kojto 122:f9eeca106725 156 #endif /* STM32F358xx */
Kojto 122:f9eeca106725 157 #if defined(STM32F303x8)
Kojto 122:f9eeca106725 158 #define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | \
Kojto 122:f9eeca106725 159 RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_ADC12 | \
Kojto 122:f9eeca106725 160 RCC_PERIPHCLK_TIM1 | RCC_PERIPHCLK_RTC))
Kojto 122:f9eeca106725 161 #endif /* STM32F303x8 */
Kojto 122:f9eeca106725 162 #if defined(STM32F334x8)
Kojto 122:f9eeca106725 163 #define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | \
Kojto 122:f9eeca106725 164 RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_ADC12 | \
Kojto 122:f9eeca106725 165 RCC_PERIPHCLK_TIM1 | RCC_PERIPHCLK_HRTIM1 | \
Kojto 122:f9eeca106725 166 RCC_PERIPHCLK_RTC))
Kojto 122:f9eeca106725 167 #endif /* STM32F334x8 */
Kojto 122:f9eeca106725 168 #if defined(STM32F328xx)
Kojto 122:f9eeca106725 169 #define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | \
Kojto 122:f9eeca106725 170 RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_ADC12 | \
Kojto 122:f9eeca106725 171 RCC_PERIPHCLK_TIM1 | RCC_PERIPHCLK_RTC))
Kojto 122:f9eeca106725 172 #endif /* STM32F328xx */
Kojto 122:f9eeca106725 173 #if defined(STM32F373xC)
Kojto 122:f9eeca106725 174 #define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_USART2 | RCC_PERIPHCLK_USART3 | \
Kojto 122:f9eeca106725 175 RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_I2C2 | \
Kojto 122:f9eeca106725 176 RCC_PERIPHCLK_ADC1 | RCC_PERIPHCLK_SDADC | \
Kojto 122:f9eeca106725 177 RCC_PERIPHCLK_CEC | RCC_PERIPHCLK_RTC | \
Kojto 122:f9eeca106725 178 RCC_PERIPHCLK_USB))
Kojto 122:f9eeca106725 179 #endif /* STM32F373xC */
Kojto 122:f9eeca106725 180 #if defined(STM32F378xx)
Kojto 122:f9eeca106725 181 #define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_USART2 | RCC_PERIPHCLK_USART3 | \
Kojto 122:f9eeca106725 182 RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_I2C2 | \
Kojto 122:f9eeca106725 183 RCC_PERIPHCLK_ADC1 | RCC_PERIPHCLK_SDADC | \
Kojto 122:f9eeca106725 184 RCC_PERIPHCLK_CEC | RCC_PERIPHCLK_RTC))
Kojto 122:f9eeca106725 185 #endif /* STM32F378xx */
Kojto 122:f9eeca106725 186
Kojto 122:f9eeca106725 187 #if defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)
Kojto 122:f9eeca106725 188 #define IS_RCC_USART1CLKSOURCE(SOURCE) (((SOURCE) == RCC_USART1CLKSOURCE_PCLK1) || \
Kojto 122:f9eeca106725 189 ((SOURCE) == RCC_USART1CLKSOURCE_SYSCLK) || \
Kojto 122:f9eeca106725 190 ((SOURCE) == RCC_USART1CLKSOURCE_LSE) || \
Kojto 122:f9eeca106725 191 ((SOURCE) == RCC_USART1CLKSOURCE_HSI))
Kojto 122:f9eeca106725 192 #define IS_RCC_I2C2CLKSOURCE(SOURCE) (((SOURCE) == RCC_I2C2CLKSOURCE_HSI) || \
Kojto 122:f9eeca106725 193 ((SOURCE) == RCC_I2C2CLKSOURCE_SYSCLK))
Kojto 122:f9eeca106725 194 #define IS_RCC_I2C3CLKSOURCE(SOURCE) (((SOURCE) == RCC_I2C3CLKSOURCE_HSI) || \
Kojto 122:f9eeca106725 195 ((SOURCE) == RCC_I2C3CLKSOURCE_SYSCLK))
Kojto 122:f9eeca106725 196 #define IS_RCC_ADC1PLLCLK_DIV(ADCCLK) (((ADCCLK) == RCC_ADC1PLLCLK_OFF) || ((ADCCLK) == RCC_ADC1PLLCLK_DIV1) || \
Kojto 122:f9eeca106725 197 ((ADCCLK) == RCC_ADC1PLLCLK_DIV2) || ((ADCCLK) == RCC_ADC1PLLCLK_DIV4) || \
Kojto 122:f9eeca106725 198 ((ADCCLK) == RCC_ADC1PLLCLK_DIV6) || ((ADCCLK) == RCC_ADC1PLLCLK_DIV8) || \
Kojto 122:f9eeca106725 199 ((ADCCLK) == RCC_ADC1PLLCLK_DIV10) || ((ADCCLK) == RCC_ADC1PLLCLK_DIV12) || \
Kojto 122:f9eeca106725 200 ((ADCCLK) == RCC_ADC1PLLCLK_DIV16) || ((ADCCLK) == RCC_ADC1PLLCLK_DIV32) || \
Kojto 122:f9eeca106725 201 ((ADCCLK) == RCC_ADC1PLLCLK_DIV64) || ((ADCCLK) == RCC_ADC1PLLCLK_DIV128) || \
Kojto 122:f9eeca106725 202 ((ADCCLK) == RCC_ADC1PLLCLK_DIV256))
Kojto 122:f9eeca106725 203 #define IS_RCC_I2SCLKSOURCE(SOURCE) (((SOURCE) == RCC_I2SCLKSOURCE_SYSCLK) || \
Kojto 122:f9eeca106725 204 ((SOURCE) == RCC_I2SCLKSOURCE_EXT))
Kojto 122:f9eeca106725 205 #define IS_RCC_TIM1CLKSOURCE(SOURCE) (((SOURCE) == RCC_TIM1CLK_HCLK) || \
Kojto 122:f9eeca106725 206 ((SOURCE) == RCC_TIM1CLK_PLLCLK))
Kojto 122:f9eeca106725 207 #define IS_RCC_TIM15CLKSOURCE(SOURCE) (((SOURCE) == RCC_TIM15CLK_HCLK) || \
Kojto 122:f9eeca106725 208 ((SOURCE) == RCC_TIM15CLK_PLLCLK))
Kojto 122:f9eeca106725 209 #define IS_RCC_TIM16CLKSOURCE(SOURCE) (((SOURCE) == RCC_TIM16CLK_HCLK) || \
Kojto 122:f9eeca106725 210 ((SOURCE) == RCC_TIM16CLK_PLLCLK))
Kojto 122:f9eeca106725 211 #define IS_RCC_TIM17CLKSOURCE(SOURCE) (((SOURCE) == RCC_TIM17CLK_HCLK) || \
Kojto 122:f9eeca106725 212 ((SOURCE) == RCC_TIM17CLK_PLLCLK))
Kojto 122:f9eeca106725 213 #endif /* STM32F301x8 || STM32F302x8 || STM32F318xx */
Kojto 122:f9eeca106725 214 #if defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 215 #define IS_RCC_USART1CLKSOURCE(SOURCE) (((SOURCE) == RCC_USART1CLKSOURCE_PCLK2) || \
Kojto 122:f9eeca106725 216 ((SOURCE) == RCC_USART1CLKSOURCE_SYSCLK) || \
Kojto 122:f9eeca106725 217 ((SOURCE) == RCC_USART1CLKSOURCE_LSE) || \
Kojto 122:f9eeca106725 218 ((SOURCE) == RCC_USART1CLKSOURCE_HSI))
Kojto 122:f9eeca106725 219 #define IS_RCC_I2C2CLKSOURCE(SOURCE) (((SOURCE) == RCC_I2C2CLKSOURCE_HSI) || \
Kojto 122:f9eeca106725 220 ((SOURCE) == RCC_I2C2CLKSOURCE_SYSCLK))
Kojto 122:f9eeca106725 221 #define IS_RCC_ADC12PLLCLK_DIV(ADCCLK) (((ADCCLK) == RCC_ADC12PLLCLK_OFF) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV1) || \
Kojto 122:f9eeca106725 222 ((ADCCLK) == RCC_ADC12PLLCLK_DIV2) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV4) || \
Kojto 122:f9eeca106725 223 ((ADCCLK) == RCC_ADC12PLLCLK_DIV6) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV8) || \
Kojto 122:f9eeca106725 224 ((ADCCLK) == RCC_ADC12PLLCLK_DIV10) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV12) || \
Kojto 122:f9eeca106725 225 ((ADCCLK) == RCC_ADC12PLLCLK_DIV16) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV32) || \
Kojto 122:f9eeca106725 226 ((ADCCLK) == RCC_ADC12PLLCLK_DIV64) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV128) || \
Kojto 122:f9eeca106725 227 ((ADCCLK) == RCC_ADC12PLLCLK_DIV256))
Kojto 122:f9eeca106725 228 #define IS_RCC_I2SCLKSOURCE(SOURCE) (((SOURCE) == RCC_I2SCLKSOURCE_SYSCLK) || \
Kojto 122:f9eeca106725 229 ((SOURCE) == RCC_I2SCLKSOURCE_EXT))
Kojto 122:f9eeca106725 230 #define IS_RCC_TIM1CLKSOURCE(SOURCE) (((SOURCE) == RCC_TIM1CLK_HCLK) || \
Kojto 122:f9eeca106725 231 ((SOURCE) == RCC_TIM1CLK_PLLCLK))
Kojto 122:f9eeca106725 232 #define IS_RCC_UART4CLKSOURCE(SOURCE) (((SOURCE) == RCC_UART4CLKSOURCE_PCLK1) || \
Kojto 122:f9eeca106725 233 ((SOURCE) == RCC_UART4CLKSOURCE_SYSCLK) || \
Kojto 122:f9eeca106725 234 ((SOURCE) == RCC_UART4CLKSOURCE_LSE) || \
Kojto 122:f9eeca106725 235 ((SOURCE) == RCC_UART4CLKSOURCE_HSI))
Kojto 122:f9eeca106725 236 #define IS_RCC_UART5CLKSOURCE(SOURCE) (((SOURCE) == RCC_UART5CLKSOURCE_PCLK1) || \
Kojto 122:f9eeca106725 237 ((SOURCE) == RCC_UART5CLKSOURCE_SYSCLK) || \
Kojto 122:f9eeca106725 238 ((SOURCE) == RCC_UART5CLKSOURCE_LSE) || \
Kojto 122:f9eeca106725 239 ((SOURCE) == RCC_UART5CLKSOURCE_HSI))
Kojto 122:f9eeca106725 240 #endif /* STM32F302xC || STM32F303xC || STM32F358xx */
Kojto 90:cb3d968589d8 241 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 122:f9eeca106725 242 #define IS_RCC_USART1CLKSOURCE(SOURCE) (((SOURCE) == RCC_USART1CLKSOURCE_PCLK2) || \
Kojto 122:f9eeca106725 243 ((SOURCE) == RCC_USART1CLKSOURCE_SYSCLK) || \
Kojto 122:f9eeca106725 244 ((SOURCE) == RCC_USART1CLKSOURCE_LSE) || \
Kojto 122:f9eeca106725 245 ((SOURCE) == RCC_USART1CLKSOURCE_HSI))
Kojto 122:f9eeca106725 246 #define IS_RCC_I2C2CLKSOURCE(SOURCE) (((SOURCE) == RCC_I2C2CLKSOURCE_HSI) || \
Kojto 122:f9eeca106725 247 ((SOURCE) == RCC_I2C2CLKSOURCE_SYSCLK))
Kojto 122:f9eeca106725 248 #define IS_RCC_I2C3CLKSOURCE(SOURCE) (((SOURCE) == RCC_I2C3CLKSOURCE_HSI) || \
Kojto 122:f9eeca106725 249 ((SOURCE) == RCC_I2C3CLKSOURCE_SYSCLK))
Kojto 122:f9eeca106725 250 #define IS_RCC_ADC12PLLCLK_DIV(ADCCLK) (((ADCCLK) == RCC_ADC12PLLCLK_OFF) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV1) || \
Kojto 122:f9eeca106725 251 ((ADCCLK) == RCC_ADC12PLLCLK_DIV2) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV4) || \
Kojto 122:f9eeca106725 252 ((ADCCLK) == RCC_ADC12PLLCLK_DIV6) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV8) || \
Kojto 122:f9eeca106725 253 ((ADCCLK) == RCC_ADC12PLLCLK_DIV10) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV12) || \
Kojto 122:f9eeca106725 254 ((ADCCLK) == RCC_ADC12PLLCLK_DIV16) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV32) || \
Kojto 122:f9eeca106725 255 ((ADCCLK) == RCC_ADC12PLLCLK_DIV64) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV128) || \
Kojto 122:f9eeca106725 256 ((ADCCLK) == RCC_ADC12PLLCLK_DIV256))
Kojto 122:f9eeca106725 257 #define IS_RCC_I2SCLKSOURCE(SOURCE) (((SOURCE) == RCC_I2SCLKSOURCE_SYSCLK) || \
Kojto 122:f9eeca106725 258 ((SOURCE) == RCC_I2SCLKSOURCE_EXT))
Kojto 122:f9eeca106725 259 #define IS_RCC_TIM1CLKSOURCE(SOURCE) (((SOURCE) == RCC_TIM1CLK_HCLK) || \
Kojto 122:f9eeca106725 260 ((SOURCE) == RCC_TIM1CLK_PLLCLK))
Kojto 122:f9eeca106725 261 #define IS_RCC_TIM2CLKSOURCE(SOURCE) (((SOURCE) == RCC_TIM2CLK_HCLK) || \
Kojto 122:f9eeca106725 262 ((SOURCE) == RCC_TIM2CLK_PLLCLK))
Kojto 122:f9eeca106725 263 #define IS_RCC_TIM3CLKSOURCE(SOURCE) (((SOURCE) == RCC_TIM34CLK_HCLK) || \
Kojto 122:f9eeca106725 264 ((SOURCE) == RCC_TIM34CLK_PLLCLK))
Kojto 122:f9eeca106725 265 #define IS_RCC_TIM15CLKSOURCE(SOURCE) (((SOURCE) == RCC_TIM15CLK_HCLK) || \
Kojto 122:f9eeca106725 266 ((SOURCE) == RCC_TIM15CLK_PLLCLK))
Kojto 122:f9eeca106725 267 #define IS_RCC_TIM16CLKSOURCE(SOURCE) (((SOURCE) == RCC_TIM16CLK_HCLK) || \
Kojto 122:f9eeca106725 268 ((SOURCE) == RCC_TIM16CLK_PLLCLK))
Kojto 122:f9eeca106725 269 #define IS_RCC_TIM17CLKSOURCE(SOURCE) (((SOURCE) == RCC_TIM17CLK_HCLK) || \
Kojto 122:f9eeca106725 270 ((SOURCE) == RCC_TIM17CLK_PLLCLK))
Kojto 122:f9eeca106725 271 #define IS_RCC_UART4CLKSOURCE(SOURCE) (((SOURCE) == RCC_UART4CLKSOURCE_PCLK1) || \
Kojto 122:f9eeca106725 272 ((SOURCE) == RCC_UART4CLKSOURCE_SYSCLK) || \
Kojto 122:f9eeca106725 273 ((SOURCE) == RCC_UART4CLKSOURCE_LSE) || \
Kojto 122:f9eeca106725 274 ((SOURCE) == RCC_UART4CLKSOURCE_HSI))
Kojto 122:f9eeca106725 275 #define IS_RCC_UART5CLKSOURCE(SOURCE) (((SOURCE) == RCC_UART5CLKSOURCE_PCLK1) || \
Kojto 122:f9eeca106725 276 ((SOURCE) == RCC_UART5CLKSOURCE_SYSCLK) || \
Kojto 122:f9eeca106725 277 ((SOURCE) == RCC_UART5CLKSOURCE_LSE) || \
Kojto 122:f9eeca106725 278 ((SOURCE) == RCC_UART5CLKSOURCE_HSI))
Kojto 122:f9eeca106725 279 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
Kojto 122:f9eeca106725 280 #if defined(STM32F303xE) || defined(STM32F398xx)
Kojto 122:f9eeca106725 281 #define IS_RCC_TIM20CLKSOURCE(SOURCE) (((SOURCE) == RCC_TIM20CLK_HCLK) || \
Kojto 122:f9eeca106725 282 ((SOURCE) == RCC_TIM20CLK_PLLCLK))
Kojto 122:f9eeca106725 283 #endif /* STM32F303xE || STM32F398xx */
Kojto 122:f9eeca106725 284 #if defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 285 || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 286 #define IS_RCC_ADC34PLLCLK_DIV(ADCCLK) (((ADCCLK) == RCC_ADC34PLLCLK_OFF) || ((ADCCLK) == RCC_ADC34PLLCLK_DIV1) || \
Kojto 122:f9eeca106725 287 ((ADCCLK) == RCC_ADC34PLLCLK_DIV2) || ((ADCCLK) == RCC_ADC34PLLCLK_DIV4) || \
Kojto 122:f9eeca106725 288 ((ADCCLK) == RCC_ADC34PLLCLK_DIV6) || ((ADCCLK) == RCC_ADC34PLLCLK_DIV8) || \
Kojto 122:f9eeca106725 289 ((ADCCLK) == RCC_ADC34PLLCLK_DIV10) || ((ADCCLK) == RCC_ADC34PLLCLK_DIV12) || \
Kojto 122:f9eeca106725 290 ((ADCCLK) == RCC_ADC34PLLCLK_DIV16) || ((ADCCLK) == RCC_ADC34PLLCLK_DIV32) || \
Kojto 122:f9eeca106725 291 ((ADCCLK) == RCC_ADC34PLLCLK_DIV64) || ((ADCCLK) == RCC_ADC34PLLCLK_DIV128) || \
Kojto 122:f9eeca106725 292 ((ADCCLK) == RCC_ADC34PLLCLK_DIV256))
Kojto 122:f9eeca106725 293 #define IS_RCC_TIM8CLKSOURCE(SOURCE) (((SOURCE) == RCC_TIM8CLK_HCLK) || \
Kojto 122:f9eeca106725 294 ((SOURCE) == RCC_TIM8CLK_PLLCLK))
Kojto 122:f9eeca106725 295 #endif /* STM32F303xC || STM32F303xE || STM32F398xx || STM32F358xx */
Kojto 122:f9eeca106725 296 #if defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)
Kojto 122:f9eeca106725 297 #define IS_RCC_USART1CLKSOURCE(SOURCE) (((SOURCE) == RCC_USART1CLKSOURCE_PCLK1) || \
Kojto 122:f9eeca106725 298 ((SOURCE) == RCC_USART1CLKSOURCE_SYSCLK) || \
Kojto 122:f9eeca106725 299 ((SOURCE) == RCC_USART1CLKSOURCE_LSE) || \
Kojto 122:f9eeca106725 300 ((SOURCE) == RCC_USART1CLKSOURCE_HSI))
Kojto 122:f9eeca106725 301 #define IS_RCC_ADC12PLLCLK_DIV(ADCCLK) (((ADCCLK) == RCC_ADC12PLLCLK_OFF) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV1) || \
Kojto 122:f9eeca106725 302 ((ADCCLK) == RCC_ADC12PLLCLK_DIV2) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV4) || \
Kojto 122:f9eeca106725 303 ((ADCCLK) == RCC_ADC12PLLCLK_DIV6) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV8) || \
Kojto 122:f9eeca106725 304 ((ADCCLK) == RCC_ADC12PLLCLK_DIV10) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV12) || \
Kojto 122:f9eeca106725 305 ((ADCCLK) == RCC_ADC12PLLCLK_DIV16) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV32) || \
Kojto 122:f9eeca106725 306 ((ADCCLK) == RCC_ADC12PLLCLK_DIV64) || ((ADCCLK) == RCC_ADC12PLLCLK_DIV128) || \
Kojto 122:f9eeca106725 307 ((ADCCLK) == RCC_ADC12PLLCLK_DIV256))
Kojto 122:f9eeca106725 308 #define IS_RCC_TIM1CLKSOURCE(SOURCE) (((SOURCE) == RCC_TIM1CLK_HCLK) || \
Kojto 122:f9eeca106725 309 ((SOURCE) == RCC_TIM1CLK_PLLCLK))
Kojto 122:f9eeca106725 310 #endif /* STM32F303x8 || STM32F334x8 || STM32F328xx */
Kojto 122:f9eeca106725 311 #if defined(STM32F334x8)
Kojto 122:f9eeca106725 312 #define IS_RCC_HRTIM1CLKSOURCE(SOURCE) (((SOURCE) == RCC_HRTIM1CLK_HCLK) || \
Kojto 122:f9eeca106725 313 ((SOURCE) == RCC_HRTIM1CLK_PLLCLK))
Kojto 122:f9eeca106725 314 #endif /* STM32F334x8 */
Kojto 122:f9eeca106725 315 #if defined(STM32F373xC) || defined(STM32F378xx)
Kojto 122:f9eeca106725 316 #define IS_RCC_USART1CLKSOURCE(SOURCE) (((SOURCE) == RCC_USART1CLKSOURCE_PCLK2) || \
Kojto 122:f9eeca106725 317 ((SOURCE) == RCC_USART1CLKSOURCE_SYSCLK) || \
Kojto 122:f9eeca106725 318 ((SOURCE) == RCC_USART1CLKSOURCE_LSE) || \
Kojto 122:f9eeca106725 319 ((SOURCE) == RCC_USART1CLKSOURCE_HSI))
Kojto 122:f9eeca106725 320 #define IS_RCC_I2C2CLKSOURCE(SOURCE) (((SOURCE) == RCC_I2C2CLKSOURCE_HSI) || \
Kojto 122:f9eeca106725 321 ((SOURCE) == RCC_I2C2CLKSOURCE_SYSCLK))
Kojto 122:f9eeca106725 322 #define IS_RCC_ADC1PCLK2_DIV(ADCCLK) (((ADCCLK) == RCC_ADC1PCLK2_DIV2) || ((ADCCLK) == RCC_ADC1PCLK2_DIV4) || \
Kojto 122:f9eeca106725 323 ((ADCCLK) == RCC_ADC1PCLK2_DIV6) || ((ADCCLK) == RCC_ADC1PCLK2_DIV8))
Kojto 122:f9eeca106725 324 #define IS_RCC_CECCLKSOURCE(SOURCE) (((SOURCE) == RCC_CECCLKSOURCE_HSI) || \
Kojto 122:f9eeca106725 325 ((SOURCE) == RCC_CECCLKSOURCE_LSE))
Kojto 122:f9eeca106725 326 #define IS_RCC_SDADCSYSCLK_DIV(DIV) (((DIV) == RCC_SDADCSYSCLK_DIV1) || ((DIV) == RCC_SDADCSYSCLK_DIV2) || \
Kojto 122:f9eeca106725 327 ((DIV) == RCC_SDADCSYSCLK_DIV4) || ((DIV) == RCC_SDADCSYSCLK_DIV6) || \
Kojto 122:f9eeca106725 328 ((DIV) == RCC_SDADCSYSCLK_DIV8) || ((DIV) == RCC_SDADCSYSCLK_DIV10) || \
Kojto 122:f9eeca106725 329 ((DIV) == RCC_SDADCSYSCLK_DIV12) || ((DIV) == RCC_SDADCSYSCLK_DIV14) || \
Kojto 122:f9eeca106725 330 ((DIV) == RCC_SDADCSYSCLK_DIV16) || ((DIV) == RCC_SDADCSYSCLK_DIV20) || \
Kojto 122:f9eeca106725 331 ((DIV) == RCC_SDADCSYSCLK_DIV24) || ((DIV) == RCC_SDADCSYSCLK_DIV28) || \
Kojto 122:f9eeca106725 332 ((DIV) == RCC_SDADCSYSCLK_DIV32) || ((DIV) == RCC_SDADCSYSCLK_DIV36) || \
Kojto 122:f9eeca106725 333 ((DIV) == RCC_SDADCSYSCLK_DIV40) || ((DIV) == RCC_SDADCSYSCLK_DIV44) || \
Kojto 122:f9eeca106725 334 ((DIV) == RCC_SDADCSYSCLK_DIV48))
Kojto 122:f9eeca106725 335 #endif /* STM32F373xC || STM32F378xx */
Kojto 122:f9eeca106725 336 #if defined(STM32F302xE) || defined(STM32F303xE)\
Kojto 122:f9eeca106725 337 || defined(STM32F302xC) || defined(STM32F303xC)\
Kojto 122:f9eeca106725 338 || defined(STM32F302x8) \
Kojto 122:f9eeca106725 339 || defined(STM32F373xC)
Kojto 122:f9eeca106725 340 #define IS_RCC_USBCLKSOURCE(SOURCE) (((SOURCE) == RCC_USBCLKSOURCE_PLL) || \
Kojto 122:f9eeca106725 341 ((SOURCE) == RCC_USBCLKSOURCE_PLL_DIV1_5))
Kojto 122:f9eeca106725 342 #endif /* STM32F302xE || STM32F303xE || */
Kojto 122:f9eeca106725 343 /* STM32F302xC || STM32F303xC || */
Kojto 122:f9eeca106725 344 /* STM32F302x8 || */
Kojto 122:f9eeca106725 345 /* STM32F373xC */
Kojto 122:f9eeca106725 346 #if defined(RCC_CFGR_MCOPRE)
Kojto 122:f9eeca106725 347 #define IS_RCC_MCODIV(DIV) (((DIV) == RCC_MCODIV_1) || ((DIV) == RCC_MCODIV_2) || \
Kojto 122:f9eeca106725 348 ((DIV) == RCC_MCODIV_4) || ((DIV) == RCC_MCODIV_8) || \
Kojto 122:f9eeca106725 349 ((DIV) == RCC_MCODIV_16) || ((DIV) == RCC_MCODIV_32) || \
Kojto 122:f9eeca106725 350 ((DIV) == RCC_MCODIV_64) || ((DIV) == RCC_MCODIV_128))
Kojto 122:f9eeca106725 351 #else
Kojto 122:f9eeca106725 352 #define IS_RCC_MCODIV(DIV) (((DIV) == RCC_MCODIV_1))
Kojto 122:f9eeca106725 353 #endif /* RCC_CFGR_MCOPRE */
Kojto 122:f9eeca106725 354
Kojto 122:f9eeca106725 355 #define IS_RCC_LSE_DRIVE(__DRIVE__) (((__DRIVE__) == RCC_LSEDRIVE_LOW) || \
Kojto 122:f9eeca106725 356 ((__DRIVE__) == RCC_LSEDRIVE_MEDIUMLOW) || \
Kojto 122:f9eeca106725 357 ((__DRIVE__) == RCC_LSEDRIVE_MEDIUMHIGH) || \
Kojto 122:f9eeca106725 358 ((__DRIVE__) == RCC_LSEDRIVE_HIGH))
Kojto 90:cb3d968589d8 359
Kojto 90:cb3d968589d8 360 /**
Kojto 122:f9eeca106725 361 * @}
Kojto 90:cb3d968589d8 362 */
Kojto 122:f9eeca106725 363
Kojto 122:f9eeca106725 364 /* Exported types ------------------------------------------------------------*/
Kojto 122:f9eeca106725 365 /** @defgroup RCCEx_Exported_Types RCCEx Exported Types
Kojto 122:f9eeca106725 366 * @{
Kojto 90:cb3d968589d8 367 */
Kojto 90:cb3d968589d8 368
Kojto 90:cb3d968589d8 369 /**
Kojto 90:cb3d968589d8 370 * @brief RCC extended clocks structure definition
Kojto 90:cb3d968589d8 371 */
Kojto 90:cb3d968589d8 372 #if defined(STM32F301x8) || defined(STM32F318xx)
Kojto 90:cb3d968589d8 373 typedef struct
Kojto 90:cb3d968589d8 374 {
Kojto 90:cb3d968589d8 375 uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured.
Kojto 90:cb3d968589d8 376 This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */
Kojto 90:cb3d968589d8 377
Kojto 90:cb3d968589d8 378 uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection
Kojto 90:cb3d968589d8 379 This parameter can be a value of @ref RCC_RTC_Clock_Source */
Kojto 90:cb3d968589d8 380
Kojto 90:cb3d968589d8 381 uint32_t Usart1ClockSelection; /*!< USART1 clock source
Kojto 90:cb3d968589d8 382 This parameter can be a value of @ref RCCEx_USART1_Clock_Source */
Kojto 90:cb3d968589d8 383
Kojto 90:cb3d968589d8 384 uint32_t I2c1ClockSelection; /*!< I2C1 clock source
Kojto 90:cb3d968589d8 385 This parameter can be a value of @ref RCC_I2C1_Clock_Source */
Kojto 90:cb3d968589d8 386
Kojto 90:cb3d968589d8 387 uint32_t I2c2ClockSelection; /*!< I2C2 clock source
Kojto 90:cb3d968589d8 388 This parameter can be a value of @ref RCCEx_I2C2_Clock_Source */
Kojto 90:cb3d968589d8 389
Kojto 90:cb3d968589d8 390 uint32_t I2c3ClockSelection; /*!< I2C3 clock source
Kojto 90:cb3d968589d8 391 This parameter can be a value of @ref RCCEx_I2C3_Clock_Source */
Kojto 90:cb3d968589d8 392
Kojto 90:cb3d968589d8 393 uint32_t Adc1ClockSelection; /*!< ADC1 clock source
Kojto 90:cb3d968589d8 394 This parameter can be a value of @ref RCCEx_ADC1_Clock_Source */
Kojto 90:cb3d968589d8 395
Kojto 90:cb3d968589d8 396 uint32_t I2sClockSelection; /*!< I2S clock source
Kojto 90:cb3d968589d8 397 This parameter can be a value of @ref RCCEx_I2S_Clock_Source */
Kojto 90:cb3d968589d8 398
Kojto 90:cb3d968589d8 399 uint32_t Tim1ClockSelection; /*!< TIM1 clock source
Kojto 90:cb3d968589d8 400 This parameter can be a value of @ref RCCEx_TIM1_Clock_Source */
Kojto 90:cb3d968589d8 401
Kojto 90:cb3d968589d8 402 uint32_t Tim15ClockSelection; /*!< TIM15 clock source
Kojto 90:cb3d968589d8 403 This parameter can be a value of @ref RCCEx_TIM15_Clock_Source */
Kojto 90:cb3d968589d8 404
Kojto 90:cb3d968589d8 405 uint32_t Tim16ClockSelection; /*!< TIM16 clock source
Kojto 90:cb3d968589d8 406 This parameter can be a value of @ref RCCEx_TIM16_Clock_Source */
Kojto 90:cb3d968589d8 407
Kojto 90:cb3d968589d8 408 uint32_t Tim17ClockSelection; /*!< TIM17 clock source
Kojto 90:cb3d968589d8 409 This parameter can be a value of @ref RCCEx_TIM17_Clock_Source */
Kojto 90:cb3d968589d8 410 }RCC_PeriphCLKInitTypeDef;
Kojto 90:cb3d968589d8 411 #endif /* STM32F301x8 || STM32F318xx */
Kojto 90:cb3d968589d8 412
Kojto 90:cb3d968589d8 413 #if defined(STM32F302x8)
Kojto 90:cb3d968589d8 414 typedef struct
Kojto 90:cb3d968589d8 415 {
Kojto 90:cb3d968589d8 416 uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured.
Kojto 90:cb3d968589d8 417 This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */
Kojto 90:cb3d968589d8 418
Kojto 90:cb3d968589d8 419 uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection
Kojto 90:cb3d968589d8 420 This parameter can be a value of @ref RCC_RTC_Clock_Source */
Kojto 90:cb3d968589d8 421
Kojto 90:cb3d968589d8 422 uint32_t Usart1ClockSelection; /*!< USART1 clock source
Kojto 90:cb3d968589d8 423 This parameter can be a value of @ref RCCEx_USART1_Clock_Source */
Kojto 90:cb3d968589d8 424
Kojto 90:cb3d968589d8 425 uint32_t I2c1ClockSelection; /*!< I2C1 clock source
Kojto 90:cb3d968589d8 426 This parameter can be a value of @ref RCC_I2C1_Clock_Source */
Kojto 90:cb3d968589d8 427
Kojto 90:cb3d968589d8 428 uint32_t I2c2ClockSelection; /*!< I2C2 clock source
Kojto 90:cb3d968589d8 429 This parameter can be a value of @ref RCCEx_I2C2_Clock_Source */
Kojto 90:cb3d968589d8 430
Kojto 90:cb3d968589d8 431 uint32_t I2c3ClockSelection; /*!< I2C3 clock source
Kojto 90:cb3d968589d8 432 This parameter can be a value of @ref RCCEx_I2C3_Clock_Source */
Kojto 90:cb3d968589d8 433
Kojto 90:cb3d968589d8 434 uint32_t Adc1ClockSelection; /*!< ADC1 clock source
Kojto 90:cb3d968589d8 435 This parameter can be a value of @ref RCCEx_ADC1_Clock_Source */
Kojto 90:cb3d968589d8 436
Kojto 90:cb3d968589d8 437 uint32_t I2sClockSelection; /*!< I2S clock source
Kojto 90:cb3d968589d8 438 This parameter can be a value of @ref RCCEx_I2S_Clock_Source */
Kojto 90:cb3d968589d8 439
Kojto 90:cb3d968589d8 440 uint32_t Tim1ClockSelection; /*!< TIM1 clock source
Kojto 90:cb3d968589d8 441 This parameter can be a value of @ref RCCEx_TIM1_Clock_Source */
Kojto 90:cb3d968589d8 442
Kojto 90:cb3d968589d8 443 uint32_t Tim15ClockSelection; /*!< TIM15 clock source
Kojto 90:cb3d968589d8 444 This parameter can be a value of @ref RCCEx_TIM15_Clock_Source */
Kojto 90:cb3d968589d8 445
Kojto 90:cb3d968589d8 446 uint32_t Tim16ClockSelection; /*!< TIM16 clock source
Kojto 90:cb3d968589d8 447 This parameter can be a value of @ref RCCEx_TIM16_Clock_Source */
Kojto 90:cb3d968589d8 448
Kojto 90:cb3d968589d8 449 uint32_t Tim17ClockSelection; /*!< TIM17 clock source
Kojto 90:cb3d968589d8 450 This parameter can be a value of @ref RCCEx_TIM17_Clock_Source */
Kojto 90:cb3d968589d8 451
Kojto 90:cb3d968589d8 452 uint32_t USBClockSelection; /*!< USB clock source
Kojto 90:cb3d968589d8 453 This parameter can be a value of @ref RCCEx_USB_Clock_Source */
Kojto 90:cb3d968589d8 454
Kojto 90:cb3d968589d8 455 }RCC_PeriphCLKInitTypeDef;
Kojto 90:cb3d968589d8 456 #endif /* STM32F302x8 */
Kojto 90:cb3d968589d8 457
Kojto 90:cb3d968589d8 458 #if defined(STM32F302xC)
Kojto 90:cb3d968589d8 459 typedef struct
Kojto 90:cb3d968589d8 460 {
Kojto 90:cb3d968589d8 461 uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured.
Kojto 90:cb3d968589d8 462 This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */
Kojto 90:cb3d968589d8 463
Kojto 90:cb3d968589d8 464 uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection
Kojto 90:cb3d968589d8 465 This parameter can be a value of @ref RCC_RTC_Clock_Source */
Kojto 90:cb3d968589d8 466
Kojto 90:cb3d968589d8 467 uint32_t Usart1ClockSelection; /*!< USART1 clock source
Kojto 90:cb3d968589d8 468 This parameter can be a value of @ref RCCEx_USART1_Clock_Source */
Kojto 90:cb3d968589d8 469
Kojto 90:cb3d968589d8 470 uint32_t Usart2ClockSelection; /*!< USART2 clock source
Kojto 90:cb3d968589d8 471 This parameter can be a value of @ref RCC_USART2_Clock_Source */
Kojto 90:cb3d968589d8 472
Kojto 90:cb3d968589d8 473 uint32_t Usart3ClockSelection; /*!< USART3 clock source
Kojto 90:cb3d968589d8 474 This parameter can be a value of @ref RCC_USART3_Clock_Source */
Kojto 90:cb3d968589d8 475
Kojto 90:cb3d968589d8 476 uint32_t Uart4ClockSelection; /*!< UART4 clock source
Kojto 90:cb3d968589d8 477 This parameter can be a value of @ref RCCEx_UART4_Clock_Source */
Kojto 90:cb3d968589d8 478
Kojto 90:cb3d968589d8 479 uint32_t Uart5ClockSelection; /*!< UART5 clock source
Kojto 90:cb3d968589d8 480 This parameter can be a value of @ref RCCEx_UART5_Clock_Source */
Kojto 90:cb3d968589d8 481
Kojto 90:cb3d968589d8 482 uint32_t I2c1ClockSelection; /*!< I2C1 clock source
Kojto 90:cb3d968589d8 483 This parameter can be a value of @ref RCC_I2C1_Clock_Source */
Kojto 90:cb3d968589d8 484
Kojto 90:cb3d968589d8 485 uint32_t I2c2ClockSelection; /*!< I2C2 clock source
Kojto 90:cb3d968589d8 486 This parameter can be a value of @ref RCCEx_I2C2_Clock_Source */
Kojto 90:cb3d968589d8 487
Kojto 90:cb3d968589d8 488 uint32_t Adc12ClockSelection; /*!< ADC1 & ADC2 clock source
Kojto 90:cb3d968589d8 489 This parameter can be a value of @ref RCCEx_ADC12_Clock_Source */
Kojto 90:cb3d968589d8 490
Kojto 90:cb3d968589d8 491 uint32_t I2sClockSelection; /*!< I2S clock source
Kojto 90:cb3d968589d8 492 This parameter can be a value of @ref RCCEx_I2S_Clock_Source */
Kojto 90:cb3d968589d8 493
Kojto 90:cb3d968589d8 494 uint32_t Tim1ClockSelection; /*!< TIM1 clock source
Kojto 90:cb3d968589d8 495 This parameter can be a value of @ref RCCEx_TIM1_Clock_Source */
Kojto 90:cb3d968589d8 496
Kojto 90:cb3d968589d8 497 uint32_t USBClockSelection; /*!< USB clock source
Kojto 90:cb3d968589d8 498 This parameter can be a value of @ref RCCEx_USB_Clock_Source */
Kojto 90:cb3d968589d8 499
Kojto 90:cb3d968589d8 500 }RCC_PeriphCLKInitTypeDef;
Kojto 90:cb3d968589d8 501 #endif /* STM32F302xC */
Kojto 90:cb3d968589d8 502
Kojto 90:cb3d968589d8 503 #if defined(STM32F303xC)
Kojto 90:cb3d968589d8 504 typedef struct
Kojto 90:cb3d968589d8 505 {
Kojto 90:cb3d968589d8 506 uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured.
Kojto 90:cb3d968589d8 507 This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */
Kojto 90:cb3d968589d8 508
Kojto 90:cb3d968589d8 509 uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection
Kojto 90:cb3d968589d8 510 This parameter can be a value of @ref RCC_RTC_Clock_Source */
Kojto 90:cb3d968589d8 511
Kojto 90:cb3d968589d8 512 uint32_t Usart1ClockSelection; /*!< USART1 clock source
Kojto 90:cb3d968589d8 513 This parameter can be a value of @ref RCCEx_USART1_Clock_Source */
Kojto 90:cb3d968589d8 514
Kojto 90:cb3d968589d8 515 uint32_t Usart2ClockSelection; /*!< USART2 clock source
Kojto 90:cb3d968589d8 516 This parameter can be a value of @ref RCC_USART2_Clock_Source */
Kojto 90:cb3d968589d8 517
Kojto 90:cb3d968589d8 518 uint32_t Usart3ClockSelection; /*!< USART3 clock source
Kojto 90:cb3d968589d8 519 This parameter can be a value of @ref RCC_USART3_Clock_Source */
Kojto 90:cb3d968589d8 520
Kojto 90:cb3d968589d8 521 uint32_t Uart4ClockSelection; /*!< UART4 clock source
Kojto 90:cb3d968589d8 522 This parameter can be a value of @ref RCCEx_UART4_Clock_Source */
Kojto 90:cb3d968589d8 523
Kojto 90:cb3d968589d8 524 uint32_t Uart5ClockSelection; /*!< UART5 clock source
Kojto 90:cb3d968589d8 525 This parameter can be a value of @ref RCCEx_UART5_Clock_Source */
Kojto 90:cb3d968589d8 526
Kojto 90:cb3d968589d8 527 uint32_t I2c1ClockSelection; /*!< I2C1 clock source
Kojto 90:cb3d968589d8 528 This parameter can be a value of @ref RCC_I2C1_Clock_Source */
Kojto 90:cb3d968589d8 529
Kojto 90:cb3d968589d8 530 uint32_t I2c2ClockSelection; /*!< I2C2 clock source
Kojto 90:cb3d968589d8 531 This parameter can be a value of @ref RCCEx_I2C2_Clock_Source */
Kojto 90:cb3d968589d8 532
Kojto 90:cb3d968589d8 533 uint32_t Adc12ClockSelection; /*!< ADC1 & ADC2 clock source
Kojto 90:cb3d968589d8 534 This parameter can be a value of @ref RCCEx_ADC12_Clock_Source */
Kojto 90:cb3d968589d8 535
Kojto 90:cb3d968589d8 536 uint32_t Adc34ClockSelection; /*!< ADC3 & ADC4 clock source
Kojto 90:cb3d968589d8 537 This parameter can be a value of @ref RCCEx_ADC34_Clock_Source */
Kojto 90:cb3d968589d8 538
Kojto 90:cb3d968589d8 539 uint32_t I2sClockSelection; /*!< I2S clock source
Kojto 90:cb3d968589d8 540 This parameter can be a value of @ref RCCEx_I2S_Clock_Source */
Kojto 90:cb3d968589d8 541
Kojto 90:cb3d968589d8 542 uint32_t Tim1ClockSelection; /*!< TIM1 clock source
Kojto 90:cb3d968589d8 543 This parameter can be a value of @ref RCCEx_TIM1_Clock_Source */
Kojto 90:cb3d968589d8 544
Kojto 90:cb3d968589d8 545 uint32_t Tim8ClockSelection; /*!< TIM8 clock source
Kojto 90:cb3d968589d8 546 This parameter can be a value of @ref RCCEx_TIM8_Clock_Source */
Kojto 90:cb3d968589d8 547
Kojto 90:cb3d968589d8 548 uint32_t USBClockSelection; /*!< USB clock source
Kojto 90:cb3d968589d8 549 This parameter can be a value of @ref RCCEx_USB_Clock_Source */
Kojto 90:cb3d968589d8 550
Kojto 90:cb3d968589d8 551 }RCC_PeriphCLKInitTypeDef;
Kojto 90:cb3d968589d8 552 #endif /* STM32F303xC */
Kojto 90:cb3d968589d8 553
Kojto 90:cb3d968589d8 554 #if defined(STM32F302xE)
Kojto 90:cb3d968589d8 555 typedef struct
Kojto 90:cb3d968589d8 556 {
Kojto 90:cb3d968589d8 557 uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured.
Kojto 90:cb3d968589d8 558 This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */
Kojto 90:cb3d968589d8 559
Kojto 90:cb3d968589d8 560 uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection
Kojto 90:cb3d968589d8 561 This parameter can be a value of @ref RCC_RTC_Clock_Source */
Kojto 90:cb3d968589d8 562
Kojto 90:cb3d968589d8 563 uint32_t Usart1ClockSelection; /*!< USART1 clock source
Kojto 90:cb3d968589d8 564 This parameter can be a value of @ref RCCEx_USART1_Clock_Source */
Kojto 90:cb3d968589d8 565
Kojto 90:cb3d968589d8 566 uint32_t Usart2ClockSelection; /*!< USART2 clock source
Kojto 90:cb3d968589d8 567 This parameter can be a value of @ref RCC_USART2_Clock_Source */
Kojto 90:cb3d968589d8 568
Kojto 90:cb3d968589d8 569 uint32_t Usart3ClockSelection; /*!< USART3 clock source
Kojto 90:cb3d968589d8 570 This parameter can be a value of @ref RCC_USART3_Clock_Source */
Kojto 90:cb3d968589d8 571
Kojto 90:cb3d968589d8 572 uint32_t Uart4ClockSelection; /*!< UART4 clock source
Kojto 90:cb3d968589d8 573 This parameter can be a value of @ref RCCEx_UART4_Clock_Source */
Kojto 90:cb3d968589d8 574
Kojto 90:cb3d968589d8 575 uint32_t Uart5ClockSelection; /*!< UART5 clock source
Kojto 90:cb3d968589d8 576 This parameter can be a value of @ref RCCEx_UART5_Clock_Source */
Kojto 90:cb3d968589d8 577
Kojto 90:cb3d968589d8 578 uint32_t I2c1ClockSelection; /*!< I2C1 clock source
Kojto 90:cb3d968589d8 579 This parameter can be a value of @ref RCC_I2C1_Clock_Source */
Kojto 90:cb3d968589d8 580
Kojto 90:cb3d968589d8 581 uint32_t I2c2ClockSelection; /*!< I2C2 clock source
Kojto 90:cb3d968589d8 582 This parameter can be a value of @ref RCCEx_I2C2_Clock_Source */
Kojto 90:cb3d968589d8 583
Kojto 90:cb3d968589d8 584 uint32_t I2c3ClockSelection; /*!< I2C3 clock source
Kojto 90:cb3d968589d8 585 This parameter can be a value of @ref RCCEx_I2C3_Clock_Source */
Kojto 90:cb3d968589d8 586
Kojto 90:cb3d968589d8 587 uint32_t Adc12ClockSelection; /*!< ADC1 & ADC2 clock source
Kojto 90:cb3d968589d8 588 This parameter can be a value of @ref RCCEx_ADC12_Clock_Source */
Kojto 90:cb3d968589d8 589
Kojto 90:cb3d968589d8 590 uint32_t I2sClockSelection; /*!< I2S clock source
Kojto 90:cb3d968589d8 591 This parameter can be a value of @ref RCCEx_I2S_Clock_Source */
Kojto 90:cb3d968589d8 592
Kojto 90:cb3d968589d8 593 uint32_t Tim1ClockSelection; /*!< TIM1 clock source
Kojto 90:cb3d968589d8 594 This parameter can be a value of @ref RCCEx_TIM1_Clock_Source */
Kojto 90:cb3d968589d8 595
Kojto 90:cb3d968589d8 596 uint32_t Tim2ClockSelection; /*!< TIM2 clock source
Kojto 90:cb3d968589d8 597 This parameter can be a value of @ref RCCEx_TIM2_Clock_Source */
Kojto 90:cb3d968589d8 598
Kojto 90:cb3d968589d8 599 uint32_t Tim34ClockSelection; /*!< TIM3 & TIM4 clock source
Kojto 90:cb3d968589d8 600 This parameter can be a value of @ref RCCEx_TIM34_Clock_Source */
Kojto 90:cb3d968589d8 601
Kojto 90:cb3d968589d8 602 uint32_t Tim15ClockSelection; /*!< TIM15 clock source
Kojto 90:cb3d968589d8 603 This parameter can be a value of @ref RCCEx_TIM15_Clock_Source */
Kojto 90:cb3d968589d8 604
Kojto 90:cb3d968589d8 605 uint32_t Tim16ClockSelection; /*!< TIM16 clock source
Kojto 90:cb3d968589d8 606 This parameter can be a value of @ref RCCEx_TIM16_Clock_Source */
Kojto 90:cb3d968589d8 607
Kojto 90:cb3d968589d8 608 uint32_t Tim17ClockSelection; /*!< TIM17 clock source
Kojto 90:cb3d968589d8 609 This parameter can be a value of @ref RCCEx_TIM17_Clock_Source */
Kojto 90:cb3d968589d8 610
Kojto 90:cb3d968589d8 611 uint32_t USBClockSelection; /*!< USB clock source
Kojto 90:cb3d968589d8 612 This parameter can be a value of @ref RCCEx_USB_Clock_Source */
Kojto 90:cb3d968589d8 613
Kojto 90:cb3d968589d8 614 }RCC_PeriphCLKInitTypeDef;
Kojto 90:cb3d968589d8 615 #endif /* STM32F302xE */
Kojto 90:cb3d968589d8 616
Kojto 90:cb3d968589d8 617 #if defined(STM32F303xE)
Kojto 90:cb3d968589d8 618 typedef struct
Kojto 90:cb3d968589d8 619 {
Kojto 90:cb3d968589d8 620 uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured.
Kojto 90:cb3d968589d8 621 This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */
Kojto 90:cb3d968589d8 622
Kojto 90:cb3d968589d8 623 uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection
Kojto 90:cb3d968589d8 624 This parameter can be a value of @ref RCC_RTC_Clock_Source */
Kojto 90:cb3d968589d8 625
Kojto 90:cb3d968589d8 626 uint32_t Usart1ClockSelection; /*!< USART1 clock source
Kojto 90:cb3d968589d8 627 This parameter can be a value of @ref RCCEx_USART1_Clock_Source */
Kojto 90:cb3d968589d8 628
Kojto 90:cb3d968589d8 629 uint32_t Usart2ClockSelection; /*!< USART2 clock source
Kojto 90:cb3d968589d8 630 This parameter can be a value of @ref RCC_USART2_Clock_Source */
Kojto 90:cb3d968589d8 631
Kojto 90:cb3d968589d8 632 uint32_t Usart3ClockSelection; /*!< USART3 clock source
Kojto 90:cb3d968589d8 633 This parameter can be a value of @ref RCC_USART3_Clock_Source */
Kojto 90:cb3d968589d8 634
Kojto 90:cb3d968589d8 635 uint32_t Uart4ClockSelection; /*!< UART4 clock source
Kojto 90:cb3d968589d8 636 This parameter can be a value of @ref RCCEx_UART4_Clock_Source */
Kojto 90:cb3d968589d8 637
Kojto 90:cb3d968589d8 638 uint32_t Uart5ClockSelection; /*!< UART5 clock source
Kojto 90:cb3d968589d8 639 This parameter can be a value of @ref RCCEx_UART5_Clock_Source */
Kojto 90:cb3d968589d8 640
Kojto 90:cb3d968589d8 641 uint32_t I2c1ClockSelection; /*!< I2C1 clock source
Kojto 90:cb3d968589d8 642 This parameter can be a value of @ref RCC_I2C1_Clock_Source */
Kojto 90:cb3d968589d8 643
Kojto 90:cb3d968589d8 644 uint32_t I2c2ClockSelection; /*!< I2C2 clock source
Kojto 90:cb3d968589d8 645 This parameter can be a value of @ref RCCEx_I2C2_Clock_Source */
Kojto 90:cb3d968589d8 646
Kojto 90:cb3d968589d8 647 uint32_t I2c3ClockSelection; /*!< I2C3 clock source
Kojto 90:cb3d968589d8 648 This parameter can be a value of @ref RCCEx_I2C3_Clock_Source */
Kojto 90:cb3d968589d8 649
Kojto 90:cb3d968589d8 650 uint32_t Adc12ClockSelection; /*!< ADC1 & ADC2 clock source
Kojto 90:cb3d968589d8 651 This parameter can be a value of @ref RCCEx_ADC12_Clock_Source */
Kojto 90:cb3d968589d8 652
Kojto 90:cb3d968589d8 653 uint32_t Adc34ClockSelection; /*!< ADC3 & ADC4 clock source
Kojto 90:cb3d968589d8 654 This parameter can be a value of @ref RCCEx_ADC34_Clock_Source */
Kojto 90:cb3d968589d8 655
Kojto 90:cb3d968589d8 656 uint32_t I2sClockSelection; /*!< I2S clock source
Kojto 90:cb3d968589d8 657 This parameter can be a value of @ref RCCEx_I2S_Clock_Source */
Kojto 90:cb3d968589d8 658
Kojto 90:cb3d968589d8 659 uint32_t Tim1ClockSelection; /*!< TIM1 clock source
Kojto 90:cb3d968589d8 660 This parameter can be a value of @ref RCCEx_TIM1_Clock_Source */
Kojto 90:cb3d968589d8 661
Kojto 90:cb3d968589d8 662 uint32_t Tim2ClockSelection; /*!< TIM2 clock source
Kojto 90:cb3d968589d8 663 This parameter can be a value of @ref RCCEx_TIM2_Clock_Source */
Kojto 90:cb3d968589d8 664
Kojto 90:cb3d968589d8 665 uint32_t Tim34ClockSelection; /*!< TIM3 & TIM4 clock source
Kojto 90:cb3d968589d8 666 This parameter can be a value of @ref RCCEx_TIM34_Clock_Source */
Kojto 90:cb3d968589d8 667
Kojto 90:cb3d968589d8 668 uint32_t Tim8ClockSelection; /*!< TIM8 clock source
Kojto 90:cb3d968589d8 669 This parameter can be a value of @ref RCCEx_TIM8_Clock_Source */
Kojto 90:cb3d968589d8 670
Kojto 90:cb3d968589d8 671 uint32_t Tim15ClockSelection; /*!< TIM15 clock source
Kojto 90:cb3d968589d8 672 This parameter can be a value of @ref RCCEx_TIM15_Clock_Source */
Kojto 90:cb3d968589d8 673
Kojto 90:cb3d968589d8 674 uint32_t Tim16ClockSelection; /*!< TIM16 clock source
Kojto 90:cb3d968589d8 675 This parameter can be a value of @ref RCCEx_TIM16_Clock_Source */
Kojto 90:cb3d968589d8 676
Kojto 90:cb3d968589d8 677 uint32_t Tim17ClockSelection; /*!< TIM17 clock source
Kojto 90:cb3d968589d8 678 This parameter can be a value of @ref RCCEx_TIM17_Clock_Source */
Kojto 90:cb3d968589d8 679
Kojto 90:cb3d968589d8 680 uint32_t Tim20ClockSelection; /*!< TIM20 clock source
Kojto 90:cb3d968589d8 681 This parameter can be a value of @ref RCCEx_TIM20_Clock_Source */
Kojto 90:cb3d968589d8 682
Kojto 90:cb3d968589d8 683 uint32_t USBClockSelection; /*!< USB clock source
Kojto 90:cb3d968589d8 684 This parameter can be a value of @ref RCCEx_USB_Clock_Source */
Kojto 90:cb3d968589d8 685
Kojto 90:cb3d968589d8 686 }RCC_PeriphCLKInitTypeDef;
Kojto 90:cb3d968589d8 687 #endif /* STM32F303xE */
Kojto 90:cb3d968589d8 688
Kojto 90:cb3d968589d8 689 #if defined(STM32F398xx)
Kojto 90:cb3d968589d8 690 typedef struct
Kojto 90:cb3d968589d8 691 {
Kojto 90:cb3d968589d8 692 uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured.
Kojto 90:cb3d968589d8 693 This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */
Kojto 90:cb3d968589d8 694
Kojto 90:cb3d968589d8 695 uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection
Kojto 90:cb3d968589d8 696 This parameter can be a value of @ref RCC_RTC_Clock_Source */
Kojto 90:cb3d968589d8 697
Kojto 90:cb3d968589d8 698 uint32_t Usart1ClockSelection; /*!< USART1 clock source
Kojto 90:cb3d968589d8 699 This parameter can be a value of @ref RCCEx_USART1_Clock_Source */
Kojto 90:cb3d968589d8 700
Kojto 90:cb3d968589d8 701 uint32_t Usart2ClockSelection; /*!< USART2 clock source
Kojto 90:cb3d968589d8 702 This parameter can be a value of @ref RCC_USART2_Clock_Source */
Kojto 90:cb3d968589d8 703
Kojto 90:cb3d968589d8 704 uint32_t Usart3ClockSelection; /*!< USART3 clock source
Kojto 90:cb3d968589d8 705 This parameter can be a value of @ref RCC_USART3_Clock_Source */
Kojto 90:cb3d968589d8 706
Kojto 90:cb3d968589d8 707 uint32_t Uart4ClockSelection; /*!< UART4 clock source
Kojto 90:cb3d968589d8 708 This parameter can be a value of @ref RCCEx_UART4_Clock_Source */
Kojto 90:cb3d968589d8 709
Kojto 90:cb3d968589d8 710 uint32_t Uart5ClockSelection; /*!< UART5 clock source
Kojto 90:cb3d968589d8 711 This parameter can be a value of @ref RCCEx_UART5_Clock_Source */
Kojto 90:cb3d968589d8 712
Kojto 90:cb3d968589d8 713 uint32_t I2c1ClockSelection; /*!< I2C1 clock source
Kojto 90:cb3d968589d8 714 This parameter can be a value of @ref RCC_I2C1_Clock_Source */
Kojto 90:cb3d968589d8 715
Kojto 90:cb3d968589d8 716 uint32_t I2c2ClockSelection; /*!< I2C2 clock source
Kojto 90:cb3d968589d8 717 This parameter can be a value of @ref RCCEx_I2C2_Clock_Source */
Kojto 90:cb3d968589d8 718
Kojto 90:cb3d968589d8 719 uint32_t I2c3ClockSelection; /*!< I2C3 clock source
Kojto 90:cb3d968589d8 720 This parameter can be a value of @ref RCCEx_I2C3_Clock_Source */
Kojto 90:cb3d968589d8 721
Kojto 90:cb3d968589d8 722 uint32_t Adc12ClockSelection; /*!< ADC1 & ADC2 clock source
Kojto 90:cb3d968589d8 723 This parameter can be a value of @ref RCCEx_ADC12_Clock_Source */
Kojto 90:cb3d968589d8 724
Kojto 90:cb3d968589d8 725 uint32_t Adc34ClockSelection; /*!< ADC3 & ADC4 clock source
Kojto 90:cb3d968589d8 726 This parameter can be a value of @ref RCCEx_ADC34_Clock_Source */
Kojto 90:cb3d968589d8 727
Kojto 90:cb3d968589d8 728 uint32_t I2sClockSelection; /*!< I2S clock source
Kojto 90:cb3d968589d8 729 This parameter can be a value of @ref RCCEx_I2S_Clock_Source */
Kojto 90:cb3d968589d8 730
Kojto 90:cb3d968589d8 731 uint32_t Tim1ClockSelection; /*!< TIM1 clock source
Kojto 90:cb3d968589d8 732 This parameter can be a value of @ref RCCEx_TIM1_Clock_Source */
Kojto 90:cb3d968589d8 733
Kojto 90:cb3d968589d8 734 uint32_t Tim2ClockSelection; /*!< TIM2 clock source
Kojto 90:cb3d968589d8 735 This parameter can be a value of @ref RCCEx_TIM2_Clock_Source */
Kojto 90:cb3d968589d8 736
Kojto 90:cb3d968589d8 737 uint32_t Tim34ClockSelection; /*!< TIM3 & TIM4 clock source
Kojto 90:cb3d968589d8 738 This parameter can be a value of @ref RCCEx_TIM34_Clock_Source */
Kojto 90:cb3d968589d8 739
Kojto 90:cb3d968589d8 740 uint32_t Tim8ClockSelection; /*!< TIM8 clock source
Kojto 90:cb3d968589d8 741 This parameter can be a value of @ref RCCEx_TIM8_Clock_Source */
Kojto 90:cb3d968589d8 742
Kojto 90:cb3d968589d8 743 uint32_t Tim15ClockSelection; /*!< TIM15 clock source
Kojto 90:cb3d968589d8 744 This parameter can be a value of @ref RCCEx_TIM15_Clock_Source */
Kojto 90:cb3d968589d8 745
Kojto 90:cb3d968589d8 746 uint32_t Tim16ClockSelection; /*!< TIM16 clock source
Kojto 90:cb3d968589d8 747 This parameter can be a value of @ref RCCEx_TIM16_Clock_Source */
Kojto 90:cb3d968589d8 748
Kojto 90:cb3d968589d8 749 uint32_t Tim17ClockSelection; /*!< TIM17 clock source
Kojto 90:cb3d968589d8 750 This parameter can be a value of @ref RCCEx_TIM17_Clock_Source */
Kojto 90:cb3d968589d8 751
Kojto 90:cb3d968589d8 752 uint32_t Tim20ClockSelection; /*!< TIM20 clock source
Kojto 90:cb3d968589d8 753 This parameter can be a value of @ref RCCEx_TIM20_Clock_Source */
Kojto 90:cb3d968589d8 754
Kojto 90:cb3d968589d8 755 }RCC_PeriphCLKInitTypeDef;
Kojto 90:cb3d968589d8 756 #endif /* STM32F398xx */
Kojto 90:cb3d968589d8 757
Kojto 90:cb3d968589d8 758 #if defined(STM32F358xx)
Kojto 90:cb3d968589d8 759 typedef struct
Kojto 90:cb3d968589d8 760 {
Kojto 90:cb3d968589d8 761 uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured.
Kojto 90:cb3d968589d8 762 This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */
Kojto 90:cb3d968589d8 763
Kojto 90:cb3d968589d8 764 uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection
Kojto 90:cb3d968589d8 765 This parameter can be a value of @ref RCC_RTC_Clock_Source */
Kojto 90:cb3d968589d8 766
Kojto 90:cb3d968589d8 767 uint32_t Usart1ClockSelection; /*!< USART1 clock source
Kojto 90:cb3d968589d8 768 This parameter can be a value of @ref RCCEx_USART1_Clock_Source */
Kojto 90:cb3d968589d8 769
Kojto 90:cb3d968589d8 770 uint32_t Usart2ClockSelection; /*!< USART2 clock source
Kojto 90:cb3d968589d8 771 This parameter can be a value of @ref RCC_USART2_Clock_Source */
Kojto 90:cb3d968589d8 772
Kojto 90:cb3d968589d8 773 uint32_t Usart3ClockSelection; /*!< USART3 clock source
Kojto 90:cb3d968589d8 774 This parameter can be a value of @ref RCC_USART3_Clock_Source */
Kojto 90:cb3d968589d8 775
Kojto 90:cb3d968589d8 776 uint32_t Uart4ClockSelection; /*!< UART4 clock source
Kojto 90:cb3d968589d8 777 This parameter can be a value of @ref RCCEx_UART4_Clock_Source */
Kojto 90:cb3d968589d8 778
Kojto 90:cb3d968589d8 779 uint32_t Uart5ClockSelection; /*!< UART5 clock source
Kojto 90:cb3d968589d8 780 This parameter can be a value of @ref RCCEx_UART5_Clock_Source */
Kojto 90:cb3d968589d8 781
Kojto 90:cb3d968589d8 782 uint32_t I2c1ClockSelection; /*!< I2C1 clock source
Kojto 90:cb3d968589d8 783 This parameter can be a value of @ref RCC_I2C1_Clock_Source */
Kojto 90:cb3d968589d8 784
Kojto 90:cb3d968589d8 785 uint32_t I2c2ClockSelection; /*!< I2C2 clock source
Kojto 90:cb3d968589d8 786 This parameter can be a value of @ref RCCEx_I2C2_Clock_Source */
Kojto 90:cb3d968589d8 787
Kojto 90:cb3d968589d8 788 uint32_t Adc12ClockSelection; /*!< ADC1 & ADC2 clock source
Kojto 90:cb3d968589d8 789 This parameter can be a value of @ref RCCEx_ADC12_Clock_Source */
Kojto 90:cb3d968589d8 790
Kojto 90:cb3d968589d8 791 uint32_t Adc34ClockSelection; /*!< ADC3 & ADC4 clock source
Kojto 90:cb3d968589d8 792 This parameter can be a value of @ref RCCEx_ADC34_Clock_Source */
Kojto 90:cb3d968589d8 793
Kojto 90:cb3d968589d8 794 uint32_t I2sClockSelection; /*!< I2S clock source
Kojto 90:cb3d968589d8 795 This parameter can be a value of @ref RCCEx_I2S_Clock_Source */
Kojto 90:cb3d968589d8 796
Kojto 90:cb3d968589d8 797 uint32_t Tim1ClockSelection; /*!< TIM1 clock source
Kojto 90:cb3d968589d8 798 This parameter can be a value of @ref RCCEx_TIM1_Clock_Source */
Kojto 90:cb3d968589d8 799
Kojto 90:cb3d968589d8 800 uint32_t Tim8ClockSelection; /*!< TIM8 clock source
Kojto 90:cb3d968589d8 801 This parameter can be a value of @ref RCCEx_TIM8_Clock_Source */
Kojto 90:cb3d968589d8 802
Kojto 90:cb3d968589d8 803 }RCC_PeriphCLKInitTypeDef;
Kojto 90:cb3d968589d8 804 #endif /* STM32F358xx */
Kojto 90:cb3d968589d8 805
Kojto 90:cb3d968589d8 806 #if defined(STM32F303x8)
Kojto 90:cb3d968589d8 807 typedef struct
Kojto 90:cb3d968589d8 808 {
Kojto 90:cb3d968589d8 809 uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured.
Kojto 90:cb3d968589d8 810 This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */
Kojto 90:cb3d968589d8 811
Kojto 90:cb3d968589d8 812 uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection
Kojto 90:cb3d968589d8 813 This parameter can be a value of @ref RCC_RTC_Clock_Source */
Kojto 90:cb3d968589d8 814
Kojto 90:cb3d968589d8 815 uint32_t Usart1ClockSelection; /*!< USART1 clock source
Kojto 90:cb3d968589d8 816 This parameter can be a value of @ref RCCEx_USART1_Clock_Source */
Kojto 90:cb3d968589d8 817
Kojto 90:cb3d968589d8 818 uint32_t I2c1ClockSelection; /*!< I2C1 clock source
Kojto 90:cb3d968589d8 819 This parameter can be a value of @ref RCC_I2C1_Clock_Source */
Kojto 90:cb3d968589d8 820
Kojto 90:cb3d968589d8 821 uint32_t Adc12ClockSelection; /*!< ADC1 & ADC2 clock source
Kojto 90:cb3d968589d8 822 This parameter can be a value of @ref RCCEx_ADC12_Clock_Source */
Kojto 90:cb3d968589d8 823
Kojto 90:cb3d968589d8 824 uint32_t Tim1ClockSelection; /*!< TIM1 clock source
Kojto 90:cb3d968589d8 825 This parameter can be a value of @ref RCCEx_TIM1_Clock_Source */
Kojto 90:cb3d968589d8 826
Kojto 90:cb3d968589d8 827 }RCC_PeriphCLKInitTypeDef;
Kojto 90:cb3d968589d8 828 #endif /* STM32F303x8 */
Kojto 90:cb3d968589d8 829
Kojto 90:cb3d968589d8 830 #if defined(STM32F334x8)
Kojto 90:cb3d968589d8 831 typedef struct
Kojto 90:cb3d968589d8 832 {
Kojto 90:cb3d968589d8 833 uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured.
Kojto 90:cb3d968589d8 834 This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */
Kojto 90:cb3d968589d8 835
Kojto 90:cb3d968589d8 836 uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection
Kojto 90:cb3d968589d8 837 This parameter can be a value of @ref RCC_RTC_Clock_Source */
Kojto 90:cb3d968589d8 838
Kojto 90:cb3d968589d8 839 uint32_t Usart1ClockSelection; /*!< USART1 clock source
Kojto 90:cb3d968589d8 840 This parameter can be a value of @ref RCCEx_USART1_Clock_Source */
Kojto 90:cb3d968589d8 841
Kojto 90:cb3d968589d8 842 uint32_t I2c1ClockSelection; /*!< I2C1 clock source
Kojto 90:cb3d968589d8 843 This parameter can be a value of @ref RCC_I2C1_Clock_Source */
Kojto 90:cb3d968589d8 844
Kojto 90:cb3d968589d8 845 uint32_t Adc12ClockSelection; /*!< ADC1 & ADC2 clock source
Kojto 90:cb3d968589d8 846 This parameter can be a value of @ref RCCEx_ADC12_Clock_Source */
Kojto 90:cb3d968589d8 847
Kojto 90:cb3d968589d8 848 uint32_t Tim1ClockSelection; /*!< TIM1 clock source
Kojto 90:cb3d968589d8 849 This parameter can be a value of @ref RCCEx_TIM1_Clock_Source */
Kojto 90:cb3d968589d8 850
Kojto 90:cb3d968589d8 851 uint32_t Hrtim1ClockSelection; /*!< HRTIM1 clock source
Kojto 90:cb3d968589d8 852 This parameter can be a value of @ref RCCEx_HRTIM1_Clock_Source */
Kojto 90:cb3d968589d8 853
Kojto 90:cb3d968589d8 854 }RCC_PeriphCLKInitTypeDef;
Kojto 90:cb3d968589d8 855 #endif /* STM32F334x8 */
Kojto 90:cb3d968589d8 856
Kojto 90:cb3d968589d8 857 #if defined(STM32F328xx)
Kojto 90:cb3d968589d8 858 typedef struct
Kojto 90:cb3d968589d8 859 {
Kojto 90:cb3d968589d8 860 uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured.
Kojto 90:cb3d968589d8 861 This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */
Kojto 90:cb3d968589d8 862
Kojto 90:cb3d968589d8 863 uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection
Kojto 90:cb3d968589d8 864 This parameter can be a value of @ref RCC_RTC_Clock_Source */
Kojto 90:cb3d968589d8 865
Kojto 90:cb3d968589d8 866 uint32_t Usart1ClockSelection; /*!< USART1 clock source
Kojto 122:f9eeca106725 867 This parameter can be a value of @ref RCCEx_USART1_Clock_Source */
Kojto 90:cb3d968589d8 868
Kojto 90:cb3d968589d8 869 uint32_t I2c1ClockSelection; /*!< I2C1 clock source
Kojto 90:cb3d968589d8 870 This parameter can be a value of @ref RCC_I2C1_Clock_Source */
Kojto 90:cb3d968589d8 871
Kojto 90:cb3d968589d8 872 uint32_t Adc12ClockSelection; /*!< ADC1 & ADC2 clock source
Kojto 90:cb3d968589d8 873 This parameter can be a value of @ref RCCEx_ADC12_Clock_Source */
Kojto 90:cb3d968589d8 874
Kojto 90:cb3d968589d8 875 uint32_t Tim1ClockSelection; /*!< TIM1 clock source
Kojto 90:cb3d968589d8 876 This parameter can be a value of @ref RCCEx_TIM1_Clock_Source */
Kojto 90:cb3d968589d8 877
Kojto 90:cb3d968589d8 878 }RCC_PeriphCLKInitTypeDef;
Kojto 90:cb3d968589d8 879 #endif /* STM32F328xx */
Kojto 90:cb3d968589d8 880
Kojto 90:cb3d968589d8 881 #if defined(STM32F373xC)
Kojto 90:cb3d968589d8 882 typedef struct
Kojto 90:cb3d968589d8 883 {
Kojto 90:cb3d968589d8 884 uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured.
Kojto 90:cb3d968589d8 885 This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */
Kojto 90:cb3d968589d8 886
Kojto 90:cb3d968589d8 887 uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection
Kojto 90:cb3d968589d8 888 This parameter can be a value of @ref RCC_RTC_Clock_Source */
Kojto 90:cb3d968589d8 889
Kojto 90:cb3d968589d8 890 uint32_t Usart1ClockSelection; /*!< USART1 clock source
Kojto 90:cb3d968589d8 891 This parameter can be a value of @ref RCCEx_USART1_Clock_Source */
Kojto 90:cb3d968589d8 892
Kojto 90:cb3d968589d8 893 uint32_t Usart2ClockSelection; /*!< USART2 clock source
Kojto 90:cb3d968589d8 894 This parameter can be a value of @ref RCC_USART2_Clock_Source */
Kojto 90:cb3d968589d8 895
Kojto 90:cb3d968589d8 896 uint32_t Usart3ClockSelection; /*!< USART3 clock source
Kojto 90:cb3d968589d8 897 This parameter can be a value of @ref RCC_USART3_Clock_Source */
Kojto 90:cb3d968589d8 898
Kojto 90:cb3d968589d8 899 uint32_t I2c1ClockSelection; /*!< I2C1 clock source
Kojto 90:cb3d968589d8 900 This parameter can be a value of @ref RCC_I2C1_Clock_Source */
Kojto 90:cb3d968589d8 901
Kojto 90:cb3d968589d8 902 uint32_t I2c2ClockSelection; /*!< I2C2 clock source
Kojto 90:cb3d968589d8 903 This parameter can be a value of @ref RCCEx_I2C2_Clock_Source */
Kojto 90:cb3d968589d8 904
Kojto 90:cb3d968589d8 905 uint32_t Adc1ClockSelection; /*!< ADC1 clock source
Kojto 90:cb3d968589d8 906 This parameter can be a value of @ref RCCEx_ADC1_Clock_Source */
Kojto 90:cb3d968589d8 907
Kojto 90:cb3d968589d8 908 uint32_t SdadcClockSelection; /*!< SDADC clock prescaler
Kojto 90:cb3d968589d8 909 This parameter can be a value of @ref RCCEx_SDADC_Clock_Prescaler */
Kojto 90:cb3d968589d8 910
Kojto 90:cb3d968589d8 911 uint32_t CecClockSelection; /*!< HDMI CEC clock source
Kojto 90:cb3d968589d8 912 This parameter can be a value of @ref RCCEx_CEC_Clock_Source */
Kojto 90:cb3d968589d8 913
Kojto 90:cb3d968589d8 914 uint32_t USBClockSelection; /*!< USB clock source
Kojto 90:cb3d968589d8 915 This parameter can be a value of @ref RCCEx_USB_Clock_Source */
Kojto 90:cb3d968589d8 916
Kojto 90:cb3d968589d8 917 }RCC_PeriphCLKInitTypeDef;
Kojto 90:cb3d968589d8 918 #endif /* STM32F373xC */
Kojto 90:cb3d968589d8 919
Kojto 90:cb3d968589d8 920 #if defined(STM32F378xx)
Kojto 90:cb3d968589d8 921 typedef struct
Kojto 90:cb3d968589d8 922 {
Kojto 90:cb3d968589d8 923 uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured.
Kojto 90:cb3d968589d8 924 This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */
Kojto 90:cb3d968589d8 925
Kojto 90:cb3d968589d8 926 uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection
Kojto 90:cb3d968589d8 927 This parameter can be a value of @ref RCC_RTC_Clock_Source */
Kojto 90:cb3d968589d8 928
Kojto 90:cb3d968589d8 929 uint32_t Usart1ClockSelection; /*!< USART1 clock source
Kojto 90:cb3d968589d8 930 This parameter can be a value of @ref RCCEx_USART1_Clock_Source */
Kojto 90:cb3d968589d8 931
Kojto 90:cb3d968589d8 932 uint32_t Usart2ClockSelection; /*!< USART2 clock source
Kojto 90:cb3d968589d8 933 This parameter can be a value of @ref RCC_USART2_Clock_Source */
Kojto 90:cb3d968589d8 934
Kojto 90:cb3d968589d8 935 uint32_t Usart3ClockSelection; /*!< USART3 clock source
Kojto 90:cb3d968589d8 936 This parameter can be a value of @ref RCC_USART3_Clock_Source */
Kojto 90:cb3d968589d8 937
Kojto 90:cb3d968589d8 938 uint32_t I2c1ClockSelection; /*!< I2C1 clock source
Kojto 90:cb3d968589d8 939 This parameter can be a value of @ref RCC_I2C1_Clock_Source */
Kojto 90:cb3d968589d8 940
Kojto 90:cb3d968589d8 941 uint32_t I2c2ClockSelection; /*!< I2C2 clock source
Kojto 90:cb3d968589d8 942 This parameter can be a value of @ref RCCEx_I2C2_Clock_Source */
Kojto 90:cb3d968589d8 943
Kojto 90:cb3d968589d8 944 uint32_t Adc1ClockSelection; /*!< ADC1 clock source
Kojto 90:cb3d968589d8 945 This parameter can be a value of @ref RCCEx_ADC1_Clock_Source */
Kojto 90:cb3d968589d8 946
Kojto 90:cb3d968589d8 947 uint32_t SdadcClockSelection; /*!< SDADC clock prescaler
Kojto 90:cb3d968589d8 948 This parameter can be a value of @ref RCCEx_SDADC_Clock_Prescaler */
Kojto 90:cb3d968589d8 949
Kojto 90:cb3d968589d8 950 uint32_t CecClockSelection; /*!< HDMI CEC clock source
Kojto 90:cb3d968589d8 951 This parameter can be a value of @ref RCCEx_CEC_Clock_Source */
Kojto 90:cb3d968589d8 952
Kojto 90:cb3d968589d8 953 }RCC_PeriphCLKInitTypeDef;
Kojto 90:cb3d968589d8 954 #endif /* STM32F378xx */
Kojto 90:cb3d968589d8 955
Kojto 90:cb3d968589d8 956 /**
Kojto 90:cb3d968589d8 957 * @}
Kojto 90:cb3d968589d8 958 */
Kojto 90:cb3d968589d8 959
Kojto 90:cb3d968589d8 960 /* Exported constants --------------------------------------------------------*/
Kojto 90:cb3d968589d8 961 /** @defgroup RCCEx_Exported_Constants RCC Extended Exported Constants
Kojto 90:cb3d968589d8 962 * @{
Kojto 90:cb3d968589d8 963 */
Kojto 90:cb3d968589d8 964 /** @defgroup RCCEx_MCO_Clock_Source RCC Extended MCO Clock Source
Kojto 90:cb3d968589d8 965 * @{
Kojto 90:cb3d968589d8 966 */
Kojto 122:f9eeca106725 967 #define RCC_MCO1SOURCE_NOCLOCK RCC_CFGR_MCO_NOCLOCK
Kojto 122:f9eeca106725 968 #define RCC_MCO1SOURCE_LSI RCC_CFGR_MCO_LSI
Kojto 122:f9eeca106725 969 #define RCC_MCO1SOURCE_LSE RCC_CFGR_MCO_LSE
Kojto 122:f9eeca106725 970 #define RCC_MCO1SOURCE_SYSCLK RCC_CFGR_MCO_SYSCLK
Kojto 122:f9eeca106725 971 #define RCC_MCO1SOURCE_HSI RCC_CFGR_MCO_HSI
Kojto 122:f9eeca106725 972 #define RCC_MCO1SOURCE_HSE RCC_CFGR_MCO_HSE
Kojto 122:f9eeca106725 973 #if defined(RCC_CFGR_PLLNODIV)
Kojto 122:f9eeca106725 974 #define RCC_MCO1SOURCE_PLLCLK (RCC_CFGR_PLLNODIV | RCC_CFGR_MCO_PLL)
Kojto 122:f9eeca106725 975 #endif /* RCC_CFGR_PLLNODIV */
Kojto 122:f9eeca106725 976 #define RCC_MCO1SOURCE_PLLCLK_DIV2 RCC_CFGR_MCO_PLL
Kojto 122:f9eeca106725 977
Kojto 90:cb3d968589d8 978 /**
Kojto 90:cb3d968589d8 979 * @}
Kojto 90:cb3d968589d8 980 */
Kojto 90:cb3d968589d8 981
Kojto 90:cb3d968589d8 982 /** @defgroup RCCEx_Periph_Clock_Selection RCC Extended Periph Clock Selection
Kojto 90:cb3d968589d8 983 * @{
Kojto 90:cb3d968589d8 984 */
Kojto 90:cb3d968589d8 985 #if defined(STM32F301x8) || defined(STM32F318xx)
Kojto 90:cb3d968589d8 986 #define RCC_PERIPHCLK_USART1 ((uint32_t)0x00000001)
Kojto 90:cb3d968589d8 987 #define RCC_PERIPHCLK_I2C1 ((uint32_t)0x00000020)
Kojto 90:cb3d968589d8 988 #define RCC_PERIPHCLK_I2C2 ((uint32_t)0x00000040)
Kojto 90:cb3d968589d8 989 #define RCC_PERIPHCLK_ADC1 ((uint32_t)0x00000080)
Kojto 90:cb3d968589d8 990 #define RCC_PERIPHCLK_I2S ((uint32_t)0x00000200)
Kojto 90:cb3d968589d8 991 #define RCC_PERIPHCLK_TIM1 ((uint32_t)0x00001000)
Kojto 90:cb3d968589d8 992 #define RCC_PERIPHCLK_I2C3 ((uint32_t)0x00008000)
Kojto 90:cb3d968589d8 993 #define RCC_PERIPHCLK_RTC ((uint32_t)0x00010000)
Kojto 90:cb3d968589d8 994 #define RCC_PERIPHCLK_TIM15 ((uint32_t)0x00040000)
Kojto 90:cb3d968589d8 995 #define RCC_PERIPHCLK_TIM16 ((uint32_t)0x00080000)
Kojto 90:cb3d968589d8 996 #define RCC_PERIPHCLK_TIM17 ((uint32_t)0x00100000)
Kojto 90:cb3d968589d8 997
Kojto 90:cb3d968589d8 998 #endif /* STM32F301x8 || STM32F318xx */
Kojto 90:cb3d968589d8 999
Kojto 90:cb3d968589d8 1000 #if defined(STM32F302x8)
Kojto 90:cb3d968589d8 1001 #define RCC_PERIPHCLK_USART1 ((uint32_t)0x00000001)
Kojto 90:cb3d968589d8 1002 #define RCC_PERIPHCLK_I2C1 ((uint32_t)0x00000020)
Kojto 90:cb3d968589d8 1003 #define RCC_PERIPHCLK_I2C2 ((uint32_t)0x00000040)
Kojto 90:cb3d968589d8 1004 #define RCC_PERIPHCLK_ADC1 ((uint32_t)0x00000080)
Kojto 90:cb3d968589d8 1005 #define RCC_PERIPHCLK_I2S ((uint32_t)0x00000200)
Kojto 90:cb3d968589d8 1006 #define RCC_PERIPHCLK_TIM1 ((uint32_t)0x00001000)
Kojto 90:cb3d968589d8 1007 #define RCC_PERIPHCLK_I2C3 ((uint32_t)0x00008000)
Kojto 90:cb3d968589d8 1008 #define RCC_PERIPHCLK_RTC ((uint32_t)0x00010000)
Kojto 90:cb3d968589d8 1009 #define RCC_PERIPHCLK_USB ((uint32_t)0x00020000)
Kojto 90:cb3d968589d8 1010 #define RCC_PERIPHCLK_TIM15 ((uint32_t)0x00040000)
Kojto 90:cb3d968589d8 1011 #define RCC_PERIPHCLK_TIM16 ((uint32_t)0x00080000)
Kojto 90:cb3d968589d8 1012 #define RCC_PERIPHCLK_TIM17 ((uint32_t)0x00100000)
Kojto 90:cb3d968589d8 1013
Kojto 122:f9eeca106725 1014
Kojto 90:cb3d968589d8 1015 #endif /* STM32F302x8 */
Kojto 90:cb3d968589d8 1016
Kojto 90:cb3d968589d8 1017 #if defined(STM32F302xC)
Kojto 90:cb3d968589d8 1018 #define RCC_PERIPHCLK_USART1 ((uint32_t)0x00000001)
Kojto 90:cb3d968589d8 1019 #define RCC_PERIPHCLK_USART2 ((uint32_t)0x00000002)
Kojto 90:cb3d968589d8 1020 #define RCC_PERIPHCLK_USART3 ((uint32_t)0x00000004)
Kojto 90:cb3d968589d8 1021 #define RCC_PERIPHCLK_UART4 ((uint32_t)0x00000008)
Kojto 90:cb3d968589d8 1022 #define RCC_PERIPHCLK_UART5 ((uint32_t)0x00000010)
Kojto 90:cb3d968589d8 1023 #define RCC_PERIPHCLK_I2C1 ((uint32_t)0x00000020)
Kojto 90:cb3d968589d8 1024 #define RCC_PERIPHCLK_I2C2 ((uint32_t)0x00000040)
Kojto 90:cb3d968589d8 1025 #define RCC_PERIPHCLK_ADC12 ((uint32_t)0x00000080)
Kojto 90:cb3d968589d8 1026 #define RCC_PERIPHCLK_I2S ((uint32_t)0x00000200)
Kojto 90:cb3d968589d8 1027 #define RCC_PERIPHCLK_TIM1 ((uint32_t)0x00001000)
Kojto 90:cb3d968589d8 1028 #define RCC_PERIPHCLK_RTC ((uint32_t)0x00010000)
Kojto 90:cb3d968589d8 1029 #define RCC_PERIPHCLK_USB ((uint32_t)0x00020000)
Kojto 90:cb3d968589d8 1030
Kojto 90:cb3d968589d8 1031 #endif /* STM32F302xC */
Kojto 90:cb3d968589d8 1032
Kojto 90:cb3d968589d8 1033 #if defined(STM32F303xC)
Kojto 90:cb3d968589d8 1034 #define RCC_PERIPHCLK_USART1 ((uint32_t)0x00000001)
Kojto 90:cb3d968589d8 1035 #define RCC_PERIPHCLK_USART2 ((uint32_t)0x00000002)
Kojto 90:cb3d968589d8 1036 #define RCC_PERIPHCLK_USART3 ((uint32_t)0x00000004)
Kojto 90:cb3d968589d8 1037 #define RCC_PERIPHCLK_UART4 ((uint32_t)0x00000008)
Kojto 90:cb3d968589d8 1038 #define RCC_PERIPHCLK_UART5 ((uint32_t)0x00000010)
Kojto 90:cb3d968589d8 1039 #define RCC_PERIPHCLK_I2C1 ((uint32_t)0x00000020)
Kojto 90:cb3d968589d8 1040 #define RCC_PERIPHCLK_I2C2 ((uint32_t)0x00000040)
Kojto 90:cb3d968589d8 1041 #define RCC_PERIPHCLK_ADC12 ((uint32_t)0x00000080)
Kojto 90:cb3d968589d8 1042 #define RCC_PERIPHCLK_ADC34 ((uint32_t)0x00000100)
Kojto 90:cb3d968589d8 1043 #define RCC_PERIPHCLK_I2S ((uint32_t)0x00000200)
Kojto 90:cb3d968589d8 1044 #define RCC_PERIPHCLK_TIM1 ((uint32_t)0x00001000)
Kojto 90:cb3d968589d8 1045 #define RCC_PERIPHCLK_TIM8 ((uint32_t)0x00002000)
Kojto 90:cb3d968589d8 1046 #define RCC_PERIPHCLK_RTC ((uint32_t)0x00010000)
Kojto 90:cb3d968589d8 1047 #define RCC_PERIPHCLK_USB ((uint32_t)0x00020000)
Kojto 90:cb3d968589d8 1048
Kojto 90:cb3d968589d8 1049 #endif /* STM32F303xC */
Kojto 90:cb3d968589d8 1050
Kojto 90:cb3d968589d8 1051 #if defined(STM32F302xE)
Kojto 90:cb3d968589d8 1052 #define RCC_PERIPHCLK_USART1 ((uint32_t)0x00000001)
Kojto 90:cb3d968589d8 1053 #define RCC_PERIPHCLK_USART2 ((uint32_t)0x00000002)
Kojto 90:cb3d968589d8 1054 #define RCC_PERIPHCLK_USART3 ((uint32_t)0x00000004)
Kojto 90:cb3d968589d8 1055 #define RCC_PERIPHCLK_UART4 ((uint32_t)0x00000008)
Kojto 90:cb3d968589d8 1056 #define RCC_PERIPHCLK_UART5 ((uint32_t)0x00000010)
Kojto 90:cb3d968589d8 1057 #define RCC_PERIPHCLK_I2C1 ((uint32_t)0x00000020)
Kojto 90:cb3d968589d8 1058 #define RCC_PERIPHCLK_I2C2 ((uint32_t)0x00000040)
Kojto 90:cb3d968589d8 1059 #define RCC_PERIPHCLK_ADC12 ((uint32_t)0x00000080)
Kojto 90:cb3d968589d8 1060 #define RCC_PERIPHCLK_I2S ((uint32_t)0x00000200)
Kojto 90:cb3d968589d8 1061 #define RCC_PERIPHCLK_TIM1 ((uint32_t)0x00001000)
Kojto 90:cb3d968589d8 1062 #define RCC_PERIPHCLK_RTC ((uint32_t)0x00010000)
Kojto 90:cb3d968589d8 1063 #define RCC_PERIPHCLK_USB ((uint32_t)0x00020000)
Kojto 90:cb3d968589d8 1064 #define RCC_PERIPHCLK_I2C3 ((uint32_t)0x00040000)
Kojto 90:cb3d968589d8 1065 #define RCC_PERIPHCLK_TIM2 ((uint32_t)0x00100000)
Kojto 90:cb3d968589d8 1066 #define RCC_PERIPHCLK_TIM34 ((uint32_t)0x00200000)
Kojto 90:cb3d968589d8 1067 #define RCC_PERIPHCLK_TIM15 ((uint32_t)0x00400000)
Kojto 90:cb3d968589d8 1068 #define RCC_PERIPHCLK_TIM16 ((uint32_t)0x00800000)
Kojto 90:cb3d968589d8 1069 #define RCC_PERIPHCLK_TIM17 ((uint32_t)0x01000000)
Kojto 90:cb3d968589d8 1070
Kojto 90:cb3d968589d8 1071 #endif /* STM32F302xE */
Kojto 90:cb3d968589d8 1072
Kojto 90:cb3d968589d8 1073 #if defined(STM32F303xE)
Kojto 90:cb3d968589d8 1074 #define RCC_PERIPHCLK_USART1 ((uint32_t)0x00000001)
Kojto 90:cb3d968589d8 1075 #define RCC_PERIPHCLK_USART2 ((uint32_t)0x00000002)
Kojto 90:cb3d968589d8 1076 #define RCC_PERIPHCLK_USART3 ((uint32_t)0x00000004)
Kojto 90:cb3d968589d8 1077 #define RCC_PERIPHCLK_UART4 ((uint32_t)0x00000008)
Kojto 90:cb3d968589d8 1078 #define RCC_PERIPHCLK_UART5 ((uint32_t)0x00000010)
Kojto 90:cb3d968589d8 1079 #define RCC_PERIPHCLK_I2C1 ((uint32_t)0x00000020)
Kojto 90:cb3d968589d8 1080 #define RCC_PERIPHCLK_I2C2 ((uint32_t)0x00000040)
Kojto 90:cb3d968589d8 1081 #define RCC_PERIPHCLK_ADC12 ((uint32_t)0x00000080)
Kojto 90:cb3d968589d8 1082 #define RCC_PERIPHCLK_ADC34 ((uint32_t)0x00000100)
Kojto 90:cb3d968589d8 1083 #define RCC_PERIPHCLK_I2S ((uint32_t)0x00000200)
Kojto 90:cb3d968589d8 1084 #define RCC_PERIPHCLK_TIM1 ((uint32_t)0x00001000)
Kojto 90:cb3d968589d8 1085 #define RCC_PERIPHCLK_TIM8 ((uint32_t)0x00002000)
Kojto 90:cb3d968589d8 1086 #define RCC_PERIPHCLK_RTC ((uint32_t)0x00010000)
Kojto 90:cb3d968589d8 1087 #define RCC_PERIPHCLK_USB ((uint32_t)0x00020000)
Kojto 90:cb3d968589d8 1088 #define RCC_PERIPHCLK_I2C3 ((uint32_t)0x00040000)
Kojto 90:cb3d968589d8 1089 #define RCC_PERIPHCLK_TIM2 ((uint32_t)0x00100000)
Kojto 90:cb3d968589d8 1090 #define RCC_PERIPHCLK_TIM34 ((uint32_t)0x00200000)
Kojto 90:cb3d968589d8 1091 #define RCC_PERIPHCLK_TIM15 ((uint32_t)0x00400000)
Kojto 90:cb3d968589d8 1092 #define RCC_PERIPHCLK_TIM16 ((uint32_t)0x00800000)
Kojto 90:cb3d968589d8 1093 #define RCC_PERIPHCLK_TIM17 ((uint32_t)0x01000000)
Kojto 90:cb3d968589d8 1094 #define RCC_PERIPHCLK_TIM20 ((uint32_t)0x02000000)
Kojto 90:cb3d968589d8 1095
Kojto 90:cb3d968589d8 1096 #endif /* STM32F303xE */
Kojto 90:cb3d968589d8 1097
Kojto 90:cb3d968589d8 1098 #if defined(STM32F398xx)
Kojto 90:cb3d968589d8 1099 #define RCC_PERIPHCLK_USART1 ((uint32_t)0x00000001)
Kojto 90:cb3d968589d8 1100 #define RCC_PERIPHCLK_USART2 ((uint32_t)0x00000002)
Kojto 90:cb3d968589d8 1101 #define RCC_PERIPHCLK_USART3 ((uint32_t)0x00000004)
Kojto 90:cb3d968589d8 1102 #define RCC_PERIPHCLK_UART4 ((uint32_t)0x00000008)
Kojto 90:cb3d968589d8 1103 #define RCC_PERIPHCLK_UART5 ((uint32_t)0x00000010)
Kojto 90:cb3d968589d8 1104 #define RCC_PERIPHCLK_I2C1 ((uint32_t)0x00000020)
Kojto 90:cb3d968589d8 1105 #define RCC_PERIPHCLK_I2C2 ((uint32_t)0x00000040)
Kojto 90:cb3d968589d8 1106 #define RCC_PERIPHCLK_ADC12 ((uint32_t)0x00000080)
Kojto 90:cb3d968589d8 1107 #define RCC_PERIPHCLK_ADC34 ((uint32_t)0x00000100)
Kojto 90:cb3d968589d8 1108 #define RCC_PERIPHCLK_I2S ((uint32_t)0x00000200)
Kojto 90:cb3d968589d8 1109 #define RCC_PERIPHCLK_TIM1 ((uint32_t)0x00001000)
Kojto 90:cb3d968589d8 1110 #define RCC_PERIPHCLK_TIM8 ((uint32_t)0x00002000)
Kojto 90:cb3d968589d8 1111 #define RCC_PERIPHCLK_RTC ((uint32_t)0x00010000)
Kojto 90:cb3d968589d8 1112 #define RCC_PERIPHCLK_I2C3 ((uint32_t)0x00040000)
Kojto 90:cb3d968589d8 1113 #define RCC_PERIPHCLK_TIM2 ((uint32_t)0x00100000)
Kojto 90:cb3d968589d8 1114 #define RCC_PERIPHCLK_TIM34 ((uint32_t)0x00200000)
Kojto 90:cb3d968589d8 1115 #define RCC_PERIPHCLK_TIM15 ((uint32_t)0x00400000)
Kojto 90:cb3d968589d8 1116 #define RCC_PERIPHCLK_TIM16 ((uint32_t)0x00800000)
Kojto 90:cb3d968589d8 1117 #define RCC_PERIPHCLK_TIM17 ((uint32_t)0x01000000)
Kojto 90:cb3d968589d8 1118 #define RCC_PERIPHCLK_TIM20 ((uint32_t)0x02000000)
Kojto 90:cb3d968589d8 1119
Kojto 122:f9eeca106725 1120
Kojto 90:cb3d968589d8 1121 #endif /* STM32F398xx */
Kojto 90:cb3d968589d8 1122
Kojto 90:cb3d968589d8 1123 #if defined(STM32F358xx)
Kojto 90:cb3d968589d8 1124 #define RCC_PERIPHCLK_USART1 ((uint32_t)0x00000001)
Kojto 90:cb3d968589d8 1125 #define RCC_PERIPHCLK_USART2 ((uint32_t)0x00000002)
Kojto 90:cb3d968589d8 1126 #define RCC_PERIPHCLK_USART3 ((uint32_t)0x00000004)
Kojto 90:cb3d968589d8 1127 #define RCC_PERIPHCLK_UART4 ((uint32_t)0x00000008)
Kojto 90:cb3d968589d8 1128 #define RCC_PERIPHCLK_UART5 ((uint32_t)0x00000010)
Kojto 90:cb3d968589d8 1129 #define RCC_PERIPHCLK_I2C1 ((uint32_t)0x00000020)
Kojto 90:cb3d968589d8 1130 #define RCC_PERIPHCLK_I2C2 ((uint32_t)0x00000040)
Kojto 90:cb3d968589d8 1131 #define RCC_PERIPHCLK_ADC12 ((uint32_t)0x00000080)
Kojto 90:cb3d968589d8 1132 #define RCC_PERIPHCLK_ADC34 ((uint32_t)0x00000100)
Kojto 90:cb3d968589d8 1133 #define RCC_PERIPHCLK_I2S ((uint32_t)0x00000200)
Kojto 90:cb3d968589d8 1134 #define RCC_PERIPHCLK_TIM1 ((uint32_t)0x00001000)
Kojto 90:cb3d968589d8 1135 #define RCC_PERIPHCLK_TIM8 ((uint32_t)0x00002000)
Kojto 90:cb3d968589d8 1136 #define RCC_PERIPHCLK_RTC ((uint32_t)0x00010000)
Kojto 90:cb3d968589d8 1137
Kojto 90:cb3d968589d8 1138 #endif /* STM32F358xx */
Kojto 90:cb3d968589d8 1139
Kojto 90:cb3d968589d8 1140 #if defined(STM32F303x8)
Kojto 90:cb3d968589d8 1141 #define RCC_PERIPHCLK_USART1 ((uint32_t)0x00000001)
Kojto 90:cb3d968589d8 1142 #define RCC_PERIPHCLK_I2C1 ((uint32_t)0x00000020)
Kojto 90:cb3d968589d8 1143 #define RCC_PERIPHCLK_ADC12 ((uint32_t)0x00000080)
Kojto 90:cb3d968589d8 1144 #define RCC_PERIPHCLK_TIM1 ((uint32_t)0x00001000)
Kojto 90:cb3d968589d8 1145 #define RCC_PERIPHCLK_RTC ((uint32_t)0x00010000)
Kojto 90:cb3d968589d8 1146
Kojto 90:cb3d968589d8 1147 #endif /* STM32F303x8 */
Kojto 90:cb3d968589d8 1148
Kojto 90:cb3d968589d8 1149 #if defined(STM32F334x8)
Kojto 90:cb3d968589d8 1150 #define RCC_PERIPHCLK_USART1 ((uint32_t)0x00000001)
Kojto 90:cb3d968589d8 1151 #define RCC_PERIPHCLK_I2C1 ((uint32_t)0x00000020)
Kojto 90:cb3d968589d8 1152 #define RCC_PERIPHCLK_ADC12 ((uint32_t)0x00000080)
Kojto 90:cb3d968589d8 1153 #define RCC_PERIPHCLK_TIM1 ((uint32_t)0x00001000)
Kojto 90:cb3d968589d8 1154 #define RCC_PERIPHCLK_HRTIM1 ((uint32_t)0x00004000)
Kojto 90:cb3d968589d8 1155 #define RCC_PERIPHCLK_RTC ((uint32_t)0x00010000)
Kojto 90:cb3d968589d8 1156
Kojto 122:f9eeca106725 1157
Kojto 90:cb3d968589d8 1158 #endif /* STM32F334x8 */
Kojto 90:cb3d968589d8 1159
Kojto 90:cb3d968589d8 1160 #if defined(STM32F328xx)
Kojto 90:cb3d968589d8 1161 #define RCC_PERIPHCLK_USART1 ((uint32_t)0x00000001)
Kojto 90:cb3d968589d8 1162 #define RCC_PERIPHCLK_I2C1 ((uint32_t)0x00000020)
Kojto 90:cb3d968589d8 1163 #define RCC_PERIPHCLK_ADC12 ((uint32_t)0x00000080)
Kojto 90:cb3d968589d8 1164 #define RCC_PERIPHCLK_TIM1 ((uint32_t)0x00001000)
Kojto 90:cb3d968589d8 1165 #define RCC_PERIPHCLK_RTC ((uint32_t)0x00010000)
Kojto 90:cb3d968589d8 1166
Kojto 90:cb3d968589d8 1167 #endif /* STM32F328xx */
Kojto 90:cb3d968589d8 1168
Kojto 90:cb3d968589d8 1169 #if defined(STM32F373xC)
Kojto 90:cb3d968589d8 1170 #define RCC_PERIPHCLK_USART1 ((uint32_t)0x00000001)
Kojto 90:cb3d968589d8 1171 #define RCC_PERIPHCLK_USART2 ((uint32_t)0x00000002)
Kojto 90:cb3d968589d8 1172 #define RCC_PERIPHCLK_USART3 ((uint32_t)0x00000004)
Kojto 90:cb3d968589d8 1173 #define RCC_PERIPHCLK_I2C1 ((uint32_t)0x00000020)
Kojto 90:cb3d968589d8 1174 #define RCC_PERIPHCLK_I2C2 ((uint32_t)0x00000040)
Kojto 90:cb3d968589d8 1175 #define RCC_PERIPHCLK_ADC1 ((uint32_t)0x00000080)
Kojto 90:cb3d968589d8 1176 #define RCC_PERIPHCLK_CEC ((uint32_t)0x00000400)
Kojto 90:cb3d968589d8 1177 #define RCC_PERIPHCLK_SDADC ((uint32_t)0x00000800)
Kojto 90:cb3d968589d8 1178 #define RCC_PERIPHCLK_RTC ((uint32_t)0x00010000)
Kojto 90:cb3d968589d8 1179 #define RCC_PERIPHCLK_USB ((uint32_t)0x00020000)
Kojto 90:cb3d968589d8 1180
Kojto 90:cb3d968589d8 1181 #endif /* STM32F373xC */
Kojto 90:cb3d968589d8 1182
Kojto 90:cb3d968589d8 1183 #if defined(STM32F378xx)
Kojto 90:cb3d968589d8 1184 #define RCC_PERIPHCLK_USART1 ((uint32_t)0x00000001)
Kojto 90:cb3d968589d8 1185 #define RCC_PERIPHCLK_USART2 ((uint32_t)0x00000002)
Kojto 90:cb3d968589d8 1186 #define RCC_PERIPHCLK_USART3 ((uint32_t)0x00000004)
Kojto 90:cb3d968589d8 1187 #define RCC_PERIPHCLK_I2C1 ((uint32_t)0x00000020)
Kojto 90:cb3d968589d8 1188 #define RCC_PERIPHCLK_I2C2 ((uint32_t)0x00000040)
Kojto 90:cb3d968589d8 1189 #define RCC_PERIPHCLK_ADC1 ((uint32_t)0x00000080)
Kojto 90:cb3d968589d8 1190 #define RCC_PERIPHCLK_CEC ((uint32_t)0x00000400)
Kojto 90:cb3d968589d8 1191 #define RCC_PERIPHCLK_SDADC ((uint32_t)0x00000800)
Kojto 90:cb3d968589d8 1192 #define RCC_PERIPHCLK_RTC ((uint32_t)0x00010000)
Kojto 90:cb3d968589d8 1193
Kojto 90:cb3d968589d8 1194 #endif /* STM32F378xx */
Kojto 90:cb3d968589d8 1195 /**
Kojto 90:cb3d968589d8 1196 * @}
Kojto 90:cb3d968589d8 1197 */
Kojto 90:cb3d968589d8 1198
Kojto 90:cb3d968589d8 1199 #if defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)
Kojto 90:cb3d968589d8 1200
Kojto 90:cb3d968589d8 1201 /** @defgroup RCCEx_USART1_Clock_Source RCC Extended USART1 Clock Source
Kojto 90:cb3d968589d8 1202 * @{
Kojto 90:cb3d968589d8 1203 */
Kojto 122:f9eeca106725 1204 #define RCC_USART1CLKSOURCE_PCLK1 RCC_CFGR3_USART1SW_PCLK1
Kojto 90:cb3d968589d8 1205 #define RCC_USART1CLKSOURCE_SYSCLK RCC_CFGR3_USART1SW_SYSCLK
Kojto 90:cb3d968589d8 1206 #define RCC_USART1CLKSOURCE_LSE RCC_CFGR3_USART1SW_LSE
Kojto 90:cb3d968589d8 1207 #define RCC_USART1CLKSOURCE_HSI RCC_CFGR3_USART1SW_HSI
Kojto 90:cb3d968589d8 1208
Kojto 90:cb3d968589d8 1209 /**
Kojto 90:cb3d968589d8 1210 * @}
Kojto 90:cb3d968589d8 1211 */
Kojto 90:cb3d968589d8 1212
Kojto 90:cb3d968589d8 1213 /** @defgroup RCCEx_I2C2_Clock_Source RCC Extended I2C2 Clock Source
Kojto 90:cb3d968589d8 1214 * @{
Kojto 90:cb3d968589d8 1215 */
Kojto 90:cb3d968589d8 1216 #define RCC_I2C2CLKSOURCE_HSI RCC_CFGR3_I2C2SW_HSI
Kojto 90:cb3d968589d8 1217 #define RCC_I2C2CLKSOURCE_SYSCLK RCC_CFGR3_I2C2SW_SYSCLK
Kojto 90:cb3d968589d8 1218
Kojto 90:cb3d968589d8 1219 /**
Kojto 90:cb3d968589d8 1220 * @}
Kojto 90:cb3d968589d8 1221 */
Kojto 90:cb3d968589d8 1222
Kojto 90:cb3d968589d8 1223 /** @defgroup RCCEx_I2C3_Clock_Source RCC Extended I2C3 Clock Source
Kojto 90:cb3d968589d8 1224 * @{
Kojto 90:cb3d968589d8 1225 */
Kojto 90:cb3d968589d8 1226 #define RCC_I2C3CLKSOURCE_HSI RCC_CFGR3_I2C3SW_HSI
Kojto 90:cb3d968589d8 1227 #define RCC_I2C3CLKSOURCE_SYSCLK RCC_CFGR3_I2C3SW_SYSCLK
Kojto 90:cb3d968589d8 1228
Kojto 90:cb3d968589d8 1229 /**
Kojto 90:cb3d968589d8 1230 * @}
Kojto 90:cb3d968589d8 1231 */
Kojto 90:cb3d968589d8 1232
Kojto 90:cb3d968589d8 1233 /** @defgroup RCCEx_ADC1_Clock_Source RCC Extended ADC1 Clock Source
Kojto 90:cb3d968589d8 1234 * @{
Kojto 90:cb3d968589d8 1235 */
Kojto 90:cb3d968589d8 1236 #define RCC_ADC1PLLCLK_OFF RCC_CFGR2_ADC1PRES_NO
Kojto 90:cb3d968589d8 1237 #define RCC_ADC1PLLCLK_DIV1 RCC_CFGR2_ADC1PRES_DIV1
Kojto 90:cb3d968589d8 1238 #define RCC_ADC1PLLCLK_DIV2 RCC_CFGR2_ADC1PRES_DIV2
Kojto 90:cb3d968589d8 1239 #define RCC_ADC1PLLCLK_DIV4 RCC_CFGR2_ADC1PRES_DIV4
Kojto 90:cb3d968589d8 1240 #define RCC_ADC1PLLCLK_DIV6 RCC_CFGR2_ADC1PRES_DIV6
Kojto 90:cb3d968589d8 1241 #define RCC_ADC1PLLCLK_DIV8 RCC_CFGR2_ADC1PRES_DIV8
Kojto 90:cb3d968589d8 1242 #define RCC_ADC1PLLCLK_DIV10 RCC_CFGR2_ADC1PRES_DIV10
Kojto 90:cb3d968589d8 1243 #define RCC_ADC1PLLCLK_DIV12 RCC_CFGR2_ADC1PRES_DIV12
Kojto 90:cb3d968589d8 1244 #define RCC_ADC1PLLCLK_DIV16 RCC_CFGR2_ADC1PRES_DIV16
Kojto 90:cb3d968589d8 1245 #define RCC_ADC1PLLCLK_DIV32 RCC_CFGR2_ADC1PRES_DIV32
Kojto 90:cb3d968589d8 1246 #define RCC_ADC1PLLCLK_DIV64 RCC_CFGR2_ADC1PRES_DIV64
Kojto 90:cb3d968589d8 1247 #define RCC_ADC1PLLCLK_DIV128 RCC_CFGR2_ADC1PRES_DIV128
Kojto 90:cb3d968589d8 1248 #define RCC_ADC1PLLCLK_DIV256 RCC_CFGR2_ADC1PRES_DIV256
Kojto 90:cb3d968589d8 1249
Kojto 90:cb3d968589d8 1250 /**
Kojto 90:cb3d968589d8 1251 * @}
Kojto 90:cb3d968589d8 1252 */
Kojto 90:cb3d968589d8 1253
Kojto 90:cb3d968589d8 1254 /** @defgroup RCCEx_I2S_Clock_Source RCC Extended I2S Clock Source
Kojto 90:cb3d968589d8 1255 * @{
Kojto 90:cb3d968589d8 1256 */
Kojto 90:cb3d968589d8 1257 #define RCC_I2SCLKSOURCE_SYSCLK RCC_CFGR_I2SSRC_SYSCLK
Kojto 90:cb3d968589d8 1258 #define RCC_I2SCLKSOURCE_EXT RCC_CFGR_I2SSRC_EXT
Kojto 90:cb3d968589d8 1259
Kojto 90:cb3d968589d8 1260 /**
Kojto 90:cb3d968589d8 1261 * @}
Kojto 90:cb3d968589d8 1262 */
Kojto 90:cb3d968589d8 1263
Kojto 90:cb3d968589d8 1264 /** @defgroup RCCEx_TIM1_Clock_Source RCC Extended TIM1 Clock Source
Kojto 90:cb3d968589d8 1265 * @{
Kojto 90:cb3d968589d8 1266 */
Kojto 90:cb3d968589d8 1267 #define RCC_TIM1CLK_HCLK RCC_CFGR3_TIM1SW_HCLK
Kojto 90:cb3d968589d8 1268 #define RCC_TIM1CLK_PLLCLK RCC_CFGR3_TIM1SW_PLL
Kojto 90:cb3d968589d8 1269
Kojto 90:cb3d968589d8 1270 /**
Kojto 90:cb3d968589d8 1271 * @}
Kojto 90:cb3d968589d8 1272 */
Kojto 90:cb3d968589d8 1273
Kojto 90:cb3d968589d8 1274 /** @defgroup RCCEx_TIM15_Clock_Source RCC Extended TIM15 Clock Source
Kojto 90:cb3d968589d8 1275 * @{
Kojto 90:cb3d968589d8 1276 */
Kojto 90:cb3d968589d8 1277 #define RCC_TIM15CLK_HCLK RCC_CFGR3_TIM15SW_HCLK
Kojto 90:cb3d968589d8 1278 #define RCC_TIM15CLK_PLLCLK RCC_CFGR3_TIM15SW_PLL
Kojto 90:cb3d968589d8 1279
Kojto 90:cb3d968589d8 1280 /**
Kojto 90:cb3d968589d8 1281 * @}
Kojto 90:cb3d968589d8 1282 */
Kojto 90:cb3d968589d8 1283
Kojto 90:cb3d968589d8 1284 /** @defgroup RCCEx_TIM16_Clock_Source RCC Extended TIM16 Clock Source
Kojto 90:cb3d968589d8 1285 * @{
Kojto 90:cb3d968589d8 1286 */
Kojto 90:cb3d968589d8 1287 #define RCC_TIM16CLK_HCLK RCC_CFGR3_TIM16SW_HCLK
Kojto 90:cb3d968589d8 1288 #define RCC_TIM16CLK_PLLCLK RCC_CFGR3_TIM16SW_PLL
Kojto 90:cb3d968589d8 1289
Kojto 90:cb3d968589d8 1290 /**
Kojto 90:cb3d968589d8 1291 * @}
Kojto 90:cb3d968589d8 1292 */
Kojto 90:cb3d968589d8 1293
Kojto 90:cb3d968589d8 1294 /** @defgroup RCCEx_TIM17_Clock_Source RCC Extended TIM17 Clock Source
Kojto 90:cb3d968589d8 1295 * @{
Kojto 90:cb3d968589d8 1296 */
Kojto 90:cb3d968589d8 1297 #define RCC_TIM17CLK_HCLK RCC_CFGR3_TIM17SW_HCLK
Kojto 90:cb3d968589d8 1298 #define RCC_TIM17CLK_PLLCLK RCC_CFGR3_TIM17SW_PLL
Kojto 90:cb3d968589d8 1299
Kojto 90:cb3d968589d8 1300 /**
Kojto 90:cb3d968589d8 1301 * @}
Kojto 90:cb3d968589d8 1302 */
Kojto 90:cb3d968589d8 1303
Kojto 90:cb3d968589d8 1304 #endif /* STM32F301x8 || STM32F302x8 || STM32F318xx */
Kojto 90:cb3d968589d8 1305
Kojto 90:cb3d968589d8 1306 #if defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 90:cb3d968589d8 1307
Kojto 90:cb3d968589d8 1308 /** @defgroup RCCEx_USART1_Clock_Source RCC Extended USART1 Clock Source
Kojto 90:cb3d968589d8 1309 * @{
Kojto 90:cb3d968589d8 1310 */
Kojto 122:f9eeca106725 1311 #define RCC_USART1CLKSOURCE_PCLK2 RCC_CFGR3_USART1SW_PCLK2
Kojto 90:cb3d968589d8 1312 #define RCC_USART1CLKSOURCE_SYSCLK RCC_CFGR3_USART1SW_SYSCLK
Kojto 90:cb3d968589d8 1313 #define RCC_USART1CLKSOURCE_LSE RCC_CFGR3_USART1SW_LSE
Kojto 90:cb3d968589d8 1314 #define RCC_USART1CLKSOURCE_HSI RCC_CFGR3_USART1SW_HSI
Kojto 90:cb3d968589d8 1315
Kojto 90:cb3d968589d8 1316 /**
Kojto 90:cb3d968589d8 1317 * @}
Kojto 90:cb3d968589d8 1318 */
Kojto 90:cb3d968589d8 1319
Kojto 90:cb3d968589d8 1320 /** @defgroup RCCEx_I2C2_Clock_Source RCC Extended I2C2 Clock Source
Kojto 90:cb3d968589d8 1321 * @{
Kojto 90:cb3d968589d8 1322 */
Kojto 90:cb3d968589d8 1323 #define RCC_I2C2CLKSOURCE_HSI RCC_CFGR3_I2C2SW_HSI
Kojto 90:cb3d968589d8 1324 #define RCC_I2C2CLKSOURCE_SYSCLK RCC_CFGR3_I2C2SW_SYSCLK
Kojto 90:cb3d968589d8 1325
Kojto 90:cb3d968589d8 1326 /**
Kojto 90:cb3d968589d8 1327 * @}
Kojto 90:cb3d968589d8 1328 */
Kojto 90:cb3d968589d8 1329
Kojto 90:cb3d968589d8 1330 /** @defgroup RCCEx_ADC12_Clock_Source RCC Extended ADC12 Clock Source
Kojto 90:cb3d968589d8 1331 * @{
Kojto 90:cb3d968589d8 1332 */
Kojto 90:cb3d968589d8 1333
Kojto 90:cb3d968589d8 1334 /* ADC1 & ADC2 */
Kojto 90:cb3d968589d8 1335 #define RCC_ADC12PLLCLK_OFF RCC_CFGR2_ADCPRE12_NO
Kojto 90:cb3d968589d8 1336 #define RCC_ADC12PLLCLK_DIV1 RCC_CFGR2_ADCPRE12_DIV1
Kojto 90:cb3d968589d8 1337 #define RCC_ADC12PLLCLK_DIV2 RCC_CFGR2_ADCPRE12_DIV2
Kojto 90:cb3d968589d8 1338 #define RCC_ADC12PLLCLK_DIV4 RCC_CFGR2_ADCPRE12_DIV4
Kojto 90:cb3d968589d8 1339 #define RCC_ADC12PLLCLK_DIV6 RCC_CFGR2_ADCPRE12_DIV6
Kojto 90:cb3d968589d8 1340 #define RCC_ADC12PLLCLK_DIV8 RCC_CFGR2_ADCPRE12_DIV8
Kojto 90:cb3d968589d8 1341 #define RCC_ADC12PLLCLK_DIV10 RCC_CFGR2_ADCPRE12_DIV10
Kojto 90:cb3d968589d8 1342 #define RCC_ADC12PLLCLK_DIV12 RCC_CFGR2_ADCPRE12_DIV12
Kojto 90:cb3d968589d8 1343 #define RCC_ADC12PLLCLK_DIV16 RCC_CFGR2_ADCPRE12_DIV16
Kojto 90:cb3d968589d8 1344 #define RCC_ADC12PLLCLK_DIV32 RCC_CFGR2_ADCPRE12_DIV32
Kojto 90:cb3d968589d8 1345 #define RCC_ADC12PLLCLK_DIV64 RCC_CFGR2_ADCPRE12_DIV64
Kojto 90:cb3d968589d8 1346 #define RCC_ADC12PLLCLK_DIV128 RCC_CFGR2_ADCPRE12_DIV128
Kojto 90:cb3d968589d8 1347 #define RCC_ADC12PLLCLK_DIV256 RCC_CFGR2_ADCPRE12_DIV256
Kojto 90:cb3d968589d8 1348
Kojto 90:cb3d968589d8 1349 /**
Kojto 90:cb3d968589d8 1350 * @}
Kojto 90:cb3d968589d8 1351 */
Kojto 90:cb3d968589d8 1352
Kojto 90:cb3d968589d8 1353 /** @defgroup RCCEx_I2S_Clock_Source RCC Extended I2S Clock Source
Kojto 90:cb3d968589d8 1354 * @{
Kojto 90:cb3d968589d8 1355 */
Kojto 90:cb3d968589d8 1356 #define RCC_I2SCLKSOURCE_SYSCLK RCC_CFGR_I2SSRC_SYSCLK
Kojto 90:cb3d968589d8 1357 #define RCC_I2SCLKSOURCE_EXT RCC_CFGR_I2SSRC_EXT
Kojto 90:cb3d968589d8 1358
Kojto 90:cb3d968589d8 1359 /**
Kojto 90:cb3d968589d8 1360 * @}
Kojto 90:cb3d968589d8 1361 */
Kojto 90:cb3d968589d8 1362 /** @defgroup RCCEx_TIM1_Clock_Source RCC Extended TIM1 Clock Source
Kojto 90:cb3d968589d8 1363 * @{
Kojto 90:cb3d968589d8 1364 */
Kojto 90:cb3d968589d8 1365 #define RCC_TIM1CLK_HCLK RCC_CFGR3_TIM1SW_HCLK
Kojto 90:cb3d968589d8 1366 #define RCC_TIM1CLK_PLLCLK RCC_CFGR3_TIM1SW_PLL
Kojto 90:cb3d968589d8 1367
Kojto 90:cb3d968589d8 1368 /**
Kojto 90:cb3d968589d8 1369 * @}
Kojto 90:cb3d968589d8 1370 */
Kojto 90:cb3d968589d8 1371
Kojto 90:cb3d968589d8 1372 /** @defgroup RCCEx_UART4_Clock_Source RCC Extended UART4 Clock Source
Kojto 90:cb3d968589d8 1373 * @{
Kojto 90:cb3d968589d8 1374 */
Kojto 90:cb3d968589d8 1375 #define RCC_UART4CLKSOURCE_PCLK1 RCC_CFGR3_UART4SW_PCLK
Kojto 90:cb3d968589d8 1376 #define RCC_UART4CLKSOURCE_SYSCLK RCC_CFGR3_UART4SW_SYSCLK
Kojto 90:cb3d968589d8 1377 #define RCC_UART4CLKSOURCE_LSE RCC_CFGR3_UART4SW_LSE
Kojto 90:cb3d968589d8 1378 #define RCC_UART4CLKSOURCE_HSI RCC_CFGR3_UART4SW_HSI
Kojto 90:cb3d968589d8 1379
Kojto 90:cb3d968589d8 1380 /**
Kojto 90:cb3d968589d8 1381 * @}
Kojto 90:cb3d968589d8 1382 */
Kojto 90:cb3d968589d8 1383
Kojto 90:cb3d968589d8 1384 /** @defgroup RCCEx_UART5_Clock_Source RCC Extended UART5 Clock Source
Kojto 90:cb3d968589d8 1385 * @{
Kojto 90:cb3d968589d8 1386 */
Kojto 90:cb3d968589d8 1387 #define RCC_UART5CLKSOURCE_PCLK1 RCC_CFGR3_UART5SW_PCLK
Kojto 90:cb3d968589d8 1388 #define RCC_UART5CLKSOURCE_SYSCLK RCC_CFGR3_UART5SW_SYSCLK
Kojto 90:cb3d968589d8 1389 #define RCC_UART5CLKSOURCE_LSE RCC_CFGR3_UART5SW_LSE
Kojto 90:cb3d968589d8 1390 #define RCC_UART5CLKSOURCE_HSI RCC_CFGR3_UART5SW_HSI
Kojto 90:cb3d968589d8 1391
Kojto 90:cb3d968589d8 1392 /**
Kojto 90:cb3d968589d8 1393 * @}
Kojto 90:cb3d968589d8 1394 */
Kojto 90:cb3d968589d8 1395
Kojto 90:cb3d968589d8 1396 #endif /* STM32F302xC || STM32F303xC || STM32F358xx */
Kojto 90:cb3d968589d8 1397
Kojto 90:cb3d968589d8 1398 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 90:cb3d968589d8 1399
Kojto 90:cb3d968589d8 1400 /** @defgroup RCCEx_USART1_Clock_Source RCC Extended USART1 Clock Source
Kojto 90:cb3d968589d8 1401 * @{
Kojto 90:cb3d968589d8 1402 */
Kojto 122:f9eeca106725 1403 #define RCC_USART1CLKSOURCE_PCLK2 RCC_CFGR3_USART1SW_PCLK2
Kojto 90:cb3d968589d8 1404 #define RCC_USART1CLKSOURCE_SYSCLK RCC_CFGR3_USART1SW_SYSCLK
Kojto 90:cb3d968589d8 1405 #define RCC_USART1CLKSOURCE_LSE RCC_CFGR3_USART1SW_LSE
Kojto 90:cb3d968589d8 1406 #define RCC_USART1CLKSOURCE_HSI RCC_CFGR3_USART1SW_HSI
Kojto 90:cb3d968589d8 1407
Kojto 90:cb3d968589d8 1408 /**
Kojto 90:cb3d968589d8 1409 * @}
Kojto 90:cb3d968589d8 1410 */
Kojto 90:cb3d968589d8 1411
Kojto 90:cb3d968589d8 1412 /** @defgroup RCCEx_I2C2_Clock_Source RCC Extended I2C2 Clock Source
Kojto 90:cb3d968589d8 1413 * @{
Kojto 90:cb3d968589d8 1414 */
Kojto 90:cb3d968589d8 1415 #define RCC_I2C2CLKSOURCE_HSI RCC_CFGR3_I2C2SW_HSI
Kojto 90:cb3d968589d8 1416 #define RCC_I2C2CLKSOURCE_SYSCLK RCC_CFGR3_I2C2SW_SYSCLK
Kojto 90:cb3d968589d8 1417
Kojto 90:cb3d968589d8 1418 /**
Kojto 90:cb3d968589d8 1419 * @}
Kojto 90:cb3d968589d8 1420 */
Kojto 90:cb3d968589d8 1421
Kojto 90:cb3d968589d8 1422 /** @defgroup RCCEx_I2C3_Clock_Source RCC Extended I2C3 Clock Source
Kojto 90:cb3d968589d8 1423 * @{
Kojto 90:cb3d968589d8 1424 */
Kojto 90:cb3d968589d8 1425 #define RCC_I2C3CLKSOURCE_HSI RCC_CFGR3_I2C3SW_HSI
Kojto 90:cb3d968589d8 1426 #define RCC_I2C3CLKSOURCE_SYSCLK RCC_CFGR3_I2C3SW_SYSCLK
Kojto 90:cb3d968589d8 1427
Kojto 90:cb3d968589d8 1428 /**
Kojto 90:cb3d968589d8 1429 * @}
Kojto 90:cb3d968589d8 1430 */
Kojto 90:cb3d968589d8 1431
Kojto 90:cb3d968589d8 1432 /** @defgroup RCCEx_ADC12_Clock_Source RCC Extended ADC12 Clock Source
Kojto 90:cb3d968589d8 1433 * @{
Kojto 90:cb3d968589d8 1434 */
Kojto 90:cb3d968589d8 1435
Kojto 90:cb3d968589d8 1436 /* ADC1 & ADC2 */
Kojto 90:cb3d968589d8 1437 #define RCC_ADC12PLLCLK_OFF RCC_CFGR2_ADCPRE12_NO
Kojto 90:cb3d968589d8 1438 #define RCC_ADC12PLLCLK_DIV1 RCC_CFGR2_ADCPRE12_DIV1
Kojto 90:cb3d968589d8 1439 #define RCC_ADC12PLLCLK_DIV2 RCC_CFGR2_ADCPRE12_DIV2
Kojto 90:cb3d968589d8 1440 #define RCC_ADC12PLLCLK_DIV4 RCC_CFGR2_ADCPRE12_DIV4
Kojto 90:cb3d968589d8 1441 #define RCC_ADC12PLLCLK_DIV6 RCC_CFGR2_ADCPRE12_DIV6
Kojto 90:cb3d968589d8 1442 #define RCC_ADC12PLLCLK_DIV8 RCC_CFGR2_ADCPRE12_DIV8
Kojto 90:cb3d968589d8 1443 #define RCC_ADC12PLLCLK_DIV10 RCC_CFGR2_ADCPRE12_DIV10
Kojto 90:cb3d968589d8 1444 #define RCC_ADC12PLLCLK_DIV12 RCC_CFGR2_ADCPRE12_DIV12
Kojto 90:cb3d968589d8 1445 #define RCC_ADC12PLLCLK_DIV16 RCC_CFGR2_ADCPRE12_DIV16
Kojto 90:cb3d968589d8 1446 #define RCC_ADC12PLLCLK_DIV32 RCC_CFGR2_ADCPRE12_DIV32
Kojto 90:cb3d968589d8 1447 #define RCC_ADC12PLLCLK_DIV64 RCC_CFGR2_ADCPRE12_DIV64
Kojto 90:cb3d968589d8 1448 #define RCC_ADC12PLLCLK_DIV128 RCC_CFGR2_ADCPRE12_DIV128
Kojto 90:cb3d968589d8 1449 #define RCC_ADC12PLLCLK_DIV256 RCC_CFGR2_ADCPRE12_DIV256
Kojto 90:cb3d968589d8 1450
Kojto 90:cb3d968589d8 1451 /**
Kojto 90:cb3d968589d8 1452 * @}
Kojto 90:cb3d968589d8 1453 */
Kojto 90:cb3d968589d8 1454
Kojto 90:cb3d968589d8 1455 /** @defgroup RCCEx_I2S_Clock_Source RCC Extended I2S Clock Source
Kojto 90:cb3d968589d8 1456 * @{
Kojto 90:cb3d968589d8 1457 */
Kojto 90:cb3d968589d8 1458 #define RCC_I2SCLKSOURCE_SYSCLK RCC_CFGR_I2SSRC_SYSCLK
Kojto 90:cb3d968589d8 1459 #define RCC_I2SCLKSOURCE_EXT RCC_CFGR_I2SSRC_EXT
Kojto 90:cb3d968589d8 1460
Kojto 90:cb3d968589d8 1461 /**
Kojto 90:cb3d968589d8 1462 * @}
Kojto 90:cb3d968589d8 1463 */
Kojto 90:cb3d968589d8 1464
Kojto 90:cb3d968589d8 1465 /** @defgroup RCCEx_TIM1_Clock_Source RCC Extended TIM1 Clock Source
Kojto 90:cb3d968589d8 1466 * @{
Kojto 90:cb3d968589d8 1467 */
Kojto 90:cb3d968589d8 1468 #define RCC_TIM1CLK_HCLK RCC_CFGR3_TIM1SW_HCLK
Kojto 90:cb3d968589d8 1469 #define RCC_TIM1CLK_PLLCLK RCC_CFGR3_TIM1SW_PLL
Kojto 90:cb3d968589d8 1470
Kojto 90:cb3d968589d8 1471 /**
Kojto 90:cb3d968589d8 1472 * @}
Kojto 90:cb3d968589d8 1473 */
Kojto 90:cb3d968589d8 1474
Kojto 90:cb3d968589d8 1475 /** @defgroup RCCEx_TIM2_Clock_Source RCC Extended TIM2 Clock Source
Kojto 90:cb3d968589d8 1476 * @{
Kojto 90:cb3d968589d8 1477 */
Kojto 90:cb3d968589d8 1478 #define RCC_TIM2CLK_HCLK RCC_CFGR3_TIM2SW_HCLK
Kojto 90:cb3d968589d8 1479 #define RCC_TIM2CLK_PLLCLK RCC_CFGR3_TIM2SW_PLL
Kojto 90:cb3d968589d8 1480
Kojto 90:cb3d968589d8 1481 /**
Kojto 90:cb3d968589d8 1482 * @}
Kojto 90:cb3d968589d8 1483 */
Kojto 90:cb3d968589d8 1484
Kojto 90:cb3d968589d8 1485 /** @defgroup RCCEx_TIM34_Clock_Source RCC Extended TIM3 & TIM4 Clock Source
Kojto 90:cb3d968589d8 1486 * @{
Kojto 90:cb3d968589d8 1487 */
Kojto 90:cb3d968589d8 1488 #define RCC_TIM34CLK_HCLK RCC_CFGR3_TIM34SW_HCLK
Kojto 90:cb3d968589d8 1489 #define RCC_TIM34CLK_PLLCLK RCC_CFGR3_TIM34SW_PLL
Kojto 90:cb3d968589d8 1490
Kojto 90:cb3d968589d8 1491 /**
Kojto 90:cb3d968589d8 1492 * @}
Kojto 90:cb3d968589d8 1493 */
Kojto 90:cb3d968589d8 1494
Kojto 90:cb3d968589d8 1495 /** @defgroup RCCEx_TIM15_Clock_Source RCC Extended TIM15 Clock Source
Kojto 90:cb3d968589d8 1496 * @{
Kojto 90:cb3d968589d8 1497 */
Kojto 90:cb3d968589d8 1498 #define RCC_TIM15CLK_HCLK RCC_CFGR3_TIM15SW_HCLK
Kojto 90:cb3d968589d8 1499 #define RCC_TIM15CLK_PLLCLK RCC_CFGR3_TIM15SW_PLL
Kojto 90:cb3d968589d8 1500
Kojto 90:cb3d968589d8 1501 /**
Kojto 90:cb3d968589d8 1502 * @}
Kojto 90:cb3d968589d8 1503 */
Kojto 90:cb3d968589d8 1504
Kojto 90:cb3d968589d8 1505 /** @defgroup RCCEx_TIM16_Clock_Source RCC Extended TIM16 Clock Source
Kojto 90:cb3d968589d8 1506 * @{
Kojto 90:cb3d968589d8 1507 */
Kojto 90:cb3d968589d8 1508 #define RCC_TIM16CLK_HCLK RCC_CFGR3_TIM16SW_HCLK
Kojto 90:cb3d968589d8 1509 #define RCC_TIM16CLK_PLLCLK RCC_CFGR3_TIM16SW_PLL
Kojto 90:cb3d968589d8 1510
Kojto 90:cb3d968589d8 1511 /**
Kojto 90:cb3d968589d8 1512 * @}
Kojto 90:cb3d968589d8 1513 */
Kojto 90:cb3d968589d8 1514
Kojto 90:cb3d968589d8 1515 /** @defgroup RCCEx_TIM17_Clock_Source RCC Extended TIM17 Clock Source
Kojto 90:cb3d968589d8 1516 * @{
Kojto 90:cb3d968589d8 1517 */
Kojto 90:cb3d968589d8 1518 #define RCC_TIM17CLK_HCLK RCC_CFGR3_TIM17SW_HCLK
Kojto 90:cb3d968589d8 1519 #define RCC_TIM17CLK_PLLCLK RCC_CFGR3_TIM17SW_PLL
Kojto 90:cb3d968589d8 1520
Kojto 90:cb3d968589d8 1521 /**
Kojto 90:cb3d968589d8 1522 * @}
Kojto 90:cb3d968589d8 1523 */
Kojto 90:cb3d968589d8 1524
Kojto 90:cb3d968589d8 1525 /** @defgroup RCCEx_UART4_Clock_Source RCC Extended UART4 Clock Source
Kojto 90:cb3d968589d8 1526 * @{
Kojto 90:cb3d968589d8 1527 */
Kojto 90:cb3d968589d8 1528 #define RCC_UART4CLKSOURCE_PCLK1 RCC_CFGR3_UART4SW_PCLK
Kojto 90:cb3d968589d8 1529 #define RCC_UART4CLKSOURCE_SYSCLK RCC_CFGR3_UART4SW_SYSCLK
Kojto 90:cb3d968589d8 1530 #define RCC_UART4CLKSOURCE_LSE RCC_CFGR3_UART4SW_LSE
Kojto 90:cb3d968589d8 1531 #define RCC_UART4CLKSOURCE_HSI RCC_CFGR3_UART4SW_HSI
Kojto 90:cb3d968589d8 1532
Kojto 90:cb3d968589d8 1533 /**
Kojto 90:cb3d968589d8 1534 * @}
Kojto 90:cb3d968589d8 1535 */
Kojto 90:cb3d968589d8 1536
Kojto 90:cb3d968589d8 1537 /** @defgroup RCCEx_UART5_Clock_Source RCC Extended UART5 Clock Source
Kojto 90:cb3d968589d8 1538 * @{
Kojto 90:cb3d968589d8 1539 */
Kojto 90:cb3d968589d8 1540 #define RCC_UART5CLKSOURCE_PCLK1 RCC_CFGR3_UART5SW_PCLK
Kojto 90:cb3d968589d8 1541 #define RCC_UART5CLKSOURCE_SYSCLK RCC_CFGR3_UART5SW_SYSCLK
Kojto 90:cb3d968589d8 1542 #define RCC_UART5CLKSOURCE_LSE RCC_CFGR3_UART5SW_LSE
Kojto 90:cb3d968589d8 1543 #define RCC_UART5CLKSOURCE_HSI RCC_CFGR3_UART5SW_HSI
Kojto 90:cb3d968589d8 1544
Kojto 90:cb3d968589d8 1545 /**
Kojto 90:cb3d968589d8 1546 * @}
Kojto 90:cb3d968589d8 1547 */
Kojto 90:cb3d968589d8 1548
Kojto 90:cb3d968589d8 1549 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
Kojto 90:cb3d968589d8 1550
Kojto 90:cb3d968589d8 1551 #if defined(STM32F303xE) || defined(STM32F398xx)
Kojto 90:cb3d968589d8 1552 /** @defgroup RCCEx_TIM20_Clock_Source RCC Extended TIM20 Clock Source
Kojto 90:cb3d968589d8 1553 * @{
Kojto 90:cb3d968589d8 1554 */
Kojto 90:cb3d968589d8 1555 #define RCC_TIM20CLK_HCLK RCC_CFGR3_TIM20SW_HCLK
Kojto 90:cb3d968589d8 1556 #define RCC_TIM20CLK_PLLCLK RCC_CFGR3_TIM20SW_PLL
Kojto 90:cb3d968589d8 1557
Kojto 90:cb3d968589d8 1558 /**
Kojto 90:cb3d968589d8 1559 * @}
Kojto 90:cb3d968589d8 1560 */
Kojto 90:cb3d968589d8 1561 #endif /* STM32F303xE || STM32F398xx */
Kojto 90:cb3d968589d8 1562
Kojto 122:f9eeca106725 1563 #if defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 1564 || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 90:cb3d968589d8 1565
Kojto 90:cb3d968589d8 1566 /** @defgroup RCCEx_ADC34_Clock_Source RCC Extended ADC34 Clock Source
Kojto 90:cb3d968589d8 1567 * @{
Kojto 90:cb3d968589d8 1568 */
Kojto 90:cb3d968589d8 1569
Kojto 90:cb3d968589d8 1570 /* ADC3 & ADC4 */
Kojto 90:cb3d968589d8 1571 #define RCC_ADC34PLLCLK_OFF RCC_CFGR2_ADCPRE34_NO
Kojto 90:cb3d968589d8 1572 #define RCC_ADC34PLLCLK_DIV1 RCC_CFGR2_ADCPRE34_DIV1
Kojto 90:cb3d968589d8 1573 #define RCC_ADC34PLLCLK_DIV2 RCC_CFGR2_ADCPRE34_DIV2
Kojto 90:cb3d968589d8 1574 #define RCC_ADC34PLLCLK_DIV4 RCC_CFGR2_ADCPRE34_DIV4
Kojto 90:cb3d968589d8 1575 #define RCC_ADC34PLLCLK_DIV6 RCC_CFGR2_ADCPRE34_DIV6
Kojto 90:cb3d968589d8 1576 #define RCC_ADC34PLLCLK_DIV8 RCC_CFGR2_ADCPRE34_DIV8
Kojto 90:cb3d968589d8 1577 #define RCC_ADC34PLLCLK_DIV10 RCC_CFGR2_ADCPRE34_DIV10
Kojto 90:cb3d968589d8 1578 #define RCC_ADC34PLLCLK_DIV12 RCC_CFGR2_ADCPRE34_DIV12
Kojto 90:cb3d968589d8 1579 #define RCC_ADC34PLLCLK_DIV16 RCC_CFGR2_ADCPRE34_DIV16
Kojto 90:cb3d968589d8 1580 #define RCC_ADC34PLLCLK_DIV32 RCC_CFGR2_ADCPRE34_DIV32
Kojto 90:cb3d968589d8 1581 #define RCC_ADC34PLLCLK_DIV64 RCC_CFGR2_ADCPRE34_DIV64
Kojto 90:cb3d968589d8 1582 #define RCC_ADC34PLLCLK_DIV128 RCC_CFGR2_ADCPRE34_DIV128
Kojto 90:cb3d968589d8 1583 #define RCC_ADC34PLLCLK_DIV256 RCC_CFGR2_ADCPRE34_DIV256
Kojto 90:cb3d968589d8 1584
Kojto 90:cb3d968589d8 1585 /**
Kojto 90:cb3d968589d8 1586 * @}
Kojto 90:cb3d968589d8 1587 */
Kojto 90:cb3d968589d8 1588
Kojto 90:cb3d968589d8 1589 /** @defgroup RCCEx_TIM8_Clock_Source RCC Extended TIM8 Clock Source
Kojto 90:cb3d968589d8 1590 * @{
Kojto 90:cb3d968589d8 1591 */
Kojto 90:cb3d968589d8 1592 #define RCC_TIM8CLK_HCLK RCC_CFGR3_TIM8SW_HCLK
Kojto 90:cb3d968589d8 1593 #define RCC_TIM8CLK_PLLCLK RCC_CFGR3_TIM8SW_PLL
Kojto 90:cb3d968589d8 1594
Kojto 90:cb3d968589d8 1595 /**
Kojto 90:cb3d968589d8 1596 * @}
Kojto 90:cb3d968589d8 1597 */
Kojto 90:cb3d968589d8 1598
Kojto 90:cb3d968589d8 1599 #endif /* STM32F303xC || STM32F303xE || STM32F398xx || STM32F358xx */
Kojto 90:cb3d968589d8 1600
Kojto 90:cb3d968589d8 1601 #if defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)
Kojto 90:cb3d968589d8 1602
Kojto 90:cb3d968589d8 1603 /** @defgroup RCCEx_USART1_Clock_Source RCC Extended USART1 Clock Source
Kojto 90:cb3d968589d8 1604 * @{
Kojto 90:cb3d968589d8 1605 */
Kojto 122:f9eeca106725 1606 #define RCC_USART1CLKSOURCE_PCLK1 RCC_CFGR3_USART1SW_PCLK1
Kojto 90:cb3d968589d8 1607 #define RCC_USART1CLKSOURCE_SYSCLK RCC_CFGR3_USART1SW_SYSCLK
Kojto 90:cb3d968589d8 1608 #define RCC_USART1CLKSOURCE_LSE RCC_CFGR3_USART1SW_LSE
Kojto 90:cb3d968589d8 1609 #define RCC_USART1CLKSOURCE_HSI RCC_CFGR3_USART1SW_HSI
Kojto 90:cb3d968589d8 1610
Kojto 90:cb3d968589d8 1611 /**
Kojto 90:cb3d968589d8 1612 * @}
Kojto 90:cb3d968589d8 1613 */
Kojto 90:cb3d968589d8 1614
Kojto 90:cb3d968589d8 1615 /** @defgroup RCCEx_ADC12_Clock_Source RCC Extended ADC12 Clock Source
Kojto 90:cb3d968589d8 1616 * @{
Kojto 90:cb3d968589d8 1617 */
Kojto 90:cb3d968589d8 1618 /* ADC1 & ADC2 */
Kojto 90:cb3d968589d8 1619 #define RCC_ADC12PLLCLK_OFF RCC_CFGR2_ADCPRE12_NO
Kojto 90:cb3d968589d8 1620 #define RCC_ADC12PLLCLK_DIV1 RCC_CFGR2_ADCPRE12_DIV1
Kojto 90:cb3d968589d8 1621 #define RCC_ADC12PLLCLK_DIV2 RCC_CFGR2_ADCPRE12_DIV2
Kojto 90:cb3d968589d8 1622 #define RCC_ADC12PLLCLK_DIV4 RCC_CFGR2_ADCPRE12_DIV4
Kojto 90:cb3d968589d8 1623 #define RCC_ADC12PLLCLK_DIV6 RCC_CFGR2_ADCPRE12_DIV6
Kojto 90:cb3d968589d8 1624 #define RCC_ADC12PLLCLK_DIV8 RCC_CFGR2_ADCPRE12_DIV8
Kojto 90:cb3d968589d8 1625 #define RCC_ADC12PLLCLK_DIV10 RCC_CFGR2_ADCPRE12_DIV10
Kojto 90:cb3d968589d8 1626 #define RCC_ADC12PLLCLK_DIV12 RCC_CFGR2_ADCPRE12_DIV12
Kojto 90:cb3d968589d8 1627 #define RCC_ADC12PLLCLK_DIV16 RCC_CFGR2_ADCPRE12_DIV16
Kojto 90:cb3d968589d8 1628 #define RCC_ADC12PLLCLK_DIV32 RCC_CFGR2_ADCPRE12_DIV32
Kojto 90:cb3d968589d8 1629 #define RCC_ADC12PLLCLK_DIV64 RCC_CFGR2_ADCPRE12_DIV64
Kojto 90:cb3d968589d8 1630 #define RCC_ADC12PLLCLK_DIV128 RCC_CFGR2_ADCPRE12_DIV128
Kojto 90:cb3d968589d8 1631 #define RCC_ADC12PLLCLK_DIV256 RCC_CFGR2_ADCPRE12_DIV256
Kojto 90:cb3d968589d8 1632
Kojto 90:cb3d968589d8 1633 /**
Kojto 90:cb3d968589d8 1634 * @}
Kojto 90:cb3d968589d8 1635 */
Kojto 90:cb3d968589d8 1636
Kojto 90:cb3d968589d8 1637 /** @defgroup RCCEx_TIM1_Clock_Source RCC Extended TIM1 Clock Source
Kojto 90:cb3d968589d8 1638 * @{
Kojto 90:cb3d968589d8 1639 */
Kojto 90:cb3d968589d8 1640 #define RCC_TIM1CLK_HCLK RCC_CFGR3_TIM1SW_HCLK
Kojto 90:cb3d968589d8 1641 #define RCC_TIM1CLK_PLLCLK RCC_CFGR3_TIM1SW_PLL
Kojto 90:cb3d968589d8 1642
Kojto 90:cb3d968589d8 1643 /**
Kojto 90:cb3d968589d8 1644 * @}
Kojto 90:cb3d968589d8 1645 */
Kojto 90:cb3d968589d8 1646
Kojto 90:cb3d968589d8 1647 #endif /* STM32F303x8 || STM32F334x8 || STM32F328xx */
Kojto 90:cb3d968589d8 1648
Kojto 90:cb3d968589d8 1649 #if defined(STM32F334x8)
Kojto 90:cb3d968589d8 1650
Kojto 90:cb3d968589d8 1651 /** @defgroup RCCEx_HRTIM1_Clock_Source RCC Extended HRTIM1 Clock Source
Kojto 90:cb3d968589d8 1652 * @{
Kojto 90:cb3d968589d8 1653 */
Kojto 90:cb3d968589d8 1654 #define RCC_HRTIM1CLK_HCLK RCC_CFGR3_HRTIM1SW_HCLK
Kojto 90:cb3d968589d8 1655 #define RCC_HRTIM1CLK_PLLCLK RCC_CFGR3_HRTIM1SW_PLL
Kojto 90:cb3d968589d8 1656
Kojto 90:cb3d968589d8 1657 /**
Kojto 90:cb3d968589d8 1658 * @}
Kojto 90:cb3d968589d8 1659 */
Kojto 90:cb3d968589d8 1660
Kojto 90:cb3d968589d8 1661 #endif /* STM32F334x8 */
Kojto 90:cb3d968589d8 1662
Kojto 90:cb3d968589d8 1663 #if defined(STM32F373xC) || defined(STM32F378xx)
Kojto 90:cb3d968589d8 1664
Kojto 90:cb3d968589d8 1665 /** @defgroup RCCEx_USART1_Clock_Source RCC Extended USART1 Clock Source
Kojto 90:cb3d968589d8 1666 * @{
Kojto 90:cb3d968589d8 1667 */
Kojto 122:f9eeca106725 1668 #define RCC_USART1CLKSOURCE_PCLK2 RCC_CFGR3_USART1SW_PCLK2
Kojto 90:cb3d968589d8 1669 #define RCC_USART1CLKSOURCE_SYSCLK RCC_CFGR3_USART1SW_SYSCLK
Kojto 90:cb3d968589d8 1670 #define RCC_USART1CLKSOURCE_LSE RCC_CFGR3_USART1SW_LSE
Kojto 90:cb3d968589d8 1671 #define RCC_USART1CLKSOURCE_HSI RCC_CFGR3_USART1SW_HSI
Kojto 90:cb3d968589d8 1672
Kojto 90:cb3d968589d8 1673 /**
Kojto 90:cb3d968589d8 1674 * @}
Kojto 90:cb3d968589d8 1675 */
Kojto 90:cb3d968589d8 1676
Kojto 90:cb3d968589d8 1677 /** @defgroup RCCEx_I2C2_Clock_Source RCC Extended I2C2 Clock Source
Kojto 90:cb3d968589d8 1678 * @{
Kojto 90:cb3d968589d8 1679 */
Kojto 90:cb3d968589d8 1680 #define RCC_I2C2CLKSOURCE_HSI RCC_CFGR3_I2C2SW_HSI
Kojto 90:cb3d968589d8 1681 #define RCC_I2C2CLKSOURCE_SYSCLK RCC_CFGR3_I2C2SW_SYSCLK
Kojto 90:cb3d968589d8 1682
Kojto 90:cb3d968589d8 1683 /**
Kojto 90:cb3d968589d8 1684 * @}
Kojto 90:cb3d968589d8 1685 */
Kojto 90:cb3d968589d8 1686
Kojto 90:cb3d968589d8 1687 /** @defgroup RCCEx_ADC1_Clock_Source RCC Extended ADC1 Clock Source
Kojto 90:cb3d968589d8 1688 * @{
Kojto 90:cb3d968589d8 1689 */
Kojto 90:cb3d968589d8 1690
Kojto 90:cb3d968589d8 1691 /* ADC1 */
Kojto 90:cb3d968589d8 1692 #define RCC_ADC1PCLK2_DIV2 RCC_CFGR_ADCPRE_DIV2
Kojto 90:cb3d968589d8 1693 #define RCC_ADC1PCLK2_DIV4 RCC_CFGR_ADCPRE_DIV4
Kojto 90:cb3d968589d8 1694 #define RCC_ADC1PCLK2_DIV6 RCC_CFGR_ADCPRE_DIV6
Kojto 90:cb3d968589d8 1695 #define RCC_ADC1PCLK2_DIV8 RCC_CFGR_ADCPRE_DIV8
Kojto 90:cb3d968589d8 1696
Kojto 90:cb3d968589d8 1697 /**
Kojto 90:cb3d968589d8 1698 * @}
Kojto 90:cb3d968589d8 1699 */
Kojto 90:cb3d968589d8 1700
Kojto 90:cb3d968589d8 1701 /** @defgroup RCCEx_CEC_Clock_Source RCC Extended CEC Clock Source
Kojto 90:cb3d968589d8 1702 * @{
Kojto 90:cb3d968589d8 1703 */
Kojto 90:cb3d968589d8 1704 #define RCC_CECCLKSOURCE_HSI RCC_CFGR3_CECSW_HSI_DIV244
Kojto 90:cb3d968589d8 1705 #define RCC_CECCLKSOURCE_LSE RCC_CFGR3_CECSW_LSE
Kojto 90:cb3d968589d8 1706
Kojto 90:cb3d968589d8 1707 /**
Kojto 90:cb3d968589d8 1708 * @}
Kojto 90:cb3d968589d8 1709 */
Kojto 90:cb3d968589d8 1710
Kojto 90:cb3d968589d8 1711 /** @defgroup RCCEx_SDADC_Clock_Prescaler RCC Extended SDADC Clock Prescaler
Kojto 90:cb3d968589d8 1712 * @{
Kojto 90:cb3d968589d8 1713 */
Kojto 90:cb3d968589d8 1714 #define RCC_SDADCSYSCLK_DIV1 RCC_CFGR_SDADCPRE_DIV1
Kojto 90:cb3d968589d8 1715 #define RCC_SDADCSYSCLK_DIV2 RCC_CFGR_SDADCPRE_DIV2
Kojto 90:cb3d968589d8 1716 #define RCC_SDADCSYSCLK_DIV4 RCC_CFGR_SDADCPRE_DIV4
Kojto 90:cb3d968589d8 1717 #define RCC_SDADCSYSCLK_DIV6 RCC_CFGR_SDADCPRE_DIV6
Kojto 90:cb3d968589d8 1718 #define RCC_SDADCSYSCLK_DIV8 RCC_CFGR_SDADCPRE_DIV8
Kojto 90:cb3d968589d8 1719 #define RCC_SDADCSYSCLK_DIV10 RCC_CFGR_SDADCPRE_DIV10
Kojto 90:cb3d968589d8 1720 #define RCC_SDADCSYSCLK_DIV12 RCC_CFGR_SDADCPRE_DIV12
Kojto 90:cb3d968589d8 1721 #define RCC_SDADCSYSCLK_DIV14 RCC_CFGR_SDADCPRE_DIV14
Kojto 90:cb3d968589d8 1722 #define RCC_SDADCSYSCLK_DIV16 RCC_CFGR_SDADCPRE_DIV16
Kojto 90:cb3d968589d8 1723 #define RCC_SDADCSYSCLK_DIV20 RCC_CFGR_SDADCPRE_DIV20
Kojto 90:cb3d968589d8 1724 #define RCC_SDADCSYSCLK_DIV24 RCC_CFGR_SDADCPRE_DIV24
Kojto 90:cb3d968589d8 1725 #define RCC_SDADCSYSCLK_DIV28 RCC_CFGR_SDADCPRE_DIV28
Kojto 90:cb3d968589d8 1726 #define RCC_SDADCSYSCLK_DIV32 RCC_CFGR_SDADCPRE_DIV32
Kojto 90:cb3d968589d8 1727 #define RCC_SDADCSYSCLK_DIV36 RCC_CFGR_SDADCPRE_DIV36
Kojto 90:cb3d968589d8 1728 #define RCC_SDADCSYSCLK_DIV40 RCC_CFGR_SDADCPRE_DIV40
Kojto 90:cb3d968589d8 1729 #define RCC_SDADCSYSCLK_DIV44 RCC_CFGR_SDADCPRE_DIV44
Kojto 90:cb3d968589d8 1730 #define RCC_SDADCSYSCLK_DIV48 RCC_CFGR_SDADCPRE_DIV48
Kojto 90:cb3d968589d8 1731
Kojto 90:cb3d968589d8 1732 /**
Kojto 90:cb3d968589d8 1733 * @}
Kojto 90:cb3d968589d8 1734 */
Kojto 90:cb3d968589d8 1735
Kojto 90:cb3d968589d8 1736 #endif /* STM32F373xC || STM32F378xx */
Kojto 90:cb3d968589d8 1737
Kojto 122:f9eeca106725 1738 #if defined(STM32F302xE) || defined(STM32F303xE)\
Kojto 122:f9eeca106725 1739 || defined(STM32F302xC) || defined(STM32F303xC)\
Kojto 122:f9eeca106725 1740 || defined(STM32F302x8) \
Kojto 122:f9eeca106725 1741 || defined(STM32F373xC)
Kojto 90:cb3d968589d8 1742 /** @defgroup RCCEx_USB_Clock_Source RCC Extended USB Clock Source
Kojto 90:cb3d968589d8 1743 * @{
Kojto 90:cb3d968589d8 1744 */
Kojto 122:f9eeca106725 1745
Kojto 122:f9eeca106725 1746 #define RCC_USBCLKSOURCE_PLL RCC_CFGR_USBPRE_DIV1
Kojto 122:f9eeca106725 1747 #define RCC_USBCLKSOURCE_PLL_DIV1_5 RCC_CFGR_USBPRE_DIV1_5
Kojto 122:f9eeca106725 1748
Kojto 90:cb3d968589d8 1749 /**
Kojto 90:cb3d968589d8 1750 * @}
Kojto 90:cb3d968589d8 1751 */
Kojto 90:cb3d968589d8 1752
Kojto 90:cb3d968589d8 1753 #endif /* STM32F302xE || STM32F303xE || */
Kojto 90:cb3d968589d8 1754 /* STM32F302xC || STM32F303xC || */
Kojto 90:cb3d968589d8 1755 /* STM32F302x8 || */
Kojto 90:cb3d968589d8 1756 /* STM32F373xC */
Kojto 90:cb3d968589d8 1757
Kojto 90:cb3d968589d8 1758
Kojto 90:cb3d968589d8 1759 /** @defgroup RCCEx_MCOx_Clock_Prescaler RCC Extended MCOx Clock Prescaler
Kojto 90:cb3d968589d8 1760 * @{
Kojto 90:cb3d968589d8 1761 */
Kojto 122:f9eeca106725 1762 #if defined(RCC_CFGR_MCOPRE)
Kojto 122:f9eeca106725 1763
Kojto 122:f9eeca106725 1764 #define RCC_MCODIV_1 ((uint32_t)0x00000000)
Kojto 122:f9eeca106725 1765 #define RCC_MCODIV_2 ((uint32_t)0x10000000)
Kojto 122:f9eeca106725 1766 #define RCC_MCODIV_4 ((uint32_t)0x20000000)
Kojto 122:f9eeca106725 1767 #define RCC_MCODIV_8 ((uint32_t)0x30000000)
Kojto 122:f9eeca106725 1768 #define RCC_MCODIV_16 ((uint32_t)0x40000000)
Kojto 122:f9eeca106725 1769 #define RCC_MCODIV_32 ((uint32_t)0x50000000)
Kojto 122:f9eeca106725 1770 #define RCC_MCODIV_64 ((uint32_t)0x60000000)
Kojto 122:f9eeca106725 1771 #define RCC_MCODIV_128 ((uint32_t)0x70000000)
Kojto 122:f9eeca106725 1772
Kojto 122:f9eeca106725 1773 #else
Kojto 122:f9eeca106725 1774
Kojto 122:f9eeca106725 1775 #define RCC_MCODIV_1 ((uint32_t)0x00000000)
Kojto 122:f9eeca106725 1776
Kojto 122:f9eeca106725 1777 #endif /* RCC_CFGR_MCOPRE */
Kojto 122:f9eeca106725 1778
Kojto 90:cb3d968589d8 1779 /**
Kojto 90:cb3d968589d8 1780 * @}
Kojto 90:cb3d968589d8 1781 */
Kojto 90:cb3d968589d8 1782
Kojto 122:f9eeca106725 1783 /** @defgroup RCCEx_LSEDrive_Configuration RCC LSE Drive Configuration
Kojto 122:f9eeca106725 1784 * @{
Kojto 122:f9eeca106725 1785 */
Kojto 122:f9eeca106725 1786
Kojto 122:f9eeca106725 1787 #define RCC_LSEDRIVE_LOW ((uint32_t)0x00000000) /*!< Xtal mode lower driving capability */
Kojto 122:f9eeca106725 1788 #define RCC_LSEDRIVE_MEDIUMLOW RCC_BDCR_LSEDRV_1 /*!< Xtal mode medium low driving capability */
Kojto 122:f9eeca106725 1789 #define RCC_LSEDRIVE_MEDIUMHIGH RCC_BDCR_LSEDRV_0 /*!< Xtal mode medium high driving capability */
Kojto 122:f9eeca106725 1790 #define RCC_LSEDRIVE_HIGH RCC_BDCR_LSEDRV /*!< Xtal mode higher driving capability */
Kojto 122:f9eeca106725 1791
Kojto 122:f9eeca106725 1792 /**
Kojto 122:f9eeca106725 1793 * @}
Kojto 122:f9eeca106725 1794 */
Kojto 90:cb3d968589d8 1795
Kojto 90:cb3d968589d8 1796 /**
Kojto 90:cb3d968589d8 1797 * @}
Kojto 90:cb3d968589d8 1798 */
Kojto 90:cb3d968589d8 1799
Kojto 90:cb3d968589d8 1800 /* Exported macro ------------------------------------------------------------*/
Kojto 90:cb3d968589d8 1801 /** @defgroup RCCEx_Exported_Macros RCC Extended Exported Macros
Kojto 90:cb3d968589d8 1802 * @{
Kojto 90:cb3d968589d8 1803 */
Kojto 90:cb3d968589d8 1804
Kojto 90:cb3d968589d8 1805 /** @defgroup RCCEx_PLL_Configuration RCC Extended PLL Configuration
Kojto 90:cb3d968589d8 1806 * @{
Kojto 90:cb3d968589d8 1807 */
Kojto 90:cb3d968589d8 1808 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 90:cb3d968589d8 1809 /** @brief Macro to configure the PLL clock source, multiplication and division factors.
Kojto 90:cb3d968589d8 1810 * @note This macro must be used only when the PLL is disabled.
Kojto 90:cb3d968589d8 1811 *
Kojto 122:f9eeca106725 1812 * @param __RCC_PLLSource__ specifies the PLL entry clock source.
Kojto 90:cb3d968589d8 1813 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 1814 * @arg @ref RCC_PLLSOURCE_HSI HSI oscillator clock selected as PLL clock entry
Kojto 122:f9eeca106725 1815 * @arg @ref RCC_PLLSOURCE_HSE HSE oscillator clock selected as PLL clock entry
Kojto 122:f9eeca106725 1816 * @param __PREDIV__ specifies the predivider factor for PLL VCO input clock
Kojto 90:cb3d968589d8 1817 * This parameter must be a number between RCC_PREDIV_DIV1 and RCC_PREDIV_DIV16.
Kojto 122:f9eeca106725 1818 * @param __PLLMUL__ specifies the multiplication factor for PLL VCO input clock
Kojto 90:cb3d968589d8 1819 * This parameter must be a number between RCC_PLL_MUL2 and RCC_PLL_MUL16.
Kojto 90:cb3d968589d8 1820 *
Kojto 90:cb3d968589d8 1821 */
Kojto 90:cb3d968589d8 1822 #define __HAL_RCC_PLL_CONFIG(__RCC_PLLSource__ , __PREDIV__, __PLLMUL__) \
Kojto 90:cb3d968589d8 1823 do { \
Kojto 90:cb3d968589d8 1824 MODIFY_REG(RCC->CFGR2, RCC_CFGR2_PREDIV, (__PREDIV__)); \
Kojto 90:cb3d968589d8 1825 MODIFY_REG(RCC->CFGR, RCC_CFGR_PLLMUL | RCC_CFGR_PLLSRC, (uint32_t)((__PLLMUL__)|(__RCC_PLLSource__))); \
Kojto 90:cb3d968589d8 1826 } while(0)
Kojto 90:cb3d968589d8 1827 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
Kojto 90:cb3d968589d8 1828
Kojto 122:f9eeca106725 1829 #if defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)\
Kojto 122:f9eeca106725 1830 || defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)\
Kojto 122:f9eeca106725 1831 || defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)\
Kojto 122:f9eeca106725 1832 || defined(STM32F373xC) || defined(STM32F378xx)
Kojto 90:cb3d968589d8 1833 /** @brief Macro to configure the PLL clock source and multiplication factor.
Kojto 90:cb3d968589d8 1834 * @note This macro must be used only when the PLL is disabled.
Kojto 90:cb3d968589d8 1835 *
Kojto 122:f9eeca106725 1836 * @param __RCC_PLLSource__ specifies the PLL entry clock source.
Kojto 90:cb3d968589d8 1837 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 1838 * @arg @ref RCC_PLLSOURCE_HSI HSI oscillator clock selected as PLL clock entry
Kojto 122:f9eeca106725 1839 * @arg @ref RCC_PLLSOURCE_HSE HSE oscillator clock selected as PLL clock entry
Kojto 122:f9eeca106725 1840 * @param __PLLMUL__ specifies the multiplication factor for PLL VCO input clock
Kojto 90:cb3d968589d8 1841 * This parameter must be a number between RCC_PLL_MUL2 and RCC_PLL_MUL16.
Kojto 90:cb3d968589d8 1842 *
Kojto 90:cb3d968589d8 1843 */
Kojto 90:cb3d968589d8 1844 #define __HAL_RCC_PLL_CONFIG(__RCC_PLLSource__ , __PLLMUL__) \
Kojto 90:cb3d968589d8 1845 MODIFY_REG(RCC->CFGR, RCC_CFGR_PLLMUL | RCC_CFGR_PLLSRC, (uint32_t)((__PLLMUL__)|(__RCC_PLLSource__)))
Kojto 90:cb3d968589d8 1846 #endif /* STM32F302xC || STM32F303xC || STM32F358xx || */
Kojto 90:cb3d968589d8 1847 /* STM32F303x8 || STM32F334x8 || STM32F328xx || */
Kojto 90:cb3d968589d8 1848 /* STM32F301x8 || STM32F302x8 || STM32F318xx */
Kojto 90:cb3d968589d8 1849 /* STM32F373xC || STM32F378xx */
Kojto 90:cb3d968589d8 1850 /**
Kojto 90:cb3d968589d8 1851 * @}
Kojto 90:cb3d968589d8 1852 */
Kojto 90:cb3d968589d8 1853
Kojto 122:f9eeca106725 1854 #if defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)\
Kojto 122:f9eeca106725 1855 || defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)\
Kojto 122:f9eeca106725 1856 || defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)\
Kojto 122:f9eeca106725 1857 || defined(STM32F373xC) || defined(STM32F378xx)
Kojto 90:cb3d968589d8 1858 /** @defgroup RCCEx_HSE_Configuration RCC Extended HSE Configuration
Kojto 90:cb3d968589d8 1859 * @{
Kojto 90:cb3d968589d8 1860 */
Kojto 90:cb3d968589d8 1861
Kojto 90:cb3d968589d8 1862 /**
Kojto 90:cb3d968589d8 1863 * @brief Macro to configure the External High Speed oscillator (HSE) Predivision factor for PLL.
Kojto 90:cb3d968589d8 1864 * @note Predivision factor can not be changed if PLL is used as system clock
Kojto 90:cb3d968589d8 1865 * In this case, you have to select another source of the system clock, disable the PLL and
Kojto 90:cb3d968589d8 1866 * then change the HSE predivision factor.
Kojto 122:f9eeca106725 1867 * @param __HSE_PREDIV_VALUE__ specifies the division value applied to HSE.
Kojto 90:cb3d968589d8 1868 * This parameter must be a number between RCC_HSE_PREDIV_DIV1 and RCC_HSE_PREDIV_DIV16.
Kojto 90:cb3d968589d8 1869 */
Kojto 122:f9eeca106725 1870 #define __HAL_RCC_HSE_PREDIV_CONFIG(__HSE_PREDIV_VALUE__) \
Kojto 122:f9eeca106725 1871 MODIFY_REG(RCC->CFGR2, RCC_CFGR2_PREDIV, (uint32_t)(__HSE_PREDIV_VALUE__))
Kojto 122:f9eeca106725 1872
Kojto 122:f9eeca106725 1873 /**
Kojto 122:f9eeca106725 1874 * @brief Macro to get prediv1 factor for PLL.
Kojto 122:f9eeca106725 1875 */
Kojto 122:f9eeca106725 1876 #define __HAL_RCC_HSE_GET_PREDIV() READ_BIT(RCC->CFGR2, RCC_CFGR2_PREDIV)
Kojto 122:f9eeca106725 1877
Kojto 90:cb3d968589d8 1878 /**
Kojto 90:cb3d968589d8 1879 * @}
Kojto 90:cb3d968589d8 1880 */
Kojto 90:cb3d968589d8 1881 #endif /* STM32F302xC || STM32F303xC || STM32F358xx || */
Kojto 90:cb3d968589d8 1882 /* STM32F303x8 || STM32F334x8 || STM32F328xx || */
Kojto 90:cb3d968589d8 1883 /* STM32F301x8 || STM32F302x8 || STM32F318xx */
Kojto 90:cb3d968589d8 1884 /* STM32F373xC || STM32F378xx */
Kojto 90:cb3d968589d8 1885
Kojto 90:cb3d968589d8 1886 /** @defgroup RCCEx_AHB_Clock_Enable_Disable RCC Extended AHB Clock Enable Disable
Kojto 90:cb3d968589d8 1887 * @brief Enable or disable the AHB peripheral clock.
Kojto 90:cb3d968589d8 1888 * @note After reset, the peripheral clock (used for registers read/write access)
Kojto 90:cb3d968589d8 1889 * is disabled and the application software has to enable this clock before
Kojto 90:cb3d968589d8 1890 * using it.
Kojto 90:cb3d968589d8 1891 * @{
Kojto 90:cb3d968589d8 1892 */
Kojto 90:cb3d968589d8 1893 #if defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)
Kojto 122:f9eeca106725 1894 #define __HAL_RCC_ADC1_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 1895 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 1896 SET_BIT(RCC->AHBENR, RCC_AHBENR_ADC1EN);\
Kojto 122:f9eeca106725 1897 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 1898 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_ADC1EN);\
Kojto 122:f9eeca106725 1899 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 1900 } while(0)
Kojto 122:f9eeca106725 1901
Kojto 122:f9eeca106725 1902 #define __HAL_RCC_ADC1_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_ADC1EN))
Kojto 90:cb3d968589d8 1903 #endif /* STM32F301x8 || STM32F302x8 || STM32F318xx */
Kojto 90:cb3d968589d8 1904
Kojto 122:f9eeca106725 1905 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 1906 || defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 1907 #define __HAL_RCC_DMA2_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 1908 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 1909 SET_BIT(RCC->AHBENR, RCC_AHBENR_DMA2EN);\
Kojto 122:f9eeca106725 1910 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 1911 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_DMA2EN);\
Kojto 122:f9eeca106725 1912 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 1913 } while(0)
Kojto 122:f9eeca106725 1914 #define __HAL_RCC_GPIOE_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 1915 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 1916 SET_BIT(RCC->AHBENR, RCC_AHBENR_GPIOEEN);\
Kojto 122:f9eeca106725 1917 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 1918 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_GPIOEEN);\
Kojto 122:f9eeca106725 1919 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 1920 } while(0)
Kojto 122:f9eeca106725 1921 #define __HAL_RCC_ADC12_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 1922 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 1923 SET_BIT(RCC->AHBENR, RCC_AHBENR_ADC12EN);\
Kojto 122:f9eeca106725 1924 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 1925 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_ADC12EN);\
Kojto 122:f9eeca106725 1926 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 1927 } while(0)
Kojto 90:cb3d968589d8 1928 /* Aliases for STM32 F3 compatibility */
Kojto 122:f9eeca106725 1929 #define __HAL_RCC_ADC1_CLK_ENABLE() __HAL_RCC_ADC12_CLK_ENABLE()
Kojto 122:f9eeca106725 1930 #define __HAL_RCC_ADC2_CLK_ENABLE() __HAL_RCC_ADC12_CLK_ENABLE()
Kojto 122:f9eeca106725 1931
Kojto 122:f9eeca106725 1932 #define __HAL_RCC_DMA2_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_DMA2EN))
Kojto 122:f9eeca106725 1933 #define __HAL_RCC_GPIOE_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_GPIOEEN))
Kojto 122:f9eeca106725 1934 #define __HAL_RCC_ADC12_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_ADC12EN))
Kojto 90:cb3d968589d8 1935 /* Aliases for STM32 F3 compatibility */
Kojto 122:f9eeca106725 1936 #define __HAL_RCC_ADC1_CLK_DISABLE() __HAL_RCC_ADC12_CLK_DISABLE()
Kojto 122:f9eeca106725 1937 #define __HAL_RCC_ADC2_CLK_DISABLE() __HAL_RCC_ADC12_CLK_DISABLE()
Kojto 90:cb3d968589d8 1938 #endif /* STM32F302xE || STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 1939 /* STM32F302xC || STM32F303xC || STM32F358xx */
Kojto 90:cb3d968589d8 1940
Kojto 122:f9eeca106725 1941 #if defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 1942 || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 1943 #define __HAL_RCC_ADC34_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 1944 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 1945 SET_BIT(RCC->AHBENR, RCC_AHBENR_ADC34EN);\
Kojto 122:f9eeca106725 1946 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 1947 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_ADC34EN);\
Kojto 122:f9eeca106725 1948 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 1949 } while(0)
Kojto 122:f9eeca106725 1950 #define __HAL_RCC_ADC34_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_ADC34EN))
Kojto 90:cb3d968589d8 1951 #endif /* STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 1952 /* STM32F303xC || STM32F358xx */
Kojto 90:cb3d968589d8 1953
Kojto 90:cb3d968589d8 1954 #if defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)
Kojto 122:f9eeca106725 1955 #define __HAL_RCC_ADC12_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 1956 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 1957 SET_BIT(RCC->AHBENR, RCC_AHBENR_ADC12EN);\
Kojto 122:f9eeca106725 1958 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 1959 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_ADC12EN);\
Kojto 122:f9eeca106725 1960 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 1961 } while(0)
Kojto 90:cb3d968589d8 1962 /* Aliases for STM32 F3 compatibility */
Kojto 122:f9eeca106725 1963 #define __HAL_RCC_ADC1_CLK_ENABLE() __HAL_RCC_ADC12_CLK_ENABLE()
Kojto 122:f9eeca106725 1964 #define __HAL_RCC_ADC2_CLK_ENABLE() __HAL_RCC_ADC12_CLK_ENABLE()
Kojto 122:f9eeca106725 1965
Kojto 122:f9eeca106725 1966 #define __HAL_RCC_ADC12_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_ADC12EN))
Kojto 90:cb3d968589d8 1967 /* Aliases for STM32 F3 compatibility */
Kojto 122:f9eeca106725 1968 #define __HAL_RCC_ADC1_CLK_DISABLE() __HAL_RCC_ADC12_CLK_DISABLE()
Kojto 122:f9eeca106725 1969 #define __HAL_RCC_ADC2_CLK_DISABLE() __HAL_RCC_ADC12_CLK_DISABLE()
Kojto 90:cb3d968589d8 1970 #endif /* STM32F303x8 || STM32F334x8 || STM32F328xx */
Kojto 90:cb3d968589d8 1971
Kojto 90:cb3d968589d8 1972 #if defined(STM32F373xC) || defined(STM32F378xx)
Kojto 122:f9eeca106725 1973 #define __HAL_RCC_DMA2_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 1974 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 1975 SET_BIT(RCC->AHBENR, RCC_AHBENR_DMA2EN);\
Kojto 122:f9eeca106725 1976 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 1977 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_DMA2EN);\
Kojto 122:f9eeca106725 1978 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 1979 } while(0)
Kojto 122:f9eeca106725 1980 #define __HAL_RCC_GPIOE_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 1981 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 1982 SET_BIT(RCC->AHBENR, RCC_AHBENR_GPIOEEN);\
Kojto 122:f9eeca106725 1983 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 1984 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_GPIOEEN);\
Kojto 122:f9eeca106725 1985 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 1986 } while(0)
Kojto 122:f9eeca106725 1987
Kojto 122:f9eeca106725 1988 #define __HAL_RCC_DMA2_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_DMA2EN))
Kojto 122:f9eeca106725 1989 #define __HAL_RCC_GPIOE_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_GPIOEEN))
Kojto 90:cb3d968589d8 1990 #endif /* STM32F373xC || STM32F378xx */
Kojto 90:cb3d968589d8 1991
Kojto 90:cb3d968589d8 1992 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 122:f9eeca106725 1993 #define __HAL_RCC_FMC_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 1994 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 1995 SET_BIT(RCC->AHBENR, RCC_AHBENR_FMCEN);\
Kojto 122:f9eeca106725 1996 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 1997 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_FMCEN);\
Kojto 122:f9eeca106725 1998 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 1999 } while(0)
Kojto 122:f9eeca106725 2000 #define __HAL_RCC_GPIOG_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2001 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2002 SET_BIT(RCC->AHBENR, RCC_AHBENR_GPIOGEN);\
Kojto 122:f9eeca106725 2003 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2004 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_GPIOGEN);\
Kojto 122:f9eeca106725 2005 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2006 } while(0)
Kojto 122:f9eeca106725 2007 #define __HAL_RCC_GPIOH_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2008 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2009 SET_BIT(RCC->AHBENR, RCC_AHBENR_GPIOHEN);\
Kojto 122:f9eeca106725 2010 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2011 tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_GPIOHEN);\
Kojto 122:f9eeca106725 2012 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2013 } while(0)
Kojto 122:f9eeca106725 2014
Kojto 122:f9eeca106725 2015 #define __HAL_RCC_FMC_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_FMCEN))
Kojto 122:f9eeca106725 2016 #define __HAL_RCC_GPIOG_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_GPIOGEN))
Kojto 122:f9eeca106725 2017 #define __HAL_RCC_GPIOH_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_GPIOHEN))
Kojto 90:cb3d968589d8 2018 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
Kojto 90:cb3d968589d8 2019 /**
Kojto 90:cb3d968589d8 2020 * @}
Kojto 90:cb3d968589d8 2021 */
Kojto 90:cb3d968589d8 2022
Kojto 90:cb3d968589d8 2023 /** @defgroup RCCEx_APB1_Clock_Enable_Disable RCC Extended APB1 Clock Enable Disable
Kojto 90:cb3d968589d8 2024 * @brief Enable or disable the Low Speed APB (APB1) peripheral clock.
Kojto 90:cb3d968589d8 2025 * @note After reset, the peripheral clock (used for registers read/write access)
Kojto 90:cb3d968589d8 2026 * is disabled and the application software has to enable this clock before
Kojto 90:cb3d968589d8 2027 * using it.
Kojto 90:cb3d968589d8 2028 * @{
Kojto 90:cb3d968589d8 2029 */
Kojto 90:cb3d968589d8 2030 #if defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)
Kojto 122:f9eeca106725 2031 #define __HAL_RCC_SPI2_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2032 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2033 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_SPI2EN);\
Kojto 122:f9eeca106725 2034 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2035 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_SPI2EN);\
Kojto 122:f9eeca106725 2036 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2037 } while(0)
Kojto 122:f9eeca106725 2038 #define __HAL_RCC_SPI3_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2039 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2040 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_SPI3EN);\
Kojto 122:f9eeca106725 2041 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2042 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_SPI3EN);\
Kojto 122:f9eeca106725 2043 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2044 } while(0)
Kojto 122:f9eeca106725 2045 #define __HAL_RCC_I2C2_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2046 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2047 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C2EN);\
Kojto 122:f9eeca106725 2048 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2049 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C2EN);\
Kojto 122:f9eeca106725 2050 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2051 } while(0)
Kojto 122:f9eeca106725 2052 #define __HAL_RCC_I2C3_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2053 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2054 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C3EN);\
Kojto 122:f9eeca106725 2055 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2056 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C3EN);\
Kojto 122:f9eeca106725 2057 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2058 } while(0)
Kojto 122:f9eeca106725 2059
Kojto 122:f9eeca106725 2060 #define __HAL_RCC_SPI2_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_SPI2EN))
Kojto 122:f9eeca106725 2061 #define __HAL_RCC_SPI3_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_SPI3EN))
Kojto 122:f9eeca106725 2062 #define __HAL_RCC_I2C2_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_I2C2EN))
Kojto 122:f9eeca106725 2063 #define __HAL_RCC_I2C3_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_I2C3EN))
Kojto 90:cb3d968589d8 2064 #endif /* STM32F301x8 || STM32F302x8 || STM32F318xx */
Kojto 90:cb3d968589d8 2065
Kojto 122:f9eeca106725 2066 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2067 || defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 2068 #define __HAL_RCC_TIM3_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2069 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2070 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM3EN);\
Kojto 122:f9eeca106725 2071 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2072 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM3EN);\
Kojto 122:f9eeca106725 2073 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2074 } while(0)
Kojto 122:f9eeca106725 2075 #define __HAL_RCC_TIM4_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2076 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2077 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM4EN);\
Kojto 122:f9eeca106725 2078 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2079 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM4EN);\
Kojto 122:f9eeca106725 2080 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2081 } while(0)
Kojto 122:f9eeca106725 2082 #define __HAL_RCC_SPI2_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2083 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2084 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_SPI2EN);\
Kojto 122:f9eeca106725 2085 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2086 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_SPI2EN);\
Kojto 122:f9eeca106725 2087 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2088 } while(0)
Kojto 122:f9eeca106725 2089 #define __HAL_RCC_SPI3_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2090 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2091 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_SPI3EN);\
Kojto 122:f9eeca106725 2092 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2093 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_SPI3EN);\
Kojto 122:f9eeca106725 2094 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2095 } while(0)
Kojto 122:f9eeca106725 2096 #define __HAL_RCC_UART4_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2097 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2098 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_UART4EN);\
Kojto 122:f9eeca106725 2099 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2100 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_UART4EN);\
Kojto 122:f9eeca106725 2101 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2102 } while(0)
Kojto 122:f9eeca106725 2103 #define __HAL_RCC_UART5_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2104 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2105 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_UART5EN);\
Kojto 122:f9eeca106725 2106 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2107 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_UART5EN);\
Kojto 122:f9eeca106725 2108 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2109 } while(0)
Kojto 122:f9eeca106725 2110 #define __HAL_RCC_I2C2_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2111 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2112 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C2EN);\
Kojto 122:f9eeca106725 2113 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2114 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C2EN);\
Kojto 122:f9eeca106725 2115 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2116 } while(0)
Kojto 122:f9eeca106725 2117
Kojto 122:f9eeca106725 2118 #define __HAL_RCC_TIM3_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM3EN))
Kojto 122:f9eeca106725 2119 #define __HAL_RCC_TIM4_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM4EN))
Kojto 122:f9eeca106725 2120 #define __HAL_RCC_SPI2_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_SPI2EN))
Kojto 122:f9eeca106725 2121 #define __HAL_RCC_SPI3_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_SPI3EN))
Kojto 122:f9eeca106725 2122 #define __HAL_RCC_UART4_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_UART4EN))
Kojto 122:f9eeca106725 2123 #define __HAL_RCC_UART5_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_UART5EN))
Kojto 122:f9eeca106725 2124 #define __HAL_RCC_I2C2_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_I2C2EN))
Kojto 90:cb3d968589d8 2125 #endif /* STM32F302xE || STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 2126 /* STM32F302xC || STM32F303xC || STM32F358xx */
Kojto 90:cb3d968589d8 2127
Kojto 90:cb3d968589d8 2128 #if defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)
Kojto 122:f9eeca106725 2129 #define __HAL_RCC_TIM3_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2130 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2131 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM3EN);\
Kojto 122:f9eeca106725 2132 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2133 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM3EN);\
Kojto 122:f9eeca106725 2134 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2135 } while(0)
Kojto 122:f9eeca106725 2136 #define __HAL_RCC_DAC2_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2137 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2138 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_DAC2EN);\
Kojto 122:f9eeca106725 2139 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2140 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_DAC2EN);\
Kojto 122:f9eeca106725 2141 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2142 } while(0)
Kojto 122:f9eeca106725 2143
Kojto 122:f9eeca106725 2144 #define __HAL_RCC_TIM3_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM3EN))
Kojto 122:f9eeca106725 2145 #define __HAL_RCC_DAC2_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_DAC2EN))
Kojto 90:cb3d968589d8 2146 #endif /* STM32F303x8 || STM32F334x8 || STM32F328xx */
Kojto 90:cb3d968589d8 2147
Kojto 90:cb3d968589d8 2148 #if defined(STM32F373xC) || defined(STM32F378xx)
Kojto 122:f9eeca106725 2149 #define __HAL_RCC_TIM3_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2150 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2151 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM3EN);\
Kojto 122:f9eeca106725 2152 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2153 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM3EN);\
Kojto 122:f9eeca106725 2154 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2155 } while(0)
Kojto 122:f9eeca106725 2156 #define __HAL_RCC_TIM4_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2157 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2158 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM4EN);\
Kojto 122:f9eeca106725 2159 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2160 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM4EN);\
Kojto 122:f9eeca106725 2161 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2162 } while(0)
Kojto 122:f9eeca106725 2163 #define __HAL_RCC_TIM5_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2164 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2165 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM5EN);\
Kojto 122:f9eeca106725 2166 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2167 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM5EN);\
Kojto 122:f9eeca106725 2168 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2169 } while(0)
Kojto 122:f9eeca106725 2170 #define __HAL_RCC_TIM12_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2171 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2172 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM12EN);\
Kojto 122:f9eeca106725 2173 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2174 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM12EN);\
Kojto 122:f9eeca106725 2175 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2176 } while(0)
Kojto 122:f9eeca106725 2177 #define __HAL_RCC_TIM13_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2178 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2179 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM13EN);\
Kojto 122:f9eeca106725 2180 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2181 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM13EN);\
Kojto 122:f9eeca106725 2182 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2183 } while(0)
Kojto 122:f9eeca106725 2184 #define __HAL_RCC_TIM14_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2185 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2186 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM14EN);\
Kojto 122:f9eeca106725 2187 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2188 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM14EN);\
Kojto 122:f9eeca106725 2189 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2190 } while(0)
Kojto 122:f9eeca106725 2191 #define __HAL_RCC_TIM18_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2192 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2193 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM18EN);\
Kojto 122:f9eeca106725 2194 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2195 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM18EN);\
Kojto 122:f9eeca106725 2196 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2197 } while(0)
Kojto 122:f9eeca106725 2198 #define __HAL_RCC_SPI2_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2199 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2200 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_SPI2EN);\
Kojto 122:f9eeca106725 2201 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2202 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_SPI2EN);\
Kojto 122:f9eeca106725 2203 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2204 } while(0)
Kojto 122:f9eeca106725 2205 #define __HAL_RCC_SPI3_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2206 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2207 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_SPI3EN);\
Kojto 122:f9eeca106725 2208 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2209 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_SPI3EN);\
Kojto 122:f9eeca106725 2210 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2211 } while(0)
Kojto 122:f9eeca106725 2212 #define __HAL_RCC_I2C2_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2213 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2214 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C2EN);\
Kojto 122:f9eeca106725 2215 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2216 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C2EN);\
Kojto 122:f9eeca106725 2217 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2218 } while(0)
Kojto 122:f9eeca106725 2219 #define __HAL_RCC_DAC2_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2220 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2221 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_DAC2EN);\
Kojto 122:f9eeca106725 2222 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2223 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_DAC2EN);\
Kojto 122:f9eeca106725 2224 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2225 } while(0)
Kojto 122:f9eeca106725 2226 #define __HAL_RCC_CEC_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2227 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2228 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_CECEN);\
Kojto 122:f9eeca106725 2229 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2230 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_CECEN);\
Kojto 122:f9eeca106725 2231 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2232 } while(0)
Kojto 122:f9eeca106725 2233
Kojto 122:f9eeca106725 2234 #define __HAL_RCC_TIM3_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM3EN))
Kojto 122:f9eeca106725 2235 #define __HAL_RCC_TIM4_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM4EN))
Kojto 122:f9eeca106725 2236 #define __HAL_RCC_TIM5_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM5EN))
Kojto 122:f9eeca106725 2237 #define __HAL_RCC_TIM12_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM12EN))
Kojto 122:f9eeca106725 2238 #define __HAL_RCC_TIM13_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM13EN))
Kojto 122:f9eeca106725 2239 #define __HAL_RCC_TIM14_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM14EN))
Kojto 122:f9eeca106725 2240 #define __HAL_RCC_TIM18_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM18EN))
Kojto 122:f9eeca106725 2241 #define __HAL_RCC_SPI2_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_SPI2EN))
Kojto 122:f9eeca106725 2242 #define __HAL_RCC_SPI3_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_SPI3EN))
Kojto 122:f9eeca106725 2243 #define __HAL_RCC_I2C2_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_I2C2EN))
Kojto 122:f9eeca106725 2244 #define __HAL_RCC_DAC2_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_DAC2EN))
Kojto 122:f9eeca106725 2245 #define __HAL_RCC_CEC_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_CECEN))
Kojto 90:cb3d968589d8 2246 #endif /* STM32F373xC || STM32F378xx */
Kojto 90:cb3d968589d8 2247
Kojto 122:f9eeca106725 2248 #if defined(STM32F303xE) || defined(STM32F398xx) \
Kojto 122:f9eeca106725 2249 || defined(STM32F303xC) || defined(STM32F358xx) \
Kojto 122:f9eeca106725 2250 || defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)\
Kojto 122:f9eeca106725 2251 || defined(STM32F373xC) || defined(STM32F378xx)
Kojto 122:f9eeca106725 2252 #define __HAL_RCC_TIM7_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2253 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2254 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM7EN);\
Kojto 122:f9eeca106725 2255 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2256 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM7EN);\
Kojto 122:f9eeca106725 2257 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2258 } while(0)
Kojto 122:f9eeca106725 2259
Kojto 122:f9eeca106725 2260 #define __HAL_RCC_TIM7_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM7EN))
Kojto 90:cb3d968589d8 2261 #endif /* STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 2262 /* STM32F303xC || STM32F358xx || */
Kojto 90:cb3d968589d8 2263 /* STM32F303x8 || STM32F334x8 || STM32F328xx || */
Kojto 90:cb3d968589d8 2264 /* STM32F373xC || STM32F378xx */
Kojto 90:cb3d968589d8 2265
Kojto 122:f9eeca106725 2266 #if defined(STM32F302xE) || defined(STM32F303xE)\
Kojto 122:f9eeca106725 2267 || defined(STM32F302xC) || defined(STM32F303xC)\
Kojto 122:f9eeca106725 2268 || defined(STM32F302x8) \
Kojto 122:f9eeca106725 2269 || defined(STM32F373xC)
Kojto 122:f9eeca106725 2270 #define __HAL_RCC_USB_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2271 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2272 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_USBEN);\
Kojto 122:f9eeca106725 2273 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2274 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_USBEN);\
Kojto 122:f9eeca106725 2275 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2276 } while(0)
Kojto 122:f9eeca106725 2277
Kojto 122:f9eeca106725 2278 #define __HAL_RCC_USB_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_USBEN))
Kojto 90:cb3d968589d8 2279 #endif /* STM32F302xE || STM32F303xE || */
Kojto 90:cb3d968589d8 2280 /* STM32F302xC || STM32F303xC || */
Kojto 90:cb3d968589d8 2281 /* STM32F302x8 || */
Kojto 90:cb3d968589d8 2282 /* STM32F373xC */
Kojto 90:cb3d968589d8 2283
Kojto 90:cb3d968589d8 2284 #if !defined(STM32F301x8)
Kojto 122:f9eeca106725 2285 #define __HAL_RCC_CAN1_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2286 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2287 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_CANEN);\
Kojto 122:f9eeca106725 2288 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2289 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_CANEN);\
Kojto 122:f9eeca106725 2290 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2291 } while(0)
Kojto 122:f9eeca106725 2292
Kojto 122:f9eeca106725 2293 #define __HAL_RCC_CAN1_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_CANEN))
Kojto 90:cb3d968589d8 2294 #endif /* STM32F301x8*/
Kojto 90:cb3d968589d8 2295
Kojto 90:cb3d968589d8 2296 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 122:f9eeca106725 2297 #define __HAL_RCC_I2C3_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2298 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2299 SET_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C3EN);\
Kojto 122:f9eeca106725 2300 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2301 tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C3EN);\
Kojto 122:f9eeca106725 2302 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2303 } while(0)
Kojto 122:f9eeca106725 2304
Kojto 122:f9eeca106725 2305 #define __HAL_RCC_I2C3_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_I2C3EN))
Kojto 90:cb3d968589d8 2306 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
Kojto 90:cb3d968589d8 2307 /**
Kojto 90:cb3d968589d8 2308 * @}
Kojto 90:cb3d968589d8 2309 */
Kojto 90:cb3d968589d8 2310
Kojto 90:cb3d968589d8 2311 /** @defgroup RCCEx_APB2_Clock_Enable_Disable RCC Extended APB2 Clock Enable Disable
Kojto 90:cb3d968589d8 2312 * @brief Enable or disable the High Speed APB (APB2) peripheral clock.
Kojto 90:cb3d968589d8 2313 * @note After reset, the peripheral clock (used for registers read/write access)
Kojto 90:cb3d968589d8 2314 * is disabled and the application software has to enable this clock before
Kojto 90:cb3d968589d8 2315 * using it.
Kojto 90:cb3d968589d8 2316 * @{
Kojto 90:cb3d968589d8 2317 */
Kojto 122:f9eeca106725 2318 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2319 || defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 2320 #define __HAL_RCC_SPI1_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2321 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2322 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN);\
Kojto 122:f9eeca106725 2323 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2324 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN);\
Kojto 122:f9eeca106725 2325 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2326 } while(0)
Kojto 122:f9eeca106725 2327
Kojto 122:f9eeca106725 2328 #define __HAL_RCC_SPI1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_SPI1EN))
Kojto 90:cb3d968589d8 2329 #endif /* STM32F302xE || STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 2330 /* STM32F302xC || STM32F303xC || STM32F358xx */
Kojto 90:cb3d968589d8 2331
Kojto 122:f9eeca106725 2332 #if defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2333 || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 2334 #define __HAL_RCC_TIM8_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2335 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2336 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM8EN);\
Kojto 122:f9eeca106725 2337 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2338 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM8EN);\
Kojto 122:f9eeca106725 2339 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2340 } while(0)
Kojto 122:f9eeca106725 2341
Kojto 122:f9eeca106725 2342 #define __HAL_RCC_TIM8_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_TIM8EN))
Kojto 90:cb3d968589d8 2343 #endif /* STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 2344 /* STM32F303xC || STM32F358xx */
Kojto 90:cb3d968589d8 2345
Kojto 90:cb3d968589d8 2346 #if defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)
Kojto 122:f9eeca106725 2347 #define __HAL_RCC_SPI1_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2348 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2349 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN);\
Kojto 122:f9eeca106725 2350 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2351 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN);\
Kojto 122:f9eeca106725 2352 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2353 } while(0)
Kojto 122:f9eeca106725 2354
Kojto 122:f9eeca106725 2355 #define __HAL_RCC_SPI1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_SPI1EN))
Kojto 90:cb3d968589d8 2356 #endif /* STM32F303x8 || STM32F334x8 || STM32F328xx */
Kojto 90:cb3d968589d8 2357
Kojto 90:cb3d968589d8 2358 #if defined(STM32F334x8)
Kojto 122:f9eeca106725 2359 #define __HAL_RCC_HRTIM1_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2360 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2361 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_HRTIM1EN);\
Kojto 122:f9eeca106725 2362 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2363 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_HRTIM1EN);\
Kojto 122:f9eeca106725 2364 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2365 } while(0)
Kojto 122:f9eeca106725 2366
Kojto 122:f9eeca106725 2367 #define __HAL_RCC_HRTIM1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_HRTIM1EN))
Kojto 90:cb3d968589d8 2368 #endif /* STM32F334x8 */
Kojto 90:cb3d968589d8 2369
Kojto 90:cb3d968589d8 2370 #if defined(STM32F373xC) || defined(STM32F378xx)
Kojto 122:f9eeca106725 2371 #define __HAL_RCC_ADC1_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2372 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2373 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_ADC1EN);\
Kojto 122:f9eeca106725 2374 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2375 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_ADC1EN);\
Kojto 122:f9eeca106725 2376 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2377 } while(0)
Kojto 122:f9eeca106725 2378 #define __HAL_RCC_SPI1_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2379 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2380 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN);\
Kojto 122:f9eeca106725 2381 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2382 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN);\
Kojto 122:f9eeca106725 2383 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2384 } while(0)
Kojto 122:f9eeca106725 2385 #define __HAL_RCC_TIM19_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2386 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2387 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM19EN);\
Kojto 122:f9eeca106725 2388 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2389 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM19EN);\
Kojto 122:f9eeca106725 2390 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2391 } while(0)
Kojto 122:f9eeca106725 2392 #define __HAL_RCC_SDADC1_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2393 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2394 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SDADC1EN);\
Kojto 122:f9eeca106725 2395 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2396 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SDADC1EN);\
Kojto 122:f9eeca106725 2397 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2398 } while(0)
Kojto 122:f9eeca106725 2399 #define __HAL_RCC_SDADC2_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2400 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2401 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SDADC2EN);\
Kojto 122:f9eeca106725 2402 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2403 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SDADC2EN);\
Kojto 122:f9eeca106725 2404 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2405 } while(0)
Kojto 122:f9eeca106725 2406 #define __HAL_RCC_SDADC3_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2407 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2408 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SDADC3EN);\
Kojto 122:f9eeca106725 2409 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2410 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SDADC3EN);\
Kojto 122:f9eeca106725 2411 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2412 } while(0)
Kojto 122:f9eeca106725 2413
Kojto 122:f9eeca106725 2414 #define __HAL_RCC_ADC1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_ADC1EN))
Kojto 122:f9eeca106725 2415 #define __HAL_RCC_SPI1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_SPI1EN))
Kojto 122:f9eeca106725 2416 #define __HAL_RCC_TIM19_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_TIM19EN))
Kojto 122:f9eeca106725 2417 #define __HAL_RCC_SDADC1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_SDADC1EN))
Kojto 122:f9eeca106725 2418 #define __HAL_RCC_SDADC2_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_SDADC2EN))
Kojto 122:f9eeca106725 2419 #define __HAL_RCC_SDADC3_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_SDADC3EN))
Kojto 90:cb3d968589d8 2420 #endif /* STM32F373xC || STM32F378xx */
Kojto 90:cb3d968589d8 2421
Kojto 122:f9eeca106725 2422 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2423 || defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)\
Kojto 122:f9eeca106725 2424 || defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)\
Kojto 122:f9eeca106725 2425 || defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)
Kojto 122:f9eeca106725 2426 #define __HAL_RCC_TIM1_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2427 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2428 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM1EN);\
Kojto 122:f9eeca106725 2429 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2430 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM1EN);\
Kojto 122:f9eeca106725 2431 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2432 } while(0)
Kojto 122:f9eeca106725 2433
Kojto 122:f9eeca106725 2434 #define __HAL_RCC_TIM1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_TIM1EN))
Kojto 90:cb3d968589d8 2435 #endif /* STM32F302xE || STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 2436 /* STM32F302xC || STM32F303xC || STM32F358xx || */
Kojto 90:cb3d968589d8 2437 /* STM32F303x8 || STM32F334x8 || STM32F328xx || */
Kojto 90:cb3d968589d8 2438 /* STM32F301x8 || STM32F302x8 || STM32F318xx */
Kojto 90:cb3d968589d8 2439
Kojto 90:cb3d968589d8 2440 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 122:f9eeca106725 2441 #define __HAL_RCC_SPI4_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2442 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2443 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI4EN);\
Kojto 122:f9eeca106725 2444 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2445 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI4EN);\
Kojto 122:f9eeca106725 2446 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2447 } while(0)
Kojto 122:f9eeca106725 2448
Kojto 122:f9eeca106725 2449 #define __HAL_RCC_SPI4_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_SPI4EN))
Kojto 90:cb3d968589d8 2450 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
Kojto 90:cb3d968589d8 2451
Kojto 90:cb3d968589d8 2452 #if defined(STM32F303xE) || defined(STM32F398xx)
Kojto 122:f9eeca106725 2453 #define __HAL_RCC_TIM20_CLK_ENABLE() do { \
Kojto 122:f9eeca106725 2454 __IO uint32_t tmpreg; \
Kojto 122:f9eeca106725 2455 SET_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM20EN);\
Kojto 122:f9eeca106725 2456 /* Delay after an RCC peripheral clock enabling */ \
Kojto 122:f9eeca106725 2457 tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM20EN);\
Kojto 122:f9eeca106725 2458 UNUSED(tmpreg); \
Kojto 122:f9eeca106725 2459 } while(0)
Kojto 122:f9eeca106725 2460 #define __HAL_RCC_TIM20_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_TIM20EN))
Kojto 90:cb3d968589d8 2461 #endif /* STM32F303xE || STM32F398xx */
Kojto 90:cb3d968589d8 2462
Kojto 90:cb3d968589d8 2463 /**
Kojto 90:cb3d968589d8 2464 * @}
Kojto 90:cb3d968589d8 2465 */
Kojto 122:f9eeca106725 2466
Kojto 122:f9eeca106725 2467 /** @defgroup RCCEx_AHB_Peripheral_Clock_Enable_Disable_Status RCC Extended AHB Peripheral Clock Enable Disable Status
Kojto 122:f9eeca106725 2468 * @brief Get the enable or disable status of the AHB peripheral clock.
Kojto 122:f9eeca106725 2469 * @note After reset, the peripheral clock (used for registers read/write access)
Kojto 122:f9eeca106725 2470 * is disabled and the application software has to enable this clock before
Kojto 122:f9eeca106725 2471 * using it.
Kojto 122:f9eeca106725 2472 * @{
Kojto 122:f9eeca106725 2473 */
Kojto 122:f9eeca106725 2474 #if defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)
Kojto 122:f9eeca106725 2475 #define __HAL_RCC_ADC1_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_ADC1EN)) != RESET)
Kojto 122:f9eeca106725 2476
Kojto 122:f9eeca106725 2477 #define __HAL_RCC_ADC1_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_ADC1EN)) == RESET)
Kojto 122:f9eeca106725 2478 #endif /* STM32F301x8 || STM32F302x8 || STM32F318xx */
Kojto 122:f9eeca106725 2479
Kojto 122:f9eeca106725 2480 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2481 || defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 2482 #define __HAL_RCC_DMA2_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_DMA2EN)) != RESET)
Kojto 122:f9eeca106725 2483 #define __HAL_RCC_GPIOE_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOEEN)) != RESET)
Kojto 122:f9eeca106725 2484 #define __HAL_RCC_ADC12_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_ADC12EN)) != RESET)
Kojto 122:f9eeca106725 2485
Kojto 122:f9eeca106725 2486 #define __HAL_RCC_DMA2_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_DMA2EN)) == RESET)
Kojto 122:f9eeca106725 2487 #define __HAL_RCC_GPIOE_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOEEN)) == RESET)
Kojto 122:f9eeca106725 2488 #define __HAL_RCC_ADC12_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_ADC12EN)) == RESET)
Kojto 122:f9eeca106725 2489 #endif /* STM32F302xE || STM32F303xE || STM32F398xx || */
Kojto 122:f9eeca106725 2490 /* STM32F302xC || STM32F303xC || STM32F358xx */
Kojto 122:f9eeca106725 2491
Kojto 122:f9eeca106725 2492 #if defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2493 || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 2494 #define __HAL_RCC_ADC34_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_ADC34EN)) != RESET)
Kojto 122:f9eeca106725 2495
Kojto 122:f9eeca106725 2496 #define __HAL_RCC_ADC34_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_ADC34EN)) == RESET)
Kojto 122:f9eeca106725 2497 #endif /* STM32F303xE || STM32F398xx || */
Kojto 122:f9eeca106725 2498 /* STM32F303xC || STM32F358xx */
Kojto 122:f9eeca106725 2499
Kojto 122:f9eeca106725 2500 #if defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)
Kojto 122:f9eeca106725 2501 #define __HAL_RCC_ADC12_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_ADC12EN)) != RESET)
Kojto 122:f9eeca106725 2502
Kojto 122:f9eeca106725 2503 #define __HAL_RCC_ADC12_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_ADC12EN)) == RESET)
Kojto 122:f9eeca106725 2504 #endif /* STM32F303x8 || STM32F334x8 || STM32F328xx */
Kojto 122:f9eeca106725 2505
Kojto 122:f9eeca106725 2506 #if defined(STM32F373xC) || defined(STM32F378xx)
Kojto 122:f9eeca106725 2507 #define __HAL_RCC_DMA2_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_DMA2EN)) != RESET)
Kojto 122:f9eeca106725 2508 #define __HAL_RCC_GPIOE_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOEEN)) != RESET)
Kojto 122:f9eeca106725 2509
Kojto 122:f9eeca106725 2510 #define __HAL_RCC_DMA2_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_DMA2EN)) == RESET)
Kojto 122:f9eeca106725 2511 #define __HAL_RCC_GPIOE_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOEEN)) == RESET)
Kojto 122:f9eeca106725 2512 #endif /* STM32F373xC || STM32F378xx */
Kojto 122:f9eeca106725 2513
Kojto 122:f9eeca106725 2514 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 122:f9eeca106725 2515 #define __HAL_RCC_FMC_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_FMCEN)) != RESET)
Kojto 122:f9eeca106725 2516 #define __HAL_RCC_GPIOG_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOGEN)) != RESET)
Kojto 122:f9eeca106725 2517 #define __HAL_RCC_GPIOH_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOHEN)) != RESET)
Kojto 122:f9eeca106725 2518
Kojto 122:f9eeca106725 2519 #define __HAL_RCC_FMC_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_FMCEN)) == RESET)
Kojto 122:f9eeca106725 2520 #define __HAL_RCC_GPIOG_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOGEN)) == RESET)
Kojto 122:f9eeca106725 2521 #define __HAL_RCC_GPIOH_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOHEN)) == RESET)
Kojto 122:f9eeca106725 2522 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
Kojto 122:f9eeca106725 2523 /**
Kojto 122:f9eeca106725 2524 * @}
Kojto 122:f9eeca106725 2525 */
Kojto 122:f9eeca106725 2526
Kojto 122:f9eeca106725 2527 /** @defgroup RCCEx_APB1_Clock_Enable_Disable_Status RCC Extended APB1 Peripheral Clock Enable Disable Status
Kojto 122:f9eeca106725 2528 * @brief Get the enable or disable status of the APB1 peripheral clock.
Kojto 122:f9eeca106725 2529 * @note After reset, the peripheral clock (used for registers read/write access)
Kojto 122:f9eeca106725 2530 * is disabled and the application software has to enable this clock before
Kojto 122:f9eeca106725 2531 * using it.
Kojto 122:f9eeca106725 2532 * @{
Kojto 122:f9eeca106725 2533 */
Kojto 122:f9eeca106725 2534 #if defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)
Kojto 122:f9eeca106725 2535 #define __HAL_RCC_SPI2_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_SPI2EN)) != RESET)
Kojto 122:f9eeca106725 2536 #define __HAL_RCC_SPI3_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_SPI3EN)) != RESET)
Kojto 122:f9eeca106725 2537 #define __HAL_RCC_I2C2_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C2EN)) != RESET)
Kojto 122:f9eeca106725 2538 #define __HAL_RCC_I2C3_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C3EN)) != RESET)
Kojto 122:f9eeca106725 2539
Kojto 122:f9eeca106725 2540 #define __HAL_RCC_SPI2_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_SPI2EN)) == RESET)
Kojto 122:f9eeca106725 2541 #define __HAL_RCC_SPI3_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_SPI3EN)) == RESET)
Kojto 122:f9eeca106725 2542 #define __HAL_RCC_I2C2_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C2EN)) == RESET)
Kojto 122:f9eeca106725 2543 #define __HAL_RCC_I2C3_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C3EN)) == RESET)
Kojto 122:f9eeca106725 2544 #endif /* STM32F301x8 || STM32F302x8 || STM32F318xx */
Kojto 122:f9eeca106725 2545
Kojto 122:f9eeca106725 2546 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2547 || defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 2548 #define __HAL_RCC_TIM3_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM3EN)) != RESET)
Kojto 122:f9eeca106725 2549 #define __HAL_RCC_TIM4_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM4EN)) != RESET)
Kojto 122:f9eeca106725 2550 #define __HAL_RCC_SPI2_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_SPI2EN)) != RESET)
Kojto 122:f9eeca106725 2551 #define __HAL_RCC_SPI3_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_SPI3EN)) != RESET)
Kojto 122:f9eeca106725 2552 #define __HAL_RCC_UART4_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_UART4EN)) != RESET)
Kojto 122:f9eeca106725 2553 #define __HAL_RCC_UART5_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_UART5EN)) != RESET)
Kojto 122:f9eeca106725 2554 #define __HAL_RCC_I2C2_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C2EN)) != RESET)
Kojto 122:f9eeca106725 2555
Kojto 122:f9eeca106725 2556 #define __HAL_RCC_TIM3_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM3EN)) == RESET)
Kojto 122:f9eeca106725 2557 #define __HAL_RCC_TIM4_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM4EN)) == RESET)
Kojto 122:f9eeca106725 2558 #define __HAL_RCC_SPI2_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_SPI2EN)) == RESET)
Kojto 122:f9eeca106725 2559 #define __HAL_RCC_SPI3_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_SPI3EN)) == RESET)
Kojto 122:f9eeca106725 2560 #define __HAL_RCC_UART4_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_UART4EN)) == RESET)
Kojto 122:f9eeca106725 2561 #define __HAL_RCC_UART5_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_UART5EN)) == RESET)
Kojto 122:f9eeca106725 2562 #define __HAL_RCC_I2C2_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C2EN)) == RESET)
Kojto 122:f9eeca106725 2563 #endif /* STM32F302xE || STM32F303xE || STM32F398xx || */
Kojto 122:f9eeca106725 2564 /* STM32F302xC || STM32F303xC || STM32F358xx */
Kojto 122:f9eeca106725 2565
Kojto 122:f9eeca106725 2566 #if defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)
Kojto 122:f9eeca106725 2567 #define __HAL_RCC_TIM3_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM3EN)) != RESET)
Kojto 122:f9eeca106725 2568 #define __HAL_RCC_DAC2_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_DAC2EN)) != RESET)
Kojto 122:f9eeca106725 2569
Kojto 122:f9eeca106725 2570 #define __HAL_RCC_TIM3_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM3EN)) == RESET)
Kojto 122:f9eeca106725 2571 #define __HAL_RCC_DAC2_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_DAC2EN)) == RESET)
Kojto 122:f9eeca106725 2572 #endif /* STM32F303x8 || STM32F334x8 || STM32F328xx */
Kojto 122:f9eeca106725 2573
Kojto 122:f9eeca106725 2574 #if defined(STM32F373xC) || defined(STM32F378xx)
Kojto 122:f9eeca106725 2575 #define __HAL_RCC_TIM3_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM3EN)) != RESET)
Kojto 122:f9eeca106725 2576 #define __HAL_RCC_TIM4_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM4EN)) != RESET)
Kojto 122:f9eeca106725 2577 #define __HAL_RCC_TIM5_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM5EN)) != RESET)
Kojto 122:f9eeca106725 2578 #define __HAL_RCC_TIM12_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM12EN)) != RESET)
Kojto 122:f9eeca106725 2579 #define __HAL_RCC_TIM13_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM13EN)) != RESET)
Kojto 122:f9eeca106725 2580 #define __HAL_RCC_TIM14_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM14EN)) != RESET)
Kojto 122:f9eeca106725 2581 #define __HAL_RCC_TIM18_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM18EN)) != RESET)
Kojto 122:f9eeca106725 2582 #define __HAL_RCC_SPI2_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_SPI2EN)) != RESET)
Kojto 122:f9eeca106725 2583 #define __HAL_RCC_SPI3_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_SPI3EN)) != RESET)
Kojto 122:f9eeca106725 2584 #define __HAL_RCC_I2C2_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C2EN)) != RESET)
Kojto 122:f9eeca106725 2585 #define __HAL_RCC_DAC2_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_DAC2EN)) != RESET)
Kojto 122:f9eeca106725 2586 #define __HAL_RCC_CEC_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_CECEN)) != RESET)
Kojto 122:f9eeca106725 2587
Kojto 122:f9eeca106725 2588 #define __HAL_RCC_TIM3_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM3EN)) == RESET)
Kojto 122:f9eeca106725 2589 #define __HAL_RCC_TIM4_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM4EN)) == RESET)
Kojto 122:f9eeca106725 2590 #define __HAL_RCC_TIM5_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM5EN)) == RESET)
Kojto 122:f9eeca106725 2591 #define __HAL_RCC_TIM12_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM12EN)) == RESET)
Kojto 122:f9eeca106725 2592 #define __HAL_RCC_TIM13_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM13EN)) == RESET)
Kojto 122:f9eeca106725 2593 #define __HAL_RCC_TIM14_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM14EN)) == RESET)
Kojto 122:f9eeca106725 2594 #define __HAL_RCC_TIM18_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM18EN)) == RESET)
Kojto 122:f9eeca106725 2595 #define __HAL_RCC_SPI2_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_SPI2EN)) == RESET)
Kojto 122:f9eeca106725 2596 #define __HAL_RCC_SPI3_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_SPI3EN)) == RESET)
Kojto 122:f9eeca106725 2597 #define __HAL_RCC_I2C2_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C2EN)) == RESET)
Kojto 122:f9eeca106725 2598 #define __HAL_RCC_DAC2_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_DAC2EN)) == RESET)
Kojto 122:f9eeca106725 2599 #define __HAL_RCC_CEC_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_CECEN)) == RESET)
Kojto 122:f9eeca106725 2600 #endif /* STM32F373xC || STM32F378xx */
Kojto 122:f9eeca106725 2601
Kojto 122:f9eeca106725 2602 #if defined(STM32F303xE) || defined(STM32F398xx) \
Kojto 122:f9eeca106725 2603 || defined(STM32F303xC) || defined(STM32F358xx) \
Kojto 122:f9eeca106725 2604 || defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)\
Kojto 122:f9eeca106725 2605 || defined(STM32F373xC) || defined(STM32F378xx)
Kojto 122:f9eeca106725 2606 #define __HAL_RCC_TIM7_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM7EN)) != RESET)
Kojto 122:f9eeca106725 2607
Kojto 122:f9eeca106725 2608 #define __HAL_RCC_TIM7_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM7EN)) == RESET)
Kojto 122:f9eeca106725 2609 #endif /* STM32F303xE || STM32F398xx || */
Kojto 122:f9eeca106725 2610 /* STM32F303xC || STM32F358xx || */
Kojto 122:f9eeca106725 2611 /* STM32F303x8 || STM32F334x8 || STM32F328xx || */
Kojto 122:f9eeca106725 2612 /* STM32F373xC || STM32F378xx */
Kojto 122:f9eeca106725 2613
Kojto 122:f9eeca106725 2614 #if defined(STM32F302xE) || defined(STM32F303xE)\
Kojto 122:f9eeca106725 2615 || defined(STM32F302xC) || defined(STM32F303xC)\
Kojto 122:f9eeca106725 2616 || defined(STM32F302x8) \
Kojto 122:f9eeca106725 2617 || defined(STM32F373xC)
Kojto 122:f9eeca106725 2618 #define __HAL_RCC_USB_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_USBEN)) != RESET)
Kojto 122:f9eeca106725 2619
Kojto 122:f9eeca106725 2620 #define __HAL_RCC_USB_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_USBEN)) == RESET)
Kojto 122:f9eeca106725 2621 #endif /* STM32F302xE || STM32F303xE || */
Kojto 122:f9eeca106725 2622 /* STM32F302xC || STM32F303xC || */
Kojto 122:f9eeca106725 2623 /* STM32F302x8 || */
Kojto 122:f9eeca106725 2624 /* STM32F373xC */
Kojto 122:f9eeca106725 2625
Kojto 122:f9eeca106725 2626 #if !defined(STM32F301x8)
Kojto 122:f9eeca106725 2627 #define __HAL_RCC_CAN1_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_CANEN)) != RESET)
Kojto 122:f9eeca106725 2628
Kojto 122:f9eeca106725 2629 #define __HAL_RCC_CAN1_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_CANEN)) == RESET)
Kojto 122:f9eeca106725 2630 #endif /* STM32F301x8*/
Kojto 122:f9eeca106725 2631
Kojto 122:f9eeca106725 2632 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 122:f9eeca106725 2633 #define __HAL_RCC_I2C3_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C3EN)) != RESET)
Kojto 122:f9eeca106725 2634
Kojto 122:f9eeca106725 2635 #define __HAL_RCC_I2C3_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C3EN)) == RESET)
Kojto 122:f9eeca106725 2636 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
Kojto 122:f9eeca106725 2637 /**
Kojto 122:f9eeca106725 2638 * @}
Kojto 122:f9eeca106725 2639 */
Kojto 122:f9eeca106725 2640
Kojto 122:f9eeca106725 2641 /** @defgroup RCCEx_APB2_Clock_Enable_Disable_Status RCC Extended APB2 Peripheral Clock Enable Disable Status
Kojto 122:f9eeca106725 2642 * @brief Get the enable or disable status of the APB2 peripheral clock.
Kojto 122:f9eeca106725 2643 * @note After reset, the peripheral clock (used for registers read/write access)
Kojto 122:f9eeca106725 2644 * is disabled and the application software has to enable this clock before
Kojto 122:f9eeca106725 2645 * using it.
Kojto 122:f9eeca106725 2646 * @{
Kojto 122:f9eeca106725 2647 */
Kojto 122:f9eeca106725 2648 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2649 || defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 2650 #define __HAL_RCC_SPI1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SPI1EN)) != RESET)
Kojto 122:f9eeca106725 2651
Kojto 122:f9eeca106725 2652 #define __HAL_RCC_SPI1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SPI1EN)) == RESET)
Kojto 122:f9eeca106725 2653 #endif /* STM32F302xE || STM32F303xE || STM32F398xx || */
Kojto 122:f9eeca106725 2654 /* STM32F302xC || STM32F303xC || STM32F358xx */
Kojto 122:f9eeca106725 2655
Kojto 122:f9eeca106725 2656 #if defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2657 || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 2658 #define __HAL_RCC_TIM8_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM8EN)) != RESET)
Kojto 122:f9eeca106725 2659
Kojto 122:f9eeca106725 2660 #define __HAL_RCC_TIM8_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM8EN)) == RESET)
Kojto 122:f9eeca106725 2661 #endif /* STM32F303xE || STM32F398xx || */
Kojto 122:f9eeca106725 2662 /* STM32F303xC || STM32F358xx */
Kojto 122:f9eeca106725 2663
Kojto 122:f9eeca106725 2664 #if defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)
Kojto 122:f9eeca106725 2665 #define __HAL_RCC_SPI1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SPI1EN)) != RESET)
Kojto 122:f9eeca106725 2666
Kojto 122:f9eeca106725 2667 #define __HAL_RCC_SPI1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SPI1EN)) == RESET)
Kojto 122:f9eeca106725 2668 #endif /* STM32F303x8 || STM32F334x8 || STM32F328xx */
Kojto 122:f9eeca106725 2669
Kojto 122:f9eeca106725 2670 #if defined(STM32F334x8)
Kojto 122:f9eeca106725 2671 #define __HAL_RCC_HRTIM1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_HRTIM1EN)) != RESET)
Kojto 122:f9eeca106725 2672
Kojto 122:f9eeca106725 2673 #define __HAL_RCC_HRTIM1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_HRTIM1EN)) == RESET)
Kojto 122:f9eeca106725 2674 #endif /* STM32F334x8 */
Kojto 122:f9eeca106725 2675
Kojto 122:f9eeca106725 2676 #if defined(STM32F373xC) || defined(STM32F378xx)
Kojto 122:f9eeca106725 2677 #define __HAL_RCC_ADC1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_ADC1EN)) != RESET)
Kojto 122:f9eeca106725 2678 #define __HAL_RCC_SPI1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SPI1EN)) != RESET)
Kojto 122:f9eeca106725 2679 #define __HAL_RCC_TIM19_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM19EN)) != RESET)
Kojto 122:f9eeca106725 2680 #define __HAL_RCC_SDADC1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SDADC1EN)) != RESET)
Kojto 122:f9eeca106725 2681 #define __HAL_RCC_SDADC2_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SDADC2EN)) != RESET)
Kojto 122:f9eeca106725 2682 #define __HAL_RCC_SDADC3_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SDADC3EN)) != RESET)
Kojto 122:f9eeca106725 2683
Kojto 122:f9eeca106725 2684 #define __HAL_RCC_ADC1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_ADC1EN)) == RESET)
Kojto 122:f9eeca106725 2685 #define __HAL_RCC_SPI1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SPI1EN)) == RESET)
Kojto 122:f9eeca106725 2686 #define __HAL_RCC_TIM19_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM19EN)) == RESET)
Kojto 122:f9eeca106725 2687 #define __HAL_RCC_SDADC1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SDADC1EN)) == RESET)
Kojto 122:f9eeca106725 2688 #define __HAL_RCC_SDADC2_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SDADC2EN)) == RESET)
Kojto 122:f9eeca106725 2689 #define __HAL_RCC_SDADC3_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SDADC3EN)) == RESET)
Kojto 122:f9eeca106725 2690 #endif /* STM32F373xC || STM32F378xx */
Kojto 122:f9eeca106725 2691
Kojto 122:f9eeca106725 2692 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2693 || defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)\
Kojto 122:f9eeca106725 2694 || defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)\
Kojto 122:f9eeca106725 2695 || defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)
Kojto 122:f9eeca106725 2696 #define __HAL_RCC_TIM1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM1EN)) != RESET)
Kojto 122:f9eeca106725 2697
Kojto 122:f9eeca106725 2698 #define __HAL_RCC_TIM1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM1EN)) == RESET)
Kojto 122:f9eeca106725 2699 #endif /* STM32F302xE || STM32F303xE || STM32F398xx || */
Kojto 122:f9eeca106725 2700 /* STM32F302xC || STM32F303xC || STM32F358xx || */
Kojto 122:f9eeca106725 2701 /* STM32F303x8 || STM32F334x8 || STM32F328xx || */
Kojto 122:f9eeca106725 2702 /* STM32F301x8 || STM32F302x8 || STM32F318xx */
Kojto 122:f9eeca106725 2703
Kojto 122:f9eeca106725 2704 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 122:f9eeca106725 2705 #define __HAL_RCC_SPI4_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SPI4EN)) != RESET)
Kojto 122:f9eeca106725 2706
Kojto 122:f9eeca106725 2707 #define __HAL_RCC_SPI4_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SPI4EN)) == RESET)
Kojto 122:f9eeca106725 2708 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
Kojto 122:f9eeca106725 2709
Kojto 122:f9eeca106725 2710 #if defined(STM32F303xE) || defined(STM32F398xx)
Kojto 122:f9eeca106725 2711 #define __HAL_RCC_TIM20_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM20EN)) != RESET)
Kojto 122:f9eeca106725 2712
Kojto 122:f9eeca106725 2713 #define __HAL_RCC_TIM20_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM20EN)) == RESET)
Kojto 122:f9eeca106725 2714 #endif /* STM32F303xE || STM32F398xx */
Kojto 122:f9eeca106725 2715 /**
Kojto 122:f9eeca106725 2716 * @}
Kojto 122:f9eeca106725 2717 */
Kojto 122:f9eeca106725 2718
Kojto 90:cb3d968589d8 2719 /** @defgroup RCCEx_AHB_Force_Release_Reset RCC Extended AHB Force Release Reset
Kojto 90:cb3d968589d8 2720 * @brief Force or release AHB peripheral reset.
Kojto 90:cb3d968589d8 2721 * @{
Kojto 90:cb3d968589d8 2722 */
Kojto 90:cb3d968589d8 2723 #if defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)
Kojto 122:f9eeca106725 2724 #define __HAL_RCC_ADC1_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_ADC1RST))
Kojto 122:f9eeca106725 2725
Kojto 122:f9eeca106725 2726 #define __HAL_RCC_ADC1_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_ADC1RST))
Kojto 90:cb3d968589d8 2727 #endif /* STM32F301x8 || STM32F302x8 || STM32F318xx */
Kojto 90:cb3d968589d8 2728
Kojto 122:f9eeca106725 2729 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2730 || defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 2731 #define __HAL_RCC_GPIOE_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_GPIOERST))
Kojto 122:f9eeca106725 2732 #define __HAL_RCC_ADC12_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_ADC12RST))
Kojto 90:cb3d968589d8 2733 /* Aliases for STM32 F3 compatibility */
Kojto 122:f9eeca106725 2734 #define __HAL_RCC_ADC1_FORCE_RESET() __HAL_RCC_ADC12_FORCE_RESET()
Kojto 122:f9eeca106725 2735 #define __HAL_RCC_ADC2_FORCE_RESET() __HAL_RCC_ADC12_FORCE_RESET()
Kojto 122:f9eeca106725 2736
Kojto 122:f9eeca106725 2737 #define __HAL_RCC_GPIOE_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_GPIOERST))
Kojto 122:f9eeca106725 2738 #define __HAL_RCC_ADC12_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_ADC12RST))
Kojto 90:cb3d968589d8 2739 /* Aliases for STM32 F3 compatibility */
Kojto 122:f9eeca106725 2740 #define __HAL_RCC_ADC1_RELEASE_RESET() __HAL_RCC_ADC12_RELEASE_RESET()
Kojto 122:f9eeca106725 2741 #define __HAL_RCC_ADC2_RELEASE_RESET() __HAL_RCC_ADC12_RELEASE_RESET()
Kojto 90:cb3d968589d8 2742 #endif /* STM32F302xE || STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 2743 /* STM32F302xC || STM32F303xC || STM32F358xx */
Kojto 90:cb3d968589d8 2744
Kojto 122:f9eeca106725 2745 #if defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2746 || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 2747 #define __HAL_RCC_ADC34_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_ADC34RST))
Kojto 122:f9eeca106725 2748
Kojto 122:f9eeca106725 2749 #define __HAL_RCC_ADC34_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_ADC34RST))
Kojto 90:cb3d968589d8 2750 #endif /* STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 2751 /* STM32F303xC || STM32F358xx */
Kojto 90:cb3d968589d8 2752
Kojto 90:cb3d968589d8 2753 #if defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)
Kojto 122:f9eeca106725 2754 #define __HAL_RCC_ADC12_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_ADC12RST))
Kojto 90:cb3d968589d8 2755 /* Aliases for STM32 F3 compatibility */
Kojto 122:f9eeca106725 2756 #define __HAL_RCC_ADC1_FORCE_RESET() __HAL_RCC_ADC12_FORCE_RESET()
Kojto 122:f9eeca106725 2757 #define __HAL_RCC_ADC2_FORCE_RESET() __HAL_RCC_ADC12_FORCE_RESET()
Kojto 122:f9eeca106725 2758
Kojto 122:f9eeca106725 2759 #define __HAL_RCC_ADC12_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_ADC12RST))
Kojto 90:cb3d968589d8 2760 /* Aliases for STM32 F3 compatibility */
Kojto 122:f9eeca106725 2761 #define __HAL_RCC_ADC1_RELEASE_RESET() __HAL_RCC_ADC12_RELEASE_RESET()
Kojto 122:f9eeca106725 2762 #define __HAL_RCC_ADC2_RELEASE_RESET() __HAL_RCC_ADC12_RELEASE_RESET()
Kojto 90:cb3d968589d8 2763 #endif /* STM32F303x8 || STM32F334x8 || STM32F328xx */
Kojto 90:cb3d968589d8 2764
Kojto 90:cb3d968589d8 2765 #if defined(STM32F373xC) || defined(STM32F378xx)
Kojto 122:f9eeca106725 2766 #define __HAL_RCC_GPIOE_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_GPIOERST))
Kojto 122:f9eeca106725 2767
Kojto 122:f9eeca106725 2768 #define __HAL_RCC_GPIOE_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_GPIOERST))
Kojto 90:cb3d968589d8 2769 #endif /* STM32F373xC || STM32F378xx */
Kojto 90:cb3d968589d8 2770
Kojto 90:cb3d968589d8 2771 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 122:f9eeca106725 2772 #define __HAL_RCC_FMC_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_FMCRST))
Kojto 122:f9eeca106725 2773 #define __HAL_RCC_GPIOG_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_GPIOGRST))
Kojto 122:f9eeca106725 2774 #define __HAL_RCC_GPIOH_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_GPIOHRST))
Kojto 122:f9eeca106725 2775
Kojto 122:f9eeca106725 2776 #define __HAL_RCC_FMC_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_FMCRST))
Kojto 122:f9eeca106725 2777 #define __HAL_RCC_GPIOG_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_GPIOGRST))
Kojto 122:f9eeca106725 2778 #define __HAL_RCC_GPIOH_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_GPIOHRST))
Kojto 90:cb3d968589d8 2779 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
Kojto 90:cb3d968589d8 2780 /**
Kojto 90:cb3d968589d8 2781 * @}
Kojto 90:cb3d968589d8 2782 */
Kojto 90:cb3d968589d8 2783
Kojto 90:cb3d968589d8 2784 /** @defgroup RCCEx_APB1_Force_Release_Reset RCC Extended APB1 Force Release Reset
Kojto 90:cb3d968589d8 2785 * @brief Force or release APB1 peripheral reset.
Kojto 90:cb3d968589d8 2786 * @{
Kojto 90:cb3d968589d8 2787 */
Kojto 90:cb3d968589d8 2788 #if defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)
Kojto 122:f9eeca106725 2789 #define __HAL_RCC_SPI2_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_SPI2RST))
Kojto 122:f9eeca106725 2790 #define __HAL_RCC_SPI3_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_SPI3RST))
Kojto 122:f9eeca106725 2791 #define __HAL_RCC_I2C2_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_I2C2RST))
Kojto 122:f9eeca106725 2792 #define __HAL_RCC_I2C3_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_I2C3RST))
Kojto 122:f9eeca106725 2793
Kojto 122:f9eeca106725 2794 #define __HAL_RCC_SPI2_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_SPI2RST))
Kojto 122:f9eeca106725 2795 #define __HAL_RCC_SPI3_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_SPI3RST))
Kojto 122:f9eeca106725 2796 #define __HAL_RCC_I2C2_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_I2C2RST))
Kojto 122:f9eeca106725 2797 #define __HAL_RCC_I2C3_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_I2C3RST))
Kojto 90:cb3d968589d8 2798 #endif /* STM32F301x8 || STM32F302x8 || STM32F318xx */
Kojto 90:cb3d968589d8 2799
Kojto 122:f9eeca106725 2800 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2801 || defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 2802 #define __HAL_RCC_TIM3_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM3RST))
Kojto 122:f9eeca106725 2803 #define __HAL_RCC_TIM4_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM4RST))
Kojto 122:f9eeca106725 2804 #define __HAL_RCC_SPI2_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_SPI2RST))
Kojto 122:f9eeca106725 2805 #define __HAL_RCC_SPI3_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_SPI3RST))
Kojto 122:f9eeca106725 2806 #define __HAL_RCC_UART4_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_UART4RST))
Kojto 122:f9eeca106725 2807 #define __HAL_RCC_UART5_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_UART5RST))
Kojto 122:f9eeca106725 2808 #define __HAL_RCC_I2C2_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_I2C2RST))
Kojto 122:f9eeca106725 2809
Kojto 122:f9eeca106725 2810 #define __HAL_RCC_TIM3_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM3RST))
Kojto 122:f9eeca106725 2811 #define __HAL_RCC_TIM4_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM4RST))
Kojto 122:f9eeca106725 2812 #define __HAL_RCC_SPI2_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_SPI2RST))
Kojto 122:f9eeca106725 2813 #define __HAL_RCC_SPI3_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_SPI3RST))
Kojto 122:f9eeca106725 2814 #define __HAL_RCC_UART4_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_UART4RST))
Kojto 122:f9eeca106725 2815 #define __HAL_RCC_UART5_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_UART5RST))
Kojto 122:f9eeca106725 2816 #define __HAL_RCC_I2C2_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_I2C2RST))
Kojto 90:cb3d968589d8 2817 #endif /* STM32F302xE || STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 2818 /* STM32F302xC || STM32F303xC || STM32F358xx */
Kojto 90:cb3d968589d8 2819
Kojto 90:cb3d968589d8 2820 #if defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)
Kojto 122:f9eeca106725 2821 #define __HAL_RCC_TIM3_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM3RST))
Kojto 122:f9eeca106725 2822 #define __HAL_RCC_DAC2_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_DAC2RST))
Kojto 122:f9eeca106725 2823
Kojto 122:f9eeca106725 2824 #define __HAL_RCC_TIM3_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM3RST))
Kojto 122:f9eeca106725 2825 #define __HAL_RCC_DAC2_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_DAC2RST))
Kojto 90:cb3d968589d8 2826 #endif /* STM32F303x8 || STM32F334x8 || STM32F328xx */
Kojto 90:cb3d968589d8 2827
Kojto 90:cb3d968589d8 2828 #if defined(STM32F373xC) || defined(STM32F378xx)
Kojto 122:f9eeca106725 2829 #define __HAL_RCC_TIM3_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM3RST))
Kojto 122:f9eeca106725 2830 #define __HAL_RCC_TIM4_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM4RST))
Kojto 122:f9eeca106725 2831 #define __HAL_RCC_TIM5_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM5RST))
Kojto 122:f9eeca106725 2832 #define __HAL_RCC_TIM12_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM12RST))
Kojto 122:f9eeca106725 2833 #define __HAL_RCC_TIM13_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM13RST))
Kojto 122:f9eeca106725 2834 #define __HAL_RCC_TIM14_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM14RST))
Kojto 122:f9eeca106725 2835 #define __HAL_RCC_TIM18_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM18RST))
Kojto 122:f9eeca106725 2836 #define __HAL_RCC_SPI2_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_SPI2RST))
Kojto 122:f9eeca106725 2837 #define __HAL_RCC_SPI3_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_SPI3RST))
Kojto 122:f9eeca106725 2838 #define __HAL_RCC_I2C2_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_I2C2RST))
Kojto 122:f9eeca106725 2839 #define __HAL_RCC_DAC2_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_DAC2RST))
Kojto 122:f9eeca106725 2840 #define __HAL_RCC_CEC_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_CECRST))
Kojto 122:f9eeca106725 2841
Kojto 122:f9eeca106725 2842 #define __HAL_RCC_TIM3_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM3RST))
Kojto 122:f9eeca106725 2843 #define __HAL_RCC_TIM4_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM4RST))
Kojto 122:f9eeca106725 2844 #define __HAL_RCC_TIM5_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM5RST))
Kojto 122:f9eeca106725 2845 #define __HAL_RCC_TIM12_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM12RST))
Kojto 122:f9eeca106725 2846 #define __HAL_RCC_TIM13_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM13RST))
Kojto 122:f9eeca106725 2847 #define __HAL_RCC_TIM14_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM14RST))
Kojto 122:f9eeca106725 2848 #define __HAL_RCC_TIM18_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM18RST))
Kojto 122:f9eeca106725 2849 #define __HAL_RCC_SPI2_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_SPI2RST))
Kojto 122:f9eeca106725 2850 #define __HAL_RCC_SPI3_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_SPI3RST))
Kojto 122:f9eeca106725 2851 #define __HAL_RCC_I2C2_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_I2C2RST))
Kojto 122:f9eeca106725 2852 #define __HAL_RCC_DAC2_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_DAC2RST))
Kojto 122:f9eeca106725 2853 #define __HAL_RCC_CEC_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_CECRST))
Kojto 90:cb3d968589d8 2854 #endif /* STM32F373xC || STM32F378xx */
Kojto 90:cb3d968589d8 2855
Kojto 122:f9eeca106725 2856 #if defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2857 || defined(STM32F303xC) || defined(STM32F358xx)\
Kojto 122:f9eeca106725 2858 || defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)\
Kojto 122:f9eeca106725 2859 || defined(STM32F373xC) || defined(STM32F378xx)
Kojto 122:f9eeca106725 2860 #define __HAL_RCC_TIM7_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM7RST))
Kojto 122:f9eeca106725 2861
Kojto 122:f9eeca106725 2862 #define __HAL_RCC_TIM7_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM7RST))
Kojto 90:cb3d968589d8 2863 #endif /* STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 2864 /* STM32F303xC || STM32F358xx || */
Kojto 90:cb3d968589d8 2865 /* STM32F303x8 || STM32F334x8 || STM32F328xx || */
Kojto 90:cb3d968589d8 2866 /* STM32F373xC || STM32F378xx */
Kojto 90:cb3d968589d8 2867
Kojto 122:f9eeca106725 2868 #if defined(STM32F302xE) || defined(STM32F303xE)\
Kojto 122:f9eeca106725 2869 || defined(STM32F302xC) || defined(STM32F303xC)\
Kojto 122:f9eeca106725 2870 || defined(STM32F302x8) \
Kojto 122:f9eeca106725 2871 || defined(STM32F373xC)
Kojto 122:f9eeca106725 2872 #define __HAL_RCC_USB_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_USBRST))
Kojto 122:f9eeca106725 2873
Kojto 122:f9eeca106725 2874 #define __HAL_RCC_USB_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_USBRST))
Kojto 90:cb3d968589d8 2875 #endif /* STM32F302xE || STM32F303xE || */
Kojto 90:cb3d968589d8 2876 /* STM32F302xC || STM32F303xC || */
Kojto 90:cb3d968589d8 2877 /* STM32F302x8 || */
Kojto 90:cb3d968589d8 2878 /* STM32F373xC */
Kojto 90:cb3d968589d8 2879
Kojto 90:cb3d968589d8 2880 #if !defined(STM32F301x8)
Kojto 122:f9eeca106725 2881 #define __HAL_RCC_CAN1_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_CANRST))
Kojto 122:f9eeca106725 2882
Kojto 122:f9eeca106725 2883 #define __HAL_RCC_CAN1_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_CANRST))
Kojto 90:cb3d968589d8 2884 #endif /* STM32F301x8*/
Kojto 90:cb3d968589d8 2885
Kojto 90:cb3d968589d8 2886 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 122:f9eeca106725 2887 #define __HAL_RCC_I2C3_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_I2C3RST))
Kojto 122:f9eeca106725 2888
Kojto 122:f9eeca106725 2889 #define __HAL_RCC_I2C3_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_I2C3RST))
Kojto 90:cb3d968589d8 2890 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
Kojto 90:cb3d968589d8 2891 /**
Kojto 90:cb3d968589d8 2892 * @}
Kojto 90:cb3d968589d8 2893 */
Kojto 90:cb3d968589d8 2894
Kojto 90:cb3d968589d8 2895 /** @defgroup RCCEx_APB2_Force_Release_Reset RCC Extended APB2 Force Release Reset
Kojto 90:cb3d968589d8 2896 * @brief Force or release APB2 peripheral reset.
Kojto 90:cb3d968589d8 2897 * @{
Kojto 90:cb3d968589d8 2898 */
Kojto 122:f9eeca106725 2899 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2900 || defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 2901 #define __HAL_RCC_SPI1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_SPI1RST))
Kojto 122:f9eeca106725 2902
Kojto 122:f9eeca106725 2903 #define __HAL_RCC_SPI1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_SPI1RST))
Kojto 90:cb3d968589d8 2904 #endif /* STM32F302xE || STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 2905 /* STM32F302xC || STM32F303xC || STM32F358xx */
Kojto 90:cb3d968589d8 2906
Kojto 122:f9eeca106725 2907 #if defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2908 || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 122:f9eeca106725 2909 #define __HAL_RCC_TIM8_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_TIM8RST))
Kojto 122:f9eeca106725 2910
Kojto 122:f9eeca106725 2911 #define __HAL_RCC_TIM8_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_TIM8RST))
Kojto 90:cb3d968589d8 2912 #endif /* STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 2913 /* STM32F303xC || STM32F358xx */
Kojto 90:cb3d968589d8 2914
Kojto 90:cb3d968589d8 2915 #if defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)
Kojto 122:f9eeca106725 2916 #define __HAL_RCC_SPI1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_SPI1RST))
Kojto 122:f9eeca106725 2917
Kojto 122:f9eeca106725 2918 #define __HAL_RCC_SPI1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_SPI1RST))
Kojto 90:cb3d968589d8 2919 #endif /* STM32F303x8 || STM32F334x8 || STM32F328xx */
Kojto 90:cb3d968589d8 2920
Kojto 90:cb3d968589d8 2921 #if defined(STM32F334x8)
Kojto 122:f9eeca106725 2922 #define __HAL_RCC_HRTIM1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_HRTIM1RST))
Kojto 122:f9eeca106725 2923
Kojto 122:f9eeca106725 2924 #define __HAL_RCC_HRTIM1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_HRTIM1RST))
Kojto 90:cb3d968589d8 2925 #endif /* STM32F334x8 */
Kojto 90:cb3d968589d8 2926
Kojto 90:cb3d968589d8 2927 #if defined(STM32F373xC) || defined(STM32F378xx)
Kojto 122:f9eeca106725 2928 #define __HAL_RCC_ADC1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_ADC1RST))
Kojto 122:f9eeca106725 2929 #define __HAL_RCC_SPI1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_SPI1RST))
Kojto 122:f9eeca106725 2930 #define __HAL_RCC_TIM19_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_TIM19RST))
Kojto 122:f9eeca106725 2931 #define __HAL_RCC_SDADC1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_SDADC1RST))
Kojto 122:f9eeca106725 2932 #define __HAL_RCC_SDADC2_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_SDADC2RST))
Kojto 122:f9eeca106725 2933 #define __HAL_RCC_SDADC3_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_SDADC3RST))
Kojto 122:f9eeca106725 2934
Kojto 122:f9eeca106725 2935 #define __HAL_RCC_ADC1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_ADC1RST))
Kojto 122:f9eeca106725 2936 #define __HAL_RCC_SPI1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_SPI1RST))
Kojto 122:f9eeca106725 2937 #define __HAL_RCC_TIM19_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_TIM19RST))
Kojto 122:f9eeca106725 2938 #define __HAL_RCC_SDADC1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_SDADC1RST))
Kojto 122:f9eeca106725 2939 #define __HAL_RCC_SDADC2_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_SDADC2RST))
Kojto 122:f9eeca106725 2940 #define __HAL_RCC_SDADC3_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_SDADC3RST))
Kojto 90:cb3d968589d8 2941 #endif /* STM32F373xC || STM32F378xx */
Kojto 90:cb3d968589d8 2942
Kojto 122:f9eeca106725 2943 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 2944 || defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)\
Kojto 122:f9eeca106725 2945 || defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)\
Kojto 122:f9eeca106725 2946 || defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)
Kojto 122:f9eeca106725 2947 #define __HAL_RCC_TIM1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_TIM1RST))
Kojto 122:f9eeca106725 2948
Kojto 122:f9eeca106725 2949 #define __HAL_RCC_TIM1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_TIM1RST))
Kojto 90:cb3d968589d8 2950 #endif /* STM32F302xE || STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 2951 /* STM32F302xC || STM32F303xC || STM32F358xx || */
Kojto 90:cb3d968589d8 2952 /* STM32F303x8 || STM32F334x8 || STM32F328xx || */
Kojto 90:cb3d968589d8 2953 /* STM32F301x8 || STM32F302x8 || STM32F318xx */
Kojto 90:cb3d968589d8 2954
Kojto 90:cb3d968589d8 2955 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 122:f9eeca106725 2956 #define __HAL_RCC_SPI4_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_SPI4RST))
Kojto 122:f9eeca106725 2957
Kojto 122:f9eeca106725 2958 #define __HAL_RCC_SPI4_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_SPI4RST))
Kojto 90:cb3d968589d8 2959 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
Kojto 90:cb3d968589d8 2960
Kojto 90:cb3d968589d8 2961 #if defined(STM32F303xE) || defined(STM32F398xx)
Kojto 122:f9eeca106725 2962 #define __HAL_RCC_TIM20_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_TIM20RST))
Kojto 122:f9eeca106725 2963
Kojto 122:f9eeca106725 2964 #define __HAL_RCC_TIM20_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_TIM20RST))
Kojto 90:cb3d968589d8 2965 #endif /* STM32F303xE || STM32F398xx */
Kojto 90:cb3d968589d8 2966
Kojto 90:cb3d968589d8 2967 /**
Kojto 90:cb3d968589d8 2968 * @}
Kojto 90:cb3d968589d8 2969 */
Kojto 90:cb3d968589d8 2970
Kojto 90:cb3d968589d8 2971 #if defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)
Kojto 90:cb3d968589d8 2972 /** @defgroup RCCEx_I2Cx_Clock_Config RCC Extended I2Cx Clock Config
Kojto 90:cb3d968589d8 2973 * @{
Kojto 90:cb3d968589d8 2974 */
Kojto 90:cb3d968589d8 2975
Kojto 90:cb3d968589d8 2976 /** @brief Macro to configure the I2C2 clock (I2C2CLK).
Kojto 122:f9eeca106725 2977 * @param __I2C2CLKSource__ specifies the I2C2 clock source.
Kojto 90:cb3d968589d8 2978 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 2979 * @arg @ref RCC_I2C2CLKSOURCE_HSI HSI selected as I2C2 clock
Kojto 122:f9eeca106725 2980 * @arg @ref RCC_I2C2CLKSOURCE_SYSCLK System Clock selected as I2C2 clock
Kojto 90:cb3d968589d8 2981 */
Kojto 90:cb3d968589d8 2982 #define __HAL_RCC_I2C2_CONFIG(__I2C2CLKSource__) \
Kojto 90:cb3d968589d8 2983 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_I2C2SW, (uint32_t)(__I2C2CLKSource__))
Kojto 90:cb3d968589d8 2984
Kojto 90:cb3d968589d8 2985 /** @brief Macro to get the I2C2 clock source.
Kojto 90:cb3d968589d8 2986 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 2987 * @arg @ref RCC_I2C2CLKSOURCE_HSI HSI selected as I2C2 clock
Kojto 122:f9eeca106725 2988 * @arg @ref RCC_I2C2CLKSOURCE_SYSCLK System Clock selected as I2C2 clock
Kojto 90:cb3d968589d8 2989 */
Kojto 90:cb3d968589d8 2990 #define __HAL_RCC_GET_I2C2_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_I2C2SW)))
Kojto 90:cb3d968589d8 2991
Kojto 90:cb3d968589d8 2992 /** @brief Macro to configure the I2C3 clock (I2C3CLK).
Kojto 122:f9eeca106725 2993 * @param __I2C3CLKSource__ specifies the I2C3 clock source.
Kojto 90:cb3d968589d8 2994 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 2995 * @arg @ref RCC_I2C3CLKSOURCE_HSI HSI selected as I2C3 clock
Kojto 122:f9eeca106725 2996 * @arg @ref RCC_I2C3CLKSOURCE_SYSCLK System Clock selected as I2C3 clock
Kojto 90:cb3d968589d8 2997 */
Kojto 90:cb3d968589d8 2998 #define __HAL_RCC_I2C3_CONFIG(__I2C3CLKSource__) \
Kojto 90:cb3d968589d8 2999 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_I2C3SW, (uint32_t)(__I2C3CLKSource__))
Kojto 90:cb3d968589d8 3000
Kojto 90:cb3d968589d8 3001 /** @brief Macro to get the I2C3 clock source.
Kojto 90:cb3d968589d8 3002 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3003 * @arg @ref RCC_I2C3CLKSOURCE_HSI HSI selected as I2C3 clock
Kojto 122:f9eeca106725 3004 * @arg @ref RCC_I2C3CLKSOURCE_SYSCLK System Clock selected as I2C3 clock
Kojto 90:cb3d968589d8 3005 */
Kojto 90:cb3d968589d8 3006 #define __HAL_RCC_GET_I2C3_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_I2C3SW)))
Kojto 90:cb3d968589d8 3007
Kojto 90:cb3d968589d8 3008 /**
Kojto 90:cb3d968589d8 3009 * @}
Kojto 90:cb3d968589d8 3010 */
Kojto 90:cb3d968589d8 3011
Kojto 90:cb3d968589d8 3012 /** @defgroup RCCEx_TIMx_Clock_Config RCC Extended TIMx Clock Config
Kojto 90:cb3d968589d8 3013 * @{
Kojto 90:cb3d968589d8 3014 */
Kojto 90:cb3d968589d8 3015 /** @brief Macro to configure the TIM1 clock (TIM1CLK).
Kojto 122:f9eeca106725 3016 * @param __TIM1CLKSource__ specifies the TIM1 clock source.
Kojto 90:cb3d968589d8 3017 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3018 * @arg @ref RCC_TIM1CLK_HCLK HCLK selected as TIM1 clock
Kojto 122:f9eeca106725 3019 * @arg @ref RCC_TIM1CLK_PLLCLK PLL Clock selected as TIM1 clock
Kojto 90:cb3d968589d8 3020 */
Kojto 90:cb3d968589d8 3021 #define __HAL_RCC_TIM1_CONFIG(__TIM1CLKSource__) \
Kojto 90:cb3d968589d8 3022 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_TIM1SW, (uint32_t)(__TIM1CLKSource__))
Kojto 90:cb3d968589d8 3023
Kojto 90:cb3d968589d8 3024 /** @brief Macro to get the TIM1 clock (TIM1CLK).
Kojto 90:cb3d968589d8 3025 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3026 * @arg @ref RCC_TIM1CLK_HCLK HCLK selected as TIM1 clock
Kojto 122:f9eeca106725 3027 * @arg @ref RCC_TIM1CLK_PLLCLK PLL Clock selected as TIM1 clock
Kojto 90:cb3d968589d8 3028 */
Kojto 90:cb3d968589d8 3029 #define __HAL_RCC_GET_TIM1_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_TIM1SW)))
Kojto 90:cb3d968589d8 3030
Kojto 90:cb3d968589d8 3031 /** @brief Macro to configure the TIM15 clock (TIM15CLK).
Kojto 122:f9eeca106725 3032 * @param __TIM15CLKSource__ specifies the TIM15 clock source.
Kojto 90:cb3d968589d8 3033 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3034 * @arg @ref RCC_TIM15CLK_HCLK HCLK selected as TIM15 clock
Kojto 122:f9eeca106725 3035 * @arg @ref RCC_TIM15CLK_PLL PLL Clock selected as TIM15 clock
Kojto 90:cb3d968589d8 3036 */
Kojto 90:cb3d968589d8 3037 #define __HAL_RCC_TIM15_CONFIG(__TIM15CLKSource__) \
Kojto 90:cb3d968589d8 3038 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_TIM15SW, (uint32_t)(__TIM15CLKSource__))
Kojto 90:cb3d968589d8 3039
Kojto 90:cb3d968589d8 3040 /** @brief Macro to get the TIM15 clock (TIM15CLK).
Kojto 90:cb3d968589d8 3041 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3042 * @arg @ref RCC_TIM15CLK_HCLK HCLK selected as TIM15 clock
Kojto 122:f9eeca106725 3043 * @arg @ref RCC_TIM15CLK_PLL PLL Clock selected as TIM15 clock
Kojto 90:cb3d968589d8 3044 */
Kojto 90:cb3d968589d8 3045 #define __HAL_RCC_GET_TIM15_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_TIM15SW)))
Kojto 90:cb3d968589d8 3046
Kojto 90:cb3d968589d8 3047 /** @brief Macro to configure the TIM16 clock (TIM16CLK).
Kojto 122:f9eeca106725 3048 * @param __TIM16CLKSource__ specifies the TIM16 clock source.
Kojto 90:cb3d968589d8 3049 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3050 * @arg @ref RCC_TIM16CLK_HCLK HCLK selected as TIM16 clock
Kojto 122:f9eeca106725 3051 * @arg @ref RCC_TIM16CLK_PLL PLL Clock selected as TIM16 clock
Kojto 90:cb3d968589d8 3052 */
Kojto 90:cb3d968589d8 3053 #define __HAL_RCC_TIM16_CONFIG(__TIM16CLKSource__) \
Kojto 90:cb3d968589d8 3054 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_TIM16SW, (uint32_t)(__TIM16CLKSource__))
Kojto 90:cb3d968589d8 3055
Kojto 90:cb3d968589d8 3056 /** @brief Macro to get the TIM16 clock (TIM16CLK).
Kojto 90:cb3d968589d8 3057 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3058 * @arg @ref RCC_TIM16CLK_HCLK HCLK selected as TIM16 clock
Kojto 122:f9eeca106725 3059 * @arg @ref RCC_TIM16CLK_PLL PLL Clock selected as TIM16 clock
Kojto 90:cb3d968589d8 3060 */
Kojto 90:cb3d968589d8 3061 #define __HAL_RCC_GET_TIM16_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_TIM16SW)))
Kojto 90:cb3d968589d8 3062
Kojto 90:cb3d968589d8 3063 /** @brief Macro to configure the TIM17 clock (TIM17CLK).
Kojto 122:f9eeca106725 3064 * @param __TIM17CLKSource__ specifies the TIM17 clock source.
Kojto 90:cb3d968589d8 3065 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3066 * @arg @ref RCC_TIM17CLK_HCLK HCLK selected as TIM17 clock
Kojto 122:f9eeca106725 3067 * @arg @ref RCC_TIM17CLK_PLL PLL Clock selected as TIM17 clock
Kojto 90:cb3d968589d8 3068 */
Kojto 90:cb3d968589d8 3069 #define __HAL_RCC_TIM17_CONFIG(__TIM17CLKSource__) \
Kojto 90:cb3d968589d8 3070 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_TIM17SW, (uint32_t)(__TIM17CLKSource__))
Kojto 90:cb3d968589d8 3071
Kojto 90:cb3d968589d8 3072 /** @brief Macro to get the TIM17 clock (TIM17CLK).
Kojto 90:cb3d968589d8 3073 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3074 * @arg @ref RCC_TIM17CLK_HCLK HCLK selected as TIM17 clock
Kojto 122:f9eeca106725 3075 * @arg @ref RCC_TIM17CLK_PLL PLL Clock selected as TIM17 clock
Kojto 90:cb3d968589d8 3076 */
Kojto 90:cb3d968589d8 3077 #define __HAL_RCC_GET_TIM17_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_TIM17SW)))
Kojto 90:cb3d968589d8 3078
Kojto 90:cb3d968589d8 3079 /**
Kojto 90:cb3d968589d8 3080 * @}
Kojto 90:cb3d968589d8 3081 */
Kojto 90:cb3d968589d8 3082
Kojto 90:cb3d968589d8 3083 /** @defgroup RCCEx_I2Sx_Clock_Config RCC Extended I2Sx Clock Config
Kojto 90:cb3d968589d8 3084 * @{
Kojto 90:cb3d968589d8 3085 */
Kojto 90:cb3d968589d8 3086 /** @brief Macro to configure the I2S clock source (I2SCLK).
Kojto 90:cb3d968589d8 3087 * @note This function must be called before enabling the I2S APB clock.
Kojto 122:f9eeca106725 3088 * @param __I2SCLKSource__ specifies the I2S clock source.
Kojto 90:cb3d968589d8 3089 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3090 * @arg @ref RCC_I2SCLKSOURCE_SYSCLK SYSCLK clock used as I2S clock source
Kojto 122:f9eeca106725 3091 * @arg @ref RCC_I2SCLKSOURCE_EXT External clock mapped on the I2S_CKIN pin
Kojto 90:cb3d968589d8 3092 * used as I2S clock source
Kojto 90:cb3d968589d8 3093 */
Kojto 90:cb3d968589d8 3094 #define __HAL_RCC_I2S_CONFIG(__I2SCLKSource__) \
Kojto 90:cb3d968589d8 3095 MODIFY_REG(RCC->CFGR, RCC_CFGR_I2SSRC, (uint32_t)(__I2SCLKSource__))
Kojto 90:cb3d968589d8 3096
Kojto 90:cb3d968589d8 3097 /** @brief Macro to get the I2S clock source (I2SCLK).
Kojto 90:cb3d968589d8 3098 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3099 * @arg @ref RCC_I2SCLKSOURCE_SYSCLK SYSCLK clock used as I2S clock source
Kojto 122:f9eeca106725 3100 * @arg @ref RCC_I2SCLKSOURCE_EXT External clock mapped on the I2S_CKIN pin
Kojto 90:cb3d968589d8 3101 * used as I2S clock source
Kojto 90:cb3d968589d8 3102 */
Kojto 90:cb3d968589d8 3103 #define __HAL_RCC_GET_I2S_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR, RCC_CFGR_I2SSRC)))
Kojto 90:cb3d968589d8 3104 /**
Kojto 90:cb3d968589d8 3105 * @}
Kojto 90:cb3d968589d8 3106 */
Kojto 90:cb3d968589d8 3107
Kojto 90:cb3d968589d8 3108 /** @defgroup RCCEx_ADCx_Clock_Config RCC Extended ADCx Clock Config
Kojto 90:cb3d968589d8 3109 * @{
Kojto 90:cb3d968589d8 3110 */
Kojto 90:cb3d968589d8 3111
Kojto 90:cb3d968589d8 3112 /** @brief Macro to configure the ADC1 clock (ADC1CLK).
Kojto 122:f9eeca106725 3113 * @param __ADC1CLKSource__ specifies the ADC1 clock source.
Kojto 90:cb3d968589d8 3114 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3115 * @arg @ref RCC_ADC1PLLCLK_OFF ADC1 PLL clock disabled, ADC1 can use AHB clock
Kojto 122:f9eeca106725 3116 * @arg @ref RCC_ADC1PLLCLK_DIV1 PLL clock divided by 1 selected as ADC1 clock
Kojto 122:f9eeca106725 3117 * @arg @ref RCC_ADC1PLLCLK_DIV2 PLL clock divided by 2 selected as ADC1 clock
Kojto 122:f9eeca106725 3118 * @arg @ref RCC_ADC1PLLCLK_DIV4 PLL clock divided by 4 selected as ADC1 clock
Kojto 122:f9eeca106725 3119 * @arg @ref RCC_ADC1PLLCLK_DIV6 PLL clock divided by 6 selected as ADC1 clock
Kojto 122:f9eeca106725 3120 * @arg @ref RCC_ADC1PLLCLK_DIV8 PLL clock divided by 8 selected as ADC1 clock
Kojto 122:f9eeca106725 3121 * @arg @ref RCC_ADC1PLLCLK_DIV10 PLL clock divided by 10 selected as ADC1 clock
Kojto 122:f9eeca106725 3122 * @arg @ref RCC_ADC1PLLCLK_DIV12 PLL clock divided by 12 selected as ADC1 clock
Kojto 122:f9eeca106725 3123 * @arg @ref RCC_ADC1PLLCLK_DIV16 PLL clock divided by 16 selected as ADC1 clock
Kojto 122:f9eeca106725 3124 * @arg @ref RCC_ADC1PLLCLK_DIV32 PLL clock divided by 32 selected as ADC1 clock
Kojto 122:f9eeca106725 3125 * @arg @ref RCC_ADC1PLLCLK_DIV64 PLL clock divided by 64 selected as ADC1 clock
Kojto 122:f9eeca106725 3126 * @arg @ref RCC_ADC1PLLCLK_DIV128 PLL clock divided by 128 selected as ADC1 clock
Kojto 122:f9eeca106725 3127 * @arg @ref RCC_ADC1PLLCLK_DIV256 PLL clock divided by 256 selected as ADC1 clock
Kojto 90:cb3d968589d8 3128 */
Kojto 90:cb3d968589d8 3129 #define __HAL_RCC_ADC1_CONFIG(__ADC1CLKSource__) \
Kojto 90:cb3d968589d8 3130 MODIFY_REG(RCC->CFGR2, RCC_CFGR2_ADC1PRES, (uint32_t)(__ADC1CLKSource__))
Kojto 90:cb3d968589d8 3131
Kojto 90:cb3d968589d8 3132 /** @brief Macro to get the ADC1 clock
Kojto 90:cb3d968589d8 3133 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3134 * @arg @ref RCC_ADC1PLLCLK_OFF ADC1 PLL clock disabled, ADC1 can use AHB clock
Kojto 122:f9eeca106725 3135 * @arg @ref RCC_ADC1PLLCLK_DIV1 PLL clock divided by 1 selected as ADC1 clock
Kojto 122:f9eeca106725 3136 * @arg @ref RCC_ADC1PLLCLK_DIV2 PLL clock divided by 2 selected as ADC1 clock
Kojto 122:f9eeca106725 3137 * @arg @ref RCC_ADC1PLLCLK_DIV4 PLL clock divided by 4 selected as ADC1 clock
Kojto 122:f9eeca106725 3138 * @arg @ref RCC_ADC1PLLCLK_DIV6 PLL clock divided by 6 selected as ADC1 clock
Kojto 122:f9eeca106725 3139 * @arg @ref RCC_ADC1PLLCLK_DIV8 PLL clock divided by 8 selected as ADC1 clock
Kojto 122:f9eeca106725 3140 * @arg @ref RCC_ADC1PLLCLK_DIV10 PLL clock divided by 10 selected as ADC1 clock
Kojto 122:f9eeca106725 3141 * @arg @ref RCC_ADC1PLLCLK_DIV12 PLL clock divided by 12 selected as ADC1 clock
Kojto 122:f9eeca106725 3142 * @arg @ref RCC_ADC1PLLCLK_DIV16 PLL clock divided by 16 selected as ADC1 clock
Kojto 122:f9eeca106725 3143 * @arg @ref RCC_ADC1PLLCLK_DIV32 PLL clock divided by 32 selected as ADC1 clock
Kojto 122:f9eeca106725 3144 * @arg @ref RCC_ADC1PLLCLK_DIV64 PLL clock divided by 64 selected as ADC1 clock
Kojto 122:f9eeca106725 3145 * @arg @ref RCC_ADC1PLLCLK_DIV128 PLL clock divided by 128 selected as ADC1 clock
Kojto 122:f9eeca106725 3146 * @arg @ref RCC_ADC1PLLCLK_DIV256 PLL clock divided by 256 selected as ADC1 clock
Kojto 90:cb3d968589d8 3147 */
Kojto 90:cb3d968589d8 3148 #define __HAL_RCC_GET_ADC1_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR2, RCC_CFGR2_ADC1PRES)))
Kojto 90:cb3d968589d8 3149 /**
Kojto 90:cb3d968589d8 3150 * @}
Kojto 90:cb3d968589d8 3151 */
Kojto 90:cb3d968589d8 3152
Kojto 90:cb3d968589d8 3153 #endif /* STM32F301x8 || STM32F302x8 || STM32F318xx */
Kojto 90:cb3d968589d8 3154
Kojto 122:f9eeca106725 3155 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 3156 || defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 90:cb3d968589d8 3157 /** @defgroup RCCEx_I2Cx_Clock_Config RCC Extended I2Cx Clock Config
Kojto 90:cb3d968589d8 3158 * @{
Kojto 90:cb3d968589d8 3159 */
Kojto 90:cb3d968589d8 3160
Kojto 90:cb3d968589d8 3161 /** @brief Macro to configure the I2C2 clock (I2C2CLK).
Kojto 122:f9eeca106725 3162 * @param __I2C2CLKSource__ specifies the I2C2 clock source.
Kojto 90:cb3d968589d8 3163 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3164 * @arg @ref RCC_I2C2CLKSOURCE_HSI HSI selected as I2C2 clock
Kojto 122:f9eeca106725 3165 * @arg @ref RCC_I2C2CLKSOURCE_SYSCLK System Clock selected as I2C2 clock
Kojto 90:cb3d968589d8 3166 */
Kojto 90:cb3d968589d8 3167 #define __HAL_RCC_I2C2_CONFIG(__I2C2CLKSource__) \
Kojto 90:cb3d968589d8 3168 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_I2C2SW, (uint32_t)(__I2C2CLKSource__))
Kojto 90:cb3d968589d8 3169
Kojto 90:cb3d968589d8 3170 /** @brief Macro to get the I2C2 clock source.
Kojto 90:cb3d968589d8 3171 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3172 * @arg @ref RCC_I2C2CLKSOURCE_HSI HSI selected as I2C2 clock
Kojto 122:f9eeca106725 3173 * @arg @ref RCC_I2C2CLKSOURCE_SYSCLK System Clock selected as I2C2 clock
Kojto 90:cb3d968589d8 3174 */
Kojto 90:cb3d968589d8 3175 #define __HAL_RCC_GET_I2C2_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_I2C2SW)))
Kojto 90:cb3d968589d8 3176 /**
Kojto 90:cb3d968589d8 3177 * @}
Kojto 90:cb3d968589d8 3178 */
Kojto 90:cb3d968589d8 3179
Kojto 90:cb3d968589d8 3180 /** @defgroup RCCEx_ADCx_Clock_Config RCC Extended ADCx Clock Config
Kojto 90:cb3d968589d8 3181 * @{
Kojto 90:cb3d968589d8 3182 */
Kojto 90:cb3d968589d8 3183
Kojto 90:cb3d968589d8 3184 /** @brief Macro to configure the ADC1 & ADC2 clock (ADC12CLK).
Kojto 122:f9eeca106725 3185 * @param __ADC12CLKSource__ specifies the ADC1 & ADC2 clock source.
Kojto 90:cb3d968589d8 3186 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3187 * @arg @ref RCC_ADC12PLLCLK_OFF ADC1 & ADC2 PLL clock disabled, ADC1 & ADC2 can use AHB clock
Kojto 122:f9eeca106725 3188 * @arg @ref RCC_ADC12PLLCLK_DIV1 PLL clock divided by 1 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3189 * @arg @ref RCC_ADC12PLLCLK_DIV2 PLL clock divided by 2 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3190 * @arg @ref RCC_ADC12PLLCLK_DIV4 PLL clock divided by 4 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3191 * @arg @ref RCC_ADC12PLLCLK_DIV6 PLL clock divided by 6 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3192 * @arg @ref RCC_ADC12PLLCLK_DIV8 PLL clock divided by 8 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3193 * @arg @ref RCC_ADC12PLLCLK_DIV10 PLL clock divided by 10 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3194 * @arg @ref RCC_ADC12PLLCLK_DIV12 PLL clock divided by 12 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3195 * @arg @ref RCC_ADC12PLLCLK_DIV16 PLL clock divided by 16 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3196 * @arg @ref RCC_ADC12PLLCLK_DIV32 PLL clock divided by 32 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3197 * @arg @ref RCC_ADC12PLLCLK_DIV64 PLL clock divided by 64 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3198 * @arg @ref RCC_ADC12PLLCLK_DIV128 PLL clock divided by 128 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3199 * @arg @ref RCC_ADC12PLLCLK_DIV256 PLL clock divided by 256 selected as ADC1 & ADC2 clock
Kojto 90:cb3d968589d8 3200 */
Kojto 90:cb3d968589d8 3201 #define __HAL_RCC_ADC12_CONFIG(__ADC12CLKSource__) \
Kojto 90:cb3d968589d8 3202 MODIFY_REG(RCC->CFGR2, RCC_CFGR2_ADCPRE12, (uint32_t)(__ADC12CLKSource__))
Kojto 90:cb3d968589d8 3203
Kojto 90:cb3d968589d8 3204 /** @brief Macro to get the ADC1 & ADC2 clock
Kojto 90:cb3d968589d8 3205 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3206 * @arg @ref RCC_ADC12PLLCLK_OFF ADC1 & ADC2 PLL clock disabled, ADC1 & ADC2 can use AHB clock
Kojto 122:f9eeca106725 3207 * @arg @ref RCC_ADC12PLLCLK_DIV1 PLL clock divided by 1 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3208 * @arg @ref RCC_ADC12PLLCLK_DIV2 PLL clock divided by 2 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3209 * @arg @ref RCC_ADC12PLLCLK_DIV4 PLL clock divided by 4 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3210 * @arg @ref RCC_ADC12PLLCLK_DIV6 PLL clock divided by 6 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3211 * @arg @ref RCC_ADC12PLLCLK_DIV8 PLL clock divided by 8 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3212 * @arg @ref RCC_ADC12PLLCLK_DIV10 PLL clock divided by 10 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3213 * @arg @ref RCC_ADC12PLLCLK_DIV12 PLL clock divided by 12 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3214 * @arg @ref RCC_ADC12PLLCLK_DIV16 PLL clock divided by 16 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3215 * @arg @ref RCC_ADC12PLLCLK_DIV32 PLL clock divided by 32 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3216 * @arg @ref RCC_ADC12PLLCLK_DIV64 PLL clock divided by 64 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3217 * @arg @ref RCC_ADC12PLLCLK_DIV128 PLL clock divided by 128 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3218 * @arg @ref RCC_ADC12PLLCLK_DIV256 PLL clock divided by 256 selected as ADC1 & ADC2 clock
Kojto 90:cb3d968589d8 3219 */
Kojto 90:cb3d968589d8 3220 #define __HAL_RCC_GET_ADC12_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR2, RCC_CFGR2_ADCPRE12)))
Kojto 90:cb3d968589d8 3221 /**
Kojto 90:cb3d968589d8 3222 * @}
Kojto 90:cb3d968589d8 3223 */
Kojto 90:cb3d968589d8 3224
Kojto 90:cb3d968589d8 3225 /** @defgroup RCCEx_TIMx_Clock_Config RCC Extended TIMx Clock Config
Kojto 90:cb3d968589d8 3226 * @{
Kojto 90:cb3d968589d8 3227 */
Kojto 90:cb3d968589d8 3228
Kojto 90:cb3d968589d8 3229 /** @brief Macro to configure the TIM1 clock (TIM1CLK).
Kojto 122:f9eeca106725 3230 * @param __TIM1CLKSource__ specifies the TIM1 clock source.
Kojto 90:cb3d968589d8 3231 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3232 * @arg @ref RCC_TIM1CLK_HCLK HCLK selected as TIM1 clock
Kojto 122:f9eeca106725 3233 * @arg @ref RCC_TIM1CLK_PLLCLK PLL Clock selected as TIM1 clock
Kojto 90:cb3d968589d8 3234 */
Kojto 90:cb3d968589d8 3235 #define __HAL_RCC_TIM1_CONFIG(__TIM1CLKSource__) \
Kojto 90:cb3d968589d8 3236 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_TIM1SW, (uint32_t)(__TIM1CLKSource__))
Kojto 90:cb3d968589d8 3237
Kojto 90:cb3d968589d8 3238 /** @brief Macro to get the TIM1 clock (TIM1CLK).
Kojto 90:cb3d968589d8 3239 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3240 * @arg @ref RCC_TIM1CLK_HCLK HCLK selected as TIM1 clock
Kojto 122:f9eeca106725 3241 * @arg @ref RCC_TIM1CLK_PLLCLK PLL Clock selected as TIM1 clock
Kojto 90:cb3d968589d8 3242 */
Kojto 90:cb3d968589d8 3243 #define __HAL_RCC_GET_TIM1_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_TIM1SW)))
Kojto 90:cb3d968589d8 3244 /**
Kojto 90:cb3d968589d8 3245 * @}
Kojto 90:cb3d968589d8 3246 */
Kojto 90:cb3d968589d8 3247
Kojto 90:cb3d968589d8 3248 /** @defgroup RCCEx_I2Sx_Clock_Config RCC Extended I2Sx Clock Config
Kojto 90:cb3d968589d8 3249 * @{
Kojto 90:cb3d968589d8 3250 */
Kojto 90:cb3d968589d8 3251
Kojto 90:cb3d968589d8 3252 /** @brief Macro to configure the I2S clock source (I2SCLK).
Kojto 90:cb3d968589d8 3253 * @note This function must be called before enabling the I2S APB clock.
Kojto 122:f9eeca106725 3254 * @param __I2SCLKSource__ specifies the I2S clock source.
Kojto 90:cb3d968589d8 3255 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3256 * @arg @ref RCC_I2SCLKSOURCE_SYSCLK SYSCLK clock used as I2S clock source
Kojto 122:f9eeca106725 3257 * @arg @ref RCC_I2SCLKSOURCE_EXT External clock mapped on the I2S_CKIN pin
Kojto 90:cb3d968589d8 3258 * used as I2S clock source
Kojto 90:cb3d968589d8 3259 */
Kojto 90:cb3d968589d8 3260 #define __HAL_RCC_I2S_CONFIG(__I2SCLKSource__) \
Kojto 90:cb3d968589d8 3261 MODIFY_REG(RCC->CFGR, RCC_CFGR_I2SSRC, (uint32_t)(__I2SCLKSource__))
Kojto 90:cb3d968589d8 3262
Kojto 90:cb3d968589d8 3263 /** @brief Macro to get the I2S clock source (I2SCLK).
Kojto 90:cb3d968589d8 3264 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3265 * @arg @ref RCC_I2SCLKSOURCE_SYSCLK SYSCLK clock used as I2S clock source
Kojto 122:f9eeca106725 3266 * @arg @ref RCC_I2SCLKSOURCE_EXT External clock mapped on the I2S_CKIN pin
Kojto 90:cb3d968589d8 3267 * used as I2S clock source
Kojto 90:cb3d968589d8 3268 */
Kojto 90:cb3d968589d8 3269 #define __HAL_RCC_GET_I2S_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR, RCC_CFGR_I2SSRC)))
Kojto 90:cb3d968589d8 3270 /**
Kojto 90:cb3d968589d8 3271 * @}
Kojto 90:cb3d968589d8 3272 */
Kojto 90:cb3d968589d8 3273
Kojto 90:cb3d968589d8 3274 /** @defgroup RCCEx_UARTx_Clock_Config RCC Extended UARTx Clock Config
Kojto 90:cb3d968589d8 3275 * @{
Kojto 90:cb3d968589d8 3276 */
Kojto 90:cb3d968589d8 3277
Kojto 90:cb3d968589d8 3278 /** @brief Macro to configure the UART4 clock (UART4CLK).
Kojto 122:f9eeca106725 3279 * @param __UART4CLKSource__ specifies the UART4 clock source.
Kojto 90:cb3d968589d8 3280 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3281 * @arg @ref RCC_UART4CLKSOURCE_PCLK1 PCLK1 selected as UART4 clock
Kojto 122:f9eeca106725 3282 * @arg @ref RCC_UART4CLKSOURCE_HSI HSI selected as UART4 clock
Kojto 122:f9eeca106725 3283 * @arg @ref RCC_UART4CLKSOURCE_SYSCLK System Clock selected as UART4 clock
Kojto 122:f9eeca106725 3284 * @arg @ref RCC_UART4CLKSOURCE_LSE LSE selected as UART4 clock
Kojto 90:cb3d968589d8 3285 */
Kojto 90:cb3d968589d8 3286 #define __HAL_RCC_UART4_CONFIG(__UART4CLKSource__) \
Kojto 90:cb3d968589d8 3287 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_UART4SW, (uint32_t)(__UART4CLKSource__))
Kojto 90:cb3d968589d8 3288
Kojto 90:cb3d968589d8 3289 /** @brief Macro to get the UART4 clock source.
Kojto 90:cb3d968589d8 3290 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3291 * @arg @ref RCC_UART4CLKSOURCE_PCLK1 PCLK1 selected as UART4 clock
Kojto 122:f9eeca106725 3292 * @arg @ref RCC_UART4CLKSOURCE_HSI HSI selected as UART4 clock
Kojto 122:f9eeca106725 3293 * @arg @ref RCC_UART4CLKSOURCE_SYSCLK System Clock selected as UART4 clock
Kojto 122:f9eeca106725 3294 * @arg @ref RCC_UART4CLKSOURCE_LSE LSE selected as UART4 clock
Kojto 90:cb3d968589d8 3295 */
Kojto 90:cb3d968589d8 3296 #define __HAL_RCC_GET_UART4_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_UART4SW)))
Kojto 90:cb3d968589d8 3297
Kojto 90:cb3d968589d8 3298 /** @brief Macro to configure the UART5 clock (UART5CLK).
Kojto 122:f9eeca106725 3299 * @param __UART5CLKSource__ specifies the UART5 clock source.
Kojto 90:cb3d968589d8 3300 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3301 * @arg @ref RCC_UART5CLKSOURCE_PCLK1 PCLK1 selected as UART5 clock
Kojto 122:f9eeca106725 3302 * @arg @ref RCC_UART5CLKSOURCE_HSI HSI selected as UART5 clock
Kojto 122:f9eeca106725 3303 * @arg @ref RCC_UART5CLKSOURCE_SYSCLK System Clock selected as UART5 clock
Kojto 122:f9eeca106725 3304 * @arg @ref RCC_UART5CLKSOURCE_LSE LSE selected as UART5 clock
Kojto 90:cb3d968589d8 3305 */
Kojto 90:cb3d968589d8 3306 #define __HAL_RCC_UART5_CONFIG(__UART5CLKSource__) \
Kojto 90:cb3d968589d8 3307 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_UART5SW, (uint32_t)(__UART5CLKSource__))
Kojto 90:cb3d968589d8 3308
Kojto 90:cb3d968589d8 3309 /** @brief Macro to get the UART5 clock source.
Kojto 90:cb3d968589d8 3310 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3311 * @arg @ref RCC_UART5CLKSOURCE_PCLK1 PCLK1 selected as UART5 clock
Kojto 122:f9eeca106725 3312 * @arg @ref RCC_UART5CLKSOURCE_HSI HSI selected as UART5 clock
Kojto 122:f9eeca106725 3313 * @arg @ref RCC_UART5CLKSOURCE_SYSCLK System Clock selected as UART5 clock
Kojto 122:f9eeca106725 3314 * @arg @ref RCC_UART5CLKSOURCE_LSE LSE selected as UART5 clock
Kojto 90:cb3d968589d8 3315 */
Kojto 90:cb3d968589d8 3316 #define __HAL_RCC_GET_UART5_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_UART5SW)))
Kojto 90:cb3d968589d8 3317 /**
Kojto 90:cb3d968589d8 3318 * @}
Kojto 90:cb3d968589d8 3319 */
Kojto 90:cb3d968589d8 3320 #endif /* STM32F302xE || STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 3321 /* STM32F302xC || STM32F303xC || STM32F358xx */
Kojto 90:cb3d968589d8 3322
Kojto 122:f9eeca106725 3323 #if defined(STM32F303xE) || defined(STM32F398xx)\
Kojto 122:f9eeca106725 3324 || defined(STM32F303xC) || defined(STM32F358xx)
Kojto 90:cb3d968589d8 3325 /** @defgroup RCCEx_ADCx_Clock_Config RCC Extended ADCx Clock Config
Kojto 90:cb3d968589d8 3326 * @{
Kojto 90:cb3d968589d8 3327 */
Kojto 90:cb3d968589d8 3328
Kojto 90:cb3d968589d8 3329 /** @brief Macro to configure the ADC3 & ADC4 clock (ADC34CLK).
Kojto 122:f9eeca106725 3330 * @param __ADC34CLKSource__ specifies the ADC3 & ADC4 clock source.
Kojto 90:cb3d968589d8 3331 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3332 * @arg @ref RCC_ADC34PLLCLK_OFF ADC3 & ADC4 PLL clock disabled, ADC3 & ADC4 can use AHB clock
Kojto 122:f9eeca106725 3333 * @arg @ref RCC_ADC34PLLCLK_DIV1 PLL clock divided by 1 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3334 * @arg @ref RCC_ADC34PLLCLK_DIV2 PLL clock divided by 2 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3335 * @arg @ref RCC_ADC34PLLCLK_DIV4 PLL clock divided by 4 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3336 * @arg @ref RCC_ADC34PLLCLK_DIV6 PLL clock divided by 6 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3337 * @arg @ref RCC_ADC34PLLCLK_DIV8 PLL clock divided by 8 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3338 * @arg @ref RCC_ADC34PLLCLK_DIV10 PLL clock divided by 10 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3339 * @arg @ref RCC_ADC34PLLCLK_DIV12 PLL clock divided by 12 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3340 * @arg @ref RCC_ADC34PLLCLK_DIV16 PLL clock divided by 16 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3341 * @arg @ref RCC_ADC34PLLCLK_DIV32 PLL clock divided by 32 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3342 * @arg @ref RCC_ADC34PLLCLK_DIV64 PLL clock divided by 64 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3343 * @arg @ref RCC_ADC34PLLCLK_DIV128 PLL clock divided by 128 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3344 * @arg @ref RCC_ADC34PLLCLK_DIV256 PLL clock divided by 256 selected as ADC3 & ADC4 clock
Kojto 90:cb3d968589d8 3345 */
Kojto 90:cb3d968589d8 3346 #define __HAL_RCC_ADC34_CONFIG(__ADC34CLKSource__) \
Kojto 90:cb3d968589d8 3347 MODIFY_REG(RCC->CFGR2, RCC_CFGR2_ADCPRE34, (uint32_t)(__ADC34CLKSource__))
Kojto 90:cb3d968589d8 3348
Kojto 90:cb3d968589d8 3349 /** @brief Macro to get the ADC3 & ADC4 clock
Kojto 90:cb3d968589d8 3350 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3351 * @arg @ref RCC_ADC34PLLCLK_OFF ADC3 & ADC4 PLL clock disabled, ADC3 & ADC4 can use AHB clock
Kojto 122:f9eeca106725 3352 * @arg @ref RCC_ADC34PLLCLK_DIV1 PLL clock divided by 1 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3353 * @arg @ref RCC_ADC34PLLCLK_DIV2 PLL clock divided by 2 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3354 * @arg @ref RCC_ADC34PLLCLK_DIV4 PLL clock divided by 4 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3355 * @arg @ref RCC_ADC34PLLCLK_DIV6 PLL clock divided by 6 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3356 * @arg @ref RCC_ADC34PLLCLK_DIV8 PLL clock divided by 8 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3357 * @arg @ref RCC_ADC34PLLCLK_DIV10 PLL clock divided by 10 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3358 * @arg @ref RCC_ADC34PLLCLK_DIV12 PLL clock divided by 12 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3359 * @arg @ref RCC_ADC34PLLCLK_DIV16 PLL clock divided by 16 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3360 * @arg @ref RCC_ADC34PLLCLK_DIV32 PLL clock divided by 32 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3361 * @arg @ref RCC_ADC34PLLCLK_DIV64 PLL clock divided by 64 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3362 * @arg @ref RCC_ADC34PLLCLK_DIV128 PLL clock divided by 128 selected as ADC3 & ADC4 clock
Kojto 122:f9eeca106725 3363 * @arg @ref RCC_ADC34PLLCLK_DIV256 PLL clock divided by 256 selected as ADC3 & ADC4 clock
Kojto 90:cb3d968589d8 3364 */
Kojto 90:cb3d968589d8 3365 #define __HAL_RCC_GET_ADC34_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR2, RCC_CFGR2_ADCPRE34)))
Kojto 90:cb3d968589d8 3366 /**
Kojto 90:cb3d968589d8 3367 * @}
Kojto 90:cb3d968589d8 3368 */
Kojto 90:cb3d968589d8 3369
Kojto 90:cb3d968589d8 3370 /** @defgroup RCCEx_TIMx_Clock_Config RCC Extended TIMx Clock Config
Kojto 90:cb3d968589d8 3371 * @{
Kojto 90:cb3d968589d8 3372 */
Kojto 90:cb3d968589d8 3373
Kojto 90:cb3d968589d8 3374 /** @brief Macro to configure the TIM8 clock (TIM8CLK).
Kojto 122:f9eeca106725 3375 * @param __TIM8CLKSource__ specifies the TIM8 clock source.
Kojto 90:cb3d968589d8 3376 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3377 * @arg @ref RCC_TIM8CLK_HCLK HCLK selected as TIM8 clock
Kojto 122:f9eeca106725 3378 * @arg @ref RCC_TIM8CLK_PLLCLK PLL Clock selected as TIM8 clock
Kojto 90:cb3d968589d8 3379 */
Kojto 90:cb3d968589d8 3380 #define __HAL_RCC_TIM8_CONFIG(__TIM8CLKSource__) \
Kojto 90:cb3d968589d8 3381 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_TIM8SW, (uint32_t)(__TIM8CLKSource__))
Kojto 90:cb3d968589d8 3382
Kojto 90:cb3d968589d8 3383 /** @brief Macro to get the TIM8 clock (TIM8CLK).
Kojto 90:cb3d968589d8 3384 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3385 * @arg @ref RCC_TIM8CLK_HCLK HCLK selected as TIM8 clock
Kojto 122:f9eeca106725 3386 * @arg @ref RCC_TIM8CLK_PLLCLK PLL Clock selected as TIM8 clock
Kojto 90:cb3d968589d8 3387 */
Kojto 90:cb3d968589d8 3388 #define __HAL_RCC_GET_TIM8_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_TIM8SW)))
Kojto 90:cb3d968589d8 3389
Kojto 90:cb3d968589d8 3390 /**
Kojto 90:cb3d968589d8 3391 * @}
Kojto 90:cb3d968589d8 3392 */
Kojto 90:cb3d968589d8 3393 #endif /* STM32F303xE || STM32F398xx || */
Kojto 90:cb3d968589d8 3394 /* STM32F303xC || STM32F358xx */
Kojto 90:cb3d968589d8 3395
Kojto 90:cb3d968589d8 3396 #if defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx)
Kojto 90:cb3d968589d8 3397 /** @defgroup RCCEx_ADCx_Clock_Config RCC Extended ADCx Clock Config
Kojto 90:cb3d968589d8 3398 * @{
Kojto 90:cb3d968589d8 3399 */
Kojto 90:cb3d968589d8 3400
Kojto 90:cb3d968589d8 3401 /** @brief Macro to configure the ADC1 & ADC2 clock (ADC12CLK).
Kojto 122:f9eeca106725 3402 * @param __ADC12CLKSource__ specifies the ADC1 & ADC2 clock source.
Kojto 90:cb3d968589d8 3403 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3404 * @arg @ref RCC_ADC12PLLCLK_OFF ADC1 & ADC2 PLL clock disabled, ADC1 & ADC2 can use AHB clock
Kojto 122:f9eeca106725 3405 * @arg @ref RCC_ADC12PLLCLK_DIV1 PLL clock divided by 1 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3406 * @arg @ref RCC_ADC12PLLCLK_DIV2 PLL clock divided by 2 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3407 * @arg @ref RCC_ADC12PLLCLK_DIV4 PLL clock divided by 4 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3408 * @arg @ref RCC_ADC12PLLCLK_DIV6 PLL clock divided by 6 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3409 * @arg @ref RCC_ADC12PLLCLK_DIV8 PLL clock divided by 8 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3410 * @arg @ref RCC_ADC12PLLCLK_DIV10 PLL clock divided by 10 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3411 * @arg @ref RCC_ADC12PLLCLK_DIV12 PLL clock divided by 12 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3412 * @arg @ref RCC_ADC12PLLCLK_DIV16 PLL clock divided by 16 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3413 * @arg @ref RCC_ADC12PLLCLK_DIV32 PLL clock divided by 32 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3414 * @arg @ref RCC_ADC12PLLCLK_DIV64 PLL clock divided by 64 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3415 * @arg @ref RCC_ADC12PLLCLK_DIV128 PLL clock divided by 128 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3416 * @arg @ref RCC_ADC12PLLCLK_DIV256 PLL clock divided by 256 selected as ADC1 & ADC2 clock
Kojto 90:cb3d968589d8 3417 */
Kojto 90:cb3d968589d8 3418 #define __HAL_RCC_ADC12_CONFIG(__ADC12CLKSource__) \
Kojto 90:cb3d968589d8 3419 MODIFY_REG(RCC->CFGR2, RCC_CFGR2_ADCPRE12, (uint32_t)(__ADC12CLKSource__))
Kojto 90:cb3d968589d8 3420
Kojto 90:cb3d968589d8 3421 /** @brief Macro to get the ADC1 & ADC2 clock
Kojto 90:cb3d968589d8 3422 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3423 * @arg @ref RCC_ADC12PLLCLK_OFF ADC1 & ADC2 PLL clock disabled, ADC1 & ADC2 can use AHB clock
Kojto 122:f9eeca106725 3424 * @arg @ref RCC_ADC12PLLCLK_DIV1 PLL clock divided by 1 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3425 * @arg @ref RCC_ADC12PLLCLK_DIV2 PLL clock divided by 2 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3426 * @arg @ref RCC_ADC12PLLCLK_DIV4 PLL clock divided by 4 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3427 * @arg @ref RCC_ADC12PLLCLK_DIV6 PLL clock divided by 6 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3428 * @arg @ref RCC_ADC12PLLCLK_DIV8 PLL clock divided by 8 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3429 * @arg @ref RCC_ADC12PLLCLK_DIV10 PLL clock divided by 10 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3430 * @arg @ref RCC_ADC12PLLCLK_DIV12 PLL clock divided by 12 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3431 * @arg @ref RCC_ADC12PLLCLK_DIV16 PLL clock divided by 16 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3432 * @arg @ref RCC_ADC12PLLCLK_DIV32 PLL clock divided by 32 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3433 * @arg @ref RCC_ADC12PLLCLK_DIV64 PLL clock divided by 64 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3434 * @arg @ref RCC_ADC12PLLCLK_DIV128 PLL clock divided by 128 selected as ADC1 & ADC2 clock
Kojto 122:f9eeca106725 3435 * @arg @ref RCC_ADC12PLLCLK_DIV256 PLL clock divided by 256 selected as ADC1 & ADC2 clock
Kojto 90:cb3d968589d8 3436 */
Kojto 90:cb3d968589d8 3437 #define __HAL_RCC_GET_ADC12_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR2, RCC_CFGR2_ADCPRE12)))
Kojto 90:cb3d968589d8 3438 /**
Kojto 90:cb3d968589d8 3439 * @}
Kojto 90:cb3d968589d8 3440 */
Kojto 90:cb3d968589d8 3441
Kojto 90:cb3d968589d8 3442 /** @defgroup RCCEx_TIMx_Clock_Config RCC Extended TIMx Clock Config
Kojto 90:cb3d968589d8 3443 * @{
Kojto 90:cb3d968589d8 3444 */
Kojto 90:cb3d968589d8 3445 /** @brief Macro to configure the TIM1 clock (TIM1CLK).
Kojto 122:f9eeca106725 3446 * @param __TIM1CLKSource__ specifies the TIM1 clock source.
Kojto 90:cb3d968589d8 3447 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3448 * @arg @ref RCC_TIM1CLK_HCLK HCLK selected as TIM1 clock
Kojto 122:f9eeca106725 3449 * @arg @ref RCC_TIM1CLK_PLLCLK PLL Clock selected as TIM1 clock
Kojto 90:cb3d968589d8 3450 */
Kojto 90:cb3d968589d8 3451 #define __HAL_RCC_TIM1_CONFIG(__TIM1CLKSource__) \
Kojto 90:cb3d968589d8 3452 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_TIM1SW, (uint32_t)(__TIM1CLKSource__))
Kojto 90:cb3d968589d8 3453
Kojto 90:cb3d968589d8 3454 /** @brief Macro to get the TIM1 clock (TIM1CLK).
Kojto 90:cb3d968589d8 3455 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3456 * @arg @ref RCC_TIM1CLK_HCLK HCLK selected as TIM1 clock
Kojto 122:f9eeca106725 3457 * @arg @ref RCC_TIM1CLK_PLLCLK PLL Clock selected as TIM1 clock
Kojto 90:cb3d968589d8 3458 */
Kojto 90:cb3d968589d8 3459 #define __HAL_RCC_GET_TIM1_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_TIM1SW)))
Kojto 90:cb3d968589d8 3460 /**
Kojto 90:cb3d968589d8 3461 * @}
Kojto 90:cb3d968589d8 3462 */
Kojto 90:cb3d968589d8 3463 #endif /* STM32F303x8 || STM32F334x8 || STM32F328xx */
Kojto 90:cb3d968589d8 3464
Kojto 90:cb3d968589d8 3465 #if defined(STM32F334x8)
Kojto 90:cb3d968589d8 3466 /** @defgroup RCCEx_HRTIMx_Clock_Config RCC Extended HRTIMx Clock Config
Kojto 90:cb3d968589d8 3467 * @{
Kojto 90:cb3d968589d8 3468 */
Kojto 90:cb3d968589d8 3469 /** @brief Macro to configure the HRTIM1 clock.
Kojto 122:f9eeca106725 3470 * @param __HRTIM1CLKSource__ specifies the HRTIM1 clock source.
Kojto 90:cb3d968589d8 3471 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3472 * @arg @ref RCC_HRTIM1CLK_HCLK HCLK selected as HRTIM1 clock
Kojto 122:f9eeca106725 3473 * @arg @ref RCC_HRTIM1CLK_PLLCLK PLL Clock selected as HRTIM1 clock
Kojto 90:cb3d968589d8 3474 */
Kojto 90:cb3d968589d8 3475 #define __HAL_RCC_HRTIM1_CONFIG(__HRTIM1CLKSource__) \
Kojto 90:cb3d968589d8 3476 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_HRTIM1SW, (uint32_t)(__HRTIM1CLKSource__))
Kojto 90:cb3d968589d8 3477
Kojto 90:cb3d968589d8 3478 /** @brief Macro to get the HRTIM1 clock source.
Kojto 90:cb3d968589d8 3479 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3480 * @arg @ref RCC_HRTIM1CLK_HCLK HCLK selected as HRTIM1 clock
Kojto 122:f9eeca106725 3481 * @arg @ref RCC_HRTIM1CLK_PLLCLK PLL Clock selected as HRTIM1 clock
Kojto 90:cb3d968589d8 3482 */
Kojto 90:cb3d968589d8 3483 #define __HAL_RCC_GET_HRTIM1_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_HRTIM1SW)))
Kojto 90:cb3d968589d8 3484 /**
Kojto 90:cb3d968589d8 3485 * @}
Kojto 90:cb3d968589d8 3486 */
Kojto 90:cb3d968589d8 3487 #endif /* STM32F334x8 */
Kojto 90:cb3d968589d8 3488
Kojto 90:cb3d968589d8 3489 #if defined(STM32F373xC) || defined(STM32F378xx)
Kojto 90:cb3d968589d8 3490 /** @defgroup RCCEx_I2Cx_Clock_Config RCC Extended I2Cx Clock Config
Kojto 90:cb3d968589d8 3491 * @{
Kojto 90:cb3d968589d8 3492 */
Kojto 90:cb3d968589d8 3493 /** @brief Macro to configure the I2C2 clock (I2C2CLK).
Kojto 122:f9eeca106725 3494 * @param __I2C2CLKSource__ specifies the I2C2 clock source.
Kojto 90:cb3d968589d8 3495 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3496 * @arg @ref RCC_I2C2CLKSOURCE_HSI HSI selected as I2C2 clock
Kojto 122:f9eeca106725 3497 * @arg @ref RCC_I2C2CLKSOURCE_SYSCLK System Clock selected as I2C2 clock
Kojto 90:cb3d968589d8 3498 */
Kojto 90:cb3d968589d8 3499 #define __HAL_RCC_I2C2_CONFIG(__I2C2CLKSource__) \
Kojto 90:cb3d968589d8 3500 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_I2C2SW, (uint32_t)(__I2C2CLKSource__))
Kojto 90:cb3d968589d8 3501
Kojto 90:cb3d968589d8 3502 /** @brief Macro to get the I2C2 clock source.
Kojto 90:cb3d968589d8 3503 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3504 * @arg @ref RCC_I2C2CLKSOURCE_HSI HSI selected as I2C2 clock
Kojto 122:f9eeca106725 3505 * @arg @ref RCC_I2C2CLKSOURCE_SYSCLK System Clock selected as I2C2 clock
Kojto 90:cb3d968589d8 3506 */
Kojto 90:cb3d968589d8 3507 #define __HAL_RCC_GET_I2C2_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_I2C2SW)))
Kojto 90:cb3d968589d8 3508 /**
Kojto 90:cb3d968589d8 3509 * @}
Kojto 90:cb3d968589d8 3510 */
Kojto 90:cb3d968589d8 3511
Kojto 90:cb3d968589d8 3512 /** @defgroup RCCEx_ADCx_Clock_Config RCC Extended ADCx Clock Config
Kojto 90:cb3d968589d8 3513 * @{
Kojto 90:cb3d968589d8 3514 */
Kojto 90:cb3d968589d8 3515 /** @brief Macro to configure the ADC1 clock (ADC1CLK).
Kojto 122:f9eeca106725 3516 * @param __ADC1CLKSource__ specifies the ADC1 clock source.
Kojto 90:cb3d968589d8 3517 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3518 * @arg @ref RCC_ADC1PCLK2_DIV2 PCLK2 clock divided by 2 selected as ADC1 clock
Kojto 122:f9eeca106725 3519 * @arg @ref RCC_ADC1PCLK2_DIV4 PCLK2 clock divided by 4 selected as ADC1 clock
Kojto 122:f9eeca106725 3520 * @arg @ref RCC_ADC1PCLK2_DIV6 PCLK2 clock divided by 6 selected as ADC1 clock
Kojto 122:f9eeca106725 3521 * @arg @ref RCC_ADC1PCLK2_DIV8 PCLK2 clock divided by 8 selected as ADC1 clock
Kojto 90:cb3d968589d8 3522 */
Kojto 90:cb3d968589d8 3523 #define __HAL_RCC_ADC1_CONFIG(__ADC1CLKSource__) \
Kojto 90:cb3d968589d8 3524 MODIFY_REG(RCC->CFGR, RCC_CFGR_ADCPRE, (uint32_t)(__ADC1CLKSource__))
Kojto 90:cb3d968589d8 3525
Kojto 90:cb3d968589d8 3526 /** @brief Macro to get the ADC1 clock (ADC1CLK).
Kojto 90:cb3d968589d8 3527 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3528 * @arg @ref RCC_ADC1PCLK2_DIV2 PCLK2 clock divided by 2 selected as ADC1 clock
Kojto 122:f9eeca106725 3529 * @arg @ref RCC_ADC1PCLK2_DIV4 PCLK2 clock divided by 4 selected as ADC1 clock
Kojto 122:f9eeca106725 3530 * @arg @ref RCC_ADC1PCLK2_DIV6 PCLK2 clock divided by 6 selected as ADC1 clock
Kojto 122:f9eeca106725 3531 * @arg @ref RCC_ADC1PCLK2_DIV8 PCLK2 clock divided by 8 selected as ADC1 clock
Kojto 90:cb3d968589d8 3532 */
Kojto 90:cb3d968589d8 3533 #define __HAL_RCC_GET_ADC1_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR, RCC_CFGR_ADCPRE)))
Kojto 90:cb3d968589d8 3534 /**
Kojto 90:cb3d968589d8 3535 * @}
Kojto 90:cb3d968589d8 3536 */
Kojto 90:cb3d968589d8 3537
Kojto 90:cb3d968589d8 3538 /** @defgroup RCCEx_SDADCx_Clock_Config RCC Extended SDADCx Clock Config
Kojto 90:cb3d968589d8 3539 * @{
Kojto 90:cb3d968589d8 3540 */
Kojto 90:cb3d968589d8 3541 /** @brief Macro to configure the SDADCx clock (SDADCxCLK).
Kojto 122:f9eeca106725 3542 * @param __SDADCPrescaler__ specifies the SDADCx system clock prescaler.
Kojto 90:cb3d968589d8 3543 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3544 * @arg @ref RCC_SDADCSYSCLK_DIV1 SYSCLK clock selected as SDADCx clock
Kojto 122:f9eeca106725 3545 * @arg @ref RCC_SDADCSYSCLK_DIV2 SYSCLK clock divided by 2 selected as SDADCx clock
Kojto 122:f9eeca106725 3546 * @arg @ref RCC_SDADCSYSCLK_DIV4 SYSCLK clock divided by 4 selected as SDADCx clock
Kojto 122:f9eeca106725 3547 * @arg @ref RCC_SDADCSYSCLK_DIV6 SYSCLK clock divided by 6 selected as SDADCx clock
Kojto 122:f9eeca106725 3548 * @arg @ref RCC_SDADCSYSCLK_DIV8 SYSCLK clock divided by 8 selected as SDADCx clock
Kojto 122:f9eeca106725 3549 * @arg @ref RCC_SDADCSYSCLK_DIV10 SYSCLK clock divided by 10 selected as SDADCx clock
Kojto 122:f9eeca106725 3550 * @arg @ref RCC_SDADCSYSCLK_DIV12 SYSCLK clock divided by 12 selected as SDADCx clock
Kojto 122:f9eeca106725 3551 * @arg @ref RCC_SDADCSYSCLK_DIV14 SYSCLK clock divided by 14 selected as SDADCx clock
Kojto 122:f9eeca106725 3552 * @arg @ref RCC_SDADCSYSCLK_DIV16 SYSCLK clock divided by 16 selected as SDADCx clock
Kojto 122:f9eeca106725 3553 * @arg @ref RCC_SDADCSYSCLK_DIV20 SYSCLK clock divided by 20 selected as SDADCx clock
Kojto 122:f9eeca106725 3554 * @arg @ref RCC_SDADCSYSCLK_DIV24 SYSCLK clock divided by 24 selected as SDADCx clock
Kojto 122:f9eeca106725 3555 * @arg @ref RCC_SDADCSYSCLK_DIV28 SYSCLK clock divided by 28 selected as SDADCx clock
Kojto 122:f9eeca106725 3556 * @arg @ref RCC_SDADCSYSCLK_DIV32 SYSCLK clock divided by 32 selected as SDADCx clock
Kojto 122:f9eeca106725 3557 * @arg @ref RCC_SDADCSYSCLK_DIV36 SYSCLK clock divided by 36 selected as SDADCx clock
Kojto 122:f9eeca106725 3558 * @arg @ref RCC_SDADCSYSCLK_DIV40 SYSCLK clock divided by 40 selected as SDADCx clock
Kojto 122:f9eeca106725 3559 * @arg @ref RCC_SDADCSYSCLK_DIV44 SYSCLK clock divided by 44 selected as SDADCx clock
Kojto 122:f9eeca106725 3560 * @arg @ref RCC_SDADCSYSCLK_DIV48 SYSCLK clock divided by 48 selected as SDADCx clock
Kojto 90:cb3d968589d8 3561 */
Kojto 90:cb3d968589d8 3562 #define __HAL_RCC_SDADC_CONFIG(__SDADCPrescaler__) \
Kojto 90:cb3d968589d8 3563 MODIFY_REG(RCC->CFGR, RCC_CFGR_SDADCPRE, (uint32_t)(__SDADCPrescaler__))
Kojto 90:cb3d968589d8 3564
Kojto 90:cb3d968589d8 3565 /** @brief Macro to get the SDADCx clock prescaler.
Kojto 90:cb3d968589d8 3566 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3567 * @arg @ref RCC_SDADCSYSCLK_DIV1 SYSCLK clock selected as SDADCx clock
Kojto 122:f9eeca106725 3568 * @arg @ref RCC_SDADCSYSCLK_DIV2 SYSCLK clock divided by 2 selected as SDADCx clock
Kojto 122:f9eeca106725 3569 * @arg @ref RCC_SDADCSYSCLK_DIV4 SYSCLK clock divided by 4 selected as SDADCx clock
Kojto 122:f9eeca106725 3570 * @arg @ref RCC_SDADCSYSCLK_DIV6 SYSCLK clock divided by 6 selected as SDADCx clock
Kojto 122:f9eeca106725 3571 * @arg @ref RCC_SDADCSYSCLK_DIV8 SYSCLK clock divided by 8 selected as SDADCx clock
Kojto 122:f9eeca106725 3572 * @arg @ref RCC_SDADCSYSCLK_DIV10 SYSCLK clock divided by 10 selected as SDADCx clock
Kojto 122:f9eeca106725 3573 * @arg @ref RCC_SDADCSYSCLK_DIV12 SYSCLK clock divided by 12 selected as SDADCx clock
Kojto 122:f9eeca106725 3574 * @arg @ref RCC_SDADCSYSCLK_DIV14 SYSCLK clock divided by 14 selected as SDADCx clock
Kojto 122:f9eeca106725 3575 * @arg @ref RCC_SDADCSYSCLK_DIV16 SYSCLK clock divided by 16 selected as SDADCx clock
Kojto 122:f9eeca106725 3576 * @arg @ref RCC_SDADCSYSCLK_DIV20 SYSCLK clock divided by 20 selected as SDADCx clock
Kojto 122:f9eeca106725 3577 * @arg @ref RCC_SDADCSYSCLK_DIV24 SYSCLK clock divided by 24 selected as SDADCx clock
Kojto 122:f9eeca106725 3578 * @arg @ref RCC_SDADCSYSCLK_DIV28 SYSCLK clock divided by 28 selected as SDADCx clock
Kojto 122:f9eeca106725 3579 * @arg @ref RCC_SDADCSYSCLK_DIV32 SYSCLK clock divided by 32 selected as SDADCx clock
Kojto 122:f9eeca106725 3580 * @arg @ref RCC_SDADCSYSCLK_DIV36 SYSCLK clock divided by 36 selected as SDADCx clock
Kojto 122:f9eeca106725 3581 * @arg @ref RCC_SDADCSYSCLK_DIV40 SYSCLK clock divided by 40 selected as SDADCx clock
Kojto 122:f9eeca106725 3582 * @arg @ref RCC_SDADCSYSCLK_DIV44 SYSCLK clock divided by 44 selected as SDADCx clock
Kojto 122:f9eeca106725 3583 * @arg @ref RCC_SDADCSYSCLK_DIV48 SYSCLK clock divided by 48 selected as SDADCx clock
Kojto 90:cb3d968589d8 3584 */
Kojto 90:cb3d968589d8 3585 #define __HAL_RCC_GET_SDADC_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR, RCC_CFGR_SDADCPRE)))
Kojto 90:cb3d968589d8 3586 /**
Kojto 90:cb3d968589d8 3587 * @}
Kojto 90:cb3d968589d8 3588 */
Kojto 90:cb3d968589d8 3589
Kojto 90:cb3d968589d8 3590 /** @defgroup RCCEx_CECx_Clock_Config RCC Extended CECx Clock Config
Kojto 90:cb3d968589d8 3591 * @{
Kojto 90:cb3d968589d8 3592 */
Kojto 90:cb3d968589d8 3593 /** @brief Macro to configure the CEC clock.
Kojto 122:f9eeca106725 3594 * @param __CECCLKSource__ specifies the CEC clock source.
Kojto 90:cb3d968589d8 3595 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3596 * @arg @ref RCC_CECCLKSOURCE_HSI HSI selected as CEC clock
Kojto 122:f9eeca106725 3597 * @arg @ref RCC_CECCLKSOURCE_LSE LSE selected as CEC clock
Kojto 90:cb3d968589d8 3598 */
Kojto 90:cb3d968589d8 3599 #define __HAL_RCC_CEC_CONFIG(__CECCLKSource__) \
Kojto 90:cb3d968589d8 3600 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_CECSW, (uint32_t)(__CECCLKSource__))
Kojto 90:cb3d968589d8 3601
Kojto 90:cb3d968589d8 3602 /** @brief Macro to get the HDMI CEC clock source.
Kojto 90:cb3d968589d8 3603 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3604 * @arg @ref RCC_CECCLKSOURCE_HSI HSI selected as CEC clock
Kojto 122:f9eeca106725 3605 * @arg @ref RCC_CECCLKSOURCE_LSE LSE selected as CEC clock
Kojto 90:cb3d968589d8 3606 */
Kojto 90:cb3d968589d8 3607 #define __HAL_RCC_GET_CEC_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_CECSW)))
Kojto 90:cb3d968589d8 3608 /**
Kojto 90:cb3d968589d8 3609 * @}
Kojto 90:cb3d968589d8 3610 */
Kojto 90:cb3d968589d8 3611
Kojto 90:cb3d968589d8 3612 #endif /* STM32F373xC || STM32F378xx */
Kojto 90:cb3d968589d8 3613
Kojto 122:f9eeca106725 3614 #if defined(STM32F302xE) || defined(STM32F303xE)\
Kojto 122:f9eeca106725 3615 || defined(STM32F302xC) || defined(STM32F303xC)\
Kojto 122:f9eeca106725 3616 || defined(STM32F302x8) \
Kojto 122:f9eeca106725 3617 || defined(STM32F373xC)
Kojto 90:cb3d968589d8 3618
Kojto 90:cb3d968589d8 3619 /** @defgroup RCCEx_USBx_Clock_Config RCC Extended USBx Clock Config
Kojto 90:cb3d968589d8 3620 * @{
Kojto 90:cb3d968589d8 3621 */
Kojto 90:cb3d968589d8 3622 /** @brief Macro to configure the USB clock (USBCLK).
Kojto 122:f9eeca106725 3623 * @param __USBCLKSource__ specifies the USB clock source.
Kojto 90:cb3d968589d8 3624 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3625 * @arg @ref RCC_USBCLKSOURCE_PLL PLL Clock divided by 1 selected as USB clock
Kojto 122:f9eeca106725 3626 * @arg @ref RCC_USBCLKSOURCE_PLL_DIV1_5 PLL Clock divided by 1.5 selected as USB clock
Kojto 90:cb3d968589d8 3627 */
Kojto 90:cb3d968589d8 3628 #define __HAL_RCC_USB_CONFIG(__USBCLKSource__) \
Kojto 90:cb3d968589d8 3629 MODIFY_REG(RCC->CFGR, RCC_CFGR_USBPRE, (uint32_t)(__USBCLKSource__))
Kojto 90:cb3d968589d8 3630
Kojto 90:cb3d968589d8 3631 /** @brief Macro to get the USB clock source.
Kojto 90:cb3d968589d8 3632 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3633 * @arg @ref RCC_USBCLKSOURCE_PLL PLL Clock divided by 1 selected as USB clock
Kojto 122:f9eeca106725 3634 * @arg @ref RCC_USBCLKSOURCE_PLL_DIV1_5 PLL Clock divided by 1.5 selected as USB clock
Kojto 90:cb3d968589d8 3635 */
Kojto 90:cb3d968589d8 3636 #define __HAL_RCC_GET_USB_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR, RCC_CFGR_USBPRE)))
Kojto 90:cb3d968589d8 3637 /**
Kojto 90:cb3d968589d8 3638 * @}
Kojto 90:cb3d968589d8 3639 */
Kojto 90:cb3d968589d8 3640
Kojto 90:cb3d968589d8 3641 #endif /* STM32F302xE || STM32F303xE || */
Kojto 90:cb3d968589d8 3642 /* STM32F302xC || STM32F303xC || */
Kojto 90:cb3d968589d8 3643 /* STM32F302x8 || */
Kojto 90:cb3d968589d8 3644 /* STM32F373xC */
Kojto 90:cb3d968589d8 3645
Kojto 90:cb3d968589d8 3646 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
Kojto 90:cb3d968589d8 3647
Kojto 90:cb3d968589d8 3648 /** @defgroup RCCEx_I2Cx_Clock_Config RCC Extended I2Cx Clock Config
Kojto 90:cb3d968589d8 3649 * @{
Kojto 90:cb3d968589d8 3650 */
Kojto 90:cb3d968589d8 3651 /** @brief Macro to configure the I2C3 clock (I2C3CLK).
Kojto 122:f9eeca106725 3652 * @param __I2C3CLKSource__ specifies the I2C3 clock source.
Kojto 90:cb3d968589d8 3653 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3654 * @arg @ref RCC_I2C3CLKSOURCE_HSI HSI selected as I2C3 clock
Kojto 122:f9eeca106725 3655 * @arg @ref RCC_I2C3CLKSOURCE_SYSCLK System Clock selected as I2C3 clock
Kojto 90:cb3d968589d8 3656 */
Kojto 90:cb3d968589d8 3657 #define __HAL_RCC_I2C3_CONFIG(__I2C3CLKSource__) \
Kojto 90:cb3d968589d8 3658 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_I2C3SW, (uint32_t)(__I2C3CLKSource__))
Kojto 90:cb3d968589d8 3659
Kojto 90:cb3d968589d8 3660 /** @brief Macro to get the I2C3 clock source.
Kojto 90:cb3d968589d8 3661 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3662 * @arg @ref RCC_I2C3CLKSOURCE_HSI HSI selected as I2C3 clock
Kojto 122:f9eeca106725 3663 * @arg @ref RCC_I2C3CLKSOURCE_SYSCLK System Clock selected as I2C3 clock
Kojto 90:cb3d968589d8 3664 */
Kojto 90:cb3d968589d8 3665 #define __HAL_RCC_GET_I2C3_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_I2C3SW)))
Kojto 90:cb3d968589d8 3666 /**
Kojto 90:cb3d968589d8 3667 * @}
Kojto 90:cb3d968589d8 3668 */
Kojto 90:cb3d968589d8 3669
Kojto 90:cb3d968589d8 3670 /** @defgroup RCCEx_TIMx_Clock_Config RCC Extended TIMx Clock Config
Kojto 90:cb3d968589d8 3671 * @{
Kojto 90:cb3d968589d8 3672 */
Kojto 90:cb3d968589d8 3673 /** @brief Macro to configure the TIM2 clock (TIM2CLK).
Kojto 122:f9eeca106725 3674 * @param __TIM2CLKSource__ specifies the TIM2 clock source.
Kojto 90:cb3d968589d8 3675 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3676 * @arg @ref RCC_TIM2CLK_HCLK HCLK selected as TIM2 clock
Kojto 122:f9eeca106725 3677 * @arg @ref RCC_TIM2CLK_PLL PLL Clock selected as TIM2 clock
Kojto 90:cb3d968589d8 3678 */
Kojto 90:cb3d968589d8 3679 #define __HAL_RCC_TIM2_CONFIG(__TIM2CLKSource__) \
Kojto 90:cb3d968589d8 3680 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_TIM2SW, (uint32_t)(__TIM2CLKSource__))
Kojto 90:cb3d968589d8 3681
Kojto 90:cb3d968589d8 3682 /** @brief Macro to get the TIM2 clock (TIM2CLK).
Kojto 90:cb3d968589d8 3683 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3684 * @arg @ref RCC_TIM2CLK_HCLK HCLK selected as TIM2 clock
Kojto 122:f9eeca106725 3685 * @arg @ref RCC_TIM2CLK_PLL PLL Clock selected as TIM2 clock
Kojto 90:cb3d968589d8 3686 */
Kojto 90:cb3d968589d8 3687 #define __HAL_RCC_GET_TIM2_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_TIM2SW)))
Kojto 90:cb3d968589d8 3688
Kojto 90:cb3d968589d8 3689 /** @brief Macro to configure the TIM3 & TIM4 clock (TIM34CLK).
Kojto 122:f9eeca106725 3690 * @param __TIM34CLKSource__ specifies the TIM3 & TIM4 clock source.
Kojto 90:cb3d968589d8 3691 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3692 * @arg @ref RCC_TIM34CLK_HCLK HCLK selected as TIM3 & TIM4 clock
Kojto 122:f9eeca106725 3693 * @arg @ref RCC_TIM34CLK_PLL PLL Clock selected as TIM3 & TIM4 clock
Kojto 90:cb3d968589d8 3694 */
Kojto 90:cb3d968589d8 3695 #define __HAL_RCC_TIM34_CONFIG(__TIM34CLKSource__) \
Kojto 90:cb3d968589d8 3696 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_TIM34SW, (uint32_t)(__TIM34CLKSource__))
Kojto 90:cb3d968589d8 3697
Kojto 90:cb3d968589d8 3698 /** @brief Macro to get the TIM3 & TIM4 clock (TIM34CLK).
Kojto 90:cb3d968589d8 3699 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3700 * @arg @ref RCC_TIM34CLK_HCLK HCLK selected as TIM3 & TIM4 clock
Kojto 122:f9eeca106725 3701 * @arg @ref RCC_TIM34CLK_PLL PLL Clock selected as TIM3 & TIM4 clock
Kojto 90:cb3d968589d8 3702 */
Kojto 90:cb3d968589d8 3703 #define __HAL_RCC_GET_TIM34_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_TIM34SW)))
Kojto 90:cb3d968589d8 3704
Kojto 90:cb3d968589d8 3705 /** @brief Macro to configure the TIM15 clock (TIM15CLK).
Kojto 122:f9eeca106725 3706 * @param __TIM15CLKSource__ specifies the TIM15 clock source.
Kojto 90:cb3d968589d8 3707 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3708 * @arg @ref RCC_TIM15CLK_HCLK HCLK selected as TIM15 clock
Kojto 122:f9eeca106725 3709 * @arg @ref RCC_TIM15CLK_PLL PLL Clock selected as TIM15 clock
Kojto 90:cb3d968589d8 3710 */
Kojto 90:cb3d968589d8 3711 #define __HAL_RCC_TIM15_CONFIG(__TIM15CLKSource__) \
Kojto 90:cb3d968589d8 3712 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_TIM15SW, (uint32_t)(__TIM15CLKSource__))
Kojto 90:cb3d968589d8 3713
Kojto 90:cb3d968589d8 3714 /** @brief Macro to get the TIM15 clock (TIM15CLK).
Kojto 90:cb3d968589d8 3715 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3716 * @arg @ref RCC_TIM15CLK_HCLK HCLK selected as TIM15 clock
Kojto 122:f9eeca106725 3717 * @arg @ref RCC_TIM15CLK_PLL PLL Clock selected as TIM15 clock
Kojto 90:cb3d968589d8 3718 */
Kojto 90:cb3d968589d8 3719 #define __HAL_RCC_GET_TIM15_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_TIM15SW)))
Kojto 90:cb3d968589d8 3720
Kojto 90:cb3d968589d8 3721 /** @brief Macro to configure the TIM16 clock (TIM16CLK).
Kojto 122:f9eeca106725 3722 * @param __TIM16CLKSource__ specifies the TIM16 clock source.
Kojto 90:cb3d968589d8 3723 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3724 * @arg @ref RCC_TIM16CLK_HCLK HCLK selected as TIM16 clock
Kojto 122:f9eeca106725 3725 * @arg @ref RCC_TIM16CLK_PLL PLL Clock selected as TIM16 clock
Kojto 90:cb3d968589d8 3726 */
Kojto 90:cb3d968589d8 3727 #define __HAL_RCC_TIM16_CONFIG(__TIM16CLKSource__) \
Kojto 90:cb3d968589d8 3728 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_TIM16SW, (uint32_t)(__TIM16CLKSource__))
Kojto 90:cb3d968589d8 3729
Kojto 90:cb3d968589d8 3730 /** @brief Macro to get the TIM16 clock (TIM16CLK).
Kojto 90:cb3d968589d8 3731 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3732 * @arg @ref RCC_TIM16CLK_HCLK HCLK selected as TIM16 clock
Kojto 122:f9eeca106725 3733 * @arg @ref RCC_TIM16CLK_PLL PLL Clock selected as TIM16 clock
Kojto 90:cb3d968589d8 3734 */
Kojto 90:cb3d968589d8 3735 #define __HAL_RCC_GET_TIM16_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_TIM16SW)))
Kojto 90:cb3d968589d8 3736
Kojto 90:cb3d968589d8 3737 /** @brief Macro to configure the TIM17 clock (TIM17CLK).
Kojto 122:f9eeca106725 3738 * @param __TIM17CLKSource__ specifies the TIM17 clock source.
Kojto 90:cb3d968589d8 3739 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3740 * @arg @ref RCC_TIM17CLK_HCLK HCLK selected as TIM17 clock
Kojto 122:f9eeca106725 3741 * @arg @ref RCC_TIM17CLK_PLL PLL Clock selected as TIM17 clock
Kojto 90:cb3d968589d8 3742 */
Kojto 90:cb3d968589d8 3743 #define __HAL_RCC_TIM17_CONFIG(__TIM17CLKSource__) \
Kojto 90:cb3d968589d8 3744 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_TIM17SW, (uint32_t)(__TIM17CLKSource__))
Kojto 90:cb3d968589d8 3745
Kojto 90:cb3d968589d8 3746 /** @brief Macro to get the TIM17 clock (TIM17CLK).
Kojto 90:cb3d968589d8 3747 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3748 * @arg @ref RCC_TIM17CLK_HCLK HCLK selected as TIM17 clock
Kojto 122:f9eeca106725 3749 * @arg @ref RCC_TIM17CLK_PLL PLL Clock selected as TIM17 clock
Kojto 90:cb3d968589d8 3750 */
Kojto 90:cb3d968589d8 3751 #define __HAL_RCC_GET_TIM17_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_TIM17SW)))
Kojto 90:cb3d968589d8 3752
Kojto 90:cb3d968589d8 3753 /**
Kojto 90:cb3d968589d8 3754 * @}
Kojto 90:cb3d968589d8 3755 */
Kojto 90:cb3d968589d8 3756
Kojto 90:cb3d968589d8 3757 #endif /* STM32f302xE || STM32f303xE || STM32F398xx */
Kojto 90:cb3d968589d8 3758
Kojto 90:cb3d968589d8 3759 #if defined(STM32F303xE) || defined(STM32F398xx)
Kojto 90:cb3d968589d8 3760 /** @addtogroup RCCEx_TIMx_Clock_Config RCC Extended TIMx Clock Config
Kojto 90:cb3d968589d8 3761 * @{
Kojto 90:cb3d968589d8 3762 */
Kojto 90:cb3d968589d8 3763 /** @brief Macro to configure the TIM20 clock (TIM20CLK).
Kojto 122:f9eeca106725 3764 * @param __TIM20CLKSource__ specifies the TIM20 clock source.
Kojto 90:cb3d968589d8 3765 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3766 * @arg @ref RCC_TIM20CLK_HCLK HCLK selected as TIM20 clock
Kojto 122:f9eeca106725 3767 * @arg @ref RCC_TIM20CLK_PLL PLL Clock selected as TIM20 clock
Kojto 90:cb3d968589d8 3768 */
Kojto 90:cb3d968589d8 3769 #define __HAL_RCC_TIM20_CONFIG(__TIM20CLKSource__) \
Kojto 90:cb3d968589d8 3770 MODIFY_REG(RCC->CFGR3, RCC_CFGR3_TIM20SW, (uint32_t)(__TIM20CLKSource__))
Kojto 90:cb3d968589d8 3771
Kojto 90:cb3d968589d8 3772 /** @brief Macro to get the TIM20 clock (TIM20CLK).
Kojto 90:cb3d968589d8 3773 * @retval The clock source can be one of the following values:
Kojto 122:f9eeca106725 3774 * @arg @ref RCC_TIM20CLK_HCLK HCLK selected as TIM20 clock
Kojto 122:f9eeca106725 3775 * @arg @ref RCC_TIM20CLK_PLL PLL Clock selected as TIM20 clock
Kojto 90:cb3d968589d8 3776 */
Kojto 90:cb3d968589d8 3777 #define __HAL_RCC_GET_TIM20_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_TIM20SW)))
Kojto 90:cb3d968589d8 3778
Kojto 90:cb3d968589d8 3779 /**
Kojto 90:cb3d968589d8 3780 * @}
Kojto 90:cb3d968589d8 3781 */
Kojto 90:cb3d968589d8 3782 #endif /* STM32f303xE || STM32F398xx */
Kojto 90:cb3d968589d8 3783
Kojto 122:f9eeca106725 3784 /** @defgroup RCCEx_LSE_Configuration LSE Drive Configuration
Kojto 122:f9eeca106725 3785 * @{
Kojto 122:f9eeca106725 3786 */
Kojto 122:f9eeca106725 3787
Kojto 122:f9eeca106725 3788 /**
Kojto 122:f9eeca106725 3789 * @brief Macro to configure the External Low Speed oscillator (LSE) drive capability.
Kojto 122:f9eeca106725 3790 * @param __RCC_LSEDRIVE__ specifies the new state of the LSE drive capability.
Kojto 122:f9eeca106725 3791 * This parameter can be one of the following values:
Kojto 122:f9eeca106725 3792 * @arg @ref RCC_LSEDRIVE_LOW LSE oscillator low drive capability.
Kojto 122:f9eeca106725 3793 * @arg @ref RCC_LSEDRIVE_MEDIUMLOW LSE oscillator medium low drive capability.
Kojto 122:f9eeca106725 3794 * @arg @ref RCC_LSEDRIVE_MEDIUMHIGH LSE oscillator medium high drive capability.
Kojto 122:f9eeca106725 3795 * @arg @ref RCC_LSEDRIVE_HIGH LSE oscillator high drive capability.
Kojto 122:f9eeca106725 3796 * @retval None
Kojto 122:f9eeca106725 3797 */
Kojto 122:f9eeca106725 3798 #define __HAL_RCC_LSEDRIVE_CONFIG(__RCC_LSEDRIVE__) (MODIFY_REG(RCC->BDCR,\
Kojto 122:f9eeca106725 3799 RCC_BDCR_LSEDRV, (uint32_t)(__RCC_LSEDRIVE__) ))
Kojto 122:f9eeca106725 3800
Kojto 122:f9eeca106725 3801 /**
Kojto 122:f9eeca106725 3802 * @}
Kojto 122:f9eeca106725 3803 */
Kojto 90:cb3d968589d8 3804
Kojto 90:cb3d968589d8 3805 /**
Kojto 90:cb3d968589d8 3806 * @}
Kojto 90:cb3d968589d8 3807 */
Kojto 90:cb3d968589d8 3808
Kojto 90:cb3d968589d8 3809 /* Exported functions --------------------------------------------------------*/
Kojto 122:f9eeca106725 3810 /** @addtogroup RCCEx_Exported_Functions
Kojto 90:cb3d968589d8 3811 * @{
Kojto 90:cb3d968589d8 3812 */
Kojto 90:cb3d968589d8 3813
Kojto 122:f9eeca106725 3814 /** @addtogroup RCCEx_Exported_Functions_Group1
Kojto 90:cb3d968589d8 3815 * @{
Kojto 90:cb3d968589d8 3816 */
Kojto 122:f9eeca106725 3817
Kojto 90:cb3d968589d8 3818 HAL_StatusTypeDef HAL_RCCEx_PeriphCLKConfig(RCC_PeriphCLKInitTypeDef *PeriphClkInit);
Kojto 122:f9eeca106725 3819 void HAL_RCCEx_GetPeriphCLKConfig(RCC_PeriphCLKInitTypeDef *PeriphClkInit);
Kojto 122:f9eeca106725 3820 uint32_t HAL_RCCEx_GetPeriphCLKFreq(uint32_t PeriphClk);
Kojto 122:f9eeca106725 3821
Kojto 90:cb3d968589d8 3822 /**
Kojto 90:cb3d968589d8 3823 * @}
Kojto 90:cb3d968589d8 3824 */
Kojto 90:cb3d968589d8 3825
Kojto 90:cb3d968589d8 3826 /**
Kojto 90:cb3d968589d8 3827 * @}
Kojto 90:cb3d968589d8 3828 */
Kojto 90:cb3d968589d8 3829
Kojto 90:cb3d968589d8 3830 /**
Kojto 90:cb3d968589d8 3831 * @}
Kojto 90:cb3d968589d8 3832 */
Kojto 90:cb3d968589d8 3833
Kojto 90:cb3d968589d8 3834 /**
Kojto 90:cb3d968589d8 3835 * @}
Kojto 90:cb3d968589d8 3836 */
Kojto 122:f9eeca106725 3837
Kojto 90:cb3d968589d8 3838 #ifdef __cplusplus
Kojto 90:cb3d968589d8 3839 }
Kojto 90:cb3d968589d8 3840 #endif
Kojto 90:cb3d968589d8 3841
Kojto 90:cb3d968589d8 3842 #endif /* __STM32F3xx_HAL_RCC_EX_H */
Kojto 90:cb3d968589d8 3843
Kojto 90:cb3d968589d8 3844 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
Kojto 122:f9eeca106725 3845