Updated and Validated
[betaflight.git] / src / main / startup / stm32f3xx_hal_conf.h
blob706948b0d7bde8e505630ba9808a5225d651c20e
1 /**
2 ******************************************************************************
3 * @file stm32f3xx_hal_conf.h
4 * @brief HAL configuration file.
5 ******************************************************************************
6 * @attention
8 * <h2><center>&copy; COPYRIGHT(c) 2016 STMicroelectronics</center></h2>
10 * Redistribution and use in source and binary forms, with or without modification,
11 * are permitted provided that the following conditions are met:
12 * 1. Redistributions of source code must retain the above copyright notice,
13 * this list of conditions and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright notice,
15 * this list of conditions and the following disclaimer in the documentation
16 * and/or other materials provided with the distribution.
17 * 3. Neither the name of STMicroelectronics nor the names of its contributors
18 * may be used to endorse or promote products derived from this software
19 * without specific prior written permission.
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
22 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
24 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
25 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
27 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
28 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
29 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 ******************************************************************************
35 /* Define to prevent recursive inclusion -------------------------------------*/
36 #ifndef __STM32F3xx_HAL_CONF_H
37 #define __STM32F3xx_HAL_CONF_H
39 #ifdef __cplusplus
40 extern "C" {
41 #endif
43 /* Exported types ------------------------------------------------------------*/
44 /* Exported constants --------------------------------------------------------*/
46 /* ########################## Module Selection ############################## */
47 /**
48 * @brief This is the list of modules to be used in the HAL driver
50 #define HAL_MODULE_ENABLED
51 #define HAL_ADC_MODULE_ENABLED
52 //#define HAL_CAN_MODULE_ENABLED
53 //#define HAL_CEC_MODULE_ENABLED
54 //#define HAL_COMP_MODULE_ENABLED
55 #define HAL_CORTEX_MODULE_ENABLED
56 //#define HAL_CRC_MODULE_ENABLED
57 #define HAL_DAC_MODULE_ENABLED
58 #define HAL_DMA_MODULE_ENABLED
59 #define HAL_FLASH_MODULE_ENABLED
60 //#define HAL_SRAM_MODULE_ENABLED
61 //#define HAL_NOR_MODULE_ENABLED
62 //#define HAL_NAND_MODULE_ENABLED
63 //#define HAL_PCCARD_MODULE_ENABLED
64 #define HAL_GPIO_MODULE_ENABLED
65 //#define HAL_HRTIM_MODULE_ENABLED
66 #define HAL_I2C_MODULE_ENABLED
67 //#define HAL_I2S_MODULE_ENABLED
68 //#define HAL_IRDA_MODULE_ENABLED
69 //#define HAL_IWDG_MODULE_ENABLED
70 //#define HAL_OPAMP_MODULE_ENABLED
71 #define HAL_PCD_MODULE_ENABLED
72 #define HAL_PWR_MODULE_ENABLED
73 #define HAL_RCC_MODULE_ENABLED
74 //#define HAL_RTC_MODULE_ENABLED
75 //#define HAL_SDADC_MODULE_ENABLED
76 //#define HAL_SMARTCARD_MODULE_ENABLED
77 //#define HAL_SMBUS_MODULE_ENABLED
78 #define HAL_SPI_MODULE_ENABLED
79 #define HAL_TIM_MODULE_ENABLED
80 //#define HAL_TSC_MODULE_ENABLED
81 #define HAL_UART_MODULE_ENABLED
82 #define HAL_USART_MODULE_ENABLED
83 //#define HAL_WWDG_MODULE_ENABLED
85 /* ########################## HSE/HSI Values adaptation ##################### */
86 /**
87 * @brief Adjust the value of External High Speed oscillator (HSE) used in your application.
88 * This value is used by the RCC HAL module to compute the system frequency
89 * (when HSE is used as system clock source, directly or through the PLL).
91 #if !defined (HSE_VALUE)
92 #define HSE_VALUE ((uint32_t)8000000) /*!< Value of the External oscillator in Hz */
93 #endif /* HSE_VALUE */
95 /**
96 * @brief In the following line adjust the External High Speed oscillator (HSE) Startup
97 * Timeout value
99 #if !defined (HSE_STARTUP_TIMEOUT)
100 #define HSE_STARTUP_TIMEOUT ((uint32_t)100) /*!< Time out for HSE start up, in ms */
101 #endif /* HSE_STARTUP_TIMEOUT */
104 * @brief Internal High Speed oscillator (HSI) value.
105 * This value is used by the RCC HAL module to compute the system frequency
106 * (when HSI is used as system clock source, directly or through the PLL).
108 #if !defined (HSI_VALUE)
109 #define HSI_VALUE ((uint32_t)8000000) /*!< Value of the Internal oscillator in Hz*/
110 #endif /* HSI_VALUE */
113 * @brief In the following line adjust the Internal High Speed oscillator (HSI) Startup
114 * Timeout value
116 #if !defined (HSI_STARTUP_TIMEOUT)
117 #define HSI_STARTUP_TIMEOUT ((uint32_t)5000) /*!< Time out for HSI start up */
118 #endif /* HSI_STARTUP_TIMEOUT */
121 * @brief Internal Low Speed oscillator (LSI) value.
123 #if !defined (LSI_VALUE)
124 #define LSI_VALUE ((uint32_t)40000)
125 #endif /* LSI_VALUE */ /*!< Value of the Internal Low Speed oscillator in Hz
126 The real value may vary depending on the variations
127 in voltage and temperature. */
129 * @brief External Low Speed oscillator (LSE) value.
131 #if !defined (LSE_VALUE)
132 #define LSE_VALUE ((uint32_t)32768) /*!< Value of the External Low Speed oscillator in Hz */
133 #endif /* LSE_VALUE */
136 * @brief Time out for LSE start up value in ms.
138 #if !defined (LSE_STARTUP_TIMEOUT)
139 #define LSE_STARTUP_TIMEOUT ((uint32_t)5000) /*!< Time out for LSE start up, in ms */
140 #endif /* LSE_STARTUP_TIMEOUT */
143 * @brief External clock source for I2S peripheral
144 * This value is used by the I2S HAL module to compute the I2S clock source
145 * frequency, this source is inserted directly through I2S_CKIN pad.
146 * - External clock generated through external PLL component on EVAL 303 (based on MCO or crystal)
147 * - External clock not generated on EVAL 373
149 #if !defined (EXTERNAL_CLOCK_VALUE)
150 #define EXTERNAL_CLOCK_VALUE ((uint32_t)8000000) /*!< Value of the External oscillator in Hz*/
151 #endif /* EXTERNAL_CLOCK_VALUE */
153 /* Tip: To avoid modifying this file each time you need to use different HSE,
154 === you can define the HSE value in your toolchain compiler preprocessor. */
156 /* ########################### System Configuration ######################### */
158 * @brief This is the HAL system configuration section
160 #define VDD_VALUE ((uint32_t)3300) /*!< Value of VDD in mv */
161 #define TICK_INT_PRIORITY ((uint32_t)(1<<__NVIC_PRIO_BITS) - 1) /*!< tick interrupt priority (lowest by default) */
162 #define USE_RTOS 0
163 #define PREFETCH_ENABLE 1
164 #define INSTRUCTION_CACHE_ENABLE 0
165 #define DATA_CACHE_ENABLE 0
167 /* ########################## Assert Selection ############################## */
169 * @brief Uncomment the line below to expanse the "assert_param" macro in the
170 * HAL drivers code
172 /*#define USE_FULL_ASSERT 1*/
174 /* Includes ------------------------------------------------------------------*/
176 * @brief Include module's header file
179 #ifdef HAL_RCC_MODULE_ENABLED
180 #include "stm32f3xx_hal_rcc.h"
181 #endif /* HAL_RCC_MODULE_ENABLED */
183 #ifdef HAL_GPIO_MODULE_ENABLED
184 #include "stm32f3xx_hal_gpio.h"
185 #endif /* HAL_GPIO_MODULE_ENABLED */
187 #ifdef HAL_DMA_MODULE_ENABLED
188 #include "stm32f3xx_hal_dma.h"
189 #endif /* HAL_DMA_MODULE_ENABLED */
191 #ifdef HAL_CORTEX_MODULE_ENABLED
192 #include "stm32f3xx_hal_cortex.h"
193 #endif /* HAL_CORTEX_MODULE_ENABLED */
195 #ifdef HAL_ADC_MODULE_ENABLED
196 #include "stm32f3xx_hal_adc.h"
197 #endif /* HAL_ADC_MODULE_ENABLED */
199 #ifdef HAL_CAN_MODULE_ENABLED
200 #include "stm32f3xx_hal_can.h"
201 #endif /* HAL_CAN_MODULE_ENABLED */
203 #ifdef HAL_CEC_MODULE_ENABLED
204 #include "stm32f3xx_hal_cec.h"
205 #endif /* HAL_CEC_MODULE_ENABLED */
207 #ifdef HAL_COMP_MODULE_ENABLED
208 #include "stm32f3xx_hal_comp.h"
209 #endif /* HAL_COMP_MODULE_ENABLED */
211 #ifdef HAL_CRC_MODULE_ENABLED
212 #include "stm32f3xx_hal_crc.h"
213 #endif /* HAL_CRC_MODULE_ENABLED */
215 #ifdef HAL_DAC_MODULE_ENABLED
216 #include "stm32f3xx_hal_dac.h"
217 #endif /* HAL_DAC_MODULE_ENABLED */
219 #ifdef HAL_FLASH_MODULE_ENABLED
220 #include "stm32f3xx_hal_flash.h"
221 #endif /* HAL_FLASH_MODULE_ENABLED */
223 #ifdef HAL_SRAM_MODULE_ENABLED
224 #include "stm32f3xx_hal_sram.h"
225 #endif /* HAL_SRAM_MODULE_ENABLED */
227 #ifdef HAL_NOR_MODULE_ENABLED
228 #include "stm32f3xx_hal_nor.h"
229 #endif /* HAL_NOR_MODULE_ENABLED */
231 #ifdef HAL_NAND_MODULE_ENABLED
232 #include "stm32f3xx_hal_nand.h"
233 #endif /* HAL_NAND_MODULE_ENABLED */
235 #ifdef HAL_PCCARD_MODULE_ENABLED
236 #include "stm32f3xx_hal_pccard.h"
237 #endif /* HAL_PCCARD_MODULE_ENABLED */
239 #ifdef HAL_HRTIM_MODULE_ENABLED
240 #include "stm32f3xx_hal_hrtim.h"
241 #endif /* HAL_HRTIM_MODULE_ENABLED */
243 #ifdef HAL_I2C_MODULE_ENABLED
244 #include "stm32f3xx_hal_i2c.h"
245 #endif /* HAL_I2C_MODULE_ENABLED */
247 #ifdef HAL_I2S_MODULE_ENABLED
248 #include "stm32f3xx_hal_i2s.h"
249 #endif /* HAL_I2S_MODULE_ENABLED */
251 #ifdef HAL_IRDA_MODULE_ENABLED
252 #include "stm32f3xx_hal_irda.h"
253 #endif /* HAL_IRDA_MODULE_ENABLED */
255 #ifdef HAL_IWDG_MODULE_ENABLED
256 #include "stm32f3xx_hal_iwdg.h"
257 #endif /* HAL_IWDG_MODULE_ENABLED */
259 #ifdef HAL_OPAMP_MODULE_ENABLED
260 #include "stm32f3xx_hal_opamp.h"
261 #endif /* HAL_OPAMP_MODULE_ENABLED */
263 #ifdef HAL_PCD_MODULE_ENABLED
264 #include "stm32f3xx_hal_pcd.h"
265 #endif /* HAL_PCD_MODULE_ENABLED */
267 #ifdef HAL_PWR_MODULE_ENABLED
268 #include "stm32f3xx_hal_pwr.h"
269 #endif /* HAL_PWR_MODULE_ENABLED */
271 #ifdef HAL_RTC_MODULE_ENABLED
272 #include "stm32f3xx_hal_rtc.h"
273 #endif /* HAL_RTC_MODULE_ENABLED */
275 #ifdef HAL_SDADC_MODULE_ENABLED
276 #include "stm32f3xx_hal_sdadc.h"
277 #endif /* HAL_SDADC_MODULE_ENABLED */
279 #ifdef HAL_SMARTCARD_MODULE_ENABLED
280 #include "stm32f3xx_hal_smartcard.h"
281 #endif /* HAL_SMARTCARD_MODULE_ENABLED */
283 #ifdef HAL_SMBUS_MODULE_ENABLED
284 #include "stm32f3xx_hal_smbus.h"
285 #endif /* HAL_SMBUS_MODULE_ENABLED */
287 #ifdef HAL_SPI_MODULE_ENABLED
288 #include "stm32f3xx_hal_spi.h"
289 #endif /* HAL_SPI_MODULE_ENABLED */
291 #ifdef HAL_TIM_MODULE_ENABLED
292 #include "stm32f3xx_hal_tim.h"
293 #endif /* HAL_TIM_MODULE_ENABLED */
295 #ifdef HAL_TSC_MODULE_ENABLED
296 #include "stm32f3xx_hal_tsc.h"
297 #endif /* HAL_TSC_MODULE_ENABLED */
299 #ifdef HAL_UART_MODULE_ENABLED
300 #include "stm32f3xx_hal_uart.h"
301 #endif /* HAL_UART_MODULE_ENABLED */
303 #ifdef HAL_USART_MODULE_ENABLED
304 #include "stm32f3xx_hal_usart.h"
305 #endif /* HAL_USART_MODULE_ENABLED */
307 #ifdef HAL_WWDG_MODULE_ENABLED
308 #include "stm32f3xx_hal_wwdg.h"
309 #endif /* HAL_WWDG_MODULE_ENABLED */
311 /* Exported macro ------------------------------------------------------------*/
312 #ifdef USE_FULL_ASSERT
314 * @brief The assert_param macro is used for function's parameters check.
315 * @param expr: If expr is false, it calls assert_failed function
316 * which reports the name of the source file and the source
317 * line number of the call that failed.
318 * If expr is true, it returns no value.
319 * @retval None
321 #define assert_param(expr) ((expr) ? (void)0U : assert_failed((uint8_t *)__FILE__, __LINE__))
322 /* Exported functions ------------------------------------------------------- */
323 void assert_failed(uint8_t* file, uint32_t line);
324 #else
325 #define assert_param(expr) ((void)0U)
326 #endif /* USE_FULL_ASSERT */
328 #ifdef __cplusplus
330 #endif
332 #endif /* __STM32F3xx_HAL_CONF_H */
335 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/