QuakeGod
2024-11-25 9aed5d7e7b3c7bf09da712e9c272ece401a7acc9
提交 | 用户 | age
9aed5d 1 /**
Q 2   ******************************************************************************
3   * @file    stm32f0xx_hal_conf.h
4   * @brief   HAL configuration file.
5   ******************************************************************************
6   * @attention
7   *
8   * <h2><center>&copy; COPYRIGHT(c) 2018 STMicroelectronics</center></h2>
9   *
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.
20   *
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.
31   *
32   ******************************************************************************
33   */ 
34
35 /* Define to prevent recursive inclusion -------------------------------------*/
36 #ifndef __STM32F0xx_HAL_CONF_H
37 #define __STM32F0xx_HAL_CONF_H
38
39 #ifdef __cplusplus
40  extern "C" {
41 #endif
42
43 #include "main.h"
44 /* Exported types ------------------------------------------------------------*/
45 /* Exported constants --------------------------------------------------------*/
46
47 /* ########################## Module Selection ############################## */
48 /**
49   * @brief This is the list of modules to be used in the HAL driver 
50   */
51 #define HAL_MODULE_ENABLED  
52 /*#define HAL_ADC_MODULE_ENABLED   */
53 /*#define HAL_CRYP_MODULE_ENABLED   */
54 /*#define HAL_CAN_MODULE_ENABLED   */
55 /*#define HAL_CEC_MODULE_ENABLED   */
56 /*#define HAL_COMP_MODULE_ENABLED   */
57 /*#define HAL_CRC_MODULE_ENABLED   */
58 /*#define HAL_CRYP_MODULE_ENABLED   */
59 /*#define HAL_TSC_MODULE_ENABLED   */
60 /*#define HAL_DAC_MODULE_ENABLED   */
61 /*#define HAL_I2S_MODULE_ENABLED   */
62 /*#define HAL_IWDG_MODULE_ENABLED   */
63 /*#define HAL_LCD_MODULE_ENABLED   */
64 /*#define HAL_LPTIM_MODULE_ENABLED   */
65 /*#define HAL_RNG_MODULE_ENABLED   */
66 /*#define HAL_RTC_MODULE_ENABLED   */
67 /*#define HAL_SPI_MODULE_ENABLED   */
68 /*#define HAL_TIM_MODULE_ENABLED   */
69 /*#define HAL_UART_MODULE_ENABLED   */
70 /*#define HAL_USART_MODULE_ENABLED   */
71 /*#define HAL_IRDA_MODULE_ENABLED   */
72 /*#define HAL_SMARTCARD_MODULE_ENABLED   */
73 /*#define HAL_SMBUS_MODULE_ENABLED   */
74 /*#define HAL_WWDG_MODULE_ENABLED   */
75 /*#define HAL_PCD_MODULE_ENABLED   */
76 /*#define HAL_EXTI_MODULE_ENABLED   */
77 #define HAL_CORTEX_MODULE_ENABLED
78 #define HAL_DMA_MODULE_ENABLED
79 #define HAL_FLASH_MODULE_ENABLED
80 #define HAL_GPIO_MODULE_ENABLED
81 #define HAL_PWR_MODULE_ENABLED
82 #define HAL_RCC_MODULE_ENABLED
83 #define HAL_I2C_MODULE_ENABLED
84
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).  
90   */
91 #if !defined  (HSE_VALUE) 
92   #define HSE_VALUE    ((uint32_t)8000000) /*!< Value of the External oscillator in Hz */
93 #endif /* HSE_VALUE */
94
95 /**
96   * @brief In the following line adjust the External High Speed oscillator (HSE) Startup 
97   *        Timeout value 
98   */
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 */
102
103 /**
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). 
107   */
108 #if !defined  (HSI_VALUE)
109   #define HSI_VALUE    ((uint32_t)8000000) /*!< Value of the Internal oscillator in Hz*/
110 #endif /* HSI_VALUE */
111
112 /**
113   * @brief In the following line adjust the Internal High Speed oscillator (HSI) Startup 
114   *        Timeout value 
115   */
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 */  
119
120 /**
121   * @brief Internal High Speed oscillator for ADC (HSI14) value.
122   */
123 #if !defined  (HSI14_VALUE) 
124 #define HSI14_VALUE ((uint32_t)14000000) /*!< Value of the Internal High Speed oscillator for ADC in Hz.
125                                              The real value may vary depending on the variations
126                                              in voltage and temperature.  */
127 #endif /* HSI14_VALUE */
128
129 /**
130   * @brief Internal High Speed oscillator for USB (HSI48) value.
131   */
132 #if !defined  (HSI48_VALUE) 
133 #define HSI48_VALUE ((uint32_t)48000000) /*!< Value of the Internal High Speed oscillator for USB in Hz.
134                                              The real value may vary depending on the variations
135                                              in voltage and temperature.  */
136 #endif /* HSI48_VALUE */
137
138 /**
139   * @brief Internal Low Speed oscillator (LSI) value.
140   */
141 #if !defined  (LSI_VALUE) 
142  #define LSI_VALUE  ((uint32_t)40000)    
143 #endif /* LSI_VALUE */                      /*!< Value of the Internal Low Speed oscillator in Hz
144                                              The real value may vary depending on the variations
145                                              in voltage and temperature.  */
146 /**
147   * @brief External Low Speed oscillator (LSI) value.
148   */
149 #if !defined  (LSE_VALUE)
150  #define LSE_VALUE  ((uint32_t)32768)    /*!< Value of the External Low Speed oscillator in Hz */
151 #endif /* LSE_VALUE */     
152
153 #if !defined  (LSE_STARTUP_TIMEOUT)
154   #define LSE_STARTUP_TIMEOUT    ((uint32_t)5000)   /*!< Time out for LSE start up, in ms */
155 #endif /* LSE_STARTUP_TIMEOUT */
156
157 /* Tip: To avoid modifying this file each time you need to use different HSE,
158    ===  you can define the HSE value in your toolchain compiler preprocessor. */
159
160 /* ########################### System Configuration ######################### */
161 /**
162   * @brief This is the HAL system configuration section
163   */     
164 #define  VDD_VALUE                    ((uint32_t)3300) /*!< Value of VDD in mv */           
165 #define  TICK_INT_PRIORITY            ((uint32_t)0)    /*!< tick interrupt priority (lowest by default)  */            
166                                                                               /*  Warning: Must be set to higher priority for HAL_Delay()  */
167                                                                               /*  and HAL_GetTick() usage under interrupt context          */
168 #define  USE_RTOS                     0     
169 #define  PREFETCH_ENABLE              1              
170 #define  INSTRUCTION_CACHE_ENABLE     0
171 #define  DATA_CACHE_ENABLE            0
172 /* ########################## Assert Selection ############################## */
173 /**
174   * @brief Uncomment the line below to expanse the "assert_param" macro in the 
175   *        HAL drivers code
176   */
177 /* #define USE_FULL_ASSERT   1U */
178
179 /* ################## SPI peripheral configuration ########################## */
180
181 /* CRC FEATURE: Use to activate CRC feature inside HAL SPI Driver
182 * Activated: CRC code is present inside driver
183 * Deactivated: CRC code cleaned from driver
184 */
185
186 #define USE_SPI_CRC                     0U
187
188 /* Includes ------------------------------------------------------------------*/
189 /**
190   * @brief Include module's header file 
191   */
192
193 #ifdef HAL_RCC_MODULE_ENABLED
194  #include "stm32f0xx_hal_rcc.h"
195 #endif /* HAL_RCC_MODULE_ENABLED */
196
197 #ifdef HAL_EXTI_MODULE_ENABLED
198  #include "stm32f0xx_hal_exti.h"
199 #endif /* HAL_EXTI_MODULE_ENABLED */
200
201 #ifdef HAL_GPIO_MODULE_ENABLED
202  #include "stm32f0xx_hal_gpio.h"
203 #endif /* HAL_GPIO_MODULE_ENABLED */
204
205 #ifdef HAL_DMA_MODULE_ENABLED
206   #include "stm32f0xx_hal_dma.h"
207 #endif /* HAL_DMA_MODULE_ENABLED */
208
209 #ifdef HAL_CORTEX_MODULE_ENABLED
210  #include "stm32f0xx_hal_cortex.h"
211 #endif /* HAL_CORTEX_MODULE_ENABLED */
212
213 #ifdef HAL_ADC_MODULE_ENABLED
214  #include "stm32f0xx_hal_adc.h"
215 #endif /* HAL_ADC_MODULE_ENABLED */
216
217 #ifdef HAL_CAN_MODULE_ENABLED
218  #include "stm32f0xx_hal_can.h"
219 #endif /* HAL_CAN_MODULE_ENABLED */
220
221 #ifdef HAL_CEC_MODULE_ENABLED
222  #include "stm32f0xx_hal_cec.h"
223 #endif /* HAL_CEC_MODULE_ENABLED */
224
225 #ifdef HAL_COMP_MODULE_ENABLED
226  #include "stm32f0xx_hal_comp.h"
227 #endif /* HAL_COMP_MODULE_ENABLED */
228
229 #ifdef HAL_CRC_MODULE_ENABLED
230  #include "stm32f0xx_hal_crc.h"
231 #endif /* HAL_CRC_MODULE_ENABLED */
232
233 #ifdef HAL_DAC_MODULE_ENABLED
234  #include "stm32f0xx_hal_dac.h"
235 #endif /* HAL_DAC_MODULE_ENABLED */
236
237 #ifdef HAL_FLASH_MODULE_ENABLED
238  #include "stm32f0xx_hal_flash.h"
239 #endif /* HAL_FLASH_MODULE_ENABLED */
240
241 #ifdef HAL_I2C_MODULE_ENABLED
242  #include "stm32f0xx_hal_i2c.h"
243 #endif /* HAL_I2C_MODULE_ENABLED */
244
245 #ifdef HAL_I2S_MODULE_ENABLED
246  #include "stm32f0xx_hal_i2s.h"
247 #endif /* HAL_I2S_MODULE_ENABLED */
248
249 #ifdef HAL_IRDA_MODULE_ENABLED
250  #include "stm32f0xx_hal_irda.h"
251 #endif /* HAL_IRDA_MODULE_ENABLED */
252
253 #ifdef HAL_IWDG_MODULE_ENABLED
254  #include "stm32f0xx_hal_iwdg.h"
255 #endif /* HAL_IWDG_MODULE_ENABLED */
256
257 #ifdef HAL_PCD_MODULE_ENABLED
258  #include "stm32f0xx_hal_pcd.h"
259 #endif /* HAL_PCD_MODULE_ENABLED */
260
261 #ifdef HAL_PWR_MODULE_ENABLED
262  #include "stm32f0xx_hal_pwr.h"
263 #endif /* HAL_PWR_MODULE_ENABLED */
264
265 #ifdef HAL_RTC_MODULE_ENABLED
266  #include "stm32f0xx_hal_rtc.h"
267 #endif /* HAL_RTC_MODULE_ENABLED */
268
269 #ifdef HAL_SMARTCARD_MODULE_ENABLED
270  #include "stm32f0xx_hal_smartcard.h"
271 #endif /* HAL_SMARTCARD_MODULE_ENABLED */
272
273 #ifdef HAL_SMBUS_MODULE_ENABLED
274  #include "stm32f0xx_hal_smbus.h"
275 #endif /* HAL_SMBUS_MODULE_ENABLED */
276
277 #ifdef HAL_SPI_MODULE_ENABLED
278  #include "stm32f0xx_hal_spi.h"
279 #endif /* HAL_SPI_MODULE_ENABLED */
280
281 #ifdef HAL_TIM_MODULE_ENABLED
282  #include "stm32f0xx_hal_tim.h"
283 #endif /* HAL_TIM_MODULE_ENABLED */
284
285 #ifdef HAL_TSC_MODULE_ENABLED
286  #include "stm32f0xx_hal_tsc.h"
287 #endif /* HAL_TSC_MODULE_ENABLED */
288
289 #ifdef HAL_UART_MODULE_ENABLED
290  #include "stm32f0xx_hal_uart.h"
291 #endif /* HAL_UART_MODULE_ENABLED */
292
293 #ifdef HAL_USART_MODULE_ENABLED
294  #include "stm32f0xx_hal_usart.h"
295 #endif /* HAL_USART_MODULE_ENABLED */
296
297 #ifdef HAL_WWDG_MODULE_ENABLED
298  #include "stm32f0xx_hal_wwdg.h"
299 #endif /* HAL_WWDG_MODULE_ENABLED */
300
301 /* Exported macro ------------------------------------------------------------*/
302 #ifdef  USE_FULL_ASSERT
303 /**
304   * @brief  The assert_param macro is used for function's parameters check.
305   * @param  expr: If expr is false, it calls assert_failed function
306   *         which reports the name of the source file and the source
307   *         line number of the call that failed. 
308   *         If expr is true, it returns no value.
309   * @retval None
310   */
311   #define assert_param(expr) ((expr) ? (void)0U : assert_failed((uint8_t *)__FILE__, __LINE__))
312 /* Exported functions ------------------------------------------------------- */
313   void assert_failed(uint8_t* file, uint32_t line);
314 #else
315   #define assert_param(expr) ((void)0U)
316 #endif /* USE_FULL_ASSERT */    
317     
318 #ifdef __cplusplus
319 }
320 #endif
321
322 #endif /* __STM32F0xx_HAL_CONF_H */
323
324 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/