/* ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. */ /** * @file STM32L4xx+/hal_lld.h * @brief STM32L4xx+ HAL subsystem low level driver header. * @pre This module requires the following macros to be defined in the * @p board.h file: * - STM32_LSECLK. * - STM32_LSEDRV. * - STM32_LSE_BYPASS (optionally). * - STM32_HSECLK. * - STM32_HSE_BYPASS (optionally). * . * One of the following macros must also be defined: * - STM32L4R5xx, STM32L4R7xx, STM32L4R9xx. * - STM32L4S5xx, STM32L4S7xx, STM32L4S9xx. * . * * @addtogroup HAL * @{ */ #ifndef HAL_LLD_H #define HAL_LLD_H #include "stm32_registry.h" /*===========================================================================*/ /* Driver constants. */ /*===========================================================================*/ /** * @name Platform identification * @{ */ #if defined(STM32L4R5xx) || defined(STM32L4R7xx) || defined(STM32L4R9xx) || \ defined(__DOXYGEN__) #define PLATFORM_NAME "STM32L4+ Ultra Low Power" #elif defined(STM32L4S5xx) || defined(STM32L4S7xx) || defined(STM32L4S9xx) #define PLATFORM_NAME "STM32L4+ Ultra Low Power with Crypto" #else #error "STM32L4+ device not specified" #endif /** * @brief Sub-family identifier. */ #if !defined(STM32L4XXP) || defined(__DOXYGEN__) #define STM32L4XXP #endif /** @} */ /** * @name Internal clock sources * @{ */ #define STM32_HSI16CLK 16000000 /**< 16MHz internal clock. */ #define STM32_HSI48CLK 48000000 /**< 48MHz internal clock. */ #define STM32_LSICLK 32000 /**< Low speed internal clock. */ /** @} */ /** * @name PWR_CR1 register bits definitions * @{ */ #define STM32_VOS_MASK (3 << 9) /**< Core voltage mask. */ #define STM32_VOS_RANGE1 (1 << 9) /**< Core voltage 1.2 Volts. */ #define STM32_VOS_RANGE2 (2 << 9) /**< Core voltage 1.0 Volts. */ /** @} */ /** * @name PWR_CR2 register bits definitions * @{ */ #define STM32_PLS_MASK (7 << 1) /**< PLS bits mask. */ #define STM32_PLS_LEV0 (0 << 1) /**< PVD level 0. */ #define STM32_PLS_LEV1 (1 << 1) /**< PVD level 1. */ #define STM32_PLS_LEV2 (2 << 1) /**< PVD level 2. */ #define STM32_PLS_LEV3 (3 << 1) /**< PVD level 3. */ #define STM32_PLS_LEV4 (4 << 1) /**< PVD level 4. */ #define STM32_PLS_LEV5 (5 << 1) /**< PVD level 5. */ #define STM32_PLS_LEV6 (6 << 1) /**< PVD level 6. */ #define STM32_PLS_EXT (7 << 1) /**< PVD level 7. */ /** @} */ /** * @name RCC_CR register bits definitions * @{ */ #define STM32_MSIRANGE_MASK (15 << 4) /**< MSIRANGE field mask. */ #define STM32_MSIRANGE_100K (0 << 4) /**< 100kHz nominal. */ #define STM32_MSIRANGE_200K (1 << 4) /**< 200kHz nominal. */ #define STM32_MSIRANGE_400K (2 << 4) /**< 400kHz nominal. */ #define STM32_MSIRANGE_800K (3 << 4) /**< 800kHz nominal. */ #define STM32_MSIRANGE_1M (4 << 4) /**< 1MHz nominal. */ #define STM32_MSIRANGE_2M (5 << 4) /**< 2MHz nominal. */ #define STM32_MSIRANGE_4M (6 << 4) /**< 4MHz nominal. */ #define STM32_MSIRANGE_8M (7 << 4) /**< 8MHz nominal. */ #define STM32_MSIRANGE_16M (8 << 4) /**< 16MHz nominal. */ #define STM32_MSIRANGE_24M (9 << 4) /**< 24MHz nominal. */ #define STM32_MSIRANGE_32M (10 << 4) /**< 32MHz nominal. */ #define STM32_MSIRANGE_48M (11 << 4) /**< 48MHz nominal. */ /** @} */ /** * @name RCC_CFGR register bits definitions * @{ */ #define STM32_SW_MASK (3 << 0) /**< SW field mask. */ #define STM32_SW_MSI (0 << 0) /**< SYSCLK source is MSI. */ #define STM32_SW_HSI16 (1 << 0) /**< SYSCLK source is HSI. */ #define STM32_SW_HSE (2 << 0) /**< SYSCLK source is HSE. */ #define STM32_SW_PLL (3 << 0) /**< SYSCLK source is PLL. */ #define STM32_HPRE_MASK (15 << 4) /**< HPRE field mask. */ #define STM32_HPRE_DIV1 (0 << 4) /**< SYSCLK divided by 1. */ #define STM32_HPRE_DIV2 (8 << 4) /**< SYSCLK divided by 2. */ #define STM32_HPRE_DIV4 (9 << 4) /**< SYSCLK divided by 4. */ #define STM32_HPRE_DIV8 (10 << 4) /**< SYSCLK divided by 8. */ #define STM32_HPRE_DIV16 (11 << 4) /**< SYSCLK divided by 16. */ #define STM32_HPRE_DIV64 (12 << 4) /**< SYSCLK divided by 64. */ #define STM32_HPRE_DIV128 (13 << 4) /**< SYSCLK divided by 128. */ #define STM32_HPRE_DIV256 (14 << 4) /**< SYSCLK divided by 256. */ #define STM32_HPRE_DIV512 (15 << 4) /**< SYSCLK divided by 512. */ #define STM32_PPRE1_MASK (7 << 8) /**< PPRE1 field mask. */ #define STM32_PPRE1_DIV1 (0 << 8) /**< HCLK divided by 1. */ #define STM32_PPRE1_DIV2 (4 << 8) /**< HCLK divided by 2. */ #define STM32_PPRE1_DIV4 (5 << 8) /**< HCLK divided by 4. */ #define STM32_PPRE1_DIV8 (6 << 8) /**< HCLK divided by 8. */ #define STM32_PPRE1_DIV16 (7 << 8) /**< HCLK divided by 16. */ #define STM32_PPRE2_MASK (7 << 11) /**< PPRE2 field mask. */ #define STM32_PPRE2_DIV1 (0 << 11) /**< HCLK divided by 1. */ #define STM32_PPRE2_DIV2 (4 << 11) /**< HCLK divided by 2. */ #define STM32_PPRE2_DIV4 (5 << 11) /**< HCLK divided by 4. */ #define STM32_PPRE2_DIV8 (6 << 11) /**< HCLK divided by 8. */ #define STM32_PPRE2_DIV16 (7 << 11) /**< HCLK divided by 16. */ #define STM32_STOPWUCK_MASK (1 << 15) /**< STOPWUCK field mask. */ #define STM32_STOPWUCK_MSI (0 << 15) /**< Wakeup clock is MSI. */ #define STM32_STOPWUCK_HSI16 (1 << 15) /**< Wakeup clock is HSI16. */ #define STM32_MCOSEL_MASK (15 << 24) /**< MCOSEL field mask. */ #define STM32_MCOSEL_NOCLOCK (0 << 24) /**< No clock on MCO pin. */ #define STM32_MCOSEL_SYSCLK (1 << 24) /**< SYSCLK on MCO pin. */ #define STM32_MCOSEL_MSI (2 << 24) /**< MSI clock on MCO pin. */ #define STM32_MCOSEL_HSI16 (3 << 24) /**< HSI16 clock on MCO pin. */ #define STM32_MCOSEL_HSE (4 << 24) /**< HSE clock on MCO pin. */ #define STM32_MCOSEL_PLL (5 << 24) /**< PLL clock on MCO pin. */ #define STM32_MCOSEL_LSI (6 << 24) /**< LSI clock on MCO pin. */ #define STM32_MCOSEL_LSE (7 << 24) /**< LSE clock on MCO pin. */ #define STM32_MCOSEL_HSI48 (8 << 24) /**< HSI48 clock on MCO pin. */ #define STM32_MCOPRE_MASK (7 << 28) /**< MCOPRE field mask. */ #define STM32_MCOPRE_DIV1 (0 << 28) /**< MCO divided by 1. */ #define STM32_MCOPRE_DIV2 (1 << 28) /**< MCO divided by 2. */ #define STM32_MCOPRE_DIV4 (2 << 28) /**< MCO divided by 4. */ #define STM32_MCOPRE_DIV8 (3 << 28) /**< MCO divided by 8. */ #define STM32_MCOPRE_DIV16 (4 << 28) /**< MCO divided by 16. */ /** @} */ /** * @name RCC_PLLCFGR register bits definitions * @{ */ #define STM32_PLLSRC_MASK (3 << 0) /**< PLL clock source mask. */ #define STM32_PLLSRC_NOCLOCK (0 << 0) /**< PLL clock source disabled. */ #define STM32_PLLSRC_MSI (1 << 0) /**< PLL clock source is MSI. */ #define STM32_PLLSRC_HSI16 (2 << 0) /**< PLL clock source is HSI16. */ #define STM32_PLLSRC_HSE (3 << 0) /**< PLL clock source is HSE. */ /** @} */ /** * @name RCC_CCIPR register bits definitions * @{ */ #define STM32_USART1SEL_MASK (3 << 0) /**< USART1SEL mask. */ #define STM32_USART1SEL_PCLK2 (0 << 0) /**< USART1 source is PCLK2. */ #define STM32_USART1SEL_SYSCLK (1 << 0) /**< USART1 source is SYSCLK. */ #define STM32_USART1SEL_HSI16 (2 << 0) /**< USART1 source is HSI16. */ #define STM32_USART1SEL_LSE (3 << 0) /**< USART1 source is LSE. */ #define STM32_USART2SEL_MASK (3 << 2) /**< USART2 mask. */ #define STM32_USART2SEL_PCLK1 (0 << 2) /**< USART2 source is PCLK1. */ #define STM32_USART2SEL_SYSCLK (1 << 2) /**< USART2 source is SYSCLK. */ #define STM32_USART2SEL_HSI16 (2 << 2) /**< USART2 source is HSI16. */ #define STM32_USART2SEL_LSE (3 << 2) /**< USART2 source is LSE. */ #define STM32_USART3SEL_MASK (3 << 4) /**< USART3 mask. */ #define STM32_USART3SEL_PCLK1 (0 << 4) /**< USART3 source is PCLK1. */ #define STM32_USART3SEL_SYSCLK (1 << 4) /**< USART3 source is SYSCLK. */ #define STM32_USART3SEL_HSI16 (2 << 4) /**< USART3 source is HSI16. */ #define STM32_USART3SEL_LSE (3 << 4) /**< USART3 source is LSE. */ #define STM32_UART4SEL_MASK (3 << 6) /**< UART4 mask. */ #define STM32_UART4SEL_PCLK1 (0 << 6) /**< UART4 source is PCLK1. */ #define STM32_UART4SEL_SYSCLK (1 << 6) /**< UART4 source is SYSCLK. */ #define STM32_UART4SEL_HSI16 (2 << 6) /**< UART4 source is HSI16. */ #define STM32_UART4SEL_LSE (3 << 6) /**< UART4 source is LSE. */ #define STM32_UART5SEL_MASK (3 << 8) /**< UART5 mask. */ #define STM32_UART5SEL_PCLK1 (0 << 8) /**< UART5 source is PCLK1. */ #define STM32_UART5SEL_SYSCLK (1 << 8) /**< UART5 source is SYSCLK. */ #define STM32_UART5SEL_HSI16 (2 << 8) /**< UART5 source is HSI16. */ #define STM32_UART5SEL_LSE (3 << 8) /**< UART5 source is LSE. */ #define STM32_LPUART1SEL_MASK (3 << 10) /**< LPUART1 mask. */ #define STM32_LPUART1SEL_PCLK1 (0 << 10) /**< LPUART1 source is PCLK1. */ #define STM32_LPUART1SEL_SYSCLK (1 << 10) /**< LPUART1 source is SYSCLK. */ #define STM32_LPUART1SEL_HSI16 (2 << 10) /**< LPUART1 source is HSI16. */ #define STM32_LPUART1SEL_LSE (3 << 10) /**< LPUART1 source is LSE. */ #define STM32_I2C1SEL_MASK (3 << 12) /**< I2C1SEL mask. */ #define STM32_I2C1SEL_PCLK1 (0 << 12) /**< I2C1 source is PCLK1. */ #define STM32_I2C1SEL_SYSCLK (1 << 12) /**< I2C1 source is SYSCLK. */ #define STM32_I2C1SEL_HSI16 (2 << 12) /**< I2C1 source is HSI16. */ #define STM32_I2C2SEL_MASK (3 << 14) /**< I2C2SEL mask. */ #define STM32_I2C2SEL_PCLK1 (0 << 14) /**< I2C2 source is PCLK1. */ #define STM32_I2C2SEL_SYSCLK (1 << 14) /**< I2C2 source is SYSCLK. */ #define STM32_I2C2SEL_HSI16 (2 << 14) /**< I2C2 source is HSI16. */ #define STM32_I2C3SEL_MASK (3 << 16) /**< I2C3SEL mask. */ #define STM32_I2C3SEL_PCLK1 (0 << 16) /**< I2C3 source is PCLK1. */ #define STM32_I2C3SEL_SYSCLK (1 << 16) /**< I2C3 source is SYSCLK. */ #define STM32_I2C3SEL_HSI16 (2 << 16) /**< I2C3 source is HSI16. */ #define STM32_LPTIM1SEL_MASK (3 << 18) /**< LPTIM1SEL mask. */ #define STM32_LPTIM1SEL_PCLK1 (0 << 18) /**< LPTIM1 source is PCLK1. */ #define STM32_LPTIM1SEL_LSI (1 << 18) /**< LPTIM1 source is LSI. */ #define STM32_LPTIM1SEL_HSI16 (2 << 18) /**< LPTIM1 source is HSI16. */ #define STM32_LPTIM1SEL_LSE (3 << 18) /**< LPTIM1 source is LSE. */ #define STM32_LPTIM2SEL_MASK (3 << 20) /**< LPTIM2SEL mask. */ #define STM32_LPTIM2SEL_PCLK1 (0 << 20) /**< LPTIM2 source is PCLK1. */ #define STM32_LPTIM2SEL_LSI (1 << 20) /**< LPTIM2 source is LSI. */ #define STM32_LPTIM2SEL_HSI16 (2 << 20) /**< LPTIM2 source is HSI16. */ #define STM32_LPTIM2SEL_LSE (3 << 20) /**< LPTIM2 source is LSE. */ #define STM32_CLK48SEL_MASK (3 << 26) /**< CLK48SEL mask. */ #define STM32_CLK48SEL_HSI48 (0 << 26) /**< CLK48 source is HSI48. */ #define STM32_CLK48SEL_PLLSAI1 (1 << 26) /**< CLK48 source is PLLSAI1-Q. */ #define STM32_CLK48SEL_PLL (2 << 26) /**< CLK48 source is PLL-Q. */ #define STM32_CLK48SEL_MSI (3 << 26) /**< CLK48 source is MSI. */ #define STM32_ADCSEL_MASK (3 << 28) /**< ADCSEL mask. */ #define STM32_ADCSEL_NOCLK (0 << 28) /**< ADC clock disabled. */ #define STM32_ADCSEL_PLLSAI1 (1 << 28) /**< ADC source is PLLSAI1-R. */ #define STM32_ADCSEL_SYSCLK (3 << 28) /**< ADC source is SYSCLK. */ /** @} */ /** * @name RCC_CCIPR2 register bits definitions * @{ */ #define STM32_I2C4SEL_MASK (3 << 0) /**< I2C1SEL mask. */ #define STM32_I2C4SEL_PCLK1 (0 << 0) /**< I2C1 source is PCLK1. */ #define STM32_I2C4SEL_SYSCLK (1 << 0) /**< I2C1 source is SYSCLK. */ #define STM32_I2C4SEL_HSI16 (2 << 0) /**< I2C1 source is HSI16. */ #define STM32_DFSDMSEL_MASK (1 << 2) /**< DFSDMSEL mask. */ #define STM32_DFSDMSEL_PCLK2 (0 << 2) /**< DFSDMSEL source is PCLK2. */ #define STM32_DFSDMSEL_SYSCLK (1 << 2) /**< DFSDMSEL source is SYSCLK. */ #define STM32_ADFSDMSEL_MASK (3 << 3) /**< ADFSDMSEL mask. */ #define STM32_ADFSDMSEL_SAI1CLK (0 << 3) /**< ADFSDMSEL source is SAI1CLK. */ #define STM32_ADFSDMSEL_HSI16 (1 << 3) /**< ADFSDMSEL source is HSI16. */ #define STM32_ADFSDMSEL_MSI (2 << 3) /**< ADFSDMSEL source is MSI. */ #define STM32_SAI1SEL_MASK (7 << 5) /**< SAI1SEL mask. */ #define STM32_SAI1SEL_PLLSAI1 (0 << 5) /**< SAI1 source is PLLSAI1CLK. */ #define STM32_SAI1SEL_PLLSAI2 (1 << 5) /**< SAI1 source is PLLSAI2CLK. */ #define STM32_SAI1SEL_PLL (2 << 5) /**< SAI1 source is PLLSAI3CLK */ #define STM32_SAI1SEL_EXTCLK (3 << 5) /**< SAI1 source is external. */ #define STM32_SAI1SEL_HSI16 (4 << 5) /**< SAI1 source is HSI16. */ #define STM32_SAI1SEL_OFF 0xFFFFFFFFU /**< SAI1 clock is not required.*/ #define STM32_SAI2SEL_MASK (7 << 8) /**< SAI2SEL mask. */ #define STM32_SAI2SEL_PLLSAI1 (0 << 8) /**< SAI2 source is PLLSAI1CLK. */ #define STM32_SAI2SEL_PLLSAI2 (1 << 8) /**< SAI2 source is PLLSAI2CLK. */ #define STM32_SAI2SEL_PLL (2 << 8) /**< SAI2 source is PLLSAI3CLK */ #define STM32_SAI2SEL_EXTCLK (3 << 8) /**< SAI2 source is external. */ #define STM32_SAI2SEL_HSI16 (4 << 8) /**< SAI2 source is HSI16. */ #define STM32_SAI2SEL_OFF 0xFFFFFFFFU /**< SAI2 clock is not required.*/ #define STM32_DSISEL_MASK (1 << 12) /**< DSISE mask. */ #define STM32_DSISEL_DSIPHY (0 << 12) /**< DSISE source is DSIPHY. */ #define STM32_DSISEL_PLLDSICLK (1 << 12) /**< DSISE source is PLLDSICLK. */ #define STM32_SDMMCSEL_MASK (1 << 14) /**< SDMMCSEL mask. */ #define STM32_SDMMCSEL_48CLK (0 << 14) /**< SDMMCSEL source is 48CLK. */ #define STM32_SDMMCSEL_PLLSAI3CLK (1 << 14) /**< SDMMCSEL source is PLLSAI3CLK. */ #define STM32_PLLSAI2DIVR_MASK (3 << 16) /**< PLLSAI2DIVR mask. */ #define STM32_PLLSAI2DIVR_DIV2 (0 << 16) /**< PLLSAI2_R divided by 2. */ #define STM32_PLLSAI2DIVR_DIV4 (1 << 16) /**< PLLSAI2_R divided by 4. */ #define STM32_PLLSAI2DIVR_DIV8 (2 << 16) /**< PLLSAI2_R divided by 8. */ #define STM32_PLLSAI2DIVR_DIV16 (3 << 16) /**< PLLSAI2_R divided by 16. */ #define STM32_OSPISEL_MASK (3 << 20) /**< OSPISEL mask. */ #define STM32_OSPISEL_SYSCLK (0 << 20) /**< OSPI source is SYSCLK. */ #define STM32_OSPISEL_MSI (1 << 20) /**< OSPI source is MSI. */ #define STM32_OSPISEL_48CLK (2 << 20) /**< OSPI source is 48CLK. */ /** @} */ /** * @name RCC_BDCR register bits definitions * @{ */ #define STM32_RTCSEL_MASK (3 << 8) /**< RTC source mask. */ #define STM32_RTCSEL_NOCLOCK (0 << 8) /**< No RTC source. */ #define STM32_RTCSEL_LSE (1 << 8) /**< RTC source is LSE. */ #define STM32_RTCSEL_LSI (2 << 8) /**< RTC source is LSI. */ #define STM32_RTCSEL_HSEDIV (3 << 8) /**< RTC source is HSE divided. */ #define STM32_LSCOSEL_MASK (3 << 24) /**< LSCO pin clock source. */ #define STM32_LSCOSEL_NOCLOCK (0 << 24) /**< No clock on LSCO pin. */ #define STM32_LSCOSEL_LSI (1 << 24) /**< LSI on LSCO pin. */ #define STM32_LSCOSEL_LSE (3 << 24) /**< LSE on LSCO pin. */ /** @} */ /** * @name RCC_CSR register bits definitions * @{ */ #define STM32_MSISRANGE_MASK (15 << 8) /**< MSISRANGE field mask. */ #define STM32_MSISRANGE_1M (4 << 8) /**< 1MHz nominal. */ #define STM32_MSISRANGE_2M (5 << 8) /**< 2MHz nominal. */ #define STM32_MSISRANGE_4M (6 << 8) /**< 4MHz nominal. */ #define STM32_MSISRANGE_8M (7 << 8) /**< 8MHz nominal. */ /** @} */ /*===========================================================================*/ /* Driver pre-compile time settings. */ /*===========================================================================*/ /** * @name Configuration options * @{ */ /** * @brief Disables the PWR/RCC initialization in the HAL. */ #if !defined(STM32_NO_INIT) || defined(__DOXYGEN__) #define STM32_NO_INIT FALSE #endif /** * @brief Core voltage selection. * @note This setting affects all the performance and clock related * settings, the maximum performance is only obtainable selecting * the maximum voltage. */ #if !defined(STM32_VOS) || defined(__DOXYGEN__) #define STM32_VOS STM32_VOS_RANGE1 #endif /** * @brief Enables or disables the programmable voltage detector. */ #if !defined(STM32_PVD_ENABLE) || defined(__DOXYGEN__) #define STM32_PVD_ENABLE FALSE #endif /** * @brief Sets voltage level for programmable voltage detector. */ #if !defined(STM32_PLS) || defined(__DOXYGEN__) #define STM32_PLS STM32_PLS_LEV0 #endif /** * @brief Enables or disables the HSI16 clock source. */ #if !defined(STM32_HSI16_ENABLED) || defined(__DOXYGEN__) #define STM32_HSI16_ENABLED FALSE #endif /** * @brief Enables or disables the HSI48 clock source. */ #if !defined(STM32_HSI48_ENABLED) || defined(__DOXYGEN__) #define STM32_HSI48_ENABLED FALSE #endif /** * @brief Enables or disables the LSI clock source. */ #if !defined(STM32_LSI_ENABLED) || defined(__DOXYGEN__) #define STM32_LSI_ENABLED TRUE #endif /** * @brief Enables or disables the HSE clock source. */ #if !defined(STM32_HSE_ENABLED) || defined(__DOXYGEN__) #define STM32_HSE_ENABLED FALSE #endif /** * @brief Enables or disables the LSE clock source. */ #if !defined(STM32_LSE_ENABLED) || defined(__DOXYGEN__) #define STM32_LSE_ENABLED FALSE #endif /** * @brief Enables or disables the MSI PLL on LSE clock source. */ #if !defined(STM32_MSIPLL_ENABLED) || defined(__DOXYGEN__) #define STM32_MSIPLL_ENABLED FALSE #endif /** * @brief MSI frequency setting. */ #if !defined(STM32_MSIRANGE) || defined(__DOXYGEN__) #define STM32_MSIRANGE STM32_MSIRANGE_4M #endif /** * @brief MSI frequency setting after standby. */ #if !defined(STM32_MSISRANGE) || defined(__DOXYGEN__) #define STM32_MSISRANGE STM32_MSISRANGE_4M #endif /** * @brief Main clock source selection. * @note If the selected clock source is not the PLL then the PLL is not * initialized and started. * @note The default value is calculated for a 120MHz system clock from * the internal 4MHz MSI clock. */ #if !defined(STM32_SW) || defined(__DOXYGEN__) #define STM32_SW STM32_SW_PLL #endif /** * @brief Clock source for the PLL. * @note This setting has only effect if the PLL is selected as the * system clock source. * @note The default value is calculated for a 120MHz system clock from * the internal 4MHz MSI clock. */ #if !defined(STM32_PLLSRC) || defined(__DOXYGEN__) #define STM32_PLLSRC STM32_PLLSRC_MSI #endif /** * @brief PLLM divider value. * @note The allowed values are 1..8. * @note The default value is calculated for a 120MHz system clock from * the internal 4MHz MSI clock. */ #if !defined(STM32_PLLM_VALUE) || defined(__DOXYGEN__) #define STM32_PLLM_VALUE 1 #endif /** * @brief PLLN multiplier value. * @note The allowed values are 8..127. * @note The default value is calculated for a 120MHz system clock from * the internal 4MHz MSI clock. */ #if !defined(STM32_PLLN_VALUE) || defined(__DOXYGEN__) #define STM32_PLLN_VALUE 60 #endif /** * @brief PLLPDIV divider value or zero if disabled. * @note The allowed values are 0, 2..31. */ #if !defined(STM32_PLLPDIV_VALUE) || defined(__DOXYGEN__) #define STM32_PLLPDIV_VALUE 0 #endif /** * @brief PLLP divider value. * @note The allowed values are 7, 17. */ #if !defined(STM32_PLLP_VALUE) || defined(__DOXYGEN__) #define STM32_PLLP_VALUE 7 #endif /** * @brief PLLQ divider value. * @note The allowed values are 2, 4, 6, 8. */ #if !defined(STM32_PLLQ_VALUE) || defined(__DOXYGEN__) #define STM32_PLLQ_VALUE 4 #endif /** * @brief PLLR divider value. * @note The allowed values are 2, 4, 6, 8. * @note The default value is calculated for a 120MHz system clock from * the internal 4MHz MSI clock. */ #if !defined(STM32_PLLR_VALUE) || defined(__DOXYGEN__) #define STM32_PLLR_VALUE 2 #endif /** * @brief AHB prescaler value. * @note The default value is calculated for a 120MHz system clock from * the internal 4MHz MSI clock. */ #if !defined(STM32_HPRE) || defined(__DOXYGEN__) #define STM32_HPRE STM32_HPRE_DIV1 #endif /** * @brief APB1 prescaler value. */ #if !defined(STM32_PPRE1) || defined(__DOXYGEN__) #define STM32_PPRE1 STM32_PPRE1_DIV1 #endif /** * @brief APB2 prescaler value. */ #if !defined(STM32_PPRE2) || defined(__DOXYGEN__) #define STM32_PPRE2 STM32_PPRE2_DIV1 #endif /** * @brief STOPWUCK clock setting. */ #if !defined(STM32_STOPWUCK) || defined(__DOXYGEN__) #define STM32_STOPWUCK STM32_STOPWUCK_MSI #endif /** * @brief MCO clock source. */ #if !defined(STM32_MCOSEL) || defined(__DOXYGEN__) #define STM32_MCOSEL STM32_MCOSEL_NOCLOCK #endif /** * @brief MCO divider setting. */ #if !defined(STM32_MCOPRE) || defined(__DOXYGEN__) #define STM32_MCOPRE STM32_MCOPRE_DIV1 #endif /** * @brief LSCO clock source. */ #if !defined(STM32_LSCOSEL) || defined(__DOXYGEN__) #define STM32_LSCOSEL STM32_LSCOSEL_NOCLOCK #endif /** * @brief PLLSAI1N multiplier value. * @note The allowed values are 8..127. */ #if !defined(STM32_PLLSAI1N_VALUE) || defined(__DOXYGEN__) #define STM32_PLLSAI1N_VALUE 72 #endif /** * @brief PLLSAI1PDIV divider value or zero if disabled. * @note The allowed values are 0, 2..31. */ #if !defined(STM32_PLLSAI1PDIV_VALUE) || defined(__DOXYGEN__) #define STM32_PLLSAI1PDIV_VALUE 6 #endif /** * @brief PLLSAI1P divider value. * @note The allowed values are 7, 17. */ #if !defined(STM32_PLLSAI1P_VALUE) || defined(__DOXYGEN__) #define STM32_PLLSAI1P_VALUE 7 #endif /** * @brief PLLSAI1Q divider value. * @note The allowed values are 2, 4, 6, 8. */ #if !defined(STM32_PLLSAI1Q_VALUE) || defined(__DOXYGEN__) #define STM32_PLLSAI1Q_VALUE 6 #endif /** * @brief PLLSAI1R divider value. * @note The allowed values are 2, 4, 6, 8. */ #if !defined(STM32_PLLSAI1R_VALUE) || defined(__DOXYGEN__) #define STM32_PLLSAI1R_VALUE 6 #endif /** * @brief PLLSAI2N multiplier value. * @note The allowed values are 8..127. */ #if !defined(STM32_PLLSAI2N_VALUE) || defined(__DOXYGEN__) #define STM32_PLLSAI2N_VALUE 72 #endif /** * @brief PLLSAI2PDIV divider value or zero if disabled. * @note The allowed values are 0, 2..31. */ #if !defined(STM32_PLLSAI2PDIV_VALUE) || defined(__DOXYGEN__) #define STM32_PLLSAI2PDIV_VALUE 6 #endif /** * @brief PLLSAI2P divider value. * @note The allowed values are 7, 17. */ #if !defined(STM32_PLLSAI2P_VALUE) || defined(__DOXYGEN__) #define STM32_PLLSAI2P_VALUE 7 #endif /** * @brief PLLSAI2Q divider value. * @note The allowed values are 2, 4, 6, 8. */ #if !defined(STM32_PLLSAI2Q_VALUE) || defined(__DOXYGEN__) #define STM32_PLLSAI2Q_VALUE 6 #endif /** * @brief PLLSAI2R divider value. * @note The allowed values are 2, 4, 6, 8. */ #if !defined(STM32_PLLSAI2R_VALUE) || defined(__DOXYGEN__) #define STM32_PLLSAI2R_VALUE 6 #endif /** * @brief USART1 clock source. */ #if !defined(STM32_USART1SEL) || defined(__DOXYGEN__) #define STM32_USART1SEL STM32_USART1SEL_SYSCLK #endif /** * @brief USART2 clock source. */ #if !defined(STM32_USART2SEL) || defined(__DOXYGEN__) #define STM32_USART2SEL STM32_USART2SEL_SYSCLK #endif /** * @brief USART3 clock source. */ #if !defined(STM32_USART3SEL) || defined(__DOXYGEN__) #define STM32_USART3SEL STM32_USART3SEL_SYSCLK #endif /** * @brief UART4 clock source. */ #if !defined(STM32_UART4SEL) || defined(__DOXYGEN__) #define STM32_UART4SEL STM32_UART4SEL_SYSCLK #endif /** * @brief UART5 clock source. */ #if !defined(STM32_UART5SEL) || defined(__DOXYGEN__) #define STM32_UART5SEL STM32_UART5SEL_SYSCLK #endif /** * @brief LPUART1 clock source. */ #if !defined(STM32_LPUART1SEL) || defined(__DOXYGEN__) #define STM32_LPUART1SEL STM32_LPUART1SEL_SYSCLK #endif /** * @brief I2C1 clock source. */ #if !defined(STM32_I2C1SEL) || defined(__DOXYGEN__) #define STM32_I2C1SEL STM32_I2C1SEL_SYSCLK #endif /** * @brief I2C2 clock source. */ #if !defined(STM32_I2C2SEL) || defined(__DOXYGEN__) #define STM32_I2C2SEL STM32_I2C2SEL_SYSCLK #endif /** * @brief I2C3 clock source. */ #if !defined(STM32_I2C3SEL) || defined(__DOXYGEN__) #define STM32_I2C3SEL STM32_I2C3SEL_SYSCLK #endif /** * @brief I2C4 clock source. */ #if !defined(STM32_I2C4SEL) || defined(__DOXYGEN__) #define STM32_I2C4SEL STM32_I2C4SEL_SYSCLK #endif /** * @brief LPTIM1 clock source. */ #if !defined(STM32_LPTIM1SEL) || defined(__DOXYGEN__) #define STM32_LPTIM1SEL STM32_LPTIM1SEL_PCLK1 #endif /** * @brief LPTIM2 clock source. */ #if !defined(STM32_LPTIM2SEL) || defined(__DOXYGEN__) #define STM32_LPTIM2SEL STM32_LPTIM2SEL_PCLK1 #endif /** * @brief CLK48SEL value (48MHz clock source). */ #if !defined(STM32_CLK48SEL) || defined(__DOXYGEN__) #define STM32_CLK48SEL STM32_CLK48SEL_PLL #endif /** * @brief ADCSEL value (ADCs clock source). */ #if !defined(STM32_ADCSEL) || defined(__DOXYGEN__) #define STM32_ADCSEL STM32_ADCSEL_SYSCLK #endif /** * @brief DFSDMSEL value (DFSDM clock source). */ #if !defined(STM32_DFSDMSEL) || defined(__DOXYGEN__) #define STM32_DFSDMSEL STM32_DFSDMSEL_PCLK2 #endif /** * @brief ADFSDMSEL value (DFSDM clock source). */ #if !defined(STM32_ADFSDMSEL) || defined(__DOXYGEN__) #define STM32_ADFSDMSEL STM32_ADFSDMSEL_SAI1CLK #endif /** * @brief SAI1SEL value (SAI1 clock source). */ #if !defined(STM32_SAI1SEL) || defined(__DOXYGEN__) #define STM32_SAI1SEL STM32_SAI1SEL_OFF #endif /** * @brief SAI2SEL value (SAI2 clock source). */ #if !defined(STM32_SAI2SEL) || defined(__DOXYGEN__) #define STM32_SAI2SEL STM32_SAI2SEL_OFF #endif /** * @brief DSISEL value (DSI clock source). */ #if !defined(STM32_DSISEL) || defined(__DOXYGEN__) #define STM32_DSISEL STM32_DSISEL_DSIPHY #endif /** * @brief SDMMC value (SDMMC clock source). */ #if !defined(STM32_SDMMC) || defined(__DOXYGEN__) #define STM32_SDMMC STM32_SDMMCSEL_48CLK #endif /** * @brief OSPISEL value (OSPISEL clock source). */ #if !defined(STM32_OSPISEL) || defined(__DOXYGEN__) #define STM32_OSPISEL STM32_OSPISEL_SYSCLK #endif /** * @brief RTC/LCD clock source. */ #if !defined(STM32_RTCSEL) || defined(__DOXYGEN__) #define STM32_RTCSEL STM32_RTCSEL_LSI #endif /** @} */ /*===========================================================================*/ /* Derived constants and error checks. */ /*===========================================================================*/ /* * Configuration-related checks. */ #if !defined(STM32L4xx_MCUCONF) #error "Using a wrong mcuconf.h file, STM32L4xx_MCUCONF not defined" #endif #if defined(STM32L4R5xx) && !defined(STM32L4R5_MCUCONF) #error "Using a wrong mcuconf.h file, STM32L4R5_MCUCONF not defined" #elif defined(STM32L4S5xx) && !defined(STM32L4S5_MCUCONF) #error "Using a wrong mcuconf.h file, STM32L4S5_MCUCONF not defined" #elif defined(STM32L4R7xx) && !defined(STM32L4R7_MCUCONF) #error "Using a wrong mcuconf.h file, STM32L4R7_MCUCONF not defined" #elif defined(STM32L4S7xx) && !defined(STM32L4S7_MCUCONF) #error "Using a wrong mcuconf.h file, STM32L4S7_MCUCONF not defined" #elif defined(STM32L4R9xx) && !defined(STM32L4R9_MCUCONF) #error "Using a wrong mcuconf.h file, STM32L4R9_MCUCONF not defined" #elif defined(STM32L4S9xx) && !defined(STM32L4S9_MCUCONF) #error "Using a wrong mcuconf.h file, STM32L4S9_MCUCONF not defined" #endif /* * Board files sanity checks. */ #if !defined(STM32_LSECLK) #error "STM32_LSECLK not defined in board.h" #endif #if !defined(STM32_LSEDRV) #error "STM32_LSEDRV not defined in board.h" #endif #if !defined(STM32_HSECLK) #error "STM32_HSECLK not defined in board.h" #endif /* Voltage related limits.*/ #if (STM32_VOS == STM32_VOS_RANGE1) || defined(__DOXYGEN__) /** * @name System Limits * @{ */ /** * @brief Maximum SYSCLK clock frequency in boost mode. */ #define STM32_SYSCLK_MAX 120000000 /** * @brief Maximum SYSCLK clock frequency in normal mode. */ #define STM32_SYSCLK_NOBOOST_MAX 80000000 /** * @brief Maximum HSE clock frequency at current voltage setting. */ #define STM32_HSECLK_MAX 48000000 /** * @brief Maximum HSE clock frequency using an external source. */ #define STM32_HSECLK_BYP_MAX 48000000 /** * @brief Minimum HSE clock frequency. */ #define STM32_HSECLK_MIN 8000000 /** * @brief Minimum HSE clock frequency using an external source. */ #define STM32_HSECLK_BYP_MIN 8000000 /** * @brief Maximum LSE clock frequency. */ #define STM32_LSECLK_MAX 32768 /** * @brief Maximum LSE clock frequency. */ #define STM32_LSECLK_BYP_MAX 1000000 /** * @brief Minimum LSE clock frequency. */ #define STM32_LSECLK_MIN 32768 /** * @brief Minimum LSE clock frequency. */ #define STM32_LSECLK_BYP_MIN 32768 /** * @brief Maximum PLLs input clock frequency. */ #define STM32_PLLIN_MAX 16000000 /** * @brief Minimum PLLs input clock frequency. */ #define STM32_PLLIN_MIN 2660000 /** * @brief Maximum VCO clock frequency at current voltage setting. */ #define STM32_PLLVCO_MAX 344000000 /** * @brief Minimum VCO clock frequency at current voltage setting. */ #define STM32_PLLVCO_MIN 64000000 /** * @brief Maximum PLL-P output clock frequency. */ #define STM32_PLLP_MAX 120000000 /** * @brief Minimum PLL-P output clock frequency. */ #define STM32_PLLP_MIN 2064500 /** * @brief Maximum PLL-Q output clock frequency. */ #define STM32_PLLQ_MAX 120000000 /** * @brief Minimum PLL-Q output clock frequency. */ #define STM32_PLLQ_MIN 8000000 /** * @brief Maximum PLL-R output clock frequency. */ #define STM32_PLLR_MAX 120000000 /** * @brief Minimum PLL-R output clock frequency. */ #define STM32_PLLR_MIN 8000000 /** * @brief Maximum APB1 clock frequency. */ #define STM32_PCLK1_MAX 120000000 /** * @brief Maximum APB2 clock frequency. */ #define STM32_PCLK2_MAX 120000000 /** * @brief Maximum ADC clock frequency. */ #define STM32_ADCCLK_MAX 80000000 /** @} */ /** * @name Flash Wait states * @{ */ #define STM32_0WS_THRESHOLD 20000000 #define STM32_1WS_THRESHOLD 40000000 #define STM32_2WS_THRESHOLD 60000000 #define STM32_3WS_THRESHOLD 80000000 #define STM32_4WS_THRESHOLD 100000000 #define STM32_5WS_THRESHOLD 120000000 /** @} */ #elif STM32_VOS == STM32_VOS_RANGE2 #define STM32_SYSCLK_MAX 26000000 #define STM32_SYSCLK_NOBOOST_MAX 26000000 #define STM32_HSECLK_MAX 26000000 #define STM32_HSECLK_BYP_MAX 26000000 #define STM32_HSECLK_MIN 8000000 #define STM32_HSECLK_BYP_MIN 8000000 #define STM32_LSECLK_MAX 32768 #define STM32_LSECLK_BYP_MAX 1000000 #define STM32_LSECLK_MIN 32768 #define STM32_LSECLK_BYP_MIN 32768 #define STM32_PLLIN_MAX 16000000 #define STM32_PLLIN_MIN 2660000 #define STM32_PLLVCO_MAX 128000000 #define STM32_PLLVCO_MIN 64000000 #define STM32_PLLP_MAX 26000000 #define STM32_PLLP_MIN 2064500 #define STM32_PLLQ_MAX 26000000 #define STM32_PLLQ_MIN 8000000 #define STM32_PLLR_MAX 26000000 #define STM32_PLLR_MIN 8000000 #define STM32_PCLK1_MAX 26000000 #define STM32_PCLK2_MAX 26000000 #define STM32_ADCCLK_MAX 26000000 #define STM32_0WS_THRESHOLD 8000000 #define STM32_1WS_THRESHOLD 16000000 #define STM32_2WS_THRESHOLD 26000000 #define STM32_3WS_THRESHOLD 0 #define STM32_4WS_THRESHOLD 0 #define STM32_5WS_THRESHOLD 0 #else #error "invalid STM32_VOS value specified" #endif /** * @brief MSI frequency. */ #if STM32_MSIRANGE == STM32_MSIRANGE_100K #define STM32_MSICLK 100000 #elif STM32_MSIRANGE == STM32_MSIRANGE_200K #define STM32_MSICLK 200000 #elif STM32_MSIRANGE == STM32_MSIRANGE_400K #define STM32_MSICLK 400000 #elif STM32_MSIRANGE == STM32_MSIRANGE_800K #define STM32_MSICLK 800000 #elif STM32_MSIRANGE == STM32_MSIRANGE_1M #define STM32_MSICLK 1000000 #elif STM32_MSIRANGE == STM32_MSIRANGE_2M #define STM32_MSICLK 2000000 #elif STM32_MSIRANGE == STM32_MSIRANGE_4M #define STM32_MSICLK 4000000 #elif STM32_MSIRANGE == STM32_MSIRANGE_8M #define STM32_MSICLK 8000000 #elif STM32_MSIRANGE == STM32_MSIRANGE_16M #define STM32_MSICLK 16000000 #elif STM32_MSIRANGE == STM32_MSIRANGE_24M #define STM32_MSICLK 24000000 #elif STM32_MSIRANGE == STM32_MSIRANGE_32M #define STM32_MSICLK 32000000 #elif STM32_MSIRANGE == STM32_MSIRANGE_48M #define STM32_MSICLK 48000000 #else #error "invalid STM32_MSIRANGE value specified" #endif /** * @brief MSIS frequency. */ #if STM32_MSISRANGE == STM32_MSISRANGE_1M #define STM32_MSISCLK 1000000 #elif STM32_MSISRANGE == STM32_MSISRANGE_2M #define STM32_MSISCLK 2000000 #elif STM32_MSISRANGE == STM32_MSISRANGE_4M #define STM32_MSISCLK 4000000 #elif STM32_MSISRANGE == STM32_MSISRANGE_8M #define STM32_MSISCLK 8000000 #else #error "invalid STM32_MSISRANGE value specified" #endif /* * HSI16 related checks. */ #if STM32_HSI16_ENABLED #else /* !STM32_HSI16_ENABLED */ #if STM32_SW == STM32_SW_HSI16 #error "HSI16 not enabled, required by STM32_SW" #endif #if (STM32_SW == STM32_SW_PLL) && (STM32_PLLSRC == STM32_PLLSRC_HSI16) #error "HSI16 not enabled, required by STM32_SW and STM32_PLLSRC" #endif /* NOTE: Missing checks on the HSI16 pre-muxes, it is also required for newer L4 devices.*/ #if (STM32_MCOSEL == STM32_MCOSEL_HSI16) || \ ((STM32_MCOSEL == STM32_MCOSEL_PLL) && \ (STM32_PLLSRC == STM32_PLLSRC_HSI16)) #error "HSI16 not enabled, required by STM32_MCOSEL" #endif #if ((STM32_SAI1SEL == STM32_SAI1SEL_PLLSAI1) || \ (STM32_SAI1SEL == STM32_SAI1SEL_PLLSAI2)) && \ (STM32_PLLSRC == STM32_PLLSRC_HSI16) #error "HSI16 not enabled, required by STM32_SAI1SEL" #endif #if ((STM32_SAI2SEL == STM32_SAI1SEL_PLLSAI1) || \ (STM32_SAI2SEL == STM32_SAI1SEL_PLLSAI2)) && \ (STM32_PLLSRC == STM32_PLLSRC_HSI16) #error "HSI16 not enabled, required by STM32_SAI2SEL" #endif #endif /* !STM32_HSI16_ENABLED */ #if STM32_HSI48_ENABLED #else /* !STM32_HSI48_ENABLED */ #if STM32_MCOSEL == STM32_MCOSEL_HSI48 #error "HSI48 not enabled, required by STM32_MCOSEL" #endif #if STM32_CLK48SEL == STM32_CLK48SEL_HSI48 #error "HSI48 not enabled, required by STM32_CLK48SEL" #endif #endif /* !STM32_HSI48_ENABLED */ /* * HSE related checks. */ #if STM32_HSE_ENABLED #if STM32_HSECLK == 0 #error "HSE frequency not defined" #else /* STM32_HSECLK != 0 */ #if defined(STM32_HSE_BYPASS) #if (STM32_HSECLK < STM32_HSECLK_BYP_MIN) || (STM32_HSECLK > STM32_HSECLK_BYP_MAX) #error "STM32_HSECLK outside acceptable range (STM32_HSECLK_BYP_MIN...STM32_HSECLK_BYP_MAX)" #endif #else /* !defined(STM32_HSE_BYPASS) */ #if (STM32_HSECLK < STM32_HSECLK_MIN) || (STM32_HSECLK > STM32_HSECLK_MAX) #error "STM32_HSECLK outside acceptable range (STM32_HSECLK_MIN...STM32_HSECLK_MAX)" #endif #endif /* !defined(STM32_HSE_BYPASS) */ #endif /* STM32_HSECLK != 0 */ #else /* !STM32_HSE_ENABLED */ #if STM32_SW == STM32_SW_HSE #error "HSE not enabled, required by STM32_SW" #endif #if (STM32_SW == STM32_SW_PLL) && (STM32_PLLSRC == STM32_PLLSRC_HSE) #error "HSE not enabled, required by STM32_SW and STM32_PLLSRC" #endif #if (STM32_MCOSEL == STM32_MCOSEL_HSE) || \ ((STM32_MCOSEL == STM32_MCOSEL_PLL) && \ (STM32_PLLSRC == STM32_PLLSRC_HSE)) #error "HSE not enabled, required by STM32_MCOSEL" #endif #if ((STM32_SAI1SEL == STM32_SAI1SEL_PLLSAI1) | \ (STM32_SAI1SEL == STM32_SAI1SEL_PLLSAI2)) && \ (STM32_PLLSRC == STM32_PLLSRC_HSE) #error "HSE not enabled, required by STM32_SAI1SEL" #endif #if ((STM32_SAI2SEL == STM32_SAI1SEL_PLLSAI1) | \ (STM32_SAI2SEL == STM32_SAI1SEL_PLLSAI2)) && \ (STM32_PLLSRC == STM32_PLLSRC_HSE) #error "HSE not enabled, required by STM32_SAI2SEL" #endif #if STM32_RTCSEL == STM32_RTCSEL_HSEDIV #error "HSE not enabled, required by STM32_RTCSEL" #endif #endif /* !STM32_HSE_ENABLED */ /* * LSI related checks. */ #if STM32_LSI_ENABLED #else /* !STM32_LSI_ENABLED */ #if STM32_RTCSEL == STM32_RTCSEL_LSI #error "LSI not enabled, required by STM32_RTCSEL" #endif #if STM32_MCOSEL == STM32_MCOSEL_LSI #error "LSI not enabled, required by STM32_MCOSEL" #endif #if STM32_LSCOSEL == STM32_LSCOSEL_LSI #error "LSI not enabled, required by STM32_LSCOSEL" #endif #endif /* !STM32_LSI_ENABLED */ /* * LSE related checks. */ #if STM32_LSE_ENABLED #if (STM32_LSECLK == 0) #error "LSE frequency not defined" #endif #if (STM32_LSECLK < STM32_LSECLK_MIN) || (STM32_LSECLK > STM32_LSECLK_MAX) #error "STM32_LSECLK outside acceptable range (STM32_LSECLK_MIN...STM32_LSECLK_MAX)" #endif #else /* !STM32_LSE_ENABLED */ #if STM32_RTCSEL == STM32_RTCSEL_LSE #error "LSE not enabled, required by STM32_RTCSEL" #endif #if STM32_MCOSEL == STM32_MCOSEL_LSE #error "LSE not enabled, required by STM32_MCOSEL" #endif #if STM32_LSCOSEL == STM32_LSCOSEL_LSE #error "LSE not enabled, required by STM32_LSCOSEL" #endif #if STM32_MSIPLL_ENABLED == TRUE #error "LSE not enabled, required by STM32_MSIPLL_ENABLED" #endif #endif /* !STM32_LSE_ENABLED */ /* * MSI related checks. */ #if (STM32_MSIRANGE == STM32_MSIRANGE_48M) && !STM32_MSIPLL_ENABLED #warning "STM32_MSIRANGE_48M should be used with STM32_MSIPLL_ENABLED" #endif /** * @brief STM32_PLLM field. */ #if ((STM32_PLLM_VALUE >= 1) && (STM32_PLLM_VALUE <= 8)) || \ defined(__DOXYGEN__) #define STM32_PLLM ((STM32_PLLM_VALUE - 1) << 4) #else #error "invalid STM32_PLLM_VALUE value specified" #endif /** * @brief PLLs input clock frequency. */ #if (STM32_PLLSRC == STM32_PLLSRC_HSE) || defined(__DOXYGEN__) #define STM32_PLLCLKIN (STM32_HSECLK / STM32_PLLM_VALUE) #elif STM32_PLLSRC == STM32_PLLSRC_MSI #define STM32_PLLCLKIN (STM32_MSICLK / STM32_PLLM_VALUE) #elif STM32_PLLSRC == STM32_PLLSRC_HSI16 #define STM32_PLLCLKIN (STM32_HSI16CLK / STM32_PLLM_VALUE) #elif STM32_PLLSRC == STM32_PLLSRC_NOCLOCK #define STM32_PLLCLKIN 0 #else #error "invalid STM32_PLLSRC value specified" #endif /* * PLLs input frequency range check. */ #if (STM32_PLLCLKIN != 0) && \ ((STM32_PLLCLKIN < STM32_PLLIN_MIN) || (STM32_PLLCLKIN > STM32_PLLIN_MAX)) #error "STM32_PLLCLKIN outside acceptable range (STM32_PLLIN_MIN...STM32_PLLIN_MAX)" #endif /* * PLL enable check. */ #if (STM32_HSI48_ENABLED && (STM32_CLK48SEL == STM32_CLK48SEL_PLL)) || \ (STM32_SW == STM32_SW_PLL) || \ (STM32_MCOSEL == STM32_MCOSEL_PLL) || \ (STM32_SAI1SEL == STM32_SAI1SEL_PLL) || \ (STM32_SAI2SEL == STM32_SAI2SEL_PLL) || \ defined(__DOXYGEN__) #if STM32_PLLCLKIN == 0 #error "PLL activation required but no PLL clock selected" #endif /** * @brief PLL activation flag. */ #define STM32_ACTIVATE_PLL TRUE #else #define STM32_ACTIVATE_PLL FALSE #endif /** * @brief STM32_PLLN field. */ #if ((STM32_PLLN_VALUE >= 8) && (STM32_PLLN_VALUE <= 127)) || \ defined(__DOXYGEN__) #define STM32_PLLN (STM32_PLLN_VALUE << 8) #else #error "invalid STM32_PLLN_VALUE value specified" #endif /** * @brief STM32_PLLP field. */ #if (STM32_PLLP_VALUE == 7) || defined(__DOXYGEN__) #define STM32_PLLP (0 << 17) #elif STM32_PLLP_VALUE == 17 #define STM32_PLLP (1 << 17) #else #error "invalid STM32_PLLP_VALUE value specified" #endif /** * @brief STM32_PLLQ field. */ #if (STM32_PLLQ_VALUE == 2) || defined(__DOXYGEN__) #define STM32_PLLQ (0 << 21) #elif STM32_PLLQ_VALUE == 4 #define STM32_PLLQ (1 << 21) #elif STM32_PLLQ_VALUE == 6 #define STM32_PLLQ (2 << 21) #elif STM32_PLLQ_VALUE == 8 #define STM32_PLLQ (3 << 21) #else #error "invalid STM32_PLLQ_VALUE value specified" #endif /** * @brief STM32_PLLR field. */ #if (STM32_PLLR_VALUE == 2) || defined(__DOXYGEN__) #define STM32_PLLR (0 << 25) #elif STM32_PLLR_VALUE == 4 #define STM32_PLLR (1 << 25) #elif STM32_PLLR_VALUE == 6 #define STM32_PLLR (2 << 25) #elif STM32_PLLR_VALUE == 8 #define STM32_PLLR (3 << 25) #else #error "invalid STM32_PLLR_VALUE value specified" #endif /** * @brief STM32_PLLPDIV field. */ #if (STM32_PLLPDIV_VALUE == 0) || \ ((STM32_PLLPDIV_VALUE != 1) && (STM32_PLLPDIV_VALUE <= 31)) || \ defined(__DOXYGEN__) #define STM32_PLLPDIV (STM32_PLLPDIV_VALUE << 27) #else #error "invalid STM32_PLLPDIV_VALUE value specified" #endif /** * @brief STM32_PLLPEN field. */ #if (STM32_SAI1SEL == STM32_SAI1SEL_PLL) || \ (STM32_SAI2SEL == STM32_SAI2SEL_PLL) || \ defined(__DOXYGEN__) #define STM32_PLLPEN (1 << 16) #else #define STM32_PLLPEN (0 << 16) #endif /** * @brief STM32_PLLQEN field. */ #if (STM32_CLK48SEL == STM32_CLK48SEL_PLL) || defined(__DOXYGEN__) #define STM32_PLLQEN (1 << 20) #else #define STM32_PLLQEN (0 << 20) #endif /** * @brief STM32_PLLREN field. */ #if (STM32_SW == STM32_SW_PLL) || \ (STM32_MCOSEL == STM32_MCOSEL_PLL) || \ defined(__DOXYGEN__) #define STM32_PLLREN (1 << 24) #else #define STM32_PLLREN (0 << 24) #endif /** * @brief PLL VCO frequency. */ #define STM32_PLLVCO (STM32_PLLCLKIN * STM32_PLLN_VALUE) /* * PLL VCO frequency range check. */ #if STM32_ACTIVATE_PLL && \ ((STM32_PLLVCO < STM32_PLLVCO_MIN) || (STM32_PLLVCO > STM32_PLLVCO_MAX)) #error "STM32_PLLVCO outside acceptable range (STM32_PLLVCO_MIN...STM32_PLLVCO_MAX)" #endif /** * @brief PLL P output clock frequency. */ #if (STM32_PLLPDIV_VALUE == 0) || defined(__DOXYGEN__) #define STM32_PLL_P_CLKOUT (STM32_PLLVCO / STM32_PLLP_VALUE) #else #define STM32_PLL_P_CLKOUT (STM32_PLLVCO / STM32_PLLPDIV_VALUE) #endif /** * @brief PLL Q output clock frequency. */ #define STM32_PLL_Q_CLKOUT (STM32_PLLVCO / STM32_PLLQ_VALUE) /** * @brief PLL R output clock frequency. */ #define STM32_PLL_R_CLKOUT (STM32_PLLVCO / STM32_PLLR_VALUE) /* * PLL-P output frequency range check. */ #if STM32_ACTIVATE_PLL && \ ((STM32_PLL_P_CLKOUT < STM32_PLLP_MIN) || (STM32_PLL_P_CLKOUT > STM32_PLLP_MAX)) #error "STM32_PLL_P_CLKOUT outside acceptable range (STM32_PLLP_MIN...STM32_PLLP_MAX)" #endif /* * PLL-Q output frequency range check. */ #if STM32_ACTIVATE_PLL && \ ((STM32_PLL_Q_CLKOUT < STM32_PLLQ_MIN) || (STM32_PLL_Q_CLKOUT > STM32_PLLQ_MAX)) #error "STM32_PLL_Q_CLKOUT outside acceptable range (STM32_PLLQ_MIN...STM32_PLLQ_MAX)" #endif /* * PLL-R output frequency range check. */ #if STM32_ACTIVATE_PLL && \ ((STM32_PLL_R_CLKOUT < STM32_PLLR_MIN) || (STM32_PLL_R_CLKOUT > STM32_PLLR_MAX)) #error "STM32_PLL_R_CLKOUT outside acceptable range (STM32_PLLR_MIN...STM32_PLLR_MAX)" #endif /** * @brief System clock source. */ #if STM32_NO_INIT || defined(__DOXYGEN__) #define STM32_SYSCLK STM32_MSICLK #elif (STM32_SW == STM32_SW_MSI) #define STM32_SYSCLK STM32_MSICLK #elif (STM32_SW == STM32_SW_HSI16) #define STM32_SYSCLK STM32_HSI16CLK #elif (STM32_SW == STM32_SW_HSE) #define STM32_SYSCLK STM32_HSECLK #elif (STM32_SW == STM32_SW_PLL) #define STM32_SYSCLK STM32_PLL_R_CLKOUT #else #error "invalid STM32_SW value specified" #endif /* Check on the system clock.*/ #if STM32_SYSCLK > STM32_SYSCLK_MAX #error "STM32_SYSCLK above maximum rated frequency (STM32_SYSCLK_MAX)" #endif /** * @brief AHB frequency. */ #if (STM32_HPRE == STM32_HPRE_DIV1) || defined(__DOXYGEN__) #define STM32_HCLK (STM32_SYSCLK / 1) #elif STM32_HPRE == STM32_HPRE_DIV2 #define STM32_HCLK (STM32_SYSCLK / 2) #elif STM32_HPRE == STM32_HPRE_DIV4 #define STM32_HCLK (STM32_SYSCLK / 4) #elif STM32_HPRE == STM32_HPRE_DIV8 #define STM32_HCLK (STM32_SYSCLK / 8) #elif STM32_HPRE == STM32_HPRE_DIV16 #define STM32_HCLK (STM32_SYSCLK / 16) #elif STM32_HPRE == STM32_HPRE_DIV64 #define STM32_HCLK (STM32_SYSCLK / 64) #elif STM32_HPRE == STM32_HPRE_DIV128 #define STM32_HCLK (STM32_SYSCLK / 128) #elif STM32_HPRE == STM32_HPRE_DIV256 #define STM32_HCLK (STM32_SYSCLK / 256) #elif STM32_HPRE == STM32_HPRE_DIV512 #define STM32_HCLK (STM32_SYSCLK / 512) #else #error "invalid STM32_HPRE value specified" #endif /* * AHB frequency check. */ #if STM32_HCLK > STM32_SYSCLK_MAX #error "STM32_HCLK exceeding maximum frequency (STM32_SYSCLK_MAX)" #endif /** * @brief APB1 frequency. */ #if (STM32_PPRE1 == STM32_PPRE1_DIV1) || defined(__DOXYGEN__) #define STM32_PCLK1 (STM32_HCLK / 1) #elif STM32_PPRE1 == STM32_PPRE1_DIV2 #define STM32_PCLK1 (STM32_HCLK / 2) #elif STM32_PPRE1 == STM32_PPRE1_DIV4 #define STM32_PCLK1 (STM32_HCLK / 4) #elif STM32_PPRE1 == STM32_PPRE1_DIV8 #define STM32_PCLK1 (STM32_HCLK / 8) #elif STM32_PPRE1 == STM32_PPRE1_DIV16 #define STM32_PCLK1 (STM32_HCLK / 16) #else #error "invalid STM32_PPRE1 value specified" #endif /* * APB1 frequency check. */ #if STM32_PCLK1 > STM32_PCLK1_MAX #error "STM32_PCLK1 exceeding maximum frequency (STM32_PCLK1_MAX)" #endif /** * @brief APB2 frequency. */ #if (STM32_PPRE2 == STM32_PPRE2_DIV1) || defined(__DOXYGEN__) #define STM32_PCLK2 (STM32_HCLK / 1) #elif STM32_PPRE2 == STM32_PPRE2_DIV2 #define STM32_PCLK2 (STM32_HCLK / 2) #elif STM32_PPRE2 == STM32_PPRE2_DIV4 #define STM32_PCLK2 (STM32_HCLK / 4) #elif STM32_PPRE2 == STM32_PPRE2_DIV8 #define STM32_PCLK2 (STM32_HCLK / 8) #elif STM32_PPRE2 == STM32_PPRE2_DIV16 #define STM32_PCLK2 (STM32_HCLK / 16) #else #error "invalid STM32_PPRE2 value specified" #endif /* * APB2 frequency check. */ #if STM32_PCLK2 > STM32_PCLK2_MAX #error "STM32_PCLK2 exceeding maximum frequency (STM32_PCLK2_MAX)" #endif /* * PLLSAI1 enable check. */ #if (STM32_SAI1SEL == STM32_SAI1SEL_PLLSAI1) || \ (STM32_SAI2SEL == STM32_SAI2SEL_PLLSAI1) || \ (STM32_CLK48SEL == STM32_CLK48SEL_PLLSAI1) || \ (STM32_ADCSEL == STM32_ADCSEL_PLLSAI1) || \ defined(__DOXYGEN__) #if STM32_PLLCLKIN == 0 #error "PLLSAI1 activation required but no PLL clock selected" #endif /** * @brief PLLSAI1 activation flag. */ #define STM32_ACTIVATE_PLLSAI1 TRUE #else #define STM32_ACTIVATE_PLLSAI1 FALSE #endif /** * @brief STM32_PLLSAI1N field. */ #if ((STM32_PLLSAI1N_VALUE >= 8) && (STM32_PLLSAI1N_VALUE <= 127)) || \ defined(__DOXYGEN__) #define STM32_PLLSAI1N (STM32_PLLSAI1N_VALUE << 8) #else #error "invalid STM32_PLLSAI1N_VALUE value specified" #endif /** * @brief STM32_PLLSAI1P field. */ #if (STM32_PLLSAI1P_VALUE == 7) || defined(__DOXYGEN__) #define STM32_PLLSAI1P (0 << 17) #elif STM32_PLLSAI1P_VALUE == 17 #define STM32_PLLSAI1P (1 << 17) #else #error "invalid STM32_PLLSAI1P_VALUE value specified" #endif /** * @brief STM32_PLLSAI1Q field. */ #if (STM32_PLLSAI1Q_VALUE == 2) || defined(__DOXYGEN__) #define STM32_PLLSAI1Q (0 << 21) #elif STM32_PLLSAI1Q_VALUE == 4 #define STM32_PLLSAI1Q (1 << 21) #elif STM32_PLLSAI1Q_VALUE == 6 #define STM32_PLLSAI1Q (2 << 21) #elif STM32_PLLSAI1Q_VALUE == 8 #define STM32_PLLSAI1Q (3 << 21) #else #error "invalid STM32_PLLSAI1Q_VALUE value specified" #endif /** * @brief STM32_PLLSAI1R field. */ #if (STM32_PLLSAI1R_VALUE == 2) || defined(__DOXYGEN__) #define STM32_PLLSAI1R (0 << 25) #elif STM32_PLLSAI1R_VALUE == 4 #define STM32_PLLSAI1R (1 << 25) #elif STM32_PLLSAI1R_VALUE == 6 #define STM32_PLLSAI1R (2 << 25) #elif STM32_PLLSAI1R_VALUE == 8 #define STM32_PLLSAI1R (3 << 25) #else #error "invalid STM32_PLLSAI1R_VALUE value specified" #endif /** * @brief STM32_PLLSAI1PDIV field. */ #if ((STM32_PLLSAI1PDIV_VALUE != 1) && (STM32_PLLSAI1PDIV_VALUE <= 31)) || \ defined(__DOXYGEN__) #define STM32_PLLSAI1PDIV (STM32_PLLSAI1PDIV_VALUE << 27) #else #error "invalid STM32_PLLSAI1PDIV_VALUE value specified" #endif /** * @brief STM32_PLLSAI1PEN field. */ #if (STM32_SAI1SEL == STM32_SAI1SEL_PLLSAI1) || \ (STM32_SAI2SEL == STM32_SAI2SEL_PLLSAI1) || \ defined(__DOXYGEN__) #define STM32_PLLSAI1PEN (1 << 16) #else #define STM32_PLLSAI1PEN (0 << 16) #endif /** * @brief STM32_PLLSAI1QEN field. */ #if (STM32_CLK48SEL == STM32_CLK48SEL_PLLSAI1) || defined(__DOXYGEN__) #define STM32_PLLSAI1QEN (1 << 20) #else #define STM32_PLLSAI1QEN (0 << 20) #endif /** * @brief STM32_PLLSAI1REN field. */ #if (STM32_ADCSEL == STM32_ADCSEL_PLLSAI1) || defined(__DOXYGEN__) #define STM32_PLLSAI1REN (1 << 24) #else #define STM32_PLLSAI1REN (0 << 24) #endif /** * @brief PLLSAI1 VCO frequency. */ #define STM32_PLLSAI1VCO (STM32_PLLCLKIN * STM32_PLLSAI1N_VALUE) /* * PLLSAI1 VCO frequency range check. */ #if STM32_ACTIVATE_PLLSAI1 && \ ((STM32_PLLSAI1VCO < STM32_PLLVCO_MIN) || (STM32_PLLSAI1VCO > STM32_PLLVCO_MAX)) #error "STM32_PLLSAI1VCO outside acceptable range (STM32_PLLVCO_MIN...STM32_PLLVCO_MAX)" #endif /** * @brief PLLSAI1-P output clock frequency. */ #if (STM32_PLLSAI1PDIV_VALUE == 0) || defined(__DOXYGEN__) #define STM32_PLLSAI1_P_CLKOUT (STM32_PLLSAI1VCO / STM32_PLLSAI1P_VALUE) #else #define STM32_PLLSAI1_P_CLKOUT (STM32_PLLSAI1VCO / STM32_PLLSAI1PDIV_VALUE) #endif /** * @brief PLLSAI1-Q output clock frequency. */ #define STM32_PLLSAI1_Q_CLKOUT (STM32_PLLSAI1VCO / STM32_PLLSAI1Q_VALUE) /** * @brief PLLSAI1-R output clock frequency. */ #define STM32_PLLSAI1_R_CLKOUT (STM32_PLLSAI1VCO / STM32_PLLSAI1R_VALUE) /* * PLLSAI1-P output frequency range check. */ #if STM32_ACTIVATE_PLLSAI1 && \ ((STM32_PLLSAI1_P_CLKOUT < STM32_PLLP_MIN) || (STM32_PLLSAI1_P_CLKOUT > STM32_PLLP_MAX)) #error "STM32_PLLSAI1_P_CLKOUT outside acceptable range (STM32_PLLP_MIN...STM32_PLLP_MAX)" #endif /* * PLLSAI1-Q output frequency range check. */ #if STM32_ACTIVATE_PLLSAI1 && \ ((STM32_PLLSAI1_Q_CLKOUT < STM32_PLLQ_MIN) || (STM32_PLLSAI1_Q_CLKOUT > STM32_PLLQ_MAX)) #error "STM32_PLLSAI1_Q_CLKOUT outside acceptable range (STM32_PLLQ_MIN...STM32_PLLQ_MAX)" #endif /* * PLLSAI1-R output frequency range check. */ #if STM32_ACTIVATE_PLLSAI1 && \ ((STM32_PLLSAI1_R_CLKOUT < STM32_PLLR_MIN) || (STM32_PLLSAI1_R_CLKOUT > STM32_PLLR_MAX)) #error "STM32_PLLSAI1_R_CLKOUT outside acceptable range (STM32_PLLR_MIN...STM32_PLLR_MAX)" #endif /* * PLLSAI2 enable check. */ #if (STM32_SAI1SEL == STM32_SAI1SEL_PLLSAI2) || \ (STM32_SAI2SEL == STM32_SAI2SEL_PLLSAI2) || \ (STM32_ADCSEL == STM32_ADCSEL_PLLSAI1) || \ defined(__DOXYGEN__) #if STM32_PLLCLKIN == 0 #error "PLLSAI2 activation required but no PLL clock selected" #endif /** * @brief PLLSAI2 activation flag. */ #define STM32_ACTIVATE_PLLSAI2 TRUE #else #define STM32_ACTIVATE_PLLSAI2 FALSE #endif /** * @brief STM32_PLLSAI2N field. */ #if ((STM32_PLLSAI2N_VALUE >= 8) && (STM32_PLLSAI2N_VALUE <= 127)) || \ defined(__DOXYGEN__) #define STM32_PLLSAI2N (STM32_PLLSAI2N_VALUE << 8) #else #error "invalid STM32_PLLSAI2N_VALUE value specified" #endif /** * @brief STM32_PLLSAI2P field. */ #if (STM32_PLLSAI2P_VALUE == 7) || defined(__DOXYGEN__) #define STM32_PLLSAI2P (0 << 17) #elif STM32_PLLSAI2P_VALUE == 17 #define STM32_PLLSAI2P (1 << 17) #else #error "invalid STM32_PLLSAI2P_VALUE value specified" #endif /** * @brief STM32_PLLSAI2R field. */ #if (STM32_PLLSAI2R_VALUE == 2) || defined(__DOXYGEN__) #define STM32_PLLSAI2R (0 << 25) #elif STM32_PLLSAI2R_VALUE == 4 #define STM32_PLLSAI2R (1 << 25) #elif STM32_PLLSAI2R_VALUE == 6 #define STM32_PLLSAI2R (2 << 25) #elif STM32_PLLSAI2R_VALUE == 8 #define STM32_PLLSAI2R (3 << 25) #else #error "invalid STM32_PLLSAI2R_VALUE value specified" #endif /** * @brief STM32_PLLSAI2PDIV field. */ #if ((STM32_PLLSAI2PDIV_VALUE != 1) && (STM32_PLLSAI2PDIV_VALUE <= 31)) || \ defined(__DOXYGEN__) #define STM32_PLLSAI2PDIV (STM32_PLLSAI2PDIV_VALUE << 27) #else #error "invalid STM32_PLLSAI2PDIV_VALUE value specified" #endif /** * @brief STM32_PLLSAI2PEN field. */ #if (STM32_SAI1SEL == STM32_SAI1SEL_PLLSAI2) || \ (STM32_SAI2SEL == STM32_SAI2SEL_PLLSAI2) || \ defined(__DOXYGEN__) #define STM32_PLLSAI2PEN (1 << 16) #else #define STM32_PLLSAI2PEN (0 << 16) #endif /** * @brief STM32_PLLSAI2REN field. * @note Always enabled. * @todo It should depend on some condition. */ #define STM32_PLLSAI2REN (1 << 24) /** * @brief PLLSAI2 VCO frequency. */ #define STM32_PLLSAI2VCO (STM32_PLLCLKIN * STM32_PLLSAI2N_VALUE) /* * PLLSAI2 VCO frequency range check. */ #if STM32_ACTIVATE_PLLSAI2 && \ ((STM32_PLLSAI2VCO < STM32_PLLVCO_MIN) || (STM32_PLLSAI2VCO > STM32_PLLVCO_MAX)) #error "STM32_PLLSAI2VCO outside acceptable range (STM32_PLLVCO_MIN...STM32_PLLVCO_MAX)" #endif /** * @brief PLLSAI2-P output clock frequency. */ #if (STM32_PLLSAI2PDIV_VALUE == 0) || defined(__DOXYGEN__) #define STM32_PLLSAI2_P_CLKOUT (STM32_PLLSAI2VCO / STM32_PLLSAI2P_VALUE) #else #define STM32_PLLSAI2_P_CLKOUT (STM32_PLLSAI2VCO / STM32_PLLSAI2PDIV_VALUE) #endif /** * @brief PLLSAI2-R output clock frequency. */ #define STM32_PLLSAI2_R_CLKOUT (STM32_PLLSAI2VCO / STM32_PLLSAI2R_VALUE) /* * PLLSAI2-P output frequency range check. */ #if STM32_ACTIVATE_PLLSAI2 && \ ((STM32_PLLSAI2_P_CLKOUT < STM32_PLLP_MIN) || (STM32_PLLSAI2_P_CLKOUT > STM32_PLLP_MAX)) #error "STM32_PLLSAI2_P_CLKOUT outside acceptable range (STM32_PLLP_MIN...STM32_PLLP_MAX)" #endif /* * PLLSAI2-R output frequency range check. */ #if STM32_ACTIVATE_PLLSAI2 && \ ((STM32_PLLSAI2_R_CLKOUT < STM32_PLLR_MIN) || (STM32_PLLSAI2_R_CLKOUT > STM32_PLLR_MAX)) #error "STM32_PLLSAI2_R_CLKOUT outside acceptable range (STM32_PLLR_MIN...STM32_PLLR_MAX)" #endif /** * @brief MCO divider clock frequency. */ #if (STM32_MCOSEL == STM32_MCOSEL_NOCLOCK) || defined(__DOXYGEN__) #define STM32_MCODIVCLK 0 #elif STM32_MCOSEL == STM32_MCOSEL_SYSCLK #define STM32_MCODIVCLK STM32_SYSCLK #elif STM32_MCOSEL == STM32_MCOSEL_MSI #define STM32_MCODIVCLK STM32_MSICLK #elif STM32_MCOSEL == STM32_MCOSEL_HSI16 #define STM32_MCODIVCLK STM32_HSI16CLK #elif STM32_MCOSEL == STM32_MCOSEL_HSE #define STM32_MCODIVCLK STM32_HSECLK #elif STM32_MCOSEL == STM32_MCOSEL_PLL #define STM32_MCODIVCLK STM32_PLL_P_CLKOUT #elif STM32_MCOSEL == STM32_MCOSEL_LSI #define STM32_MCODIVCLK STM32_LSICLK #elif STM32_MCOSEL == STM32_MCOSEL_LSE #define STM32_MCODIVCLK STM32_LSECLK #elif STM32_MCOSEL == STM32_MCOSEL_HSI48 #define STM32_MCODIVCLK STM32_HSI48CLK #else #error "invalid STM32_MCOSEL value specified" #endif /** * @brief MCO output pin clock frequency. */ #if (STM32_MCOPRE == STM32_MCOPRE_DIV1) || defined(__DOXYGEN__) #define STM32_MCOCLK STM32_MCODIVCLK #elif STM32_MCOPRE == STM32_MCOPRE_DIV2 #define STM32_MCOCLK (STM32_MCODIVCLK / 2) #elif STM32_MCOPRE == STM32_MCOPRE_DIV4 #define STM32_MCOCLK (STM32_MCODIVCLK / 4) #elif STM32_MCOPRE == STM32_MCOPRE_DIV8 #define STM32_MCOCLK (STM32_MCODIVCLK / 8) #elif STM32_MCOPRE == STM32_MCOPRE_DIV16 #define STM32_MCOCLK (STM32_MCODIVCLK / 16) #else #error "invalid STM32_MCOPRE value specified" #endif /** * @brief RTC clock frequency. */ #if (STM32_RTCSEL == STM32_RTCSEL_NOCLOCK) || defined(__DOXYGEN__) #define STM32_RTCCLK 0 #elif STM32_RTCSEL == STM32_RTCSEL_LSE #define STM32_RTCCLK STM32_LSECLK #elif STM32_RTCSEL == STM32_RTCSEL_LSI #define STM32_RTCCLK STM32_LSICLK #elif STM32_RTCSEL == STM32_RTCSEL_HSEDIV #define STM32_RTCCLK (STM32_HSECLK / 32) #else #error "invalid STM32_RTCSEL value specified" #endif /** * @brief USART1 clock frequency. */ #if (STM32_USART1SEL == STM32_USART1SEL_PCLK2) || defined(__DOXYGEN__) #define STM32_USART1CLK STM32_PCLK2 #elif STM32_USART1SEL == STM32_USART1SEL_SYSCLK #define STM32_USART1CLK STM32_SYSCLK #elif STM32_USART1SEL == STM32_USART1SEL_HSI16 #define STM32_USART1CLK STM32_HSI16CLK #elif STM32_USART1SEL == STM32_USART1SEL_LSE #define STM32_USART1CLK STM32_LSECLK #else #error "invalid source selected for USART1 clock" #endif /** * @brief USART2 clock frequency. */ #if (STM32_USART2SEL == STM32_USART2SEL_PCLK1) || defined(__DOXYGEN__) #define STM32_USART2CLK STM32_PCLK1 #elif STM32_USART2SEL == STM32_USART2SEL_SYSCLK #define STM32_USART2CLK STM32_SYSCLK #elif STM32_USART2SEL == STM32_USART2SEL_HSI16 #define STM32_USART2CLK STM32_HSI16CLK #elif STM32_USART2SEL == STM32_USART2SEL_LSE #define STM32_USART2CLK STM32_LSECLK #else #error "invalid source selected for USART2 clock" #endif /** * @brief USART3 clock frequency. */ #if (STM32_USART3SEL == STM32_USART3SEL_PCLK1) || defined(__DOXYGEN__) #define STM32_USART3CLK STM32_PCLK1 #elif STM32_USART3SEL == STM32_USART3SEL_SYSCLK #define STM32_USART3CLK STM32_SYSCLK #elif STM32_USART3SEL == STM32_USART3SEL_HSI16 #define STM32_USART3CLK STM32_HSI16CLK #elif STM32_USART3SEL == STM32_USART3SEL_LSE #define STM32_USART3CLK STM32_LSECLK #else #error "invalid source selected for USART3 clock" #endif /** * @brief UART4 clock frequency. */ #if (STM32_UART4SEL == STM32_UART4SEL_PCLK1) || defined(__DOXYGEN__) #define STM32_UART4CLK STM32_PCLK1 #elif STM32_UART4SEL == STM32_UART4SEL_SYSCLK #define STM32_UART4CLK STM32_SYSCLK #elif STM32_UART4SEL == STM32_UART4SEL_HSI16 #define STM32_UART4CLK STM32_HSI16CLK #elif STM32_UART4SEL == STM32_UART4SEL_LSE #define STM32_UART4CLK STM32_LSECLK #else #error "invalid source selected for UART4 clock" #endif /** * @brief UART5 clock frequency. */ #if (STM32_UART5SEL == STM32_UART5SEL_PCLK1) || defined(__DOXYGEN__) #define STM32_UART5CLK STM32_PCLK1 #elif STM32_UART5SEL == STM32_UART5SEL_SYSCLK #define STM32_UART5CLK STM32_SYSCLK #elif STM32_UART5SEL == STM32_UART5SEL_HSI16 #define STM32_UART5CLK STM32_HSI16CLK #elif STM32_UART5SEL == STM32_UART5SEL_LSE #define STM32_UART5CLK STM32_LSECLK #else #error "invalid source selected for UART5 clock" #endif /** * @brief LPUART1 clock frequency. */ #if (STM32_LPUART1SEL == STM32_LPUART1SEL_PCLK1) || defined(__DOXYGEN__) #define STM32_LPUART1CLK STM32_PCLK1 #elif STM32_LPUART1SEL == STM32_LPUART1SEL_SYSCLK #define STM32_LPUART1CLK STM32_SYSCLK #elif STM32_LPUART1SEL == STM32_LPUART1SEL_HSI16 #define STM32_LPUART1CLK STM32_HSI16CLK #elif STM32_LPUART1SEL == STM32_LPUART1SEL_LSE #define STM32_LPUART1CLK STM32_LSECLK #else #error "invalid source selected for LPUART1 clock" #endif /** * @brief I2C1 clock frequency. */ #if (STM32_I2C1SEL == STM32_I2C1SEL_PCLK1) || defined(__DOXYGEN__) #define STM32_I2C1CLK STM32_PCLK1 #elif STM32_I2C1SEL == STM32_I2C1SEL_SYSCLK #define STM32_I2C1CLK STM32_SYSCLK #elif STM32_I2C1SEL == STM32_I2C1SEL_HSI16 #define STM32_I2C1CLK STM32_HSI16CLK #else #error "invalid source selected for I2C1 clock" #endif /** * @brief I2C2 clock frequency. */ #if (STM32_I2C2SEL == STM32_I2C2SEL_PCLK1) || defined(__DOXYGEN__) #define STM32_I2C2CLK STM32_PCLK1 #elif STM32_I2C2SEL == STM32_I2C2SEL_SYSCLK #define STM32_I2C2CLK STM32_SYSCLK #elif STM32_I2C2SEL == STM32_I2C2SEL_HSI16 #define STM32_I2C2CLK STM32_HSI16CLK #else #error "invalid source selected for I2C2 clock" #endif /** * @brief I2C3 clock frequency. */ #if (STM32_I2C3SEL == STM32_I2C3SEL_PCLK1) || defined(__DOXYGEN__) #define STM32_I2C3CLK STM32_PCLK1 #elif STM32_I2C3SEL == STM32_I2C3SEL_SYSCLK #define STM32_I2C3CLK STM32_SYSCLK #elif STM32_I2C3SEL == STM32_I2C3SEL_HSI16 #define STM32_I2C3CLK STM32_HSI16CLK #else #error "invalid source selected for I2C3 clock" #endif /** * @brief LPTIM1 clock frequency. */ #if (STM32_LPTIM1SEL == STM32_LPTIM1SEL_PCLK1) || defined(__DOXYGEN__) #define STM32_LPTIM1CLK STM32_PCLK1 #elif STM32_LPTIM1SEL == STM32_LPTIM1SEL_LSI #define STM32_LPTIM1CLK STM32_LSICLK #elif STM32_LPTIM1SEL == STM32_LPTIM1SEL_HSI16 #define STM32_LPTIM1CLK STM32_HSI16CLK #elif STM32_LPTIM1SEL == STM32_LPTIM1SEL_LSE #define STM32_LPTIM1CLK STM32_LSECLK #else #error "invalid source selected for LPTIM1 clock" #endif /** * @brief LPTIM2 clock frequency. */ #if (STM32_LPTIM2SEL == STM32_LPTIM2SEL_PCLK1) || defined(__DOXYGEN__) #define STM32_LPTIM2CLK STM32_PCLK1 #elif STM32_LPTIM2SEL == STM32_LPTIM2SEL_LSI #define STM32_LPTIM2CLK STM32_LSICLK #elif STM32_LPTIM2SEL == STM32_LPTIM2SEL_HSI16 #define STM32_LPTIM2CLK STM32_HSI16CLK #elif STM32_LPTIM2SEL == STM32_LPTIM2SEL_LSE #define STM32_LPTIM2CLK STM32_LSECLK #else #error "invalid source selected for LPTIM2 clock" #endif /** * @brief 48MHz clock frequency. */ #if (STM32_CLK48SEL == STM32_CLK48SEL_HSI48) || defined(__DOXYGEN__) #define STM32_48CLK STM32_HSI48CLK #elif STM32_CLK48SEL == STM32_CLK48SEL_PLLSAI1 #define STM32_48CLK (STM32_PLLSAI1VCO / STM32_PLLSAI1Q_VALUE) #elif STM32_CLK48SEL == STM32_CLK48SEL_PLL #define STM32_48CLK (STM32_PLLVCO / STM32_PLLQ_VALUE) #elif STM32_CLK48SEL == STM32_CLK48SEL_MSI #define STM32_48CLK STM32_MSICLK #else #error "invalid source selected for 48CLK clock" #endif /** * @brief USB clock point. */ #define STM32_USBCLK STM32_48CLK /** * @brief RNG clock point. */ #define STM32_RNGCLK STM32_48CLK /** * @brief ADC clock frequency. */ #if (STM32_ADCSEL == STM32_ADCSEL_NOCLK) || defined(__DOXYGEN__) #define STM32_ADCCLK 0 #elif STM32_ADCSEL == STM32_ADCSEL_PLLSAI1 #define STM32_ADCCLK STM32_PLLSAI1_R_CLKOUT #elif STM32_ADCSEL == STM32_ADCSEL_SYSCLK #define STM32_ADCCLK STM32_SYSCLK #else #error "invalid source selected for ADC clock" #endif /** * @brief DFSDM clock frequency. */ #if (STM32_DFSDMSEL == STM32_DFSDMSEL_PCLK2) || defined(__DOXYGEN__) #define STM32_DFSDMCLK STM32_PCLK2 #elif STM32_DFSDMSEL == STM32_DFSDMSEL_SYSCLK #define STM32_DFSDMCLK STM32_SYSCLK #else #error "invalid source selected for DFSDM clock" #endif /** * @brief SDMMC frequency. */ #define STM32_SDMMC1CLK STM32_48CLK /** * @brief Clock of timers connected to APB1 */ #if (STM32_PPRE1 == STM32_PPRE1_DIV1) || defined(__DOXYGEN__) #define STM32_TIMCLK1 (STM32_PCLK1 * 1) #else #define STM32_TIMCLK1 (STM32_PCLK1 * 2) #endif /** * @brief Clock of timers connected to APB2. */ #if (STM32_PPRE2 == STM32_PPRE2_DIV1) || defined(__DOXYGEN__) #define STM32_TIMCLK2 (STM32_PCLK2 * 1) #else #define STM32_TIMCLK2 (STM32_PCLK2 * 2) #endif /** * @brief Voltage boost settings. */ #if (STM32_SYSCLK <= STM32_SYSCLK_NOBOOST_MAX) || defined(__DOXYGEN__) #define STM32_R1MODE PWR_CR5_R1MODE #else #define STM32_R1MODE 0 #endif /** * @brief Flash settings. */ #if (STM32_HCLK <= STM32_0WS_THRESHOLD) || defined(__DOXYGEN__) #define STM32_FLASHBITS FLASH_ACR_LATENCY_0WS #elif STM32_HCLK <= STM32_1WS_THRESHOLD #define STM32_FLASHBITS FLASH_ACR_LATENCY_1WS #elif STM32_HCLK <= STM32_2WS_THRESHOLD #define STM32_FLASHBITS FLASH_ACR_LATENCY_2WS #elif STM32_HCLK <= STM32_3WS_THRESHOLD #define STM32_FLASHBITS FLASH_ACR_LATENCY_3WS #else #define STM32_FLASHBITS FLASH_ACR_LATENCY_4WS #endif /** * @brief Flash settings for MSI. */ #if (STM32_MSICLK <= STM32_0WS_THRESHOLD) || defined(__DOXYGEN__) #define STM32_MSI_FLASHBITS FLASH_ACR_LATENCY_0WS #elif STM32_MSICLK <= STM32_1WS_THRESHOLD #define STM32_MSI_FLASHBITS FLASH_ACR_LATENCY_1WS #elif STM32_MSICLK <= STM32_2WS_THRESHOLD #define STM32_MSI_FLASHBITS FLASH_ACR_LATENCY_2WS #elif STM32_MSICLK <= STM32_3WS_THRESHOLD #define STM32_MSI_FLASHBITS FLASH_ACR_LATENCY_3WS #else #define STM32_MSI_FLASHBITS FLASH_ACR_LATENCY_4WS #endif /*===========================================================================*/ /* Driver data structures and types. */ /*===========================================================================*/ /*===========================================================================*/ /* Driver macros. */ /*===========================================================================*/ /*===========================================================================*/ /* External declarations. */ /*===========================================================================*/ /* Various helpers.*/ #include "nvic.h" #include "cache.h" #include "mpu_v7m.h" #include "stm32_isr.h" #include "stm32_dma.h" #include "stm32_rcc.h" #ifdef __cplusplus extern "C" { #endif void hal_lld_init(void); void stm32_clock_init(void); #ifdef __cplusplus } #endif #endif /* HAL_LLD_H */ /** @} */