1 /** 2 ****************************************************************************** 3 * @file stm32u0xx_hal_conf_template.h 4 * @author MCD Application Team 5 * @brief HAL configuration template file. 6 * This file should be copied to the application folder and renamed 7 * to stm32u0xx_hal_conf.h. 8 ****************************************************************************** 9 * @attention 10 * 11 * Copyright (c) 2023 STMicroelectronics. 12 * All rights reserved. 13 * 14 * This software is licensed under terms that can be found in the LICENSE file 15 * in the root directory of this software component. 16 * If no LICENSE file comes with this software, it is provided AS-IS. 17 * 18 ****************************************************************************** 19 */ 20 21 /* Define to prevent recursive inclusion -------------------------------------*/ 22 #ifndef __STM32U0xx_HAL_CONF_H 23 #define __STM32U0xx_HAL_CONF_H 24 25 #ifdef __cplusplus 26 extern "C" { 27 #endif 28 29 /* Exported types ------------------------------------------------------------*/ 30 /* Exported constants --------------------------------------------------------*/ 31 32 /* ########################## Module Selection ############################## */ 33 /** 34 * @brief This is the list of modules to be used in the HAL driver 35 */ 36 #define HAL_MODULE_ENABLED 37 #define HAL_ADC_MODULE_ENABLED 38 #define HAL_COMP_MODULE_ENABLED 39 #define HAL_CRC_MODULE_ENABLED 40 #define HAL_CRS_MODULE_ENABLED 41 #define HAL_CRYP_MODULE_ENABLED 42 #define HAL_DAC_MODULE_ENABLED 43 #define HAL_I2C_MODULE_ENABLED 44 #define HAL_IRDA_MODULE_ENABLED 45 #define HAL_IWDG_MODULE_ENABLED 46 #define HAL_LCD_MODULE_ENABLED 47 #define HAL_OPAMP_MODULE_ENABLED 48 #define HAL_RNG_MODULE_ENABLED 49 #define HAL_RTC_MODULE_ENABLED 50 #define HAL_SPI_MODULE_ENABLED 51 #define HAL_TIM_MODULE_ENABLED 52 #define HAL_LPTIM_MODULE_ENABLED 53 #define HAL_TSC_MODULE_ENABLED 54 #define HAL_UART_MODULE_ENABLED 55 #define HAL_USART_MODULE_ENABLED 56 #define HAL_WWDG_MODULE_ENABLED 57 #define HAL_CORTEX_MODULE_ENABLED 58 #define HAL_EXTI_MODULE_ENABLED 59 #define HAL_FLASH_MODULE_ENABLED 60 #define HAL_GPIO_MODULE_ENABLED 61 #define HAL_PWR_MODULE_ENABLED 62 #define HAL_RCC_MODULE_ENABLED 63 #define HAL_DMA_MODULE_ENABLED 64 #define HAL_SMARTCARD_MODULE_ENABLED 65 #define HAL_PCD_MODULE_ENABLED 66 67 /* ########################## Oscillator Values adaptation ####################*/ 68 /** 69 * @brief Adjust the value of External High Speed oscillator (HSE) used in your application. 70 * This value is used by the RCC HAL module to compute the system frequency 71 * (when HSE is used as system clock source, directly or through the PLL). 72 */ 73 #if !defined (HSE_VALUE) 74 #define HSE_VALUE 32000000U /*!< Value of the External oscillator in Hz */ 75 #endif /* HSE_VALUE */ 76 77 #if !defined (HSE_STARTUP_TIMEOUT) 78 #define HSE_STARTUP_TIMEOUT 5000U /*!< Time out for HSE start up, in ms */ 79 #endif /* HSE_STARTUP_TIMEOUT */ 80 81 /** 82 * @brief Internal Multiple Speed oscillator (MSI) default value. 83 * This value is the default MSI range value after Reset. 84 */ 85 #if !defined (MSI_VALUE) 86 #define MSI_VALUE 4000000U /*!< Value of the Internal oscillator in Hz*/ 87 #endif /* MSI_VALUE */ 88 89 /** 90 * @brief Internal Multiple Speed oscillator (MSI) default value. 91 * This value is the default MSI range value after Reset. 92 */ 93 #if !defined (MSI32_VALUE) 94 #define MSI32_VALUE 32000000U /*!< Value of the Internal oscillator in Hz*/ 95 #endif /* MSI32_VALUE */ 96 97 /** 98 * @brief Internal High Speed oscillator (HSI) value. 99 * This value is used by the RCC HAL module to compute the system frequency 100 * (when HSI is used as system clock source, directly or through the PLL). 101 */ 102 #if !defined (HSI_VALUE) 103 #define HSI_VALUE 16000000U /*!< Value of the Internal oscillator in Hz*/ 104 #endif /* HSI_VALUE */ 105 106 /** 107 * @brief Internal High Speed oscillator (HSI48) value for USB FS and RNG. 108 * This internal oscillator is mainly dedicated to provide a high precision clock to 109 * the USB peripheral by means of a special Clock Recovery System (CRS) circuitry. 110 * When the CRS is not used, the HSI48 RC oscillator runs on it default frequency 111 * which is subject to manufacturing process variations. 112 */ 113 #if !defined (HSI48_VALUE) 114 #define HSI48_VALUE 48000000U /*!< Value of the Internal High Speed oscillator for USB FS/RNG in Hz. 115 The real value my vary depending on manufacturing process variations.*/ 116 #endif /* HSI48_VALUE */ 117 118 /** 119 * @brief Internal Low Speed oscillator (LSI) value. 120 */ 121 #if !defined (LSI_VALUE) 122 #define LSI_VALUE 32000U /*!< LSI Typical Value in Hz*/ 123 #endif /* LSI_VALUE */ /*!< Value of the Internal Low Speed oscillator in Hz 124 The real value may vary depending on the variations in voltage and temperature.*/ 125 126 #if !defined (LSI_STARTUP_TIME) 127 #define LSI_STARTUP_TIME 130U /*!< Time out for LSI start up, in ms */ 128 #endif /* LSI_STARTUP_TIME */ 129 130 /** 131 * @brief External Low Speed oscillator (LSE) value. 132 * This value is used by the UART, RTC HAL module to compute the system frequency 133 */ 134 #if !defined (LSE_VALUE) 135 #define LSE_VALUE 32768U /*!< Value of the External oscillator in Hz*/ 136 #endif /* LSE_VALUE */ 137 138 #if !defined (LSE_STARTUP_TIMEOUT) 139 #define LSE_STARTUP_TIMEOUT 5000U /*!< Time out for LSE start up, in ms */ 140 #endif /* LSE_STARTUP_TIMEOUT */ 141 142 /* Tip: To avoid modifying this file each time you need to use different HSE, 143 === you can define the HSE value in your toolchain compiler preprocessor. */ 144 145 /* ########################### System Configuration ######################### */ 146 /** 147 * @brief This is the HAL system configuration section 148 */ 149 #define VDD_VALUE 3300U /*!< Value of VDD in mv */ 150 #define TICK_INT_PRIORITY ((1U<<__NVIC_PRIO_BITS) - 1U) /*!< tick interrupt priority */ 151 #define USE_RTOS 0U 152 #define PREFETCH_ENABLE 0U 153 #define INSTRUCTION_CACHE_ENABLE 1U 154 155 /* ########################## Assert Selection ############################## */ 156 /** 157 * @brief Uncomment the line below to expanse the "assert_param" macro in the 158 * HAL drivers code 159 */ 160 /* #define USE_FULL_ASSERT 1U */ 161 162 /* ################## Register callback feature configuration ############### */ 163 /** 164 * @brief Set below the peripheral configuration to "1U" to add the support 165 * of HAL callback registration/unregistration feature for the HAL 166 * driver(s). This allows user application to provide specific callback 167 * functions thanks to HAL_PPP_RegisterCallback() rather than overwriting 168 * the default weak callback functions (see each stm32n6xx_hal_ppp.h file 169 * for possible callback identifiers defined in HAL_PPP_CallbackIDTypeDef 170 * for each PPP peripheral). 171 */ 172 #define USE_HAL_ADC_REGISTER_CALLBACKS 0U /* ADC register callback disabled */ 173 #define USE_HAL_CRYP_REGISTER_CALLBACKS 0U /* CRYP register callback disabled */ 174 #define USE_HAL_DAC_REGISTER_CALLBACKS 0U /* DAC register callback disabled */ 175 #define USE_HAL_I2C_REGISTER_CALLBACKS 0U /* I2C register callback disabled */ 176 #define USE_HAL_IWDG_REGISTER_CALLBACKS 0U /* IWDG register callback disabled */ 177 #define USE_HAL_IRDA_REGISTER_CALLBACKS 0U /* IRDA register callback disabled */ 178 #define USE_HAL_LPTIM_REGISTER_CALLBACKS 0U /* LPTIM register callback disabled */ 179 #define USE_HAL_LCD_REGISTER_CALLBACKS 0U /* LCD register callback disabled */ 180 #define USE_HAL_PCD_REGISTER_CALLBACKS 0U /* PCD register callback disabled */ 181 #define USE_HAL_RNG_REGISTER_CALLBACKS 0U /* RNG register callback disabled */ 182 #define USE_HAL_RTC_REGISTER_CALLBACKS 0U /* RTC register callback disabled */ 183 #define USE_HAL_SMARTCARD_REGISTER_CALLBACKS 0U /* SMARTCARD register callback disabled */ 184 #define USE_HAL_SPI_REGISTER_CALLBACKS 0U /* SPI register callback disabled */ 185 #define USE_HAL_TIM_REGISTER_CALLBACKS 0U /* TIM register callback disabled */ 186 #define USE_HAL_UART_REGISTER_CALLBACKS 0U /* UART register callback disabled */ 187 #define USE_HAL_USART_REGISTER_CALLBACKS 0U /* USART register callback disabled */ 188 #define USE_HAL_WWDG_REGISTER_CALLBACKS 0U /* WWDG register callback disabled */ 189 190 /* Includes ------------------------------------------------------------------*/ 191 /** 192 * @brief Include module's header file 193 */ 194 195 #ifdef HAL_RCC_MODULE_ENABLED 196 #include "stm32u0xx_hal_rcc.h" 197 #endif /* HAL_RCC_MODULE_ENABLED */ 198 199 #ifdef HAL_GPIO_MODULE_ENABLED 200 #include "stm32u0xx_hal_gpio.h" 201 #endif /* HAL_GPIO_MODULE_ENABLED */ 202 203 #ifdef HAL_DMA_MODULE_ENABLED 204 #include "stm32u0xx_hal_dma.h" 205 #endif /* HAL_DMA_MODULE_ENABLED */ 206 207 #ifdef HAL_CORTEX_MODULE_ENABLED 208 #include "stm32u0xx_hal_cortex.h" 209 #endif /* HAL_CORTEX_MODULE_ENABLED */ 210 211 #ifdef HAL_ADC_MODULE_ENABLED 212 #include "stm32u0xx_hal_adc.h" 213 #include "stm32u0xx_hal_adc_ex.h" 214 #endif /* HAL_ADC_MODULE_ENABLED */ 215 216 #ifdef HAL_COMP_MODULE_ENABLED 217 #include "stm32u0xx_hal_comp.h" 218 #endif /* HAL_COMP_MODULE_ENABLED */ 219 220 #ifdef HAL_CRC_MODULE_ENABLED 221 #include "stm32u0xx_hal_crc.h" 222 #endif /* HAL_CRC_MODULE_ENABLED */ 223 224 #ifdef HAL_CRS_MODULE_ENABLED 225 #include "stm32u0xx_ll_crs.h" 226 #endif /* HAL_CRS_MODULE_ENABLED */ 227 228 #ifdef HAL_CRYP_MODULE_ENABLED 229 #include "stm32u0xx_hal_cryp.h" 230 #endif /* HAL_CRYP_MODULE_ENABLED */ 231 232 #ifdef HAL_DAC_MODULE_ENABLED 233 #include "stm32u0xx_hal_dac.h" 234 #endif /* HAL_DAC_MODULE_ENABLED */ 235 236 #ifdef HAL_EXTI_MODULE_ENABLED 237 #include "stm32u0xx_hal_exti.h" 238 #endif /* HAL_EXTI_MODULE_ENABLED */ 239 240 #ifdef HAL_FLASH_MODULE_ENABLED 241 #include "stm32u0xx_hal_flash.h" 242 #endif /* HAL_FLASH_MODULE_ENABLED */ 243 244 #ifdef HAL_I2C_MODULE_ENABLED 245 #include "stm32u0xx_hal_i2c.h" 246 #endif /* HAL_I2C_MODULE_ENABLED */ 247 248 #ifdef HAL_IWDG_MODULE_ENABLED 249 #include "stm32u0xx_hal_iwdg.h" 250 #endif /* HAL_IWDG_MODULE_ENABLED */ 251 252 #ifdef HAL_LPTIM_MODULE_ENABLED 253 #include "stm32u0xx_hal_lptim.h" 254 #endif /* HAL_LPTIM_MODULE_ENABLED */ 255 256 #ifdef HAL_LCD_MODULE_ENABLED 257 #include "stm32u0xx_hal_lcd.h" 258 #endif /* HAL_LTDC_MODULE_ENABLED */ 259 260 #ifdef HAL_OPAMP_MODULE_ENABLED 261 #include "stm32u0xx_hal_opamp.h" 262 #endif /* HAL_OPAMP_MODULE_ENABLED */ 263 264 #ifdef HAL_PWR_MODULE_ENABLED 265 #include "stm32u0xx_hal_pwr.h" 266 #endif /* HAL_PWR_MODULE_ENABLED */ 267 268 #ifdef HAL_RNG_MODULE_ENABLED 269 #include "stm32u0xx_hal_rng.h" 270 #endif /* HAL_RNG_MODULE_ENABLED */ 271 272 #ifdef HAL_RTC_MODULE_ENABLED 273 #include "stm32u0xx_hal_rtc.h" 274 #endif /* HAL_RTC_MODULE_ENABLED */ 275 276 #ifdef HAL_SPI_MODULE_ENABLED 277 #include "stm32u0xx_hal_spi.h" 278 #endif /* HAL_SPI_MODULE_ENABLED */ 279 280 #ifdef HAL_TIM_MODULE_ENABLED 281 #include "stm32u0xx_hal_tim.h" 282 #endif /* HAL_TIM_MODULE_ENABLED */ 283 284 #ifdef HAL_TSC_MODULE_ENABLED 285 #include "stm32u0xx_hal_tsc.h" 286 #endif /* HAL_TSC_MODULE_ENABLED */ 287 288 #ifdef HAL_UART_MODULE_ENABLED 289 #include "stm32u0xx_hal_uart.h" 290 #endif /* HAL_UART_MODULE_ENABLED */ 291 292 #ifdef HAL_USART_MODULE_ENABLED 293 #include "stm32u0xx_hal_usart.h" 294 #endif /* HAL_USART_MODULE_ENABLED */ 295 296 #ifdef HAL_IRDA_MODULE_ENABLED 297 #include "stm32u0xx_hal_irda.h" 298 #endif /* HAL_IRDA_MODULE_ENABLED */ 299 300 #ifdef HAL_SMARTCARD_MODULE_ENABLED 301 #include "stm32u0xx_hal_smartcard.h" 302 #endif /* HAL_SMARTCARD_MODULE_ENABLED */ 303 304 #ifdef HAL_WWDG_MODULE_ENABLED 305 #include "stm32u0xx_hal_wwdg.h" 306 #endif /* HAL_WWDG_MODULE_ENABLED */ 307 308 #ifdef HAL_LCD_MODULE_ENABLED 309 #include "stm32u0xx_hal_lcd.h" 310 #endif /* HAL_LCD_MODULE_ENABLED */ 311 312 #ifdef HAL_PCD_MODULE_ENABLED 313 #include "stm32u0xx_hal_pcd.h" 314 #endif /* HAL_PCD_MODULE_ENABLED */ 315 316 /* Exported macro ------------------------------------------------------------*/ 317 #ifdef USE_FULL_ASSERT 318 /** 319 * @brief The assert_param macro is used for function's parameters check. 320 * @param expr: If expr is false, it calls assert_failed function 321 * which reports the name of the source file and the source 322 * line number of the call that failed. 323 * If expr is true, it returns no value. 324 * @retval None 325 */ 326 #define assert_param(expr) ((expr) ? (void)0U : assert_failed((uint8_t *)__FILE__, __LINE__)) 327 /* Exported functions ------------------------------------------------------- */ 328 void assert_failed(uint8_t *file, uint32_t line); 329 #else 330 #define assert_param(expr) ((void)0U) 331 #endif /* USE_FULL_ASSERT */ 332 333 #ifdef __cplusplus 334 } 335 #endif 336 337 #endif /* __STM32U0xx_HAL_CONF_H */ 338